:root{
  --bg:#0F1419; --bg2:#161B22; --bg3:#1d2530; --border:rgba(212,165,116,.10);
  --br-hover:rgba(212,165,116,.22); --acc:#D4A574; --acc-d:#a87f4e; --acc-l:#e8c79a;
  --text:#E8DFC9; --text-mid:#C4B89D; --muted:#8A7F6A;
  --green:#7FB069; --red:#D67878; --blue:#7FAEC8;
  --shadow:0 8px 32px rgba(0,0,0,.35);
  --r:14px; --r-s:8px;
  --ff-body:'Inter',system-ui,-apple-system,sans-serif;
  --ff-title:'Cormorant Garamond',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--ff-body);background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;background-image:radial-gradient(ellipse at 25% 35%,rgba(212,165,116,.04) 0%,transparent 55%),radial-gradient(ellipse at 78% 75%,rgba(127,174,200,.025) 0%,transparent 50%)}
a{color:var(--acc-l);text-decoration:none}
a:hover{color:var(--acc)}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:15px;color:var(--text);background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-s);padding:12px 14px;width:100%;transition:border .2s,background .2s}
input:focus,textarea:focus{outline:none;border-color:var(--acc);background:rgba(255,255,255,.05)}
textarea{resize:vertical;min-height:90px;font-family:var(--ff-body)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:var(--r-s);font-weight:600;font-size:15px;transition:all .2s;letter-spacing:.01em}
.btn-primary{background:linear-gradient(135deg,var(--acc-d),var(--acc));color:#0c0f12;box-shadow:0 4px 14px rgba(212,165,116,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,165,116,.4)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{border-color:var(--acc);color:var(--acc-l)}
.btn-soft{background:var(--bg3);color:var(--text)}
.btn-soft:hover{background:var(--bg2)}
.title-serif{font-family:var(--ff-title);font-weight:600;letter-spacing:-.01em}
.muted{color:var(--muted);font-size:14px}
.error{color:var(--red);background:rgba(214,120,120,.08);padding:10px 14px;border-radius:var(--r-s);font-size:14px;border:1px solid rgba(214,120,120,.2)}
.success{color:var(--green);background:rgba(127,176,105,.08);padding:10px 14px;border-radius:var(--r-s);font-size:14px;border:1px solid rgba(127,176,105,.2)}

/* ─── LAYOUT ─── */
.app{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--bg2);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
.brand{padding:12px 14px 24px;border-bottom:1px solid var(--border);margin-bottom:12px}
.brand h1{font-family:var(--ff-title);font-size:24px;color:var(--acc-l);font-weight:700;line-height:1}
.brand small{display:block;color:var(--muted);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.nav-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--r-s);color:var(--text-mid);font-size:14.5px;font-weight:500;transition:all .15s}
.nav-link:hover{background:rgba(212,165,116,.06);color:var(--text)}
.nav-link.active{background:rgba(212,165,116,.10);color:var(--acc-l);border-left:2px solid var(--acc)}
.nav-link .icon{font-size:18px}
.nav-spacer{flex:1}
.sb-user{padding:14px;background:rgba(212,165,116,.06);border-radius:var(--r-s);font-size:13px;display:flex;align-items:center;gap:10px}
.sb-user .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--acc-d),var(--acc));color:#0c0f12;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.sb-user .meta{overflow:hidden;flex:1}
.sb-user .meta b{display:block;color:var(--text);font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user .meta small{color:var(--muted);font-size:11px}

.main{flex:1;padding:36px 28px;max-width:760px;margin:0 auto}
.right-panel{width:280px;padding:36px 24px;border-left:1px solid var(--border);display:none;flex-direction:column;min-height:calc(100vh - 60px)}
@media(min-width:1080px){.right-panel{display:flex}}

/* ─── LANDING ─── */
.landing{max-width:920px;margin:0 auto;padding:80px 24px}
.landing-hero{text-align:center;margin-bottom:80px}
.landing-eyebrow{color:var(--acc);font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-bottom:18px}
.landing-hero h1{font-family:var(--ff-title);font-size:clamp(40px,6vw,68px);font-weight:600;line-height:1.05;margin-bottom:24px;background:linear-gradient(135deg,var(--text),var(--acc-l));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}
.landing-hero .lede{font-size:19px;color:var(--text-mid);max-width:620px;margin:0 auto 36px;line-height:1.6}
.landing-hero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.landing-feat{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin:60px 0}
.feat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:28px;transition:border .2s,transform .2s}
.feat:hover{border-color:var(--br-hover);transform:translateY(-2px)}
.feat .ico{font-size:32px;margin-bottom:14px}
.feat h3{font-family:var(--ff-title);font-size:22px;font-weight:600;margin-bottom:10px;color:var(--acc-l)}
.feat p{color:var(--text-mid);font-size:14.5px}
.landing-foot{text-align:center;padding:40px 0 20px;color:var(--muted);font-size:13px;border-top:1px solid var(--border)}

