/* Helena & Anders — Wedding site styles */

:root {
  --paper: #f6f1e7;
  --paper-deep: #efe8d8;
  --ink: #1c1a16;
  --ink-soft: #4b463d;
  --ink-mute: #7a7264;
  --rule: #cdbf9e;
  --gold: #b08838;
  --gold-deep: #8c6a23;
  --gold-soft: #d4b977;
  --shadow: 0 1px 0 rgba(28, 26, 22, 0.04), 0 30px 60px -30px rgba(28, 26, 22, 0.18);
  --serif: "Cormorant Garamond", "EB Garamond", Garamond, "Times New Roman", serif;
  --display: "Italiana", "Cormorant Garamond", Garamond, serif;
  --sans: "Inter Tight", "Helvetica Neue", Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
  --content: 1100px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* subtle paper texture */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(176, 136, 56, 0.06), transparent 60%),
    radial-gradient(800px 400px at -10% 110%, rgba(176, 136, 56, 0.05), transparent 60%);
  z-index: 0;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; }

/* ---- TopBar ---- */
.topbar {
  position: fixed; top: 0; left: 0; right: 0;
  display: flex; align-items: center; gap: 24px;
  padding: 18px 36px;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  z-index: 50;
  border-bottom: 1px solid transparent;
  transition: padding 200ms ease, border-color 200ms ease, background 200ms ease;
}
.topbar--compact { padding: 10px 36px; border-bottom-color: var(--rule); }
.topbar__mark { display: flex; align-items: center; gap: 10px; color: var(--gold); }
.topbar__monogram { font-family: var(--display); font-size: 22px; letter-spacing: 0.04em; color: var(--ink); }
.topbar__monogram .amp { color: var(--gold); margin: 0 2px; font-style: italic; }
.topbar__nav { display: flex; gap: 22px; margin-left: auto; flex-wrap: wrap; }
.topbar__link {
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-soft); padding: 4px 0; border-bottom: 1px solid transparent;
  transition: color 150ms, border-color 150ms;
}
.topbar__link:hover { color: var(--ink); border-bottom-color: var(--gold); }
.topbar__lang { display: flex; align-items: center; gap: 4px; padding-left: 18px; border-left: 1px solid var(--rule); }
.langbtn {
  background: transparent; border: 0; padding: 4px 6px;
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.18em; color: var(--ink-mute);
}
.langbtn.is-active { color: var(--gold-deep); }
.langbtn__sep { color: var(--ink-mute); font-family: var(--sans); font-size: 12px; }

/* ---- Generic ---- */
main { position: relative; z-index: 1; padding-top: 96px; }
.section { max-width: var(--content); margin: 0 auto; padding: 96px 36px; }

.sechead { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; margin-bottom: 56px; }
.sechead--center { align-items: center; text-align: center; }
.sechead__seal { color: var(--gold); margin-bottom: 6px; }
.sechead__kicker {
  margin: 0; font-family: var(--sans); font-size: 11px; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--ink-mute);
}
.sechead__title {
  margin: 0; font-family: var(--display); font-weight: 400;
  font-size: clamp(36px, 5vw, 56px); letter-spacing: 0.01em; color: var(--ink);
}
.sechead__rule { width: 80px; height: 1px; background: var(--rule); margin-top: 6px; position: relative; }
.sechead__rule span {
  position: absolute; top: -3px; left: 50%; transform: translateX(-50%);
  width: 7px; height: 7px; border-radius: 50%; background: var(--gold);
}

