/* =====================================================
   Pink City Cabs · Jaipur Taxi Service
   Premium mobile-first stylesheet
   ===================================================== */

/* ---------- Design Tokens ---------- */
:root{
  --pink:        #E91E63;
  --pink-dark:   #AD1457;
  --pink-deep:   #880E4F;
  --pink-soft:   #FCE4EC;
  --saffron:     #FF9933;
  --saffron-soft:#FFF3E0;
  --royal:       #5E35B1;
  --royal-soft:  #EDE7F6;
  --gold:        #F9A825;
  --gold-bright: #FFD600;
  --green:       #25D366;
  --green-dark:  #128C7E;

  --ink:         #0F1419;
  --ink-soft:    #2A3441;
  --muted:       #6B7280;
  --muted-soft:  #9CA3AF;
  --line:        #E5E7EB;
  --line-soft:   #F3F4F6;

  --bg:          #FFFFFF;
  --bg-soft:     #FAFAFB;
  --bg-cream:    #FFF8F1;

  --shadow-sm:   0 1px 2px rgba(15,20,25,.06), 0 1px 3px rgba(15,20,25,.04);
  --shadow:      0 4px 14px rgba(15,20,25,.08), 0 2px 6px rgba(15,20,25,.04);
  --shadow-lg:   0 16px 40px rgba(15,20,25,.10), 0 6px 16px rgba(15,20,25,.06);
  --shadow-pink: 0 14px 36px rgba(233,30,99,.32);

  --radius-sm:   10px;
  --radius:      16px;
  --radius-lg:   22px;
  --radius-xl:   28px;

  --gradient-primary: linear-gradient(135deg, #E91E63 0%, #AD1457 50%, #880E4F 100%);
  --gradient-warm:    linear-gradient(135deg, #FF9933 0%, #E91E63 100%);
  --gradient-royal:   linear-gradient(135deg, #5E35B1 0%, #E91E63 100%);
  --gradient-gold:    linear-gradient(135deg, #FFD600 0%, #F9A825 100%);

  --ease: cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter','Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  padding-bottom:88px; /* room for sticky bottom call bar on mobile */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

h1,h2,h3,h4,h5{
  font-family:'Poppins','Inter','Segoe UI',sans-serif;
  font-weight:800;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink);
  margin:0 0 .5em;
}

img{max-width:100%;display:block;height:auto}
a{color:var(--pink-dark);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--pink)}
button{font-family:inherit}

.container{max-width:1180px;margin:0 auto;padding:0 18px}
@media (min-width:900px){ .container{padding:0 24px} }

/* ---------- Reveal animation (added by JS) ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}

/* ---------- Top notice bar ---------- */
.topbar{
  background:linear-gradient(90deg,#0F1419 0%,#2A3441 100%);
  color:#fff;
  font-size:13px;
  padding:8px 16px;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
}
.topbar a{color:#fff;font-weight:600}
.topbar .badge-est{
  background:var(--gradient-gold);color:#000;
  padding:3px 10px;border-radius:20px;
  font-size:11px;font-weight:800;letter-spacing:.5px;
}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
  padding:12px 16px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
@media (min-width:900px){ .header{padding:14px 24px} }

.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.brand-logo{
  width:46px;height:46px;border-radius:14px;
  background:var(--gradient-primary);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:900;font-size:22px;
  font-family:'Poppins',sans-serif;
  box-shadow:var(--shadow-pink);
  position:relative;overflow:hidden;
}
.brand-logo::after{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);
  transform:rotate(45deg);
}
.brand-name{font-weight:800;font-size:17px;line-height:1.1;letter-spacing:-.01em}
.brand-tag{font-size:11px;color:var(--muted);font-weight:500}

.header-nav{display:none;gap:24px;align-items:center}
.header-nav a{color:var(--ink-soft);font-weight:600;font-size:14px}
.header-nav a:hover{color:var(--pink)}
@media (min-width:1000px){ .header-nav{display:flex} }

.btn-call-top{
  background:var(--green);color:#fff;font-weight:700;
  padding:10px 16px;border-radius:30px;font-size:14px;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 6px 16px rgba(37,211,102,.36);
  transition:all .2s var(--ease);
}
.btn-call-top:hover{background:var(--green-dark);color:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(37,211,102,.45)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;border:none;
  font-family:inherit;font-size:15px;font-weight:700;
  padding:14px 22px;border-radius:14px;text-align:center;
  transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  text-decoration:none;
}
.btn:hover{text-decoration:none}

.btn-primary{
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:var(--shadow-pink);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transition:left .6s var(--ease);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(233,30,99,.42);color:#fff}
.btn-primary:hover::before{left:100%}
.btn-primary:active{transform:translateY(0)}

.btn-call-big{
  background:var(--green);color:#fff;
  box-shadow:0 8px 20px rgba(37,211,102,.36);
}
.btn-call-big:hover{background:var(--green-dark);color:#fff;transform:translateY(-2px);box-shadow:0 12px 28px rgba(37,211,102,.5)}

.btn-ghost{
  background:#fff;color:var(--ink);
  border:2px solid var(--line);
}
.btn-ghost:hover{border-color:var(--pink);color:var(--pink)}

.btn-block{width:100%}
.btn-lg{padding:16px 26px;font-size:16px;border-radius:16px}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  background:
    radial-gradient(ellipse at top right, rgba(255,153,51,.18), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(94,53,177,.18), transparent 50%),
    linear-gradient(135deg, #1A0B14 0%, #2D1325 40%, #4A1B3C 100%);
  color:#fff;
  padding:32px 16px 40px;
  overflow:hidden;
}
.hero::before{
  /* Decorative mandala-style dots */
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 25%, rgba(255,255,255,.08) 1.5px, transparent 2px),
    radial-gradient(circle at 85% 75%, rgba(255,153,51,.18) 1.5px, transparent 2.5px),
    radial-gradient(circle at 60% 15%, rgba(255,255,255,.06) 1px, transparent 2px);
  background-size:60px 60px, 80px 80px, 40px 40px;
  pointer-events:none;
}
.hero::after{
  /* Glow blobs */
  content:'';position:absolute;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(233,30,99,.4),transparent 70%);
  bottom:-100px;right:-80px;filter:blur(40px);
  pointer-events:none;
}

.hero-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto}
@media (min-width:1000px){
  .hero-inner{display:grid;grid-template-columns:1.05fr 420px;gap:48px;align-items:center}
}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(8px);
  padding:7px 14px;border-radius:30px;
  font-size:12px;font-weight:700;letter-spacing:.4px;
  text-transform:uppercase;color:#fff;
  margin-bottom:18px;
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(37,211,102,.3);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(37,211,102,.3)}50%{box-shadow:0 0 0 8px rgba(37,211,102,.05)}}

.hero h1{
  font-size:34px;line-height:1.1;
  margin:0 0 14px;
  font-weight:900;letter-spacing:-.03em;color:#fff;
}
.hero h1 .accent{
  background:linear-gradient(135deg,#FFD600 0%,#FF9933 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.hero .sub{
  font-size:16px;line-height:1.6;color:rgba(255,255,255,.85);
  margin:0 0 22px;max-width:560px;
}

.hero-trust{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;
}
.hero-trust span{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.20);
  backdrop-filter:blur(8px);
  padding:7px 12px;border-radius:24px;
  font-size:12.5px;font-weight:600;color:#fff;
  display:inline-flex;align-items:center;gap:5px;
}
.hero-trust span svg{width:14px;height:14px;flex-shrink:0}

.hero-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  padding:16px;border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(10px);
}
.hero-stat{text-align:center}
.hero-stat-num{
  font-family:'Poppins',sans-serif;
  font-size:22px;font-weight:800;color:#FFD600;line-height:1;
}
.hero-stat-lbl{font-size:11px;color:rgba(255,255,255,.7);font-weight:600;margin-top:4px;letter-spacing:.3px;text-transform:uppercase}

