/* ===== Quindel & Imani — shared responsive styles ===== */
* { margin:0; padding:0; box-sizing:border-box; }
:root{
  --cream:#F4F0E8; --cream-bg:#e8e2d6; --cream-bg2:#dcd2bd; --panel:#ece5d7; --field:#fbf9f4;
  --espresso:#3f2e21; --espresso2:#271203; --brown-soft:#5f4a39;
  --blue:#9FB2CD; --slate:#496677; --border:#d3c6ad; --border2:#e2d8c6;
  --ink:#3f2e21; --muted:#6a6258; --muted2:#8a7e6c; --tan:#cbb89b;
}
html{ scroll-behavior:smooth; background:var(--espresso); }
body{ background-color:var(--cream-bg2);
  background-image:linear-gradient(rgba(220,210,189,.78), rgba(220,210,189,.78)), url(floral_line_olive.png);
  background-repeat:repeat, repeat; background-size:auto, 230px auto; background-position:center top;
  font-family:'EB Garamond',serif; color:var(--ink); }

/* ---------- NAV ---------- */
.nav{ background:var(--espresso); position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; padding:14px 22px; }
.nav .mono{ color:#EDE9E2; font-size:18px; letter-spacing:3px; text-decoration:none; }
.nav .links{ display:flex; gap:18px; font-size:11px; letter-spacing:1.5px;
  color:#D6CEC2; text-transform:uppercase; align-items:center; }
.nav .links a{ color:#D6CEC2; text-decoration:none; padding-bottom:2px; transition:color .15s; }
.nav .links a:hover{ color:#fff; }
.nav .links a.active{ border-bottom:1px solid var(--blue); color:#fff; }
.nav .links a.rsvp{ border:1px solid var(--blue); padding:5px 13px; border-radius:6px; color:#EDE9E2; }
.nav .links a.rsvp:hover{ background:var(--blue); color:var(--espresso); }
.nav .burger{ display:none; background:none; border:none; cursor:pointer; flex-direction:column;
  align-items:center; gap:4px; padding:6px 8px; }
.nav .burger span{ width:22px; height:2px; background:#EDE9E2; display:block; }
.nav .burger::after{ content:"MENU"; color:#EDE9E2; font-family:'EB Garamond',serif;
  font-size:8.5px; letter-spacing:1.5px; margin-top:3px; }

/* mobile nav: a clear "Menu" button (not an icon) toggles a dropdown of the page links */
@media (max-width:720px){
  .nav .burger{ display:block; padding:0; }
  .nav .burger span{ display:none; }                 /* hide the hamburger lines */
  .nav .burger::after{ content:"Menu \25BE"; margin:0; font-size:12px; letter-spacing:2px;
    text-transform:uppercase; color:#EDE9E2; border:1px solid rgba(255,255,255,.45);
    border-radius:6px; padding:6px 14px; }
  .nav .links{ position:fixed; inset:56px 0 auto 0; background:var(--espresso);
    flex-direction:column; gap:0; padding:8px 0 16px; transform:translateY(-120%);
    transition:transform .25s ease; box-shadow:0 12px 30px rgba(0,0,0,.25); }
  .nav .links.open{ transform:translateY(0); }
  .nav .links a{ padding:13px 22px; width:100%; font-size:13.5px; }
  .nav .links a.active{ border-bottom:none; color:var(--blue); }
  .nav .links a.rsvp{ margin:10px 22px 0; text-align:center; }
}

/* ---------- PAGE SHELL ---------- */
.wrap{ max-width:1100px; margin:0 auto; }
.frame-wrap{ padding:26px 20px; }
.frame{ background:var(--cream); border:1px solid var(--border); border-radius:14px;
  padding:54px 26px 36px; position:relative; box-shadow:0 8px 40px rgba(60,45,30,.10); }
.crown{ position:absolute; top:-24px; left:50%; transform:translateX(-50%); width:78px; z-index:3; }
.crown-mask{ position:absolute; top:-2px; left:50%; transform:translateX(-50%);
  width:94px; height:18px; background:var(--cream); z-index:2; }

.eyebrow{ text-align:center; color:#9a8a73; font-size:11px; letter-spacing:5px;
  text-transform:uppercase; margin-bottom:10px; }
.script-h1{ font-family:'Pinyon Script',cursive; color:var(--blue); text-align:center;
  font-weight:400; line-height:.95; font-size:clamp(54px, 9vw, 92px); margin-bottom:8px; }
.script-h2{ font-family:'Pinyon Script',cursive; color:var(--blue); text-align:center;
  font-weight:400; font-size:clamp(34px, 5vw, 50px); margin:6px 0 12px; }
.intro{ text-align:center; color:var(--muted); line-height:1.75;
  font-size:clamp(14px, 1.6vw, 16.5px); margin:6px auto 10px; max-width:620px; }
.sect-label{ text-align:center; color:#9a8a73; font-size:11px; letter-spacing:3px;
  text-transform:uppercase; margin:2px 0; }

.divider{ display:flex; align-items:center; justify-content:center; gap:16px; margin:30px 0 20px; }
.divider .line{ width:60px; height:1px; background:var(--border); }
.divider img{ width:62px; opacity:.9; }

/* ---------- COUNTDOWN FOOTER ---------- */
.countdown{ background:var(--espresso); padding:40px 20px 34px; position:relative;
  overflow:hidden; border-radius:22px 22px 0 0; margin-top:10px; }
/* corner flowers removed — the single-stem art read scraggly at small size; countdown is cleaner plain.
   To bring them back, delete the display:none below. */
.cd-flowers-left,.cd-flowers-right{ display:none; position:absolute; bottom:-14px; width:130px; height:160px; }
.cd-flowers-left{ left:-4px; } .cd-flowers-right{ right:-4px; }
.cd-flowers-left img,.cd-flowers-right img{ position:absolute; width:88px; bottom:0; opacity:.96; }
/* a third bloom tucked behind & between the pair so each corner reads as a fuller cluster */
.cd-flowers-left::before,.cd-flowers-right::before{ content:""; position:absolute; bottom:10px;
  width:78px; height:120px; background:url(floral_blue.png) no-repeat bottom center;
  background-size:contain; opacity:.9; }
.cd-flowers-left::before{ left:16px; transform:rotate(-6deg); transform-origin:bottom center; }
.cd-flowers-right::before{ right:16px; transform:rotate(6deg); transform-origin:bottom center; }
.cd-label{ text-align:center; font-family:'Pinyon Script',cursive; color:var(--blue);
  font-size:clamp(30px,4vw,40px); margin-bottom:4px; }
.cd-sub{ text-align:center; color:#cbb89b; font-size:11px; letter-spacing:3px;
  text-transform:uppercase; margin-bottom:18px; }
.cd-timer{ display:flex; justify-content:center; gap:clamp(18px,4vw,40px); position:relative; z-index:2; }
.cd-unit{ text-align:center; min-width:46px; }
.cd-num{ color:var(--cream); font-size:clamp(30px,4vw,44px); line-height:1; }
.cd-name{ color:#a89274; font-size:9px; letter-spacing:2px; text-transform:uppercase; margin-top:6px; }
@media (min-width:721px){ .cd-flowers-left,.cd-flowers-right{ width:170px; }
  .cd-flowers-left img,.cd-flowers-right img{ width:118px; }
  .cd-flowers-left::before,.cd-flowers-right::before{ width:104px; height:158px; } }
/* mobile: shrink the countdown flowers into the corners so all four numbers stay readable */
@media (max-width:720px){
  .cd-flowers-left,.cd-flowers-right{ width:74px; height:104px; opacity:.85; z-index:1; }
  .cd-flowers-left img,.cd-flowers-right img{ width:48px; }
  .cd-flowers-left::before,.cd-flowers-right::before{ width:42px; height:64px; bottom:7px; }
  .cd-flowers-left::before{ left:11px; } .cd-flowers-right::before{ right:11px; }
  .cd-flowers-left{ left:-12px; } .cd-flowers-right{ right:-12px; }
  .cd-timer{ gap:16px; }
  .cd-unit{ min-width:40px; }
}

/* ---------- generic cards/buttons reused ---------- */
.pill{ display:inline-block; border:1px solid var(--blue); color:var(--slate);
  font-size:10px; letter-spacing:2px; text-transform:uppercase; padding:8px 20px; border-radius:20px; text-decoration:none; }
.btn-solid{ display:inline-block; background:var(--espresso); color:var(--cream);
  border:none; border-radius:9px; padding:15px 22px; font-family:'EB Garamond',serif;
  font-size:12px; letter-spacing:2px; text-transform:uppercase; cursor:pointer; text-decoration:none; }

/* ---------- HERO (home) ---------- */
.hero{ position:relative; min-height:78vh; display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
  background:radial-gradient(circle at 50% 35%, #6f7f93, #4a5b6e 60%, #36444f);
  color:#fff; padding:60px 24px; }
/* placeholder save-the-date slideshow behind the title (swap hero.mp4 for the real video later) */
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.hero::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(39,18,3,.34), rgba(39,18,3,.50)); }
.hero-inner{ position:relative; z-index:2; }
.hero .names{ font-family:'Pinyon Script',cursive; font-weight:400; line-height:.9;
  font-size:clamp(64px,13vw,150px); text-shadow:0 4px 30px rgba(0,0,0,.35); }
.hero .amp{ display:block; font-size:.5em; margin:6px 0; opacity:.92; }
.hero .tag{ letter-spacing:6px; text-transform:uppercase; font-size:clamp(11px,1.5vw,14px);
  margin-top:18px; color:#ede6da; }
.hero .date{ margin-top:22px; font-size:clamp(15px,2vw,19px); letter-spacing:1px; color:#f3ece0; }
.hero .hero-cta{ margin-top:30px; display:inline-block; border:1px solid rgba(255,255,255,.7);
  color:#fff; padding:13px 30px; border-radius:8px; text-decoration:none; letter-spacing:2px;
  text-transform:uppercase; font-size:12px; transition:background .2s,color .2s; }
.hero .hero-cta:hover{ background:#fff; color:var(--espresso); }

/* ---------- generic responsive grid helper ---------- */
.grid{ display:grid; gap:14px; }
@media (min-width:721px){ .grid-2{ grid-template-columns:1fr 1fr; } .grid-3{ grid-template-columns:1fr 1fr 1fr; } }

/* venue / feature card */
.feature{ background:var(--panel); border-radius:12px; padding:26px 22px; text-align:center; }
.feature .fname{ font-family:'Pinyon Script',cursive; color:var(--brown-soft); font-size:clamp(28px,3.5vw,38px); margin-bottom:6px; }
.feature .faddr{ color:var(--muted); font-size:14px; line-height:1.7; }

/* hotel/air cards */
.card{ background:var(--field); border:1px solid var(--border2); border-radius:11px; padding:17px 18px; }
.card .top{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.card .hname{ color:var(--ink); font-size:17px; }
.card .dist{ color:var(--blue); font-size:11px; letter-spacing:1px; text-transform:uppercase; white-space:nowrap; }
.card .tag{ display:inline-block; background:#eef2f6; color:var(--slate); font-size:10px;
  letter-spacing:1px; text-transform:uppercase; padding:3px 9px; border-radius:12px; margin:8px 0; }
.card .desc{ color:#5a554c; font-size:14px; line-height:1.6; }
.card .book{ color:var(--slate); font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  margin-top:9px; display:inline-block; border-bottom:1px solid var(--blue); padding-bottom:1px; text-decoration:none; }
.air{ display:flex; align-items:center; gap:16px; background:var(--field); border:1px solid var(--border2);
  border-radius:11px; padding:15px 18px; }
.air .code{ color:var(--blue); font-size:30px; min-width:58px; text-align:center; }
.air .sep{ width:1px; align-self:stretch; background:var(--border2); }
.air .an{ color:var(--ink); font-size:15px; }
.air .ad{ color:var(--muted2); font-size:12.5px; font-style:italic; margin-top:2px; }

/* footer credit */
.foot-credit{ display:none; }

/* ---------- FAQ page ---------- */
.dress{ background:var(--panel); border-radius:12px; padding:28px 22px; text-align:center; margin:16px auto 8px; max-width:680px; }
.dress .intro{ margin-left:auto; margin-right:auto; }
.swatches{ display:flex; justify-content:center; gap:18px; flex-wrap:wrap; }
.sw{ text-align:center; }
.sw .dot{ width:48px; height:48px; border-radius:50%; margin:0 auto 7px; border:1px solid rgba(0,0,0,.08); }
.sw .nm{ color:#7a6f60; font-size:11px; letter-spacing:.5px; }
.kindly{ background:#eef2f6; border:1px solid #cdd9e4; border-radius:9px; color:var(--slate);
  font-size:13.5px; line-height:1.65; padding:14px 18px; margin:20px auto 0; max-width:520px; }
.unplugged{ background:var(--espresso); border-radius:12px; padding:30px 24px; text-align:center; margin:6px auto 22px; max-width:680px; }
.unplugged p{ color:#e4dccb; font-size:14px; line-height:1.85; margin-bottom:10px; }
.unplugged p:last-child{ margin-bottom:0; }
.acc-wrap{ max-width:680px; margin:0 auto; }
.acc{ border:1px solid var(--border2); border-radius:10px; margin-bottom:11px; overflow:hidden; background:var(--field); }
.acc summary{ list-style:none; cursor:pointer; padding:16px 18px; color:var(--ink); font-size:16px;
  display:flex; justify-content:space-between; align-items:center; gap:10px; }
.acc summary::-webkit-details-marker{ display:none; }
.acc summary .chev{ color:var(--blue); font-size:14px; transition:transform .2s; flex-shrink:0; }
.acc[open] summary .chev{ transform:rotate(180deg); }
.acc .body{ padding:0 18px 16px; color:#5a554c; font-size:14.5px; line-height:1.7; }

/* ---------- Registry ---------- */
.nest{ background:var(--panel); border-radius:14px; padding:38px 26px 32px; text-align:center; max-width:620px; margin:0 auto; }
.nest h3{ font-family:'Pinyon Script',cursive; color:var(--brown-soft); font-size:clamp(40px,6vw,56px); font-weight:400; margin:6px 0 4px; line-height:1; }
.nest .sub{ color:#9a8a73; font-size:11px; letter-spacing:2px; text-transform:uppercase; margin-bottom:18px; }
.nest p.body{ color:var(--muted); font-size:15px; line-height:1.85; margin-bottom:24px; }
.give-primary{ display:block; width:100%; background:var(--espresso); color:var(--cream);
  font-size:13px; letter-spacing:2px; text-transform:uppercase; padding:18px; border-radius:10px;
  text-decoration:none; margin-bottom:6px; }
.give-primary .small{ display:block; font-size:9.5px; letter-spacing:1px; color:#cbb89b; margin-top:4px; text-transform:none; font-style:italic; }
.or{ color:#9a8a73; font-size:11px; letter-spacing:2px; text-transform:uppercase; margin:18px 0 12px; }
.pay-row{ display:flex; gap:12px; }
.pay{ flex:1; background:var(--field); border:1px solid var(--border); border-radius:9px; padding:14px 8px; color:var(--slate); font-size:14px; text-decoration:none; }
.pay .h{ font-size:9px; letter-spacing:1px; text-transform:uppercase; color:#9a8a73; display:block; margin-bottom:3px; }
.note{ text-align:center; color:var(--muted2); font-size:13.5px; font-style:italic; line-height:1.8; margin:26px auto 0; max-width:520px; }

/* ---------- RSVP ---------- */
.deadline{ text-align:center; font-style:italic; color:var(--muted2); font-size:13.5px; margin-bottom:24px; }
.lookup{ max-width:440px; margin:0 auto; }
.lookup label.big{ display:block; text-align:center; color:var(--brown-soft); font-size:12px; letter-spacing:2px; text-transform:uppercase; margin-bottom:10px; }
.lookup input{ width:100%; background:var(--field); border:1px solid var(--border); border-radius:8px; padding:14px 16px; font-family:'EB Garamond',serif; font-size:16px; color:var(--ink); text-align:center; }
.lookup input:focus{ outline:none; border-color:var(--blue); }
.find{ width:100%; margin-top:12px; background:var(--espresso); color:var(--cream); border:none; border-radius:9px; padding:15px; font-family:'EB Garamond',serif; font-size:12px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; }
.hint{ text-align:center; color:var(--muted2); font-size:12.5px; font-style:italic; margin-top:14px; line-height:1.7; }
.disambig{ max-width:520px; margin:0 auto; }
.match{ background:var(--field); border:1px solid var(--border); border-radius:10px; padding:16px 18px; margin-bottom:12px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; text-decoration:none; }
.match:hover{ border-color:var(--blue); background:#eef2f6; }
.match .who{ color:var(--ink); font-size:16px; }
.match .members{ color:var(--muted2); font-size:12.5px; font-style:italic; margin-top:3px; }
.match .arrow{ color:var(--blue); font-size:20px; }
.help{ text-align:center; margin-top:18px; }
.help a{ color:var(--slate); font-size:12.5px; border-bottom:1px solid var(--blue); padding-bottom:1px; cursor:pointer; text-decoration:none; }
.guest-grid{ max-width:600px; margin:0 auto; }
.editnote{ text-align:center; background:#eef2f6; border:1px solid #cdd9e4; border-radius:9px; color:var(--slate); font-size:13px; line-height:1.6; padding:12px 16px; margin:0 auto 20px; max-width:520px; }
.guest-card{ background:var(--field); border:1px solid var(--border); border-radius:10px; padding:15px 15px 7px; margin-bottom:14px; }
.guest-card .gname{ color:var(--ink); font-size:16.5px; margin-bottom:10px; }
.yn-row{ display:flex; gap:8px; }
.yn{ flex:1; text-align:center; border:1px solid var(--border); border-radius:8px; padding:10px 4px; cursor:pointer; background:#fff; color:var(--muted); font-size:12.5px; }
.yn.sel-yes{ border-color:var(--blue); background:#eef2f6; color:var(--slate); }
.yn.sel-no{ border-color:#c9a99a; background:#f3ebe7; color:#9a6b58; }
.yn.sel-maybe{ border-color:#bcae7f; background:#f2eede; color:#7d6f3d; }
.fl{ display:block; color:var(--brown-soft); font-size:12px; letter-spacing:2px; text-transform:uppercase; margin:22px 0 8px; }
.t{ width:100%; background:var(--field); border:1px solid var(--border); border-radius:8px; padding:12px 14px; font-family:'EB Garamond',serif; font-size:15px; color:var(--ink); }
textarea.t{ resize:none; height:62px; }
.t:focus{ outline:none; border-color:var(--blue); }
.travel-row{ display:flex; gap:8px; }
.tv{ flex:1; text-align:center; border:1px solid var(--border); border-radius:8px; padding:13px 6px; cursor:pointer; background:var(--field); color:#5a554c; font-size:14px; }
.tv.sel{ border-color:var(--blue); background:#eef2f6; color:var(--slate); }
.opt{ font-style:italic; color:#a89c88; font-size:11.5px; text-transform:none; letter-spacing:0; margin-left:4px; }
.flight-fields{ background:#f5f1e8; border:1px dashed #c9bfa8; border-radius:9px; padding:4px 15px 15px; margin-top:10px; }
.submit{ width:100%; margin-top:26px; background:var(--espresso); color:var(--cream); border:none; border-radius:9px; padding:16px; font-family:'EB Garamond',serif; font-size:13px; letter-spacing:3px; text-transform:uppercase; cursor:pointer; }

/* ---------- Invitation request form ---------- */
.invite-form{ max-width:520px; margin:8px auto 0; }

/* ---------- DESKTOP: denser, a touch more opaque olive print so it reads on wide screens ---------- */
@media (min-width:1024px){
  body{
    background-image:linear-gradient(rgba(220,210,189,.72), rgba(220,210,189,.72)), url(floral_line_olive.png);
    background-size:auto, 185px auto;
  }
}

/* ---------- MOBILE: slightly larger body text for readability ---------- */
/* iOS Safari does not enlarge sites to match a guest's "Larger Text" setting,
   so we nudge the most-read copy up a touch on phones. */
@media (max-width:720px){
  .intro{ font-size:15.5px; }
  .card .desc, .feature .faddr, .nest p.body{ font-size:15px; }
  .acc summary{ font-size:16.5px; }
  .acc .body{ font-size:15.5px; }
}

