/*
Theme Name: Zen Rides
Theme URI: https://www.zenrides.com.my
Author: Codech
Description: Custom marketing theme for Zen Rides (Perfect Premium Charter Services) — chauffeur & MPV charter across Malaysia. Built from the approved codech-web-builder prototype.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: zen-rides
*/

/* ============ Brand tokens (from logo) ============ */
:root{
  --bg:#FFFFFF; --surface:#F5FAF7; --surface-2:#E8F3EC;
  --ink:#14201A; --ink-2:#586A60; --line:#E1EBE5;
  --primary:#237A4B; --primary-ink:#FFFFFF; --accent:#14543C;
  --primary-50:#EAF6EF; --primary-100:#CDEADA; --primary-200:#9FD6BB; --primary-300:#66BD96;
  --primary-400:#3DA06E; --primary-500:#2A8A59; --primary-600:#237A4B; --primary-700:#1A5F3A;
  --primary-800:#134A2D; --primary-900:#0D3520;
  --step--1:.875rem; --step-0:1rem; --step-1:1.25rem; --step-2:1.5625rem;
  --step-3:1.953rem; --step-4:2.441rem; --step-5:3.5rem;
  --space-4:1rem; --space-6:1.5rem; --space-8:2rem;
  --radius:12px; --radius-lg:20px;
  --shadow:0 1px 3px rgba(20,40,30,.08),0 6px 16px rgba(20,40,30,.06);
  --shadow-lg:0 12px 40px rgba(20,60,40,.14);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Plus Jakarta Sans","Noto Sans SC",system-ui,-apple-system,sans-serif;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.zh{font-family:"Noto Sans SC",var(--sans)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.01em;color:var(--ink)}
.h-eyebrow{font-size:var(--step--1);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--primary-600)}
.lead{color:var(--ink-2);font-size:var(--step-1);max-width:62ch}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-weight:600;
  font-size:var(--step-0);padding:.85rem 1.5rem;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;white-space:nowrap}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:var(--primary);color:var(--primary-ink);box-shadow:0 6px 18px rgba(35,122,75,.28)}
.btn-primary:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:0 10px 26px rgba(35,122,75,.34)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:#fff;color:var(--primary-700);border-color:#fff}
.btn-outline{background:transparent;color:var(--primary-700);border-color:var(--primary-300)}
.btn-outline:hover{background:var(--primary-50);border-color:var(--primary-600)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1fb858;transform:translateY(-2px)}
.wa-ico{width:1.25em;height:1.25em;flex:0 0 auto;fill:currentColor}
.fa-ico{width:1.02em;height:1.02em;flex:0 0 auto;fill:currentColor}

