/* =====================================================================
   TopCar — Design System tokens
   ===================================================================== */
:root{
  /* Primary (green) */
  --p-50:#F2FFC9;  --p-100:#E5FF93; --p-200:#D7FF5E; --p-300:#CAFF28;
  --p-400:#B6F100; --p-500:#8DBB00; --p-600:#759C00; --p-700:#5E7D00;
  --p-800:#465E00;

  /* Secondary (yellow / FlexiMiles accent) */
  --s-50:#FFF6D5; --s-100:#FFEEAA; --s-200:#FFE580; --s-300:#FFDC55;
  --s-400:#FFD42B; --s-500:#FFCB00; --s-600:#D5A900; --s-700:#AA8700;
  --s-800:#806500;

  /* Neutral (warm-green grays) */
  --n-50:#F8F9F6; --n-100:#F1F3ED; --n-200:#EBECE4; --n-300:#E4E6D0;
  --n-400:#DDE0D1; --n-500:#D6DAC8; --n-600:#B1B896; --n-700:#889665;
  --n-800:#5D6443;

  /* Shape neutrals */
  --black:#212529; --gray:#979797; --white:#FFFFFF;

  /* State */
  --success-500:#4BB543; --success-700:#32792D;
  --warning-500:#FFB800;
  --danger-500:#DD1717;  --danger-700:#930F0F;

  /* Spacing — 8pt grid */
  --sp-1:8px; --sp-2:16px; --sp-3:24px; --sp-4:32px;
  --sp-5:40px; --sp-6:48px; --sp-8:64px; --sp-10:80px; --sp-12:96px;

  /* Radii */
  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:20px; --r-pill:999px;

  /* Shadow */
  --shadow-sm:0 1px 2px rgba(33,37,41,.05),0 1px 1px rgba(33,37,41,.04);
  --shadow-md:0 4px 12px rgba(33,37,41,.07),0 2px 4px rgba(33,37,41,.04);
  --shadow-lg:0 14px 40px rgba(33,37,41,.10),0 4px 10px rgba(33,37,41,.04);

  /* Container */
  --container:1200px;

  /* Legacy aliases used by inline-style strings in the i18n dictionary
     (consent labels, faqMore links, schemeCap accents, etc.) */
  --gold-dark:var(--s-700);
  --gold:var(--s-500);
  --muted:var(--n-700);
  --green-dark:var(--p-700);
  --green:var(--p-500);
  --ink:var(--black);
  --line:var(--n-200);
  --bg:var(--n-50);
  --red:var(--danger-500);
}

/* =====================================================================
   Reset + base
   ===================================================================== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Barlow','Helvetica Neue',Arial,sans-serif;
  font-size:16px;line-height:1.55;color:var(--black);
  background:var(--white);-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
p{margin:0 0 var(--sp-2)}
p:last-child{margin-bottom:0}

/* Major-third scale (1.25), Barlow */
h1,h2,h3,h4,h5{margin:0;font-weight:700;line-height:1.15;letter-spacing:-0.01em;color:var(--black)}
h1{font-size:clamp(40px,5.2vw,64px);letter-spacing:-0.02em;line-height:1.05}
h2{font-size:clamp(32px,3.6vw,48px);letter-spacing:-0.015em}
h3{font-size:clamp(24px,2.4vw,31px)}
h4{font-size:25px}
h5{font-size:20px}
.eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--n-700);
}
.eyebrow.accent{color:var(--s-700)}
.lead{font-size:18px;color:var(--n-800);max-width:62ch}

/* =====================================================================
   Layout helpers
   ===================================================================== */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
section{padding:96px 0}
.section-sm{padding:64px 0}
.section-head{margin-bottom:48px;max-width:760px}
.section-head .eyebrow{margin-bottom:12px;display:block}
.section-head h2{margin-bottom:14px}

@media(max-width:780px){
  section{padding:64px 0}
  .section-head{margin-bottom:32px}
}

/* =====================================================================
   Buttons
   ===================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 28px;border:none;border-radius:var(--r-pill);
  cursor:pointer;transition:background .18s,transform .12s,box-shadow .18s;
  text-decoration:none;line-height:1;
}
.btn-primary{background:var(--p-500);color:var(--white)}
.btn-primary:hover{background:var(--p-600)}
.btn-primary:active{transform:translateY(1px)}
.btn-secondary{background:var(--s-500);color:var(--black)}
.btn-secondary:hover{background:var(--s-600);color:var(--white)}
.btn-ghost{background:transparent;color:var(--black);border:1.5px solid var(--n-500)}
.btn-ghost:hover{border-color:var(--p-500);color:var(--p-700)}
.btn-neutral{background:var(--n-700);color:var(--white)}
.btn-neutral:hover{background:var(--n-800);color:var(--white)}
.btn-neutral:active{transform:translateY(1px)}
.btn-lg{padding:18px 38px;font-size:16px}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-block{display:flex;width:100%}
.btn-primary .chk,.btn-secondary .chk{font-size:13px;opacity:.9}

/* =====================================================================
   Header
   ===================================================================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(1.4) blur(8px);
  border-bottom:1px solid var(--n-200);
}
.hdr{
  display:flex;align-items:center;justify-content:space-between;
  height:76px;gap:32px;
}

/* Brand — logo + FlexiMiles label, on one baseline */
.brand-lockup{display:inline-flex;align-items:center;gap:14px;text-decoration:none;flex-shrink:0}
.brand-lockup .logo{display:block;height:45px;width:auto;flex-shrink:0}
.brand-lockup .divider{width:1px;height:24px;background:var(--n-300);flex-shrink:0}
.fm-name{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Barlow',sans-serif;font-weight:700;font-size:17px;
  color:var(--black);letter-spacing:-0.01em;line-height:1;
}
.fm-name::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--s-500);flex-shrink:0;
}

/* Nav — items centered on the header baseline, underline on hover */
.hnav{display:flex;align-items:center;gap:30px}
.hnav a{
  display:inline-flex;align-items:center;height:40px;padding:0;
  font-size:14px;font-weight:500;color:var(--n-800);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color .15s,border-color .15s;
}
.hnav a:hover{color:var(--black);border-bottom-color:var(--p-500)}
.hnav a.active{color:var(--black);font-weight:600;border-bottom-color:var(--p-500)}

/* Right group — all items 40px tall, gap-spaced */
.hdr-right{display:flex;align-items:center;gap:14px;position:relative}
.hdr-phone{
  display:inline-flex;align-items:center;gap:8px;
  height:40px;padding:0 4px;
  font-size:14px;font-weight:600;color:var(--black);
  white-space:nowrap;transition:color .15s;
}
.hdr-phone:hover{color:var(--p-700)}
.hdr-phone svg{width:16px;height:16px;color:var(--p-600);flex-shrink:0}

.lang-picker{
  display:inline-flex;align-items:center;gap:8px;
  height:40px;padding:0 14px;border:1px solid var(--n-300);
  border-radius:var(--r-pill);background:var(--white);cursor:pointer;
  font-size:13px;font-weight:600;color:var(--n-800);
  font-family:inherit;letter-spacing:.02em;
  transition:border-color .15s,color .15s;
}
.lang-picker:hover{border-color:var(--n-600);color:var(--black)}
.lang-picker.open{border-color:var(--p-500);color:var(--black);background:var(--p-50)}
.lang-picker .globe{width:15px;height:15px;color:var(--n-700);flex-shrink:0}
.lang-picker .caret{width:10px;height:10px;color:var(--n-700);transition:transform .18s;flex-shrink:0}
.lang-picker.open .caret{transform:rotate(180deg)}

/* Match CTA button height to the other header items */
.hdr-right .btn-sm{height:40px;padding:0 20px;font-size:14px}

