/* ============================================================
   MAREEN BUJAK — DESIGN SYSTEM
   Tokens + component styles, ported from the Claude Design
   handoff (ui_kits/website) into static HTML/CSS.
   ============================================================ */
@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,500;1,600&family=Archivo:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* ---- Navy ---- */
  --navy-950: #131C25; --navy-900: #1B2733; --navy-800: #22303D; --navy-700: #2C3E50;
  --navy-600: #3A5066; --navy-500: #4C6580; --navy-400: #6E879F; --navy-300: #9DB1C3;
  --navy-200: #C8D4DF; --navy-100: #E5ECF1; --navy-50: #F2F5F8;

  /* ---- Copper ---- */
  --copper-950: #2E2113; --copper-900: #43301C; --copper-800: #5C4128; --copper-700: #715333;
  --copper-600: #8B6B4A; --copper-500: #A07E57; --copper-400: #BC9A74; --copper-300: #D4B997;
  --copper-200: #E6D5BE; --copper-100: #F3E9DA; --copper-50: #FAF4EC;

  /* ---- Sand ---- */
  --sand-950: #1F1B16; --sand-900: #2C2620; --sand-800: #45403A; --sand-700: #5A5249;
  --sand-600: #756B5F; --sand-500: #938878; --sand-400: #B4AA9B; --sand-300: #D2C9BC;
  --sand-200: #E7E0D6; --sand-150: #EFEAE1; --sand-100: #F4F0E9; --sand-50: #FAF8F4;
  --white: #FFFFFF;

  /* ---- Status ---- */
  --success-700: #3F6147; --success-600: #4E7A5A; --success-100: #E2EDE4;
  --warning-700: #9A742B; --warning-600: #C2943A; --warning-100: #F6EBD3;
  --danger-700: #9A4434;  --danger-600: #B85540;  --danger-100: #F4E0DA;
  --info-700: var(--navy-700); --info-600: var(--navy-500); --info-100: var(--navy-100);

  /* ---- Semantic aliases ---- */
  --surface-page: var(--sand-50);
  --surface-card: var(--white);
  --surface-subtle: var(--sand-100);
  --surface-sunken: var(--sand-150);
  --surface-inverse: var(--navy-800);
  --surface-brand: var(--navy-700);
  --surface-accent-soft: var(--copper-50);

  --text-strong: var(--navy-800);
  --text-body: var(--sand-800);
  --text-muted: var(--sand-600);
  --text-subtle: var(--sand-500);
  --text-on-brand: var(--sand-50);
  --text-on-accent: var(--white);
  --text-accent: var(--copper-600);
  --text-link: var(--copper-700);

  --border-subtle: var(--sand-200);
  --border-default: var(--sand-300);
  --border-strong: var(--sand-400);
  --border-brand: var(--navy-700);
  --border-accent: var(--copper-600);
  --divider: var(--sand-200);

  --accent: var(--copper-600);
  --accent-hover: var(--copper-700);
  --accent-active: var(--copper-800);
  --brand: var(--navy-700);
  --brand-hover: var(--navy-800);
  --brand-active: var(--navy-900);

  --focus-ring: color-mix(in oklab, var(--copper-600) 55%, transparent);

  /* ---- Typography ---- */
  --font-serif: 'Playfair Display', 'Iowan Old Style', Georgia, 'Times New Roman', serif;
  --font-sans: 'Archivo', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --font-display: var(--font-serif);
  --font-heading: var(--font-sans);
  --font-body: var(--font-sans);
  --font-eyebrow: var(--font-sans);
  --font-code: var(--font-mono);

  --text-2xs: 0.6875rem; --text-xs: 0.75rem; --text-sm: 0.875rem; --text-base: 1rem;
  --text-md: 1.125rem; --text-lg: 1.375rem; --text-xl: 1.75rem; --text-2xl: 2.25rem;
  --text-3xl: 3rem; --text-4xl: 3.875rem; --text-5xl: 5rem; --text-6xl: 6.5rem;

  --weight-light: 300; --weight-regular: 400; --weight-medium: 500;
  --weight-semibold: 600; --weight-bold: 700; --weight-black: 900;

  --leading-tight: 1.08; --leading-snug: 1.22; --leading-normal: 1.45; --leading-relaxed: 1.65;

  --tracking-tight: -0.02em; --tracking-snug: -0.01em; --tracking-normal: 0em;
  --tracking-wide: 0.08em; --tracking-eyebrow: 0.22em;

  /* ---- Spacing ---- */
  --space-0: 0; --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
  --space-5: 1.5rem; --space-6: 2rem; --space-7: 2.5rem; --space-8: 3rem; --space-9: 4rem;
  --space-10: 5rem; --space-11: 6.5rem; --space-12: 8rem;

  /* ---- Radius ---- */
  --radius-xs: 3px; --radius-sm: 6px; --radius-md: 10px; --radius-lg: 16px;
  --radius-xl: 24px; --radius-2xl: 32px; --radius-pill: 999px; --radius-card: var(--radius-lg);

  --border-width: 1px; --border-width-strong: 1.5px;

  /* ---- Elevation ---- */
  --shadow-xs: 0 1px 2px rgba(43, 33, 22, 0.05);
  --shadow-sm: 0 1px 3px rgba(43, 33, 22, 0.07), 0 1px 2px rgba(43, 33, 22, 0.04);
  --shadow-md: 0 4px 14px rgba(31, 27, 22, 0.08), 0 2px 5px rgba(31, 27, 22, 0.05);
  --shadow-lg: 0 14px 40px rgba(31, 27, 22, 0.10), 0 5px 14px rgba(31, 27, 22, 0.06);
  --shadow-xl: 0 28px 70px rgba(19, 28, 37, 0.16), 0 10px 28px rgba(19, 28, 37, 0.08);
  --shadow-accent: 0 10px 28px rgba(139, 107, 74, 0.22);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.6);

  /* ---- Motion ---- */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-soft: cubic-bezier(0.4, 0.1, 0.1, 1);
  --dur-fast: 140ms; --dur-base: 220ms; --dur-slow: 420ms;

  /* ---- Layout ---- */
  --container-sm: 640px; --container-md: 860px; --container-lg: 1120px; --container-xl: 1320px;
  --gutter: clamp(1.25rem, 5vw, 4rem);

  --z-base: 0; --z-raised: 10; --z-sticky: 100; --z-overlay: 1000; --z-modal: 1100; --z-toast: 1200;
}