/* ============ Header / Nav ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;height:72px;display:flex;align-items:center;
  background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:.3s}
.nav.scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.4rem;font-weight:700;color:var(--primary-700);white-space:nowrap}
.brand img{height:60px;width:auto}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.95rem;font-weight:700;color:var(--ink);position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--primary);transition:width .25s}
.nav-links a:hover{color:var(--primary-700)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{display:flex;align-items:center;gap:.4rem;font-weight:600;color:var(--ink);font-size:.95rem}
.nav-phone i{color:var(--primary-600)}
.nav-toggle{display:none;font-size:1.7rem;color:var(--ink);background:none;border:none;cursor:pointer}

/* ============ Hero ============ */
.hero{min-height:100dvh;display:flex;align-items:center;position:relative;overflow:hidden;color:#fff}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease}
.hero-slide.active{opacity:1}
.hero-slide picture,.hero-slide img{width:100%;height:100%}
.hero-slide img{object-fit:cover;transform:scale(1.02)}
.hero-slide.active img{animation:kenburns 6.5s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero-slide .m-img{display:none}
.hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(8,28,18,.82) 0%,rgba(8,28,18,.55) 42%,rgba(8,28,18,.12) 78%,rgba(8,28,18,.3) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-top:72px}
.hero-card{max-width:680px}
.hero h1{font-size:clamp(2.5rem,5.4vw,var(--step-5));color:#fff;letter-spacing:-.015em;margin-bottom:1.2rem;text-shadow:0 2px 24px rgba(0,0,0,.25)}
.hero p.sub{font-family:var(--sans);font-size:clamp(1rem,1.5vw,1.2rem);color:rgba(255,255,255,.92);max-width:54ch;margin-bottom:1.4rem}
.hero .cn-tag{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;color:rgba(255,255,255,.85)}
.hero .cn-tag span.line{height:1px;width:40px;background:rgba(255,255,255,.5)}
.hero .cn-tag .zh{font-size:1.05rem;letter-spacing:.05em;white-space:nowrap}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:30px;left:0;right:0;z-index:3;display:flex;gap:.6rem;justify-content:center}
.hero-dots button{width:34px;height:4px;border-radius:99px;border:none;background:rgba(255,255,255,.4);cursor:pointer;transition:.3s;padding:0}
.hero-dots button.active{background:#fff;width:54px}

/* ============ Section scaffolding ============ */
.sec{padding:96px 0}
.sec-head{max-width:640px;margin-bottom:56px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4vw,var(--step-4));margin:.5rem 0 .8rem}
.sec-head p{color:var(--ink-2);font-size:var(--step-1)}

/* ============ Why Choose (trust strip) ============ */
.why{background:var(--surface)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.why-item{text-align:center;padding:8px}
.why-ic{width:68px;height:68px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;
  background:var(--surface-2);color:var(--primary-700);font-size:2rem;transition:.3s}
.why-item:hover .why-ic{background:var(--primary);color:#fff;transform:translateY(-4px)}
.why-item h3{font-family:var(--sans);font-size:1.05rem;font-weight:700;line-height:1.3}

/* ============ Services (photo-background cards) ============ */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.svc{position:relative;min-height:448px;border-radius:var(--radius-lg);overflow:hidden;isolation:isolate;
  display:flex;align-items:flex-end;color:#fff;transition:box-shadow .35s,transform .35s}
.svc-bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;
  filter:saturate(.92) contrast(1.02);transition:transform .6s ease}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,28,18,.12) 0%,rgba(8,28,18,.4) 46%,rgba(8,28,18,.93) 100%)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.svc:hover .svc-bg{transform:scale(1.07)}
.svc-content{padding:26px;position:relative;width:100%}
.svc .svc-num{position:absolute;top:22px;left:26px;font-family:var(--serif);font-size:1.5rem;font-weight:600;
  color:rgba(255,255,255,.55)}
.svc h3{font-family:var(--sans);font-size:1.18rem;font-weight:700;color:#fff;line-height:1.25}
.svc .zh-label{display:block;font-size:.85rem;color:var(--primary-200);font-weight:500;margin:.25rem 0 .7rem}
.svc p{color:rgba(255,255,255,.86);font-size:.9rem;line-height:1.45}

/* ============ Vehicles ============ */
.veh{background:var(--surface)}
.veh-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.veh-card{background:var(--bg);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 0 0 1px var(--line), 0 12px 40px rgba(20,60,40,0);
  display:flex;flex-direction:column}
/* higher specificity than .reveal so the interaction transition isn't overridden */
.veh-grid .veh-card{transition:opacity .55s ease,transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s ease}
.veh-photo{aspect-ratio:16/10;background:#fff;position:relative;overflow:hidden}
.veh-photo img{width:100%;height:100%;object-fit:contain;padding:10px;
  transition:transform .55s cubic-bezier(.16,1,.3,1)}
.veh-body{padding:26px;flex:1;display:flex;flex-direction:column}
.veh-body h3{font-family:var(--sans);font-size:1.25rem;font-weight:700}
.veh-models{color:var(--ink-2);font-size:.92rem;margin:.35rem 0 .15rem}
.veh-cap{color:var(--primary-700);font-size:.88rem;font-weight:600;margin-bottom:1rem}
.veh-list{list-style:none;margin:.5rem 0 1.3rem;padding-top:1rem;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:.6rem}
.veh-list li{display:flex;gap:.55rem;align-items:flex-start;font-size:.92rem;color:var(--ink-2);line-height:1.4}
.veh-list li i{color:var(--primary-600);font-size:1.15rem;flex:0 0 auto;margin-top:1px}
.veh-list li b{color:var(--ink);font-weight:700}
.veh-book{width:100%;justify-content:center;margin-top:auto}
/* eco-green hover (brief: not grey) — smooth */
.veh-grid .veh-card:hover{transform:translateY(-8px);box-shadow:0 0 0 1px var(--primary), 0 12px 40px rgba(20,60,40,.16)}
.veh-card:hover .veh-photo img{transform:scale(1.07)}

/* ============ Testimonials ============ */
.tst-slider{position:relative;max-width:860px;margin:0 auto;text-align:center;min-height:240px}
.tst{opacity:0;position:absolute;inset:0;transition:opacity .6s;pointer-events:none}
.tst.active{opacity:1;position:relative;pointer-events:auto}
.tst .stars{color:#f5a623;font-size:1.2rem;letter-spacing:.1em;margin-bottom:1.2rem}
.tst blockquote{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.85rem);line-height:1.4;color:var(--ink);font-weight:500}
.tst blockquote.zh{font-family:"Noto Sans SC",var(--sans);font-size:clamp(1.15rem,2vw,1.5rem);font-weight:500;line-height:1.6}
.tst cite{display:block;margin-top:1.4rem;font-style:normal;font-weight:600;color:var(--primary-700)}
.tst cite span{display:block;font-weight:400;color:var(--ink-2);font-size:.9rem}
.tst-nav{display:flex;gap:.5rem;justify-content:center;margin-top:32px}
.tst-nav button{width:11px;height:11px;border-radius:50%;border:none;background:var(--primary-200);cursor:pointer;transition:.3s;padding:0}
.tst-nav button.active{background:var(--primary);transform:scale(1.25)}
.tst-carousel{margin-top:60px}
.tst-carousel-row{position:relative}
.tst-viewport{overflow:hidden}
.tst-track{display:flex;gap:18px;transition:transform .6s cubic-bezier(.16,1,.3,1);will-change:transform}
.tst-track figure{flex:0 0 calc((100% - 36px)/3);margin:0;aspect-ratio:1/1;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);background:var(--surface-2)}
.tst-track img{width:100%;height:100%;object-fit:cover;transition:.5s}
.tst-track figure:hover img{transform:scale(1.05)}
.tst-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-lg);display:grid;place-items:center;
  cursor:pointer;font-size:1.25rem;color:var(--primary-700);z-index:3;transition:.2s}
