:root{--cream:#f7efde;--cream-2:#fbf6ea;--gold:#b8975a;--gold-deep:#8a6d3a;--ink:#3a2f20;--line:#d9c79a}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0;overflow-x:hidden}html{height:100dvh}body{color:var(--ink);-webkit-font-smoothing:antialiased;background:linear-gradient(#efe6d2 0%,#f7efde 50%,#efe6d2 100%);min-height:100dvh;font-family:Cormorant Garamond,Georgia,serif}.page{justify-content:center;align-items:center;min-height:100dvh;padding:14px;display:flex}.card{flex-direction:column;width:min(560px,100%);max-height:96dvh;display:flex}.card-hidden{opacity:0;pointer-events:none;transform:translateY(20px)scale(.96)}.card-open{animation:1.1s cubic-bezier(.2,.8,.2,1) .25s both cardReveal}@keyframes cardReveal{0%{opacity:0;transform:translateY(40px)scale(.94)}60%{opacity:1}to{opacity:1;transform:translateY(0)scale(1)}}.cover{z-index:100;cursor:pointer;background:linear-gradient(#efe6d2 0%,#f7efde 50%,#efe6d2 100%);border:none;justify-content:center;align-items:center;padding:18px;font-family:Cinzel,serif;display:flex;position:fixed;inset:0}.cover[aria-label]:focus{outline:none}.cover:active .cover-inner{transform:scale(.985)}.cover-opening{animation:1.2s cubic-bezier(.7,0,.3,1) forwards coverOpen}@keyframes coverOpen{0%{opacity:1;transform:translateY(0)}55%{opacity:1;transform:translateY(-6%)rotateX(-4deg)}to{opacity:0;pointer-events:none;visibility:hidden;transform:translateY(-110%)rotateX(-25deg)}}.cover-inner{aspect-ratio:3/4.2;text-align:center;background:#f5ecd9;border:2px solid #c33a2b;border-radius:10px;flex-direction:column;justify-content:space-between;align-items:center;width:min(440px,92vw);max-height:88dvh;padding:60px 30px 36px;transition:transform .15s;display:flex;position:relative;box-shadow:0 30px 60px -30px #503c1466}.cover-inner:before{content:"";background:#f5ecd9;border:2px solid #c33a2b;border-top:none;border-radius:0 0 40px 40px;width:70px;height:32px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.cover-monogram{align-items:center;gap:14px;margin-top:40px;display:flex}.cover-monogram span{color:var(--gold);font-family:Cinzel,serif;font-size:clamp(72px,18vw,110px);font-weight:500;line-height:1}.cover-bar{background:var(--gold);align-self:center;width:2px;height:.8em}.cover-tagline{letter-spacing:.18em;color:var(--gold-deep);margin-top:18px;font-size:13px;line-height:1.7}.cover-date{letter-spacing:.18em;color:var(--gold-deep);margin-top:16px;font-family:Cormorant Garamond,serif;font-size:18px}.cover-sn{border:1.5px solid var(--gold);letter-spacing:.2em;width:80%;color:var(--gold-deep);text-align:left;border-radius:999px;margin-top:auto;padding:10px 16px;font-size:13px}.cover-hint{color:var(--gold);opacity:.7;margin-top:14px;font-family:Cormorant Garamond,serif;font-size:13px;font-style:italic;animation:1.8s ease-in-out infinite hintPulse}@keyframes hintPulse{0%,to{opacity:.5}50%{opacity:1}}@media (width<=420px){.cover-inner{padding:50px 22px 28px}}.intro-stage{z-index:200;background:linear-gradient(#f3d9a8 0%,#efc88a 45%,#d9a86c 75%,#b8835a 100%);justify-content:center;align-items:flex-end;transition:opacity .6s;display:flex;position:fixed;inset:0;overflow:hidden}.intro-fade{opacity:0}.intro-sky{pointer-events:none;position:absolute;inset:0}.intro-sun{filter:blur(2px);background:radial-gradient(circle,#fff4d4 0%,#ffd98a 55%,#ffd98a00 75%);border-radius:50%;width:160px;height:160px;animation:3s ease-in-out infinite sunPulse;position:absolute;top:18%;left:50%;transform:translate(-50%)}@keyframes sunPulse{0%,to{opacity:.95;transform:translate(-50%)scale(1)}50%{opacity:1;transform:translate(-50%)scale(1.05)}}.intro-dragon{filter:drop-shadow(0 10px 20px #14080c80);transform-origin:50%;width:clamp(180px,36vw,320px);animation:5s cubic-bezier(.55,0,.85,.8) forwards dragonApproach;position:absolute;top:40%;left:50%}.dragon-svg{width:100%;height:auto;display:block}.dwing{transform-origin:160px 120px;animation:.5s ease-in-out infinite wingFlap}@keyframes wingFlap{0%,to{transform:scaleY(1)scaleX(1)}50%{transform:scaleY(.4)scaleX(.92)}}.dragon-fire{transform-origin:160px 70px;animation:.16s ease-in-out infinite fireFlicker}@keyframes fireFlicker{0%,to{opacity:.95;transform:scaleX(1)scaleY(1)}50%{opacity:1;transform:scaleX(.85)scaleY(1.15)}}@keyframes dragonApproach{0%{opacity:0;transform:translate(-50%,-50%)scale(.08)}10%{opacity:1}60%{opacity:1;transform:translate(-50%,-50%)scale(1.2)}85%{opacity:1;transform:translate(-50%,-50%)scale(6)}to{opacity:0;transform:translate(-50%,-50%)scale(14)}}.intro-hills{background:radial-gradient(at 20% 100%,#8a6d3a 0%,#0000 60%),radial-gradient(at 80% 100%,#6e5530 0%,#0000 55%),linear-gradient(#0000 0%,#5a4624 100%);height:38%;position:absolute;bottom:0;left:0;right:0}.intro-actors{justify-content:center;align-items:flex-end;gap:clamp(12px,4vw,40px);width:100%;height:50%;padding:0 16px 10%;animation:5s linear forwards actorsTravel;display:flex;position:relative}@keyframes actorsTravel{0%{opacity:1;transform:translate(-12%)}70%{opacity:1;transform:translate(6%)}to{opacity:0;transform:translate(8%)}}.intro-rider{filter:drop-shadow(0 8px 12px #00000040);flex:none;width:clamp(170px,42vw,320px);animation:.55s ease-in-out infinite riderBob}@keyframes riderBob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.intro-rider .hleg{transform-origin:top;animation:.55s ease-in-out infinite hlegStep}.intro-rider .hleg.fl,.intro-rider .hleg.br{animation-delay:0s}.intro-rider .hleg.fr,.intro-rider .hleg.bl{animation-delay:.275s}@keyframes hlegStep{0%,to{transform:rotate(-10deg)}50%{transform:rotate(15deg)}}.intro-rider .veil{transform-origin:70px 30px;animation:1.4s ease-in-out infinite veilWave}@keyframes veilWave{0%,to{transform:rotate(-2deg)}50%{transform:rotate(4deg)}}.intro-groom{filter:drop-shadow(0 6px 8px #00000040);flex:none;align-self:flex-end;width:clamp(60px,14vw,110px)}.intro-groom .leg-front,.intro-groom .leg-back,.intro-groom .arm-front,.intro-groom .arm-back{transform-origin:top;animation:.5s ease-in-out infinite groomStep}.intro-groom .leg-front,.intro-groom .arm-back{animation-delay:0s}.intro-groom .leg-back,.intro-groom .arm-front{animation-delay:.25s}@keyframes groomStep{0%,to{transform:rotate(-12deg)}50%{transform:rotate(14deg)}}.intro-caption{color:#fff8e6;text-shadow:0 4px 16px #50280a66;opacity:0;font-family:Great Vibes,cursive;font-size:clamp(40px,8vw,64px);animation:1s ease-out .5s forwards captionIn;position:absolute;top:8%;left:50%;transform:translate(-50%)}@keyframes captionIn{0%{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%)}}.arch{background:var(--cream-2);border-radius:280px 280px 18px 18px;padding:14px;position:relative;box-shadow:0 30px 60px -30px #503c1459,0 4px 16px #503c1414}.arch-inner{border:1px solid var(--line);border-radius:270px 270px 12px 12px;padding:56px 32px 36px;position:relative}.arch-inner:before{content:"";border:1px solid var(--line);opacity:.55;pointer-events:none;border-radius:264px 264px 8px 8px;position:absolute;inset:8px}.names{text-align:center;flex-direction:column;align-items:center;margin-bottom:22px;line-height:.9;display:flex}.script{color:var(--gold);font-family:Great Vibes,cursive;font-size:clamp(58px,13vw,92px);font-weight:400}.script.amp{color:var(--gold-deep);margin:-8px 0;font-size:clamp(36px,7vw,52px)}.intro{text-align:center;color:#6b563a;margin:18px 0 26px;font-size:17px;font-style:italic;line-height:1.55}.parents{grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;margin:18px 0 26px;display:grid}.parent{letter-spacing:.08em;color:var(--gold-deep);text-align:center;flex-direction:column;gap:4px;font-family:Cinzel,serif;font-size:13px;line-height:1.4;display:flex}.wheat{width:44px;height:64px}.date-block{text-align:center;color:var(--gold-deep);margin:24px 0 8px;font-family:Cinzel,serif}.date-label{letter-spacing:.32em;margin-bottom:8px;font-size:14px}.date-row{border-top:1px solid var(--line);border-bottom:1px solid var(--line);justify-content:center;align-items:center;gap:14px;max-width:320px;margin:0 auto;padding:8px 0;display:flex}.date-side{letter-spacing:.2em;font-size:13px}.date-num{color:var(--gold);font-family:Cormorant Garamond,serif;font-size:38px;font-weight:500;line-height:1}.date-year{letter-spacing:.2em;margin-top:6px;font-size:15px}.date-time{letter-spacing:.2em;margin-top:4px;font-size:13px}.date-venue{letter-spacing:.18em;color:var(--gold);margin-top:10px;font-size:13px}.countdown{border-top:1px solid var(--line);border-bottom:1px solid var(--line);grid-template-columns:repeat(4,1fr);gap:8px;margin:28px 0 24px;padding:14px 8px;display:grid}.cd-cell{text-align:center}.cd-num{color:var(--gold-deep);font-family:Cormorant Garamond,serif;font-size:26px;font-weight:500;line-height:1}.cd-label{letter-spacing:.2em;color:var(--gold);margin-top:4px;font-family:Cinzel,serif;font-size:10px}.actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:8px;display:flex}.btn{letter-spacing:.16em;cursor:pointer;border:1px solid var(--gold);border-radius:999px;align-items:center;gap:8px;padding:12px 18px;font-family:Cinzel,serif;font-size:12px;text-decoration:none;transition:transform .15s,background .15s,color .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--gold);color:#fff}.btn-primary:hover{background:var(--gold-deep)}.btn-ghost{color:var(--gold-deep);background:0 0}.btn-ghost:hover{background:#b8975a1a}.modal-back{z-index:50;background:#3a2f208c;justify-content:center;align-items:center;padding:20px;animation:.2s fade;display:flex;position:fixed;inset:0}.modal{background:var(--cream-2);border:1px solid var(--line);text-align:center;border-radius:16px;width:100%;max-width:420px;padding:28px}.modal h3{color:var(--gold-deep);letter-spacing:.16em;margin:0 0 12px;font-family:Cinzel,serif}.muted{color:#6b563a;margin-bottom:18px;font-size:16px;line-height:1.5}@keyframes fade{0%{opacity:0}to{opacity:1}}@media (width<=420px){.arch-inner{padding:36px 16px 22px}.parents{gap:8px;margin:10px 0 16px}.parent{font-size:10px}.intro{margin:10px 0 14px;font-size:14px}.script{font-size:clamp(46px,11vw,68px)}.script.amp{margin:-6px 0;font-size:clamp(28px,5vw,40px)}.date-block{margin:14px 0 6px}.date-num{font-size:30px}.countdown{margin:14px 0;padding:10px 4px}.cd-num{font-size:22px}.cd-label{font-size:9px}.actions{gap:8px}.btn{padding:10px 14px;font-size:11px}.wheat{width:30px;height:46px}}@media (height<=720px){.arch-inner{padding-top:28px;padding-bottom:18px}.countdown{margin:10px 0;padding:8px 4px}.intro{margin:8px 0 12px}}
