/* ============================================================
   BeyX Hub — stylesheet
   La prima risorsa italiana per Beyblade X
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --bg-0:#0A0A0A;
  --bg-1:#141414;
  --bg-2:#1C1C1C;
  --bg-3:#222;
  --line:#2A2A2A;
  --line-2:#3A3A3A;
  --red:#C8392B;
  --red-deep:#9d2a1f;
  --gold:#D4A017;
  --text:#F5F5F5;
  --text-2:#888;
  --text-3:#5a5a5a;
  --atk:#C8392B;
  --def:#378ADD;
  --sta:#639922;
  --bal:#D4A017;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg-0);color:var(--text);font-family:"DM Sans",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden;min-height:100vh;line-height:1.55}

/* ---------- GRAIN OVERLAY ---------- */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.deco-lines{
  position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:
    linear-gradient(115deg, transparent 49.85%, var(--line) 49.85%, var(--line) 50%, transparent 50%),
    linear-gradient(115deg, transparent 79.85%, var(--line) 79.85%, var(--line) 80%, transparent 80%);
  background-size:100% 100%;
  opacity:.35;
}

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}

.container{max-width:1320px;margin:0 auto;padding:0 32px;position:relative;z-index:2}

/* ---------- NAVBAR ---------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.logo{
  display:flex;align-items:center;gap:12px;
  font-family:"Bebas Neue",sans-serif;font-size:32px;letter-spacing:1px;line-height:1;
}
.logo-mark{
  width:32px;height:32px;flex:none;position:relative;
  animation:spin 8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.logo-mark svg{width:100%;height:100%;display:block}
.logo-text .red{color:var(--red)}
.logo-text .white{color:var(--text)}

.nav-links{display:flex;gap:34px}
.nav-links a{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:13px;
  letter-spacing:2px;text-transform:uppercase;color:var(--text-2);
  transition:color .2s ease;
  position:relative;padding:6px 0;
}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--text)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--red);
}

.nav-cta{display:flex;align-items:center;gap:14px}
.nav-search{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--line);padding:8px 12px;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  transition:border-color .2s;
  cursor:pointer;
}
.nav-search:hover{border-color:var(--line-2);color:var(--text-2)}
.nav-search kbd{
  font:inherit;color:var(--text-3);background:var(--bg-2);
  padding:2px 6px;border:1px solid var(--line);
}

/* mobile burger */
.nav-burger{
  display:none;
  width:32px;height:32px;
  flex-direction:column;justify-content:center;gap:5px;
  cursor:pointer;
}
.nav-burger span{display:block;height:2px;background:var(--text);transition:transform .2s, opacity .2s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:14px;
  letter-spacing:2px;text-transform:uppercase;
  padding:16px 28px;
  border:1px solid transparent;
  transition:all .2s ease;
  cursor:pointer;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-deep);box-shadow:0 0 24px rgba(200,57,43,.45)}
.btn-ghost{border-color:var(--line-2);color:var(--text)}
.btn-ghost:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 12px rgba(200,57,43,.4)}
.btn-gold{background:var(--gold);color:#0a0a0a}
.btn-gold:hover{background:#b8890e;box-shadow:0 0 24px rgba(212,160,23,.4)}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  overflow:hidden;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 80px), 0 100%);
}
.hero-watermark{
  position:absolute;
  left:-2vw;top:50%;transform:translateY(-50%);
  font-family:"Bebas Neue",sans-serif;
  font-size:28vw;
  line-height:.85;
  color:transparent;
  -webkit-text-stroke:1px rgba(245,245,245,.07);
  white-space:nowrap;
  user-select:none;pointer-events:none;
  letter-spacing:-.02em;
  z-index:0;
}
.hero-grid{
  position:absolute;inset:0;z-index:0;opacity:.4;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 70% 50%, black 30%, transparent 75%);
}

.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns: 1.15fr .85fr;gap:60px;align-items:center;
  width:100%;padding:120px 0 160px;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--red);
  padding:8px 14px;
  border:1px solid var(--red);
  background:rgba(200,57,43,.08);
  margin-bottom:32px;
  width:fit-content;
}
.hero-badge .dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{50%{transform:scale(1.6);opacity:.5}}

.hero h1{
  font-family:"Bebas Neue",sans-serif;
  font-size:clamp(72px,10vw,168px);
  line-height:.88;
  letter-spacing:-.005em;
  margin-bottom:28px;
}
.hero h1 .line-1{display:block;color:var(--text)}
.hero h1 .line-2{
  display:block;color:var(--red);
  transform:skewX(-6deg);
  font-style:italic;
  position:relative;
  width:fit-content;
}
.hero h1 .line-2::before{
  content:"";position:absolute;left:-22px;top:50%;height:8px;width:14px;background:var(--red);
}

.hero p.lede{
  font-size:19px;line-height:1.55;color:var(--text-2);
  max-width:540px;margin-bottom:40px;
}
.hero p.lede strong{color:var(--text);font-weight:500}

.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:64px}