/* ─── REGISTER FLOW ─── */
.reg-wrap{max-width:560px;margin:0 auto;padding:60px 24px}
.reg-steps{display:flex;justify-content:center;gap:8px;margin-bottom:40px}
.reg-step{width:36px;height:4px;border-radius:4px;background:var(--bg3);transition:background .25s}
.reg-step.active{background:var(--acc)}
.reg-step.done{background:var(--acc-d)}
.reg-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:36px;box-shadow:var(--shadow)}
.reg-card h2{font-family:var(--ff-title);font-size:30px;font-weight:600;margin-bottom:8px;color:var(--text)}
.reg-card .sub{color:var(--text-mid);font-size:15px;margin-bottom:30px}
.kind-choice{display:grid;gap:14px;margin-bottom:24px}
.kind-card{background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r);padding:22px;cursor:pointer;transition:all .2s}
.kind-card:hover{border-color:var(--br-hover)}
.kind-card.selected{border-color:var(--acc);background:rgba(212,165,116,.08)}
.kind-card h3{font-family:var(--ff-title);font-size:22px;font-weight:600;margin-bottom:6px;color:var(--acc-l)}
.kind-card p{color:var(--text-mid);font-size:14px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;color:var(--text-mid);font-weight:500;margin-bottom:6px;letter-spacing:.02em}

/* ─── CHARTER ARTICLES ─── */
.article-list{display:flex;flex-direction:column;gap:14px}
.article{background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r);padding:22px;transition:border .25s}
.article.acked{border-color:rgba(127,176,105,.4);background:rgba(127,176,105,.04)}
.article-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:8px}
.article-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--acc);color:#0c0f12;font-weight:700;font-size:13px;flex-shrink:0}
.article h4{font-family:var(--ff-title);font-size:21px;font-weight:600;color:var(--acc-l);line-height:1.25;flex:1;padding-top:2px}
.article-body{color:var(--text-mid);font-size:14.5px;line-height:1.65;margin:8px 0 14px}
.article-ack{display:flex;justify-content:flex-end}
.btn-ack{padding:8px 16px;border-radius:var(--r-s);background:var(--bg2);color:var(--text-mid);font-size:13px;font-weight:500;border:1px solid var(--border);transition:all .2s}
.btn-ack:hover{border-color:var(--acc);color:var(--text)}
.btn-ack.acked{background:rgba(127,176,105,.12);color:var(--green);border-color:rgba(127,176,105,.3);cursor:default}
.btn-ack.acked::before{content:'✓ ';font-weight:700}
.charter-final{margin-top:30px;padding-top:24px;border-top:1px solid var(--border);text-align:center}
.charter-progress{font-size:13px;color:var(--muted);margin-bottom:12px}