/* Responsive collapse */
@media(max-width:1180px){
  .hdr-phone span{display:none}
}
@media(max-width:1024px){
  .hnav{display:none}
}
@media(max-width:780px){
  .brand-lockup .divider,.fm-name{display:none}
  .hdr-phone{display:none}
}
@media(max-width:640px){
  .hdr{height:64px;gap:12px}
  .hdr-right{gap:8px}
  .lang-picker{padding:0 10px}
  .hdr-right .btn-sm{padding:0 14px}
}

/* =====================================================================
   Hero
   ===================================================================== */
.hero{
  position:relative;color:var(--white);
  background:var(--black);overflow:hidden;
}
.hero-media{
  position:absolute;inset:0;
}
.hero-media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(.95);
}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(33,37,41,.10) 0%,rgba(33,37,41,.55) 65%,rgba(33,37,41,.85) 100%),
    linear-gradient(100deg,rgba(33,37,41,.55) 0%,rgba(94,125,0,.18) 50%,rgba(33,37,41,0) 80%);
}
.hero-inner{
  position:relative;z-index:2;padding-top:128px;padding-bottom:88px;
  display:grid;grid-template-columns:1.2fr .9fr;gap:64px;align-items:end;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:9px;white-space:nowrap;
  background:var(--s-500);border:none;
  padding:9px 18px;border-radius:var(--r-pill);
  font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--black);
  box-shadow:0 6px 22px rgba(255,203,0,.38);
  margin-bottom:24px;
}
.hero-eyebrow::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--black);
}
.hero h1{color:var(--white);max-width:18ch;margin-bottom:24px}
.hero .sub{
  font-size:19px;color:rgba(255,255,255,.85);max-width:54ch;
  margin-bottom:36px;line-height:1.5;
}
.hero-cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hero-cta .btn-primary{padding:18px 32px;font-size:16px}
.hero-cta .meta{
  font-size:13px;color:rgba(255,255,255,.7);
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.hero-cta .meta li{display:flex;align-items:center;gap:6px;list-style:none}
.hero-cta .meta li::before{
  content:"";width:4px;height:4px;border-radius:50%;background:var(--s-500);
}

/* Price card floating at right of hero */
.hero-price{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(16px) saturate(1.2);
  border-radius:var(--r-xl);padding:36px;
  color:var(--white);
  position:relative;overflow:hidden;
}
.hero-price::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--s-500) 0%,var(--s-400) 100%);
}
.hp-eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--s-500);margin-bottom:20px;
}
.hp-eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--s-500);
  box-shadow:0 0 0 3px rgba(255,203,0,.22);
}
.hp-price{
  display:flex;align-items:flex-end;gap:10px;
  margin-bottom:20px;line-height:1;
}
.hp-price .from{
  font-size:13px;font-weight:600;color:rgba(255,255,255,.7);
  text-transform:uppercase;letter-spacing:.08em;
  padding-bottom:18px;
}
.hp-price .big{
  font-size:96px;font-weight:800;color:var(--white);
  letter-spacing:-0.05em;line-height:.9;
}
.hp-price .unit{
  display:flex;flex-direction:column;gap:2px;
  padding-bottom:10px;
}
.hp-price .unit span{
  font-size:15px;font-weight:600;color:rgba(255,255,255,.92);
  line-height:1.1;
}
.hp-price .unit span:first-child{color:rgba(255,255,255,.6);font-size:13px}
.hp-fixed{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--s-500);color:var(--black);
  padding:10px 16px;border-radius:var(--r-pill);
  font-size:14px;font-weight:600;
  margin-bottom:24px;
  box-shadow:0 6px 20px -8px rgba(255,203,0,.55);
}
.hp-fixed svg{width:16px;height:16px;flex-shrink:0}
.hp-fixed b{font-weight:800}
.hp-list{list-style:none;padding:0;margin:0;border-top:1px solid rgba(255,255,255,.14)}
.hp-list li{
  padding:13px 0;border-bottom:1px solid rgba(255,255,255,.10);
  font-size:14.5px;color:rgba(255,255,255,.92);
  display:flex;align-items:center;gap:11px;
}
.hp-list li:last-child{border-bottom:none}
.hp-list li svg{
  width:16px;height:16px;flex-shrink:0;color:var(--s-500);
}

@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:40px;padding-top:88px;padding-bottom:64px}
  .hero-price{order:2}
  .hp-price .big{font-size:80px}
}
@media(max-width:560px){
  .hero-price{padding:28px}
  .hp-price .big{font-size:64px}
  .hero-eyebrow{font-size:10px;padding:7px 14px}
}

/* =====================================================================
   Booking bar (sits below the hero, design-system CTA Book pattern)
   ===================================================================== */
.book-bar-wrap{
  position:relative;margin-top:-44px;z-index:5;
}
.book-bar{
  background:var(--white);
  border:1px solid var(--n-200);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);
  padding:24px 24px 20px;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr auto;gap:16px;align-items:end;
}
.bb-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.bb-field label{
  font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--n-700);
}
.bb-field .control{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border:1px solid var(--n-300);
  border-radius:var(--r-md);background:var(--white);
  transition:border-color .15s,box-shadow .15s;cursor:pointer;
}
.bb-field .control:hover{border-color:var(--n-600)}
.bb-field .control:focus-within{
  border-color:var(--p-500);
  box-shadow:0 0 0 3px rgba(141,187,0,.18);
}
.bb-field .control svg{width:18px;height:18px;color:var(--n-700);flex-shrink:0}
.bb-field .control input,.bb-field .control select{
  border:none;outline:none;background:none;
  font-family:inherit;font-size:15px;color:var(--black);font-weight:500;
  flex:1;min-width:0;width:100%;padding:0;
}
.bb-field .control select{appearance:none;-webkit-appearance:none;cursor:pointer}
.bb-field .control .time{
  border-left:1px solid var(--n-200);padding-left:10px;
  font-size:14px;color:var(--n-800);font-weight:600;
}
.bb-toggle{
  grid-column:1/-1;display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--n-800);margin-top:4px;
}
.bb-toggle input{appearance:none;-webkit-appearance:none;
  width:36px;height:20px;background:var(--n-300);
  border-radius:var(--r-pill);position:relative;cursor:pointer;
  transition:background .18s;
}
.bb-toggle input::after{
  content:"";position:absolute;top:2px;left:2px;
  width:16px;height:16px;background:var(--white);border-radius:50%;
  transition:left .18s;
}
.bb-toggle input:checked{background:var(--p-500)}
.bb-toggle input:checked::after{left:18px}

.book-bar .btn{align-self:stretch;min-width:160px}

@media(max-width:980px){
  .book-bar{grid-template-columns:1fr 1fr}
  .book-bar .btn{grid-column:1/-1}
  .bb-toggle{grid-column:1/-1}
}
@media(max-width:560px){
  .book-bar{grid-template-columns:1fr;padding:18px}
  .book-bar-wrap{margin-top:-30px}
}

/* =====================================================================
   What is FlexiMiles
   ===================================================================== */
.what-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;
}
.what-prose p{font-size:17px;color:var(--n-800);margin-bottom:18px}
.what-prose p:first-of-type{font-size:19px;color:var(--black)}
.what-prose b{color:var(--black);font-weight:600}
.what-prose .kicker{
  display:inline-block;margin-top:12px;
  font-size:14px;font-weight:600;color:var(--p-700);
  border-bottom:1.5px solid var(--p-400);padding-bottom:2px;
}

