/*
Theme Name: GTA CHEAT V1
Theme URI: https://cybernc.com/gta-cheat
Author: CyberNC
Author URI: https://cybernc.com
Description: Premium multi-ambiance theme blending the whole GTA saga — San Andreas cartoon, GTA IV grit, GTA V neon and Vice City sunset. Hybrid palette, HUD header, category-driven homepage builder, 4 ambiances (Dark, Light, Neon, Retro) and a full admin panel.
Version: 2.012
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gta-cheat
Tags: dark, light, custom-colors, custom-header, custom-menu, featured-images, theme-options, translation-ready, blog, two-columns, right-sidebar

GTA CHEAT V1 is an independent, fan-made theme inspired by an aesthetic. "Grand Theft Auto" and the saga titles are trademarks of Take-Two Interactive / Rockstar Games. This theme is neither affiliated with nor endorsed by those rights holders.
*/

/* =================================================================
   GTA CHEAT V1 — DESIGN TOKENS
   Palette hybride : IV (asphalte) · Vice City (néon) · SA (argent/or) · V (trio)
   ================================================================= */
:root {
  /* — Neutres : base granuleuse GTA IV — */
  --ink:        #0b0e13;
  --night:      #11151c;
  --asphalt:    #161c25;
  --panel:      #1b222d;
  --panel-2:    #212a37;
  --steel:      #2b3543;
  --steel-2:    #3a4757;
  --smoke:      #8b97a6;
  --ash:        #aeb8c4;
  --chrome:     #e9eef4;
  --white:      #ffffff;

  /* — Vice City : coucher de soleil tropical — */
  --vice-pink:    #ff2e88;
  --vice-magenta: #e21d6e;
  --vice-cyan:    #2de2e6;
  --vice-purple:  #7a3ff2;
  --sunset:       #ff7a18;
  --sunset-2:     #ffb347;

  /* — San Andreas : argent / Grove / or — */
  --money:  #4caf50;
  --grove:  #6a9b35;
  --gold:   #f4c04e;

  /* — GTA V : le trio Michael / Franklin / Trevor — */
  --v-blue:   #19a7e0;
  --v-green:  #57b956;
  --v-orange: #f2a03d;

  /* — Jetons sémantiques (réécrits par variante + personnalisateur) — */
  --bg:          var(--ink);
  --bg-grad-1:   #0b0e13;
  --bg-grad-2:   #141a23;
  --bg-elev:     var(--asphalt);
  --surface:     var(--panel);
  --surface-2:   var(--panel-2);
  --border:      var(--steel);
  --border-2:    var(--steel-2);
  --text:        var(--chrome);
  --text-muted:  var(--smoke);
  --heading:     var(--white);
  --accent:      var(--vice-pink);
  --accent-2:    var(--vice-cyan);
  --accent-3:    var(--gold);
  --money-clr:   var(--money);
  --link:        var(--vice-cyan);
  --link-hover:  var(--vice-pink);
  --glow:        0 0 0 rgba(0,0,0,0);     /* activé en variante Néon */
  --hazard:      var(--gold);

  /* — Typo — */
  --font-display: "Anton", "Oswald", Impact, "Haettenschweiler", sans-serif;
  --font-ui:      "Oswald", "Bebas Neue", "Arial Narrow", sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* — Rythme / formes — */
  --maxw:       1200px;
  --maxw-text:  720px;
  --radius:     14px;
  --radius-sm:  8px;
  --gap:        clamp(16px, 2.4vw, 28px);
  --cut:        14px;            /* taille de chanfrein HUD (clip-path) */
  --ease:       cubic-bezier(.2,.7,.2,1);
  --shadow-1:   0 1px 0 rgba(255,255,255,.04), 0 6px 22px rgba(0,0,0,.45);
  --shadow-2:   0 18px 50px rgba(0,0,0,.55);

  /* — Textures urbaines légères (data-URI, faible opacité) — */
  --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}

/* =================================================================
   RESET & BASE
   ================================================================= */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: clamp(15px, 1.05vw, 17px);
  line-height: 1.65;
  color: var(--text);
  background-color: var(--bg);
  background-image:
    radial-gradient(1200px 600px at 85% -10%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 60%),
    radial-gradient(900px 500px at 0% 0%, color-mix(in srgb, var(--accent-2) 9%, transparent), transparent 55%),
    linear-gradient(180deg, var(--bg-grad-1), var(--bg-grad-2));
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Texture de grain globale, très discrète */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image: var(--grain);
  background-size: 180px 180px;
  opacity: .035;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: overlay;
}

