/* ═══════════════════════════════════════════════════════════════
   SOLONAS Global — Reset, typography, layout primitives
   ═══════════════════════════════════════════════════════════════ */

/* ── Reset ────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: var(--leading-normal);
  padding-top: var(--header-h);
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Typography ───────────────────────────────────────── */
.eyebrow {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-text-secondary);
  font-weight: 600;
}

.headline-hero {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw + 1rem, var(--text-5xl));
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  color: var(--color-text);
}

.headline-section {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw + 0.5rem, var(--text-4xl));
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-snug);
  color: var(--color-text);
}

.headline-sub {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw + 0.3rem, var(--text-2xl));
  font-weight: 600;
  letter-spacing: var(--tracking-snug);
  line-height: var(--leading-snug);
  color: var(--color-text);
}

.body-large {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

.body-default {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

.body-small {
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--color-text-tertiary);
}

.caption {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

/* ── Layout primitives ────────────────────────────────── */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-5);
}

.container-wide {
  max-width: var(--max-width-wide);
  margin: 0 auto;
  padding: 0 var(--space-5);
}

.container-narrow {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 var(--space-5);
}

.section-padding {
  padding-top: var(--space-section);
  padding-bottom: var(--space-section);
}

@media (max-width: 734px) {
  .section-padding {
    padding-top: var(--space-16);
    padding-bottom: var(--space-16);
  }
}

.text-center { text-align: center; }

/* ── Section backgrounds ──────────────────────────────── */
.bg-default { background: var(--color-bg); }
.bg-alt     { background: var(--color-surface-alt); }
.bg-dark {
  background: #1d1d1f;
  color: #f5f5f7;
}
@media (prefers-color-scheme: dark) {
  .bg-dark { background: #000000; }
}