.compare-strip{
  background:var(--n-50);border:1px solid var(--n-200);
  border-radius:var(--r-xl);overflow:hidden;
}
.compare-strip .row{
  display:grid;grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--n-200);
}
.compare-strip .row:last-child{border-bottom:none}
.compare-strip .row > div{padding:18px 22px;font-size:15px;color:var(--n-800)}
.compare-strip .row.head > div{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:700;color:var(--white);padding:14px 22px;
}
.compare-strip .row.head > div:first-child{background:var(--n-700)}
.compare-strip .row.head > div:last-child{background:var(--black);color:var(--s-500);font-weight:800;font-size:14px;letter-spacing:.16em;text-shadow:0 0 14px rgba(255,203,0,.45);box-shadow:inset 0 -3px 0 var(--s-500)}
.compare-strip .row > div:last-child{
  background:rgba(141,187,0,.07);color:var(--black);font-weight:500;
  border-left:1px solid var(--n-200);
}

@media(max-width:880px){
  .what-grid{grid-template-columns:1fr;gap:40px}
}

/* =====================================================================
   The 80 km flow
   ===================================================================== */
.km-flow{
  background:var(--n-50);padding:96px 0;border-top:1px solid var(--n-200);
  border-bottom:1px solid var(--n-200);
}
.km-stage{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);padding:48px 40px;
  box-shadow:var(--shadow-sm);
}
.km-route{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr;
  align-items:center;gap:24px;margin-bottom:40px;
}
.km-node{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}
.km-node .icon{
  width:64px;height:64px;border-radius:18px;
  background:var(--p-50);color:var(--p-700);
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--p-100);
}
.km-node.alt .icon{background:var(--s-50);color:var(--s-700);border-color:var(--s-100)}
.km-node .icon svg{width:28px;height:28px}
.km-node .name{font-weight:600;font-size:16px;color:var(--black)}
.km-node .meta{font-size:13px;color:var(--n-700);max-width:18ch;line-height:1.4}
.km-arrow{display:flex;flex-direction:column;align-items:center;gap:6px}
.km-arrow .line{
  width:80px;height:2px;background:var(--n-400);position:relative;
}
.km-arrow .line::after{
  content:"";position:absolute;right:-5px;top:-5px;
  width:0;height:0;border-style:solid;border-width:6px 0 6px 9px;
  border-color:transparent transparent transparent var(--n-600);
}
.km-arrow .km-km{
  font-size:13px;font-weight:700;color:var(--p-700);letter-spacing:.06em;
}
.km-arrow .km-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--n-700)}

.km-summary{
  display:grid;grid-template-columns:auto 1fr;gap:40px;
  border-top:1px dashed var(--n-300);padding-top:32px;align-items:center;
}
.km-bigprice{
  background:var(--p-500);color:var(--white);
  border-radius:var(--r-xl);padding:28px 32px;text-align:center;
  min-width:200px;
  box-shadow:0 12px 24px -10px rgba(94,125,0,.5);
}
.km-bigprice .from{font-size:13px;opacity:.9;font-weight:600}
.km-bigprice .amount{font-size:56px;font-weight:700;line-height:1;letter-spacing:-0.02em}
.km-bigprice .week{font-size:13px;opacity:.9;font-weight:600}
.km-feat{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:14px 32px}
.km-feat li{
  display:flex;align-items:flex-start;gap:12px;font-size:14.5px;color:var(--n-800);
}
.km-feat li b{color:var(--black);font-weight:600}
.km-feat .ic{
  flex-shrink:0;width:28px;height:28px;border-radius:8px;
  background:var(--p-50);color:var(--p-700);
  display:flex;align-items:center;justify-content:center;
}
.km-feat .ic svg{width:15px;height:15px}
.km-cap{
  margin-top:24px;font-size:13.5px;color:var(--n-700);
  text-align:center;max-width:760px;margin-left:auto;margin-right:auto;
}
.km-cap b{color:var(--s-700)}

@media(max-width:880px){
  .km-route{grid-template-columns:1fr;gap:10px}
  .km-arrow{
    width:80px;height:80px;justify-self:center;justify-content:center;
    transform:rotate(90deg);margin:0;
  }
  .km-summary{grid-template-columns:1fr;gap:24px;text-align:center}
  .km-feat{grid-template-columns:1fr;text-align:left}
  .km-stage{padding:32px 24px}
}

/* =====================================================================
   How it works — 3 steps
   ===================================================================== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step-card{
  position:relative;background:var(--white);
  border:1px solid var(--n-200);border-radius:var(--r-xl);
  padding:36px 32px;
}
.step-card .num{
  width:44px;height:44px;border-radius:50%;
  background:var(--black);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:18px;margin-bottom:24px;
  letter-spacing:-0.02em;
}
.step-card:nth-child(2) .num{background:var(--p-600)}
.step-card:nth-child(3) .num{background:var(--s-500);color:var(--black)}
.step-card h3{font-size:21px;margin-bottom:10px}
.step-card p{font-size:15px;color:var(--n-800);margin:0}

@media(max-width:880px){.steps{grid-template-columns:1fr}}

/* =====================================================================
   What's included / Optional
   ===================================================================== */
.incl-section{background:var(--n-50);border-top:1px solid var(--n-200);border-bottom:1px solid var(--n-200)}
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.incl-card{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);overflow:hidden;
}
.incl-card .top{padding:24px 28px;border-bottom:1px solid var(--n-200);display:flex;align-items:center;gap:14px}
.incl-card .top .ic{
  width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.incl-card.yes .top .ic{background:var(--p-50);color:var(--p-700)}
.incl-card.opt .top .ic{background:var(--s-50);color:var(--s-700)}
.incl-card .top h3{font-size:19px;margin:0}
.incl-card .top .ic svg{width:20px;height:20px}
.incl-card ul{list-style:none;padding:0;margin:0}
.incl-card li{
  display:flex;justify-content:space-between;gap:16px;
  padding:14px 28px;border-bottom:1px solid var(--n-100);
  font-size:15px;color:var(--n-800);
}
.incl-card li:last-child{border-bottom:none}
.incl-card li .v{font-weight:600;color:var(--black);white-space:nowrap}
.incl-card.yes li .v{color:var(--p-700)}
.incl-card.opt li .v{color:var(--s-700)}

@media(max-width:780px){.incl-grid{grid-template-columns:1fr}}

/* =====================================================================
   Pricing
   ===================================================================== */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.price-card{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;
}
.price-card .head{
  padding:28px 32px;color:var(--white);
  background:linear-gradient(135deg,var(--p-500) 0%,var(--p-600) 100%);
}
.price-card.b .head{background:linear-gradient(135deg,var(--p-700) 0%,var(--p-800) 100%)}
.price-card .head h3{color:var(--white);margin:0 0 6px;font-size:24px}
.price-card .head .desc{font-size:14px;opacity:.88}
.price-card .body{padding:24px 32px 32px;flex:1}
.price-card .ptile{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:16px 0;border-bottom:1px dashed var(--n-300);font-size:15px;
}
.price-card .ptile:last-of-type{border-bottom:none}
.price-card .ptile .term{color:var(--n-800)}
.price-card .ptile .v{font-weight:600;color:var(--black)}
.price-card .ptile .v .big{font-size:22px;font-weight:700;color:var(--p-700)}
.price-card .ptile .v .sc{font-size:13px;color:var(--n-700);font-weight:500;margin-left:6px}
.price-card .km-line{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--n-50);border-radius:var(--r-md);
  padding:14px 18px;margin-top:18px;font-size:14px;color:var(--n-800);
}
.price-card .km-line b{color:var(--black);font-weight:600}
.price-note{
  margin-top:24px;font-size:13.5px;color:var(--n-700);
  text-align:center;max-width:760px;margin-left:auto;margin-right:auto;
}

@media(max-width:780px){.price-grid{grid-template-columns:1fr}}

/* =====================================================================
   Booking form
   ===================================================================== */
