*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root {
  --bg: #F8F5F0;
  --bg-warm: #F2EDE6;
  --bg-card: #FDFBF8;
  --text: #2D2926;
  --text-mid: #5C4F46;
  --text-light: #8A7B6F;
  --accent: #B8877A;
  --accent-soft: rgba(184,135,122,0.10);
  --accent-glow: rgba(184,135,122,0.06);
  --border: #E4DDD4;
  --border-light: #EDE8E1;
  --seal: #A0675A;
  --seal-dark: #7D4F44;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Outfit', -apple-system, sans-serif;
  --hand: 'Caveat', cursive;
}

html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);font-weight:300;color:var(--text);background:var(--bg);line-height:1.6;min-height:100dvh;overflow-x:hidden}

body::before{content:'';position:fixed;inset:0;pointer-events:none;opacity:0.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;z-index:9999}

/* ═══ SEAL ═══ */
.seal-overlay{position:fixed;inset:0;z-index:10000;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity 0.6s ease,visibility 0.6s ease}
.seal-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.seal-prompt{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.1rem;color:var(--text-light);margin-bottom:2.5rem;
  opacity:0;animation:seal-fade-in 1s 0.5s ease both}
.seal{width:120px;height:120px;cursor:pointer;position:relative;
  opacity:0;animation:seal-fade-in 0.8s 0.2s ease both;
  -webkit-tap-highlight-color:transparent}
.seal:active{transform:scale(0.95)}
.seal-circle{width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--accent),var(--seal) 50%,var(--seal-dark) 100%);
  box-shadow:0 4px 20px rgba(125,79,68,0.25),inset 0 2px 4px rgba(255,255,255,0.15),inset 0 -2px 6px rgba(0,0,0,0.15);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transition:transform 0.15s ease}
.seal:hover .seal-circle{transform:scale(1.03)}
.seal-letter{font-family:var(--serif);font-weight:500;font-size:2.8rem;
  color:rgba(255,255,255,0.85);line-height:1;margin-top:-2px;
  text-shadow:0 1px 2px rgba(0,0,0,0.15)}
.seal-year{font-family:var(--serif);font-weight:300;font-size:0.7rem;
  color:rgba(255,255,255,0.55);letter-spacing:0.2em;margin-top:2px}
.seal-circle::before{content:'';position:absolute;inset:8px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.12)}
.seal-circle::after{content:'';position:absolute;inset:14px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.08)}
.seal-tap-hint{font-family:var(--sans);font-weight:300;font-size:0.7rem;
  color:var(--text-light);letter-spacing:0.08em;text-transform:lowercase;
  margin-top:2rem;opacity:0;animation:seal-fade-in 1s 1.2s ease both}

@keyframes seal-break-left{
  0%{transform:translate(0) rotate(0);opacity:1}
  100%{transform:translate(-60px,30px) rotate(-15deg);opacity:0}}
@keyframes seal-break-right{
  0%{transform:translate(0) rotate(0);opacity:1}
  100%{transform:translate(60px,20px) rotate(12deg);opacity:0}}
@keyframes seal-fade-in{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}}

.seal.breaking .seal-circle{animation:seal-break-right 0.5s ease-in forwards}
.seal.breaking::after{content:'';position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--accent),var(--seal) 50%,var(--seal-dark) 100%);
  box-shadow:0 4px 20px rgba(125,79,68,0.25);
  animation:seal-break-left 0.5s ease-in forwards;
  clip-path:polygon(0 0,55% 0,45% 100%,0 100%)}

/* ═══ LAYOUT ═══ */
.views{position:relative}
.view{display:none;max-width:480px;margin:0 auto;padding:2rem 1.25rem 7rem;min-height:100dvh}
.view.active{display:block}
@media(min-width:520px){.view{padding:2.5rem 2rem 7rem}}
@media(min-width:768px){.view{max-width:540px}}

/* ═══ NAV ═══ */
.nav{position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:rgba(248,245,240,0.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--border-light);transition:transform 0.4s ease}
.nav.nav-hidden{transform:translateY(100%)}
.nav-inner{display:flex;max-width:480px;margin:0 auto}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:0.6rem 0 0.75rem;background:none;border:none;cursor:pointer;
  font-family:var(--sans);font-size:0.65rem;font-weight:400;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--text-light);transition:color 0.3s}
