/* =========================================================================
   Tian2 Design System — Colors & Type
   New Yorker editorial × warm cream palette × retro flat vector
   ========================================================================= */

/* ---------- Webfonts (Google Fonts) ----------
   Fonts are linked from Google Fonts. To self-host, drop files into /fonts
   and replace the @import below with @font-face declarations. */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,700&family=Inter:wght@400;500;600;700&family=Bebas+Neue&family=Noto+Serif+SC:wght@400;500;700;900&family=Noto+Sans+SC:wght@400;500;700&display=swap');

:root {
  /* ---------- COLORS ---------- */
  /* Brand palette — flat fills, no gradients */
  --cream:    #F5EDDC;   /* paper / primary background */
  --cream-2:  #EFE4CD;   /* slightly deeper cream, for subtle layering */
  --ink:      #2C2416;   /* type & all linework */
  --ink-2:    #4A3E2A;   /* secondary type */
  --ink-3:    #7A6B53;   /* tertiary / muted type */
  --coral:    #E8614C;   /* primary emphasis, callouts */
  --mint:     #8FB89A;   /* knowledge / definition blocks */
  --mustard:  #D9A441;   /* steps / instruction blocks */
  --stone:    #6B8CAE;   /* tags / secondary support */
  --burnt:    #C4663B;   /* secondary emphasis */

  /* Semantic foreground / background */
  --fg-1: var(--ink);          /* primary text */
  --fg-2: var(--ink-2);         /* secondary text */
  --fg-3: var(--ink-3);         /* tertiary / captions */
  --fg-inverse: var(--cream);   /* text on dark */
  --bg-1: var(--cream);         /* primary background (the page) */
  --bg-2: var(--cream-2);       /* secondary surface */
  --bg-inverse: var(--ink);     /* dark surface (chapter openers, quotes) */

  /* Semantic accents */
  --accent-emphasis: var(--coral);
  --accent-knowledge: var(--mint);
  --accent-step: var(--mustard);
  --accent-tag: var(--stone);
  --accent-2: var(--burnt);

  /* ---------- LINE / STROKE ---------- */
  --stroke: 2.5px;
  --stroke-color: var(--ink);
  --stroke-hairline: 1px;

  /* ---------- RADIUS (kept tiny — we are print, not app) ---------- */
  --radius-0: 0;
  --radius-1: 2px;
  --radius-2: 4px;

  /* ---------- SPACING (8px base for UI; print uses pt) ---------- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* ---------- TYPE FAMILIES ---------- */
  --font-display-en: 'Playfair Display', 'Noto Serif SC', Georgia, serif;
  --font-display-zh: 'Noto Serif SC', 'Playfair Display', serif;
  --font-body-en: 'Inter', 'Noto Sans SC', -apple-system, system-ui, sans-serif;
  --font-body-zh: 'Noto Sans SC', 'Inter', sans-serif;
  --font-serif-zh: 'Noto Serif SC', serif;
  --font-label: 'Bebas Neue', 'Inter', sans-serif;

  /* ---------- TYPE SCALE (web defaults; slides override) ---------- */
  --fs-display-1: 96px;   /* hero / chapter opener */
  --fs-display-2: 72px;
  --fs-h1: 56px;
  --fs-h2: 40px;
  --fs-h3: 28px;
  --fs-h4: 22px;
  --fs-body: 18px;
  --fs-small: 15px;
  --fs-caption: 13px;
  --fs-label: 14px;       /* Bebas labels — letter-spacing carries it */

  /* ---------- LINE HEIGHT ---------- */
  --lh-tight: 1.05;
  --lh-display: 1.15;
  --lh-heading: 1.25;
  --lh-body: 1.6;
  --lh-loose: 1.75;

  /* ---------- LETTER SPACING ---------- */
  --ls-display: -0.01em;
  --ls-tight: -0.02em;
  --ls-body: 0;
  --ls-label: 0.12em;     /* Bebas all-caps */
  --ls-small-caps: 0.06em;

  /* ---------- MOTION ---------- */
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --dur-fast: 160ms;
  --dur: 240ms;
  --dur-slow: 320ms;
}

/* =========================================================================
   SEMANTIC ELEMENT STYLES
   ========================================================================= */

html, body {
  background: var(--bg-1);
  color: var(--fg-1);
  font-family: var(--font-body-en);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "onum" 1, "kern" 1, "liga" 1;
}

h1, .h1 {
  font-family: var(--font-display-en);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  color: var(--fg-1);
  margin: 0 0 var(--space-5);
}

