/* ===== Fluent Academy & Immigration Consultants - Modern/Tech Premium Theme ===== */
:root{
  --bg: #f6f8fb;
  --text: #0b1220;
  --muted: #5a6b86;

  --card: #ffffff;
  --border: rgba(14, 41, 84, 0.10);
  --shadow: 0 12px 28px rgba(12, 28, 56, 0.10);

  /* Modern tech brand */
  --brand: #0f766e;     /* teal-green */
  --brand2:#16a34a;     /* green */
  --brand3:#0b3a5a;     /* deep slate blue */
  --glow: rgba(15,118,110,.18);

  --radius: 18px;
  --max: 1240px;

  --h1: clamp(40px, 4vw, 60px);
  --h2: clamp(28px, 2.4vw, 38px);
  --p: 18px;
}

*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  margin:0;
  background: var(--bg);
  color: var(--text);
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-size: var(--p);
  line-height: 1.75;
}

a{ color:inherit; text-decoration:none }
.container{ max-width: var(--max); margin:0 auto; padding:0 20px }

/* Soft modern background energy */
body::before{
  content:"";
  position: fixed;
  inset: -200px;
  z-index: -1;
  background:
    radial-gradient(900px 480px at 15% 0%, rgba(15,118,110,.07), transparent 60%),
    radial-gradient(900px 520px at 85% 10%, rgba(11,58,90,.06), transparent 55%),
    radial-gradient(700px 400px at 30% 90%, rgba(22,163,74,.05), transparent 55%);
  pointer-events:none;
}

/* ===== NAV ===== */
.nav{
  position: sticky; top:0; z-index: 99;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .2s ease, background .2s ease;
}
.nav.scrolled{
  box-shadow: 0 10px 24px rgba(12,28,56,.10);
  background: rgba(255,255,255,.90);
}
.nav-inner{
  position: relative;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0; gap:10px;
  transition: padding .2s ease;
}
.nav.scrolled .nav-inner{ padding:10px 0; }

.brand{ display:flex; align-items:center; gap:12px; min-width: 260px; }
.logo{
  width:46px; height:46px; border-radius: 14px;
  object-fit: cover;
  background: linear-gradient(135deg, var(--brand3), var(--brand));
  box-shadow: 0 10px 24px rgba(11,58,90,.18);
}
.brand h1{ font-size: 15px; margin:0; line-height: 1.1; font-weight: 800; letter-spacing: .2px }
.brand small{ display:block; margin-top:3px; color: var(--muted); font-weight: 600 }

.nav-links{ display:flex; align-items:center; gap:8px; flex-wrap:wrap }
.nav-links a{
  padding:10px 12px; border-radius: 12px;
  font-weight: 700; font-size: 14px;
  color: #0b1220;
}
.nav-links a:hover{ background: rgba(15,118,110,.08) }
.nav-links a.active{ background: rgba(15,118,110,.12) }

.nav-cta{ display:flex; align-items:center; gap:10px }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px;
  border-radius: 14px;
  font-weight: 800;
  border:1px solid var(--border);
  background: #fff;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 20px rgba(12,28,56,.12) }
.btn:focus{ outline: none }
.btn:focus-visible{ box-shadow: 0 0 0 4px rgba(15,118,110,.18), 0 10px 20px rgba(12,28,56,.12) }

.btn-primary{
  background: linear-gradient(135deg, var(--brand3), var(--brand));
  color: #fff;
  border: none;
  box-shadow: 0 14px 30px rgba(11,58,90,.15);
}
.btn-primary:hover{
  box-shadow: 0 18px 44px rgba(11,58,90,.18);
}

.btn-outline{
  background: rgba(255,255,255,.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(8px);
}
.btn-outline:hover{
  background: rgba(255,255,255,.14);
}

.btn-outline-dark{
  background: transparent;
  border: 1px solid rgba(15,118,110,.22);
  color: var(--text);
}
.btn-outline-dark:hover{
  background: rgba(15,118,110,.08);
}

.btn-ghost{
  background: transparent;
  border: 1px solid rgba(15,118,110,.20);
}
.mobile-toggle{ display:none }

/* ===== HERO ===== */
.hero{
  padding: 26px 0 0;
}
.hero-wrap{
  display:grid;
  grid-template-columns: 1fr;
  gap:18px;
  padding: 18px 0 28px;
}

.hero-card{
  position:relative;
  border-radius: 28px;
  overflow:hidden;
  min-height: 720px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow:
    0 22px 60px rgba(12,28,56,.18),
    0 0 0 1px rgba(15,118,110,.08) inset;
  background:#111827;
}

.hero-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(600px 260px at 20% 20%, rgba(15,118,110,.18), transparent 55%);
  pointer-events:none;
}

