:root{
  --bg-deep:#0E0D0C; --bg-warm:#171410; --ink:#0A0908;
  --surface:#16130F; --surface-2:#1C1813; --surface-3:#221D17;
  --line:rgba(242,237,228,0.08); --line-2:rgba(242,237,228,0.12);
  --cream:#F4EFE7; --cream-muted:rgba(244,239,231,0.60); --cream-faint:rgba(244,239,231,0.38);
  --gold:#C9A24B; --gold-bright:#E6C77E; --gold-soft:rgba(201,162,75,0.12); --gold-line:rgba(201,162,75,0.26);
  --good:#86C98F; --bad:#E5917A;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --radius:18px; --radius-sm:13px;
  --shadow:0 24px 60px rgba(0,0,0,0.45);
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{
  font-family:var(--sans);font-weight:300;color:var(--cream);background:var(--bg-deep);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;
  min-height:100svh;position:relative;overflow-x:hidden;letter-spacing:0.005em;
}
/* fond chaud + halo doré, comme la vitrine */
body::before{content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(90% 60% at 50% -12%,rgba(201,162,75,0.10) 0%,rgba(201,162,75,0.025) 34%,transparent 60%),
    radial-gradient(70% 50% at 100% 100%,rgba(201,162,75,0.05) 0%,transparent 55%),
    linear-gradient(180deg,var(--bg-warm) 0%,var(--bg-deep) 55%,var(--ink) 100%);}
/* grain fin premium */
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:0.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
a{color:inherit;text-decoration:none;}
::selection{background:var(--gold-soft);color:var(--cream);}
button{font-family:inherit;cursor:pointer;color:inherit;}
.serif{font-family:var(--serif);}

/* scrollbars discrètes */
*{scrollbar-width:thin;scrollbar-color:rgba(244,239,231,0.14) transparent;}
::-webkit-scrollbar{width:9px;height:9px;}
::-webkit-scrollbar-thumb{background:rgba(244,239,231,0.12);border-radius:10px;border:2px solid transparent;background-clip:content-box;}
::-webkit-scrollbar-thumb:hover{background:rgba(244,239,231,0.2);background-clip:content-box;}

/* ---------- BOUTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;border-radius:999px;
  font-size:0.9rem;font-weight:500;letter-spacing:0.01em;padding:13px 26px;position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .4s var(--ease),filter .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease),color .4s var(--ease);}
.btn-gold{color:#1A1410;background:linear-gradient(180deg,#EBCB82,var(--gold));box-shadow:0 10px 26px rgba(201,162,75,0.22),inset 0 1px 0 rgba(255,255,255,0.3);}
.btn-gold::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,0.5),transparent);transform:skewX(-18deg);transition:left .7s var(--ease);}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.04);box-shadow:0 16px 38px rgba(201,162,75,0.34);}
.btn-gold:hover::after{left:130%;}
.btn-gold:active{transform:translateY(0);}
.btn-gold:disabled{opacity:0.55;transform:none;filter:none;cursor:default;box-shadow:none;}
.btn-gold:disabled::after{display:none;}
.btn-ghost{color:var(--cream);background:rgba(244,239,231,0.02);border:1px solid var(--line-2);}
.btn-ghost:hover{border-color:var(--gold-line);color:var(--gold-bright);background:rgba(244,239,231,0.05);}
.btn-block{width:100%;}
.btn-sm{padding:11px 18px;font-size:0.82rem;}

input,textarea,select{font-family:inherit;}
.field{display:block;width:100%;background:rgba(244,239,231,0.035);border:1px solid var(--line-2);border-radius:var(--radius-sm);
  padding:14px 16px;color:var(--cream);font-size:0.95rem;font-weight:300;transition:border-color .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease);}
.field::placeholder{color:var(--cream-faint);}
.field:focus{outline:none;border-color:var(--gold-line);background:rgba(244,239,231,0.06);box-shadow:0 0 0 4px rgba(201,162,75,0.08);}
label.lbl{display:block;font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--cream-muted);margin:0 0 9px 2px;}

/* ---------- CHARGEMENT ---------- */
#loading{min-height:100svh;display:flex;align-items:center;justify-content:center;}
.spin{width:34px;height:34px;border:2px solid var(--line-2);border-top-color:var(--gold);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------- SETUP ---------- */
.setup{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:32px;}
.setup .box{max-width:560px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:44px;box-shadow:var(--shadow);}
.setup h1{font-family:var(--serif);font-weight:600;font-size:2rem;margin-bottom:12px;}
.setup p{color:var(--cream-muted);margin-bottom:14px;font-size:0.96rem;}
.setup code{background:rgba(244,239,231,0.06);border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:0.85em;color:var(--gold-bright);}
.setup ol{margin:8px 0 0 18px;color:var(--cream-muted);}
.setup li{margin-bottom:8px;}

/* ---------- AUTH ---------- */
.auth{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:28px;position:relative;}
.auth::before{content:"";position:absolute;top:8%;left:50%;width:min(640px,120vw);height:420px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(201,162,75,0.16) 0%,transparent 62%);filter:blur(20px);pointer-events:none;}
.auth-card{position:relative;width:100%;max-width:440px;background:linear-gradient(180deg,rgba(28,24,19,0.92),rgba(22,19,15,0.92));
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--line-2);border-radius:24px;padding:44px 36px;box-shadow:var(--shadow);
  animation:rise .8s var(--ease) both;}
