/* =========================================================================
   PRIYANKA & ARAVIND — Wedding Site
   Direction 04 · "Vetiver & Blush"  (Lumen Vitae — where light meets life)
   ========================================================================= */

/* ---------- Fonts ---------- */
@font-face{font-family:'Instr';src:url('assets/fonts/InstrumentSerif-Regular.ttf');font-display:swap;}
@font-face{font-family:'Instr';font-style:italic;src:url('assets/fonts/InstrumentSerif-Italic.ttf');font-display:swap;}
@font-face{font-family:'Lora';src:url('assets/fonts/Lora-Regular.ttf');font-display:swap;}
@font-face{font-family:'Lora';font-style:italic;src:url('assets/fonts/Lora-Italic.ttf');font-display:swap;}
@font-face{font-family:'Jura';font-weight:300;src:url('assets/fonts/Jura-Light.ttf');font-display:swap;}
@font-face{font-family:'Jura';font-weight:500;src:url('assets/fonts/Jura-Medium.ttf');font-display:swap;}
@font-face{font-family:'Arsenal';src:url('assets/fonts/ArsenalSC-Regular.ttf');font-display:swap;}
@font-face{font-family:'Cormorant';src:url('assets/fonts/Cormorant.ttf');font-display:swap;}
@font-face{font-family:'Cormorant';font-style:italic;src:url('assets/fonts/Cormorant-Italic.ttf');font-display:swap;}
@font-face{font-family:'Pinyon';src:url('assets/fonts/PinyonScript.ttf');font-display:swap;}

/* ---------- Tokens ---------- */
html{color-scheme:light}
:root{
  --ivory:#f5f0e6; --ivory-2:#fbf8f2; --paper:#efe9dd;
  --sage:#8c9a7e; --sage-deep:#455138; --mist:#cbd2c2;
  --terra:#be6a48; --terra-deep:#a4542f;
  --blush:#e9c9bc; --blush-soft:#f1dcd2;
  --clove:#5a4836; --ink:#2f322a; --ink-soft:#4c4f43;
  --line:rgba(110,90,72,.18);
  --shadow:0 18px 50px -28px rgba(60,55,40,.45);
  --maxw:1180px;
  --serif:'Cormorant','Instr',Georgia,serif;
  --body:'Lora',Georgia,serif;
  --label:'Jura',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:84px;overflow-x:hidden;}
body{
  font-family:var(--body);color:var(--ink);background:var(--ivory);
  font-size:17px;line-height:1.75;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ---------- Type atoms ---------- */
.eyebrow{font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.42em;font-size:11.5px;color:var(--sage);}
.display{font-family:var(--serif);font-weight:400;line-height:1;letter-spacing:.005em;}
.script{font-family:'Script',cursive;color:var(--terra);}
.amp{font-family:var(--body);font-style:italic;color:var(--terra);}
h2.sec-title{font-family:var(--serif);font-weight:400;color:var(--sage-deep);
  font-size:clamp(34px,5.5vw,58px);line-height:1.02;letter-spacing:.01em;}
.sec-lead{font-style:italic;color:var(--ink-soft);max-width:54ch;margin:0 auto;}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
section{padding:clamp(70px,9vw,128px) 0;position:relative;}
.center{text-align:center;}
.sec-head{text-align:center;margin-bottom:56px;}
.sec-head .eyebrow{display:block;margin-bottom:18px;}
.divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:20px auto 0;}
.divider .ln{height:1px;width:54px;background:var(--line);}
.divider .dot{width:5px;height:5px;border-radius:50%;background:var(--terra);opacity:.7;}
.alt{background:var(--ivory-2);}
.paper{background:var(--paper);}

