/* ============================================================
   DTPS — Danger to Public Safety
   Shared design system. Black & white. No accent color.
   ============================================================ */
:root{
  --paper:#FFFFFF;--ink:#0A0A0A;--ink-soft:#1A1A1A;--gray-9:#111111;
  --gray-7:#3D3D3D;--gray-5:#6E6E6E;--gray-3:#B8B8B8;--gray-1:#E8E8E8;--line:#000000;
  --disp:'Archivo Expanded',-apple-system,sans-serif;
  --body:'Archivo',-apple-system,sans-serif;
  --mono:'Space Mono',monospace;
  --ease:cubic-bezier(0.16,1,0.3,1);--ease-sharp:cubic-bezier(0.7,0,0.2,1);
  --nav-h:68px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.locked{overflow:hidden;height:100vh}
body.menu-open{overflow:hidden}
::selection{background:var(--ink);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

/* ---------- INTRO (home only) ---------- */
#intro{position:fixed;inset:0;z-index:2000;background:var(--paper);display:flex;align-items:center;justify-content:center;flex-direction:column}
#intro.done{animation:introLift 1s var(--ease) forwards;pointer-events:none}
@keyframes introLift{to{transform:translateY(-100%)}}
.stamp-wrap{position:relative;overflow:hidden}
.stamp{font-family:var(--disp);font-weight:900;font-size:clamp(60px,16vw,200px);letter-spacing:-0.04em;line-height:0.8;color:var(--ink);transform:scale(2.4);opacity:0;filter:blur(12px);animation:stampHit 0.5s var(--ease-sharp) 0.3s forwards}
@keyframes stampHit{to{transform:scale(1);opacity:1;filter:blur(0)}}
.stamp-line{height:2px;background:var(--ink);width:0;margin:20px auto 0;animation:lineGrow 0.6s var(--ease) 0.8s forwards}
@keyframes lineGrow{to{width:100%}}
.stamp-sub{font-family:var(--mono);font-size:clamp(9px,1.4vw,13px);letter-spacing:0.5em;text-transform:uppercase;margin-top:18px;opacity:0;animation:fadeIn 0.6s ease 1.1s forwards;padding-left:0.5em}
.intro-meta{position:absolute;bottom:40px;left:0;right:0;display:flex;justify-content:space-between;padding:0 40px;font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-5);opacity:0;animation:fadeIn 0.8s ease 1.3s forwards}
@keyframes fadeIn{to{opacity:1}}

/* ---------- NAV ---------- */
nav.top{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:var(--nav-h);background:rgba(255,255,255,0.82);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .4s,background .4s}
nav.top.scrolled{border-bottom-color:var(--line)}
.nav-logo{font-family:var(--disp);font-weight:900;font-size:24px;letter-spacing:-0.03em;color:var(--ink);position:relative;z-index:2}
.nav-mid{display:flex;gap:32px;align-items:center}
.nav-mid a{font-family:var(--mono);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink);position:relative;padding:6px 0;opacity:.7;transition:opacity .3s}
.nav-mid a:hover{opacity:1}
.nav-mid a.active{opacity:1}
.nav-mid a::after{content:'';position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--ink);transition:width 0.35s var(--ease)}
.nav-mid a:hover::after,.nav-mid a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:22px}
.nav-cta{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:11px 20px;border:1.5px solid var(--ink);background:var(--ink);color:var(--paper);transition:.35s var(--ease-sharp);position:relative;overflow:hidden}
.nav-cta span{position:relative;z-index:2}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--paper);transform:translateY(101%);transition:transform .35s var(--ease-sharp)}
.nav-cta:hover{color:var(--ink)}
.nav-cta:hover::before{transform:translateY(0)}
.menu-btn{display:flex;flex-direction:column;gap:5px;width:26px;height:18px;justify-content:center;background:none;border:none;padding:0}
.menu-btn span{width:100%;height:2px;background:var(--ink);transition:.35s var(--ease-sharp);transform-origin:center}

