/* ============ United Care Medical Transportation ============ */
:root{
  --navy-900:#06122B;
  --navy-800:#0A1F44;
  --navy-700:#102C5E;
  --navy-600:#163D7C;
  --silver:#C0C5CE;
  --silver-light:#E5E8EE;
  --red:#C8102E;
  --red-dark:#9C0C24;
  --gold:#D4AF37;
  --gold-light:#E8C66A;
  --white:#FFFFFF;
  --ink:#0E1A33;
  --ink-soft:#465272;
  --bg-soft:#F6F8FC;
  --border:#E3E8F0;
  --shadow-sm:0 4px 14px rgba(10,31,68,.08);
  --shadow-md:0 12px 36px rgba(10,31,68,.12);
  --shadow-lg:0 24px 60px rgba(10,31,68,.18);
  --radius:14px;
  --radius-lg:20px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.25s}
ul{list-style:none}

.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* ============ Typography ============ */
h1,h2,h3,h4,h5{font-family:'Playfair Display',serif;color:var(--navy-900);letter-spacing:-.01em;line-height:1.18;font-weight:600}
h1{font-size:clamp(2.2rem,4.4vw,3.6rem)}
h2{font-size:clamp(1.9rem,3.2vw,2.6rem)}
h3{font-size:1.35rem}
h4{font-size:1.1rem}
p{color:var(--ink-soft);font-size:1rem}
.accent-gold{color:var(--gold);font-style:italic;font-weight:600}
.accent-red{color:var(--red);font-style:italic}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);background:rgba(212,175,55,.08);
  padding:.5rem 1rem;border-radius:99px;border:1px solid rgba(212,175,55,.25);
  margin-bottom:1.2rem;
}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.95rem 1.8rem;border-radius:99px;font-weight:600;font-size:.95rem;
  border:none;cursor:pointer;transition:.3s;letter-spacing:.01em;
  font-family:'Inter',sans-serif;
}
.btn-primary{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  color:#fff;box-shadow:0 10px 30px rgba(200,16,46,.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(200,16,46,.5)}
.btn-ghost{background:transparent;color:var(--navy-900);border:1.5px solid var(--navy-900)}
.btn-ghost:hover{background:var(--navy-900);color:#fff}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-ghost-light:hover{background:#fff;color:var(--navy-900);border-color:#fff}
.btn-block{width:100%}

/* ============ Top Bar ============ */
.top-bar{
  background:var(--navy-900);color:rgba(255,255,255,.85);
  font-size:.82rem;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.06);
}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.top-bar i{color:var(--gold);margin-right:.4rem}
.top-bar-right{display:flex;gap:1.5rem}
.top-bar-right a:hover{color:var(--gold)}

/* ============ Header ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.95);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition:.3s;
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;justify-content:space-between;align-items:center;padding:.9rem 28px;max-width:1240px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.75rem}
.logo img{height:90px;width:auto;object-fit:contain;border-radius:10px}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--navy-900);letter-spacing:.02em}
.logo-tag{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);margin-top:.35rem;font-weight:500}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.95rem;font-weight:500;color:var(--navy-900);position:relative}
.nav a:not(.nav-cta):hover{color:var(--red)}
.nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--red);transition:.3s}
.nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:.65rem 1.4rem;font-size:.88rem}
.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--navy-900);cursor:pointer}

/* ============ Hero ============ */
.hero{position:relative;min-height:780px;display:flex;align-items:center;padding:5rem 0 6rem;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(212,175,55,.18) 0%,transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(22,61,124,.45) 0%,transparent 55%),
    linear-gradient(135deg,#06122B 0%,#0A1F44 50%,#102C5E 100%);
}
.hero-bg::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(212,175,55,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask:radial-gradient(circle at center,#000 30%,transparent 75%);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'><g fill='none' stroke='%23D4AF37' stroke-opacity='.15'><circle cx='100' cy='100' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='300' cy='200' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='600' cy='150' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='700' cy='400' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='450' cy='500' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='200' cy='600' r='2' fill='%23D4AF37' fill-opacity='.4'/><circle cx='550' cy='700' r='2' fill='%23D4AF37' fill-opacity='.4'/><line x1='100' y1='100' x2='300' y2='200'/><line x1='300' y1='200' x2='600' y2='150'/><line x1='600' y1='150' x2='700' y2='400'/><line x1='700' y1='400' x2='450' y2='500'/><line x1='450' y1='500' x2='200' y2='600'/><line x1='200' y1='600' x2='550' y2='700'/><line x1='300' y1='200' x2='450' y2='500'/></g></svg>") center/cover;
  opacity:.7;
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(6,18,43,.3) 100%)}
.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr .85fr;gap:4rem;align-items:center;
}
.hero-content h1{color:#fff;margin-bottom:1.5rem}
.hero-content .eyebrow{background:rgba(212,175,55,.12);border-color:rgba(212,175,55,.3)}
.hero-content .lead{color:rgba(255,255,255,.82);font-size:1.15rem;max-width:580px;margin-bottom:2.2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.35)}
.hero-cta .btn-ghost:hover{background:#fff;color:var(--navy-900)}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.8rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}
.trust-item{display:flex;align-items:center;gap:.65rem;color:rgba(255,255,255,.85);font-size:.92rem;font-weight:500}
.trust-item i{color:var(--gold);font-size:1.15rem}

.hero-card{
  background:rgba(255,255,255,.98);
  border-radius:var(--radius-lg);padding:2.2rem;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.1);
}
.hero-card h3{margin-bottom:1.4rem;color:var(--navy-900)}
.hero-card form{display:flex;flex-direction:column;gap:.85rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.hero-card input,.hero-card select,.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--border);border-radius:10px;
  font-family:inherit;font-size:.92rem;color:var(--ink);background:#fff;transition:.25s;
}
.hero-card input:focus,.hero-card select:focus,.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(200,16,46,.1);
}
.form-note{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:.4rem}
.form-note i{color:var(--gold)}
.thank-you{font-size:.9rem;color:#0a8a3e;background:#e8f7ee;padding:.7rem;border-radius:8px;text-align:center;font-weight:500}

/* ============ Trust Strip ============ */
.trust-strip{background:#fff;border-bottom:1px solid var(--border);padding:2.4rem 0}
.trust-strip-inner{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:1.5rem}
.trust-stat{display:flex;flex-direction:column;align-items:center;text-align:center}
.trust-stat .num{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:700;color:var(--navy-900);line-height:1}
.trust-stat .label{font-size:.82rem;color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase;margin-top:.4rem}
.divider{width:1px;height:50px;background:var(--border)}

/* ============ Sections ============ */
.section{padding:6rem 0;position:relative;overflow:hidden}
.section-light{background:var(--bg-soft)}
.section-dark{background:linear-gradient(135deg,#06122B 0%,#0A1F44 100%);color:#fff;position:relative}
.section-dark::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 70% 30%,rgba(212,175,55,.12) 0%,transparent 50%);
  pointer-events:none;
}
.bg-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(212,175,55,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.04) 1px,transparent 1px);
  background-size:50px 50px;
  mask:radial-gradient(circle at center,#000 0%,transparent 80%);
  pointer-events:none;
}
.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark p{color:rgba(255,255,255,.75)}

.section-head{text-align:center;max-width:760px;margin:0 auto 4rem}
.section-head h2{margin-bottom:1rem}
.section-head p{font-size:1.08rem}
.section-head.light .eyebrow{background:rgba(212,175,55,.12)}

/* ============ Services ============ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.service-card{
  background:#fff;border-radius:var(--radius-lg);padding:2.2rem;
  border:1px solid var(--border);transition:.4s;position:relative;overflow:hidden;
}
.service-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--red));
  transform:scaleX(0);transform-origin:left;transition:.4s;
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-card.featured{background:linear-gradient(135deg,#06122B 0%,#102C5E 100%);color:#fff;border:none}
.service-card.featured h3,.service-card.featured p{color:#fff}
.service-card.featured p{color:rgba(255,255,255,.8)}
.service-card.featured li{color:rgba(255,255,255,.85)}
.service-card.featured .icon-wrap{background:rgba(212,175,55,.15);color:var(--gold)}
.badge{
  position:absolute;top:1.4rem;right:1.4rem;
  background:var(--gold);color:var(--navy-900);font-size:.7rem;font-weight:700;
  padding:.3rem .7rem;border-radius:99px;letter-spacing:.08em;text-transform:uppercase;
}
.icon-wrap{
  width:62px;height:62px;border-radius:16px;
  background:linear-gradient(135deg,rgba(200,16,46,.08),rgba(212,175,55,.08));
  color:var(--red);display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1.4rem;
}
.service-card h3{margin-bottom:.7rem}
.service-card p{margin-bottom:1.2rem;font-size:.95rem}
.service-card ul li{font-size:.88rem;color:var(--ink-soft);padding:.35rem 0;padding-left:1.4rem;position:relative}
.service-card ul li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}

/* ============ Why Grid ============ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;position:relative;z-index:2}
.why-card{
  background:rgba(255,255,255,.04);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);
  padding:2.2rem;transition:.4s;
}
.why-card:hover{background:rgba(255,255,255,.07);border-color:rgba(212,175,55,.3);transform:translateY(-4px)}
.why-card i{font-size:2rem;color:var(--gold);margin-bottom:1rem;display:block}
.why-card h4{margin-bottom:.6rem;font-size:1.18rem}
.why-card p{font-size:.92rem;color:rgba(255,255,255,.72)}

/* ============ Facilities ============ */
.facilities-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.facilities-content h2{margin-bottom:1.2rem}
.facilities-content > p{margin-bottom:2rem;font-size:1.05rem}
.facility-feature{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--border)}
.facility-feature:last-of-type{border-bottom:none;margin-bottom:1.8rem}
.facility-feature i{color:var(--gold);font-size:1.3rem;margin-top:.15rem}
.facility-feature strong{display:block;color:var(--navy-900);font-size:1.02rem;margin-bottom:.15rem}
.facility-feature span{color:var(--ink-soft);font-size:.92rem}