/* ---------- Nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,4vw,40px);
  background:rgba(245,240,230,0);transition:background .4s ease,box-shadow .4s ease,padding .4s ease;}
header.nav.solid{background:rgba(245,240,230,.92);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--line);padding-top:12px;padding-bottom:12px;}
.nav .brand{font-family:'Arsenal';font-size:19px;letter-spacing:.14em;color:var(--sage-deep);}
.nav .brand .heart{color:var(--terra);margin:0 4px;}
.nav nav{display:flex;gap:30px;align-items:center;}
.nav nav a{font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.18em;font-size:11px;color:var(--ink-soft);position:relative;padding:4px 0;}
.nav nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;
  background:var(--terra);transition:right .3s ease;}
.nav nav a:hover{color:var(--clove);}
.nav nav a:hover::after{right:0;}
.nav .nav-cta{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.18em;
  font-size:11px;border:1px solid var(--sage);color:var(--sage-deep);border-radius:30px;padding:9px 18px;}
.nav .nav-cta:hover{background:var(--sage);color:var(--ivory);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;min-width:44px;min-height:44px;align-items:center;justify-content:center;}
.burger span{width:24px;height:2px;background:var(--clove);border-radius:2px;transition:.3s;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--label);font-weight:500;
  text-transform:uppercase;letter-spacing:.2em;font-size:12px;cursor:pointer;
  padding:15px 30px;border-radius:34px;border:1px solid transparent;transition:.3s;}
.btn-primary{background:var(--terra-deep);color:#fff;box-shadow:0 12px 26px -14px rgba(164,84,47,.7);}
/* AA contrast: terracotta #be6a48 fails AA on ivory (~3.4:1) — deepen micro-labels to terra-deep */
.ev .when,.fam-card .role,.ev-label,.dress-guide .dg-day,.bless .by,.concierge .c .role{color:var(--terra-deep);}
.btn-primary:hover{background:var(--terra-deep);transform:translateY(-2px);}
.btn-ghost{border-color:var(--sage);color:var(--sage-deep);background:transparent;}
.btn-ghost:hover{background:var(--sage);color:#fff;}
.btn-soft{background:var(--ivory);border-color:var(--line);color:var(--clove);}
.btn-soft:hover{border-color:var(--sage);}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;
  position:relative;overflow:hidden;
  background:
    radial-gradient(60% 50% at 78% 22%,rgba(233,201,188,.5),transparent 60%),
    radial-gradient(55% 45% at 18% 78%,rgba(140,154,126,.28),transparent 60%),
    linear-gradient(160deg,#eef0e6 0%,var(--ivory) 48%,#ece2d5 100%);}
.hero .veil{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 30%,transparent 40%,rgba(110,90,72,.06));}
.hero-inner{position:relative;z-index:2;padding:120px 24px 90px;}
.hero .kicker{margin-bottom:26px;}
.hero h1{font-family:var(--serif);font-weight:400;color:var(--sage-deep);
  font-size:clamp(58px,12vw,150px);line-height:.9;letter-spacing:.01em;}
.hero h1 .amp{display:block;font-size:.42em;margin:6px 0;color:var(--terra);}
.hero .tag{font-style:italic;color:var(--ink-soft);font-size:clamp(17px,2.4vw,22px);margin-top:26px;}
.hero .meta{display:flex;gap:18px;align-items:center;justify-content:center;flex-wrap:wrap;
  margin-top:30px;font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.2em;font-size:15px;color:var(--clove);}
.hero .meta .sep{width:5px;height:5px;border-radius:50%;background:var(--terra);}
.hero .cta-row{margin-top:42px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  font-family:var(--label);letter-spacing:.3em;text-transform:uppercase;font-size:9.5px;color:var(--sage);
  display:flex;flex-direction:column;align-items:center;gap:8px;}
.scrollcue .line{width:1px;height:34px;background:linear-gradient(var(--sage),transparent);animation:cue 2.4s ease-in-out infinite;}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6);transform-origin:top;}50%{opacity:1;transform:scaleY(1);}}
.sprig{position:absolute;opacity:.5;z-index:1;}

/* ---------- Intro ---------- */
.intro{text-align:center;}
.intro .big{font-family:var(--serif);font-weight:400;color:var(--ink);
  font-size:clamp(24px,3.6vw,40px);line-height:1.4;max-width:20ch;margin:0 auto;}
