/* =====================================================================
   SWAINSBORO RACEWAY — motorsports design system
   Black + racing red + neon. Aggressive, slanted, checkered, fast.
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:ital,wght@0,600;0,700;0,800;0,900;1,700;1,800;1,900&family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,500&display=swap');

:root{
  --black:#08080a; --carbon:#101116; --panel:#15161c; --panel-2:#1b1d25; --line:#2a2c36; --line-lit:#3a3d4a;
  --ink:#f4f5f7; --ink-dim:#b9bcc7; --ink-faint:#7e8290;
  --red:#e10600; --red-hot:#ff1e1e; --red-deep:#8c0400;
  --neon:#ff2740; --neon-2:#ff5a1f; --volt:#e6ff3a; --chrome:#d7dbe4;
  --disp:"Saira Condensed",Impact,"Arial Narrow",sans-serif;
  --body:"Barlow",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --maxw:1180px;
  --glow:0 0 18px rgba(255,39,64,.55);
}
*{box-sizing:border-box}
html{background:var(--black);scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--black);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--red-hot);text-decoration:none}
a:hover{color:#fff}
h1,h2,h3,h4{font-family:var(--disp);font-weight:800;line-height:.98;margin:0;color:#fff;
  text-transform:uppercase;letter-spacing:.5px;font-style:italic}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-9999px}.skip-link:focus{left:8px;top:8px;background:var(--red);color:#fff;padding:8px 12px;z-index:200}

/* carbon texture + checker utilities */
.carbon{background:
  linear-gradient(27deg,#15161c 5px,transparent 5px) 0 5px,
  linear-gradient(207deg,#15161c 5px,transparent 5px) 10px 0,
  linear-gradient(27deg,#1b1d25 5px,transparent 5px) 0 10px,
  linear-gradient(207deg,#1b1d25 5px,transparent 5px) 10px 5px,
  #121317;background-size:20px 20px}
.checker{background-image:
  linear-gradient(45deg,#fff 25%,transparent 25%,transparent 75%,#fff 75%),
  linear-gradient(45deg,#fff 25%,#000 25%,#000 75%,#fff 75%);
  background-size:16px 16px;background-position:0 0,8px 8px;background-color:#000}

/* speed-slash divider */
.slash{height:6px;background:repeating-linear-gradient(115deg,var(--red) 0 28px,#000 28px 34px,var(--red-hot) 34px 40px,#000 40px 64px)}

/* ---- buttons (skewed parallelogram) -------------------------------- */
.btn{--c:var(--red);display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-weight:800;
  font-style:italic;font-size:17px;text-transform:uppercase;letter-spacing:1px;color:#fff;cursor:pointer;
  background:var(--c);border:0;padding:13px 26px;transform:skewX(-9deg);box-shadow:0 0 0 0 rgba(255,39,64,.0);
  transition:box-shadow .15s,transform .08s,filter .15s;clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
.btn>*{transform:skewX(9deg)}
.btn span{display:inline-block;transform:skewX(9deg)}
.btn:hover{color:#fff;box-shadow:var(--glow);filter:brightness(1.08)}
.btn:active{transform:skewX(-9deg) translateY(2px)}
.btn.ghost{background:transparent;border:2px solid var(--red);color:#fff}
.btn.ghost:hover{background:rgba(225,6,0,.16)}
.btn.volt{--c:var(--volt);color:#0a0a0a}
.btn.volt:hover{box-shadow:0 0 18px rgba(230,255,58,.55)}
.btn.lg{font-size:20px;padding:16px 32px}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ---- top bar + header ---------------------------------------------- */
.topbar{background:#000;border-bottom:1px solid var(--red-deep);color:var(--ink-dim);font-family:var(--disp);
  font-style:italic;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:13px;text-align:center;padding:6px 10px}
.topbar b{color:var(--volt)}
.site-header{position:sticky;top:0;z-index:100;background:rgba(8,8,10,.96);backdrop-filter:blur(8px);
  border-bottom:2px solid var(--red);box-shadow:0 6px 24px rgba(0,0,0,.6)}
.site-header .wrap{display:flex;align-items:center;gap:18px;padding-top:10px;padding-bottom:10px}
.brand img{height:54px;width:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.7))}
.nav{margin-left:auto;display:flex;align-items:center;gap:2px}
.nav a{font-family:var(--disp);font-weight:700;font-style:italic;text-transform:uppercase;letter-spacing:1px;
  font-size:16px;color:var(--ink-dim);padding:10px 13px;position:relative;transition:color .12s}
.nav a:hover{color:#fff}
.nav a::after{content:"";position:absolute;left:8px;right:8px;bottom:4px;height:2px;background:var(--red);
  transform:scaleX(0);transform-origin:left;transition:transform .16s}
.nav a:hover::after,.nav a.on::after{transform:scaleX(1)}
.nav a.on{color:#fff}
.nav .btn{margin-left:8px;padding:9px 16px;font-size:15px;color:#fff}
.nav-toggle{display:none;margin-left:auto;background:#000;border:2px solid var(--red);color:#fff;
  font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;padding:8px 14px;cursor:pointer}

/* ---- hero ---------------------------------------------------------- */
.hero{position:relative;min-height:clamp(440px,72vh,680px);display:flex;align-items:center;overflow:hidden;
  background:#000}
.hero-bg{position:absolute;inset:0;background:center/cover no-repeat;
  filter:saturate(1.05) contrast(1.05);transform:scale(1.04)}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(8,8,10,.92) 0%,rgba(8,8,10,.7) 42%,rgba(8,8,10,.25) 100%),
  linear-gradient(0deg,#08080a 2%,transparent 40%)}
/* neon speed streaks */
.hero::after{content:"";position:absolute;right:-5%;top:0;bottom:0;width:55%;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(110deg,transparent 0 60px,rgba(255,39,64,.045) 60px 64px);
  mask:linear-gradient(90deg,transparent,#000)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero .kicker{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:3px;
  color:var(--volt);font-size:15px;margin:0 0 10px;text-shadow:0 0 14px rgba(230,255,58,.4)}
.hero h1{font-size:clamp(46px,8vw,104px);font-weight:900;letter-spacing:0;
  text-shadow:0 3px 0 #000,0 0 40px rgba(255,39,64,.35)}
.hero h1 .red{color:var(--red);text-shadow:0 3px 0 #000,0 0 36px rgba(255,39,64,.7)}
.hero .sub{max-width:560px;color:var(--ink-dim);font-size:19px;margin:14px 0 24px}
.hero .btn-row{margin-top:6px}

/* ---- next-event banner --------------------------------------------- */
.nextrace{position:relative;z-index:3;margin-top:-1px;background:linear-gradient(90deg,var(--red-deep),var(--red));
  border-top:2px solid #000;border-bottom:2px solid #000}
.nextrace .wrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap;padding:16px 22px}
.nextrace .flag{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;
  font-size:14px;letter-spacing:2px;color:#fff;background:#000;padding:6px 12px;transform:skewX(-9deg)}
.nextrace .flag span{display:inline-block;transform:skewX(9deg)}
.nextrace .ne-title{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;
  font-size:24px;color:#fff;line-height:1}
.nextrace .ne-meta{color:#ffd9d6;font-weight:600;font-size:15px}
.nextrace .btn{margin-left:auto;--c:#000}
.nextrace .btn:hover{box-shadow:0 0 18px rgba(0,0,0,.6)}

/* ---- sections ------------------------------------------------------ */
.section{padding:64px 0;position:relative}
.section.alt{background:var(--carbon)}
.eyebrow{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:3px;
  font-size:14px;color:var(--red-hot);margin:0 0 8px}
.section h2{font-size:clamp(32px,5vw,52px);font-weight:900}
.section h2 .red{color:var(--red)}
.lede{color:var(--ink-dim);font-size:19px;max-width:620px;margin:10px 0 0}
.sec-head{margin-bottom:28px}
.center{text-align:center}.center .lede{margin-left:auto;margin-right:auto}
.muted{color:var(--ink-faint)}

/* ---- dual track split ---------------------------------------------- */
.tracks{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.track-card{position:relative;overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;border:1px solid var(--line);background:var(--panel);isolation:isolate}
.track-card .tc-bg{position:absolute;inset:0;z-index:-2;background:center/cover no-repeat;transform:scale(1.05);
  transition:transform .5s;filter:grayscale(.2)}
.track-card:hover .tc-bg{transform:scale(1.12)}
.track-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(0deg,#000 8%,rgba(0,0,0,.35) 60%,rgba(0,0,0,.15) 100%)}
.track-card .badge{align-self:flex-start;font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;
  letter-spacing:1px;font-size:13px;padding:5px 12px;transform:skewX(-9deg);margin-bottom:auto}
.track-card .badge span{display:inline-block;transform:skewX(9deg)}
.track-card.dirt .badge{background:var(--red);color:#fff}
.track-card.kart .badge{background:var(--volt);color:#0a0a0a}
.track-card h3{font-size:38px;font-weight:900;margin:0 0 6px}
.track-card p{color:var(--ink-dim);font-size:15.5px;margin:0 0 16px;max-width:42ch}
.track-card .go{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  color:#fff;font-size:16px}
.track-card.dirt:hover{border-color:var(--red)}
.track-card.kart:hover{border-color:var(--volt)}
/* The kart photo is much brighter than the dirt one — dim it to match. */
.track-card.kart .tc-bg{filter:grayscale(.2) brightness(.6) contrast(1.02)}
/* kart card: themed graphic instead of a (wrong) dirt-car photo */
.track-card.kart .tc-bg.kart-art{background:
  radial-gradient(circle at 68% 34%, rgba(230,255,58,.10), transparent 55%),
  repeating-linear-gradient(115deg,#14151b 0 26px,#101116 26px 30px),#0d0e13;
  filter:none}
.track-card.kart .tc-bg.kart-art::after{content:"";position:absolute;inset:0;
  background:url('../img/kart.svg') no-repeat center 42%;background-size:80%}
.track-card.kart:hover .tc-bg.kart-art{transform:scale(1.06)}

/* ---- schedule list ------------------------------------------------- */
.sched{border:1px solid var(--line);background:var(--panel)}
.sched-row{display:grid;grid-template-columns:120px 1fr auto;gap:18px;align-items:center;padding:16px 20px;
  border-bottom:1px solid var(--line);transition:background .12s}
.sched-row:last-child{border-bottom:0}
.sched-row:hover{background:var(--panel-2)}
.sched-date{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;line-height:1;color:#fff}
.sched-date .d{display:block;font-size:30px;color:var(--red)}
.sched-date .m{display:block;font-size:14px;letter-spacing:1px;color:var(--ink-dim)}
.sched-title{font-family:var(--disp);font-style:italic;font-weight:700;text-transform:uppercase;font-size:21px;color:#fff;line-height:1.05}
.sched-sub{font-family:var(--body);font-style:normal;text-transform:none;color:var(--ink-faint);font-size:14px;font-weight:500;letter-spacing:0;margin-top:2px}
.sched-tag{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:1px;
  padding:4px 10px;border:1px solid var(--line-lit);color:var(--ink-dim);white-space:nowrap}
.sched-tag.dirt{border-color:var(--red);color:#ff7a72}
.sched-tag.kart{border-color:var(--volt);color:var(--volt)}

/* ---- sponsors ------------------------------------------------------ */
.sponsors{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.sponsor{aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;text-align:center;padding:14px;
  background:#fff;border:1px solid var(--line);transition:transform .12s,box-shadow .12s}
.sponsor:hover{transform:translateY(-3px);box-shadow:var(--glow)}
.sponsor img{max-height:80%;max-width:90%;object-fit:contain}
/* text fallback sponsor (no logo) */
.sponsor.text{background:linear-gradient(135deg,#1b1d25,#101116);border:1px solid var(--line-lit)}
.sponsor.text span{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;
  letter-spacing:1px;font-size:19px;color:#fff;line-height:1.05}
.sponsor.text small{display:block;font-family:var(--body);font-style:normal;text-transform:none;letter-spacing:0;
  color:var(--red-hot);font-size:12px;font-weight:600;margin-top:4px}

/* ---- interior page hero + blocks ----------------------------------- */
.page-hero{position:relative;padding:48px 0 30px;border-bottom:2px solid var(--red);
  background:linear-gradient(rgba(8,8,10,.86),rgba(8,8,10,.94)),url('../img/hero.jpg');
  background-size:cover;background-position:center}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(38px,6vw,64px);font-weight:900;text-shadow:0 2px 14px rgba(0,0,0,.9)}
.page-hero .eyebrow,.page-hero .lede{text-shadow:0 1px 10px rgba(0,0,0,.9)}
.page-hero h1 .red{color:var(--red)}
.page-hero .lede{margin-top:10px}
.page-hero + .section{padding-top:40px}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.chip{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  font-size:15px;color:var(--ink-dim);background:var(--panel);border:1px solid var(--line-lit);padding:7px 16px;
  transform:skewX(-9deg)}
.chip>*{display:inline-block;transform:skewX(9deg)}
.chip:hover{color:#fff;border-color:var(--red)}
.chip.on{background:var(--red);color:#fff;border-color:var(--red)}
.block-h{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;font-size:26px;
  color:#fff;margin:0 0 16px;padding-left:14px;border-left:5px solid var(--red)}

/* schedule rows as links */
a.sched-row{text-decoration:none;color:inherit}
a.sched-row:hover .sched-title{color:var(--red-hot)}

/* ---- event detail -------------------------------------------------- */
.event-hero .event-sub{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;
  font-size:clamp(20px,3.4vw,30px);color:var(--volt);margin:4px 0 8px;line-height:1}
.event-date{font-family:var(--disp);font-style:italic;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  color:var(--ink-dim);font-size:18px;margin:0}
.event-grid{display:grid;grid-template-columns:1fr 380px;gap:34px;align-items:start}
.event-grid.no-flyer{grid-template-columns:1fr;max-width:780px}
.event-desc{font-size:18px;color:var(--ink-dim);margin:0 0 26px}
.time-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:6px}
.time-cell{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--volt);padding:12px 14px}
.time-cell .tl{display:block;font-family:var(--body);font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-faint)}
.time-cell .tv{display:block;font-family:var(--disp);font-style:italic;font-weight:800;font-size:22px;color:#fff}
.div-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px}
.div-list li{background:var(--panel);border:1px solid var(--line);padding:11px 14px;font-weight:600;
  position:relative;padding-left:34px}
.div-list li::before{content:"";position:absolute;left:12px;top:50%;width:10px;height:10px;margin-top:-5px;
  background:var(--red);transform:skewX(-12deg)}
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.price-cell{background:linear-gradient(135deg,#1b1d25,#101116);border:1px solid var(--line-lit);padding:14px 16px}
.price-cell .pl{display:block;font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;color:var(--red-hot);font-size:15px}
.price-cell .pv{display:block;font-size:18px;color:#fff;font-weight:600;margin-top:3px}
.event-flyer img{width:100%;border:1px solid var(--line-lit);box-shadow:0 10px 40px rgba(0,0,0,.6)}
.event-flyer .muted{margin-top:8px}
.red-glow{text-shadow:0 0 18px rgba(255,39,64,.4)}

/* ---- class / info cards (track + about pages) ---------------------- */
.volt-t{color:var(--volt);text-shadow:0 0 18px rgba(230,255,58,.35)}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.class-card{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--red);padding:18px 20px}
.class-card.kart{border-left-color:var(--volt)}
.class-card h3{font-size:21px;font-weight:800;margin:0 0 6px;color:#fff}
.class-card p{color:var(--ink-dim);font-size:15px;margin:0}
.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.info-card{display:block;background:var(--panel);border:1px solid var(--line);padding:16px 18px;text-decoration:none}
.info-card .il{display:block;font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;
  letter-spacing:1px;color:var(--red-hot);font-size:14px}
.info-card .iv{display:block;color:var(--ink);font-size:16px;margin-top:5px;line-height:1.4}
.info-card.link:hover{border-color:var(--red);background:var(--panel-2)}

/* ---- feature band -------------------------------------------------- */
.feature-band{background:var(--carbon);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:56px 0}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.feature-grid img{width:100%;border:1px solid var(--line-lit);box-shadow:0 12px 40px rgba(0,0,0,.6)}
.feature-band .btn-row{margin-top:24px}

/* ---- directions map ------------------------------------------------ */
.dir-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:28px;align-items:start}
.map-wrap{position:relative;aspect-ratio:4/3;border:2px solid var(--red);box-shadow:0 12px 40px rgba(0,0,0,.6)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}
.contact-note{margin-top:40px;max-width:760px}
.contact-note .block-h{margin-bottom:8px}
.contact-note .btn-row{margin-top:26px}

@media(max-width:720px){
  .feature-grid,.dir-grid{grid-template-columns:1fr}
  /* Full-width hero text on mobile needs an even, darker scrim to stay readable. */
  .hero::before{background:
    linear-gradient(180deg,rgba(8,8,10,.84) 0%,rgba(8,8,10,.66) 45%,rgba(8,8,10,.92) 100%)}
  .hero-bg{filter:saturate(1.05) contrast(1.05) brightness(.78)}
}

/* ---- pull quote ---------------------------------------------------- */
.pull{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;font-size:26px;
  color:#fff;border-left:5px solid var(--red);padding:6px 0 6px 16px;margin:24px 0}

/* ---- rules / document pages ---------------------------------------- */
.doc-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin:14px 0}
.doc-list.big{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.doc{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--panel);
  border:1px solid var(--line-lit);border-left:4px solid var(--red);padding:14px 16px;color:#fff;
  font-weight:600;text-decoration:none}
.doc:hover{border-color:var(--red);background:var(--panel-2);color:#fff}
.doc .dl{font-family:var(--mono,monospace);font-size:12px;color:var(--red-hot)}
.rules-doc{border:1px solid var(--line);background:var(--panel);margin:0 0 12px}
.rules-doc>summary{cursor:pointer;list-style:none;padding:16px 20px;font-family:var(--disp);font-style:italic;
  font-weight:800;text-transform:uppercase;font-size:21px;color:#fff;border-left:5px solid var(--red);
  display:flex;align-items:center;justify-content:space-between}
.rules-doc>summary::-webkit-details-marker{display:none}
.rules-doc>summary::after{content:"+";color:var(--red-hot);font-size:26px;line-height:1}
.rules-doc[open]>summary::after{content:"\2212"}
.rules-doc>summary:hover{background:var(--panel-2)}
.rules-body{padding:6px 22px 20px;color:var(--ink-dim);font-size:15px;line-height:1.6}
.rules-body h2{font-size:20px;color:var(--red-hot);margin:20px 0 8px;font-style:italic;text-transform:uppercase}
.rules-body h3{font-size:17px;color:#fff;margin:16px 0 6px}
.rules-body ul,.rules-body ol{padding-left:22px;margin:8px 0}
.rules-body li{margin:5px 0}
.rules-body ol.rl li{margin:7px 0;padding-left:4px}
.rules-body p{margin:0 0 10px}
.rules-body a{color:var(--red-hot)}
.rules-body strong{color:var(--ink)}
.rules-body img{margin:12px 0;border:1px solid var(--line)}

/* big (headline) sponsor tiles */
.sponsors.big{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.sponsors.big .sponsor{aspect-ratio:5/2}

/* ---- footer -------------------------------------------------------- */
.site-footer{background:#000;border-top:2px solid var(--red);padding:46px 0 70px;color:var(--ink-faint);font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:28px;margin-bottom:24px}
.foot-grid img{height:48px;margin-bottom:12px}
.foot-grid h4{font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:1px;
  font-size:15px;color:var(--red-hot);margin:0 0 10px}
.foot-grid a{display:block;color:var(--ink-dim);padding:3px 0}
.foot-grid a:hover{color:var(--volt)}
.foot-bottom{border-top:1px solid var(--line);padding-top:16px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ---- responsive ---------------------------------------------------- */
@media(max-width:860px){
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:#0c0c10;border-bottom:2px solid var(--red);padding:8px}
  .nav.open{display:flex}
  .nav a{padding:12px 14px;border-bottom:1px solid var(--line)}
  .nav .btn{margin:8px 0 4px;justify-content:center}
  .nav-toggle{display:block}
  .site-header .wrap{position:relative}
  .tracks{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .sched-row{grid-template-columns:64px 1fr;grid-template-areas:"date title" "date tag"}
  .sched-row .sched-tag{grid-area:tag;justify-self:start}
  .sched-date .d{font-size:24px}
  .nextrace .btn{margin-left:0;width:100%;justify-content:center}
}

/* ============================ FORUM ============================ */
.forum-bar{background:var(--carbon);border-bottom:1px solid var(--line)}
.forum-bar .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 22px;flex-wrap:wrap}
.forum-bar a{font-family:var(--disp);font-weight:700;font-style:italic;text-transform:uppercase;letter-spacing:.5px;font-size:14px;color:var(--ink-dim)}
.forum-bar a:hover{color:#fff}
.forum-bar .fb-home{color:var(--red-hot)}
.fb-auth{display:flex;align-items:center;gap:14px}
.fb-hi{color:var(--ink-dim);font-size:14px;font-family:var(--disp);font-style:italic}
.fb-hi a{color:var(--volt)}
.fb-out{margin:0}
.fb-out button{background:none;border:0;color:var(--ink-dim);font-family:var(--disp);font-style:italic;font-weight:700;text-transform:uppercase;font-size:14px;letter-spacing:.5px;cursor:pointer;padding:0}
.fb-out button:hover{color:var(--red-hot)}
.fb-cta{color:#fff !important;background:var(--red);padding:6px 14px;transform:skewX(-9deg)}
.fb-cta:hover{filter:brightness(1.1)}

.forum-flash{padding:12px 16px;margin:16px 0;border-left:4px solid var(--line-lit);background:var(--panel);font-size:15px}
.forum-flash.ok{border-color:#39d353;background:rgba(57,211,83,.1)}
.forum-flash.err{border-color:var(--red);background:rgba(225,6,0,.12)}

.page-hero.compact{padding:34px 0 22px}
.forum-grid{display:grid;grid-template-columns:1fr 320px;gap:30px;align-items:start}
.forum-main{min-width:0}

.cat-list{display:flex;flex-direction:column;gap:12px}
.cat-row{display:flex;align-items:center;gap:16px;background:var(--panel);border:1px solid var(--line);padding:16px 18px;text-decoration:none}
.cat-row:hover{border-color:var(--red);background:var(--panel-2)}
.cat-row.market{border-left:3px solid var(--volt)}
.cat-ic{font-size:26px;flex:0 0 auto;width:40px;text-align:center}
.cat-body{flex:1;min-width:0}
.cat-body h3{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;font-size:20px;color:#fff;margin:0}
.cat-body p{color:var(--ink-dim);font-size:14px;margin:4px 0 0}
.cat-stats{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;gap:2px}
.cat-stats span{color:var(--ink-faint);font-size:13px}
.cat-stats b{color:var(--ink);font-size:16px}

.forum-side{display:flex;flex-direction:column;gap:16px}
.side-box{background:var(--panel);border:1px solid var(--line);padding:16px 18px}
.side-box h4{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;font-size:16px;margin:0 0 10px;color:var(--red-hot)}
.recent-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.recent-list li{border-bottom:1px solid var(--line);padding-bottom:10px}
.recent-list li:last-child{border-bottom:0;padding-bottom:0}
.recent-list a{display:block;color:var(--ink);font-weight:600;font-size:15px}
.recent-list a:hover{color:var(--red-hot)}
.recent-list .muted{display:block;font-size:12px;margin-top:2px}

.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}

.thread-list{display:flex;flex-direction:column;border:1px solid var(--line);background:var(--panel)}
.thread-row{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line);text-decoration:none}
.thread-row:last-child{border-bottom:0}
.thread-row:hover{background:var(--panel-2)}
.tr-thumb{width:64px;height:48px;object-fit:cover;border:1px solid var(--line-lit);flex:0 0 auto}
.tr-thumb.ph{background:repeating-linear-gradient(45deg,#1a1c24 0 8px,#15161c 8px 16px)}
.tr-main{flex:1;min-width:0}
.tr-title{color:#fff;font-weight:700;font-size:16px;line-height:1.3}
.tr-meta{color:var(--ink-faint);font-size:13px;margin-top:3px}
.tr-price{color:var(--volt);font-weight:700}
.tr-stats{flex:0 0 auto;display:none;flex-direction:column;text-align:right;gap:2px}
.tr-stats span{color:var(--ink-faint);font-size:12px}
.tr-stats b{color:var(--ink)}
.tr-last{flex:0 0 auto;display:none;flex-direction:column;text-align:right;gap:2px;min-width:84px}
.tr-last .muted{font-size:12px}
@media(min-width:760px){.tr-stats{display:flex}.tr-last{display:flex}}

.tag{display:inline-block;font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:.5px;font-size:11px;padding:2px 8px;background:var(--panel-2);border:1px solid var(--line-lit);color:var(--ink-dim);vertical-align:middle}
.tag.pin{color:#0a0a0a;background:var(--volt);border-color:var(--volt)}
.tag.lock{color:var(--ink);background:var(--panel-2)}
.tag.sold{color:#fff;background:var(--red);border-color:var(--red)}
.tag.market{color:#0a0a0a;background:var(--volt);border-color:var(--volt)}

.pager{display:flex;gap:6px;margin-top:20px;flex-wrap:wrap}
.pager a{padding:8px 14px;background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);font-family:var(--disp);font-weight:700}
.pager a:hover{border-color:var(--red)}
.pager a.on{background:var(--red);color:#fff;border-color:var(--red)}

.forum-thread{max-width:860px}
.market-box{display:flex;gap:18px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--volt);padding:16px;margin-bottom:22px;flex-wrap:wrap}
.market-box img{max-width:260px;width:100%;height:auto;border:1px solid var(--line-lit)}
.market-meta{flex:1;min-width:200px}
.market-price{font-family:var(--disp);font-style:italic;font-weight:900;font-size:32px;color:var(--volt)}
.market-status{display:inline-block;font-family:var(--disp);font-style:italic;font-weight:800;text-transform:uppercase;font-size:13px;padding:3px 12px;margin:8px 0;border:1px solid var(--line-lit)}
.market-status.sold{background:var(--red);color:#fff;border-color:var(--red)}
.market-status.available{color:var(--volt);border-color:var(--volt)}

.post{display:flex;gap:0;border:1px solid var(--line);background:var(--panel);margin-bottom:14px}
.post-author{flex:0 0 180px;background:var(--carbon);border-right:1px solid var(--line);padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.pa-name{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;font-size:18px;color:#fff}
.pa-name:hover{color:var(--red-hot)}
.pa-op{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--volt);letter-spacing:.5px}
.pa-loc{font-size:12px;color:var(--ink-dim)}
.pa-since{font-size:12px}
.post-body{flex:1;min-width:0;padding:14px 18px}
.post-when{font-size:12px;margin-bottom:8px}
.post-text{color:var(--ink);line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}
.post-text a{color:var(--red-hot);text-decoration:underline}
@media(max-width:620px){.post{flex-direction:column}.post-author{flex-basis:auto;border-right:0;border-bottom:1px solid var(--line);flex-direction:row;flex-wrap:wrap;align-items:center}}

.reply-form{margin-top:22px;background:var(--panel);border:1px solid var(--line);padding:18px}
.reply-form h3{font-family:var(--disp);font-style:italic;font-weight:900;text-transform:uppercase;margin:0 0 12px}
.reply-locked,.reply-cta{margin-top:22px;background:var(--panel);border:1px solid var(--line);padding:16px 18px;color:var(--ink-dim)}
.reply-cta a{color:var(--red-hot)}

.forum-form{display:flex;flex-direction:column;gap:6px}
.forum-form label{font-family:var(--disp);font-style:italic;font-weight:700;text-transform:uppercase;font-size:14px;color:var(--ink-dim);margin-top:10px}
.forum-form input,.forum-form select,.forum-form textarea,.reply-form textarea{width:100%;background:var(--carbon);border:1px solid var(--line-lit);color:var(--ink);padding:11px 13px;font-size:15px;font-family:inherit}
.forum-form input:focus,.forum-form select:focus,.forum-form textarea:focus,.reply-form textarea:focus{outline:none;border-color:var(--red)}
.forum-form textarea,.reply-form textarea{resize:vertical;line-height:1.5}
.forum-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.forum-form .form-actions,.reply-form .form-actions{display:flex;gap:12px;margin-top:16px}
.market-fields{border:1px dashed var(--line-lit);padding:14px 16px;margin-top:12px;background:rgba(230,255,58,.03)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.empty{background:var(--panel);border:1px dashed var(--line-lit);padding:22px;color:var(--ink-dim);text-align:center}
.empty a{color:var(--red-hot)}
@media(max-width:820px){.forum-grid{grid-template-columns:1fr}}
