/* =============================================================================
   Sunday Marathon — public design system (ds.css) — VOLT brand.
   Pivoted to match the SundayMarathon App: warm ink + paper + electric volt
   lime, Archivo (display) / Hanken Grotesk (body) / Space Mono (data).
   Plain unlayered CSS loaded AFTER the inline shell partial so it wins ties.
   Re-skins the legacy --sm-* token surface used by every public view.
   ========================================================================== */

/* ---------------------------------------------------------------- tokens -- */
:root {
  /* Volt brand (shared with public/css/app.css) */
  --ink:        oklch(0.20 0.012 95);
  --ink-2:      oklch(0.30 0.012 95);
  --paper:      oklch(0.965 0.006 95);
  --paper-2:    oklch(0.945 0.008 95);
  --card:       oklch(1 0 0);
  --line:       oklch(0.90 0.01 95);
  --line-dk:    oklch(0.34 0.012 95);
  --volt:       oklch(0.87 0.20 128);
  --volt-deep:  oklch(0.74 0.20 130);
  --volt-soft:  oklch(0.95 0.06 128);
  --muted:      oklch(0.52 0.012 95);
  --muted-dk:   oklch(0.70 0.01 95);
  --gold:       #E8B23A;
  --gold-soft:  #FBF0D2;
  --danger:     #C9362D;
  --success:    var(--volt-deep);

  /* Type */
  --font-display: "Archivo", system-ui, -apple-system, sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono:    "Space Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Type scale (Archivo is heavy → slightly tighter than the serif scale) */
  --fs-display: clamp(2.1rem, 1.3rem + 3.6vw, 4.2rem);
  --fs-h2:      clamp(1.55rem, 1.1rem + 2vw, 2.5rem);
  --fs-h3:      clamp(1.12rem, 1rem + .6vw, 1.35rem);
  --fs-title:   1.05rem;
  --fs-lead:    clamp(1rem, .96rem + .5vw, 1.18rem);
  --fs-body:    1rem;
  --fs-caption: .82rem;
  --fs-eyebrow: .76rem;

  /* Geometry / motion */
  --r-sm: 9px; --r-md: 12px; --r-lg: 16px; --r-xl: 20px; --r-pill: 999px;
  --sh-1: 0 1px 2px rgba(20,22,18,.05);
  --sh-2: 0 14px 30px -22px rgba(20,22,18,.45);
  --sh-3: 0 24px 50px -34px rgba(20,22,18,.5);
  --t-fast: 140ms cubic-bezier(.2,.7,.2,1);
  --t: 240ms cubic-bezier(.2,.7,.2,1);

  /* ---- Legacy --sm-* alias bridge (re-skins all existing public views) -- */
  --sm-road:         var(--ink);
  --sm-road-soft:    var(--ink-2);
  --sm-mile:         var(--muted);
  --sm-muted:        var(--muted);
  --sm-start:        var(--card);
  --sm-cloud:        var(--paper-2);
  --sm-sky:          var(--volt-soft);
  --sm-cream:        var(--volt-soft);
  --sm-teal:         var(--volt-deep);
  --sm-teal-dark:    var(--ink);
  --sm-teal-soft:    var(--volt-soft);
  --sm-route:        var(--volt-deep);
  --sm-route-soft:   var(--volt-soft);
  --sm-gold:         var(--gold);
  --sm-gold-soft:    var(--gold-soft);
  --sm-clay:         var(--volt-deep);
  --sm-clay-soft:    var(--volt-soft);
  --sm-red:          var(--danger);
  --sm-border:       var(--line);
  --sm-border-strong:var(--line-dk);
  --sm-surface:      var(--card);
  --sm-surface-soft: var(--paper-2);
  --sm-radius:       var(--r-md);
  --sm-radius-sm:    var(--r-sm);
  --sm-shadow:       var(--sh-3);
  --sm-shadow-soft:  var(--sh-2);
  --sm-focus:        0 0 0 3px color-mix(in oklab, var(--volt-deep) 35%, transparent);
}

