/* ==========================================================================
   Thème global Undercover — sobre & pro, palette issue de l'app Android.
   Variables CSS + clair/sombre. Les pages spécifiques ajoutent leurs propres
   feuilles (home.css, etc.) ; NE PAS surcharger ce fichier depuis les features
   pour éviter les collisions entre agents.
   ========================================================================== */

:root {
    /* Palette app : navy primaire, vert "civil", rouge "undercover" */
    --c-navy: #2D3142;
    --c-navy-600: #3a3f54;
    --c-green: #4A7C59;
    --c-green-300: #A3D4AF;
    --c-red: #BA1A1A;
    --c-red-300: #FFB4AB;

    /* Neutres — mode clair par défaut */
    --bg: #FAFAFC;
    --bg-elev: #FFFFFF;
    --surface: #F1F2F6;
    --border: #E2E3EC;
    --text: #1C1D24;
    --text-muted: #5B5E6E;
    --primary: var(--c-navy);
    --primary-contrast: #FFFFFF;
    --accent: var(--c-green);
    --danger: var(--c-red);
    --accent-contrast: #FFFFFF;
    /* Texte des badges mots civil/undercover : vert assombri en clair pour le contraste AA */
    --word-civil-text: #2F5A3D;
    --word-under-text: var(--c-red);

    --radius: 12px;
    --radius-sm: 8px;
    --shadow: 0 1px 2px rgba(20,21,30,.06), 0 8px 24px rgba(20,21,30,.06);
    --shadow-lg: 0 12px 40px rgba(20,21,30,.12);
    --container: 1120px;
    --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --transition: .22s cubic-bezier(.4,0,.2,1);
}

/* Mode sombre : auto (préférence système) + override explicite via [data-theme] */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --bg: #131316;
        --bg-elev: #1B1B20;
        --surface: #24242C;
        --border: #2F2F38;
        --text: #ECECF1;
        --text-muted: #A4A6B3;
        --primary: #BFC2D4;
        --primary-contrast: #1C1D24;
        /* En sombre, accent vert et rouge danger doivent s'eclaircir pour rester lisibles */
        --accent: var(--c-green-300);
        --danger: var(--c-red-300);
        --accent-contrast: #1C1D24;
        --word-civil-text: var(--c-green-300);
        --word-under-text: var(--c-red-300);
        --shadow: 0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.35);
        --shadow-lg: 0 12px 40px rgba(0,0,0,.5);
    }
}
:root[data-theme="dark"] {
    --bg: #131316;
    --bg-elev: #1B1B20;
    --surface: #24242C;
    --border: #2F2F38;
    --text: #ECECF1;
    --text-muted: #A4A6B3;
    --primary: #BFC2D4;
    --primary-contrast: #1C1D24;
    /* En sombre, accent vert et rouge danger doivent s'eclaircir pour rester lisibles */
    --accent: var(--c-green-300);
    --danger: var(--c-red-300);
    --accent-contrast: #1C1D24;
    --word-civil-text: var(--c-green-300);
    --word-under-text: var(--c-red-300);
    --shadow: 0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.35);
    --shadow-lg: 0 12px 40px rgba(0,0,0,.5);
}

* { box-sizing: border-box; }

/*
 * Garde-fou anti-débordement horizontal global.
 * overflow-x sur html seul (pas body) préserve le position:sticky de la navbar —
 * mettre overflow sur body créerait un nouveau contexte de formatage qui
 * annulerait le sticky.
 */
html { overflow-x: clip; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

h1, h2, h3 { line-height: 1.2; letter-spacing: -.02em; margin: 0 0 .5em; }
h1 { font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 800; }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 700; }
p { margin: 0 0 1rem; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Focus clavier visible et coherent sur tous les elements interactifs (boutons, liens, nav) */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* Lien d'evitement : cache hors focus, apparait en haut a gauche au focus clavier */
.skip-link {
    position: absolute; left: .5rem; top: .5rem; z-index: 200;
    background: var(--bg-elev); color: var(--text);
    border: 1px solid var(--border); border-radius: var(--radius-sm);
    padding: .6rem 1rem; font-weight: 600;
    transform: translateY(-150%); transition: transform var(--transition);
}
.skip-link:focus { transform: translateY(0); text-decoration: none; }

/* Masque visuel mais lisible par les lecteurs d'ecran (utilitaire global) */
.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: 1.25rem; }