.hero-taxi-wrap{
  display:flex;justify-content:center;align-items:center;
  margin:24px 0 8px;
}
.hero-taxi{
  width:100%;max-width:340px;height:auto;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.45));
  animation:taxiBounce 4s ease-in-out infinite;
}
@keyframes taxiBounce{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-8px) rotate(-.5deg)}
}
@media (min-width:1000px){
  .hero{padding:60px 24px 80px}
  .hero h1{font-size:48px}
  .hero .sub{font-size:17px}
  .hero-taxi-wrap{display:none} /* desktop: form takes the right column */
}

/* ---------- Booking form (glassmorphic) ---------- */
.booking-card{
  background:rgba(255,255,255,.98);
  border:1px solid rgba(255,255,255,.6);
  border-radius:var(--radius-lg);
  padding:22px 20px;
  box-shadow:0 24px 60px rgba(0,0,0,.32), 0 8px 24px rgba(0,0,0,.18);
  position:relative;
  margin-top:6px;
}
.booking-card::before{
  /* Top accent bar */
  content:'';position:absolute;top:0;left:24px;right:24px;height:3px;
  background:var(--gradient-primary);border-radius:0 0 4px 4px;
}
.booking-card-head{
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;
}
.booking-card-head h2{
  margin:0;font-size:20px;color:var(--pink-dark);font-weight:800;
}
.booking-card-head .ico{
  width:40px;height:40px;border-radius:12px;
  background:var(--gradient-primary);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:#fff;
  box-shadow:0 6px 16px rgba(233,30,99,.35);
}
.booking-card .lead{font-size:13px;color:var(--muted);margin:0 0 16px;line-height:1.5}