/* ---------- SLIDE-OUT MENU ---------- */
.menu-overlay{position:fixed;inset:0;z-index:300;background:rgba(10,10,10,0.4);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;backdrop-filter:blur(2px)}
.menu-overlay.open{opacity:1;visibility:visible}
.side-menu{position:fixed;top:0;right:0;bottom:0;width:min(440px,86vw);z-index:400;background:var(--ink);color:var(--paper);transform:translateX(100%);transition:transform .55s var(--ease);display:flex;flex-direction:column;padding:36px 40px}
.side-menu.open{transform:translateX(0)}
.side-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:54px}
.side-head .sm-logo{font-family:var(--disp);font-weight:900;font-size:26px;letter-spacing:-0.03em}
.sm-close{width:30px;height:30px;position:relative;background:none;border:none}
.sm-close::before,.sm-close::after{content:'';position:absolute;top:14px;left:3px;width:24px;height:2px;background:var(--paper)}
.sm-close::before{transform:rotate(45deg)}
.sm-close::after{transform:rotate(-45deg)}
.sm-links{display:flex;flex-direction:column;flex:1}
.sm-links a{font-family:var(--disp);font-weight:800;font-size:clamp(30px,5vw,46px);letter-spacing:-0.03em;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.12);position:relative;overflow:hidden;display:flex;align-items:baseline;gap:16px;transition:padding-left .4s var(--ease)}
.sm-links a .idx{font-family:var(--mono);font-size:12px;font-weight:400;color:var(--gray-5);letter-spacing:0.1em;flex-shrink:0;width:30px}
.sm-links a:hover{padding-left:14px}
.sm-links a.active{color:var(--paper)}
.sm-links a.active .idx{color:var(--paper)}
.sm-links a:not(.active){color:var(--gray-3)}
.sm-foot{margin-top:40px;display:flex;flex-direction:column;gap:18px}
.sm-account{display:flex;gap:12px}
.sm-account .sm-btn{flex:1;text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:14px;border:1.5px solid rgba(255,255,255,0.3);transition:.3s}
.sm-account .sm-btn.solid{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.sm-account .sm-btn:hover{border-color:var(--paper)}
.sm-account .sm-btn.solid:hover{background:var(--gray-3)}
.sm-social{display:flex;gap:20px}
.sm-social a{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5);transition:color .3s}
.sm-social a:hover{color:var(--paper)}
.sm-meta{font-family:var(--mono);font-size:10px;letter-spacing:0.1em;color:var(--gray-7);text-transform:uppercase}

/* ---------- PAGE HEADER (interior pages) ---------- */
.page-head{padding:calc(var(--nav-h) + 80px) 40px 60px;border-bottom:2px solid var(--line);position:relative;overflow:hidden}
.page-head .ph-grid{position:absolute;inset:0;background-image:linear-gradient(var(--gray-1) 1px,transparent 1px),linear-gradient(90deg,var(--gray-1) 1px,transparent 1px);background-size:70px 70px;mask-image:radial-gradient(ellipse 70% 120% at 80% 0%,#000,transparent 70%);opacity:.6}
.ph-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gray-5);margin-bottom:20px;display:flex;align-items:center;gap:12px;position:relative}
.ph-eyebrow .dot{width:7px;height:7px;background:var(--ink);border-radius:50%}
.page-title{font-family:var(--disp);font-weight:900;font-size:clamp(56px,13vw,180px);letter-spacing:-0.05em;line-height:0.82;position:relative}
.page-title .outline{-webkit-text-stroke:2px var(--ink);-webkit-text-fill-color:transparent}
.page-sub{font-size:17px;line-height:1.55;color:var(--gray-7);max-width:560px;margin-top:26px;position:relative}

/* ---------- BUTTONS ---------- */
.btn{font-family:var(--mono);font-size:12px;letter-spacing:0.15em;text-transform:uppercase;padding:18px 34px;border:2px solid var(--ink);background:var(--ink);color:var(--paper);position:relative;overflow:hidden;transition:color 0.4s var(--ease-sharp);display:inline-block}
.btn span{position:relative;z-index:2}
.btn::before{content:'';position:absolute;inset:0;background:var(--paper);transform:translateY(101%);transition:transform 0.4s var(--ease-sharp)}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost::before{background:var(--ink)}
.btn.ghost:hover{color:var(--paper)}

