/* ====================================================================
   JujuLulu — feuille de style
   Thème clair, blanc & bleu, épuré et responsive (mobile first).
   ==================================================================== */

:root {
    --bleu: #2f6df6;
    --bleu-fonce: #1d4ed8;
    --bleu-clair: #eaf1ff;
    --bleu-tres-clair: #f5f8ff;
    --blanc: #ffffff;
    --fond: #f6f8fc;
    --texte: #0f172a;
    --texte-doux: #64748b;
    --texte-leger: #94a3b8;
    --bordure: #e6eaf2;
    --vert: #16a34a;
    --vert-clair: #e9f7ef;
    --rouge: #dc2626;
    --rouge-clair: #fdecec;
    --orange: #d97706;
    --orange-clair: #fef3e2;
    --ombre: 0 1px 2px rgba(15, 23, 42, .04), 0 4px 16px rgba(15, 23, 42, .05);
    --ombre-forte: 0 8px 30px rgba(47, 109, 246, .15);
    --rayon: 16px;
    --rayon-petit: 10px;
    --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
    --sans: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--sans);
    background: var(--fond);
    color: var(--texte);
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3 {
    font-family: var(--serif);
    font-weight: 600;
    letter-spacing: -.01em;
    margin: 0;
}

h1 { font-size: 1.9rem; }
h2 { font-size: 1.3rem; }

a { color: var(--bleu); text-decoration: none; }

/* ---------- En-tête ---------- */
.entete {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .75rem 1.25rem;
    background: rgba(255, 255, 255, .85);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--bordure);
}

.marque { display: flex; align-items: center; gap: .6rem; color: var(--texte); }

.marque__logo {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--bleu), #6aa0ff);
    color: #fff;
    font-family: var(--serif);
    font-weight: 700;
    font-size: 1.1rem;
    box-shadow: var(--ombre-forte);
}

.marque__logo--grand { width: 56px; height: 56px; font-size: 1.7rem; border-radius: 16px; }

.marque__nom {
    font-family: var(--serif);
    font-weight: 700;
    font-style: italic;
    letter-spacing: .02em;
    font-size: 1.1rem;
}

.entete__nav { display: none; gap: .25rem; margin-left: 1rem; }

.entete__nav a {
    padding: .45rem .8rem;
    border-radius: 999px;
    color: var(--texte-doux);
    font-weight: 500;
    font-size: .95rem;
}

.entete__nav a:hover { background: var(--bleu-tres-clair); color: var(--bleu); }
.entete__nav a.actif { background: var(--bleu-clair); color: var(--bleu-fonce); }

.entete__droite { margin-left: auto; display: flex; align-items: center; gap: .75rem; }
.entete__user { color: var(--texte-doux); font-weight: 500; font-size: .9rem; }
.entete__deconnexion {
    color: var(--texte-doux);
    font-size: .85rem;
    font-weight: 600;
    padding: .35rem .7rem;
    border-radius: 999px;
    border: 1px solid var(--bordure);
}
.entete__deconnexion:hover { border-color: var(--rouge); color: var(--rouge); }

/* ---------- Contenu ---------- */
.contenu {
    max-width: 1000px;
    margin: 0 auto;
    padding: 1.25rem 1.25rem 6rem;
}
.contenu--plein { max-width: 460px; padding-top: 8vh; }

.page-entete { margin-bottom: 1.5rem; }
.page-entete p { color: var(--texte-doux); margin: .25rem 0 0; }

/* ---------- Barre d'onglets (mobile) ---------- */
.onglets {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 60;
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: .4rem .5rem calc(.4rem + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(12px);
    border-top: 1px solid var(--bordure);
}

.onglets__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    color: var(--texte-leger);
    font-size: .68rem;
    font-weight: 600;
    padding: .3rem .5rem;
    flex: 1;
}
.onglets__item svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.onglets__item.actif { color: var(--bleu); }

.onglets__plus svg {
    width: 30px; height: 30px;
    background: var(--bleu);
    color: #fff;
    border-radius: 12px;
    padding: 5px;
    box-shadow: var(--ombre-forte);
}
.onglets__plus { color: var(--bleu); }

/* ---------- Cartes ---------- */
.carte {
    background: var(--blanc);
    border: 1px solid var(--bordure);
    border-radius: var(--rayon);
    padding: 1.25rem;
    box-shadow: var(--ombre);
}
.carte + .carte { margin-top: 1rem; }
.carte__titre { font-size: 1.05rem; margin-bottom: 1rem; display: flex; align-items: center; justify-content: space-between; }

/* ---------- Grille d'indicateurs ---------- */
.grille-indic {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .9rem;
    margin-bottom: 1.25rem;
}
@media (min-width: 720px) { .grille-indic { grid-template-columns: repeat(4, 1fr); } }