.intro .big em{font-style:italic;color:var(--terra);}
.intro .names-script{font-family:'Script',cursive;color:var(--sage);font-size:clamp(30px,5vw,48px);margin-top:18px;}

/* ---------- Countdown ---------- */
.countdown{background:
   radial-gradient(50% 80% at 50% 0%,rgba(140,154,126,.18),transparent),var(--ivory-2);}
.cd-grid{display:flex;gap:clamp(16px,4vw,52px);justify-content:center;flex-wrap:wrap;margin-top:14px;}
.cd-cell{text-align:center;min-width:78px;}
.cd-cell .num{font-family:var(--serif);font-size:clamp(48px,8vw,84px);line-height:1;color:var(--sage-deep);}
.cd-cell .lab{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.3em;
  font-size:11px;color:var(--clove);margin-top:8px;}
.cd-date{margin-top:34px;font-style:italic;color:var(--ink-soft);}

/* ---------- Story ---------- */
.story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,6vw,80px);align-items:center;}
.story-art{aspect-ratio:4/5;border-radius:200px 200px 14px 14px;overflow:hidden;position:relative;
  background:linear-gradient(160deg,var(--blush-soft),var(--mist));box-shadow:var(--shadow);}
.story-art .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;}
.story-copy p{margin-bottom:18px;}
.story-copy .lead-line{font-family:var(--serif);font-size:clamp(24px,3vw,34px);color:var(--sage-deep);line-height:1.25;margin-bottom:24px;}

/* ---------- Families ---------- */
.fam-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,64px);}
.fam-card{text-align:center;padding:44px 30px;background:var(--ivory-2);border:1px solid var(--line);border-radius:14px;}
.fam-card .role{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.32em;font-size:11px;color:var(--terra);}
.fam-card h3{font-family:var(--serif);font-weight:400;font-size:clamp(28px,4vw,40px);color:var(--sage-deep);margin:10px 0 6px;}
.fam-card .sub{font-style:italic;color:var(--clove);font-size:17px;margin-bottom:20px;}
.fam-card ul{list-style:none;}
/* siblings read quieter than the parents line (smaller + softer) so parents lead */
.fam-card li{padding:7px 0;border-top:1px solid var(--line);font-size:14.5px;color:var(--ink-soft);}
.fam-card li:first-child{border-top:0;}

/* ---------- Events / timeline ---------- */
.tl{max-width:760px;margin:0 auto;position:relative;}
.tl::before{content:"";position:absolute;left:26px;top:8px;bottom:8px;width:1px;background:var(--line);}
.ev{display:grid;grid-template-columns:54px 1fr;gap:22px;padding:18px 0;position:relative;}
.ev .node{width:13px;height:13px;border-radius:50%;background:var(--ivory);border:2px solid var(--terra);
  margin-left:20px;margin-top:8px;z-index:2;}
.ev .card{background:var(--ivory-2);border:1px solid var(--line);border-radius:12px;padding:22px 26px;transition:.3s;}
.ev .card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.ev .when{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--terra);}
.ev h3{font-family:var(--serif);font-weight:400;font-size:26px;color:var(--sage-deep);margin:4px 0 6px;}
.ev .where{font-style:italic;color:var(--ink-soft);font-size:15px;}
/* expandable event cards */
.ev-card{cursor:pointer;}
.ev-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;}
.ev-cue{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.18em;
  font-size:10px;color:var(--sage);display:inline-flex;align-items:center;gap:7px;flex:none;white-space:nowrap;margin-top:6px;}
