/* ============================================================
   Landing page — page-specific CSS.
   Shell (statusbar/nav/footer/btn/chip/grid-bg/tier/wrap/section/
   mono-small/main/page-head) lives in /static/shared.css.
   This file only contains hero, queue, scoreboard, stats, feats,
   process, road-to-pro, leaderboard preview, end-CTA rules.
   ============================================================ */

/* ── Scanline overlay (landing only) ── */
.scan{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 0%,rgba(255,70,85,0.015) 50%,transparent 100%);
  background-size:100% 4px;
  opacity:0.4;
}

/* ── Section head (denser variant for landing) ── */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:48px;gap:40px;border-bottom:1px solid var(--line);padding-bottom:20px;
}
.section-head .label{
  font-family:var(--mono);font-size:11px;color:var(--red);
  letter-spacing:0.2em;text-transform:uppercase;margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.section-head .label::before{content:'';width:24px;height:1px;background:var(--red)}
.section-head h2{
  font-size:clamp(32px,4vw,48px);font-weight:600;letter-spacing:-0.02em;
  line-height:1;
}
.section-head .meta{
  font-family:var(--mono);font-size:11px;color:var(--fg-mute);
  letter-spacing:0.1em;text-transform:uppercase;
  display:flex;gap:20px;flex-shrink:0;
}
.section-head .meta span{display:flex;flex-direction:column;gap:2px}
.section-head .meta b{color:var(--fg);font-weight:600}

/* ── HERO ── */
.hero{
  padding-top:140px;padding-bottom:80px;
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:48px;align-items:stretch;
}
.hero-left{display:flex;flex-direction:column}
.hero-crosshair{
  display:flex;align-items:center;gap:16px;
  font-family:var(--mono);font-size:11px;color:var(--fg-dim);
  letter-spacing:0.16em;text-transform:uppercase;margin-bottom:32px;
}
.hero-crosshair .tag{
  padding:4px 10px;border:1px solid var(--line-red);color:var(--red);
  background:var(--red-bg);
}
.hero-crosshair .coord{color:var(--fg-mute)}
.hero h1{
  font-size:clamp(48px,7.5vw,104px);font-weight:700;
  line-height:0.92;letter-spacing:-0.035em;margin-bottom:28px;
  overflow-wrap:anywhere;hyphens:auto;
}
/* Russian translations include single very long words ("Соревновательные")
   that overflow the hero left column at the default clamp ceiling. Scale
   down the upper bound + tighten letter-spacing so the headline fits. */
:lang(ru) .hero h1{
  font-size:clamp(40px,6.4vw,84px);
  letter-spacing:-0.04em;
}
.hero h1 .red{color:var(--red)}
.hero h1 .outlined{
  -webkit-text-stroke:1.5px var(--fg);
  color:transparent;
}
.hero h1 .slash{
  color:var(--fg-mute);font-weight:500;
  margin:0 0.15em;
}
.hero p.sub{
  font-size:18px;color:var(--fg-dim);max-width:520px;margin-bottom:36px;
  line-height:1.55;
}
.hero-ctas{display:flex;gap:12px;margin-bottom:44px;flex-wrap:wrap}

/* Queue panel */
.queue-panel{
  margin-top:auto;border:1px solid var(--line);
  background:var(--bg-1);
  padding:0;
}
.queue-head{
  padding:10px 14px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:11px;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--fg-dim);
}
.queue-head .live{
  display:flex;align-items:center;gap:8px;color:var(--green);
}
.queue-head .live .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 1.2s ease-in-out infinite}
.queue-body{
  display:grid;grid-template-columns:1fr 1fr;
}
.queue-side{
  padding:18px 16px;display:flex;flex-direction:column;gap:8px;
}
.queue-side + .queue-side{border-left:1px solid var(--line)}
.queue-side-head{
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);
  letter-spacing:0.12em;text-transform:uppercase;display:flex;justify-content:space-between;
}
.queue-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 10px;background:var(--bg);
  border-left:2px solid transparent;
}
.queue-row.active{border-left-color:var(--red)}
.queue-row .name{
  font-family:var(--mono);font-size:12px;color:var(--fg);display:flex;align-items:center;gap:8px;
}
.queue-row .name .idx{color:var(--fg-mute);font-weight:500;width:14px;text-align:right}
.queue-row .rank{font-family:var(--mono);font-size:11px;color:var(--fg-dim)}
.queue-row.empty .name{color:var(--fg-mute)}
.queue-row.empty .name .idx{color:var(--fg-mute)}
.queue-row.empty .rank{color:var(--fg-mute)}
.queue-panel.offline .queue-head{color:var(--red)}
.queue-panel.offline .queue-head .live .dot{background:var(--red);box-shadow:0 0 8px var(--red);animation:none}

