/* =====================================================================
   LOOTER SHOOTERS - "Tactical Loot Terminal"
   Design system : dark slate + néon loot-green, tiers = couleurs de rareté
   ===================================================================== */

:root {
  /* Surfaces */
  --bg:        #090c11;
  --bg-2:      #0d121a;
  --surface:   #141b25;
  --surface-2: #1b2531;
  --line:      #243040;
  --line-soft: #1a232f;

  /* Texte */
  --text:      #e8eef5;
  --text-dim:  #a3b3c4;
  --text-mute: #66788b;

  /* Accent signature (loot green) */
  --accent:    #7cff50;
  --accent-ink:#0a0f08;
  --accent-2:  #1fe3c2;   /* teal secondaire */
  --glow:      0 0 22px rgba(124,255,80,.45);

  /* Tiers = raretés du genre */
  --t-s: #ffce3a;  /* exotique / or      */
  --t-a: #c07bff;  /* légendaire / violet*/
  --t-b: #3ea6ff;  /* rare / bleu        */
  --t-c: #5fdc6b;  /* commun / vert      */

  /* Système */
  --radius: 4px;
  --gap: clamp(16px, 2.4vw, 28px);
  --maxw: 1240px;
  --font-display: "Chakra Petch", "Segoe UI", sans-serif;
  --font-body: "Barlow", system-ui, sans-serif;
  --font-mono: "DM Mono", ui-monospace, "SFMono-Regular", monospace;
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --header-h: 104px;
}

/* ------------------------------ reset ------------------------------ */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 16px;
  overflow-x: hidden;
  /* Atmosphère : halos colorés + grille tech fine + vignette de profondeur */
  background-image:
    radial-gradient(1200px 680px at 82% -12%, rgba(124,255,80,.10), transparent 58%),
    radial-gradient(1000px 560px at -8% 2%, rgba(31,227,194,.07), transparent 55%),
    radial-gradient(1400px 900px at 50% 120%, rgba(124,255,80,.04), transparent 60%),
    linear-gradient(rgba(36,48,64,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(36,48,64,.5) 1px, transparent 1px),
    radial-gradient(140% 120% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
  background-size: auto, auto, auto, 52px 52px, 52px 52px, auto;
  background-position: 0 0, 0 0, 0 0, center top, center top, center;
  background-attachment: fixed;
}
/* Grain filmique (profondeur, anti-flat) */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  opacity: .035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

::selection { background: var(--accent); color: var(--accent-ink); }

/* ------------------------------ layout ----------------------------- */
.wrap { width: min(100% - 2.5rem, var(--maxw)); margin-inline: auto; }
.section { padding-block: clamp(38px, 6vw, 72px); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--accent); font-weight: 500;
  display: inline-flex; align-items: center; gap: .6em;
}
.eyebrow::before { content:""; width: 22px; height: 2px; background: var(--accent); box-shadow: var(--glow); transition: width .4s var(--ease-out); }
*:hover > .eyebrow::before { width: 34px; }

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.08; letter-spacing: -.01em; }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom: var(--gap); flex-wrap: wrap; }
.section-head h2 { font-size: clamp(1.55rem, 3vw, 2.2rem); text-transform: uppercase; letter-spacing:-.01em; }
.section-head h2 .hl, h2 .hl { color: var(--accent); text-shadow: 0 0 26px color-mix(in srgb, var(--accent) 45%, transparent); }