/* ---- Hero ---- */
.hero {
  position: relative;
  text-align: center;
  padding: 96px 36px 80px;
  max-width: 980px;
  margin: 0 auto;
}
.hero__rule { display: flex; align-items: center; justify-content: center; height: 1px; }
.hero__rule span { width: 200px; height: 1px; background: linear-gradient(90deg, transparent, var(--rule), transparent); }
.hero__eyebrow {
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.32em;
  text-transform: uppercase; color: var(--ink-mute); margin: 36px 0 8px;
}
.hero__names {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(64px, 11vw, 140px);
  line-height: 0.95; letter-spacing: 0.005em;
  margin: 12px 0; color: var(--ink);
  display: flex; align-items: baseline; justify-content: center; gap: clamp(16px, 3vw, 40px);
  flex-wrap: wrap;
}
.hero__amp { font-style: italic; font-size: 0.9em; color: var(--gold); }
.hero__rose { display: flex; justify-content: center; margin: 8px 0 8px; }

/* Tint the black-line SVG to gold using filter chain.
   sepia + saturate + hue-rotate maps black strokes to a warm gold. */
.rose-img {
  display: block;
  filter:
    brightness(0) saturate(100%)
    invert(58%) sepia(38%) saturate(640%)
    hue-rotate(2deg) brightness(92%) contrast(88%);
}
body[data-rose="bold"] .rose-img {
  filter:
    brightness(0) saturate(100%)
    invert(46%) sepia(50%) saturate(720%)
    hue-rotate(2deg) brightness(82%) contrast(95%);
}
body[data-rose="soft"] .rose-img {
  filter:
    brightness(0) saturate(100%)
    invert(72%) sepia(28%) saturate(520%)
    hue-rotate(2deg) brightness(102%) contrast(82%);
}
body[data-tone="graphite"] .rose-img {
  filter:
    brightness(0) saturate(100%)
    invert(50%) sepia(40%) saturate(540%)
    hue-rotate(2deg) brightness(78%) contrast(90%);
}
.hero__date {
  font-family: var(--display); font-size: clamp(22px, 2.4vw, 30px); margin: 0 0 18px;
  letter-spacing: 0.02em; color: var(--ink);
}
.hero__meta {
  list-style: none; padding: 0; margin: 0 auto 36px;
  display: flex; gap: 0; justify-content: center; flex-wrap: wrap;
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-soft);
}
.hero__meta li { padding: 0 14px; border-right: 1px solid var(--rule); }
.hero__meta li:last-child { border-right: 0; }

/* ---- Intro ---- */
.intro {
  max-width: 720px; margin: 0 auto; padding: 48px 36px 96px;
  text-align: center;
}
.intro__title {
  font-family: var(--display); font-size: clamp(28px, 4vw, 40px); margin: 0 0 16px;
  color: var(--ink);
}
.intro__body {
  font-family: var(--serif); font-size: 20px; line-height: 1.6; color: var(--ink-soft);
  text-wrap: pretty;
}
.intro__sign {
  font-family: var(--display); font-style: italic; font-size: 22px; color: var(--gold-deep);
  margin-top: 24px;
}

/* ---- Schedule timeline ---- */
.timeline {
  list-style: none; padding: 0; margin: 0;
  max-width: 640px; margin-left: auto; margin-right: auto;
}
.timeline__row {
  display: grid; grid-template-columns: 90px 24px 1fr; align-items: start; gap: 24px;
  padding: 20px 0; border-bottom: 1px dotted var(--rule);
  position: relative;
}
.timeline__row:last-child { border-bottom: 0; }
.timeline__time {
  font-family: var(--display); font-size: 22px; color: var(--ink); padding-top: 2px;
  font-variant-numeric: tabular-nums;
}
.timeline__dot {
  width: 11px; height: 11px; border-radius: 50%;
  border: 2px solid var(--gold); background: var(--paper);
  margin-top: 10px; justify-self: center; position: relative;
}
.timeline__dot::before {
  content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 3px; height: 3px; border-radius: 50%; background: var(--gold);
}
.timeline__row:not(:last-child) .timeline__dot::after {
  content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  width: 1px; height: calc(100% + 24px); background: var(--rule);
}
.timeline__label {
  font-family: var(--display); font-size: 22px; margin: 0 0 2px; color: var(--ink);
}
.timeline__note {
  margin: 0; font-family: var(--sans); font-size: 13px; color: var(--ink-mute);
  letter-spacing: 0.04em;
}

