/* =========================================
   ARNOLDIO — TOKENS (Light/Dark)
   Theme controlled by: html[data-theme="light|dark"]
========================================= */

/* System default when JS is disabled or before it runs */
html:not([data-theme]) { color-scheme: light dark; }

/* If the system prefers LIGHT and there's no explicit data-theme yet */
@media (prefers-color-scheme: light) {
  html:not([data-theme]) { color-scheme: light; }
  html:not([data-theme]) {
    /* map LIGHT tokens as default when no data-theme */
    --bg-dark: oklch(0.92 0.01 235);
    --bg: oklch(0.96 0.01 235);
    --bg-light: oklch(1.00 0.01 235);

    --surface-1: oklch(1.00 0.01 235);
    --surface-2: oklch(0.98 0.01 235);
    --overlay: oklch(0.96 0.01 235 / .72);

    --text: oklch(0.15 0.02 235);
    --text-muted: oklch(0.40 0.02 235);

    --highlight: oklch(0.98 0.01 235);
    --border: oklch(0.60 0.02 235);
    --border-muted: oklch(0.70 0.02 235);

    --primary: oklch(0.55 0.11 235);
    --primary-ink: oklch(0.40 0.10 235);
    --secondary: oklch(0.40 0.10 55);

    --danger: oklch(0.50 0.05 30);
    --warning: oklch(0.50 0.05 100);
    --success: oklch(0.50 0.05 160);
    --info: oklch(0.50 0.05 260);

    --shadow: 0 18px 60px rgba(15,23,42,.12);
    --shadow-sm: 0 8px 24px rgba(15,23,42,.10);
  }
}

/* ---------- DARK (default) ---------- */
:root{
  /* Accessibility / Design-system controls */
  --az-font-scale: 1;
  --az-font-scale-min: 0.9;
  --az-font-scale-max: 1.8;
  --az-font-scale-safe: clamp(var(--az-font-scale-min), var(--az-font-scale), var(--az-font-scale-max));
  --az-line-height: calc(1.55 + ((var(--az-font-scale-safe) - 1) * 0.18));
  --az-contrast: 0;
  --az-grayscale: 0;
  --az-motion: 1;
  --az-links-underline: 0;
  --az-link-decoration-line: none;
  --az-fg: var(--text);
  --az-brand: var(--primary);
  --az-surface: color-mix(in oklab, var(--surface-1) 96%, #ffffff 4%);
  --az-surface-2: color-mix(in oklab, var(--surface-1) 92%, var(--bg) 8%);
  --az-bg: color-mix(in oklab, var(--bg) 94%, var(--surface-1) 6%);
  --az-border: color-mix(in oklab, var(--az-fg) 10%, transparent);
  --az-border-2: color-mix(in oklab, var(--az-fg) 14%, transparent);
  --az-shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);
  --az-shadow-md: 0 14px 40px rgba(15, 23, 42, .10);
  --az-title-brand: #7dc9ff;
  --az-btn-grad-1: #2478ff;
  --az-btn-grad-2: #45c0ff;
  --az-btn-shadow: 0 12px 26px rgba(36, 120, 255, .28);
  --az-btn-shadow-hover: 0 18px 36px rgba(69, 192, 255, .32);

  /* hsl fallback */
  --bg-dark: hsl(207 53% 1%);
  --bg: hsl(203 34% 4%);
  --bg-light: hsl(203 19% 9%);

  --surface-1: hsl(203 19% 9%);
  --surface-2: hsl(203 18% 12%);
  --overlay: hsl(203 34% 4% / .72);

  --text: hsl(203 90% 95%);
  --text-muted: hsl(203 15% 69%);

  --highlight: hsl(203 18% 12%);      /* subtle hover surface */
  --border: hsl(203 14% 28%);
  --border-muted: hsl(203 20% 18%);

  --primary: hsl(202 72% 67%);
  --primary-ink: hsl(202 72% 67%);
  --secondary: hsl(24 66% 67%);

  --danger: hsl(9 26% 64%);
  --warning: hsl(52 19% 57%);
  --success: hsl(146 17% 59%);
  --info: hsl(217 28% 65%);

  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --shadow-sm: 0 8px 24px rgba(0,0,0,.35);

  --admin-bar-h: 40px;
  --radius: 18px;
  --radius-sm: 14px;
  --container: 1160px;
  --pad: 24px;
  --navm-panel-top: 66px;

  /* oklch (preferred) */
  --bg-dark: oklch(0.10 0.01 235);
  --bg: oklch(0.15 0.01 235);
  --bg-light: oklch(0.20 0.01 235);

  --surface-1: oklch(0.20 0.01 235);
  --surface-2: oklch(0.24 0.01 235);
  --overlay: oklch(0.15 0.01 235 / .72);

  --text: oklch(0.96 0.02 235);
  --text-muted: oklch(0.76 0.02 235);

  --highlight: oklch(0.22 0.01 235);
  --border: oklch(0.40 0.02 235);
  --border-muted: oklch(0.30 0.02 235);

  --primary: oklch(0.76 0.10 235);
  --primary-ink: oklch(0.76 0.10 235);
  --on-primary: #041019;
  --secondary: oklch(0.76 0.10 55);

  --danger: oklch(0.70 0.05 30);
  --warning: oklch(0.70 0.05 100);
  --success: oklch(0.70 0.05 160);
  --info: oklch(0.70 0.05 260);

  /* Typography scale (mobile-first clamp, wrapper-relative) */
  --fs-1: clamp(0.75em, 1.2vw, 0.875em);
  --fs-2: clamp(0.875em, 1.35vw, 1em);
  --fs-3: clamp(1em, 1.7vw, 1.25em);
  --fs-4: clamp(1.375em, 2.6vw, 2.125em);

  /* Typography */
  --font-sans: "Manrope", "Avenir Next", "Segoe UI", sans-serif;
  --font-display: "Montserrat", "Manrope", "Segoe UI", sans-serif;
  --font-brand: "Montserrat", "Manrope", "Segoe UI", sans-serif;

  /* Focus ring */
  --focus: var(--primary);
}