.tst-arrow:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.tst-arrow.prev{left:-10px}
.tst-arrow.next{right:-10px}
.tst-dots2{display:flex;gap:.5rem;justify-content:center;margin-top:26px}
.tst-dots2 button{width:9px;height:9px;border-radius:50%;border:none;background:var(--primary-200);cursor:pointer;transition:.3s;padding:0}
.tst-dots2 button.active{background:var(--primary);transform:scale(1.25)}

/* ============ Corporate trust band ============ */
.trust{background:var(--primary-900);color:#fff}
.trust .wrap{display:grid;grid-template-columns:1fr;gap:40px;text-align:center}
.trust-head{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.trust-head h2{font-family:var(--serif);font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:600;color:#fff;
  line-height:1.18;letter-spacing:-.01em}
.trust-head h2 .hl{color:var(--primary-300)}
.logos{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;align-items:stretch;max-width:1100px;margin:0 auto}
.logos .logo-chip{height:96px;border-radius:14px;background:#fff;padding:0;overflow:hidden;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.logos .logo-chip img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;display:block}

/* ============ Enquiry form ============ */
.enq-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}
.enq-info h2{font-size:clamp(2rem,3.6vw,var(--step-4));margin-bottom:1rem}
.enq-info p{color:var(--ink-2);font-size:var(--step-1);margin-bottom:1.8rem;max-width:42ch}
.enq-contacts{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}
.enq-contacts a{display:flex;align-items:center;gap:.9rem;font-weight:600;color:var(--ink);line-height:1.4}
.enq-contacts a i{width:46px;height:46px;flex:0 0 46px;border-radius:12px;display:grid;place-items:center;background:var(--surface-2);color:var(--primary-700);font-size:1.3rem}
.enq-form{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-lg)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.88rem;font-weight:600;margin-bottom:.4rem;color:var(--ink)}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:.98rem;color:var(--ink);background:#fff;transition:.2s}
.field input::placeholder,.field textarea::placeholder{color:#9aa8a0}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}
.field-row{display:grid;grid-template-columns:110px 1fr;gap:12px}
.enq-form .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:.82rem;color:var(--ink-2);text-align:center;margin-top:14px}

/* ============ Footer ============ */
footer{background:var(--surface);border-top:1px solid var(--line);padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1.4fr;gap:48px;margin-bottom:48px}
.foot-brand img{height:84px;margin-bottom:18px}
.foot-brand p{color:var(--ink-2);font-size:.94rem;max-width:38ch}
.foot-col h4{font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink);margin-bottom:18px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:11px}
.foot-col a{color:var(--ink-2);font-size:.94rem;transition:.2s}
.foot-col a:hover{color:var(--primary-700)}
.foot-info p{color:var(--ink-2);font-size:.9rem;margin-bottom:.6rem;line-height:1.5}
.foot-info b{color:var(--ink)}
.pay{display:flex;gap:16px;align-items:center;margin-top:14px;flex-wrap:wrap}
.pay img{height:54px;width:auto;object-fit:contain;display:block}
.pay-label{display:block;font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  color:var(--ink);font-weight:700;margin:1.4rem 0 .2rem}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:10px;color:var(--ink-2);font-size:.86rem}

