/* ============================================================
   Robinson Family Reunion 2026
   Styles ported 1:1 from the Claude Design handoff prototype.
   Color tokens, type scale, and spacing match the handoff README.
   ============================================================ */

/* Self-hosted fonts (latin subset, woff2) — same families/weights the
   handoff specifies (Anton, Barlow, Barlow Condensed), served from our
   own origin so there's no render-blocking request to Google. */
@font-face {
  font-family: 'Anton'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('assets/fonts/anton-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('assets/fonts/barlow-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow'; font-style: normal; font-weight: 500; font-display: swap;
  src: url('assets/fonts/barlow-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('assets/fonts/barlow-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('assets/fonts/barlow-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow Condensed'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('assets/fonts/barlowcondensed-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Barlow Condensed'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('assets/fonts/barlowcondensed-700.woff2') format('woff2');
}

* { box-sizing: border-box; }

html {
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
  --gold: #D2A857;            /* Heritage Gold (default). Copper #C97B4A / Brass #B8923B */
  background: #0E1B2A;        /* Ink */
  font-family: 'Barlow', sans-serif;
  color: #EFE7D6;            /* Cream */
  overflow-x: hidden;
}

@keyframes rfade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes bob   { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(6px); } }

/* Shared layout primitives ---------------------------------- */
.wrap {
  max-width: 1080px;
  margin: 0 auto;
  padding: clamp(44px, 7vw, 62px) clamp(18px, 5vw, 64px);
}
.gold-rule { width: 58px; height: 3px; background: var(--gold); }
.eyebrow-row { display: flex; align-items: baseline; gap: 16px; margin-bottom: 6px; }
.eyebrow-num { font: 400 22px/1 'Anton', sans-serif; color: var(--gold); }
.eyebrow-label {
  font: 600 12px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .26em; text-transform: uppercase; color: #7e93a8;
}
.section-h2 {
  font: 400 clamp(36px, 7.5vw, 60px)/.92 'Anton', sans-serif;
  color: #EFE7D6; text-transform: uppercase; margin: 0 0 30px;
}
section { scroll-margin-top: 80px; }

/* ================= NAV ================= */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(14, 27, 42, .9);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid #20364d;
}
.nav-inner {
  max-width: 1080px; margin: 0 auto;
  padding: 10px clamp(18px, 5vw, 64px);
  min-height: 68px; display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 8px 16px;
}
.brand { display: flex; align-items: center; gap: 13px; text-decoration: none; }
.monogram {
  display: grid; place-items: center; width: 36px; height: 36px;
  border: 2px solid var(--gold); color: var(--gold);
  font: 400 19px/1 'Anton', sans-serif; padding-top: 2px;
}
.brand-text {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .22em; text-transform: uppercase; color: #cdd8e3;
}
.nav-links {
  display: flex; gap: clamp(14px, 3vw, 30px);
  align-items: center; flex-wrap: wrap; justify-content: flex-end;
}
.nav-link {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .16em; text-transform: uppercase;
  color: #9fb0c2; text-decoration: none; transition: color .15s;
}
.nav-link:hover { color: #EFE7D6; }
.nav-cta {
  font: 700 12px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .16em; text-transform: uppercase;
  color: #0E1B2A; text-decoration: none; background: var(--gold);
  padding: 11px 18px; border-radius: 2px; transition: transform .15s;
}
.nav-cta:hover { transform: translateY(-1px); }

/* Mobile: brand on its own row, the three section links spread across a
   full-width row, and "Save the Date" as a full-width button below —
   instead of the links bunching against the right edge. */
@media (max-width: 600px) {
  .nav-inner {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    padding-top: 14px;
    padding-bottom: 14px;
    min-height: 0;
  }
  .nav-links {
    width: 100%;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
  }
  .nav-cta {
    flex-basis: 100%;
    text-align: center;
    margin-left: 0;
    padding-top: 13px;
    padding-bottom: 13px;
  }
}

/* ================= HERO ================= */
.hero {
  position: relative;
  padding: clamp(48px, 7vw, 78px) clamp(18px, 5vw, 64px) clamp(44px, 6vw, 64px);
  max-width: 1080px; margin: 0 auto;
  box-shadow: inset 0 -1px 0 #16293E;
}
.hero-eyebrow {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .34em; text-transform: uppercase; color: var(--gold);
}
.hero-rule { margin: 18px 0 0; }
.hero-h1 {
  font: 400 clamp(30px, 8.6vw, 110px)/.9 'Anton', sans-serif;
  color: #EFE7D6; margin: 28px 0 0; letter-spacing: .004em; text-transform: uppercase;
}
.hero-h1 .accent { color: var(--gold); }
.hero-meta {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 24px; margin-top: 42px;
}
.hero-date { font: 700 22px/1 'Barlow', sans-serif; color: #EFE7D6; }
.hero-place {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .24em; text-transform: uppercase; color: #7e93a8; margin-top: 9px;
}
.hero-tagline {
  font: 500 14px/1.5 'Barlow', sans-serif; color: #9fb0c2;
  text-align: right; max-width: 230px;
}

/* countdown */
.countdown { margin-top: 40px; }
.countdown-label {
  font: 600 11px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .28em; text-transform: uppercase; color: #7e93a8; margin-bottom: 14px;
}
.countdown-tiles { display: flex; gap: 14px; flex-wrap: wrap; }
.tile {
  flex: 1 1 84px; min-width: 84px;
  background: #13243a; border: 1px solid #2a4159; border-top: 3px solid var(--gold);
  padding: clamp(14px, 3vw, 18px) 12px; text-align: center;
}
.tile-num { font: 400 clamp(38px, 9vw, 54px)/1 'Anton', sans-serif; color: #fff; }
.tile-num.gold { color: var(--gold); }
.tile-label {
  font: 600 11px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .24em; text-transform: uppercase; color: #7e93a8; margin-top: 10px;
}
.scroll-cue {
  display: inline-flex; align-items: center; gap: 9px; margin-top: 40px;
  font: 600 12px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .22em; text-transform: uppercase; color: #9fb0c2; text-decoration: none;
}
.scroll-cue .arrow { display: inline-block; animation: bob 1.8s ease-in-out infinite; }

/* ================= SCHEDULE ================= */
#weekend { background: #16293E; }
.schedule { border-top: 1px solid #2a4159; }
.sched-row {
  display: flex; gap: 18px 28px; flex-wrap: wrap; align-items: baseline;
  padding: 24px 16px 24px 0; border-bottom: 1px solid #2a4159;
  border-left: 3px solid transparent;
  transition: background .15s, border-color .15s, padding-left .15s;
}
.sched-row:hover { background: #1b3147; border-left-color: var(--gold); padding-left: 18px; }
.sched-day-col { flex: none; width: 150px; }
.sched-day { font: 400 28px/1 'Anton', sans-serif; color: var(--gold); text-transform: uppercase; }
.sched-date {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .18em; text-transform: uppercase; color: #7e93a8; margin-top: 7px;
}
.sched-time { flex: none; width: 140px; font: 700 16px/1.3 'Barlow', sans-serif; color: #fff; }
.sched-body { flex: 1; min-width: 240px; }
.sched-title { font: 700 20px/1.2 'Barlow', sans-serif; color: #fff; margin-bottom: 5px; }
.sched-desc { font: 400 15px/1.55 'Barlow', sans-serif; color: #9fb0c2; }

/* ================= FAMILY ================= */
#family { background: #0E1B2A; }
.family-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 30px;
}
.family-header .section-h2 { margin: 0; }
.family-hint {
  font: 600 12px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .18em; text-transform: uppercase; color: #7e93a8;
}
.family-grid { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; }
.card {
  width: 248px; cursor: pointer; position: relative;
  border: 1px solid #2a4159; background: #16293E;
  transition: transform .18s, border-color .18s, box-shadow .18s;
}
.card:hover { transform: translateY(-6px); border-color: var(--gold); box-shadow: 0 16px 34px rgba(0, 0, 0, .4); }
.card-photo {
  display: block;
  width: 246px; height: 300px;
  object-fit: cover; object-position: center;
  background-color: #16293E;
}
.card-caption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 34px 14px 13px;
  background: linear-gradient(to top, rgba(8, 15, 24, .96), rgba(8, 15, 24, 0));
}
.card-name { font: 700 16px/1.1 'Barlow', sans-serif; color: #fff; }
.card-rel {
  font: 600 11px/1.3 'Barlow Condensed', sans-serif;
  letter-spacing: .1em; text-transform: uppercase; color: var(--gold); margin-top: 5px;
}

/* ================= T-SHIRTS ================= */
#shirts { background: var(--gold); color: #1a1305; }
.shirts-cols { display: flex; gap: 44px; align-items: flex-start; flex-wrap: wrap; }
.shirts-copy { flex: 1.1; min-width: min(340px, 100%); }
.shirts-copy .eyebrow-num { color: #1a1305; }
.shirts-copy .eyebrow-label { color: #7a5e1d; }
.shirts-h2 {
  font: 400 clamp(40px, 8vw, 66px)/.92 'Anton', sans-serif;
  text-transform: uppercase; color: #1a1305; margin: 8px 0 16px;
}
.shirts-p {
  font: 500 15px/1.6 'Barlow', sans-serif; color: #4a3a14; margin: 0 0 22px; max-width: 430px;
}
.chips { display: flex; flex-wrap: wrap; gap: 9px; }
.chip {
  background: #1a1305; color: var(--gold);
  font: 700 14px/1 'Barlow', sans-serif; padding: 11px 15px;
}
.picker-card {
  flex: none; width: 340px; max-width: 100%;
  background: #0E1B2A; color: #EFE7D6; padding: 28px;
}
.picker-badge {
  display: inline-block; background: var(--gold); color: #1a1305;
  font: 700 11px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .12em; text-transform: uppercase; padding: 8px 12px;
}
.picker-title {
  font: 400 30px/1 'Anton', sans-serif; text-transform: uppercase;
  margin: 20px 0 4px; color: #fff;
}
.picker-sub { font: 400 13px/1.4 'Barlow', sans-serif; color: #9fb0c2; margin-bottom: 16px; }
.picker-select {
  width: 100%; font: 600 15px 'Barlow', sans-serif; padding: 13px 12px;
  border: 1px solid #2a4159; background: #16293E; color: #fff; border-radius: 2px;
}
.picker-readout {
  margin-top: 16px; padding: 16px; background: #16293E;
  border-left: 3px solid var(--gold); font: 700 17px/1.3 'Barlow', sans-serif; color: #fff;
}

/* ================= PAYMENTS ================= */
#payments { background: #16293E; }
.payments-intro {
  font: 400 15px/1.55 'Barlow', sans-serif; color: #9fb0c2; margin: 0 0 28px; max-width: 540px;
}
.payments-h2 { margin: 0 0 10px; }
.pay-cards { display: flex; gap: 18px; flex-wrap: wrap; }
.pay-card {
  flex: 1; min-width: min(280px, 100%);
  background: #0E1B2A; border: 1px solid #2a4159; padding: 26px;
}
.pay-card-title {
  font: 600 12px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .18em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px;
}
.pay-row {
  display: flex; justify-content: space-between; padding: 11px 0;
  border-bottom: 1px solid #2a4159;
  font: 500 15px 'Barlow', sans-serif; color: #dfe7ef;
}
.pay-row:last-child { border-bottom: none; }
.pay-row strong { color: #fff; }
.pay-val { font-weight: 700; color: #fff; }
.pay-val.gold { color: var(--gold); font-weight: 700; }

/* ================= FOOTER ================= */
.footer { background: #0E1B2A; border-top: 3px solid var(--gold); }
.footer .wrap { text-align: center; padding: clamp(44px, 7vw, 56px) clamp(18px, 5vw, 64px); }
.footer-monogram {
  display: inline-grid; place-items: center; width: 54px; height: 54px;
  border: 2px solid var(--gold); color: var(--gold);
  font: 400 30px/1 'Anton', sans-serif; padding-top: 3px; margin-bottom: 18px;
}
.footer-title {
  font: 400 clamp(26px, 6vw, 40px)/.92 'Anton', sans-serif;
  text-transform: uppercase; color: #EFE7D6;
}
.footer-sub {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .24em; text-transform: uppercase; color: #7e93a8; margin-top: 14px;
}
.footer-rule { margin: 26px auto; }
.footer-contact { font: 500 14px/1.6 'Barlow', sans-serif; color: #9fb0c2; }
.footer-contact a {
  color: var(--gold); font-weight: 700; text-decoration: underline; text-underline-offset: 3px;
}
.footer-share {
  font: 400 24px/1 'Anton', sans-serif; text-transform: uppercase; color: var(--gold); margin-top: 24px;
}

/* ================= ERROR PAGE ================= */
.error-page {
  min-height: 100vh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  padding: clamp(40px, 8vw, 80px) clamp(18px, 5vw, 64px);
}
.error-eyebrow {
  font: 600 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .34em; text-transform: uppercase; color: var(--gold);
}
.error-code {
  font: 400 clamp(72px, 22vw, 150px)/.9 'Anton', sans-serif;
  color: #EFE7D6; text-transform: uppercase; margin: 14px 0 0; letter-spacing: .004em;
}
.error-title {
  font: 400 clamp(24px, 6vw, 40px)/.95 'Anton', sans-serif;
  color: var(--gold); text-transform: uppercase; margin: 8px 0 0;
}
.error-text {
  font: 500 15px/1.6 'Barlow', sans-serif; color: #9fb0c2; margin: 18px 0 0; max-width: 420px;
}
.error-home {
  margin-top: 30px;
  font: 700 13px/1 'Barlow Condensed', sans-serif;
  letter-spacing: .16em; text-transform: uppercase;
  color: #0E1B2A; background: var(--gold);
  padding: 14px 22px; border-radius: 2px; text-decoration: none;
  transition: transform .15s;
}
.error-home:hover { transform: translateY(-1px); }

/* ================= LIGHTBOX ================= */
.lightbox {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(8, 14, 22, .9);
  display: flex; align-items: center; justify-content: center;
  animation: rfade .2s ease; padding: 24px;
}
.lightbox[hidden] { display: none; }
.lightbox-frame {
  background: #EFE7D6; padding: 14px 14px 0;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .6);
  border-top: 4px solid var(--gold); max-width: 90vw;
}
.lightbox-photo {
  display: block;
  width: 440px; height: 540px; max-width: 84vw;
  object-fit: cover; object-position: center;
  background-color: #d8cdb8;
}
.lightbox-text { padding: 20px 8px 24px; text-align: center; }
.lightbox-name { font: 400 30px/1 'Anton', sans-serif; text-transform: uppercase; color: #0E1B2A; }
.lightbox-rel {
  font: 600 12px/1.3 'Barlow Condensed', sans-serif;
  letter-spacing: .16em; text-transform: uppercase; color: #a07c2e; margin-top: 8px;
}