.hero-slides{ position:absolute; inset:0 }
.slide{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  opacity:0;
  transform: scale(1.03);
  transition: opacity 1s ease, transform 1.4s ease;
}

.slide::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 500px at 18% 25%, rgba(0,0,0,.25), transparent 60%),
    linear-gradient(90deg, rgba(0,0,0,.45), rgba(0,0,0,.18) 60%, rgba(0,0,0,.12)),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.42));
}
.slide.active{ opacity:1; transform: scale(1.0) }

.hero-content{
  position:relative;
  padding: 44px 42px;
  color: #fff;
  max-width: 980px;
}

.badge{
  display:inline-flex; gap:10px; align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
  font-weight: 800;
  font-size: 14px;
}

.hero-title{
  margin: 14px 0 10px;
  font-size: var(--h1);
  line-height: 1.03;
  letter-spacing: -0.6px;
  font-family: "Playfair Display", Georgia, serif;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.hero-sub{
  margin:0 0 16px;
  color: rgba(255,255,255,.90);
  max-width: 62ch;
  font-weight: 500;
}

.pills{ display:flex; flex-wrap:wrap; gap:10px; margin: 18px 0 }
.pill{
  padding: 10px 12px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
}

.hero-actions{ display:flex; flex-wrap:wrap; gap:10px; margin-top: 18px }
.hero-actions .btn{ box-shadow:none }

.side.side-below{
  width: 100%;
  max-width: 100%;
}


/* Right card */
.side{
  border-radius: 28px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.70);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(12,28,56,.12);
  padding: 26px;
  display:flex; flex-direction:column; gap:14px;
}
.side h3{ margin:0; font-size: 20px; font-weight: 900 }
.side p{ margin:0; color: var(--muted) }

.kpis{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
.kpi{
  border-radius: 16px;
  padding: 14px;
  border:1px solid var(--border);
  background: linear-gradient(180deg, #ffffff, #f7fafc);
}
.kpi b{ display:block; font-size: 22px }
.kpi small{ color: var(--muted); font-weight: 700 }

.mini{
  display:flex; gap:12px; align-items:flex-start;
  padding: 16px;
  border:1px solid var(--border);
  border-radius: 16px;
  background:#fff;
}

.mini i{
  width: 38px; height: 38px;
  border-radius: 12px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(15,118,110,.10);
  border: 1px solid rgba(15,118,110,.16);
  color: var(--brand3);
}
.mini strong{ display:block; font-weight: 900 }
.mini span{ color: var(--muted); font-weight: 600; font-size: 14px }

/* ===== SECTIONS ===== */
.section{ padding: 56px 0 }
.section h2{
  margin:0 0 10px;
  font-size: var(--h2);
  font-weight: 900;
  letter-spacing: -.4px;
}
.section p.lead{
  margin:0 0 18px;
  color: var(--muted);
  max-width: 90ch;
}
.section.alt{
  background: rgba(255,255,255,.78);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(8px);
}

.split{ display:grid; grid-template-columns: 1fr 1fr; gap:16px }

.card{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.70);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: 0 14px 38px rgba(12,28,56,.10);
  transition: transform .18s ease, box-shadow .18s ease;
  backdrop-filter: blur(8px);
}
.card:hover{ transform: translateY(-4px); box-shadow: 0 20px 52px rgba(12,28,56,.14); }

.card-pad{
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.card h3{ margin:0 0 2px; font-size: 20px; font-weight: 900 }
.card p{ margin:0; color: var(--muted) }

.card-img{
  height: 190px;
  background-size: cover;
  background-position: center;
  position:relative;
  transition: transform .35s ease;
}
.card:hover .card-img{ transform: scale(1.03); }

.card-img::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.55));
}
.card-tag{
  position:absolute; left:14px; bottom:14px;
  background: rgba(255,255,255,.92);
  color: #0b1220;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 900;
  border:1px solid rgba(0,0,0,.08);
}

.icon{
  width:46px; height:46px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(15,118,110,.10);
  border:1px solid rgba(15,118,110,.18);
  color: var(--brand3);
}

/* ===== TRUST BAR ===== */
.trustbar{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 18px;
}
.trustitem{
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(255,255,255,.70);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 14px 38px rgba(12,28,56,.10);
  backdrop-filter: blur(8px);
}
.trustitem b{display:block; font-size:16px}
.trustitem span{color: var(--muted); font-weight:600; font-size:14px}

