:root{
  --cream:#FAF5E6;
  --ink:#1b1b1b;
  --ink-soft:rgba(27,27,27,.7);
  --badge-bg:rgba(255,255,255,.55);
  --border:rgba(0,0,0,.12);
}

*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--ink);
  background: var(--cream);
}

/* Reel scroll container */
.reel{
  height:100svh;
  overflow-y:scroll;
  scroll-snap-type:y mandatory;
  scroll-behavior:auto; /* we simulate slide via snap */
  background: var(--cream);
  position:relative;
}

/* Paper grain overlay */
.grain{
  position:fixed; inset:0; pointer-events:none; opacity:.3; mix-blend:multiply;
  background-image: radial-gradient(rgba(0,0,0,.03) 1px, transparent 1px);
  background-size:4px 4px;
}

/* Fullscreen panels */
/* Viewport-safe height to reduce mobile URL-bar jumps */
.panel{
  position:relative;
  height:100svh;              /* modern browsers */
  height:100vh;               /* fallback */
  min-height: 100vh;
  width:100%;
  scroll-snap-align:start;
  scroll-snap-stop: always; 
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}

/* Base image styles (no crop animations by default) */
.panel-bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-position:center center;
  opacity:0;
  transition:opacity 900ms ease-out, transform 900ms ease-out;
  background: var(--cream);           /* shows behind letterbox/pillarbox */
}

/* NEW: keep full image visible, maintain aspect ratio */
.panel-bg.fit-contain{
  object-fit: contain;     
  object-position: center var(--imgY, 35%);            /* <— key change */
  transform: translateY(6px);                      /* avoid zoom that could clip edges */
}

/* If you still want a tiny reveal motion without cropping, use <=1.0 scale */
.panel-bg.fit-contain.in-view{
  opacity:1;
  transform: translateY(0);              /* do not exceed 1.00 to prevent crop */
}

/* Vignette & cream wash */
.vignette{ position:absolute; inset:0; box-shadow: inset 0 0 200px rgba(0,0,0,.25); }
.panel::before{ content:""; position:absolute; inset:0; background:rgba(250,245,230,.30); }

/* Content */
.center{ text-align:center; }
.panel-content{ position:relative; z-index:2; padding:1rem; }

.title{
  font-family: 'Cormorant Garamond', serif;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:600;
  font-size: clamp(28px, 5vw, 56px);
  margin:0 0 .5rem;
}
.subtitle{
  font-family: 'Cormorant Garamond', serif;
  font-style:italic;
  font-size: clamp(16px, 2.6vw, 28px);
  opacity:.9;
  max-width:48ch; margin:0 auto;
}

/* Scroll hint */
.scroll-hint{ margin-top:1rem; color:var(--ink-soft); display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.scroll-hint span{ text-transform:uppercase; letter-spacing:.3em; font-size:12px; }
.scroll-hint .rule{ width:1px; height:32px; background:rgba(0,0,0,.4); }

/* Label badge */
.badge{
  backdrop-filter: blur(6px);
  background: var(--badge-bg);
  border: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  padding: .9rem 1.1rem;
  border-radius: 16px;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(18px, 2.4vw, 28px);
}

/* Panel index (subtle) */
.panel-index{
  position:absolute; right:16px; bottom:14px;
  font-size:10px; letter-spacing:.3em; text-transform:uppercase; opacity:.7;
}

/* Footer */
.footer{
  height:40vh; display:flex; align-items:center; justify-content:center;
  background:var(--cream);
}
.footer-inner{ text-align:center; }
.footer-line.serif{ font-family: 'Cormorant Garamond', serif; font-size:20px; }
.footer-line.small{ font-size:12px; opacity:.7; margin-top:.3rem; }

/* Reduced motion support */
@media (prefers-reduced-motion: reduce){
  .panel-bg, .fade-in{ transition:none !important; animation:none !important; }
}

/* Ensure background images "parallax-lite" when entering view */
.parallax.in-view{ transform:none !important; }

html, body { height: 100%; }
body { overflow: hidden; }  /* let .reel be the only scroller */

/* ---------- Scroll indicators ---------- */
.indicator {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  background: none;
  border: none;
  cursor: pointer;
  opacity: 0;
  transition: opacity .3s ease;
  z-index: 50;
  padding: 4px;
  pointer-events: none;
  
}

.indicator-up   { top: 24px; }
.indicator-down { bottom: 32px; }

.indicator .triangle {
  width: 28px; height: 28px;
  fill: none;
  stroke: rgba(0,0,0,0.45);
  stroke-width: 5;
  stroke-linejoin: round;
  transform-origin: 50% 50%;
  transform: rotate(var(--rot, 0deg));
  transition: stroke .25s ease, transform .25s ease;
  pointer-events: auto;
}
.triangle.down { --rot: 0deg; }
.triangle.up   { --rot: 180deg; }

.indicator:hover .triangle,
.indicator:focus .triangle {
  stroke: rgba(0,0,0,0.7);
  transform: rotate(var(--rot, 0deg)) scale(1.1);
}

.indicator.visible { opacity: 1; }

/* Pulse animations (translation only) */
@keyframes pulseDown {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%     { transform: translateX(-50%) translateY(6px); }
}
@keyframes pulseUp {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%     { transform: translateX(-50%) translateY(-6px); }
}
.indicator-down.visible { animation: pulseDown 2.4s ease-in-out infinite; }
.indicator-up.visible   { animation: pulseUp   2.4s ease-in-out infinite; }

/* -------- Language toggle (top-right) -------- */
.lang-toggle{
  position: fixed;
  top: 18px;
  right: 14px;
  z-index: 60;
  padding: 6px 10px;
  background: transparent;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 12px;
  cursor: pointer;
  opacity: 0;                /* same visibility behavior as indicators */
  transition: opacity .3s ease, transform .2s ease, border-color .2s ease, background-color .2s ease;
  font-family: 'Great Vibes', cursive;
  font-size: 22px;
  line-height: 1;
  color: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  background-color: rgba(255,255,255,0.35);
}

.lang-toggle:hover,
.lang-toggle:focus{
  transform: translateY(-1px);
  border-color: rgba(0,0,0,0.25);
  background-color: rgba(255,255,255,0.5);
}

.lang-toggle.visible{ opacity: 1; }

/* Smooth cross-fade when swapping sources */
.panel-bg.crossfade{
  transition: opacity 250ms ease;
}
.panel-bg.crossfade.fading-out{ opacity: 0; }
/* Safety so scrolling fades work independently of crossfade */
.panel-bg     { opacity: 0; transition: opacity 900ms ease-out, transform 900ms ease-out; }
.panel-bg.in-view { opacity: 1; }  /* fades in on every entry because of (A) */

/* -------- RSVP button (top-left) -------- */
.rsvp-button{
  position: fixed;
  top: 18px;
  left: 14px;
  z-index: 60;
  padding: 6px 12px;
  background: transparent;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 12px;
  cursor: pointer;
  opacity: 0;
  transition: opacity .3s ease, transform .2s ease, border-color .2s ease, background-color .2s ease;
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  line-height: 1;
  color: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  background-color: rgba(255,255,255,0.35);
}

.rsvp-button:hover,
.rsvp-button:focus{
  transform: translateY(-1px);
  border-color: rgba(0,0,0,0.25);
  background-color: rgba(255,255,255,0.5);
}

.rsvp-button.visible{ 
  opacity: 1; 
}
