/* ============================================================
   Stromvergleich Düsseldorf — Design Tokens
   Brand: "Rheinrot" — elegant, fashionable, local energy.
   Düsseldorf-Stadtrot · Bernstein/Kupfer-Akzent · Graphit-Tinte.
   Editorial serif (Fraunces) + clean sans (Instrument Sans).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;9..144,900&family=Instrument+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500;600&display=swap');

:root {
  /* ============================================================
     COLOR — Brand: Düsseldorfer Stadtrot (Rheinrot)
     ============================================================ */
  --rot-900: #5C0815;
  --rot-800: #82091F;   /* press */
  --rot-700: #A50F28;   /* hover */
  --rot-600: #C81432;   /* PRIMARY — Düsseldorf red */
  --rot-500: #E0263F;
  --rot-400: #EC5469;
  --rot-300: #F38E9B;
  --rot-200: #F8C2CA;
  --rot-100: #FBE0E4;
  --rot-050: #FDF1F3;

  /* Bernstein / Kupfer — Energie-Akzent (Senf · Altbier · Strom-Wärme) */
  --amber-700: #B97516;
  --amber-600: #D88A1E;
  --amber-500: #E8A33D;   /* ACCENT */
  --amber-400: #F2BB6A;
  --amber-300: #F8D49B;
  --amber-100: #FCEFD6;

  /* Graphit-Tinte — Dark surfaces (Kö bei Nacht) */
  --ink-900: #14111A;
  --ink-800: #1A1620;   /* dark surface */
  --ink-700: #271F30;
  --ink-600: #3A3047;

  /* Rhein — kühler Info-Akzent (sparsam) */
  --rhein-600: #2E5E8C;
  --rhein-500: #3C76AC;
  --rhein-100: #E4EDF5;

  /* ============================================================
     COLOR — Neutrals (warm taupe-gray, papierhaft)
     ============================================================ */
  --neutral-000: #FFFFFF;
  --neutral-050: #FAF6F1;   /* app background — warmes Papier */
  --neutral-100: #F2ECE4;
  --neutral-200: #E7DED3;   /* borders */
  --neutral-300: #D5C8B9;
  --neutral-400: #B3A595;
  --neutral-500: #8A7C6C;   /* text tertiary */
  --neutral-600: #6A5D4F;
  --neutral-700: #4E443A;   /* text secondary */
  --neutral-800: #322B24;
  --neutral-900: #1E1812;   /* text primary */

  /* ============================================================
     COLOR — Semantic
     ============================================================ */
  --success: #1F8A5B;
  --success-bg: #E2F3EA;
  --warning: #C98A12;
  --warning-bg: #FBF0D8;
  --danger:  #C81432;
  --danger-bg: #FBE0E4;
  --info: #2E5E8C;
  --info-bg: #E4EDF5;

  /* ============================================================
     COLOR — Roles
     ============================================================ */
  --bg:            var(--neutral-050);
  --surface:       var(--neutral-000);
  --surface-sunken:var(--neutral-100);
  --surface-dark:  var(--ink-800);
  --border:        var(--neutral-200);
  --border-strong: var(--neutral-300);

  --fg1: var(--neutral-900);
  --fg2: var(--neutral-700);
  --fg3: var(--neutral-500);
  --fg-on-dark:   #F4EDE4;
  --fg-on-dark-2: #B8AB9C;

  --primary:        var(--rot-600);
  --primary-hover:  var(--rot-700);
  --primary-press:  var(--rot-800);
  --on-primary:     #FFFFFF;
  --accent:         var(--amber-500);
  --accent-strong:  var(--amber-600);
  --on-accent:      var(--ink-900);

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

  /* ============================================================
     TYPOGRAPHY
     ============================================================ */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Instrument Sans', system-ui, -apple-system, sans-serif;
  --font-mono:    'IBM Plex Mono', ui-monospace, 'SF Mono', monospace;

  --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:  clamp(2.5rem, 1.7rem + 3.4vw, 3.75rem);
  --text-4xl:  clamp(3rem, 1.9rem + 5vw, 5rem);

  --leading-tight: 1.02;
  --leading-snug:  1.14;
  --leading-normal:1.5;
  --leading-relaxed:1.68;

  --tracking-tight: -0.02em;
  --tracking-snug:  -0.01em;
  --tracking-wide:  0.02em;
  --tracking-caps:  0.14em;

  --weight-regular: 400;
  --weight-medium:  500;
  --weight-semibold:600;
  --weight-bold:    700;
  --weight-extra:   900;

  /* ============================================================
     SPACING — 4px base
     ============================================================ */
  --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;

  /* ============================================================
     RADII — schärfer/eleganter als Hamburg (Editorial)
     ============================================================ */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;   /* buttons, inputs */
  --radius-lg: 16px;   /* cards */
  --radius-xl: 22px;   /* feature panels */
  --radius-2xl: 30px;
  --radius-pill: 999px;

  /* ============================================================
     SHADOWS — warm, ink-tinted
     ============================================================ */
  --shadow-xs: 0 1px 2px rgba(30, 24, 18, 0.06);
  --shadow-sm: 0 1px 3px rgba(30, 24, 18, 0.08), 0 1px 2px rgba(30, 24, 18, 0.05);
  --shadow-md: 0 6px 16px rgba(30, 24, 18, 0.09), 0 2px 5px rgba(30, 24, 18, 0.05);
  --shadow-lg: 0 16px 36px rgba(30, 24, 18, 0.12), 0 6px 12px rgba(30, 24, 18, 0.06);
  --shadow-xl: 0 28px 64px rgba(30, 24, 18, 0.16), 0 10px 20px rgba(30, 24, 18, 0.07);
  --shadow-amber: 0 8px 24px rgba(216, 138, 30, 0.30);
  --shadow-primary: 0 8px 22px rgba(200, 20, 50, 0.26);

  /* ============================================================
     MOTION
     ============================================================ */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 130ms;
  --dur: 200ms;
  --dur-slow: 320ms;

  --container: 1180px;
}