/* ---------- SECTION SHELL ---------- */
section.block{padding:110px 40px;position:relative;border-bottom:2px solid var(--line)}
.sec-head{display:flex;align-items:baseline;gap:20px;margin-bottom:60px}
.sec-num{font-family:var(--mono);font-size:13px;color:var(--gray-5);letter-spacing:0.1em}
.sec-title{font-family:var(--disp);font-weight:800;font-size:clamp(34px,6vw,76px);letter-spacing:-0.04em;line-height:0.9}
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.9s var(--ease),transform 0.9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--ink);color:var(--paper);padding:18px 0;overflow:hidden;white-space:nowrap;border-bottom:2px solid var(--line)}
.marquee-track{display:inline-block;animation:scroll 32s linear infinite}
.marquee-track span{font-family:var(--disp);font-weight:800;font-size:26px;letter-spacing:-0.01em;text-transform:uppercase;margin:0 30px}
.marquee-track .o{-webkit-text-stroke:1.5px var(--paper);-webkit-text-fill-color:transparent}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- FOOTER ---------- */
footer{padding:80px 40px 40px;background:var(--paper)}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:80px}
.foot-logo{font-family:var(--disp);font-weight:900;font-size:clamp(60px,14vw,180px);letter-spacing:-0.05em;line-height:0.8}
.foot-cols{display:flex;gap:80px;flex-wrap:wrap}
.foot-col h5{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-5);margin-bottom:18px}
.foot-col a{display:block;font-family:var(--body);font-size:15px;margin-bottom:11px;color:var(--gray-7);transition:color .3s,padding-left .3s var(--ease)}
.foot-col a:hover{color:var(--ink);padding-left:6px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;border-top:2px solid var(--line);flex-wrap:wrap;gap:16px}
.foot-bottom span{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:var(--gray-5);text-transform:uppercase}

/* ============================================================
   HOME PAGE
   ============================================================ */
.hero{min-height:100vh;position:relative;display:flex;flex-direction:column;justify-content:center;padding:0 40px;border-bottom:2px solid var(--line);overflow:hidden}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--gray-1) 1px,transparent 1px),linear-gradient(90deg,var(--gray-1) 1px,transparent 1px);background-size:80px 80px;opacity:0;animation:gridIn 1.5s ease 0.2s forwards;pointer-events:none;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 30%,transparent 75%)}
@keyframes gridIn{to{opacity:1}}
.hero-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:0.4em;text-transform:uppercase;color:var(--gray-5);margin-bottom:24px;display:flex;align-items:center;gap:14px;opacity:0;transform:translateY(20px)}
.hero-eyebrow .dot{width:8px;height:8px;background:var(--ink);border-radius:50%;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.3;transform:scale(0.7)}}
.hero-title{font-family:var(--disp);font-weight:900;font-size:clamp(70px,19vw,280px);line-height:0.78;letter-spacing:-0.05em;position:relative;z-index:2}
.hero-title .row{overflow:hidden;display:block}
.hero-title .row span{display:block;transform:translateY(110%)}
.hero-title .outline{-webkit-text-stroke:2px var(--ink);-webkit-text-fill-color:transparent;color:transparent}
.hero-expand{font-family:var(--mono);font-size:clamp(11px,1.5vw,15px);letter-spacing:0.35em;text-transform:uppercase;color:var(--ink);margin-top:28px;opacity:0;transform:translateY(20px)}
.hero-sub{margin-top:22px;max-width:560px;font-size:18px;line-height:1.5;color:var(--gray-7);opacity:0;transform:translateY(20px)}
.hero-cta{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap;opacity:0;transform:translateY(20px)}
.hero-corner{position:absolute;bottom:34px;right:40px;font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-5);text-align:right;opacity:0;animation:fadeIn 1s ease 1.8s forwards;line-height:1.8}
.scroll-hint{position:absolute;bottom:34px;left:40px;font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-5);display:flex;align-items:center;gap:10px;opacity:0;animation:fadeIn 1s ease 1.8s forwards}
.scroll-hint .bar{width:1px;height:30px;background:var(--gray-3);position:relative;overflow:hidden}
.scroll-hint .bar::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--ink);animation:scrollBar 2s ease infinite}
@keyframes scrollBar{to{top:100%}}