/* ---- Base ---- */
*, *::before, *::after { box-sizing: border-box; }

body.ds {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--text-body);
  background: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.ds h1, .ds h2, .ds h3, .ds h4, .ds h5, .ds h6 { margin: 0; color: var(--text-strong); }
.ds p { margin: 0; }
.ds a { color: var(--text-link); text-decoration: none; }
.ds ::selection { background: var(--copper-200); color: var(--navy-900); }
.ds :focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: var(--radius-xs); }
.ds img { max-width: 100%; display: block; }

.ds-wrap { max-width: var(--container-xl); margin: 0 auto; padding: 0 var(--gutter); }

/* ============================================================
   COMPONENTS
   ============================================================ */

/* ---- Button ---- */
.btn-ds {
  display: inline-flex; align-items: center; justify-content: center; white-space: nowrap;
  font-family: var(--font-body); font-weight: var(--weight-semibold); line-height: 1.1;
  letter-spacing: 0.005em; cursor: pointer; border: 1px solid transparent;
  transition: background var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.btn-ds:active { transform: scale(0.98); }
.btn-ds--sm { padding: 8px 16px; font-size: var(--text-sm); gap: 7px; border-radius: var(--radius-sm); }
.btn-ds--md { padding: 12px 22px; font-size: var(--text-base); gap: 9px; border-radius: var(--radius-md); }
.btn-ds--lg { padding: 16px 30px; font-size: var(--text-md); gap: 11px; border-radius: var(--radius-md); }

.btn-ds--primary { background: var(--brand); color: var(--text-on-brand); border-color: var(--brand); box-shadow: var(--shadow-sm); }
.btn-ds--primary:hover { background: var(--brand-hover); border-color: var(--brand-hover); }

.btn-ds--accent { background: var(--accent); color: var(--text-on-accent); border-color: var(--accent); box-shadow: var(--shadow-accent); }
.btn-ds--accent:hover { background: var(--accent-hover); border-color: var(--accent-hover); }

.btn-ds--secondary { background: transparent; color: var(--text-strong); border: 1.5px solid var(--border-strong); }
.btn-ds--secondary:hover { background: var(--surface-subtle); border-color: var(--navy-700); }

.btn-ds--ghost { background: transparent; color: var(--text-strong); }
.btn-ds--ghost:hover { background: var(--surface-subtle); }

.btn-ds--link { background: transparent; color: var(--text-link); padding: 0; border: none; height: auto; }
.btn-ds--link:hover { text-decoration: underline; text-underline-offset: 4px; }

.btn-ds .icon { display: inline-flex; }

/* ---- Badge ---- */
.badge-ds {
  display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px;
  border-radius: var(--radius-pill); font-weight: var(--weight-semibold); font-size: var(--text-xs);
  letter-spacing: 0.01em; line-height: 1.3; white-space: nowrap; border: 1px solid transparent;
}
.badge-ds--ai { font-family: var(--font-mono); font-weight: 500; font-size: var(--text-2xs); letter-spacing: 0.06em; text-transform: uppercase; }
.badge-ds--ai.badge-ds--solid { background: var(--navy-800); color: var(--copper-200); }
.badge-ds--ai:not(.badge-ds--solid) { background: var(--copper-50); color: var(--copper-700); border-color: var(--copper-200); }

/* ---- Card ---- */
.card-ds {
  position: relative; background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-card); box-shadow: var(--shadow-md);
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.card-ds--interactive { cursor: pointer; }
.card-ds--interactive:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }

/* ---- Eyebrow ---- */
.eyebrow-ds {
  display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-eyebrow);
  font-weight: var(--weight-semibold); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase; color: var(--text-accent);
}
.eyebrow-ds--muted { color: var(--text-muted); }

/* ---- LayerMark ---- */
.layer-mark { display: inline-flex; flex-direction: column; gap: 4px; }
.layer-mark span { display: block; height: 4px; border-radius: 999px; background: var(--navy-700); }
.layer-mark span:nth-child(1) { width: 100%; }
.layer-mark span:nth-child(2) { width: 60%; background: var(--copper-600); opacity: 1; }
.layer-mark span:nth-child(3) { width: 86%; }

/* ---- StatBlock ---- */
.stat-ds { text-align: left; }
.stat-ds__value {
  font-family: var(--font-display); font-weight: var(--weight-bold); font-size: var(--text-3xl);
  line-height: 1; letter-spacing: var(--tracking-tight); color: var(--text-strong);
  display: flex; align-items: baseline; gap: 2px;
}
.stat-ds--accent .stat-ds__value { color: var(--text-accent); }
.stat-ds__suffix { font-size: var(--text-lg); font-weight: var(--weight-medium); }
.stat-ds__label {
  margin-top: var(--space-2); font-family: var(--font-eyebrow); font-weight: var(--weight-semibold);
  font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-muted);
}

/* ---- Divider ---- */
.divider-ds--v { display: inline-block; width: 1px; align-self: stretch; background: var(--divider); }

/* ---- Field / Input / Textarea ---- */
.field-ds { display: flex; flex-direction: column; gap: 7px; }
.field-ds__label { font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-sm); color: var(--text-strong); }
.field-ds__label .req { color: var(--copper-600); margin-left: 3px; }

.input-ds {
  display: flex; align-items: center; gap: 10px; background: var(--surface-card);
  border: 1.5px solid var(--border-default); border-radius: var(--radius-md); padding: 12px 14px;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.input-ds:focus-within { border-color: var(--copper-600); box-shadow: 0 0 0 3px var(--focus-ring); }
.input-ds .icon { color: var(--text-subtle); flex-shrink: 0; display: inline-flex; }
.input-ds input {
  flex: 1; min-width: 0; border: none; outline: none; background: transparent;
  font-family: var(--font-body); font-size: var(--text-base); color: var(--text-strong);
}

.textarea-ds {
  width: 100%; resize: vertical; background: var(--surface-card); border: 1.5px solid var(--border-default);
  border-radius: var(--radius-md); padding: 12px 14px; font-family: var(--font-body); font-size: var(--text-base);
  line-height: var(--leading-normal); color: var(--text-strong); outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.textarea-ds:focus { border-color: var(--copper-600); box-shadow: 0 0 0 3px var(--focus-ring); }