.hero-meta{
  display:flex;gap:32px;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  text-transform:uppercase;letter-spacing:1px;
  flex-wrap:wrap;
}
.hero-meta .item{display:flex;align-items:center;gap:8px}
.hero-meta .live-dot{width:6px;height:6px;background:#5fbf3f;border-radius:50%;box-shadow:0 0 6px #5fbf3f}

/* ---------- HERO BEY VISUAL ---------- */
.bey-visual{
  position:relative;width:100%;aspect-ratio:1/1;max-width:520px;margin-left:auto;
}
.bey-visual::before{
  content:"";position:absolute;inset:-30px;
  background:radial-gradient(circle, rgba(200,57,43,.18), transparent 60%);
  filter:blur(20px);
}
.bey-disc{
  position:absolute;inset:0;
  border-radius:50%;
  border:1px solid var(--line-2);
  animation:spin 24s linear infinite;
}
.bey-disc.r2{inset:8%;border:1px dashed rgba(212,160,23,.4);animation-duration:18s;animation-direction:reverse}
.bey-disc.r3{inset:18%;border:1px solid rgba(200,57,43,.4);animation-duration:14s}
.bey-disc.r4{inset:30%;border:1px solid var(--line-2);animation-duration:30s;animation-direction:reverse}

.bey-rays{position:absolute;inset:0;animation:spin 40s linear infinite}
.bey-rays svg{width:100%;height:100%}

.bey-core{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:18%;height:18%;
  background:linear-gradient(135deg,var(--red) 0%, var(--red-deep) 100%);
  border-radius:50%;
  box-shadow:0 0 30px rgba(200,57,43,.6), inset 0 0 20px rgba(0,0,0,.4);
  display:flex;align-items:center;justify-content:center;
  font-family:"Bebas Neue",sans-serif;color:#fff;font-size:1.5vw;letter-spacing:.05em;
}
.bey-callout{
  position:absolute;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  text-transform:uppercase;letter-spacing:1px;
  display:flex;align-items:center;gap:10px;
  white-space:nowrap;
}
.bey-callout .tick{width:30px;height:1px;background:var(--line-2)}
.bey-callout.c1{top:8%;right:-12%}
.bey-callout.c2{bottom:18%;left:-18%}
.bey-callout.c3{bottom:-2%;right:6%}
.bey-callout strong{color:var(--gold);font-weight:500;font-family:"Rajdhani";font-size:13px;letter-spacing:1.5px}

.hero-corner{
  position:absolute;top:32px;right:0;z-index:3;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  text-transform:uppercase;letter-spacing:1.5px;
  text-align:right;line-height:1.5;
}
.hero-corner b{color:var(--gold);font-weight:500}

/* ---------- STATS BAR ---------- */
.stats-bar{
  background:var(--bg-1);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-top:-80px;
  position:relative;z-index:3;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{
  padding:36px 40px;
  border-right:1px solid var(--line);
  position:relative;
}
.stat:last-child{border-right:none}
.stat .num{
  font-family:"Bebas Neue",sans-serif;
  font-size:48px;line-height:1;color:var(--gold);
  letter-spacing:.5px;margin-bottom:6px;
  display:flex;align-items:baseline;gap:8px;
}
.stat .num small{font-size:18px;color:var(--text-2);font-family:"JetBrains Mono",monospace;font-weight:400}
.stat .label{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:11px;
  color:var(--text-2);letter-spacing:2px;text-transform:uppercase;
}
.stat .icon-bar{
  position:absolute;top:0;left:40px;right:40px;height:2px;background:var(--line);
}
.stat .icon-bar::after{content:"";position:absolute;left:0;top:0;height:100%;width:30%;background:var(--red)}
.stat:nth-child(2) .icon-bar::after{width:55%;background:var(--gold)}
.stat:nth-child(3) .icon-bar::after{width:80%;background:var(--def)}
.stat:nth-child(4) .icon-bar::after{width:100%;background:var(--sta)}

/* ---------- SECTION HEADERS ---------- */
section{padding:96px 0;position:relative}
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:32px;
  margin-bottom:48px;
}
.section-eyebrow{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--red);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.section-eyebrow::before{content:"";width:24px;height:1px;background:var(--red)}
.section-title{
  font-family:"Bebas Neue",sans-serif;
  font-size:clamp(44px,5.5vw,76px);
  line-height:.95;letter-spacing:.005em;
  display:flex;align-items:center;gap:24px;
}
.section-title .line-trail{flex:1;height:1px;background:linear-gradient(90deg,var(--line) 0%, transparent 100%);margin-left:8px}
.section-sub{
  color:var(--text-2);font-size:15px;max-width:440px;
  text-align:right;
}

/* filter chips */
.chips{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px;
  align-items:center;
}
.chip{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:12px;
  letter-spacing:2px;text-transform:uppercase;
  padding:9px 18px;
  border:1px solid var(--line);color:var(--text-2);
  background:transparent;cursor:pointer;
  transition:all .2s ease;
  display:flex;align-items:center;gap:8px;
}
.chip:hover{color:var(--text);border-color:var(--line-2)}
.chip.active{background:var(--red);border-color:var(--red);color:#fff}
.chip .count{
  font-family:"JetBrains Mono",monospace;font-size:10px;
  color:var(--text-3);font-weight:400;
}
.chip.active .count{color:rgba(255,255,255,.7)}
.chips-spacer{flex:1}
.chip-sort{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  letter-spacing:1px;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.chip-sort select{
  background:transparent;color:var(--text);border:1px solid var(--line);
  font:inherit;letter-spacing:1px;text-transform:uppercase;
  padding:8px 10px;cursor:pointer;
}

/* tabs (database page) */
.tabs{
  display:flex;gap:0;margin-bottom:32px;
  border-bottom:1px solid var(--line);
}
.tab{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:13px;
  letter-spacing:2px;text-transform:uppercase;
  padding:14px 24px;
  color:var(--text-3);background:transparent;cursor:pointer;
  position:relative;transition:color .2s;
  border-bottom:2px solid transparent;margin-bottom:-1px;
}
.tab:hover{color:var(--text-2)}
.tab.active{color:var(--text);border-bottom-color:var(--red)}
.tab .tcount{
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);
  margin-left:8px;font-weight:400;
}
.tab.active .tcount{color:var(--red)}

/* db header bar (counter + sort) */
.db-bar{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  margin-bottom:18px;flex-wrap:wrap;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  letter-spacing:1px;text-transform:uppercase;
}

/* search input (database page) */
.search-input{
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--line);padding:10px 14px;
  background:var(--bg-1);
  margin-bottom:24px;
  max-width:480px;
}
.search-input input{
  flex:1;background:transparent;border:none;outline:none;color:var(--text);
  font:14px "DM Sans",sans-serif;
}
.search-input input::placeholder{color:var(--text-3)}
.search-input .ic{color:var(--text-3);font-family:"JetBrains Mono",monospace;font-size:11px}

/* ---------- BEY CARDS ---------- */
.bey-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.bey-card{
  background:var(--bg-1);
  border:1px solid var(--line);
  padding:28px;
  position:relative;
  transition:all .25s ease;
  clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);
  cursor:pointer;
  display:flex;flex-direction:column;
}
.bey-card::before{
  content:"";position:absolute;top:0;right:0;
  width:24px;height:24px;
  background:var(--bg-0);
  clip-path:polygon(0 0,100% 0,100% 100%);
}
.bey-card::after{
  content:"";position:absolute;top:0;right:0;
  width:34px;height:1px;background:var(--line);
  transform-origin:right top;transform:rotate(-45deg) translateX(-7px);
  transition:background .25s ease;
}
.bey-card:hover{
  border-color:var(--red);
  box-shadow:0 0 24px rgba(200,57,43,.25);
  transform:translateY(-2px);
}
.bey-card:hover::after{background:var(--red)}
/* Overlay link: tutta la card cliccabile senza rompere il grid */
.card-overlay{
  position:absolute;inset:0;z-index:1;
}
/* Amazon link e altri link interattivi sopra l'overlay */
.bey-card .card-foot a.arrow,
.bey-card .card-foot a{
  position:relative;z-index:2;
}

