/* ============================================================
   Hire Cars Crete — Shared Design System
   All pages link this file. Variables, components, layout.
   ============================================================ */

:root {
  --paper:#ffffff; --paper-2:#fafaf7; --paper-3:#f4f3ee;
  --ink:#0a0a0a; --ink-2:#1f1f1f; --ink-3:#3a3a3a; --muted:#595959;
  --rule:#e5e3dc; --rule-soft:#efedea;
  --brand:#ffd100; --brand-dark:#e8bd00;
  --flag-red:#c8102e; --flag-red-dark:#9e0a23;
  --trust:#16a34a; --trust-dark:#15803d;
  --t:0.15s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Manrope',-apple-system,sans-serif;color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.05;letter-spacing:-0.015em;font-variation-settings:"opsz" 144;}
img{display:block;max-width:100%;}
a{color:inherit;}
button{font-family:inherit;cursor:pointer;}
.container{max-width:1240px;margin:0 auto;padding:0 24px;}

/* SKIP LINK */
.skip-link{position:absolute;top:-40px;left:8px;background:var(--brand);color:var(--ink);padding:8px 16px;font-weight:700;z-index:999;transition:top .2s;text-decoration:none;}
.skip-link:focus{top:8px;}

/* UTIL BAR */
.util-bar{background:linear-gradient(to right,#0c0c14,#111118,#0c0c14);color:#e8e6dd;font-size:12.5px;padding:9px 0;letter-spacing:.02em;border-bottom:1px solid rgba(255,209,0,0.15);}
.util-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.util-bar a{color:#e8e6dd;text-decoration:none;transition:color var(--t);}
.util-bar a:hover{color:var(--brand);}
.util-bar strong{color:var(--brand);}
.langs{display:flex;gap:2px;align-items:center;font-family:'JetBrains Mono',monospace;font-size:11.5px;}
.langs a{padding:3px 9px;font-weight:600;text-transform:uppercase;text-decoration:none;border-radius:1px;}
.langs a.active{background:var(--brand);color:var(--ink);}
.util-right{display:flex;gap:18px;align-items:center;flex-wrap:wrap;}
.pulse-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--trust);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.6);}70%{box-shadow:0 0 0 8px rgba(22,163,74,0);}100%{box-shadow:0 0 0 0 rgba(22,163,74,0);}}