/* ---- Venues ---- */
.venues__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.venue { display: flex; flex-direction: column; }
.venue__image {
  aspect-ratio: 4 / 3; background: var(--paper-deep); border: 1px solid var(--rule);
  margin-bottom: 24px; position: relative; overflow: hidden;
}
.venue__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }
.venue__placeholder, .gphoto__placeholder {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background-image: repeating-linear-gradient(45deg, transparent 0 14px, rgba(176, 136, 56, 0.07) 14px 15px);
  color: var(--ink-mute); font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
}
.venue__kicker { font-family: var(--sans); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold-deep); margin: 0 0 8px; }
.venue__name { font-family: var(--display); font-size: 36px; font-weight: 400; margin: 0 0 6px; }
.venue__address, .venue__time { margin: 0 0 4px; font-family: var(--sans); font-size: 14px; color: var(--ink-soft); }
.venue__time { color: var(--ink-mute); }
.venue__body { margin: 16px 0 18px; color: var(--ink-soft); font-size: 17px; text-wrap: pretty; }

.link--arrow {
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold-deep); border-bottom: 1px solid var(--gold-soft); padding-bottom: 3px;
  align-self: flex-start; transition: color 150ms, border-color 150ms;
}
.link--arrow:hover { color: var(--ink); border-bottom-color: var(--ink); }

/* ---- Rehearsal ---- */
.rehearsal { background: var(--paper-deep); max-width: none; padding: 96px 36px; margin: 0; }
.dayafter { background: var(--paper); max-width: none; padding: 96px 36px; margin: 0; }
.rehearsal__inner {
  max-width: var(--content); margin: 0 auto;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 72px; align-items: center;
}
.rehearsal__copy .sechead__kicker { margin-bottom: 12px; display: block; }
.rehearsal__copy .sechead__title { margin-bottom: 20px; }
.rehearsal__body { font-size: 19px; color: var(--ink-soft); text-wrap: pretty; }
.rehearsal__details { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.rehearsal__rose { color: var(--gold); }
.deflist { margin: 0; padding: 24px 36px; border: 1px solid var(--rule); background: var(--paper); width: 100%; max-width: 360px; }
.deflist__row { display: flex; justify-content: space-between; gap: 16px; padding: 10px 0; border-bottom: 1px dotted var(--rule); }
.deflist__row:last-child { border-bottom: 0; }
.deflist dt { font-family: var(--sans); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-mute); }
.deflist dd { margin: 0; font-family: var(--display); font-size: 18px; color: var(--ink); }

/* ---- Dress ---- */
.dress__inner { max-width: 640px; margin: 0 auto; text-align: center; }
.dress__code {
  font-family: var(--display); font-style: italic; font-size: clamp(48px, 7vw, 84px);
  margin: 0 0 16px; color: var(--gold);
}
.dress__body { font-size: 19px; color: var(--ink-soft); text-wrap: pretty; }

/* ---- Travel ---- */
.travel__intro {
  max-width: 640px; margin: 0 auto 36px; text-align: center;
  color: var(--ink-soft); font-size: 17px; text-wrap: pretty;
}
.travel__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.travelcard {
  border: 1px solid var(--rule); background: var(--paper);
  display: flex; flex-direction: column; overflow: hidden;
  transition: border-color 200ms, transform 200ms;
}
.travelcard:hover { border-color: var(--gold-soft); }
.travelcard__image {
  aspect-ratio: 16 / 9; background: var(--paper-deep); position: relative; overflow: hidden;
  border-bottom: 1px solid var(--rule);
}
.travelcard__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }
.travelcard__body-wrap { padding: 28px 28px 24px; display: flex; flex-direction: column; flex: 1; }
.travelcard__kicker { font-family: var(--sans); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold-deep); margin: 0 0 8px; }
.travelcard__name { font-family: var(--display); font-size: 26px; font-weight: 400; margin: 0 0 10px; }
.travelcard__body { margin: 0 0 20px; color: var(--ink-soft); font-size: 16px; flex: 1; text-wrap: pretty; }
.travelcard__links { display: flex; flex-wrap: wrap; gap: 22px 28px; align-items: center; }
.link--arrow-quiet { color: var(--ink-mute); border-bottom-color: var(--rule); }
.link--arrow-quiet:hover { color: var(--ink); border-bottom-color: var(--ink); }