.indic {
    background: var(--blanc);
    border: 1px solid var(--bordure);
    border-radius: var(--rayon);
    padding: 1rem 1.1rem;
    box-shadow: var(--ombre);
}
.indic--accent { background: linear-gradient(160deg, #fff, var(--bleu-tres-clair)); border-color: #d8e4ff; }
.indic__label { color: var(--texte-doux); font-size: .8rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.indic__valeur { font-family: var(--serif); font-size: 1.7rem; font-weight: 700; margin-top: .35rem; }
.indic__valeur.vert { color: var(--vert); }
.indic__valeur.rouge { color: var(--rouge); }
.indic__valeur.orange { color: var(--orange); }
.indic__detail { color: var(--texte-leger); font-size: .8rem; margin-top: .15rem; }

/* ---------- Graphiques ---------- */
.graphique { position: relative; height: 280px; }

/* ---------- Répartition par marque ---------- */
.marque-ligne { display: flex; align-items: center; gap: .75rem; padding: .5rem 0; }
.marque-ligne__nom { width: 110px; font-weight: 500; font-size: .92rem; flex-shrink: 0; }
.marque-ligne__barre { flex: 1; height: 8px; background: var(--fond); border-radius: 999px; overflow: hidden; }
.marque-ligne__remplissage { height: 100%; background: linear-gradient(90deg, var(--bleu), #6aa0ff); border-radius: 999px; }
.marque-ligne__pct { width: 42px; text-align: right; color: var(--texte-doux); font-weight: 600; font-size: .9rem; }

/* ---------- Listes d'articles ---------- */
.groupe-mois { margin-top: 1.25rem; }
.groupe-mois__entete {
    display: flex; align-items: baseline; justify-content: space-between;
    padding: 0 .25rem .5rem;
}
.groupe-mois__titre { font-family: var(--serif); font-size: 1.25rem; }
.groupe-mois__titre span { color: var(--texte-leger); font-family: var(--sans); font-size: .85rem; font-weight: 500; margin-left: .5rem; }
.groupe-mois__valeur { color: var(--texte-doux); font-weight: 600; }

.article {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: .85rem 1rem;
    background: var(--blanc);
    border: 1px solid var(--bordure);
    border-radius: var(--rayon-petit);
    margin-bottom: .55rem;
}
.article__photo {
    width: 46px; height: 46px; border-radius: 10px; object-fit: cover;
    background: var(--fond); flex-shrink: 0;
    display: grid; place-items: center; color: var(--texte-leger);
}
.article__info { flex: 1; min-width: 0; }
.article__titre { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.article__meta { color: var(--texte-doux); font-size: .85rem; }
.article__droite { text-align: right; flex-shrink: 0; }
.article__prix { font-weight: 700; }

/* ---------- Pastilles statut / âge ---------- */
.pastille {
    display: inline-block;
    padding: .2rem .55rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .02em;
}
.pastille--vert { background: var(--vert-clair); color: var(--vert); }
.pastille--bleu { background: var(--bleu-clair); color: var(--bleu-fonce); }
.pastille--jaune { background: var(--orange-clair); color: var(--orange); }
.pastille--gris { background: #eef1f6; color: var(--texte-doux); }
.pastille--age { background: #eef1f6; color: var(--texte-doux); }
.pastille--age.alerte { background: var(--orange-clair); color: var(--orange); }

/* ---------- Boutons ---------- */
.bouton {
    display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
    padding: .7rem 1.2rem;
    border-radius: 999px;
    border: 1px solid var(--bordure);
    background: var(--blanc);
    color: var(--texte);
    font-family: var(--sans);
    font-weight: 600;
    font-size: .95rem;
    cursor: pointer;
    transition: transform .05s ease, box-shadow .15s ease;
}
.bouton:hover { box-shadow: var(--ombre); }
.bouton:active { transform: translateY(1px); }
.bouton--principal { background: var(--bleu); border-color: var(--bleu); color: #fff; box-shadow: var(--ombre-forte); }
.bouton--principal:hover { background: var(--bleu-fonce); }
.bouton--bloc { width: 100%; }
.bouton--danger { color: var(--rouge); border-color: var(--rouge-clair); background: var(--rouge-clair); }
.bouton--petit { padding: .35rem .7rem; font-size: .82rem; }
.bouton--vert { background: var(--vert); border-color: var(--vert); color: #fff; }

.barre-actions { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: 1.25rem; }

/* ---------- Formulaires ---------- */
.formulaire > div { margin-bottom: 1rem; }
.formulaire label {
    display: block;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--texte-doux);
    margin-bottom: .4rem;
}
.formulaire input[type="text"],
.formulaire input[type="email"],
.formulaire input[type="password"],
.formulaire input[type="url"],
.formulaire input[type="number"],
.formulaire input[type="date"],
.formulaire input[type="file"],
.formulaire select,
.formulaire textarea {
    width: 100%;
    padding: .8rem .9rem;
    border: 1px solid var(--bordure);
    border-radius: var(--rayon-petit);
    background: var(--blanc);
    font-family: var(--sans);
    font-size: 1rem;
    color: var(--texte);
}
.formulaire input:focus,
.formulaire select:focus,
.formulaire textarea:focus {
    outline: none;
    border-color: var(--bleu);
    box-shadow: 0 0 0 3px var(--bleu-clair);
}
.formulaire textarea { resize: vertical; min-height: 80px; }

/* MoneyType : symbole € aligné dans le champ */
.formulaire .input-group,
.formulaire .form-money-widget { display: flex; align-items: center; }

/* Checkbox / radios */
.formulaire input[type="checkbox"],
.formulaire input[type="radio"] { width: auto; margin-right: .5rem; accent-color: var(--bleu); transform: scale(1.15); }
.formulaire .radio label,
.formulaire .checkbox label { text-transform: none; letter-spacing: 0; font-weight: 500; color: var(--texte); display: inline-flex; align-items: center; }

.formulaire .help-text, .formulaire small { color: var(--texte-leger); font-size: .82rem; }

.form-erreurs, .formulaire ul { color: var(--rouge); font-size: .85rem; list-style: none; padding: 0; margin: .3rem 0 0; }

.formulaire__actions { display: flex; gap: .75rem; margin-top: 1.5rem; }

/* ---------- Flash ---------- */
.flash {
    padding: .85rem 1.1rem;
    border-radius: var(--rayon-petit);
    margin-bottom: 1rem;
    font-weight: 500;
    font-size: .95rem;
}
.flash--succes { background: var(--vert-clair); color: var(--vert); }
.flash--erreur { background: var(--rouge-clair); color: var(--rouge); }
.flash--info { background: var(--bleu-clair); color: var(--bleu-fonce); }

/* ---------- Tableaux ---------- */
.tableau { width: 100%; border-collapse: collapse; }
.tableau th { text-align: left; color: var(--texte-doux); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; padding: .6rem .5rem; border-bottom: 1px solid var(--bordure); }
.tableau td { padding: .75rem .5rem; border-bottom: 1px solid var(--bordure); }
.tableau tr:last-child td { border-bottom: none; }
.montant-credit { color: var(--vert); font-weight: 700; }
.montant-debit { color: var(--rouge); font-weight: 700; }

/* ---------- Login ---------- */
.login { display: grid; place-items: center; }
.login__carte { width: 100%; background: var(--blanc); border: 1px solid var(--bordure); border-radius: 24px; padding: 2rem; box-shadow: var(--ombre); }
.login__entete { text-align: center; margin-bottom: 1.5rem; }
.login__entete .marque__logo--grand { margin: 0 auto .8rem; }
.login__titre { font-style: italic; }
.login__sous { color: var(--texte-doux); margin: .25rem 0 0; }
.login__memoire { display: flex; align-items: center; font-size: .9rem; color: var(--texte-doux); margin-bottom: 1rem; }
.login__memoire input { width: auto; margin-right: .5rem; accent-color: var(--bleu); }

/* ---------- Recherche & filtres ---------- */
.filtres { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.filtres input[type="search"], .filtres select {
    padding: .7rem .9rem; border: 1px solid var(--bordure); border-radius: var(--rayon-petit);
    background: var(--blanc); font-family: var(--sans); font-size: .95rem; flex: 1; min-width: 140px;
}

.vide { text-align: center; color: var(--texte-doux); padding: 2.5rem 1rem; }
.vide svg { width: 48px; height: 48px; stroke: var(--texte-leger); fill: none; stroke-width: 1.5; margin-bottom: .5rem; }

.profit-positif { color: var(--vert); font-weight: 700; }
.profit-negatif { color: var(--rouge); font-weight: 700; }

/* ====================================================================
   Module Études de Marché
   ==================================================================== */

/* -- Grille de dossiers -- */
.etudes-grille {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
}

.etude-carte {
    display: flex;
    flex-direction: column;
    background: var(--blanc);
    border: 1.5px solid var(--bordure);
    border-radius: var(--rayon);
    box-shadow: var(--ombre);
    overflow: hidden;
    text-decoration: none;
    color: var(--texte);
    transition: box-shadow .15s, transform .15s;
}
.etude-carte:hover { box-shadow: var(--ombre-forte); transform: translateY(-2px); }

.etude-carte--chaud { border-color: #86efac; background: linear-gradient(160deg, #fff, #f0fdf4); }
.etude-carte--froid { border-color: #fca5a5; background: linear-gradient(160deg, #fff, #fff5f5); }

.etude-carte__couverture {
    height: 140px;
    background: var(--fond);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.etude-carte__couverture img { width: 100%; height: 100%; object-fit: cover; }
.etude-carte__emoji { font-size: 3rem; }

.etude-carte__corps { padding: .9rem 1rem 1rem; flex: 1; }
.etude-carte__top { display: flex; align-items: center; justify-content: space-between; gap: .5rem; margin-bottom: .4rem; }
.etude-carte__nom { font-weight: 700; font-size: 1rem; flex: 1; }

.etude-carte__stats {
    display: flex;
    gap: .6rem;
    margin-top: .6rem;
    flex-wrap: wrap;
}
.etude-carte__stat { text-align: center; }
.etude-carte__stat-val { display: block; font-family: var(--serif); font-size: 1.15rem; font-weight: 700; line-height: 1.1; }
.etude-carte__stat-lab { display: block; font-size: .72rem; color: var(--texte-doux); text-transform: uppercase; letter-spacing: .04em; }
.etude-carte__stat.vert .etude-carte__stat-val { color: var(--vert); }
.etude-carte__stat.rouge .etude-carte__stat-val { color: var(--rouge); }
.etude-carte__stat.orange .etude-carte__stat-val { color: var(--orange); }

.etude-carte__delai { color: var(--texte-doux); font-size: .8rem; margin-top: .5rem; }

/* -- Étoiles -- */
.etoiles { font-size: 1.05rem; letter-spacing: .05em; }
.etoile--pleine { color: #f59e0b; }
.etoile--vide { color: #d1d5db; }

/* -- Layout page de détail -- */
.etude-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 800px) {
    .etude-layout { grid-template-columns: 280px 1fr; align-items: start; }
}

.etude-prix-ligne {
    display: flex;
    gap: 1.25rem;
    flex-wrap: wrap;
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--bordure);
}

/* -- Zone de dépôt -- */
.zone-depot {
    border: 2px dashed var(--bleu-clair);
    border-radius: var(--rayon);
    background: var(--bleu-tres-clair);
    cursor: pointer;
    margin-bottom: 1rem;
    transition: background .15s, border-color .15s;
}
.zone-depot--actif {
    border-color: var(--bleu);
    background: #e0ecff;
}
.zone-depot__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    padding: 1.75rem 1rem;
    color: var(--bleu);
    text-align: center;
}
.zone-depot__inner p { margin: 0; font-weight: 600; }
.zone-depot__inner small { color: var(--texte-doux); font-weight: 400; }
.zone-depot__progress { text-align: center; padding: .75rem 1rem; color: var(--bleu); font-size: .9rem; }

/* -- Grille d'articles -- */
.articles-grille {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: .85rem;
}

.article-etude {
    background: var(--blanc);
    border: 1.5px solid var(--bordure);
    border-radius: var(--rayon-petit);
    overflow: hidden;
    box-shadow: var(--ombre);
    display: flex;
    flex-direction: column;
}
.article-etude--vendu { opacity: .75; }

.article-etude__photo-wrap {
    position: relative;
    height: 160px;
    background: var(--fond);
}
.article-etude__photo-wrap--vide {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
}
.article-etude__photo { width: 100%; height: 100%; object-fit: cover; display: block; }
.article-etude__badge-vendu {
    position: absolute;
    top: .4rem;
    right: .4rem;
    background: var(--vert);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    padding: .2rem .5rem;
    border-radius: 6px;
}

.article-etude__corps { padding: .6rem .75rem .75rem; flex: 1; display: flex; flex-direction: column; gap: .35rem; }
.article-etude__ligne { display: flex; align-items: center; justify-content: space-between; gap: .35rem; }
.article-etude__prix { font-family: var(--serif); font-size: 1.05rem; font-weight: 700; }
.article-etude__meta { color: var(--texte-doux); font-size: .78rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.article-etude__delai { font-size: .78rem; color: var(--vert); font-weight: 600; }
.article-etude__notes { font-size: .8rem; color: var(--texte-doux); margin: 0; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.article-etude__actions { display: flex; gap: .3rem; flex-wrap: wrap; margin-top: auto; padding-top: .35rem; }
.article-etude__form-vente { padding: .6rem .75rem .75rem; border-top: 1px solid var(--bordure); background: var(--fond); }

/* ---------- Desktop : nav en haut, plus de barre d'onglets ---------- */
@media (min-width: 900px) {
    .entete__nav { display: flex; }
    .onglets { display: none; }
    .contenu { padding-bottom: 2.5rem; }
}
