/* Crest — Design Tokens (aligned with reference designs) */
:root {
  /* Brand palette from reference */
  --crest-wine-deep: #3e0a15;
  --crest-wine: #5e1220;
  --crest-wine-bright: #8c1a2a;
  --crest-wine-red: #b51c28;
  /* The bright red band with bride photo */
  --crest-black: #0a0609;
  --crest-black-2: #14090d;
  --crest-cream: #f0e5cf;
  --crest-cream-2: #e8dcc2;
  --crest-paper: linear-gradient(180deg, #d7d5cf 90%, #dddbd7 100%);
  /* About us cream background f5ecd9*/
  --crest-gold: #c9a961;
  /* Gold from logo + frames */
  --crest-gold-soft: #d4b878;
  --crest-gold-deep: #a88947;
  --crest-line: rgba(201, 169, 97, 0.35);
  --crest-line-soft: rgba(240, 229, 207, 0.15);
  --crest-line-dark: rgba(62, 10, 21, 0.18);

  /* Typography */
  --font-display: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  /* Spacing + rhythm */
  --track-wide: 0.34em;
  --track-mid: 0.18em;
  --track-tight: 0.06em;

  /* Motion */
  --ease-out: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-body);
  background: var(--crest-black);
  color: var(--crest-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Black frame around the site like the reference */
.page-frame {
  background: var(--crest-black);
  padding: 22px;
  min-height: 100vh;
}

.page-inner {
  position: relative;
}

.serif {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: var(--track-tight);
}

.italic {
  font-style: italic;
}

.eyebrow {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--crest-gold);
}

/* The signature serif small-caps label */
.label-caps {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--crest-gold);
}

/* Placeholder images */
.ph {
  position: relative;
  background:
    repeating-linear-gradient(45deg, rgba(240, 229, 207, 0.03) 0 8px, rgba(240, 229, 207, 0.06) 8px 16px),
    var(--crest-black-2);
  border: 1px dashed rgba(201, 169, 97, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--crest-gold-soft);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  padding: 16px;
  overflow: hidden;
}

.ph.cream {
  background:
    repeating-linear-gradient(45deg, rgba(62, 10, 21, 0.04) 0 8px, rgba(62, 10, 21, 0.08) 8px 16px),
    var(--crest-paper);
  color: var(--crest-wine);
  border-color: rgba(62, 10, 21, 0.25);
}

.ph.mountain {
  background:
    linear-gradient(180deg, rgba(10, 6, 9, 0) 0%, rgba(62, 10, 21, 0.35) 60%, rgba(62, 10, 21, 0.6) 100%),
    linear-gradient(135deg, #d8cfc5 0%, #8a7268 40%, #5e1220 70%, #2a0810 100%);
}

.ph .ph-label {
  position: relative;
  z-index: 2;
  background: rgba(10, 6, 9, 0.55);
  padding: 8px 14px;
  border: 1px solid rgba(201, 169, 97, 0.3);
  max-width: 80%;
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 32px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--crest-gold);
  color: var(--crest-cream);
  background: transparent;
  cursor: pointer;
  transition: all 0.4s var(--ease-out);
  position: relative;
}

.btn:hover {
  background: var(--crest-gold);
  color: var(--crest-black);
  letter-spacing: 0.4em;
}

.btn.filled {
  background: var(--crest-gold);
  color: var(--crest-black);
}

.btn.filled:hover {
  background: var(--crest-cream);
  border-color: var(--crest-cream);
}

.btn.ghost-dark {
  border-color: var(--crest-wine-deep);
  color: var(--crest-wine-deep);
}

.btn.ghost-dark:hover {
  background: var(--crest-wine-deep);
  color: var(--crest-cream);
}

/* Signature brace ornaments (the big { } from the design) */
.brace {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: 260px;
  line-height: 0.6;
  color: var(--crest-wine-deep);
  user-select: none;
  display: inline-block;
}

.brace.gold {
  color: var(--crest-gold);
}

.brace.cream {
  color: var(--crest-cream);
}

/* Bracket enclosure — row with { content } */
.brace-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
}

.brace-row .brace {
  font-size: 140px;
  line-height: 1;
  font-weight: 300;
}

/* Small brace for inline labels */
.brace-sm {
  font-family: var(--font-display);
  font-size: 30px;
  color: var(--crest-gold);
  line-height: 1;
}

/* Thin ornament divider with tiny glyph */
.ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  color: var(--crest-gold);
}

.ornament::before,
.ornament::after {
  content: "";
  height: 1px;
  width: 72px;
  background: currentColor;
  opacity: 0.5;
}

/* Reveal */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out);
}

.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* Section base */
section {
  position: relative;
}