/* ---- Gallery ---- */
.gallery__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 280px 220px;
  gap: 16px;
}
.gphoto { margin: 0; display: flex; flex-direction: column; gap: 8px; }
.gphoto__frame { background: var(--paper-deep); border: 1px solid var(--rule); position: relative; flex: 1; overflow: hidden; }
.gphoto__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; }
.gphoto--3 .gphoto__img { object-position: center 72%; }
.gphoto--0 .gphoto__img { transform: scaleX(-1); }
.gphoto--2 .gphoto__img { transform: scaleX(-1); }
.gphoto figcaption { font-family: var(--sans); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
.gphoto--0 { grid-column: 1; grid-row: 1 / 3; }
.gphoto--1 { grid-column: 2; grid-row: 1; }
.gphoto--2 { grid-column: 3; grid-row: 1; }
.gphoto--3 { grid-column: 2 / 4; grid-row: 2; }

/* ---- RSVP ---- */
.rsvp { max-width: 720px; }
.rsvp__intro { text-align: center; color: var(--ink-soft); font-size: 18px; margin: -32px auto 40px; max-width: 540px; }
.rsvp__form {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px 24px;
  background: var(--paper-deep);
  border: 1px solid var(--rule);
  padding: 36px;
}
.field { display: flex; flex-direction: column; gap: 6px; }
.field--full { grid-column: 1 / -1; }
.field label, .field legend {
  font-family: var(--sans); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-soft);
  padding: 0;
}
.field input[type="text"], .field input[type="email"], .field input[type="tel"], .field textarea {
  font: inherit; font-family: var(--serif); font-size: 18px;
  background: var(--paper); border: 0; border-bottom: 1px solid var(--rule);
  padding: 8px 0; color: var(--ink); outline: none;
  transition: border-color 150ms;
}
.field input:focus, .field textarea:focus { border-bottom-color: var(--gold); }
.field textarea { border: 1px solid var(--rule); padding: 12px; resize: vertical; }
.field input[aria-invalid="true"] { border-bottom-color: #b04848; }
.field__err { font-family: var(--sans); font-size: 12px; color: #b04848; }
.field fieldset, fieldset.field { border: 0; padding: 0; margin: 0; }

.choice { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 10px; }
.choice__opt {
  flex: 1; min-width: 200px;
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  border: 1px solid var(--rule); background: var(--paper);
  font-family: var(--display); font-size: 18px;
  cursor: pointer; transition: all 150ms;
}
.choice__opt input { accent-color: var(--gold); }
.choice__opt.is-selected { border-color: var(--gold); background: color-mix(in srgb, var(--gold) 7%, var(--paper)); color: var(--ink); }

.checkrow { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.checkrow input { accent-color: var(--gold); width: 18px; height: 18px; }
.checkrow span { font-family: var(--serif); font-size: 17px; letter-spacing: 0; text-transform: none; color: var(--ink); }

.btn {
  font-family: var(--sans); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase;
  padding: 16px 32px; border: 1px solid var(--ink); background: var(--ink); color: var(--paper);
  cursor: pointer; transition: all 200ms; align-self: start; justify-self: start;
}
.btn:hover { transform: translateY(-1px); }
.btn--primary { grid-column: 1 / -1; justify-self: center; }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--ink); }

.rsvp__success { text-align: center; padding: 24px 0 8px; }
.rsvp__successrose { color: var(--gold); display: flex; justify-content: center; margin-bottom: 12px; }
.rsvp__success h3 { font-family: var(--display); font-size: 44px; font-weight: 400; margin: 0 0 12px; }
.rsvp__success p { color: var(--ink-soft); font-size: 19px; margin: 0 0 24px; }

/* ---- Footer ---- */
.footer {
  text-align: center; padding: 80px 36px 60px; border-top: 1px solid var(--rule);
  margin-top: 40px;
}
.footer__rose { color: var(--gold); display: flex; justify-content: center; margin-bottom: 16px; }
.footer__count {
  font-family: var(--display); font-size: 28px; margin: 0 0 8px; color: var(--ink);
}
.footer__count span { font-size: 40px; font-style: italic; margin-right: 6px; }
.footer__sign { font-family: var(--sans); font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-soft); margin: 0 0 6px; }
.footer__contact { font-family: var(--sans); font-size: 12px; color: var(--ink-mute); letter-spacing: 0.08em; margin: 0; }

