/* ============================================================
   CCS Design System — colors, type, semantic styles
   Single source of truth. All UI kits and previews import this.
   ============================================================ */

/* ---------- Fonts ---------- */
/* Brief specifies Degular Display (proprietary, Pangram Pangram) for hero +
   eyebrow, and Inter for everything else.
   SUBSTITUTION: Mona Sans (GitHub, OFL) used in place of Degular Display.
   Both faces load from Google Fonts. To self-host, drop .woff2 files into
   fonts/ and replace the @import with @font-face rules. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Mona+Sans:wght@400;500;600;700&display=swap');

/* ---------- Tokens ---------- */
:root {
  /* Brand & accent ---------------------------------------------- */
  --color-primary: #ff4f00;        /* CTA orange. ONE element per screen. */
  --color-primary-hover: #e84800;
  --color-on-primary: #fffefb;     /* warm white text on orange */

  /* Surface ---------------------------------------------- */
  --color-canvas: #fffefb;         /* page background — warm cream */
  --color-canvas-soft: #f8f4f0;    /* inset surface, alt band, card fill */
  --color-canvas-hover: #f1ece5;   /* hover state on cream surfaces */

  /* Ink ladder ---------------------------------------------- */
  --color-ink: #201515;            /* primary text + dark surface */
  --color-ink-soft: #2f2a26;       /* near-black, brown warmth */
  --color-ink-mid: #36342e;        /* mid-emphasis text */
  --color-body: #605d52;           /* default body text */
  --color-body-mid: #939084;       /* metadata, secondary body */
  --color-mute: #c5c0b1;           /* lowest-priority text, dividers */

  /* Semantic (dashboard only — not in core brief) -------------- */
  --color-status-good: #3f7a4d;
  --color-status-warn: #b67a1f;
  --color-status-bad: #a8341d;
  --color-status-good-soft: #e7efe4;
  --color-status-warn-soft: #f4ebd9;
  --color-status-bad-soft: #f1dfd8;

  /* Type families ---------------------------------------------- */
  --font-display: 'Mona Sans', 'Inter', system-ui, -apple-system, sans-serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: ui-monospace, 'SF Mono', Menlo, monospace;

  /* Type scale ---------------------------------------------- */
  --type-display-xl-size: 56px;   --type-display-xl-line: 56px;   --type-display-xl-weight: 500; --type-display-xl-track: 0;
  --type-display-lg-size: 48px;   --type-display-lg-line: 48px;   --type-display-lg-weight: 500; --type-display-lg-track: 0;
  --type-display-md-size: 32px;   --type-display-md-line: 36px;   --type-display-md-weight: 500; --type-display-md-track: 1px;

  --type-sub-lg-size: 48px;       --type-sub-lg-line: 49.92px;    --type-sub-lg-weight: 500;    --type-sub-lg-track: 0;
  --type-sub-md-size: 32px;       --type-sub-md-line: 40px;       --type-sub-md-weight: 400;    --type-sub-md-track: 0;
  --type-sub-sm-size: 24px;       --type-sub-sm-line: 30px;       --type-sub-sm-weight: 600;    --type-sub-sm-track: -0.6px;
  --type-display-xs-size: 20px;   --type-display-xs-line: 25px;   --type-display-xs-weight: 700; --type-display-xs-track: -0.5px;

  --type-body-lg-size: 20px;      --type-body-lg-line: 30px;      --type-body-lg-weight: 400;   --type-body-lg-track: -0.2px;
  --type-body-md-size: 18px;      --type-body-md-line: 27px;      --type-body-md-weight: 400;   --type-body-md-track: 0;
  --type-body-md-strong-weight: 600;
  --type-body-sm-size: 16px;      --type-body-sm-line: 24px;      --type-body-sm-weight: 400;   --type-body-sm-track: 0;
  --type-body-sm-strong-weight: 600;
  --type-caption-size: 14px;      --type-caption-line: 21px;      --type-caption-weight: 400;   --type-caption-track: 0;
  --type-eyebrow-size: 14px;      --type-eyebrow-line: 14px;      --type-eyebrow-weight: 500;   --type-eyebrow-track: 1px;

  --type-button-md-size: 18px;    --type-button-md-line: 27px;    --type-button-md-weight: 600;
  --type-button-sm-size: 14.4px;  --type-button-sm-line: 14.4px;  --type-button-sm-weight: 700; --type-button-sm-track: 0.144px;

  /* Spacing (4px base) ---------------------------------------- */
  --space-xxs: 2px;
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
  --space-2xl: 32px;
  --space-3xl: 48px;
  --space-4xl: 64px;

  /* Radii ---------------------------------------------- */
  --radius-none: 0;
  --radius-sm: 6px;
  --radius-md: 12px;  /* the brand's signature button + card radius */
  --radius-pill: 9999px;

  /* Elevation ---------------------------------------------- */
  --border-hairline: 1px solid var(--color-ink);
  --border-mute: 1px solid var(--color-mute);
  --shadow-floating: 0 1px 2px rgba(32, 21, 21, 0.06), 0 4px 12px rgba(32, 21, 21, 0.04);
  --shadow-modal:    0 8px 24px rgba(32, 21, 21, 0.10), 0 32px 80px rgba(32, 21, 21, 0.08);

  /* Motion ---------------------------------------------- */
  --ease-out: cubic-bezier(0.2, 0, 0, 1);
  --dur-fast: 160ms;
  --dur-med:  220ms;
}

