/* ============================================================
   Saffron Design System — colors & type
   Import this file into any HTML artifact. Body text is 18px.
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600;6..72,700&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=JetBrains+Mono:wght@400;500;600&display=swap");

:root {
  /* ----- Brand colors ----- */
  --saffron-300: #FFE88A;
  --saffron-400: #FFDD63;
  --saffron-500: #FFD23F;   /* PRIMARY */
  --saffron-600: #F5C518;
  --saffron-700: #D9A800;

  /* ----- Ink (text & dark surfaces) ----- */
  --ink-900: #1B2235;
  --ink-800: #232B40;
  --ink-700: #3A4358;
  --ink-500: #6B7387;
  --ink-300: #B7BCC9;
  --ink-100: #E4E6EC;

  /* ----- Cream (default surface) ----- */
  --cream-50:  #FAF6EC;
  --cream-100: #F3EEDD;
  --cream-200: #EAE3CB;

  /* ----- Mint (secondary accent) ----- */
  --mint-100: #EAF3EA;
  --mint-200: #DDEDDE;
  --mint-400: #9FC6A4;
  --mint-600: #5A9466;

  /* ----- Dark surface (testimonial / footer) ----- */
  --charcoal-800: #22303C;
  --charcoal-900: #16222C;

  /* ----- Semantic ----- */
  --success: #2F8F4E;
  --warning: #E89C2A;
  --error:   #C8413E;

  --white: #FFFFFF;

  /* ----- Semantic aliases (use these in product code) ----- */
  --bg:        var(--cream-50);
  --bg-card:   var(--cream-100);
  --bg-alt:    var(--mint-200);
  --bg-dark:   var(--charcoal-800);

  --fg:        var(--ink-900);
  --fg-muted:  var(--ink-700);
  --fg-quiet:  var(--ink-500);
  --fg-on-dark: var(--cream-50);
  --fg-on-yellow: var(--ink-900);

  --accent:    var(--saffron-500);
  --accent-hover: var(--saffron-600);

  --border: rgba(27, 34, 53, 0.08);
  --border-strong: rgba(27, 34, 53, 0.16);
  --border-on-dark: rgba(255, 255, 255, 0.10);

  /* ----- Type tokens ----- */
  --font-display: "Newsreader", "Cormorant Garamond", Georgia, serif;
  --font-sans: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* ----- Type scale (px values for clarity) ----- */
  --fs-eyebrow: 13px;
  --fs-caption: 14px;
  --fs-body-sm: 16px;
  --fs-body:    18px;   /* PRIMARY BODY SIZE */
  --fs-lead:    22px;
  --fs-h4:      24px;
  --fs-h3:      32px;
  --fs-h2:      44px;
  --fs-h1:      64px;
  --fs-display: 88px;

  /* ----- Line heights ----- */
  --lh-tight: 1.05;
  --lh-snug: 1.2;
  --lh-normal: 1.55;
  --lh-loose: 1.7;

  /* ----- Tracking ----- */
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.08em;
  --tracking-eyebrow: 0.12em;

  /* ----- Spacing (4px base) ----- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 32px;
  --space-8: 40px;
  --space-9: 48px;
  --space-10: 64px;
  --space-11: 80px;
  --space-12: 96px;
  --space-13: 128px;

  /* ----- Radii ----- */
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-pill: 999px;

  /* ----- Shadows ----- */
  --shadow-sm: 0 1px 2px rgba(27,34,53,0.06), 0 1px 1px rgba(27,34,53,0.04);
  --shadow-md: 0 6px 16px rgba(27,34,53,0.08), 0 2px 4px rgba(27,34,53,0.05);
  --shadow-lg: 0 20px 40px rgba(27,34,53,0.12);
  --shadow-yellow: 0 10px 28px rgba(255, 210, 63, 0.45);

  /* ----- Motion ----- */
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-micro: 150ms;
  --dur-base: 220ms;
  --dur-page: 360ms;
}

/* ============================================================
   Base & semantic element styles
   ============================================================ */

html, body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, .display {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: var(--fg);
  margin: 0 0 var(--space-4);
  text-wrap: balance;
}

h1, .h1 { font-size: var(--fs-h1); }
h2, .h2 { font-size: var(--fs-h2); }
h3, .h3 { font-size: var(--fs-h3); line-height: var(--lh-snug); }
h4, .h4 { font-size: var(--fs-h4); line-height: var(--lh-snug); font-weight: 600; }

.display { font-size: var(--fs-display); }

p, .body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--fg);
  text-wrap: pretty;
  margin: 0 0 var(--space-4);
}

.body-sm { font-size: var(--fs-body-sm); }
.lead { font-size: var(--fs-lead); line-height: 1.45; color: var(--fg-muted); }
.caption { font-size: var(--fs-caption); color: var(--fg-quiet); }

.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-eyebrow);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--fg-muted);
}

code, pre, .mono {
  font-family: var(--font-mono);
  font-size: 0.92em;
}

/* ============================================================
   Common primitive classes
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 17px;
  line-height: 1;
  padding: 14px 22px;
  border-radius: var(--radius-md);
  border: 0;
  cursor: pointer;
  transition: background var(--dur-micro) var(--ease), transform 80ms var(--ease), color var(--dur-micro) var(--ease);
  text-decoration: none;
}
.btn:active { transform: scale(0.98); }
.btn:focus-visible { outline: 3px solid rgba(255, 210, 63, 0.55); outline-offset: 2px; }

.btn-yellow {
  background: var(--saffron-500);
  color: var(--ink-900);
}
.btn-yellow:hover { background: var(--saffron-600); }

.btn-ink {
  background: var(--ink-900);
  color: var(--cream-50);
}
.btn-ink:hover { background: var(--ink-700); }

.btn-ghost {
  background: transparent;
  color: var(--ink-900);
  border: 1px solid var(--border-strong);
}
.btn-ghost:hover { background: rgba(27, 34, 53, 0.04); }

.btn-pill { border-radius: var(--radius-pill); padding: 14px 26px; }

.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 12px;
  background: var(--cream-100);
  border-radius: var(--radius-pill);
  font-size: 14px;
  font-weight: 500;
  color: var(--fg-muted);
}

.card {
  background: var(--cream-100);
  border-radius: var(--radius-xl);
  padding: var(--space-7);
  box-shadow: var(--shadow-sm);
}

.card-mint { background: var(--mint-200); }
.card-yellow { background: var(--saffron-500); color: var(--ink-900); }
.card-dark { background: var(--charcoal-800); color: var(--cream-50); }
