/* ============ Root & Reset ============ */
:root{
  --bg:#0c0c0d;
  --bg-elev:#121214;
  --txt:#f5f5f6;
  --muted:#a9a9b3;
  --gold:#d4af37;
  --gold-2:#f0d97e;
  --accent: var(--gold);
  --card:#141417;
  --stroke:#24242a;
  --brand-serif:"Playfair Display",serif;
  --brand-sans:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --brand-roboto:"Roboto Slab", Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --header-h:70px;
}

*{box-sizing:border-box}
html:focus-within{scroll-behavior:smooth}
html,body{height:100%}
body{
  margin:0;color:var(--txt);background:var(--bg);
  font:400 16px/1.6 var(--brand-sans);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{opacity:.9}
.container{width:min(1120px,92%);margin-inline:auto}
.section{padding:80px 0}
.section.alt{background:linear-gradient(180deg,#0e0e10, #0b0b0c)}
.section-head{margin-bottom:28px}
.section-head .h2{margin:0 0 8px}
.h2{font:700 38px/1.15 var(--brand-serif);letter-spacing:.3px}
.h4{font:600 18px var(--brand-sans); text-transform:uppercase; letter-spacing:.14em}
.lead{font-size:20px;color:var(--muted)}
.lead.center{text-align:center;max-width:820px;margin:0 auto}
.muted{color:var(--muted)}

ul.bullet{padding-left:18px;margin:12px 0}
ul.bullet li{margin:6px 0}

/* ============ Header ============ */
.site-header{
  position:sticky; top:0; z-index:999;
  background:rgba(12,12,13,.7); backdrop-filter:saturate(120%) blur(14px);
  border-bottom:0;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:var(--header-h)}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.08em}
.brand-badge{display:none}

/* Logo integration */
.brand-logo{display:inline-block;width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));}
.footer-brand .brand-logo{width:56px;height:56px}

.brand-word{font:700 18px var(--brand-roboto)}
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer;width:48px;height:48px;display:none;place-items:center;padding:0;margin:0;position:relative;z-index:1000;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.hamburger{width:26px;height:2px;background:var(--txt);position:relative;pointer-events:none}
.hamburger::before,.hamburger::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--txt);pointer-events:none}
.hamburger::before{top:-7px}.hamburger::after{top:7px}
.nav-list{display:flex;gap:26px;list-style:none;margin:0;padding:0;border:0;}
.nav-list a{display:block;padding:10px 0;border-bottom:2px solid transparent}
.nav-list a:hover,.nav-list a:focus{border-color:var(--accent)}

/* ============ Hero ============ */
.hero{position:relative;min-height:76vh;display:grid;place-items:center;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media picture, .hero-media img{display:block;width:100%;height:100%}
.hero-media img{object-fit:cover;object-position:center 55%;filter:contrast(1.05) saturate(.95) brightness(.78)}
.hero-overlay{position:absolute;inset:0;background:
  radial-gradient(90% 70% at 50% 58%, rgba(0,0,0,.0) 0%, rgba(0,0,0,.42) 58%, rgba(0,0,0,.75) 100%),
  linear-gradient(to top, rgba(0,0,0,.55) 0%, rgba(0,0,0,.25) 30%, rgba(0,0,0,.10) 60%, rgba(0,0,0,0) 100%);
}
.hero-content{padding:80px 0;text-align:center}
.display{font:700 clamp(34px,6vw,64px)/1.05 var(--brand-serif); margin:0 0 16px}
.hero .display, .hero .lead {text-shadow:0 2px 12px rgba(0,0,0,.55)}
.cta-group{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.btn{display:inline-block;padding:14px 20px;border-radius:999px;border:1px solid var(--stroke);box-shadow:var(--shadow);transition:.2s}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#171717;border-color:transparent;font-weight:700}
.btn-ghost{background:transparent;color:var(--txt)}
.trust-badges{display:flex;gap:18px;justify-content:center;list-style:none;padding:0;margin:22px 0 0;color:var(--muted);font-weight:500}
.trust-badges li{padding-left:14px;border-left:1px solid rgba(255,255,255,.1)}
.trust-badges li:first-child{border-left:0;padding-left:0}

/* ============ Booking ============ */
.booking-card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);overflow:hidden;min-height:360px}
.booking-iframe{display:block;width:100%;height:680px;border:0}
.booking-placeholder{display:grid;place-items:center;padding:50px}
.bp-inner{text-align:center;max-width:680px}
.bp-icon{font-size:42px;margin-bottom:10px}