.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:start}
.manifesto{font-family:var(--disp);font-weight:600;font-size:clamp(26px,3.6vw,46px);line-height:1.08;letter-spacing:-0.025em}
.manifesto em{font-style:normal;-webkit-text-stroke:1.5px var(--ink);-webkit-text-fill-color:transparent}
.about-side p{font-size:16px;line-height:1.65;color:var(--gray-7);margin-bottom:20px}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin-top:40px;border:2px solid var(--line)}
.stat{background:var(--paper);padding:28px 24px}
.stat .n{font-family:var(--disp);font-weight:800;font-size:46px;line-height:1;letter-spacing:-0.03em}
.stat .l{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5);margin-top:10px}

/* ---------- STAFF ---------- */
.staff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:2px solid var(--line)}
.staff{background:var(--paper);padding:0;position:relative;overflow:hidden}
.staff-photo{aspect-ratio:1;background:var(--gray-1);position:relative;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.staff-initial{font-family:var(--disp);font-weight:900;font-size:128px;color:var(--paper);-webkit-text-stroke:2px var(--gray-3);-webkit-text-fill-color:transparent;line-height:1;transition:transform .6s var(--ease-sharp),-webkit-text-stroke .5s,color .5s;align-self:center}
.staff:hover .staff-photo{background:var(--ink)}
.staff:hover .staff-initial{color:var(--ink-soft);-webkit-text-stroke:2px var(--gray-7);transform:scale(1.12)}
.staff-body{padding:22px 22px 26px}
.staff-role{font-family:var(--mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5);margin-bottom:9px}
.staff-name{font-family:var(--disp);font-weight:800;font-size:24px;letter-spacing:-0.02em;line-height:1}
.staff-tag{font-size:13px;color:var(--gray-7);margin-top:10px;line-height:1.45}

/* ---------- CTA BAND ---------- */
.cta-band{padding:140px 40px;text-align:center;background:var(--ink);color:var(--paper);border-bottom:2px solid var(--line)}
.cta-band h2{font-family:var(--disp);font-weight:900;font-size:clamp(46px,10vw,150px);letter-spacing:-0.05em;line-height:0.85}
.cta-band h2 .o{-webkit-text-stroke:2px var(--paper);-webkit-text-fill-color:transparent}
.cta-band p{font-family:var(--mono);font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-3);margin:30px 0 44px}
.cta-band .btn{border-color:var(--paper);background:var(--paper);color:var(--ink)}
.cta-band .btn::before{background:var(--ink)}
.cta-band .btn:hover{color:var(--paper)}

/* ============================================================
   TEAMS PAGE
   ============================================================ */
.teams-bar{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.teams-count{font-family:var(--mono);font-size:12px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5)}
.teams-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:2px solid var(--line)}
.team{background:var(--paper);padding:26px 24px;position:relative;overflow:hidden;transition:background 0.45s var(--ease-sharp);min-height:118px;display:flex;flex-direction:column;justify-content:space-between}
.team::after{content:attr(data-seed);position:absolute;top:14px;right:18px;font-family:var(--mono);font-size:11px;color:var(--gray-3);transition:color 0.45s;letter-spacing:0.05em}
.team-name{font-family:var(--disp);font-weight:700;font-size:21px;letter-spacing:-0.02em;line-height:1.05;transition:color 0.45s;max-width:88%;word-break:break-word}
.team-meta{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-5);margin-top:14px;transition:color 0.45s}
.team-meta b{font-weight:700;color:var(--ink);transition:color 0.45s}
.team:hover{background:var(--ink)}
.team:hover .team-name{color:var(--paper)}
.team:hover .team-meta,.team:hover .team-meta b{color:var(--gray-3)}
.team:hover::after{color:var(--gray-7)}
.teams-note{font-family:var(--mono);font-size:11px;color:var(--gray-5);margin-top:24px;letter-spacing:0.05em;line-height:1.7}

