/* ============================================================
   ÉTERNEL — "The Story" (coastal editorial, designed edition)
   Drawn emblem · arched frames · script watermarks · index
   numerals · marquee · SVG wave dividers · mask reveals
   ============================================================ */
:root {
  --paper: #f3f5f4;
  --paper-warm: #efece4;
  --shell: #e9e3d6;
  --ink: #233640;
  --ink-soft: #69797f;
  --sea: #6f9fb0;
  --sea-deep: #45788a;
  --brass: #b89b6a;
  --brass-deep: #957c4d;
  --line: #ded8ca;
  --serif: "Cormorant Garamond", Georgia, serif;
  --script: "Great Vibes", cursive;
  --sans: "Jost", "Segoe UI", sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--serif); font-weight: 400;
  background: var(--paper); color: var(--ink);
  line-height: 1.7; overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; }

body.locked { overflow: hidden; height: 100dvh; }

/* ============================================================
   OPENING — tap to open
   ============================================================ */
.opening {
  position: fixed; inset: 0; z-index: 1000;
  background:
    radial-gradient(120% 80% at 50% 16%, rgba(111,159,176,0.14), transparent 60%),
    linear-gradient(180deg, #f6f8f7, #e6eef0 90%);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: opacity 0.9s var(--ease) 0.5s, visibility 0.9s 0.5s;
}
.opening.open { opacity: 0; visibility: hidden; pointer-events: none; }
.opening-inner { text-align: center; padding: 1.5rem; }
.opening-emblem { width: 64px; height: 64px; margin: 0 auto 1.4rem; color: var(--brass-deep); }
.opening-kicker { font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.46em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 1.5rem; }

.opening-arch {
  position: relative; width: min(280px, 66vw); aspect-ratio: 3 / 4; margin: 0 auto;
  border: 8px solid #fff; border-radius: 50% 50% 6px 6px / 30% 30% 6px 6px;
  overflow: hidden; box-shadow: 0 30px 64px rgba(35,54,64,0.24);
  transform-origin: center;
  transition: transform 1.2s var(--ease), border-radius 1.2s var(--ease), opacity 0.8s ease 0.5s;
}
.opening-arch img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); animation: openKen 14s ease-in-out infinite alternate; }
@keyframes openKen { from { transform: scale(1.05); } to { transform: scale(1.18) translateY(-3%); } }
.opening-mono { position: absolute; left: 0; right: 0; bottom: 12px; z-index: 2; color: #fff; font-family: var(--serif); font-size: 1.1rem; letter-spacing: 0.16em; text-shadow: 0 2px 14px rgba(0,0,0,0.5); }
.opening-names { font-weight: 500; font-size: clamp(1.6rem, 6vw, 2.3rem); margin-top: 1.5rem; color: var(--ink); }
.opening-hint { font-family: var(--sans); font-size: 0.64rem; letter-spacing: 0.34em; text-transform: uppercase; color: var(--sea-deep); margin-top: 1.4rem; animation: hintPulse 2.2s ease-in-out infinite; }
@keyframes hintPulse { 0%,100% { opacity: 0.5; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-2px); } }

/* the expand-away on open */
.opening.open .opening-arch { transform: scale(7); border-radius: 0; opacity: 0; }
.opening.open .opening-inner > *:not(.opening-arch) { opacity: 0; transition: opacity 0.5s ease; }

