/* ============================================================
   Newcastle Skip Co - core stylesheet
   Palette + type derived from the brand mark.
   ============================================================ */

:root{
  --ink:#131316;
  --ink-2:#1c1d21;
  --ink-3:#26272c;
  --red:#e01b22;
  --red-deep:#a50f16;
  --red-glow:rgba(224,27,34,.35);
  --bone:#f4f1ec;
  --bone-2:#eae5db;
  --paper:#ffffff;
  --line:#e4e0d8;
  --line-dk:#33343a;
  --steel:#6b6e76;
  --steel-2:#8b8e96;
  --ok:#1f9d55;

  --shadow-sm:0 1px 2px rgba(19,19,22,.06),0 2px 8px rgba(19,19,22,.05);
  --shadow-md:0 8px 24px rgba(19,19,22,.10),0 2px 6px rgba(19,19,22,.06);
  --shadow-lg:0 24px 60px rgba(19,19,22,.18),0 8px 20px rgba(19,19,22,.10);
  --shadow-red:0 12px 30px rgba(224,27,34,.28);

  --r-sm:10px;
  --r-md:16px;
  --r-lg:22px;
  --r-xl:30px;

  --wrap:1180px;
  --gutter:clamp(20px,5vw,48px);

  --font-display:"Archivo","Inter",system-ui,sans-serif;
  --font-util:"Inter",system-ui,-apple-system,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bone);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* --- Type --------------------------------------------------- */
