:root{

  --font-body: "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-display: "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  --fw-body: 400;
  --fw-medium: 600;
  --fw-bold: 700;
  --fw-display: 900;

  --fs-body: 16px;
  --lh-body: 1.6;

  --fs-h1: clamp(44px, 5.6vw, 60px);
  --fs-h2: clamp(26px, 3vw, 34px);
  --fs-h3: 22px;
  --fs-h4: 18px;

  --lh-h1: 1.08;
  --lh-h2: 1.12;
  --lh-h3: 1.25;
  --lh-h4: 1.3;

  --ls-display: -0.02em;

  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 20px;
  --r-pill: 999px;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;

  --shadow-sm: 0 6px 18px rgba(14, 42, 84, 0.08);

  --blue-50:  #e7eefb;
  --blue-100: #dbe5f8;
  --blue-200: #c2d4f4;
  --blue-300: #9ebaed;
  --blue-400: #6d97e4;
  --blue-500: #0c52d2;
  --blue-600: #0a46b2; 
  --blue-700: #083993;
  --blue-800: #072d74;
  --blue-900: #052154;

  --slate-50:  #f4f5f6;
  --slate-100: #eaebed;
  --slate-200: #d9dcde;
  --slate-300: #bfc4c9;
  --slate-400: #a0a6ae;
  --slate-500: #757f89;
  --slate-600: #55616e; 
  --slate-700: #2b3a4a; 
  --slate-800: #202c38;
  --slate-900: #1a232c;

  --teal-500: #5ba3a8;
  --teal-ink: #407276;

  --gold-500: #d8bf7a;
  --gold-ink: #978655;

  --color-primary:        var(--blue-500);
  --color-primary-hover:  var(--blue-600);
  --color-primary-active: var(--blue-700);
  --color-primary-tint:   var(--blue-50);

  --color-bg:          #f0f5fe;   
  --color-surface:     #ffffff;
  --color-surface-alt: #eaf1ff;
  --color-border:      #dbe5f7;

  --color-text:        var(--slate-700);
  --color-text-muted:  var(--slate-600);
  --color-text-inverse:#ffffff;

  --color-accent-teal:     var(--teal-500);
  --color-accent-teal-ink: var(--teal-ink);

  --color-accent-gold:     var(--gold-500);
  --color-accent-gold-ink: var(--gold-ink);

  --color-success: #4d8b8f; 
  --color-warning: #b8a268; 
  --color-danger:  #e25d6a;

  --focus-ring-primary: color-mix(in srgb, var(--color-primary) 28%, transparent);
  --focus-ring-teal:    color-mix(in srgb, var(--color-accent-teal-ink) 28%, transparent);

  --btn2-teal-bg: var(--color-surface);
  --btn2-teal-fg: var(--color-accent-teal-ink);
  --btn2-teal-border: color-mix(in srgb, var(--color-accent-teal-ink) 55%, var(--color-border));

  --btn2-teal-hover-bg: color-mix(in srgb, var(--color-accent-teal) 12%, var(--color-surface));
  --btn2-teal-hover-border: color-mix(in srgb, var(--color-accent-teal-ink) 65%, var(--color-border));

  --btn2-teal-active-bg: color-mix(in srgb, var(--color-accent-teal) 18%, var(--color-surface));
  --btn2-teal-active-border: color-mix(in srgb, var(--color-accent-teal-ink) 75%, var(--color-border));
}

*{ box-sizing:border-box; }
html, body{ height:100%; }

body{
  margin:0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: var(--fw-body);
  line-height: var(--lh-body);
}

a{ color: var(--color-primary); text-decoration: none; }
a:hover{ color: var(--color-primary-hover); text-decoration: underline; }
a:focus-visible{
  outline: 3px solid var(--focus-ring-primary);
  outline-offset: 2px;
  border-radius: 8px;
}

h1,h2{
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  letter-spacing: var(--ls-display);
  margin: 0 0 var(--space-3);
  color: var(--color-text);
}
h1{ font-size: var(--fs-h1); line-height: var(--lh-h1); }
h2{ font-size: var(--fs-h2); line-height: var(--lh-h2); }

h3,h4{
  margin: 0 0 var(--space-2);
  font-family: var(--font-body);
  font-weight: 800;
  color: var(--color-text);
}
h3{ font-size: var(--fs-h3); line-height: var(--lh-h3); }
h4{ font-size: var(--fs-h4); line-height: var(--lh-h4); }

.small, small{
  color: var(--color-text-muted);
  font-size: 12px;
  line-height: 1.5;
}

.card{
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}

.section-alt{
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--r-lg);
}

.btn{
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  border-radius: var(--r-sm);
  padding: 10px 14px;
  border: 1px solid transparent;
  cursor: pointer;
}

.btn-primary{
  background: var(--color-primary);
  color: var(--color-text-inverse);
}
.btn-primary:hover{ background: var(--color-primary-hover); }
.btn-primary:active{ background: var(--color-primary-active); }
.btn-primary:focus-visible{
  outline: 3px solid var(--focus-ring-primary);
  outline-offset: 2px;
}

.btn-secondary-teal{
  background: var(--btn2-teal-bg);
  color: var(--btn2-teal-fg);
  border: 2px solid var(--btn2-teal-border);
}
.btn-secondary-teal:hover{
  background: var(--btn2-teal-hover-bg);
  border-color: var(--btn2-teal-hover-border);
}
.btn-secondary-teal:active{
  background: var(--btn2-teal-active-bg);
  border-color: var(--btn2-teal-active-border);
}
.btn-secondary-teal:focus-visible{
  outline: 3px solid var(--focus-ring-teal);
  outline-offset: 2px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: var(--fw-medium);
  line-height: 1;
}

.badge-teal{
  background: var(--color-accent-teal-ink);
  color: #fff;
}

.badge-gold{
  background: var(--color-accent-gold);
  color: var(--color-accent-gold-ink);
}

input, select, textarea{
  font-family: var(--font-body);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  color: var(--color-text);
}
input:focus, select:focus, textarea:focus{
  outline: 3px solid var(--focus-ring-primary);
  outline-offset: 2px;
  border-color: color-mix(in srgb, var(--color-primary) 25%, var(--color-border));
}
