:root {
  --font-family: "Rubik", sans-serif;
  --font-size-base: 16px;
  --line-height-base: 1.48;

  --max-w: 1200px;
  --space-x: 1.1rem;
  --space-y: 1.25rem;
  --gap: 1.13rem;

  --radius-xl: 1.12rem;
  --radius-lg: 0.74rem;
  --radius-md: 0.4rem;
  --radius-sm: 0.25rem;

  --shadow-sm: 0 1px 6px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 14px rgba(0,0,0,0.1);
  --shadow-lg: 0 18px 30px rgba(0,0,0,0.12);

  --overlay: rgba(0, 0, 0, 0.4);
  --anim-duration: 190ms;
  --anim-ease: cubic-bezier(0.16,1,0.3,1);
  --random-number: 2;

  --brand: #1a56db;
  --brand-contrast: #ffffff;
  --accent: #0ea5e9;
  --accent-contrast: #ffffff;

  --neutral-0: #ffffff;
  --neutral-100: #f8fafc;
  --neutral-300: #cbd5e1;
  --neutral-600: #475569;
  --neutral-800: #1e293b;
  --neutral-900: #0f172a;

  --bg-page: #f1f5f9;
  --fg-on-page: #0f172a;

  --bg-alt: #e2e8f0;
  --fg-on-alt: #1e293b;

  --surface-1: #ffffff;
  --surface-2: #f8fafc;
  --fg-on-surface: #1e293b;
  --border-on-surface: #e2e8f0;

  --surface-light: #ffffff;
  --fg-on-surface-light: #475569;
  --border-on-surface-light: #cbd5e1;

  --bg-primary: #1d4ed8;
  --fg-on-primary: #ffffff;
  --bg-primary-hover: #2563eb;
  --ring: #3b82f6;

  --bg-accent: #f0f9ff;
  --fg-on-accent: #0369a1;
  --bg-accent-hover: #38bdf8;

  --link: #1d4ed8;
  --link-hover: #2563eb;

  --gradient-hero: linear-gradient(135deg, #1e40af 0%, #0ea5e9 100%);
  --gradient-accent: linear-gradient(90deg, #0ea5e9 0%, #38bdf8 100%);

  --btn-ghost-bg: transparent;
  --btn-ghost-bg-hover: rgba(255,255,255,0.06);
  --chip-bg: rgba(255,255,255,0.68);
  --input-placeholder: rgba(255,255,255,0.55);
}
body{margin:0;padding:0;font-family:var(--font-family);box-sizing: border-box;}
*{box-sizing:border-box;}