.ev-plus{font-family:var(--body);color:var(--terra);font-size:20px;line-height:1;transition:transform .3s ease;}
.ev-card.open .ev-plus{transform:rotate(45deg);}
.ev-card:hover .ev-cue{color:var(--sage-deep);}
.ev-more{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.ev-detail{display:flex;gap:16px;align-items:baseline;padding-top:14px;margin-top:14px;border-top:1px solid var(--line);}
.ev-label{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.18em;
  font-size:10px;color:var(--terra);min-width:92px;flex:none;}
.ev-val{font-size:15px;color:var(--ink-soft);line-height:1.55;}
@media(max-width:560px){
  .ev-detail{flex-direction:column;gap:4px;}
}

/* ---------- Venue ---------- */
.venue-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,5vw,56px);align-items:stretch;}
.venue-info{display:flex;flex-direction:column;justify-content:center;}
.venue-info h3{font-family:var(--serif);font-weight:400;font-size:clamp(30px,4vw,44px);color:var(--sage-deep);}
.venue-info .addr{font-style:italic;color:var(--ink-soft);margin:14px 0 24px;}
.venue-info .row{display:flex;gap:14px;flex-wrap:wrap;}
.map-wrap{border-radius:14px;overflow:hidden;border:1px solid var(--line);min-height:340px;box-shadow:var(--shadow);}
.map-wrap iframe{width:100%;height:100%;min-height:340px;border:0;filter:saturate(.9) contrast(.98);}
.stay{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;}
.stay .s{background:var(--ivory-2);border:1px solid var(--line);border-radius:12px;padding:24px;}
.stay .s .ic{font-size:22px;}
.stay .s h4{font-family:var(--serif);font-weight:400;font-size:22px;color:var(--sage-deep);margin:8px 0 4px;}
.stay .s p{font-size:15px;color:var(--ink-soft);}

/* ---------- Gallery ---------- */
/* Masonry — keeps every photo's true aspect (engagement landscape + pre-wedding portrait), no crop, no stretch */
.gal{column-count:3;column-gap:14px;}
.gal .gcell{display:block;width:100%;margin:0 0 14px;break-inside:avoid;-webkit-column-break-inside:avoid;
  border-radius:12px;overflow:hidden;position:relative;line-height:0;
  background:linear-gradient(150deg,var(--blush-soft),var(--mist));box-shadow:0 12px 30px -24px rgba(60,55,40,.55);}
.gal .gcell img{width:100%;height:auto;display:block;border-radius:12px;transition:transform .5s ease,filter .5s ease;}
.gal .gcell:hover img{transform:scale(1.035);}
.gal .gcell:focus-visible{outline:2px solid var(--terra);outline-offset:3px;}
/* legacy placeholder cells (no longer in markup) */
.gal .cell{border-radius:12px;overflow:hidden;position:relative;
  background:linear-gradient(150deg,var(--blush-soft),var(--mist));display:flex;align-items:center;justify-content:center;}
.gal .cell .lbl{font-family:var(--label);letter-spacing:.25em;text-transform:uppercase;font-size:10px;color:var(--sage-deep);opacity:.7;}
.gal-note{text-align:center;margin-top:26px;font-style:italic;color:var(--ink-soft);}