/* ── Hero scoreboard card ── */
.hero-right{
  border:1px solid var(--line);background:var(--bg-1);
  display:flex;flex-direction:column;
  position:relative;
}
.scoreboard-head{
  padding:12px 16px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:11px;
}
.scoreboard-head .info{color:var(--fg-dim);display:flex;gap:14px}
.scoreboard-head .info b{color:var(--fg);font-weight:600}

.map-strip{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;padding:18px 16px;gap:14px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(77,159,255,0.04),transparent 40%,transparent 60%,rgba(255,70,85,0.04));
}
.team{display:flex;flex-direction:column;gap:4px}
.team.right{text-align:right;align-items:flex-end}
.team .tname{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-dim)}
.team.left .tname{color:var(--blue)}
.team.right .tname{color:var(--red)}
.team .tscore{font-family:var(--mono);font-size:48px;font-weight:700;line-height:1;letter-spacing:-0.02em}
.team.left .tscore{color:var(--blue)}
.team.right .tscore{color:var(--red)}
.map-info{
  text-align:center;font-family:var(--mono);font-size:10px;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);
  display:flex;flex-direction:column;gap:4px;
}
.map-info .m{color:var(--fg);font-size:14px;letter-spacing:0.1em;font-weight:600}

.sb-placeholder{
  flex:1;padding:20px 16px 14px;
  display:flex;flex-direction:column;gap:14px;
  border-bottom:1px solid var(--line);
  font-family:var(--mono);
  color:var(--fg-mute);
  background:
    radial-gradient(ellipse 80% 60% at 50% 50%,rgba(255,70,85,0.02),transparent 70%);
}
.sb-placeholder .sb-cells{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
}
.sb-placeholder .sb-cell{
  display:flex;flex-direction:column;gap:4px;
  padding:0 12px;border-right:1px solid var(--line);text-align:center;
}
.sb-placeholder .sb-cell:last-child{border-right:none}
.sb-placeholder .sb-k{
  font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);font-weight:600;
}
.sb-placeholder .sb-v{
  font-size:16px;color:var(--fg);font-weight:600;letter-spacing:0.02em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.sb-placeholder .sb-v .mvp{
  color:var(--amber);font-weight:700;letter-spacing:0.04em;
}
.sb-placeholder .sb-sub{
  font-size:10px;color:var(--fg-dim);letter-spacing:0.08em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.sb-placeholder .sb-note{
  font-size:10px;letter-spacing:0.14em;text-transform:uppercase;
  text-align:center;color:var(--fg-dim);
}

.scoreboard-foot{
  padding:10px 16px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-mute);
}
.scoreboard-foot a{color:var(--fg-dim);display:flex;align-items:center;gap:6px}
.scoreboard-foot a:hover{color:var(--fg)}

/* ── STATS STRIP ── */
.stats{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-1);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
}
.stat{
  padding:28px 24px;border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
  position:relative;
}
.stat:first-child{border-left:none}
.stat .k{
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);
  letter-spacing:0.16em;text-transform:uppercase;
}
.stat .v{
  font-family:var(--mono);font-size:32px;font-weight:600;letter-spacing:-0.01em;color:var(--fg);
  line-height:1;
}
.stat .v .u{color:var(--fg-mute);font-size:18px;margin-left:4px}
.stat .delta{
  font-family:var(--mono);font-size:11px;color:var(--green);
}
.stat .delta.dn{color:var(--red)}

/* ── FEATURES ── */
.feats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);background:var(--bg-1);
}
.feat{
  padding:28px 24px;border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:16px;
  transition:background 0.2s ease;position:relative;
}
.feat:first-child{border-left:none}
.feat:hover{background:var(--bg-2)}
.feat-id{
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);
  letter-spacing:0.14em;display:flex;justify-content:space-between;align-items:center;
}
.feat-id .red{color:var(--red)}
.feat-ico{width:32px;height:32px;color:var(--red)}
.feat-ico svg{width:100%;height:100%}
.feat h3{font-size:18px;font-weight:600;letter-spacing:-0.01em;line-height:1.2}
.feat p{font-size:13px;color:var(--fg-dim);line-height:1.55}
.feat code{
  background:var(--bg-3);padding:1px 5px;font-size:11px;color:var(--red);
  border:1px solid var(--line);
}
.feat-spec{
  margin-top:auto;padding-top:16px;border-top:1px dashed var(--line);
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg-mute);
}
.feat-spec b{color:var(--fg);font-weight:600}