/* ------------------------------------------------------------------ base -- */
html { background: var(--paper-2); }
body {
  background: var(--paper-2);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, .site-content h1, .site-content h2, .site-content h3, .smui-page-hero h1, .smui-empty h2 {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.02;
  color: var(--ink);
}
.site-content h1, .smui-page-hero h1 { font-weight: 900; line-height: 1.0; }
.smui-stat strong, .race-list-countdown, .race-date-card__day, .race-date-card__year,
.race-comparison-date-text, .location-date-text, .home-date-text, .ds-num, time, .ds-price,
.eyebrow, .smui-page-hero-kicker, .location-kicker {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}
a { color: var(--volt-deep); }
::selection { background: var(--volt); color: var(--ink); }

/* ---- Header ---------------------------------------------------------- */
.site-header {
  background: color-mix(in oklab, var(--paper) 88%, transparent);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 rgba(20,22,18,.03);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.site-brand-mark { border-color: var(--line); background: var(--ink); box-shadow: var(--sh-1); }
.site-brand-name { font-family: var(--font-display); font-weight: 900; letter-spacing: -.03em; color: var(--ink); }
.site-brand-tagline { color: var(--muted); font-weight: 500; font-family: var(--font-mono); font-size: .72rem; }
.site-nav a:not(.site-nav-submit) { color: var(--ink); font-weight: 700; font-size: .95rem; }
.site-nav a:hover, .site-nav a:focus-visible { color: var(--volt-deep); border-bottom-color: var(--volt-deep); }
.site-nav a:not(.site-nav-submit)[aria-current="page"] { color: var(--ink); border-bottom-color: var(--volt); }
.site-submit-link, .site-nav-submit {
  border-color: var(--volt); background: var(--volt); color: var(--ink);
  font-family: var(--font-display); font-weight: 800; border-radius: var(--r-pill);
  box-shadow: 0 1px 0 var(--volt-deep); transition: transform var(--t-fast), box-shadow var(--t);
}
.site-submit-link:hover, .site-nav-submit:hover { background: var(--volt); color: var(--ink); transform: translateY(-1px); box-shadow: 0 8px 22px -8px var(--volt-deep); }
.site-header-tools { display: inline-flex; align-items: center; gap: var(--sp-2, 8px); }
.site-search-link, .site-myraces-link {
  display: inline-flex; align-items: center; gap: 6px; min-height: 38px; padding: 7px 13px;
  border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--paper-2);
  color: var(--ink); font-weight: 700; font-size: .92rem; text-decoration: none; transition: border-color var(--t-fast);
}
.site-search-link:hover, .site-myraces-link:hover { border-color: var(--ink); color: var(--ink); text-decoration: none; }
.site-search-link svg, .site-myraces-link svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.9; }
.site-nav-more { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; padding-top: 8px; border-top: 1px dashed var(--line); }

/* ---- Buttons --------------------------------------------------------- */
.site-content button, .site-content input[type="submit"], .site-content input[type="button"],
.site-content .button, .smui-button {
  border-radius: var(--r-pill); font-family: var(--font-display); font-weight: 700;
  background: var(--ink); border-color: var(--ink); color: var(--paper);
  box-shadow: none; transition: transform var(--t-fast), background var(--t), box-shadow var(--t);
}
.smui-button:hover, .site-content button:hover { transform: translateY(-1px); box-shadow: 0 10px 24px -12px var(--ink); color: var(--paper); }
.smui-button--primary, .ds-btn-cta, .home-hero-search button, .location-search button,
.race-filter-actions .smui-button, .calendar-filter button {
  background: var(--volt); border-color: var(--volt); color: var(--ink);
  box-shadow: 0 1px 0 var(--volt-deep);
}
.smui-button--primary:hover, .ds-btn-cta:hover, .home-hero-search button:hover, .location-search button:hover,
.race-filter-actions .smui-button:hover, .calendar-filter button:hover {
  background: var(--volt); border-color: var(--volt); color: var(--ink); box-shadow: 0 8px 22px -8px var(--volt-deep);
}
/* volt-bg link buttons need ink text (beats the dark-button a.smui-button rule) */
.site-content a.smui-button--primary, .home-page a.smui-button--primary, a.ds-btn-cta { color: var(--ink); }
.smui-button--secondary, .site-content .button-secondary {
  background: var(--card); border-color: var(--line); color: var(--ink); box-shadow: none;
}
.smui-button--secondary:hover, .site-content .button-secondary:hover { background: var(--paper-2); border-color: var(--ink); color: var(--ink); }