/* ===== SERVICES GRID (balanced, no buttons) ===== */
.services-grid{
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(2, 1fr);
  align-items: stretch;
}

@media (min-width: 1200px){
  .services-grid{ grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 980px){
  .services-grid{ grid-template-columns: 1fr; }
}

/* ✅ keep service cards premium without buttons */
.services-grid .card{ display:flex; flex-direction:column; }
.services-grid .card-pad{
  flex: 1;
  padding-bottom: 26px; /* extra breathing room after removing button */
}

/* ===== Rectangular flags (3 x 2 grid) ===== */
.flag-grid-rect{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px 28px;
  margin-top: 22px;
  max-width: 520px;
}
.flag-rect-item{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: transform .15s ease;
}
.flag-rect-item:hover{ transform: translateY(-3px); }
.flag-rect-item img{
  width: 120px;
  height: 80px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  box-shadow: 0 10px 26px rgba(12,28,56,.12);
}
.flag-rect-item span{
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

@media (max-width: 768px){
  .flag-grid-rect{ grid-template-columns: repeat(2, 1fr); max-width: 420px; }
}
@media (max-width: 480px){
  .flag-grid-rect{ grid-template-columns: 1fr; max-width: 260px; }
}

/* ===== FOOTER ===== */
.footer{
  background:#0b1220;
  color:#fff;
  padding: 34px 0;
  margin-top: 10px;
}
.footer-brand h1{ color:#fff; margin:0; font-size: 15px; font-weight: 800 }
.footer .brand small{ color: rgba(255,255,255,.72) }
.footer-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap:16px }
.footer-link{ color: rgba(255,255,255,.88); text-decoration: underline; text-underline-offset: 3px }
.socials{ display:flex; flex-wrap:wrap; gap:10px; margin-top:12px }
.socials a{
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  padding: 12px 14px;
  border-radius: 14px;
  font-weight: 900;
}
.hr{ height:1px; background: rgba(255,255,255,.18); margin:16px 0 }
.smallprint{ color: rgba(255,255,255,.74); font-size: 13px; font-weight: 600 }

/* ===== Floating quick actions ===== */
.float-actions{
  position: fixed;
  right: 18px;
  bottom: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 999;
}
.float-btn{
  width: 48px;
  height: 48px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  color:#fff;
  box-shadow: 0 12px 28px rgba(12,28,56,.18);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .15s ease, box-shadow .15s ease;
}
.float-btn:hover{ transform: translateY(-2px); box-shadow: 0 18px 40px rgba(12,28,56,.20); }
.float-btn.wa{ background: linear-gradient(135deg, var(--brand2), #15803d); }
.float-btn.call{ background: linear-gradient(135deg, var(--brand3), var(--brand)); }

/* ===== Scroll reveal support (works with your app.js reveal) ===== */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease;
  will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: translateY(0);
}

/* ===== MOBILE ===== */
@media (max-width: 980px){
  .hero-wrap{ grid-template-columns:1fr }
  .split{ grid-template-columns:1fr }
  .trustbar{ grid-template-columns:1fr }
  .footer-grid{ grid-template-columns:1fr }

  .nav-links{ display:none }
  .mobile-toggle{ display:inline-flex }

  .nav-links.mobile-open{
    display:flex;
    position:absolute;
    right: 0;
    top: 66px;
    flex-direction:column;
    background:#fff;
    border:1px solid var(--border);
    border-radius:16px;
    padding:10px;
    min-width: 220px;
    box-shadow: var(--shadow);
  }
}

/* ===== Respect Reduce Motion ===== */
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; }
  .reveal{ opacity: 1 !important; transform: none !important; transition: none !important; }
  .card, .card-img, .float-btn, .slide{ transition: none !important; }
}

/* ===== PROFESSIONAL TEAM SECTION ===== */
.team-pro{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 24px;
}

.team-card{
  display: flex;
  gap: 20px;
  padding: 24px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  transition: transform .2s ease, box-shadow .2s ease;
}

.team-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(12,28,56,.16);
}

.team-avatar{
  width: 72px;
  height: 72px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--brand3), var(--brand));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  flex-shrink: 0;
}

.team-avatar.alt{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
}

.team-info h3{
  margin: 0;
  font-size: 20px;
  font-weight: 900;
}

