/* ============================================================
   Hrivix — site-wide styles
   Brand: Space Grotesk (display) · Hanken Grotesk (text) · Space Mono (accents)
   Palette: ink #0A0B14 · blue #2A43FF · azure #5C7CFF · lime #CBF94A · violet #8B5CF6
   ============================================================ */
:root{
  --ink:#0A0B14;
  --graphite:#2B2F42;
  --slate:#6B7187;
  --faint:#9AA0BD;
  --mist:#E6E8F2;
  --cloud:#F5F6FB;
  --white:#FFFFFF;
  --blue:#2A43FF;
  --blue-deep:#1E33CC;
  --azure:#5C7CFF;
  --lime:#CBF94A;
  --violet:#8B5CF6;
  --green:#2B9A66;
  --red:#E5484D;
  --amber:#D98E04;
  --blue-tint:rgba(42,67,255,.07);
  --lime-tint:rgba(203,249,74,.16);
  --r:20px;
  --r-sm:13px;
  --maxw:1200px;
  --pad:40px;
  --display:'Space Grotesk',sans-serif;
  --text:'Hanken Grotesk',sans-serif;
  --mono:'Space Mono',monospace;
  --shadow:0 1px 2px rgba(10,11,20,.04),0 10px 30px -18px rgba(10,11,20,.14);
  --shadow-lg:0 24px 60px -28px rgba(10,11,20,.28);
  --paper:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--text);color:var(--ink);background:var(--white);line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}
@media(max-width:760px){:root{--pad:20px;}}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-.025em;line-height:1.04;text-wrap:balance;}
/* Blazor's <FocusOnNavigate Selector="h1"> programmatically focuses the heading after each
   navigation; suppress the resulting focus ring (headings aren't interactive). */
h1:focus,h1:focus-visible{outline:none;}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);}
.kicker.dim{color:var(--slate);}
.lead{font-size:clamp(16.5px,1.6vw,19.5px);color:var(--graphite);max-width:62ch;text-wrap:pretty;}
.tiny{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--display);
  font-weight:600;font-size:15.5px;letter-spacing:-.01em;text-decoration:none;cursor:pointer;border:0;
  border-radius:12px;padding:14px 22px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;}
.btn svg{width:17px;height:17px;flex:none;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 12px 28px -12px rgba(42,67,255,.55);}
.btn-primary:hover{background:var(--blue-deep);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--mist);}
.btn-ghost:hover{border-color:var(--ink);}
.btn-lime{background:var(--lime);color:var(--ink);box-shadow:0 12px 28px -14px rgba(160,200,30,.7);}
.btn.sm{padding:10px 16px;font-size:14px;border-radius:10px;}

/* ---------- badges & pills ---------- */
.pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;padding:7px 14px;border-radius:999px;
  border:1px solid var(--mist);color:var(--slate);background:#fff;}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);flex:none;}
.pill .dot.live{background:var(--green);box-shadow:0 0 0 3px rgba(43,154,102,.18);}
.badge{display:inline-flex;align-items:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;padding:5px 10px;border-radius:7px;}
.badge.b-blue{background:var(--blue-tint);color:var(--blue);}
.badge.b-lime{background:var(--lime-tint);color:#5d7a06;}
.badge.b-violet{background:rgba(139,92,246,.1);color:var(--violet);}
.badge.b-green{background:rgba(43,154,102,.1);color:var(--green);}

/* ---------- header / nav (NavBar.razor) ---------- */
.site-nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--mist);}
.site-nav .bar{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);height:68px;
  display:flex;align-items:center;gap:30px;}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex:none;}
.logo .word{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.03em;color:var(--ink);}
.logo .word i{font-style:normal;color:var(--blue);}
.logo svg{width:28px;height:28px;}
.site-nav nav{display:flex;gap:4px;margin-left:8px;}
.site-nav nav a{font-family:var(--text);font-weight:600;font-size:14.5px;color:var(--slate);text-decoration:none;
  padding:9px 13px;border-radius:9px;transition:color .12s,background .12s;white-space:nowrap;}
.site-nav nav a:hover{color:var(--ink);background:var(--cloud);}
.site-nav nav a.on{color:var(--blue);background:var(--blue-tint);}
.site-nav .spacer{flex:1;}
.site-nav .cta{flex:none;}
@media(max-width:920px){.site-nav nav{display:none;}}

/* breadcrumb strip for project sub-pages (ProjectStrip.razor) */
.proj-strip{background:var(--ink);color:#fff;}
.proj-strip .bar{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);height:46px;display:flex;align-items:center;gap:18px;}
.proj-strip .pname{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);
  text-decoration:none;flex:none;}
