/* ===================================================================
   Dynamo Bresno — unified site design system (v2)
   One stylesheet, site-wide. Tonal rhythm: deep-navy cinematic
   sections alternating with light ivory editorial sections.
   Space over borders. Gold = jewellery. Slow, expensive motion.
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;0,700;0,800;1,600&family=Inter:wght@400;500&display=swap');

:root{
  --navy:#16293F; --navy-deep:#0E1D2E; --navy-mid:#1D3A57; --ink:#0B1622;
  --crimson:#A02732; --crimson-b:#B83340;
  --gold:#C9A44C; --gold-b:#DCBB62;
  --cream:#F1E8D4; --cream-dim:#CDC3AD;
  --ivory:#F3ECDC; --ivory-2:#EAE0C9; --ivory-line:#dcd1b6;
  --ink-on-ivory:#16293F; --body-on-ivory:#3c4a5a; --muted-on-ivory:#8a7a52;
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--ink);color:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 48px}
h1,h2,h3{font-family:'Playfair Display',serif;font-weight:700;line-height:1.08}
.kick,.kicker{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:.72rem;font-weight:600}
:focus-visible{outline:2px solid var(--gold-b);outline-offset:3px}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;
  font-size:.9rem;font-weight:600;padding:16px 34px;cursor:pointer;border:none;transition:.25s}
.btn-crimson,.btn-primary{background:var(--crimson);color:#fff}
.btn-crimson:hover,.btn-primary:hover{background:var(--crimson-b)}
.btn-gold{background:var(--gold);color:var(--ink);font-weight:700}
.btn-gold:hover{background:var(--gold-b)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(241,232,212,.3)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ghost-dark{background:transparent;color:var(--navy);border:1px solid var(--ivory-line)}
.btn-ghost-dark:hover{border-color:var(--crimson);color:var(--crimson)}

/* ---------- Top utility strip ---------- */
.topbar{background:var(--ink);border-bottom:1px solid rgba(241,232,212,.08)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:58px;
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:.82rem;color:var(--cream-dim)}
.topbar .l{color:var(--gold)}
.topbar .r{display:flex;gap:36px}
.topbar a:hover{color:var(--cream)}