/* ------------------------------ header ----------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter: blur(14px) saturate(1.2);
  border-bottom: 1px solid var(--line);
}
.site-header::after { content:""; position:absolute; left:0; right:0; bottom:-1px; height:1px; background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 45%, transparent) 50%, transparent); opacity:.6; }
.site-header.scrolled { background: color-mix(in srgb, var(--bg) 94%, transparent); }
.header-inner { display:flex; align-items:center; gap: clamp(14px,2vw,28px); height: var(--header-h); }
.brand { display:flex; align-items:center; gap:.6rem; flex-shrink:0; }
.brand .logo-mark {
  font-family: var(--font-display); font-weight: 700; font-size: 1.25rem;
  letter-spacing: .02em; line-height:1;
}
.brand .logo-mark b { color: var(--accent); text-shadow: var(--glow); }
.brand img, .brand .custom-logo { max-height: calc(var(--header-h) - 14px); width:auto; display:block; transition: filter .3s var(--ease); }
.brand .custom-logo-link { display:flex; align-items:center; line-height:0; }
.brand .custom-logo-link:hover .custom-logo { filter: drop-shadow(0 0 10px color-mix(in srgb, var(--accent) 55%, transparent)); }

.nav-games { display:flex; align-items:center; gap:.4rem; margin-left:auto; flex-wrap:wrap; }
.game-pill {
  font-family: var(--font-display); font-weight: 600; font-size: .82rem;
  letter-spacing: .04em; text-transform: uppercase;
  padding: .42rem .8rem; border: 1px solid var(--line);
  color: var(--text-dim); border-radius: 2px;
  transition: color .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease), box-shadow .25s var(--ease);
  position: relative; white-space: nowrap;
}
.game-pill:hover, .game-pill.is-active {
  color: var(--accent); border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
  background: color-mix(in srgb, var(--accent) 9%, transparent);
}
.game-pill.is-active { box-shadow: 0 0 18px -5px color-mix(in srgb, var(--accent) 70%, transparent); }
.game-pill::after { content:""; position:absolute; left:.8rem; right:.8rem; bottom:3px; height:1px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease-out); opacity:.8; }
.game-pill:hover::after { transform:scaleX(1); }

/* CTA "Outil de build" dans le header - mis en avant */
.nav-cta {
  display:inline-flex; align-items:center; gap:.45rem; white-space:nowrap;
  font-family: var(--font-display); font-weight:700; font-size:.82rem; letter-spacing:.04em; text-transform:uppercase;
  padding:.5rem .95rem; margin-left:.2rem;
  background: var(--accent); color: var(--accent-ink); border:1px solid var(--accent);
  clip-path: polygon(0 0, 100% 0, 100% 66%, calc(100% - 10px) 100%, 0 100%);
  box-shadow: 0 0 18px -4px color-mix(in srgb, var(--accent) 75%, transparent);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.nav-cta svg { width:15px; height:15px; }
.nav-cta:hover { transform: translateY(-1px); box-shadow: var(--glow); }
.icon-btn {
  display:grid; place-items:center; width:40px; height:40px; flex-shrink:0;
  border:1px solid var(--line); background: var(--surface); color: var(--text-dim);
  border-radius: 2px; transition: all .2s var(--ease);
}
.icon-btn:hover { color: var(--accent); border-color: var(--accent); }
.nav-toggle { display:none; }

/* ------------------------------ buttons ---------------------------- */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family: var(--font-display); font-weight:600; font-size:.86rem;
  letter-spacing:.06em; text-transform:uppercase;
  padding:.7rem 1.25rem; border-radius:2px; transition: all .2s var(--ease);
}
.btn-primary {
  background: var(--accent); color: var(--accent-ink);
  clip-path: polygon(0 0, 100% 0, 100% 70%, calc(100% - 12px) 100%, 0 100%);
}
.btn-primary:hover { box-shadow: var(--glow); transform: translateY(-1px); }
.btn-ghost { background: transparent; border:1px solid var(--line); color: var(--text); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); }

/* ------------------------------ tier badge ------------------------- */
.tier {
  --c: var(--accent);
  display:inline-flex; align-items:center; gap:.35em;
  font-family: var(--font-mono); font-weight:500; font-size:.7rem;
  letter-spacing:.08em; text-transform:uppercase;
  padding:.22em .55em .2em; color: var(--c);
  border:1px solid color-mix(in srgb, var(--c) 55%, transparent);
  background: color-mix(in srgb, var(--c) 12%, transparent);
  border-radius:2px; line-height:1;
}
.tier::before { content:""; width:6px; height:6px; background:var(--c); box-shadow:0 0 8px var(--c); transform:rotate(45deg); }
.tier-s{--c:var(--t-s)} .tier-a{--c:var(--t-a)} .tier-b{--c:var(--t-b)} .tier-c{--c:var(--t-c)}

/* ------------------------------ hero ------------------------------- */
.hero { padding-top: clamp(28px,4vw,48px); }
.hero-grid { display:grid; grid-template-columns: 1.55fr 1fr; gap: var(--gap); }
.hero-feature {
  position:relative; min-height: 460px; border:1px solid var(--line);
  border-radius: var(--radius); overflow:hidden; display:flex; align-items:flex-end;
  background: var(--surface);
  box-shadow: inset 0 2px 0 color-mix(in srgb, var(--accent) 55%, transparent), 0 30px 60px -40px rgba(0,0,0,.9);
}
.hero-feature .ph, .hero-feature img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-feature img { animation: heroKen 22s var(--ease-out) both; }
@keyframes heroKen { from { transform: scale(1.02); } to { transform: scale(1.1); } }
.hero-feature::after {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, transparent 18%, rgba(9,12,17,.5) 56%, rgba(9,12,17,.97) 100%),
    linear-gradient(90deg, rgba(9,12,17,.55), transparent 55%);
}
/* Réticule d'angle HUD sur le hero */
.hero-feature .meta::before {
  content:""; position:absolute; top: calc(-1 * clamp(20px,3vw,36px) + 14px); left: clamp(20px,3vw,36px);
  width:18px; height:18px; border:2px solid var(--accent); border-right:0; border-bottom:0; opacity:.7;
}
.hero-feature .meta { position:relative; z-index:2; padding: clamp(20px,3vw,36px); width:100%; }
.hero-feature .cat { display:flex; gap:.5rem; align-items:center; margin-bottom:.8rem; flex-wrap:wrap; }
.hero-feature h1 { font-size: clamp(1.9rem, 4.2vw, 3.1rem); text-transform:uppercase; max-width: 18ch; letter-spacing:-.015em; text-shadow: 0 2px 36px rgba(0,0,0,.55); }
.hero-feature h1 a:hover { color: var(--accent); }
.hero-feature .excerpt { color: var(--text-dim); margin-top:.7rem; max-width: 56ch; }
.hero-side { display:grid; grid-template-rows: repeat(3,1fr); gap: var(--gap); }
.hero-mini {
  position:relative; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; align-items:flex-end; min-height: 130px; background:var(--surface);
}
.hero-mini img, .hero-mini .ph { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-mini::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 30%,rgba(9,12,17,.95)); }
.hero-mini .m { position:relative; z-index:2; padding:14px 16px; }
.hero-mini h3 { font-size:.98rem; text-transform:uppercase; }
.hero-mini h3 a:hover { color: var(--accent); }
.hero-mini .game { font-family:var(--font-display); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }

/* placeholder fond (sans image) */
.ph {
  background:
    radial-gradient(120% 80% at 70% 0%, color-mix(in srgb,var(--accent) 12%, transparent), transparent 60%),
    repeating-linear-gradient(135deg, var(--surface) 0 14px, var(--surface-2) 14px 28px);
}

/* ------------------------------ card grid -------------------------- */
.card-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(270px,1fr)); gap: var(--gap); }
.card {
  --c: var(--accent);
  position:relative; border:1px solid var(--line);
  border-left: 2px solid var(--c); border-radius: var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, #fff 0%) 0%, var(--surface) 40%, var(--bg-2) 100%);
  transition: transform .3s var(--ease-out), border-color .3s, box-shadow .3s;
}
.card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--c) 60%, var(--line));
  border-left-color: var(--c);
  box-shadow: 0 22px 48px -24px rgba(0,0,0,.95), 0 0 0 1px color-mix(in srgb,var(--c) 35%, transparent),
              -10px 0 26px -20px var(--c);
}
.card-thumb { position:relative; aspect-ratio: 16/9; overflow:hidden; background: var(--surface-2); }
.card-thumb img, .card-thumb .ph { width:100%; height:100%; object-fit:cover; filter: saturate(.85) brightness(.9); transition: transform .6s var(--ease-out), filter .45s var(--ease-out); }
.card:hover .card-thumb img { transform: scale(1.07); filter: saturate(1.08) brightness(1); }
.card-thumb::before { content:""; position:absolute; inset:0; z-index:1; background: linear-gradient(180deg, transparent 55%, rgba(9,12,17,.5)); opacity:.7; }
/* Réticules d'angle (HUD) qui apparaissent au survol - via pseudo-éléments */
.card::before, .card::after { content:""; position:absolute; z-index:4; width:14px; height:14px; border:2px solid var(--c); opacity:0; transition: opacity .35s var(--ease-out), transform .35s var(--ease-out); transform: scale(.6); pointer-events:none; }
.card::before { top:9px; left:9px; border-right:0; border-bottom:0; }
.card::after { bottom:9px; right:9px; border-left:0; border-top:0; }
.card:hover::before, .card:hover::after { opacity:.95; transform: scale(1); }
.card-thumb .game-tag {
  position:absolute; top:10px; left:10px; z-index:2;
  font-family:var(--font-display); font-weight:600; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.28em .6em; background: rgba(9,12,17,.8); border:1px solid var(--line); color: var(--accent); border-radius:2px;
  backdrop-filter: blur(4px);
}
.card-thumb .tier { position:absolute; top:10px; right:10px; z-index:2; background: rgba(9,12,17,.78); backdrop-filter: blur(4px); }
.card-body { padding: 16px 16px 18px; display:flex; flex-direction:column; gap:.55rem; flex:1; }
.card-body h3 { font-size: 1.06rem; line-height:1.18; text-transform:uppercase; }
.card-body h3 a:hover { color: var(--c); }
.card-excerpt { color: var(--text-mute); font-size:.9rem; line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-foot { margin-top:auto; display:flex; align-items:center; gap:.6rem; padding-top:.5rem; border-top:1px solid var(--line-soft); font-size:.78rem; color:var(--text-mute); }
.card-foot .avatar { width:22px; height:22px; border-radius:50%; object-fit:cover; border:1px solid var(--line); }
.card-foot .dot { width:3px; height:3px; background:var(--text-mute); border-radius:50%; }

/* accents par jeu (couleur barre carte) */
.g-division { --c:#ff7a1a } .g-warframe { --c:#3ea6ff } .g-destiny { --c:#c07bff }
.g-borderlands { --c:#ffce3a } .g-outriders { --c:#ff4d57 } .g-divers { --c:var(--accent) }

/* staggered load */
.reveal { opacity:0; transform: translateY(14px); animation: rise .6s var(--ease) forwards; }
@keyframes rise { to { opacity:1; transform:none; } }

/* Chargement orchestré du hero (reveals échelonnés) */
.hero-feature .meta > * { opacity:0; animation: rise .7s var(--ease-out) forwards; }
.hero-feature .meta > *:nth-child(1){ animation-delay:.10s }
.hero-feature .meta > *:nth-child(2){ animation-delay:.20s }
.hero-feature .meta > *:nth-child(3){ animation-delay:.30s }
.hero-side .hero-mini { opacity:0; animation: rise .65s var(--ease-out) forwards; }
.hero-side .hero-mini:nth-child(1){ animation-delay:.22s }
.hero-side .hero-mini:nth-child(2){ animation-delay:.32s }
.hero-side .hero-mini:nth-child(3){ animation-delay:.42s }

/* Hubs : ligne d'accent qui se trace au survol */
.hub::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; z-index:1; background:var(--c); box-shadow:0 0 12px var(--c); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease-out); }
.hub:hover::before { transform:scaleX(1); }

/* ====================================================================
   HOME - sections enrichies
   ==================================================================== */

/* bandeau identité / stats */
.stat-band { border-block: 1px solid var(--line); background: var(--bg-2); }
.stat-band .wrap { display:flex; align-items:stretch; gap:0; flex-wrap:wrap; }
.stat-band .stat { flex:1; min-width:140px; padding: 18px 10px; text-align:center; border-right:1px solid var(--line-soft); }
.stat-band .stat:last-child { border-right:none; }
.stat-band .stat { transition: background .3s var(--ease); }
.stat-band .stat:hover { background: color-mix(in srgb, var(--accent) 5%, transparent); }
.stat-band .n { font-family:var(--font-mono); font-weight:500; font-size: clamp(1.5rem,3.4vw,2.15rem); color: var(--accent); line-height:1; font-variant-numeric: tabular-nums; }
.stat-band .l { font-family:var(--font-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); margin-top:.5rem; }

/* hubs de jeux */
.game-hubs { display:grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: var(--gap); }
.hub {
  --c: var(--accent);
  position:relative; min-height: 220px; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end;
  padding:18px; isolation:isolate; transition: transform .28s var(--ease), border-color .28s;
}
.hub img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition: transform .5s var(--ease); filter: saturate(1.05); }
.hub::after { content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(160deg, color-mix(in srgb,var(--c) 22%, transparent) 0%, rgba(9,12,17,.55) 45%, rgba(9,12,17,.96) 100%); }
.hub:hover { transform: translateY(-6px); border-color: color-mix(in srgb,var(--c) 65%, var(--line)); }
.hub:hover img { transform: scale(1.07); }
.hub .tag { font-family:var(--font-display); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--c); font-weight:600; }
.hub h3 { font-size: 1.5rem; text-transform:uppercase; margin-top:.2rem; }
.hub .cnt { margin-top:.5rem; font-size:.84rem; color:var(--text-dim); display:flex; align-items:center; gap:.5rem; }
.hub .cnt b { color:var(--c); font-family:var(--font-display); }
.hub .go { position:absolute; top:16px; right:16px; width:34px; height:34px; display:grid; place-items:center;
  border:1px solid color-mix(in srgb,var(--c) 50%, var(--line)); border-radius:2px; color:var(--c); background:rgba(9,12,17,.5); backdrop-filter:blur(4px); transition:.2s; }