@keyframes rise{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}
.auth-brand{text-align:center;font-family:var(--serif);font-weight:600;font-size:2rem;letter-spacing:0.04em;margin-bottom:6px;}
.auth-brand span{color:var(--gold);}
.auth-sub{text-align:center;color:var(--cream-muted);font-size:0.92rem;margin-bottom:30px;}
.tabs{display:flex;background:rgba(244,239,231,0.04);border:1px solid var(--line);border-radius:999px;padding:4px;margin-bottom:26px;}
.tabs button{flex:1;background:none;border:none;color:var(--cream-muted);padding:11px;border-radius:999px;font-size:0.86rem;font-weight:500;transition:background .35s var(--ease),color .35s var(--ease);}
.tabs button.active{background:var(--gold-soft);color:var(--gold-bright);box-shadow:inset 0 0 0 1px var(--gold-line);}
.auth form{display:flex;flex-direction:column;gap:16px;}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;background:rgba(244,239,231,0.03);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 15px;}
.toggle-row .tt{font-size:0.84rem;color:var(--cream-muted);}
.toggle-row .tt b{color:var(--cream);font-weight:500;display:block;font-size:0.92rem;margin-bottom:2px;}
.switch{position:relative;width:46px;height:26px;flex:0 0 auto;}
.switch input{opacity:0;width:0;height:0;}
.switch .slider{position:absolute;inset:0;background:rgba(244,239,231,0.14);border-radius:999px;transition:background .3s var(--ease);}
.switch .slider::before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:var(--cream);border-radius:50%;transition:transform .3s var(--ease);box-shadow:0 2px 5px rgba(0,0,0,0.3);}
.switch input:checked + .slider{background:var(--gold);}
.switch input:checked + .slider::before{transform:translateX(20px);}
.auth-msg{font-size:0.85rem;min-height:1.1em;text-align:center;margin-top:4px;}
.auth-msg.err{color:var(--bad);}
.auth-msg.ok{color:var(--gold-bright);}
.auth-foot{text-align:center;margin-top:22px;font-size:0.82rem;}
.auth-foot a{color:var(--cream-muted);transition:color .3s var(--ease);}
.auth-foot a:hover{color:var(--gold-bright);}

/* ---------- APP SHELL ---------- */
.app{display:none;min-height:100svh;flex-direction:column;}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px clamp(16px,4vw,38px);background:rgba(14,13,12,0.66);-webkit-backdrop-filter:saturate(1.4) blur(18px);backdrop-filter:saturate(1.4) blur(18px);border-bottom:1px solid var(--line);}
.topbar .logo{font-family:var(--serif);font-weight:600;font-size:1.35rem;letter-spacing:0.03em;}
.topbar .logo span{color:var(--gold);}
.tabsnav{display:flex;gap:4px;background:rgba(244,239,231,0.04);border:1px solid var(--line);border-radius:999px;padding:4px;}
.tabsnav button{background:none;border:none;color:var(--cream-muted);font-size:0.84rem;font-weight:500;padding:9px 17px;border-radius:999px;transition:background .3s var(--ease),color .3s var(--ease);}
.tabsnav button.active{background:var(--gold-soft);color:var(--gold-bright);box-shadow:inset 0 0 0 1px var(--gold-line);}
.tabsnav button:hover:not(.active){color:var(--cream);}
.top-right{display:flex;align-items:center;gap:12px;}
.me-pill{display:flex;align-items:center;gap:9px;font-size:0.84rem;color:var(--cream-muted);}
.me-pill .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(180deg,var(--gold-soft),transparent);border:1px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-size:0.95rem;}

.view{display:none;flex:1;min-height:0;}
.view.active{display:flex;animation:viewIn .55s var(--ease);}
@keyframes viewIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.container{width:100%;max-width:1180px;margin:0 auto;padding:clamp(20px,3.5vw,36px);}

/* ---------- CHAT ---------- */
#view-chat{flex-direction:column;}
.chat-layout{display:grid;grid-template-columns:268px 1fr;gap:20px;width:100%;max-width:1200px;margin:0 auto;padding:clamp(16px,3vw,28px);flex:1;min-height:0;}
.rooms{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:16px;height:fit-content;position:sticky;top:90px;}
.rooms h3{font-size:0.68rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--gold);opacity:0.85;margin:6px 10px 14px;}
.room-btn{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;color:var(--cream-muted);text-align:left;padding:12px 13px;border-radius:12px;position:relative;transition:background .25s var(--ease),color .25s var(--ease);}
.room-btn .em{font-size:1.1rem;width:24px;text-align:center;}
.room-btn .nm{font-size:0.92rem;font-weight:500;}
.room-btn:hover{background:rgba(244,239,231,0.04);color:var(--cream);}
.room-btn.active{background:rgba(201,162,75,0.1);color:var(--cream);}
.room-btn.active::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:var(--gold);}
.chat-main{display:flex;flex-direction:column;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);min-height:0;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,0.28);}
.chat-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line);background:rgba(244,239,231,0.015);}
.chat-head .t{font-family:var(--serif);font-size:1.4rem;font-weight:600;letter-spacing:0.01em;}
.chat-head .d{font-size:0.82rem;color:var(--cream-muted);margin-top:1px;}
.online{display:flex;align-items:center;gap:8px;font-size:0.78rem;color:var(--cream-muted);white-space:nowrap;background:rgba(244,239,231,0.04);border:1px solid var(--line);padding:6px 12px;border-radius:999px;}
.online .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 8px rgba(134,201,143,0.9);animation:pulse 2.2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:0.45;}50%{opacity:1;}}
.messages{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:15px;min-height:320px;}
.msg{display:flex;flex-direction:column;gap:4px;max-width:74%;animation:msgIn .35s var(--ease);}
@keyframes msgIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.msg.mine{align-self:flex-end;align-items:flex-end;}
.msg .meta{display:flex;align-items:center;gap:0;font-size:0.72rem;color:var(--cream-faint);padding:0 4px;}
.msg .meta .av{display:inline-flex;width:19px;height:19px;border-radius:50%;align-items:center;justify-content:center;font-size:0.6rem;margin-right:7px;color:#1A1410;font-weight:600;}
.msg .meta .who{color:var(--gold-bright);font-weight:500;}
.msg .bubble{background:rgba(244,239,231,0.05);border:1px solid var(--line-2);padding:11px 15px;border-radius:16px 16px 16px 5px;font-size:0.94rem;font-weight:300;line-height:1.55;word-break:break-word;white-space:pre-wrap;}
.msg.mine .bubble{background:linear-gradient(180deg,rgba(201,162,75,0.26),rgba(201,162,75,0.14));border-color:var(--gold-line);color:var(--cream);border-radius:16px 16px 5px 16px;}
.msg.grouped{margin-top:-10px;}
.msg.grouped .meta{display:none;}
.chat-empty{margin:auto;color:var(--cream-faint);font-size:0.92rem;text-align:center;line-height:1.7;}
/* réactions emoji */
.msg-reacts{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:3px;padding:0 2px;}
.msg.mine .msg-reacts{justify-content:flex-end;}
.react-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(244,239,231,0.05);border:1px solid var(--line-2);border-radius:999px;padding:2px 9px;font-size:0.82rem;color:var(--cream-muted);transition:border-color .25s var(--ease),background .25s var(--ease);}
.react-chip.mine{border-color:var(--gold-line);background:var(--gold-soft);color:var(--gold-bright);}
.react-chip .rc{font-size:0.72rem;}
.react-add{width:24px;height:24px;border-radius:50%;border:1px solid var(--line);background:none;color:var(--cream-faint);font-size:0.82rem;display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);}
.msg:hover .react-add{opacity:1;}
.react-add:hover{color:var(--gold-bright);border-color:var(--gold-line);}
.react-picker{display:none;gap:2px;background:var(--surface-3);border:1px solid var(--line-2);border-radius:999px;padding:3px 7px;}
.react-picker.open{display:inline-flex;}
.react-picker button{background:none;border:none;font-size:1.15rem;padding:1px 3px;line-height:1;transition:transform .2s var(--ease);}
.react-picker button:hover{transform:scale(1.25);}
@media (hover:none){.react-add{opacity:1;}}
.composer{display:flex;gap:11px;padding:15px;border-top:1px solid var(--line);align-items:flex-end;background:rgba(244,239,231,0.015);}
.composer textarea{flex:1;resize:none;height:48px;max-height:140px;border-radius:14px;line-height:1.4;}
.send-btn{flex:0 0 auto;width:48px;height:48px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#1A1410;background:linear-gradient(180deg,#EBCB82,var(--gold));box-shadow:0 6px 18px rgba(201,162,75,0.28),inset 0 1px 0 rgba(255,255,255,0.3);
  transition:transform .3s var(--ease),filter .3s var(--ease);}