/* film grain texture overlay */
.grain { position: fixed; inset: 0; z-index: 480; pointer-events: none; opacity: 0.5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E"); }

/* svg symbol sprite is hidden */
.svg-defs { position: absolute; width: 0; height: 0; overflow: hidden; }

/* ---------- progress + controls ---------- */
.progress { position: fixed; top: 0; left: 0; height: 2px; width: 0%; background: linear-gradient(90deg, var(--sea), var(--brass)); z-index: 500; }
.controls { position: fixed; top: 1.2rem; right: 1.2rem; z-index: 460; display: flex; gap: 0.5rem; }
.ctrl-btn { width: 42px; height: 42px; border-radius: 50%; background: rgba(255,255,255,0.7); border: 1px solid var(--line); color: var(--sea-deep); font-family: var(--sans); font-size: 0.72rem; cursor: pointer; display: flex; align-items: center; justify-content: center; backdrop-filter: blur(10px); transition: 0.3s; }
.ctrl-btn:hover { border-color: var(--brass); color: var(--brass-deep); }
.ctrl-btn.playing { animation: spin 6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.lang-bar { position: fixed; bottom: 1.1rem; left: 50%; transform: translateX(-50%); z-index: 460; display: flex; gap: 0.2rem; background: rgba(255,255,255,0.72); backdrop-filter: blur(10px); border: 1px solid var(--line); border-radius: 999px; padding: 0.28rem; }
.lang-bar button { background: none; border: none; cursor: pointer; font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); padding: 0.4rem 0.85rem; border-radius: 999px; transition: 0.3s; }
.lang-bar button.active { background: var(--sea-deep); color: #fff; }

/* ---------- emblem ---------- */
.emblem { color: var(--brass-deep); }
.emblem svg { width: 100%; height: 100%; display: block; }
.emblem .draw { stroke-dasharray: 1; stroke-dashoffset: 1; }
.emblem.lit .draw { animation: drawIn 2s var(--ease) forwards; }
@keyframes drawIn { to { stroke-dashoffset: 0; } }

/* ============================================================
   COVER
   ============================================================ */
.cover { position: relative; height: 100svh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.cover-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.2); opacity: 0; transition: transform 2.6s var(--ease), opacity 1.4s ease; will-change: transform; }
.cover.ready .cover-img { transform: scale(1.05); opacity: 1; }
.cover-shade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,32,38,0.34), rgba(20,32,38,0.08) 36%, rgba(20,32,38,0.5) 100%); }

/* thin inner frame on the cover */
.cover-frame { position: absolute; inset: 18px; border: 1px solid rgba(255,255,255,0.35); z-index: 2; pointer-events: none; }
.cover-frame::before, .cover-frame::after { content: ""; position: absolute; width: 16px; height: 16px; border: 1px solid rgba(255,255,255,0.6); }
.cover-frame::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.cover-frame::after { bottom: -1px; right: -1px; border-left: none; border-top: none; }

.cover-side { position: absolute; top: 50%; z-index: 3; color: rgba(255,255,255,0.8); font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.4em; text-transform: uppercase; writing-mode: vertical-rl; }
.cover-side.l { left: 1.6rem; transform: translateY(-50%) rotate(180deg); }
.cover-side.r { right: 1.6rem; transform: translateY(-50%); }

