/* =========================================
   CABSMYSORE — PREMIUM LANDING (DX-style)
   ========================================= */
:root{
  /* Brand palette (same) */
  --cm-primary:#F7B104;
  --cm-primary-2:#FDC623;
  --cm-amber:#F9D160;
  --cm-gold:#F9E19C;

  /* Light theme base */
  --cm-bg:#F6F7FB;          /* page background */
  --cm-surface:#FFFFFF;     /* cards */
  --cm-text:#0C1017;        /* charcoal text */
  --cm-muted:#5F6166;       /* muted gray text */
  --cm-border:rgba(12,16,23,.10);
  --cm-white:#FDFDFD;

  --radius:18px;
  --shadow: 0 18px 50px rgba(12,16,23,.10);
  --ease: cubic-bezier(.2,.8,.2,1);
}
body{
  font-family: 'Rajdhani', sans-serif;
  font-weight: 500;
  letter-spacing: .3px;
}


*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(247,177,4,.18), transparent 55%),
    radial-gradient(900px 550px at 95% 0%, rgba(253,198,35,.12), transparent 60%),
    var(--cm-bg);
  color:var(--cm-text);
  line-height:1.55;
}
h1, h2, h3, h4 {
  font-weight: 700;
  letter-spacing: .8px;
}

p {
  font-weight: 500;
  line-height: 1.7;
}

.nav a,
.btn {
  font-weight: 600;
  letter-spacing: .6px;
}

/* =========================================================
   GLOBAL ELEMENTS
   ========================================================= */

a{
  color: inherit;
  text-decoration: none;
}

img{
  max-width: 100%;
  height: auto;
  display: block;
}

/* =========================================================
   UTILITIES
   ========================================================= */

.cm-muted{
  color: var(--cm-muted);
}

/* ---------- Chip (unified, no duplicate) ---------- */
.cm-chip{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem .8rem;
  border-radius: 999px;
  border: 1px solid rgba(12,16,23,.10);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: rgba(12,16,23,.85);
  font-weight: 800;
  font-size: .85rem;
  letter-spacing: .02em;
  transition: all .2s ease;
}

.cm-chip:hover{
  background: rgba(255,255,255,.95);
  border-color: rgba(244,180,0,.35);
}

/* ---------- Badge ---------- */
.cm-badge{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .35rem .7rem;
  border-radius: 999px;
  border: 1px solid rgba(244,180,0,.40);
  background: rgba(244,180,0,.18);
  color: #0C1017;
  font-weight: 900;
  font-size: .8rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* ---------- Card System ---------- */
.cm-card{
  border: 1px solid var(--cm-border);
  border-radius: var(--radius);
  background: linear-gradient(
    180deg,
    rgba(255,255,255,.98),
    rgba(255,255,255,.94)
  );
  box-shadow: var(--shadow);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}

.cm-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 50px rgba(12,16,23,.12);
  border-color: rgba(244,180,0,.25);
}

.cm-card--soft{
  box-shadow: 0 12px 32px rgba(12,16,23,.18);
}

/* ---------- Sections ---------- */
.cm-section{
  padding: 72px 0;
}

@media (max-width: 767px){
  .cm-section{
    padding: 56px 0;
  }
}

/* ---------- Heading System ---------- */
.cm-h2{
  font-size: clamp(1.55rem, 2.2vw, 2.2rem);
  margin: 0 0 .5rem 0;
  letter-spacing: -.02em;
  font-weight: 900;
  color: rgba(12,16,23,.95);
}

/* Optional: Lead paragraph consistency */
.cm-lead{
  color: rgba(12,16,23,.70);
  font-size: 1rem;
  line-height: 1.7;
  font-weight: 600;
}

/* =========================================================
   CABSMYSORE — FINAL PREMIUM HEADER CSS (RESPONSIVE)
   Works with your exact HTML:
   header.site-header > .container > .header-wrap
   + .brand + .nav.nav--capsule + .header-cta + .mobile-drawer
   ========================================================= */

/* ---------- Base ---------- */
.site-header{
  position: sticky;
  top: 0;
  z-index: 999;

  background:
    radial-gradient(900px 140px at 50% 0%, rgba(244,180,0,.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88));
  border-bottom: 1px solid rgba(12,16,23,.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.site-header.is-scrolled{
  background:
    radial-gradient(900px 140px at 50% 0%, rgba(244,180,0,.12), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));
  box-shadow: 0 16px 45px rgba(12,16,23,.10);
}

.header-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  padding: 10px 0;
}

