/* =============================================================
   Wedding website — design system tokens
   Palette C · Butter & Jungle  |  Type A · Cormorant + Newsreader
   ============================================================= */

:root {
  /* Colour */
  --c-bg:           #FBFAF4;   /* off-white page surface */
  --c-bg-deep:      #F1EEDF;   /* section break */
  --c-cream:        #FFFFFF;   /* card surface */
  --c-ink:          #1C1A12;   /* warm near-black */
  --c-ink-soft:     #5B5443;   /* secondary text */
  --c-rule:         #D8D2BD;   /* hairlines, dividers */
  --c-accent:       #FFF6A3;   /* butter yellow hero */
  --c-accent-deep:  #D9C75A;   /* hover/active for accent */
  --c-jungle:       #2E4A2C;   /* boxwood-hedge counter */
  --c-foliage:      #6F8A4A;   /* lighter stem-green */

  /* Type */
  --f-display: 'Cormorant', 'Cormorant Garamond', Georgia, serif;
  --f-body:    'Newsreader', 'Iowan Old Style', Georgia, serif;
  --f-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Type scale */
  --t-h1: clamp(48px, 9vw, 120px);
  --t-h2: clamp(32px, 5vw, 56px);
  --t-h3: clamp(22px, 3vw, 28px);
  --t-h4: clamp(18px, 2vw, 20px);
  --t-body: 17px;
  --t-body-lg: 19px;
  --t-caption: 13px;
  --t-eyebrow: 11px;

  /* Spacing — 4px base */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;
  --s-10: 128px;

  /* Radii */
  --r-0: 0px;
  --r-1: 2px;
  --r-2: 4px;
  --r-pill: 999px;

  /* Elevation */
  --e-1: 0 1px 2px rgba(28,26,18,0.06), 0 4px 12px rgba(28,26,18,0.05);
  --e-2: 0 2px 4px rgba(28,26,18,0.08), 0 12px 32px rgba(28,26,18,0.08);

  /* Layout */
  --maxw: 1180px;
}

/* ---- Element resets ---- */
.wp-page * { box-sizing: border-box; }
.wp-page {
  font-family: var(--f-body);
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'kern' 1, 'liga' 1, 'onum' 1;
}
.wp-page h1, .wp-page h2, .wp-page h3, .wp-page h4 {
  font-family: var(--f-display);
  font-weight: 400;
  margin: 0;
  color: var(--c-ink);
  text-wrap: balance;
  letter-spacing: -0.005em;
}
.wp-page p { margin: 0 0 var(--s-4); max-width: 65ch; text-wrap: pretty; }
.wp-page a { color: inherit; text-underline-offset: 3px; }

/* ---- Eyebrow / caption / mono utility ---- */
.wp-eyebrow {
  font-family: var(--f-mono);
  font-size: var(--t-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-ink-soft);
  font-weight: 500;
  margin: 0;
}
.wp-caption {
  font-family: var(--f-mono);
  font-size: var(--t-caption);
  letter-spacing: 0.04em;
  color: var(--c-ink-soft);
  line-height: 1.5;
}

/* ---- Buttons ---- */
.wp-btn {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 14px 28px;
  border: 1px solid currentColor;
  background: transparent;
  color: var(--c-ink);
  cursor: pointer;
  border-radius: 0;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease;
  min-height: 48px;
  font-weight: 500;
}
.wp-btn:hover { background: var(--c-ink); color: var(--c-bg); }
.wp-btn--primary {
  background: var(--c-jungle);
  color: var(--c-cream);
  border-color: var(--c-jungle);
}
.wp-btn--primary:hover { background: var(--c-ink); border-color: var(--c-ink); color: var(--c-accent); }
.wp-btn--ghost {
  border-color: transparent;
  padding-left: 0; padding-right: 0;
}
.wp-btn--ghost::after {
  content: '';
  display: inline-block;
  width: 24px; height: 1px;
  background: currentColor;
  margin-left: 6px;
  transition: width 200ms ease;
}
.wp-btn--ghost:hover { background: transparent; color: var(--c-ink); }
.wp-btn--ghost:hover::after { width: 36px; }

/* ---- Image placeholder ---- */
.wp-img-frame {
  position: relative;
  background:
    repeating-linear-gradient(135deg, var(--c-bg-deep) 0 14px, var(--c-cream) 14px 28px);
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--c-rule);
  overflow: hidden;
}
.wp-img-frame.dark {
  background:
    repeating-linear-gradient(135deg, #243B22 0 14px, #2E4A2C 14px 28px);
  border-color: rgba(255,255,255,0.1);
}
.wp-img-frame .wp-placeholder-label {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-ink-soft);
  background: var(--c-cream);
  padding: 6px 10px;
  border: 1px solid var(--c-rule);
  white-space: nowrap;
}
.wp-img-frame.dark .wp-placeholder-label {
  color: var(--c-accent);
  background: rgba(46,74,44,0.85);
  border-color: rgba(255,246,163,0.2);
}

/* ---- Monogram (interlocked, italic Cormorant + accent ampersand) ---- */
.wp-monogram {
  font-family: var(--f-display);
  font-style: italic;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  line-height: 1;
  color: var(--c-ink);
  letter-spacing: 0.01em;
}
.wp-monogram .amp {
  color: var(--c-accent-deep);
  font-size: 0.62em;
  margin: 0 1px;
  transform: translateY(-0.2em);
  display: inline-block;
}