.card-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;
  margin-bottom:18px;
}
.type-badge{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:10px;
  letter-spacing:2px;text-transform:uppercase;
  padding:5px 10px;
  background:rgba(200,57,43,.12);color:var(--red);
  border:1px solid rgba(200,57,43,.4);
}
.type-badge.def{background:rgba(55,138,221,.12);color:var(--def);border-color:rgba(55,138,221,.4)}
.type-badge.sta{background:rgba(99,153,34,.12);color:var(--sta);border-color:rgba(99,153,34,.4)}
.type-badge.bal{background:rgba(212,160,23,.12);color:var(--gold);border-color:rgba(212,160,23,.4)}

.tier{
  font-family:"Bebas Neue",sans-serif;
  font-size:32px;line-height:1;color:var(--gold);
  margin-right:36px;
  display:flex;align-items:baseline;gap:4px;
}
.tier small{font-size:11px;color:var(--text-3);font-family:"JetBrains Mono",monospace}

.bey-art{
  height:120px;margin:6px 0 18px;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at center, rgba(200,57,43,.06) 0%, transparent 70%),
    repeating-linear-gradient(45deg, transparent 0 6px, rgba(255,255,255,.012) 6px 12px);
  border:1px dashed var(--line);
}
.mini-bey{
  width:100px;height:100px;border-radius:50%;
  background:
    radial-gradient(circle, var(--bg-3) 18%, transparent 19%),
    conic-gradient(from 0deg, var(--red) 0deg 30deg, var(--bg-3) 30deg 60deg, var(--red) 60deg 90deg, var(--bg-3) 90deg 120deg, var(--red) 120deg 150deg, var(--bg-3) 150deg 180deg, var(--red) 180deg 210deg, var(--bg-3) 210deg 240deg, var(--red) 240deg 270deg, var(--bg-3) 270deg 300deg, var(--red) 300deg 330deg, var(--bg-3) 330deg 360deg);
  border:2px solid var(--bg-3);
  box-shadow:inset 0 0 16px rgba(0,0,0,.6);
  animation:spin 6s linear infinite;
}
.bey-card:hover .mini-bey{animation-duration:1.5s}