/* Prevent overflow on mobile */
html, body{ overflow-x: hidden; }

/* ---------- Brand ---------- */
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  min-width: 0;              /* IMPORTANT: avoid overflow */
  flex: 1 1 auto;
}

.brand-mark{
  display:flex;
  align-items:center;
  min-width: 0;
}

/* Your logo image */
.brand-logoImg{
  width: 190px;
  max-width: 100%;
  height: auto;
  display:block;
  object-fit: contain;
}

/* (Optional) if you ever use brand-copy */
.brand-copy{display:flex;flex-direction:column;line-height:1.1}
.brand-name{
  font-weight: 900;
  letter-spacing: -.02em;
  color: rgba(12,16,23,.95);
  font-size: 1.06rem;
}
.brand-tag{
  margin-top: 3px;
  font-size: .88rem;
  color: rgba(12,16,23,.62);
}

/* ---------- Desktop nav capsule ---------- */
.nav{
  display:flex;
  align-items:center;
  gap: 18px;
}

.nav--capsule{
  display:flex;
  align-items:center;
  gap: 6px;
  padding: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(12,16,23,.10);
  box-shadow: 0 10px 30px rgba(12,16,23,.08);
}

.nav--capsule a{
  text-decoration:none;
  padding: .56rem .85rem;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: -.01em;
  color: rgba(12,16,23,.72);
  transition: background .2s ease, color .2s ease, transform .15s ease, border-color .2s ease;
}

.nav--capsule a:hover{
  background: rgba(12,16,23,.06);
  color: #0C1017;
  transform: translateY(-1px);
}

.nav--capsule a.is-active{
  background: rgba(244,180,0,.18);
  border: 1px solid rgba(244,180,0,.45);
  color: #0C1017;
}

/* ---------- Header CTA buttons ---------- */
.header-cta{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 10px;
  flex-wrap: wrap; /* IMPORTANT for mobile */
}

.header-cta .btn{
  height: 46px;
  border-radius: 999px;
  padding: 0 1.05rem;
  font-weight: 900;
  letter-spacing: -.01em;
  box-shadow: 0 14px 34px rgba(12,16,23,.10);
  white-space: nowrap;
}

.btn-ico{display:inline-flex;transform: translateY(-.5px)}

/* Keep your existing .btn system; just enhance */
.header-cta .btn-primary{
  box-shadow: 0 16px 36px rgba(244,180,0,.25);
}

.header-cta .btn-dark{
  background: rgba(12,16,23,.92);
  border-color: rgba(12,16,23,.92);
  color:#fff;
}
.header-cta .btn-dark:hover{ background: rgba(12,16,23,.98); }

.header-cta .btn-ghost{
  background: rgba(255,255,255,.72);
  border-color: rgba(12,16,23,.14);
  color: rgba(12,16,23,.92);
}
.header-cta .btn-ghost:hover{ background: rgba(255,255,255,.92); }

/* Focus (keyboard) */
.nav--capsule a:focus-visible,
.btn:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(244,180,0,.22);
}

/* ---------- Mobile toggle visibility ---------- */
.nav-toggle{ display:none; }

/* ---------- Mobile drawer ---------- */
.mobile-drawer{
  display:none;
  padding: 12px 0 18px 0;
}
.mobile-drawer.is-open{ display:block; }

.mobile-sheet{
  width: 100%;
  border-radius: 22px;
  border: 1px solid rgba(12,16,23,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 22px 70px rgba(12,16,23,.18);
  padding: 14px;
}

.mobile-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(12,16,23,.08);
}

.mobile-title{
  font-weight: 900;
  color: #0C1017;
}

.mobile-close{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(12,16,23,.10);
  background: rgba(12,16,23,.04);
  cursor:pointer;
  font-weight: 900;
}

.mobile-links{
  display:grid;
  gap: 8px;
  padding: 12px 0;
}

.mobile-links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  text-decoration:none;
  padding: 12px 12px;
  border-radius: 16px;
  font-weight: 900;
  color: rgba(12,16,23,.88);
  background: rgba(12,16,23,.03);
  border: 1px solid rgba(12,16,23,.06);
}