.book-section{
  background:linear-gradient(180deg,var(--n-50) 0%,var(--white) 100%);
  border-top:1px solid var(--n-200);
}
.book-card{
  max-width:760px;margin:0 auto;
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);box-shadow:var(--shadow-md);
  overflow:hidden;
}
.book-card .head{padding:32px 40px 24px;border-bottom:1px solid var(--n-100)}
.book-card .head h3{font-size:24px;margin:0 0 6px}
.book-card .head p{font-size:14.5px;color:var(--n-700);margin:0}
.book-card .body{padding:32px 40px 32px}

.f-group{margin-bottom:24px}
.f-label{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:13px;font-weight:600;color:var(--n-800);margin-bottom:8px;
}
.f-label .req{color:var(--danger-500);margin-left:3px}
.f-label .help{font-size:12px;color:var(--n-700);font-weight:500}
.f-input,.f-select,.f-textarea{
  width:100%;padding:13px 16px;
  border:1px solid var(--n-400);border-radius:var(--r-md);
  font-family:inherit;font-size:15px;color:var(--black);
  background:var(--white);
  transition:border-color .15s,box-shadow .15s;
}
.f-input:hover,.f-select:hover,.f-textarea:hover{border-color:var(--n-600)}
.f-input:focus,.f-select:focus,.f-textarea:focus{
  outline:none;border-color:var(--p-500);
  box-shadow:0 0 0 3px rgba(141,187,0,.18);
}
.f-input::placeholder{color:var(--n-600)}
.f-input[readonly]{background:var(--n-50);color:var(--n-800);font-weight:600;cursor:default}
.f-textarea{resize:vertical;min-height:80px}
.f-select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23889665' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer;
}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.f-help{font-size:12px;color:var(--n-700);margin-top:6px;display:block}
.f-fixed{
  display:flex;align-items:center;gap:10px;
  background:var(--p-50);border:1px solid var(--p-100);
  border-radius:var(--r-md);padding:12px 14px;font-size:13.5px;color:var(--p-800);margin-bottom:24px;
}
.f-fixed svg{width:18px;height:18px;color:var(--p-700);flex-shrink:0}

.f-divider{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--s-700);margin:32px 0 16px;display:flex;align-items:center;gap:12px;
}
.f-divider::after{content:"";flex:1;height:1px;background:var(--n-200)}

/* Super Cover radio cards */
.sc-list{display:flex;flex-direction:column;gap:10px}
.sc-opt{position:relative;display:block;cursor:pointer}
.sc-opt input{position:absolute;opacity:0;width:0;height:0}
.sc-box{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px 18px;border:1.5px solid var(--n-300);
  border-radius:var(--r-md);background:var(--white);transition:.15s;
}
.sc-box::before{
  content:"";width:18px;height:18px;border-radius:50%;
  border:1.5px solid var(--n-500);flex-shrink:0;margin-top:2px;transition:.15s;
}
.sc-opt:hover .sc-box{border-color:var(--n-600)}
.sc-opt input:checked + .sc-box{border-color:var(--p-500);background:var(--p-50)}
.sc-opt input:checked + .sc-box::before{
  border-color:var(--p-500);background:var(--p-500);
  box-shadow:inset 0 0 0 3px var(--white);
}
.sc-main{flex:1;min-width:0;font-size:14px;color:var(--n-800);line-height:1.5}
.sc-main b{color:var(--black);font-weight:600;display:block;margin-bottom:4px}
.sc-badge{
  display:inline-block;background:var(--s-500);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 8px;border-radius:var(--r-sm);margin-left:6px;vertical-align:middle;
}

/* Chip checkboxes */
.chip-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{position:relative;display:inline-block}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip-box{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1.5px solid var(--n-300);
  border-radius:var(--r-pill);background:var(--white);
  font-size:13.5px;font-weight:600;color:var(--n-800);
  cursor:pointer;transition:.15s;
}
.chip input:checked + .chip-box{
  background:var(--p-50);border-color:var(--p-500);color:var(--p-700);
}
.chip-box::before{
  content:"";width:14px;height:14px;border:1.5px solid var(--n-500);
  border-radius:4px;flex-shrink:0;transition:.15s;
}
.chip input:checked + .chip-box::before{
  background:var(--p-500);border-color:var(--p-500);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 8 7 12 13 4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:10px;
}

/* Consent rows */
.consent{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--n-800);line-height:1.5;margin-bottom:12px}
.consent input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:20px;height:20px;border:1.5px solid var(--n-500);
  border-radius:5px;background:var(--white);margin:0;cursor:pointer;
  position:relative;flex-shrink:0;transition:.15s;
}
.consent input[type="checkbox"]:checked{background:var(--p-500);border-color:var(--p-500)}
.consent input[type="checkbox"]:checked::after{
  content:"";position:absolute;left:5px;top:1px;
  width:6px;height:11px;border:solid var(--white);
  border-width:0 2.5px 2.5px 0;transform:rotate(45deg);
}
.consent a{color:var(--s-700);font-weight:600;border-bottom:1px solid currentColor}

/* Price box (estimate) */
.f-price-box{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  padding:20px 22px;background:var(--p-50);border:1px solid var(--p-100);
  border-radius:var(--r-md);margin-top:8px;margin-bottom:20px;
}
.f-price-box .lbl{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--p-700);
}
.f-price-box .amt{font-size:36px;font-weight:700;color:var(--p-700);line-height:1;letter-spacing:-0.02em}
.f-price-box .est{font-size:12.5px;color:var(--n-700);max-width:300px;text-align:right}
.submit-note{font-size:12.5px;color:var(--n-700);text-align:center;margin-top:14px}

@media(max-width:640px){
  .book-card .head,.book-card .body{padding-left:24px;padding-right:24px}
  .f-row{grid-template-columns:1fr}
  .f-price-box .est{text-align:left}
}

/* =====================================================================
   Why TopCar
   ===================================================================== */
.why-section{background:var(--white)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.why-card{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-lg);padding:28px;transition:border-color .2s,box-shadow .2s;
}
.why-card:hover{border-color:var(--p-400);box-shadow:var(--shadow-md)}
.why-card .ic{
  width:44px;height:44px;border-radius:11px;
  background:var(--p-50);color:var(--p-700);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.why-card .ic svg{width:22px;height:22px}
.why-card h3{font-size:18px;margin-bottom:8px}
.why-card p{font-size:14.5px;color:var(--n-800);margin:0}

.aena-trust{
  background:var(--black);color:var(--white);
  border-radius:var(--r-xl);padding:32px 40px;
  display:flex;align-items:center;gap:24px;
}
.aena-trust .seal{
  flex-shrink:0;width:64px;height:64px;border-radius:50%;
  background:var(--s-500);color:var(--black);
  display:flex;align-items:center;justify-content:center;
}
.aena-trust .seal svg{width:32px;height:32px}
.aena-trust h4{font-size:17px;color:var(--white);margin:0 0 4px}
.aena-trust p{font-size:14px;color:rgba(255,255,255,.75);margin:0}
.aena-trust .num{
  flex-shrink:0;text-align:center;border-left:1px solid rgba(255,255,255,.18);padding-left:24px;
}
.aena-trust .num .n{font-size:36px;font-weight:700;color:var(--s-500);line-height:1;letter-spacing:-0.02em}
.aena-trust .num .l{font-size:12px;color:rgba(255,255,255,.7);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-top:4px}

@media(max-width:880px){
  .why-grid{grid-template-columns:1fr 1fr}
  .aena-trust{flex-direction:column;text-align:center;align-items:center;padding:28px 24px}
  .aena-trust .num{border-left:none;border-top:1px solid rgba(255,255,255,.18);padding-left:0;padding-top:18px;width:100%}
}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}

/* =====================================================================
   Comparison table
   ===================================================================== */