/* ---------- Dominant main nav ---------- */
.hdr{position:sticky;top:0;z-index:60;background:var(--navy);border-bottom:4px solid var(--crimson);box-shadow:0 8px 28px rgba(0,0,0,.45)}
.hdr .wrap{display:flex;align-items:center;height:118px;gap:30px}
.brand{display:flex;align-items:center;gap:18px}
.brand img{height:78px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}
.brand b{font-family:'Oswald',sans-serif;font-size:1.75rem;letter-spacing:.05em;text-transform:uppercase;color:#fff;line-height:1}
.brand .tl{display:block;font-family:'Oswald',sans-serif;font-size:.64rem;letter-spacing:.38em;color:var(--gold);text-transform:uppercase;margin-top:5px}
.nav{margin-left:auto;display:flex;align-items:center;gap:30px;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:.12em;font-size:.96rem;font-weight:500}
.nav a{color:var(--cream);padding:6px 0;border-bottom:2px solid transparent;transition:.15s}
.nav a:hover{color:#fff}
.nav a.on{color:#fff;border-bottom-color:var(--gold)}
.nav .join{background:var(--gold);color:var(--ink);padding:15px 18px;font-weight:700;letter-spacing:.1em;border-bottom:none;text-align:center}
.nav .join:hover{background:var(--gold-b);color:var(--ink)}
.navbtn{display:none}

/* ---------- Section frames ---------- */
.sec{padding:120px 0}
.sec-light{background:var(--ivory);color:var(--ink-on-ivory)}
.sec-ink{background:var(--ink)}
.sec-navy{background:var(--navy-deep)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;gap:24px}
.sec-head h2{font-size:2.7rem;color:#fff;margin-top:10px}
.sec-light .sec-head h2{color:var(--navy)}
.sec-head .kicker{color:var(--gold)}
.sec-light .sec-head .kicker{color:var(--crimson)}
.sec-head .more{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:.82rem;color:var(--gold);white-space:nowrap}
.sec-light .sec-head .more{color:var(--crimson)}

/* ===================================================================
   HOMEPAGE COMPONENTS
   =================================================================== */

/* ---------- Hero ---------- */
.hero{position:relative;min-height:520px;display:flex;align-items:flex-end;
  background:linear-gradient(90deg,rgba(8,14,22,.92),rgba(8,14,22,.3) 55%,rgba(8,14,22,0) 82%),
            linear-gradient(0deg,rgba(8,14,22,.94),transparent 52%),
            url('images/hero.jpg'),
            url('images/hero-proto.jpg'),
            radial-gradient(120% 90% at 72% -10%,rgba(160,39,50,.5),transparent 60%) , var(--navy-mid);
  background-size:cover;background-position:center;background-repeat:no-repeat}
.hero .wrap{width:100%;padding-top:64px;padding-bottom:72px}
.hero .tag{display:inline-block;background:var(--crimson);color:#fff;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:.18em;font-size:.66rem;padding:7px 15px;font-weight:600;margin:0 0 26px -15px}
.hero h1{font-size:4.1rem;color:#fff;max-width:16ch;letter-spacing:-.01em;text-shadow:0 2px 30px rgba(0,0,0,.6)}
.hero p{color:var(--cream-dim);font-size:1.18rem;max-width:48ch;margin:24px 0 0}
.hero .fixbar{margin-top:50px;display:flex;align-items:center;gap:26px;flex-wrap:wrap;
  border-top:1px solid rgba(241,232,212,.2);padding-top:22px;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;color:var(--cream-dim)}
.hero .fixbar b{color:#fff}
.hero .fixbar .g{color:var(--gold-b)}

/* ---------- Game promo (light) ---------- */
.promo{background:var(--ivory);color:var(--ink-on-ivory);padding:128px 0}
.promo .grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.promo .pic{aspect-ratio:4/5;background-size:cover;background-position:center top;background-color:var(--ivory-2);position:relative}
.promo .pic .badge{position:absolute;left:20px;top:20px;background:var(--crimson);color:#fff;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;font-weight:600;padding:7px 14px}
.promo .kick{color:var(--crimson)}
.promo h2{font-size:3.1rem;margin:16px 0 22px;color:var(--navy)}
.promo p{font-size:1.12rem;color:var(--body-on-ivory);max-width:44ch;margin-bottom:16px}
.promo .meta{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--muted-on-ivory);margin:6px 0 26px}
.promo .cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}

/* ---------- Squad rail (dark) ---------- */
.rail{background:var(--ink);padding:120px 0}
.rail .kick{color:var(--gold)}
.rail .row{display:grid;grid-template-columns:repeat(5,1fr);gap:26px}
.pl .pic{aspect-ratio:3/4;background-size:cover;background-position:center top;background-color:var(--navy-deep);transition:.25s}
.pl:hover .pic{filter:brightness(1.08)}
.pl .pos{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.58rem;color:var(--gold);margin-top:16px}
.pl .nm{font-family:'Playfair Display',serif;font-size:1.18rem;color:var(--cream);margin-top:4px}

/* ---------- News (light editorial) ---------- */
.news{background:var(--navy);color:var(--cream-dim);padding:120px 0}
.news .grid{display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:start}
.news .lead .pic{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--navy-deep);margin-bottom:24px}
.news .lead .k{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--gold)}
.news .lead h3{font-size:2.1rem;color:#fff;margin:10px 0 12px}
.news .lead p{color:var(--cream-dim);font-size:1.04rem;max-width:50ch}
.news .list a{display:block;padding:22px 0;border-top:1px solid rgba(241,232,212,.14)}
.news .list a:first-child{border-top:none;padding-top:0}
.news .list .k{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--gold)}
.news .list h4{font-family:'Playfair Display',serif;font-size:1.16rem;color:#fff;font-weight:600;margin-top:5px}
.news .list a:hover h4{color:var(--gold-b)}

/* ---------- The Rivalry / Iron Divide (dark) ---------- */
.rivalry{position:relative;background:var(--navy-deep);overflow:hidden}
.rivalry .split{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.rivalry .west{background:linear-gradient(160deg,var(--navy-mid),var(--navy-deep))}
.rivalry .east{background:linear-gradient(160deg,#7a1d27,#3c0f15)}
.rivalry .half{display:flex;flex-direction:column;justify-content:center;padding:80px 60px;color:#fff}
.rivalry .east .half{align-items:flex-end;text-align:right}
.rivalry .half .side{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;color:var(--gold)}
.rivalry .east .half .side{color:#f0c0c8}
.rivalry .half .club{font-family:'Playfair Display',serif;font-size:2.4rem;margin:10px 0 6px}
.rivalry .half .note{font-size:.98rem;color:var(--cream-dim);max-width:30ch}
.rivalry .center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center;
  background:var(--ink);border:1px solid rgba(241,232,212,.2);padding:32px 40px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.rivalry .center .kick{color:var(--gold);display:block;margin-bottom:10px}
.rivalry .center h2{font-size:2rem;color:#fff;margin-bottom:6px}
.rivalry .center .when{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--cream-dim)}

/* ---------- Dispatch sign-up (light) ---------- */
.dispatch{background:var(--ivory);color:var(--ink-on-ivory);padding:120px 0;text-align:center}
.dispatch .inner{max-width:620px;margin:0 auto}
.dispatch .kick{color:var(--crimson)}
.dispatch h2{font-size:2.6rem;color:var(--navy);margin:14px 0 14px}
.dispatch p{color:var(--body-on-ivory);font-size:1.08rem;margin-bottom:28px}
.dispatch form{display:flex;gap:12px;max-width:480px;margin:0 auto}
.dispatch input{flex:1;padding:15px 18px;background:#fff;border:1px solid var(--ivory-line);color:var(--navy);font-family:'Inter',sans-serif;font-size:.98rem}
.dispatch input:focus{outline:none;border-color:var(--crimson)}
.dispatch .note{font-size:.76rem;color:var(--muted-on-ivory);margin-top:16px}
.dispatch .ok{color:var(--crimson);font-family:'Oswald',sans-serif;letter-spacing:.05em;margin-top:16px;min-height:20px}

/* ===================================================================
   INNER-PAGE COMPONENTS
   =================================================================== */

/* ---------- Page hero (inner, dark cinematic) ---------- */
.page-hero{position:relative;overflow:hidden;background:
   radial-gradient(120% 120% at 80% -20%,rgba(160,39,50,.32),transparent 55%),
   linear-gradient(160deg,var(--navy),var(--navy-deep) 60%,var(--ink));
   padding:150px 0 110px;border-bottom:1px solid rgba(241,232,212,.08)}
.page-hero .crest-bg{position:absolute;right:-80px;top:50%;transform:translateY(-50%);
   height:440px;opacity:.05;pointer-events:none;filter:grayscale(.2)}
.page-hero .wrap{position:relative}
.page-hero .kicker{color:var(--gold);display:block;margin-bottom:20px}
.page-hero h1{font-size:4rem;color:#fff;letter-spacing:-.01em;max-width:16ch}
.page-hero p{color:var(--cream-dim);font-size:1.18rem;max-width:54ch;margin-top:24px}

/* ---------- Generic editorial block ---------- */
.block{padding:110px 0}
.block.light{background:var(--ivory);color:var(--ink-on-ivory)}
.block.light h2,.block.light h3{color:var(--navy)}
.block .sec-head h2{color:#fff}
.block.light .sec-head h2{color:var(--navy)}

/* ---------- Long-form prose ---------- */
.prose{max-width:760px}
.prose h2{font-size:2.4rem;color:#fff;margin:56px 0 18px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--cream-dim);font-size:1.08rem;margin-bottom:20px}
.prose .pull{font-family:'Playfair Display',serif;font-style:italic;font-size:1.5rem;color:var(--gold-b);
  border-left:2px solid var(--gold);padding-left:26px;margin:40px 0;max-width:30ch;line-height:1.4}
.prose a{color:var(--gold)}
.block.light .prose h2{color:var(--navy)}
.block.light .prose p{color:var(--body-on-ivory)}
.block.light .prose .pull{color:var(--crimson)}

/* ---------- Fact strip ---------- */
.fact-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-bottom:80px}
.fact-strip > div{padding:6px 0}
.fact-strip .v{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--gold-b);line-height:1}
.fact-strip .l{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:var(--cream-dim);margin-top:10px}
.block.light .fact-strip .v{color:var(--crimson)}
.block.light .fact-strip .l{color:var(--muted-on-ivory)}

/* ---------- Fixtures / results (slim, quiet) ---------- */
.fix-list{display:flex;flex-direction:column}
.fix-row{display:grid;grid-template-columns:1.3fr 2fr auto;gap:24px;align-items:center;
  padding:22px 4px;border-top:1px solid rgba(241,232,212,.1)}
.fix-row:last-child{border-bottom:1px solid rgba(241,232,212,.1)}
.fix-row .comp{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--gold)}
.fix-row .teams{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--cream)}
.fix-row .teams .ha{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.58rem;color:var(--cream-dim);margin-left:10px;border:1px solid rgba(241,232,212,.2);padding:3px 8px;vertical-align:middle}
.fix-row .dt{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--cream-dim);text-align:right}
.fix-row .score{font-family:'Oswald',sans-serif;font-size:1.2rem;color:var(--cream);text-align:right;letter-spacing:.05em}
.fix-row .score .w{color:var(--gold-b);font-weight:600}

/* ---------- League table (de-boxed) ---------- */
.league{width:100%;border-collapse:collapse;font-size:.95rem}
.league th{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;font-weight:600;
  color:var(--cream-dim);text-align:center;padding:0 10px 16px;border-bottom:1px solid rgba(241,232,212,.18)}
.league th.club{text-align:left}
.league td{padding:15px 10px;text-align:center;color:var(--cream-dim);border-bottom:1px solid rgba(241,232,212,.07)}
.league td.pos{color:var(--cream);font-family:'Oswald',sans-serif}
.league td.club{text-align:left;font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--cream)}
.league td.pts{font-family:'Oswald',sans-serif;font-weight:600;color:var(--cream)}
.league tr.dynamo td{background:rgba(201,164,76,.08)}
.league tr.dynamo td.club{color:var(--gold-b)}
.league tr.dynamo td.pos{color:var(--gold-b)}

/* ---------- Squad grid (de-boxed portraits) ---------- */
.squad-group{margin-bottom:84px}
.squad-group:last-child{margin-bottom:0}
.squad-group > h2{font-size:1.7rem;color:#fff;margin-bottom:30px;font-weight:600;
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em}
.squad-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:26px}
.player{display:block}
.player .pimg{position:relative;aspect-ratio:3/4;background-size:cover;background-position:center top;
  background-color:var(--navy-deep);transition:.25s filter}
.player:hover .pimg{filter:brightness(1.08)}
.player .pimg .num{position:absolute;right:12px;bottom:10px;font-family:'Oswald',sans-serif;font-weight:700;
  font-size:1.5rem;color:rgba(241,232,212,.85);text-shadow:0 2px 8px rgba(0,0,0,.6)}
.player .pinfo{padding-top:14px}
.player .pos{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.58rem;color:var(--gold)}
.player .pname{font-family:'Playfair Display',serif;font-size:1.18rem;color:var(--cream);margin-top:4px}
.player .pnat{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.62rem;color:var(--cream-dim);margin-top:5px}
.player.coach .pimg{aspect-ratio:3/4}

/* ---------- Player profile ---------- */
.read-link{display:inline-block;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.13em;
  font-size:.8rem;color:var(--gold)}
.read-link:hover{color:var(--gold-b)}
.profile-top{display:grid;grid-template-columns:380px 1fr;gap:60px;align-items:start}
.profile-photo{position:relative;aspect-ratio:3/4;background-size:cover;background-position:center top;background-color:var(--navy-deep)}
.profile-photo .num{position:absolute;right:18px;bottom:14px;font-family:'Oswald',sans-serif;font-weight:700;font-size:3rem;color:rgba(241,232,212,.85);text-shadow:0 2px 10px rgba(0,0,0,.6)}
.profile-head .kicker{color:var(--gold)}
.profile-head h1{font-size:3.2rem;color:#fff;margin:14px 0 8px}
.profile-head .pos{color:var(--cream-dim)}
.profile-facts{display:flex;gap:40px;margin:34px 0;padding:24px 0;border-top:1px solid rgba(241,232,212,.12);border-bottom:1px solid rgba(241,232,212,.12)}
.profile-facts .l{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:var(--cream-dim)}
.profile-facts .v{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--gold-b);margin-top:6px}
.profile-body h3{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.82rem;color:var(--gold);margin:30px 0 12px}
.profile-body p{color:var(--cream-dim);font-size:1.04rem;margin-bottom:16px}

/* ---------- Staff cards (de-boxed) ---------- */
.staff-card{display:grid;grid-template-columns:120px 1fr;gap:36px;align-items:start;
  padding:44px 0;border-top:1px solid rgba(241,232,212,.1)}
.staff-card:first-of-type{border-top:none;padding-top:0}
.staff-av{width:120px;height:120px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--navy-mid),var(--navy-deep));color:var(--gold-b);
  font-family:'Playfair Display',serif;font-size:2rem;letter-spacing:.05em}
.staff-card .role{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--gold)}
.staff-card h3{font-size:1.9rem;color:#fff;margin:6px 0 16px}
.staff-card .quote{font-family:'Playfair Display',serif;font-style:italic;font-size:1.2rem;color:var(--gold-b);margin-bottom:16px;max-width:46ch}
.staff-card p{color:var(--cream-dim);margin-bottom:14px;max-width:64ch}
.staff-card .meta{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--cream-dim);opacity:.85}
.staff-card .meta a{color:var(--gold)}

/* ---------- Montiselle network grid ---------- */
.net-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px}
.net-card{padding:30px 0;border-top:1px solid rgba(201,164,76,.25)}
.net-card .role{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.6rem;color:var(--gold)}
.net-card h4{font-family:'Playfair Display',serif;font-size:1.3rem;color:#fff;margin:6px 0 12px}
.net-card p{color:var(--cream-dim);font-size:.92rem;margin-bottom:12px}
.net-card .q{font-family:'Playfair Display',serif;font-style:italic;font-size:.98rem;color:var(--cream-dim);opacity:.85}

/* ---------- Kit page ---------- */
.kit-hero{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:96px}
.kit-hero .khimg{background:var(--ivory-2);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;overflow:hidden}
.kit-hero .khimg img{width:100%;height:100%;object-fit:cover}
.kit-hero .khbody .kicker{color:var(--crimson)}
.kit-hero .khbody h2{font-size:2.8rem;margin:14px 0 18px}
.kit-hero .khbody p{color:var(--body-on-ivory);font-size:1.1rem;max-width:46ch;margin-bottom:22px}
.kit-hero .price{font-family:'Oswald',sans-serif;letter-spacing:.04em;color:var(--navy)}
.kit-hero .price small{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-on-ivory);margin-top:6px}
.kit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.kit .kimg{background:var(--ivory-2);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:18px}
.kit .kimg img{width:100%;height:100%;object-fit:cover}
.kit .ktype{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:var(--muted-on-ivory)}
.kit h3{font-size:1.4rem;color:var(--navy);margin:6px 0 10px}
.kit .price{font-family:'Oswald',sans-serif;letter-spacing:.04em;color:var(--navy);font-size:1.05rem;margin-bottom:16px}
.kit .price small{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-on-ivory);margin-left:6px}

/* ---------- Article ---------- */
.article{max-width:720px;margin:0 auto}
.article .article-img{aspect-ratio:16/9;background-size:cover;background-position:center;background-color:var(--navy-deep);margin-bottom:40px}
.article .kicker{color:var(--gold);display:block;margin-bottom:16px}
.article h1{font-size:3rem;color:#fff;line-height:1.12;margin-bottom:18px}
.article .standfirst{font-size:1.25rem;color:var(--cream);font-family:'Playfair Display',serif;font-style:italic;margin-bottom:14px}
.article .byline{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--cream-dim);padding-bottom:30px;margin-bottom:30px;border-bottom:1px solid rgba(241,232,212,.12)}
.article p{color:var(--cream-dim);font-size:1.08rem;margin-bottom:22px}
.article h2{font-size:1.8rem;color:#fff;margin:40px 0 14px}
.article .pull{font-family:'Playfair Display',serif;font-style:italic;font-size:1.6rem;color:var(--gold-b);
  border-left:2px solid var(--gold);padding-left:26px;margin:36px 0;line-height:1.4}
.article a{color:var(--gold)}

/* ---------- CTA bands ---------- */
.band{background:var(--ivory);color:var(--ink-on-ivory);padding:110px 0;text-align:center}
.band .inner{max-width:620px;margin:0 auto}
.band .kicker{color:var(--crimson)}
.band h2{font-size:2.6rem;color:var(--navy);margin:14px 0 14px}
.band p{color:var(--body-on-ivory);font-size:1.08rem;margin-bottom:28px}
.band form{display:flex;gap:12px;max-width:480px;margin:0 auto}
.band input{flex:1;padding:15px 18px;background:#fff;border:1px solid var(--ivory-line);color:var(--navy);font-family:'Inter',sans-serif;font-size:.98rem}
.band input:focus{outline:none;border-color:var(--crimson)}
.band .note{font-size:.76rem;color:var(--muted-on-ivory);margin-top:16px}
.band .ok{color:var(--crimson);font-family:'Oswald',sans-serif;letter-spacing:.05em;margin-top:16px;min-height:20px}

/* ---------- Game feature band (dark) ---------- */
.game-band{background:var(--navy-deep);padding:100px 0;border-top:1px solid rgba(241,232,212,.08);border-bottom:1px solid rgba(241,232,212,.08)}
.game-band .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
.game-band .kicker{color:var(--gold)}
.game-band h2{font-size:2.6rem;color:#fff;margin:14px 0 16px}
.game-band p{color:var(--cream-dim);font-size:1.08rem;max-width:48ch;margin-bottom:26px}
.game-band .game-art{position:relative;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 40%,rgba(160,39,50,.3),transparent 60%),var(--ink)}
.game-band .game-art img{height:180px;opacity:.5}
.game-band .game-art .ov{position:absolute;bottom:26px;left:26px;right:26px;font-family:'Playfair Display',serif;
  font-style:italic;font-size:1.05rem;color:var(--cream-dim)}

/* ---------- "What you'll balance" cards (de-boxed) ---------- */
.balance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 50px}
.balance-item{padding-top:24px;border-top:1px solid rgba(241,232,212,.14)}
.balance-item .tag{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;color:var(--gold)}
.balance-item.crimson .tag{color:var(--crimson-b)}
.balance-item h3{font-size:1.4rem;color:#fff;margin:10px 0 10px}
.balance-item p{color:var(--cream-dim);font-size:.96rem}

/* ---------- News index (de-boxed editorial) ---------- */
.news-index{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start}
.news-lead .article-img,.news-lead .thumb{display:block;aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--navy-deep);margin-bottom:24px}
.news-lead .k{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--gold)}
.news-lead h3{font-size:2.2rem;color:#fff;margin:12px 0 14px}
.news-lead p{color:var(--cream-dim);font-size:1.06rem;max-width:52ch}
.news-lead .date{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;color:var(--cream-dim);margin-top:14px;opacity:.8}
.story-list .story{display:block;padding:24px 0;border-top:1px solid rgba(241,232,212,.1)}
.story-list .story:first-child{border-top:none;padding-top:0}
.story-list .k{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--gold)}
.story-list h4{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--cream);font-weight:600;margin:6px 0 6px}
.story-list .story:hover h4{color:var(--gold-b)}
.story-list p{color:var(--cream-dim);font-size:.9rem;opacity:.85}
.story-list .date{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--cream-dim);margin-top:8px;opacity:.7}