/* ---------- Live ---------- */
.live{text-align:center;background:linear-gradient(160deg,var(--sage-deep),#4e5743);color:var(--ivory);}
.live .eyebrow{color:var(--blush);}
.live h2.sec-title{color:var(--ivory-2);}
.live .sec-lead{color:rgba(245,240,230,.92);}
/* dress-code per-event guide */
.dress-guide{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:10px;}
.dress-guide .dg{flex:1 1 220px;max-width:320px;background:var(--ivory-2);border:1px solid var(--line);border-radius:14px;padding:28px 24px;text-align:center;}
.dress-guide .dg-day{font-family:var(--label);font-weight:500;text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--terra);margin-bottom:10px;}
.dress-guide .dg-what{font-family:var(--serif);font-size:clamp(20px,3vw,27px);color:var(--sage-deep);}
/* gallery sub-titles (Engagement / Pre-Wedding) */
.gal-title{font-family:var(--serif);font-weight:400;color:var(--sage-deep);font-size:clamp(22px,3.5vw,30px);text-align:center;margin-bottom:20px;}
/* interlocking rings — subtle wedding motif */
.hero .rings{display:block;margin:24px auto 0;width:58px;height:auto;opacity:.9;}
.hero .rings .r1{stroke:var(--sage);}
.hero .rings .r2{stroke:var(--terra);}
/* a single solitaire set on the gold ring */
.hero .rings .sol-gem{fill:#fbf8f2;stroke:var(--terra);stroke-width:.7;}
.hero .rings .sol-fac{fill:none;stroke:var(--terra);stroke-width:.45;opacity:.6;}
.live .pulse{display:inline-flex;align-items:center;gap:9px;font-family:var(--label);letter-spacing:.2em;
  text-transform:uppercase;font-size:11px;margin-top:24px;color:var(--blush);}
.live .pulse .d{width:9px;height:9px;border-radius:50%;background:var(--terra);box-shadow:0 0 0 0 rgba(190,106,72,.7);animation:pl 1.8s infinite;}
@keyframes pl{0%{box-shadow:0 0 0 0 rgba(190,106,72,.6);}70%{box-shadow:0 0 0 14px rgba(190,106,72,0);}100%{box-shadow:0 0 0 0 rgba(190,106,72,0);}}
.live .btn-primary{margin-top:30px;}

/* ---------- RSVP ---------- */
.rsvp-card{max-width:680px;margin:0 auto;background:var(--ivory-2);border:1px solid var(--line);
  border-radius:18px;padding:clamp(28px,5vw,52px);box-shadow:var(--shadow);}
.field{margin-bottom:20px;}
.field label{display:block;font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.18em;font-size:10.5px;color:var(--clove);margin-bottom:8px;}
.field input,.field select,.field textarea{width:100%;font-family:var(--body);font-size:16px;color:var(--ink);
  background:var(--ivory);border:1px solid var(--line);border-radius:10px;padding:13px 15px;transition:.25s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--sage);}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field.two>div{margin:0;}
.seg{display:flex;gap:10px;}
.seg label{flex:1;cursor:pointer;}
.seg input{position:absolute;opacity:0;width:1px;height:1px;}
.seg .opt{display:block;text-align:center;padding:13px;border:1px solid var(--line);border-radius:10px;
  font-family:var(--label);letter-spacing:.12em;text-transform:uppercase;font-size:12px;transition:.25s;}
.seg input:checked + .opt{background:var(--sage);color:#fff;border-color:var(--sage);}
.rsvp-note{font-size:13px;color:var(--ink-soft);text-align:center;margin-top:8px;}

/* ---------- Registry ---------- */
.reg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.reg-card{background:var(--ivory-2);border:1px solid var(--line);border-radius:14px;padding:34px 28px;text-align:center;transition:.3s;}
.reg-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.reg-card .ic{font-size:26px;}
.reg-card h3{font-family:var(--serif);font-weight:400;font-size:24px;color:var(--sage-deep);margin:12px 0 8px;}
.reg-card p{font-size:14.5px;color:var(--ink-soft);margin-bottom:20px;min-height:42px;}

/* ---------- Blessings ---------- */
.bless-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:34px;}
.bless{background:var(--ivory-2);border:1px solid var(--line);border-radius:14px;padding:26px;position:relative;}
.bless .q{font-family:var(--serif);font-size:40px;color:var(--blush);line-height:.6;}
.bless p{font-style:italic;color:var(--ink-soft);margin:6px 0 14px;}
.bless .by{font-family:var(--label);text-transform:uppercase;letter-spacing:.2em;font-size:10.5px;color:var(--terra);}

/* ---------- Dress code ---------- */
.dress{text-align:center;}
.palette-strip{display:flex;gap:0;max-width:560px;margin:30px auto 0;border-radius:40px;overflow:hidden;box-shadow:var(--shadow);}
.palette-strip .c{flex:1;height:64px;position:relative;}
.palette-strip .c span{position:absolute;bottom:-26px;left:0;right:0;font-family:var(--label);
  letter-spacing:.12em;text-transform:uppercase;font-size:9px;color:var(--ink-soft);}
.dress .hint{margin-top:54px;font-style:italic;color:var(--ink-soft);}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:760px;margin:0 auto;}
.faq{border-bottom:1px solid var(--line);}
.faq button{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 4px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--serif);font-size:21px;color:var(--sage-deep);}
.faq button .pm{font-family:var(--body);color:var(--terra);transition:.3s;flex:none;font-size:22px;}
.faq.open button .pm{transform:rotate(45deg);}
.faq .ans{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.faq .ans p{padding:0 4px 22px;color:var(--ink-soft);}
.concierge{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px;}
.concierge .c{background:var(--ivory-2);border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center;}
.concierge .c .role{font-family:var(--label);text-transform:uppercase;letter-spacing:.2em;font-size:10px;color:var(--terra);}
.concierge .c h4{font-family:var(--serif);font-weight:400;font-size:21px;color:var(--sage-deep);margin:6px 0 2px;}
.concierge .c a{font-size:15px;color:var(--ink-soft);}
.concierge-note{text-align:center;max-width:54ch;margin:22px auto 0;}
.concierge-note p{font-style:italic;color:var(--ink-soft);font-size:clamp(15px,2vw,17px);line-height:1.6;}
/* ---- Leave-a-blessing modal ---- */
.bless-modal{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(38,40,33,.55);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);
  animation:blessfade .25s ease;}
