/* ============================================================
   Vacadock marketing site — design tokens from the product
   ============================================================ */
:root{
  --ocean-900:#0c4a6e; --ocean-700:#0369a1; --ocean-500:#06b6d4;
  --ocean-100:#cffafe; --ocean-50:#ecfeff;
  --teal:#0d9488; --coral:#f97316; --violet:#6d5ef0;
  --headline-navy:#134b63; --headline-coral:#e87b4d;
  --navy-btn:#16455c; --navy-btn-hover:#0f3a4f;
  --sand:#fbf7f0; --canvas:#fcf8f1; --line:#e7e2d8;
  --ink:#0f172a; --ink-2:#475569; --ink-3:#94a3b8;
  --card:#ffffff;
  --shadow:0 1px 2px rgb(15 23 42 / .04), 0 8px 24px rgb(15 23 42 / .06);
  --shadow-lg:0 2px 4px rgb(15 23 42 / .05), 0 16px 40px rgb(15 23 42 / .10);
  --serif:"Source Serif 4", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, "Segoe UI", Roboto, sans-serif;
  --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans); color:var(--ink); font-size:16px; line-height:1.5;
  background:linear-gradient(180deg,#f4e7d5 0%, #f0ddc6 40%, #ecd6bc 100%);
  min-height:100vh; padding:22px;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;border:none;background:none;cursor:pointer}
strong{font-weight:600}

.canvas{
  max-width:1560px;margin:0 auto;background:var(--canvas);
  border-radius:var(--r-xl); overflow:hidden;
  box-shadow:0 24px 80px rgb(120 72 20 / .18);
}

/* ---------- icons ---------- */
.ic{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;
    stroke-linecap:round;stroke-linejoin:round;flex:none}
.ic-16{width:16px;height:16px}
.ic-14{width:14px;height:14px}
.ic-12{width:12px;height:12px}

/* ---------- buttons / links / chips ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;
     border-radius:14px;padding:13px 22px;font-size:15px;transition:all .15s ease}
.btn-navy{background:var(--navy-btn);color:#fff;box-shadow:var(--shadow)}
.btn-navy:hover{background:var(--navy-btn-hover)}
.btn-ghost{background:rgb(255 255 255 / .75);color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{background:#fff}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{background:#ea6a0a}
.btn-sm{padding:9px 18px;font-size:14px;border-radius:12px}
.btn-xs{padding:7px 13px;font-size:12px;border-radius:10px}
.play-dot{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;
  border-radius:50%;border:1.5px solid var(--ink-2);color:var(--ink-2)}

.card-link{display:inline-flex;align-items:center;gap:5px;color:var(--ocean-700);
  font-size:12.5px;font-weight:600;white-space:nowrap}
.card-link:hover{color:var(--ocean-900)}

.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;
  background:#fff;border:1px solid var(--line);font-size:12px;font-weight:500;color:var(--ink-2);
  white-space:nowrap}
.chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}

.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;
  font-size:11px;font-weight:600;font-style:normal}
.pill-green{background:#e5f3ea;color:#2e7d5b}

.arr{color:var(--ink-3)}

/* ---------- icon tiles ---------- */
.tile{display:inline-flex;align-items:center;justify-content:center;flex:none;
  width:38px;height:38px;border-radius:12px}