/* HEADER */
.site-header{background:var(--paper);padding:14px 0;position:sticky;top:0;z-index:200;box-shadow:0 4px 0 0 var(--brand),0 6px 0 0 var(--flag-red),0 8px 0 0 var(--ink);}
.header-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;}
.logo{font-family:'Fraunces',serif;font-weight:700;color:var(--ink);text-decoration:none;display:inline-flex;align-items:center;gap:13px;}
.logo-mark{display:inline-flex;width:46px;height:46px;flex-shrink:0;align-items:center;justify-content:center;background:transparent;border:none;}
.logo-mark::after{content:none;}
.logo-mark svg{display:block;}
.logo-words{display:flex;flex-direction:column;gap:0;}
.logo-name{font-family:'Fraunces',serif;font-size:20px;font-weight:700;line-height:1;letter-spacing:.03em;color:var(--ink);text-transform:uppercase;padding:6px 0 5px;border-top:3px solid var(--brand);border-bottom:1px solid var(--ink);}
.logo-est{font-family:'JetBrains Mono',monospace;font-size:7.5px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;padding-top:4px;}
/* car card placeholder */
.car-no-photo{background:linear-gradient(160deg,#f5f2eb,#ede8dd);display:flex;align-items:center;justify-content:center;}
.car-silhouette{position:absolute;width:64%;color:#0a0a0a;opacity:0.09;top:50%;left:50%;transform:translate(-50%,-44%);pointer-events:none;}

/* NAV */
.site-nav ul{display:flex;gap:4px;list-style:none;align-items:center;}
.site-nav a{color:var(--ink-2);text-decoration:none;font-size:12.5px;font-weight:600;transition:color var(--t),background var(--t);padding:8px 10px;display:block;white-space:nowrap;border-radius:1px;}
.site-nav a:hover,.site-nav a.current{color:var(--ink);background:var(--paper-3);}
.nav-cta{background:var(--flag-red)!important;color:#fff!important;padding:10px 14px!important;font-weight:700!important;display:inline-flex!important;align-items:center;gap:5px;min-height:44px;transition:background var(--t)!important;}
.nav-cta:hover{background:var(--flag-red-dark)!important;}

/* DROPDOWN */
.has-dropdown{position:relative;}
.has-dropdown > a::after{content:' ▾';font-size:10px;opacity:.6;}
.dropdown{display:none;position:absolute;top:100%;left:0;margin-top:8px;background:var(--paper);border:2px solid var(--ink);box-shadow:6px 6px 0 var(--brand);min-width:240px;z-index:300;}
.dropdown a{padding:10px 16px;font-size:12px;border-bottom:1px solid var(--rule-soft);display:block;color:var(--ink-2);}
.dropdown a:last-child{border-bottom:none;}
.dropdown a:hover{background:var(--paper-3);color:var(--ink);}
.dropdown .drop-head{background:var(--ink);color:var(--brand);font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.1em;padding:7px 16px;font-weight:700;}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{display:block;}
/* transparent bridge fills the 8px gap so hover isn't lost while moving cursor toward the dropdown */
.has-dropdown:hover::after,.has-dropdown:focus-within::after{content:'';position:absolute;top:100%;left:-4px;right:-4px;height:12px;}
.hamburger{display:none;background:none;border:2px solid var(--ink);padding:6px 10px;font-size:18px;min-width:44px;min-height:44px;align-items:center;justify-content:center;cursor:pointer;}

/* BREADCRUMB */
.breadcrumb{background:var(--paper-3);border-bottom:1px solid var(--rule);padding:12px 0;}
.breadcrumb-inner{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.05em;}
.breadcrumb a{color:var(--muted);text-decoration:none;}
.breadcrumb a:hover{color:var(--ink);}
.breadcrumb-sep{opacity:.4;}

/* PAGE HERO (inner pages) */
.page-hero{background:var(--ink);color:#fff;padding:72px 0 80px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(to right,var(--ink) 33%,var(--flag-red) 33%,var(--flag-red) 66%,var(--brand) 66%);}
.page-hero-eyebrow{font-family:'JetBrains Mono',monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.15em;color:var(--brand);margin-bottom:10px;font-weight:700;}
.page-hero h1{font-size:clamp(32px,4.5vw,56px);color:#fff;line-height:1.0;margin-bottom:20px;}
.page-hero h1 em{font-style:italic;color:var(--brand);}
.page-hero-sub{font-size:15.5px;color:rgba(255,255,255,.8);line-height:1.7;max-width:640px;}

/* SECTION UTILITIES */
.section-eyebrow{font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.15em;font-size:10px;font-weight:700;display:inline-block;background:var(--brand);padding:4px 10px;margin-bottom:13px;color:var(--ink);}
.section-title{font-size:clamp(26px,3.8vw,46px);margin-bottom:13px;font-weight:600;letter-spacing:-.02em;line-height:1.06;}
.section-title em{font-style:italic;font-weight:500;}
.section-lede{font-size:15.5px;color:var(--ink-3);max-width:620px;margin-bottom:42px;line-height:1.65;}

/* HIGHLIGHT */
.highlight{background:var(--brand);padding:0 4px;color:var(--ink);font-weight:600;}

/* CAR CARD */
.car-card{background:var(--paper);border:1px solid var(--rule);border-radius:1px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;}
.car-card:hover{transform:translateY(-3px);box-shadow:0 12px 0 -4px var(--brand);border-color:var(--ink);}
.car-img{aspect-ratio:16/10;background:var(--paper-3) center/cover no-repeat;position:relative;}
.class-tag{position:absolute;top:10px;left:10px;background:var(--ink);color:var(--brand);padding:4px 9px;font-family:'JetBrains Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;}
.badge{position:absolute;top:10px;right:10px;padding:4px 9px;font-family:'JetBrains Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;}
.badge-pop{background:var(--flag-red);color:#fff;}
.badge-val{background:var(--trust);color:#fff;}
.car-body{padding:18px;}
.car-name{font-family:'Fraunces',serif;font-size:21px;font-weight:700;color:var(--ink);margin-bottom:9px;line-height:1.1;}
.car-specs{display:flex;gap:4px;font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--muted);margin-bottom:14px;flex-wrap:wrap;text-transform:uppercase;letter-spacing:.05em;}
.car-specs span{background:var(--paper-3);padding:3px 7px;border:1px solid var(--rule);}
.car-foot{display:flex;justify-content:space-between;align-items:flex-end;padding-top:13px;border-top:1px solid var(--rule);}
.price-from{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;}
.price-num{font-family:'Fraunces',serif;font-size:27px;color:var(--ink);font-weight:700;line-height:1;font-variant-numeric:tabular-nums;}
.price-per{font-size:11.5px;color:var(--muted);margin-left:2px;}
.car-cta{display:inline-flex;align-items:center;padding:9px 13px;background:var(--brand);color:var(--ink);text-decoration:none;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--ink);transition:transform .1s,box-shadow .15s;min-height:44px;}
.car-cta:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink);}

/* LOCATION CARD */
.loc-card{background:var(--paper);padding:22px;border-bottom:2px solid var(--ink);border-right:2px solid var(--ink);transition:background var(--t);}
.loc-card:hover{background:var(--brand);}
.loc-card.featured{background:var(--ink);color:#fff;}
.loc-card.featured h3{color:#fff;}
.loc-card.featured .addr{color:rgba(255,255,255,.75);}
.loc-card.featured:hover{background:var(--ink-2);}
.loc-tag{font-family:'JetBrains Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;background:var(--brand);color:var(--ink);padding:3px 7px;margin-bottom:10px;font-weight:700;display:inline-block;}
.loc-card h3{font-family:'Fraunces',serif;font-size:19px;margin-bottom:10px;font-weight:700;}
.loc-card .addr{font-size:13px;color:var(--ink-3);line-height:1.65;margin-bottom:10px;}
.loc-card .phone{font-family:'JetBrains Mono',monospace;font-size:11.5px;font-weight:600;text-decoration:none;color:inherit;}

/* FAQ */
.faq-item{border-top:2px solid var(--ink);overflow:hidden;}
.faq-item:last-child{border-bottom:2px solid var(--ink);}
.faq-q{padding:19px 0;font-family:'Fraunces',serif;font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:16.5px;list-style:none;line-height:1.3;gap:13px;min-height:44px;}
.faq-q::-webkit-details-marker{display:none;}
.faq-q::after{content:'+';font-family:'Manrope',sans-serif;font-size:20px;background:var(--brand);color:var(--ink);font-weight:700;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s;flex-shrink:0;}
details[open] .faq-q::after{transform:rotate(45deg);}
.faq-a{padding:0 0 18px;color:var(--ink-3);font-size:14px;line-height:1.7;max-width:92%;}
.faq-a strong{color:var(--ink);}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:var(--brand);color:var(--ink);border:2px solid var(--ink);font-family:'Manrope',sans-serif;font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;text-decoration:none;cursor:pointer;transition:background var(--t),transform .1s,box-shadow .1s;min-height:52px;}
.btn-primary:hover{background:var(--brand-dark);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink);}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:transparent;color:var(--ink);border:2px solid var(--ink);font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;text-decoration:none;cursor:pointer;transition:background var(--t);min-height:52px;}
.btn-secondary:hover{background:var(--paper-3);}

/* TRUST STRIP */
.trust-strip{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:18px 0;}
.trust-strip-inner{display:flex;gap:32px;align-items:center;flex-wrap:wrap;justify-content:center;}
.trust-badge{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--trust-dark);}

/* BOOKING WIDGET (compact, for inner pages) */
.mini-booking{background:var(--paper);border:2px solid var(--ink);box-shadow:8px 8px 0 var(--brand);padding:0;}
.mini-booking-head{background:var(--ink);color:#fff;padding:14px 20px;display:flex;justify-content:space-between;align-items:center;}
.mini-booking-head h3{font-size:17px;color:#fff;font-weight:600;}
.mini-booking-head .meta{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--brand);text-transform:uppercase;letter-spacing:.05em;font-weight:700;}
.mini-booking-body{padding:16px 20px 0;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:11px;}
.form-field{display:flex;flex-direction:column;gap:4px;}
.form-field label{font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);}
.form-field select,.form-field input{padding:10px 12px;border:1.5px solid var(--rule);border-radius:1px;font-family:'Manrope',sans-serif;font-size:13.5px;background:var(--paper-3);color:var(--ink);transition:border-color var(--t),box-shadow var(--t);font-weight:500;min-height:44px;}
.form-field select:focus,.form-field input:focus{outline:none;border-color:var(--ink);background:var(--paper);box-shadow:0 0 0 3px rgba(255,209,0,.5);}
.cta-btn{width:100%;padding:15px;background:var(--brand);color:var(--ink);border:2px solid var(--ink);border-radius:1px;font-family:'Manrope',sans-serif;font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:background var(--t),transform .1s,box-shadow .1s;margin-top:13px;margin-bottom:0;display:flex;align-items:center;justify-content:center;gap:8px;min-height:50px;}
.cta-btn:hover{background:var(--brand-dark);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink);}
.mini-booking-foot{padding:10px 20px;border-top:1px solid var(--rule);margin-top:13px;font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace;}

/* FOOTER */
.site-foot{background:var(--ink);color:#e8e6dd;padding:60px 0 26px;}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.foot-brand p{font-size:13px;color:rgba(255,255,255,.82);line-height:1.7;margin:13px 0 7px;}
.foot-eot{font-family:'JetBrains Mono',monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--brand);font-weight:700;}
.foot-contacts{font-family:'JetBrains Mono',monospace;font-size:11.5px;line-height:2;margin-top:16px;}
.foot-contacts a{color:#fff;text-decoration:none;}
.foot-contacts a:hover{color:var(--brand);}
.site-foot h4{color:var(--brand);font-size:10.5px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:15px;}
.site-foot ul{list-style:none;}
.site-foot li{margin-bottom:8px;font-size:13px;}
.site-foot a{color:rgba(255,255,255,.88);text-decoration:none;transition:color var(--t);}
.site-foot a:hover{color:var(--brand);}
.foot-bottom{border-top:1px solid #2a2a2a;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:11.5px;opacity:.75;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.05em;}
.legal-required{color:var(--flag-red)!important;font-weight:700;opacity:1!important;}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:80px;right:20px;background:#25D366;color:#fff;padding:11px 15px;border-radius:1px;font-weight:700;font-size:12.5px;text-decoration:none;box-shadow:0 6px 20px rgba(37,211,102,.4);z-index:150;display:flex;align-items:center;gap:7px;transition:transform .2s;}
.wa-float:hover{transform:translateY(-2px);}

/* MOBILE CTA BAR */
.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--ink);z-index:300;padding:10px 16px;gap:10px;align-items:center;box-shadow:0 -4px 20px rgba(0,0,0,.3);border-top:3px solid var(--brand);}
.mobile-cta-bar a{display:flex;align-items:center;justify-content:center;font-weight:800;text-decoration:none;gap:6px;border-radius:1px;min-height:48px;font-size:13px;text-transform:uppercase;letter-spacing:.06em;}
.mobile-cta-book{flex:2;background:var(--brand);color:var(--ink);}
.mobile-cta-call{flex:1;background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .util-right span:first-child{display:none;}
  .site-nav{display:none;position:fixed;inset:0;background:var(--paper);z-index:250;padding:72px 24px 24px;flex-direction:column;overflow-y:auto;}
  .site-nav.open{display:flex;}
  .site-nav ul{flex-direction:column;gap:0;width:100%;}
  .site-nav li{border-bottom:1px solid var(--rule);width:100%;}
  .site-nav a{padding:15px 0;font-size:17px;display:block;}
  .nav-cta{text-align:center;margin-top:14px;}
  .dropdown{position:static;border:none;box-shadow:none;display:none;background:var(--paper-3);}
  .has-dropdown.open .dropdown{display:block;}
  .dropdown a{padding:10px 16px;font-size:14px;}
  .hamburger{display:inline-flex;}
  .logo-est{display:none;}
  .page-hero{padding:48px 0 56px;}
  .form-row{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;gap:28px;}
  .mobile-cta-bar{display:flex;}
  .wa-float{bottom:76px;right:14px;padding:10px 13px;font-size:12px;}
}
@media(max-width:480px){
  .container{padding:0 16px;}
}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;}

/* ============================================================
   v2 UPGRADE — new components & overrides (2026-05)
   ============================================================ */

/* ── HERO OVERRIDES ──────────────────────────────────────── */
.hero{min-height:680px;}
.hero-overlay{background:rgba(0,0,0,0.45);}
.hero-grid{align-items:end;padding-bottom:80px;}
.hero-text h1{font-size:clamp(2.8rem,7vw,6rem);}
.hero-bg picture{display:block;width:100%;height:100%;}
.hero-bg picture img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}

/* ── TRUST BADGES STRIP ──────────────────────────────────── */
.trust-badges-strip{background:var(--ink);padding:20px 0;width:100%;border-bottom:3px solid var(--brand);}
.trust-badges-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:nowrap;}
.trust-badge-item{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:#fff;padding:8px 22px;display:flex;align-items:center;gap:7px;white-space:nowrap;}
.trust-badge-item .chk{color:var(--brand);font-weight:800;font-size:14px;line-height:1;}
.trust-badge-divider{width:1px;height:22px;background:var(--brand);opacity:0.45;flex-shrink:0;}
@media(max-width:960px){
  .trust-badges-inner{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0;}
  .trust-badge-divider{display:none;}
  .trust-badge-item{padding:11px 14px;font-size:10px;border:1px solid rgba(255,255,255,0.07);}
}
@media(max-width:540px){
  .trust-badges-inner{grid-template-columns:1fr;}
  .trust-badge-item{padding:10px 16px;font-size:10.5px;}
}

/* ── PRICING HERO BLOCK ──────────────────────────────────── */
.pricing-hero{background:#fdfaf3;padding:80px 24px 88px;text-align:center;border-bottom:2px solid var(--ink);}
.pricing-hero h2{font-size:clamp(2rem,4.5vw,3.6rem);line-height:1.05;margin-bottom:18px;letter-spacing:-0.025em;font-weight:600;}
.pricing-hero h2 em{font-style:italic;font-weight:500;color:var(--flag-red);}
.pricing-hero-sub{font-size:17px;color:var(--ink-3);max-width:600px;margin:0 auto 48px;line-height:1.65;}
.pricing-checklist{display:grid;grid-template-columns:1fr 1fr;gap:13px 48px;max-width:680px;margin:0 auto 42px;text-align:left;}
.pricing-check-item{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--ink);line-height:1.45;}
.pricing-check-item .chk{color:var(--trust);font-weight:800;font-size:17px;flex-shrink:0;margin-top:0px;line-height:1.3;}
.pricing-hero .btn-primary{display:inline-flex;margin:0 auto;}
@media(max-width:640px){
  .pricing-checklist{grid-template-columns:1fr;}
  .pricing-hero{padding:52px 16px 60px;}
  .pricing-hero h2{font-size:clamp(1.8rem,7vw,2.8rem);}
}

/* ── COMPARE TABLE DATA-AOS ──────────────────────────────── */
/* No extra CSS needed — handled by AOS JS */

/* ── FLEET SWIPER CAROUSEL ───────────────────────────────── */
.fleet-swiper .swiper-pagination{position:static;margin-top:22px;}
.fleet-swiper .swiper-pagination-bullet{background:var(--rule);opacity:1;width:8px;height:8px;}
.fleet-swiper .swiper-pagination-bullet-active{background:var(--brand);}
/* Desktop: override Swiper flex to CSS grid */
@media(min-width:768px){
  .fleet-swiper{overflow:visible !important;cursor:default;}
  .fleet-swiper .swiper-wrapper{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:22px !important;transform:none !important;width:100% !important;height:auto !important;}
  .fleet-swiper .swiper-slide{width:auto !important;height:auto !important;margin-right:0 !important;}
  .fleet-swiper .swiper-pagination{display:none;}
}
@media(min-width:768px) and (max-width:1024px){
  .fleet-swiper .swiper-wrapper{grid-template-columns:repeat(2,1fr) !important;}
}
/* Car img with real <img> tag inside */
.car-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}

/* ── DESTINATION CARD HOVER ──────────────────────────────── */
.dest-card{transition:background var(--t),transform 0.3s ease,box-shadow 0.3s ease;}
.dest-card:hover{transform:scale(1.03);box-shadow:0 8px 32px rgba(0,0,0,0.13);}

/* ── MOBILE BOOKING FORM ─────────────────────────────────── */
@media(max-width:767px){
  .form-field select,.form-field input{min-height:52px;}
  .booking-card .cta-btn{min-height:56px;font-size:15px;}
  .mobile-book-sticky{display:flex;position:fixed;bottom:64px;left:16px;right:16px;z-index:199;
    background:var(--brand);color:var(--ink);border:2px solid var(--ink);
    font-family:'Manrope',sans-serif;font-size:14px;font-weight:800;text-transform:uppercase;
    letter-spacing:0.08em;text-decoration:none;padding:15px 24px;
    align-items:center;justify-content:center;gap:8px;
    box-shadow:0 4px 20px rgba(0,0,0,0.25);}
}
@media(min-width:768px){
  .mobile-book-sticky{display:none !important;}
}

/* ── STATS COUNTER ───────────────────────────────────────── */
@keyframes flash-zero{0%{opacity:0;transform:scale(0.7);}60%{opacity:1;transform:scale(1.1);}100%{opacity:1;transform:scale(1);}}
.stat-flash{animation:flash-zero 0.6s ease forwards;}

/* ── FOOTER UPGRADES ─────────────────────────────────────── */
.site-foot{position:relative;overflow:hidden;}
.foot-bg-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;opacity:0.18;pointer-events:none;z-index:0;display:block;}
.foot-dark-overlay{position:absolute;inset:0;background:rgba(8,8,10,0.82);z-index:1;pointer-events:none;}
.site-foot .container{position:relative;z-index:2;}
.foot-tagline{font-family:'Fraunces',serif;font-size:14px;color:rgba(255,255,255,0.72);letter-spacing:0.02em;margin-bottom:10px;font-style:italic;display:block;font-weight:400;}