.form-row{display:grid;gap:10px;margin-bottom:12px}
.form-row.two{grid-template-columns:1fr 1fr}
@media (max-width:380px){ .form-row.two{grid-template-columns:1fr} }

label{
  display:block;font-size:12.5px;font-weight:600;
  margin-bottom:6px;color:var(--ink-soft);
  letter-spacing:.1px;
}

.input,.select,.textarea{
  width:100%;
  border:1.5px solid var(--line);
  border-radius:12px;
  padding:13px 14px;
  font-size:15px;
  font-family:inherit;
  background:#fff;color:var(--ink);
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  appearance:none;-webkit-appearance:none;
}
.select{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3e%3cpath fill='%236B7280' d='M6 8L0 0h12z'/%3e%3c/svg%3e");
  background-repeat:no-repeat;background-position:right 14px center;
  padding-right:38px;
}
.input:focus,.select:focus,.textarea:focus{
  outline:none;border-color:var(--pink);
  background:#fff;
  box-shadow:0 0 0 4px rgba(233,30,99,.12);
}
.textarea{min-height:72px;resize:vertical;line-height:1.5}

.btn-block{width:100%}
.form-foot{font-size:11px;color:var(--muted);text-align:center;margin:12px 0 0}
.form-divider{
  display:flex;align-items:center;gap:8px;margin:10px 0;
  color:var(--muted-soft);font-size:11px;font-weight:600;
}
.form-divider::before,.form-divider::after{
  content:'';flex:1;height:1px;background:var(--line);
}

.field-error{color:#C62828;font-size:12px;margin-top:4px;display:block}

/* ---------- Sections ---------- */
.section{padding:56px 0}
@media (min-width:900px){ .section{padding:90px 0} }
.section.alt{background:var(--bg-soft)}
.section.cream{background:var(--bg-cream)}

.section-head{text-align:center;margin-bottom:36px}
.section-head .eyebrow{
  display:inline-block;
  background:var(--pink-soft);color:var(--pink-dark);
  padding:5px 12px;border-radius:30px;
  font-size:11.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;
  margin-bottom:12px;
}
.section-head h2{
  font-size:28px;margin:0 0 8px;
  letter-spacing:-.02em;
}
@media (min-width:900px){ .section-head h2{font-size:38px} }
.section-head .sub{
  font-size:15px;color:var(--muted);
  max-width:640px;margin:0 auto;line-height:1.6;
}
@media (min-width:900px){ .section-head .sub{font-size:16px} }

/* ---------- Trust strip (between hero and rest) ---------- */
.trust-strip{
  background:#fff;
  border-bottom:1px solid var(--line);
  padding:16px 0;
}
.trust-strip-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
@media (min-width:700px){ .trust-strip-grid{grid-template-columns:repeat(4,1fr)} }
.trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:13.5px;font-weight:600;color:var(--ink-soft);
}
.trust-item .ico{
  width:38px;height:38px;border-radius:12px;
  background:var(--pink-soft);color:var(--pink-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}

/* ---------- Stats section ---------- */
.stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
@media (min-width:700px){ .stats{grid-template-columns:repeat(4,1fr)} }
.stat{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px 16px;text-align:center;
  box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  position:relative;overflow:hidden;
}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.stat::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gradient-primary);
}
.stat .num{
  font-family:'Poppins',sans-serif;
  font-size:32px;font-weight:900;
  background:var(--gradient-primary);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;line-height:1;margin-bottom:6px;
}
.stat .lbl{
  font-size:12px;color:var(--muted);font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
}