h1,h2,h3,h4{margin:0;line-height:1.04;font-weight:800;font-family:var(--font-display)}
.display{
  font-family:var(--font-display);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:-.01em;
  line-height:.98;
}
/* every display-family element renders at a heavy, readable weight */
.hero h1,.page-hero h1,.section-head h2,.band h2,.step h3,.wz-step h3,.confirm h3,
.size-card .vol,.size-card .price .amt,.opt .ov,.summary .total .tv,.summary .sh h4,
.hero-meta .m b,.step .n,.can h3,.footer .quick h3,.quote .av,.price-flag .v,
.foot-brand,.section-head h2,.split h2,.wz-step h3{font-weight:800}
.eyebrow{
  font-family:var(--font-util);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:600;
  font-size:.78rem;
  color:var(--red);
  display:inline-flex;
  align-items:center;
  gap:.6em;
}
.eyebrow::before{
  content:"";
  width:26px;height:2px;background:var(--red);display:inline-block;
}
.eyebrow.on-dark{color:#ff5b60}
.lead{font-size:1.12rem;color:var(--steel);max-width:56ch}
.lead.on-dark{color:#b9bcc4}

/* --- Layout ------------------------------------------------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,120px)}
.section.tight{padding-block:clamp(48px,6vw,80px)}
.section-head{max-width:64ch;margin-bottom:clamp(32px,5vw,56px)}
.section-head h2{
  font-family:var(--font-display);text-transform:uppercase;
  font-size:clamp(2.1rem,5.4vw,3.9rem);line-height:.95;margin-top:14px;
}
.section-head .lead{margin-top:18px}
.txt-red{color:var(--red)}
.dark{background:var(--ink);color:#eef0f3}
.dark h2,.dark h3{color:#fff}
/* light cards nested inside dark sections keep dark headings (fixes white-on-white) */
.dark .card h2,.dark .card h3,.dark .card h4,
.dark .step h3,.dark .can h3,.dark .quote h3{color:var(--ink)}

/* --- Buttons ------------------------------------------------ */
.btn{
  --bg:var(--red);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-util);letter-spacing:.01em;
  font-weight:600;font-size:1rem;line-height:1.3;
  /* transparent border keeps solid + ghost + lg all the exact same height */
  padding:14px 26px;border:2px solid transparent;border-radius:var(--r-sm);
  background:var(--bg);color:var(--fg);
  box-shadow:var(--shadow-red);
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease,border-color .16s ease;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(224,27,34,.34)}
.btn:active{transform:translateY(0)}
.btn svg{width:20px;height:20px;flex:none}
.btn .arw{transition:transform .18s ease;font-size:1.05em;line-height:1}
.btn:hover .arw{transform:translateX(4px)}
.btn.ghost{
  --bg:transparent;--fg:var(--ink);box-shadow:none;border-color:var(--ink);
}
.btn.ghost:hover{background:var(--ink);color:#fff;transform:translateY(-2px);box-shadow:none}
.btn.ghost.on-dark{--fg:#fff;border-color:rgba(255,255,255,.4)}
.btn.ghost.on-dark:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn.dark{--bg:var(--ink);--fg:#fff;box-shadow:var(--shadow-md);border-color:transparent}
.btn.dark:hover{background:#000;box-shadow:var(--shadow-lg)}
.btn.lg{padding:17px 32px;font-size:1.05rem}
.btn.block{width:100%}
.btn:focus-visible{outline:3px solid #7fb6ff;outline-offset:3px}

/* --- Nav ---------------------------------------------------- */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(19,19,22,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-inner{display:flex;align-items:center;gap:24px;height:70px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand img{height:46px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
.brand .bw{display:none}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-family:var(--font-util);text-transform:uppercase;letter-spacing:.08em;
  font-weight:500;font-size:.92rem;color:#cfd2d8;
  padding:9px 14px;border-radius:8px;transition:color .15s,background .15s;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav-links a.active{color:#fff}
.nav-links a.active::after{
  content:"";display:block;height:3px;width:60%;margin:3px auto 0;
  background:var(--red);border-radius:2px;
}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{
  font-family:var(--font-util);color:#fff;font-weight:600;letter-spacing:.03em;
  display:flex;align-items:center;gap:8px;font-size:1.02rem;white-space:nowrap;
}
.nav-phone svg{fill:var(--red)}
.nav-toggle{display:none;background:none;border:none;padding:8px;color:#fff}
.nav-toggle svg{width:26px;height:26px}

/* --- Hero --------------------------------------------------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 85% -10%,rgba(224,27,34,.28),transparent 55%),
    radial-gradient(90% 70% at 0% 120%,rgba(224,27,34,.12),transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding-block:clamp(56px,8vw,96px);position:relative;z-index:1;
}
.hero h1{
  font-family:var(--font-display);text-transform:uppercase;
  font-size:clamp(3rem,8.2vw,6.2rem);line-height:.9;letter-spacing:.005em;
}
.hero h1 .stroke{
  color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.55);
}
.hero p.lead{margin:22px 0 30px;color:#c3c6cd}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-media{position:relative}
.hero-media img{
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  transform:rotate(-1.2deg);
}
.price-flag{
  position:absolute;left:-14px;bottom:-18px;
  background:var(--red);color:#fff;border-radius:var(--r-md);
  padding:14px 20px;box-shadow:var(--shadow-red);transform:rotate(-2deg);
}
.price-flag .k{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;opacity:.9}
.price-flag .v{font-family:var(--font-display);font-size:2rem;line-height:1}
.price-flag .v small{font-size:1rem;opacity:.85}

.hero-meta{
  display:flex;flex-wrap:wrap;gap:22px 34px;margin-top:34px;
  padding-top:26px;border-top:1px solid rgba(255,255,255,.12);
}
.hero-meta .m{display:flex;flex-direction:column}
.hero-meta .m b{font-family:var(--font-display);font-size:1.7rem;color:#fff;line-height:1}
.hero-meta .m span{font-size:.82rem;color:#9a9da5;font-family:var(--font-util);text-transform:uppercase;letter-spacing:.1em;margin-top:6px}

/* --- Trust strip ------------------------------------------- */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.trust-item{
  display:flex;align-items:center;gap:14px;padding:22px 26px;
  border-right:1px solid var(--line);
}
.trust-item:last-child{border-right:none}
.trust-item .ic{
  width:44px;height:44px;flex:none;border-radius:50%;
  border:2px solid var(--red);display:grid;place-items:center;color:var(--red);
}
.trust-item .ic svg{width:22px;height:22px}
.trust-item b{font-family:var(--font-util);text-transform:uppercase;font-weight:600;letter-spacing:.04em;font-size:.9rem;line-height:1.15}

/* --- Cards / grid ------------------------------------------ */
.grid{display:grid;gap:22px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.card.pad{padding:28px}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--bone-2)}

/* --- Size cards -------------------------------------------- */
.size-card{
  position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
  display:flex;flex-direction:column;
}
.size-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--red)}
.size-card .top{
  background:var(--ink);color:#fff;padding:20px 22px;display:flex;align-items:baseline;
  justify-content:space-between;gap:10px;position:relative;overflow:hidden;
}
.size-card .top::after{
  content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;
  background:radial-gradient(circle,var(--red-glow),transparent 70%);
}
.size-card .vol{font-family:var(--font-display);font-size:2.7rem;line-height:.9;position:relative}
.size-card .vol sup{font-size:1.1rem;top:-1.1em}
.size-card .tag{
  font-family:var(--font-util);text-transform:uppercase;letter-spacing:.08em;
  font-size:.7rem;background:var(--red);padding:5px 10px;border-radius:20px;position:relative;
}
.size-card .body{padding:22px;display:flex;flex-direction:column;gap:14px;flex:1}
.size-card .best{font-weight:600;color:var(--ink);font-size:1.02rem}
.size-card .dims{
  display:flex;gap:8px;flex-wrap:wrap;font-family:var(--font-util);
  text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--steel);
}
.size-card .dims span{background:var(--bone);border:1px solid var(--line);padding:5px 10px;border-radius:8px}
.size-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.size-card ul li{position:relative;padding-left:24px;font-size:.94rem;color:#40424a}
.size-card ul li::before{
  content:"";position:absolute;left:0;top:8px;width:13px;height:13px;border-radius:50%;
  background:var(--red);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/85% no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/85% no-repeat;
}
.size-card .foot{
  margin-top:auto;padding:18px 22px;border-top:1px dashed var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.size-card .price{display:flex;flex-direction:column;line-height:1}
.size-card .price .from{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--steel)}
.size-card .price .amt{font-family:var(--font-display);font-size:2.1rem;color:var(--ink)}
.size-card .price .amt small{font-size:.9rem;color:var(--steel);font-family:var(--font-body);font-weight:500}

/* --- Steps ------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;box-shadow:var(--shadow-sm)}
.step .n{
  counter-increment:step;font-family:var(--font-display);font-size:2.4rem;color:var(--red);
  line-height:1;display:flex;align-items:center;gap:12px;
}
.step .n::before{content:"0" counter(step)}
.step h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.35rem;margin:14px 0 8px}
.step p{color:var(--steel);font-size:.98rem;margin:0}

/* --- CTA band (skip-lid motif) ----------------------------- */
.band{
  background:var(--red);color:#fff;position:relative;overflow:hidden;
  clip-path:polygon(0 14px,100% 0,100% 100%,0 100%);
}
.band::after{
  content:"";position:absolute;inset:0;opacity:.16;
  background:repeating-linear-gradient(115deg,rgba(0,0,0,.4) 0 2px,transparent 2px 22px);
  pointer-events:none;
}
.band-inner{
  position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;
  gap:30px;flex-wrap:wrap;padding-block:clamp(44px,6vw,72px);
}
.band h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);line-height:.95}
.band p{margin:12px 0 0;color:rgba(255,255,255,.9);max-width:46ch}

/* --- Testimonials ------------------------------------------ */
.quote{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;
}
.quote .stars{color:var(--red);letter-spacing:3px;font-size:1.05rem}
.quote p{margin:0;font-size:1.04rem;color:#2a2c33}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.quote .av{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:1.1rem}
.quote .who b{display:block;font-size:.95rem}
.quote .who span{font-size:.82rem;color:var(--steel)}

/* --- Split feature ----------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.split .media img{border-radius:var(--r-lg);box-shadow:var(--shadow-md)}
.feat-list{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.feat-list li{display:flex;gap:14px;align-items:flex-start}
.feat-list .fi{
  flex:none;width:38px;height:38px;border-radius:11px;background:var(--red);color:#fff;
  display:grid;place-items:center;box-shadow:var(--shadow-red)
}
.feat-list .fi svg{width:20px;height:20px}
.feat-list b{display:block;font-size:1.04rem}
.feat-list span{color:var(--steel);font-size:.95rem}

/* --- Forms ------------------------------------------------- */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;color:var(--ink);font-weight:500}
.field .req{color:var(--red)}
.input,.select,.textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--paper);transition:border-color .15s,box-shadow .15s;
}
.input:focus,.select:focus,.textarea:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(224,27,34,.12);
}
.textarea{resize:vertical;min-height:120px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* --- Footer ------------------------------------------------ */
.footer{background:var(--ink);color:#c7cad1}
.footer .quick{
  background:var(--ink-2);border-radius:var(--r-xl);padding:clamp(28px,4vw,44px);
  box-shadow:var(--shadow-lg);transform:translateY(-56px);margin-bottom:-28px;
  border:1px solid rgba(255,255,255,.06);
}
.footer .quick h3{font-family:var(--font-display);text-transform:uppercase;color:#fff;font-size:clamp(1.6rem,3.4vw,2.3rem);line-height:.98}
.footer .quick .field label{color:#cfd2d8}
.footer .quick .input,.footer .quick .select,.footer .quick .textarea{
  background:var(--ink-3);border-color:rgba(255,255,255,.12);color:#fff;
}
.footer .quick .input::placeholder{color:#7f838c}
.foot-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px;padding-block:56px 40px}
.foot-brand img{height:64px;margin-bottom:16px}
.foot-brand p{color:#9a9da5;font-size:.94rem;max-width:34ch}
.foot-col h4{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;color:#fff;margin:0 0 16px}
.foot-col a,.foot-col p{display:block;color:#9a9da5;font-size:.95rem;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-block:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#7f838c;font-size:.85rem}
.foot-bottom .made{color:#7f838c}
.foot-bottom .made b{color:#b9bcc4;font-weight:600}

/* --- Page hero (interior) ---------------------------------- */
.page-hero{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 90% -20%,rgba(224,27,34,.26),transparent 55%)}
.page-hero-inner{position:relative;z-index:1;padding-block:clamp(56px,8vw,92px);max-width:70ch}
.page-hero h1{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.6rem,7vw,5rem);line-height:.92}
.page-hero p{color:#c3c6cd;font-size:1.14rem;margin-top:18px}
.crumbs{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;color:#8b8e96;margin-bottom:18px}
.crumbs a:hover{color:#fff}
.crumbs .sep{color:var(--red);margin:0 8px}

/* ============================================================
   Booking wizard
   ============================================================ */
.booking{display:grid;grid-template-columns:1fr 366px;gap:30px;align-items:start}
.wizard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden}
.wz-track{display:flex;background:var(--bone);border-bottom:1px solid var(--line);padding:6px;gap:4px;overflow-x:auto}
.wz-track .st{
  flex:1;min-width:96px;text-align:center;padding:12px 8px;border-radius:12px;
  font-family:var(--font-util);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;
  color:var(--steel);position:relative;transition:.2s;white-space:nowrap;
}
.wz-track .st .num{
  display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;
  background:var(--bone-2);color:var(--steel);font-weight:700;margin-right:7px;font-size:.8rem;
  transition:.2s;
}
.wz-track .st.active{color:var(--ink);background:var(--paper);box-shadow:var(--shadow-sm)}
.wz-track .st.active .num{background:var(--red);color:#fff}
.wz-track .st.done .num{background:var(--ink);color:#fff}
.wz-panel{padding:clamp(24px,4vw,40px);min-height:380px}
.wz-step{display:none;animation:fade .35s ease}
.wz-step.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.wz-step h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.7rem}
.wz-step .sub{color:var(--steel);margin:8px 0 24px}

/* option cards */
.opt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.opt{
  position:relative;border:1.5px solid var(--line);border-radius:var(--r-md);padding:16px;
  background:var(--paper);cursor:pointer;transition:.16s;text-align:left;display:flex;flex-direction:column;gap:6px;
}
.opt:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.opt.sel{border-color:var(--red);background:rgba(224,27,34,.045);box-shadow:0 0 0 3px rgba(224,27,34,.12)}
.opt.sel::after{
  content:"";position:absolute;top:12px;right:12px;width:20px;height:20px;border-radius:50%;background:var(--red);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/78% no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/78% no-repeat;
}
.opt .ov{font-family:var(--font-display);font-size:1.9rem;line-height:.9;color:var(--ink)}
.opt .ov sup{font-size:.85rem;top:-.9em}
.opt .ol{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;color:var(--steel)}
.opt .op{font-weight:700;color:var(--red);font-size:.95rem;margin-top:2px}
.opt .odim{font-size:.74rem;color:var(--steel)}
.opt .note{font-size:.73rem;color:var(--steel);line-height:1.3}

.toggle-row{display:flex;flex-direction:column;gap:12px}
.tgl{
  display:flex;align-items:center;gap:14px;border:1.5px solid var(--line);border-radius:var(--r-md);
  padding:16px 18px;cursor:pointer;transition:.16s;background:var(--paper);
}
.tgl:hover{border-color:var(--red)}
.tgl.on{border-color:var(--red);background:rgba(224,27,34,.045)}
.tgl .box{
  width:22px;height:22px;border-radius:6px;border:2px solid var(--line);flex:none;transition:.16s;position:relative;
}
.tgl.on .box{background:var(--red);border-color:var(--red)}
.tgl.on .box::after{content:"";position:absolute;inset:0;background:#fff;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/72% no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z' fill='black'/></svg>") center/72% no-repeat;}
.tgl .tt{flex:1}
.tgl .tt b{display:block;font-size:.98rem}
.tgl .tt span{font-size:.85rem;color:var(--steel)}
.tgl .tp{font-family:var(--font-util);font-weight:600;color:var(--red);white-space:nowrap}

.wz-nav{display:flex;justify-content:space-between;gap:12px;padding:20px clamp(24px,4vw,40px);border-top:1px solid var(--line);background:var(--bone)}
.wz-back{background:none;border:none;color:var(--steel);font-family:var(--font-util);text-transform:uppercase;letter-spacing:.06em;font-weight:500;font-size:.92rem;display:inline-flex;align-items:center;gap:8px}
.wz-back:hover{color:var(--ink)}
.wz-back[disabled]{opacity:.35;cursor:not-allowed}

/* price panel */
.summary{position:sticky;top:90px;background:var(--ink);color:#fff;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.summary .sh{padding:22px 24px 18px;border-bottom:1px solid rgba(255,255,255,.1)}
.summary .sh .el{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:#ff5b60}
.summary .sh h4{font-family:var(--font-display);text-transform:uppercase;font-size:1.5rem;color:#fff;margin-top:4px}
.summary .lines{padding:18px 24px;display:flex;flex-direction:column;gap:12px}
.sline{display:flex;justify-content:space-between;gap:14px;font-size:.94rem}
.sline .lk{color:#9a9da5}
.sline .lv{color:#fff;text-align:right;font-weight:500}
.sline.muted .lv{color:#9a9da5;font-weight:400}
.summary .total{
  padding:20px 24px;background:var(--red);display:flex;align-items:center;justify-content:space-between;
  clip-path:polygon(0 10px,100% 0,100% 100%,0 100%);
}
.summary .total .tl{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem}
.summary .total .tv{font-family:var(--font-display);font-size:2.3rem;line-height:1}
.summary .total .tv small{font-size:.9rem;font-family:var(--font-body);opacity:.85}
.summary .fineprint{padding:14px 24px 22px;font-size:.76rem;color:#8b8e96;line-height:1.4}

/* confirmation */
.confirm{text-align:center;padding:40px 20px}
.confirm .tick{width:78px;height:78px;border-radius:50%;background:var(--ok);margin:0 auto 22px;display:grid;place-items:center;box-shadow:0 12px 30px rgba(31,157,85,.35)}
.confirm .tick svg{width:40px;height:40px;fill:#fff}
.confirm h3{font-family:var(--font-display);text-transform:uppercase;font-size:2rem}
.confirm p{color:var(--steel);max-width:44ch;margin:12px auto 0}
.ref{display:inline-block;margin-top:18px;font-family:var(--font-util);letter-spacing:.1em;background:var(--bone);border:1px dashed var(--line);border-radius:10px;padding:10px 18px;color:var(--ink)}

/* info callouts */
.callout{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.can{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.can h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.3rem;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.can h3 .dot{width:12px;height:12px;border-radius:50%}
.can.yes h3 .dot{background:var(--ok)}
.can.no h3 .dot{background:var(--red)}
.can ul{list-style:none;margin:0;padding:0;columns:2;column-gap:20px}
.can ul li{padding:5px 0 5px 20px;position:relative;font-size:.94rem;break-inside:avoid}
.can.yes ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;border-radius:50%;background:var(--ok)}
.can.no ul li::before{content:"";position:absolute;left:2px;top:9px;width:11px;height:2px;background:var(--red)}

/* pill row */
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.pill{font-family:var(--font-util);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:8px 16px;color:var(--ink)}
.pill.solid{background:var(--ink);color:#fff;border-color:var(--ink)}

/* image with infographic */
.figure{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md)}

/* --- Floating call button (mobile only) -------------------- */
.call-fab{
  position:fixed;z-index:90;right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom,0px));
  display:none;align-items:center;gap:10px;
  background:var(--red);color:#fff;font-family:var(--font-util);
  font-weight:700;letter-spacing:.01em;font-size:1rem;
  padding:14px 20px 14px 15px;border-radius:50px;border:none;
  box-shadow:0 12px 28px rgba(224,27,34,.5),0 3px 10px rgba(0,0,0,.28);
  -webkit-tap-highlight-color:transparent;
}
.call-fab:active{transform:scale(.96)}
.call-fab .ph{position:relative;display:grid;place-items:center;width:26px;height:26px}
.call-fab .ph svg{width:22px;height:22px;fill:#fff;position:relative;z-index:1}
.call-fab .ph::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(255,255,255,.6);animation:fabpulse 2s ease-out infinite;
}
@keyframes fabpulse{0%{transform:scale(.7);opacity:.9}100%{transform:scale(1.5);opacity:0}}
@media (prefers-reduced-motion:reduce){.call-fab .ph::before{animation:none;display:none}}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-media img{transform:none}
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-media{max-width:520px}
  .booking{grid-template-columns:1fr}
  .summary{position:static}
  .foot-main{grid-template-columns:1fr 1fr;gap:28px}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .trust-row{grid-template-columns:1fr 1fr}
  .trust-item:nth-child(2){border-right:none}
  .trust-item{border-bottom:1px solid var(--line)}
}
@media (max-width:820px){
  .call-fab{display:inline-flex}
  a,button{-webkit-tap-highlight-color:rgba(224,27,34,.12)}
  .section{padding-block:clamp(52px,11vw,84px)}
  .hero h1{font-size:clamp(2.7rem,12vw,3.6rem)}
  .page-hero h1{font-size:clamp(2.3rem,10vw,3.4rem)}
  .btn.lg{padding:16px 26px;font-size:1rem}
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:inline-flex}
  .nav.open .nav-links{
    display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;
    background:var(--ink);padding:14px;gap:2px;border-bottom:1px solid rgba(255,255,255,.1);
  }
  .nav.open .nav-links a{padding:14px 16px}
  .split{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .g-3,.g-2{grid-template-columns:1fr}
  .callout{grid-template-columns:1fr}
  .can ul{columns:1}
  .row-2{grid-template-columns:1fr}
}
@media (max-width:560px){
  body{font-size:16px}
  .g-4{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr}
  .trust-item{border-right:none}
  .foot-main{grid-template-columns:1fr}
  .hero-meta{gap:18px 24px}
  .band-inner{flex-direction:column;align-items:flex-start}
}