/* ---- Responsive ---- */
@media (max-width: 960px) {
  .topbar { flex-wrap: wrap; padding: 14px 20px; gap: 12px; }
  .topbar__nav { order: 3; width: 100%; justify-content: flex-start; gap: 14px; }
  .topbar__lang { padding-left: 12px; margin-left: auto; }
  main { padding-top: 130px; }
  .section { padding: 64px 24px; }
  .venues__grid, .travel__grid, .rsvp__form { grid-template-columns: 1fr; gap: 32px; }
  .rehearsal__inner { grid-template-columns: 1fr; gap: 36px; }
  .gallery__grid { grid-template-columns: 1fr 1fr; grid-template-rows: 220px 180px 180px; }
  .gphoto--0 { grid-column: 1 / 3; grid-row: 1; }
  .gphoto--1 { grid-column: 1; grid-row: 2; }
  .gphoto--2 { grid-column: 2; grid-row: 2; }
  .gphoto--3 { grid-column: 1 / 3; grid-row: 3; }
  .timeline__row { grid-template-columns: 70px 18px 1fr; gap: 16px; }
  .timeline__time { font-size: 18px; }
  .hero { padding: 56px 24px 56px; }
  .hero__meta li { padding: 4px 12px; border-right: 0; }
}

@media (max-width: 560px) {
  body { font-size: 16px; }
  .hero__names { gap: 8px; }
  .topbar__nav { display: none; }
  .topbar { padding: 12px 18px; }
  main { padding-top: 64px; }
  .section { padding: 56px 20px; }
  .rsvp__form { padding: 22px; }
  .choice__opt { min-width: 0; flex: 1 1 100%; }
}

/* ---- Tweak: tone variations ---- */
body[data-tone="warm"] { --paper: #f8f1e1; --paper-deep: #f0e5cd; --rule: #d4c298; --gold: #b88a30; --gold-deep: #8c6720; --gold-soft: #dcc488; }
body[data-tone="cool"] { --paper: #f3f0e8; --paper-deep: #ebe7da; --rule: #c8c2b0; --gold: #9e7d3a; --gold-deep: #76591f; --gold-soft: #c5ad75; }
body[data-tone="ivory"] { --paper: #fbf6ec; --paper-deep: #f4ecd8; --rule: #d8c79e; --gold: #a8782c; --gold-deep: #7e5919; --gold-soft: #cda760; }
body[data-tone="graphite"] { --paper: #ecebe6; --paper-deep: #e2e0d7; --rule: #bdb5a0; --ink: #15140f; --gold: #9b7424; --gold-deep: #6f5012; }

body[data-rose="bold"] { --gold: #9b6f1c; --gold-deep: #6f4f10; }
body[data-rose="soft"] { --gold: #c9a55e; --gold-deep: #a37e2e; }