.mini-bey.def{
  background:
    radial-gradient(circle, var(--bg-3) 18%, transparent 19%),
    conic-gradient(from 0deg, var(--def) 0deg 60deg, var(--bg-3) 60deg 120deg, var(--def) 120deg 180deg, var(--bg-3) 180deg 240deg, var(--def) 240deg 300deg, var(--bg-3) 300deg 360deg);
}
.mini-bey.sta{
  background:
    radial-gradient(circle, var(--bg-3) 18%, transparent 19%),
    conic-gradient(from 0deg, var(--sta) 0deg 45deg, var(--bg-3) 45deg 90deg, var(--sta) 90deg 135deg, var(--bg-3) 135deg 180deg, var(--sta) 180deg 225deg, var(--bg-3) 225deg 270deg, var(--sta) 270deg 315deg, var(--bg-3) 315deg 360deg);
}
.mini-bey.bal{
  background:
    radial-gradient(circle, var(--bg-3) 18%, transparent 19%),
    conic-gradient(from 0deg, var(--gold) 0deg 36deg, var(--bg-3) 36deg 72deg, var(--gold) 72deg 108deg, var(--bg-3) 108deg 144deg, var(--gold) 144deg 180deg, var(--bg-3) 180deg 216deg, var(--gold) 216deg 252deg, var(--bg-3) 252deg 288deg, var(--gold) 288deg 324deg, var(--bg-3) 324deg 360deg);
}

.bey-name{
  font-family:"Bebas Neue",sans-serif;
  font-size:24px;line-height:1.05;color:var(--text);
  letter-spacing:.5px;margin-bottom:4px;
}
.bey-code{
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-2);
  letter-spacing:.5px;margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.bey-code .div{width:12px;height:1px;background:var(--line-2)}

.stat-row{
  display:grid;grid-template-columns:36px 1fr 36px;
  align-items:center;gap:12px;margin-bottom:8px;
  font-family:"JetBrains Mono",monospace;font-size:11px;
}
.stat-row .lbl{color:var(--text-2);letter-spacing:1px;text-transform:uppercase;font-weight:500}
.stat-row .val{color:var(--text);text-align:right;font-weight:500}
.stat-row .bar{
  height:6px;background:var(--bg-3);position:relative;overflow:hidden;
}
.stat-row .bar .fill{
  position:absolute;left:0;top:0;height:100%;
  width:0;
  transition:width 1.2s cubic-bezier(.2,.7,.2,1);
}
.stat-row.atk .fill{background:linear-gradient(90deg, var(--red-deep) 0%, var(--atk) 100%)}
.stat-row.def .fill{background:linear-gradient(90deg, #205fa3 0%, var(--def) 100%)}
.stat-row.sta .fill{background:linear-gradient(90deg, #466b18 0%, var(--sta) 100%)}

.card-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:auto;padding-top:18px;border-top:1px solid var(--line);
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);
  text-transform:uppercase;letter-spacing:1px;
}
.card-foot .winrate{color:var(--gold)}
.card-foot .arrow{
  color:var(--text-2);transition:transform .2s, color .2s;
}
.bey-card:hover .arrow{transform:translateX(4px);color:var(--red)}

/* empty state */
.empty-state{
  text-align:center;padding:60px 20px;
  border:1px dashed var(--line);
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-3);
  letter-spacing:1px;
}

/* pagination */
.pagination{
  display:flex;justify-content:center;gap:6px;margin-top:48px;
}
.pagination button{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:12px;
  letter-spacing:1px;
  padding:10px 14px;min-width:40px;
  border:1px solid var(--line);color:var(--text-2);
  transition:all .2s;
}
.pagination button:hover{border-color:var(--line-2);color:var(--text)}
.pagination button.active{background:var(--red);border-color:var(--red);color:#fff}
.pagination button:disabled{opacity:.3;cursor:not-allowed}

/* ---------- MAIN LAYOUT (2 col) ---------- */
.layout-2{
  display:grid;grid-template-columns:1.5fr 1fr;gap:48px;
}

.col-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line);
}
.col-head h3{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:15px;
  text-transform:uppercase;letter-spacing:2px;color:var(--text);
  display:flex;align-items:center;gap:10px;
}
.col-head h3::before{content:"";width:4px;height:18px;background:var(--red)}
.col-head .more{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  letter-spacing:1px;text-transform:uppercase;
}
.col-head .more:hover{color:var(--red)}

.article{
  display:grid;grid-template-columns:200px 1fr auto;gap:24px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line);
  cursor:pointer;transition:padding .2s;
}
.article:hover{padding-left:8px}
.article:hover .art-arrow{color:var(--red);transform:translateX(4px)}
.article-thumb{
  aspect-ratio:16/10;
  background:
    radial-gradient(circle at 30% 40%, rgba(200,57,43,.18) 0%, transparent 60%),
    repeating-linear-gradient(135deg, transparent 0 8px, rgba(255,255,255,.02) 8px 16px),
    var(--bg-1);
  border:1px solid var(--line);
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.article-thumb .ph{
  font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--text-3);
  letter-spacing:1px;text-transform:uppercase;
}
.article-thumb.t2{
  background:
    radial-gradient(circle at 70% 30%, rgba(212,160,23,.14) 0%, transparent 55%),
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(255,255,255,.02) 8px 16px),
    var(--bg-1);
}
.article-cat{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:10px;
  color:var(--red);letter-spacing:2px;text-transform:uppercase;
  margin-bottom:8px;display:flex;align-items:center;gap:8px;
}
.article-cat::before{content:"";width:14px;height:1px;background:var(--red)}
.article h4{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:18px;
  line-height:1.3;color:var(--text);margin-bottom:10px;
}
.article-meta{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;
}
.article-meta .sep{width:3px;height:3px;background:var(--text-3);border-radius:50%}
.art-arrow{color:var(--text-3);transition:all .2s ease;font-size:24px;font-family:"Rajdhani"}