.cover-inner { position: relative; z-index: 4; text-align: center; color: #fff; padding: 0 1.5rem; }
.cover-emblem { width: 76px; height: 76px; margin: 0 auto 1.4rem; color: #fff; opacity: 0; transform: translateY(14px); transition: all 1s var(--ease) 0.3s; }
.cover.ready .cover-emblem { opacity: 0.95; transform: none; }
.cover-kicker { font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.5em; text-transform: uppercase; }
.cover-kicker .l { display: inline-block; opacity: 0; transform: translateY(14px); transition: all 0.7s var(--ease); }
.cover-names { font-weight: 500; font-size: clamp(3rem, 13vw, 6.2rem); line-height: 1.02; margin: 0.5rem 0; }
.cover-names .mask { display: inline-block; overflow: hidden; vertical-align: bottom; }
.cover-names .mask span { display: inline-block; transform: translateY(108%); transition: transform 1.2s var(--ease); }
.cover.ready .cover-names .mask span { transform: none; }
.cover-names .amp { font-family: var(--script); font-weight: 400; color: #d7e7ee; padding: 0 0.1em; }
.cover-rule { width: 0; height: 1px; background: rgba(255,255,255,0.7); margin: 1rem auto; transition: width 1.2s var(--ease) 0.9s; }
.cover.ready .cover-rule { width: 120px; }
.cover-date { font-family: var(--sans); font-size: 0.74rem; letter-spacing: 0.36em; text-transform: uppercase; opacity: 0; transition: opacity 1s ease 1.2s; }
.cover.ready .cover-date { opacity: 1; }
.cover-cue { position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 4; color: #fff; font-size: 1.05rem; opacity: 0.85; animation: bob 2.2s ease-in-out infinite; }
@keyframes bob { 0%,100% { transform: translate(-50%,0); } 50% { transform: translate(-50%,8px); } }

/* ============================================================
   MARQUEE RIBBON
   ============================================================ */
.marquee { overflow: hidden; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--paper-warm); padding: 0.8rem 0; white-space: nowrap; }
.marquee-track { display: inline-block; white-space: nowrap; animation: slide 32s linear infinite; }
.marquee.rev .marquee-track { animation-direction: reverse; }
@keyframes slide { to { transform: translateX(-50%); } }
.marquee span { font-size: 1.1rem; font-style: italic; color: var(--ink-soft); letter-spacing: 0.1em; padding: 0 1.1rem; }
.marquee .dot { color: var(--brass); }

/* ============================================================
   SECTIONS / REVEALS
   ============================================================ */
.sect { position: relative; padding: clamp(4.5rem, 11vw, 9rem) 1.6rem; }
.wrap { max-width: 1040px; margin: 0 auto; position: relative; }
.narrow { max-width: 640px; margin: 0 auto; }

.reveal { opacity: 0; transform: translateY(40px); transition: opacity 1s var(--ease), transform 1.1s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.12s; } .reveal.d2 { transition-delay: 0.24s; } .reveal.d3 { transition-delay: 0.36s; }

/* word-by-word reveal */
.words .word { display: inline-block; overflow: hidden; vertical-align: bottom; }
.words .word > span { display: inline-block; transform: translateY(110%); transition: transform 0.9s var(--ease); transition-delay: var(--wd, 0s); }
.words.in .word > span { transform: none; }

.eyebrow { font-family: var(--sans); font-size: 0.64rem; letter-spacing: 0.42em; text-transform: uppercase; color: var(--brass-deep); display: inline-flex; align-items: center; gap: 0.7rem; }
.eyebrow::before, .eyebrow.both::after { content: ""; width: 26px; height: 1px; background: var(--brass); display: inline-block; }

/* big script watermark behind a section */
.watermark { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); font-family: var(--script); font-size: clamp(8rem, 30vw, 20rem); color: var(--brass); opacity: 0.07; pointer-events: none; white-space: nowrap; z-index: 0; }

/* index numerals */
.chapter-no { font-family: var(--serif); font-size: clamp(4rem, 12vw, 8rem); font-weight: 500; color: var(--sea); opacity: 0.18; line-height: 0.8; }

/* ============================================================
   INTRO
   ============================================================ */
.intro { text-align: center; }
.intro .narrow { position: relative; z-index: 1; }
.intro p.lead { font-size: clamp(1.5rem, 4.4vw, 2.3rem); line-height: 1.5; margin-top: 1.3rem; font-weight: 500; }
.divider { display: flex; align-items: center; justify-content: center; gap: 1rem; margin: 2.4rem auto 0; }
.divider .wave { width: clamp(120px, 40vw, 240px); height: 18px; color: var(--brass); }
.divider .wave path { stroke-dasharray: 1; stroke-dashoffset: 1; }
.divider.in .wave path { animation: drawIn 1.6s var(--ease) forwards; }
.divider .em { width: 26px; height: 26px; color: var(--brass-deep); flex-shrink: 0; }

/* ============================================================
   STORY — editorial collage chapters
   ============================================================ */
.story-chapter { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 5vw, 4rem); align-items: center; }
.story-chapter + .story-chapter { margin-top: clamp(4rem, 10vw, 8rem); }
.story-chapter.flip .sc-media { order: 2; }
.sc-media { position: relative; }
.sc-frame {
  position: relative; overflow: hidden; aspect-ratio: 4 / 5;
  border: 8px solid #fff; box-shadow: 0 34px 70px rgba(35,54,64,0.20);
}
.sc-frame::before { /* sweeping reveal panel */
  content: ""; position: absolute; inset: 0; z-index: 3; background: var(--paper);
  transform: translateY(0); transition: transform 1.1s var(--ease);
}
.story-chapter.in .sc-frame::before { transform: translateY(-101%); }
.sc-frame img { position: absolute; inset: -8% 0; width: 100%; height: 116%; object-fit: cover; will-change: transform; }
.sc-arch { border-radius: 50% 50% 6px 6px / 22% 22% 6px 6px; }
.sc-no { position: absolute; z-index: 4; top: -0.5em; left: -0.2em; }
.story-chapter.flip .sc-no { left: auto; right: -0.2em; }
.sc-text { position: relative; z-index: 2; }
.sc-text .eyebrow { margin-bottom: 0.9rem; }
.sc-title { font-weight: 500; font-size: clamp(1.9rem, 5vw, 2.7rem); line-height: 1.12; margin-bottom: 1rem; }
.sc-body { font-size: 1.08rem; color: var(--ink-soft); }
.sc-quote { font-family: var(--script); color: var(--sea-deep); font-size: 1.8rem; margin-top: 1.2rem; }

/* ============================================================
   WAVE DIVIDER (full width)
   ============================================================ */
.wave-divider { padding: 1.5rem 1.6rem; display: flex; justify-content: center; }
.wave-divider svg { width: min(680px, 92%); height: 40px; color: var(--brass); }
.wave-divider path { stroke-dasharray: 1; stroke-dashoffset: 1; }
.wave-divider.in path { animation: drawIn 2.2s var(--ease) forwards; }

/* ============================================================
   SCROLLYTELLING
   ============================================================ */
.scrolly { position: relative; }
.scrolly-track { position: relative; }
.scrolly-sticky { position: sticky; top: 0; height: 100svh; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.scrolly-sticky img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.08); will-change: transform; }
.scrolly-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,32,38,0.32), rgba(20,32,38,0.55)); }
.scrolly-frame { position: absolute; inset: 22px; border: 1px solid rgba(255,255,255,0.3); z-index: 2; pointer-events: none; }
.scrolly-caps { position: relative; z-index: 3; text-align: center; color: #fff; }
.scrolly-cap { position: absolute; left: 50%; top: 50%; transform: translate(-50%, calc(-50% + 28px)); width: max-content; max-width: 86vw; font-weight: 500; font-size: clamp(2.2rem, 8vw, 4rem); line-height: 1.1; opacity: 0; transition: opacity 0.5s ease, transform 0.7s var(--ease); text-shadow: 0 4px 30px rgba(0,0,0,0.4); }
.scrolly-cap .ix { display: block; font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.4em; opacity: 0.7; margin-bottom: 0.8rem; }
.scrolly-cap.active { opacity: 1; transform: translate(-50%, -50%); }
.scrolly-ticks { position: absolute; right: 1.4rem; top: 50%; transform: translateY(-50%); z-index: 3; display: flex; flex-direction: column; gap: 0.6rem; }
.scrolly-ticks .tk { width: 8px; height: 8px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.6); }
.scrolly-ticks .tk.on { background: #fff; }

/* ============================================================
   COUNTDOWN
   ============================================================ */
.count { position: relative; min-height: 76svh; display: flex; align-items: center; justify-content: center; overflow: hidden; text-align: center; }
.count-img { position: absolute; inset: -10% 0; width: 100%; height: 120%; object-fit: cover; will-change: transform; }
.count-veil { position: absolute; inset: 0; background: rgba(20,32,38,0.52); }
.count-inner { position: relative; z-index: 2; color: #fff; padding: 3rem 1.5rem; }
.count-grid { display: flex; justify-content: center; gap: clamp(0.6rem, 4vw, 2.4rem); margin-top: 1.6rem; }
.cd-cell { min-width: clamp(62px, 16vw, 96px); position: relative; padding-top: 1.2rem; }
.cd-cell + .cd-cell::before { content: ""; position: absolute; left: -0.8rem; top: 50%; width: 1px; height: 40px; background: rgba(255,255,255,0.25); transform: translateY(-30%); }
.cd-num { font-weight: 500; font-size: clamp(2.4rem, 9vw, 4rem); line-height: 1; }
.cd-lab { font-family: var(--sans); font-size: 0.58rem; letter-spacing: 0.26em; text-transform: uppercase; opacity: 0.85; margin-top: 0.5rem; }

/* ============================================================
   SCHEDULE timeline
   ============================================================ */
.sched { position: relative; max-width: 560px; margin: 2.6rem auto 0; }
.sched::before { content: ""; position: absolute; left: 7px; top: 6px; bottom: 6px; width: 1px; background: var(--line); }
.sched-row { position: relative; display: grid; grid-template-columns: 1fr auto; gap: 0.6rem 1.4rem; padding: 0 0 2rem 2.4rem; text-align: left; }
.sched-row:last-child { padding-bottom: 0; }
.sched-row::before { content: ""; position: absolute; left: 0; top: 0.5rem; width: 15px; height: 15px; border-radius: 50%; border: 1px solid var(--brass); background: var(--paper); }
.sched-row::after { content: ""; position: absolute; left: 4px; top: calc(0.5rem + 4px); width: 7px; height: 7px; border-radius: 50%; background: var(--brass); transform: scale(0); transition: transform 0.5s var(--ease) var(--td, 0s); }
.sched.in .sched-row::after { transform: scale(1); }
.sched-name { font-size: 1.35rem; font-weight: 500; }
.sched-time { font-family: var(--sans); font-size: 0.72rem; letter-spacing: 0.16em; color: var(--sea-deep); white-space: nowrap; padding-top: 0.5rem; }
.sched-detail { grid-column: 1 / -1; font-size: 0.95rem; color: var(--ink-soft); font-style: italic; }

/* ============================================================
   VENUE
   ============================================================ */
.venue { text-align: center; }
.venue-photo { position: relative; overflow: hidden; aspect-ratio: 16/10; max-width: 900px; margin: 2rem auto 0; border: 9px solid #fff; box-shadow: 0 34px 70px rgba(35,54,64,0.2); }
.venue-photo::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px var(--line); pointer-events: none; }
.venue-photo img { position: absolute; inset: -8% 0; width: 100%; height: 116%; object-fit: cover; will-change: transform; }
.venue-name { font-weight: 500; font-size: clamp(1.7rem, 4.5vw, 2.3rem); margin-top: 1.6rem; }
.venue-addr { font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ink-soft); margin-top: 0.3rem; }
.venue-note { font-size: 1rem; color: var(--ink-soft); font-style: italic; max-width: 520px; margin: 1.1rem auto 0; }

.btn { position: relative; display: inline-block; margin-top: 1.7rem; font-family: var(--sans); font-size: 0.66rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--sea-deep); border: 1px solid var(--sea-deep); padding: 0.9rem 2.2rem; text-decoration: none; overflow: hidden; z-index: 1; transition: color 0.4s ease; }
.btn::before { content: ""; position: absolute; inset: 0; background: var(--sea-deep); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease); z-index: -1; }
.btn:hover { color: #fff; }
.btn:hover::before { transform: scaleX(1); }

/* ============================================================
   INSTAGRAM
   ============================================================ */
.gram { text-align: center; }
.gram-handle { font-family: var(--sans); font-size: 0.84rem; letter-spacing: 0.1em; color: var(--sea-deep); margin-top: 0.5rem; }
.gram-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(6px, 1.3vw, 13px); margin-top: 2rem; }
.gram-tile { position: relative; overflow: hidden; aspect-ratio: 1; opacity: 0; transform: scale(0.9) translateY(20px); transition: opacity 0.7s var(--ease), transform 0.8s var(--ease); transition-delay: var(--gd, 0s); }
.gram-grid.in .gram-tile { opacity: 1; transform: none; }
.gram-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease); }
.gram-tile:hover img { transform: scale(1.1); }
.gram-tile::after { content: "♡ @" attr(data-h); position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.12em; background: rgba(35,54,64,0.0); opacity: 0; transition: 0.4s; }
.gram-tile:hover::after { background: rgba(35,54,64,0.42); opacity: 1; }

