:root{--navy:#09233b;--navy2:#061829;--cream:#f5ead5;--paper:#fff5df;--ink:#15283d;--muted:#746758;--gold:#caa463;--red:#a24c37;--line:rgba(21,40,61,.18);--shadow:0 30px 90px rgba(2,12,24,.28);--mono:"Courier New",monospace;--serif:Georgia,"Times New Roman",serif;--sans:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*{box-sizing:border-box}body,html{margin:0;min-height:100%;font-family:var(--sans);color:var(--ink);background:radial-gradient(circle at 15% 12%,rgba(202,164,99,.18),transparent 28%),radial-gradient(circle at 90% 25%,rgba(162,76,55,.14),transparent 26%),linear-gradient(135deg,#061829,#0a2745 45%,#17110e);overflow-x:hidden}.grain{pointer-events:none;opacity:.14;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.7' numOctaves='3'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E");z-index:0}.grain,.nameGate{position:fixed;inset:0}.nameGate{z-index:100;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at 15% 12%,rgba(202,164,99,.18),transparent 28%),radial-gradient(circle at 90% 25%,rgba(162,76,55,.14),transparent 26%),linear-gradient(135deg,#061829,#0a2745 45%,#17110e);transition:.7s ease}.nameGate.hidden{opacity:0;pointer-events:none;transform:translateY(-18px)}.nameGateWrap{text-align:center;max-width:480px;width:100%}.nameGateSeal{width:130px;height:130px;border-radius:50%;background:var(--navy);display:grid;place-items:center;margin:0 auto 28px;border:3px solid rgba(202,164,99,.85);box-shadow:0 18px 40px rgba(0,0,0,.35),inset 0 0 0 2px rgba(202,164,99,.2);overflow:hidden}.nameGateSeal img{width:100%;height:100%;object-fit:cover;object-position:top center}.nameGateAgency{font-family:var(--mono);letter-spacing:.22em;text-transform:uppercase;color:rgba(202,164,99,.85);font-size:10px;margin-bottom:8px}.nameGateTitle{font-family:var(--serif);font-size:clamp(26px,5vw,36px);color:var(--cream);margin:0 0 10px;line-height:1.1}.nameGateSub{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:hsla(39,62%,90%,.6);text-transform:uppercase;margin-bottom:32px}.nameGateInput{width:100%;background:hsla(39,62%,90%,.08);border:1px solid rgba(202,164,99,.45);border-radius:14px;padding:16px 20px;color:var(--cream);font-family:var(--mono);font-size:16px;letter-spacing:.06em;outline:none;transition:.3s}.nameGateInput::placeholder{color:hsla(39,62%,90%,.35)}.nameGateInput:focus{border-color:rgba(202,164,99,.85);background:hsla(39,62%,90%,.12)}.nameGateBtn{margin-top:14px;width:100%;border:0;border-radius:999px;background:var(--gold);color:var(--navy);padding:15px 22px;font-family:var(--mono);font-weight:900;letter-spacing:.14em;text-transform:uppercase;font-size:13px;cursor:pointer;box-shadow:0 12px 36px rgba(0,0,0,.25);transition:.2s}.nameGateBtn:hover{background:#d4ad6a}.nameGateNote{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:hsla(39,62%,90%,.35);text-transform:uppercase;margin-top:18px}.intro{min-height:100vh;display:grid;place-items:center;padding:28px;position:relative;z-index:2;transition:.8s ease}.intro.hidden{opacity:0;transform:translateY(-24px);pointer-events:none;position:absolute;inset:0}.envelopeWrap{text-align:center}.caseLabel{font-family:var(--mono);letter-spacing:.18em;color:hsla(39,62%,90%,.72);font-size:12px;margin-top:24px}.caseLabel,.openBtn{text-transform:uppercase}.openBtn{margin-top:20px;border:1px solid rgba(202,164,99,.5);background:hsla(39,62%,90%,.08);color:#f7e6c6;border-radius:999px;padding:14px 22px;font-weight:900;letter-spacing:.12em;cursor:pointer;box-shadow:0 18px 50px rgba(0,0,0,.25)}.envelope{width:min(720px,92vw);aspect-ratio:1.55;background:linear-gradient(160deg,#f6e5c5,#d8bd8c);border-radius:18px;position:relative;box-shadow:var(--shadow);border:1px solid hsla(0,0%,100%,.35);overflow:hidden;cursor:pointer;transform:translateY(0);animation:float 4s ease-in-out infinite}.envelope:before{content:"";position:absolute;inset:0;background:linear-gradient(140deg,transparent 49%,rgba(120,80,35,.22) 50%,transparent 51%),linear-gradient(220deg,transparent 49%,rgba(120,80,35,.18) 50%,transparent 51%)}.envelope:after{content:"";bottom:0;height:55%;background:linear-gradient(160deg,#efd7ab,#cba66b);-webkit-clip-path:polygon(0 0,50% 62%,100% 0,100% 100%,0 100%);clip-path:polygon(0 0,50% 62%,100% 0,100% 100%,0 100%)}.envelope:after,.flap{position:absolute;left:0;right:0}.flap{top:0;height:62%;background:linear-gradient(180deg,#f9edcf,#d8b777);-webkit-clip-path:polygon(0 0,100% 0,50% 100%);clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top;z-index:4;transition:1s cubic-bezier(.2,.8,.2,1)}.seal{position:absolute;left:50%;top:49%;transform:translate(-50%,-50%);z-index:6;width:174px;height:174px;border-radius:50%;background:var(--navy);display:grid;place-items:center;box-shadow:0 18px 35px rgba(0,0,0,.35),inset 0 0 0 2px rgba(202,164,99,.35);border:3px solid rgba(202,164,99,.85);transition:.65s ease;overflow:hidden}.seal img{width:100%;height:100%;object-fit:cover;object-position:top center}.letterPeek{position:absolute;left:12%;right:12%;top:24%;height:58%;background:#fff2d7;border-radius:10px;box-shadow:0 14px 30px rgba(0,0,0,.2);z-index:2;transition:1s ease}.intro.opening .flap{transform:rotateX(170deg)}.intro.opening .seal{transform:translate(-50%,-50%) scale(.75) rotate(-16deg);opacity:0}.intro.opening .letterPeek{top:-20%;transform:scale(1.04)}@keyframes float{50%{transform:translateY(-10px)}}.confetti{position:fixed;width:0;height:0;pointer-events:none;z-index:200}.confettiPiece{position:absolute;top:0;left:0;font-size:var(--size,26px);line-height:1;will-change:transform,opacity;transform:translateZ(0) rotate(0deg) scale(.4);animation:confetti-burst var(--dur,3s) var(--delay,0s) forwards;filter:drop-shadow(0 4px 6px rgba(0,0,0,.22));-webkit-user-select:none;-moz-user-select:none;user-select:none}@keyframes confetti-burst{0%{transform:translateZ(0) rotate(0deg) scale(.35);opacity:0;animation-timing-function:cubic-bezier(.18,.85,.4,1)}8%{opacity:1;animation-timing-function:cubic-bezier(.18,.85,.4,1)}38%{transform:translate3d(var(--bx,0),var(--by,0),0) rotate(calc(var(--rot, 2turn) * .45)) scale(1);opacity:1;animation-timing-function:cubic-bezier(.55,0,.95,.5)}to{transform:translate3d(calc(var(--bx, 0px) + var(--driftx, 0px)),calc(var(--by, 0px) + 110vh),0) rotate(var(--rot,2turn)) scale(.85);opacity:0}}@media (prefers-reduced-motion:reduce){.confetti{display:none}}.site{display:none;position:relative;z-index:2;padding:20px;min-height:100vh}.site.visible{display:block}.book{max-width:1500px;margin:0 auto;display:grid;grid-template-columns:138px 1fr;min-height:calc(100vh - 40px);background:#081827;border-radius:26px;box-shadow:var(--shadow);overflow:hidden;border:1px solid hsla(0,0%,100%,.15)}.rail{background:linear-gradient(180deg,#09233b 0 22%,#efe4cf 22% 100%);padding:22px 16px;color:var(--ink);position:relative;display:flex;flex-direction:column;min-height:0}.railLogo{height:170px;display:grid;place-items:center;margin-bottom:28px;flex-shrink:0}.railSteps{flex:1 1 auto;min-height:0;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(21,40,61,.35) transparent}.railSteps::-webkit-scrollbar{width:6px}.railSteps::-webkit-scrollbar-thumb{background:rgba(21,40,61,.3);border-radius:999px}.railLogo img{width:106px;height:106px;border-radius:50%;object-fit:cover;object-position:top center;border:2px solid rgba(202,164,99,.6)}.step{grid-template-columns:42px 1fr;grid-gap:10px;gap:10px;align-items:center;padding:16px 0;border-bottom:1px solid rgba(21,40,61,.16);font-family:var(--mono);font-weight:900;font-size:11px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.num,.step{display:grid}.num{width:34px;height:34px;border-radius:50%;place-items:center;border:1px solid rgba(21,40,61,.25)}.step.active .num{background:var(--navy);color:var(--cream)}.passportStamp{flex-shrink:0;margin-top:14px;border:1px solid rgba(162,76,55,.35);color:#9c6e31;border-radius:8px;padding:10px 8px;text-align:center;font-family:var(--mono);font-size:12px;background:hsla(0,0%,100%,.25)}.content{background:linear-gradient(90deg,#d4c1a2,#f4ead8 2%,#fbefd9 48%,#d7c1a2 50%,#efe1c9 52%,#e8d6b7);display:flex;flex-direction:column}.content,.page{position:relative}.page{padding:60px;width:100%;flex:1 1 auto}.page:before{content:"";position:absolute;inset:22px;border:1px solid rgba(21,40,61,.12);border-radius:16px;pointer-events:none}.cover{text-align:center;display:flex;flex-direction:column;justify-content:center}.mark{font-family:var(--serif);color:#9c6e31;letter-spacing:.22em;margin-bottom:34px}.caseSmall{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:#9a442f;font-weight:900}.title{font-family:var(--serif);font-size:clamp(48px,6vw,88px);line-height:.9;margin:18px 0;color:var(--navy);letter-spacing:-.03em}.title .red{color:var(--red);font-weight:900;letter-spacing:.02em}.subtitle{letter-spacing:.28em;text-transform:uppercase;font-weight:900;margin:28px 0 48px}.details,.subtitle{font-family:var(--mono)}.details{max-width:620px;margin:0 auto;text-align:left;font-size:18px}.details .row{display:grid;grid-template-columns:170px 1fr;grid-gap:18px;gap:18px;border-top:1px dotted rgba(21,40,61,.28);padding:14px 0}.label{font-family:var(--sans);font-size:12px;letter-spacing:.12em;color:var(--navy)}.label,.stamp{font-weight:900;text-transform:uppercase}.stamp{display:inline-block;border:3px double rgba(162,76,55,.75);color:var(--red);font-family:var(--mono);letter-spacing:.08em;padding:12px 16px;transform:rotate(-7deg);margin-top:24px}.photos{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);grid-gap:8px;gap:8px;padding:20px;opacity:.54;filter:sepia(.35) saturate(.9);overflow:hidden}.photos img{width:100%;height:100%;object-fit:cover;border:6px solid rgba(255,247,230,.84);box-shadow:0 12px 28px rgba(0,0,0,.22);background:#fff}.letter{position:relative;z-index:4;background:linear-gradient(180deg,#fff3d8,#f3dfb9);margin:34px auto;padding:58px 62px;width:min(630px,92%);min-height:720px;box-shadow:0 22px 65px rgba(0,0,0,.35);transform:rotate(2deg);font-family:var(--mono);line-height:1.52}.letter:before{content:"📎";position:absolute;left:34px;top:-30px;font-size:64px;transform:rotate(-12deg)}.letter h3{text-align:center;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin:0 0 12px}.letter .selected{text-align:center;font-family:var(--serif);font-size:22px;font-weight:900;line-height:1.1;margin:0 0 28px;color:var(--navy)}.dear{font-size:26px}.dear,.signature{font-family:var(--serif);font-style:italic}.signature{font-size:44px;margin-top:16px}.section{display:none;background:linear-gradient(90deg,#fbefd9,#ebd7b6)}.section.active{display:flex;flex-direction:column;flex:1 1 auto}.ceremony{text-align:center}.ceremony h2{font-family:var(--serif);font-size:44px;color:var(--navy)}.infoList{max-width:520px;margin:30px auto;text-align:left}.infoItem{display:grid;grid-template-columns:52px 1fr;grid-gap:18px;gap:18px;margin:20px 0;font-family:var(--mono)}.ico{width:44px;height:44px;border:1px solid rgba(21,40,61,.3);border-radius:50%;display:grid;place-items:center}.gallery{column-count:3;column-gap:14px;max-width:940px;margin:0 auto}.gallery img{display:block;width:100%;height:auto;margin:0 0 14px;border:8px solid #fff2d7;box-shadow:0 14px 35px rgba(0,0,0,.18);page-break-inside:avoid;break-inside:avoid}.witnessPhotos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:22px;margin:36px auto 0}.witnessPhotos img{height:clamp(340px,40vw,520px);width:auto;max-width:100%;object-fit:contain;border:6px solid rgba(255,247,230,.84);box-shadow:0 12px 28px rgba(0,0,0,.18);border-radius:4px}.featuredPhoto{display:block;width:min(480px,100%);height:auto;object-fit:contain;border:8px solid #fff2d7;box-shadow:0 14px 35px rgba(0,0,0,.22);border-radius:8px;margin:20px auto 0}.rsvpForm{max-width:560px;margin:20px auto;background:rgba(255,247,230,.72);border:1px solid var(--line);border-radius:20px;padding:28px;text-align:left}.rsvpForm label{display:block;margin:14px 0 6px;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.1em}.rsvpForm input,.rsvpForm select,.rsvpForm textarea{width:100%;border:1px solid rgba(21,40,61,.22);border-radius:12px;padding:14px;background:#fffaf0;font:inherit}.btn{border:0;border-radius:999px;background:var(--navy);color:#fff;padding:15px 22px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;margin-top:16px}.btn.gold{background:var(--gold);color:var(--navy)}.nav{position:fixed;right:26px;bottom:24px;display:flex;gap:10px;z-index:20}.nav button{width:52px;height:52px;border-radius:50%;border:0;background:var(--navy);color:#fff;font-size:24px;box-shadow:0 12px 35px rgba(0,0,0,.25);cursor:pointer}.toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.92);background:#fff7e6;color:var(--ink);border-radius:24px;padding:34px;box-shadow:var(--shadow);z-index:100;width:min(520px,90vw);display:none;text-align:center;border:1px solid rgba(202,164,99,.45)}.toast.show{display:block}.toast h2{font-family:var(--serif);font-size:38px;margin:0 0 12px;color:var(--navy)}.small{color:var(--muted);font-size:13px;line-height:1.5}.countdownClock{position:fixed;left:50%;top:18px;transform:translateX(-50%);z-index:30;background:rgba(255,245,223,.94);border:1px solid rgba(202,164,99,.55);box-shadow:0 14px 38px rgba(0,0,0,.22);border-radius:999px;padding:10px 14px;display:none;align-items:center;gap:10px;font-family:var(--mono);color:var(--navy)}.countdownClock.visible{display:flex}.countdownTitle{font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--red);white-space:nowrap}.countdownUnits{display:flex;gap:8px}.countUnit{min-width:48px;text-align:center;border-left:1px solid rgba(21,40,61,.15);padding-left:8px}.countUnit b{display:block;font-size:18px;line-height:1;color:var(--navy)}.countUnit span{display:block;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:3px}.mobileSteps{display:none;z-index:25;padding:10px 12px;background:rgba(8,24,39,.92);overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);gap:6px}.mobileSteps::-webkit-scrollbar{display:none}.mobilePill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(202,164,99,.35);background:hsla(39,62%,90%,.05);color:hsla(39,62%,90%,.78);border-radius:999px;padding:6px 12px;font-family:var(--mono);font-size:10px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s,border-color .2s;flex-shrink:0}.mobilePill.active{background:var(--gold);color:var(--navy);border-color:var(--gold)}.mobilePill .pillNum{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 4px;border-radius:999px;background:rgba(202,164,99,.2);color:var(--cream);font-size:10px}.mobilePill.active .pillNum{background:var(--navy);color:var(--gold)}@media (max-width:900px){.countdownClock{top:0;left:0;right:0;bottom:auto;transform:none;justify-content:center;border-radius:0;border-left:0;border-right:0;border-top:0;padding:10px 14px}.countdownTitle{display:none}.countUnit{min-width:42px}.countUnit b{font-size:16px}.mobileSteps{display:flex;position:fixed;bottom:0;left:0;right:0;border-top:1px solid rgba(202,164,99,.3);padding-bottom:calc(10px + env(safe-area-inset-bottom, 0px))}.site.visible{padding-top:56px;padding-bottom:64px}.site{padding:0}.book{display:flex;flex-direction:column;border-radius:0;min-height:calc(100vh - 120px)}.content{flex:1 1 auto}.rail{display:none}.page{padding:34px 22px}.page:before{inset:12px}.title{font-size:54px}.details .row{grid-template-columns:1fr}.photos{position:relative;height:360px;grid-template-columns:repeat(2,1fr);opacity:.8}.letter{transform:none;width:100%;padding:44px 28px;margin:0}.gallery{column-count:2;max-width:none}.gallery img{height:auto;margin-bottom:12px}.nav{right:14px;bottom:calc(72px + env(safe-area-inset-bottom, 0px))}.envelope{width:94vw}.seal{width:138px;height:138px}.witnessPhotos{display:grid;grid-template-columns:1fr 1fr;align-items:center;grid-gap:12px;gap:12px}.witnessPhotos img{width:100%;height:auto;max-width:none}.featuredPhoto{width:100%}}