.bless-modal[hidden]{display:none;}
@keyframes blessfade{from{opacity:0}to{opacity:1}}
.bless-dialog{position:relative;width:100%;max-width:440px;background:var(--ivory);border:1px solid var(--line);
  border-radius:18px;padding:36px 30px 30px;box-shadow:0 40px 90px -30px rgba(0,0,0,.55);}
.bless-dialog h3{font-family:var(--serif);font-weight:400;font-size:clamp(25px,5vw,32px);color:var(--sage-deep);text-align:center;}
.bless-sub{text-align:center;font-style:italic;color:var(--ink-soft);margin:8px auto 22px;max-width:34ch;line-height:1.5;}
.bless-x{position:absolute;top:12px;right:15px;background:none;border:0;font-size:28px;line-height:1;color:var(--clove);cursor:pointer;padding:4px;}
.bless-x:hover{color:var(--terra-deep);}

/* ---------- Footer ---------- */
footer{background:var(--sage-deep);color:var(--ivory);text-align:center;padding:70px 24px 40px;}
footer .mono{font-family:'Arsenal';font-size:30px;letter-spacing:.1em;color:var(--ivory-2);}
footer .mono .heart{color:var(--blush);}
footer .tag{font-style:italic;color:rgba(245,240,230,.75);margin:12px 0 22px;}
footer .hash{font-family:var(--label);font-weight:500;letter-spacing:.14em;font-size:13px;color:var(--blush);}
footer .fnav{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin:26px 0;}
footer .fnav a{font-family:var(--label);text-transform:uppercase;letter-spacing:.16em;font-size:10.5px;color:rgba(245,240,230,.7);}
footer .fnav a:hover{color:var(--ivory);}
footer .fine{font-size:12px;color:rgba(245,240,230,.5);margin-top:20px;}

/* ---------- Event credit (Wedding Chemistry) ---------- */
.event-credit{background:var(--ivory);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:11px;padding:30px 24px 40px;}
.event-credit .ec-by{font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.34em;font-size:10px;color:var(--ink-soft);opacity:.72;}
.event-credit .ec-logo{width:150px;height:auto;opacity:.92;}

/* ---------- placeholder chip ---------- */
.ph-tag{display:inline-block;font-family:var(--label);font-weight:500;text-transform:uppercase;
  letter-spacing:.14em;font-size:9px;color:var(--terra-deep);background:rgba(190,106,72,.1);
  border:1px dashed rgba(190,106,72,.5);border-radius:20px;padding:3px 9px;vertical-align:middle;}
.muted{color:var(--ink-soft);}