/* ============================================================
   RULES PAGE
   ============================================================ */
.format-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:2px solid var(--line);margin-bottom:80px}
.format-cell{background:var(--paper);padding:36px 30px}
.format-cell .k{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-5);margin-bottom:14px}
.format-cell .v{font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:-0.02em;line-height:1.05}
.format-cell .d{font-size:14px;color:var(--gray-7);margin-top:12px;line-height:1.5}
.rules-list{border-top:2px solid var(--line)}
.rule{border-bottom:1px solid var(--gray-1)}
.rule-head{display:grid;grid-template-columns:80px 1fr 40px;gap:30px;align-items:center;padding:30px 0;cursor:pointer;transition:padding-left 0.4s var(--ease),background 0.4s}
.rule-head:hover{padding-left:18px;background:linear-gradient(90deg,var(--gray-1),transparent)}
.rule-num{font-family:var(--disp);font-weight:800;font-size:30px;color:var(--gray-3);letter-spacing:-0.03em;line-height:1;transition:color 0.4s}
.rule.open .rule-num{color:var(--ink)}
.rule-title{font-family:var(--disp);font-weight:700;font-size:clamp(19px,2.4vw,26px);letter-spacing:-0.02em}
.rule-toggle{position:relative;width:18px;height:18px;justify-self:end}
.rule-toggle::before,.rule-toggle::after{content:'';position:absolute;background:var(--ink);transition:transform 0.4s var(--ease-sharp)}
.rule-toggle::before{top:8px;left:0;width:18px;height:2px}
.rule-toggle::after{left:8px;top:0;width:2px;height:18px}
.rule.open .rule-toggle::after{transform:scaleY(0)}
.rule-content{max-height:0;overflow:hidden;transition:max-height 0.5s var(--ease)}
.rule-inner{padding:0 0 34px 110px}
.rule-inner p{font-size:15px;line-height:1.65;color:var(--gray-7);max-width:760px;margin-bottom:14px}
.rule-inner ul{list-style:none;max-width:760px}
.rule-inner li{font-size:15px;line-height:1.6;color:var(--gray-7);padding:8px 0 8px 22px;position:relative;border-bottom:1px solid var(--gray-1)}
.rule-inner li:last-child{border-bottom:none}
.rule-inner li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:2px;background:var(--ink)}
.rule-inner li b{color:var(--ink);font-weight:700}
.rule-inner h5{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);margin:24px 0 12px}
.rule-inner h5:first-child{margin-top:0}
.kvtable{border:1px solid var(--gray-1);margin:6px 0 16px;max-width:760px}
.kvtable .kv{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--gray-1)}
.kvtable .kv:last-child{border-bottom:none}
.kvtable .kv span{padding:11px 16px;font-size:14px}
.kvtable .kv span:first-child{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--gray-5);border-right:1px solid var(--gray-1)}
.kvtable .kv span:last-child{font-weight:600}
.banlist{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 8px;max-width:760px}
.banlist .b{font-family:var(--mono);font-size:12px;padding:7px 12px;border:1px solid var(--ink);letter-spacing:0.03em;text-decoration:line-through;color:var(--gray-7)}
.warn{font-family:var(--mono);font-size:11px;letter-spacing:0.05em;color:var(--ink);border-left:2px solid var(--ink);padding:4px 0 4px 14px;margin-top:10px;max-width:760px}

/* ============================================================
   SCHEDULE PAGE
   ============================================================ */