.send-btn svg{width:20px;height:20px;}
.send-btn:hover{transform:translateY(-2px) scale(1.04);filter:brightness(1.05);}
.send-btn:active{transform:scale(0.96);}

/* ---------- DASHBOARD ---------- */
.kicker{font-size:0.68rem;letter-spacing:0.26em;text-transform:uppercase;color:var(--gold);opacity:0.85;}
.welcome{font-family:var(--serif);font-size:clamp(2rem,4.4vw,2.9rem);font-weight:500;margin:6px 0 0;letter-spacing:-0.01em;}
.quote-day{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.4vw,1.4rem);color:var(--cream-muted);border-left:2px solid var(--gold-line);padding:2px 0 2px 18px;margin:0 0 26px;max-width:62ch;}

/* avatars en dégradé */
.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#1A1410;font-weight:600;text-transform:uppercase;letter-spacing:0.02em;}

/* en-tête tableau de bord */
.dash-hero{display:flex;align-items:center;gap:18px;margin-bottom:22px;}
.dash-hero-av{width:64px;height:64px;flex:0 0 auto;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;font-weight:600;color:#1A1410;border:1px solid var(--gold-line);box-shadow:0 8px 26px rgba(0,0,0,0.35);}
.dash-hero-txt{min-width:0;}

/* statistiques */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:30px;}
.stat{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 16px;text-align:center;transition:border-color .4s var(--ease),transform .4s var(--ease);}
.stat:hover{border-color:var(--gold-line);transform:translateY(-3px);}
.stat .s-n{display:block;font-family:var(--serif);font-size:1.9rem;font-weight:600;color:var(--gold-bright);line-height:1;}
.stat .s-l{display:block;font-size:0.72rem;letter-spacing:0.06em;color:var(--cream-muted);margin-top:8px;}

/* ancrage 5-4-3-2-1 */
.ground{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:150px;gap:14px;margin-bottom:18px;}
.ground-num{font-family:var(--serif);font-size:3.4rem;font-weight:600;line-height:1;color:transparent;-webkit-text-stroke:1px var(--gold-line);}
.ground-num.active{color:var(--gold-bright);-webkit-text-stroke:0;transition:color .3s var(--ease);}
.ground-txt{color:var(--cream-muted);font-size:0.96rem;max-width:38ch;line-height:1.6;}

/* reveal dashboard */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
.reveal[data-delay="1"]{transition-delay:.08s;}
.reveal[data-delay="2"]{transition-delay:.16s;}
.reveal[data-delay="3"]{transition-delay:.24s;}
.grid{display:grid;grid-template-columns:1.05fr 1fr;gap:20px;}
.card{position:relative;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease);}
.card:hover{border-color:var(--line-2);box-shadow:0 22px 50px rgba(0,0,0,0.3);}
.card.span{grid-column:1 / -1;}
.card .ttl{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.45rem;font-weight:600;margin-bottom:6px;}
.card .sub{color:var(--cream-muted);font-size:0.9rem;margin-bottom:20px;}

/* apparition en cascade des cartes */
#view-dash.active .grid > .card{animation:cardIn .55s var(--ease) both;}
@keyframes cardIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
#view-dash.active .grid > .card:nth-child(1){animation-delay:.04s;}
#view-dash.active .grid > .card:nth-child(2){animation-delay:.1s;}
#view-dash.active .grid > .card:nth-child(3){animation-delay:.16s;}
#view-dash.active .grid > .card:nth-child(4){animation-delay:.22s;}
#view-dash.active .grid > .card:nth-child(5){animation-delay:.28s;}
#view-dash.active .grid > .card:nth-child(6){animation-delay:.34s;}

/* défi */
.challenge{background:linear-gradient(135deg,rgba(201,162,75,0.14),rgba(201,162,75,0.03));border-color:var(--gold-line);overflow:hidden;}
.challenge::after{content:"";position:absolute;top:-40%;right:-10%;width:280px;height:280px;background:radial-gradient(circle,rgba(201,162,75,0.18),transparent 65%);pointer-events:none;}
.challenge .ch-title{font-family:var(--serif);font-size:1.7rem;font-weight:600;margin:12px 0 10px;letter-spacing:-0.01em;}
.challenge .ch-desc{color:var(--cream-muted);font-size:0.96rem;margin-bottom:22px;max-width:60ch;}
.streak{display:flex;align-items:center;gap:8px;font-size:0.88rem;color:var(--cream-muted);margin-top:16px;}
.streak b{color:var(--gold-bright);font-size:1.15rem;}