/* ── PROCESS ── */
.landing-process{padding-top:40px}
.process{
  border:1px solid var(--line);background:var(--bg-1);
  position:relative;
}
.process-head{
  display:grid;grid-template-columns:repeat(6,1fr);
  border-bottom:1px solid var(--line);
}
.phase{
  padding:16px;border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;
  position:relative;
}
.phase:first-child{border-left:none}
.phase .num{
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);
  letter-spacing:0.14em;display:flex;justify-content:space-between;
}
.phase .num .t{color:var(--red)}
.phase .ph-name{font-size:14px;font-weight:600;letter-spacing:-0.01em;margin-top:4px}
.phase.done .num .t{color:var(--green)}
.phase.active{background:var(--red-bg);border-left-color:var(--red)}
.phase.active::after{
  content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--red);
}

.process-body{
  display:grid;grid-template-columns:repeat(6,1fr);
  min-height:220px;
}
.pcol{
  padding:22px 18px;border-left:1px solid var(--line);
  display:flex;flex-direction:column;gap:12px;
  font-family:var(--mono);font-size:11px;color:var(--fg-dim);
  line-height:1.6;
}
.pcol:first-child{border-left:none}
.pcol.pcol-active{background:var(--red-bg);border-left-color:var(--red)}
.pcol .cmd{
  background:var(--bg);border:1px solid var(--line);
  padding:8px 10px;font-size:11px;color:var(--fg);
  display:flex;align-items:center;gap:8px;
}
.pcol .cmd::before{content:'>';color:var(--red);font-weight:700}
.pcol .kv{display:flex;justify-content:space-between;gap:8px;padding:4px 0;border-bottom:1px dashed var(--line)}
.pcol .kv span:first-child{color:var(--fg-mute)}
.pcol .kv span:last-child{color:var(--fg)}
.pcol .note{color:var(--fg-mute);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;margin-top:auto}
.pcol .note.pcol-note-red{color:var(--red)}
.pcol .note.pcol-note-green{color:var(--green)}
.pcol .big{font-size:22px;color:var(--fg);font-weight:600;letter-spacing:-0.01em;font-family:var(--sans)}

/* ── ROAD TO PRO ── */
.landing-road{padding-top:40px}
.road{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);
  gap:24px;align-items:stretch;
}
.road-left{
  border:1px solid var(--line);background:var(--bg-1);padding:32px 28px;
  display:flex;flex-direction:column;gap:14px;
}
.road-left .tag{
  font-family:var(--mono);font-size:11px;color:var(--red);letter-spacing:0.2em;text-transform:uppercase;
}
.road-left h3{font-size:34px;font-weight:600;letter-spacing:-0.02em;line-height:1.05}
.road-left p{color:var(--fg-dim);font-size:15px;line-height:1.6}
.road-left .req{
  margin-top:auto;padding-top:18px;border-top:1px dashed var(--line);
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.req .k{font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:4px}
.req .v{font-family:var(--mono);font-size:18px;color:var(--fg);font-weight:600}

.road-right{
  border:1px solid var(--line);background:var(--bg-1);padding:28px;
  display:flex;flex-direction:column;gap:24px;
}
/* Scope road-tier grid layout under .tiers so it overrides the shared
   .tier chip rule. shared.css has .tier{display:inline-flex;...}, but
   inside .tiers we want a three-column grid row. */
.tiers{position:relative}
.tiers .tier{
  display:grid;grid-template-columns:40px 1fr auto;gap:16px;align-items:center;
  padding:16px 0;border:none;border-bottom:1px solid var(--line);
  color:var(--fg);font-size:inherit;font-family:inherit;letter-spacing:0;text-transform:none;
}
.tiers .tier:last-child{border-bottom:none}
.tiers .tier .t-num{
  font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:0.1em;
}
.tiers .tier .t-body{display:flex;flex-direction:column;gap:2px}
.tiers .tier .t-name{font-size:18px;font-weight:600;letter-spacing:-0.01em}
.tiers .tier .t-desc{font-family:var(--mono);font-size:11px;color:var(--fg-dim);letter-spacing:0.04em}
.tiers .tier .t-range{
  font-family:var(--mono);font-size:11px;color:var(--fg-dim);
  padding:4px 10px;border:1px solid var(--line-2);
}
.tiers .tier.final .t-num{color:var(--red)}
.tiers .tier.final .t-name{color:var(--red)}
.tiers .tier.final .t-range{border-color:var(--line-red);color:var(--red);background:var(--red-bg)}

.progress{
  position:relative;height:6px;background:var(--bg-3);
  margin-top:8px;
}
.progress-fill{
  position:absolute;inset:0;width:62%;
  background:linear-gradient(90deg,var(--blue),var(--red));
}
.progress-ticks{
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);
  letter-spacing:0.08em;margin-top:8px;
}