.cmp-section{background:var(--n-50);border-top:1px solid var(--n-200);border-bottom:1px solid var(--n-200)}
.cmp-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);overflow:hidden;font-size:15px;
}
.cmp-table th,.cmp-table td{
  padding:18px 24px;text-align:left;border-bottom:1px solid var(--n-200);vertical-align:top;
}
.cmp-table tr:last-child th,.cmp-table tr:last-child td{border-bottom:none}
.cmp-table thead th{
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--n-100);color:var(--n-800);font-weight:700;padding:16px 24px;
}
.cmp-table thead th:nth-child(2){background:var(--n-700);color:var(--white)}
.cmp-table thead th:nth-child(3){background:var(--black);color:var(--s-500);font-weight:800;font-size:15px;letter-spacing:.12em;text-shadow:0 0 14px rgba(255,203,0,.45);box-shadow:inset 0 -3px 0 var(--s-500)}
.cmp-table tbody th{
  font-weight:600;color:var(--black);width:24%;background:var(--n-50);
  font-size:14px;
}
.cmp-table tbody td:last-child{background:rgba(141,187,0,.06);color:var(--black);font-weight:500}
.cmp-table tbody td{color:var(--n-800)}

@media(max-width:780px){
  .cmp-table,.cmp-table tbody,.cmp-table tr,.cmp-table th,.cmp-table td{display:block;width:auto}
  .cmp-table{background:transparent;border:none;border-radius:0;overflow:visible}
  .cmp-table thead{display:none}
  /* each criterion becomes a self-contained card */
  .cmp-table tbody tr{
    background:var(--white);border:1px solid var(--n-200);
    border-radius:var(--r-lg);box-shadow:var(--shadow-sm);
    overflow:hidden;margin-bottom:14px;
  }
  .cmp-table tbody tr:last-child{margin-bottom:0}
  .cmp-table tbody th{
    width:auto;background:var(--n-100);color:var(--black);
    font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
    padding:13px 18px;border-bottom:1px solid var(--n-200);
  }
  .cmp-table tbody td{padding:13px 18px;border:none;font-size:14.5px}
  .cmp-table tbody td:first-of-type{border-bottom:1px solid var(--n-200)}
  .cmp-table tbody td:last-child{background:rgba(141,187,0,.07)}
  .cmp-table tbody td::before{
    content:attr(data-col);display:block;
    font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;
    color:var(--n-700);font-weight:700;margin-bottom:3px;
  }
  .cmp-table tbody td:last-child::before{color:var(--p-700)}
}

/* =====================================================================
   Reviews proof
   ===================================================================== */
.reviews{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rv-card{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-lg);padding:24px;text-align:center;
}
.rv-card .pf{font-size:13px;font-weight:600;color:var(--n-700);letter-spacing:.04em;margin-bottom:10px}
.rv-card .score{font-size:36px;font-weight:700;color:var(--black);line-height:1;letter-spacing:-0.02em}
.rv-card .score small{font-size:16px;color:var(--n-700);font-weight:600}
.rv-card .stars{
  color:var(--s-500);font-size:14px;letter-spacing:2px;margin-top:8px;
}
.rv-card .ct{font-size:12px;color:var(--n-700);margin-top:6px}

@media(max-width:780px){.reviews{grid-template-columns:1fr 1fr}}

/* =====================================================================
   FAQ accordion
   ===================================================================== */
.faq-list{max-width:880px;margin:0 auto}
.faq-item{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-lg);margin-bottom:12px;overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-weight:600;font-size:17px;color:var(--black);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";width:28px;height:28px;flex-shrink:0;border-radius:50%;
  background-color:var(--n-100);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%23889665' stroke-width='1.5' stroke-linecap='round'%3E%3Cline x1='6' y1='2' x2='6' y2='10'/%3E%3Cline x1='2' y1='6' x2='10' y2='6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:12px 12px;
  transition:background-color .2s,background-image .2s;
}
.faq-item[open] summary::after{
  background-color:var(--p-500);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%23ffffff' stroke-width='1.5' stroke-linecap='round'%3E%3Cline x1='2' y1='6' x2='10' y2='6'/%3E%3C/svg%3E");
}
.faq-item .body{padding:0 28px 22px;color:var(--n-800);font-size:15px;line-height:1.65}
.faq-item .body a{color:var(--p-700);font-weight:600;border-bottom:1px solid var(--p-200)}
.faq-more{
  margin-top:24px;text-align:center;font-size:14px;color:var(--n-700);
}
.faq-more a{color:var(--p-700);font-weight:600;border-bottom:1px solid var(--p-200);margin:0 4px}
.fee-row{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px dashed var(--n-300);font-size:15px}
.fee-row:last-child{border-bottom:none}
.fee-row b{color:var(--black);font-weight:600;white-space:nowrap}

/* =====================================================================
   Footer
   ===================================================================== */
.site-footer{background:var(--black);color:rgba(255,255,255,.78);padding:80px 0 32px;font-size:14px}

/* =====================================================================
   Language switcher — dropdown
   ===================================================================== */
.hdr-right{position:relative}
.lang-picker{display:flex}
.lang-picker.open{border-color:var(--p-500);color:var(--black)}
.langs{
  position:absolute;top:calc(100% + 8px);right:0;z-index:100;
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-md);box-shadow:var(--shadow-lg);
  padding:6px;display:none;flex-direction:column;gap:2px;min-width:160px;
}
.langs.open{display:flex}
.langs button{
  width:100%;text-align:left;display:flex;align-items:center;gap:12px;
  background:none;border:none;
  padding:9px 14px;font-size:14px;font-weight:500;
  color:var(--n-800);font-family:inherit;
  border-radius:var(--r-sm);cursor:pointer;
  text-transform:none;letter-spacing:0;
  transition:.12s;
}
.langs button::before{
  content:attr(data-l);
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--n-700);min-width:22px;
}
.langs button:hover{background:var(--n-50);color:var(--black)}
.langs button.on{background:var(--p-50);color:var(--p-700);font-weight:600}
.langs button.on::before{color:var(--p-700)}

/* =====================================================================
   Form (2-step) — based on original FlexiMiles structure
   ===================================================================== */
.book-card .form-head{
  padding:32px 40px 0;display:flex;align-items:flex-start;gap:16px;
}
.book-card .form-head .fh-ic{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:var(--p-50);color:var(--p-700);
  display:flex;align-items:center;justify-content:center;
}
.book-card .form-head .fh-ic svg{width:22px;height:22px}
.book-card .form-head h3{margin:0 0 4px;font-size:22px}
.book-card .form-head p{margin:0;font-size:14.5px;color:var(--n-700)}
.book-card .form-body{padding:0 40px 36px}

/* Stepper */
.fsteps{
  display:flex;align-items:center;gap:12px;
  padding:24px 0 8px;color:var(--n-700);flex-wrap:wrap;
}
.fstep-dot{
  width:26px;height:26px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
  background:var(--n-200);color:var(--n-700);
  transition:.2s;flex-shrink:0;
}
.fstep-dot.on{background:var(--p-500);color:var(--white)}
.fstep-dot.done{background:var(--p-100);color:var(--p-700)}
.fstep-bar{
  flex:1;min-width:24px;height:3px;border-radius:2px;
  background:var(--n-200);position:relative;overflow:hidden;
}
.fstep-bar::after{
  content:"";position:absolute;inset:0;width:var(--p,0%);
  background:var(--p-500);transition:width .3s;
}
.fstep[hidden]{display:none}

/* Form sections */
.form-sec{padding:28px 0 4px}
.form-sec:first-of-type{padding-top:16px}
.form-sec .fs-h{
  display:flex;align-items:center;gap:12px;
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--s-700);margin:0 0 18px;
}
.form-sec .fs-h::before{
  content:"";width:22px;height:2px;background:var(--s-500);border-radius:2px;flex-shrink:0;
}
.fs-h-row{flex-wrap:wrap;row-gap:10px}
.fs-h-row>span{overflow-wrap:anywhere}