/* ---- Surfaces / cards ------------------------------------------------ */
.smui-panel, .smui-form, .smui-empty, .smui-item-list li, .smui-fact-list, .smui-stat,
.site-content table, .smui-table, .race-comparison {
  border-color: var(--line); border-radius: var(--r-md); box-shadow: var(--sh-2); background: var(--card);
}
.smui-stat { background: linear-gradient(180deg, var(--card), var(--paper-2)); }
.smui-stat strong { color: var(--ink); font-size: 1.5rem; }
.smui-page-hero {
  border-color: var(--line-dk); border-radius: var(--r-lg);
  background: linear-gradient(135deg, var(--ink) 0%, var(--ink-2) 100%); color: var(--paper);
  box-shadow: var(--sh-2);
}
.smui-page-hero h1 { color: var(--paper); }
.smui-page-hero p { color: var(--muted-dk); }
.smui-page-hero a:not(.smui-button) { color: var(--volt); }
.smui-page-hero-kicker, .location-kicker {
  border-color: transparent; background: color-mix(in oklab, var(--volt) 22%, transparent); color: var(--volt);
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em; font-size: .72rem;
}

/* ---- Date card → volt month band, mono numerals ---------------------- */
.race-date-card { border-color: var(--line); border-radius: var(--r-sm); box-shadow: var(--sh-1); }
.race-date-card__month { background: var(--volt); color: var(--ink); }
.race-date-card__day { color: var(--ink); }
.race-date-card__year { color: var(--muted); }