/* fiche de route */
.rm-progress{height:7px;border-radius:999px;background:rgba(244,239,231,0.08);overflow:hidden;margin-bottom:18px;}
.rm-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .6s var(--ease);box-shadow:0 0 12px rgba(201,162,75,0.5);}
.rm-add{display:flex;gap:8px;margin-bottom:16px;}
.rm-add .btn-ghost{flex:0 0 auto;width:48px;padding:0;font-size:1.3rem;}
.rm-list{display:flex;flex-direction:column;gap:8px;}
.rm-item{display:flex;align-items:center;gap:12px;padding:12px 13px;border:1px solid var(--line);border-radius:12px;background:rgba(244,239,231,0.015);transition:border-color .3s var(--ease),background .3s var(--ease);}
.rm-item:hover{border-color:var(--gold-line);background:rgba(244,239,231,0.04);}
.rm-check{width:23px;height:23px;flex:0 0 auto;border-radius:7px;border:1.5px solid var(--gold-line);background:none;display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:0.8rem;transition:background .25s var(--ease),transform .2s var(--ease);}
.rm-check:hover{transform:scale(1.08);}
.rm-check.done{background:var(--gold);}
.rm-item .rm-txt{flex:1;font-size:0.94rem;}
.rm-item.done .rm-txt{color:var(--cream-faint);text-decoration:line-through;}
.rm-del{background:none;border:none;color:var(--cream-faint);font-size:1.2rem;line-height:1;padding:2px 6px;border-radius:6px;transition:color .25s var(--ease);}
.rm-del:hover{color:var(--bad);}

/* humeur / évolution */
.mood-pick{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
.mood-pick button{flex:1;min-width:52px;background:rgba(244,239,231,0.035);border:1px solid var(--line-2);border-radius:13px;padding:13px 0;font-size:1.5rem;transition:border-color .25s var(--ease),background .25s var(--ease),transform .25s var(--ease);}
.mood-pick button:hover{transform:translateY(-3px);border-color:var(--gold-line);}
.mood-pick button.sel{border-color:var(--gold);background:var(--gold-soft);transform:translateY(-3px);box-shadow:0 8px 20px rgba(201,162,75,0.2);}
.chart{display:flex;align-items:flex-end;gap:7px;height:140px;margin-top:20px;padding-top:12px;border-top:1px solid var(--line);}
.bar{flex:1;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-radius:7px 7px 4px 4px;min-height:8px;opacity:0.92;transition:height .6s var(--ease),opacity .25s var(--ease);}
.bar:hover{opacity:1;filter:brightness(1.1);}
.chart-empty{color:var(--cream-faint);font-size:0.88rem;margin-top:18px;line-height:1.6;}
.avg{font-size:0.86rem;color:var(--cream-muted);margin-top:14px;}
.avg b{color:var(--gold-bright);}

/* respiration */
.breathe{display:flex;align-items:center;justify-content:center;height:210px;margin:6px 0 18px;}
.breathe-orb{width:130px;height:130px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;
  background:radial-gradient(circle at 38% 32%,rgba(230,199,126,0.45),rgba(201,162,75,0.1));
  border:1px solid var(--gold-line);box-shadow:0 0 60px rgba(201,162,75,0.3),inset 0 0 30px rgba(230,199,126,0.15);
  transform:scale(0.55);transition:transform 4s var(--ease);will-change:transform;}
.breathe-orb span{font-size:0.92rem;color:var(--cream);font-weight:400;letter-spacing:0.06em;}

/* badges */
.badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(98px,1fr));gap:11px;}
.badge{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:16px 8px;border:1px solid var(--line);border-radius:14px;background:rgba(244,239,231,0.015);transition:border-color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);}
.badge.earned{border-color:var(--gold-line);background:var(--gold-soft);}
.badge.earned:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,0.3);}
.badge.locked{opacity:0.38;filter:grayscale(0.7);}
.badge .be{font-size:1.8rem;line-height:1;}
.badge .bn{font-size:0.74rem;font-weight:500;color:var(--cream);}
.badge .bd{font-size:0.66rem;color:var(--cream-faint);line-height:1.3;}

/* ---------- FIL DE PUBLICATIONS ---------- */
.post-composer{margin-bottom:22px;}
.post-composer textarea{resize:none;width:100%;margin-bottom:12px;line-height:1.5;}
.post-composer-actions{display:flex;align-items:center;gap:10px;}
.post-composer-actions .btn-gold{margin-left:auto;}
.post-preview{position:relative;width:fit-content;margin:0 0 12px;}
.post-preview img{max-height:180px;max-width:100%;border-radius:12px;display:block;}
.post-preview button{position:absolute;top:8px;right:8px;width:28px;height:28px;border:none;border-radius:50%;background:rgba(11,10,9,0.8);color:var(--cream);font-size:1.1rem;line-height:1;}

