/**
 * ZZB Base — body defaults, typography, layout primitives.
 * Loaded after tokens.css. Does NOT reset Blocksy's reset (parent already does that).
 */

body.zzb-theme {
  background: var(--zzb-cream);
  color: var(--zzb-ink-soft);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  font-weight: var(--fw-regular);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body.zzb-theme h1,
body.zzb-theme h2,
body.zzb-theme h3,
body.zzb-theme h4,
body.zzb-theme h5,
body.zzb-theme h6 {
  font-family: var(--font-display);
  font-weight: var(--fw-regular);
  color: var(--zzb-ink);
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight);
  margin-top: 0;
  margin-bottom: var(--space-4);
}

body.zzb-theme h1 { font-size: var(--fs-4xl); line-height: var(--lh-tight); }
body.zzb-theme h2 { font-size: var(--fs-3xl); font-style: italic; }
body.zzb-theme h3 { font-size: var(--fs-2xl); }
body.zzb-theme h4 { font-size: var(--fs-xl); }
body.zzb-theme h5 { font-size: var(--fs-lg); }
body.zzb-theme h6 {
  font-size: var(--fs-base);
  font-family: var(--font-body);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

body.zzb-theme p {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  color: var(--zzb-ink-soft);
  margin-top: 0;
  margin-bottom: var(--space-4);
}

body.zzb-theme a {
  color: var(--zzb-gold-deep);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
body.zzb-theme a:hover {
  color: var(--zzb-gold);
}

body.zzb-theme img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Containers */
.zzb-container {
  width: 100%;
  max-width: var(--width-content);
  margin-inline: auto;
  padding-inline: var(--space-6);
}
.zzb-container--narrow { max-width: var(--width-narrow); }
.zzb-container--wide   { max-width: var(--width-wide); }
.zzb-container--full   { max-width: 100%; padding-inline: 0; }

/* Eyebrow label (used everywhere) */
.zzb-eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-extra);
  text-transform: uppercase;
  color: var(--zzb-gold-deep);
  margin-bottom: var(--space-3);
}
.zzb-eyebrow::before {
  content: '✦ ';
  color: var(--zzb-gold);
}

/* Decorative divider (gold gradient line) */
.zzb-divider {
  display: block;
  width: 80px;
  height: 1px;
  margin: var(--space-8) auto;
  background: linear-gradient(90deg, transparent, var(--zzb-gold-200), var(--zzb-gold), var(--zzb-gold-200), transparent);
  border: 0;
}

/* Section spacing */
.zzb-section {
  padding-block: var(--space-32);
}
.zzb-section--tight {
  padding-block: var(--space-16);
}

/* Initial cap (first letter of editorial paragraphs) */
.zzb-initial-cap::first-letter {
  font-family: var(--font-display);
  font-size: 4rem;
  line-height: 0.85;
  float: left;
  padding-right: var(--space-3);
  padding-top: 0.25rem;
  color: var(--zzb-gold-deep);
}

/* Tabular numerics for prices */
.zzb-price,
.zzb-tabular {
  font-variant-numeric: tabular-nums;
}

/* Visually hidden (a11y) */
.zzb-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Global focus-visible ring (keyboard navigation a11y) */
body.zzb-theme :focus-visible {
  outline: 2px solid var(--zzb-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
body.zzb-theme .zzb-btn:focus-visible,
body.zzb-theme .zzb-icon-btn:focus-visible,
body.zzb-theme .zzb-variant-pill:focus-visible {
  outline-offset: 3px;
}