.form-confirm{
  margin:24px -40px 0;padding:28px 40px 16px;
  background:var(--n-50);border-top:1px solid var(--n-200);
}

.fixed-info{
  display:flex;align-items:center;gap:10px;
  background:var(--p-50);border:1px solid var(--p-100);
  border-radius:var(--r-md);padding:12px 14px;font-size:13.5px;color:var(--p-800);
  margin-bottom:20px;
}
.fixed-info svg{width:18px;height:18px;color:var(--p-700);flex-shrink:0}
.fixed-info b{font-weight:700}

/* Field groups */
.fld{margin-bottom:18px;position:relative}
.fld:last-child{margin-bottom:0}
.fld>label{
  display:block;font-size:13px;font-weight:600;color:var(--n-800);
  margin-bottom:8px;letter-spacing:.01em;
}
.fld .req{color:var(--danger-500);margin-left:3px}
.fld .opt-tag{color:var(--n-700);font-weight:500;font-size:12px;margin-left:6px}
.fld input,.fld select,.fld textarea{
  width:100%;padding:13px 16px;
  border:1px solid var(--n-400);border-radius:var(--r-md);
  font-family:inherit;font-size:15px;color:var(--black);background:var(--white);
  transition:border-color .15s,box-shadow .15s;
}
.fld input:hover,.fld select:hover,.fld textarea:hover{border-color:var(--n-600)}
.fld input:focus,.fld select:focus,.fld textarea:focus{
  outline:none;border-color:var(--p-500);
  box-shadow:0 0 0 3px rgba(141,187,0,.18);
}
.fld input::placeholder{color:var(--n-600)}
.fld textarea{resize:vertical;min-height:80px}
.fld select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23889665' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.fld small{display:block;color:var(--n-700);font-size:12px;margin-top:6px}
.dt-row{display:flex;gap:var(--sp-1)}
.dt-row .f-input{flex:1 1 58%;min-width:0}
.dt-row .f-select,.dt-row .f-timepicker{flex:1 1 42%;min-width:0}
@media(max-width:560px){.dt-row{flex-direction:column}}