/* SIDEBAR */
.side-card{
  background:var(--bg-1);border:1px solid var(--line);
  padding:28px;margin-bottom:24px;
  position:relative;
}
.side-card.dashed{
  background:var(--bg-2);
  border:1px dashed var(--line-2);
}
.side-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:24px;
}
.side-head h3{
  font-family:"Bebas Neue",sans-serif;font-size:26px;line-height:1;
  color:var(--text);letter-spacing:.5px;
}
.side-head h3 small{
  display:block;font-family:"JetBrains Mono",monospace;font-size:10px;
  color:var(--gold);letter-spacing:1.5px;margin-bottom:6px;font-weight:400;
  text-transform:uppercase;
}
.side-head .badge{
  font-family:"JetBrains Mono",monospace;font-size:10px;
  color:var(--text-3);letter-spacing:1px;text-transform:uppercase;
  border:1px solid var(--line);padding:4px 8px;
}

.combo{
  display:grid;grid-template-columns:36px 1fr auto;gap:16px;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--line);
  cursor:pointer;transition:transform .2s;
}
.combo:last-child{border-bottom:none;padding-bottom:0}
.combo:hover{transform:translateX(2px)}
.combo .rank{
  font-family:"Bebas Neue",sans-serif;font-size:24px;line-height:1;
  text-align:center;
}
.combo:nth-child(1) .rank{color:var(--gold)}
.combo:nth-child(2) .rank{color:#bbb}
.combo:nth-child(3) .rank{color:#a36b2b}
.combo:nth-child(4) .rank{color:var(--text-3)}
.combo .name{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:14px;color:var(--text);
  margin-bottom:4px;letter-spacing:.5px;
}
.combo .parts{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  letter-spacing:.5px;
}
.combo .wr{
  font-family:"Bebas Neue",sans-serif;font-size:22px;line-height:1;color:var(--red);
  text-align:right;
}
.combo .wr small{
  display:block;font-family:"JetBrains Mono",monospace;font-size:9px;
  color:var(--text-3);letter-spacing:1px;font-weight:400;margin-top:2px;
}

/* news */
.news{
  padding:14px 0;border-bottom:1px solid var(--line);
  cursor:pointer;
}
.news:last-child{border-bottom:none;padding-bottom:0}
.news .news-tag{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:10px;
  letter-spacing:2px;text-transform:uppercase;
  padding:3px 8px;display:inline-block;margin-bottom:10px;
}
.news-tag.new{background:rgba(200,57,43,.15);color:var(--red)}
.news-tag.tournament{background:rgba(212,160,23,.15);color:var(--gold)}
.news-tag.update{background:var(--bg-3);color:var(--text-2)}
.news h4{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:14px;
  line-height:1.35;color:var(--text);margin-bottom:6px;
}
.news .date{
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);
  letter-spacing:1px;
}
.news:hover h4{color:var(--red)}

/* affiliate sidebar */
.aff-stamp{
  position:absolute;top:14px;right:14px;
  font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--text-3);
  letter-spacing:1.5px;text-transform:uppercase;
  border:1px solid var(--line-2);padding:3px 6px;
}
.aff h4{
  font-family:"Bebas Neue",sans-serif;font-size:24px;line-height:1.05;
  color:var(--text);margin-bottom:10px;letter-spacing:.5px;
}
.aff p{font-size:13px;color:var(--text-2);margin-bottom:18px;line-height:1.5}
.aff p strong{color:var(--gold);font-weight:500}
.aff .btn{padding:12px 18px;font-size:12px;width:100%;justify-content:space-between}

/* affiliate disclosure (inline, on guides etc.) */
.aff-disclosure{
  background:rgba(212,160,23,.06);
  border:1px solid rgba(212,160,23,.25);
  border-left:3px solid var(--gold);
  padding:14px 18px;
  font-size:12px;color:var(--text-2);line-height:1.55;
  margin:24px 0;
  font-family:"DM Sans",sans-serif;
}
.aff-disclosure b{color:var(--gold);font-weight:500}