.sched-tag{font-family:var(--mono);font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-5);margin-bottom:24px}
.sched-list{border-top:2px solid var(--line)}
.match{display:grid;grid-template-columns:120px 1fr auto 1fr 130px;gap:24px;align-items:center;padding:28px 0;border-bottom:1px solid var(--gray-1);transition:background 0.4s,padding 0.4s var(--ease);position:relative}
.match:hover{background:var(--ink);color:var(--paper);padding-left:24px;padding-right:24px}
.match:hover .m-date,.match:hover .vs{color:var(--gray-3)}
.match:hover .m-status{border-color:var(--gray-3);color:var(--gray-3)}
.m-date{font-family:var(--mono);font-size:12px;letter-spacing:0.05em;color:var(--gray-5);transition:color .4s}
.m-date .day{display:block;font-family:var(--disp);font-weight:700;font-size:24px;color:inherit;letter-spacing:-0.02em}
.m-team{font-family:var(--disp);font-weight:700;font-size:clamp(17px,2.2vw,28px);letter-spacing:-0.02em}
.m-team.right{text-align:right}
.vs{font-family:var(--mono);font-size:13px;color:var(--gray-5);text-align:center;transition:color .4s}
.m-status{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;border:1px solid var(--gray-3);padding:7px 12px;text-align:center;transition:.4s}
.m-status.live{background:var(--ink);color:var(--paper);border-color:var(--ink);animation:livePulse 1.6s ease infinite}
@keyframes livePulse{50%{opacity:0.55}}

/* ============================================================
   STANDINGS PAGE
   ============================================================ */
.standings{border:2px solid var(--line)}
.st-head,.st-row{display:grid;grid-template-columns:60px 1fr 70px 70px 70px 90px;gap:10px;align-items:center;padding:18px 24px}
.st-head{background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:0.15em;text-transform:uppercase}
.st-row{border-bottom:1px solid var(--gray-1);transition:background 0.3s}
.st-row:last-child{border-bottom:none}
.st-row:hover{background:var(--gray-1)}
.st-rank{font-family:var(--disp);font-weight:800;font-size:22px;letter-spacing:-0.02em}
.st-team{font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:-0.01em;display:flex;align-items:center;gap:14px}
.st-team .badge{width:30px;height:30px;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;flex-shrink:0;text-transform:uppercase}
.st-cell{font-family:var(--mono);font-size:15px;text-align:center}
.st-pts{font-family:var(--disp);font-weight:800;font-size:20px;text-align:center;letter-spacing:-0.02em}
.st-note{font-family:var(--mono);font-size:11px;color:var(--gray-5);margin-top:20px;letter-spacing:0.05em}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .staff-grid{grid-template-columns:repeat(2,1fr)}
  .teams-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .format-row{grid-template-columns:1fr}
  .nav-mid{display:none}
}
@media(max-width:768px){
  nav.top{padding:0 20px}
  .hero{padding:0 20px}
  .page-head{padding:calc(var(--nav-h) + 50px) 20px 44px}
  section.block{padding:70px 20px}
  .cta-band{padding:90px 20px}
  footer{padding:60px 20px 30px}
  .scroll-hint,.hero-corner{display:none}
  .nav-cta{display:none}
  .staff-grid{grid-template-columns:1fr 1fr}
  .teams-grid{grid-template-columns:1fr}
  .match{grid-template-columns:1fr;gap:10px;text-align:left}
  .m-team.right{text-align:left}
  .vs{text-align:left}
  .st-head{display:none}
  .st-row{grid-template-columns:40px 1fr 60px;gap:8px}
  .st-row .st-cell:nth-child(3),.st-row .st-cell:nth-child(4){display:none}
  .foot-cols{gap:40px}
  .sec-head{flex-direction:column;gap:8px;margin-bottom:40px}
  .rule-inner{padding-left:0}
  .rule-head{grid-template-columns:50px 1fr 30px;gap:16px}
  .kvtable .kv{grid-template-columns:1fr}
  .side-menu{padding:28px 24px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}
  .stamp,.hero-title .row span,.reveal{opacity:1!important;transform:none!important;filter:none!important}
}