.facilities-visual{position:relative;min-height:480px}
.visual-image{
  position:absolute;inset:0;
  border-radius:var(--radius-lg);
  background:
    linear-gradient(135deg,rgba(6,18,43,.5),rgba(22,61,124,.5)),
    url("https://images.unsplash.com/photo-1530497610245-94d3c16cda28?w=1200&q=80") center/cover;
  box-shadow:var(--shadow-lg);
}
.visual-card{
  position:absolute;background:#fff;padding:1.1rem 1.4rem;border-radius:14px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:1rem;z-index:2;
  border:1px solid var(--border);
}
.visual-card i{font-size:1.5rem;color:var(--red);background:rgba(200,16,46,.08);padding:.7rem;border-radius:10px}
.visual-card strong{display:block;font-size:.98rem;color:var(--navy-900);font-family:'Playfair Display',serif}
.visual-card span{font-size:.78rem;color:var(--ink-soft)}
.stat-card-1{top:1.5rem;left:-1.5rem}
.stat-card-2{top:50%;right:-2rem;transform:translateY(-50%)}
.stat-card-3{bottom:1.5rem;left:1.5rem}

/* ============ Process ============ */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.process-step{
  background:#fff;padding:2.2rem 1.6rem;border-radius:var(--radius-lg);
  text-align:center;position:relative;border:1px solid var(--border);
  transition:.4s;
}
.process-step:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.step-num{
  font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;
  color:transparent;-webkit-text-stroke:1.5px var(--gold);
  line-height:1;margin-bottom:.6rem;
}
.process-step i{font-size:1.6rem;color:var(--red);margin-bottom:1rem;display:block}
.process-step h4{margin-bottom:.5rem}
.process-step p{font-size:.9rem}