/* ---------- COMBO BUILDER ---------- */
.builder{
  display:grid;grid-template-columns: 1.4fr 1fr;gap:0;
  background:var(--bg-1);border:1px solid var(--line);
  position:relative;overflow:hidden;
}
.builder::before{
  content:"COMBO//BUILDER";
  position:absolute;right:-30px;top:18px;
  font-family:"Bebas Neue",sans-serif;font-size:10vw;line-height:.85;
  color:transparent;-webkit-text-stroke:1px rgba(245,245,245,.03);
  pointer-events:none;letter-spacing:-.01em;white-space:nowrap;
}
.builder-cols{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-right:1px solid var(--line);position:relative;z-index:1;
}
.builder-col{
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
}
.builder-col:last-child{border-right:none}
.builder-col-head{
  padding:18px 20px;border-bottom:1px solid var(--line);
  background:var(--bg-2);
  display:flex;justify-content:space-between;align-items:center;
}
.builder-col-head .ttl{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:2px;color:var(--text);
  display:flex;align-items:center;gap:10px;
}
.builder-col-head .ttl span.idx{
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--red);
  border:1px solid var(--red);padding:2px 6px;letter-spacing:1px;
  background:rgba(200,57,43,.08);
}
.builder-col-head .cnt{
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);
  letter-spacing:1px;text-transform:uppercase;
}
.builder-list{
  flex:1;max-height:480px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--line-2) var(--bg-1);
}
.builder-list::-webkit-scrollbar{width:6px}
.builder-list::-webkit-scrollbar-track{background:var(--bg-1)}
.builder-list::-webkit-scrollbar-thumb{background:var(--line-2)}

.part{
  padding:14px 20px;border-bottom:1px solid var(--line);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;
  transition:background .15s, padding .2s, border-color .15s;
  position:relative;
}
.part::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background .15s;
}
.part:hover{background:var(--bg-2);padding-left:24px}
.part.selected{background:rgba(200,57,43,.08)}
.part.selected::before{background:var(--red)}
.part .pname{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:13px;color:var(--text);
  letter-spacing:.5px;
}
.part .pcode{
  font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);
  letter-spacing:.5px;margin-top:2px;
}
.part .ptype{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:9px;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 6px;
}
.part .ptype.atk{background:rgba(200,57,43,.15);color:var(--red)}
.part .ptype.def{background:rgba(55,138,221,.15);color:var(--def)}
.part .ptype.sta{background:rgba(99,153,34,.15);color:var(--sta)}
.part .ptype.bal{background:rgba(212,160,23,.15);color:var(--gold)}

/* preview panel */
.builder-preview{
  padding:32px;display:flex;flex-direction:column;gap:24px;
  background:linear-gradient(180deg, var(--bg-1) 0%, var(--bg-2) 100%);
  position:relative;z-index:1;
}
.preview-head{
  display:flex;justify-content:space-between;align-items:flex-start;
}
.preview-head .ttl{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:11px;
  color:var(--text-2);letter-spacing:2px;text-transform:uppercase;
  margin-bottom:6px;
}
.preview-head .name{
  font-family:"Bebas Neue",sans-serif;font-size:34px;line-height:1;color:var(--text);
  letter-spacing:.5px;
}
.preview-head .code{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  letter-spacing:1px;margin-top:6px;
}
.preview-tier{
  font-family:"Bebas Neue",sans-serif;font-size:48px;line-height:.85;color:var(--gold);
  text-align:right;
}
.preview-tier small{
  display:block;font-family:"JetBrains Mono",monospace;font-size:9px;
  color:var(--text-3);letter-spacing:1.5px;font-weight:400;margin-top:4px;
  text-transform:uppercase;
}