/* ---------- Base ---------- */
html, body {
  background: var(--color-canvas);
  color: var(--color-ink);
  font-family: var(--font-sans);
  font-size: var(--type-body-md-size);
  line-height: var(--type-body-md-line);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
}

* { box-sizing: border-box; }

/* ---------- Semantic typography classes ---------- */
.t-display-xl  { font-family: var(--font-display); font-size: var(--type-display-xl-size); line-height: var(--type-display-xl-line); font-weight: var(--type-display-xl-weight); letter-spacing: var(--type-display-xl-track); color: var(--color-ink); margin: 0; }
.t-display-lg  { font-family: var(--font-display); font-size: var(--type-display-lg-size); line-height: var(--type-display-lg-line); font-weight: var(--type-display-lg-weight); letter-spacing: var(--type-display-lg-track); color: var(--color-ink); margin: 0; }
.t-display-md  { font-family: var(--font-display); font-size: var(--type-display-md-size); line-height: var(--type-display-md-line); font-weight: var(--type-display-md-weight); letter-spacing: var(--type-display-md-track); color: var(--color-ink); margin: 0; }

.t-sub-lg      { font-family: var(--font-sans); font-size: var(--type-sub-lg-size); line-height: var(--type-sub-lg-line); font-weight: var(--type-sub-lg-weight); color: var(--color-ink); margin: 0; }
.t-sub-md      { font-family: var(--font-sans); font-size: var(--type-sub-md-size); line-height: var(--type-sub-md-line); font-weight: var(--type-sub-md-weight); color: var(--color-ink); margin: 0; }
.t-sub-sm      { font-family: var(--font-sans); font-size: var(--type-sub-sm-size); line-height: var(--type-sub-sm-line); font-weight: var(--type-sub-sm-weight); letter-spacing: var(--type-sub-sm-track); color: var(--color-ink); margin: 0; }
.t-display-xs  { font-family: var(--font-sans); font-size: var(--type-display-xs-size); line-height: var(--type-display-xs-line); font-weight: var(--type-display-xs-weight); letter-spacing: var(--type-display-xs-track); color: var(--color-ink); margin: 0; }

.t-body-lg          { font-family: var(--font-sans); font-size: var(--type-body-lg-size); line-height: var(--type-body-lg-line); font-weight: var(--type-body-lg-weight); letter-spacing: var(--type-body-lg-track); color: var(--color-body); margin: 0; }
.t-body-md          { font-family: var(--font-sans); font-size: var(--type-body-md-size); line-height: var(--type-body-md-line); font-weight: var(--type-body-md-weight); color: var(--color-body); margin: 0; }
.t-body-md-strong   { font-family: var(--font-sans); font-size: var(--type-body-md-size); line-height: var(--type-body-md-line); font-weight: var(--type-body-md-strong-weight); color: var(--color-ink); margin: 0; }
.t-body-sm          { font-family: var(--font-sans); font-size: var(--type-body-sm-size); line-height: var(--type-body-sm-line); font-weight: var(--type-body-sm-weight); color: var(--color-body); margin: 0; }
.t-body-sm-strong   { font-family: var(--font-sans); font-size: var(--type-body-sm-size); line-height: var(--type-body-sm-line); font-weight: var(--type-body-sm-strong-weight); color: var(--color-ink); margin: 0; }
.t-caption          { font-family: var(--font-sans); font-size: var(--type-caption-size); line-height: var(--type-caption-line); font-weight: var(--type-caption-weight); color: var(--color-body-mid); margin: 0; }
.t-eyebrow          { font-family: var(--font-display); font-size: var(--type-eyebrow-size); line-height: var(--type-eyebrow-line); font-weight: var(--type-eyebrow-weight); letter-spacing: var(--type-eyebrow-track); color: var(--color-ink); text-transform: uppercase; margin: 0 0 20px; }