.proj-strip nav{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;}
.proj-strip nav::-webkit-scrollbar{display:none;}
.proj-strip nav a{font-size:13px;font-weight:600;color:#9AA0BD;text-decoration:none;padding:7px 11px;border-radius:8px;white-space:nowrap;}
.proj-strip nav a:hover{color:#fff;}
.proj-strip nav a.on{color:#fff;background:rgba(255,255,255,.1);}

/* ---------- section scaffolding ---------- */
section{padding:90px 0;}
section.tight{padding:64px 0;}
section.alt{background:var(--cloud);border-top:1px solid var(--mist);border-bottom:1px solid var(--mist);}
section.dark{background:var(--ink);color:#fff;}
section.dark .lead{color:#AAB0C8;}
.sec-head{margin-bottom:44px;max-width:740px;}
.sec-head h2{font-size:clamp(30px,3.6vw,46px);margin:13px 0 14px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head.row{max-width:none;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.sec-head.row h2{margin-bottom:0;}
@media(max-width:760px){section{padding:64px 0;}}

.grid{display:grid;gap:18px;}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:980px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr;}}

.card{background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:26px;box-shadow:var(--shadow);}

/* ---------- flags ---------- */
.flag{border-radius:4px;object-fit:cover;box-shadow:0 0 0 1px rgba(10,11,20,.08);background:var(--cloud);}

/* ---------- footer (SiteFooter.razor) ---------- */
.site-foot{background:var(--ink);color:var(--faint);padding:72px 0 44px;}
.site-foot .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:48px;
  border-bottom:1px solid #1B1E30;}
@media(max-width:860px){.site-foot .cols{grid-template-columns:1fr 1fr;}}
@media(max-width:540px){.site-foot .cols{grid-template-columns:1fr;}}
.site-foot .word{font-family:var(--display);font-weight:700;font-size:24px;color:#fff;letter-spacing:-.03em;}
.site-foot .word i{font-style:normal;color:var(--lime);}
.site-foot .blurb{font-size:14px;margin-top:14px;max-width:34ch;text-wrap:pretty;}
.site-foot h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:16px;}
.site-foot ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.site-foot ul a{color:var(--faint);text-decoration:none;font-size:14.5px;}
.site-foot ul a:hover{color:#fff;}
.site-foot .legal{padding-top:28px;display:flex;flex-direction:column;gap:14px;}
.site-foot .legal p{font-size:12.5px;line-height:1.65;color:#6E7596;max-width:96ch;text-wrap:pretty;}
.site-foot .legal .row{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#6E7596;}

/* ---------- shared page hero ---------- */
.page-hero{padding:74px 0 60px;}
.page-hero h1{font-size:clamp(38px,5.4vw,64px);margin:16px 0 18px;max-width:18ch;}
.page-hero .lead{margin-bottom:28px;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* ---------- tables ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:14.5px;}
.tbl th{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);
  text-align:left;padding:12px 14px;border-bottom:1px solid var(--mist);}
.tbl td{padding:14px;border-bottom:1px solid var(--mist);vertical-align:middle;}
.tbl tr:last-child td{border-bottom:0;}

/* ---------- footnote / disclosure ---------- */
.disclosure{display:flex;gap:12px;align-items:flex-start;background:var(--cloud);border:1px solid var(--mist);
  border-radius:var(--r-sm);padding:16px 18px;font-size:13px;color:var(--slate);line-height:1.6;}
.disclosure svg{width:18px;height:18px;flex:none;margin-top:2px;color:var(--blue);}

/* ============================================================
   HOME / HUB  (Pages/Home.razor)
   ============================================================ */
.home-hero{position:relative;overflow:hidden;padding:96px 0 110px;}
.home-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(640px 420px at 88% 0%, rgba(42,67,255,.08), transparent 65%),
    radial-gradient(520px 380px at 0% 100%, rgba(203,249,74,.14), transparent 60%);}
.home-hero .wrap{position:relative;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:64px;align-items:center;}
@media(max-width:960px){.home-hero .wrap{grid-template-columns:1fr;gap:48px;}}
.home-hero h1{font-size:clamp(44px,6vw,76px);margin:18px 0 20px;max-width:14ch;}
.home-hero h1 .u{position:relative;white-space:nowrap;}
.home-hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.18em;
  background:var(--lime);z-index:-1;border-radius:3px;}
.hero-proof{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap;}
.hero-proof .item{display:flex;flex-direction:column;gap:3px;}
.hero-proof .n{font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.02em;}
.hero-proof .l{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);}

/* hub visual — stacked project windows */
.hubviz{position:relative;min-height:420px;}
.pwin{position:absolute;background:#fff;border:1px solid var(--mist);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;}
.pwin .pbar{display:flex;align-items:center;gap:7px;padding:10px 13px;border-bottom:1px solid var(--mist);}
.pwin .pbar i{width:9px;height:9px;border-radius:50%;background:var(--mist);font-style:normal;}
.pwin .pbar .url{margin-left:6px;font-family:var(--mono);font-size:10.5px;color:var(--slate);background:var(--cloud);
  padding:4px 11px;border-radius:7px;letter-spacing:.02em;}
.pwin .pbody{padding:16px;}
.pwin.w1{width:330px;top:8px;left:0;z-index:3;}
.pwin.w2{width:300px;top:130px;right:0;z-index:4;}
.pwin.w3{width:260px;bottom:0;left:46px;z-index:5;}
@media(max-width:960px){.hubviz{min-height:380px;max-width:560px;}}
@media(max-width:560px){.pwin.w1{width:75%;}.pwin.w2{width:66%;}.pwin.w3{width:60%;left:8%;}}
.mini-h{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:-.01em;margin-bottom:9px;}
.mini-row{display:flex;align-items:center;gap:9px;padding:7px 0;border-top:1px solid var(--cloud);font-size:12.5px;font-weight:600;color:var(--graphite);}
.mini-row img{width:21px;height:14px;}
.mini-row .sc{margin-left:auto;font-family:var(--mono);font-size:11.5px;color:var(--slate);}
.mini-bar{height:8px;border-radius:99px;background:var(--cloud);overflow:hidden;margin:7px 0 11px;}
.mini-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),var(--azure));}
.mini-tag{display:inline-block;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-tint);border-radius:6px;padding:4px 8px;margin-bottom:9px;}

/* live projects */
.proj-card{display:flex;flex-direction:column;gap:0;text-decoration:none;color:inherit;overflow:hidden;
  background:#fff;border:1px solid var(--mist);border-radius:var(--r);box-shadow:var(--shadow);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;}
.proj-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#d6daea;}
.proj-card .art{height:150px;position:relative;display:flex;align-items:flex-end;padding:18px;}
.proj-card .art .badge{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);}
.proj-card .art h3{color:#fff;font-size:23px;letter-spacing:-.02em;max-width:14ch;}
.proj-card .body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px;flex:1;}
.proj-card .body p{font-size:14.5px;color:var(--slate);text-wrap:pretty;flex:1;}
.proj-card .go{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--blue);}
.proj-card .go svg{width:15px;height:15px;transition:transform .15s;}
.proj-card:hover .go svg{transform:translateX(3px);}
.proj-card .art-1{background:radial-gradient(120% 160% at 80% 0%,#5C7CFF,#2A43FF 55%,#1E33CC);}
.proj-card .art-2{background:radial-gradient(120% 160% at 20% 0%,#2B2F42,#0A0B14);}
.proj-card .art-3{background:radial-gradient(120% 160% at 80% 0%,#A78BFA,#8B5CF6 60%,#6D3FE0);}

/* address pattern (dark section) */
.addr{display:flex;flex-direction:column;gap:14px;margin-top:36px;}
.addr .row{display:flex;align-items:center;gap:14px;background:#12152A;border:1px solid #222843;border-radius:14px;
  padding:16px 20px;font-family:var(--mono);font-size:clamp(12px,1.7vw,15px);letter-spacing:.02em;flex-wrap:wrap;}
.addr .row .host{color:#6E7596;}
.addr .row .proj{color:var(--lime);}
.addr .row .what{margin-left:auto;font-family:var(--text);font-size:13px;color:#9AA0BD;font-weight:600;}
@media(max-width:560px){.addr .row .what{margin-left:0;width:100%;}}

/* ============================================================
   HUB v2 — bento landing (Pages/Home.razor, mirrors hub.html)
   ============================================================ */
.hub-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:88px 0 0;}
.hub-hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 460px at 80% -15%, rgba(42,67,255,.55), transparent 62%),
    radial-gradient(420px 320px at 5% 105%, rgba(139,92,246,.28), transparent 60%);}
.hub-hero .wrap{position:relative;z-index:2;}
.hub-hero .word{font-family:var(--display);font-weight:700;letter-spacing:-.045em;line-height:.92;
  font-size:clamp(64px,11vw,150px);}
.hub-hero .word i{font-style:normal;color:var(--lime);}
.hub-hero .tag{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin-top:18px;}
.hub-hero .tag p{font-size:clamp(16px,1.8vw,20px);color:#AAB0C8;max-width:52ch;text-wrap:pretty;}
.hub-hero .pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#C9CEE2;}

/* ticker (dark) */
.ticker{margin-top:54px;border-top:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);overflow:hidden;}
.ticker .lane{display:flex;gap:0;white-space:nowrap;width:max-content;animation:tick 36s linear infinite;}
@media (prefers-reduced-motion: reduce){.ticker .lane{animation:none;}}
@keyframes tick{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.ticker span{display:inline-flex;align-items:center;gap:10px;padding:13px 26px;font-family:var(--mono);
  font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:#8189A8;}
.ticker b{color:var(--lime);font-weight:400;}

/* ---- bento ---- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;}
.bento .b{border-radius:var(--r);border:1px solid var(--mist);background:#fff;box-shadow:var(--shadow);
  position:relative;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  transition:transform .18s ease,box-shadow .18s ease;}
.bento a.b:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.bento .b .pad{padding:26px;display:flex;flex-direction:column;gap:10px;flex:1;}
.bento .b h3{font-size:20px;}
.bento .b p{font-size:13.5px;color:var(--slate);text-wrap:pretty;}
.bento .b .go{margin-top:auto;font-family:var(--display);font-weight:600;font-size:14px;color:var(--blue);display:inline-flex;align-items:center;gap:7px;}
.bento .b .go svg{width:15px;height:15px;transition:transform .15s;}
.bento a.b:hover .go svg{transform:translateX(3px);}

/* feature: world cup */
.bento .b.wc{grid-column:span 7;background:radial-gradient(130% 170% at 85% -10%,#3E5FFF,#2A43FF 48%,#1A2ECC);
  border:0;color:#fff;min-height:340px;}
.bento .b.wc .pad{padding:32px;}
.bento .b.wc .topline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.bento .b.wc h2{font-size:clamp(28px,3.4vw,42px);letter-spacing:-.025em;line-height:1;color:#fff;max-width:14ch;}
.bento .b.wc p{color:#C9D2FF;font-size:15px;max-width:44ch;}
.bento .b.wc .cd{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap;}
.bento .b.wc .cell{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:11px;
  padding:9px 14px;text-align:center;min-width:64px;}
.bento .b.wc .cell .n{font-family:var(--display);font-weight:700;font-size:24px;font-variant-numeric:tabular-nums;}
.bento .b.wc .cell .l{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#B9C4FF;}
.bento .b.wc h2 a:hover{text-decoration:underline;text-decoration-color:var(--lime);text-underline-offset:6px;}
.bento .b.wc .links{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;}
.bento .b.wc .links a{font-family:var(--display);font-weight:600;font-size:13.5px;color:#fff;text-decoration:none;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:9px 16px;
  transition:background .14s;}
.bento .b.wc .links a:hover{background:rgba(255,255,255,.24);}
.bento .b.wc .ball{position:absolute;right:-58px;bottom:-58px;width:230px;height:230px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.25),rgba(255,255,255,.05) 60%);
  border:1px solid rgba(255,255,255,.18);}

/* side stack cards */
.bento .b.s4{grid-column:span 5;}
.bento .b.s6{grid-column:span 6;}
.bento .b.s3{grid-column:span 4;}
.bento .b .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;}
.bento .b .ic svg{width:21px;height:21px;}
.bento .b .kick{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);}

/* violet accent mini (predictions) */
.bento .b.inkbg{background:linear-gradient(160deg,#FBFAFF,#F3EFFE);border-color:#E2D9F8;}
.bento .b.inkbg h3{color:var(--ink);} .bento .b.inkbg p{color:var(--slate);} .bento .b.inkbg .go{color:var(--violet);}

/* ---- bento data widgets ---- */
.fixt{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  border-radius:13px;padding:11px 14px;margin-top:6px;}
.fixt img{width:26px;height:18px;border-radius:3px;box-shadow:0 0 0 1px rgba(255,255,255,.2);}
.fixt .t{font-family:var(--display);font-weight:600;font-size:14.5px;color:#fff;}
.fixt .vs{font-family:var(--mono);font-size:10px;color:#B9C4FF;letter-spacing:.14em;}
.fixt .ven{margin-left:auto;text-align:right;font-family:var(--mono);font-size:10px;color:#B9C4FF;letter-spacing:.06em;line-height:1.5;text-transform:uppercase;}
@media(max-width:560px){.fixt .ven{display:none;}}
.miniprob{margin-top:4px;}
.miniprob .bar{display:flex;height:9px;border-radius:99px;overflow:hidden;}
.miniprob .bar i{display:block;height:100%;}
.miniprob .lbl{display:flex;justify-content:space-between;margin-top:7px;font-family:var(--mono);font-size:10px;color:var(--slate);letter-spacing:.04em;}
.miniprob .lbl b{color:var(--ink);}
.headlines{display:flex;flex-direction:column;margin-top:2px;}
.headlines .hl{display:flex;gap:10px;align-items:baseline;padding:8px 0;border-top:1px solid var(--cloud);}
.headlines .hl:first-child{border-top:0;}
.headlines .d{font-family:var(--mono);font-size:10px;color:var(--faint);flex:none;letter-spacing:.04em;}
.headlines .h{font-size:13.5px;font-weight:600;color:var(--graphite);line-height:1.35;}
.scoreline{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;margin-top:4px;}
.scoreline .who{font-family:var(--display);font-weight:600;font-size:13px;}
.scoreline .bar{height:7px;border-radius:99px;background:var(--cloud);overflow:hidden;}
.scoreline .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),var(--azure));}
.scoreline .v{font-family:var(--display);font-weight:700;font-size:13px;}

/* coming soon slots */
.bento .b.soon{background:transparent;border:1.5px dashed #C9CFE6;box-shadow:none;}
.bento .b.soon .pad{justify-content:center;align-items:flex-start;gap:8px;}
.bento .b.soon .addr{font-family:var(--mono);font-size:12px;color:var(--slate);letter-spacing:.02em;}
.bento .b.soon .addr b{color:var(--blue);font-weight:400;}
.bento .b.soon h3{color:var(--graphite);font-size:17px;}
.bento .b.soon p{font-size:13px;color:var(--faint);}

@media(max-width:980px){.bento .b.wc{grid-column:span 12;}.bento .b.s4{grid-column:span 12;}.bento .b.s6{grid-column:span 6;}.bento .b.s3{grid-column:span 6;}}
@media(max-width:640px){.bento{gap:12px;}.bento .b.s6,.bento .b.s3{grid-column:span 12;}}

/* ---- tilted stat ribbon ---- */
.ribbon-zone{position:relative;overflow:hidden;padding:58px 0;background:var(--cloud);border-top:1px solid var(--mist);border-bottom:1px solid var(--mist);}
.ribbon{position:relative;left:-3%;width:106%;transform:rotate(-2.2deg);background:var(--ink);
  box-shadow:0 18px 40px -24px rgba(10,11,20,.5);overflow:hidden;}
.ribbon .rlane{display:flex;white-space:nowrap;width:max-content;animation:tick 30s linear infinite;}
.ribbon span{display:inline-flex;align-items:center;gap:26px;padding:16px 13px 16px 26px;
  font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:.12em;text-transform:uppercase;color:#fff;}
.ribbon .star{color:var(--lime);font-size:14px;}

/* ---- directory ---- */
.dir{display:flex;flex-direction:column;}
.dir-row{display:grid;grid-template-columns:200px minmax(0,1fr) auto;gap:24px;align-items:center;
  padding:26px 0;border-top:1px solid var(--mist);}
.dir-row:last-child{border-bottom:1px solid var(--mist);}
@media(max-width:760px){.dir-row{grid-template-columns:1fr;gap:10px;}}
.dir-row .cat{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.02em;display:flex;align-items:center;gap:12px;}
.dir-row .cat .badge{font-size:10px;}
.dir-row .items{display:flex;gap:8px;flex-wrap:wrap;}
.dir-row .items a{font-family:var(--text);font-weight:600;font-size:14px;color:var(--graphite);text-decoration:none;
  border:1.5px solid var(--mist);border-radius:999px;padding:8px 16px;background:#fff;transition:all .14s;}
.dir-row .items a:hover{border-color:var(--blue);color:var(--blue);}
.dir-row .items .ghosted{border-style:dashed;color:var(--faint);pointer-events:none;background:transparent;}
.dir-row .n{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase;}

/* ============================================================
   WORLD CUP HUB  (Branches/WorldCup/Home.razor)
   ============================================================ */
.wc-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:84px 0 72px;}
.wc-hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(560px 400px at 85% -10%, rgba(42,67,255,.5), transparent 65%),
    radial-gradient(420px 320px at 4% 110%, rgba(139,92,246,.3), transparent 60%);}
.wc-hero::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at 70% 30%,#000,transparent 70%);}
.wc-hero .wrap{position:relative;z-index:2;}
.wc-hero h1{font-size:clamp(40px,5.6vw,72px);margin:18px 0 18px;max-width:16ch;}
.wc-hero h1 em{font-style:normal;color:var(--lime);}
.wc-hero .lead{color:#AAB0C8;}
.wc-hero .pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#C9CEE2;}

/* countdown */
.count{display:flex;gap:12px;margin:34px 0 8px;flex-wrap:wrap;}
.count .cell{min-width:86px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:14px;padding:14px 16px 12px;text-align:center;}
.count .n{font-family:var(--display);font-weight:700;font-size:34px;letter-spacing:-.02em;font-variant-numeric:tabular-nums;}
.count .l{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#8189A8;margin-top:2px;}
.count .cell.hot{background:rgba(203,249,74,.1);border-color:rgba(203,249,74,.35);}
.count .cell.hot .n{color:var(--lime);}

.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--mist);border:1px solid var(--mist);
  border-radius:var(--r);overflow:hidden;margin-top:-46px;position:relative;z-index:5;box-shadow:var(--shadow-lg);}
@media(max-width:760px){.statband{grid-template-columns:repeat(2,1fr);}}
.statband .s{background:#fff;padding:22px 24px;}
.statband .n{font-family:var(--display);font-weight:700;font-size:32px;letter-spacing:-.02em;}
.statband .n em{font-style:normal;color:var(--blue);}
.statband .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);margin-top:3px;}

/* explore cards */
.exp{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:980px){.exp{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.exp{grid-template-columns:1fr;}}
.exp a{text-decoration:none;color:inherit;background:#fff;border:1px solid var(--mist);border-radius:var(--r);
  padding:22px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);
  transition:transform .16s ease,box-shadow .16s ease;}
.exp a:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.exp .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;}
.exp .ic svg{width:21px;height:21px;}
.exp h3{font-size:18.5px;}
.exp p{font-size:13.5px;color:var(--slate);flex:1;text-wrap:pretty;}
.exp .go{font-family:var(--display);font-weight:600;font-size:14px;color:var(--blue);}

/* country grid */
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:980px){.cgrid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.cgrid{grid-template-columns:1fr;}}
.crow{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--mist);border-radius:14px;
  padding:14px 16px;text-decoration:none;color:inherit;transition:border-color .14s,transform .14s,box-shadow .14s;}
.crow:hover{border-color:#c9cfe6;transform:translateY(-2px);box-shadow:var(--shadow);}
.crow img{width:34px;height:24px;border-radius:4px;}
.crow .cn{font-family:var(--display);font-weight:600;font-size:15.5px;line-height:1.15;}
.crow .bc{font-size:12px;color:var(--slate);margin-top:1px;}
.crow .fr{margin-left:auto;flex:none;}
.crow.crow--home{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue) inset;}
.crow .you{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-tint);border-radius:6px;padding:4px 8px;}
.crow .you + .fr{margin-left:10px;}

/* country search */
.country-search{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--mist);
  border-radius:12px;padding:12px 16px;margin-bottom:22px;max-width:420px;color:var(--slate);}
.country-search svg{flex:none;}
.country-search input{border:0;outline:none;font-family:var(--text);font-size:15px;width:100%;color:var(--ink);background:transparent;}
.country-empty{margin-top:18px;color:var(--slate);}

/* vpn picks strip */
.vpick{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:880px){.vpick{grid-template-columns:1fr;}}
.vpick .v{background:#12152A;border:1px solid #222843;border-radius:var(--r);padding:24px;color:#fff;position:relative;}
.vpick .v .rank{position:absolute;top:18px;right:20px;font-family:var(--mono);font-size:11px;color:#6E7596;letter-spacing:.1em;}
.vpick .v.best{border-color:rgba(203,249,74,.4);background:linear-gradient(150deg,#161b33,#12152A);}
.vpick .v.best .rank{color:var(--lime);}
.vpick h3{font-size:21px;}
.vpick .why{font-size:13.5px;color:#9AA0BD;margin:10px 0 16px;text-wrap:pretty;}
.vpick .meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;color:#8189A8;letter-spacing:.04em;margin-bottom:18px;}
.vpick .meta b{color:#fff;font-weight:700;}

/* ============================================================
   HOW TO WATCH  (Branches/WorldCup/HowToWatch.razor)
   ============================================================ */
.watch-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);gap:22px;align-items:start;}
@media(max-width:920px){.watch-grid{grid-template-columns:1fr;}}

/* main broadcaster card */
.bcard{background:#fff;border:1px solid var(--mist);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;}
.bcard .bhead{display:flex;align-items:center;gap:16px;padding:24px 26px;border-bottom:1px solid var(--mist);
  background:linear-gradient(180deg,#fbfcfe,#f6f7fc);}
.bcard .bhead img{width:46px;height:32px;border-radius:6px;}
.bcard .bhead h2{font-size:26px;}
.bcard .bhead .tz{margin-left:auto;text-align:right;font-family:var(--mono);font-size:11px;color:var(--slate);
  letter-spacing:.06em;text-transform:uppercase;line-height:1.6;}
.brow{display:grid;grid-template-columns:54px minmax(0,1fr) auto;gap:16px;align-items:center;padding:18px 26px;}
.brow + .brow{border-top:1px solid var(--mist);}
.brow .blogo{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:15px;color:#fff;letter-spacing:-.02em;}
.brow h3{font-size:18px;}
.brow .det{font-size:13.5px;color:var(--slate);margin-top:3px;text-wrap:pretty;}
.brow .tags{display:flex;flex-direction:column;gap:6px;align-items:flex-end;}
@media(max-width:560px){.brow{grid-template-columns:44px minmax(0,1fr);}.brow .tags{grid-column:2;flex-direction:row;align-items:center;}}

/* steps card */
.steps{background:var(--ink);color:#fff;border-radius:var(--r);padding:26px;position:sticky;top:140px;}
.steps h3{font-size:20px;margin-bottom:6px;}
.steps .sub{font-size:13.5px;color:#9AA0BD;margin-bottom:20px;text-wrap:pretty;}
.step{display:flex;gap:14px;padding:13px 0;border-top:1px solid #1F2440;}
.step .n{width:26px;height:26px;border-radius:50%;background:var(--lime);color:var(--ink);flex:none;
  display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:12.5px;}
.step p{font-size:14px;color:#C9CEE2;line-height:1.5;}
.step p b{color:#fff;}
.steps .btn{width:100%;margin-top:18px;}

/* FAQ */
.faq{max-width:760px;}
.faq details{border:1px solid var(--mist);border-radius:14px;background:#fff;margin-bottom:10px;overflow:hidden;}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:18px 20px;font-family:var(--display);font-weight:600;font-size:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-family:var(--mono);font-size:18px;color:var(--blue);transition:transform .18s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .a{padding:0 20px 18px;font-size:14.5px;color:var(--graphite);max-width:68ch;text-wrap:pretty;}
.faq .a p{margin-bottom:10px;}

/* watch hero broadcaster list */
.bcard .blist .brow .blogo.muted{background:var(--slate);}

/* country directory */
.you-row{display:flex;align-items:center;gap:14px;background:var(--blue);color:#fff;border-radius:16px;
  padding:18px 22px;cursor:pointer;border:0;width:100%;font-family:var(--text);text-align:left;text-decoration:none;
  box-shadow:0 16px 36px -18px rgba(42,67,255,.55);transition:transform .15s;}
.you-row:hover{transform:translateY(-2px);}
.you-row .code{font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:.04em;}
.you-row .nm{font-family:var(--display);font-weight:600;font-size:17px;}
.you-row .you{margin-left:auto;display:inline-flex;align-items:center;gap:10px;}
.you-row .you b{background:var(--lime);color:var(--ink);font-family:var(--mono);font-size:10px;
  letter-spacing:.12em;border-radius:999px;padding:5px 11px;font-weight:700;}
.you-row svg{width:18px;height:18px;}
.dirgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px;}
@media(max-width:1100px){.dirgrid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:880px){.dirgrid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:640px){.dirgrid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:430px){.dirgrid{grid-template-columns:1fr;}}
.dcell{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--mist);border-radius:999px;
  padding:12px 16px;cursor:pointer;font-family:var(--text);text-align:left;width:100%;text-decoration:none;
  transition:border-color .14s,transform .14s,box-shadow .14s;}
.dcell:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow);}
.dcell.on{border-color:var(--blue);background:var(--blue-tint);}
.dcell .code{font-family:var(--display);font-weight:700;font-size:13.5px;letter-spacing:.03em;color:var(--ink);flex:none;}
.dcell .nm{font-size:14px;font-weight:600;color:var(--graphite);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dcell svg{width:15px;height:15px;margin-left:auto;flex:none;color:var(--blue);}
.dcell.na .nm{color:var(--slate);}

/* ============================================================
   VPN COMPARE  (Branches/WorldCup/VpnCompare.razor)
   ============================================================ */
.vrank{display:flex;flex-direction:column;gap:18px;}
.vcard{display:grid;grid-template-columns:64px minmax(0,1.1fr) minmax(0,1fr) auto;gap:24px;align-items:center;
  background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:26px 28px;box-shadow:var(--shadow);position:relative;}
@media(max-width:980px){.vcard{grid-template-columns:56px minmax(0,1fr);}.vcard .scores{grid-column:1/-1;}.vcard .act{grid-column:1/-1;justify-self:start;}}
.vcard.best{border:2px solid var(--blue);box-shadow:0 24px 56px -28px rgba(42,67,255,.35);}
.vcard .ribbon{position:absolute;top:-12px;left:26px;background:var(--blue);color:#fff;font-family:var(--mono);
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;border-radius:7px;padding:5px 11px;}
.vcard .vlogo{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;color:#fff;
  font-family:var(--display);font-weight:700;font-size:21px;}
.vcard h3{font-size:23px;}
.vcard .why{font-size:14px;color:var(--slate);margin-top:5px;max-width:38ch;text-wrap:pretty;}
.vcard .facts{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap;}
.vcard .facts span{font-family:var(--mono);font-size:11px;color:var(--slate);letter-spacing:.04em;}
.vcard .facts b{color:var(--ink);font-weight:700;}
.scores{display:flex;flex-direction:column;gap:10px;min-width:220px;}
.score{display:grid;grid-template-columns:92px 1fr 38px;align-items:center;gap:10px;}
.score .l{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);}
.score .bar{height:7px;border-radius:99px;background:var(--cloud);overflow:hidden;}
.score .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue),var(--azure));}
.score .v{font-family:var(--display);font-weight:700;font-size:13.5px;text-align:right;}
.vcard .act{display:flex;flex-direction:column;gap:9px;align-items:stretch;}
.vcard .price{text-align:center;font-family:var(--mono);font-size:11px;color:var(--slate);}
.vcard .price b{display:block;font-family:var(--display);font-size:24px;color:var(--ink);letter-spacing:-.02em;}

/* compare table */
.cmp{overflow-x:auto;border:1px solid var(--mist);border-radius:var(--r);background:#fff;box-shadow:var(--shadow);}
.cmp .tbl{min-width:680px;}
.cmp td:first-child{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);}
.cmp .yes{color:var(--green);font-weight:800;} .cmp .no{color:var(--red);font-weight:800;}
.cmp .best-col{background:var(--blue-tint);}

/* methodology */
.method{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:860px){.method{grid-template-columns:1fr;}}
.method .m{background:#12152A;border:1px solid #222843;border-radius:var(--r);padding:24px;color:#C9CEE2;}
.method .m h3{color:#fff;font-size:17.5px;margin:14px 0 8px;}
.method .m p{font-size:13.5px;color:#9AA0BD;text-wrap:pretty;}
.method .ic{width:40px;height:40px;border-radius:11px;background:rgba(203,249,74,.12);display:grid;place-items:center;color:var(--lime);}
.method .ic svg{width:20px;height:20px;}

/* partner add-ons */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:880px){.partners{grid-template-columns:1fr;}}
.partner-card{display:flex;align-items:center;gap:16px;}
.partner-card .plogo{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#fff;
  font-family:var(--display);font-weight:700;font-size:18px;flex:none;}
.partner-card .pname{font-family:var(--display);font-weight:700;font-size:17px;}
.partner-card .ptag{font-size:13px;color:var(--slate);margin-top:2px;text-wrap:pretty;}
.partner-card .pcta{margin-left:auto;flex:none;}

/* ============================================================
   VPN REVIEW  (Branches/WorldCup/VpnReview.razor)
   ============================================================ */
.rev-head{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:40px;align-items:start;padding-bottom:10px;}
@media(max-width:920px){.rev-head{grid-template-columns:1fr;}}
.rev-head h1{font-size:clamp(36px,4.8vw,56px);margin:14px 0 16px;}
.verdict-card{background:var(--ink);color:#fff;border-radius:var(--r);padding:28px;position:relative;overflow:hidden;}
.verdict-card::before{content:"";position:absolute;inset:0;background:radial-gradient(300px 200px at 90% 0%,rgba(42,67,255,.4),transparent 65%);}
.verdict-card > *{position:relative;}
.bigscore{display:flex;align-items:baseline;gap:12px;margin:6px 0 14px;}
.bigscore .n{font-family:var(--display);font-weight:700;font-size:64px;letter-spacing:-.03em;color:var(--lime);}
.bigscore .d{font-family:var(--mono);font-size:13px;color:#8189A8;}
.verdict-card p{font-size:14.5px;color:#C9CEE2;text-wrap:pretty;}
.verdict-card .btn{width:100%;margin-top:20px;}
.verdict-card .gnote{margin-top:10px;text-align:center;font-family:var(--mono);font-size:10.5px;color:#6E7596;letter-spacing:.06em;}

/* pros cons */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:760px){.pc{grid-template-columns:1fr;}}
.pc .col{background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:24px;}
.pc h3{font-size:17px;display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.pc ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.pc li{display:flex;gap:11px;font-size:14.5px;color:var(--graphite);line-height:1.5;}
.pc li::before{font-weight:800;flex:none;}
.pc .pros li::before{content:"✓";color:var(--green);}
.pc .cons li::before{content:"✗";color:var(--red);}

/* ============================================================
   PREDICTIONS  (Branches/WorldCup/PredictIndex.razor + PredictDay.razor)
   ============================================================ */
.pred-hero{background:var(--ink);color:#fff;padding:64px 0 56px;position:relative;overflow:hidden;}
.pred-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(540px 360px at 90% -20%,rgba(139,92,246,.45),transparent 65%);}
.pred-hero .wrap{position:relative;}
.pred-hero h1{font-size:clamp(36px,5vw,60px);margin:16px 0 14px;}
.pred-hero .lead{color:#AAB0C8;}
.pred-hero .pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#C9CEE2;}

.modelband{display:flex;gap:26px;flex-wrap:wrap;margin-top:30px;}
.modelband .m{display:flex;flex-direction:column;gap:2px;}
.modelband .n{font-family:var(--display);font-weight:700;font-size:23px;color:var(--lime);}
.modelband .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#8189A8;}

.pcards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
@media(max-width:880px){.pcards{grid-template-columns:1fr;}}
.pcard{background:#fff;border:1px solid var(--mist);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;
  text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:transform .16s,box-shadow .16s;}
a.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.pcard .ph{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 20px;border-bottom:1px solid var(--mist);
  background:linear-gradient(180deg,#fbfcfe,#f6f7fc);}
.pcard .ph .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);}
.pcard h3{font-size:19px;line-height:1.18;padding:18px 20px 0;}
.pcard .note{padding:8px 20px 20px;font-size:13.5px;color:var(--graphite);line-height:1.55;text-wrap:pretty;flex:1;}
.pcard .note b{font-weight:700;}
.pcard .pdate{padding:0 20px 18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);}
.pcard.featured{border:2px solid var(--violet);}
.pcard.featured .ph .t{color:var(--violet);}

/* accuracy panel */
.acc{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:760px){.acc{grid-template-columns:1fr;}}
.acc .a{background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:24px;}
.acc .n{font-family:var(--display);font-weight:700;font-size:38px;letter-spacing:-.02em;color:var(--blue);}
.acc p{font-size:13.5px;color:var(--slate);margin-top:6px;text-wrap:pretty;}

/* ============================================================
   NEWS  (Branches/WorldCup/NewsIndex.razor + NewsArticlePage.razor)
   ============================================================ */
.news-head{padding:64px 0 38px;}
.news-head h1{font-size:clamp(38px,5vw,60px);margin:14px 0 12px;}

/* featured */
.featured{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:0;background:var(--ink);
  border-radius:var(--r);overflow:hidden;color:#fff;box-shadow:var(--shadow-lg);text-decoration:none;}
@media(max-width:880px){.featured{grid-template-columns:1fr;}}
.featured .img{min-height:320px;background:#12152A;position:relative;}
.featured .img img{width:100%;height:100%;min-height:320px;object-fit:cover;}
.featured .txt{padding:36px;display:flex;flex-direction:column;gap:14px;justify-content:center;}
.featured h2{font-size:clamp(24px,2.8vw,34px);line-height:1.1;color:#fff;}
.featured:hover h2{text-decoration:underline;text-decoration-color:var(--lime);text-underline-offset:5px;}
.featured p{font-size:15px;color:#AAB0C8;text-wrap:pretty;}
.featured .meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#6E7596;}

/* article grid */
.arts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:980px){.arts{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.arts{grid-template-columns:1fr;}}
.art{display:flex;flex-direction:column;gap:0;background:#fff;border:1px solid var(--mist);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow);transition:transform .16s,box-shadow .16s;text-decoration:none;color:inherit;}
.art:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.art .stripe{height:5px;}
.art .cover{height:160px;background:#12152A;}
.art .cover img{width:100%;height:100%;object-fit:cover;}
.art .body{padding:22px;display:flex;flex-direction:column;gap:11px;flex:1;}
.art h3{font-size:19px;line-height:1.18;}
.art:hover h3{color:var(--blue);}
.art p{font-size:13.5px;color:var(--slate);flex:1;text-wrap:pretty;}
.art .meta{display:flex;justify-content:space-between;gap:10px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.07em;text-transform:uppercase;color:var(--faint);}

/* newsletter */
.nl{background:var(--blue);border-radius:var(--r);color:#fff;padding:40px;display:grid;
  grid-template-columns:minmax(0,1fr) auto;gap:28px;align-items:center;position:relative;overflow:hidden;}
.nl::before{content:"";position:absolute;inset:0;background:radial-gradient(340px 240px at 92% -20%,rgba(203,249,74,.35),transparent 60%);}
.nl > *{position:relative;}
@media(max-width:760px){.nl{grid-template-columns:1fr;}}
.nl h2{font-size:clamp(22px,3vw,30px);}
.nl p{margin-top:8px;color:#C9D2FF;font-size:14.5px;max-width:46ch;}
.nl form{display:flex;gap:10px;flex-wrap:wrap;}
.nl input[type=email]{border:0;border-radius:11px;padding:14px 18px;font-family:var(--text);font-size:15px;min-width:240px;outline:none;color:var(--ink);}
.nl .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}
.nl-msg{width:100%;margin-top:12px;font-family:var(--display);font-weight:700;color:#fff;}

/* ---------- article body ---------- */
.article{max-width:720px;margin:8px 0 0;font-size:17px;line-height:1.7;color:var(--graphite);}
.article h2{font-size:clamp(24px,3vw,32px);margin:36px 0 14px;color:var(--ink);}
.article h3{font-size:21px;margin:28px 0 10px;color:var(--ink);}
.article p{margin-bottom:18px;text-wrap:pretty;}
.article ul,.article ol{margin:0 0 18px 22px;}
.article li{margin-bottom:8px;}
.article a{color:var(--blue);text-decoration:underline;text-underline-offset:2px;}
.article-hero{margin:0 0 8px;border-radius:var(--r);overflow:hidden;max-width:840px;}
.article-hero img{width:100%;}
.article-meta{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--slate);}
.crumbs{display:flex;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:22px;}
.crumbs a{color:var(--slate);text-decoration:none;} .crumbs a:hover{color:var(--blue);}

/* ---------- share row ---------- */
.share{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.share__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);}
.share__btn{width:40px;height:40px;border-radius:11px;border:1.5px solid var(--mist);background:#fff;color:var(--graphite);
  display:grid;place-items:center;cursor:pointer;text-decoration:none;transition:border-color .14s,color .14s,transform .14s;}
.share__btn:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px);}
.share__btn.is-copied{border-color:var(--green);color:var(--green);}

/* ---------- bracket (Branches/WorldCup/Bracket.razor + Groups) ---------- */
.gcols{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:980px){.gcols{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.gcols{grid-template-columns:1fr;}}
.gc{background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);}
.gc-top{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.gl{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:15px;color:#fff;}
.gl.on-blue{background:var(--blue);}.gl.on-pink{background:var(--violet);}.gl.on-green{background:var(--green);}.gl.on-amber{background:var(--amber);}
.bk-grouptag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);}
.tr{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--cloud);width:100%;}
.tr:first-of-type{border-top:0;}
.tr .nm{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:14.5px;}
.tr .nm .tflag,.tr .nm img{width:24px;height:16px;border-radius:3px;}
.tr .sd{margin-left:auto;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);}
.tr .sd.on-green{color:var(--green);}.tr .sd.on-amber{color:var(--amber);}
.bk-team{display:flex;align-items:center;gap:10px;width:100%;background:none;border:0;cursor:pointer;text-align:left;
  border-radius:8px;padding:9px 8px;border-top:1px solid var(--cloud);font:inherit;}
.bk-team:first-of-type{border-top:0;}
.bk-team:hover{background:var(--cloud);}
.bk-team[data-rank="1"]{background:var(--blue-tint);}
.bk-team[data-rank="2"]{background:var(--lime-tint);}
.bk-team .nm{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:14.5px;}
.bk-rank{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--blue);min-width:26px;flex:none;}
.bk-team[data-rank="1"] .bk-rank::before{content:"1st";color:var(--blue);}
.bk-team[data-rank="2"] .bk-rank::before{content:"2nd";color:#5d7a06;}
.bk-flag{display:inline-block;}
.bk-group{transform:perspective(900px) rotateX(var(--rx,0)) rotateY(var(--ry,0));transition:transform .12s ease;}
.bk-hint{font-size:13.5px;color:var(--slate);margin-bottom:16px;}

/* knockout tree */
.bk-ko{display:flex;gap:18px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;}
.bk-ko::-webkit-scrollbar{display:none;}
.bk-round{display:flex;flex-direction:column;gap:14px;justify-content:space-around;min-width:200px;flex:none;}
.bk-round__label{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);}
.bk-tie{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--mist);border-radius:12px;padding:8px;box-shadow:var(--shadow);}
.bk-slot{display:flex;align-items:center;gap:8px;width:100%;background:none;border:0;border-radius:8px;padding:9px 10px;cursor:pointer;
  font-family:var(--display);font-weight:600;font-size:14px;text-align:left;color:var(--ink);}
.bk-slot:hover:not([disabled]){background:var(--cloud);}
.bk-slot[disabled]{color:var(--faint);cursor:default;}
.bk-slot[data-winner]{background:var(--blue-tint);color:var(--blue);}
.bk-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:24px;
  background:#fff;border:1px solid var(--mist);border-radius:var(--r);padding:16px 20px;box-shadow:var(--shadow);}
.bk-score{font-family:var(--display);font-weight:600;}
.bk-actions{display:flex;gap:10px;flex-wrap:wrap;}
.bk-champion{display:flex;align-items:center;gap:14px;background:var(--ink);color:#fff;border-radius:var(--r);padding:20px 24px;margin-bottom:20px;}
.bk-champion[hidden]{display:none;}
.bk-champion__tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);}
.bk-champion__name{font-family:var(--display);font-weight:700;font-size:24px;}
.bk-ko{margin-top:8px;}
.bk-empty{color:var(--slate);font-size:14px;}

/* ---------- fixtures (Schedule.razor) ---------- */
.fx{display:grid;grid-template-columns:96px minmax(0,1fr) auto;gap:16px;align-items:center;
  background:#fff;border:1px solid var(--mist);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow);}
.fx + .fx{margin-top:10px;}
.fx.fin{border-color:rgba(217,142,4,.4);background:linear-gradient(180deg,#fffdf6,#fff);}
.fx .fd b{display:block;font-family:var(--display);font-weight:700;font-size:15px;}
.fx .fd small{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--slate);}
.fx .fm{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.fx .fm .tm{font-family:var(--display);font-weight:600;font-size:16px;}
.fx .fm .tm .x{color:var(--faint);font-weight:400;font-size:13px;margin:0 4px;}
.fx .fv{text-align:right;flex:none;}
.fx .fv b{display:block;font-family:var(--display);font-weight:600;font-size:14px;}
.fx .fv small{font-size:12px;color:var(--slate);}
@media(max-width:640px){.fx{grid-template-columns:1fr;}.fx .fv{text-align:left;}}
.tg{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;border-radius:6px;padding:4px 9px;}
.tg.on-blue{background:var(--blue-tint);color:var(--blue);}
.tg.on-pink{background:rgba(139,92,246,.1);color:var(--violet);}
.tg.on-green{background:rgba(43,154,102,.1);color:var(--green);}
.tg.on-amber{background:rgba(217,142,4,.1);color:var(--amber);}

/* ---------- generic helpers ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:980px){.grid-3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.grid-3{grid-template-columns:1fr;}}
.mono{font-family:var(--mono);}
.lead-top{padding-top:34px;}
.stack{display:flex;flex-direction:column;gap:16px;}
.split{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:40px;align-items:start;}
@media(max-width:920px){.split{grid-template-columns:1fr;}}
.pillrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;}
.pill-stat{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
  background:#fff;border:1px solid var(--mist);border-radius:999px;padding:7px 14px;color:var(--graphite);}
.pill-stat svg{width:15px;height:15px;}
.icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;}
.icon--lg{width:24px;height:24px;}