/* ============================================================
   DETAILS
   ============================================================ */
.details-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.4rem,4vw,2.4rem); position: relative; z-index: 1; }
.detail { background: #fff; border: 1px solid var(--line); padding: clamp(2rem,4vw,2.8rem); text-align: center; }
.detail .em { width: 40px; height: 40px; margin: 0 auto 1rem; color: var(--brass-deep); }
.detail h3 { font-weight: 500; font-size: 1.4rem; }
.detail h3::after { content: ""; display: block; width: 30px; height: 1px; background: var(--sea); margin: 0.7rem auto 0.9rem; }
.detail p { font-size: 0.98rem; color: var(--ink-soft); font-style: italic; }

/* ============================================================
   RSVP
   ============================================================ */
.rsvp { position: relative; overflow: hidden; }
.rsvp-img { position: absolute; inset: -10% 0; width: 100%; height: 120%; object-fit: cover; will-change: transform; }
.rsvp-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,32,38,0.42), rgba(20,32,38,0.7)); }
.rsvp-inner { position: relative; z-index: 2; text-align: center; }
.rsvp-card { max-width: 480px; margin: 2rem auto 0; background: rgba(255,255,255,0.96); backdrop-filter: blur(6px); padding: clamp(2rem,5vw,2.8rem); text-align: left; box-shadow: 0 40px 80px rgba(0,0,0,0.35); border: 1px solid rgba(255,255,255,0.5); }
.rsvp-card-em { width: 38px; height: 38px; margin: 0 auto 1.2rem; color: var(--brass-deep); }
.r-field { margin-bottom: 1.2rem; }
.r-field label { display: block; font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 0.4rem; }
.r-field input, .r-field select, .r-field textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line); border-radius: 0; font-family: var(--serif); font-size: 1.08rem; color: var(--ink); padding: 0.45rem 0.1rem; transition: border-color 0.3s; }
.r-field input:focus, .r-field select:focus, .r-field textarea:focus { outline: none; border-color: var(--sea); }
.r-field textarea { min-height: 70px; resize: vertical; }
.r-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.attend-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem; margin-bottom: 1.2rem; }
.attend-btn { background: none; border: 1px solid var(--line); font-family: var(--serif); font-style: italic; font-size: 1rem; color: var(--ink-soft); padding: 0.8rem 0.5rem; cursor: pointer; transition: 0.3s; }
.attend-btn.selected { border-color: var(--sea); color: var(--ink); background: rgba(111,159,176,0.12); }
.rsvp-submit { position: relative; width: 100%; background: var(--sea-deep); border: 1px solid var(--sea-deep); color: #fff; font-family: var(--sans); font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase; padding: 1rem; cursor: pointer; margin-top: 0.3rem; overflow: hidden; z-index: 1; transition: color 0.4s; }
.rsvp-submit::before { content: ""; position: absolute; inset: 0; background: var(--brass-deep); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease); z-index: -1; }
.rsvp-submit:hover:not(:disabled) { color: #fff; }
.rsvp-submit:hover:not(:disabled)::before { transform: scaleX(1); }
.rsvp-submit:disabled { opacity: 0.5; cursor: wait; }
.rsvp-deadline { color: #e9f0f2; font-style: italic; margin-top: 1.4rem; position: relative; z-index: 2; }
.rsvp-status { margin-top: 1rem; text-align: center; font-size: 0.92rem; display: none; font-family: var(--sans); }
.rsvp-status.ok { display: block; color: #3c6b4f; }
.rsvp-status.err { display: block; color: #a05252; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { text-align: center; padding: clamp(4rem,10vw,7rem) 1.5rem 4rem; }
.foot-em { width: 54px; height: 54px; margin: 0 auto 1.4rem; color: var(--brass-deep); }
.foot-script { font-family: var(--script); font-size: clamp(2.4rem,8vw,3.6rem); color: var(--sea-deep); }
.foot-brand { font-family: var(--sans); font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-soft); margin-top: 1.6rem; }
.foot-brand a { color: var(--brass-deep); text-decoration: none; }

/* admin */
.admin-panel { position: fixed; inset: auto 0 0 0; z-index: 600; background: #fff; border-top: 2px solid var(--sea-deep); padding: 1.4rem 1.6rem 1.8rem; max-height: 50vh; overflow: auto; display: none; font-family: var(--sans); }
.admin-panel.show { display: block; }
.admin-panel h3 { font-family: var(--serif); margin-bottom: 0.7rem; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
.admin-table th, .admin-table td { border: 1px solid var(--line); padding: 0.45rem 0.65rem; text-align: left; }
.admin-table th { color: var(--sea-deep); font-weight: 400; letter-spacing: 0.08em; text-transform: uppercase; font-size: 0.66rem; }
.admin-actions { margin-top: 0.9rem; display: flex; gap: 0.8rem; }
.admin-actions button { background: none; border: 1px solid var(--ink); color: var(--ink); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; padding: 0.5rem 1.2rem; cursor: pointer; }

@media (max-width: 720px) {
  .story-chapter { grid-template-columns: 1fr; }
  .story-chapter.flip .sc-media { order: 0; }
  .sc-frame { max-width: 420px; margin: 0 auto; }
  .sc-no { left: 0.2em; }
  .story-chapter.flip .sc-no { right: auto; left: 0.2em; }
  .details-grid { grid-template-columns: 1fr; }
  .cover-side { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .cover-img, .scrolly-sticky img { transform: none; }
  .reveal, .gram-tile, .cover-emblem, .cover-date { opacity: 1 !important; transform: none !important; }
  .cover-names .mask span, .words .word > span { transform: none !important; }
  .cover-rule { width: 120px !important; }
  .sc-frame::before { transform: translateY(-101%) !important; }
  .emblem .draw, .divider .wave path, .wave-divider path { stroke-dashoffset: 0 !important; animation: none !important; }
  .sc-frame img, .count-img, .venue-photo img, .rsvp-img { position: absolute; inset: 0; height: 100%; }
}