/* line icons */
.ico{width:30px;height:30px;stroke:var(--sage-deep);stroke-width:1.4;fill:none;
  stroke-linecap:round;stroke-linejoin:round;display:inline-block;}
.reg-card .ico{width:34px;height:34px;stroke:var(--terra);}
.stay .s .ic{line-height:0;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .nav nav{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;
    justify-content:center;gap:26px;background:var(--ivory-2);box-shadow:var(--shadow);
    transform:translateX(100%);transition:transform .4s ease;padding:40px;}
  .nav nav.open{transform:none;}
  .nav nav a{font-size:14px;}
  .burger{display:flex;z-index:60;}
  .story-grid,.venue-grid{grid-template-columns:1fr;}
  .story-art{max-width:420px;margin:0 auto;width:100%;}
  .reg-grid,.bless-grid,.concierge,.stay{grid-template-columns:1fr;}
  .gal{column-count:2;}
}
@media(max-width:560px){
  body{font-size:16px;}
  .fam-grid{grid-template-columns:1fr;}
  .field.two{grid-template-columns:1fr;}
  .hero .meta{font-size:13px;letter-spacing:.16em;flex-direction:column;gap:8px;}
  .hero .meta .sep{display:none;}
  .cd-grid{gap:14px;}
  .cd-cell{min-width:64px;}
  .palette-strip{flex-wrap:wrap;border-radius:14px;}
  .palette-strip .c{flex:1 0 33%;height:54px;margin-bottom:28px;}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;}
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* =========================================================================
   ELEVATION PASS — driven by Taste (design-taste-frontend) + Impeccable
   anti-slop directives, adapted for an editorial, ceremonial wedding
   context (intentionally low design-variance / symmetric).
   ========================================================================= */

