/* Mamenza Design Tokens
   Shared across all templates. Do not hardcode colors/spacing in components. */

:root {
  /* —— Color —— */
  --ink: #1F1F1F;
  --ink-soft: #3C3A36;
  --ink-muted: #4B4742;

  --warm-orange: #F97316;
  --warm-orange-hover: #E86610;
  --warm-orange-soft: #FFEEDD;

  --terracotta: #E76F51;
  --terracotta-light: #E8A48A;
  --terracotta-soft: #FBE3D5;

  --sage: #A7BCA1;
  --sage-light: #C9D5C3;
  --sage-soft: #DFE6D7;

  --peach: #F5D4BD;
  --peach-soft: #FAF2E6;

  --cream: #FDFBF9;
  --cream-warm: #FFF6EE;

  --stone: #6B7280;
  --stone-light: #9CA3AF;
  --border-soft: rgba(31,31,31,0.06);
  --border: rgba(31,31,31,0.12);

  --off-white: #FFFFFF;
  --bg: #FFFFFF;

  /* Semantic */
  --color-affiliate: #8B5E3C; /* Affiliate-label (onderscheidend van eigen product) */
  --color-medical: #4A6B7C;   /* YMYL / Hebamme reviewer */
  --color-success: #5A7C5A;
  --color-warning: #B6513B;

  /* —— Spacing —— */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 60px; --sp-9: 96px;

  /* —— Radii —— */
  --r-sm: 4px; --r-md: 8px; --r-lg: 12px; --r-xl: 16px; --r-2xl: 24px; --r-pill: 999px;

  /* —— Shadows —— */
  --shadow-sm: 0 1px 2px rgba(31,31,31,0.04), 0 1px 1px rgba(31,31,31,0.03);
  --shadow-md: 0 4px 12px rgba(31,31,31,0.06), 0 2px 4px rgba(31,31,31,0.04);
  --shadow-lg: 0 12px 32px rgba(31,31,31,0.08), 0 4px 10px rgba(31,31,31,0.04);

  /* —— Type —— */
  --font-body: 'Inter', system-ui, sans-serif;
  --font-display: 'Satoshi', 'Inter', sans-serif;
  --font-script: 'Caveat Brush', 'Caveat', cursive;

  /* —— Layout —— */
  --container-max: 1240px;
  --container-pad: 28px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--ink);
}

h1 { font-size: 64px; line-height: 1.05; letter-spacing: -0.035em; }
h2 { font-size: 36px; letter-spacing: -0.025em; }
h3 { font-size: 22px; letter-spacing: -0.02em; }
h4 { font-size: 18px; letter-spacing: -0.01em; }

.script { font-family: var(--font-script); font-weight: 400; }
.eyebrow {
  font-family: var(--font-display);
  font-size: 12px; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--terracotta);
}
a { color: inherit; text-decoration: none; }

.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-pad); }
.container-narrow { max-width: 760px; margin: 0 auto; padding: 0 var(--container-pad); }

.section { padding: 56px 0; }
.section-sm { padding: 36px 0; }
.section-lg { padding: 80px 0; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 18px; border-radius: 10px;
  font-family: var(--font-display);
  font-size: 14px; font-weight: 600; cursor: pointer;
  border: 1px solid transparent;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space: nowrap;
}
.btn-primary {
  background: var(--warm-orange); color: white; border-color: var(--warm-orange);
  box-shadow: 0 4px 10px rgba(249,115,22,0.22);
}
.btn-primary:hover { background: var(--warm-orange-hover); border-color: var(--warm-orange-hover); transform: translateY(-1px); box-shadow: 0 6px 14px rgba(249,115,22,0.28); }
.btn-secondary {
  background: white; color: var(--ink); border-color: var(--border);
}
.btn-secondary:hover { border-color: var(--ink); background: var(--cream); }
.btn-ghost {
  background: transparent; color: var(--terracotta); padding: 6px 0; font-weight: 600; border: none;
}
.btn-ghost:hover { gap: 14px; }
.btn-sm { padding: 8px 14px; font-size: 13px; border-radius: 8px; }
