/* ════════════════════════════════════════════════════════════════
   LUNI HUNT — Design System commun
   Importé par : Connexion, Mes Groupes, Créer Groupe, Groupe
   ════════════════════════════════════════════════════════════════ */
:root{
  --black:#0E120D; --ink:#15191A;
  --olive:#4A6B36; --olive-2:#5E8246; --olive-deep:#2E4321; --forest:#1B2418;
  --cream:#EFE6D2; --cream-2:#DFD3B6;
  --amber:#D97842; --amber-2:#E89A6A;
  --sky:#9BC2D6; --sky-2:#B9D5E4;
  --wheat:#D9B864; --crimson:#C24632;
  --line: rgba(239,230,210,0.14);
  --line-strong: rgba(239,230,210,0.28);
  --line-amber: rgba(217,120,66,0.35);
  --font-display:"Anton", Impact, sans-serif;
  --font-ui:"Manrope", system-ui, sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, monospace;
  --font-italic:"Cormorant", serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--black);color:var(--cream);font-family:var(--font-ui);font-weight:400;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden;line-height:1.55;min-height:100vh}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,select,textarea{font:inherit;color:inherit;background:none;border:none;outline:none}
::selection{background:var(--amber);color:var(--ink)}
.wrap{max-width:1520px;margin:0 auto;padding:0 40px}
@media (max-width:720px){.wrap{padding:0 18px}}

@keyframes livepulse{50%{box-shadow:0 0 0 8px rgba(217,120,66,.08)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ──── PILL / BANNER / EYEBROW ──── */
.banner{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:var(--cream);color:var(--olive-deep);border:2px solid var(--olive-deep);border-radius:5px;font-family:var(--font-display);font-size:14px;letter-spacing:.08em;text-transform:uppercase;line-height:1;box-shadow:3px 3px 0 0 var(--olive-deep)}
.banner.amber{background:var(--amber);color:var(--ink);border-color:var(--ink);box-shadow:3px 3px 0 0 var(--ink)}
.banner.sky{background:var(--sky);color:var(--olive-deep);border-color:var(--olive-deep);box-shadow:3px 3px 0 0 var(--olive-deep)}
.banner.olive{background:var(--olive);color:var(--cream);border-color:var(--olive-deep);box-shadow:3px 3px 0 0 var(--olive-deep)}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--line-strong);border-radius:999px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);background:rgba(14,18,13,.5)}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(217,120,66,.22);animation:livepulse 1.8s ease-in-out infinite}
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--amber)}
.mono{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}

/* ──── TOPBAR ──── */
.topbar{position:fixed;inset:0 0 auto 0;z-index:60;padding:16px 0;transition:background .35s, padding .35s}
.topbar.scrolled{background:rgba(14,18,13,.86);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:10px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:28px}
.mark{display:flex;align-items:center;gap:14px}
.mark .crest{width:42px;height:42px;border-radius:8px;background:var(--cream);border:2px solid var(--olive-deep);overflow:hidden;box-shadow:2px 2px 0 0 var(--olive-deep)}
.mark .crest img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.mark .word{font-family:var(--font-display);font-size:22px;letter-spacing:.06em;color:var(--cream)}
.mark .word small{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.3em;display:block;color:var(--cream-2);opacity:.65;margin-top:2px;font-weight:400}
.nav ul{list-style:none;display:flex;gap:28px;align-items:center}
.nav ul a{font-size:13px;letter-spacing:.04em;font-weight:500;color:var(--cream);opacity:.78;transition:opacity .2s, color .2s;padding:6px 0}
.nav ul a:hover{opacity:1;color:var(--amber-2)}
.nav ul a.active{opacity:1;color:var(--amber);display:inline-flex;align-items:center;gap:8px}
.nav ul a.active::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(217,120,66,.22);animation:livepulse 1.8s ease-in-out infinite}

/* ──── USER MENU (avatar) ──── */
.user-menu{position:relative}
.user-avatar{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:rgba(14,18,13,.7);border:1px solid var(--line-strong);border-radius:999px;cursor:pointer;transition:border-color .2s}
.user-avatar:hover{border-color:var(--amber)}
.user-avatar img,.user-avatar .ph{width:30px;height:30px;border-radius:50%;background:var(--olive-deep);object-fit:cover;display:grid;place-items:center;color:var(--amber);font-family:var(--font-display);font-size:14px}
.user-avatar .name{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--cream);text-transform:uppercase;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:rgba(14,18,13,.98);border:1px solid var(--line-strong);border-radius:8px;min-width:220px;padding:8px;display:none;box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:100}
.user-dropdown.open{display:block}
.user-dropdown a, .user-dropdown button{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;text-align:left;font-size:13px;color:var(--cream);border-radius:5px;transition:background .15s;letter-spacing:.02em}
.user-dropdown a:hover, .user-dropdown button:hover{background:rgba(217,120,66,.12);color:var(--amber-2)}
.user-dropdown .divider{height:1px;background:var(--line);margin:6px 0}