/* ─── FEED / LA PLACE ─── */
.feed-head{margin-bottom:24px}
.feed-head h2{font-family:var(--ff-title);font-size:32px;font-weight:600;color:var(--text);letter-spacing:-.01em}
.feed-tabs{display:flex;gap:0;margin-top:18px;border-bottom:1px solid var(--border)}
.feed-tab{padding:10px 18px;color:var(--text-mid);font-size:14.5px;font-weight:500;border-bottom:2px solid transparent;transition:all .15s}
.feed-tab:hover{color:var(--text)}
.feed-tab.active{color:var(--acc-l);border-bottom-color:var(--acc)}
.composer{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:24px;transition:border .2s}
.composer:focus-within{border-color:var(--br-hover)}
.composer textarea{background:transparent;border:none;padding:0;min-height:64px;font-size:15px}
.composer textarea:focus{background:transparent}
.composer-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.composer-count{color:var(--muted);font-size:12px}
.post{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:14px;transition:border .2s}
.post:hover{border-color:rgba(212,165,116,.14)}
.post-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--acc-d),var(--acc));color:#0c0f12;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}
.post-meta{flex:1;min-width:0}
.post-author{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.post-author b{font-size:14.5px;color:var(--text);font-weight:600}
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.02em}
.badge-certified{background:rgba(29,155,240,.10);color:#1d9bf0;border:1px solid rgba(29,155,240,.30);font-weight:600}
.badge-en-quete{background:rgba(127,174,200,.12);color:var(--blue);border:1px solid rgba(127,174,200,.25)}
.badge-demande{background:rgba(232,199,154,.10);color:var(--acc-l)}
.badge-verified{background:rgba(180,140,90,.18);color:var(--acc-l);border:1px solid var(--br-hover);font-weight:700}
.badge-pending{background:rgba(170,170,170,.10);color:var(--muted);border:1px solid rgba(170,170,170,.20);font-weight:500}

.post-time{color:var(--muted);font-size:12.5px;margin-top:2px}
.post-body{font-size:15px;line-height:1.65;color:var(--text);white-space:pre-wrap;word-wrap:break-word}
.post-actions{display:flex;gap:6px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.act-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-s);color:var(--muted);font-size:13px;transition:all .15s}
.act-btn:hover{background:rgba(212,165,116,.06);color:var(--text)}
.act-btn.active{color:var(--acc-l)}
.act-btn .ico{font-size:15px}

/* Comments */
.comments{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);display:none}
.comments.open{display:block}
.comment{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.comment:last-child{border-bottom:none}
.comment .avatar{width:30px;height:30px;font-size:12px}
.comment-body{flex:1;font-size:14px;line-height:1.55}
.comment-body b{color:var(--text);font-size:13.5px}
.comment-body .text{margin-top:2px;color:var(--text-mid)}
.comment-form{margin-top:10px;display:flex;gap:8px}
.comment-form input{flex:1;padding:8px 12px;font-size:14px}

/* Profile */
.profile{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:32px;margin-bottom:24px}
.profile-head{display:flex;align-items:center;gap:18px;margin-bottom:20px}
.profile-head .avatar{width:72px;height:72px;font-size:26px}
.profile-head h2{font-family:var(--ff-title);font-size:30px;font-weight:600;color:var(--text);margin-bottom:4px}
.profile-head .role{color:var(--text-mid);font-size:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.profile-bio{font-size:15px;color:var(--text-mid);line-height:1.65;margin:18px 0;white-space:pre-wrap}
.profile-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.profile-meta span{display:flex;align-items:center;gap:6px}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;background:var(--bg2);border:1px solid var(--br-hover);padding:14px 20px;border-radius:var(--r-s);box-shadow:var(--shadow);font-size:14px;animation:fadeIn .25s;z-index:9999;max-width:340px}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Mobile */
@media(max-width:760px){
  .sidebar{position:fixed;left:-260px;z-index:100;transition:left .25s}
  .sidebar.open{left:0}
  .main{padding:24px 18px}
  .reg-card{padding:24px 20px}
  .landing{padding:50px 20px}
}
.menu-btn{display:none;position:fixed;top:14px;left:14px;width:40px;height:40px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-s);align-items:center;justify-content:center;font-size:20px;z-index:50}
@media(max-width:760px){.menu-btn{display:flex}}

/* ───── Modale signalement ───── */
.modal-bg{position:fixed;inset:0;background:rgba(8,12,18,.78);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;backdrop-filter:blur(4px)}
.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:28px;max-width:480px;width:100%;box-shadow:0 18px 48px rgba(0,0,0,.5)}
.reason-list{display:flex;flex-direction:column;gap:6px}
.reason{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:14px;color:var(--text-mid);transition:.15s}
.reason:hover{border-color:var(--br-hover);background:rgba(212,165,116,.05)}
.reason input{accent-color:var(--acc-l)}