#feed-list{display:flex;flex-direction:column;gap:16px;}
.post{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:20px;animation:msgIn .4s var(--ease);}
.post-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.post-av{width:42px;height:42px;flex:0 0 auto;border-radius:50%;font-size:1.05rem;background-size:cover;background-position:center;}
.post-head .who{font-weight:500;color:var(--cream);font-size:0.95rem;}
.post-head .time{font-size:0.74rem;color:var(--cream-faint);}
.post-del{margin-left:auto;background:none;border:none;color:var(--cream-faint);font-size:1.3rem;line-height:1;padding:0 6px;border-radius:6px;transition:color .25s var(--ease);}
.post-del:hover{color:var(--bad);}
.post-body{font-size:0.98rem;line-height:1.6;color:var(--cream);white-space:pre-wrap;word-break:break-word;}
.post-img{margin-top:14px;width:100%;border-radius:14px;display:block;border:1px solid var(--line);}
.post-actions{display:flex;align-items:center;gap:18px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);}
.post-actions button{display:inline-flex;align-items:center;gap:7px;background:none;border:none;color:var(--cream-muted);font-size:0.86rem;font-weight:500;transition:color .25s var(--ease);}
.post-actions button svg{width:19px;height:19px;}
.post-actions button:hover{color:var(--cream);}
.post-like.liked{color:var(--gold-bright);}
.post-like.liked svg{fill:var(--gold-bright);stroke:var(--gold-bright);}
.post-comments{margin-top:14px;display:none;}
.post-comments.open{display:block;}
.cmt-list{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;}
.cmt{display:flex;gap:10px;}
.cmt .cmt-av{width:28px;height:28px;flex:0 0 auto;border-radius:50%;font-size:0.7rem;background-size:cover;background-position:center;}
.cmt .cmt-bub{background:rgba(244,239,231,0.04);border:1px solid var(--line);border-radius:12px;padding:8px 12px;font-size:0.88rem;}
.cmt .cmt-bub .cmt-who{color:var(--gold-bright);font-weight:500;font-size:0.78rem;display:block;margin-bottom:2px;}
.cmt-add{display:flex;gap:8px;}
.cmt-add input{flex:1;border-radius:999px;padding:10px 14px;font-size:0.88rem;}
.cmt-add button{flex:0 0 auto;width:40px;border-radius:50%;border:none;background:linear-gradient(180deg,#EBCB82,var(--gold));color:#1A1410;font-size:1.1rem;}
.feed-empty{text-align:center;color:var(--cream-faint);font-size:0.92rem;padding:40px 0;line-height:1.7;}

/* profil */
.pf-top{display:flex;align-items:center;gap:18px;padding-bottom:22px;margin-bottom:6px;border-bottom:1px solid var(--line);}
.pf-av{width:76px;height:76px;flex:0 0 auto;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.9rem;font-weight:600;color:#1A1410;border:1px solid var(--gold-line);background-size:cover;background-position:center;box-shadow:0 8px 24px rgba(0,0,0,0.35);}
.profile-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);}
.profile-row:last-child{border-bottom:none;}
.profile-row .k{color:var(--cream-muted);font-size:0.9rem;}
.profile-row .v{font-size:0.95rem;}

.me-pill .av,.online .av{font-weight:600;color:#1A1410;}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface-3);border:1px solid var(--gold-line);color:var(--cream);padding:13px 24px;border-radius:999px;font-size:0.88rem;opacity:0;pointer-events:none;transition:opacity .4s var(--ease),transform .4s var(--ease);z-index:50;box-shadow:var(--shadow);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.hint{font-size:0.8rem;color:var(--cream-faint);margin-top:12px;line-height:1.6;}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition-duration:0.01ms !important;}
}

@media (max-width:860px){
  .grid{grid-template-columns:1fr;}
  .chat-layout{grid-template-columns:1fr;}
  .rooms{position:static;display:flex;overflow-x:auto;gap:8px;padding:10px;}
  .rooms h3{display:none;}
  .room-btn{flex:0 0 auto;}
  .room-btn.active::before{display:none;}
  .tabsnav button{padding:8px 12px;font-size:0.8rem;}
  .me-pill .nm{display:none;}
  .topbar{padding:12px 16px;}
}

/* ============================================================
   REFONTE MODERNE — Glass & Glow (futuriste)
============================================================ */
:root{
  --radius:22px; --radius-sm:15px;
  --glass-line:rgba(255,255,255,0.07);
}

/* Fond vivant : halos lumineux qui dérivent lentement */
body::before{
  background:
    radial-gradient(38% 30% at 14% 10%, rgba(201,162,75,0.16), transparent 60%),
    radial-gradient(42% 34% at 88% 6%, rgba(120,160,210,0.09), transparent 60%),
    radial-gradient(50% 42% at 82% 96%, rgba(201,162,75,0.12), transparent 62%),
    radial-gradient(46% 46% at 8% 92%, rgba(160,120,210,0.08), transparent 62%),
    linear-gradient(180deg,#141009 0%,#0E0D0C 55%,#080706 100%);
  background-size:170% 170%;
  background-repeat:no-repeat;
  animation:bgdrift 34s ease-in-out infinite alternate;
}
@keyframes bgdrift{from{background-position:0% 0%;}to{background-position:100% 100%;}}

/* Surfaces en verre dépoli + lueur */
.card,.post,.chat-main,.rooms,.stat,.auth-card,.setup .box,.post-composer{
  background:linear-gradient(180deg,rgba(36,31,24,0.58),rgba(20,17,13,0.5)) !important;
  -webkit-backdrop-filter:blur(20px) saturate(1.35);
  backdrop-filter:blur(20px) saturate(1.35);
  border:1px solid var(--glass-line) !important;
  box-shadow:0 24px 60px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.05);
}
.card.challenge{
  background:linear-gradient(135deg,rgba(201,162,75,0.16),rgba(36,31,24,0.5)) !important;
  border-color:var(--gold-line) !important;
}
.card:hover,.post:hover,.stat:hover{
  box-shadow:0 30px 70px rgba(0,0,0,0.5), 0 0 36px rgba(201,162,75,0.1) !important;
}

/* Barre du haut : verre + lueur */
.topbar{
  background:rgba(14,13,12,0.5) !important;
  -webkit-backdrop-filter:blur(24px) saturate(1.5);
  backdrop-filter:blur(24px) saturate(1.5);
  border-bottom:1px solid var(--glass-line);
  box-shadow:0 1px 0 rgba(255,255,255,0.04), 0 8px 30px rgba(0,0,0,0.3);
}
.tabsnav{background:rgba(255,255,255,0.03);border-color:var(--glass-line);}
.tabsnav button.active{
  box-shadow:inset 0 0 0 1px var(--gold-line), 0 0 20px rgba(201,162,75,0.28);
}

/* Titres en dégradé lumineux */
.welcome{
  background:linear-gradient(180deg,#FBF6EC 0%,#F2EDE4 45%,#E2C074 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* Avatars & éléments lumineux */
.dash-hero-av,.pf-av{box-shadow:0 0 0 1px var(--glass-line), 0 10px 30px rgba(0,0,0,0.4), 0 0 26px rgba(201,162,75,0.18);}
.me-pill .av{box-shadow:0 0 16px rgba(201,162,75,0.25);}

/* Bulles de chat plus douces et lumineuses */
.msg .bubble{border-radius:18px 18px 18px 6px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}
.msg.mine .bubble{border-radius:18px 18px 6px 18px;box-shadow:0 6px 20px rgba(201,162,75,0.14);}

/* Champs plus modernes */
.field{border-radius:14px;background:rgba(255,255,255,0.04);border-color:var(--glass-line);}
.field:focus{box-shadow:0 0 0 4px rgba(201,162,75,0.1), 0 0 22px rgba(201,162,75,0.12);}

/* Boutons dorés : halo lumineux */
.btn-gold,.send-btn{box-shadow:0 10px 30px rgba(201,162,75,0.3), inset 0 1px 0 rgba(255,255,255,0.35);}
.btn-gold:hover{box-shadow:0 16px 44px rgba(201,162,75,0.42), inset 0 1px 0 rgba(255,255,255,0.4);}

/* Salon actif : pastille lumineuse */
.room-btn.active{box-shadow:inset 0 0 0 1px var(--gold-line), 0 0 18px rgba(201,162,75,0.14);}

/* Un peu plus d'air */
.container{padding:clamp(22px,4vw,42px);}
.card{padding:28px;}

/* ============================================================
   ICÔNES (remplacent les emojis)
============================================================ */
.ttl .ic{width:22px;height:22px;color:var(--gold-bright);flex:0 0 auto;}
.streak .ic{width:18px;height:18px;color:var(--gold-bright);}
.room-btn .em{display:inline-flex;align-items:center;justify-content:center;color:var(--gold-bright);width:24px;}
.room-btn .em .ic{width:20px;height:20px;}
.room-btn.active .em{color:var(--gold-bright);}
.chat-head .t{display:flex;align-items:center;gap:9px;}
.chat-head .t .ic{width:21px;height:21px;color:var(--gold-bright);flex:0 0 auto;}
.badge .be{display:inline-flex;align-items:center;justify-content:center;height:30px;}
.badge .be .ic{width:27px;height:27px;color:var(--gold-bright);}
.badge.locked .be .ic{color:var(--cream-muted);}
#post-photo-btn .ic{width:17px;height:17px;}
.mood-pick button{display:flex;align-items:center;justify-content:center;}
.mood-pick button .ic-face{width:30px;height:30px;color:var(--cream-muted);transition:color .25s var(--ease);}
.mood-pick button:hover .ic-face{color:var(--cream);}
.mood-pick button.sel .ic-face{color:var(--gold-bright);}

/* ============================================================
   SYSTÈME DE NIVEAUX
============================================================ */
.level-card{display:flex;align-items:center;gap:24px;
  background:linear-gradient(135deg,rgba(201,162,75,0.14),rgba(36,31,24,0.5)) !important;border-color:var(--gold-line) !important;}
.level-ring{width:88px;height:88px;flex:0 0 auto;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 35% 30%,rgba(230,199,126,0.4),rgba(201,162,75,0.08));
  border:1px solid var(--gold-line);box-shadow:0 0 34px rgba(201,162,75,0.3),inset 0 0 20px rgba(230,199,126,0.15);}
.level-ring span{font-family:var(--serif);font-size:2.3rem;font-weight:600;color:var(--gold-bright);}
.level-info{flex:1;min-width:0;}
.level-title{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--cream);letter-spacing:-0.01em;}
.level-sub{font-size:0.84rem;color:var(--gold-bright);margin:2px 0 12px;letter-spacing:0.04em;}
.lvl-progress{height:8px;border-radius:999px;background:rgba(244,239,231,0.08);overflow:hidden;}
.lvl-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-bright));box-shadow:0 0 14px rgba(201,162,75,0.6);transition:width .8s var(--ease);}
.level-next{font-size:0.78rem;color:var(--cream-muted);margin-top:9px;}
.lvl-chip{font-size:0.68rem;font-weight:600;color:#1A1410;background:linear-gradient(180deg,#EBCB82,var(--gold));padding:3px 9px;border-radius:999px;letter-spacing:0.02em;box-shadow:0 0 14px rgba(201,162,75,0.3);}
@media (max-width:540px){
  .level-card{gap:16px;}
  .level-ring{width:68px;height:68px;}
  .level-ring span{font-size:1.8rem;}
}

/* ============================================================
   CLASSEMENT + RÉCOMPENSES
============================================================ */
.leaderboard{display:flex;flex-direction:column;gap:8px;}
.lb-row{display:flex;align-items:center;gap:13px;padding:10px 13px;border:1px solid var(--line);border-radius:13px;background:rgba(244,239,231,0.015);transition:border-color .3s var(--ease);}
.lb-row.me{border-color:var(--gold-line);background:var(--gold-soft);}
.lb-rank{width:24px;text-align:center;font-family:var(--serif);font-size:1.15rem;font-weight:600;color:var(--cream-muted);flex:0 0 auto;}
.lb-row.top .lb-rank{color:var(--gold-bright);}
.lb-av{width:38px;height:38px;border-radius:50%;flex:0 0 auto;font-size:0.85rem;background-size:cover;background-position:center;}
.lb-name{font-size:0.93rem;font-weight:500;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.lb-lvl{font-size:0.72rem;color:var(--cream-faint);}
.lb-xp{font-size:0.85rem;color:var(--gold-bright);font-weight:600;flex:0 0 auto;}

.rewards{display:flex;flex-direction:column;gap:8px;}
.reward{display:flex;align-items:center;gap:13px;padding:11px 13px;border:1px solid var(--line);border-radius:13px;transition:border-color .3s var(--ease),opacity .3s var(--ease);}
.reward.unlocked{border-color:var(--gold-line);background:var(--gold-soft);}
.reward.locked{opacity:0.5;}
.rw-lvl{width:44px;height:44px;flex:0 0 auto;border-radius:11px;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;color:var(--gold-bright);border:1px solid var(--gold-line);font-size:0.82rem;}
.rw-info{flex:1;min-width:0;}
.rw-name{font-size:0.93rem;font-weight:500;color:var(--cream);}
.rw-desc{font-size:0.78rem;color:var(--cream-muted);}
.rw-state{font-size:0.72rem;flex:0 0 auto;font-weight:500;}
.reward.unlocked .rw-state{color:var(--gold-bright);}
.reward.locked .rw-state{color:var(--cream-faint);}

/* Récompense : halo doré sur l'avatar (niveau 5+) */
.avatar.halo{box-shadow:0 0 0 2px var(--gold), 0 0 20px rgba(201,162,75,0.55) !important;}

/* ============================================================
   CADRES D'AVATAR (paliers jusqu'au niveau 100)
============================================================ */
.avatar{position:relative;}
.fr-2{box-shadow:0 0 0 2px var(--gold), 0 0 16px rgba(201,162,75,0.45) !important;}
.fr-3{box-shadow:0 0 0 2px var(--gold), 0 0 0 5px rgba(201,162,75,0.22) !important;}
.fr-4{box-shadow:0 0 0 2px var(--gold-bright), 0 0 24px rgba(201,162,75,0.6) !important;}
.fr-5{box-shadow:0 0 0 2px #cfe3ee, 0 0 18px rgba(180,210,230,0.5) !important;}
.fr-6{box-shadow:0 0 0 2px #8fd0c0, 0 0 20px rgba(120,200,180,0.5) !important;}
.fr-7::before,.fr-9::before,.fr-10::before,.fr-11::before,.fr-12::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;z-index:-1;}
.fr-7::before{background:conic-gradient(from 0deg,var(--gold),var(--gold-bright),#fff3d6,var(--gold));}
.fr-8{animation:frpulse 2s ease-in-out infinite;}
@keyframes frpulse{0%,100%{box-shadow:0 0 0 2px var(--gold),0 0 10px rgba(201,162,75,0.4);}50%{box-shadow:0 0 0 2px var(--gold-bright),0 0 28px rgba(201,162,75,0.85);}}
.fr-9::before{background:conic-gradient(from 0deg,var(--gold),#fff3d6,var(--gold),#fff3d6,var(--gold));animation:frspin 4s linear infinite;}
.fr-10::before{background:conic-gradient(from 0deg,var(--gold),#8fd0c0,#caa6e0,var(--gold-bright),var(--gold));animation:frspin 6s linear infinite;}
.fr-11::before{background:conic-gradient(from 0deg,#cfe3ee,var(--gold-bright),#caa6e0,#8fd0c0,#cfe3ee);animation:frspin 5s linear infinite;}
.fr-11{box-shadow:0 0 22px rgba(180,200,230,0.5) !important;}
.fr-12::before{inset:-5px;background:conic-gradient(from 0deg,#ffd97a,#fff7e0,#ffce5a,#fff,#ffd97a);animation:frspin 3.2s linear infinite;}
.fr-12{box-shadow:0 0 30px rgba(255,210,110,0.8) !important;}
@keyframes frspin{to{transform:rotate(360deg);}}

.frames{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:16px;}
.frame-item{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;}
.frame-item.locked{opacity:0.4;}
.frame-prev{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#caa45a,#6f5226);color:#1a1410;font-size:1rem;}
.frame-name{font-size:0.74rem;color:var(--cream);font-weight:500;line-height:1.2;}
.frame-lvl{font-size:0.66rem;color:var(--cream-faint);}
.frame-item.active .frame-name{color:var(--gold-bright);}
.frame-item.active .frame-lvl{color:var(--gold-bright);}

/* ============================================================
   ADMINISTRATION
============================================================ */
.admin-list{display:flex;flex-direction:column;gap:8px;}
.admin-row{display:flex;align-items:center;gap:13px;padding:10px 13px;border:1px solid var(--line);border-radius:13px;}
.admin-row.banned{border-color:rgba(229,145,122,0.4);background:rgba(229,145,122,0.06);}
.admin-actions{display:flex;gap:8px;flex:0 0 auto;}
.admin-actions .danger{color:var(--bad);border-color:rgba(229,145,122,0.4);}
.admin-actions .danger:hover{background:rgba(229,145,122,0.1);color:var(--bad);}

/* contrôles de modération sur les messages */
.msg-mod{display:flex;gap:8px;margin-top:4px;opacity:0;transition:opacity .25s var(--ease);}
.msg:hover .msg-mod{opacity:1;}
.mod-btn{background:none;border:1px solid var(--line);color:var(--cream-faint);font-size:0.72rem;padding:3px 9px;border-radius:999px;transition:color .2s var(--ease),border-color .2s var(--ease);}
.mod-btn:hover{color:var(--cream);border-color:var(--gold-line);}
.mod-btn.ban:hover{color:var(--bad);border-color:rgba(229,145,122,0.5);}
@media (hover:none){.msg-mod{opacity:1;}}

/* ============================================================
   MESSAGES PRIVÉS
============================================================ */
.dm-side-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0 4px 12px;}
.dm-side-head h3{font-size:0.68rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--gold);opacity:0.85;margin:0;}
.dm-convo,.dm-pick{align-items:center;}
.dm-cv-av{width:38px;height:38px;flex:0 0 auto;border-radius:50%;font-size:0.85rem;background-size:cover;background-position:center;}
.dm-cv-prev{font-size:0.78rem;color:var(--cream-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dm-pick{gap:11px;}
#dm-messages .msg .meta{font-size:0.7rem;}

/* ============================================================
   NAVIGATION DU BAS (mobile, style app)
============================================================ */
.bottomnav{position:fixed;bottom:0;left:0;right:0;z-index:45;display:none;justify-content:space-around;align-items:flex-end;
  background:rgba(12,11,10,0.82);-webkit-backdrop-filter:blur(22px) saturate(1.4);backdrop-filter:blur(22px) saturate(1.4);
  border-top:1px solid var(--glass-line);padding:9px 4px calc(9px + env(safe-area-inset-bottom));}
.bottomnav button{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--cream-faint);font-size:0.6rem;font-weight:500;letter-spacing:0.01em;padding:3px 6px;flex:1;
  transition:color .25s var(--ease),transform .2s var(--ease);}
.bottomnav button svg{width:23px;height:23px;}
.bottomnav button.active{color:var(--gold-bright);}
.bottomnav button.active svg{filter:drop-shadow(0 0 8px rgba(201,162,75,0.5));}
.bottomnav button:active{transform:scale(0.9);}

@media (max-width:860px){
  .bottomnav{display:flex;}
  .tabsnav{display:none;}
  #app{padding-bottom:calc(74px + env(safe-area-inset-bottom));}
}

/* bouton central + (créer) */
.bottomnav button{position:relative;}
.bn-create{flex:0 0 auto;width:54px;height:54px;border-radius:50%;border:none;margin-top:-20px;
  background:linear-gradient(180deg,#EBCB82,var(--gold));color:#1A1410;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(201,162,75,0.5),inset 0 1px 0 rgba(255,255,255,0.4);transition:transform .2s var(--ease),filter .2s var(--ease);}
.bn-create svg{width:26px;height:26px;}
.bn-create:hover{filter:brightness(1.05);}
.bn-create:active{transform:scale(0.9);}

/* pastille de notification */
.nav-badge{position:absolute;top:-1px;right:22%;background:#E5675A;color:#fff;font-size:0.58rem;font-weight:700;
  min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;
  border:1.5px solid rgba(12,11,10,0.92);box-shadow:0 0 8px rgba(229,103,90,0.6);}
.tabsnav button{position:relative;}
.tabsnav .nav-badge{top:-3px;right:-3px;}

/* ---------- Notifications (cloche + panneau) ---------- */
.notif-wrap{position:relative;display:flex;}
.notif-bell{position:relative;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(244,239,231,0.04);border:1px solid var(--line-2);color:var(--cream-muted);transition:all .25s var(--ease);}
.notif-bell:hover{border-color:var(--gold-line);color:var(--cream);}
.notif-bell svg{width:19px;height:19px;}
.notif-badge{position:absolute;top:-3px;right:-3px;background:#E5675A;color:#fff;font-size:0.58rem;font-weight:700;
  min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;
  border:1.5px solid rgba(12,11,10,0.92);box-shadow:0 0 8px rgba(229,103,90,0.6);}
.notif-panel{position:absolute;top:48px;right:0;width:340px;max-width:88vw;z-index:60;
  background:rgba(20,18,16,0.96);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--line-2);border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,0.55);overflow:hidden;}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line);
  font-family:var(--serif,'Cormorant Garamond',serif);font-size:1.1rem;color:var(--cream);}
.notif-head button{font-size:0.74rem;color:var(--gold-bright);font-weight:500;}
.notif-perm{padding:10px 12px;border-bottom:1px solid var(--line);}
.notif-perm button{width:100%;font-size:0.78rem;color:var(--gold-bright);background:var(--gold-soft);border:1px solid var(--gold-line);
  border-radius:10px;padding:9px 10px;transition:all .2s var(--ease);}
.notif-perm button:hover{background:rgba(201,162,75,0.16);}
.notif-list{max-height:60vh;overflow-y:auto;}
.notif-empty{padding:28px 16px;text-align:center;color:var(--cream-muted);font-size:0.84rem;line-height:1.5;}
.notif-item{display:flex;gap:11px;align-items:flex-start;width:100%;text-align:left;padding:12px 15px;border-bottom:1px solid var(--line);transition:background .2s var(--ease);}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:rgba(244,239,231,0.04);}
.notif-item.unread{background:rgba(201,162,75,0.07);}
.notif-item.unread .notif-body{color:var(--cream);}
.notif-ic{flex:0 0 auto;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(244,239,231,0.05);border:1px solid var(--line-2);color:var(--cream-muted);}
.notif-ic svg{width:16px;height:16px;}
.notif-ic-like{color:#E5675A;border-color:rgba(229,103,90,0.4);background:rgba(229,103,90,0.1);}
.notif-ic-level,.notif-ic-daily{color:var(--gold-bright);border-color:var(--gold-line);background:var(--gold-soft);}
.notif-tx{flex:1;min-width:0;}
.notif-body{font-size:0.83rem;color:var(--cream-muted);line-height:1.4;}
.notif-time{font-size:0.7rem;color:var(--cream-muted);opacity:.6;margin-top:3px;}
@media (max-width:560px){
  .notif-panel{position:fixed;top:58px;right:8px;left:8px;width:auto;max-width:none;}
}

/* consentement inscription */
.consent{display:flex;align-items:flex-start;gap:10px;font-size:0.8rem;color:var(--cream-muted);line-height:1.45;cursor:pointer;}
.consent input{margin-top:2px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--gold);}
.consent a{color:var(--gold-bright);}

/* aperçu média (photo ou vidéo) dans le composer du fil */
#post-preview-media img, #post-preview-media video{max-height:200px;max-width:100%;border-radius:12px;display:block;}
.post-img{margin-top:14px;width:100%;border-radius:14px;display:block;border:1px solid var(--line);background:#000;}
video.post-img{max-height:70vh;}

/* sons d'ambiance */
.sounds{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.snd-btn{background:rgba(244,239,231,0.04);border:1px solid var(--line-2);color:var(--cream-muted);border-radius:999px;padding:9px 16px;font-size:0.85rem;font-weight:500;transition:all .25s var(--ease);}
.snd-btn:hover{border-color:var(--gold-line);color:var(--cream);}
.snd-btn.active{background:var(--gold-soft);border-color:var(--gold);color:var(--gold-bright);box-shadow:0 0 16px rgba(201,162,75,0.25);}
.snd-btn.loading{opacity:.7;position:relative;color:var(--gold-bright);border-color:var(--gold-line);}
.snd-btn.loading::after{content:"";display:inline-block;width:11px;height:11px;margin-left:8px;vertical-align:-1px;border:2px solid rgba(201,162,75,0.35);border-top-color:var(--gold);border-radius:50%;animation:snd-spin .7s linear infinite;}
@keyframes snd-spin{to{transform:rotate(360deg);}}
.snd-vol-row{display:flex;align-items:center;gap:10px;}
.snd-vol{flex:1;accent-color:var(--gold);height:4px;}
.snd-credit{margin-top:12px;font-size:0.72rem;color:var(--cream-muted);opacity:.7;line-height:1.4;}