/* ---- Chips / badges -------------------------------------------------- */
.smui-status-chip, .smui-trust-label { border-radius: var(--r-pill); font-weight: 700; font-size: .82rem; font-family: var(--font-mono); }
.smui-status-chip--success { background: var(--volt-soft); border-color: color-mix(in oklab, var(--volt-deep) 35%, transparent); color: var(--ink); }
.smui-status-chip--warning { background: var(--gold-soft); border-color: rgba(232,178,58,.5); color: #7A5200; }
.smui-status-chip--danger  { background: #FCEBEA; border-color: rgba(201,54,45,.3); color: #9B1C1C; }
.ds-chip { display:inline-flex; align-items:center; gap:5px; min-height:24px; padding:3px 9px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--paper-2); font-family:var(--font-mono); font-size:.74rem; font-weight:700; color:var(--ink); text-transform:uppercase; letter-spacing:.06em; }
.ds-chip--bq { background: var(--gold-soft); border-color: rgba(232,178,58,.5); color:#7A5200; }
.ds-chip--full, .ds-chip--teal { background: var(--volt); border-color: var(--volt); color: var(--ink); }

/* ---- Content links + tables ------------------------------------------ */
.site-content a, .site-footer a { color: var(--ink); text-decoration-color: color-mix(in oklab, var(--volt-deep) 55%, transparent); text-underline-offset: 3px; }
.site-content a:hover, .site-footer a:hover { color: var(--volt-deep); text-decoration-color: var(--volt-deep); }
.site-content th, .smui-table th, .race-comparison th { background: var(--paper-2); color: var(--ink-2); font-family: var(--font-mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.race-comparison tr:hover, .location-table tr:hover, .smui-directory-table tr:hover { background: var(--paper-2); }
.race-comparison-race, .location-race-link, .smui-directory-table td:first-child a { color: var(--ink); font-weight: 800; }
.race-comparison-plan, .race-comparison-organizer-update, .location-plan-link, .home-plan-link { color: var(--volt-deep); }

/* ---- Footer ---------------------------------------------------------- */
.site-footer { background: var(--card); border-top: 1px solid var(--line); }
.site-footer-grid { grid-template-columns: minmax(220px,1.5fr) repeat(4, minmax(120px,1fr)); }
.site-footer-brand strong { font-family: var(--font-display); font-weight: 900; }
.site-footer-links h2 { font-family: var(--font-mono); font-weight: 700; font-size: .76rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }
@media (max-width: 920px) { .site-footer-grid { grid-template-columns: 1fr 1fr 1fr; } .site-footer-brand { grid-column: 1 / -1; } }
@media (max-width: 640px) { .site-footer-grid { grid-template-columns: 1fr 1fr; } }

/* ====================================================================
   APP CHROME on public pages — the appbar + bottom nav from the app, so
   the whole site wears the app shell. Classes don't collide with public ones.
   ==================================================================== */
.appbar{position:sticky;top:0;z-index:40;background:color-mix(in oklab,var(--paper) 88%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.appbar-in{max-width:1180px;margin:0 auto;height:62px;display:flex;align-items:center;gap:20px;padding:0 24px}
.appbar .brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:-.03em;color:var(--ink);text-decoration:none}
.appbar .mark{width:28px;height:28px;border-radius:50%;background:var(--ink);position:relative;flex:none}
.appbar .mark::before{content:"";position:absolute;inset:0;border-radius:50%;border:3px solid var(--volt);clip-path:polygon(50% 0,100% 0,100% 100%,50% 100%)}
.appbar .mark::after{content:"";position:absolute;width:7px;height:7px;border-radius:50%;background:var(--volt);top:5px;left:5px}
.appbar .brand-tx{font-size:18px}
@media(max-width:720px){.appbar .brand-tx{display:none}}
.appbar-search{flex:1;max-width:360px;display:flex;align-items:center;gap:9px;background:var(--paper-2);border:1px solid var(--line);border-radius:11px;padding:9px 13px;color:var(--muted);text-decoration:none}
.appbar-search:hover{border-color:var(--ink);color:var(--muted)}
.appbar-search .gi{font-family:var(--font-mono);font-size:15px;font-weight:700}
.appbar-search span{font-size:14px}
.appbar-nav{margin-left:auto;display:flex;align-items:center;gap:4px}
.appbar-nav .navitem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 14px;border-radius:10px;color:var(--muted);font-size:11px;font-weight:600;font-family:var(--font-body);text-decoration:none;transition:color .15s,background .15s}
.appbar-nav .navitem .gi{font-family:var(--font-mono);font-size:18px}
.appbar-nav .navitem:hover{color:var(--ink);background:var(--paper-2);text-decoration:none}
.appbar-nav .navitem[aria-current="page"]{color:var(--ink)}
.appbar-nav .navitem[aria-current="page"] .gi{color:var(--volt-deep)}
@media(max-width:720px){.appbar-nav .navitem{display:none}}
.appbar-upgrade{display:flex;align-items:center;gap:6px;margin-left:8px;background:var(--volt);color:var(--ink);font-family:var(--font-display);font-weight:800;font-size:13px;padding:9px 15px;border-radius:999px;text-decoration:none;transition:transform .14s,box-shadow .2s}
.appbar-upgrade:hover{transform:translateY(-1px);box-shadow:0 8px 20px -8px var(--volt-deep);color:var(--ink)}
.appbar-ava{margin-left:8px;width:36px;height:36px;border-radius:11px;display:inline-grid;place-items:center;background:var(--ink);color:var(--paper);font-family:var(--font-display);font-weight:900;font-size:14px;text-decoration:none;transition:transform .14s}
.appbar-ava:hover{transform:translateY(-1px);color:var(--paper)}
.app-mobnav{display:none}
@media(max-width:720px){
  .app-mobnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:var(--card);border-top:1px solid var(--line);justify-content:space-around;padding:8px 0 calc(10px + env(safe-area-inset-bottom))}
  .app-mobnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--muted);font-weight:600;text-decoration:none}
  .app-mobnav a .gi{font-family:var(--font-mono);font-size:19px}
  .app-mobnav a[aria-current="page"]{color:var(--ink)}
  .app-mobnav a[aria-current="page"] .gi{color:var(--volt-deep)}
  body{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
}

/* ====================================================================
   APP COMPONENTS on public pages — page header, chips, race-card grid,
   so directory/listing pages read as the app's directory screen.
   (Namespaced to match app.css class names; public pages don't load app.css.)
   ==================================================================== */
.app-page{max-width:1100px;margin:0 auto}
.app-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;flex-wrap:wrap}
.app-page-head .eyebrow{display:block;font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--volt-deep);margin-bottom:8px}
.app-page-title{font-family:var(--font-display);font-weight:900;letter-spacing:-.03em;font-size:clamp(30px,4vw,46px);line-height:1.0;margin:0;color:var(--ink)}
.app-page-lede{font-size:17px;color:var(--muted);margin-top:12px;max-width:62ch}
.app-page-lede a{color:var(--ink);text-decoration-color:var(--volt-deep)}
.app-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 24px}
@media(max-width:760px){.app-metrics{grid-template-columns:repeat(2,1fr)}}
.app-metric{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 16px}
.app-metric b{display:block;font-family:var(--font-display);font-weight:900;font-size:20px;letter-spacing:-.02em;color:var(--ink)}
.app-metric span{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:3px;display:block}
.app-chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.app-chip{font-family:var(--font-display);font-weight:700;font-size:14px;padding:9px 16px;border-radius:999px;border:1.5px solid var(--line);background:var(--card);color:var(--ink-2);text-decoration:none;transition:all .15s var(--ease,ease)}
.app-chip:hover{border-color:var(--ink);color:var(--ink);text-decoration:none}
.app-chip[aria-current="page"],.app-chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.app-race-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.app-race-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.app-race-grid{grid-template-columns:1fr}}
.app-rcard{display:flex;flex-direction:column;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:16px;text-decoration:none;color:var(--ink);transition:transform .2s var(--ease,ease),box-shadow .2s,border-color .2s}
.app-rcard:hover{transform:translateY(-3px);box-shadow:var(--sh-3);border-color:var(--ink);color:var(--ink);text-decoration:none}
.app-rc-img{height:148px;position:relative;background:var(--rc-grad,linear-gradient(135deg,var(--ink),var(--ink-2)))}
.app-rc-img .ph-tag{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dk);background:color-mix(in oklab,var(--ink) 66%,transparent);padding:5px 9px;border-radius:6px;text-align:center;max-width:80%}
.app-rc-date{position:absolute;top:11px;left:11px;background:var(--card);border-radius:10px;text-align:center;padding:6px 10px;box-shadow:0 6px 16px -10px rgba(0,0,0,.6);line-height:1}
.app-rc-date .d{font-family:var(--font-display);font-weight:900;font-size:19px;letter-spacing:-.03em;color:var(--ink)}
.app-rc-date .m{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.app-rc-dist{position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;background:var(--volt);color:var(--ink);padding:5px 9px;border-radius:7px}
.app-rc-body{padding:16px;flex:1;display:flex;flex-direction:column}
.app-rc-name{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.02em;line-height:1.12;color:var(--ink)}
.app-rc-loc{font-size:13.5px;color:var(--muted);margin-top:6px;display:flex;align-items:center;gap:6px}
.app-rc-loc .gi{font-family:var(--font-mono);font-size:12px;color:var(--volt-deep)}
.app-rc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.app-rc-meta{font-family:var(--font-mono);font-size:11px;color:var(--muted)}
.app-rc-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--volt-deep)}
.app-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:30px 0 16px}
.app-section-head h2{font-family:var(--font-display);font-weight:900;font-size:clamp(20px,2.4vw,28px);letter-spacing:-.02em;margin:0;color:var(--ink)}
.app-section-head a{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--volt-deep);text-decoration:none;white-space:nowrap}
.app-section-head a:hover{color:var(--ink)}
.app-join{margin:8px 0 4px;padding:clamp(22px,3vw,32px);border-radius:18px;background:var(--ink);color:var(--paper);display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;position:relative;overflow:hidden;isolation:isolate}
.app-join::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(60% 90% at 100% 0%,color-mix(in oklab,var(--volt) 22%,transparent),transparent 60%)}
.app-join-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--volt)}
.app-join h2{color:var(--paper);font-family:var(--font-display);font-weight:900;font-size:clamp(21px,2.6vw,30px);letter-spacing:-.02em;margin:8px 0 6px;line-height:1.04}
.app-join p{color:var(--muted-dk);margin:0;max-width:56ch}
.app-join-actions{display:flex;gap:10px;flex-wrap:wrap}
.app-join-actions a{display:inline-flex;align-items:center;min-height:48px;padding:0 22px;border-radius:999px;font-family:var(--font-display);font-weight:800;text-decoration:none}
.app-join-primary{background:var(--volt);color:var(--ink)}
.app-join-primary:hover{color:var(--ink);transform:translateY(-1px)}
.app-join-ghost{border:1.5px solid rgba(255,255,255,.4);color:var(--paper)}
.app-join-ghost:hover{background:rgba(255,255,255,.12);color:var(--paper)}
@media(max-width:760px){.app-join{grid-template-columns:1fr}.app-join-actions a{width:100%;justify-content:center}}
.app-quicklinks{display:flex;gap:10px;flex-wrap:wrap;margin:4px 0 8px}
.app-quicklink{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:14px;text-decoration:none;transition:border-color .15s}
.app-quicklink:hover{border-color:var(--ink);color:var(--ink);text-decoration:none}
.app-quicklink b{font-family:var(--font-mono);font-weight:700;font-size:11px;color:var(--muted)}