/* ---------- Navbar ---------- */
.nav {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in srgb, var(--bg-elev) 86%, transparent);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--border);
    /* Garde-fou : la navbar elle-même ne doit pas déborder */
    overflow: visible;
}
.nav__inner {
    display: flex; align-items: center; gap: 1rem; height: 64px;
    /* Sur mobile, la nav__inner se replie sur 2 lignes (inner + menu déroulant) */
    flex-wrap: wrap;
}
.nav__brand { display: flex; align-items: center; gap: .55rem; font-weight: 800; color: var(--text); font-size: 1.15rem; letter-spacing: -.02em; white-space: nowrap; }
.nav__brand:hover { text-decoration: none; }
.nav__dot { width: 14px; height: 14px; border-radius: 50%; background: var(--c-red); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-red) 22%, transparent); flex-shrink: 0; }

/* Groupe thème + hamburger. Sur desktop, order:3 le place tout à DROITE,
   après les liens (le bouton thème reste ainsi collé au bord droit). */
.nav__end { display: flex; align-items: center; gap: .5rem; order: 3; margin-left: .5rem; }

/* Cloche de notification (demandes de synchronisation reçues) */
.nav__bell {
    position: relative;
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    transition: var(--transition);
}
.nav__bell:hover { background: var(--surface); color: var(--text); text-decoration: none; }
.nav__bell-badge {
    position: absolute; top: 3px; right: 3px;
    min-width: 16px; height: 16px; padding: 0 4px;
    border-radius: 8px;
    background: var(--c-red); color: #fff;
    font-size: .62rem; font-weight: 700; line-height: 1;
    display: flex; align-items: center; justify-content: center;
}

/* Bouton hamburger — visible uniquement sur mobile */
.nav__hamburger {
    display: none; /* masqué par défaut (desktop) */
    align-items: center; justify-content: center;
    flex-direction: column; gap: 5px;
    width: 44px; height: 44px;
    background: transparent; border: 1px solid var(--border);
    border-radius: var(--radius-sm); cursor: pointer;
    transition: var(--transition); padding: 0; color: var(--text);
}
.nav__hamburger:hover { background: var(--surface); }
.nav__hamburger-bar {
    display: block; width: 18px; height: 2px;
    background: currentColor; border-radius: 2px;
    transition: var(--transition);
    transform-origin: center;
}
/* Croix animée quand le menu est ouvert */
.nav__hamburger[aria-expanded="true"] .nav__hamburger-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__hamburger[aria-expanded="true"] .nav__hamburger-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav__hamburger[aria-expanded="true"] .nav__hamburger-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Liste des liens — desktop : inline, poussés à droite (order:2), le bouton
   thème (.nav__end, order:3) venant juste après, au bord droit. */
.nav__links { display: flex; align-items: center; gap: .25rem; order: 2; margin-left: auto; }
.nav__link { color: var(--text-muted); padding: .5rem .8rem; border-radius: var(--radius-sm); font-weight: 600; font-size: .95rem; transition: var(--transition); }
.nav__link:hover { color: var(--text); background: var(--surface); text-decoration: none; }
.nav__link--active { color: var(--text); }

/* ---- Responsive : mobile (< 760px) ---- */
@media (max-width: 759px) {
    /* La hauteur fixe n'est applicable qu'à la première ligne */
    .nav__inner { height: auto; min-height: 64px; align-items: center; padding-top: 0; padding-bottom: 0; }

    /* Le brand occupe la première ligne avec nav__end */
    .nav__brand { height: 64px; /* aligne verticalement dans la ligne marque+boutons */ }

    /* Hamburger visible sur mobile */
    .nav__hamburger { display: flex; }

    /* Sur mobile : thème + hamburger en haut À DROITE (1re ligne), menu en 2e ligne. */
    .nav__end { order: 2; margin-left: auto; }

    /*
     * Menu replié par défaut : on le sort du flux et on le masque.
     * On n'utilise pas display:none pour ne pas briser l'accessibilité du focus
     * sur les éléments internes (la modale notamment).
     * On utilise height:0 + overflow:hidden + visibility:hidden.
     */
    .nav__links {
        order: 3;
        /* Pleine largeur sous la barre de nav */
        flex: 0 0 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        margin-left: 0;
        /* Masquage accessible */
        height: 0;
        overflow: hidden;
        visibility: hidden;
        /* Fond du panneau déroulant */
        background: var(--bg-elev);
        border-top: 0 solid var(--border);
        padding: 0;
        transition: height var(--transition), padding var(--transition), border-top-width var(--transition);
    }

    /* État ouvert : piloté par l'attribut data-nav-open ajouté par le contrôleur */
    .nav__links[data-nav-open] {
        height: auto;
        visibility: visible;
        padding: .5rem 0;
        border-top-width: 1px;
    }

    /* Chaque lien prend toute la largeur et est lisible sur mobile */
    .nav__links .nav__link,
    .nav__links .btn {
        display: block;
        width: 100%;
        text-align: left;
        padding: .85rem 1.25rem;
        border-radius: 0;
        font-size: 1rem;
    }
    .nav__links .btn--primary {
        margin: .5rem 1.25rem;
        width: calc(100% - 2.5rem);
        text-align: center;
        border-radius: var(--radius-sm);
    }

    /* Le span wrappant la modale de déconnexion doit aussi être full-width */
    .nav__links > span[data-controller="modal"] { display: block; }
}