/* ---------- News filter chips ---------- */
.chips{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px}
.chip{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:.72rem;
  color:var(--cream-dim);padding:9px 20px;border:1px solid rgba(241,232,212,.2);cursor:pointer;transition:.2s}
.chip:hover{color:var(--cream);border-color:var(--gold)}
.chip.active{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:600}

/* ---------- Footer ---------- */
.foot{background:var(--ink);padding:80px 0 30px}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:40px;margin-bottom:48px}
.foot-brand img{height:72px;margin-bottom:16px}
.foot-brand p{color:var(--cream-dim);font-size:.88rem;max-width:300px}
.foot-col h4{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--gold);margin-bottom:16px;font-weight:600}
.foot-col a{display:block;color:var(--cream-dim);font-size:.9rem;padding:6px 0}
.foot-col a:hover{color:var(--cream)}
.foot-news p,.foot-dispatch p{color:var(--cream-dim);font-size:.86rem;margin-bottom:14px}
.foot-news form,.foot-dispatch form{display:flex;gap:8px}
.foot-news input,.foot-dispatch input{flex:1;padding:12px 14px;background:var(--navy);border:1px solid rgba(241,232,212,.2);color:var(--cream);font-size:.88rem}
.foot-news input:focus,.foot-dispatch input:focus{outline:none;border-color:var(--gold)}
.foot-news .btn,.foot-dispatch .btn{padding:12px 18px;font-size:.78rem}
.foot-news .ok,.foot-dispatch .ok{color:var(--gold-b);font-size:.78rem;margin-top:8px;font-family:'Oswald',sans-serif}
.partners{border-top:1px solid rgba(241,232,212,.1);border-bottom:1px solid rgba(241,232,212,.1);
  padding:28px 0;margin-bottom:24px;display:flex;align-items:center;justify-content:center;gap:50px;flex-wrap:wrap}