/* ---------- Big services (Local + Outstation) ---------- */
.big-services{display:grid;grid-template-columns:1fr;gap:22px}
@media (min-width:900px){ .big-services{grid-template-columns:1fr 1fr;gap:28px} }
.big-service{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  position:relative;
}
.big-service:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.big-service-img{
  position:relative;
  background:linear-gradient(135deg,#FCE4EC 0%,#FFF8F1 100%);
  padding:30px 24px 18px;text-align:center;
  overflow:hidden;
}
.big-service:nth-child(2) .big-service-img{
  background:linear-gradient(135deg,#E3F2FD 0%,#FFF8F1 100%);
}
.big-service-img::after{
  content:'';position:absolute;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(233,30,99,.18),transparent 70%);
  top:-80px;right:-60px;filter:blur(20px);
}
.big-service:nth-child(2) .big-service-img::after{
  background:radial-gradient(circle,rgba(25,118,210,.18),transparent 70%);
}
.big-service-img img{
  position:relative;z-index:2;
  max-width:260px;width:90%;height:auto;margin:0 auto;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.18));
}
.big-service-body{padding:22px 22px 26px}
.bs-tag{
  display:inline-block;
  background:var(--gradient-primary);color:#fff;
  font-size:11px;font-weight:800;
  padding:5px 12px;border-radius:24px;
  letter-spacing:1px;text-transform:uppercase;
  margin-bottom:10px;
  box-shadow:0 4px 12px rgba(233,30,99,.3);
}
.big-service:nth-child(2) .bs-tag{background:linear-gradient(135deg,#1976D2,#0D47A1);box-shadow:0 4px 12px rgba(25,118,210,.3)}
.big-service h3{margin:0 0 8px;font-size:22px;font-weight:800}
.bs-lead{margin:0 0 14px;font-size:14.5px;color:var(--muted);line-height:1.55}
.bs-points{
  list-style:none;padding:0;margin:0 0 20px;
  font-size:14px;color:var(--ink-soft);
}
.bs-points li{
  padding:9px 0 9px 26px;border-bottom:1px dashed var(--line-soft);
  line-height:1.5;position:relative;
}
.bs-points li::before{
  content:'✓';position:absolute;left:0;top:9px;
  width:18px;height:18px;border-radius:50%;
  background:var(--pink-soft);color:var(--pink-dark);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:12px;
}
.big-service:nth-child(2) .bs-points li::before{background:#E3F2FD;color:#1565C0}
.bs-points li:last-child{border-bottom:none}
.bs-cta{display:grid;gap:8px}
.bs-cta .btn{font-size:15px;padding:13px}

/* ---------- How it works (4 steps) ---------- */
.steps{
  display:grid;grid-template-columns:1fr;gap:18px;
}
@media (min-width:700px){ .steps{grid-template-columns:repeat(2,1fr)} }
@media (min-width:1000px){ .steps{grid-template-columns:repeat(4,1fr)} }
.step{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 22px 22px;
  text-align:left;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--pink-soft)}
.step-num{
  font-family:'Poppins',sans-serif;
  font-size:48px;font-weight:900;line-height:1;
  background:var(--gradient-primary);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  opacity:.92;
  margin-bottom:8px;
}
.step h3{font-size:17px;font-weight:800;margin:0 0 6px}
.step p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.55}
.step-ico{
  position:absolute;top:18px;right:18px;
  width:36px;height:36px;border-radius:10px;
  background:var(--pink-soft);color:var(--pink-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;
}

/* ---------- Fleet ---------- */
.fleet-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (min-width:700px){ .fleet-grid{grid-template-columns:repeat(4,1fr)} }
.fleet-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px 14px 18px;text-align:center;
  box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  cursor:default;position:relative;overflow:hidden;
}
.fleet-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:90px;
  background:linear-gradient(180deg,var(--pink-soft) 0%,transparent 100%);
  opacity:.4;
}
.fleet-item > *{position:relative;z-index:1}
.fleet-item:hover{
  transform:translateY(-6px) rotate(-.5deg);
  box-shadow:var(--shadow-lg);
  border-color:var(--pink-soft);
}
.fleet-item img{
  width:100%;max-width:170px;height:auto;
  margin:6px auto 8px;
}
.fleet-item h4{margin:4px 0 4px;font-size:15px;font-weight:800;color:var(--ink)}
.fleet-item .seats{font-size:12.5px;color:var(--pink-dark);font-weight:800}
.fleet-item small{display:block;font-size:11.5px;color:var(--muted);margin-top:4px}