.tile .ic{width:18px;height:18px}
.tile-sky{background:#e3f2fb;color:var(--ocean-700)}
.tile-sand{background:#f6ecdd;color:#b0722d}
.tile-teal{background:#e0f2ef;color:var(--teal)}
.tile-coral{background:#fdeadd;color:var(--coral)}
.tile-amber{background:#fdf3dc;color:#c98a1b}
.tile-lg{width:52px;height:52px;border-radius:16px}
.tile-lg .ic{width:24px;height:24px}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid rgb(231 226 216 / .8);
  border-radius:var(--r-lg);box-shadow:var(--shadow);padding:18px}
.card-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.card-head h3{font-size:14.5px;font-weight:600;letter-spacing:-.01em}
.card-head .card-link{margin-left:auto}
.head-ic{color:var(--ink-2);display:inline-flex}

/* ============================================================
   NAV
   ============================================================ */
.nav{display:flex;align-items:center;gap:34px;padding:18px 34px;position:relative;z-index:20}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:38px;height:38px}
.brand-mark-sm{width:22px;height:22px}
.brand-name{font-family:var(--serif);font-size:24px;font-weight:600;color:#1d2a33;letter-spacing:-.01em}
.nav-links{display:flex;gap:28px;font-size:14.5px;font-weight:500;color:var(--ink-2)}
.nav-links a{display:inline-flex;align-items:center;gap:4px}
.nav-links a:hover{color:var(--ink)}
.nav-actions{margin-left:auto;display:flex;align-items:center;gap:22px}
.nav-login{font-size:14.5px;font-weight:500;color:var(--ink-2)}
.nav-burger{display:none;color:var(--ink);margin-left:auto}

/* ============================================================
   HERO ROW
   ============================================================ */
.collage{padding:0 26px 26px}
.row{position:relative}

.hero-row{
  display:grid;
  grid-template-columns:minmax(400px,500px) minmax(120px,1fr) minmax(280px,322px) minmax(300px,352px);
  gap:18px;align-items:center;
  min-height:440px;padding:12px 8px 18px;
}
.hero-row .card-ai,.hero-row .card-itin{align-self:start}
.hero-copy{grid-column:1}
.hero-photo-wrap{position:relative;grid-column:2;align-self:stretch;z-index:0;pointer-events:none}
.hero-row .card-ai{grid-column:3}
.hero-row .card-itin{grid-column:4}
/* The frame bleeds symmetrically out of the gap column, so the photo's center —
   where the family sits — always lands in the visible gap at any viewport width. */
.hero-photo-frame{position:absolute;inset:2px -300px -8px -300px}
.hero-photo{width:100%;height:100%;object-fit:cover;object-position:50% 78%;
  -webkit-mask-image:radial-gradient(ellipse 56% 72% at 50% 52%, #000 52%, transparent 96%);
  mask-image:radial-gradient(ellipse 56% 72% at 50% 52%, #000 52%, transparent 96%);}
.hero-photo-fade{position:absolute;inset:0;
  background:linear-gradient(90deg,var(--canvas) 0%,transparent 18%,transparent 82%,var(--canvas) 100%),
             linear-gradient(180deg,var(--canvas) 0%,transparent 22%,transparent 80%,var(--canvas) 100%);}

.hero-copy{position:relative;z-index:2;padding-left:26px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--headline-coral);margin-bottom:16px}
.headline{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;
  font-size:clamp(42px,4.6vw,66px);line-height:1.06;color:var(--headline-navy)}
.headline .accent{color:var(--headline-coral)}
.subhead{font-size:17.5px;color:var(--ink-2);max-width:420px;margin:20px 0 26px;line-height:1.55}
.hero-ctas{display:flex;gap:14px;flex-wrap:nowrap;white-space:nowrap}
.hero-ctas .btn{padding:13px 18px;flex:none}

/* AI chat card */
.card-ai{position:relative;z-index:2;padding:16px}
.ai-spark{display:inline-flex;align-items:center;justify-content:center;color:var(--violet)}
.chat{display:flex;flex-direction:column;gap:8px}
.chat-row{display:flex;gap:8px;align-items:flex-start}
.chat-row-user{justify-content:flex-end}
.chat-avatar{display:inline-flex;align-items:center;justify-content:center;flex:none;
  width:22px;height:22px;border-radius:50%;background:#fdeadd;color:var(--coral);margin-top:2px}
.bubble{border-radius:14px;padding:9px 12px;font-size:12.5px;line-height:1.45;color:var(--ink-2);
  max-width:88%}
.bubble-ai{background:#f6f1e7;border-bottom-left-radius:4px}
.bubble-user{background:#fff;border:1px solid var(--line);box-shadow:0 1px 2px rgb(15 23 42/.04);
  border-bottom-right-radius:4px}
.chat-input{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 8px 8px 14px;
  border:1px solid var(--line);border-radius:999px;font-size:12.5px;color:var(--ink-3);
  background:#fff}
.chat-input span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-send{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;
  border-radius:50%;background:var(--ocean-700);color:#fff;flex:none}
.chat-send-coral{background:var(--coral)}

/* Itinerary card */
.card-itin{position:relative;z-index:2;padding:16px 16px 6px}
.itin-list{display:flex;flex-direction:column}
.itin-row{display:flex;align-items:center;gap:11px;padding:10px 0;border-top:1px solid #f0ebe1}
.itin-row:first-child{border-top:none}
.itin-txt{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.3}
.itin-day{font-size:10.5px;font-weight:600;color:var(--ink-3);text-transform:none}
.itin-txt strong{font-size:13px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.itin-txt small{font-size:11.5px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.thumb{width:46px;height:40px;object-fit:cover;border-radius:9px;flex:none}
.kebab{width:3px;height:3px;border-radius:50%;background:var(--ink-3);position:relative;flex:none;margin:0 4px}
.kebab::before,.kebab::after{content:"";position:absolute;left:0;width:3px;height:3px;border-radius:50%;background:var(--ink-3)}
.kebab::before{top:-6px}.kebab::after{top:6px}

/* ============================================================
   MID ROW
   ============================================================ */
.mid-row{display:grid;grid-template-columns:25.5fr 25fr 17fr 29fr;gap:18px;margin-top:16px}

.bookings-cols{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.booking-list{display:flex;flex-direction:column}
.booking-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-top:1px solid #f0ebe1}
.booking-row:first-child{border-top:none}
.booking-row .pill{margin-left:auto}
.docs-col{border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;background:#fdfbf7}
.docs-title{font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:8px}
.docs-list{display:flex;flex-direction:column;gap:8px}
.docs-list li{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2)}
.docs-list .ic{color:var(--ink-3)}

/* Route / map */
.card-route{display:flex;flex-direction:column}
.map-wrap{position:relative;flex:1;min-height:170px;border-radius:var(--r-md);overflow:hidden}
.map-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.map-overlay{position:absolute;inset:0;width:100%;height:100%}
.map-zoom{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;
  background:#fff;border-radius:9px;box-shadow:var(--shadow);overflow:hidden;z-index:2}
.map-zoom button{width:26px;height:26px;font-size:14px;color:var(--ink-2);line-height:1}
.map-zoom button:first-child{border-bottom:1px solid var(--line)}
.map-pin{position:absolute;width:14px;height:14px;border-radius:50% 50% 50% 0;transform:rotate(-45deg) translate(-50%,-50%);
  box-shadow:0 2px 5px rgb(15 23 42/.3);z-index:2}
.map-pin::after{content:"";position:absolute;inset:4px;border-radius:50%;background:#fff}
.pin-ocean{background:var(--ocean-700)}
.pin-coral{background:var(--coral)}
.route-bar{display:flex;align-items:center;gap:10px;margin-top:12px}
.route-chips{display:flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:7px 10px;font-size:11.5px;font-weight:600;flex:1;min-width:0;
  overflow:hidden;white-space:nowrap}
.route-bar .btn{margin-left:auto;flex:none}

/* Family preferences */
.pref-list{display:flex;flex-direction:column}
.pref-list li{display:flex;align-items:center;gap:11px;padding:9px 0;border-top:1px solid #f0ebe1}
.pref-list li:first-child{border-top:none}
.pref-edit{margin-top:8px}
.mobile-only{display:none}

/* Photo card */
.card-photo{position:relative;padding:0;overflow:hidden;min-height:280px}
.card-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.card-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgb(12 30 40/.28) 0%,transparent 30%,transparent 55%,rgb(12 30 40/.62) 100%)}
.photo-top{position:absolute;top:16px;left:18px;right:16px;display:flex;align-items:center;
  justify-content:space-between;z-index:2}
.photo-title{font-family:var(--serif);font-size:19px;font-weight:500;color:#fff;
  text-shadow:0 1px 8px rgb(0 0 0/.35)}
.photo-temp{display:inline-flex;align-items:center;gap:5px;background:rgb(255 255 255/.22);
  backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:600;border-radius:999px;padding:5px 11px}
.photo-quote{position:absolute;left:20px;right:20px;bottom:18px;z-index:2;color:#fff;
  font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.4;
  text-shadow:0 1px 8px rgb(0 0 0/.4)}

/* ============================================================
   BOTTOM ROW
   ============================================================ */
.bottom-row{display:grid;grid-template-columns:19fr 32fr 47fr;gap:18px;margin-top:16px}

.packing-body{display:flex;align-items:center;gap:18px}
.ring{position:relative;width:86px;height:86px;flex:none}
.ring svg{width:100%;height:100%}
.ring-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;line-height:1.1}
.ring-label strong{font-size:17px}
.ring-label small{font-size:10px;color:var(--ink-3)}
.check-list{display:flex;flex-direction:column;gap:7px;font-size:12.5px;color:var(--ink-2)}
.check-list li{display:flex;align-items:center;gap:9px}
.check-list li.done{color:var(--ink)}
.cbx{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;
  border-radius:5px;background:var(--teal);color:#fff;flex:none}
.cbx-empty{background:#fff;border:1.5px solid var(--line)}

/* Weather */
.weather-grid{display:grid;grid-template-columns:repeat(5,1fr);text-align:center}
.wday{display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px 4px;
  border-left:1px solid #f0ebe1}
.wday:first-child{border-left:none}
.wday span{font-size:11.5px;font-weight:600;color:var(--ink-3)}
.wday strong{font-size:14px}
.wday small{font-size:11px;color:var(--ink-3)}
.w-sun{color:#f4a933;width:22px;height:22px}
.w-cloud{color:#a9b6c2;width:22px;height:22px}
.weather-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:10px;padding-top:10px;border-top:1px solid #f0ebe1;font-size:12.5px;color:var(--ink-2)}

/* Feature strip */
.card-features{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:center;
  background:#faf5ec}
.feature{display:flex;align-items:flex-start;gap:11px}
.feature strong{display:block;font-size:13px;letter-spacing:-.01em}
.feature small{display:block;font-size:11.5px;color:var(--ink-2);line-height:1.4;margin-top:2px}

/* ============================================================
   MARKETING SECTIONS
   ============================================================ */
.section{padding:84px 34px;max-width:1120px;margin:0 auto;text-align:center}
.h2{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;
  font-size:clamp(30px,3.2vw,44px);line-height:1.12;color:var(--headline-navy);margin-bottom:18px}
.section-copy{font-size:16.5px;color:var(--ink-2);max-width:640px;margin:0 auto 30px;line-height:1.6}
.section .eyebrow{margin-bottom:14px}

.section-problem{border-top:1px solid var(--line);margin-top:34px;max-width:none}
.tab-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:640px;margin:0 auto}
.tab-pill{padding:8px 16px;border-radius:999px;background:#fff;border:1px solid var(--line);
  font-size:13.5px;color:var(--ink-3);text-decoration:line-through;text-decoration-color:rgb(148 163 184/.6)}
.tab-pill-good{display:inline-flex;align-items:center;gap:7px;text-decoration:none;color:#fff;
  background:var(--navy-btn);border-color:var(--navy-btn);font-weight:600}

.three-up{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:left;margin-top:10px}
.info-card{padding:26px}
.info-card h3{font-size:17px;margin:16px 0 8px;letter-spacing:-.01em}
.info-card p{font-size:14px;color:var(--ink-2);line-height:1.55}
.door{position:relative}
.door-num{position:absolute;top:20px;right:22px;font-family:var(--serif);font-size:30px;
  color:var(--line);font-weight:600;line-height:1}
.addr-pill{display:inline-block;margin-top:14px;padding:7px 13px;border-radius:999px;
  background:#f6f1e7;font-size:12.5px;color:var(--ink-2);font-weight:500;
  font-variant-numeric:tabular-nums}

/* Ask section */
.section-ask{max-width:1240px}
.ask-grid{display:grid;grid-template-columns:1.1fr .8fr .8fr;gap:34px;align-items:center;text-align:left}
.ask-copy .eyebrow,.ask-copy .h2{text-align:left}
.ask-copy .section-copy{margin-left:0;text-align:left}
.qa-list{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.qa{display:flex;flex-direction:column;gap:6px}
.qa .bubble-user{align-self:flex-end;font-weight:500;color:var(--ink)}
.qa .bubble-ai{align-self:flex-start;max-width:92%}

/* Phone mockups */
.phone{background:#1c2530;border-radius:42px;padding:10px;box-shadow:var(--shadow-lg);
  max-width:300px;justify-self:center}
.phone-screen{background:var(--sand);border-radius:34px;padding:16px 13px;overflow:hidden;
  display:flex;flex-direction:column;gap:10px;min-height:520px}
.p-head{display:flex;align-items:center;justify-content:space-between}
.p-title{display:flex;align-items:center;gap:7px;font-weight:600;font-size:14.5px}
.p-title .brand-mark{width:22px;height:22px}
.p-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#f4b183,#c98a1b)}
.p-sub{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.p-sub strong{font-size:13.5px}
.p-label{font-size:12px;font-weight:600;margin-top:2px}
.phone .itin-list{background:#fff;border-radius:var(--r-md);padding:2px 12px;border:1px solid rgb(231 226 216/.8)}
.phone .bubble{font-size:11.5px}
.phone .chip{font-size:10.5px;padding:5px 10px}
.phone .chat-input{margin-top:auto}
.mini-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mini-card{background:#fff;border:1px solid rgb(231 226 216/.8);border-radius:12px;padding:7px;
  font-size:10.5px;line-height:1.3}
.mini-card img{width:100%;height:64px;object-fit:cover;border-radius:8px;margin-bottom:6px}
.mini-card strong{display:block;font-size:11px}
.mini-card small{color:var(--ink-3);font-size:10px}
.p-quad{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.pq{background:#fff;border:1px solid rgb(231 226 216/.8);border-radius:12px;padding:9px 4px;
  display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10.5px;font-weight:600}
.pq .ic{width:16px;height:16px;color:var(--ocean-700)}
.pq .pill{font-size:8.5px;padding:2px 6px}
.p-note{font-style:normal;font-size:9px;color:var(--ink-3)}
.map-mini{min-height:110px;flex:none;height:110px}

/* Families */
.section-families{background:#f6efe3;max-width:none;border-radius:var(--r-xl);margin:0 26px}
.fam-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.fam-chips .chip{font-size:13px;padding:9px 16px}

/* Surfaces */
.surface-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;text-align:left;margin-top:14px}
.surface{display:flex;align-items:flex-start;gap:13px;padding:20px}
.surface strong{font-size:14.5px}
.surface small{display:block;font-size:12.5px;color:var(--ink-2);margin-top:3px;line-height:1.45}

/* Trust */
.section-trust{padding-top:40px}
.section-trust .tile-lg{margin:0 auto 18px}

/* CTA */
.section-cta{max-width:none;padding-top:20px}
.cta-panel{background:linear-gradient(135deg,var(--ocean-900),#0a3a56);
  border-radius:var(--r-xl);padding:74px 30px;color:#fff}
.eyebrow-light{color:#fbbf8f}
.h2-light{color:#fff}
.cta-panel .btn{margin-top:8px}
.cta-note{display:block;margin-top:16px;font-size:12.5px;color:rgb(255 255 255/.55)}

/* Footer */
.footer{display:flex;align-items:center;gap:28px;padding:26px 34px;border-top:1px solid var(--line);
  flex-wrap:wrap}
.footer-links{display:flex;gap:22px;font-size:13.5px;color:var(--ink-2)}
.footer small{margin-left:auto;font-size:12.5px;color:var(--ink-3)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1420px){
  /* copy column can no longer fit both CTAs side by side — wrap instead of
     spilling over the hero photo */
  .hero-ctas{flex-wrap:wrap}
}

@media (max-width:1280px){
  .hero-row{grid-template-columns:1fr 1fr;min-height:0}
  .hero-copy{grid-column:1/-1;text-align:center;padding:30px 10px 0}
  .subhead{margin-left:auto;margin-right:auto}
  .hero-ctas{justify-content:center}
  .hero-photo-wrap{grid-column:1/-1;height:340px;margin:0 -26px;align-self:auto}
  .hero-photo-frame{inset:0}
  .hero-photo{-webkit-mask-image:none;mask-image:none;object-position:center 70%}
  .hero-photo-fade{background:
    linear-gradient(90deg,var(--canvas) 0%,transparent 9%,transparent 91%,var(--canvas) 100%),
    linear-gradient(180deg,var(--canvas) 0%,transparent 12%,transparent 88%,var(--canvas) 100%)}
  .hero-row .card-ai{grid-column:1}
  .hero-row .card-itin{grid-column:2}
  .mid-row{grid-template-columns:1fr 1fr}
  .bottom-row{grid-template-columns:1fr 1fr}
  .card-features{grid-template-columns:1fr 1fr;grid-column:1/-1}
  .ask-grid{grid-template-columns:1fr 1fr}
  .ask-copy{grid-column:1/-1}
  .three-up{grid-template-columns:1fr}
  .surface-grid{grid-template-columns:1fr 1fr}
}

@media (max-width:720px){
  body{padding:0}
  .canvas{border-radius:0}
  .desk-br{display:none}
  .mobile-hide{display:none!important}
  .mobile-only{display:inline-flex}

  .nav{padding:14px 20px;gap:0}
  .nav-links,.nav-actions{display:none}
  .nav-burger{display:block}
  .brand-mark{width:34px;height:34px}
  .brand-name{font-size:21px}

  .collage{padding:0 16px 16px;display:flex;flex-direction:column;gap:14px}
  .row{display:contents}

  .hero-copy{order:1;text-align:left;padding:10px 4px 0}
  .eyebrow{margin-bottom:12px;font-size:11px}
  .headline{font-size:44px;line-height:1.08}
  .subhead{font-size:16px;margin:16px 0 22px}
  .hero-ctas{justify-content:flex-start}
  .hero-ctas .btn-ghost{display:none}
  .btn{padding:13px 24px}

  .hero-photo-wrap{order:2;position:relative;inset:auto;height:300px;margin:6px -16px 0;pointer-events:auto}
  .hero-photo{-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 14%,#000 100%);
    mask-image:linear-gradient(180deg,transparent 0,#000 14%,#000 100%);object-position:center 60%}
  .hero-photo-fade{display:none}

  .card{padding:16px}
  .card-itin{order:3;margin-top:-40px;z-index:2}
  .card-bookings{order:4}
  .card-family{order:5}
  .card-ai{order:6}
  .card-route{order:7}
  .card-photo{order:8;min-height:340px}
  .card-packing{order:9}
  .card-weather{order:10}
  .card-features{order:11;grid-template-columns:1fr;gap:16px}

  .bookings-cols{grid-template-columns:1fr}
  .pref-edit{display:none}

  .section{padding:56px 20px}
  .section-problem{margin-top:10px}
  .three-up{grid-template-columns:1fr}
  .ask-grid{grid-template-columns:1fr;gap:26px}
  .phone{max-width:320px;margin:0 auto}
  .surface-grid{grid-template-columns:1fr}
  .section-families{margin:0 12px;border-radius:var(--r-lg)}
  .footer{flex-direction:column;align-items:flex-start;gap:14px}
  .footer small{margin-left:0}
}