/* Bouton signaler en commentaire */
.comment-report{background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:4px 0 0;opacity:.6;transition:.2s}
.comment-report:hover{opacity:1;color:var(--red,#d67878)}

/* Préférence notif checkbox */
.check{display:flex;align-items:flex-start;gap:8px;padding:8px 0;font-size:13.5px;color:var(--text-mid);cursor:pointer}
.check input{margin-top:3px;accent-color:var(--acc-l)}

/* Avatar image (photo Giri Soins) */
.avatar.avatar-img{padding:0;overflow:hidden;background:none}
.avatar.avatar-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}

/* ───── Sidebar bottom (logout + gear) ───── */
.sb-bottom{margin-top:auto;display:flex;align-items:center;gap:6px;padding-top:10px;border-top:1px solid var(--border)}
.sb-bottom .sb-logout{flex:1}
.sb-bottom .sb-gear{flex:0 0 auto;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:18px;padding:0;border:1px solid var(--border);border-radius:var(--r-s)}
.sb-bottom .sb-gear:hover{background:rgba(212,165,116,.08);border-color:var(--br-hover);transform:rotate(40deg);transition:transform .25s,background .15s,border-color .15s}

/* ───── Page Paramètres ───── */
.settings-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:24px 28px;margin-bottom:18px}
.settings-section h3{font-family:var(--ff-title);font-size:20px;font-weight:600;color:var(--text);margin-bottom:6px}
.settings-section .desc{color:var(--text-mid);font-size:13.5px;margin-bottom:18px}
.settings-section .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

