/* ═══════════════════════════════════════════════════════════════
   MEMBER SHELL — CSS SOCLE HAUT COMMUN
   Source : LOCKED_MON_ESPACE_VALIDATED_20260523.html (commit 72ea95a)
   Périmètre : topbar, wall banner, bloc identité, mode clair/nuit
   Ne pas modifier sans valider une nouvelle version LOCKED.
═══════════════════════════════════════════════════════════════ */

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── TOKENS ─────────────────────────────────────────────────── */
:root{
  --nav-bg:#E4DDD0;
  --bg:#EEE9E0;
  --s1:#F7F1E7;
  --s2:#EFE6D8;
  --s3:#E4D8C8;
  --t1:#1A1816;
  --t2:#3D3733;
  --t3:#5F5750;
  --t4:#9A9490;
  --red:#C1121F;
  --red-dk:#9B0E18;
  --red-dim:rgba(193,18,31,.10);
  --glow:rgba(193,18,31,.08);
  --glow-str:rgba(193,18,31,.12);
  --drop:rgba(0,0,0,.08);
  --bd:rgba(26,24,22,.14);
  --bdv:rgba(26,24,22,.24);
  --nav-h:104px;
  --font:'DM Sans',sans-serif;
}

/* ── MODE SOMBRE ─────────────────────────────────────────────── */
body.night-on{
  --nav-bg:#0A0807;
  --bg:#0D0B09;
  --s1:#17140F;
  --s2:#1F1B16;
  --s3:#29231D;
  --t1:#EEE9E0;
  --t2:#C8C2BA;
  --t3:#9A9490;
  --t4:#6B6560;
  --red:#C1121F;
  --red-dk:#9B0E18;
  --red-dim:rgba(193,18,31,.15);
  --glow:rgba(193,18,31,.14);
  --glow-str:rgba(193,18,31,.20);
  --drop:rgba(0,0,0,.45);
  --bd:rgba(255,255,255,.10);
  --bdv:rgba(255,255,255,.17);
}
body.night-on .topbar{
  --t1:#EEE9E0;--t2:#C8C2BA;--t3:#9A9490;--t4:#6B6560;
  --s1:#17140F;--s2:#1F1B16;--s3:#29231D;
  --bd:rgba(255,255,255,.10);--bdv:rgba(255,255,255,.17);
}
html.night-on{background:#0C0A09}
body.night-on{background:#0C0A09}

/* ── BASE ────────────────────────────────────────────────────── */
html{background:#EEE9E0;color:var(--t1);font-family:var(--font);font-size:15px;transition:background .35s}
body{min-height:100vh;background:#EEE9E0;transition:background .35s,color .35s}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font);color:inherit}
img{display:block}
input,select,textarea{font-family:var(--font)}

/* ── TOPBAR ──────────────────────────────────────────────────── */
.topbar{
  position:sticky;top:0;z-index:200;
  background:var(--nav-bg);
  border-bottom:1px solid var(--bd);
  height:var(--nav-h);
  display:flex;align-items:center;
  padding:0 28px;gap:16px;
  box-shadow:
    0 1px 0 var(--bd),
    0 2px 12px var(--drop);
}

/* Logo — dark SVG viewBox 1200×630, crop exact */
.tb-logo{flex-shrink:0;overflow:hidden;height:50px}
.tb-logo img{height:128px;width:auto;display:block;margin-top:-31px}

.tb-div{width:1px;height:44px;background:var(--bd);flex-shrink:0}

/* Recherche */
.tb-search{flex-shrink:0;position:relative;width:210px}
.tb-search input{
  width:100%;background:var(--s1);
  border:1px solid var(--bd);border-radius:8px;
  padding:8px 12px 8px 36px;
  color:var(--t1);font-size:13px;
  transition:border-color .15s;
}
.tb-search input:focus{outline:none;border-color:var(--bdv)}
.tb-search input::placeholder{color:var(--t4)}
.tb-search-ico{
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--t4);pointer-events:none;
}

/* Gimmick */
.tb-gimmick{flex:1;text-align:center;min-width:0;padding:0 8px}
.tb-gimmick-title{
  font-family:'Pacifico',cursive;
  font-size:clamp(14px,1.8vw,21px);
  color:var(--t1);letter-spacing:.2px;line-height:1.2;
}
.tb-gimmick-title .exq-word{
  font-family:'DM Sans',sans-serif;
  font-weight:700;font-style:normal;letter-spacing:.6px;
}
.tb-gimmick-sub{
  font-size:clamp(9.5px,.85vw,11.5px);
  color:var(--t3);letter-spacing:.3px;font-weight:400;margin-top:3px;
}

/* Navigation */
.tb-nav{display:flex;align-items:center;gap:3px;flex-shrink:0}
.tb-nl{
  padding:6px 10px;border-radius:7px;
  font-size:13px;font-weight:500;color:var(--t2);
  white-space:nowrap;transition:background .14s,color .14s;
}
.tb-nl:hover{background:var(--s2);color:var(--t1)}
.tb-nl.write{background:var(--red);color:#fff;padding:7px 14px;border-radius:7px;font-weight:600}
.tb-nl.write:hover{background:var(--red-dk)}
.tb-nl.write[aria-disabled="true"]{opacity:.65;cursor:default}
.tb-nl.write[aria-disabled="true"]:hover{background:var(--red)}

/* Night Shift + Langue */
.tb-icon-btn{
  width:34px;height:34px;
  border:1px solid var(--bd);border-radius:7px;
  background:transparent;color:var(--t3);
  display:flex;align-items:center;justify-content:center;
  transition:all .18s;flex-shrink:0;
}
.tb-icon-btn:hover{border-color:var(--bdv);color:var(--t1)}
.tb-icon-btn.day-active{
  border-color:rgba(255,165,40,.4);
  color:rgba(255,155,30,.9);
  background:rgba(255,145,20,.08);
}
.tb-lang-btn{
  font-size:11px;font-weight:700;letter-spacing:.05em;
  color:var(--t3);border:1px solid var(--bd);border-radius:7px;
  padding:5px 10px;transition:all .14s;flex-shrink:0;
}
.tb-lang-btn:hover{border-color:var(--bdv);color:var(--t1)}

/* Avatar dropdown */
.tb-av-wrap{flex-shrink:0;position:relative}
.tb-av-btn{
  width:40px;height:40px;border-radius:50%;
  background:var(--s2);border:2px solid var(--bdv);
  color:var(--t1);font-size:15px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .14s;
}
.tb-av-btn:hover{border-color:var(--red)}
.tb-av-dd{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--s1);border:1px solid var(--bdv);
  border-radius:11px;min-width:220px;padding:6px 0;
  display:none;box-shadow:0 10px 40px rgba(0,0,0,.7),0 0 40px var(--glow);
}
.tb-av-wrap:hover .tb-av-dd,
.tb-av-wrap:focus-within .tb-av-dd{display:block}
.tb-ddi{
  display:block;width:100%;padding:9px 16px;
  font-size:13.5px;font-weight:500;color:var(--t2);
  text-align:left;transition:background .12s,color .12s;
}
.tb-ddi:hover{background:var(--s2);color:var(--t1)}
.tb-ddi.current{color:var(--red)}
.tb-ddi.danger{color:#e55}
.tb-ddi[aria-disabled="true"]{opacity:.45;cursor:default}
.tb-ddi[aria-disabled="true"]:hover{background:transparent;color:var(--t2)}
.tb-sep{height:1px;background:var(--bd);margin:4px 0}

/* ── WALL BANNER ─────────────────────────────────────────────── */
.wall-banner{
  position:relative;
  overflow:hidden;
  height:270px;
  background:linear-gradient(150deg,#9A8878 0%,#8A7868 55%,#7A6858 100%);
  box-shadow:
    inset 0 2px 0 rgba(193,18,31,.80),
    inset 0 -2px 0 rgba(193,18,31,.80);
}
.wb-rows{
  position:absolute;top:10px;left:0;right:0;
  display:flex;flex-direction:column;gap:8px;overflow:hidden;
}
.wb-row{display:flex;gap:8px;overflow:hidden}
.wb-track{display:flex;gap:8px;will-change:transform;min-width:max-content}
.wb-track.t1{animation:wb-left 50s linear infinite}
.wb-track.t2{animation:wb-right 62s linear infinite}
@keyframes wb-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes wb-right{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* Vignettes latérales */
.wall-banner::before,
.wall-banner::after{
  content:'';position:absolute;top:0;bottom:0;z-index:4;pointer-events:none;width:220px;
}
.wall-banner::before{left:0;background:linear-gradient(to right,rgba(238,233,224,1) 0%,rgba(238,233,224,.90) 25%,rgba(238,233,224,.50) 60%,rgba(238,233,224,0) 100%)}
.wall-banner::after{right:0;background:linear-gradient(to left,rgba(238,233,224,1) 0%,rgba(238,233,224,.90) 25%,rgba(238,233,224,.50) 60%,rgba(238,233,224,0) 100%)}

/* Mini-carte EXQ */
.mwb-card{
  flex-shrink:0;width:80px;height:120px;
  background:#FDFCF9;border:3px solid #1A1816;border-radius:4px;
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:2px 3px 9px rgba(0,0,0,.3),1px 1px 4px rgba(0,0,0,.15);
}
.mwb-card.cf-r{border-color:#C1121F}
.mwb-card.cf-b{border-color:#2563EB}
.mwb-card.cf-g{border-color:#D4A017}
.mc-h{display:flex;align-items:center;gap:3px;padding:4px 5px 3px;flex-shrink:0}
.mc-av{width:10px;height:10px;border-radius:2px;background:#1A1816;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:5px;font-weight:900;color:#fff}
.mc-ps{font-size:6px;font-weight:700;color:#8A8078;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.mc-sep{height:0.5px;background:rgba(0,0,0,.1);flex-shrink:0}
.mc-body{flex:1;display:flex;align-items:center;justify-content:center;padding:3px 5px}
.mc-exq{font-size:7px;font-weight:900;font-style:italic;color:#1A1816;line-height:1.35;word-break:break-word}
.mc-ft{border-top:0.5px solid rgba(0,0,0,.1);flex-shrink:0}
.mc-acts{display:flex;padding:2px 4px;font-size:5.5px;font-weight:700;color:#8A8078}
.mc-act{flex:1;text-align:center}
.mc-act.lk{color:#C1121F}
.mc-life{display:flex;align-items:center;gap:3px;padding:1px 5px 4px}
.mc-bar{flex:1;height:2px;border-radius:1px;background:#E0DBD3;overflow:hidden}
.mc-fill{height:100%;border-radius:1px;background:#16A34A}
.mc-timer{font-size:5px;font-weight:600;color:#A09888;white-space:nowrap}

/* Bloc identité */
.wb-id-row{
  position:absolute;bottom:0;top:0;left:0;right:0;z-index:5;
  display:flex;align-items:center;
}
.wb-id-inner{max-width:1240px;margin:0 auto;padding:0 16px;width:100%}
.id-glass{
  display:inline-flex;align-items:center;gap:14px;
  max-width:580px;
  background:rgba(247,241,231,.97);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1.5px solid rgba(193,18,31,.72);border-radius:12px;
  padding:14px 20px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.45),
    0 0 4px rgba(255,31,53,.34),
    0 0 10px rgba(193,18,31,.22),
    0 8px 28px rgba(0,0,0,.28);
}
.id-av{
  width:50px;height:50px;border-radius:50%;
  background:var(--s3);border:2px solid rgba(193,18,31,.40);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:var(--t1);flex-shrink:0;
}
.id-txt{flex:1;min-width:0}
.id-pseudo-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:3px}
.id-pseudo{font-size:15px;font-weight:700;color:var(--t1);line-height:1.3}
.id-meta{font-size:11.5px;color:var(--t3);margin-top:3px}
.id-bio{font-size:12px;color:var(--t2);margin-top:4px;line-height:1.4}

/* Badge statut */
.status-badge{
  font-size:10px;font-weight:700;padding:2px 7px;
  border-radius:10px;letter-spacing:.4px;text-transform:uppercase;
  background:rgba(26,24,22,.08);color:var(--t3);border:1px solid var(--bd);
}
.status-badge.premium{background:rgba(193,18,31,.15);color:#e87;border-color:rgba(193,18,31,.28)}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1100px){
  .tb-search{width:175px}
  .tb-logo img{height:82px}
  :root{--nav-h:90px}
}
@media(max-width:768px){
  .tb-gimmick{display:none}
  .tb-nl:not(.write){display:none}
  .tb-icon-btn,.tb-lang-btn{display:none}
}
@media(max-width:600px){
  .topbar{padding:0 14px;gap:10px}
  .tb-search{width:140px}
  .tb-logo img{height:60px}
  :root{--nav-h:72px}
}
@media(max-width:480px){
  .tb-search{display:none}
  .tb-nl{padding:5px 8px;font-size:12px}
  .wall-banner{height:210px}
  .id-glass{padding:8px 10px;gap:8px}
  .id-av{width:36px;height:36px;font-size:15px}
  .id-pseudo{font-size:13px}
}
@media(max-width:375px){
  .topbar{padding:0 10px;gap:8px}
  .tb-logo img{height:52px}
  :root{--nav-h:62px}
}

/* V4.15 — wall banner brun-taupe */
.wall-banner{
  background:linear-gradient(150deg,#9A8878 0%,#8A7868 48%,#7A6858 100%) !important;
}
/* V4.15 — logo crop responsive */
@media(max-width:1100px){
  .tb-logo{height:32px}
  .tb-logo img{margin-top:-20px}
}
@media(max-width:600px){
  .tb-logo{height:24px}
  .tb-logo img{margin-top:-15px}
}
@media(max-width:375px){
  .tb-logo{height:20px}
  .tb-logo img{margin-top:-13px}
}

/* THEME_REPAIRED_V1 — fond body nuit + crop logo light */
body.night-on{background:#0C0A09}
.tb-logo img.logo-night{height:83px;margin-top:-17px}
@media(max-width:1100px){.tb-logo img.logo-night{height:53px;margin-top:-11px}}
@media(max-width:600px){.tb-logo img.logo-night{height:40px;margin-top:-8px}}
@media(max-width:375px){.tb-logo img.logo-night{height:33px;margin-top:-7px}}

/* THEME_REPAIRED_V2 — wall banner sombre en mode nuit */
body.night-on .wall-banner,
html.night-on .wall-banner{
  background:
    linear-gradient(150deg,#1A1816 0%,#0E0C0A 55%,#080706 100%) !important;
  box-shadow:
    inset 0 2px 0 rgba(255,35,55,.72),
    inset 0 -2px 0 rgba(255,35,55,.72),
    0 8px 34px rgba(193,18,31,.28) !important;
}
body.night-on .wall-banner::before,
html.night-on .wall-banner::before{
  background:linear-gradient(to right,rgba(8,7,6,1) 0%,rgba(8,7,6,.85) 30%,rgba(8,7,6,0) 100%) !important;
  width:80px !important;
}
body.night-on .wall-banner::after,
html.night-on .wall-banner::after{
  background:linear-gradient(to left,rgba(8,7,6,1) 0%,rgba(8,7,6,.85) 30%,rgba(8,7,6,0) 100%) !important;
  width:80px !important;
}

/* THEME_REPAIRED_V3 — bloc identité sombre en mode nuit */
body.night-on .id-glass,
html.night-on .id-glass{
  background:rgba(20,17,15,.96) !important;
  border-color:rgba(193,18,31,.72) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.05) inset,
    0 0 6px rgba(193,18,31,.28),
    0 0 24px rgba(193,18,31,.18),
    0 14px 36px rgba(0,0,0,.55) !important;
}
body.night-on .id-av,
html.night-on .id-av{border-color:rgba(193,18,31,.60) !important}

/* ═══════════════════════════════════════════════════════════════
   EXTENSIONS MODULAIRES V2 — additif, ne redessine pas le socle LOCKED
   (slot actions contextuelles, .wb-zone moteur, champs identité étendus,
    bloc partenaire). Le visuel topbar / wall banner / identité reste LOCKED.
═══════════════════════════════════════════════════════════════ */

/* Alias de tokens (compat naming socle V2) — mappés sur les tokens existants */
:root{
  --shell-nav-h:104px;
  --shell-nav-h-mobile:58px;
  --shell-banner-h:270px;
  --shell-banner-h-mobile:200px;
  --cream:#F6EFE4;
  --cream-2:#FFF9EF;
  --sand:#E8DAC7;
  --taupe:#9A8878;
  --ink:#171312;
  --ink-2:#2A2421;
  --muted:#7D7068;
  --night-bg:#1A1816;
  --night-bg-2:#2A1E18;
  --font-main:'DM Sans',system-ui,sans-serif;
  --font-display:'Pacifico',cursive;
}

/* Module 1 — slot actions contextuelles (vide par défaut, injecté par JS) */
.tb-actions{display:flex;align-items:center;gap:3px;flex-shrink:0}
.tb-actions:empty{display:none}

/* Module 2 — conteneur moteur banner (rendu JS via window.EXQBanner) */
.wb-zone{position:absolute;top:10px;left:0;right:0;bottom:0;overflow:hidden;z-index:1}

/* Module 3 — champs identité étendus (masqués proprement si vides) */
.id-fields{display:flex;flex-wrap:wrap;gap:4px 14px;margin-top:5px}
.id-field{font-size:11.5px;color:var(--t3);display:flex;align-items:baseline;gap:4px}
.id-field-lbl{font-weight:600;color:var(--t4)}
.id-field-val{color:var(--t2)}
.id-links{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.id-link{
  font-size:11.5px;color:var(--t2);
  border:1px solid var(--bd);border-radius:7px;padding:3px 9px;
  transition:border-color .13s,color .13s;
}
.id-link:hover{border-color:var(--red);color:var(--t1)}
.id-passions{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.id-passion-tag{
  font-size:10.5px;font-weight:600;color:var(--t2);
  background:var(--s2);border:1px solid var(--bd);
  border-radius:6px;padding:2px 8px;white-space:nowrap;
}
.id-media-row{display:flex;gap:6px;margin-top:7px}
.id-media{
  width:38px;height:38px;border-radius:7px;overflow:hidden;
  background:var(--s2);border:1px solid var(--bd);flex-shrink:0;
}
.id-media img,.id-media video{width:100%;height:100%;object-fit:cover}
/* Avatar : accueille photo / gif / mini-vidéo (fallback = initiale texte) */
.id-av img,.id-av video{width:100%;height:100%;object-fit:cover;border-radius:inherit}

/* Module 4 — Partner Identity Block (style distinct du bloc personnel) */
.id-block-partner{
  display:inline-flex;align-items:center;gap:14px;
  max-width:620px;
  background:rgba(247,241,231,.97);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1.5px solid var(--bdv);border-left:4px solid var(--red);
  border-radius:12px;padding:14px 20px;
  box-shadow:0 0 0 1px rgba(255,255,255,.40),0 8px 28px rgba(0,0,0,.24);
}
.idp-logo{
  width:54px;height:54px;border-radius:10px;flex-shrink:0;
  background:var(--s2);border:1px solid var(--bd);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:800;color:var(--t2);overflow:hidden;
}
.idp-txt{flex:1;min-width:0}
.idp-name-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.idp-name{font-size:15px;font-weight:700;color:var(--t1);line-height:1.3}
.idp-verified{
  font-size:9.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  color:var(--red);background:rgba(193,18,31,.10);
  border:1px solid rgba(193,18,31,.28);border-radius:9px;padding:1px 7px;
}
.idp-meta{font-size:11.5px;color:var(--t3);margin-top:3px}
.idp-meta .sep{opacity:.45;margin:0 3px}
.idp-site{font-size:11.5px;color:var(--red);font-weight:600;margin-top:3px;display:inline-block}
.idp-desc{font-size:12px;color:var(--t2);margin-top:5px;line-height:1.45}
body.night-on .id-block-partner,
html.night-on .id-block-partner{
  background:rgba(20,17,15,.96) !important;
  border-color:var(--bdv) !important;border-left-color:var(--red) !important;
}

@media(max-width:480px){
  .id-block-partner{padding:10px 12px;gap:10px}
  .idp-logo{width:42px;height:42px;font-size:18px}
  .idp-name{font-size:13px}
}