img, picture, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--link); text-decoration: none; transition: color .18s var(--ease); }
a:hover { color: var(--link-hover); }
::selection { background: var(--accent); color: #fff; }

/* =================================================================
   TYPOGRAPHIE
   ================================================================= */
h1, h2, h3, h4, h5, h6 { color: var(--heading); line-height: 1.06; font-weight: 400; }
h1, h2 { font-family: var(--font-display); letter-spacing: .5px; text-transform: uppercase; }
h3, h4, h5, h6 { font-family: var(--font-ui); font-weight: 600; letter-spacing: .3px; }

h1 { font-size: clamp(2.4rem, 6vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.75rem); text-transform: uppercase; }
h4 { font-size: 1.2rem; }

p, ul, ol, blockquote, figure, table, pre { margin-bottom: 1.1em; }
p { max-width: var(--maxw-text); }
strong, b { color: var(--heading); font-weight: 700; }

blockquote {
  border-left: 4px solid var(--accent);
  padding: .4em 1.2em;
  background: color-mix(in srgb, var(--surface) 60%, transparent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--ash);
  font-style: italic;
}
blockquote cite { display:block; margin-top:.5em; font-style: normal; color: var(--accent-2); font-family: var(--font-ui); text-transform: uppercase; letter-spacing:.5px; font-size:.85em; }

code, kbd, pre { font-family: var(--font-mono); font-size: .92em; }
:not(pre) > code { background: var(--night); border: 1px solid var(--border); padding: .12em .4em; border-radius: 5px; color: var(--accent-2); }
pre { background: var(--night); border: 1px solid var(--border); border-left: 3px solid var(--accent); padding: 1.1em 1.3em; border-radius: var(--radius-sm); overflow:auto; }

hr { border: 0; height: 1px; margin: 2.2em 0; background: linear-gradient(90deg, transparent, var(--border-2), transparent); }

/* Petit label HUD réutilisable */
.kicker {
  font-family: var(--font-ui);
  text-transform: uppercase;
  letter-spacing: 3px;
  font-size: .76rem;
  font-weight: 600;
  color: var(--accent-2);
  display: inline-flex;
  align-items: center;
  gap: .55em;
}
.kicker::before { content:""; width: 26px; height: 2px; background: var(--accent); display:inline-block; }

/* =================================================================
   LAYOUT
   ================================================================= */
.wrap { width: min(100% - 2.4rem, var(--maxw)); margin-inline: auto; }
.section { padding-block: clamp(48px, 8vw, 110px); }
.grid { display: grid; gap: var(--gap); }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px){ .cols-3,.cols-4 { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .cols-2,.cols-3,.cols-4 { grid-template-columns: 1fr; } }

.content-area { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: clamp(28px, 4vw, 56px); }
@media (max-width: 980px){ .content-area { grid-template-columns: 1fr; } }
.skip-link { position:absolute; left:-9999px; }
.skip-link:focus { left:1rem; top:1rem; z-index:10000; background:var(--accent); color:#fff; padding:.6em 1em; border-radius:6px; }

/* =================================================================
   BOUTONS — chanfreinés style HUD
   ================================================================= */
.btn {
  --c: var(--accent);
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--font-ui);
  font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
  font-size: .92rem;
  padding: .78em 1.5em;
  color: #0b0e13;
  background: var(--c);
  border: none; cursor: pointer;
  clip-path: polygon(var(--cut) 0, 100% 0, 100% calc(100% - var(--cut)), calc(100% - var(--cut)) 100%, 0 100%, 0 var(--cut));
  position: relative;
  transition: transform .15s var(--ease), filter .2s var(--ease), box-shadow .2s var(--ease);
  box-shadow: var(--glow);
}
.btn:hover { transform: translateY(-2px); filter: brightness(1.08); color:#0b0e13; box-shadow: 0 8px 26px color-mix(in srgb, var(--c) 45%, transparent); }
.btn:active { transform: translateY(0); }
.btn--ghost {
  background: transparent; color: var(--text);
  box-shadow: inset 0 0 0 2px var(--border-2);
  clip-path: polygon(var(--cut) 0, 100% 0, 100% calc(100% - var(--cut)), calc(100% - var(--cut)) 100%, 0 100%, 0 var(--cut));
}
.btn--ghost:hover { color: var(--heading); box-shadow: inset 0 0 0 2px var(--accent-2); }
.btn--money { --c: var(--money-clr); }
.btn--cyan  { --c: var(--accent-2); }
.btn--gold  { --c: var(--accent-3); }
.btn--lg { font-size: 1rem; padding: .95em 1.9em; }

/* =================================================================
   CARTES
   ================================================================= */
.card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), var(--surface));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  transition: transform .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.card::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(120deg, transparent 60%, color-mix(in srgb, var(--accent) 14%, transparent));
  opacity:0; transition: opacity .3s var(--ease);
}
.card:hover { transform: translateY(-4px); border-color: var(--border-2); box-shadow: var(--shadow-2); }
.card:hover::after { opacity: 1; }
.card__media { aspect-ratio: 16/10; overflow:hidden; position:relative; }
.card__media img { width:100%; height:100%; object-fit: cover; transition: transform .5s var(--ease); }
.card:hover .card__media img { transform: scale(1.06); }
.card__body { padding: 1.2rem 1.3rem 1.5rem; }
.card__title { font-family: var(--font-ui); font-weight: 600; font-size: 1.25rem; text-transform: uppercase; letter-spacing:.4px; }
.card__title a { color: var(--heading); }
.card__title a:hover { color: var(--accent); }
.card__meta { display:flex; flex-wrap:wrap; gap: .4rem 1rem; color: var(--text-muted); font-family: var(--font-ui); text-transform: uppercase; letter-spacing:.6px; font-size:.78rem; margin: .5rem 0 .8rem; }
.card__excerpt { color: var(--ash); }

/* Badge / catégorie en pastille HUD */
.tag {
  display:inline-flex; align-items:center; gap:.4em;
  font-family: var(--font-ui); text-transform: uppercase; letter-spacing:1px;
  font-size:.72rem; font-weight:600;
  padding:.3em .7em; border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}
.tag--cyan { background: color-mix(in srgb, var(--accent-2) 16%, transparent); color: var(--accent-2); border-color: color-mix(in srgb, var(--accent-2) 35%, transparent); }
.tag--money{ background: color-mix(in srgb, var(--money-clr) 16%, transparent); color: var(--money-clr); border-color: color-mix(in srgb, var(--money-clr) 35%, transparent); }
.tag--gold { background: color-mix(in srgb, var(--accent-3) 18%, transparent); color: var(--accent-3); border-color: color-mix(in srgb, var(--accent-3) 35%, transparent); }

