/* 1x1 Random Arena — общий стиль сайта (server-rendered, Jinja2).
   Тёмная Radiant-vs-Dire тема. Источник правды стилей для всех страниц. */

:root{
  --bg:#080a0f; --bg2:#0d1118; --panel:#12161f; --panel2:#171c27;
  --radiant:#43d17a; --radiant-deep:#1f7a48;
  --dire:#ff5347; --dire-deep:#8f1f1a;
  --gold:#f6c945; --gold-deep:#c99a1f;
  --text:#e9eef6; --muted:#94a2b8; --faint:#5e6b80;
  --line:rgba(255,255,255,.09);
  --r:16px; --maxw:1180px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--text);
  font-family:"Manrope",-apple-system,system-ui,sans-serif;
  font-size:17px; line-height:1.6; letter-spacing:.1px;
  overflow-x:hidden; -webkit-font-smoothing:antialiased; min-height:100vh;
}
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60% 50% at 12% -5%, rgba(67,209,122,.16), transparent 60%),
    radial-gradient(55% 50% at 92% 0%, rgba(255,83,71,.14), transparent 60%),
    radial-gradient(80% 60% at 50% 120%, rgba(246,201,69,.06), transparent 60%),
    var(--bg);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.muted{color:var(--muted)} .faint{color:var(--faint)}

/* typography helpers */
.kicker{font-family:"JetBrains Mono",monospace; font-size:12.5px; font-weight:700;
  letter-spacing:.32em; text-transform:uppercase; color:var(--faint)}
.display{font-family:"Oswald",sans-serif; font-weight:700; line-height:.98; letter-spacing:.5px; text-transform:uppercase}
.mono{font-family:"JetBrains Mono",monospace}
.grad-rd{background:linear-gradient(100deg,var(--radiant),var(--gold) 55%,var(--dire));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.pos{color:var(--radiant)} .neg{color:var(--dire)}

/* header */
header{position:sticky; top:0; z-index:50; backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  background:linear-gradient(180deg,rgba(8,10,15,.85),rgba(8,10,15,.5)); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; gap:28px; height:68px}
.logo{display:flex; align-items:center; gap:11px}
.logo img{height:38px;width:auto;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.45))}
.nav .links{display:flex;gap:24px;margin-left:auto;font-size:14.5px;font-weight:600;color:var(--muted);align-items:center}
.nav .links a{transition:color .2s} .nav .links a:hover,.nav .links a.active{color:var(--text)}
.nav .links a.active{color:var(--gold)}
.btn{font-family:"Oswald";font-weight:600;text-transform:uppercase;letter-spacing:1px;font-size:15px;
  display:inline-flex;align-items:center;gap:9px; padding:13px 22px;border-radius:11px; cursor:pointer;
  border:1px solid transparent; transition:transform .15s ease, box-shadow .25s ease, background .2s; white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--gold),#e9a91f); color:#1c1402;
  box-shadow:0 10px 30px rgba(246,201,69,.28), inset 0 1px 0 rgba(255,255,255,.4)}
.btn-gold:hover{transform:translateY(-2px); box-shadow:0 16px 40px rgba(246,201,69,.42), inset 0 1px 0 rgba(255,255,255,.5)}
.btn-ghost{background:rgba(255,255,255,.04); border-color:var(--line); color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.09); transform:translateY(-2px)}
.nav .btn{padding:10px 18px}
.btn-sm{padding:8px 14px;font-size:13px}
/* play-треугольник (вместо ▶: эмодзи на iOS цветной и нестилизованный) */
.ic-play{display:inline-block;width:0;height:0;border-style:solid;border-width:6px 0 6px 11px;
  border-color:transparent transparent transparent currentColor;margin-right:4px;vertical-align:middle;position:relative;top:-1px}
/* бургер мобильного меню (скрыт на десктопе) */
.burger{display:none;margin-left:auto;width:44px;height:44px;flex:0 0 auto;border:1px solid var(--line);
  border-radius:11px;background:rgba(255,255,255,.04);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.burger span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:.25s}