/* ============ Testimonials ============ */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;position:relative;z-index:2}
.testimonial{
  background:rgba(255,255,255,.05);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);
  padding:2.2rem;
}
.stars{color:var(--gold);margin-bottom:1rem;font-size:.95rem}
.testimonial > p{color:rgba(255,255,255,.88);font-size:1.02rem;font-style:italic;margin-bottom:1.6rem;line-height:1.7}
.t-author{display:flex;align-items:center;gap:.9rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.1)}
.avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--navy-900);font-weight:700;font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;
}
.t-author strong{display:block;color:#fff;font-size:.95rem}
.t-author span{color:rgba(255,255,255,.6);font-size:.82rem}

/* ============ FAQ ============ */
.faq-container{max-width:880px}
.faq-list{display:flex;flex-direction:column;gap:.85rem}
.faq-list details{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:1.3rem 1.6rem;transition:.3s;
}
.faq-list details[open]{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.faq-list summary{
  font-family:'Playfair Display',serif;font-size:1.08rem;font-weight:600;
  color:var(--navy-900);cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary i{color:var(--gold);transition:.3s;font-size:.85rem}
.faq-list details[open] summary i{transform:rotate(45deg)}
.faq-list p{margin-top:1rem;color:var(--ink-soft);font-size:.95rem}

/* ============ CTA Band ============ */
.cta-band{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  padding:4rem 0;color:#fff;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(212,175,55,.15) 0%,transparent 50%);
}
.cta-inner{position:relative;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem}
.cta-inner h2{color:#fff;font-size:clamp(1.7rem,2.5vw,2.2rem);max-width:680px;margin-bottom:.4rem}
.cta-inner p{color:rgba(255,255,255,.9)}
.cta-buttons{display:flex;gap:1rem;flex-wrap:wrap}
.cta-buttons .btn-primary{background:#fff;color:var(--red);box-shadow:0 10px 30px rgba(0,0,0,.2)}
.cta-buttons .btn-primary:hover{background:var(--navy-900);color:#fff}

/* ============ Contact ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:start}
.contact-block{display:flex;gap:1.2rem;padding:1.2rem 0;border-bottom:1px solid var(--border);align-items:flex-start}
.contact-block:last-child{border-bottom:none}
.contact-block i{
  font-size:1.1rem;color:var(--gold);
  background:rgba(212,175,55,.1);padding:.85rem;border-radius:10px;min-width:42px;text-align:center;
}
.contact-block strong{display:block;font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--navy-900);margin-bottom:.2rem}
.contact-block a,.contact-block span{color:var(--ink-soft);font-size:.95rem}
.contact-block a:hover{color:var(--red)}

.contact-form{
  background:#fff;padding:2.6rem;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);border:1px solid var(--border);
  display:flex;flex-direction:column;gap:1rem;
}
.contact-form h3{margin-bottom:.5rem}

/* ============ Footer ============ */
.footer{background:var(--navy-900);color:rgba(255,255,255,.7);padding:4.5rem 0 0;position:relative}
.footer::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 30%,rgba(212,175,55,.06) 0%,transparent 40%);
  pointer-events:none;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:3rem;position:relative;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .logo{margin-bottom:1.2rem}
.footer-brand .logo img{height:110px}
.footer-brand .logo-name{color:#fff;font-size:1.7rem}
.footer-brand .logo-tag{color:rgba(255,255,255,.6);font-size:.78rem}
.motto{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);font-size:1.1rem;margin-bottom:1rem}
.footer-desc{font-size:.92rem;color:rgba(255,255,255,.6);max-width:380px;line-height:1.7}
.socials{display:flex;gap:.6rem;margin-top:1.4rem}
.socials a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);
}
.socials a:hover{background:var(--gold);color:var(--navy-900);border-color:var(--gold)}
.footer h5{color:#fff;font-family:'Playfair Display',serif;font-size:1.05rem;margin-bottom:1.2rem}
.footer ul li{padding:.4rem 0;font-size:.92rem}
.footer ul li i{color:var(--gold);margin-right:.5rem;width:14px}
.footer a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.6rem 28px;font-size:.85rem;flex-wrap:wrap;gap:1rem;color:rgba(255,255,255,.55)}

/* ============ Floating Call ============ */
.floating-call{
  position:fixed;bottom:28px;right:28px;width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  box-shadow:0 10px 30px rgba(200,16,46,.5);z-index:90;
  animation:pulse 2.5s infinite;
}
.floating-call:hover{transform:scale(1.08)}
@keyframes pulse{
  0%,100%{box-shadow:0 10px 30px rgba(200,16,46,.5),0 0 0 0 rgba(200,16,46,.5)}
  50%{box-shadow:0 10px 30px rgba(200,16,46,.5),0 0 0 18px rgba(200,16,46,0)}
}

/* ============ Animations ============ */
.fade-in{opacity:0;transform:translateY(24px);animation:fadeUp .9s .15s forwards cubic-bezier(.16,1,.3,1)}
.fade-in.delay-1{animation-delay:.4s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ Page Hero (sub-pages) ============ */
.page-hero{
  position:relative;padding:7rem 0 5rem;overflow:hidden;
  background:linear-gradient(135deg,#06122B 0%,#0A1F44 60%,#102C5E 100%);
  color:#fff;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(212,175,55,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,175,55,.05) 1px,transparent 1px);
  background-size:55px 55px;
  mask:radial-gradient(circle at 70% 50%,#000 0%,transparent 70%);
}
.page-hero::after{
  content:"";position:absolute;top:-30%;right:-10%;width:60%;height:160%;
  background:radial-gradient(circle,rgba(212,175,55,.18) 0%,transparent 60%);
  pointer-events:none;
}
.page-hero-inner{position:relative;z-index:2;max-width:880px}
.breadcrumb{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:1.4rem;letter-spacing:.05em}
.breadcrumb a{color:var(--gold)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.85)}
.page-hero h1{color:#fff;margin-bottom:1rem;font-size:clamp(2rem,4vw,3.2rem)}
.page-hero .lead{color:rgba(255,255,255,.82);font-size:1.15rem;max-width:680px}

/* Generic content blocks for sub-pages */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split-image{
  height:460px;border-radius:var(--radius-lg);
  background-size:cover;background-position:center;
  box-shadow:var(--shadow-lg);position:relative;
}
.split-image::after{
  content:"";position:absolute;inset:0;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(6,18,43,.25),transparent 50%);
}
.split h2{margin-bottom:1.2rem}
.split p{margin-bottom:1rem;font-size:1.02rem}
.check-list{margin-top:1.5rem;display:flex;flex-direction:column;gap:.7rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.98rem;color:var(--ink)}
.check-list li i{color:var(--gold);margin-top:.3rem}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.feature-block{background:#fff;padding:2rem;border-radius:var(--radius-lg);border:1px solid var(--border);transition:.4s}
.feature-block:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.feature-block i{font-size:1.8rem;color:var(--gold);margin-bottom:1rem;display:block}
.feature-block h4{margin-bottom:.5rem}
.feature-block p{font-size:.94rem}

.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.price-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.4rem;transition:.4s;position:relative}
.price-card.popular{background:linear-gradient(135deg,#06122B,#102C5E);color:#fff;border:none;transform:scale(1.03)}
.price-card.popular h3,.price-card.popular .price{color:#fff}
.price-card.popular p,.price-card.popular li{color:rgba(255,255,255,.78)}
.price-card .tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy-900);font-size:.7rem;font-weight:700;padding:.35rem .9rem;border-radius:99px;letter-spacing:.1em;text-transform:uppercase}
.price-card h3{margin-bottom:.4rem;font-size:1.4rem}
.price-card .price{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:700;color:var(--navy-900);margin:1rem 0 .2rem}
.price-card .price small{font-size:.85rem;color:var(--ink-soft);font-weight:400;font-family:'Inter',sans-serif}
.price-card ul{margin:1.6rem 0;display:flex;flex-direction:column;gap:.6rem}
.price-card ul li{font-size:.92rem;padding-left:1.5rem;position:relative}
.price-card ul li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.blog-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:.4s}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.blog-thumb{height:220px;background-size:cover;background-position:center;position:relative}
.blog-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(6,18,43,.45))}
.blog-body{padding:1.8rem}
.blog-meta{font-size:.78rem;color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.7rem}
.blog-meta .cat{color:var(--red);font-weight:600;margin-right:.6rem}
.blog-body h3{font-size:1.2rem;margin-bottom:.7rem;line-height:1.3}
.blog-body p{font-size:.92rem;margin-bottom:1rem}
.read-more{color:var(--red);font-weight:600;font-size:.9rem;letter-spacing:.02em}
.read-more i{transition:.3s;margin-left:.3rem}
.read-more:hover i{transform:translateX(4px)}

.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.area-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);transition:.4s;
}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.area-banner{height:180px;background:linear-gradient(135deg,#06122B,#102C5E);position:relative;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700}
.area-banner::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 50%,rgba(212,175,55,.2),transparent)}
.area-banner span{position:relative;z-index:2}
.area-body{padding:1.6rem 1.8rem}
.area-body p{font-size:.92rem;margin-bottom:.8rem}
.area-body ul{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.6rem}
.area-body ul li{font-size:.78rem;background:var(--bg-soft);padding:.3rem .7rem;border-radius:99px;color:var(--navy-800)}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.team-card{text-align:center;background:#fff;padding:2rem 1.4rem;border-radius:var(--radius-lg);border:1px solid var(--border);transition:.4s}
.team-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.team-photo{width:120px;height:120px;border-radius:50%;margin:0 auto 1.2rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--navy-900);font-weight:700;box-shadow:0 8px 24px rgba(212,175,55,.3)}
.team-card h4{margin-bottom:.2rem}
.team-card .role{font-size:.85rem;color:var(--red);font-weight:600;letter-spacing:.04em;margin-bottom:.8rem}
.team-card p{font-size:.88rem}

.timeline{position:relative;max-width:780px;margin:0 auto;padding-left:2.2rem}
.timeline::before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--gold),transparent)}
.t-item{position:relative;padding:1.2rem 0 2rem}
.t-item::before{content:"";position:absolute;left:-2.2rem;top:1.7rem;width:18px;height:18px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(212,175,55,.2)}
.t-item .year{font-family:'Playfair Display',serif;color:var(--red);font-size:1.1rem;font-weight:700;margin-bottom:.3rem}
.t-item h4{margin-bottom:.4rem}
.t-item p{font-size:.95rem}