/* ============ Floating CTAs ============ */
.floats{position:fixed;right:20px;bottom:24px;z-index:60;display:flex;flex-direction:column;gap:12px}
.floats a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.6rem;
  box-shadow:var(--shadow-lg);transition:transform .2s}
.floats a:hover{transform:scale(1.08)}
.floats .wa{background:#25D366}
.floats .call{background:var(--primary-700)}
.floats a .lbl{position:absolute;right:64px;background:var(--ink);color:#fff;font-size:.8rem;font-family:var(--sans);
  padding:.4rem .7rem;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:.2s;transform:translateX(6px)}
.floats a:hover .lbl{opacity:1;transform:translateX(0)}

/* ============ Reveal animation ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ============ Responsive ============ */
@media(max-width:980px){
  .why-grid{grid-template-columns:repeat(2,1fr);gap:36px 24px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .veh-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .enq-grid{grid-template-columns:1fr;gap:36px}
  .tst-track figure{flex-basis:calc((100% - 18px)/2)}
  .logos{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:900px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
    background:#fff;padding:20px 24px;border-bottom:1px solid var(--line);gap:1rem;box-shadow:var(--shadow)}
}
@media(max-width:760px){
  .svc-grid{grid-template-columns:1fr}
  .svc{min-height:380px}
  .tst-track figure{flex-basis:100%}
  .logos{grid-template-columns:repeat(2,1fr)}
  .tst-arrow{display:none}
  .hero-slide .d-img{display:none}
  .hero-slide .m-img{display:block}
  .hero::before{background:linear-gradient(180deg,rgba(8,28,18,.4) 0%,rgba(8,28,18,.55) 55%,rgba(8,28,18,.85) 100%)}
  .sec{padding:64px 0}
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column}
  .floats a .lbl{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero-slide.active img{animation:none}
}

/* ============ Legal / content pages ============ */
.page-hero{background:linear-gradient(160deg,var(--primary-800),var(--primary-900));color:#fff;
  padding:130px 0 64px;text-align:center}
.page-hero h1{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,3.2rem);color:#fff;margin-bottom:.6rem}
.page-hero p{color:rgba(255,255,255,.75);max-width:56ch;margin:0 auto}
.legal{padding:72px 0 96px}
.legal .wrap{max-width:860px}
.legal .updated{color:var(--ink-2);font-size:.9rem;margin-bottom:2.5rem;padding-bottom:1.4rem;border-bottom:1px solid var(--line)}
.legal h2{font-family:var(--serif);font-size:var(--step-2);margin:2.4rem 0 .8rem;color:var(--ink)}
.legal h3{font-family:var(--sans);font-size:1.1rem;font-weight:700;margin:1.6rem 0 .5rem}
.legal p{color:var(--ink-2);margin-bottom:1rem;line-height:1.75}
.legal ul{margin:0 0 1.2rem 1.2rem;color:var(--ink-2);line-height:1.75}
.legal li{margin-bottom:.5rem}
.legal a{color:var(--primary-700);text-decoration:underline}
.legal .note{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--primary);
  border-radius:10px;padding:1rem 1.2rem;font-size:.9rem;color:var(--ink-2);margin:1.5rem 0}


/* ===== CF7 enquiry form ===== */
.enq-form .wpcf7-form p{margin:0}
.enq-form .wpcf7-form br{display:none}
.enq-form .wpcf7-form-control-wrap{display:block;width:100%}
.enq-form .field{margin-bottom:18px}
.enq-form .wpcf7-form-control{width:100%}
.enq-form input.wpcf7-submit{width:100%;margin-top:6px}
.enq-form .wpcf7-not-valid-tip{color:#c0392b;font-size:.82rem;margin-top:.35rem;display:block}
.enq-form .wpcf7-response-output{margin:1.1rem 0 0 !important;padding:.8rem 1rem;border-radius:10px;font-size:.9rem;border:1px solid var(--line) !important}
.enq-form .wpcf7-spinner{margin:.6rem auto 0;display:block}


/* select chevron spacing (custom arrow, offset from right border) */
.field select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23586A60' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:13px;
  padding-right:2.4rem;
}


/* ===== custom styled select dropdown (enquiry country code) ===== */
.zr-select{position:relative;width:100%}
.zr-select>select{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;pointer-events:none}
.zr-select-btn{width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:10px;
  padding:.85rem 2.2rem .85rem 1rem;font-family:var(--sans);font-size:.98rem;color:var(--ink);cursor:pointer;
  position:relative;transition:border-color .2s,box-shadow .2s}
.zr-select-btn::after{content:"";position:absolute;right:14px;top:44%;width:8px;height:8px;
  border-right:2px solid var(--ink-2);border-bottom:2px solid var(--ink-2);transform:translateY(-50%) rotate(45deg);transition:transform .2s}
.zr-select.open .zr-select-btn{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}
.zr-select.open .zr-select-btn::after{transform:translateY(-20%) rotate(225deg)}
.zr-select-list{position:absolute;top:calc(100% + 6px);left:0;min-width:100%;z-index:30;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);list-style:none;margin:0;padding:6px;
  max-height:240px;overflow:auto;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s,transform .18s}
.zr-select.open .zr-select-list{opacity:1;transform:none;pointer-events:auto}
.zr-select-list li{padding:.6rem .8rem;border-radius:8px;font-size:.95rem;color:var(--ink);cursor:pointer;
  white-space:nowrap;transition:background .15s,color .15s}
.zr-select-list li:hover{background:var(--surface-2)}
.zr-select-list li.sel{background:var(--primary);color:#fff;font-weight:600}

/* center a lone trailing vehicle card on desktop */
@media(min-width:981px){.veh-grid > .veh-card:last-child:nth-child(3n+1){grid-column:1}}


/* ===== contact section background ===== */
#contact{position:relative;
  background-image:linear-gradient(rgba(8,28,18,.80),rgba(8,28,18,.84)), url('assets/img/contact-bg.jpg');
  background-size:cover;background-position:center;background-repeat:no-repeat}
#contact .h-eyebrow{color:var(--primary-300)}
#contact .enq-info h2{color:#fff}
#contact .enq-info p{color:rgba(255,255,255,.85)}