/* ── AOS SECTION HEADING UTILITY ─────────────────────────── */
/* section-title and section-lede get data-aos in HTML; AOS handles the rest */
[data-aos]{will-change:transform,opacity;}

/* ── PERFORMANCE — lazy img ──────────────────────────────── */
img[loading="lazy"]{opacity:0;transition:opacity 0.4s ease;}
img[loading="lazy"].loaded{opacity:1;}

/* ── HERO VIDEO ──────────────────────────────────────────── */
.hero-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 30%;
  z-index:0;
  pointer-events:none;
  opacity:0;
  transition:opacity .8s ease;
}
.hero-video.ready{opacity:1;}
/* Make hero-bg sit behind overlay correctly when using video */
.hero-bg{z-index:-2;position:absolute;inset:0;}
.hero-bg .hero-video{position:absolute;inset:0;}

/* ── DESTINATION PHOTO CARDS ─────────────────────────────── */
.dest-card.has-photo{
  position:relative;
  overflow:hidden;
  min-height:240px;
  padding:0;
  background:#0a0a0a;
  color:#fff;
}
.dest-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:transform 0.55s ease;
  z-index:0;
  opacity:1 !important; /* override lazy-img rule — always show */
}
.dest-card.has-photo:hover .dest-photo{transform:scale(1.07);}
.dest-photo-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,0.22) 0%,rgba(0,0,0,0.72) 100%);
  z-index:1;
  transition:opacity 0.3s;
}
.dest-card.has-photo:hover .dest-photo-overlay{opacity:0.85;}
.dest-card-body{
  position:relative;
  z-index:2;
  padding:22px;
  display:flex;
  flex-direction:column;
  height:100%;
  min-height:240px;
  justify-content:flex-end;
}
.dest-card.has-photo h3{color:#fff;font-size:18px;margin-bottom:6px;}
.dest-card.has-photo p{color:rgba(255,255,255,0.85);font-size:12.5px;line-height:1.55;}
.dest-card.has-photo:hover p{color:rgba(255,255,255,0.95);}
.dest-card.has-photo .dest-link{color:var(--brand);margin-top:10px;display:inline-block;}
.dest-card.has-photo:hover .dest-link{color:var(--brand);}
.dest-card.has-photo:hover{background:#0a0a0a;}