.job-list{display:flex;flex-direction:column;gap:1rem}
.job-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem 1.8rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;transition:.3s;flex-wrap:wrap}
.job-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateX(4px)}
.job-card h4{margin-bottom:.3rem}
.job-meta{font-size:.85rem;color:var(--ink-soft);display:flex;gap:1rem;flex-wrap:wrap}
.job-meta span i{color:var(--gold);margin-right:.3rem}

.legal-content{max-width:820px;margin:0 auto}
.legal-content h2{margin:2.5rem 0 1rem;font-size:1.6rem}
.legal-content h3{margin:1.8rem 0 .8rem;font-size:1.2rem}
.legal-content p,.legal-content li{font-size:.95rem;margin-bottom:.8rem;color:var(--ink-soft);line-height:1.75}
.legal-content ul{padding-left:1.4rem;margin-bottom:1rem}
.legal-content ul li{list-style:disc;margin-bottom:.4rem}
.legal-tabs{display:flex;gap:.6rem;justify-content:center;margin-bottom:3rem;flex-wrap:wrap}
.legal-tabs a{padding:.7rem 1.4rem;border:1.5px solid var(--border);border-radius:99px;font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.legal-tabs a.active,.legal-tabs a:hover{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}

/* ============ Booking & Fare Calculator ============ */
[hidden]{display:none!important}
.booking-hero{padding-bottom:4rem}
.booking-section{background:var(--bg-soft)}
.booking-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.75fr);gap:2rem;align-items:start}
.booking-layout>*{min-width:0}
.booking-form{display:flex;flex-direction:column;gap:1.4rem;min-width:0}
.booking-group{background:#fff;border:1px solid var(--border);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}
.booking-group-head{display:flex;gap:1rem;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}
.booking-group-head>span{width:36px;height:36px;display:grid;place-items:center;background:var(--navy-900);color:#fff;border-radius:50%;font-family:'Playfair Display',serif;font-weight:700;flex:0 0 auto}
.booking-group-head h2{font-size:1.35rem;margin:0}
.booking-group-head p{font-size:.85rem;margin:.15rem 0 0}
.booking-group label{font-size:.84rem;font-weight:600;color:var(--navy-800);display:flex;flex-direction:column;gap:.45rem}
.booking-group label input,.booking-group label select{font-weight:400}
.mileage-display{min-height:46px;border:1.5px solid var(--border);border-radius:10px;background:var(--bg-soft);padding:.75rem 1rem;display:flex;align-items:center;gap:.65rem;font-weight:400;color:var(--ink-soft)}
.mileage-display i{color:var(--gold)}
.mileage-display strong{color:var(--navy-900);font-weight:600}
.route-match{font-size:.78rem;background:rgba(212,175,55,.08);border-left:3px solid var(--gold);padding:.7rem .85rem;border-radius:0 6px 6px 0;overflow-wrap:anywhere}
.booking-checks{display:grid;grid-template-columns:1fr;gap:.65rem}
.check-control,.terms-control{flex-direction:row!important;align-items:flex-start;gap:.7rem!important;background:var(--bg-soft);padding:.85rem 1rem;border:1px solid var(--border);border-radius:8px;cursor:pointer}
.check-control input,.terms-control input{width:18px;height:18px;margin-top:.1rem;accent-color:var(--red);flex:0 0 auto}
.check-control span{display:flex;flex-direction:column;gap:.1rem}
.check-control small{color:var(--ink-soft);font-weight:400}
.terms-control span{font-weight:400;color:var(--ink-soft);line-height:1.45}
.quote-panel{position:sticky;top:100px;background:var(--navy-900);color:#fff;border-radius:var(--radius-lg);padding:1.7rem;box-shadow:var(--shadow-lg)}
.quote-panel-head{display:flex;align-items:center;gap:1rem;padding-bottom:1.2rem;border-bottom:1px solid rgba(255,255,255,.12)}
.quote-panel-head>i{font-size:1.3rem;color:var(--gold);width:42px;height:42px;border-radius:8px;background:rgba(212,175,55,.12);display:grid;place-items:center}
.quote-panel-head span{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.62)}
.quote-panel-head strong{display:block;font-family:'Playfair Display',serif;font-size:1.4rem;margin-top:.2rem}
.quote-breakdown{padding:1rem 0;display:flex;flex-direction:column;gap:.55rem}
.quote-breakdown>div{display:flex;justify-content:space-between;gap:1rem;font-size:.85rem;color:rgba(255,255,255,.72)}
.quote-breakdown strong{color:#fff;font-weight:500}
.quote-due{display:flex;justify-content:space-between;align-items:end;padding:1rem 0;border-top:1px solid rgba(255,255,255,.12);margin-bottom:.5rem}
.quote-due span{font-size:.85rem;color:rgba(255,255,255,.72)}
.quote-due strong{font-family:'Playfair Display',serif;font-size:1.75rem;color:var(--gold)}
.quote-message{font-size:.82rem;color:rgba(255,255,255,.7);margin:0 0 1rem}
.quote-panel .btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.stripe-note{display:flex;align-items:center;gap:.7rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.12)}
.stripe-note i{font-size:2rem;color:#aeb8ff}
.stripe-note span,.quote-fineprint{font-size:.75rem;line-height:1.45;color:rgba(255,255,255,.62)}
.quote-fineprint{margin-top:.8rem}

@media(max-width:1280px){
  .booking-layout{grid-template-columns:1fr;max-width:960px}
  .quote-panel{position:relative;top:auto;width:100%}
}

/* ============ Responsive ============ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .services-grid,.why-grid,.testimonial-grid,.feature-grid,.price-grid,.blog-grid,.area-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid,.team-grid{grid-template-columns:repeat(2,1fr)}
  .split,.split.reverse{grid-template-columns:1fr;direction:ltr;gap:3rem}
  .facilities-inner,.contact-grid{grid-template-columns:1fr;gap:3rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}
@media(max-width:720px){
  .menu-toggle{display:block}
  .nav{
    position:absolute;top:100%;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;padding:1.5rem;gap:1rem;
    border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);
    display:none;
  }
  .nav.open{display:flex}
  .top-bar-right{display:none}
  .services-grid,.why-grid,.testimonial-grid,.process-grid,.footer-grid,.feature-grid,.price-grid,.blog-grid,.area-grid,.team-grid{grid-template-columns:1fr}
  .split,.split.reverse{grid-template-columns:1fr;direction:ltr;gap:2.5rem}
  .split-image{height:300px}
  .hero-cta,.cta-inner,.cta-buttons{flex-direction:column;align-items:stretch}
  .hero{padding:3rem 0 4rem;min-height:auto}
  .section{padding:4rem 0}
  .stat-card-1,.stat-card-2,.stat-card-3{position:relative;inset:auto;transform:none;margin:.5rem 0}
  .facilities-visual{min-height:auto;display:flex;flex-direction:column;gap:1rem}
  .visual-image{position:relative;height:280px;margin-top:1rem}
  .trust-strip-inner .divider{display:none}
  .form-row{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