header.open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
header.open .burger span:nth-child(2){opacity:0}
header.open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* footer */
footer{border-top:1px solid var(--line); margin-top:96px; padding:38px 0; color:var(--faint)}
.foot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-size:14px}
.foot .logo img{height:34px}
.foot a:hover{color:var(--text)} .foot .dot{opacity:.4;margin:0 8px}

/* ============ shared media ============ */
.hero-portrait{border-radius:8px;overflow:hidden;background:var(--panel);border:1px solid var(--line)}
.hero-portrait img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9;display:block}
.hero-chip{display:inline-flex;align-items:center;gap:8px}
.hero-chip img{width:44px;height:25px;object-fit:cover;border-radius:5px;border:1px solid var(--line)}
.hero-ic{width:46px;height:26px;object-fit:cover;border-radius:5px;border:1px solid var(--line);display:inline-block;vertical-align:middle}
.medal{display:inline-flex;align-items:center;gap:6px}
.medal img{width:30px;height:30px;object-fit:contain;vertical-align:middle}
.medal small{color:var(--faint);font-family:"JetBrains Mono";font-size:11px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);object-fit:cover}

/* ============ generic section / page head ============ */
section{position:relative; padding:96px 0}
.sec-head{max-width:760px; margin-bottom:46px}
.sec-head h2{font-size:clamp(30px,4.2vw,52px); margin:14px 0 0}
.sec-head p{color:var(--muted); font-size:18px; margin:16px 0 0}
.page{padding:54px 0 0}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:30px}
.page-head h1{font-family:"Oswald";text-transform:uppercase;font-size:clamp(30px,5vw,52px);margin:8px 0 0;line-height:1}
.crumbs{font-family:"JetBrains Mono";font-size:12px;color:var(--faint);letter-spacing:.06em}
.crumbs a:hover{color:var(--gold)}
.empty{border:1px dashed var(--line);border-radius:var(--r);padding:54px 24px;text-align:center;color:var(--muted)}
.empty .big{font-size:34px;margin-bottom:10px}

/* ============ tables (leaderboard / stats) ============ */
.tbl-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel)}
table.tbl{border-collapse:collapse;width:100%;font-size:15px}
table.tbl th{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);
  text-align:left;padding:14px 16px;background:var(--bg2);border-bottom:1px solid var(--line);white-space:nowrap}
table.tbl td{padding:12px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
table.tbl tr:last-child td{border-bottom:0}
table.tbl tbody tr{transition:background .15s} table.tbl tbody tr:hover{background:rgba(255,255,255,.03)}
table.tbl .num{font-family:"JetBrains Mono";text-align:right}
.rank-cell{font-family:"Oswald";font-weight:700;color:var(--faint);width:48px}
.rank-cell.top1{color:var(--gold)} .rank-cell.top2{color:#cfd6e0} .rank-cell.top3{color:#d8a05a}
.who{display:flex;align-items:center;gap:11px;min-width:0}
.who .nm{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.who a.nm:hover{color:var(--gold)}
.rating-val{font-family:"JetBrains Mono";font-weight:700;color:var(--gold)}
.wl .w{color:var(--radiant)} .wl .l{color:var(--dire)}
.bar{height:7px;border-radius:4px;background:rgba(255,255,255,.08);overflow:hidden;min-width:90px}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--radiant),var(--gold))}

/* search */
.search{display:flex;gap:10px;align-items:center}
.search input{background:var(--panel);border:1px solid var(--line);border-radius:10px;color:var(--text);
  padding:10px 14px;font-size:16px;font-family:inherit;min-width:220px}
.search input:focus{outline:none;border-color:rgba(246,201,69,.5)}

/* ============ cards grid (value / stats tiles) ============ */
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line);
  border-radius:var(--r); padding:26px 22px; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease}
