/* ============================================================
   THE WEEKEND — page styles (extends site-v7.css)
   ============================================================ */

/* this page opens on a light (cream) header, not a dark hero — keep the nav legible */
.nav{ color:var(--navy); }
.nav .brand{ text-shadow:none; }

/* page header — light cream, matching the other pages' headers */
.page-head{ text-align:center; padding:clamp(130px,20vh,200px) 0 clamp(40px,6vw,72px); position:relative; }
.page-head .kicker{ display:block; margin-bottom:18px; }
.page-head h1{ font-family:var(--display); font-weight:500; font-size:clamp(54px,11vw,140px); line-height:.96; padding-bottom:.3em; }
.page-head h1 .amp{ font-family:var(--script); color:var(--accent); }
.page-head .ph-sub{ font-family:var(--display); font-style:italic; font-size:clamp(18px,2vw,25px);
  color:var(--ink-soft); max-width:44ch; margin:clamp(18px,3vh,28px) auto 0; }
.page-head .ph-addr{ display:inline-flex; align-items:center; gap:9px; margin-top:clamp(22px,3.4vh,32px);
  font-family:var(--label); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--navy);
  border-bottom:1px solid var(--line); padding-bottom:5px; transition:color .3s var(--t), border-color .3s var(--t); }
.page-head .ph-addr:hover{ color:var(--accent); border-color:var(--accent); }

/* day block — sections are separated by alternating background tone, not hairlines */
.wk-day{ padding:clamp(40px,6vw,76px) 0; scroll-margin-top:84px; }
.wk-day.alt{ background:var(--cream-2); }
.wk-day-head{ text-align:center; margin-bottom:clamp(34px,5vw,56px); display:flex; flex-direction:column; align-items:center; gap:12px; }
.wk-day-head .d-date{ font-family:var(--label); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; }
.wk-day-head h2{ font-family:var(--display); font-size:clamp(40px,7vw,82px); line-height:1; padding-bottom:.82em; }
.wk-day-head h2 .amp, .wk-day-head h2 em{ font-family:var(--script); color:var(--accent); font-style:normal; }
.wk-day-head .d-lede{ font-family:var(--display); font-style:italic; font-size:clamp(17px,1.7vw,21px); color:var(--ink-soft); max-width:52ch; }
.wk-day-head .d-tag{ font-family:var(--label); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--navy); border:1px solid var(--line); border-radius:999px; padding:6px 16px; white-space:nowrap; }

/* moments grid */
.moments{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,40px); max-width:1040px; margin:0 auto; }
.moments.two{ grid-template-columns:repeat(2,1fr); max-width:620px; }
.moment{ text-align:center; display:flex; flex-direction:column; align-items:center; }
.moment .ic{ height:clamp(96px,12vw,128px); display:flex; align-items:flex-end; justify-content:center; margin-bottom:18px; }
.moment .ic img{ max-height:100%; width:auto; }
.moment h3{ font-family:var(--display); font-size:clamp(22px,2.2vw,28px); font-weight:500; margin-bottom:4px; }
.moment .m-time{ font-family:var(--label); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.moment p{ color:var(--ink-soft); font-size:15px; line-height:1.6; max-width:24ch; }

/* a slim text-only day (Thursday) */
.wk-note{ max-width:720px; margin:0 auto; text-align:center; }
.wk-note p{ color:var(--ink-soft); font-size:clamp(16px,1.4vw,18px); }
.wk-note .ic-sm{ height:78px; margin:0 auto 18px; display:block; }

/* ============================================================
   VENUE
   ============================================================ */
.venue-sec{ padding:clamp(56px,8vw,100px) 0; }
.venue-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,68px); align-items:center; max-width:1080px; margin:0 auto; }
.venue-info .ic-house{ height:96px; margin-bottom:20px; }
.venue-info h2{ font-family:var(--display); font-size:clamp(34px,5vw,58px); line-height:1; margin-bottom:6px; }
.venue-info h2 em{ font-family:var(--script); color:var(--accent); font-style:normal; }
.venue-info .v-addr{ font-family:var(--display); font-style:italic; font-size:clamp(18px,1.7vw,22px); color:var(--navy); margin:14px 0; }
.venue-info p{ color:var(--ink-soft); max-width:46ch; }
.venue-info .v-rows{ margin-top:22px; border-top:1px solid var(--line); }
.v-row{ display:flex; gap:18px; align-items:baseline; padding:13px 0; border-bottom:1px solid var(--line); }
.v-row .ic-mini{ width:24px; height:24px; flex:0 0 auto; opacity:.9; }
.v-row .vr-k{ font-family:var(--label); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); min-width:124px; flex:0 0 auto; }
.v-row .vr-v{ font-size:15px; color:var(--ink); }
.venue-map{ position:relative; aspect-ratio:4/5; border:1px solid var(--line); background:
  repeating-linear-gradient(45deg, var(--cream-2), var(--cream-2) 14px, #e3d9c6 14px, #e3d9c6 28px);
  display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius:4px; }
.venue-map .map-note{ background:color-mix(in oklab,var(--cream) 88%, transparent); border:1px solid var(--line);
  padding:14px 22px; font-family:var(--label); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); text-align:center; }