/* Custom time picker */
.f-timepicker{
  position:relative;cursor:pointer;user-select:none;
  width:100%;padding:13px 40px 13px 16px;
  border:1px solid var(--n-400);border-radius:var(--r-md);
  font-family:inherit;font-size:15px;color:var(--black);background:var(--white);
  transition:border-color .15s,box-shadow .15s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23889665' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  box-sizing:border-box;
}
.f-timepicker:hover{border-color:var(--n-600)}
.f-timepicker:focus{outline:none;border-color:var(--p-500);box-shadow:0 0 0 3px rgba(141,187,0,.18)}
.f-tp-val{display:block;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.f-tp-val.placeholder{color:var(--n-600)}
.f-tp-list{
  position:absolute;top:calc(100% + 4px);left:0;right:0;
  max-height:208px;overflow-y:auto;
  background:var(--white);border:1px solid var(--n-400);border-radius:var(--r-md);
  box-shadow:0 6px 20px rgba(0,0,0,.12);
  z-index:300;list-style:none;margin:0;padding:4px 0;
  display:none;
}
.f-timepicker[aria-expanded="true"] .f-tp-list{display:block}
.f-tp-list li{
  padding:9px 16px;font-size:15px;cursor:pointer;
  transition:background .08s;
}
.f-tp-list li.active{font-weight:700;color:var(--p-700)}
.f-tp-list li.kfocus{background:var(--p-50)}
.fld.invalid .f-timepicker{border-color:var(--danger-500);background-color:#fdf4f4}
.err{
  display:none;color:var(--danger-500);
  font-size:12.5px;font-weight:600;margin-top:6px;
}
.fld.invalid input,.fld.invalid select,.fld.invalid textarea{
  border-color:var(--danger-500);background:#fdf4f4;
}
.fld.invalid .err{display:block}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Alertbox (out-of-hours) */
.alertbox{
  display:none;
  align-items:center;gap:10px;
  background:var(--s-50);border:1px solid var(--s-200);
  border-left:4px solid var(--s-500);
  border-radius:var(--r-md);padding:12px 16px;font-size:13.5px;color:var(--s-700);
  margin:14px 0 6px;font-weight:500;
}
.alertbox.show{display:flex}

/* Super Cover radio cards (form) */
.scopts{display:flex;flex-direction:column;gap:10px}
.scopt{position:relative;display:block;cursor:pointer}
.scopt input{position:absolute;opacity:0;width:0;height:0}
.scopt-box{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;border:1.5px solid var(--n-300);
  border-radius:var(--r-md);background:var(--white);transition:.15s;
}
.scopt-box::before{
  content:"";width:18px;height:18px;border-radius:50%;
  border:1.5px solid var(--n-500);flex-shrink:0;margin-top:2px;transition:.15s;
}
.scopt:hover .scopt-box{border-color:var(--n-600)}
.scopt input:checked + .scopt-box{border-color:var(--p-500);background:var(--p-50)}
.scopt input:checked + .scopt-box::before{
  border-color:var(--p-500);background:var(--p-500);
  box-shadow:inset 0 0 0 3px var(--white);
}
.scopt-main{flex:1;min-width:0;font-size:14px;color:var(--n-800);line-height:1.5}
.scopt-badge{
  display:inline-block;background:var(--s-500);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 8px;border-radius:var(--r-sm);margin-left:6px;vertical-align:middle;
}
.sc-acc{margin-top:10px}

/* Chips (extras) */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips label{
  display:inline-flex;align-items:center;gap:9px;
  padding:10px 16px;border:1.5px solid var(--n-300);
  border-radius:var(--r-pill);background:var(--white);
  font-size:13.5px;font-weight:600;color:var(--n-800);
  cursor:pointer;transition:.15s;user-select:none;
}
.chips label:hover{border-color:var(--n-600)}
.chips input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.chips .cbx{
  width:16px;height:16px;border:1.5px solid var(--n-500);
  border-radius:4px;flex-shrink:0;transition:.15s;
}
.chips input:checked ~ .cbx{
  background:var(--p-500);border-color:var(--p-500);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 8 7 12 13 4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:10px;
}
.chips label:has(input:checked){
  background:var(--p-50);border-color:var(--p-500);color:var(--p-700);
}

/* Step navigation buttons */
.fstep-nav{display:flex;justify-content:flex-end;padding:14px 0 0}
.fstep-nav .btn{min-width:200px}

/* Selection summary (step 2) */
.sum-trip{
  background:var(--p-50);border:1px solid var(--p-100);
  border-radius:var(--r-md);padding:14px 18px;margin-bottom:14px;font-size:14px;
}
.sum-trip .sum-row{display:flex;justify-content:space-between;gap:16px;padding:5px 0}
.sum-trip .sum-row span{color:var(--n-700)}
.sum-trip .sum-row b{color:var(--black);font-weight:600;text-align:right;overflow-wrap:anywhere}

.sum-edit{
  margin-left:auto;display:inline-flex;align-items:center;gap:7px;
  background:var(--s-50);border:1.5px solid var(--s-500);color:var(--s-700);
  font-family:inherit;font-size:13.5px;font-weight:700;cursor:pointer;
  padding:8px 16px;border-radius:var(--r-pill);
  transition:.15s;
}
.sum-edit::before{
  content:"";width:14px;height:14px;flex-shrink:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23AA8700' stroke-width='2.3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.12 2.12 0 0 1 3 3L7 19l-4 1 1-4z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.sum-edit:hover{background:var(--s-100);border-color:var(--s-700)}

.sum-lines{font-size:14px;margin-bottom:8px}
.sum-lines .sum-row{
  display:flex;justify-content:space-between;gap:16px;
  padding:10px 0;border-bottom:1px dashed var(--n-300);
}
.sum-lines .sum-row:last-child{border-bottom:none}
.sl-l{color:var(--black)}
.sl-q{display:block;color:var(--n-700);font-size:12px;margin-top:2px}
.sl-a{font-weight:700;color:var(--black);white-space:nowrap}
.sum-lines .sum-row.free .sl-a{color:var(--p-700)}

.sum-note{font-size:12.5px;color:var(--n-700);line-height:1.55;margin-top:10px}

/* Estimated total box */
.price-box{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  padding:18px 22px;background:var(--p-50);border:1px solid var(--p-100);
  border-radius:var(--r-md);margin:14px 0 6px;
}
.price-box .lbl{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--p-700);
}
.price-box .amt{
  font-size:32px;font-weight:800;color:var(--p-700);line-height:1;letter-spacing:-0.02em;
}

/* Consent checkboxes */
.chk{
  display:flex;align-items:flex-start;gap:13px;
  font-size:14px;color:var(--n-800);line-height:1.55;
  padding:6px 0 14px;border-bottom:1px dashed var(--n-200);
}
.chk:last-of-type{border-bottom:none}
.chk input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:22px;height:22px;border:1.5px solid var(--n-500);
  border-radius:5px;background:var(--white);cursor:pointer;
  position:relative;flex-shrink:0;margin:0;transition:.15s;
}
.chk input[type="checkbox"]:checked{background:var(--p-500);border-color:var(--p-500)}
.chk input[type="checkbox"]:checked::after{
  content:"";position:absolute;left:6px;top:2px;
  width:6px;height:11px;border:solid var(--white);
  border-width:0 2.5px 2.5px 0;transform:rotate(45deg);
}
.chk label{cursor:pointer}
.chk.invalid{
  border:1px solid var(--danger-500);background:#fdf4f4;
  border-radius:8px;padding:12px;margin:2px 0;
}
.chk.invalid input[type="checkbox"]{border-color:var(--danger-500)}

/* Honeypot (anti-spam) */
.hp-field{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* Submit note */
.submit-note{
  text-align:center;font-size:12.5px;color:var(--n-700);
  margin:12px 0 0;font-weight:500;
}

/* Reviews proof */
.proof{
  margin-top:48px;background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);padding:32px;
}
.reviews-lead{
  text-align:center;color:var(--n-700);
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:22px;
}
.reviews{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px;
}
.rv{
  display:flex;flex-direction:column;align-items:center;min-width:150px;
  background:var(--n-50);border:1px solid var(--n-200);
  border-radius:var(--r-lg);padding:18px 22px;
}
.rv .pf{font-size:12px;color:var(--n-700);font-weight:600;margin-bottom:8px;letter-spacing:.02em}
.rv .sc{font-size:24px;font-weight:700;color:var(--black);line-height:1;letter-spacing:-0.02em}
.rv .sc small{font-size:13px;color:var(--n-700);font-weight:600}
.rv .stars{color:var(--s-500);font-size:13px;letter-spacing:2px;margin-top:6px}
.rv .cnt{font-size:11px;color:var(--n-700);margin-top:4px}

/* Thank-you overlay */
.ty{
  position:fixed;inset:0;background:rgba(33,37,41,.75);z-index:200;
  display:none;align-items:flex-start;justify-content:center;
  padding:30px 18px;overflow-y:auto;
}
.ty.show{display:flex}
.ty-card{
  background:var(--white);border-radius:var(--r-xl);
  max-width:680px;width:100%;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.ty-head{
  background:var(--p-500);color:var(--white);padding:30px 36px;
}
.ty-head .ic{
  font-size:38px;line-height:1;
  width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.ty-head h2{color:var(--white);margin:0 0 6px;font-size:28px}
.ty-head p{font-size:14.5px;margin:0;color:rgba(255,255,255,.92)}
.ty-body{padding:28px 36px 32px}
.ty-body h3{font-size:17px;color:var(--p-700);margin:20px 0 12px}
.ty-body ul{margin:0 0 0 18px;padding:0;font-size:14.5px;color:var(--black)}
.ty-body li{margin-bottom:7px;line-height:1.5}
.ty-summary{background:var(--n-50);border-radius:var(--r-md);padding:16px 20px;font-size:14px}
.ty-summary .sum-row{display:flex;justify-content:space-between;gap:16px;padding:5px 0}
.ty-summary .sum-row span{color:var(--n-700)}
.ty-summary .sum-row b{color:var(--black);font-weight:600;text-align:right}
.ty-summary .sl-l{color:var(--black)}
.ty-summary .sl-q{display:block;color:var(--n-700);font-size:12px;margin-top:1px}
.ty-summary .sl-a{font-weight:700;color:var(--black)}
.ty-summary .ty-tot{
  display:flex;justify-content:space-between;gap:16px;
  margin-top:10px;padding-top:10px;
  border-top:1px solid var(--n-300);
  font-size:16px;font-weight:800;color:var(--p-700);
}
.ty-close{width:100%;margin-top:22px;justify-content:center}

@media(max-width:640px){
  .book-card .form-head{padding:24px 22px 0;gap:12px}
  .book-card .form-head h3{font-size:19px}
  .book-card .form-body{padding:0 22px 28px}
  .form-confirm{margin:22px -22px 0;padding:24px 22px 14px}
  .grid2{grid-template-columns:1fr}
  .fstep-nav .btn{width:100%;min-width:0}
  .price-box{flex-direction:column;align-items:flex-start;gap:6px}
  .price-box .amt{font-size:28px}
  .rv{min-width:42%}
  .ty-head,.ty-body{padding-left:22px;padding-right:22px}
}

/* Out-of-hours alert (in booking form) */
.ooh-alert{
  display:flex;align-items:center;gap:10px;
  background:var(--s-50);border:1px solid var(--s-200);
  border-left:4px solid var(--s-500);
  border-radius:var(--r-md);padding:12px 16px;font-size:13.5px;color:var(--s-700);
  margin:14px 0 6px;font-weight:500;
}
.ooh-alert svg{width:18px;height:18px;color:var(--s-700);flex-shrink:0}

/* "What Super Cover includes" accordion under the radio in form */
.f-acc{
  margin-top:12px;background:var(--n-50);
  border:1px solid var(--n-200);border-radius:var(--r-md);overflow:hidden;
}
.f-acc summary{
  list-style:none;cursor:pointer;
  padding:12px 16px;font-size:13.5px;font-weight:600;color:var(--p-700);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.f-acc summary::-webkit-details-marker{display:none}
.f-acc summary::after{content:"+";font-size:18px;color:var(--n-700);font-weight:400}
.f-acc[open] summary::after{content:"−";color:var(--p-700)}
.f-acc-body{padding:0 16px 14px;font-size:13.5px;color:var(--n-800);line-height:1.6}

/* Super Cover, explained — dedicated section */
.sc-section{background:var(--white);border-top:1px solid var(--n-200);border-bottom:1px solid var(--n-200)}
.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.sc-card{
  background:var(--white);border:1px solid var(--n-200);
  border-radius:var(--r-xl);padding:32px;
}
.sc-card.sc-save{
  background:linear-gradient(180deg,var(--s-50) 0%,var(--white) 100%);
  border-color:var(--s-200);
}
.sc-card-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.sc-card-head .ic{
  width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:var(--p-50);color:var(--p-700);
}
.sc-card-head .ic.alt{background:var(--s-100);color:var(--s-700)}
.sc-card-head .ic svg{width:22px;height:22px}
.sc-card-head h3{margin:0;font-size:20px}
.sc-card p{margin:0;font-size:15px;color:var(--n-800);line-height:1.6}
.sc-card .sc-old{
  font-size:15px;color:var(--n-700);text-decoration:line-through;margin-bottom:8px;
}
.sc-card .sc-new{
  font-size:21px;font-weight:700;color:var(--p-700);margin-bottom:14px;line-height:1.3;letter-spacing:-0.01em;
}
.sc-card .sc-fine{font-size:13px;color:var(--n-700);margin-top:6px}

@media(max-width:780px){.sc-grid{grid-template-columns:1fr}}
@media(max-width:560px){.sc-card{padding:24px}}

.cta-row{display:flex;justify-content:center;margin-top:20px}
@media(max-width:560px){.cta-row .btn{width:100%;justify-content:center}}

/* Footer social + trust badges */
.f-social{display:flex;gap:10px;margin:14px 0 0}
.f-social .f-social-a{
  width:34px;height:34px;border-radius:50%;display:flex;
  align-items:center;justify-content:center;padding:0;
  border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.78);
  transition:border-color .15s,color .15s;
}
.f-social .f-social-a:hover{border-color:var(--p-400);color:var(--p-400)}
.f-social .f-social-a svg{width:16px;height:16px}

.f-trust{display:flex;gap:8px;flex-wrap:wrap;margin:32px 0 22px}
.f-trust-badge{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.85);font-size:12px;font-weight:600;
  padding:6px 12px;border-radius:var(--r-sm);letter-spacing:.02em;
}

.f-disclaim{
  margin-top:14px;font-size:11px;color:rgba(255,255,255,.42);
  border-top:none;padding-top:0;line-height:1.6;
}
.f-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.f-col h4{
  color:var(--white);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  margin:0 0 16px;font-weight:700;
}
.f-col a{display:block;padding:5px 0;color:rgba(255,255,255,.72);transition:color .15s;font-size:14px}
.f-col a:hover{color:var(--s-500)}
.f-brand-logo{display:inline-block;margin-bottom:20px}
.f-brand-logo img{display:block;height:34px;width:auto}
.f-brand p{color:rgba(255,255,255,.65);font-size:14px;line-height:1.6;margin-bottom:18px;max-width:38ch}
.f-brand .badges{display:flex;gap:8px;flex-wrap:wrap}
.f-brand .badge2{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-sm);padding:6px 10px;font-size:12px;font-weight:600;color:var(--white);
}
.f-contact b{color:var(--white);font-weight:600}
.f-aena{
  background:rgba(141,187,0,.10);border:1px solid rgba(141,187,0,.25);
  border-radius:var(--r-md);padding:14px 16px;font-size:13px;line-height:1.55;
  color:rgba(255,255,255,.82);margin-top:18px;
}
.f-aena b{color:var(--p-400)}
.f-legal{
  border-top:1px solid rgba(255,255,255,.10);padding-top:24px;
  font-size:12px;color:rgba(255,255,255,.55);line-height:1.7;
}
.f-legal a{color:var(--s-500);font-weight:500}

@media(max-width:880px){.f-cols{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.f-cols{grid-template-columns:1fr}}

/* =====================================================================
   Cookie consent banner + preferences modal
   ===================================================================== */
.ck[hidden],.ckm[hidden]{display:none!important}
.ck{
  position:fixed;left:24px;bottom:24px;right:auto;z-index:9000;
  max-width:520px;width:calc(100% - 48px);
  animation:ckIn .25s ease-out;
}
.ck-card{
  background:var(--white);
  border:1px solid var(--n-300);
  border-top:3px solid var(--gold-dark);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  padding:20px 22px 18px;
}
.ck-title{font-size:18px;margin:0 0 8px;color:var(--ink)}
.ck-body{font-size:14px;line-height:1.55;color:var(--n-800);margin:0 0 14px}
.ck-policy{color:var(--gold-dark);font-weight:600;text-decoration:underline}
.ck-policy:hover{color:var(--s-800)}
.ck-btns{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.ck-btn{
  font-family:inherit;font-size:14px;font-weight:600;
  padding:10px 16px;border-radius:var(--r-md);
  cursor:pointer;border:1px solid transparent;
  line-height:1;min-height:40px;
  transition:background-color .15s ease,border-color .15s ease,color .15s ease;
}
.ck-btn--ghost{
  background:var(--white);color:var(--ink);
  border-color:var(--n-400);
}
.ck-btn--ghost:hover{background:var(--n-50);border-color:var(--n-600)}
.ck-btn--primary{
  background:var(--gold-dark);color:var(--white);
  border-color:var(--gold-dark);
}
.ck-btn--primary:hover{background:var(--s-800);border-color:var(--s-800)}

@keyframes ckIn{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}

@media(max-width:640px){
  .ck{
    left:0;right:0;bottom:0;width:100%;max-width:none;
  }
  .ck-card{
    border-radius:0;border-left:none;border-right:none;border-bottom:none;
    padding:16px 18px;
  }
  .ck-btns{justify-content:stretch}
  .ck-btn{flex:1 1 100%}
}

/* ---- preferences modal ---- */
.ckm{
  position:fixed;inset:0;z-index:9100;
  display:flex;align-items:center;justify-content:center;
  padding:16px;
}
.ckm-overlay{
  position:absolute;inset:0;background:rgba(33,37,41,.55);
  animation:ckmFade .2s ease-out;
}
.ckm-card{
  position:relative;background:var(--white);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  width:100%;max-width:560px;
  max-height:calc(100vh - 32px);overflow:auto;
  padding:24px;
  animation:ckmIn .2s ease-out;
}
.ckm-title{font-size:22px;margin:0 0 16px;color:var(--ink)}
.ckm-rows{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}
.ckm-row{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px;border:1px solid var(--n-200);border-radius:var(--r-md);
  background:var(--n-50);
}
label.ckm-row{cursor:pointer}
.ckm-row:has(.ckm-sw-input:checked){
  background:rgba(255,203,0,.08);border-color:var(--s-400);
}
.ckm-r-text{flex:1 1 auto;min-width:0}
.ckm-r-name{font-weight:700;font-size:15px;color:var(--ink);margin-bottom:2px}
.ckm-r-desc{font-size:13px;line-height:1.5;color:var(--n-800)}
.ckm-r-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.ckm-r-meta{font-size:11px;font-weight:600;color:var(--n-700);text-transform:uppercase;letter-spacing:.04em}
.ckm-sw{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.ckm-sw-input{
  position:absolute;inset:0;opacity:0;margin:0;cursor:pointer;
}
.ckm-sw-track{
  position:absolute;inset:0;background:var(--n-400);
  border-radius:999px;transition:background-color .15s ease;
}
.ckm-sw-thumb{
  position:absolute;top:2px;left:2px;width:18px;height:18px;
  background:var(--white);border-radius:50%;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
  transition:transform .15s ease;
}
.ckm-sw-input:checked + .ckm-sw-track{background:var(--gold-dark)}
.ckm-sw-input:checked + .ckm-sw-track .ckm-sw-thumb,
.ckm-sw-track--on .ckm-sw-thumb{transform:translateX(18px)}
.ckm-sw-input:focus-visible + .ckm-sw-track{outline:2px solid var(--gold-dark);outline-offset:2px}
.ckm-sw--locked .ckm-sw-track{background:var(--n-600);opacity:.7}

.ckm-btns{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
@media(max-width:480px){
  .ckm-card{padding:18px}
  .ckm-btns{justify-content:stretch}
  .ckm-btns .ck-btn{flex:1 1 100%}
}

@keyframes ckmFade{from{opacity:0}to{opacity:1}}
@keyframes ckmIn{from{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}

@media(prefers-reduced-motion:reduce){
  .ck,.ckm-overlay,.ckm-card{animation:none}
  .ckm-sw-track,.ckm-sw-thumb{transition:none}
}