/* ──── BURGER & DRAWER ──── */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border:1px solid var(--line-strong);border-radius:6px;background:rgba(14,18,13,.6);cursor:pointer;align-items:center;transition:border-color .2s, background .2s;flex-shrink:0}
.burger:hover{border-color:var(--amber);background:rgba(217,120,66,.08)}
.burger span{display:block;width:20px;height:2px;background:var(--cream);transition:transform .25s, opacity .25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);background:linear-gradient(180deg, #15191A, #0e120d);border-left:1px solid var(--line-strong);z-index:200;transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);padding:80px 32px 32px;overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.5)}
.drawer.open{transform:translateX(0)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(7,10,5,.78);backdrop-filter:blur(6px);z-index:199;opacity:0;pointer-events:none;transition:opacity .3s}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer-close{position:absolute;top:22px;right:22px;width:40px;height:40px;border-radius:50%;background:rgba(239,230,210,.08);display:grid;place-items:center;color:var(--cream);font-size:22px;line-height:1;cursor:pointer;border:none;transition:background .2s}
.drawer-close:hover{background:var(--amber);color:var(--ink)}
.drawer-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--amber);margin-bottom:24px;opacity:.85}
.drawer ul{list-style:none;display:flex;flex-direction:column;gap:0;margin:0;padding:0}
.drawer ul li{border-bottom:1px solid var(--line)}
.drawer ul a{display:flex;align-items:center;justify-content:space-between;padding:18px 4px;font-family:var(--font-display);font-size:22px;letter-spacing:.04em;text-transform:uppercase;color:var(--cream);transition:color .2s, padding-left .2s}
.drawer ul a:hover,.drawer ul a.active{color:var(--amber-2);padding-left:8px}
.drawer ul a.active::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(217,120,66,.22);animation:livepulse 1.8s infinite;margin-right:10px}
.drawer ul a .arr{font-family:var(--font-mono);font-size:14px;opacity:.5}
@media (max-width:1100px){ .nav ul{display:none} .burger{display:flex} }
@media (max-width:720px){ .nav .mark .word{font-size:18px} .nav .mark .crest{width:38px;height:38px} .user-avatar .name{display:none} }

/* ──── BUTTONS ──── */
.btn-amber{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--amber);color:var(--ink);padding:14px 24px;font-family:var(--font-display);font-size:16px;letter-spacing:.05em;text-transform:uppercase;border:2px solid var(--ink);box-shadow:3px 3px 0 0 var(--ink);cursor:pointer;transition:transform .15s, box-shadow .15s;border-radius:4px}
.btn-amber:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 0 var(--ink)}
.btn-amber:active{transform:translate(1px,1px);box-shadow:1px 1px 0 0 var(--ink)}
.btn-amber:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line-strong);color:var(--cream);background:transparent;cursor:pointer;border-radius:4px;transition:all .2s}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber-2);background:rgba(217,120,66,.06)}
.btn-cream{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--cream);color:var(--ink);padding:13px 22px;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border-radius:4px;cursor:pointer;border:none;transition:background .2s}
.btn-cream:hover{background:var(--amber);color:var(--ink)}

/* ──── INPUTS ──── */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-2);opacity:.85}
.field input, .field textarea, .field select{width:100%;background:rgba(14,18,13,.7);border:1.5px solid var(--line-strong);padding:13px 16px;font-family:var(--font-ui);font-size:15px;color:var(--cream);border-radius:5px;transition:border-color .2s, background .2s}
.field input:focus, .field textarea:focus, .field select:focus{border-color:var(--amber);background:rgba(14,18,13,1)}
.field textarea{resize:vertical;min-height:90px;line-height:1.5}
.field .hint{font-size:12px;color:var(--cream-2);opacity:.7;margin-top:-2px}

/* ──── CARDS ──── */
.card{border:1px solid var(--line);background:rgba(14,18,13,.55);backdrop-filter:blur(8px);padding:24px;border-radius:6px}
.card-empty{padding:60px 30px;text-align:center;color:var(--cream-2);font-family:var(--font-italic);font-style:italic;opacity:.7;font-size:16px}

/* ──── SECTIONS ──── */
.sec{padding:60px 40px 40px;max-width:1520px;margin:0 auto}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:32px;flex-wrap:wrap}
.sec-head .l{display:flex;flex-direction:column;gap:10px;min-width:0;max-width:100%}
.sec-head h2{font-family:var(--font-display);font-size:clamp(36px,5.5vw,72px);line-height:.9;text-transform:uppercase;color:var(--cream);word-break:break-word}
.sec-head h2 .accent{color:var(--sky);font-family:var(--font-italic);font-style:italic;text-transform:lowercase;font-weight:300}
.sec-head .num{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--amber);text-transform:uppercase}
.sec-head .r{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
@media (max-width:720px){.sec{padding:40px 18px 30px}}

/* ──── LOADING SPINNER ──── */
.loading-full{position:fixed;inset:0;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:9000}
.loading-full .spin{width:40px;height:40px;border:3px solid var(--line-strong);border-top-color:var(--amber);border-radius:50%;animation:spin 1s linear infinite}
.loading-full .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;color:var(--cream-2);text-transform:uppercase}

/* ──── REVEAL ──── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s} .reveal.d2{transition-delay:.14s} .reveal.d3{transition-delay:.22s}