.card:hover{transform:translateY(-6px); border-color:rgba(246,201,69,.4); box-shadow:0 22px 50px rgba(0,0,0,.45)}
.card .ic{font-size:26px; margin-bottom:14px}
.card h3{font-family:"Oswald";text-transform:uppercase;letter-spacing:.5px;font-size:19px;margin:0 0 8px}
.card p{margin:0;color:var(--muted);font-size:15.5px;line-height:1.55}
.stat-tile{text-align:center;padding:28px 18px}
.stat-tile .v{font-family:"Oswald";font-weight:700;font-size:clamp(34px,5vw,52px);color:var(--gold);line-height:1}
.stat-tile .k{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:8px}

/* chips */
.chip{font-family:"JetBrains Mono";font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted)}
.chip.r{border-color:rgba(67,209,122,.35);color:#9be7bb}
.chip.d{border-color:rgba(255,83,71,.35);color:#ffb1ab}
.chip.g{border-color:rgba(246,201,69,.4);color:var(--gold)}

/* ============ profile ============ */
.pcard{border:1px solid var(--line);border-radius:22px;overflow:hidden;
  background:radial-gradient(80% 130% at 0% -10%, rgba(246,201,69,.08), transparent 55%), linear-gradient(180deg,var(--panel),var(--bg2))}
.pcard .top{display:flex;gap:22px;align-items:center;padding:32px 34px;flex-wrap:wrap}
.pcard .pavatar{width:84px;height:84px;border-radius:18px;border:1px solid var(--line);background:var(--panel2);object-fit:cover}
.pcard .pname{font-family:"Oswald";text-transform:uppercase;font-size:clamp(26px,4vw,40px);line-height:1;margin:0}
.pcard .pmeta{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.pcard .pstats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.pcard .pstats > div{padding:20px;text-align:center;border-right:1px solid var(--line)}
.pcard .pstats > div:last-child{border-right:0}
.pcard .pstats .v{font-family:"Oswald";font-weight:700;font-size:28px}
.pcard .pstats .k{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-top:4px}
.h2row{display:flex;align-items:baseline;gap:14px;margin:42px 0 18px}
.h2row h2{font-family:"Oswald";text-transform:uppercase;font-size:24px;margin:0}
.heroes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.hbox{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel)}
.hbox img{width:100%;aspect-ratio:16/9;object-fit:cover}
.hbox .hb{padding:10px 12px}
.hbox .hn{font-family:"Oswald";text-transform:uppercase;font-size:13px;letter-spacing:.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hbox .hs{font-family:"JetBrains Mono";font-size:11px;color:var(--muted);margin-top:3px}

/* match rows (recent / history) */
.mrow{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;
  padding:13px 16px;border:1px solid var(--line);border-radius:12px;background:var(--panel);margin-bottom:10px;transition:border-color .2s}
.mrow:hover{border-color:rgba(246,201,69,.35)}
/* строки слева/справа одной высоты → блоки равны по высоте */
#live .how{align-items:stretch}
#live .mrow{padding:8px 14px;margin-bottom:8px;min-height:46px}
#live .prow{padding:8px 16px;min-height:46px}

/* топ игроков на главной — карточки-строки (как матчи справа) */
.plist{display:flex;flex-direction:column}
.prow{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:9px 16px;border:1px solid var(--line);border-radius:12px;background:var(--panel);
  margin-bottom:8px;transition:border-color .2s,transform .2s}
.prow:hover{border-color:rgba(246,201,69,.35);transform:translateX(2px)}
.prow .prk{font-family:"Oswald";font-weight:700;font-size:18px;color:var(--faint);width:22px;text-align:center}
.prow .rating-val{font-family:"JetBrains Mono";font-weight:700}
.prow.rank1{background:linear-gradient(135deg,var(--gold),#e9a91f);border-color:rgba(246,201,69,.75);
  color:#1c1402;animation:goldpulse 2.6s ease-in-out infinite}
.prow.rank1 .prk,.prow.rank1 .nm,.prow.rank1 .rating-val{color:#1c1402}
.prow.rank2{background:linear-gradient(100deg,rgba(207,214,224,.16),rgba(207,214,224,.03));border-color:rgba(207,214,224,.45)}
.prow.rank2 .prk{color:#cfd6e0}
.prow.rank3{background:linear-gradient(100deg,rgba(216,160,90,.18),rgba(216,160,90,.03));border-color:rgba(216,160,90,.5)}
.prow.rank3 .prk{color:#d8a05a}
@keyframes goldpulse{0%,100%{box-shadow:0 6px 20px rgba(246,201,69,.30), inset 0 1px 0 rgba(255,255,255,.45)}
  50%{box-shadow:0 10px 34px rgba(246,201,69,.62), inset 0 1px 0 rgba(255,255,255,.55)}}
.mrow .res{font-family:"Oswald";font-weight:700;width:34px;text-align:center}
.mrow .res.win{color:var(--radiant)} .mrow .res.loss{color:var(--dire)}
.mrow .delta{font-family:"JetBrains Mono";font-weight:700}
.mrow .when{font-family:"JetBrains Mono";font-size:12px;color:var(--faint);text-align:right;white-space:nowrap}

/* ============ match page ============ */
.duelpage{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:stretch;margin-bottom:28px}
.side{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--panel)}
.side.win{box-shadow:0 0 0 1px rgba(246,201,69,.4), 0 16px 40px rgba(0,0,0,.4)}
.side .ph{position:relative}
.side .ph img{width:100%;aspect-ratio:16/9;object-fit:cover}
.side .ph .team{position:absolute;top:10px;left:12px;font-family:"Oswald";text-transform:uppercase;font-size:13px;letter-spacing:1px;
  padding:4px 10px;border-radius:7px;background:rgba(8,10,15,.7)}
.side.radiant .ph .team{color:var(--radiant)} .side.dire .ph .team{color:var(--dire)}
.side .pb{padding:18px 20px}
.side .pn{font-family:"Oswald";text-transform:uppercase;font-size:20px;line-height:1;margin:0 0 4px}
.side .pn a:hover{color:var(--gold)}
.side .pd{font-family:"JetBrains Mono";font-weight:700;font-size:15px}
.vsbadge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:0 6px}
.vsbadge .vs{font-family:"Oswald";font-weight:700;font-size:46px;color:var(--gold);text-shadow:0 0 26px rgba(246,201,69,.5)}
.vsbadge .cond{font-family:"JetBrains Mono";font-size:11px;color:var(--faint);text-align:center;text-transform:uppercase;letter-spacing:.1em}
.statrows{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.statrows .sr{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border-bottom:1px solid var(--line)}
.statrows .sr:last-child{border-bottom:0}
.statrows .sr .a{padding:11px 18px;text-align:right;font-family:"JetBrains Mono"}
.statrows .sr .b{padding:11px 18px;text-align:left;font-family:"JetBrains Mono"}
.statrows .sr .lbl{padding:11px 12px;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);text-align:center;background:var(--bg2)}
.statrows .sr .a.lead,.statrows .sr .b.lead{color:var(--gold);font-weight:700}

/* ============ tournaments ============ */
.tlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.tcard{border:1px solid var(--line);border-radius:var(--r);padding:24px;background:linear-gradient(180deg,var(--panel),var(--bg2));transition:transform .2s,border-color .2s}
.tcard:hover{transform:translateY(-5px);border-color:rgba(246,201,69,.4)}
.tcard .st{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border-radius:999px;display:inline-block}
.st.live{color:var(--dire);border:1px solid rgba(255,83,71,.4)} .st.ready,.st.draft{color:var(--gold);border:1px solid rgba(246,201,69,.4)}
.st.finished{color:var(--muted);border:1px solid var(--line)}
.tcard h3{font-family:"Oswald";text-transform:uppercase;font-size:22px;margin:14px 0 6px}
.tcard .tm{color:var(--muted);font-size:14px}
.bracket{display:flex;gap:40px;overflow-x:auto;padding:8px 2px 18px}
.round{display:flex;flex-direction:column;justify-content:space-around;gap:18px;min-width:220px}
.round .rh{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.tm-match{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel)}
.tm-match .p{display:flex;justify-content:space-between;padding:9px 12px;font-size:14px}
.tm-match .p+.p{border-top:1px solid var(--line)}
.tm-match .p.win{background:rgba(67,209,122,.08);font-weight:700}
.tm-match .p .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============ landing (home) ============ */
.hero{position:relative; padding:74px 0 90px; isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:url("/static/img/bg-vs-split.png") center top/cover no-repeat; opacity:.20;
  -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.95),transparent 90%);
  mask-image:linear-gradient(180deg,rgba(0,0,0,.95),transparent 90%)}
.hero .grid{display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center}
.hero h1{font-size:clamp(42px,6.4vw,88px); margin:18px 0 0}
.hero .sub{font-size:clamp(17px,1.9vw,21px); color:var(--muted); max-width:540px; margin:22px 0 0}
.hero .sub b{color:var(--text); font-weight:700}
.cta-row{display:flex; gap:14px; flex-wrap:wrap; margin-top:34px}
.cta-note{font-family:"JetBrains Mono";font-size:12px;color:var(--faint);margin-top:16px;letter-spacing:.05em}
.mini{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.duel{position:relative; aspect-ratio:1/1; max-width:480px; margin-inline:auto; width:100%}
.duel-card{position:absolute; width:62%; border-radius:14px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 26px 60px rgba(0,0,0,.55); background:var(--panel)}
.duel-card img{width:100%; height:100%; object-fit:cover; aspect-ratio:16/10; transition:opacity .45s ease}
.duel-card .tag{position:absolute; left:0; right:0; bottom:0; padding:10px 12px 11px; display:flex; justify-content:space-between; align-items:center;
  background:linear-gradient(0deg,rgba(8,10,15,.92),transparent); font-family:"Oswald";text-transform:uppercase;letter-spacing:.5px;font-size:13px}
.duel-card .tag .mono{font-size:13px}
.duel-card.radiant{top:2%; left:0; transform:rotate(-4deg); border-color:rgba(67,209,122,.45);
  box-shadow:0 26px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(67,209,122,.25), 0 18px 50px rgba(67,209,122,.22); animation:floaty 6s ease-in-out infinite}
.duel-card.dire{bottom:2%; right:0; transform:rotate(4deg); border-color:rgba(255,83,71,.45);
  box-shadow:0 26px 60px rgba(0,0,0,.55), 0 0 0 1px rgba(255,83,71,.25), 0 18px 50px rgba(255,83,71,.22); animation:floaty 6s ease-in-out infinite .9s}
.duel-card.radiant .tag b{color:var(--radiant)} .duel-card.radiant .tag .mono{color:var(--radiant)}
.duel-card.dire .tag b{color:var(--dire)} .duel-card.dire .tag .mono{color:var(--dire)}
.vs{font-family:"Oswald";font-weight:700;line-height:1;letter-spacing:1px;color:var(--gold)}
/* абсолют + пульс — ТОЛЬКО для дуэли на главной (на матче .vsbadge .vs статичный) */
.duel .vs{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) rotate(-7deg); z-index:5;
  font-size:54px; text-shadow:0 0 30px rgba(246,201,69,.55), 0 6px 18px rgba(0,0,0,.6);
  -webkit-text-stroke:1.5px rgba(28,20,2,.55); animation:vspulse 3.4s ease-in-out infinite}
.float{position:absolute; z-index:6; font-family:"JetBrains Mono";font-weight:700; padding:9px 13px;border-radius:11px; font-size:13px; letter-spacing:.05em;
  border:1px solid var(--line); background:rgba(13,17,24,.86); backdrop-filter:blur(6px); box-shadow:0 14px 30px rgba(0,0,0,.5)}
.float.rate{top:-6%; right:4%; color:#04130b; background:linear-gradient(135deg,var(--radiant),#2fa862); border-color:transparent; box-shadow:0 14px 34px rgba(67,209,122,.4)}
.float.time{bottom:-4%; left:2%; color:var(--gold)}
.aha{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.aha .panel{border:1px solid var(--line); border-radius:var(--r); padding:32px; position:relative; overflow:hidden;
  background:radial-gradient(120% 120% at 0% 0%, rgba(67,209,122,.1), transparent 55%), var(--panel)}
.aha .panel.two{background:radial-gradient(120% 120% at 100% 0%, rgba(255,83,71,.12), transparent 55%), var(--panel)}
.aha .step{font-family:"JetBrains Mono";font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.aha h3{font-family:"Oswald";text-transform:uppercase;font-size:24px;margin:10px 0 12px}
.aha p{margin:0;color:var(--muted)} .aha .big{font-family:"Oswald";font-size:40px;color:var(--radiant);margin-top:14px}
.aha .panel.two .big{color:var(--gold)}
.recog{border:1px solid var(--line); border-radius:22px; overflow:hidden; background:linear-gradient(180deg,var(--panel),var(--bg2))}
.recog .top{padding:40px 40px 8px}
.recog .lead{font-size:clamp(20px,2.6vw,28px); font-weight:800; max-width:780px; line-height:1.3}
.recog ul{list-style:none; margin:24px 0 0; padding:0 40px 40px; display:grid; grid-template-columns:1fr 1fr; gap:14px 34px}
.recog li{display:flex; gap:13px; align-items:flex-start; color:var(--muted); font-size:16px}
.recog li::before{content:"›"; color:var(--dire); font-family:"Oswald"; font-weight:700; font-size:20px; line-height:1.2}
.how{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.lane{border:1px solid var(--line);border-radius:var(--r);padding:30px;background:var(--panel)}
.lane.r{box-shadow:inset 3px 0 0 var(--radiant)} .lane.d{box-shadow:inset 3px 0 0 var(--dire)}
.lane .lh{font-family:"Oswald";text-transform:uppercase;font-size:21px;letter-spacing:.5px;margin:0 0 6px}
.lane.r .lh{color:var(--radiant)} .lane.d .lh{color:var(--dire)}
.lane .ls{color:var(--faint);font-family:"JetBrains Mono";font-size:11.5px;letter-spacing:.2em;text-transform:uppercase}
.steps{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.steps li{display:grid;grid-template-columns:30px 1fr;gap:14px;align-items:start}
.steps .n{font-family:"JetBrains Mono";font-weight:700;font-size:13px;color:#04130b;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--radiant)}
.lane.d .steps .n{background:var(--dire);color:#1a0403}
.steps .t{font-weight:700} .steps .v{color:var(--muted);font-size:15px;display:block;margin-top:2px;font-weight:400}
.outcome{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.oc{border:1px solid var(--line);border-radius:var(--r);padding:34px;background:linear-gradient(180deg,var(--panel2),var(--bg2))}
.oc .ic{font-size:34px} .oc .ic-img{height:66px;width:auto;display:block;margin-bottom:2px}
.oc h3{font-family:"Oswald";text-transform:uppercase;font-size:23px;margin:14px 0 8px}
.oc p{margin:0;color:var(--muted)}
.tourn{border:1px solid rgba(246,201,69,.28); border-radius:22px; overflow:hidden;
  background:radial-gradient(80% 130% at 50% -12%, rgba(246,201,69,.13), transparent 60%), linear-gradient(180deg,var(--panel),var(--bg2))}
.tourn .thead{padding:38px 40px 0; text-align:center}
.tourn .pool{font-family:"Oswald";font-weight:700;font-size:clamp(46px,8vw,92px);line-height:1; color:var(--gold); text-shadow:0 0 44px rgba(246,201,69,.4); margin:6px 0 0}
.tourn .pool small{font-size:.42em;color:var(--muted);font-weight:500;display:inline-block;vertical-align:.5em;margin-left:6px}
.tourn .tsub{color:var(--muted); margin:12px 0 0}
.prizes{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; padding:30px 40px 8px}
.prize{border:1px solid var(--line); border-radius:14px; padding:26px 22px; background:rgba(255,255,255,.03); text-align:center; transition:transform .2s ease, border-color .2s ease}
.prize:hover{transform:translateY(-6px); border-color:rgba(246,201,69,.45)}
.prize .pic{font-size:30px; margin-bottom:10px}
.prize h3{font-family:"Oswald";text-transform:uppercase;font-size:18px;letter-spacing:.5px;margin:0 0 7px}
.prize p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.5}
.tourn .tcta{padding:26px 40px 40px; text-align:center}
details{border:1px solid var(--line);border-radius:14px;background:var(--panel);overflow:hidden}
details[open]{border-color:rgba(246,201,69,.35)}
summary{list-style:none;cursor:pointer;padding:22px 24px;font-family:"Oswald";text-transform:uppercase;
  letter-spacing:.4px;font-size:18px;display:flex;justify-content:space-between;align-items:center;gap:16px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:26px;color:var(--gold);transition:transform .25s;line-height:1}
details[open] summary::after{transform:rotate(45deg)}
details .ans{padding:0 24px 24px;color:var(--muted);font-size:16px;max-width:680px}
.faq{display:flex;flex-direction:column;gap:12px;max-width:860px}
.cmp{display:flex;flex-direction:column;gap:16px}
.row{display:grid;grid-template-columns:1fr auto 1.1fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.row .them,.row .us{padding:24px 26px}
.row .them{background:rgba(255,83,71,.05)} .row .us{background:rgba(67,209,122,.06)}
.row .mid{display:grid;place-items:center;padding:0 18px;background:var(--bg2);border-left:1px solid var(--line);border-right:1px solid var(--line)}
.row .arr{font-family:"Oswald";color:var(--gold);font-size:26px}
.row .lbl{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.row .them .lbl{color:var(--dire)} .row .us .lbl{color:var(--radiant)}
.row .who2{font-family:"Oswald";text-transform:uppercase;font-size:17px;margin-bottom:7px}
.row p{margin:0;color:var(--muted);font-size:15px} .row .us p{color:#bfe9cf}
.final{text-align:center; border-radius:26px; padding:72px 30px; margin:30px 0 0; border:1px solid var(--line); position:relative; overflow:hidden;
  background:radial-gradient(60% 120% at 20% 0%, rgba(67,209,122,.16), transparent 60%), radial-gradient(60% 120% at 80% 0%, rgba(255,83,71,.16), transparent 60%), linear-gradient(180deg,var(--panel),var(--bg2))}
.final-logo{height:200px;width:auto;display:block;margin:0 auto 20px;filter:drop-shadow(0 14px 34px rgba(0,0,0,.55))}
.final h2{font-family:"Oswald";text-transform:uppercase;font-size:clamp(32px,5vw,60px);margin:0 0 8px;line-height:1}
.final p{color:var(--muted);margin:0 0 28px} .final .cta-note{justify-content:center;margin-top:24px}

/* модалка «как играть» */
.modal-bg{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,6,10,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.modal-bg[hidden]{display:none}
.modal{position:relative;width:100%;max-width:440px;max-height:92vh;overflow:auto;text-align:center;
  background:radial-gradient(120% 90% at 50% -10%,rgba(246,201,69,.1),transparent 60%),linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line);border-radius:20px;padding:30px 26px 26px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-x{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:9px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);color:var(--muted);font-size:15px;cursor:pointer}
.modal-x:hover{color:var(--text);background:rgba(255,255,255,.1)}
.modal-logo{height:38px;width:auto;margin:0 auto 14px;display:block;filter:drop-shadow(0 6px 16px rgba(0,0,0,.5))}
.modal-h{font-family:"Oswald";text-transform:uppercase;font-size:24px;margin:0 0 6px}
.modal-sub{color:var(--muted);margin:0 0 18px;font-size:15px}
.modal-cta{width:100%;justify-content:center}
.modal-alt{display:inline-block;margin-top:10px;font-size:13px;color:var(--faint);font-family:"JetBrains Mono"}
.modal-alt:hover{color:var(--gold)}
.modal-or{position:relative;color:var(--faint);font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin:22px 0 14px}
.modal-or::before,.modal-or::after{content:"";position:absolute;top:50%;width:22%;height:1px;background:var(--line)}
.modal-or::before{left:0}.modal-or::after{right:0}
.modal-steps{text-align:left;margin:0;padding:0 0 0 22px;display:flex;flex-direction:column;gap:9px;color:var(--text)}
.modal-steps li{font-size:15px}.modal-steps b{color:var(--gold);font-weight:700}
.modal-note{color:var(--muted);font-size:13.5px;margin:18px 0 0;text-align:left}
.modal-note a{color:var(--gold)}

/* reveal */
.no-js .reveal{opacity:1}
html.js .reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal.in{opacity:1; transform:none}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}.d4{transition-delay:.24s}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}50%{transform:translateY(-9px) rotate(var(--rot,0deg))}}
.duel-card.radiant{--rot:-4deg} .duel-card.dire{--rot:4deg}
@keyframes vspulse{0%,100%{transform:translate(-50%,-50%) rotate(-7deg) scale(1)}50%{transform:translate(-50%,-50%) rotate(-7deg) scale(1.08)}}

/* responsive */
@media (max-width:980px){
  .hero .grid{grid-template-columns:1fr; gap:48px} .duel{max-width:420px}
  .cards,.cards.c3{grid-template-columns:1fr 1fr} .prizes{grid-template-columns:1fr}
  .aha,.how,.outcome{grid-template-columns:1fr} .recog ul{grid-template-columns:1fr}
  .nav{position:relative} .burger{display:flex}
  .nav .links{position:absolute;top:calc(100% + 10px);right:0;left:0;flex-direction:column;align-items:stretch;
    gap:6px;background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:10px;margin:0;
    box-shadow:0 22px 50px rgba(0,0,0,.55);display:none;z-index:60}
  header.open .nav .links{display:flex}
  .nav .links a{padding:13px 14px;border-radius:10px;font-size:16px}
  .nav .links a:hover,.nav .links a.active{background:rgba(255,255,255,.06)}
  .nav .links .btn-gold{justify-content:center;margin-top:2px}
  .duelpage{grid-template-columns:1fr} .vsbadge{padding:12px 0}
  .pcard .pstats{grid-template-columns:1fr 1fr} .pcard .pstats > div:nth-child(2){border-right:0}
}
@media (max-width:560px){
  body{font-size:16px} section{padding:56px 0}
  .wrap{padding:0 16px}
  .hero{padding:44px 0 56px}
  .sec-head{margin-bottom:30px}
  .cards,.cards.c3{grid-template-columns:1fr}
  .row{grid-template-columns:1fr} .row .mid{display:none} .row .them{border-bottom:1px solid var(--line)}
  .duel .vs{font-size:42px} .cta-row .btn{flex:1;justify-content:center}
  .page-head{align-items:flex-start}
  table.tbl .hide-sm{display:none}
  .tbl-wrap{overflow-x:auto}
  table.tbl th,table.tbl td{padding:11px 12px}
  /* убираем избыточные внутренние отступы (на 375px 40px слишком много) */
  .recog .top{padding:26px 20px 4px} .recog ul{padding:0 20px 26px;gap:12px}
  .tourn .thead{padding:28px 20px 0} .prizes{padding:22px 20px 4px} .tourn .tcta{padding:22px 20px 28px}
  .pcard .top{padding:24px 22px} .pcard .pstats > div{padding:16px 8px}
  .aha .panel{padding:24px} .lane{padding:22px} .oc{padding:26px} .card{padding:22px 18px}
  .final{padding:48px 20px 52px} .final-logo{height:150px}
  h2,.sec-head h2{overflow-wrap:anywhere}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  html.js .reveal{opacity:1;transform:none;transition:none}
}