h2, .h2 {
  font-family: var(--font-display-en);
  font-weight: 700;
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-display);
  color: var(--fg-1);
  margin: 0 0 var(--space-4);
}

h3, .h3 {
  font-family: var(--font-display-en);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: var(--lh-heading);
  color: var(--fg-1);
  margin: 0 0 var(--space-3);
}

h4, .h4 {
  font-family: var(--font-body-en);
  font-weight: 600;
  font-size: var(--fs-h4);
  line-height: var(--lh-heading);
  color: var(--fg-1);
  margin: 0 0 var(--space-3);
}

p {
  font-family: var(--font-body-en);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--fg-1);
  margin: 0 0 1em;
  text-wrap: pretty;
}

.display-1 {
  font-family: var(--font-display-en);
  font-weight: 900;
  font-size: var(--fs-display-1);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
}

.display-2 {
  font-family: var(--font-display-en);
  font-weight: 800;
  font-size: var(--fs-display-2);
  line-height: var(--lh-display);
}

/* Editorial label — Bebas, all caps, wide tracking */
.label, .eyebrow {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--fg-1);
  line-height: 1;
}

/* Italic editorial pull-quote */
.pull-quote {
  font-family: var(--font-display-en);
  font-style: italic;
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  color: var(--fg-1);
}

/* Drop cap — for body intros */
.drop-cap::first-letter {
  font-family: var(--font-display-en);
  font-weight: 900;
  font-size: 4.6em;
  line-height: 0.85;
  float: left;
  margin: 0.05em 0.08em -0.1em 0;
  color: var(--fg-1);
}

/* Small caps for editorial section starts */
.small-caps {
  font-variant: small-caps;
  letter-spacing: var(--ls-small-caps);
}

/* Chinese type helpers */
.zh-display { font-family: var(--font-display-zh); }
.zh-serif { font-family: var(--font-serif-zh); }
.zh-sans { font-family: var(--font-body-zh); }

/* Code / monospace (rare — but spec'd for completeness) */
code, pre, .mono {
  font-family: 'IBM Plex Mono', ui-monospace, 'Courier New', monospace;
  font-size: 0.95em;
  background: var(--cream-2);
  padding: 0.1em 0.3em;
  border: var(--stroke-hairline) solid var(--ink);
  border-radius: var(--radius-1);
}

/* Hairline rule */
hr {
  border: 0;
  border-top: var(--stroke-hairline) solid var(--ink);
  margin: var(--space-6) 0;
}

hr.thick {
  border-top-width: var(--stroke);
}

/* Editorial ornament divider */
.ornament {
  text-align: center;
  font-family: var(--font-display-en);
  font-size: 1.5em;
  color: var(--ink);
  margin: var(--space-7) 0;
  letter-spacing: 0.5em;
}
.ornament::before { content: "⁂"; }

/* Links */
a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  transition: color var(--dur) var(--ease-standard);
}
a:hover { color: var(--coral); }

/* =========================================================================
   COMPONENT PRIMITIVES — frames, callouts, chips
   ========================================================================= */

.frame {
  border: var(--stroke) solid var(--ink);
  border-radius: var(--radius-0);
  padding: var(--space-5);
  background: var(--bg-1);
}

.callout {
  border: var(--stroke) solid var(--ink);
  padding: var(--space-5) var(--space-6);
  position: relative;
}
.callout--knowledge { background: var(--mint); }
.callout--step { background: var(--mustard); }
.callout--emphasis { background: var(--coral); color: var(--cream); }
.callout--quote { background: var(--ink); color: var(--cream); }

.chip {
  display: inline-block;
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  padding: 4px 10px;
  border: var(--stroke) solid var(--ink);
  background: var(--cream);
  border-radius: var(--radius-2);
  line-height: 1.2;
}
.chip--coral { background: var(--coral); color: var(--cream); }
.chip--mint { background: var(--mint); }
.chip--mustard { background: var(--mustard); }
.chip--stone { background: var(--stone); color: var(--cream); }

.btn {
  font-family: var(--font-body-en);
  font-weight: 600;
  font-size: var(--fs-body);
  padding: 12px 22px;
  border: var(--stroke) solid var(--ink);
  background: var(--cream);
  color: var(--ink);
  border-radius: var(--radius-0);
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-standard),
              background var(--dur) var(--ease-standard);
}
.btn:hover { background: var(--cream-2); }
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--ink); color: var(--cream); }
.btn--primary:hover { background: var(--ink-2); }
.btn--coral { background: var(--coral); color: var(--cream); }
.btn--coral:hover { background: #D85540; }