/* ---- App content surfaces (cards, prose, panels) for converted pages -- */
.app-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px}
.app-prose{max-width:760px}
.app-prose h2{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:clamp(20px,2.4vw,26px);margin:28px 0 10px;color:var(--ink)}
.app-prose h3{font-family:var(--font-display);font-weight:800;font-size:18px;margin:20px 0 8px;color:var(--ink)}
.app-prose p,.app-prose li{color:var(--ink-2);line-height:1.65}
.app-prose a{color:var(--volt-deep)}
.app-back{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--muted);margin-bottom:18px;padding:7px 12px;border-radius:9px;text-decoration:none;transition:color .15s,background .15s}
.app-back:hover{color:var(--ink);background:var(--card)}

/* ---- App race-detail layout (for /marathon/{slug}) ------------------- */
.app-race-hero{height:clamp(220px,32vw,320px);position:relative;border-radius:18px;overflow:hidden;margin-bottom:24px;background:var(--rc-grad,linear-gradient(135deg,var(--ink),var(--ink-2)))}
.app-race-hero .ph-tag{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-dk);background:color-mix(in oklab,var(--ink) 60%,transparent);padding:6px 11px;border-radius:7px}
.app-race-hero .app-rc-dist{top:14px;right:14px;font-size:13px;padding:7px 12px;border-radius:9px}
.app-race-detail{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:30px;align-items:start}
@media(max-width:860px){.app-race-detail{grid-template-columns:1fr}}
.app-rd-blurb{font-size:17px;line-height:1.6;color:var(--ink-2);margin:14px 0 26px;max-width:62ch}
.app-fact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:28px}
@media(max-width:560px){.app-fact-grid{grid-template-columns:1fr}}
.app-fact{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px}
.app-fact-ic{width:40px;height:40px;border-radius:10px;background:var(--paper-2);display:grid;place-items:center;color:var(--ink);font-family:var(--font-mono);font-size:16px;flex:none}
.app-fact-l{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.app-fact-v{font-family:var(--font-display);font-weight:800;font-size:16px;margin-top:2px;color:var(--ink)}
.app-rd-sec-head{font-family:var(--font-display);font-weight:900;font-size:18px;margin:26px 0 14px;color:var(--ink)}
.app-rd-side{position:sticky;top:80px}
.app-rd-cta{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px}
.app-rd-date-big{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.app-rd-date-big .d{font-family:var(--font-display);font-weight:900;font-size:44px;letter-spacing:-.04em;color:var(--ink)}
.app-rd-date-big .rest{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--muted)}
.app-rd-cta .smui-button{width:100%;margin-bottom:10px}
.app-rd-perk{font-size:13px;color:var(--muted);background:var(--volt-soft);border-radius:10px;padding:12px;margin-top:6px;line-height:1.45}
.app-rd-perk b{color:var(--ink)}

/* ---- Mobile bottom tab-bar (legacy, kept for any non-converted page) -- */
.mobile-tabbar { display: none; }
@media (max-width: 760px) {
  .mobile-tabbar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 30;
    display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
    padding: 6px 6px calc(6px + env(safe-area-inset-bottom));
    background: color-mix(in oklab, var(--paper) 96%, transparent);
    border-top: 1px solid var(--line); box-shadow: 0 -6px 20px rgba(20,22,18,.06);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  }
  .mobile-tab { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 7px 2px 5px; border-radius: var(--r-sm); color: var(--muted); text-decoration: none; font-size: .64rem; font-weight: 700; letter-spacing: .2px; line-height: 1; -webkit-tap-highlight-color: transparent; }
  .mobile-tab svg { width: 23px; height: 23px; stroke: currentColor; fill: none; stroke-width: 1.7; }
  .mobile-tab[aria-current="page"] { color: var(--ink); }
  .mobile-tab[aria-current="page"] svg { stroke: var(--volt-deep); stroke-width: 2; }
  .mobile-tab:active { transform: scale(.92); }
  body { padding-bottom: calc(58px + env(safe-area-inset-bottom)); }
}

/* ---- Toast ----------------------------------------------------------- */
.ds-toast { position: fixed; left: 50%; bottom: 84px; transform: translateX(-50%) translateY(8px); z-index: 60; max-width: min(420px, 92vw); padding: 12px 18px; border-radius: var(--r-pill); background: var(--ink); color: var(--paper); font-family: var(--font-display); font-weight: 700; font-size: .92rem; box-shadow: var(--sh-3); opacity: 0; pointer-events: none; transition: opacity var(--t), transform var(--t); }
.ds-toast.is-open { opacity: 1; transform: translateX(-50%) translateY(0); }
.ds-toast--error { background: var(--danger); }

/* ---- Utilities ------------------------------------------------------- */
.u-mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.u-display { font-family: var(--font-display); }
.u-muted { color: var(--muted); }
.u-center { text-align: center; }
.u-hide { display: none !important; }
@media (max-width: 760px) { .u-hide-mobile { display: none !important; } }
@media (min-width: 761px) { .u-only-mobile { display: none !important; } }

@media (prefers-reduced-motion: reduce) { * { animation-duration: .001ms !important; transition-duration: .001ms !important; } }