.avatar-edit{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.avatar-edit .avatar{width:88px;height:88px;font-size:32px;flex-shrink:0}
.avatar-edit-actions{display:flex;flex-direction:column;gap:8px}
.avatar-edit-actions input[type=file]{font-size:13px;color:var(--text-mid);max-width:340px}
.avatar-edit-actions input[type=file]::file-selector-button{background:var(--bg3);color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:var(--r-s);cursor:pointer;margin-right:10px;transition:.15s}
.avatar-edit-actions input[type=file]::file-selector-button:hover{border-color:var(--br-hover);background:var(--bg2)}
.avatar-edit-actions .hint{font-size:12px;color:var(--muted)}

.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.theme-card{position:relative;display:block;border:1px solid var(--border);border-radius:var(--r-s);padding:14px;cursor:pointer;transition:.18s;background:rgba(255,255,255,.02)}
.theme-card:hover{border-color:var(--br-hover)}
.theme-card input{position:absolute;opacity:0;pointer-events:none}
.theme-card input:checked + .theme-preview + .theme-label{color:var(--text)}
.theme-card:has(input:checked){border-color:var(--acc);background:rgba(212,165,116,.06);box-shadow:0 0 0 1px var(--acc) inset}
.theme-preview{height:84px;border-radius:6px;margin-bottom:10px;position:relative;overflow:hidden;border:1px solid var(--border)}
.theme-preview-sombre{background:linear-gradient(135deg,#0F1419 0%,#161B22 60%,#1d2530 100%)}
.theme-preview-sombre::after{content:;position:absolute;top:18px;left:18px;width:36px;height:6px;background:#D4A574;border-radius:3px;box-shadow:0 12px 0 -1px rgba(232,223,201,.4)}
.theme-preview-clair{background:linear-gradient(135deg,#f5f1e8 0%,#ece4d3 60%,#dfd5be 100%)}
.theme-preview-clair::after{content:;position:absolute;top:18px;left:18px;width:36px;height:6px;background:#8b6914;border-radius:3px;box-shadow:0 12px 0 -1px rgba(60,42,18,.45)}
.theme-label{font-size:14px;font-weight:600;color:var(--text-mid);display:flex;align-items:center;justify-content:space-between}
.theme-label small{font-weight:400;font-size:12px;color:var(--muted)}

.account-info{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:14px}
.account-info dt{color:var(--muted);font-size:13px}
.account-info dd{color:var(--text-mid)}
.account-info dd b{color:var(--text)}

.danger-zone{border-color:rgba(214,120,120,.25)}
.danger-zone h3{color:#d67878}

/* ───── Thème Aurore (clair) ───── */
html[data-theme=clair]{
  --bg:#f5f1e8; --bg2:#ffffff; --bg3:#ece4d3;
  --border:rgba(139,105,20,.16);
  --br-hover:rgba(139,105,20,.34);
  --text:#3c2a12; --text-mid:#5a4628; --muted:#8a7956;
  --acc:#8b6914; --acc-l:#b8893a;
  --shadow:0 8px 28px rgba(60,42,18,.10);
  --bg-card:#ffffff;
}
html[data-theme=clair] body{background-image:radial-gradient(ellipse at 25% 35%,rgba(184,137,58,.06) 0%,transparent 55%),radial-gradient(ellipse at 78% 75%,rgba(139,105,20,.04) 0%,transparent 50%)}
html[data-theme=clair] input,html[data-theme=clair] textarea,html[data-theme=clair] select{background:#fff;border-color:rgba(139,105,20,.18)}
html[data-theme=clair] .nav-link:hover{background:rgba(139,105,20,.08)}
html[data-theme=clair] .reason:hover{background:rgba(139,105,20,.06)}
html[data-theme=clair] .theme-card{background:rgba(139,105,20,.03)}
html[data-theme=clair] .theme-card:has(input:checked){background:rgba(139,105,20,.10)}
html[data-theme=clair] .toast{background:#fff}
html[data-theme=clair] .modal-bg{background:rgba(60,42,18,.55)}

/* ───── Barre de contrôle (La Place/Demandes) — premium ───── */
.control-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:240px;max-width:520px}
.search-wrap .search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.search-wrap input{width:100%;padding:11px 16px 11px 38px;font-size:14px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:24px;color:var(--text);transition:all .2s}
.search-wrap input::placeholder{color:var(--muted)}
.search-wrap input:focus{outline:none;border-color:var(--acc);background:rgba(212,165,116,.04);box-shadow:0 0 0 4px rgba(212,165,116,.08)}

.seg-sort{display:inline-flex;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:24px;padding:3px;gap:2px}
.seg-opt{background:transparent;border:none;color:var(--text-mid);padding:7px 16px;font-size:13px;font-weight:500;border-radius:20px;cursor:pointer;letter-spacing:.01em;transition:all .2s}
.seg-opt:hover{color:var(--text)}
.seg-opt.active{background:linear-gradient(135deg,var(--acc),var(--acc-l));color:#0c0f12;font-weight:600;box-shadow:0 2px 8px rgba(212,165,116,.18)}

.btn-filters{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:24px;color:var(--text);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .2s;position:relative}
.btn-filters svg{color:var(--text-mid);transition:.2s}
.btn-filters:hover{border-color:var(--br-hover);background:rgba(212,165,116,.04)}
.btn-filters:hover svg{color:var(--acc-l)}
.btn-filters .filter-count{display:none;min-width:20px;height:20px;line-height:20px;padding:0 6px;background:linear-gradient(135deg,var(--acc),var(--acc-l));color:#0c0f12;font-size:11px;font-weight:700;border-radius:10px;text-align:center;margin-left:2px}
.btn-filters .filter-count.on{display:inline-block;animation:pop .25s}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}

/* Active filters chips */
.active-chips{display:none;flex-wrap:wrap;gap:8px;margin-bottom:18px;animation:slideDown .25s}
@keyframes slideDown{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.active-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 14px;background:rgba(212,165,116,.10);border:1px solid rgba(212,165,116,.28);color:var(--text);font-size:12.5px;font-weight:500;border-radius:14px;cursor:pointer;transition:.18s}
.active-chip:hover{background:rgba(212,165,116,.16);border-color:rgba(212,165,116,.45)}
.active-chip .x{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(212,165,116,.20);color:var(--acc-l);font-size:14px;line-height:1;font-weight:400;margin-left:2px;transition:.15s}
.active-chip:hover .x{background:rgba(214,120,120,.30);color:#fff}
.active-chip.clear{background:transparent;border-color:transparent;color:var(--muted);font-style:italic;text-decoration:underline;text-decoration-color:rgba(255,255,255,.18);text-underline-offset:3px}
.active-chip.clear:hover{color:var(--text);text-decoration-color:var(--acc-l)}

/* ───── Drawer filtres premium ───── */
.drawer-overlay{position:fixed;inset:0;background:rgba(8,12,18,.70);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9000;opacity:0;transition:opacity .28s ease}
.drawer-overlay.open{opacity:1}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);border-left:1px solid var(--border);z-index:9001;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .32s cubic-bezier(.22,1,.36,1);box-shadow:-24px 0 60px rgba(0,0,0,.45)}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 28px 18px;border-bottom:1px solid var(--border)}
.drawer-head h3{font-size:24px;font-weight:600;color:var(--text);letter-spacing:-.01em;margin:0}
.drawer-close{background:transparent;border:1px solid var(--border);color:var(--text-mid);width:34px;height:34px;border-radius:50%;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s}
.drawer-close:hover{border-color:var(--br-hover);color:var(--text);background:rgba(255,255,255,.04);transform:rotate(90deg)}
.drawer-body{flex:1;overflow-y:auto;padding:8px 28px 24px;scrollbar-width:thin}
.drawer-body::-webkit-scrollbar{width:6px}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(212,165,116,.20);border-radius:3px}
.drawer-section{padding:18px 0;border-bottom:1px solid rgba(212,165,116,.06)}
.drawer-section:last-child{border-bottom:none}
.drawer-section h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);margin:0 0 12px}

/* Seg cards (radio cards style) */
.seg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px}
.seg-card{position:relative;background:rgba(255,255,255,.025);border:1px solid var(--border);color:var(--text-mid);padding:14px 12px;border-radius:12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.seg-card .seg-ico{font-size:18px;color:var(--acc-l);line-height:1}
.seg-card:hover{border-color:var(--br-hover);background:rgba(212,165,116,.04);color:var(--text);transform:translateY(-1px)}
.seg-card.active{background:linear-gradient(135deg,rgba(212,165,116,.18),rgba(212,165,116,.06));border-color:var(--acc);color:var(--text);box-shadow:0 4px 16px rgba(212,165,116,.12),0 0 0 1px var(--acc) inset}
.seg-card.active::before{content:"";position:absolute;top:8px;right:8px;width:6px;height:6px;background:var(--acc);border-radius:50%;box-shadow:0 0 8px var(--acc)}

/* Select premium */
.select-wrap{position:relative}
.select-wrap select{width:100%;appearance:none;-webkit-appearance:none;padding:12px 38px 12px 14px;font-size:14px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;transition:.18s}
.select-wrap select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(212,165,116,.10)}
.select-wrap .select-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--text-mid);pointer-events:none}

/* Drawer input */
.drawer-input{width:100%;padding:12px 14px;font-size:14px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:10px;color:var(--text);transition:.18s}
.drawer-input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(212,165,116,.10)}

/* iOS-style toggle */
.drawer-toggle{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;font-size:14px;color:var(--text-mid)}
.drawer-toggle > span:first-child{flex:1;display:flex;flex-direction:column;gap:3px}
.drawer-toggle b{color:var(--text);font-weight:500;font-size:14px}
.drawer-toggle small{color:var(--muted);font-size:12px;font-weight:400}
.drawer-toggle input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}
.drawer-toggle .switch{position:relative;width:44px;height:24px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:12px;flex-shrink:0;transition:.22s}
.drawer-toggle .switch::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--text-mid);border-radius:50%;transition:.22s cubic-bezier(.4,0,.2,1)}
.drawer-toggle input:checked ~ .switch{background:linear-gradient(135deg,var(--acc),var(--acc-l));border-color:var(--acc)}
.drawer-toggle input:checked ~ .switch::after{left:22px;background:#0c0f12;box-shadow:0 1px 4px rgba(0,0,0,.4)}

/* Drawer footer */
.drawer-foot{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:18px 28px;border-top:1px solid var(--border);background:rgba(0,0,0,.20)}
.drawer-foot .btn-link{background:transparent;border:none;color:var(--text-mid);font-size:13.5px;cursor:pointer;padding:8px 4px;text-underline-offset:3px;transition:.15s}
.drawer-foot .btn-link:hover{color:var(--acc-l);text-decoration:underline}
.drawer-foot .btn-primary{padding:11px 22px;font-size:14px;font-weight:600}

@media(max-width:600px){
  .control-bar{gap:8px}
  .search-wrap{order:1;flex:1 1 100%;max-width:none}
  .seg-sort{order:2;flex:1}
  .btn-filters{order:3}
  .seg-opt{padding:7px 12px;font-size:12.5px}
  .drawer{width:100vw}
  .drawer-head{padding:18px 20px 14px}
  .drawer-body{padding:8px 20px 20px}
  .drawer-foot{padding:14px 20px}
}


/* Drawer — rendu select/inputs lisible quel que soit le thème */
.drawer-body select,.drawer-body input[type=text],.drawer-body input[type=search]{appearance:auto;-webkit-appearance:menulist;color:var(--text)}
.drawer-section > div{margin-top:6px}
.drawer-section select#filter-specialty{width:100%;padding:11px 14px;font-size:14.5px;background:rgba(255,255,255,.04);border:1.5px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer}
.drawer-section select#filter-specialty:focus{outline:none;border-color:var(--acc);background:rgba(255,255,255,.06)}
.drawer-section select#filter-specialty option{background:var(--bg2);color:var(--text)}
/* Force light color-scheme côté natif si thème clair */
html[data-theme="clair"] .drawer-body{color-scheme:light}
html[data-theme="clair"] .drawer-section select#filter-specialty{background:#fff;border-color:rgba(139,105,20,.22);color:#3c2a12}
html[data-theme="clair"] .drawer-section select#filter-specialty:focus{border-color:var(--acc);background:#fff;box-shadow:0 0 0 3px rgba(139,105,20,.12)}
html[data-theme="clair"] .drawer-section select#filter-specialty option{background:#fff;color:#3c2a12}
/* Sombre — explicit dark scheme pour cohérence native */
html:not([data-theme="clair"]) .drawer-body{color-scheme:dark}

/* Theme clair (Aurore) — ajustements drawer */
html[data-theme="clair"] .drawer{background:linear-gradient(180deg,#fff 0%,#f5f1e8 100%);border-left-color:rgba(139,105,20,.15)}
html[data-theme="clair"] .drawer-overlay{background:rgba(60,42,18,.45)}
/* Theme clair (Aurore) — intérieur drawer */
html[data-theme="clair"] .drawer-section{border-bottom-color:rgba(139,105,20,.10)}
html[data-theme="clair"] .drawer-section h4{color:#7a6440}
html[data-theme="clair"] .drawer-input{background:#fff;border-color:rgba(139,105,20,.20);color:var(--text)}
html[data-theme="clair"] .drawer-input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(139,105,20,.12)}
html[data-theme="clair"] .drawer-body select,html[data-theme="clair"] .drawer-body input,html[data-theme="clair"] .drawer-body textarea{background:#fff;color:var(--text);border-color:rgba(139,105,20,.20)}
html[data-theme="clair"] .drawer-body::-webkit-scrollbar-thumb{background:rgba(139,105,20,.24)}
html[data-theme="clair"] .drawer-toggle{color:var(--text-mid)}
html[data-theme="clair"] .drawer-toggle b{color:var(--text)}
html[data-theme="clair"] .drawer-toggle small{color:var(--muted)}
html[data-theme="clair"] .drawer-toggle .switch{background:rgba(139,105,20,.10);border-color:rgba(139,105,20,.22)}
html[data-theme="clair"] .drawer-toggle .switch::after{background:#fff;box-shadow:0 1px 3px rgba(60,42,18,.20)}
html[data-theme="clair"] .drawer-toggle input:checked ~ .switch::after{background:#fff}
html[data-theme="clair"] .drawer-foot{background:rgba(139,105,20,.06);border-top-color:rgba(139,105,20,.14)}
html[data-theme="clair"] .drawer-foot .btn-link{color:var(--text-mid)}
html[data-theme="clair"] .drawer-foot .btn-link:hover{color:var(--acc)}
html[data-theme="clair"] .drawer-head{border-bottom-color:rgba(139,105,20,.14)}
html[data-theme="clair"] .drawer-close{border-color:rgba(139,105,20,.20);color:var(--text-mid)}
html[data-theme="clair"] .drawer-close:hover{background:rgba(139,105,20,.06);color:var(--text);border-color:var(--acc)}
html[data-theme="clair"] .seg-card.active{background:linear-gradient(135deg,rgba(139,105,20,.14),rgba(139,105,20,.06))}
html[data-theme="clair"] .active-chip{background:rgba(139,105,20,.10);border-color:rgba(139,105,20,.28)}

/* ───── Promo Card SUPER DECOUVERTE (right-panel) ───── */
.promo-card{position:relative;display:block;margin:0 0 22px;padding:22px 18px 18px;background:linear-gradient(155deg,rgba(212,165,116,.12) 0%,rgba(139,26,60,.18) 100%);border:1px solid rgba(212,165,116,.32);border-radius:16px;text-decoration:none;color:var(--text);overflow:hidden;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,border-color .25s;box-shadow:0 4px 20px rgba(0,0,0,.18)}
.promo-card:hover{transform:translateY(-3px);border-color:var(--acc);box-shadow:0 12px 32px rgba(212,165,116,.22),0 0 0 1px rgba(212,165,116,.4) inset}
.promo-card:hover .promo-arrow{transform:translateX(4px)}
.promo-card:hover .promo-glow{opacity:1}
.promo-glow{position:absolute;top:-40%;right:-30%;width:180px;height:180px;background:radial-gradient(circle,rgba(212,165,116,.4) 0%,transparent 70%);opacity:.6;transition:opacity .35s;pointer-events:none}
.promo-badge{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,var(--acc),var(--acc-l));color:#0c0f12;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;margin-bottom:12px;box-shadow:0 2px 8px rgba(212,165,116,.3);animation:pulse-soft 2.4s ease-in-out infinite}
@keyframes pulse-soft{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
.promo-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;letter-spacing:.02em;line-height:1.1;color:var(--text);margin-bottom:10px}
.promo-price{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}
.promo-amount{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:600;color:var(--acc-l);letter-spacing:-.01em;line-height:1}
.promo-old{font-size:12.5px;color:var(--muted);text-decoration:line-through;text-decoration-color:rgba(214,120,120,.7);text-decoration-thickness:1.5px}
.promo-desc{font-size:12.5px;line-height:1.55;color:var(--text-mid);margin-bottom:14px}
.promo-cta{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:rgba(212,165,116,.14);border:1px solid rgba(212,165,116,.32);border-radius:10px;font-size:13px;font-weight:600;color:var(--text);transition:.2s}
.promo-card:hover .promo-cta{background:linear-gradient(135deg,var(--acc),var(--acc-l));color:#0c0f12;border-color:var(--acc)}
.promo-arrow{display:inline-block;transition:transform .2s;font-weight:700}
.promo-meta{margin-top:10px;text-align:center;font-size:11px;color:var(--muted);font-style:italic;letter-spacing:.02em}

/* Theme clair (Aurore) */
html[data-theme="clair"] .promo-card{background:linear-gradient(155deg,rgba(139,105,20,.10) 0%,rgba(139,26,60,.10) 100%);border-color:rgba(139,105,20,.30)}
html[data-theme="clair"] .promo-card:hover{box-shadow:0 12px 32px rgba(139,105,20,.18)}
html[data-theme="clair"] .promo-glow{background:radial-gradient(circle,rgba(139,105,20,.30) 0%,transparent 70%)}
.rp-about{margin-top:auto;padding-top:24px;border-top:1px solid var(--border)}

.cert-tick{display:inline-block;line-height:0}
.cert-tick-mini{display:inline-block;line-height:0;margin-left:2px}

/* === Clarté La Place vs Demandes (2026-05-11) === */
.feed-sub{color:var(--text-mid);font-size:14.5px;line-height:1.55;margin-top:10px;margin-bottom:0;max-width:680px}
.feed-sub b{color:var(--text);font-weight:600}
.feed-tab{display:inline-flex;align-items:center;gap:8px}
.feed-tab-ico{font-size:15px;opacity:.85}
.feed-tab-label{font-weight:600}
.feed-tab-hint{font-size:11px;opacity:.55;text-transform:uppercase;letter-spacing:.06em;padding:2px 6px;border-radius:3px;background:rgba(255,255,255,.04)}
.feed-tab.active .feed-tab-hint{opacity:.85;background:rgba(212,165,116,.12);color:var(--acc-l)}
html[data-theme="clair"] .feed-tab-hint{background:rgba(60,42,18,.05);color:rgba(60,42,18,.65)}
html[data-theme="clair"] .feed-tab.active .feed-tab-hint{background:rgba(139,105,20,.12);color:#8b6914}

/* === Like button (2026-05-11) === */
.like-btn{display:inline-flex;align-items:center;gap:6px;transition:color .15s,transform .15s}
.like-btn .ico-heart{transition:transform .15s,fill .15s}
.like-btn:hover{color:#e0245e}
.like-btn:hover .ico-heart{transform:scale(1.12)}
.like-btn.liked{color:#e0245e}
.like-btn.liked .ico-heart{fill:#e0245e;stroke:#e0245e;animation:likePop .25s ease-out}
@keyframes likePop{0%{transform:scale(.85)}50%{transform:scale(1.25)}100%{transform:scale(1)}}