.mobile-links a:hover{
  background: rgba(244,180,0,.10);
  border-color: rgba(244,180,0,.35);
}

.mobile-ctaRow{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(12,16,23,.08);
}

/* =========================================================
   RESPONSIVE BREAKPOINTS
   ========================================================= */

/* Tablet / Mobile */
@media (max-width: 991px){

  /* hide desktop nav, show menu */
  .nav--capsule{ display:none; }
  .nav-toggle{ display:inline-flex; }

  .header-wrap{
    gap: 10px;
    padding: 10px 0;
  }

  /* logo smaller */
  .brand-logoImg{
    width: 150px;
  }

  /* compact CTA buttons */
  .header-cta .btn{
    height: 42px;
    padding: 0 12px;
    font-size: 13px;
  }

  /* Optional: keep both WhatsApp + Call visible, or hide Call to reduce crowding */
  /* If you want to hide Call in header on mobile, uncomment next line: */
  /* .header-cta a.btn.btn-dark{ display:none; } */

  /* drawer CTA stack on narrow screens via next breakpoint */
}

/* Small phones */
@media (max-width: 560px){

  .brand-logoImg{
    width: 130px;
  }

  .header-cta{
    gap: 6px;
  }

  /* Turn Menu into icon-only to save space */
  .nav-toggle{
    padding: 0 10px;
    font-size: 0; /* hide "Menu" text */
  }
  .nav-toggle .btn-ico{
    font-size: 16px; /* show icon */
    margin-right: 0;
  }

  /* Drawer CTA buttons stacked */
  .mobile-ctaRow{
    grid-template-columns: 1fr;
  }
  .mobile-ctaRow .btn{
    width: 100%;
  }
}
@media (max-width: 991px){
  .header-cta a.btn.btn-primary,
  .header-cta a.btn.btn-dark{
    display: none !important;
  }

  /* Ensure menu button stays visible */
  .header-cta .nav-toggle{
    display: inline-flex !important;
  }
}
/* ================================
   STICKY HEADER (FINAL)
   ================================ */

/* IMPORTANT: do NOT put overflow hidden on body/html for sticky.
   If you need to prevent horizontal scroll, use clip (safe). */
html, body{
  overflow-x: clip; /* instead of hidden */
}

/* If any wrapper has overflow set, sticky will break.
   Ensure main wrappers are visible. */
.page, .wrapper, main{
  overflow: visible;
}

.site-header{
  position: sticky;      /* stays at top while scrolling */
  top: 0;
  z-index: 9999;

  /* premium glass */
  background:
    radial-gradient(900px 140px at 50% 0%, rgba(244,180,0,.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.82));

  border-bottom: 1px solid rgba(12,16,23,.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  transition: box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

/* apply this class via JS when scrolled */
.site-header.is-scrolled{
  background:
    radial-gradient(900px 140px at 50% 0%, rgba(244,180,0,.12), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88));

  border-bottom-color: rgba(12,16,23,.10);
  box-shadow: 0 18px 50px rgba(12,16,23,.12);
}

/* Hero */
.hero{padding:64px 0 18px 0}
.hero-grid{
  display:grid;grid-template-columns: 1.25fr .75fr;gap:20px;align-items:stretch;
}
@media (max-width: 991px){
  .hero{padding:44px 0 14px 0}
  .hero-grid{grid-template-columns:1fr;gap:14px}
}
.hero-card{
  padding:28px;
  border-radius: calc(var(--radius) + 4px);
  position:relative;
  overflow:hidden;
}
.hero-card::before{
  content:"";
  position:absolute;inset:-2px;
  background:
    radial-gradient(800px 340px at 10% 0%, rgba(247,177,4,.22), transparent 60%),
    radial-gradient(700px 320px at 95% 10%, rgba(253,198,35,.16), transparent 60%);
  pointer-events:none;
}

.hero-card > *{position:relative}
.hero h1{
  margin:0 0 10px 0;
  font-size: clamp(2.0rem, 4vw, 3.1rem);
  line-height:1.08;
  letter-spacing:-.03em;
}
.hero p{margin:0 0 16px 0;color:rgba(255,255,255,.86);max-width:70ch}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.hero-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.hero-aside{
  padding:22px;
}
.kpi{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px
}
.kpi .cm-card{padding:14px}
.kpi strong{display:block;font-size:1.05rem}
.kpi span{font-size:.9rem;color:rgba(255,255,255,.78)}
/* Image placeholders */
.img-ph{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(12,16,23,.10);
  background:
    radial-gradient(240px 160px at 20% 20%, rgba(247,177,4,.20), transparent 65%),
    radial-gradient(260px 170px at 80% 30%, rgba(253,198,35,.14), transparent 70%),
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,255,255,.75));
  min-height: 220px;
}
.img-ph .img-label{
  position:absolute;left:14px;bottom:14px;
  padding:.45rem .65rem;border-radius:999px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(12,16,23,.12);
  color:#0C1017;
  font-weight:800;font-size:.86rem;
}

