/* =====================================================================
   CABO CURATED — Cape Verde travel agency
   Design system / global stylesheet
   ---------------------------------------------------------------------
   BRAND SWAP: change the values in :root below (colors + brand font) and
   the whole site updates. Brand NAME text lives in the page HTML headers.
   ===================================================================== */

:root {
  /* --- Brand palette (swap these) --- */
  --atlantic:      #0a3a5c;   /* deep ocean blue   */
  --atlantic-deep: #06283d;   /* near-navy         */
  --teal:          #137a78;   /* lagoon teal       */
  --turquoise:     #2bb3ad;   /* shallow water     */
  --sand:          #f5ecdc;   /* warm sand         */
  --sand-deep:     #ecdcc2;
  --coral:         #e8743b;   /* sunset accent     */
  --coral-soft:    #f4a07a;
  --gold:          #e3b341;   /* flag gold star    */
  --ink:           #14202b;   /* body text         */
  --ink-soft:      #45565f;
  --line:          #e4ddd0;   /* hairlines         */
  --white:         #ffffff;
  --cream:         #fbf7ef;

  /* --- Type --- */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* --- Layout --- */
  --maxw: 1180px;
  --radius: 16px;
  --radius-lg: 24px;
  --shadow-sm: 0 2px 10px rgba(6,40,61,.06);
  --shadow:    0 12px 36px rgba(6,40,61,.12);
  --shadow-lg: 0 28px 70px rgba(6,40,61,.22);
  --ease: cubic-bezier(.16,.84,.44,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--teal); text-decoration: none; transition: color .2s var(--ease); }
a:hover { color: var(--coral); }
h1,h2,h3,h4 { font-family: var(--serif); font-weight: 600; line-height: 1.12; color: var(--atlantic-deep); letter-spacing: -.01em; }
h1 { font-size: clamp(2.4rem, 5.4vw, 4.1rem); }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.9rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.6rem); }
p { color: var(--ink-soft); }
section { position: relative; }