/* ── LEADERBOARD PREVIEW ── */
.landing-leader{padding-top:40px}
.leader{
  border:1px solid var(--line);background:var(--bg-1);
}
.leader-head{
  padding:14px 20px;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:40px 1fr 100px 100px 80px 80px 80px;
  gap:16px;font-family:var(--mono);font-size:10px;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
}
.leader-row{
  padding:14px 20px;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:40px 1fr 100px 100px 80px 80px 80px;
  gap:16px;align-items:center;font-family:var(--mono);font-size:13px;
  transition:background 0.1s ease;
}
.leader-row:hover{background:var(--bg-2)}
.leader-row:last-child{border-bottom:none}
.leader-row .rank{color:var(--fg-mute);font-weight:600}
.leader-row.top1 .rank{color:var(--amber)}
.leader-row.top2 .rank{color:#c9cdd6}
.leader-row.top3 .rank{color:#c68c4c}
.leader-row .player{color:var(--fg);font-weight:600;font-family:var(--sans);display:flex;align-items:center;gap:10px}
.leader-row .avatar{
  width:28px;height:28px;background:var(--bg-3);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;color:var(--fg-dim);font-weight:700;
}
.leader-row .tier{color:var(--fg);font-size:12px;padding:3px 8px;border:1px solid var(--line-2);justify-self:start;font-weight:600}
.leader-row .tier.rad{color:var(--amber);border-color:#ffb54755}
.leader-row .tier.imm{color:var(--red);border-color:#ff465555}
.leader-row .tier.asc{color:var(--green);border-color:#3ddc8455}
.leader-row .tier.dia{color:#8b5dff;border-color:#8b5dff55}
.leader-row .elo{color:var(--fg);font-weight:600;text-align:right}
.leader-row .wl{color:var(--fg-dim);text-align:right}
.leader-row .wr{color:var(--fg);text-align:right}
.leader-row .streak{text-align:right;font-weight:600}
.leader-row .streak.up{color:var(--green)}
.leader-row .streak.down{color:var(--red)}
.leader-row.leader-empty .player{color:var(--fg-mute);font-family:var(--mono);font-size:12px}

/* ── END CTA ── */
.endcta{
  padding:100px 0;position:relative;
  border-top:1px solid var(--line);
}
.endcta-grid{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:center}
.endcta-copy{text-align:left}
.endcta .xh{
  font-family:var(--mono);font-size:11px;color:var(--red);
  letter-spacing:0.24em;text-transform:uppercase;margin-bottom:20px;
  display:inline-flex;align-items:center;gap:10px;
}
.endcta .xh::after{content:'';width:40px;height:1px;background:var(--red)}
.endcta h2{
  font-size:clamp(40px,6vw,72px);font-weight:600;letter-spacing:-0.03em;line-height:1;
  margin-bottom:18px;
}
.endcta p{color:var(--fg-dim);max-width:560px;margin:0 0 32px;font-size:17px}
.endcta-btn{padding:18px 32px;font-size:13px}
.endcta-widget{border:1px solid var(--line);background:var(--bg);padding:8px}
.endcta-widget iframe{display:block;width:100%;border:0}

/* ── RESPONSIVE ── */
@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .feats{grid-template-columns:repeat(2,1fr)}
  .feat:nth-child(3){border-left:none}
  .feat:nth-child(3),.feat:nth-child(4){border-top:1px solid var(--line)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-left:none}
  .stat:nth-child(n+3){border-top:1px solid var(--line)}
  .process-head,.process-body{grid-template-columns:repeat(3,1fr)}
  .phase:nth-child(4){border-left:none}
  .phase:nth-child(n+4){border-top:1px solid var(--line)}
  .pcol:nth-child(4){border-left:none}
  .pcol:nth-child(n+4){border-top:1px solid var(--line)}
  .road{grid-template-columns:1fr}
  .leader-head,.leader-row{grid-template-columns:32px 1fr 80px 90px 70px}
  .leader-row .wr,.leader-row .streak,.leader-head > span:nth-child(6),.leader-head > span:nth-child(7){display:none}
  .endcta-grid{grid-template-columns:1fr;gap:32px}
  .endcta-copy{text-align:center}
  .endcta p{margin-left:auto;margin-right:auto}
  .endcta-widget{max-width:380px;margin:0 auto}
}
@media (max-width:700px){
  .hero h1{font-size:52px}
  .stats-grid{grid-template-columns:1fr}
  .stat{border-left:none;border-top:1px solid var(--line)}
  .stat:first-child{border-top:none}
  .feats{grid-template-columns:1fr}
  .feat{border-left:none;border-top:1px solid var(--line)}
  .feat:first-child{border-top:none}
  .process-head,.process-body{grid-template-columns:1fr}
  .phase,.pcol{border-left:none;border-top:1px solid var(--line)}
  .phase:first-child,.pcol:first-child{border-top:none}
  .section-head{flex-direction:column;align-items:flex-start;gap:16px}
  .section-head .meta{display:none}
  .leader-head,.leader-row{grid-template-columns:32px 1fr 80px 70px}
  .leader-row .tier,.leader-head > span:nth-child(4){display:none}
}