/* HTML element defaults — keep semantic markup looking right by default */
h1 { font-family: var(--font-display); font-size: var(--type-display-xl-size); line-height: var(--type-display-xl-line); font-weight: 500; color: var(--color-ink); margin: 0; }
h2 { font-family: var(--font-display); font-size: var(--type-display-lg-size); line-height: var(--type-display-lg-line); font-weight: 500; color: var(--color-ink); margin: 0; }
h3 { font-family: var(--font-display); font-size: var(--type-display-md-size); line-height: var(--type-display-md-line); font-weight: 500; letter-spacing: 1px; color: var(--color-ink); margin: 0; }
h4 { font-family: var(--font-sans); font-size: var(--type-sub-sm-size); line-height: var(--type-sub-sm-line); font-weight: 600; letter-spacing: -0.6px; color: var(--color-ink); margin: 0; }
h5 { font-family: var(--font-sans); font-size: var(--type-display-xs-size); line-height: var(--type-display-xs-line); font-weight: 700; letter-spacing: -0.5px; color: var(--color-ink); margin: 0; }
p  { font-family: var(--font-sans); font-size: var(--type-body-md-size); line-height: var(--type-body-md-line); color: var(--color-body); margin: 0; }
small { font-size: var(--type-caption-size); line-height: var(--type-caption-line); color: var(--color-body-mid); }
a  { color: var(--color-ink); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--color-primary); }

/* ---------- Component primitives (used across kits) ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-sm);
  border: 0; cursor: pointer;
  font-family: var(--font-sans); font-size: var(--type-button-md-size); line-height: var(--type-button-md-line); font-weight: var(--type-button-md-weight);
  padding: var(--space-md) var(--space-xl);
  border-radius: var(--radius-md);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), filter var(--dur-fast) var(--ease-out);
  text-decoration: none;
}
.btn:active { transform: translateY(1px); }

.btn-primary   { background: var(--color-primary); color: var(--color-on-primary); }
.btn-primary:hover { background: var(--color-primary-hover); }

.btn-secondary { background: var(--color-ink); color: var(--color-on-primary); }
.btn-secondary:hover { filter: brightness(1.10); }

.btn-tertiary  { background: var(--color-canvas); color: var(--color-ink); box-shadow: inset 0 0 0 1px var(--color-ink); }
.btn-tertiary:hover { background: var(--color-canvas-hover); }

.btn-text {
  background: transparent; color: var(--color-ink);
  font-size: var(--type-button-sm-size); line-height: var(--type-button-sm-line); font-weight: var(--type-button-sm-weight); letter-spacing: var(--type-button-sm-track);
  padding: var(--space-sm) var(--space-lg);
}
.btn-text:hover { color: var(--color-primary); }

.input {
  display: block; width: 100%;
  background: var(--color-canvas); color: var(--color-ink);
  border: 1px solid var(--color-ink);
  font-family: var(--font-sans); font-size: var(--type-body-md-size); line-height: var(--type-body-md-line);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.input::placeholder { color: var(--color-body-mid); }
.input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(255,79,0,0.18); }

.card        { background: var(--color-canvas-soft); color: var(--color-ink); padding: var(--space-xl); border-radius: var(--radius-md); }
.card-dark   { background: var(--color-ink); color: var(--color-on-primary); padding: var(--space-xl); border-radius: var(--radius-md); }
.card-bordered { background: var(--color-canvas); color: var(--color-ink); padding: var(--space-xl); border-radius: var(--radius-md); box-shadow: inset 0 0 0 1px var(--color-ink); }

.pill {
  display: inline-flex; align-items: center; gap: var(--space-xs);
  background: var(--color-canvas-soft); color: var(--color-ink);
  font-size: var(--type-body-sm-size); line-height: var(--type-body-sm-line);
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-pill);
}
.pill-orange { background: var(--color-primary); color: var(--color-on-primary); }
.pill-dark   { background: var(--color-ink); color: var(--color-on-primary); }