.team-info small{
  display: block;
  margin: 4px 0 10px;
  color: var(--muted);
  font-weight: 700;
}

.team-info p{
  margin: 0 0 12px;
  color: var(--muted);
}

.team-points{
  list-style: none;
  padding: 0;
  margin: 0;
}

.team-points li{
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}

.team-points i{
  color: var(--brand);
  margin-top: 3px;
}

@media (max-width: 980px){
  .team-pro{
    grid-template-columns: 1fr;
  }
}



/* =========================
   BOOKING PAGE
   ========================= */
.booking-page{ padding-top: 24px; }
.booking-hero{ padding: 6px 0 24px; }
.booking-hero-inner{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items: stretch;
}

.booking-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(15,118,110,.10);
  border: 1px solid rgba(15,118,110,.16);
  color: var(--text);
  font-weight: 800;
  font-size: 14px;
}

.booking-title{
  margin: 12px 0 8px;
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.4px;
  font-family: "Playfair Display", Georgia, serif;
}

.booking-sub{
  margin: 0;
  color: var(--muted);
  font-weight: 600;
  max-width: 70ch;
}

.booking-hero-pills{ margin-top: 14px; display:flex; flex-wrap:wrap; gap:10px; }

.booking-hero-card{
  height: 100%;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.70);
  border-radius: 18px;
  box-shadow: 0 14px 38px rgba(12,28,56,.10);
  backdrop-filter: blur(8px);
  padding: 16px;
  display: grid;
  gap: 12px;
}

.booking-hero-cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 4px;
}

.booking-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items: start;
}

.booking-card .booking-pad{ padding: 20px; }
.booking-head{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  align-items:flex-start;
  margin-bottom: 10px;
}

.booking-head-note{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  background: rgba(11,58,90,.06);
  border: 1px solid rgba(11,58,90,.10);
  color: var(--text);
  font-weight: 800;
  font-size: 13px;
  white-space: nowrap;
}

.booking-form .req{ color: #dc2626; font-weight: 900; }

.booking-section{
  border: 1px solid rgba(14,41,84,.10);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,.70);
}

.booking-section-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 900;
  margin-bottom: 12px;
  color: var(--text);
}
.booking-section-title i{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(15,118,110,.10);
  border: 1px solid rgba(15,118,110,.16);
  color: var(--brand3);
}

.booking-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}

.booking-privacy{
  margin-top: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(15,118,110,.07);
  border: 1px solid rgba(15,118,110,.12);
  color: var(--muted);
  font-weight: 650;
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.booking-privacy i{ color: var(--brand3); margin-top: 3px; }

.booking-side{ position: sticky; top: 88px; }

.booking-steps{ display:grid; gap: 12px; margin-top: 8px; }
.booking-step{
  display:flex;
  gap: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(14,41,84,.10);
  background: rgba(255,255,255,.78);
}
.step-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(11,58,90,.06);
  border: 1px solid rgba(11,58,90,.10);
  color: var(--brand3);
  flex-shrink: 0;
}
.booking-step strong{ font-weight: 900; }
.booking-step .muted{ color: var(--muted); font-weight: 600; font-size: 14px; }

.booking-callout{
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(22,163,74,.06);
  border: 1px solid rgba(22,163,74,.12);
}
.booking-callout-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 900;
  margin-bottom: 10px;
}
.booking-check{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.booking-check li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-weight: 650;
  color: var(--text);
  font-size: 14px;
}
.booking-check i{ color: var(--brand); margin-top: 2px; }

.booking-contact{ margin-top: 14px; display:grid; gap: 12px; }
.booking-contact-row{ display:flex; gap: 10px; flex-wrap:wrap; }
.booking-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(14,41,84,.10);
  font-weight: 800;
  color: var(--text);
}
.booking-chip i{ color: var(--brand3); }

/* Responsive */
@media (max-width: 980px){
  .booking-hero-inner{ grid-template-columns: 1fr; }
  .booking-grid{ grid-template-columns: 1fr; }
  .booking-side{ position: static; top: auto; }
  .booking-head{ flex-direction: column; }
  .booking-head-note{ white-space: normal; }
}


/* ===== Compact premium booking header ===== */
.booking-hero{
  padding: 12px 0 22px;
}

.booking-banner.compact{
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  min-height: 520px; /* ✅ compact height */
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 14px 36px rgba(12,28,56,.12);
}

.booking-banner-bg{
  position: absolute;
  inset: 0;
  background-image: url("../Images/Consultation.png");
  background-size: cover;
  background-position: center;
}

