/* ============================================================================
   Starttiin · Tulostaulu — Design Tokens
   V5 Jersey Stripe · Painos 001 · 2026
   
   Paste into your app's global stylesheet. All tokens are :root CSS vars.
   ============================================================================ */

:root {
  /* ---------- Surfaces ---------- */
  --tt-bg:        #efe7d6;  /* cream · hallitseva taustaväri */
  --tt-bg-warm:   #f5eee0;  /* lämmin variantti · filter bars, sidebars */
  --tt-surface:   #faf4e3;  /* korttipohja · light card background */

  /* ---------- Ink (text) ---------- */
  --tt-ink:        #1a1714;  /* rungot · primary body text */
  --tt-ink-soft:   #3d342c;  /* leipäteksti · softer body */
  --tt-ink-muted:  #6a5f50;  /* meta · captions */

  /* ---------- Burgundy (primary accent) ---------- */
  --tt-burgundy:    #6b1f1f;
  --tt-burgundy-d:  #4a1414;  /* hover / pressed */
  --tt-burgundy-l:  #8a3030;  /* tints */

  /* ---------- Mustard (CTA / highlight) ---------- */
  --tt-mustard:    #d4a537;
  --tt-mustard-d:  #b88820;  /* sportive row-color */
  --tt-mustard-l:  #e6bd5a;

  /* ---------- Secondary ---------- */
  --tt-olive:      #5d5a2b;  /* brevet · long-distance */

  /* ---------- Rules ---------- */
  --tt-rule:         #c9bfa6;
  --tt-rule-soft:    #ddd4be;
  --tt-rule-strong:  #8a8165;

  /* ---------- Discipline tags ---------- */
  --tt-disc-gravel: #6b5d2b;
  --tt-disc-road:   #6b1f1f;
  --tt-disc-mtb:    #8a4a20;
  --tt-disc-cx:     #4a2b44;
  --tt-disc-trial:  #3d5028;
  --tt-disc-brevet: #2d2c4a;

  /* ---------- Typography ---------- */
  --tt-font-display: "Oswald", Impact, "Arial Narrow", sans-serif;
  --tt-font-serif:   "Playfair Display", "Times New Roman", serif;
  --tt-font-sans:    "Inter", -apple-system, BlinkMacSystemFont, sans-serif;

  /* Type scale (px) */
  --tt-size-eyebrow:   10px;
  --tt-size-meta:      11px;
  --tt-size-caption:   13px;
  --tt-size-body:      16px;
  --tt-size-body-lg:   18px;
  --tt-size-h4:        22px;
  --tt-size-h3:        32px;
  --tt-size-h2:        56px;
  --tt-size-h1:        88px;
  --tt-size-masthead: 140px;

  /* Tracking */
  --tt-track-eyebrow: 0.3em;
  --tt-track-meta:    0.2em;
  --tt-track-caps:    0.25em;
  --tt-track-display: 0.005em;

  /* ---------- Spacing ---------- */
  --tt-space-1:  4px;
  --tt-space-2:  8px;
  --tt-space-3:  12px;
  --tt-space-4:  16px;
  --tt-space-5:  24px;
  --tt-space-6:  32px;
  --tt-space-7:  48px;
  --tt-space-8:  72px;

  /* ---------- No radius ---------- */
  /* Tulostaulu käyttää teräviä kulmia. Pyöristyksiä vältetään.  */
  --tt-radius: 0;
}

/* ============================================================================
   Font imports (Google Fonts)
   ============================================================================ */
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=Inter:wght@400;500;600&display=swap");

/* ============================================================================
   Atomic utilities — copy as needed
   ============================================================================ */

body {
  background: var(--tt-bg);
  color: var(--tt-ink);
  font-family: var(--tt-font-sans);
  font-size: var(--tt-size-body);
  line-height: 1.55;
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

/* Caps — tracked display label */
.tt-caps {
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: var(--tt-size-meta);
  letter-spacing: var(--tt-track-caps);
  text-transform: uppercase;
  color: var(--tt-burgundy);
}

/* Place name — editorial italic */
.tt-place {
  font-family: var(--tt-font-serif);
  font-style: italic;
  font-size: var(--tt-size-body);
  color: var(--tt-burgundy);
}

/* Double rule */
.tt-rule-double {
  border-top: 3px double var(--tt-ink);
  height: 0;
}
.tt-rule-double--burgundy { border-top-color: var(--tt-burgundy); }

/* Ribbon (top strip) */
.tt-ribbon {
  background: var(--tt-burgundy);
  color: var(--tt-mustard);
  padding: 9px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--tt-font-display);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  font-weight: 700;
  gap: 16px;
}

/* Race number box */
.tt-number-box {
  display: inline-block;
  background: var(--tt-surface);
  color: var(--tt-ink);
  border: 2px solid var(--tt-ink);
  padding: 6px 12px;
  font-family: var(--tt-font-display);
  font-weight: 700;
  text-align: center;
  line-height: 0.88;
}

/* Pill / filter chip */
.tt-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--tt-font-display);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 6px 12px;
  font-size: 11px;
  border: 1.5px solid var(--tt-rule-strong);
  background: transparent;
  color: var(--tt-ink);
  cursor: pointer;
  transition: all 0.1s;
}
.tt-pill:hover { border-color: var(--tt-ink); }
.tt-pill--active {
  background: var(--tt-ink);
  color: var(--tt-surface);
  border-color: var(--tt-ink);
}

/* Type badge */
.tt-type-badge {
  display: inline-block;
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 10px;
}
.tt-type-badge--race     { background: var(--tt-burgundy); color: var(--tt-surface); }
.tt-type-badge--mixed    { background: var(--tt-burgundy); color: var(--tt-mustard); }
.tt-type-badge--sportive { background: var(--tt-mustard);  color: var(--tt-ink);     }
.tt-type-badge--brevet   { background: var(--tt-olive);    color: var(--tt-surface); }
.tt-type-badge--social   { background: var(--tt-surface);  color: var(--tt-ink); border: 1.5px solid var(--tt-ink); }

/* CTA */
.tt-button {
  display: inline-block;
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 12px 22px;
  background: transparent;
  color: var(--tt-ink);
  border: 2px solid var(--tt-ink);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.1s;
}
.tt-button--primary {
  background: var(--tt-burgundy);
  color: var(--tt-surface);
  border-color: var(--tt-burgundy);
}
.tt-button--primary:hover { background: var(--tt-burgundy-d); border-color: var(--tt-burgundy-d); }
.tt-button--mustard {
  background: var(--tt-mustard);
  color: var(--tt-ink);
  border-color: var(--tt-mustard);
}

/* H tokens */
h1, .tt-h1 {
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: var(--tt-size-h1);
  line-height: 0.95;
  letter-spacing: var(--tt-track-display);
  text-transform: uppercase;
  margin: 0;
}
h2, .tt-h2 {
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: var(--tt-size-h2);
  line-height: 0.95;
  letter-spacing: var(--tt-track-display);
  text-transform: uppercase;
  margin: 0;
}
h3, .tt-h3 {
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: var(--tt-size-h3);
  line-height: 1;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin: 0;
}
h4, .tt-h4 {
  font-family: var(--tt-font-display);
  font-weight: 700;
  font-size: var(--tt-size-h4);
  line-height: 1.1;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin: 0;
}

.tt-lede {
  font-family: var(--tt-font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.55;
  color: var(--tt-burgundy);
  max-width: 720px;
}
