:root{
  --navy:#101f36; --navy-2:#1a2f4f; --navy-soft:#23395c;
  --gold:#c79a3e; --gold-2:#e3c270; --gold-soft:#f4e9cf;
  --ink:#222a35; --muted:#6c7787; --line:#e9e4da; --line-2:#eef1f5;
  --bg:#f8f5ef;            /* warm ivory */
  --bg-2:#fffdf9; --white:#fff;
  --radius:18px; --radius-sm:12px;
  --shadow:0 18px 50px -18px rgba(16,31,54,.28);
  --shadow-sm:0 8px 24px -12px rgba(16,31,54,.20);
  --shadow-gold:0 12px 28px -8px rgba(199,154,62,.45);
  --maxw:1180px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Playfair Display','Manrope',serif;line-height:1.18;color:var(--navy);margin:.2em 0 .4em;letter-spacing:-.01em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:780px;margin:0 auto}
.center{text-align:center}
.section{padding:84px 0}
.section.alt{background:var(--bg-2)}
.section-title{font-size:36px;text-align:center;margin-bottom:8px}
.section-sub{text-align:center;color:var(--muted);margin:0 auto 44px;max-width:620px;font-size:16px}
.eyebrow{display:block;text-align:center;color:var(--gold);font-weight:700;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:10px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;cursor:pointer;
  font-weight:700;font-size:15px;padding:14px 26px;border-radius:12px;transition:.22s var(--ease);font-family:inherit;line-height:1}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#2a2008;box-shadow:var(--shadow-gold)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -8px rgba(199,154,62,.6)}
.btn-outline{background:transparent;border:1.5px solid var(--gold);color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:#2a2008}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-block{width:100%}
.btn-lg{padding:17px 36px;font-size:17px}

/* Topbar */
.topbar{background:var(--navy);color:#c6d2e2;font-size:13.5px}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar-right a{margin-left:20px;color:#e9eef5;transition:.2s}
.topbar-right a:hover{color:var(--gold-2)}

/* Header */
.site-header{background:rgba(255,253,249,.88);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(16,31,54,.06);transition:.3s}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800}
.brand-mark{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#2a2008;font-weight:800;padding:7px 11px;border-radius:9px;letter-spacing:1px;box-shadow:var(--shadow-gold)}
.brand-text{font-size:19px;color:var(--navy);font-family:'Playfair Display',serif}
.main-nav{display:flex;align-items:center;gap:28px}
.main-nav a{font-weight:600;color:var(--ink);font-size:15px;position:relative;padding:4px 0}
.main-nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .25s var(--ease)}
.main-nav a.active::after,.main-nav a:hover::after{width:100%}
.main-nav a.active,.main-nav a:hover{color:var(--gold)}
.nav-cta{color:#2a2008 !important;padding:11px 22px}
.nav-cta::after{display:none}
.nav-toggle{display:none;background:none;border:0;font-size:25px;cursor:pointer;color:var(--navy)}

/* ---------------- HERO ---------------- */
.hero{position:relative;color:#fff;overflow:hidden;background:#0a1322}
.hero-bg{position:absolute;inset:0;background-image:url('/assets/img/hero.jpg');background-size:cover;background-position:center;transform:scale(1.05);animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1.14)}}
.hero-overlay{position:absolute;inset:0;background:
  linear-gradient(105deg,rgba(10,19,34,.92) 0%,rgba(10,19,34,.78) 38%,rgba(10,19,34,.45) 70%,rgba(10,19,34,.25) 100%)}
.hero-content{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:96px 24px 110px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(199,154,62,.16);border:1px solid rgba(227,194,112,.4);color:var(--gold-2);font-weight:700;font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;padding:8px 16px;border-radius:30px;margin-bottom:22px}
.hero-text h1{color:#fff;font-size:50px;margin-bottom:18px;line-height:1.1}
.hero-text h1 em{font-style:normal;color:var(--gold-2)}
.hero-text p{color:#d2dcea;font-size:18.5px;max-width:520px}
.hero-points{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-wrap:wrap;gap:12px 26px}
.hero-points li{color:#eef2f8;font-weight:600;display:flex;align-items:center;gap:8px}
.hero-points li b{color:var(--gold-2);font-size:18px}

/* Booking widget (glassy) */
.booking-widget{background:rgba(255,255,255,.97);border-radius:22px;box-shadow:0 30px 70px -20px rgba(0,0,0,.55);padding:26px;color:var(--ink);border:1px solid rgba(255,255,255,.6)}
.bw-head{font-family:'Playfair Display',serif;font-size:20px;color:var(--navy);margin-bottom:14px}
.bw-tabs{display:flex;background:var(--bg);border-radius:12px;padding:5px;margin-bottom:18px}
.bw-tab{flex:1;border:0;background:transparent;padding:11px;border-radius:9px;font-weight:700;cursor:pointer;color:var(--muted);font-family:inherit;transition:.2s}
.bw-tab.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.bw-form .field{margin-bottom:15px;position:relative}
.bw-form label,.field label{display:block;font-size:12.5px;font-weight:700;color:var(--navy);margin-bottom:7px;letter-spacing:.2px}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-size:15px;font-family:inherit;background:#fff;transition:.18s;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 4px rgba(199,154,62,.14)}
.field-with-icon{position:relative}
.field-with-icon input{padding-left:42px}
.field-icon{position:absolute;left:14px;top:38px;color:var(--gold);font-size:15px}
.field-row{display:flex;gap:12px}
.field-row .field{flex:1}
.field-small{max-width:120px}

/* Autocomplete */
.autocomplete{position:relative}
.ac-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);z-index:30;max-height:270px;overflow:auto;display:none;margin-top:4px}
.ac-list.show{display:block}
.ac-item{padding:11px 15px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--line-2);transition:.12s}
.ac-item:hover,.ac-item.active{background:var(--gold-soft)}
.ac-item:last-child{border-bottom:0}

/* Trust strip */
.trust-strip{background:var(--navy);color:#cdd8e7}
.trust-inner{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:18px;padding:26px 24px}
.trust-item{display:flex;align-items:center;gap:12px;font-weight:600;font-size:15px}
.trust-item .ti-num{font-family:'Playfair Display',serif;font-size:30px;color:var(--gold-2);line-height:1}

/* Why */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.why-card{background:#fff;padding:32px 24px;border-radius:var(--radius);box-shadow:var(--shadow-sm);text-align:center;transition:.3s var(--ease);border:1px solid var(--line-2);position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-2));transform:scaleX(0);transition:transform .3s var(--ease)}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.why-card:hover::before{transform:scaleX(1)}
.why-icon{width:62px;height:62px;margin:0 auto 14px;border-radius:16px;background:linear-gradient(135deg,var(--gold-soft),#fff);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:inset 0 0 0 1px var(--line)}
.why-card h3{font-size:18px;margin:0 0 7px}
.why-card p{color:var(--muted);font-size:14px;margin:0}

/* Routes */
.route-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.route-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:.3s var(--ease);border:1px solid var(--line-2)}
.route-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.route-body{padding:24px 24px 16px}
.route-line{display:flex;align-items:center;gap:11px;font-weight:600;font-size:15.5px;color:var(--navy)}
.dot{width:10px;height:10px;border-radius:50%;flex:none}
.dot-from{background:var(--gold)} .dot-to{background:var(--navy)}
.route-connector{width:2px;height:18px;background:repeating-linear-gradient(var(--line) 0 3px,transparent 3px 6px);margin-left:4px;margin-block:2px}
.route-foot{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--bg);border-top:1px solid var(--line-2)}
.route-price{font-weight:800;color:var(--navy);font-size:17px}
.route-price small{font-weight:600;color:var(--muted);font-size:12px}
.route-cta{color:var(--gold);font-weight:700;font-size:14px;transition:.2s}
.route-card:hover .route-cta{transform:translateX(4px)}

/* Fleet */
.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fleet-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;transition:.3s var(--ease);border:1px solid var(--line-2)}
.fleet-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.fleet-img{aspect-ratio:2/1;width:100%;object-fit:cover;background:var(--navy)}
.fleet-body{padding:22px 24px 26px}
.fleet-card h3{font-size:21px;margin:0 0 8px}
.fleet-card p{color:var(--muted);font-size:14px;min-height:42px;margin:0 0 14px}
.fleet-meta{display:flex;gap:18px;font-weight:600;color:var(--navy);font-size:14px;border-top:1px solid var(--line-2);padding-top:14px}
.fleet-meta span{display:flex;align-items:center;gap:6px}

/* Services */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:32px;transition:.3s var(--ease);border:1px solid var(--line-2)}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.service-icon{width:58px;height:58px;border-radius:15px;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:var(--gold-2);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:16px}
.service-card h3{font-size:19px;margin:4px 0 9px}
.service-card p{color:var(--muted);font-size:14.5px;margin:0}

/* About split */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative}
.about-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.about-media .media-badge{position:absolute;bottom:18px;left:18px;background:rgba(16,31,54,.85);backdrop-filter:blur(6px);color:#fff;padding:14px 18px;border-radius:14px;border:1px solid rgba(227,194,112,.4)}
.about-media .media-badge b{display:block;font-family:'Playfair Display',serif;color:var(--gold-2);font-size:22px}

/* CTA band with image */
.cta-band{position:relative;color:#fff;padding:0;overflow:hidden}
.cta-band .cta-bg{position:absolute;inset:0;background:url('/assets/img/cta.jpg') center/cover;}
.cta-band .cta-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,31,54,.92),rgba(16,31,54,.62))}
.cta-inner{position:relative;display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap;padding:64px 24px}
.cta-inner h2{color:#fff;font-size:32px;margin:0;max-width:620px}
.cta-inner p{color:#cdd8e7;margin:8px 0 0}

/* Page head */
.page-head{position:relative;color:#fff;padding:72px 0;background:var(--navy)}
.page-head::before{content:'';position:absolute;inset:0;background:url('/assets/img/city.jpg') center/cover;opacity:.18}
.page-head::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,31,54,.7),rgba(16,31,54,.92))}
.page-head .container{position:relative}
.page-head h1{color:#fff;font-size:42px;margin:0}
.page-head p{color:#cdd8e7;margin:10px 0 0;font-size:17px}

/* Cards / forms */
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:30px;margin-bottom:22px;border:1px solid var(--line-2)}
.card-title{font-size:22px;margin:0 0 20px;display:flex;align-items:center;gap:10px}
.card-title .step-n{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#2a2008;display:inline-flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;font-family:'Manrope'}
.booking-layout{max-width:760px;margin:0 auto}

/* Alerts */
.alert{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:600;font-size:14.5px}
.alert-success{background:#e8f7ef;color:#1c7c4a;border:1px solid #bce6cf}
.alert-error{background:#fdecec;color:#b23b3b;border:1px solid #f4c7c7}

/* Vehicle results */
.route-summary{background:var(--gold-soft);border:1px solid rgba(199,154,62,.3);border-radius:12px;padding:14px 18px;margin-bottom:18px;font-weight:600;color:var(--navy);font-size:14.5px}
.vehicle-results{display:grid;gap:14px}
.vehicle-opt{display:flex;align-items:center;gap:18px;border:1.5px solid var(--line);border-radius:14px;padding:16px;transition:.2s var(--ease);background:#fff}
.vehicle-opt:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.vehicle-opt .v-icon{width:84px;height:52px;border-radius:9px;object-fit:cover;flex:none}
.vehicle-opt .v-body{flex:1}
.vehicle-opt .v-body h4{margin:0 0 3px;font-size:17px}
.vehicle-opt .v-body p{margin:0;color:var(--muted);font-size:13px}
.vehicle-opt .v-meta{font-size:13px;color:var(--navy);font-weight:600;margin-top:5px}
.vehicle-opt .v-price{font-size:23px;font-weight:800;color:var(--navy);white-space:nowrap;font-family:'Playfair Display',serif}
.selected-vehicle{background:var(--gold-soft);border-radius:12px;padding:15px 18px;margin-bottom:20px;font-weight:600}

/* Confirm */
.confirm-box{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:42px;text-align:center;border:1px solid var(--line-2)}
.confirm-check{width:70px;height:70px;border-radius:50%;background:#e8f7ef;color:#1c7c4a;font-size:36px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.confirm-lead{color:var(--muted);max-width:520px;margin:0 auto 22px}
.confirm-code{background:var(--navy);color:#fff;border-radius:14px;padding:18px 28px;display:inline-block;margin-bottom:24px}
.confirm-code span{display:block;font-size:12px;color:#9fb2cc;text-transform:uppercase;letter-spacing:1.5px}
.confirm-code strong{font-size:28px;letter-spacing:2px;color:var(--gold-2);font-family:'Playfair Display',serif}
.confirm-table{width:100%;text-align:left;border-collapse:collapse;margin:8px 0 24px}
.confirm-table th{width:38%;color:var(--muted);font-weight:600;padding:10px 6px;border-bottom:1px solid var(--line-2);vertical-align:top;font-size:14px}
.confirm-table td{padding:10px 6px;border-bottom:1px solid var(--line-2);font-weight:600;font-size:14.5px}
.confirm-total th,.confirm-total td{font-size:19px;color:var(--navy);border-bottom:0}
.confirm-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Badges */
.badge{display:inline-block;padding:5px 13px;border-radius:30px;font-size:12.5px;font-weight:700}
.badge-pending{background:#fff3d6;color:#9a6b00}
.badge-confirmed{background:#e0f0ff;color:#155fa8}
.badge-completed{background:#e8f7ef;color:#1c7c4a}
.badge-cancelled{background:#fdecec;color:#b23b3b}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:13px}
.faq-item{background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line-2)}
.faq-item summary{cursor:pointer;padding:20px 24px;font-weight:700;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:24px;color:var(--gold);transition:.2s;flex:none}
.faq-item[open] summary::after{content:'–'}
.faq-answer{padding:0 24px 20px;color:var(--muted)}

/* Prose */
.prose .lead,.lead{font-size:20px;color:var(--ink);line-height:1.6}
.prose h2{font-size:26px;margin-top:30px}
.check-list{list-style:none;padding:0}
.check-list li{position:relative;padding-left:32px;margin-bottom:13px}
.check-list li::before{content:'✓';position:absolute;left:0;top:1px;width:20px;height:20px;background:var(--gold-soft);color:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}

/* Contact */
.contact-layout{display:grid;grid-template-columns:1.4fr .8fr;gap:26px}
.contact-info{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#dbe4f0;border-radius:var(--radius);padding:32px;position:relative;overflow:hidden}
.contact-info::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(199,154,62,.3),transparent 70%)}
.contact-info h3{color:#fff;position:relative}
.contact-info p{position:relative}
.contact-info a{color:var(--gold-2)}

/* Footer */
.site-footer{background:var(--navy);color:#b3c0d2;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding:60px 24px 36px}
.footer-brand{font-family:'Playfair Display',serif;font-size:24px;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.footer-brand .fb-mark{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#2a2008;padding:5px 9px;border-radius:8px;font-size:18px;font-family:'Manrope'}
.footer-about{font-size:14px;color:#98a8bf;max-width:360px}
.site-footer h4{color:#fff;font-size:16px;margin:0 0 16px}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:10px;font-size:14.5px;transition:.2s}
.footer-links a:hover{color:var(--gold-2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09);padding:18px 0;font-size:13.5px;color:#7e91a9}

/* Responsive */
@media(max-width:900px){
  .hero-content{grid-template-columns:1fr;gap:34px;padding:64px 24px 72px}
  .hero-text h1{font-size:38px}
  .why-grid,.route-grid,.fleet-grid,.service-grid{grid-template-columns:repeat(2,1fr)}
  .about-split{grid-template-columns:1fr;gap:30px}
  .contact-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .section{padding:64px 0}
}
@media(max-width:640px){
  .main-nav{position:absolute;top:76px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:0;box-shadow:var(--shadow);display:none}
  .main-nav.open{display:flex}
  .main-nav a{width:100%;padding:15px 24px;border-bottom:1px solid var(--line-2)}
  .main-nav a::after{display:none}
  .nav-cta{margin:12px 24px}
  .nav-toggle{display:block}
  .why-grid,.route-grid,.fleet-grid,.service-grid,.footer-grid{grid-template-columns:1fr}
  .field-row{flex-direction:column}
  .field-small{max-width:none}
  .vehicle-opt{flex-wrap:wrap}
  .cta-inner{flex-direction:column;text-align:center}
  .section-title{font-size:28px}
  .hero-text h1{font-size:32px}
}