/* ---------- Utilities ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.narrow { max-width: 760px; }
.eyebrow {
  font-family: var(--sans); font-weight: 700; font-size: .78rem;
  letter-spacing: .18em; text-transform: uppercase; color: var(--coral);
  display: inline-block; margin-bottom: 14px;
}
.eyebrow.light { color: var(--gold); }
.lead { font-size: 1.18rem; color: var(--ink-soft); }
.center { text-align: center; }
.pad { padding: 88px 0; }
.pad-sm { padding: 56px 0; }
.mt-s{margin-top:10px}.mt{margin-top:20px}.mt-l{margin-top:38px}
.muted { color: var(--ink-soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--sans); font-weight: 600; font-size: .98rem;
  padding: 14px 26px; border-radius: 999px; border: 1.5px solid transparent;
  cursor: pointer; transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--coral); color: #fff; box-shadow: 0 8px 22px rgba(232,116,59,.32); }
.btn-primary:hover { background: #d9632c; color: #fff; transform: translateY(-2px); box-shadow: 0 14px 30px rgba(232,116,59,.4); }
.btn-dark { background: var(--atlantic-deep); color: #fff; }
.btn-dark:hover { background: var(--atlantic); color: #fff; transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--atlantic-deep); border-color: var(--atlantic-deep); }
.btn-ghost:hover { background: var(--atlantic-deep); color: #fff; }
.btn-ghost.light { color: #fff; border-color: rgba(255,255,255,.6); }
.btn-ghost.light:hover { background: #fff; color: var(--atlantic-deep); }
.btn-wa { background: #25D366; color: #062a1a; }
.btn-wa:hover { background: #1fb858; color: #062a1a; transform: translateY(-2px); }
.btn-lg { padding: 17px 34px; font-size: 1.05rem; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(251,247,239,.82); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--serif); font-weight: 600; font-size: 1.32rem; color: var(--atlantic-deep); letter-spacing: -.01em; }
.brand:hover { color: var(--atlantic-deep); }
.brand .mark {
  width: 38px; height: 38px; border-radius: 11px; flex: 0 0 auto;
  background: linear-gradient(135deg, var(--teal), var(--atlantic));
  display: grid; place-items: center; color: #fff; box-shadow: var(--shadow-sm);
}
.brand .mark svg { width: 22px; height: 22px; }
.brand .cv { color: var(--coral); }
.brand small { display:block; font-family:var(--sans); font-weight:600; font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--coral); margin-top:1px;}
.nav-links { display: flex; align-items: center; gap: 30px; list-style: none; }
.nav-links a { color: var(--ink); font-weight: 500; font-size: .98rem; }
.nav-links a:hover, .nav-links a.active { color: var(--coral); }
.nav-cta { display: flex; align-items: center; gap: 12px; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--atlantic-deep); margin: 5px 0; transition: .3s var(--ease); }

/* ---------- Hero ---------- */
.hero {
  position: relative; color: #fff; overflow: hidden;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(43,179,173,.55), transparent 60%),
    radial-gradient(90% 80% at 10% 110%, rgba(232,116,59,.45), transparent 55%),
    linear-gradient(160deg, var(--atlantic) 0%, var(--atlantic-deep) 100%);
}
.hero::after { /* subtle wave */
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:90px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 90' preserveAspectRatio='none'%3E%3Cpath fill='%23fbf7ef' d='M0,40 C240,90 480,90 720,55 C960,20 1200,20 1440,55 L1440,90 L0,90 Z'/%3E%3C/svg%3E") no-repeat center/cover;
}
.hero-inner { position: relative; z-index: 2; padding: 96px 0 130px; }
.hero h1 { color: #fff; max-width: 16ch; }
.hero .lead { color: rgba(255,255,255,.86); max-width: 52ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-stats { display: flex; gap: 38px; margin-top: 54px; flex-wrap: wrap; }
.hero-stats .stat strong { font-family: var(--serif); font-size: 2rem; color: #fff; display: block; }
.hero-stats .stat span { font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.island-tags { display:flex; gap:10px; flex-wrap:wrap; margin-top:30px;}
.island-tags span{ font-size:.8rem; font-weight:600; letter-spacing:.05em; padding:7px 15px; border-radius:999px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:#fff;}

/* page hero (interior) */
.page-hero { position: relative; color: #fff; padding: 70px 0 64px;
  background: linear-gradient(160deg, var(--atlantic) 0%, var(--atlantic-deep) 100%); }
.page-hero h1 { color:#fff; }
.page-hero .lead { color: rgba(255,255,255,.85); }
.crumbs { font-size:.85rem; color:rgba(255,255,255,.7); margin-bottom:16px;}
.crumbs a{color:rgba(255,255,255,.9);}

/* ---------- Cards / Trip grid ---------- */
.section-head { max-width: 640px; margin-bottom: 46px; }
.section-head.center { margin-left:auto; margin-right:auto; }
.grid { display: grid; gap: 26px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }

.trip-card {
  background: #fff; border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-sm); border: 1px solid var(--line);
  display: flex; flex-direction: column; transition: transform .28s var(--ease), box-shadow .28s var(--ease);
}
.trip-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.trip-card .thumb {
  height: 200px; position: relative; color:#fff;
  display:flex; align-items:flex-end; padding:18px;
}
.trip-card .thumb::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,40,61,.05),rgba(6,40,61,.55));}
.thumb .badge { position:absolute; top:16px; left:16px; z-index:2; background:rgba(255,255,255,.92); color:var(--atlantic-deep); font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:6px 12px; border-radius:999px;}
.thumb .where { position:relative; z-index:2; font-family:var(--serif); font-size:1.05rem; font-weight:600; }
/* duotone thumbs per island */
.thumb.santiago { background: linear-gradient(150deg,#1f7a5a,#0a3a5c); }
.thumb.sal { background: linear-gradient(150deg,#2bb3ad,#0a3a5c); }
.thumb.grand { background: linear-gradient(150deg,#e3b341,#137a78,#06283d); }

.trip-card .body { padding: 22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.trip-card h3 { margin-bottom: 8px; }
.trip-meta { display:flex; gap:14px; font-size:.84rem; color:var(--ink-soft); margin-bottom:14px; flex-wrap:wrap; }
.trip-meta span{display:inline-flex;align-items:center;gap:5px;}
.trip-card p.desc { font-size:.96rem; flex:1; }
.trip-foot { display:flex; align-items:center; justify-content:space-between; margin-top:18px; padding-top:18px; border-top:1px solid var(--line); }
.price .from{ font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-soft); display:block;}
.price .amt{ font-family:var(--serif); font-size:1.55rem; color:var(--atlantic-deep); font-weight:600;}
.price .amt small{ font-size:.8rem; color:var(--ink-soft); font-weight:400;}

/* ---------- Feature / why-us ---------- */
.feature { display:flex; gap:16px; }
.feature .ic { flex:0 0 auto; width:50px; height:50px; border-radius:14px; display:grid; place-items:center;
  background:var(--sand); color:var(--teal); box-shadow:var(--shadow-sm);}
.feature .ic svg{width:25px;height:25px;}
.feature h3{ font-size:1.18rem; margin-bottom:6px;}
.feature p{ font-size:.96rem;}

/* alt background blocks */
.bg-sand { background: var(--sand); }
.bg-deep { background: linear-gradient(160deg,var(--atlantic),var(--atlantic-deep)); color:#fff; }
.bg-deep h2,.bg-deep h3{color:#fff;} .bg-deep p{color:rgba(255,255,255,.82);}
.bg-white{ background:#fff;}

/* ---------- Steps ---------- */
.steps{ counter-reset: s; display:grid; gap:24px; grid-template-columns:repeat(4,1fr);}
.step{ position:relative; padding-top:8px;}
.step .n{ font-family:var(--serif); font-size:2.4rem; color:var(--coral); line-height:1; }
.step h3{ font-size:1.12rem; margin:10px 0 6px;}
.step p{ font-size:.93rem;}

/* ---------- Comparison table ---------- */
.cmp{ width:100%; border-collapse:collapse; background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); font-size:.95rem;}
.cmp th,.cmp td{ padding:15px 16px; text-align:left; border-bottom:1px solid var(--line);}
.cmp thead th{ background:var(--atlantic-deep); color:#fff; font-family:var(--sans); font-weight:600; font-size:.85rem; letter-spacing:.04em;}
.cmp tbody tr:hover{ background:var(--cream);}
.cmp td .amt{ font-family:var(--serif); color:var(--atlantic-deep); font-weight:600;}
.tick{ color:var(--teal); font-weight:700;}
.dash{ color:var(--line); }

/* ---------- Itinerary (trip detail) ---------- */
.trip-hero{ position:relative; color:#fff; padding:78px 0 70px;}
.trip-hero .price-pill{ display:inline-block; background:var(--coral); color:#fff; font-weight:700; padding:8px 18px; border-radius:999px; font-size:.95rem; margin-top:18px;}
.layout{ display:grid; grid-template-columns: 1fr 340px; gap:46px; align-items:start;}
.day{ display:flex; gap:20px; padding:24px 0; border-bottom:1px solid var(--line);}
.day:last-child{border-bottom:0;}
.day .daynum{ flex:0 0 auto; width:62px; }
.day .daynum .lbl{ font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; color:var(--coral); font-weight:700;}
.day .daynum .num{ font-family:var(--serif); font-size:2rem; color:var(--atlantic-deep); line-height:1;}
.day h3{ font-size:1.2rem; margin-bottom:6px;}
.day p{ font-size:.97rem;}
.day .tag{ display:inline-block; margin-top:9px; font-size:.76rem; font-weight:600; color:var(--teal); background:var(--sand); padding:4px 11px; border-radius:999px;}

.booking-card{ position:sticky; top:92px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:26px; }
.booking-card .amt{ font-family:var(--serif); font-size:2.2rem; color:var(--atlantic-deep); font-weight:600;}
.booking-card .per{ font-size:.85rem; color:var(--ink-soft);}
.booking-card ul{ list-style:none; padding:0; margin:18px 0; }
.booking-card li{ display:flex; gap:9px; font-size:.92rem; padding:6px 0; color:var(--ink);}
.booking-card li svg{ flex:0 0 auto; width:18px; height:18px; color:var(--teal); margin-top:3px;}
.incl-list{ list-style:none; padding:0;}
.incl-list li{ display:flex; gap:10px; padding:8px 0; font-size:.97rem; border-bottom:1px dashed var(--line);}
.incl-list li svg{flex:0 0 auto;width:19px;height:19px;color:var(--teal);margin-top:3px;}
.excl-list li svg{ color:var(--coral);}
.pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.pill{ font-size:.8rem; font-weight:600; padding:6px 13px; border-radius:999px; background:var(--sand); color:var(--atlantic-deep);}

/* ---------- Forms ---------- */
.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:34px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; font-size:.9rem; margin-bottom:7px; color:var(--atlantic-deep);}
.field input,.field select,.field textarea{
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:12px;
  font-family:var(--sans); font-size:1rem; color:var(--ink); background:var(--cream); transition:border .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:0; border-color:var(--turquoise); box-shadow:0 0 0 4px rgba(43,179,173,.16); background:#fff;}
.field textarea{ min-height:130px; resize:vertical;}
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.form-note{ font-size:.84rem; color:var(--ink-soft); margin-top:10px;}
.form-success{ display:none; background:#eafaf3; border:1px solid #b6e6d0; color:#0d6b46; padding:16px 18px; border-radius:12px; margin-bottom:18px; font-weight:500;}

/* contact tiles */
.contact-tile{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); }
.contact-tile .ic{ width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--sand);color:var(--teal);margin-bottom:14px;}
.contact-tile h3{font-size:1.1rem;margin-bottom:6px;}
.contact-tile p{font-size:.93rem;}

/* ---------- Testimonials ---------- */
.quote-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow-sm);}
.quote-card .stars{ color:var(--gold); letter-spacing:2px; margin-bottom:12px;}
.quote-card p{ font-family:var(--serif); font-size:1.12rem; color:var(--ink); font-style:italic; line-height:1.5;}
.quote-card .who{ margin-top:16px; font-size:.9rem; font-weight:600; color:var(--atlantic-deep); font-style:normal;}
.quote-card .who span{ display:block; font-weight:400; color:var(--ink-soft);}

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(135deg,var(--coral),#d9632c); color:#fff; border-radius:var(--radius-lg); padding:54px; text-align:center;}
.cta-band h2{ color:#fff; max-width:18ch; margin:0 auto;}
.cta-band p{ color:rgba(255,255,255,.92); max-width:50ch; margin:14px auto 0;}
.cta-band .hero-cta{ justify-content:center;}

/* ---------- Footer ---------- */
.site-footer{ background:var(--atlantic-deep); color:rgba(255,255,255,.75); padding:64px 0 28px; margin-top:0;}
.site-footer h4{ color:#fff; font-family:var(--sans); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:16px;}
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.footer-grid a{ color:rgba(255,255,255,.75); display:block; padding:5px 0; font-size:.95rem;}
.footer-grid a:hover{ color:var(--gold);}
.site-footer .brand{ color:#fff; margin-bottom:14px;}
.site-footer .brand small{color:var(--gold);}
.foot-bottom{ border-top:1px solid rgba(255,255,255,.14); margin-top:40px; padding-top:22px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.85rem;}

/* ---------- Floating WhatsApp ---------- */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:60; display:flex; align-items:center; gap:11px;
  background:#25D366; color:#062a1a; font-weight:700; padding:13px 19px 13px 15px; border-radius:999px;
  box-shadow:0 12px 30px rgba(37,211,102,.45); transition:transform .2s var(--ease);}
.wa-float:hover{ transform:translateY(-3px) scale(1.02); color:#062a1a;}
.wa-float svg{ width:26px; height:26px;}
.wa-float .lbl{ font-size:.95rem;}

/* ---------- Notice banner (placeholder reminder) ---------- */
.devnote{ background:var(--gold); color:#3a2a00; font-size:.86rem; text-align:center; padding:9px 16px; font-weight:600;}
.devnote a{ color:#3a2a00; text-decoration:underline;}

/* ---------- Hero flag card ---------- */
.hero-grid{ display:grid; grid-template-columns:1.08fr .92fr; gap:46px; align-items:center; }
.flag-col{ display:flex; justify-content:center; }
.flag-card{
  background:#fff; padding:15px 15px 16px; border-radius:18px; width:100%; max-width:470px;
  box-shadow:0 34px 80px rgba(6,40,61,.42); transform:rotate(-3deg); position:relative;
  animation:floaty 6.5s ease-in-out infinite;
}
.flag-card .cv-flag{ width:100%; height:auto; border-radius:9px; display:block; box-shadow:0 8px 20px rgba(0,0,0,.22); }
.flag-cap{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; margin:13px 4px 2px; }
.flag-cap b{ font-family:var(--serif); color:var(--atlantic-deep); font-size:1.04rem; }
.flag-cap span{ font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--coral); font-weight:700; white-space:nowrap; }
.flag-stamp{
  position:absolute; top:-16px; right:-16px; z-index:3; width:66px; height:66px; border-radius:14px;
  background:var(--coral); color:#fff; display:grid; place-items:center; text-align:center;
  font-family:var(--serif); font-weight:600; font-size:.74rem; line-height:1.05; letter-spacing:.04em;
  transform:rotate(7deg); box-shadow:var(--shadow);
}
@keyframes floaty{ 0%,100%{ transform:rotate(-3deg) translateY(0);} 50%{ transform:rotate(-3deg) translateY(-9px);} }
@media (prefers-reduced-motion: reduce){ .flag-card{ animation:none; } }

/* ---------- Legal pages (terms / privacy) ---------- */
.legal-doc h2 { font-size: 1.28rem; margin: 26px 0 8px; color: var(--atlantic-deep); }
.legal-doc p { font-size: 1rem; margin-bottom: 12px; color: var(--ink-soft); }
.legal-doc a { font-weight: 600; }

/* ---------- Booking: choose your stay ---------- */
.stay-list{ display:flex; flex-direction:column; gap:12px; margin:14px 0 12px; }
.stay{ border:1px solid var(--line); border-radius:14px; padding:14px 15px; background:var(--cream); }
.stay-h{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.stay-h b{ font-family:var(--serif); font-size:1.08rem; color:var(--atlantic-deep); }
.stay-h .amt{ font-family:var(--serif); font-size:1.35rem; color:var(--atlantic-deep); font-weight:600; }
.stay-sub{ font-size:.82rem; color:var(--ink-soft); margin:5px 0 4px; }
.stay-solo{ font-size:.82rem; font-weight:600; color:var(--teal); margin:0 0 12px; }

/* ---------- FAQ accordion ---------- */
.faq details{ background:#fff; border:1px solid var(--line); border-radius:14px; margin-bottom:14px; box-shadow:var(--shadow-sm); overflow:hidden; }
.faq summary{ cursor:pointer; padding:20px 22px; font-family:var(--serif); font-size:1.14rem; font-weight:600; color:var(--atlantic-deep); list-style:none; display:flex; justify-content:space-between; align-items:center; gap:18px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--sans); font-weight:400; font-size:1.6rem; line-height:1; color:var(--coral); flex:0 0 auto; }
.faq details[open] summary::after{ content:"\2013"; }
.faq details[open] summary{ border-bottom:1px solid var(--line); }
.faq .ans{ padding:16px 22px 22px; }
.faq .ans p{ font-size:1rem; color:var(--ink-soft); }
.faq .ans a{ font-weight:600; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .grid-3{ grid-template-columns:repeat(2,1fr);}
  .steps{ grid-template-columns:repeat(2,1fr);}
  .footer-grid{ grid-template-columns:1fr 1fr;}
  .layout{ grid-template-columns:1fr; }
  .booking-card{ position:static; }
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  .flag-card{ max-width:430px; }
}
@media (max-width: 720px){
  body{ font-size:16px;}
  .nav-links{ position:fixed; inset:72px 0 auto 0; background:var(--cream); flex-direction:column; gap:0; padding:12px 24px 22px; border-bottom:1px solid var(--line); box-shadow:var(--shadow); transform:translateY(-130%); transition:transform .35s var(--ease); }
  .nav-links.open{ transform:translateY(0); }
  .nav-links li{ width:100%; border-bottom:1px solid var(--line);}
  .nav-links a{ display:block; padding:15px 0;}
  .nav-cta .btn-ghost{ display:none;}
  .nav-toggle{ display:block;}
  .grid-3,.grid-2{ grid-template-columns:1fr;}
  .steps{ grid-template-columns:1fr;}
  .footer-grid{ grid-template-columns:1fr 1fr; gap:24px;}
  .field-row{ grid-template-columns:1fr;}
  .cta-band{ padding:36px 22px;}
  .pad{ padding:60px 0;}
  .hero-inner{ padding:64px 0 110px;}
  .wa-float .lbl{ display:none;}
  .flag-stamp{ display:none; }
  .flag-card{ max-width:340px; }
}