/* ---------- Highlights of Jaipur (premium magazine style) ---------- */
.highlights-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
@media (min-width:700px){ .highlights-grid{grid-template-columns:repeat(3,1fr)} }
@media (min-width:1100px){ .highlights-grid{grid-template-columns:repeat(4,1fr)} }

.hl-card{
  display:block;
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  text-decoration:none;color:inherit;
  border:1px solid var(--line);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  position:relative;
}
.hl-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  text-decoration:none;color:inherit;
  border-color:transparent;
}

.hl-banner{
  position:relative;height:150px;
  background:linear-gradient(135deg, var(--c1, #E91E63), var(--c2, #AD1457));
  overflow:hidden;
}
.hl-banner img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  display:block;
  transition:transform .6s var(--ease);
}
.hl-card:hover .hl-banner img{transform:scale(1.08)}
.hl-banner::after{
  /* Mandala-style decorative pattern overlay */
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 25% 30%, rgba(255,255,255,.20) 1.5px, transparent 2px),
    radial-gradient(circle at 75% 70%, rgba(255,255,255,.14) 1px, transparent 2px),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.06) 25px, transparent 26px);
  background-size:30px 30px, 40px 40px, 100% 100%;
  pointer-events:none;
}
.hl-icon{
  position:absolute;top:12px;right:12px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.96);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  z-index:2;
  box-shadow:0 4px 14px rgba(0,0,0,.22);
  transition:transform .3s var(--ease);
}
.hl-card:hover .hl-icon{transform:scale(1.1) rotate(8deg)}
.hl-name{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.55) 50%, rgba(0,0,0,.85) 100%);
  color:#fff;
  padding:30px 14px 12px;
  font-family:'Poppins',sans-serif;
  font-weight:800;font-size:16px;
  letter-spacing:.2px;
  text-shadow:0 2px 4px rgba(0,0,0,.4);
  z-index:1;line-height:1.2;
}
.hl-body{padding:14px 16px 16px}
.hl-body p{
  margin:0;font-size:13.5px;line-height:1.55;color:var(--muted);
}

/* ---------- Routes ---------- */
.routes{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (min-width:700px){ .routes{grid-template-columns:repeat(3,1fr)} }
.route{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;display:flex;justify-content:space-between;align-items:center;
  text-decoration:none;color:inherit;
  transition:all .25s var(--ease);
  position:relative;overflow:hidden;
}
.route::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--gradient-primary);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .25s var(--ease);
}
.route:hover{
  border-color:var(--pink);
  transform:translateX(4px);
  box-shadow:var(--shadow);
  text-decoration:none;color:inherit;
}
.route:hover::before{transform:scaleY(1)}
.route strong{font-size:14px;font-weight:700;display:block}
.route .km{font-size:12px;color:var(--muted);margin-top:2px}
.route-arrow{
  font-size:22px;color:var(--pink);font-weight:700;
  transition:transform .25s var(--ease);
}
.route:hover .route-arrow{transform:translateX(4px)}