/* =================================================================
   SITE HEADER / NAV
   ================================================================= */
.site-header { position: relative; z-index: 50; }

/* Barre HUD supérieure : horloge, argent, étoiles */
.hud-bar {
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--night) 80%, transparent);
  backdrop-filter: blur(6px);
  font-family: var(--font-ui);
  text-transform: uppercase; letter-spacing: 1px; font-size: .76rem;
}
.hud-bar__in { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.5rem 0; min-height: 40px; }
.hud-bar__group { display:flex; align-items:center; gap: 1.1rem; color: var(--text-muted); }
.hud-bar__item { display:inline-flex; align-items:center; gap:.45em; white-space:nowrap; }
.hud-bar__item svg { width:16px; height:16px; }

/* Barre de navigation principale */
.nav-bar {
  position: sticky; top: 0; z-index: 60;
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(12px) saturate(1.2);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .3s var(--ease), background .3s var(--ease);
}
.nav-bar.is-stuck { box-shadow: 0 10px 30px rgba(0,0,0,.45); }
.nav-bar__in { display:flex; align-items:center; gap: 1.4rem; min-height: 72px; }

.brand { display:flex; align-items:center; gap:.7rem; margin-right:auto; min-width:0; }
.brand__logo { width: 42px; height: 42px; flex:0 0 auto; }   /* repère SVG (fallback) */
/* Logo image (custom-logo WP ou option dédiée) — hauteur réglable, ratio respecté */
.custom-logo, .brand__img { height: var(--logo-h, 48px); width:auto; max-width:min(62vw,300px); object-fit:contain; display:block; }
.custom-logo-link, .brand__imglink { display:inline-flex; align-items:center; line-height:0; flex:0 0 auto; }
.brand__text { display:flex; flex-direction:column; min-width:0; text-decoration:none; }
.brand__name {
  font-family: var(--font-display); text-transform: uppercase;
  font-size: 1.7rem; line-height: 1; letter-spacing: .5px;
  color: var(--heading);
  background: linear-gradient(92deg, var(--accent-3), var(--accent), var(--accent-2));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.brand__sub { display:block; font-family:var(--font-ui); font-size:.62rem; letter-spacing:3px; color:var(--text-muted); text-transform:uppercase; -webkit-text-fill-color: var(--text-muted); }

.main-nav ul { list-style:none; display:flex; align-items:center; gap: .3rem; padding:0; margin:0; }
.main-nav a {
  display:block; padding: .55em .9em;
  font-family: var(--font-ui); text-transform: uppercase; letter-spacing: 1.3px;
  font-size: .9rem; font-weight: 500; color: var(--text);
  position: relative; border-radius: 6px;
}
.main-nav a::after {
  content:""; position:absolute; left:.9em; right:.9em; bottom:.35em; height:2px;
  background: var(--accent); transform: scaleX(0); transform-origin: left;
  transition: transform .22s var(--ease);
}
.main-nav a:hover, .main-nav .current-menu-item > a { color: var(--heading); }
.main-nav a:hover::after, .main-nav .current-menu-item > a::after { transform: scaleX(1); }
.main-nav .sub-menu {
  position:absolute; top:100%; left:0; min-width: 220px;
  background: var(--surface); border:1px solid var(--border); border-radius: var(--radius-sm);
  padding:.4rem; flex-direction:column; gap:0; box-shadow: var(--shadow-2);
  opacity:0; visibility:hidden; transform: translateY(8px); transition: all .2s var(--ease);
}
.main-nav li { position:relative; }
.main-nav li:hover > .sub-menu { opacity:1; visibility:visible; transform: translateY(0); }
.main-nav .sub-menu a::after { display:none; }
.main-nav .sub-menu a:hover { background: var(--panel-2); }

.nav-toggle { display:none; background:none; border:1px solid var(--border-2); color:var(--text); width:46px; height:42px; border-radius:8px; cursor:pointer; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after { content:""; display:block; width:20px; height:2px; background:currentColor; margin:0 auto; position:relative; transition:.25s var(--ease); }
.nav-toggle span::before { position:absolute; top:-6px; } .nav-toggle span::after { position:absolute; top:6px; }
.nav-open .nav-toggle span { background:transparent; }
.nav-open .nav-toggle span::before { transform: rotate(45deg); top:0; }
.nav-open .nav-toggle span::after { transform: rotate(-45deg); top:0; }

/* Bouton loupe + panneau de recherche (s'ouvre sous le header) */
.nav-search-toggle { background:none; border:0; color:var(--text); padding:.35em; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; transition:color .2s var(--ease), transform .2s var(--ease); }
.nav-search-toggle:hover { color:var(--accent-2); transform:scale(1.08); }
.nav-search-toggle svg { width:21px; height:21px; }
.search-open .nav-search-toggle { color:var(--accent); }

.site-search { position:absolute; top:100%; left:0; right:0; background:color-mix(in srgb, var(--bg) 96%, transparent); backdrop-filter:blur(12px); border-top:1px solid var(--border); border-bottom:1px solid var(--border); box-shadow:var(--shadow-2); opacity:0; visibility:hidden; transform:translateY(-12px); transition:opacity .25s var(--ease), transform .25s var(--ease), visibility .25s; z-index:55; }
.search-open .site-search { opacity:1; visibility:visible; transform:none; }
.site-search__in { display:flex; align-items:center; gap:.8rem; padding-block:1.1rem; }
.site-search__form { flex:1; display:flex; align-items:center; gap:.7rem; background:var(--night); border:1px solid var(--border-2); border-radius:999px; padding:.4rem .5rem .4rem 1.1rem; transition:border-color .2s var(--ease), box-shadow .2s var(--ease); }
.site-search__form:focus-within { border-color:var(--accent-2); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent-2) 22%, transparent); }
.site-search__submit { background:none; border:0; padding:0; margin:0; color:var(--text-muted); cursor:pointer; display:inline-flex; align-items:center; flex:0 0 auto; transition:color .2s var(--ease); }
.site-search__submit:hover { color:var(--accent); }
.site-search__submit svg { width:22px; height:22px; }
.site-search__input { flex:1; width:auto; background:none; border:0; padding:.5em 0; font-size:1.1rem; color:var(--text); }
.site-search__input:focus { outline:none; box-shadow:none; border:0; }
.site-search__form .btn { flex:0 0 auto; }
.site-search__close { background:none; border:0; color:var(--text-muted); font-size:1.6rem; line-height:1; cursor:pointer; padding:0 .3rem; flex:0 0 auto; }
.site-search__close:hover { color:var(--accent); }
@media (max-width:520px){ .site-search__form .btn { display:none; } }