.img-ph::after{
  content:"";
  position:absolute;inset:0;
  backdrop-filter: blur(2px);
  opacity:.35;
}

/* Grids */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width: 991px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 575px){
  .grid-4,.grid-3{grid-template-columns:1fr}
}
.card-pad{padding:18px}
.card-title{margin:0 0 6px 0;font-weight:900;letter-spacing:-.02em}

.card-meta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}

/* Package cards */
.pkg{
  padding:18px;
}
.pkg .top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px
}
.pkg h3{margin:0;font-size:1.1rem;letter-spacing:-.02em}
.pkg ul{margin:12px 0 0 18px;color:rgba(255,255,255,.84)}
.pkg li{margin:4px 0}
.pkg .bestfor{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.pkg .cta{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}

/* Pricing logic */
.steps{counter-reset: step}
.step{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
}
.step::before{
  counter-increment: step;
  content: counter(step);
  flex:0 0 auto;
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background: rgba(247,177,4,.18);
  border:1px solid rgba(247,177,4,.28);
  font-weight:900;
}
.step p{margin:0;color:rgba(255,255,255,.84)}

/* Testimonials */
.quote{
  padding:18px;
}
.quote p{margin:0 0 12px 0;color:rgba(255,255,255,.86)}
.quote .by{display:flex;flex-direction:column}
.quote .by strong{font-weight:900}
.quote .by span{color:rgba(255,255,255,.70);font-size:.92rem}

/* FAQ */
.faq-item{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  border-radius:16px;
  overflow:hidden;
}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 16px;
  background:transparent;
  border:0;
  color:#fff;
  font-weight:900;
  cursor:pointer;
  text-align:left;
}
.faq-a{
  padding:0 16px 14px 16px;
  color:rgba(255,255,255,.84);
  display:none;
}
.faq-item.is-open .faq-a{display:block}
.faq-icon{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
}

/* Contact */
.nap{
  display:grid;grid-template-columns:1fr 1fr;gap:14px
}
@media (max-width: 767px){.nap{grid-template-columns:1fr}}
.nap a{text-decoration:none}
.nap .cm-card{padding:16px}

/* Footer */
.footer{
  border-top:1px solid rgba(12,16,23,.10);
  background: rgba(255,255,255,.78);
  padding:34px 0 90px 0;
}


.mobile-cta{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:12px;z-index:60;
  display:none;
  width:min(560px, calc(100% - 24px));
  padding:10px;
  border-radius:20px;
  border:1px solid rgba(12,16,23,.12);
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(12px);
  box-shadow: 0 16px 45px rgba(12,16,23,.14);
}

.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:18px}
@media (max-width: 991px){.footer-grid{grid-template-columns:1fr;gap:14px}}

/* Mobile sticky CTA bar */
.mobile-cta{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:12px;z-index:60;
  display:none;
  width:min(560px, calc(100% - 24px));
  padding:10px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(12,16,23,.78);
  backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(0,0,0,.40);
}
.mobile-cta .inner{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mobile-cta .btn{padding:.75rem .9rem;border-radius:16px}
@media (max-width: 991px){.mobile-cta{display:block}}

/* Forms (optional) */
.input{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(12,16,23,.14);
  background: rgba(255,255,255,.92);
  color:#0C1017;
  outline:none;
}
.input:focus{
  border-color: rgba(247,177,4,.65);
  box-shadow: 0 0 0 4px rgba(247,177,4,.18);
}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 575px){.form-row{grid-template-columns:1fr}}
.form-help{font-size:.9rem;color:rgba(255,255,255,.70)}