.partners .plabel{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:var(--cream-dim)}
.partners .pname{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--cream)}
.partners .pname small{font-family:'Oswald',sans-serif;font-size:.56rem;letter-spacing:.2em;display:block;color:var(--gold);text-transform:uppercase}
.foot-legal{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-legal .links a{font-size:.74rem;color:var(--cream-dim);margin-right:18px}
.foot-legal .copy{font-size:.74rem;color:var(--cream-dim);opacity:.7}
.fiction,.fiction-note{text-align:center;font-size:.72rem;color:var(--cream-dim);opacity:.55;margin-top:22px;max-width:760px;margin-left:auto;margin-right:auto;line-height:1.6}
.fiction a,.fiction-note a{color:var(--gold)}

/* ---------- Scroll-reveal motion (slow, expensive) ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .nav{display:none}
  .navbtn{display:inline-flex;margin-left:auto;align-items:center;gap:9px;background:var(--crimson);color:#fff;border:none;
    cursor:pointer;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.9rem;font-weight:600;padding:13px 22px}
  .hdr.nav-open .nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--navy-deep);border-top:1px solid rgba(241,232,212,.15);padding:8px 0;box-shadow:0 18px 40px rgba(0,0,0,.5)}
  .hdr.nav-open .nav a{padding:14px 48px;border-bottom:none}
  .hdr.nav-open .nav .join{margin:10px 48px;text-align:center}
}
@media(max-width:980px){
  .wrap{padding:0 26px}
  .hero h1{font-size:2.9rem}
  .page-hero{padding:110px 0 80px}
  .page-hero h1{font-size:2.9rem}
  .promo .grid,.news .grid,.news-index,.kit-hero,.game-band .wrap{grid-template-columns:1fr;gap:40px}
  .rail .row,.squad-grid{grid-template-columns:1fr 1fr 1fr}
  .kit-grid{grid-template-columns:1fr 1fr}
  .net-grid,.balance-grid{grid-template-columns:1fr 1fr}
  .rivalry .split{grid-template-columns:1fr}
  .rivalry .center{position:static;transform:none;margin:0 auto}
  .fact-strip{grid-template-columns:1fr 1fr;gap:30px 20px}
  .profile-top{grid-template-columns:1fr;gap:32px}
  .profile-photo{max-width:340px}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand,.foot-news,.foot-dispatch{grid-column:1/-1}
  .fix-row{grid-template-columns:1fr;gap:6px}
  .fix-row .dt,.fix-row .score{text-align:left}
}
@media(max-width:560px){
  .sec,.promo,.rail,.news,.dispatch,.block,.band,.game-band{padding:72px 0}
  .page-hero{padding:90px 0 64px}
  .rail .row,.squad-grid,.kit-grid,.net-grid,.balance-grid{grid-template-columns:1fr 1fr}
  .staff-card{grid-template-columns:1fr;gap:18px}
  .staff-av{width:90px;height:90px;font-size:1.5rem}
  .dispatch form,.band form{flex-direction:column}
  .league th.hide-sm,.league td.hide-sm{display:none}
  .article h1{font-size:2.1rem}
  .page-hero h1{font-size:2.3rem}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}

/* ---------- News carousel (The Dispatch) ---------- */
.carousel{position:relative;margin-top:10px}
.car-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 20px;-ms-overflow-style:none;scrollbar-width:none}
.car-track::-webkit-scrollbar{display:none}
.car-card{flex:0 0 calc(33.333% - 16px);scroll-snap-align:start;min-width:0;display:block;background:rgba(255,255,255,.04);border:1px solid rgba(241,232,212,.14);border-radius:8px;overflow:hidden;transition:transform .2s,border-color .2s;text-decoration:none}
.car-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.car-card .thumb{display:block;aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--navy-deep)}
.car-card .k{display:block;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;color:var(--gold);margin:18px 20px 0}
.car-card h3{font-family:'Playfair Display',serif;font-size:1.22rem;color:#fff;margin:8px 20px 0;line-height:1.25}
.car-card p{color:var(--cream-dim);font-size:.92rem;margin:10px 20px 0}
.car-card .date{display:block;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;color:var(--cream-dim);opacity:.7;margin:14px 20px 22px}
.car-btn{position:absolute;top:34%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border-radius:50%;border:1px solid rgba(241,232,212,.25);background:var(--navy-deep);color:var(--gold);font-size:1.7rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.car-btn:hover{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.car-btn.prev{left:-12px}.car-btn.next{right:-12px}
.car-btn[disabled]{opacity:.25;cursor:default}
@media(max-width:900px){.car-card{flex-basis:calc(50% - 12px)}}
@media(max-width:600px){.car-card{flex-basis:84%}.car-btn{display:none}}

/* ---------- Article prev/next floating arrows ---------- */
.art-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:40;width:54px;height:54px;border-radius:50%;background:var(--navy);color:var(--gold);border:1px solid rgba(241,232,212,.22);display:flex;align-items:center;justify-content:center;font-size:2rem;line-height:1;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.4);transition:background .2s,color .2s}
.art-nav:hover{background:var(--gold);color:var(--navy-deep)}
.art-nav.prev{left:18px}.art-nav.next{right:18px}
@media(max-width:760px){.art-nav{width:44px;height:44px;font-size:1.6rem}.art-nav.prev{left:8px}.art-nav.next{right:8px}}

/* The Dynamo Dispatch animated logo */
.dispatch-logo{display:block;width:72px;height:72px;border-radius:50%;object-fit:cover;margin:0 auto 18px;box-shadow:0 0 0 1px rgba(212,175,93,.4)}
.foot-news .dispatch-logo{width:46px;height:46px;margin:0 0 14px}