.hub:hover .go { background:var(--c); color:var(--accent-ink); }

/* section sombre alternée */
.section-alt { background: var(--bg-2); border-block:1px solid var(--line); }

/* rangée spotlight par jeu */
.spotlight + .spotlight { margin-top: clamp(30px,4vw,48px); }
.spotlight-head { display:flex; align-items:center; gap:.9rem; margin-bottom: var(--gap); padding-left:.9rem; border-left:4px solid var(--c, var(--accent)); }
.spotlight-head h2 { font-size: clamp(1.3rem,2.6vw,1.8rem); text-transform:uppercase; }
.spotlight-head .badge { font-family:var(--font-display); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--c,var(--accent)); padding:.25em .6em; border:1px solid color-mix(in srgb, var(--c,var(--accent)) 50%, var(--line)); border-radius:2px; }
.spotlight-head .more { margin-left:auto; font-family:var(--font-display); font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color:var(--text-dim); white-space:nowrap; }
.spotlight-head .more:hover { color: var(--c, var(--accent)); }
.row-4 { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--gap); }

/* bandeau communauté */
.cta-band { position:relative; overflow:hidden; border:1px solid var(--line); border-radius:var(--radius); padding: clamp(28px,5vw,52px); text-align:center;
  background:
    radial-gradient(600px 300px at 50% -20%, color-mix(in srgb,var(--accent) 16%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, var(--surface) 0 16px, var(--surface-2) 16px 32px); }
.cta-band h2 { font-size: clamp(1.6rem,4vw,2.6rem); text-transform:uppercase; }
.cta-band p { color:var(--text-dim); max-width: 52ch; margin: .8rem auto 1.6rem; }

/* bandeau promo outil */
.tool-promo {
  display:flex; align-items:center; gap: var(--gap); overflow:hidden; position:relative;
  border:1px solid var(--line); border-left:3px solid #ff7a1a; border-radius:var(--radius);
  padding: clamp(22px,4vw,40px); transition: border-color .25s var(--ease), transform .25s var(--ease);
  background:
    radial-gradient(600px 240px at 0% 0%, color-mix(in srgb, #ff7a1a 16%, transparent), transparent 70%),
    var(--surface);
}
.tool-promo:hover { border-color:#ff7a1a; transform: translateY(-3px); }
.tool-promo .eyebrow { color:#ff7a1a; }
.tool-promo .eyebrow::before { background:#ff7a1a; box-shadow:0 0 14px #ff7a1a; }
.tool-promo h2 { font-size: clamp(1.5rem,3.4vw,2.4rem); text-transform:uppercase; margin:.4rem 0 .5rem; }
.tool-promo h2 span { color:#ff7a1a; }
.tool-promo p { color:var(--text-dim); max-width:54ch; margin-bottom:1.3rem; }
.tool-promo .tp-deco { margin-left:auto; color:#ff7a1a; opacity:.25; flex-shrink:0; }
.tool-promo .tp-deco svg { width:clamp(80px,12vw,160px); height:auto; }
@media (max-width:680px){ .tool-promo .tp-deco{ display:none; } }

@media (max-width: 980px) { .row-4 { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .row-4 { grid-template-columns: 1fr; } .spotlight-head .more { display:none; } }

/* ------------------------------ archive header --------------------- */
.archive-hero { border-bottom:1px solid var(--line); padding-block: clamp(32px,5vw,56px); position:relative; }
.archive-hero h1 { font-size: clamp(2rem,5vw,3.4rem); text-transform:uppercase; }
.archive-hero p { color: var(--text-dim); margin-top:.6rem; max-width:60ch; }
.archive-hero .count { color: var(--accent); font-family:var(--font-display); }

/* ------------------------------ single ----------------------------- */
.post-hero { position:relative; min-height: clamp(320px,46vw,520px); display:flex; align-items:flex-end; border-bottom:1px solid var(--line); overflow:hidden; }
.post-hero img, .post-hero .ph { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.post-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(9,12,17,.4) 0%, rgba(9,12,17,.7) 55%, rgba(9,12,17,.98) 100%); }
.post-hero .ph-meta { position:relative; z-index:2; padding-block: clamp(24px,4vw,46px); width:100%; }
.post-hero .cat { display:flex; gap:.5rem; align-items:center; margin-bottom:1rem; flex-wrap:wrap; }
.post-hero h1 { font-size: clamp(1.9rem,4.4vw,3.2rem); text-transform:uppercase; max-width: 24ch; }
.post-meta { display:flex; align-items:center; gap:.7rem; margin-top:1.1rem; color: var(--text-dim); font-size:.9rem; flex-wrap:wrap; }
.post-meta .avatar { width:30px; height:30px; border-radius:50%; border:1px solid var(--line); }

.article-layout { display:grid; grid-template-columns: minmax(0,1fr) 300px; gap: clamp(24px,4vw,56px); padding-block: clamp(34px,5vw,60px); }
.prose { font-size: 1.06rem; color: var(--text-dim); max-width: 76ch; }
.prose > * + * { margin-top: 1.15rem; }
.prose h2 { font-size: 1.7rem; color: var(--text); margin-top: 2.2rem; text-transform:uppercase; padding-left:.7rem; border-left:3px solid var(--accent); }
.prose h3 { font-size: 1.3rem; color: var(--text); margin-top: 1.8rem; }
.prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.prose a:hover { text-shadow: var(--glow); }
.prose strong { color: var(--text); }
.prose img { border-radius: var(--radius); border:1px solid var(--line); margin-block: 1.4rem; }
.prose ul, .prose ol { padding-left: 1.3rem; } .prose li { margin-top:.4rem; }
.prose blockquote { border-left:3px solid var(--accent); padding:.4rem 0 .4rem 1.1rem; color:var(--text); font-style:italic; }
.prose code { background: var(--surface); border:1px solid var(--line); padding:.1em .4em; border-radius:3px; font-size:.9em; }
.prose table { width:100%; border-collapse:collapse; }
.prose th, .prose td { border:1px solid var(--line); padding:.6rem .8rem; text-align:left; }
.prose th { background: var(--surface); font-family:var(--font-display); text-transform:uppercase; font-size:.85rem; letter-spacing:.05em; }

/* === Normalisation du contenu migré (couleurs pensées pour l'ancien thème CLAIR) === */

/* 1. Encadrés/callouts : fond plein OU dégradé clair -> boîte sombre cohérente */
.prose p[class*="background-color"], .prose div[class*="background-color"],
.prose ul[class*="background-color"], .prose ol[class*="background-color"],
.prose section[class*="background-color"], .prose figure[class*="background-color"],
.prose blockquote[class*="background-color"],
.prose p[class*="gradient-background"], .prose div[class*="gradient-background"],
.prose ul[class*="gradient-background"], .prose ol[class*="gradient-background"],
.prose section[class*="gradient-background"], .prose figure[class*="gradient-background"] {
  background: var(--surface) !important;
  background-image: none !important;
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  padding: 1rem 1.2rem !important;
  border-radius: var(--radius);
}
/* Texte lisible à l'intérieur des encadrés */
.prose [class*="background-color"] *, .prose [class*="gradient-background"] * { color: var(--text) !important; }
.prose [class*="background-color"] a, .prose [class*="gradient-background"] a { color: var(--accent) !important; }

/* 2. Texte coloré dispersé (vert-cyan, bleu, rose, gris foncé…) -> couleur du thème,
      pour éliminer l'effet "arc-en-ciel" et le texte sombre invisible sur fond sombre. */
.prose span[class*="has-"][class*="-color"]:not([class*="background"]):not([class*="border"]):not([class*="gradient"]),
.prose p[class*="has-"][class*="-color"]:not([class*="background"]):not([class*="gradient"]),
.prose li[class*="has-"][class*="-color"]:not([class*="background"]),
.prose strong[class*="has-"], .prose em[class*="has-"],
.prose .has-very-dark-gray-color, .prose .has-dark-gray-color,
.prose .has-black-color, .prose .has-cyan-bluish-gray-color { color: var(--text) !important; }

/* 3. Surlignages inline (gb-highlight / mark) : pas de fond clair, emphase accent lisible */
.prose .gb-highlight, .prose mark,
.prose span[class*="background-color"], .prose span[class*="gradient-background"] {
  background: transparent !important; background-image: none !important;
  color: var(--accent) !important; padding: 0 !important; border: 0 !important;
}

/* 4. Boutons WordPress migrés (#32373c) -> style accent du thème */
.prose .wp-block-button__link, .prose .wp-element-button, .prose .gb-button {
  background: var(--accent) !important; color: var(--accent-ink) !important; border-radius: 2px !important;
}

/* 5. STYLES INLINE du contenu migré (la vraie cause : ex. <p style="background:lightblue">) :
      les styles inline ont la priorité max -> on les neutralise avec !important. */
.prose [style*="background"] {
  background: var(--surface) !important;
  background-image: none !important;
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  padding: 1rem 1.2rem !important;
  border-radius: var(--radius);
  color: var(--text) !important;
}
.prose [style*="background"] :where(p, li, span, strong, em, td, th, h1, h2, h3, h4) { color: var(--text) !important; }
.prose [style*="background"] a { color: var(--accent) !important; }
/* Couleur de texte inline (sombre, pour l'ancien thème clair) -> couleur du thème */
.prose span[style*="color"]:not([style*="background"]),
.prose p[style*="color"]:not([style*="background"]),
.prose font[color] { color: var(--text) !important; }

.sidebar { align-self:start; position:sticky; top:90px; display:flex; flex-direction:column; gap: var(--gap); }
.widget { background: var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px; }
.widget h4 { font-size:.95rem; text-transform:uppercase; letter-spacing:.05em; margin-bottom:.9rem; padding-bottom:.7rem; border-bottom:1px solid var(--line); }
.widget h4 span { color: var(--accent); }
.toc-list, .mini-list { display:flex; flex-direction:column; gap:.55rem; font-size:.92rem; }
.mini-list a { color: var(--text-dim); display:flex; gap:.6rem; align-items:flex-start; }
.mini-list a:hover { color: var(--accent); }
.mini-list .n { color: var(--accent); font-family:var(--font-display); font-weight:700; }

/* author box */
.author-box { display:flex; gap:1rem; align-items:center; padding:18px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); margin-top: 2.4rem; }
.author-box img { width:56px; height:56px; border-radius:50%; border:2px solid var(--accent); }
.author-box .n { font-family:var(--font-display); font-weight:700; text-transform:uppercase; }
.author-box .r { color:var(--text-mute); font-size:.85rem; }

/* post nav */
.post-nav { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:2.4rem; }
.post-nav a { padding:16px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); transition:.2s var(--ease); }
.post-nav a:hover { border-color:var(--accent); }
.post-nav .lbl { font-family:var(--font-display); font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--accent); }
.post-nav .t { margin-top:.4rem; font-weight:600; color:var(--text); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.post-nav .next { text-align:right; }

/* ----------------------------- commentaires ----------------------- */
.comments-area, .comment-respond, #comments { margin-top: 2.6rem; }
.comments-title, .comment-reply-title { font-family:var(--font-display); text-transform:uppercase; font-size: clamp(1.3rem,2.4vw,1.6rem); margin-bottom:.5rem; letter-spacing:-.01em; }
.comment-reply-title small { font-weight:400; font-size:.85rem; margin-left:.5rem; }
.comment-reply-title small a { color: var(--accent); }
.comment-notes, .comment-form-cookies-consent label, .logged-in-as { color: var(--text-mute); font-size:.9rem; }
.comment-notes .required { color: var(--accent); }
.comment-form { display:grid; gap:1.1rem; margin-top:1.3rem; }
.comment-form p { margin:0; }
.comment-form label { display:block; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-dim); margin-bottom:.4rem; }
.comment-form input[type=text], .comment-form input[type=email], .comment-form input[type=url], .comment-form textarea {
  width:100%; background: var(--bg-2); border:1px solid var(--line); color:var(--text);
  padding:.7rem .9rem; border-radius:3px; font:inherit; outline:none; transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.comment-form input:focus, .comment-form textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 18%, transparent); }
.comment-form textarea { min-height:150px; resize:vertical; }
.comment-form-cookies-consent { display:flex; align-items:flex-start; gap:.55rem; }
.comment-form-cookies-consent input[type=checkbox] { margin-top:.15rem; width:16px; height:16px; accent-color: var(--accent); flex-shrink:0; }
.comment-form .form-submit { margin:0; }
.comment-form #submit, #respond #submit, .comment-form input[type=submit] {
  font-family:var(--font-display); font-weight:600; font-size:.86rem; letter-spacing:.06em; text-transform:uppercase;
  background: var(--accent); color: var(--accent-ink); border:0; padding:.78rem 1.4rem; cursor:pointer;
  clip-path: polygon(0 0, 100% 0, 100% 68%, calc(100% - 12px) 100%, 0 100%); transition: box-shadow .2s var(--ease), transform .2s var(--ease);
}
.comment-form #submit:hover, .comment-form input[type=submit]:hover { box-shadow: var(--glow); transform: translateY(-1px); }
@media (min-width:680px){
  .comment-form { grid-template-columns:1fr 1fr 1fr; }
  .comment-form-comment, .comment-form-cookies-consent, .comment-form .form-submit, .comment-notes, .logged-in-as { grid-column:1/-1; }
}
/* commentaires existants */
.comment-list { list-style:none; padding:0; margin:2.2rem 0 0; display:flex; flex-direction:column; gap:1rem; }
.comment-list ol.children { list-style:none; margin:1rem 0 0 1.2rem; padding-left:1rem; border-left:1px solid var(--line); display:flex; flex-direction:column; gap:1rem; }
.comment-list .comment-body { background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--accent); border-radius:var(--radius); padding:14px 16px; }
.comment-author { display:flex; align-items:center; gap:.6rem; }
.comment-author .avatar { border-radius:50%; border:1px solid var(--line); }
.comment-author .fn { font-family:var(--font-display); color:var(--text); font-style:normal; }
.comment-metadata, .comment-metadata a { color:var(--text-mute); font-size:.82rem; }
.comment-content { margin-top:.6rem; color:var(--text-dim); }
.comment-reply-link, .comment-edit-link { color:var(--accent); font-size:.84rem; }

/* ------------------------------ pagination ------------------------- */
.pagination { margin-top: calc(var(--gap)*1.5); }
.pagination .nav-links { display:flex; justify-content:center; align-items:center; gap:.4rem; flex-wrap:wrap; }
.pagination .page-numbers { display:grid; place-items:center; min-width:42px; height:42px; padding:0 .6rem; border:1px solid var(--line); border-radius:2px; font-family:var(--font-display); color:var(--text-dim); transition:.2s var(--ease); }
.pagination .page-numbers:hover, .pagination .current { color:var(--accent); border-color:var(--accent); background:color-mix(in srgb,var(--accent) 8%, transparent); }

/* ------------------------------ footer ----------------------------- */
.site-footer { border-top:1px solid var(--line); margin-top: clamp(40px,6vw,80px); background: var(--bg-2); }
.footer-top { display:grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--gap); padding-block: clamp(34px,5vw,56px); }
.footer-brand .logo-mark { font-family:var(--font-display); font-weight:700; font-size:1.4rem; }
.footer-brand .logo-mark b { color:var(--accent); }
.footer-brand .footer-logo { max-width: 210px; height:auto; display:block; }
.footer-brand p { color:var(--text-mute); margin-top:.7rem; max-width:42ch; }
.footer-col h5 { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.08em; font-size:.82rem; color:var(--accent); margin-bottom:.9rem; }
.footer-col a { display:block; color:var(--text-dim); padding:.28rem 0; transition:.15s; }
.footer-col a:hover { color:var(--accent); padding-left:.3rem; }
.footer-bottom { border-top:1px solid var(--line); padding-block:18px; display:flex; justify-content:space-between; gap:1rem; color:var(--text-mute); font-size:.85rem; flex-wrap:wrap; }

/* partenaires (page dédiée) */
.partners-section .wrap { padding-block: clamp(20px,3vw,36px); }
.partners-head { display:flex; align-items:baseline; gap:.8rem; flex-wrap:wrap; margin-bottom:1.3rem; }
.partners-title { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-size:1.1rem; color:var(--text); }
.partners-sub { color:var(--text-mute); font-size:.86rem; }
.partners-grid { display:flex; flex-direction:column; gap:1.4rem; }

.partner { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:14px 16px; }
.partner-head { display:flex; align-items:center; justify-content:space-between; gap:.8rem; margin-bottom:.9rem; }
.partner-name { display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-display); font-weight:600; font-size:1rem; color:var(--text); letter-spacing:.02em; }
.partner-name:hover { color:var(--accent); }
.plat-mark { display:inline-grid; place-items:center; width:24px; height:24px; border-radius:5px; font-size:.72rem; color:#fff; }
.plat-mark.yt { background:#ff0033; }
.plat-mark.tw { background:#9146ff; }
.partner-cta { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.05em; font-size:.7rem; color:var(--accent); border:1px solid color-mix(in srgb,var(--accent) 40%,var(--line)); padding:.3em .7em; border-radius:3px; transition:.15s; }
.partner-cta:hover { background:color-mix(in srgb,var(--accent) 14%,transparent); }
.partner-plat { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.06em; font-size:.7rem; color:var(--text-mute); }

.partner-vids { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:.7rem; }
.pv { display:flex; flex-direction:column; gap:.4rem; color:var(--text-dim); }
.pv-thumb { display:block; border:1px solid var(--line); border-radius:4px; overflow:hidden; background:var(--bg-2); position:relative; }
.pv-thumb img { display:block; width:100%; aspect-ratio:16/9; object-fit:cover; transition:transform .25s var(--ease); }
.pv:hover .pv-thumb { border-color:color-mix(in srgb,var(--accent) 55%,var(--line)); }
.pv:hover .pv-thumb img { transform:scale(1.05); }
.pv-title { font-size:.78rem; line-height:1.3; color:var(--text-dim); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pv:hover .pv-title { color:var(--text); }
.partner-empty { color:var(--text-mute); font-size:.85rem; }

.partner-twitch .twitch-card { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:14px 16px; border:1px solid color-mix(in srgb,#9146ff 35%,var(--line)); border-left:3px solid #9146ff; border-radius:var(--radius); background:color-mix(in srgb,#9146ff 9%,var(--bg-2)); transition:.18s; }
.partner-twitch .twitch-card:hover { border-color:#9146ff; background:color-mix(in srgb,#9146ff 16%,var(--bg-2)); }
.twitch-card-txt strong { display:block; font-family:var(--font-display); color:var(--text); font-size:1rem; }
.twitch-card-txt span { color:var(--text-mute); font-size:.82rem; }
.twitch-go { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.05em; font-size:.74rem; color:#b794ff; white-space:nowrap; }

@media (max-width: 1100px) { .partner-vids { grid-template-columns:repeat(4,1fr); } }
@media (max-width: 640px) {
  .partner-vids { grid-auto-flow:column; grid-auto-columns:minmax(150px,55%); grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:.4rem; }
  .partner-vids .pv { scroll-snap-align:start; }
}

/* ------------------------------ search overlay --------------------- */
.search-overlay { position:fixed; inset:0; z-index:100; background:rgba(9,12,17,.96); backdrop-filter:blur(8px); display:none; place-items:start center; padding-top:18vh; }
.search-overlay.open { display:grid; }
.search-overlay form { width:min(92%,640px); }
.search-overlay input { width:100%; background:transparent; border:none; border-bottom:2px solid var(--accent); color:var(--text); font-family:var(--font-display); font-size:clamp(1.5rem,5vw,2.6rem); padding:.4rem 0; outline:none; }
.search-overlay .hint { color:var(--text-mute); margin-top:1rem; font-size:.9rem; }
.search-close { position:absolute; top:24px; right:24px; }

/* ------------------------------ responsive ------------------------- */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns:1fr; }
  .hero-side { grid-template-rows:none; grid-template-columns:repeat(3,1fr); }
  .article-layout { grid-template-columns:1fr; }
  .sidebar { position:static; }
  .footer-top { grid-template-columns:1fr 1fr; }
}
@media (max-width: 720px) {
  body { background-size: auto,auto,34px 34px,34px 34px; }
  :root { --header-h: 84px; }
  .nav-games { display:none; position:fixed; inset:var(--header-h) 0 auto 0; flex-direction:column; align-items:stretch; gap:0; background:var(--bg-2); border-bottom:1px solid var(--line); padding:10px; }
  .nav-games.open { display:flex; }
  .game-pill { padding:.8rem 1rem; border:none; border-bottom:1px solid var(--line-soft); }
  .nav-cta { justify-content:center; margin:.6rem 0 0; clip-path:none; padding:.9rem 1rem; }
  .nav-toggle { display:grid; }
  .hero-side { grid-template-columns:1fr; }
  .post-nav, .footer-top { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { animation:none !important; transition:none !important; } }