:root { color-scheme: dark; }
html[data-theme="light"] { color-scheme: light; }
html[data-theme="dark"] { color-scheme: dark; }


/* ---------- LIGHT ---------- */
html[data-theme="light"]{
  /* hsl fallback */
  --bg-dark: hsl(203 22% 90%);
  --bg: hsl(203 45% 95%);
  --bg-light: hsl(203 100% 100%);

  --surface-1: hsl(203 100% 100%);
  --surface-2: hsl(203 45% 98%);
  --overlay: hsl(203 45% 95% / .72);

  --text: hsl(204 66% 4%);
  --text-muted: hsl(203 14% 28%);

  --highlight: hsl(203 45% 98%);
  --border: hsl(203 8% 50%);
  --border-muted: hsl(203 11% 62%);

  /* primary split: bg for buttons vs ink for links */
  --primary: hsl(202 90% 40%);       /* button bg */
  --primary-ink: hsl(196 100% 18%);  /* text/link */
  --secondary: hsl(29 100% 22%);

  --danger: hsl(9 21% 41%);
  --warning: hsl(52 23% 34%);
  --success: hsl(147 19% 36%);
  --info: hsl(217 22% 41%);

  --shadow: 0 18px 60px rgba(15,23,42,.12);
  --shadow-sm: 0 8px 24px rgba(15,23,42,.10);
  --az-fg: var(--text);
  --az-brand: var(--primary);
  --az-surface: #ffffff;
  --az-surface-2: color-mix(in oklab, #ffffff 92%, #0f172a 8%);
  --az-bg: color-mix(in oklab, #ffffff 94%, #0f172a 6%);
  --az-border: color-mix(in oklab, var(--az-fg) 10%, transparent);
  --az-border-2: color-mix(in oklab, var(--az-fg) 14%, transparent);
  --az-shadow-sm: 0 6px 18px rgba(15, 23, 42, .06);
  --az-shadow-md: 0 14px 40px rgba(15, 23, 42, .10);
  --az-title-brand: #0f6cab;
  --az-btn-grad-1: #1e63ff;
  --az-btn-grad-2: #3b82f6;
  --az-btn-shadow: 0 10px 24px rgba(30, 99, 255, .22);
  --az-btn-shadow-hover: 0 16px 34px rgba(30, 99, 255, .28);

  /* oklch */
  --bg-dark: oklch(0.92 0.01 235);
  --bg: oklch(0.96 0.01 235);
  --bg-light: oklch(1.00 0.01 235);

  --surface-1: oklch(1.00 0.01 235);
  --surface-2: oklch(0.98 0.01 235);
  --overlay: oklch(0.96 0.01 235 / .72);

  --text: oklch(0.15 0.02 235);
  --text-muted: oklch(0.40 0.02 235);

  --highlight: oklch(0.98 0.01 235);
  --border: oklch(0.60 0.02 235);
  --border-muted: oklch(0.70 0.02 235);

  --primary: oklch(0.55 0.11 235);      /* button bg */
  --primary-ink: oklch(0.40 0.10 235);  /* link text */
  --on-primary: #ffffff;
  --secondary: oklch(0.40 0.10 55);

  --danger: oklch(0.50 0.05 30);
  --warning: oklch(0.50 0.05 100);
  --success: oklch(0.50 0.05 160);
  --info: oklch(0.50 0.05 260);
}

html[data-theme="dark"]{
  --az-fg: var(--text);
  --az-brand: var(--primary);
  --az-surface: color-mix(in oklab, var(--surface-1) 94%, #ffffff 6%);
  --az-surface-2: color-mix(in oklab, var(--surface-2) 92%, #ffffff 8%);
  --az-bg: color-mix(in oklab, var(--bg) 95%, #ffffff 5%);
  --az-border: color-mix(in oklab, var(--az-fg) 10%, transparent);
  --az-border-2: color-mix(in oklab, var(--az-fg) 14%, transparent);
  --az-shadow-sm: 0 10px 24px rgba(0, 0, 0, .32);
  --az-shadow-md: 0 20px 54px rgba(0, 0, 0, .45);
  --az-title-brand: #7dc9ff;
  --az-btn-grad-1: #2478ff;
  --az-btn-grad-2: #45c0ff;
  --az-btn-shadow: 0 12px 26px rgba(36, 120, 255, .28);
  --az-btn-shadow-hover: 0 18px 36px rgba(69, 192, 255, .32);
  --on-primary: #f6fbff;
}

/* ---------- HIGH CONTRAST (strong, accessibility-first) ---------- */
html[data-az-contrast="1"] {
  --bg-dark: #000000;
  --bg: #000000;
  --bg-light: #060606;

  --surface-1: #000000;
  --surface-2: #0a0a0a;
  --overlay: rgba(0, 0, 0, .92);

  --text: #ffffff;
  --text-muted: #ffffff;
  --highlight: #0f0f0f;
  --border: #ffe600;
  --border-muted: #ffe600;

  --primary: #ffe600;
  --primary-ink: #ffe600;
  --on-primary: #000000;
  --secondary: #00e5ff;

  --danger: #ff5f5f;
  --warning: #ffe600;
  --success: #7dff7d;
  --info: #8ecbff;

  --shadow: none;
  --shadow-sm: none;
  --az-fg: #ffffff;
  --az-brand: #ffe600;
  --az-surface: #000000;
  --az-surface-2: #050505;
  --az-bg: #000000;
  --az-border: #ffe600;
  --az-border-2: #ffe600;
  --az-shadow-sm: none;
  --az-shadow-md: none;
  --az-title-brand: #ffe600;
  --az-btn-grad-1: var(--primary);
  --az-btn-grad-2: var(--primary);
  --az-btn-shadow: none;
  --az-btn-shadow-hover: none;
}

/* ---------- GRAYSCALE (accessibility) ---------- */
html[data-az-grayscale="1"] {
  --primary: #111111;
  --on-primary: #ffffff;
  --az-btn-grad-1: #111111;
  --az-btn-grad-2: #050505;
  --az-btn-shadow: none;
  --az-btn-shadow-hover: none;
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --az-motion: 0;
  }
}

html[data-theme="light"]{
  --border-muted: color-mix(in oklab, var(--text) 16%, transparent);
  --border: color-mix(in oklab, var(--text) 22%, transparent);
}
