/* ============================================================
   East Pass Excursions — v2 design system
   Playful + vibrant + clean/minimal + immersive.
   Bright Emerald Coast palette on generous whitespace.
   Type: Clash Display (display) + General Sans (body).
   ============================================================ */

:root {
  /* Fluid type — pushed bigger for editorial feel */
  --text-xs: clamp(0.72rem, 0.68rem + 0.2vw, 0.8rem);
  --text-sm: clamp(0.85rem, 0.8rem + 0.3vw, 0.95rem);
  --text-base: clamp(1rem, 0.96rem + 0.25vw, 1.1rem);
  --text-lg: clamp(1.15rem, 1.02rem + 0.6vw, 1.4rem);
  --text-xl: clamp(1.4rem, 1.1rem + 1.4vw, 2rem);
  --text-2xl: clamp(2rem, 1.3rem + 2.8vw, 3.4rem);
  --text-3xl: clamp(2.8rem, 1.4rem + 5.6vw, 5.6rem);
  --text-4xl: clamp(3.4rem, 1rem + 11vw, 9rem);

  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
  --space-12:3rem; --space-16:4rem; --space-20:5rem; --space-24:6rem; --space-32:8rem;

  /* Emerald Coast */
  --bg:#ffffff;
  --cream:#fdfaf3;          /* warm off-white for airy bands */
  --surface:#f0faf8;
  --surface-2:#e2f4f0;
  --ink:#0b2b30;
  --ink-soft:#3f5c61;
  --ink-faint:#7a969a;
  --line:#e4efec;

  --teal:#00a5b5;           /* bright gulf teal */
  --teal-deep:#057682;
  --teal-ink:#053238;       /* near-black teal */
  --aqua:#2ed3c9;           /* pop turquoise */
  --emerald:#12b48f;
  --sun:#ff7a2e;            /* sunset orange — CTA */
  --sun-deep:#ee5f12;
  --sun-soft:#ffe7d6;
  --sky:#c9f0ee;

  --radius-sm:.55rem; --radius-md:1rem; --radius-lg:1.5rem; --radius-xl:2.25rem; --radius-full:999px;
  --shadow-sm:0 2px 8px rgba(5,50,56,.06);
  --shadow-md:0 14px 40px rgba(5,50,56,.12);
  --shadow-lg:0 34px 80px rgba(5,50,56,.20);
  --shadow-sun:0 14px 30px rgba(238,95,18,.32);

  --content:1240px;
  --content-narrow:780px;

  --font-display:'Clash Display','Georgia',serif;
  --font-body:'General Sans','Helvetica Neue',system-ui,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; text-rendering:optimizeLegibility; scroll-behavior:smooth; scroll-padding-top:92px; }
body{ min-height:100dvh; line-height:1.62; font-family:var(--font-body); font-size:var(--text-base); color:var(--ink); background:var(--bg); overflow-x:hidden; }
img,picture,video,svg{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ cursor:pointer; background:none; border:none; font:inherit; color:inherit; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.02; text-wrap:balance; letter-spacing:-0.02em; }
p{ text-wrap:pretty; }
:focus-visible{ outline:3px solid var(--teal); outline-offset:3px; border-radius:var(--radius-sm); }
::selection{ background:var(--sun-soft); color:var(--teal-ink); }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
}