/* ---------- Boutons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    padding: .7rem 1.25rem; border-radius: var(--radius-sm);
    font-weight: 600; font-size: .98rem; cursor: pointer;
    border: 1px solid transparent; transition: var(--transition);
    text-decoration: none; line-height: 1;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn--primary { background: var(--primary); color: var(--primary-contrast); }
.btn--primary:hover { background: color-mix(in srgb, var(--primary) 88%, #000); }
.btn--accent { background: var(--accent); color: var(--accent-contrast); }
.btn--ghost { background: transparent; color: var(--text); border-color: var(--border); }
.btn--ghost:hover { background: var(--surface); }
.btn--lg { padding: .95rem 1.6rem; font-size: 1.05rem; }

/* ---------- Cartes & surfaces ---------- */
.card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 1.5rem; }

/* ---------- Sections ---------- */
.section { padding: clamp(3rem, 8vw, 6rem) 0; }
.muted { color: var(--text-muted); }
.center { text-align: center; }
.lead { font-size: 1.2rem; color: var(--text-muted); max-width: 60ch; }

/* ---------- Badges mots civil/undercover (réutilisable par l'historique) ---------- */
.word { display: inline-block; padding: .2rem .6rem; border-radius: 6px; font-weight: 600; font-size: .9rem; }
.word--civil { background: color-mix(in srgb, var(--c-green) 18%, transparent); color: var(--word-civil-text); }
.word--under { background: color-mix(in srgb, var(--c-red) 16%, transparent); color: var(--word-under-text); }

/* ---------- Formulaires (auth, etc.) ---------- */
.form-row { margin-bottom: 1rem; }
.form-row label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .35rem; }
.form-row input, .form-row select, .form-row textarea {
    width: 100%; padding: .7rem .85rem; border: 1px solid var(--border);
    border-radius: var(--radius-sm); background: var(--bg); color: var(--text); font: inherit;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
    outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}
.form-error { color: var(--danger); font-size: .85rem; margin-top: .3rem; }
.auth-card { max-width: 420px; margin: clamp(2rem,6vw,4rem) auto; }

/* ---------- Alertes flash ---------- */
.flash { padding: .85rem 1.1rem; border-radius: var(--radius-sm); margin-bottom: 1rem; border: 1px solid var(--border); }
.flash--success { background: color-mix(in srgb, var(--c-green) 14%, var(--bg-elev)); border-color: color-mix(in srgb, var(--c-green) 40%, var(--border)); }
.flash--error { background: color-mix(in srgb, var(--c-red) 12%, var(--bg-elev)); border-color: color-mix(in srgb, var(--c-red) 40%, var(--border)); }

/* ---------- Footer ---------- */
.footer { margin-top: auto; border-top: 1px solid var(--border); background: var(--bg-elev); }
.footer__inner { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between; padding: 1.5rem 0; color: var(--text-muted); font-size: .9rem; }

/* ---------- Bouton thème ---------- */
.theme-toggle { background: transparent; border: 1px solid var(--border); color: var(--text); width: 44px; height: 44px; border-radius: var(--radius-sm); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: var(--transition); }
.theme-toggle:hover { background: var(--surface); }

/* ---------- Utilitaires ---------- */
.stack > * + * { margin-top: 1rem; }
.grid { display: grid; gap: 1.5rem; }
@media (min-width: 720px) { .grid--3 { grid-template-columns: repeat(3, 1fr); } .grid--2 { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Modales (élément <dialog> natif) ---------- */
dialog {
    border: none;
    padding: 0;
    background: transparent;
    max-width: 460px;
    width: calc(100% - 2rem);
    color: var(--text);
}
dialog::backdrop {
    background: rgba(10, 11, 15, .55);
    backdrop-filter: blur(2px);
}
.modal__card {
    background: var(--bg-elev);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    padding: 1.5rem;
}
.modal__title { margin: 0 0 .35rem; font-size: 1.2rem; }
.modal__text { color: var(--text-muted); font-size: .95rem; margin-bottom: 1.25rem; }
.modal__actions { display: flex; gap: .5rem; justify-content: flex-end; margin-top: 1.25rem; flex-wrap: wrap; }

/* Respect des préférences de mouvement réduit */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
    [data-aos] { opacity: 1 !important; transform: none !important; }
}
