/* ============================================================
   AMANDA & SHANUKA — Royal Paper Invitation  (complete build)
   ============================================================ */
:root{
  --paper:#f4ecdc; --paper-soft:#f8f2e6; --paper-deep:#e8dcc4; --cream:#fbf7ef;
  --pearl:#f1ece2; --parchment-edge:#d8c8a6;
  --ink:#40362a; --ink-soft:#6f6047; --ink-faint:#9a8b71;
  --gold:#b48a3c; --gold-light:#e4c878; --gold-pale:#efe0b8; --gold-deep:#856321; --gold-shadow:#5e4515;
  --wax:#842c26; --wax-light:#a64038; --wax-deep:#5d1c17;
  --shadow:rgba(74,54,28,.28); --shadow-soft:rgba(74,54,28,.14); --glow:rgba(255,240,205,.55);
  --serif:"Cormorant Garamond","EB Garamond",Georgia,serif;
  --body:"EB Garamond","Cormorant Garamond",Georgia,serif;
  --royal:"Cinzel","Cormorant Garamond",serif;
  --script:"Pinyon Script","Cormorant Garamond",cursive;
  --ease-paper:cubic-bezier(.22,.61,.36,1);
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ font-family:var(--body); color:var(--ink); background:#e7dcc6; line-height:1.6; overflow-x:hidden; font-size:18px; letter-spacing:.2px; text-rendering:optimizeLegibility; -webkit-font-smoothing:antialiased; }
body.locked{ overflow:hidden; height:100vh; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

.grain{ position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5; mix-blend-mode:multiply; background-image:url("/img/grain.svg"); background-size:300px 300px; }
.vignette{ position:fixed; inset:0; z-index:2; pointer-events:none; background:radial-gradient(120% 90% at 50% 30%, transparent 50%, rgba(60,42,18,.10) 78%, rgba(45,30,12,.30) 100%); }

.script{ font-family:var(--script); font-weight:400; line-height:.95; color:var(--ink); }
.royal{ font-family:var(--royal); letter-spacing:.18em; text-transform:uppercase; }
.eyebrow{ font-family:var(--royal); font-size:.72rem; letter-spacing:.42em; text-transform:uppercase; color:var(--gold-deep); }
.foil{ background:linear-gradient(92deg, var(--gold-deep) 0%, var(--gold) 18%, var(--gold-light) 38%, #fff6d8 50%, var(--gold-light) 62%, var(--gold) 82%, var(--gold-deep) 100%); background-size:250% 100%; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; animation:foilSheen 7s linear infinite; filter:drop-shadow(0 1px 0 rgba(255,255,255,.35)) drop-shadow(0 2px 3px rgba(94,69,21,.35)); }
@keyframes foilSheen{ to{ background-position:250% 0; } }
.emboss{ color:#cbba97; text-shadow:0 1px 0 rgba(255,250,235,.8), 0 -1px 1px rgba(120,95,55,.55); }
.ink{ color:var(--ink); }
.divider{ display:flex; align-items:center; justify-content:center; gap:14px; margin:22px auto; color:var(--gold); max-width:340px; }
.divider::before,.divider::after{ content:""; height:1px; flex:1; background:linear-gradient(90deg, transparent, var(--gold) 60%, var(--gold-deep)); }
.divider::after{ transform:scaleX(-1); }
.divider .lozenge{ font-size:.9rem; letter-spacing:.3em; }

/* ---- OPENING STAGE ---- */
#stage{ position:fixed; inset:0; z-index:60; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(80% 60% at 50% 38%, rgba(255,243,214,.55), transparent 60%), radial-gradient(120% 120% at 50% 50%, #efe4cb 0%, #ddcdaa 45%, #c9b78f 100%);
  perspective:1700px; perspective-origin:50% 42%; overflow:hidden; transition:opacity 1.1s ease, visibility 1.1s ease; }
#stage.dismiss{ opacity:0; visibility:hidden; pointer-events:none; }
.stage-glow{ position:absolute; width:140vmax; height:140vmax; left:50%; top:34%; transform:translate(-50%,-50%); pointer-events:none; z-index:0;
  background:radial-gradient(circle at 50% 50%, rgba(255,238,200,.45), rgba(255,225,170,.10) 28%, transparent 55%); animation:flicker 5.5s ease-in-out infinite; }
@keyframes flicker{ 0%,100%{opacity:.85; transform:translate(-50%,-50%) scale(1)} 45%{opacity:1; transform:translate(-50%,-51%) scale(1.04)} 70%{opacity:.78} }
.card-wrap{ position:relative; z-index:3; width:min(86vw, 430px); aspect-ratio:7 / 10; transform-style:preserve-3d; filter:drop-shadow(0 40px 60px rgba(70,48,18,.45)); }
.card-shadow{ position:absolute; left:50%; bottom:-7%; width:88%; height:8%; transform:translateX(-50%); background:radial-gradient(50% 60% at 50% 50%, rgba(60,40,15,.45), transparent 70%); filter:blur(7px); z-index:0; }
.reveal{ position:absolute; inset:0; z-index:1; border-radius:6px; overflow:hidden;
  background:linear-gradient(180deg, rgba(255,252,244,.6), rgba(244,236,220,.6)), var(--paper-soft);
  box-shadow:inset 0 0 60px rgba(120,90,45,.20), inset 0 0 0 1px rgba(180,138,60,.25);
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:8% 9%;
  opacity:0; transform:scale(.92); transition:opacity .9s ease .25s, transform 1.1s var(--ease-paper) .25s; }
.reveal::after{ content:""; position:absolute; inset:14px; border:1px solid rgba(180,138,60,.5); border-radius:3px; pointer-events:none; box-shadow:inset 0 0 0 4px rgba(255,250,235,.5), inset 0 0 0 5px rgba(180,138,60,.25); }
#stage.opened .reveal{ opacity:1; transform:scale(1); }
.reveal .r-mono{ font-family:var(--royal); letter-spacing:.3em; color:var(--gold-deep); font-size:.8rem; }
.reveal .r-names{ font-family:var(--script); font-size:clamp(2.6rem,11vw,3.6rem); margin:.1em 0; }
.reveal .r-amp{ display:block; font-size:.5em; color:var(--gold); margin:.05em 0; }
.reveal .r-date{ font-family:var(--royal); letter-spacing:.22em; font-size:.78rem; color:var(--ink-soft); }
.reveal .r-hint{ margin-top:18px; font-size:.7rem; letter-spacing:.25em; text-transform:uppercase; color:var(--ink-faint); }
.reveal .r-hint span{ display:inline-block; animation:bob 2s ease-in-out infinite; }
@keyframes bob{ 50%{ transform:translateY(5px) } }

.door{ position:absolute; top:0; height:100%; width:50%; z-index:4; transform-style:preserve-3d; backface-visibility:hidden; will-change:transform; }
.door .face{ position:absolute; inset:0; backface-visibility:hidden; background:linear-gradient(180deg, rgba(255,253,247,.65), rgba(238,228,208,.5)), var(--paper); background-blend-mode:overlay; overflow:hidden; }
.door .face::before{ content:""; position:absolute; inset:0; opacity:.5; mix-blend-mode:multiply; background-image:url("/img/grain.svg"); background-size:240px; }
.door .face::after{ content:""; position:absolute; inset:0; pointer-events:none; }
.door.left .face::after{ background:linear-gradient(90deg, rgba(54,38,16,var(--shade,0)), rgba(54,38,16,0) 72%); }
.door.right .face::after{ background:linear-gradient(270deg, rgba(54,38,16,var(--shade,0)), rgba(54,38,16,0) 72%); }
.door.left .face{ background-image:linear-gradient(100deg, rgba(255,250,235,0) 60%, rgba(255,248,225,.5)), linear-gradient(180deg, rgba(255,253,247,.65), rgba(238,228,208,.5)); }
.door.right .face{ background-image:linear-gradient(260deg, rgba(255,250,235,0) 60%, rgba(255,248,225,.5)), linear-gradient(180deg, rgba(255,253,247,.65), rgba(238,228,208,.5)); }
.door .back{ position:absolute; inset:0; transform:rotateY(180deg); backface-visibility:hidden; background:linear-gradient(180deg,#e7dabf,#dccaa6); box-shadow:inset 0 0 50px rgba(110,82,40,.35); }
.door .back::before{ content:""; position:absolute; inset:0; opacity:.4; mix-blend-mode:multiply; background-image:url("/img/grain.svg"); background-size:240px; }
.door.left{ left:0; transform-origin:left center; border-right:1px solid rgba(150,116,55,.25); }
.door.right{ right:0; transform-origin:right center; border-left:1px solid rgba(150,116,55,.25); }
.door.left .face{ box-shadow:inset -10px 0 22px -10px rgba(120,90,40,.5); }
.door.right .face{ box-shadow:inset 10px 0 22px -10px rgba(120,90,40,.5); }

.door-art{ position:absolute; top:0; height:100%; width:200%; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:flex-start; text-align:center; pointer-events:none; padding:12% 0 0; }
.door.left .door-art{ left:0; }
.door.right .door-art{ right:0; }
.door-art .crest{ width:74px; height:74px; margin-bottom:10px; }
.da-mono{ font-family:var(--royal); letter-spacing:.34em; font-size:.72rem; color:var(--gold-deep); }
.da-names{ font-family:var(--script); font-size:clamp(2.2rem,9.5vw,3rem); color:var(--ink); line-height:.9; margin:.12em 0; }
.da-amp{ font-size:.5em; color:var(--gold); }
.da-rule{ width:120px; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); margin:10px 0; }
.da-for{ font-family:var(--royal); font-size:.6rem; letter-spacing:.34em; text-transform:uppercase; color:var(--ink-faint); }
.da-guest{ font-family:var(--serif); font-style:italic; font-size:1.25rem; color:var(--ink-soft); margin-top:4px; }

.seal{ position:absolute; left:50%; top:70%; z-index:7; width:104px; height:104px; transform:translate(-50%,-50%); transform-style:preserve-3d; pointer-events:none; }
.seal .half{ position:absolute; top:0; height:100%; width:50%; overflow:hidden; }
.seal .half svg{ position:absolute; top:0; height:100%; width:108px; }
.seal .half.l{ left:0; transform-origin:left center; }
.seal .half.l svg{ left:0; }
.seal .half.r{ right:0; transform-origin:right center; }
.seal .half.r svg{ right:0; }
.seal{ filter:drop-shadow(0 6px 8px rgba(70,30,20,.45)); transition:opacity .35s ease; }
.seal .half{ transition:transform .55s var(--ease-paper); }
.seal.crack .half.l{ transform:translateX(-7px) translateY(2px) rotate(-14deg); }
.seal.crack .half.r{ transform:translateX(7px) translateY(2px) rotate(14deg); }
.ribbon{ position:absolute; left:50%; top:50%; z-index:6; transform:translate(-50%,-46%); pointer-events:none; }
.tap-hint{ position:absolute; left:50%; bottom:7%; z-index:8; transform:translateX(-50%); font-family:var(--royal); font-size:.64rem; letter-spacing:.4em; text-transform:uppercase; color:var(--ink-soft); text-align:center; white-space:nowrap; transition:opacity .5s ease; }
.tap-hint .key{ display:block; margin-bottom:9px; font-size:1.5rem; color:var(--gold); animation:bob 2.2s ease-in-out infinite; }
#stage.opening .tap-hint, #stage.opened .tap-hint{ opacity:0; }
.motes{ position:absolute; inset:0; z-index:5; pointer-events:none; overflow:hidden; }
.mote{ position:absolute; width:4px; height:4px; border-radius:50%; background:radial-gradient(circle,rgba(255,244,210,.9),rgba(255,235,180,0)); animation:rise linear infinite; opacity:0; }
@keyframes rise{ 0%{ transform:translateY(20px) scale(.6); opacity:0 } 15%{ opacity:.8 } 85%{ opacity:.5 } 100%{ transform:translateY(-110px) scale(1.1); opacity:0 } }

/* ---- MAIN DOC ---- */
#scroll-root{ position:relative; z-index:3; }
.section{ position:relative; padding:clamp(64px,11vw,140px) 22px; display:flex; flex-direction:column; align-items:center; text-align:center; }
.wrap{ width:100%; max-width:1080px; margin:0 auto; }
.narrow{ max-width:680px; }
.panel{ position:relative; background:var(--paper-soft); border-radius:8px; padding:clamp(30px,5vw,60px); box-shadow:0 24px 60px -28px var(--shadow), inset 0 0 0 1px rgba(180,138,60,.18); overflow:hidden; }
.panel::before{ content:""; position:absolute; inset:0; opacity:.45; mix-blend-mode:multiply; pointer-events:none; background-image:url("/img/grain.svg"); background-size:300px; }
.panel.framed::after{ content:""; position:absolute; inset:13px; border:1px solid rgba(180,138,60,.45); border-radius:4px; pointer-events:none; }
h1,h2,h3{ font-weight:500; line-height:1.1; }
.section h2.title{ font-family:var(--serif); font-size:clamp(2rem,5.4vw,3.1rem); color:var(--ink); font-weight:600; letter-spacing:.01em; }
.section .sub{ color:var(--ink-soft); font-style:italic; font-size:1.15rem; }
.kicker{ margin-bottom:10px; }

#hero{ min-height:100vh; justify-content:center; padding-top:90px; }
.hero-card{ max-width:760px; }
.hero-names{ font-family:var(--script); font-size:clamp(4rem,17vw,8.4rem); line-height:.82; margin:.06em 0; }
.hero-names .amp{ display:block; font-size:.34em; color:var(--gold); margin:.08em 0; letter-spacing:.05em; }
.hero-sub{ font-family:var(--royal); letter-spacing:.34em; text-transform:uppercase; font-size:clamp(.7rem,2vw,.92rem); color:var(--ink-soft); }
.hero-date{ font-family:var(--serif); font-size:1.5rem; color:var(--gold-deep); margin-top:6px; letter-spacing:.04em; }
.hero-photo-frame{ width:min(80vw,300px); aspect-ratio:3/4; margin:0 auto 26px; position:relative; border-radius:200px 200px 8px 8px; overflow:hidden; box-shadow:0 30px 60px -26px var(--shadow), 0 0 0 1px rgba(180,138,60,.4), 0 0 0 9px var(--paper-soft), 0 0 0 10px rgba(180,138,60,.5); }
.hero-photo-frame img{ width:100%; height:100%; object-fit:cover; }

.greeting .panel{ max-width:720px; margin:0 auto; }
.greet-name{ font-family:var(--script); font-size:clamp(2.4rem,8vw,3.4rem); color:var(--ink); }
.greet-body{ font-size:1.18rem; color:var(--ink-soft); margin-top:12px; }
.greet-allow{ margin-top:18px; font-family:var(--royal); letter-spacing:.16em; font-size:.74rem; text-transform:uppercase; color:var(--gold-deep); }

.countdown{ display:flex; gap:clamp(10px,3vw,30px); justify-content:center; flex-wrap:wrap; margin-top:8px; }
.cd-unit{ min-width:84px; }
.cd-num{ font-family:var(--serif); font-weight:600; font-size:clamp(2.6rem,8vw,4rem); color:var(--ink); line-height:1; }
.cd-label{ font-family:var(--royal); letter-spacing:.28em; text-transform:uppercase; font-size:.6rem; color:var(--gold-deep); margin-top:8px; }

.venues{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.venue{ text-align:center; }
.venue .badge{ width:58px; height:58px; margin:0 auto 12px; color:var(--gold-deep); }
.venue h3{ font-family:var(--serif); font-size:1.7rem; color:var(--ink); font-weight:600; }
.venue .vsub{ font-style:italic; color:var(--ink-soft); }
.venue .vnative{ font-size:1.05rem; color:var(--ink-soft); }
.venue .vaddr{ font-size:.98rem; color:var(--ink-faint); margin-top:8px; }
.venue .vtime{ font-family:var(--royal); letter-spacing:.18em; font-size:.78rem; color:var(--gold-deep); margin-top:10px; text-transform:uppercase; }

.timeline{ position:relative; max-width:620px; margin:14px auto 0; text-align:left; }
.timeline::before{ content:""; position:absolute; left:23px; top:6px; bottom:6px; width:1px; background:linear-gradient(var(--gold),rgba(180,138,60,.15)); }
.tl-item{ position:relative; padding:0 0 30px 64px; }
.tl-item:last-child{ padding-bottom:0; }
.tl-dot{ position:absolute; left:13px; top:2px; width:22px; height:22px; border-radius:50%; background:var(--paper-soft); border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; color:var(--gold-deep); }
.tl-dot::after{ content:""; width:7px; height:7px; border-radius:50%; background:var(--gold); }
.tl-time{ font-family:var(--royal); letter-spacing:.16em; font-size:.74rem; color:var(--gold-deep); text-transform:uppercase; }
.tl-title{ font-family:var(--serif); font-size:1.45rem; color:var(--ink); font-weight:600; }
.tl-desc{ color:var(--ink-soft); font-size:1rem; }

.gallery{ columns:3; column-gap:14px; }
.gallery .g-item{ break-inside:avoid; margin-bottom:14px; position:relative; border-radius:5px; overflow:hidden; box-shadow:0 14px 30px -18px var(--shadow), 0 0 0 1px rgba(180,138,60,.3), 0 0 0 6px var(--paper-soft); cursor:pointer; }
.gallery .g-item img{ width:100%; transition:transform .8s var(--ease-paper), filter .6s ease; filter:saturate(.96) sepia(.05); }
.gallery .g-item:hover img{ transform:scale(1.05); filter:saturate(1.02) sepia(0); }
.gallery .g-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(70,48,18,.18)); pointer-events:none; }
.lightbox{ position:fixed; inset:0; z-index:90; background:rgba(40,28,12,.86); display:none; align-items:center; justify-content:center; padding:20px; }
.lightbox.on{ display:flex; }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:4px; box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(180,138,60,.5), 0 0 0 10px rgba(244,236,220,.12); }
.lb-close{ position:absolute; top:18px; right:22px; color:var(--gold-pale); font-size:2rem; background:none; border:none; }
.lb-nav{ position:absolute; top:50%; transform:translateY(-50%); color:var(--gold-pale); font-size:2.4rem; background:none; border:none; padding:18px; opacity:.8; }
.lb-nav:hover{ opacity:1; } .lb-prev{ left:6px; } .lb-next{ right:6px; }

.maps{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.map-card{ overflow:hidden; }
.map-embed{ width:100%; aspect-ratio:16/11; border:0; border-radius:5px; filter:sepia(.18) saturate(.92) brightness(1.02); box-shadow:inset 0 0 0 1px rgba(180,138,60,.3); }
.map-card h3{ font-family:var(--serif); font-size:1.4rem; color:var(--ink); margin-bottom:4px; }
.btn-dir{ margin-top:14px; }

.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--royal); letter-spacing:.2em; text-transform:uppercase; font-size:.72rem; padding:15px 30px; border-radius:2px; border:1px solid var(--gold); color:var(--gold-deep); background:linear-gradient(180deg,var(--cream),var(--paper-soft)); box-shadow:0 8px 22px -12px var(--shadow), inset 0 1px 0 rgba(255,255,255,.6); transition:transform .3s var(--ease-paper), box-shadow .3s ease, background .3s ease; }
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -12px var(--shadow); background:linear-gradient(180deg,#fff,var(--cream)); }
.btn.gold{ color:#523c12; border-color:var(--gold-deep); background:linear-gradient(180deg,var(--gold-light),var(--gold)); text-shadow:0 1px 0 rgba(255,255,255,.4); }
.btn.gold:hover{ background:linear-gradient(180deg,#f1d894,var(--gold-light)); }
.btn .ico{ width:15px; height:15px; }

.form{ max-width:560px; margin:18px auto 0; text-align:left; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--royal); letter-spacing:.14em; text-transform:uppercase; font-size:.66rem; color:var(--ink-soft); margin-bottom:7px; }
.field input, .field select, .field textarea{ width:100%; font-family:var(--body); font-size:1.05rem; color:var(--ink); background:var(--cream); border:1px solid var(--parchment-edge); border-radius:3px; padding:13px 15px; transition:border-color .25s ease, box-shadow .25s ease; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(180,138,60,.16); }
.field textarea{ resize:vertical; min-height:92px; }
.field .hint{ font-size:.82rem; color:var(--ink-faint); font-style:italic; margin-top:5px; }
.attend{ display:flex; gap:12px; }
.attend label{ flex:1; margin:0; }
.attend input{ position:absolute; opacity:0; pointer-events:none; }
.attend .opt{ display:block; text-align:center; padding:16px; border-radius:4px; cursor:pointer; border:1px solid var(--parchment-edge); background:var(--cream); font-family:var(--royal); letter-spacing:.14em; text-transform:uppercase; font-size:.72rem; color:var(--ink-soft); transition:all .25s ease; }
.attend input:checked + .opt{ border-color:var(--gold-deep); background:linear-gradient(180deg,var(--gold-pale),#f6e9c6); color:#5a420f; box-shadow:0 6px 16px -10px var(--shadow); }
.guest-rows .grow{ display:flex; gap:10px; align-items:center; margin-bottom:8px; }
.guest-rows .gn{ flex:1; }
.muted{ color:var(--ink-faint); font-size:.9rem; }
.toast{ position:fixed; left:50%; bottom:26px; translate:-50% 0; background:var(--ink); color:var(--paper-soft); padding:13px 22px; border-radius:3px; font-family:var(--royal); letter-spacing:.1em; font-size:.74rem; text-transform:uppercase; box-shadow:0 16px 40px rgba(0,0,0,.35); opacity:0; pointer-events:none; transition:opacity .4s ease, translate .4s ease; z-index:95; }
.toast.on{ opacity:1; translate:-50% -10px; }

#closing{ min-height:92vh; justify-content:center; }
.closing-names{ font-family:var(--script); font-size:clamp(3rem,12vw,5.4rem); line-height:.85; }
.closing-line{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--ink-soft); max-width:520px; margin:0 auto; }
.foot{ margin-top:40px; font-family:var(--royal); letter-spacing:.2em; font-size:.6rem; text-transform:uppercase; color:var(--ink-faint); }
.petals{ position:fixed; inset:0; z-index:2; pointer-events:none; overflow:hidden; }
.petal{ position:absolute; top:-6%; color:rgba(213,178,94,.5); animation:fall linear infinite; }
@keyframes fall{ 0%{ transform:translateY(-10vh) rotate(0deg); opacity:0 } 10%{ opacity:.7 } 100%{ transform:translateY(110vh) rotate(320deg); opacity:0 } }
.reveal-up{ opacity:0; transform:translateY(38px); transition:opacity 1s ease, transform 1.1s var(--ease-paper); }
.reveal-up.in{ opacity:1; transform:none; }
.reveal-scale{ opacity:0; transform:scale(.94); transition:opacity 1s ease, transform 1.2s var(--ease-paper); }
.reveal-scale.in{ opacity:1; transform:none; }
[data-delay="1"]{ transition-delay:.12s; }
[data-delay="2"]{ transition-delay:.24s; }
[data-delay="3"]{ transition-delay:.36s; }
[data-delay="4"]{ transition-delay:.48s; }
.scroll-cue{ position:fixed; right:18px; bottom:18px; z-index:40; display:flex; gap:10px; }
.mini-btn{ width:42px; height:42px; border-radius:50%; border:1px solid rgba(180,138,60,.5); background:var(--paper-soft); color:var(--gold-deep); display:flex; align-items:center; justify-content:center; box-shadow:0 8px 20px -10px var(--shadow); }

@media (max-width:760px){
  body{ font-size:17px; }
  .venues, .maps{ grid-template-columns:1fr; }
  .gallery{ columns:2; }
  .card-wrap{ width:min(90vw,360px); }
}
@media (max-width:430px){
  .gallery{ columns:1; }
  .countdown{ gap:8px; }
  .cd-unit{ min-width:64px; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.18s !important; scroll-behavior:auto !important; }
  .foil{ animation:none; background-position:0 0; }
  .reveal-up,.reveal-scale{ opacity:1 !important; transform:none !important; }
  .motes,.petals,.stage-glow{ display:none !important; }
}

/* WebGL opening */
#paperCanvas{ position:absolute; inset:0; width:100%; height:100%; display:block; z-index:3; }
.paper-fallback{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .6s ease; z-index:2; pointer-events:none; }
.pf-card{ text-align:center; padding:48px 40px; background:var(--paper-soft); border-radius:8px; box-shadow:0 30px 70px -30px var(--shadow), inset 0 0 0 1px rgba(180,138,60,.4); }
.pf-mono{ font-family:var(--royal); letter-spacing:.3em; color:var(--gold-deep); }
.pf-names{ font-family:var(--script); font-size:clamp(2.6rem,9vw,3.6rem); margin:.1em 0; color:var(--ink); }
.pf-date{ font-family:var(--royal); letter-spacing:.22em; font-size:.8rem; color:var(--ink-soft); }