/* Fine paper grain — fixed & pointer-safe (Taste §5 performance guardrail) */
body::after{content:"";position:fixed;inset:0;z-index:900;pointer-events:none;opacity:.035;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* Tactile feedback — physical push on press (Taste Rule 5) */
.btn{transition:background .3s,color .3s,border-color .3s,transform .12s ease,box-shadow .3s;}
.btn:active{transform:translateY(1px) scale(.99);}
.ev .card:active,.reg-card:active{transform:translateY(0);}

/* Visible focus states (accessibility / Impeccable) */
.btn:disabled,.btn[aria-disabled="true"]{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}

a:focus-visible,button:focus-visible,.ev-card:focus-visible,.faq button:focus-visible,.pa-tap:focus-visible{
  outline:2px solid var(--terra);outline-offset:3px;border-radius:4px;}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible,.seg input:focus-visible + .opt{outline:2px solid var(--sage);outline-offset:2px;}

/* Staggered, waterfall reveals (Taste §4 orchestration) */
.tl .ev:nth-child(2){transition-delay:.07s}
.tl .ev:nth-child(3){transition-delay:.14s}
.tl .ev:nth-child(4){transition-delay:.21s}

/* --- Kill the "3 equal cards" AI tell (Taste §7): unify into one divided
       composition with hairline separators, not three boxed cards. --- */
.stay{background:var(--ivory-2);border:1px solid var(--line);border-radius:16px;overflow:hidden;gap:0;}
.stay .s{background:transparent;border:0;border-left:1px solid var(--line);border-radius:0;}
.stay .s:first-child{border-left:0;}

.reg-grid{background:var(--ivory-2);border:1px solid var(--line);border-radius:20px;overflow:hidden;gap:0;}
.reg-card{background:transparent;border:0;border-left:1px solid var(--line);border-radius:0;
  transition:background .35s ease;}
.reg-card:first-child{border-left:0;}
.reg-card:hover{transform:none;box-shadow:none;background:rgba(140,154,126,.07);}

/* Give Back — single, centred statement (registry simplified to one option) */
.give-back{max-width:620px;margin:0 auto;text-align:center;background:var(--ivory-2);
  border:1px solid var(--line);border-radius:18px;padding:clamp(34px,5vw,56px);box-shadow:var(--shadow);}
.give-back .ico{width:44px;height:44px;stroke:var(--terra);}
.give-back .gb-line{font-family:var(--serif);font-size:clamp(20px,2.6vw,28px);line-height:1.4;
  color:var(--sage-deep);margin:16px auto 26px;max-width:30ch;}

.concierge{background:var(--ivory-2);border:1px solid var(--line);border-radius:16px;overflow:hidden;gap:0;}
.concierge .c{background:transparent;border:0;border-left:1px solid var(--line);border-radius:0;}
.concierge .c:first-child{border-left:0;}

/* Blessings: intentional vertical offset for asymmetric rhythm */
.bless:nth-child(2){transform:translateY(22px);}

/* Hero: calmer, more editorial scale; botanicals recede behind content */
.hero h1{font-size:clamp(52px,10.5vw,122px);}
.sprig{opacity:.38;}

/* Story portrait & gallery: make placeholders feel *designed*, not empty */
.story-art .ph,.gal .cell{position:relative;}
.story-art .ph::before,.gal .cell::before{content:"P \2022 A";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;font-family:'Arsenal';
  font-size:clamp(28px,6vw,54px);letter-spacing:.12em;color:rgba(95,106,82,.16);}
.story-art .ph{z-index:1;background:rgba(255,255,255,.0);}
.story-art .ph>*{position:relative;z-index:2;}
.gal .cell .lbl{position:relative;z-index:2;}

@media(max-width:900px){
  .stay .s,.reg-card,.concierge .c{border-left:0;border-top:1px solid var(--line);}
  .stay .s:first-child,.reg-card:first-child,.concierge .c:first-child{border-top:0;}
  .bless:nth-child(2){transform:none;}
}

/* =========================================================================
   /design-review (gstack) fix pass — findings F1–F4
   ========================================================================= */

/* F1 — Contrast: eyebrows were sage on cream (~2:1, fails WCAG AA).
   Move to sage-deep (~4.8:1). Dark-section overrides keep their colour
   via higher specificity (.live .eyebrow / .live .pulse). */
.eyebrow{color:var(--sage-deep);}

/* F2 — Replace the casual marker-style script (NothingYouCouldDo) with an
   elegant Instrument Serif italic signature; on-system, far more premium. */
.script,.intro .names-script{font-family:'Pinyon','Cormorant',cursive;font-style:normal;letter-spacing:.01em;}
/* couple's names — elegant wedding script */
.display,.hero h1,.hero h1 .amp{font-family:'Pinyon','Cormorant',cursive;font-style:normal;line-height:1.04;letter-spacing:.01em;}
.hero h1{font-size:clamp(64px,13vw,138px);}
.hero h1 .amp{font-size:.5em;color:var(--terra);margin:2px 0;}
.intro .names-script{font-size:clamp(34px,5.5vw,56px);}

/* F3 — Touch targets: nav + footer links were <44px. Pad hit areas. */
.nav nav a{padding:8px 2px;}
footer .fnav a{padding:8px 4px;display:inline-block;}
@media(max-width:900px){
  .nav nav a{padding:12px 6px;}      /* generous tap target in slide menu */
}

/* F4 — Hero: stop the lower botanical sprig from crossing the CTA buttons
   on small screens (it sat behind the buttons and added clutter). */
@media(max-width:620px){
  .hero .sprig:nth-of-type(2){display:none;}
  .hero .sprig:nth-of-type(1){opacity:.3;}
}

/* =========================================================================
   frontend-design (anthropics/skills) + awesome-claude-design/warm refinements
   ========================================================================= */
/* Tabular numerals so the countdown doesn't jitter as digits change */
.cd-cell .num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;}
/* Typographic niceties: balanced headings, pretty body reflow */
h1,h2,h3,h4,.display,.sec-title,.boardname{text-wrap:balance;}
p,.philo,.sec-lead,.story-copy p,.ev-val{text-wrap:pretty;}