@media (max-width: 860px){
  .nav-toggle { display:block; }
  /* Menu déroulant ancré sous la barre (le backdrop-filter du parent
     crée un bloc conteneur : on positionne en absolu, pas en fixed). */
  .main-nav {
    position:absolute; top:100%; left:0; right:0;
    background:var(--bg); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    box-shadow: var(--shadow-2);
    opacity:0; visibility:hidden; transform: translateY(-8px);
    transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
    max-height: calc(100vh - 112px); overflow-y:auto;
  }
  .nav-open .main-nav { opacity:1; visibility:visible; transform: translateY(0); }
  .main-nav ul { flex-direction:column; align-items:stretch; padding:1rem; gap:.2rem; }
  .main-nav .sub-menu { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; background:transparent; border:none; padding-left:1rem; }
}

/* =================================================================
   HERO MULTI-AMBIANCE
   ================================================================= */
.hero { position: relative; overflow: hidden; padding-block: clamp(60px, 11vw, 150px); }
.hero__bg { position:absolute; inset:0; z-index:0; }
/* 4 couches d'ambiance superposées : IV → Vice → V → SA */
.hero__bg::before {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, transparent 35%, color-mix(in srgb, var(--vice-purple) 30%, transparent) 78%, color-mix(in srgb, var(--sunset) 30%, transparent) 100%),
    radial-gradient(120% 80% at 80% 0%, color-mix(in srgb, var(--vice-pink) 28%, transparent), transparent 55%),
    radial-gradient(90% 70% at 10% 10%, color-mix(in srgb, var(--vice-cyan) 16%, transparent), transparent 50%);
}
/* lignes de grille type mini-map */
.hero__bg::after {
  content:""; position:absolute; inset:0; opacity:.5;
  background-image:
    linear-gradient(color-mix(in srgb, var(--accent-2) 8%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--accent-2) 8%, transparent) 1px, transparent 1px);
  background-size: 46px 46px; mask-image: radial-gradient(80% 80% at 50% 40%, #000, transparent 75%);
}
/* soleil Vice City */
.hero__sun {
  position:absolute; right: 8%; top: 18%; width: clamp(120px, 22vw, 280px); aspect-ratio:1; z-index:1;
  background: radial-gradient(circle at 50% 50%, var(--sunset-2), var(--vice-pink) 55%, transparent 70%);
  border-radius:50%; filter: blur(2px) saturate(1.2); opacity:.9;
  mask-image: repeating-linear-gradient(180deg, #000 0 12px, transparent 12px 20px);
  -webkit-mask-image: repeating-linear-gradient(180deg, #000 0 12px, transparent 12px 20px);
}
.hero .wrap { position: relative; z-index: 2; }
.hero__title { font-size: clamp(2.8rem, 8vw, 6rem); margin: .2em 0 .35em; text-shadow: 0 6px 30px rgba(0,0,0,.5); }
.hero__title .hl { color: var(--accent); -webkit-text-fill-color: var(--accent); }
.hero__lead { font-size: clamp(1.05rem, 1.8vw, 1.3rem); color: var(--ash); max-width: 56ch; }
.hero__cta { display:flex; flex-wrap:wrap; gap: .9rem; margin-top: 2rem; }

/* Bandeau « ambiances » sous le hero */
.ambiance-strip { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:2.6rem; }
.ambiance-chip {
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-ui); text-transform:uppercase; letter-spacing:1px; font-size:.74rem;
  padding:.45em .8em; border-radius:999px; border:1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 70%, transparent); color: var(--ash);
}
.ambiance-chip i { width:9px; height:9px; border-radius:50%; display:inline-block; }

/* =================================================================
   ENTRÉES / ARTICLES (boucle)
   ================================================================= */
.entry { margin-bottom: 2.4rem; }
.entry__header { margin-bottom: 1.2rem; }
.entry__title { margin-bottom:.4rem; }
.entry__title a { color: var(--heading); }
.entry__title a:hover { color: var(--accent); }
.entry__meta { display:flex; flex-wrap:wrap; gap:.4rem 1.1rem; color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.6px; font-size:.8rem; }
.entry__meta svg { width:15px; height:15px; vertical-align:-2px; margin-right:.25em; color:var(--accent-2); }
.entry__content > * { max-width: var(--maxw-text); }
.entry__content img { border-radius: var(--radius-sm); }
.featured { border-radius: var(--radius); overflow:hidden; margin-bottom:1.4rem; border:1px solid var(--border); }

