:root{
  --bg1:#fcf9f1; --bg2:#efe4cb; --ink:#21372b; --soft:#54614f;
  --emerald:#1f5c44; --emerald-d:#123524; --gold:#b8922f; --gold-l:#e0c372; --gold-deep:#9a7820;
  --berry:#8c2f3d; --cream:#fbf8f0;
  --red:#8c2f3d; --orange:#1f5c44; --marigold:#b8922f; --maroon:#54614f; --deep:#21372b;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Cormorant Garamond',serif;color:var(--ink);
  background:
    radial-gradient(circle at 50% -8%,rgba(184,146,47,.18),transparent 55%),
    radial-gradient(circle at 50% 108%,rgba(31,92,68,.14),transparent 55%),
    linear-gradient(180deg,var(--bg1) 0%,#f5eddb 50%,var(--bg2) 100%);
  background-attachment:fixed;overflow-x:hidden;-webkit-tap-highlight-color:transparent;
}
img{max-width:100%}
body.locked{overflow:hidden;height:100vh}
body.preview-open{overflow:hidden}

/* flower backdrop (unchanged behaviour) */
.petals{position:fixed;inset:0;pointer-events:none;z-index:5;overflow:hidden}
.petal{position:absolute;top:-40px;font-size:22px;opacity:.7;animation:fall linear infinite}
@keyframes fall{
  0%{transform:translateY(-40px) rotate(0deg);opacity:0}
  10%{opacity:.8}
  100%{transform:translateY(105vh) rotate(420deg);opacity:.15}
}

/* ===== INTRO COVER ===== */
.cover{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  padding:24px;text-align:center;color:var(--gold-l);
  background:
    radial-gradient(circle at 50% 30%,rgba(31,92,68,.55),transparent 60%),
    linear-gradient(160deg,#16402f 0%,#0e2b1f 60%,#0a2017 100%);
  transition:opacity 1s ease,transform 1.1s cubic-bezier(.7,0,.3,1);}
.cover.open{opacity:0;transform:translateY(-12%);pointer-events:none}
.cover-frame{position:relative;max-width:340px;width:100%;padding:46px 26px;
  border:1px solid rgba(224,195,114,.5);border-radius:4px;
  box-shadow:0 0 0 5px rgba(224,195,114,.12),0 30px 60px rgba(0,0,0,.35);
  background:radial-gradient(circle at 50% 0%,rgba(224,195,114,.08),transparent 70%)}
.cover-frame::before,.cover-frame::after{content:"";position:absolute;width:26px;height:26px;border:1px solid var(--gold-l);opacity:.8}
.cover-frame::before{top:9px;left:9px;border-right:0;border-bottom:0}
.cover-frame::after{bottom:9px;right:9px;border-left:0;border-top:0}
.cv-eyebrow{font-family:'Cinzel',serif;font-size:11px;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold-l);opacity:0;animation:rise .9s .2s forwards}
.cv-name{font-family:'Great Vibes',cursive;font-size:62px;line-height:1.25;margin:2px 0 6px;
  background:linear-gradient(180deg,#f6e7bd,#c79a35);-webkit-background-clip:text;background-clip:text;color:transparent;
  opacity:0;animation:rise 1s .65s forwards}
.cv-orn{width:180px;height:24px;color:var(--gold-l);display:block;margin:8px auto 6px;opacity:0;animation:rise .9s .9s forwards}
.cv-sub{font-family:'Cinzel',serif;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:#e7d6a8;opacity:0;animation:rise .9s 1.05s forwards}
.cv-date{font-size:18px;margin-top:12px;color:#f3e6c4;opacity:0;animation:rise .9s 1.2s forwards}
.cv-date sup{font-size:.6em}
.cv-btn{margin-top:26px;padding:14px 34px;border-radius:40px;cursor:pointer;
  font-family:'Cinzel',serif;font-size:14px;letter-spacing:2px;text-transform:uppercase;color:#15402e;
  background:linear-gradient(180deg,#f1dca0,#c89e3c);border:none;
  box-shadow:0 10px 26px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.5);
  opacity:0;animation:rise .9s 1.4s forwards,glow 2.6s 2.4s ease-in-out infinite}
.cv-btn:active{transform:scale(.96)}
.cv-hint{margin-top:14px;font-size:13px;letter-spacing:1px;color:rgba(231,214,168,.7);opacity:0;animation:rise .9s 1.6s forwards}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes glow{0%,100%{box-shadow:0 10px 26px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.5),0 0 0 0 rgba(224,195,114,.5)}50%{box-shadow:0 10px 26px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.5),0 0 26px 4px rgba(224,195,114,.45)}}

/* music button */
.music{position:fixed;right:16px;z-index:40;bottom:calc(16px + env(safe-area-inset-bottom));
  width:54px;height:54px;border-radius:50%;border:1px solid var(--gold-l);cursor:pointer;
  background:linear-gradient(150deg,var(--emerald),var(--emerald-d));
  color:var(--gold-l);font-size:21px;box-shadow:0 8px 20px rgba(18,52,36,.45);
  display:flex;align-items:center;justify-content:center;transition:transform .3s}
.music:active{transform:scale(.94)}
.music .ring{position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(184,146,47,.6);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}
.music.paused .ring{display:none}

/* ornamental fixed frame */
.appframe{position:fixed;inset:10px;border:1px solid rgba(184,146,47,.45);border-radius:4px;pointer-events:none;z-index:20}
.appframe .fc{position:absolute;width:16px;height:16px;border:1.5px solid var(--gold)}
.appframe .tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.appframe .tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.appframe .bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.appframe .br{bottom:-1px;right:-1px;border-left:0;border-top:0}

.wrap{--pad:clamp(16px,5vw,24px);width:100%;max-width:460px;margin:0 auto;
  padding:0 var(--pad) calc(74px + env(safe-area-inset-bottom));position:relative;z-index:10}

/* hero */
.hero{display:block;text-align:center;padding:clamp(18px,5vw,28px) 0 6px}
.hero-kicker{font-family:'Great Vibes',cursive;font-size:clamp(38px,12vw,54px);line-height:1.2;color:var(--emerald);
  margin:0 0 14px;background:linear-gradient(180deg,#2a7a5c,#15402e);-webkit-background-clip:text;
  background-clip:text;color:transparent;opacity:0;animation:fadeUp 1s .1s forwards}
.frame{position:relative;width:calc(100% + var(--pad) + var(--pad));margin-left:calc(0px - var(--pad));margin-bottom:20px;
  opacity:0;animation:fadeIn 1.3s .2s forwards}
.hero-location{display:inline-flex;align-items:center;justify-content:center;gap:12px;margin-top:4px;padding:11px 18px;
  border-bottom:1px solid rgba(184,146,47,.65);font-family:'Cinzel',serif;font-size:clamp(10px,2.8vw,12px);
  letter-spacing:2px;text-transform:uppercase;text-decoration:none;color:var(--emerald);opacity:0;animation:fadeUp 1s .9s forwards}
.hero-location-copy{display:grid;gap:4px}
.hero-location-copy strong{font:inherit;font-weight:500}
.nickname{display:block;width:100%;font-family:'Great Vibes',cursive;font-size:2.25em;line-height:1.2;
  letter-spacing:1px;text-align:center;text-transform:none;margin:-.08em 0 -.12em;
  background:linear-gradient(90deg,#8c2f3d,#d7972e,#1f7a58,#b8922f,#8c2f3d);
  background-size:250% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 2px 5px rgba(184,146,47,.2));
  animation:nicknameShimmer 4s linear infinite,nicknameFloat 2.4s ease-in-out infinite}
.hero-location-copy small{font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:1px;
  text-transform:none;color:var(--soft)}
.hero-location .hero-location-arrow{font-size:20px;color:var(--gold);animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@keyframes nicknameShimmer{to{background-position:250% 0}}
@keyframes nicknameFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.05)}}

/* SVG ornament divider */
.orn{height:30px;margin:clamp(28px,7vw,40px) 0 clamp(22px,5vw,28px);
  background-repeat:no-repeat;background-position:center;background-size:auto 26px;
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 30'%3E%3Cg fill='none' stroke='%23b8922f' stroke-width='1.1'%3E%3Cpath d='M10 15 H96'/%3E%3Cpath d='M230 15 H144'/%3E%3Ccircle cx='103' cy='15' r='2'/%3E%3Ccircle cx='137' cy='15' r='2'/%3E%3C/g%3E%3Cg fill='%231f5c44'%3E%3Cpath d='M120 3 C125 8 125 15 120 22 C115 15 115 8 120 3Z'/%3E%3C/g%3E%3Cg fill='%23b8922f'%3E%3Cpath d='M120 7 C131 11 132 17 120 22 C108 17 109 11 120 7Z' opacity='.85'/%3E%3Cpath d='M120 7 C109 11 108 17 120 22 C132 17 131 11 120 7Z' opacity='.85'/%3E%3C/g%3E%3C/svg%3E")}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

.eyebrow-c{font-family:'Cinzel',serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.section-label{text-align:center}

/* elegant card */
.card{background:linear-gradient(180deg,rgba(255,253,247,.95),rgba(249,242,226,.95));
  border:1px solid var(--gold-l);border-radius:6px;position:relative;text-align:center;
  padding:clamp(28px,7vw,36px) clamp(20px,6vw,28px);
  box-shadow:0 14px 32px rgba(18,52,36,.1),inset 0 0 0 4px rgba(184,146,47,.16)}
.card .corner{position:absolute;width:16px;height:16px;border:1px solid var(--gold);opacity:.85}
.card .c1{top:7px;left:7px;border-right:0;border-bottom:0}
.card .c2{top:7px;right:7px;border-left:0;border-bottom:0}
.card .c3{bottom:7px;left:7px;border-right:0;border-top:0}
.card .c4{bottom:7px;right:7px;border-left:0;border-top:0}

/* prominent event information */
#venue{scroll-margin-top:24px}
.event-card{text-align:left;padding:clamp(28px,7vw,38px) clamp(20px,6vw,30px)}
.event-card>.eyebrow-c{text-align:center;margin-bottom:8px}
.event-heading{font-family:'Great Vibes',cursive;font-size:clamp(42px,13vw,58px);font-weight:400;line-height:1.15;
  text-align:center;color:var(--emerald);margin-bottom:22px;white-space:nowrap}
.venue-primary{display:grid;grid-template-columns:52px 1fr;gap:14px;align-items:start;padding:18px 16px;
  border:1px solid rgba(184,146,47,.55);border-radius:5px;
  background:linear-gradient(135deg,rgba(31,92,68,.08),rgba(224,195,114,.13))}
.venue-icon{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-size:27px;
  color:var(--gold-l);background:linear-gradient(150deg,var(--emerald),var(--emerald-d));
  border:1px solid var(--gold-l);box-shadow:0 5px 14px rgba(18,52,36,.26)}
.lbl{display:block;font-family:'Cinzel',serif;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:4px}
.venue-name{font-size:clamp(18px,4.8vw,24px);line-height:1.15;color:var(--ink);font-weight:600;white-space:nowrap}
.venue-primary address{font-style:normal;font-size:clamp(15px,4.2vw,17px);line-height:1.45;color:var(--soft);margin-top:5px}
.date-strip{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:12px;overflow:hidden;
  border:1px solid rgba(184,146,47,.45);border-radius:5px;background:rgba(184,146,47,.35)}
.date-strip>div{padding:14px 12px;background:rgba(255,253,247,.96)}
.date-strip strong{display:block;font-size:clamp(15px,4.2vw,17px);line-height:1.3;color:var(--ink)}
.btn.map-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:16px;text-align:center}
.map-btn span{font-size:17px}
.map-note{text-align:center;margin-top:9px;font-size:13px;font-style:italic;color:var(--soft)}
.pdf-actions{margin-top:22px;padding-top:20px;border-top:1px solid rgba(184,146,47,.35)}
.pdf-copy{display:flex;align-items:center;gap:12px}
.pdf-icon{flex:0 0 42px;height:42px;border-radius:4px;display:grid;place-items:center;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;font-weight:600;color:#f6e7bd;
  background:linear-gradient(150deg,var(--berry),#621e29);border:1px solid rgba(184,146,47,.65);
  box-shadow:0 5px 12px rgba(98,30,41,.2)}
.pdf-copy strong{display:block;font-size:18px;line-height:1.15;color:var(--ink)}
.pdf-copy div>span{display:block;margin-top:2px;font-size:14px;color:var(--soft)}
.pdf-buttons{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:14px}
.pdf-btn{min-height:44px;padding:11px 10px;border-radius:30px;display:flex;align-items:center;justify-content:center;gap:7px;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease}
.pdf-btn:hover{transform:translateY(-2px)}
.pdf-btn:focus-visible{outline:3px solid var(--emerald);outline-offset:3px}
.pdf-open{color:var(--gold-l);background:linear-gradient(150deg,var(--emerald),var(--emerald-d));
  border:1px solid var(--gold-l);box-shadow:0 6px 14px rgba(18,52,36,.22)}
.pdf-download{color:var(--emerald-d);background:#fffdf7;border:1px solid var(--gold);
  box-shadow:0 6px 14px rgba(18,52,36,.09)}
.pdf-quick-links{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px 9px;
  margin-top:18px;font-size:14px;color:var(--soft)}
.pdf-quick-links a{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--emerald);font-weight:600;text-underline-offset:4px}

.poem{font-size:clamp(18px,5.2vw,22px);line-height:1.7;font-style:italic;color:var(--soft);white-space:pre-line}
.poem b{color:var(--berry);font-style:normal;font-weight:600}
.signoff{margin-top:18px;font-family:'Cinzel',serif;font-size:clamp(12px,3.4vw,14px);letter-spacing:4px;color:var(--gold);font-weight:600}

.invite-line{font-size:clamp(17px,4.8vw,20px);line-height:1.6;color:var(--soft);text-align:center}
.name-big{font-family:'Great Vibes',cursive;font-size:clamp(50px,17vw,76px);line-height:1.25;color:var(--emerald);
  width:100%;margin:-2px auto 10px;text-align:center;
  background:linear-gradient(180deg,#2a7a5c,#15402e);-webkit-background-clip:text;background-clip:text;color:transparent}

/* framed invitation images */
.image-frame{appearance:none;-webkit-appearance:none;padding:clamp(5px,1.5vw,7px);border:1px solid var(--gold);
  border-radius:3px;display:block;position:relative;cursor:zoom-in;color:inherit;font:inherit;
  background:linear-gradient(135deg,#fffdf7 0%,#ead9a8 48%,#fffdf7 100%);
  box-shadow:0 14px 30px rgba(18,52,36,.2),0 0 0 3px rgba(255,255,255,.8),0 0 0 4px rgba(184,146,47,.38);
  transition:transform .3s ease,box-shadow .3s ease}
.image-frame::before{content:"";position:absolute;inset:10px;border:1px solid rgba(224,195,114,.8);
  pointer-events:none;z-index:1;box-shadow:inset 0 0 0 1px rgba(18,52,36,.18)}
.image-frame::after{content:"\2315";position:absolute;right:14px;bottom:14px;z-index:2;width:36px;height:36px;
  border:1px solid rgba(224,195,114,.8);border-radius:50%;display:grid;place-items:center;
  color:#f6e7bd;background:rgba(14,43,31,.82);font-size:22px;line-height:1;
  box-shadow:0 5px 14px rgba(0,0,0,.28);transition:transform .3s ease,background .3s ease}
.image-frame img{width:100%;height:auto;display:block}
.image-frame:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(18,52,36,.25),0 0 0 3px #fff,0 0 0 4px var(--gold)}
.image-frame:hover::after{transform:scale(1.08);background:rgba(31,92,68,.95)}
.image-frame:focus-visible{outline:3px solid var(--emerald);outline-offset:6px}
.image-frame:active{transform:scale(.985)}
.page-frame{width:calc(100% + var(--pad) + var(--pad));margin-left:calc(0px - var(--pad))}

/* full-screen image preview */
.lightbox{position:fixed;inset:0;z-index:100;display:grid;grid-template-columns:clamp(48px,10vw,82px) 1fr clamp(48px,10vw,82px);
  align-items:center;padding:max(16px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right))
  max(16px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left));
  background:rgba(5,22,15,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease,visibility .35s ease}
.lightbox.open{opacity:1;visibility:visible;pointer-events:auto}
.lightbox-glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 45%,rgba(224,195,114,.18),transparent 48%),
  linear-gradient(135deg,rgba(31,92,68,.18),transparent 45%)}
.lightbox-stage{min-width:0;max-width:min(100%,900px);max-height:calc(100dvh - 80px);margin:auto;display:flex;
  flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:1}
.lightbox-frame{position:relative;display:flex;max-width:100%;max-height:calc(100dvh - 130px);padding:7px;
  border:1px solid var(--gold-l);background:linear-gradient(135deg,#f7e7b9,#9a7820,#f7e7b9);
  box-shadow:0 24px 70px rgba(0,0,0,.65),0 0 0 5px rgba(224,195,114,.1);
  transform:scale(.94);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.lightbox.open .lightbox-frame{transform:scale(1)}
.lightbox-frame::after{content:"";position:absolute;inset:12px;border:1px solid rgba(246,231,189,.6);pointer-events:none}
.lightbox-frame img{display:block;max-width:100%;max-height:calc(100dvh - 144px);object-fit:contain;background:#102f23}
.lightbox-meta{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:13px 2px 0;color:#f3e6c4}
.lightbox-caption{font-size:clamp(16px,3vw,20px);font-style:italic}
.lightbox-count{font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;color:var(--gold-l);white-space:nowrap}
.lightbox-close,.lightbox-nav{appearance:none;border:1px solid rgba(224,195,114,.65);border-radius:50%;
  display:grid;place-items:center;position:relative;z-index:2;cursor:pointer;color:var(--gold-l);
  background:rgba(18,53,36,.78);box-shadow:0 8px 24px rgba(0,0,0,.35);
  transition:transform .25s ease,background .25s ease}
.lightbox-close:hover,.lightbox-nav:hover{background:var(--emerald);transform:scale(1.08)}
.lightbox-close:focus-visible,.lightbox-nav:focus-visible{outline:2px solid #fff;outline-offset:4px}
.lightbox-close{position:absolute;top:max(16px,env(safe-area-inset-top));right:max(16px,env(safe-area-inset-right));
  width:44px;height:44px;font-size:16px}
.lightbox-nav{width:46px;height:46px;font-size:25px;justify-self:center}
.lightbox-prev{grid-column:1}.lightbox-stage{grid-column:2}.lightbox-next{grid-column:3}

.btn{display:inline-block;margin-top:22px;padding:13px 34px;border-radius:40px;text-decoration:none;
  font-family:'Cinzel',serif;font-size:13px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold-l);background:linear-gradient(150deg,var(--emerald),var(--emerald-d));
  border:1px solid var(--gold-l);box-shadow:0 8px 20px rgba(18,52,36,.3);transition:transform .25s}
.btn:active{transform:scale(.97)}

.regards{font-size:clamp(16px,4.6vw,18px);line-height:1.7;color:var(--soft)}
.regards .who{font-family:'Great Vibes',cursive;font-size:clamp(26px,8vw,34px);color:var(--emerald);margin-top:6px;display:block}

.footer{text-align:center;margin-top:clamp(32px,8vw,46px);font-family:'Cinzel',serif;
  font-size:12px;letter-spacing:2px;color:var(--soft);opacity:.85}
.footer .heart{color:var(--berry)}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

@media (min-width:520px){
  .frame{width:min(86vw,400px);margin-left:auto;margin-right:auto}
  .page-frame{width:100%;margin-left:0}
}
@media (max-width:519px){
  .date-strip{grid-template-columns:1fr}
  .lightbox{grid-template-columns:1fr 1fr;padding:64px 14px max(14px,env(safe-area-inset-bottom))}
  .lightbox-stage{grid-column:1 / -1;grid-row:1}
  .lightbox-prev,.lightbox-next{grid-row:2;margin-top:12px}
  .lightbox-prev{grid-column:1;justify-self:end;margin-right:10px}
  .lightbox-next{grid-column:2;justify-self:start;margin-left:10px}
  .lightbox-frame{max-height:calc(100dvh - 190px)}
  .lightbox-frame img{max-height:calc(100dvh - 204px)}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.2s!important}
  .reveal{opacity:1;transform:none}
}