.nav-btn.active{color:var(--accent)}
.nav-btn svg{transition:opacity 0.3s;opacity:0.45}
.nav-btn.active svg{opacity:1}
.nav-dot{width:3px;height:3px;border-radius:50%;background:var(--accent);
  opacity:0;transition:opacity 0.3s;margin-top:1px}
.nav-btn.active .nav-dot{opacity:1}

/* ═══ HEADER ═══ */
.header{text-align:center;padding:3.5rem 0 2.5rem}
.header-name{font-family:var(--serif);font-weight:300;font-size:clamp(3.4rem,13vw,5rem);
  letter-spacing:0.03em;color:var(--text);line-height:0.95}
.header-sub{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.05rem;color:var(--text-light);margin-top:0.75rem}
.header-line{width:32px;height:1.5px;background:var(--accent);margin:1.2rem auto 0;opacity:0.7}

.prelaunch{text-align:center;padding:3rem 0}
.prelaunch-text{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.3rem;color:var(--text-mid);line-height:1.5;margin-bottom:2rem}
.countdown{font-family:var(--serif);font-weight:300;color:var(--text-light);letter-spacing:0.02em}
.countdown-big{font-size:clamp(1.5rem,4.5vw,2rem);color:var(--text-mid);margin-bottom:0.25rem}
.countdown-label{font-family:var(--sans);font-size:0.7rem;font-weight:300;
  color:var(--text-light);text-transform:lowercase;letter-spacing:0.08em}

/* ═══ ALBUM ═══ */
.day-section{margin-bottom:3.5rem}
.day-header{margin-bottom:1.8rem}
.day-date{font-family:var(--sans);font-weight:400;font-size:0.7rem;color:var(--text-light);
  text-transform:uppercase;letter-spacing:0.14em;margin-bottom:0.4rem}
.day-message{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.3rem,4vw,1.55rem);color:var(--text);line-height:1.4}

.photos-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem}
.photo-frame{position:relative;overflow:hidden;background:var(--bg-warm);border-radius:2px;line-height:0}
.photo-frame img{width:100%;height:auto;display:block;opacity:0;transition:opacity 0.6s ease}
.photo-frame img.loaded{opacity:1}
.photo-frame .placeholder{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:0.65rem;color:var(--text-light);letter-spacing:0.04em}
.photo-caption{font-family:var(--hand);font-size:1.05rem;font-weight:400;
  color:var(--text-mid);margin-top:0.35rem;line-height:1.3}

/* ═══ LOCKED DAY ═══ */
.day-locked{text-align:center;padding:2rem 1.2rem;margin-bottom:1.5rem;
  border:1px solid var(--border);border-radius:4px;position:relative;overflow:hidden;
  background:var(--bg-card)}
.day-locked::before{content:'';position:absolute;inset:0;opacity:0.35;
  background:repeating-linear-gradient(120deg,transparent,transparent 6px,var(--border-light) 6px,var(--border-light) 7px)}
.day-locked-date{font-family:var(--sans);font-weight:400;font-size:0.7rem;
  color:var(--text-light);text-transform:uppercase;letter-spacing:0.14em;
  margin-bottom:0.2rem;position:relative}
.day-locked-hint{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.1rem;color:var(--text-mid);margin-bottom:0.8rem;position:relative}
.day-locked-cd{position:relative;display:inline-flex;align-items:baseline;gap:0.6rem;
  font-family:var(--serif);font-weight:300}
.day-locked-cd .cd-num{font-size:1.6rem;color:var(--text);line-height:1;letter-spacing:0.02em}
.day-locked-cd .cd-unit{font-size:0.7rem;color:var(--text-light);
  font-family:var(--sans);text-transform:lowercase;letter-spacing:0.06em}
.day-locked-cd .cd-sep{color:var(--border);font-size:1rem}

/* ═══ SCHEDULE ═══ */
.schedule-header{text-align:center;padding:3rem 0 0.5rem}
.schedule-title{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,8vw,3rem);
  color:var(--text);line-height:1;letter-spacing:0.02em}
.schedule-subtitle{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:1.1rem;color:var(--text-light);margin-top:0.6rem}
.bday-badge{display:inline-flex;align-items:center;gap:0.4rem;
  padding:0.35rem 1rem;border:1px solid var(--border);border-radius:20px;
  font-family:var(--hand);font-size:1.15rem;font-weight:500;color:var(--accent);
  margin-top:1.2rem;background:var(--bg-card)}