/* Layout primitives */
.wrap{ width:100%; max-width:var(--content); margin-inline:auto; padding-inline:clamp(1.25rem,4vw,3rem); }
.narrow{ max-width:var(--content-narrow); }
.section{ padding-block:clamp(4rem,9vw,8rem); }
.section-sm{ padding-block:clamp(3rem,6vw,5rem); }
.cream{ background:var(--cream); }
.surface{ background:var(--surface); }
.ink-band{ background:var(--teal-ink); color:#fff; }

.eyebrow{ font-family:var(--font-body); font-weight:600; font-size:var(--text-xs); letter-spacing:.22em; text-transform:uppercase; color:var(--teal-deep); display:inline-flex; align-items:center; gap:.6rem; }
.eyebrow::before{ content:''; width:24px; height:3px; background:var(--sun); border-radius:3px; }
.eyebrow.light{ color:#fff; }
.section-head{ max-width:760px; margin-bottom:clamp(2.5rem,5vw,3.75rem); }
.section-head h2{ font-size:var(--text-2xl); margin-top:var(--space-4); }
.section-head p{ color:var(--ink-soft); font-size:var(--text-lg); margin-top:var(--space-4); }
.lede{ font-size:var(--text-lg); color:var(--ink-soft); }

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.55rem; font-weight:600; font-size:var(--text-sm); padding:.95rem 1.7rem; border-radius:var(--radius-full); transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease); white-space:nowrap; }
.btn svg{ width:1.1em; height:1.1em; }
.btn-primary{ background:var(--sun); color:#fff; box-shadow:var(--shadow-sun); }
.btn-primary:hover{ background:var(--sun-deep); transform:translateY(-3px); box-shadow:0 18px 38px rgba(238,95,18,.4); }
.btn-teal{ background:var(--teal); color:#fff; }
.btn-teal:hover{ background:var(--teal-deep); transform:translateY(-3px); }
.btn-ghost{ background:rgba(255,255,255,.14); color:#fff; border:1.5px solid rgba(255,255,255,.6); backdrop-filter:blur(6px); }
.btn-ghost:hover{ background:rgba(255,255,255,.26); transform:translateY(-3px); }
.btn-outline{ border:1.5px solid var(--line); color:var(--ink); }
.btn-outline:hover{ border-color:var(--teal); color:var(--teal-deep); }
.btn-dark{ background:var(--teal-ink); color:#fff; }
.btn-dark:hover{ background:#03282d; transform:translateY(-3px); }
.btn-lg{ padding:1.1rem 2.1rem; font-size:var(--text-base); }
.btn-block{ width:100%; }

/* Rating chip (reusable) */
.rating-chip{ display:inline-flex; align-items:center; gap:.6rem; background:#fff; color:var(--teal-ink); padding:.6rem 1rem; border-radius:var(--radius-full); box-shadow:var(--shadow-md); font-size:var(--text-sm); font-weight:600; }
.rating-chip .stars{ color:#ffb020; letter-spacing:1px; }
.rating-chip .stars svg{ display:inline-block; width:15px; height:15px; vertical-align:-2px; }
.stars{ color:#ffb020; }
.stars svg{ display:inline-block; width:16px; height:16px; }

/* ---------- Header ---------- */
.site-header{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.9); backdrop-filter:saturate(180%) blur(16px); border-bottom:1px solid transparent; transition:box-shadow .25s var(--ease),border-color .25s var(--ease); }
.nav{ display:flex; align-items:center; gap:var(--space-6); height:76px; }
.brand{ display:flex; align-items:center; gap:.7rem; font-family:var(--font-display); font-weight:600; font-size:1.2rem; color:var(--teal-ink); letter-spacing:-.02em; line-height:1; }
.brand svg{ flex-shrink:0; }
.brand-logo{ display:block; height:52px; width:auto; }
.footer-logo{ height:64px; }
@media (max-width:600px){ .brand-logo{ height:44px; } }
.brand small{ display:block; font-family:var(--font-body); font-weight:600; font-size:.56rem; letter-spacing:.26em; color:var(--sun-deep); text-transform:uppercase; margin-top:3px; }
.nav-links{ display:flex; align-items:center; gap:2px; margin-left:auto; }
.nav-links a{ font-size:var(--text-sm); font-weight:500; color:var(--ink-soft); padding:.5rem .85rem; border-radius:var(--radius-full); transition:color .18s,background .18s; }
.nav-links a:hover,.nav-links a.active{ color:var(--teal-ink); background:var(--surface-2); }
.nav-cta{ display:flex; align-items:center; gap:var(--space-4); margin-left:var(--space-5); }
.nav-phone{ display:inline-flex; align-items:center; gap:.45rem; font-weight:600; font-size:var(--text-sm); color:var(--teal-deep); }
.nav-phone svg{ width:1.05em; height:1.05em; }
.nav-toggle{ display:none; width:46px; height:46px; align-items:center; justify-content:center; border-radius:var(--radius-md); color:var(--teal-ink); margin-left:auto; }
.nav-toggle svg{ width:27px; height:27px; }
.mobile-phone{ display:none; }

/* ---------- Home hero — asymmetric, parallax ---------- */
.hero{ position:relative; overflow:hidden; background:var(--cream); padding-block:clamp(3rem,6vw,5.5rem) clamp(4rem,8vw,7rem); }
.hero-grid{ display:grid; grid-template-columns:1.02fr 1fr; gap:clamp(1.5rem,4vw,3.5rem); align-items:center; }
.hero-copy{ position:relative; z-index:3; }
.hero h1{ font-size:var(--text-3xl); margin-top:var(--space-5); }
.hero h1 .em{ color:var(--teal); font-style:italic; padding-right:0.12em; }
.hero p{ font-size:var(--text-lg); color:var(--ink-soft); max-width:44ch; margin-top:var(--space-6); }
.hero-actions{ display:flex; flex-wrap:wrap; gap:var(--space-3); margin-top:var(--space-8); }
.hero-proof{ display:flex; align-items:center; gap:var(--space-4); margin-top:var(--space-8); flex-wrap:wrap; font-size:var(--text-sm); color:var(--ink-soft); }
.hero-proof b{ color:var(--ink); }
/* stage: photo with floating chip and organic shape */
.hero-stage{ position:relative; }
.hero-photo{ position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/5; will-change:transform; }
.hero-photo img{ width:100%; height:112%; object-fit:cover; }
.hero-stage .blob{ position:absolute; z-index:-1; }
.hero-blob-a{ top:-8%; right:-10%; width:42%; aspect-ratio:1; background:radial-gradient(circle at 30% 30%,var(--aqua),var(--teal)); border-radius:48% 52% 60% 40%/55% 45% 55% 45%; opacity:.4; filter:blur(6px); }
.hero-blob-b{ bottom:-6%; left:-8%; width:34%; aspect-ratio:1; background:var(--sun-soft); border-radius:60% 40% 45% 55%/45% 60% 40% 55%; opacity:.9; }
.hero-float-chip{ position:absolute; left:-6%; bottom:9%; z-index:4; }
.hero-price-chip{ position:absolute; right:-4%; top:12%; z-index:4; background:var(--teal-ink); color:#fff; padding:.85rem 1.15rem; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); text-align:center; }
.hero-price-chip b{ font-family:var(--font-display); font-size:1.5rem; display:block; color:var(--aqua); }
.hero-price-chip span{ font-size:var(--text-xs); letter-spacing:.06em; opacity:.85; }
.scroll-cue{ display:inline-flex; align-items:center; gap:.5rem; margin-top:var(--space-10); font-size:var(--text-xs); letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); }
.scroll-cue .dot{ width:22px; height:34px; border:2px solid var(--ink-faint); border-radius:var(--radius-full); position:relative; }
.scroll-cue .dot::after{ content:''; position:absolute; top:6px; left:50%; transform:translateX(-50%); width:4px; height:7px; background:var(--sun); border-radius:2px; animation:scrolldot 1.6s var(--ease) infinite; }
@keyframes scrolldot{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 100%{opacity:0;transform:translate(-50%,10px)} }
@media (prefers-reduced-motion:reduce){ .scroll-cue .dot::after{ animation:none; } }

/* ---------- Marquee of gallery thumbs ---------- */
.marquee{ overflow:hidden; padding-block:var(--space-6); -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.marquee-track{ display:flex; gap:var(--space-4); width:max-content; animation:marquee 46s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track img{ height:150px; width:auto; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); object-fit:cover; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee-track{ animation:none; } }

/* ---------- Trip feature blocks (the 2 offerings) ---------- */
.trip-feature{ display:grid; grid-template-columns:1.05fr .95fr; gap:0; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-md); background:#fff; border:1px solid var(--line); }
.trip-feature + .trip-feature{ margin-top:clamp(2rem,4vw,3.5rem); }
.trip-feature.rev .tf-media{ order:2; }
.tf-media{ position:relative; min-height:420px; }
.tf-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.tf-badge{ position:absolute; top:var(--space-5); left:var(--space-5); background:var(--sun); color:#fff; font-weight:600; font-size:var(--text-xs); letter-spacing:.1em; text-transform:uppercase; padding:.5rem 1rem; border-radius:var(--radius-full); box-shadow:var(--shadow-sm); }
.tf-badge.teal{ background:var(--teal); }
.tf-body{ padding:clamp(2rem,4vw,3.5rem); align-self:center; }
.tf-body .kicker{ font-size:var(--text-xs); font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--teal-deep); }
.tf-body h3{ font-size:var(--text-2xl); margin-top:var(--space-3); }
.tf-body .tag{ display:inline-block; width:fit-content; font-family:var(--font-display); font-style:italic; font-size:var(--text-lg); line-height:1.25; color:var(--sun-deep); margin-top:var(--space-2); text-wrap:balance; max-width:22ch; }
.tf-body p{ color:var(--ink-soft); margin-top:var(--space-4); }
.tf-meta{ display:flex; flex-wrap:wrap; gap:var(--space-5); margin-top:var(--space-5); }
.tf-meta div{ display:flex; flex-direction:column; }
.tf-meta b{ font-family:var(--font-display); font-size:var(--text-lg); color:var(--teal-ink); }
.tf-meta span{ font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.08em; color:var(--ink-faint); }
.tf-highlights{ display:grid; gap:.7rem; margin-top:var(--space-5); }
.tf-highlights li{ display:flex; gap:.6rem; align-items:flex-start; font-size:var(--text-sm); }
.tf-highlights svg{ width:20px; height:20px; color:var(--emerald); flex-shrink:0; margin-top:2px; }
.tf-actions{ display:flex; flex-wrap:wrap; gap:var(--space-3); margin-top:var(--space-6); }
.trip-feature.hero-trip{ box-shadow:var(--shadow-lg); border-color:transparent; }
.trip-feature.hero-trip .tf-media{ min-height:520px; }

/* Trips-hub price line (on trip-feature cards) */
.tf-price{ display:flex; flex-wrap:wrap; align-items:baseline; gap:.25rem .7rem; margin-top:var(--space-4); }
.tf-price-amt{ font-family:var(--font-display); font-size:var(--text-xl); color:var(--teal-ink); font-weight:600; }
.tf-price-note{ font-size:var(--text-xs); color:var(--ink-faint); }

/* ---------- Homepage "pick" cards (light funnel to trips) ---------- */
.pick-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); margin-top:var(--space-6); }
.pick-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .2s var(--ease), box-shadow .2s var(--ease); }
.pick-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pick-media{ position:relative; display:block; aspect-ratio:3/2; overflow:hidden; }
.pick-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.pick-media:hover img{ transform:scale(1.05); }
.pick-body{ display:flex; flex-direction:column; padding:var(--space-5); flex:1; }
.pick-body h3{ font-size:var(--text-xl); }
.pick-tag{ font-family:var(--font-display); font-style:italic; font-size:var(--text-lg); line-height:1.25; color:var(--sun-deep); margin-top:var(--space-2); }
.pick-meta{ display:flex; flex-wrap:wrap; align-items:baseline; gap:.5rem; margin-top:var(--space-4); font-size:var(--text-sm); color:var(--ink-soft); }
.pick-price{ font-family:var(--font-display); font-size:var(--text-lg); font-weight:600; color:var(--teal-ink); }
.pick-sep{ color:var(--ink-faint); }
.pick-priceblurb{ font-size:var(--text-xs); color:var(--ink-faint); margin-top:.35rem; }
.pick-card .boat-chips{ margin-top:var(--space-4); }
.pick-actions{ display:flex; flex-direction:column; gap:.65rem; align-items:center; margin-top:auto; padding-top:var(--space-5); }
.pick-more{ font-size:var(--text-sm); font-weight:600; color:var(--teal-deep); text-decoration:none; }
.pick-more:hover{ text-decoration:underline; }
.pick-funnel{ text-align:center; margin-top:var(--space-6); font-size:var(--text-lg); color:var(--ink-soft); }
.pick-funnel a{ color:var(--teal-deep); font-weight:600; text-decoration:none; }
.pick-funnel a:hover{ text-decoration:underline; }

/* Booking-not-yet-live placeholder buttons + footnotes */
.btn.is-soon{ background:var(--surface-2); color:var(--ink-faint); border-color:var(--line); cursor:default; box-shadow:none; pointer-events:none; }
.btn.is-soon:hover{ transform:none; background:var(--surface-2); }
.soon-star{ color:var(--sun); font-weight:700; margin-left:.15em; }
.soon-note{ text-align:center; margin-top:var(--space-4); font-size:var(--text-xs); color:var(--ink-faint); }
.soon-note a{ color:var(--teal-deep); font-weight:600; }
.price-note{ font-size:var(--text-xs); color:var(--ink-faint); margin-top:.35rem; }

/* Boat chips — which boats run a trip style + where they depart */
.boat-chips{ display:flex; flex-wrap:wrap; gap:.55rem; margin-top:var(--space-5); }
.boat-chip{ display:inline-flex; align-items:center; gap:.5rem; background:var(--surface-2); border:1px solid var(--line); border-radius:var(--radius-full); padding:.45rem .9rem; font-size:var(--text-xs); text-decoration:none; transition:border-color .18s ease, background .18s ease; }
a.boat-chip:hover{ border-color:var(--teal); background:#fff; }
.boat-chip b{ font-family:var(--font-display); color:var(--teal-ink); font-weight:600; }
.boat-chip span{ color:var(--ink-faint); letter-spacing:.02em; }
.boat-chip .dot{ width:5px; height:5px; border-radius:50%; background:var(--sun); flex-shrink:0; }
.boat-chip.tier-premium .dot{ background:var(--teal); }
.boat-chip.tier-value .dot{ background:var(--emerald); }

/* Tier ribbon on fleet media */
.fleet-tier{ position:absolute; top:var(--space-5); right:var(--space-5); background:rgba(255,255,255,.92); color:var(--teal-ink); font-weight:600; font-size:var(--text-xs); letter-spacing:.06em; text-transform:uppercase; padding:.4rem .85rem; border-radius:var(--radius-full); box-shadow:var(--shadow-sm); }
.fleet-meta{ display:flex; flex-wrap:wrap; align-items:center; gap:.5rem 1.1rem; margin-top:var(--space-3); }
.fleet-depart{ display:inline-flex; align-items:center; gap:.45rem; font-size:var(--text-sm); color:var(--ink-soft); }
.fleet-depart svg{ width:16px; height:16px; color:var(--teal); }
.fleet-pax{ display:inline-flex; align-items:center; gap:.45rem; font-size:var(--text-sm); font-weight:600; color:var(--teal-ink); }
.fleet-pax svg{ width:16px; height:16px; color:var(--teal); }
.fleet-captag{ font-size:var(--text-xs); font-weight:600; letter-spacing:.04em; color:var(--teal-ink); background:var(--surface-2); border:1px solid var(--line); padding:.28rem .7rem; border-radius:var(--radius-full); }

/* Boat picker (tour detail) — selectable boats that run a trip style */
.boat-picker{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:.85rem; margin-top:var(--space-4); }
.boat-pick{ display:flex; flex-direction:column; gap:.4rem; padding:var(--space-4); border:1px solid var(--line); border-left:4px solid var(--sun); border-radius:var(--radius-md); background:#fff; text-decoration:none; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.boat-pick:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.boat-pick.tier-value{ border-left-color:var(--emerald); }
.boat-pick.tier-premium{ border-left-color:var(--teal); }
.boat-pick .bp-top{ display:flex; align-items:baseline; justify-content:space-between; gap:.5rem; }
.boat-pick .bp-top b{ font-family:var(--font-display); font-size:var(--text-base); color:var(--teal-ink); }
.boat-pick .bp-tier{ font-size:var(--text-xs); color:var(--ink-faint); text-transform:uppercase; letter-spacing:.06em; }
.boat-pick .bp-depart{ display:inline-flex; align-items:center; gap:.4rem; font-size:var(--text-sm); color:var(--ink-soft); }
.boat-pick .bp-depart svg{ width:15px; height:15px; color:var(--teal); flex-shrink:0; }
.boat-pick .bp-cap{ font-size:var(--text-xs); color:var(--ink-faint); }

/* Text-only price (placeholder until real pricing) */
.book-card .price:not(:has(small)){ font-size:var(--text-xl); }

/* ---------- East Pass story band (signature) ---------- */
.eastpass-band{ position:relative; overflow:hidden; background:var(--teal-ink); color:#fff; }
.eastpass-wordmark{ font-family:var(--font-display); font-weight:700; font-size:var(--text-4xl); line-height:.82; letter-spacing:-.03em; color:transparent; -webkit-text-stroke:1.5px rgba(255,255,255,.16); text-stroke:1.5px rgba(255,255,255,.16); pointer-events:none; user-select:none; }
.eastpass-inner{ position:relative; z-index:2; }
.eastpass-lead{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:end; margin-top:var(--space-8); }
.eastpass-lead h2{ font-size:var(--text-2xl); }
.eastpass-lead .em{ color:var(--aqua); }
.eastpass-lead p{ color:rgba(255,255,255,.85); font-size:var(--text-lg); }
.eastpass-points{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-6); margin-top:clamp(2.5rem,5vw,4rem); }
.ep-point{ position:relative; padding-top:var(--space-6); border-top:2px solid rgba(255,255,255,.18); }
.ep-point .n{ font-family:var(--font-display); font-size:var(--text-lg); color:var(--sun); font-weight:600; }
.ep-point h3{ font-size:var(--text-lg); margin-top:var(--space-2); color:#fff; }
.ep-point p{ color:rgba(255,255,255,.78); font-size:var(--text-sm); margin-top:var(--space-3); }
.eastpass-band .wave-deco{ position:absolute; left:0; right:0; bottom:0; opacity:.4; z-index:1; }
.eastpass-band .wave-deco svg{ width:100%; }

/* ---------- Reviews (staggered, fresh) ---------- */
.reviews-rail{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.review{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-sm); }
.reviews-rail .review:nth-child(2){ transform:translateY(28px); }
.reviews-rail .review:nth-child(3){ transform:translateY(-14px); }
.review .stars{ font-size:.95rem; }
.review .quote{ margin-top:var(--space-3); color:var(--ink); font-size:var(--text-base); }
.review .who{ display:flex; align-items:center; justify-content:space-between; margin-top:var(--space-5); font-size:var(--text-sm); }
.review .who b{ font-weight:600; }
.review .who span{ color:var(--ink-faint); font-size:var(--text-xs); }
.review .src{ display:inline-block; margin-top:.35rem; font-size:var(--text-xs); font-weight:600; color:var(--teal-deep); }

/* Big rating headline */
.rating-hero{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:center; }
.rating-hero .num{ font-family:var(--font-display); font-size:clamp(4rem,10vw,7rem); line-height:.9; color:var(--teal-ink); }
.rating-hero .stars{ font-size:1.4rem; }
.rating-hero p{ color:var(--ink-soft); margin-top:var(--space-2); }

/* ---------- Included checklist (playful) ---------- */
.include-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:var(--space-4); }
.include-item{ display:flex; gap:.85rem; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius-full); padding:.8rem 1.25rem; box-shadow:var(--shadow-sm); }
.include-item .ic{ width:38px; height:38px; flex-shrink:0; border-radius:var(--radius-full); background:var(--surface-2); color:var(--teal-deep); display:flex; align-items:center; justify-content:center; }
.include-item .ic svg{ width:20px; height:20px; }
.include-item span{ font-size:var(--text-sm); font-weight:500; }

/* ---------- Closing CTA ---------- */
.cta-band{ position:relative; overflow:hidden; color:#fff; text-align:center; }
.cta-band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.cta-band::after{ content:''; position:absolute; inset:0; z-index:-1; background:linear-gradient(120deg,rgba(5,50,56,.86),rgba(0,165,181,.6)); }
.cta-band h2{ font-size:var(--text-2xl); max-width:20ch; margin-inline:auto; }
.cta-band p{ font-size:var(--text-lg); color:rgba(255,255,255,.92); max-width:52ch; margin:var(--space-4) auto 0; }
.cta-band .hero-actions{ justify-content:center; margin-top:var(--space-8); }

/* ---------- Interior page hero ---------- */
.page-hero{ position:relative; background:linear-gradient(150deg,var(--sun-soft) 0%,#fdf1e6 32%,var(--surface) 68%,var(--surface-2) 100%); padding-block:clamp(3.5rem,8vw,6rem) clamp(2.5rem,5vw,4rem); overflow:hidden; }
.page-hero .eyebrow{ color:var(--teal-deep); }
.page-hero h1{ font-size:var(--text-3xl); margin-top:var(--space-4); max-width:20ch; }
.page-hero p{ font-size:var(--text-lg); color:var(--ink-soft); max-width:56ch; margin-top:var(--space-5); }
.page-hero .breadcrumb{ font-size:var(--text-xs); color:var(--ink-faint); margin-bottom:var(--space-4); }
.page-hero .breadcrumb a:hover{ color:var(--teal-deep); }
.page-hero .blob-deco{ display:none; }
.page-hero .wrap{ position:relative; z-index:1; }

/* Dark interior hero variant (photo bg) */
.page-hero.dark{ color:#fff; background:var(--teal-ink); }
.page-hero.dark img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; opacity:.42; }
.page-hero.dark::after{ content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg,rgba(5,50,56,.5),rgba(5,50,56,.78)); }
.page-hero.dark .wrap{ z-index:2; }
.page-hero.dark .eyebrow{ color:#fff; }
.page-hero.dark p{ color:rgba(255,255,255,.9); }
.page-hero.dark .breadcrumb{ color:rgba(255,255,255,.72); }

/* ---------- Trip detail ---------- */
.detail-grid{ display:grid; grid-template-columns:1.5fr .85fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.detail-hero-img{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); margin-bottom:var(--space-8); }
.detail-hero-img img{ width:100%; aspect-ratio:16/10; object-fit:cover; }
.detail-body h2{ font-size:var(--text-xl); margin-top:var(--space-8); }
.detail-body h2:first-child{ margin-top:0; }
.detail-body p{ color:var(--ink-soft); margin-top:var(--space-4); font-size:var(--text-lg); }
.detail-thumbs{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); margin-top:var(--space-6); }
.detail-thumbs img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); }
.book-card{ position:sticky; top:100px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-md); }
.book-card .price{ font-family:var(--font-display); font-size:var(--text-2xl); color:var(--teal-ink); }
.book-card .price small{ font-family:var(--font-body); font-size:var(--text-sm); color:var(--ink-faint); font-weight:400; }
.book-card .specs{ display:grid; gap:0; margin:var(--space-5) 0; }
.book-card .specs li{ display:flex; justify-content:space-between; font-size:var(--text-sm); border-bottom:1px dashed var(--line); padding:var(--space-3) 0; }
.book-card .specs b{ color:var(--ink); font-weight:600; }
.book-card .note{ font-size:var(--text-xs); color:var(--ink-faint); margin-top:var(--space-4); text-align:center; }
.tag-row{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:var(--space-4); }
.tag{ background:var(--surface-2); color:var(--teal-deep); font-size:var(--text-xs); font-weight:600; padding:.4rem .85rem; border-radius:var(--radius-full); }
.detail-faq{ margin-top:var(--space-8); }

/* ---------- Fleet ---------- */
.fleet-card{ display:grid; grid-template-columns:1fr 1fr; background:#fff; border:1px solid var(--line); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-sm); }
.fleet-card + .fleet-card{ margin-top:var(--space-8); }
.fleet-card.rev .fleet-media{ order:2; }
.fleet-media{ min-height:340px; position:relative; }
.fleet-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.fleet-body{ padding:clamp(1.75rem,4vw,3.25rem); align-self:center; }
.fleet-body .type{ font-size:var(--text-xs); font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--sun-deep); }
.fleet-body h3{ font-size:var(--text-xl); margin-top:var(--space-2); }
.fleet-body p{ color:var(--ink-soft); margin-top:var(--space-4); }

/* ---------- Gallery ---------- */
.masonry{ columns:3 300px; column-gap:var(--space-4); }
.masonry a{ display:block; margin-bottom:var(--space-4); border-radius:var(--radius-md); overflow:hidden; break-inside:avoid; box-shadow:var(--shadow-sm); }
.masonry img{ width:100%; transition:transform .5s var(--ease); }
.masonry a:hover img{ transform:scale(1.05); }

/* ---------- FAQ ---------- */
.faq-list{ max-width:var(--content-narrow); margin-inline:auto; display:grid; gap:var(--space-3); }
.faq-item{ border:1px solid var(--line); border-radius:var(--radius-md); background:#fff; overflow:hidden; box-shadow:var(--shadow-sm); }
.faq-item summary{ list-style:none; cursor:pointer; padding:var(--space-5) var(--space-6); font-family:var(--font-display); font-weight:600; font-size:var(--text-lg); display:flex; justify-content:space-between; gap:var(--space-4); align-items:center; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; font-size:1.6rem; color:var(--teal); transition:transform .2s var(--ease); line-height:1; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item .a{ padding:0 var(--space-6) var(--space-5); color:var(--ink-soft); }

/* ---------- About ---------- */
.about-split{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.about-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:4/5; }
.about-media img{ width:100%; height:100%; object-fit:cover; }
.about-body h2{ font-size:var(--text-2xl); margin-top:var(--space-3); }
.about-body p{ color:var(--ink-soft); font-size:var(--text-lg); margin-top:var(--space-4); }
.value-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:var(--space-5); }
.value-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-sm); }
.value-card .ic{ width:46px; height:46px; border-radius:var(--radius-md); background:var(--surface-2); color:var(--teal-deep); display:flex; align-items:center; justify-content:center; }
.value-card .ic svg{ width:24px; height:24px; }
.value-card h3{ font-size:var(--text-lg); margin-top:var(--space-4); }
.value-card p{ color:var(--ink-soft); font-size:var(--text-sm); margin-top:var(--space-2); }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); }
.field{ display:grid; gap:.4rem; margin-bottom:var(--space-4); }
.field label{ font-size:var(--text-sm); font-weight:600; }
.field input,.field textarea{ border:1.5px solid var(--line); border-radius:var(--radius-md); padding:.85rem 1.05rem; font-size:var(--text-base); background:#fff; font-family:inherit; }
.field input:focus,.field textarea:focus{ border-color:var(--teal); outline:none; }
.contact-card{ background:var(--surface); border-radius:var(--radius-lg); padding:clamp(1.5rem,3vw,2.5rem); }
.contact-info li{ display:flex; gap:var(--space-3); align-items:flex-start; margin-bottom:var(--space-5); }
.contact-info svg{ width:24px; height:24px; color:var(--teal); flex-shrink:0; margin-top:3px; }
.contact-info b{ display:block; color:var(--ink); }
.contact-info a,.contact-info span{ color:var(--ink-soft); }
.form-msg{ padding:var(--space-4); border-radius:var(--radius-md); font-size:var(--text-sm); margin-top:var(--space-3); }
.form-msg.ok{ background:#e3f6ee; color:#11633f; }
.form-msg.err{ background:#fde7e2; color:#a4310f; }

/* ---------- 404 ---------- */
.nf{ text-align:center; padding-block:clamp(5rem,12vw,9rem); }
.nf .big{ font-family:var(--font-display); font-size:clamp(5rem,18vw,11rem); line-height:.9; color:var(--teal); }
.nf h1{ font-size:var(--text-2xl); margin-top:var(--space-4); }
.nf p{ color:var(--ink-soft); font-size:var(--text-lg); margin:var(--space-4) auto 0; max-width:44ch; }
.nf .hero-actions{ justify-content:center; margin-top:var(--space-8); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--teal-ink); color:rgba(255,255,255,.78); padding-block:var(--space-16) var(--space-8); }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:var(--space-8); }
.site-footer h4{ color:#fff; font-family:var(--font-body); font-weight:600; font-size:var(--text-sm); letter-spacing:.1em; text-transform:uppercase; margin-bottom:var(--space-4); }
.site-footer a{ color:rgba(255,255,255,.78); font-size:var(--text-sm); }
.site-footer a:hover{ color:#fff; }
.site-footer .fcol li{ margin-bottom:var(--space-3); }
.footer-brand p{ font-size:var(--text-sm); max-width:36ch; margin-top:var(--space-4); }
.socials{ display:flex; gap:var(--space-3); margin-top:var(--space-6); }
.socials a{ width:40px; height:40px; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-full); background:rgba(255,255,255,.08); }
.socials a:hover{ background:var(--sun); }
.socials svg{ width:19px; height:19px; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:var(--space-12); padding-top:var(--space-6); display:flex; justify-content:space-between; flex-wrap:wrap; gap:var(--space-3); font-size:var(--text-xs); }

/* ---------- Reveal — gated behind html.js ---------- */
.reveal.in{ opacity:1; transform:none; }
html.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease),transform .8s var(--ease); }
html.js .reveal.in{ opacity:1; transform:none; }
html.js .reveal.d1{ transition-delay:.08s; }
html.js .reveal.d2{ transition-delay:.16s; }
html.js .reveal.d3{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){ html.js .reveal{ opacity:1; transform:none; } }

/* ---------- Live conditions widgets (weather + tide) ---------- */
/* Header chip */
.wx-chip{ display:inline-flex; align-items:center; gap:.3rem; padding:.28rem .6rem; border-radius:var(--radius-full); background:var(--surface); border:1px solid rgba(0,165,181,.22); color:var(--teal-deep); font-weight:600; font-size:var(--text-sm); line-height:1; text-decoration:none; transition:background .2s ease,border-color .2s ease; }
.wx-chip:hover{ background:#e4f6f4; border-color:rgba(0,165,181,.4); }
.wx-chip .wx-icon{ font-size:1.05em; line-height:1; }
.wx-chip .wx-temp{ font-variant-numeric:tabular-nums; }

/* Footer conditions block (dark footer background) */
.conditions{ display:grid; grid-template-columns:1fr 1.15fr; gap:var(--space-5); margin-top:var(--space-12); padding-top:var(--space-8); border-top:1px solid rgba(255,255,255,.12); }
.cond-card{ display:block; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-md); padding:var(--space-5); text-decoration:none; color:inherit; transition:background .2s ease, border-color .2s ease, transform .2s ease; }
a.cond-card:hover{ background:rgba(255,255,255,.07); border-color:rgba(127,216,208,.4); }
a.cond-card:hover .cond-source{ color:var(--sun); }
.cond-source{ display:inline-block; margin-left:auto; color:rgba(255,255,255,.5); font-size:var(--text-xs); font-weight:600; letter-spacing:.02em; transition:color .2s ease; }
.cond-tide .cond-source{ display:block; margin-top:var(--space-3); text-align:right; }
.cond-head{ display:flex; align-items:baseline; justify-content:space-between; gap:var(--space-3); margin-bottom:var(--space-4); }
.cond-label{ color:#fff; font-family:var(--font-body); font-weight:600; font-size:var(--text-xs); letter-spacing:.1em; text-transform:uppercase; }
.cond-loc{ color:rgba(255,255,255,.55); font-size:var(--text-xs); }
.cond-weather-main{ display:flex; align-items:center; gap:var(--space-4); }
.wx-icon-lg{ font-size:2.4rem; line-height:1; }
.wx-temp-lg{ display:block; color:#fff; font-family:var(--font-display,var(--font-body)); font-weight:700; font-size:var(--text-2xl); line-height:1; font-variant-numeric:tabular-nums; }
.wx-desc{ display:block; color:rgba(255,255,255,.75); font-size:var(--text-sm); margin-top:.2rem; }
.wx-meta{ display:flex; align-items:baseline; gap:var(--space-3); margin-top:var(--space-4); color:rgba(255,255,255,.6); font-size:var(--text-sm); }

/* Tide chart */
.tide-chart-wrap{ position:relative; }
.tide-chart{ display:block; width:100%; height:72px; overflow:visible; }
.tide-now-label{ display:inline-flex; align-items:center; gap:.35rem; padding:.15rem .55rem; border-radius:var(--radius-full); background:rgba(255,122,46,.14); color:var(--sun); font-size:var(--text-xs); font-weight:700; font-variant-numeric:tabular-nums; white-space:nowrap; }
.tide-events{ display:flex; align-items:center; flex-wrap:wrap; gap:.5rem .75rem; margin-top:var(--space-3); color:rgba(255,255,255,.75); font-size:var(--text-sm); }
.tide-events > [data-tide-events]{ display:inline-flex; align-items:center; flex-wrap:wrap; gap:.5rem; }
.tide-events strong{ color:#fff; font-weight:600; }
.tide-ev{ font-variant-numeric:tabular-nums; }
.tide-sep{ color:rgba(255,255,255,.35); }

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .nav-links,.nav-phone{ display:none; }
  .wx-chip{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-cta{ margin-left:auto; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-stage{ order:-1; max-width:440px; margin-inline:auto; }
  .hero-photo{ aspect-ratio:5/4; }
  .trip-feature,.trip-feature.rev{ grid-template-columns:1fr; }
  .trip-feature.rev .tf-media{ order:0; }
  .pick-grid{ grid-template-columns:repeat(2,1fr); }
  .fleet-card,.fleet-card.rev{ grid-template-columns:1fr; }
  .fleet-card.rev .fleet-media{ order:0; }
  .eastpass-lead{ grid-template-columns:1fr; gap:var(--space-5); }
  .eastpass-points{ grid-template-columns:1fr; gap:var(--space-8); }
  .reviews-rail{ grid-template-columns:1fr; }
  .reviews-rail .review:nth-child(2),.reviews-rail .review:nth-child(3){ transform:none; }
  .detail-grid{ grid-template-columns:1fr; }
  .book-card{ position:static; }
  .about-split{ grid-template-columns:1fr; }
  .about-media{ aspect-ratio:4/3; max-width:520px; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .masonry{ columns:2 220px; }
}
@media (max-width:600px){
  .footer-grid{ grid-template-columns:1fr; }
  .conditions{ grid-template-columns:1fr; gap:var(--space-4); margin-top:var(--space-8); }
  .masonry{ columns:1; }
  .pick-grid{ grid-template-columns:1fr; }
  .hero-actions .btn,.cta-band .hero-actions .btn{ flex:1; }
  .tf-media,.fleet-media{ min-height:280px; }
  .trip-feature.hero-trip .tf-media{ min-height:320px; }
  .hero-price-chip{ right:2%; }
  .hero-float-chip{ left:2%; }
  .detail-thumbs{ grid-template-columns:1fr; }
  /* Mobile nav drawer */
  .nav-links.open{ display:flex; position:absolute; top:76px; left:0; right:0; flex-direction:column; align-items:stretch; background:#fff; border-bottom:1px solid var(--line); padding:var(--space-4); gap:2px; box-shadow:var(--shadow-md); }
  .nav-links.open a{ padding:var(--space-4); font-size:var(--text-base); }
  .nav-links.open .mobile-phone{ display:flex; align-items:center; gap:.5rem; color:var(--teal-deep); font-weight:600; }
}
@media (max-width:960px) and (min-width:601px){
  .nav-links.open{ display:flex; position:absolute; top:76px; left:0; right:0; flex-direction:column; align-items:stretch; background:#fff; border-bottom:1px solid var(--line); padding:var(--space-4); gap:2px; box-shadow:var(--shadow-md); }
  .nav-links.open a{ padding:var(--space-4); font-size:var(--text-base); }
  .nav-links.open .mobile-phone{ display:flex; align-items:center; gap:.5rem; color:var(--teal-deep); font-weight:600; }
}

/* ============================================================
   Agreement / Waiver page (unlisted, noindex)
   ============================================================ */
.agreement-header{ position:sticky; top:0; z-index:60; background:#fff; border-bottom:1px solid var(--line); }
.agreement-header .nav{ height:70px; justify-content:space-between; }
.agreement-header .secure-tag{ display:inline-flex; align-items:center; gap:.45rem; font-size:var(--text-xs); font-weight:600; color:var(--teal-deep); background:var(--surface); padding:.45rem .85rem; border-radius:var(--radius-full); }
.agreement-main{ background:var(--cream); min-height:70vh; }

.agreement-intro{ position:relative; overflow:hidden; padding-block:clamp(2.75rem,6vw,4.5rem) clamp(1.5rem,3vw,2.5rem); }
.agreement-intro .blob-deco{ position:absolute; top:-40%; right:-6%; width:30%; aspect-ratio:1; background:radial-gradient(circle at 30% 30%,var(--sky),var(--surface-2)); border-radius:50%; opacity:.6; }
.agreement-intro .wrap{ position:relative; z-index:1; }
.agreement-intro h1{ font-size:var(--text-2xl); margin-top:var(--space-3); }
.agreement-intro .lede{ margin-top:var(--space-4); }
.agreement-intro a{ color:var(--teal-deep); font-weight:600; text-decoration:underline; text-underline-offset:2px; }

.agreement-shell{ padding-top:var(--space-6); }

/* Stepper progress */
.stepper-progress{ margin-bottom:var(--space-8); }
.stepper-bar{ height:6px; background:var(--surface-2); border-radius:var(--radius-full); overflow:hidden; }
.stepper-bar span{ display:block; height:100%; width:16.67%; background:linear-gradient(90deg,var(--teal),var(--aqua)); border-radius:var(--radius-full); transition:width .4s var(--ease); }
.stepper-dots{ display:flex; justify-content:space-between; margin-top:var(--space-4); gap:.3rem; }
.stepper-dots li{ display:flex; flex-direction:column; align-items:center; gap:.35rem; flex:1; text-align:center; }
.stepper-dots li span{ width:30px; height:30px; border-radius:var(--radius-full); background:var(--surface-2); color:var(--ink-faint); display:flex; align-items:center; justify-content:center; font-weight:600; font-size:var(--text-sm); border:2px solid transparent; transition:.25s var(--ease); }
.stepper-dots li em{ font-style:normal; font-size:var(--text-xs); color:var(--ink-faint); letter-spacing:.02em; }
.stepper-dots li.current span{ background:var(--teal); color:#fff; box-shadow:0 0 0 4px var(--sky); }
.stepper-dots li.current em{ color:var(--teal-deep); font-weight:600; }
.stepper-dots li.done span{ background:var(--emerald); color:#fff; }

/* Form panels */
.agreement-form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.5rem,4vw,3rem); box-shadow:var(--shadow-sm); }
.step-panel{ border:none; }
html.js .agreement-form .step-panel{ display:none; }
html.js .agreement-form .step-panel.active{ display:block; animation:stepIn .35s var(--ease); }
html:not(.js) .agreement-form .step-panel + .step-panel{ margin-top:var(--space-12); padding-top:var(--space-8); border-top:1px solid var(--line); }
@keyframes stepIn{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
.step-legend{ font-family:var(--font-display); font-weight:600; font-size:var(--text-xl); letter-spacing:-.02em; margin-bottom:var(--space-2); }
.step-num{ display:block; font-family:var(--font-body); font-size:var(--text-xs); font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--teal-deep); margin-bottom:.35rem; }
.step-hint{ color:var(--ink-soft); font-size:var(--text-sm); margin-bottom:var(--space-6); }
.step-hint em{ color:var(--sun-deep); font-style:normal; font-weight:600; }
.sub-h{ font-size:var(--text-lg); margin-top:var(--space-6); margin-bottom:var(--space-4); }
.body-copy{ color:var(--ink-soft); font-size:var(--text-sm); margin-top:var(--space-4); }

.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4) var(--space-5); }
.grid-3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:var(--space-4) var(--space-5); }
.init-input{ max-width:130px; text-transform:uppercase; letter-spacing:.1em; font-weight:600; }
.field .invalid,.field input.invalid,input.invalid{ border-color:var(--sun-deep)!important; background:#fff6f2; }
.fine-print{ font-size:var(--text-xs); color:var(--ink-faint); background:var(--surface); border-radius:var(--radius-md); padding:var(--space-4); margin-top:var(--space-6); line-height:1.5; }
.field-note{ font-size:var(--text-xs); color:var(--ink-faint); }

.step-actions{ display:flex; gap:var(--space-3); margin-top:var(--space-8); flex-wrap:wrap; }
.step-actions .btn-primary{ margin-left:auto; }

/* Rules list */
.rules-list{ display:grid; gap:var(--space-4); counter-reset:rule; }
.rules-list li{ display:grid; grid-template-columns:1fr auto; gap:var(--space-5); align-items:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:var(--space-5); }
.rule-text{ font-size:var(--text-sm); color:var(--ink); line-height:1.55; }
.rule-text b{ color:var(--teal-deep); }
.rule-init{ display:flex; align-items:center; }
.rule-check{ display:inline-flex; align-items:center; gap:.55rem; font-size:var(--text-sm); font-weight:600; color:var(--ink-soft); cursor:pointer; white-space:nowrap; padding:.35rem .55rem; border-radius:var(--radius-sm); transition:.15s var(--ease); }
.rule-check:hover{ color:var(--teal-deep); }
.rule-check input{ width:22px; height:22px; accent-color:var(--teal); flex-shrink:0; cursor:pointer; }
.rule-check input:checked ~ span{ color:var(--teal-deep); }
.rules-list li:has(input:checked){ border-color:var(--teal); box-shadow:var(--shadow-sm); }

/* Captain selection */
.rate-callout{ background:var(--sun-soft); color:var(--sun-deep); border-radius:var(--radius-md); padding:var(--space-4) var(--space-5); margin-top:var(--space-4); font-size:var(--text-sm); }
.rate-callout b{ color:var(--sun-deep); }
.captain-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3); margin-top:var(--space-4); }
.captain-card{ position:relative; display:flex; align-items:center; gap:var(--space-3); border:1.5px solid var(--line); border-radius:var(--radius-md); padding:var(--space-4); cursor:pointer; transition:.18s var(--ease); background:#fff; }
.captain-card:hover{ border-color:var(--teal); }
.captain-card input{ position:absolute; opacity:0; pointer-events:none; }
.cap-check{ width:22px; height:22px; border-radius:var(--radius-full); border:2px solid var(--line); flex-shrink:0; transition:.18s var(--ease); }
.captain-card input:checked ~ .cap-check{ border-color:var(--teal); background:radial-gradient(circle,var(--teal) 42%,transparent 46%); }
.captain-card input:checked ~ .cap-info b{ color:var(--teal-deep); }
.captain-card:has(input:checked){ border-color:var(--teal); background:var(--surface); box-shadow:var(--shadow-sm); }
.captain-card input:focus-visible ~ .cap-check{ outline:3px solid var(--teal); outline-offset:2px; }
.cap-info{ display:flex; flex-direction:column; }
.cap-info b{ font-size:var(--text-sm); }
.cap-info a{ font-size:var(--text-xs); color:var(--ink-soft); }
.cap-note{ font-size:var(--text-xs); color:var(--ink-faint); }
.captain-other-fields{ margin-top:var(--space-4); }
/* Reveal the fill-in captain fields + hint only when "Someone else" is chosen.
   Backs up the JS toggle (works even if the [hidden] attr is cleared). */
.step-panel[data-step="3"]:not(:has(#captainOther:checked)) #captainOtherFields,
.step-panel[data-step="3"]:not(:has(#captainOther:checked)) #captainOtherHint{ display:none!important; }
@media (max-width:560px){ .rules-list li{ grid-template-columns:1fr; gap:var(--space-3); } }

/* Waiver doc */
.waiver-doc{ max-height:340px; overflow-y:auto; border:1px solid var(--line); border-radius:var(--radius-md); padding:var(--space-6); background:var(--surface); margin-bottom:var(--space-5); }
.waiver-doc:focus-visible{ outline:3px solid var(--teal); outline-offset:2px; }
.waiver-clauses{ display:grid; gap:var(--space-4); counter-reset:clause; }
.waiver-clauses li{ font-size:var(--text-sm); color:var(--ink-soft); line-height:1.6; padding-left:1.75rem; position:relative; }
.waiver-clauses li::before{ counter-increment:clause; content:counter(clause) '.'; position:absolute; left:0; top:0; font-family:var(--font-display); font-weight:600; color:var(--teal); }
.waiver-clauses li b{ color:var(--ink); }
.waiver-ack{ margin-top:var(--space-5); padding-top:var(--space-4); border-top:1px dashed var(--line); font-size:var(--text-sm); font-weight:600; color:var(--ink); }
.ack-check,.captain-card{ font-size:var(--text-sm); }
.ack-check{ display:flex; align-items:flex-start; gap:.65rem; font-weight:500; color:var(--ink); }
.ack-check input{ width:20px; height:20px; margin-top:2px; accent-color:var(--teal); flex-shrink:0; }

/* Guest list */
.guest-list{ display:grid; gap:.5rem; }
.guest-head,.guest-row{ display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:var(--space-3); }
.guest-head{ font-size:var(--text-xs); font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); padding:0 .2rem; }
.guest-row input{ border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.65rem .8rem; font-size:var(--text-sm); background:#fff; font-family:inherit; }
.guest-row input:focus{ border-color:var(--teal); outline:none; }
.upload-label{ display:inline-flex; align-items:center; gap:.6rem; border:1.5px dashed var(--line); border-radius:var(--radius-md); padding:var(--space-4) var(--space-5); cursor:pointer; color:var(--teal-deep); font-weight:600; font-size:var(--text-sm); transition:.18s var(--ease); width:fit-content; }
.upload-label:hover{ border-color:var(--teal); background:var(--surface); }
.visually-hidden-file{ position:absolute; width:1px; height:1px; opacity:0; }
.file-name{ display:inline-block; margin-left:var(--space-3); font-size:var(--text-sm); color:var(--ink-soft); }
.req-star{ color:#c0392b; font-weight:700; margin-left:.15rem; }

/* Sign & summary */
.summary-box{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:var(--space-5); margin-bottom:var(--space-6); }
.summary-box h3{ font-size:var(--text-lg); margin-bottom:var(--space-3); }
.summary-box dl{ display:grid; gap:.55rem; }
.summary-box dl > div{ display:grid; grid-template-columns:150px 1fr; gap:var(--space-3); font-size:var(--text-sm); }
.summary-box dt{ color:var(--ink-faint); font-weight:600; }
.summary-box dd{ color:var(--ink); }
.cert-copy{ font-size:var(--text-sm); color:var(--ink-soft); background:var(--sun-soft); border-radius:var(--radius-md); padding:var(--space-5); line-height:1.6; margin-bottom:var(--space-6); }
.signature-input{ font-family:var(--font-display); font-size:var(--text-lg); }

/* QR helper */
.qr-aside{ display:flex; align-items:center; gap:var(--space-5); margin-top:var(--space-8); padding:var(--space-5); background:#fff; border:1px dashed var(--line); border-radius:var(--radius-md); }
.qr-aside img{ border-radius:var(--radius-sm); flex-shrink:0; }
.qr-aside b{ font-size:var(--text-sm); color:var(--ink); }
.qr-aside p{ font-size:var(--text-xs); color:var(--ink-faint); margin-top:.25rem; }

/* Confirmation */
.agreement-done{ text-align:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(2.5rem,6vw,4rem); box-shadow:var(--shadow-md); }
.done-check{ width:74px; height:74px; margin:0 auto var(--space-5); border-radius:var(--radius-full); background:var(--emerald); color:#fff; display:flex; align-items:center; justify-content:center; }
.done-check svg{ width:38px; height:38px; }
.agreement-done h2{ font-size:var(--text-2xl); }
.agreement-done p{ color:var(--ink-soft); font-size:var(--text-lg); margin-top:var(--space-4); max-width:52ch; margin-inline:auto; }
.agreement-done .done-note{ font-size:var(--text-sm); }
.agreement-done .btn{ margin-top:var(--space-8); }

/* Agreement footer variant */
.agreement-footer{ padding-block:var(--space-8); }
.agreement-footer .wrap{ text-align:center; }
.agreement-footer p{ font-size:var(--text-sm); }
.agreement-footer a{ color:#fff; text-decoration:underline; }
.agreement-footer .copyline{ font-size:var(--text-xs); margin-top:var(--space-2); opacity:.7; }

/* no-JS: hide JS-only chrome */
html:not(.js) .js-only{ display:none; }

@media (max-width:700px){
  .grid-2,.grid-3{ grid-template-columns:1fr; }
  .rules-list li{ grid-template-columns:1fr; gap:var(--space-3); }
  .init-input{ max-width:160px; }
  .captain-grid{ grid-template-columns:1fr; }
  .guest-head{ display:none; }
  .guest-row{ grid-template-columns:1fr; gap:.4rem; padding:var(--space-3); background:var(--surface); border-radius:var(--radius-sm); }
  .stepper-dots li em{ display:none; }
  .summary-box dl > div{ grid-template-columns:1fr; gap:.15rem; }
  .step-actions .btn{ flex:1; }
  .step-actions .btn-primary{ margin-left:0; }
  .qr-aside{ flex-direction:column; text-align:center; }
}

/* ============ Blog / Journal ============ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,3vw,2.25rem); }
.blog-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.blog-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.blog-card-media{ position:relative; display:block; aspect-ratio:3/2; overflow:hidden; }
.blog-card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.blog-card:hover .blog-card-media img{ transform:scale(1.04); }
.blog-card-tag{ position:absolute; top:.9rem; left:.9rem; background:rgba(5,50,56,.82); color:#fff; font-family:var(--font-display); font-weight:600; font-size:var(--text-xs); letter-spacing:.02em; padding:.35rem .7rem; border-radius:var(--radius-full); backdrop-filter:blur(4px); }
.blog-card-body{ padding:var(--space-5); display:flex; flex-direction:column; gap:.7rem; flex:1; }
.blog-card-meta{ display:flex; align-items:center; gap:.5rem; font-size:var(--text-xs); color:var(--ink-faint); text-transform:uppercase; letter-spacing:.06em; }
.blog-card-body h2,.blog-card-body h3{ font-size:var(--text-lg); line-height:1.12; }
.blog-card-body h2 a,.blog-card-body h3 a{ color:var(--teal-ink); text-decoration:none; }
.blog-card-body h2 a:hover,.blog-card-body h3 a:hover{ color:var(--teal); }
.blog-card-body p{ color:var(--ink-soft); font-size:var(--text-sm); line-height:1.55; }
.blog-card-link{ margin-top:auto; display:inline-flex; align-items:center; gap:.4rem; font-family:var(--font-display); font-weight:600; font-size:var(--text-sm); color:var(--teal-ink); text-decoration:none; }
.blog-card-link svg{ width:1.05em; height:1.05em; transition:transform .25s var(--ease); }
.blog-card-link:hover{ color:var(--teal); }
.blog-card-link:hover svg{ transform:translateX(4px); }

/* Article body */
.article-hero{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); margin:0 0 clamp(2rem,4vw,3rem); }
.article-hero img{ width:100%; aspect-ratio:16/9; object-fit:cover; }
.article-body{ max-width:var(--content-narrow); margin-inline:auto; }
.article-body h2{ font-size:var(--text-xl); margin:clamp(2rem,4vw,2.75rem) 0 var(--space-3); color:var(--teal-ink); }
.article-body p{ color:var(--ink-soft); font-size:var(--text-lg); line-height:1.7; margin-bottom:var(--space-4); }
.article-body a{ color:var(--teal); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1.5px; }
.article-body a:hover{ color:var(--teal-deep); }
.article-body ul{ margin:0 0 var(--space-4); padding-left:1.4rem; display:grid; gap:.6rem; }
.article-body li{ color:var(--ink-soft); font-size:var(--text-lg); line-height:1.6; }
.article-body li::marker{ color:var(--teal); }
.article-body strong{ color:var(--ink); font-weight:600; }

@media (max-width:900px){
  .blog-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .blog-grid{ grid-template-columns:1fr; }
  .article-body p,.article-body li{ font-size:var(--text-base); }
}

/* ============================================================
   Whiskey (Demise Charter Agreement) — standalone waiver page
   ============================================================ */
.field-wide{ grid-column:1 / -1; }

.whiskey-terms{ max-height:520px; }
.whiskey-terms .wk-section{ padding-bottom:var(--space-5); margin-bottom:var(--space-5); border-bottom:1px solid var(--line); }
.whiskey-terms .wk-section:last-child{ border-bottom:0; margin-bottom:0; padding-bottom:0; }
.wk-section-title{ font-family:var(--font-display); font-size:var(--text-base); font-weight:600; color:var(--teal-deep); margin:0 0 var(--space-3); line-height:1.3; }
.wk-p{ font-size:var(--text-sm); color:var(--ink-soft); line-height:1.6; margin:0 0 var(--space-3); }
.wk-p:last-of-type{ margin-bottom:var(--space-3); }
.wk-allcaps{ font-weight:600; color:var(--ink); text-transform:uppercase; letter-spacing:.01em; }
.wk-bullets,.wk-items{ margin:0 0 var(--space-3); padding-left:1.5rem; display:grid; gap:.45rem; }
.wk-bullets li,.wk-items li{ font-size:var(--text-sm); color:var(--ink-soft); line-height:1.55; }
.wk-bullets li{ list-style:disc; }
.wk-items{ list-style:none; padding-left:0; counter-reset:none; }
.wk-items li{ padding-left:2rem; position:relative; }
.wk-items li b{ position:absolute; left:0; top:0; color:var(--teal-deep); font-weight:600; }
.wk-ack{ margin-top:var(--space-4); padding:.5rem .7rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); white-space:normal; }
.wk-ack input:checked ~ span{ color:var(--teal-deep); }

.captain-plainlist{ list-style:none; margin:var(--space-3) 0 var(--space-5); padding:0; display:grid; gap:.5rem; }
.captain-plainlist li{ font-size:var(--text-sm); color:var(--ink-soft); }
.captain-plainlist li b{ color:var(--ink); }
.captain-plainlist a{ color:var(--teal-deep); font-weight:600; }