.venue-map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-sec{ padding:clamp(56px,8vw,100px) 0; background:var(--cream-2); }
.faq-list{ max-width:760px; margin:clamp(34px,5vw,52px) auto 0; border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:22px 4px; font-family:var(--display); font-size:clamp(20px,2vw,26px); color:var(--navy); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary .pm{ font-family:var(--label); font-size:22px; color:var(--accent); transition:transform .3s var(--t); line-height:1; }
.faq-item[open] summary .pm{ transform:rotate(45deg); }
.faq-item .faq-a{ padding:0 4px 24px; color:var(--ink-soft); max-width:62ch; font-size:16px; line-height:1.7; }
.faq-item .faq-a a{ color:var(--accent); border-bottom:1px solid currentColor; }

/* ============================================================
   YOUR PRESENCE (gifts)
   ============================================================ */
.gifts-sec{ padding:clamp(64px,9vw,110px) 0; text-align:center; }
.gifts-sec .ic-gift{ height:clamp(92px,11vw,120px); margin:0 auto clamp(20px,3vh,30px); display:block; }
.gifts-sec .kicker{ display:block; margin-bottom:14px; }
.gifts-sec h2{ font-family:var(--display); font-size:clamp(38px,6vw,72px); line-height:1; }
.gifts-sec h2 em{ font-family:var(--script); color:var(--accent); font-style:normal; }
.gifts-sec p{ max-width:50ch; margin:clamp(18px,3vh,26px) auto 0; color:var(--ink-soft);
  font-family:var(--display); font-style:italic; font-size:clamp(18px,1.6vw,22px); }
.gifts-sec .g-links{ margin-top:clamp(28px,4vh,40px); display:flex; gap:16px; justify-content:center; align-items:center; flex-wrap:wrap; }
.gifts-sec .g-links a{ white-space:nowrap; display:inline-flex; align-items:center; justify-content:center; min-height:56px; line-height:1.1; margin:0; }

/* back to rsvp band */
.wk-cta{ text-align:center; padding:clamp(56px,8vw,96px) 0; background:var(--navy-deep); color:var(--cream); }
.wk-cta .kicker{ color:var(--butter); display:block; margin-bottom:14px; }
.wk-cta h2{ font-family:var(--display); font-size:clamp(34px,5vw,60px); line-height:1; margin-bottom:8px; }
.wk-cta h2 em{ font-family:var(--script); color:var(--butter); font-style:normal; }
.wk-cta p{ color:rgba(244,238,227,.8); font-style:italic; font-family:var(--display); font-size:clamp(17px,1.5vw,21px); max-width:44ch; margin:0 auto; }
.wk-cta .btn{ background:var(--cream); color:var(--navy); margin-top:clamp(26px,4vh,38px); }
.wk-cta .btn:hover{ background:var(--butter); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:880px){
  .moments{ grid-template-columns:repeat(2,1fr); gap:34px clamp(20px,5vw,36px); }
  .venue-grid{ grid-template-columns:1fr; gap:34px; }
  .venue-map{ aspect-ratio:3/2; }
  .page-head{ padding:clamp(110px,16vh,150px) 0 clamp(32px,7vw,52px); }
  .wk-day{ padding:clamp(40px,9vw,60px) 0; }
}
@media (max-width:460px){
  .moments{ grid-template-columns:1fr 1fr; gap:28px 18px; }
  .moment p{ font-size:14px; }
}