/* ---------- Why choose us ---------- */
.features{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:700px){ .features{grid-template-columns:repeat(2,1fr)} }
@media (min-width:1000px){ .features{grid-template-columns:repeat(3,1fr)} }
.feature{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature-ico{
  width:52px;height:52px;border-radius:14px;
  background:var(--gradient-primary);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:14px;
  box-shadow:0 8px 18px rgba(233,30,99,.3);
}
.feature h3{margin:0 0 6px;font-size:17px;font-weight:800}
.feature p{margin:0;font-size:14px;color:var(--muted);line-height:1.55}

/* ---------- Reviews ---------- */
.reviews{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:700px){ .reviews{grid-template-columns:repeat(3,1fr)} }
.review{
  background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow-sm);
  position:relative;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.review::before{
  content:'"';position:absolute;top:8px;right:18px;
  font-family:'Poppins','Georgia',serif;
  font-size:80px;font-weight:900;line-height:1;
  color:var(--pink-soft);
  opacity:.7;
}
.review:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.review .stars{color:var(--gold);font-size:16px;letter-spacing:2px;margin-bottom:8px}
.review p{font-size:14.5px;color:var(--ink-soft);margin:0 0 14px;line-height:1.6;position:relative;z-index:1}
.review-author{display:flex;align-items:center;gap:10px}
.review-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--gradient-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:16px;
  box-shadow:0 4px 10px rgba(233,30,99,.3);
}
.review .who{font-size:14px;font-weight:700;color:var(--ink)}
.review .where{font-size:12px;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:0;margin-bottom:10px;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.faq details[open]{border-color:var(--pink);box-shadow:0 6px 20px rgba(233,30,99,.1)}
.faq summary{
  font-size:15px;font-weight:700;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:16px 18px;
  color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:'+';
  width:28px;height:28px;border-radius:50%;
  background:var(--pink-soft);color:var(--pink-dark);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;line-height:1;flex-shrink:0;
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.faq details[open] summary::after{
  content:'−';
  background:var(--pink);color:#fff;
  transform:rotate(180deg);
}
.faq p{
  margin:0;padding:0 18px 18px;
  font-size:14px;color:var(--muted);line-height:1.6;
}

/* ---------- CTA banner (premium multi-layer) ---------- */
.cta-banner{
  position:relative;
  background:
    radial-gradient(circle at 80% 20%, rgba(255,153,51,.5), transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(94,53,177,.5), transparent 50%),
    var(--gradient-primary);
  color:#fff;
  padding:54px 20px;text-align:center;
  overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.10) 2px, transparent 3px),
    radial-gradient(circle at 70% 70%, rgba(255,255,255,.06) 1.5px, transparent 2.5px);
  background-size:50px 50px, 70px 70px;
  pointer-events:none;
}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{color:#fff;font-size:30px;margin:0 0 10px}
@media (min-width:900px){ .cta-banner h2{font-size:42px} }
.cta-banner p{margin:0 0 22px;font-size:16px;opacity:.95;max-width:560px;margin-left:auto;margin-right:auto}
.cta-banner .btns{
  display:flex;flex-direction:column;gap:10px;
  max-width:380px;margin:0 auto;
}
@media (min-width:600px){ .cta-banner .btns{flex-direction:row;justify-content:center} }
.cta-banner .btns .btn{flex:1;min-width:160px}
.cta-banner .btn-call-big{background:#fff;color:var(--pink-dark);box-shadow:0 8px 22px rgba(0,0,0,.25)}
.cta-banner .btn-call-big:hover{background:#FFF8F1;color:var(--pink-deep)}
.cta-banner .btn-wa{background:var(--green);color:#fff;box-shadow:0 8px 22px rgba(37,211,102,.4)}

/* ---------- Footer ---------- */
.footer{
  background:linear-gradient(180deg,#0F1419 0%,#1A1F26 100%);
  color:#9CA3AF;
  padding:50px 16px 24px;font-size:14px;
}
.footer h4{
  color:#fff;font-size:14px;
  margin:0 0 12px;
  letter-spacing:.5px;text-transform:uppercase;font-weight:700;
}
.footer .cols{display:grid;grid-template-columns:1fr;gap:28px}
@media (min-width:700px){ .footer .cols{grid-template-columns:repeat(2,1fr)} }
@media (min-width:1000px){ .footer .cols{grid-template-columns:1.3fr 1fr 1fr 1fr} }
.footer p{margin:0 0 12px;line-height:1.7}
.footer a{color:#9CA3AF;display:inline-block;padding:1px 0}
.footer a:hover{color:#fff}
.footer .footer-brand{
  display:flex;align-items:center;gap:12px;margin-bottom:12px;
}
.footer .footer-brand .brand-logo{box-shadow:0 6px 16px rgba(233,30,99,.4)}
.footer .footer-brand-name{
  font-family:'Poppins',sans-serif;font-weight:800;font-size:18px;color:#fff;
}
.footer .social{display:flex;gap:10px;margin-top:14px}
.footer .social a{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:#fff;
  transition:background .2s var(--ease);
}
.footer .social a:hover{background:var(--pink)}
.footer-bottom{
  text-align:center;border-top:1px solid rgba(255,255,255,.08);
  margin-top:32px;padding-top:18px;font-size:12.5px;color:#6B7280;
}
.footer-bottom span{color:var(--pink)}

/* ---------- Sticky bottom call bar (mobile) ---------- */
.fixed-call{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  display:grid;grid-template-columns:1fr 1fr;
  background:#fff;
  box-shadow:0 -6px 22px rgba(0,0,0,.12);
  border-top:1px solid var(--line);
}
.fixed-call a{
  padding:14px 8px;text-align:center;font-weight:800;font-size:14px;
  color:#fff;display:flex;align-items:center;justify-content:center;gap:6px;
  letter-spacing:.3px;
}
.fixed-call .fc-call{background:var(--green)}
.fixed-call .fc-book{background:var(--gradient-primary)}
.fixed-call a:hover{text-decoration:none;color:#fff;opacity:.95}
@media (min-width:1000px){
  .fixed-call{display:none}
  body{padding-bottom:0}
}

/* ---------- WhatsApp floating ---------- */
.wa-float{
  position:fixed;right:14px;bottom:96px;z-index:99;
  width:56px;height:56px;border-radius:50%;
  background:var(--green);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:30px;
  box-shadow:0 8px 22px rgba(37,211,102,.5);
  text-decoration:none;
  transition:transform .25s var(--ease);
}
.wa-float::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  background:rgba(37,211,102,.4);
  animation:waPulse 2s infinite;z-index:-1;
}
@keyframes waPulse{
  0%{transform:scale(1);opacity:1}
  100%{transform:scale(1.5);opacity:0}
}
.wa-float:hover{background:var(--green-dark);color:#fff;text-decoration:none;transform:scale(1.1)}
@media (min-width:1000px){ .wa-float{bottom:24px;right:24px} }

/* ---------- Alerts ---------- */
.alert{
  padding:13px 16px;border-radius:12px;
  margin-bottom:14px;font-size:13.5px;font-weight:600;
}
.alert-error{background:#FEE2E2;color:#991B1B;border:1px solid #FECACA}
.alert-success{background:#DCFCE7;color:#166534;border:1px solid #BBF7D0}

/* ---------- Admin panel (kept readable) ---------- */
.admin-wrap{max-width:1200px;margin:24px auto;padding:0 14px}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;margin-bottom:18px}
.admin-card h2{margin:0 0 14px;font-size:18px}
.table-wrap{overflow-x:auto}
table.leads{width:100%;border-collapse:collapse;font-size:13px;min-width:760px}
table.leads th,table.leads td{padding:10px 8px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top}
table.leads th{background:#FAFAFA;font-size:12px;text-transform:uppercase;color:#666;font-weight:700;letter-spacing:.4px}
table.leads tr:hover{background:#FFF8FB}
.tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.tag-new{background:#DBEAFE;color:#1E40AF}
.tag-contacted{background:#FEF3C7;color:#92400E}
.tag-confirmed{background:#DCFCE7;color:#166534}
.tag-completed{background:#F3F4F6;color:#374151}
.tag-cancelled{background:#FEE2E2;color:#991B1B}

.login-box{
  max-width:400px;margin:80px auto;
  background:#fff;padding:32px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.login-box h1{margin:0 0 6px;font-size:24px;color:var(--pink-dark)}
.login-box .lead{font-size:13.5px;color:var(--muted);margin:0 0 22px}