.pagination { display:flex; gap:.4rem; flex-wrap:wrap; margin-top:2rem; }
.pagination .page-numbers {
  font-family:var(--font-ui); min-width:44px; height:44px; display:inline-flex; align-items:center; justify-content:center;
  padding:0 .7em; border:1px solid var(--border); border-radius:8px; color:var(--text); font-weight:600;
}
.pagination .current { background:var(--accent); color:#0b0e13; border-color:var(--accent); }
.pagination a.page-numbers:hover { border-color:var(--accent-2); color:var(--heading); }

/* =================================================================
   SIDEBAR / WIDGETS
   ================================================================= */
.widget { background: var(--surface); border:1px solid var(--border); border-radius: var(--radius); padding:1.3rem 1.4rem; margin-bottom:1.4rem; }
.widget-title { font-family:var(--font-ui); text-transform:uppercase; letter-spacing:1px; font-size:1rem; color:var(--heading); margin-bottom:1rem; padding-bottom:.6rem; border-bottom:1px solid var(--border); position:relative; }
.widget-title::after { content:""; position:absolute; left:0; bottom:-1px; width:48px; height:2px; background:var(--accent); }
.widget ul { list-style:none; padding:0; margin:0; }
.widget li { padding:.45em 0; border-bottom:1px dashed var(--border); }
.widget li:last-child { border-bottom:0; }
.widget a { color:var(--ash); } .widget a:hover { color:var(--accent-2); }

/* =================================================================
   FORMULAIRES
   ================================================================= */
input[type=text], input[type=email], input[type=url], input[type=password],
input[type=search], input[type=tel], input[type=number], textarea, select {
  width:100%; font-family: var(--font-body); font-size:1rem; color:var(--text);
  background: var(--night); border:1px solid var(--border); border-radius: var(--radius-sm);
  padding:.7em .9em; transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
input:focus, textarea:focus, select:focus { outline:none; border-color: var(--accent-2); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-2) 22%, transparent); }
label { font-family: var(--font-ui); text-transform: uppercase; letter-spacing:.5px; font-size:.82rem; color:var(--ash); display:block; margin-bottom:.4em; }
.search-form { display:flex; gap:.5rem; }
.search-form input { flex:1; }

/* =================================================================
   COMMENTAIRES
   ================================================================= */
.comment-list { list-style:none; padding:0; }
.comment-body { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.1rem 1.3rem; margin-bottom:1rem; }
.comment-author { font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; color:var(--heading); }
.comment-meta { color:var(--text-muted); font-size:.8rem; }
.comment-list .children { list-style:none; margin-left:1.5rem; padding-left:1rem; border-left:2px solid var(--border); }

/* =================================================================
   FOOTER
   ================================================================= */
.site-footer { border-top:1px solid var(--border); margin-top: clamp(60px,9vw,120px); background: color-mix(in srgb, var(--night) 70%, transparent); position:relative; }
.site-footer::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background: linear-gradient(90deg, var(--accent-3), var(--accent), var(--accent-2), var(--vice-purple)); }
.footer-grid { display:grid; grid-template-columns: 1.4fr repeat(3,1fr); gap: var(--gap); padding-block: clamp(40px,6vw,72px); }
@media (max-width: 860px){ .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .footer-grid { grid-template-columns: 1fr; } }
.footer-bottom { border-top:1px solid var(--border); padding-block:1.2rem; display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:1px; font-size:.78rem; }

/* =================================================================
   WORDPRESS CORE (alignements, légendes, galeries, a11y)
   ================================================================= */
.alignleft  { float:left;  margin: .3rem 1.4rem 1rem 0; }
.alignright { float:right; margin: .3rem 0 1rem 1.4rem; }
.aligncenter{ display:block; margin-inline:auto; }
.alignwide  { width: min(100%, calc(var(--maxw-text) + 180px)); margin-inline:auto; }
.alignfull  { width: 100vw; margin-inline: calc(50% - 50vw); }
.wp-caption-text, .wp-element-caption { color: var(--text-muted); font-size:.85rem; text-align:center; margin-top:.5rem; font-family:var(--font-ui); letter-spacing:.4px; }
.sticky .entry__title::before { content:"★ "; color: var(--accent-3); }
.screen-reader-text { position:absolute !important; width:1px; height:1px; overflow:hidden; clip:rect(1px,1px,1px,1px); white-space:nowrap; }
.bypostauthor { } /* requis par le contrôle de thème WP */

/* Icône miroir (flèche « précédent ») */
.gta-ico.flip { transform: scaleX(-1); }