.schedule-teaser{text-align:center;padding:2.5rem 0}

/* Timeline */
.timeline{position:relative;padding:2rem 0 1rem}
.timeline::before{content:'';position:absolute;top:0;bottom:0;left:22px;width:1px;background:var(--border)}

.step{position:relative;padding-left:56px;margin-bottom:2rem}
.step-dot{position:absolute;left:11px;top:6px;width:23px;height:23px;
  border-radius:50%;background:var(--bg);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;transition:all 0.5s ease;z-index:2}
.step.unlocked .step-dot{border-color:var(--accent);background:var(--accent)}
.step-dot svg{width:11px;height:11px}
.step-time{font-family:var(--serif);font-weight:400;font-size:clamp(1.4rem,4.5vw,1.7rem);
  color:var(--text);line-height:1;margin-bottom:0.25rem}
.step-hint{font-family:var(--serif);font-style:italic;font-weight:300;font-size:1rem;color:var(--text-light)}
.step-countdown{font-family:var(--sans);font-weight:300;font-size:0.75rem;
  color:var(--text-light);margin-top:0.4rem;letter-spacing:0.02em;
  display:flex;align-items:center;gap:0.3rem}
.step-countdown::before{content:'';display:inline-block;width:8px;height:8px;
  border:1px solid var(--border);border-radius:50%;flex-shrink:0}

.step-card{margin-top:0.75rem;padding:1rem 1.15rem;background:var(--bg-card);
  border:1px solid var(--border-light);border-radius:6px;animation:card-appear 0.5s ease both}
.step-card-title{font-family:var(--sans);font-weight:500;font-size:0.95rem;color:var(--text);margin-bottom:0.15rem}
.step-card-details{font-family:var(--sans);font-weight:300;font-size:0.88rem;color:var(--text-mid);margin-bottom:0.4rem}
.step-card-address{display:inline-flex;align-items:center;gap:0.3rem;
  font-family:var(--sans);font-weight:300;font-size:0.82rem;color:var(--accent);
  text-decoration:none;border-bottom:1px solid transparent;transition:border-color 0.2s}
.step-card-address:hover{border-bottom-color:var(--accent)}
.step-card-address svg{width:12px;height:12px;flex-shrink:0}
.step-card-note{font-family:var(--hand);font-size:1.1rem;font-weight:400;
  color:var(--text-mid);margin-top:0.5rem;line-height:1.3}

.step-locked-card{margin-top:0.75rem;padding:0.8rem 1rem;
  border:1px dashed var(--border);border-radius:6px;text-align:center;
  background:repeating-linear-gradient(135deg,transparent,transparent 8px,var(--accent-glow) 8px,var(--accent-glow) 9px)}
.step-locked-text{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:0.9rem;color:var(--text-light)}
.step-locked-cd{display:inline-flex;align-items:baseline;gap:0.4rem;
  font-family:var(--serif);font-weight:300}
.step-locked-cd .cd-num{font-size:1.35rem;color:var(--text);line-height:1;letter-spacing:0.02em}
.step-locked-cd .cd-unit{font-size:0.65rem;color:var(--text-light);
  font-family:var(--sans);text-transform:lowercase;letter-spacing:0.06em}
.step-locked-cd .cd-sep{color:var(--border);font-size:0.85rem}

@keyframes card-appear{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}

/* ═══ REVEAL ═══ */
.reveal{opacity:0;transform:translateY(14px);transition:opacity 0.5s ease,transform 0.5s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.rstagger>.reveal:nth-child(1){transition-delay:0s}
.rstagger>.reveal:nth-child(2){transition-delay:0.06s}
.rstagger>.reveal:nth-child(3){transition-delay:0.12s}
.rstagger>.reveal:nth-child(4){transition-delay:0.18s}
.rstagger>.reveal:nth-child(5){transition-delay:0.24s}
.rstagger>.reveal:nth-child(6){transition-delay:0.3s}
.rstagger>.reveal:nth-child(7){transition-delay:0.36s}
.rstagger>.reveal:nth-child(8){transition-delay:0.42s}

.footer{text-align:center;padding:3rem 0 1.5rem}
.footer-text{font-family:var(--hand);font-weight:500;font-size:1.3rem;color:var(--text-light)}

.countdown,.step-countdown,.day-locked{user-select:none}
a{color:inherit}