/* ============ Fleet ============ */
.fleet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.vehicle-card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);overflow:hidden;display:grid;grid-template-rows:auto 1fr}
.vehicle-media img{width:100%;aspect-ratio:16/9;object-fit:contain;background:#000;border-bottom:1px solid var(--stroke)}
.vehicle-body{padding:18px}
.vehicle-body h3{margin:0 0 6px;font:700 22px var(--brand-sans)}
.vehicle-meta{color:var(--muted);margin:0 0 10px}

/* ============ Services ============ */
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-card{background:var(--card);border:1px solid var(--stroke);border-radius:var(--radius);padding:22px}
.service-card h3{margin:0 0 8px;font:600 18px var(--brand-sans)}

/* ============ Carousel ============ */
.carousel{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--stroke);background:var(--card)}
.carousel-track{display:flex;scroll-snap-type:x mandatory;overflow-x:auto;scroll-behavior:smooth}
.carousel-track picture{flex:0 0 100%;scroll-snap-align:center;display:block}
.carousel-track img{width:100%;height:420px;object-fit:cover}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:0;color:#fff;font-size:28px;line-height:1;width:44px;height:44px;border-radius:50%;cursor:pointer}
.carousel-btn:hover{background:rgba(0,0,0,.65)}
.carousel-btn.prev{left:10px}
.carousel-btn.next{right:10px}

/* ============ CTA ============ */
.cta{background:linear-gradient(135deg, rgba(212,175,55,.18), rgba(240,217,126,.12));border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke)}
.cta-inner{display:grid;place-items:center;text-align:center}

/* ============ Footer ============ */
.site-footer{background:#0a0a0b;border-top:1px solid var(--stroke);padding-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:26px}
.brand-footer{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.social{display:flex;gap:14px;list-style:none;padding:0;margin:12px 0}
.contact-list,.footer-links{list-style:none;padding:0;margin:10px 0}
.footer-links li{margin:6px 0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--stroke);padding:16px 0;margin-top:20px;color:var(--muted);font-size:14px}

/* --- Anchor offset so headings don't hide behind sticky header --- */
[id] { scroll-margin-top: calc(var(--header-h) + 10px); }

/* ============ Utilities ============ */
.narrow{width:min(860px,92%);margin-inline:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.scroll-top{position:fixed;right:18px;bottom:18px;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--card);border:1px solid var(--stroke);box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s}
.scroll-top.show{opacity:1;pointer-events:auto}

/* ============ Responsive ============ */
@media (max-width: 960px){
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .fleet-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  :root{ --header-h: 62px; }
  .nav-toggle{display:block}
  .nav-list{position:absolute;left:0;right:0;top:var(--header-h);background:rgba(10,10,11,.98);
  backdrop-filter:blur(12px);display:grid;gap:0;transform:translateY(-120%);
  transition:transform .25s ease;z-index:-1;border:0;overflow:hidden}
.nav-list.open{transform:translateY(0);border-bottom:1px solid var(--stroke);z-index:998}

  .nav-list li{border-top:1px solid var(--stroke)}
  .nav-list a{padding:20px 24px}
  .trust-badges{flex-wrap:wrap}
  .service-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}

@media (max-width: 720px){ .nav-list:not(.open) li{border-top:0!important} }


@media (max-width: 720px){
  /* Hide mobile menu completely when closed to avoid 1px bleed */
  .nav-list{transform:translateY(calc(-100% - 4px)); max-height:0; overflow:hidden; visibility:hidden; pointer-events:none;}
  .nav-list.open{transform:translateY(0); max-height:calc(100vh - var(--header-h)); visibility:visible; pointer-events:auto;}
  .nav-list:not(.open) li{border-top-color:transparent;}
}


@media (max-width: 720px){
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer;width:48px;height:48px;display:none;place-items:center;padding:0;margin:0;position:relative;z-index:1000;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
}

@media (max-width: 720px){
  .nav-toggle{display:grid; margin-right:4px;}
}


/* Glass panel behind hero text for perfect legibility while showing more image */
.hero-panel{
  display:inline-block;
  padding:26px 28px;
  background: rgba(8,8,9,.28);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35);
  backdrop-filter: blur(3px) saturate(115%);
}
@media (max-width:720px){
  .hero-panel{ padding:18px 16px; border-radius:14px; background: rgba(8,8,9,.34); }
}


/* Performance & CLS helpers */
.section{content-visibility:auto;contain-intrinsic-size:1px 800px}
.display{contain-intrinsic-size:0 120px}
.vehicle-media{aspect-ratio:16/9}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important;}
}