.preview-stats{display:flex;flex-direction:column;gap:14px}
.pstat{
  display:grid;grid-template-columns:48px 1fr 44px;gap:14px;align-items:center;
  font-family:"JetBrains Mono",monospace;font-size:11px;
}
.pstat .lbl{color:var(--text-2);letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.pstat .val{color:var(--text);text-align:right;font-weight:500;font-size:14px}
.pstat .bar{height:8px;background:var(--bg-3);position:relative;overflow:hidden}
.pstat .bar .fill{position:absolute;left:0;top:0;height:100%;width:0;transition:width .5s cubic-bezier(.2,.7,.2,1)}
.pstat.atk .fill{background:linear-gradient(90deg, var(--red-deep), var(--atk))}
.pstat.def .fill{background:linear-gradient(90deg, #205fa3, var(--def))}
.pstat.sta .fill{background:linear-gradient(90deg, #466b18, var(--sta))}
.pstat.wgt .fill{background:linear-gradient(90deg, #555, var(--text-2))}

.preview-totals{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);padding-top:18px;
}
.ptotal{
  text-align:center;border-right:1px solid var(--line);padding:0 8px;
}
.ptotal:last-child{border-right:none}
.ptotal .n{
  font-family:"Bebas Neue",sans-serif;font-size:28px;line-height:1;color:var(--text);
}
.ptotal .n.gold{color:var(--gold)}
.ptotal .n.red{color:var(--red)}
.ptotal .l{
  font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--text-3);
  letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;
}

.preview-actions{display:flex;gap:10px;flex-wrap:wrap}
.preview-actions .btn{flex:1;padding:14px 18px;font-size:12px;justify-content:center;min-width:140px}

.preview-empty{
  color:var(--text-3);font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:1px;text-transform:uppercase;text-align:center;padding:18px;
  border:1px dashed var(--line);
}

.preview-art{
  height:140px;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at center, rgba(200,57,43,.08) 0%, transparent 65%),
    repeating-linear-gradient(45deg, transparent 0 8px, rgba(255,255,255,.012) 8px 16px);
  border:1px dashed var(--line);position:relative;
}
.preview-art .built{
  width:120px;height:120px;border-radius:50%;
  border:2px solid var(--bg-3);
  box-shadow:inset 0 0 18px rgba(0,0,0,.6), 0 0 24px rgba(200,57,43,.2);
  animation:spin 4s linear infinite;
  transition:background .4s ease;
}
.preview-art .lbl-corner{
  position:absolute;top:8px;left:10px;
  font-family:"JetBrains Mono",monospace;font-size:9px;
  color:var(--text-3);letter-spacing:1px;
}
.preview-art .lbl-corner b{color:var(--red);font-weight:500}

/* affiliate cta inside builder preview */
.preview-aff{
  background:var(--bg-2);border:1px dashed var(--line-2);
  padding:14px 16px;font-size:12px;color:var(--text-2);line-height:1.5;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;
}
.preview-aff strong{color:var(--gold);font-weight:500}
.preview-aff a{color:var(--red);font-family:"Rajdhani";font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:11px}
.preview-aff a:hover{text-decoration:underline}

/* ---------- TIER LIST ---------- */
.tier-list{
  background:var(--bg-1);border:1px solid var(--line);padding:8px;
}
.tier-row{
  display:grid;grid-template-columns:80px 1fr;gap:0;
  border-bottom:1px solid var(--line);
}
.tier-row:last-child{border-bottom:none}
.tier-letter{
  font-family:"Bebas Neue",sans-serif;font-size:42px;
  display:flex;align-items:center;justify-content:center;
  color:#0a0a0a;line-height:1;
}
.tier-row.splus .tier-letter{background:var(--gold,#D4A017);color:#0a0a0a}
.tier-row.s .tier-letter{background:#C8392B}
.tier-row.a .tier-letter{background:#D4A017}
.tier-row.b .tier-letter{background:#9aa01a}
.tier-row.c .tier-letter{background:#4a7e2c;color:#fff}
.tier-row.d .tier-letter{background:#3a3a3a;color:var(--text-2)}
.tier-items{
  display:flex;flex-wrap:wrap;gap:8px;padding:14px;align-items:center;
}
.tier-pill{
  font-family:"Rajdhani",sans-serif;font-weight:600;font-size:12px;
  letter-spacing:1px;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--line);background:var(--bg-2);
  display:flex;align-items:center;gap:8px;cursor:pointer;
  transition:all .2s ease;
}
.tier-pill:hover{border-color:var(--red);color:var(--red)}
.tier-pill .dot{width:6px;height:6px;border-radius:50%}
.tier-pill .dot.atk{background:var(--red)}
.tier-pill .dot.def{background:var(--def)}
.tier-pill .dot.sta{background:var(--sta)}
.tier-pill .dot.bal{background:var(--gold)}

/* ---------- PAGE HEADER (interior pages) ---------- */
.page-header{
  padding:80px 0 48px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.page-header .breadcrumb{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  letter-spacing:1.5px;text-transform:uppercase;margin-bottom:18px;
  display:flex;gap:10px;align-items:center;
}
.page-header .breadcrumb a{color:var(--text-3)}
.page-header .breadcrumb a:hover{color:var(--red)}
.page-header .breadcrumb .sep{color:var(--text-3)}
.page-header h1{
  font-family:"Bebas Neue",sans-serif;
  font-size:clamp(48px,7vw,96px);
  line-height:.95;letter-spacing:.005em;
  color:var(--text);margin-bottom:16px;
}
.page-header h1 .accent{color:var(--red)}
.page-header .lede{
  color:var(--text-2);font-size:17px;max-width:680px;line-height:1.6;
}

/* ---------- LONGFORM (guide article) ---------- */
.longform{
  max-width:760px;margin:0 auto;padding:60px 0;
}
.longform h2{
  font-family:"Bebas Neue",sans-serif;font-size:36px;line-height:1.1;
  margin:48px 0 16px;letter-spacing:.5px;
  display:flex;align-items:center;gap:14px;
}
.longform h2::before{content:"";width:6px;height:24px;background:var(--red);flex:none}
.longform h3{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:22px;
  margin:32px 0 12px;color:var(--text);letter-spacing:.5px;
}
.longform p{
  font-size:16px;line-height:1.7;color:#d8d8d8;margin-bottom:18px;
}
.longform p strong{color:var(--text);font-weight:600}
.longform a{color:var(--red);text-decoration:underline;text-decoration-color:rgba(200,57,43,.4);text-underline-offset:3px}
.longform a:hover{text-decoration-color:var(--red)}
.longform a.btn{text-decoration:none}
.longform a.btn-primary{color:#fff}
.longform a.btn-ghost{color:var(--text)}
.longform a.btn-gold{color:#0a0a0a}
.longform ul,.longform ol{margin:18px 0 18px 24px;color:#d8d8d8}
.longform li{margin-bottom:8px;line-height:1.6}
.longform blockquote{
  border-left:3px solid var(--gold);padding:8px 20px;
  margin:24px 0;font-style:italic;color:var(--text-2);
  background:rgba(212,160,23,.04);
}
.longform .article-hero-meta{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-2);
  letter-spacing:1px;text-transform:uppercase;
  display:flex;gap:16px;flex-wrap:wrap;
  padding:18px 0;border-bottom:1px solid var(--line);margin-bottom:36px;
}
.longform .product-card{
  background:var(--bg-1);border:1px solid var(--line);border-left:3px solid var(--gold);
  padding:20px 22px;margin:24px 0;
  display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;
}
.longform .product-card .pname{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:17px;
  color:var(--text);margin-bottom:4px;letter-spacing:.5px;
}
.longform .product-card .pdesc{font-size:13px;color:var(--text-2);line-height:1.5}

/* ---------- AD SLOTS ---------- */
.ad-slot{
  margin:36px auto;
  text-align:center;
  min-height:90px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.ad-slot::before{
  content:"PUBBLICITÀ";
  position:absolute;top:-8px;left:0;
  font-family:"JetBrains Mono",monospace;font-size:9px;
  color:var(--text-3);letter-spacing:1.5px;
}
.ad-slot.placeholder{
  border:1px dashed var(--line-2);
  color:var(--text-3);
  font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:1px;
  background:var(--bg-1);
  padding:30px;
}

/* ---------- COOKIE BANNER (GDPR) ---------- */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;
  z-index:9999;
  background:var(--bg-1);
  border:1px solid var(--line-2);
  border-left:4px solid var(--red);
  padding:24px 28px;
  max-width:640px;margin:0 auto;
  box-shadow:0 12px 40px rgba(0,0,0,.5);
  display:none;
}
.cookie-banner.show{display:block;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner h3{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:14px;
  letter-spacing:2px;text-transform:uppercase;color:var(--text);
  margin-bottom:10px;display:flex;align-items:center;gap:10px;
}
.cookie-banner h3::before{content:"";width:6px;height:18px;background:var(--red)}
.cookie-banner p{
  font-size:13px;color:var(--text-2);line-height:1.55;margin-bottom:18px;
}
.cookie-banner p a{color:var(--gold);text-decoration:underline}
.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner-actions .btn{padding:10px 18px;font-size:11px}

/* ---------- FOOTER ---------- */
footer{
  background:var(--bg-0);
  border-top:1px solid var(--line);
  padding:64px 0 32px;
  margin-top:64px;
  position:relative;
}
.footer-watermark{
  position:absolute;left:0;right:0;top:0;text-align:center;
  font-family:"Bebas Neue",sans-serif;font-size:14vw;line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(245,245,245,.04);
  pointer-events:none;user-select:none;letter-spacing:.02em;
  transform:translateY(-30%);
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:48px;position:relative;
}
.footer-brand .tagline{
  color:var(--text-2);font-size:14px;margin:18px 0 24px;line-height:1.55;max-width:280px;
}
.footer-meta{
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  letter-spacing:1px;line-height:1.8;
}
.footer-meta b{color:var(--text-2);font-weight:500}
.footer-col h5{
  font-family:"Rajdhani",sans-serif;font-weight:700;font-size:12px;
  letter-spacing:2px;text-transform:uppercase;color:var(--text);
  margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.footer-col h5::before{content:"";width:14px;height:1px;background:var(--red)}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{
  font-size:13px;color:var(--text-2);
  transition:color .2s;
}
.footer-col a:hover{color:var(--red)}
.footer-disclosure{
  background:var(--bg-1);border:1px solid var(--line);
  padding:14px 20px;margin-bottom:24px;
  font-size:11px;color:var(--text-2);line-height:1.6;
  font-family:"DM Sans",sans-serif;
  position:relative;
}
.footer-disclosure b{color:var(--gold)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding-top:32px;border-top:1px solid var(--line);
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);
  letter-spacing:1px;flex-wrap:wrap;
}
.footer-bottom .credit{color:var(--text-2)}
.footer-bottom .credit b{color:var(--red);font-weight:500}

/* ---------- ANIMATIONS ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr}
  .bey-visual{display:none}
  .bey-grid{grid-template-columns:repeat(2,1fr)}
  .layout-2{grid-template-columns:1fr}
  .nav-links{
    display:none;
    position:absolute;top:72px;left:0;right:0;
    background:var(--bg-1);
    flex-direction:column;gap:0;
    border-bottom:1px solid var(--line);
    padding:12px 0;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 32px;border-bottom:1px solid var(--line)}
  .nav-links a:last-child{border-bottom:none}
  .nav-burger{display:flex}
  .nav-search{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .article{grid-template-columns:120px 1fr auto;gap:16px}
  .builder{grid-template-columns:1fr}
  .builder-cols{border-right:none;border-bottom:1px solid var(--line)}
  .builder-list{max-height:260px}
  .section-head{flex-direction:column;align-items:flex-start}
  .section-sub{text-align:left}
}
@media(max-width:640px){
  .container{padding:0 20px}
  .bey-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .article{grid-template-columns:1fr}
  .article-thumb{aspect-ratio:16/8}
  .builder-cols{grid-template-columns:1fr}
  .builder-col{border-right:none;border-bottom:1px solid var(--line)}
  .builder-col:last-child{border-bottom:none}
  .hero-corner{display:none}
  .tier-row{grid-template-columns:60px 1fr}
  .tier-letter{font-size:32px}
  section{padding:64px 0}
  .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left}
}