/* light professional overlay (not dark) */
.booking-banner.compact::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(11,18,32,.55), rgba(11,18,32,.25) 60%, rgba(11,18,32,.12)),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.32));
}

.booking-banner-content{
  position: relative;
  z-index: 2;
  padding: 36px 28px;
  max-width: 900px;
  color: #fff;
}

/* tighter typography for compact look */
.booking-title{
  font-size: clamp(28px, 2.4vw, 36px);
  margin: 10px 0 6px;
}

.booking-sub{
  font-size: 16px;
  margin-bottom: 12px;
  color: rgba(255,255,255,.95);
}

.booking-hero-pills{
  gap: 10px;
  margin-top: 10px;
}

/* responsive */
@media (max-width: 768px){
  .booking-banner.compact{
    min-height: 240px;
  }
  .booking-banner-content{
    padding: 22px 18px;
  }
}


/* =========================
   BOOKING ALERT (confirmed animation)
   ========================= */
.alert{
  display:none;
  padding: 14px 16px;
  border-radius: 14px;
  font-weight: 800;
  border: 1px solid rgba(22,163,74,.25);
  background: rgba(22,163,74,.10);
  color: #0b1220;
}

.alert.show{ display:block; }

.alert.success{
  border-color: rgba(22,163,74,.35);
  background: rgba(22,163,74,.12);
}

.alert.error{
  border-color: rgba(220,38,38,.35);
  background: rgba(220,38,38,.10);
}

.alert-anim{
  display:flex;
  gap: 12px;
  align-items:center;
}

.alert-anim .msg{
  font-weight: 900;
}

.alert-anim .sub{
  font-weight: 650;
  color: rgba(11,18,32,.70);
  font-size: 14px;
  margin-top: 2px;
}

.pop-in{
  animation: popIn .45s ease both;
}

@keyframes popIn{
  from{ transform: translateY(10px) scale(.985); opacity: 0; }
  to{ transform: translateY(0) scale(1); opacity: 1; }
}

/* Animated check */
.check{
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(22,163,74,.12);
  border: 1px solid rgba(22,163,74,.25);
  flex: 0 0 auto;
}

.check svg{ width: 26px; height: 26px; }

.check .path{
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: draw .6s .15s ease forwards;
}

@keyframes draw{
  to{ stroke-dashoffset: 0; }
}

/* Error shake */
.shake{
  animation: shake .35s ease;
}
@keyframes shake{
  0%,100%{ transform: translateX(0); }
  25%{ transform: translateX(-6px); }
  50%{ transform: translateX(6px); }
  75%{ transform: translateX(-4px); }
}

/* ===== Booking success animation (extra premium) ===== */
.alert{
  margin: 14px 0;
}

.alert.success .check{
  box-shadow: 0 10px 26px rgba(22,163,74,.18);
}

.alert.success .msg{
  letter-spacing: .2px;
}

.alert.success{
  position: relative;
  overflow: hidden;
}

.alert.success::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(520px 140px at 15% 50%, rgba(22,163,74,.12), transparent 60%);
  pointer-events:none;
}
/* =========================
   BOOKING CONFIRMATION POPUP
   ========================= */
.modal-overlay{
  position: fixed;
  inset: 0;
  background: rgba(11,18,32,.55);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}

.modal-overlay.show{
  opacity: 1;
  pointer-events: auto;
}

.modal-card{
  background: #fff;
  border-radius: 22px;
  padding: 32px 28px;
  max-width: 420px;
  width: calc(100% - 40px);
  text-align: center;
  box-shadow: 0 30px 80px rgba(12,28,56,.25);
  animation: modalPop .45s ease both;
}

@keyframes modalPop{
  from{ transform: scale(.92) translateY(10px); opacity: 0; }
  to{ transform: scale(1) translateY(0); opacity: 1; }
}

.modal-check{
  width: 64px;
  height: 64px;
  margin: 0 auto 14px;
  border-radius: 18px;
  background: rgba(22,163,74,.12);
  border: 1px solid rgba(22,163,74,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #16a34a;
}

.modal-check svg{
  width: 34px;
  height: 34px;
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: drawCheck .6s .15s ease forwards;
}

@keyframes drawCheck{
  to{ stroke-dashoffset: 0; }
}

.modal-card h3{
  margin: 12px 0 8px;
  font-size: 22px;
  font-weight: 900;
}

.modal-card p{
  margin: 0 0 18px;
  color: var(--muted);
  font-weight: 600;
  line-height: 1.6;
}