/* Animations d'apparition (respecte prefers-reduced-motion) */
@media (prefers-reduced-motion: no-preference){
  .reveal { opacity:0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
  .reveal.is-in { opacity:1; transform:none; }
}

/* =================================================================
   HOMEPAGE — en-tête de section + entête de page léger
   ================================================================= */
.home-section { padding-block: clamp(28px, 4.5vw, 56px); }
.home-intro { padding: clamp(28px,5vw,52px) 0 0; }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem 1.4rem; margin-bottom:1.3rem; flex-wrap:wrap; }
.section-head__l { min-width:0; }
.section-head h2 { font-size: clamp(1.45rem,3vw,2.1rem); margin:.25rem 0 0; }
.section-head__h { display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; }
.section-head__img { max-height:56px; width:auto; display:block; }
.section-head .view-all {
  font-family:var(--font-ui); text-transform:uppercase; letter-spacing:1px; font-size:.8rem;
  color:var(--accent-2); display:inline-flex; align-items:center; gap:.4em; white-space:nowrap;
  border:1px solid var(--border-2); padding:.5em .9em; border-radius:999px; transition: border-color .2s var(--ease), color .2s var(--ease);
}
.section-head .view-all:hover { border-color:var(--accent-2); color:var(--heading); }
.section-head .view-all svg { width:15px; height:15px; }
.section-head__actions { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; justify-content:flex-end; }
/* Bouton CTA stratégique « CHEAT CODES … » — même forme que View all, rempli */
.section-head .view-all--cta { background:var(--row-accent,var(--accent)); color:#0b0e13; border-color:transparent; font-weight:700; }
.section-head .view-all--cta:hover { filter:brightness(1.08); color:#0b0e13; border-color:transparent; box-shadow:0 6px 18px color-mix(in srgb, var(--row-accent,var(--accent)) 40%, transparent); }

/* — placeholder média générique (article sans image à la une) — */
.media-ph { width:100%; height:100%; display:grid; place-items:center;
  background: linear-gradient(135deg, var(--night), color-mix(in srgb, var(--row-accent, var(--accent)) 38%, var(--asphalt))); }
.media-ph svg { width:40px; height:40px; opacity:.55; color:#fff; }

/* =================================================================
   FEATURED (catégorie à la une) — basé sur de vraies images
   ================================================================= */
.featured-grid { display:grid; grid-template-columns: 1.7fr 1fr; gap: clamp(16px,2vw,24px); }
@media (max-width: 880px){ .featured-grid { grid-template-columns:1fr; } }

.feat-lead { position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border-2); min-height:430px; display:flex; }
@media (max-width:880px){ .feat-lead{ min-height:320px; } }
.feat-lead__media { position:absolute; inset:0; }
.feat-lead__media img { width:100%; height:100%; object-fit:cover; }
.feat-lead__media::after { content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(7,9,13,.05) 0%, rgba(7,9,13,.5) 52%, rgba(7,9,13,.93) 100%); }
.feat-lead__body { position:relative; align-self:flex-end; padding: clamp(1.2rem,3vw,2.1rem); z-index:1; width:100%; }
.feat-lead__title { font-family:var(--font-display); text-transform:uppercase; font-size:clamp(1.6rem,3.4vw,2.7rem); line-height:1.02; margin:.55rem 0; }
.feat-lead__title a { color:#fff; } .feat-lead__title a:hover { color:var(--accent); }
.feat-lead__excerpt { color:#dde3ea; max-width:56ch; }
.feat-lead__meta { color:#c4ccd6; font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.6px; font-size:.76rem; display:flex; gap:.4rem 1rem; flex-wrap:wrap; margin-top:.6rem; }

.feat-list { display:flex; flex-direction:column; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; background:var(--surface); }
.feat-item { display:grid; grid-template-columns: 104px 1fr; gap:.9rem; padding:.85rem; border-bottom:1px solid var(--border); transition: background .2s var(--ease); }
.feat-item:last-child { border-bottom:0; }
.feat-item:hover { background: var(--surface-2); }
.feat-item__thumb { aspect-ratio:4/3; border-radius:8px; overflow:hidden; background:var(--night); }
.feat-item__thumb img { width:100%; height:100%; object-fit:cover; }
.feat-item__title { font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.3px; font-size:.98rem; line-height:1.18; }
.feat-item__title a { color:var(--heading); } .feat-item__title a:hover { color:var(--accent); }
.feat-item__meta { color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.68rem; margin-top:.3rem; }

/* =================================================================
   CATEGORY ROWS — articles bien délimités dans un row-bg-wrap
   ================================================================= */
.cat-row { padding-block: clamp(22px,3.2vw,40px); }
.row-bg-wrap {
  background: linear-gradient(180deg, color-mix(in srgb,var(--surface) 60%, transparent), color-mix(in srgb,var(--surface) 28%, transparent));
  border:1px solid var(--border);
  border-radius: calc(var(--radius) + 4px);
  padding: clamp(14px,2vw,22px);
}
.row-bg-wrap > .grid { gap: clamp(14px,1.8vw,20px); }

/* Carte d'article réutilisable, nettement délimitée (barre d'accent à gauche) */
.post-card {
  background: var(--bg-elev);
  border:1px solid var(--border-2);
  border-left:3px solid var(--row-accent, var(--accent));
  border-radius: var(--radius);
  overflow:hidden; display:flex; flex-direction:column; min-width:0;
  transition: transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: var(--border-2); border-left-color: var(--accent-2); }
.post-card__media { aspect-ratio:16/10; background:var(--night); overflow:hidden; display:block; }
.post-card__media img { width:100%; height:100%; object-fit:cover; transition: transform .5s var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { padding:1rem 1.1rem 1.15rem; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.post-card__title { font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.3px; font-size:1.08rem; line-height:1.2; }
.post-card__title a { color:var(--heading); } .post-card__title a:hover { color:var(--row-accent,var(--accent)); }
.post-card__excerpt { color:var(--ash); font-size:.92rem; }
.post-card__meta { color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.72rem; margin-top:auto; display:flex; gap:.4rem 1rem; flex-wrap:wrap; align-items:center; }
.post-card .tag { align-self:flex-start; }

/* =================================================================
   SINGLE POST — pleine largeur + bandeau image à la une
   ================================================================= */
.single-hero { position:relative; min-height:clamp(320px,46vw,560px); display:flex; align-items:flex-end; overflow:hidden; margin-bottom:clamp(20px,3vw,40px); }
.single-hero__media { position:absolute; inset:0; }
.single-hero__media img { width:100%; height:100%; object-fit:cover; }
.single-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(7,9,13,.1) 0%, rgba(7,9,13,.55) 55%, rgba(7,9,13,.96) 100%); }
.single-hero__inner { position:relative; z-index:1; padding-block:clamp(1.6rem,4vw,3rem); }
.single-hero__title { font-size:clamp(2rem,5vw,4rem); color:#fff; margin:.5rem 0; max-width:22ch; text-shadow:0 4px 30px rgba(0,0,0,.5); }
.single-hero .entry__meta { color:#cfd6df; }
.single-hero .entry__meta svg { color:var(--accent-2); }

.single-narrow { max-width:820px; margin-inline:auto; }
.single-narrow .entry__content { font-size:1.06rem; }
.single-narrow .entry__content > * { max-width:none; }
.read-next-sec { margin-top:clamp(36px,6vw,72px); }

/* =================================================================
   LAYOUT « LIST » — rangées horizontales (image + texte)
   ================================================================= */
.post-list { display:flex; flex-direction:column; gap:14px; }
.post-row { display:grid; grid-template-columns:clamp(180px,26%,300px) 1fr; gap:1.3rem; background:var(--bg-elev); border:1px solid var(--border-2); border-left:3px solid var(--row-accent,var(--accent)); border-radius:var(--radius); overflow:hidden; transition:transform .2s var(--ease), box-shadow .2s var(--ease); }
.post-row:hover { transform:translateY(-2px); box-shadow:var(--shadow-2); }
.post-row__media { display:block; background:var(--night); overflow:hidden; min-height:160px; }
.post-row__media img { width:100%; height:100%; object-fit:cover; }
.post-row__body { padding:1.1rem 1.3rem 1.1rem 0; display:flex; flex-direction:column; gap:.5rem; justify-content:center; }
.post-row__title { font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.3px; font-size:clamp(1.1rem,1.8vw,1.45rem); line-height:1.15; }
.post-row__title a { color:var(--heading); } .post-row__title a:hover { color:var(--row-accent,var(--accent)); }
.post-row__excerpt { color:var(--ash); font-size:.94rem; }
@media (max-width:640px){ .post-row { grid-template-columns:1fr; } .post-row__media { aspect-ratio:16/9; min-height:0; } .post-row__body { padding:0 1.2rem 1.2rem; } }

/* =================================================================
   LAYOUT « COMPACT » / READ-NEXT — image + titre
   ================================================================= */
.rn-card { display:flex; flex-direction:column; background:var(--bg-elev); border:1px solid var(--border-2); border-radius:var(--radius); overflow:hidden; transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease); }
.rn-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-2); border-color:var(--row-accent,var(--accent-2)); }
.rn-card__media { display:block; aspect-ratio:16/9; background:var(--night); overflow:hidden; }
.rn-card__media img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.rn-card:hover .rn-card__media img { transform:scale(1.05); }
.rn-card__body { padding:.85rem 1rem 1rem; display:flex; flex-direction:column; gap:.25rem; }
.rn-card__cat { font-family:var(--font-ui); text-transform:uppercase; letter-spacing:1px; font-size:.66rem; color:var(--row-accent,var(--accent-2)); }
.rn-card__title { font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.3px; font-size:1.02rem; line-height:1.2; color:var(--heading); }
.rn-card:hover .rn-card__title { color:var(--row-accent,var(--accent)); }
.rn-card__date { color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.7rem; margin-top:.2rem; }

/* =================================================================
   STOCK TICKER (Take-Two · auto-hébergé, SVG maison, aucun lien externe)
   ================================================================= */
.stock-band { border-bottom:1px solid var(--border); background:color-mix(in srgb, var(--night) 72%, transparent); }
.stock-band--footer { border-bottom:0; border-top:1px solid var(--border); }
.stock-band__in { padding-block:.55rem; display:flex; align-items:center; }

.stockx { display:flex; align-items:center; gap:1.4rem; font-family:var(--font-ui); width:100%; }
.stockx--tape { gap:2.2rem; overflow-x:auto; scrollbar-width:none; }
.stockx--tape::-webkit-scrollbar { display:none; }
.stockx__item { display:flex; align-items:center; gap:1rem; white-space:nowrap; min-width:0; }
.stockx__info { display:flex; align-items:baseline; gap:.6rem; }
.stockx__name { text-transform:uppercase; letter-spacing:.6px; font-weight:600; color:var(--text); font-size:.8rem; }
.stockx__price { font-family:var(--font-display); font-size:1.2rem; letter-spacing:.5px; color:var(--heading); }
.stockx__chg { font-weight:600; font-size:.82rem; }
.stockx__item.is-up .stockx__chg { color:var(--money-clr); }
.stockx__item.is-down .stockx__chg { color:#ff5b6e; }
.stockx__na { color:var(--text-muted); }
.stockx__chart { flex:0 0 auto; line-height:0; }
.spark { display:block; }
.stockx-mount { width:100%; }
.stock-band .stockx-mount { display:flex; align-items:center; }

/* Bandeau : le graphique s'étire sur la largeur disponible */
.stock-band--style-mini .stockx__item,
.stock-band--style-advanced .stockx__item { flex:1; }
.stock-band--style-mini .stockx__chart,
.stock-band--style-advanced .stockx__chart { flex:1; }
.stock-band--style-mini .spark { width:100%; height:40px; }
.stock-band--style-advanced .spark { width:100%; height:72px; }
@media (max-width:640px){ .stock-band .stockx__chart { display:none; } }

/* Style « tv » : widget TradingView en iframe (hauteur fixe) */
.stock-band--style-tv .stock-band__in { height:220px; padding-block:0; }
.stock-band--style-tv .tradingview-widget-container { height:100%; width:100%; }
.stock-floating--tv .stock-floating__body { height:200px; padding:0; }
.stock-floating--tv .tradingview-widget-container { height:100%; width:100%; }

/* Flottant */
.stock-floating { position:fixed; left:16px; bottom:16px; z-index:9000; width:min(92vw,300px); background:var(--surface); border:1px solid var(--border-2); border-radius:var(--radius); box-shadow:var(--shadow-2); overflow:hidden; }
.stock-floating__head { display:flex; align-items:center; justify-content:space-between; gap:.5rem; padding:.5rem .8rem; font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.72rem; color:var(--text); border-bottom:1px solid var(--border); background:var(--night); }
.stock-floating__head span { display:inline-flex; align-items:center; gap:.45em; }
.stock-floating__head svg { color:var(--money-clr); }
.stock-floating__close { background:none; border:0; color:var(--text-muted); font-size:1.3rem; line-height:1; cursor:pointer; padding:0 .15em; }
.stock-floating__close:hover { color:var(--accent); }
.stock-floating__body { padding:.85rem .9rem; }
.stock-floating .stockx { flex-direction:column; align-items:flex-start; gap:.5rem; }
.stock-floating .stockx__item { flex-direction:column; align-items:flex-start; gap:.4rem; width:100%; }
.stock-floating .spark { width:100%; height:48px; }
@media (max-width:520px){ .stock-floating { left:8px; right:8px; width:auto; } }

/* =================================================================
   CHEAT CODES — tableaux des pages
   ================================================================= */
.cheat-codes { margin-block:1.5rem; }
.cheat-lead { color:var(--ash); }
.cheat-table-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius); margin:1.4rem 0; }
/* Tableaux de codes : débordent plus large que la colonne de texte (lecture confortable) */
@media (min-width:1024px){ .single-narrow .cheat-table-wrap { width:min(1080px,94vw); margin-left:50%; transform:translateX(-50%); } }
.cheat-table { width:100%; border-collapse:collapse; font-size:.96rem; min-width:520px; }
.cheat-table thead th { text-align:left; font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.74rem; color:var(--accent-2); background:var(--night); padding:.8rem 1rem; border-bottom:1px solid var(--border); white-space:nowrap; }
.cheat-table td { padding:.7rem 1rem; border-bottom:1px solid var(--border); vertical-align:middle; }
.cheat-table tbody tr:nth-child(odd) td { background:color-mix(in srgb, var(--surface) 40%, transparent); }
.cheat-table tbody tr:hover td { background:color-mix(in srgb, var(--accent) 8%, transparent); }
.cheat-table tbody tr:last-child td { border-bottom:0; }
.cheat-effect { color:var(--heading); font-weight:600; }
.cheat-code { font-family:var(--font-mono); background:var(--night); border:1px solid var(--border-2); color:var(--accent-3); padding:.25em .6em; border-radius:6px; font-size:.9em; white-space:nowrap; }
.cheat-combo { font-family:var(--font-ui); letter-spacing:.5px; }
.cheat-na { color:var(--text-muted); }
.cheat-empty { color:var(--text-muted); }
.cheat-faq-title { margin-top:2.2rem; }
.cheat-faq { display:flex; flex-direction:column; gap:.6rem; margin-top:1rem; }
.cheat-faq__item { border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--surface); overflow:hidden; }
.cheat-faq__item summary { cursor:pointer; padding:.9rem 2.4rem .9rem 1.1rem; font-family:var(--font-ui); font-weight:600; color:var(--heading); list-style:none; position:relative; }
.cheat-faq__item summary::-webkit-details-marker { display:none; }
.cheat-faq__item summary::after { content:"+"; position:absolute; right:1.1rem; top:50%; transform:translateY(-50%); color:var(--accent); font-size:1.3rem; line-height:1; }
.cheat-faq__item[open] summary::after { content:"–"; }
.cheat-faq__a { padding:0 1.1rem 1rem; color:var(--ash); }
.cheat-faq__a p { margin:0; max-width:none; }

/* Index « All GTA Cheats » (maillage interne) */
.cheat-index { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; margin:1.6rem 0; }
.cheat-index__card { display:flex; flex-direction:column; gap:.35rem; padding:1.1rem 1.2rem; background:var(--bg-elev); border:1px solid var(--border-2); border-left:3px solid var(--row-accent,var(--accent)); border-radius:var(--radius); transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease); }
.cheat-index__card:hover { transform:translateY(-3px); box-shadow:var(--shadow-2); border-left-color:var(--accent-2); }
.cheat-index__title { font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.4px; font-size:1.12rem; color:var(--heading); }
.cheat-index__card:hover .cheat-index__title { color:var(--row-accent,var(--accent)); }
.cheat-index__meta { color:var(--text-muted); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.72rem; }
.cheat-index__go { display:inline-flex; align-items:center; gap:.4em; color:var(--row-accent,var(--accent)); font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.5px; font-size:.74rem; margin-top:.3rem; }
.cheat-index__go svg { width:16px; height:16px; }
