/* ==========================================================================
   Medical Admissions Guide — Premium Styles
   Palette: Deep Blue, Sky Blue, Soft Green, White, Light Gray
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Poppins:wght@500;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root{
  --deep-blue:#0b3d91;
  --deep-blue-2:#13509f;
  --sky:#2aa7ff;
  --sky-2:#7cd0ff;
  --green:#22c08a;
  --green-2:#a7f3d0;
  --bg:#f6f9fd;
  --surface:#ffffff;
  --text:#0f172a;
  --muted:#5b6b85;
  --border:#e6edf7;
  --shadow-sm:0 4px 14px rgba(11,61,145,.08);
  --shadow-md:0 12px 32px rgba(11,61,145,.10);
  --shadow-lg:0 24px 60px rgba(11,61,145,.18);
  --grad-primary:linear-gradient(135deg,#0b3d91 0%,#2aa7ff 100%);
  --grad-soft:linear-gradient(135deg,#eaf4ff 0%,#f6fbff 100%);
  --grad-green:linear-gradient(135deg,#22c08a,#7cd0ff);
  --radius:18px;
  --radius-lg:26px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Manrope','Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--deep-blue);text-decoration:none}
a:hover{color:var(--sky)}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;color:var(--text);line-height:1.22;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:700;letter-spacing:-.01em}
h3{font-size:1.2rem;font-weight:700}
p{margin:0 0 1em;color:var(--muted)}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:14px 26px;border-radius:999px;font-weight:600;font-family:inherit;font-size:.97rem;border:0;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;white-space:nowrap}
.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 10px 24px rgba(42,167,255,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(42,167,255,.45);color:#fff}
.btn-ghost{background:#fff;color:var(--deep-blue);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--sky);color:var(--sky);transform:translateY(-2px)}
.btn-green{background:var(--grad-green);color:#fff}
.btn-green:hover{transform:translateY(-2px);color:#fff}
.btn-lg{padding:16px 30px;font-size:1rem}

/* ===== Navbar ===== */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:all .3s ease}
.nav.scrolled{box-shadow:var(--shadow-sm);border-bottom-color:var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px;transition:height .3s ease}
.nav.scrolled .nav-inner{height:64px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Poppins';font-weight:800;color:var(--deep-blue);font-size:1.05rem}
.logo img{width:38px;height:38px}
.logo span{line-height:1.05}
.logo small{display:block;font-size:.7rem;font-weight:500;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.nav-links{display:flex;gap:6px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{padding:10px 14px;border-radius:10px;color:var(--text);font-weight:600;font-size:.95rem;transition:all .2s}
.nav-links a:hover,.nav-links a.active{background:var(--grad-soft);color:var(--deep-blue)}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;background:none;border:0;width:42px;height:42px;border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--deep-blue);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--deep-blue);transition:transform .3s}
.burger span::before{top:-7px}.burger span::after{top:7px}
.burger.open span{background:transparent}
.burger.open span::before{transform:translateY(7px) rotate(45deg)}
.burger.open span::after{transform:translateY(-7px) rotate(-45deg)}

@media (max-width:900px){
  .nav-links{position:fixed;left:0;right:0;top:78px;flex-direction:column;background:#fff;padding:16px;gap:4px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translateY(-12px);transition:opacity .25s ease,transform .25s ease,visibility .25s;border-bottom:1px solid var(--border);max-height:calc(100vh - 78px);overflow-y:auto}
  .nav.scrolled .nav-links{top:64px}
  .nav-links.open{opacity:1;visibility:visible;transform:translateY(0)}
  .nav-links a{width:100%;padding:14px 16px;font-size:1rem}
  .burger{display:inline-flex}
  .nav-cta .btn{display:none}
}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;padding:70px 0 90px;background:var(--grad-soft)}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;z-index:0}
.hero::before{width:420px;height:420px;background:#bfe3ff;top:-120px;right:-100px;animation:float 8s ease-in-out infinite}
.hero::after{width:340px;height:340px;background:#cdf5e3;bottom:-140px;left:-80px;animation:float 10s ease-in-out infinite reverse}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);color:var(--deep-blue);font-weight:600;font-size:.82rem;padding:8px 14px;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(34,192,138,.18)}
.hero h1 .grad{background:var(--grad-primary);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.1rem;color:var(--muted);max-width:560px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0 28px}
.trust-badges{display:flex;flex-wrap:wrap;gap:18px}
.trust-badges .b{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-weight:600;font-size:.92rem}
.trust-badges .b svg{color:var(--green)}
.hero-visual{position:relative}
.hero-visual .glass{position:absolute;background:rgba(255,255,255,.75);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);border-radius:18px;padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;font-weight:700;font-size:.95rem;color:var(--deep-blue)}
.hero-visual .glass small{display:block;font-weight:500;font-size:.78rem;color:var(--muted)}
.hero-visual .g1{top:18%;left:-22px;animation:float 6s ease-in-out infinite}
.hero-visual .g2{bottom:14%;right:-18px;animation:float 7s ease-in-out infinite reverse}
.hero-visual .g3{top:-10px;right:30px;animation:float 9s ease-in-out infinite}
.hero-img-wrap{border-radius:30px;overflow:hidden;box-shadow:var(--shadow-lg);background:#fff;animation:rise 1s ease both}
.hero-img-wrap img{width:100%;display:block}
.icon-pill{width:38px;height:38px;border-radius:12px;background:var(--grad-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.icon-pill.green{background:var(--grad-green)}

@media (max-width:900px){
  .hero{padding:40px 0 60px}
  .hero-grid{grid-template-columns:1fr;gap:30px;text-align:left}
  .hero-visual .g1{left:0}.hero-visual .g2{right:0}
}

/* ===== Sections ===== */
section{padding:80px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 50px}
.section-head .eyebrow{margin-bottom:14px}
.section-head p{font-size:1.05rem}

/* ===== Search ===== */
.search-bar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px;box-shadow:var(--shadow-sm);max-width:720px;margin:0 auto}
.search-bar input{flex:1;border:0;outline:none;padding:14px 18px;font-size:1rem;font-family:inherit;background:transparent;color:var(--text)}
.search-bar .btn{padding:14px 22px}
.search-results{max-width:720px;margin:18px auto 0;display:grid;gap:8px}
.search-results a{background:#fff;padding:12px 18px;border-radius:14px;border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-weight:600}
.search-results a:hover{border-color:var(--sky)}

/* ===== Course cards ===== */
.grid{display:grid;gap:24px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.cards-3,.cards-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cards-3,.cards-4,.cards-2{grid-template-columns:1fr}}

.card{background:#fff;border-radius:var(--radius);padding:26px;border:1px solid var(--border);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.course-card .icon{width:54px;height:54px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:var(--grad-soft);color:var(--deep-blue);margin-bottom:16px;font-size:1.4rem;font-weight:800;font-family:'Poppins'}
.course-card h3{margin-bottom:6px}
.course-card .meta{font-size:.88rem;color:var(--muted);margin-bottom:14px}
.course-card .arrow{display:inline-flex;align-items:center;gap:6px;color:var(--deep-blue);font-weight:600;font-size:.92rem}
.course-card:hover .arrow{color:var(--sky)}
.tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:#eaf4ff;color:var(--deep-blue);margin-right:6px}
.tag.green{background:#dcfce7;color:#047857}

/* Why cards */
.why-card .icon{width:60px;height:60px;border-radius:16px;background:var(--grad-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px}
.why-card.alt .icon{background:var(--grad-green)}

/* Updates */
.update-card .date{font-size:.82rem;color:var(--sky);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}

/* States */
.state-card{padding:22px;text-align:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);transition:all .3s}
.state-card:hover{transform:translateY(-4px);border-color:var(--sky);box-shadow:var(--shadow-sm)}
.state-card .pin{width:46px;height:46px;border-radius:50%;background:var(--grad-soft);color:var(--deep-blue);display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px}
.state-card h4{font-family:'Poppins';margin:0;font-size:1rem;color:var(--text)}

/* Testimonials */
.testi{background:linear-gradient(180deg,#fff,#eaf4ff)}
.testi-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding:10px 4px 30px;scrollbar-width:none}
.testi-track::-webkit-scrollbar{display:none}
.testi-card{min-width:320px;max-width:380px;flex:0 0 auto;scroll-snap-align:start;background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.testi-card p{font-size:1rem;color:var(--text);font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px;margin-top:14px}
.testi-author .avatar{width:46px;height:46px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.testi-author b{display:block}
.testi-author small{color:var(--muted)}
.stars{color:#f59e0b;letter-spacing:2px;font-size:.95rem}

/* CTA Banner */
.cta-banner{background:var(--grad-primary);color:#fff;border-radius:var(--radius-lg);padding:50px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta-banner::before{content:"";position:absolute;width:300px;height:300px;background:rgba(255,255,255,.08);border-radius:50%;top:-100px;right:-80px}
.cta-banner h2{color:#fff;margin:0 0 8px}
.cta-banner p{color:rgba(255,255,255,.9);margin:0;max-width:520px}
.cta-banner .btn{background:#fff;color:var(--deep-blue);box-shadow:none}
.cta-banner .btn:hover{background:#eaf4ff;color:var(--deep-blue)}

/* Footer */
footer{background:#0a1f44;color:#cbd6ee;padding:70px 0 24px;margin-top:60px}
footer h4{color:#fff;font-family:'Poppins';font-size:1rem;margin:0 0 18px;letter-spacing:.02em}
footer a{color:#cbd6ee;display:block;padding:6px 0;font-size:.94rem}
footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-about p{color:#9eb1d6;font-size:.94rem}
.socials{display:flex;gap:10px;margin-top:14px}
.socials a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s}
.socials a:hover{background:var(--sky);color:#fff}
.contact-list li{display:flex;gap:10px;align-items:flex-start;list-style:none;margin-bottom:10px;font-size:.94rem;color:#cbd6ee}
.contact-list{padding:0;margin:0}
.contact-list svg{flex-shrink:0;color:var(--sky-2);margin-top:3px}
.copyright{margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);text-align:center;color:#8aa0c8;font-size:.88rem}
.copyright a{display:inline;color:#cbd6ee}

/* WhatsApp Float */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:60;width:60px;height:60px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 10px 28px rgba(37,211,102,.45);animation:pulse 2s ease-in-out infinite}
.wa-float:hover{color:#fff;transform:scale(1.06)}

/* Sticky mobile CTA */
.mobile-cta{display:none;position:fixed;left:14px;right:88px;bottom:20px;z-index:55}
.mobile-cta .btn{width:100%;justify-content:center;box-shadow:var(--shadow-lg)}
@media (max-width:768px){.mobile-cta{display:block}}

/* Forms */
.form-card{background:#fff;border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.92rem;margin-bottom:6px;color:var(--text)}
.field input,.field select,.field textarea{width:100%;padding:13px 16px;border-radius:12px;border:1.5px solid var(--border);font-size:.97rem;font-family:inherit;color:var(--text);background:#fbfdff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 4px rgba(42,167,255,.15)}
.field textarea{min-height:120px;resize:vertical}
.form-success{background:#dcfce7;color:#065f46;padding:14px 18px;border-radius:12px;margin-bottom:14px;display:none;font-weight:600}
.form-error{background:#fee2e2;color:#991b1b;padding:14px 18px;border-radius:12px;margin-bottom:14px;display:none;font-weight:600}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;min-width:520px}
th,td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border);font-size:.94rem}
th{background:var(--grad-soft);color:var(--deep-blue);font-family:'Poppins';font-weight:700}
tr:last-child td{border-bottom:0}

/* Page header */
.page-head{padding:60px 0 40px;background:var(--grad-soft);border-bottom:1px solid var(--border)}
.page-head .eyebrow{margin-bottom:12px}
.page-head h1{margin-bottom:8px}
.page-head p{max-width:680px}
.breadcrumbs{font-size:.88rem;color:var(--muted);margin-bottom:14px}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs span{margin:0 6px;color:#cbd5e1}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--border);border-radius:14px;margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:18px 22px;font-weight:600;background:none;border:0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:1rem;font-family:inherit;color:var(--text)}
.faq-q::after{content:"+";font-size:1.4rem;color:var(--deep-blue);transition:transform .3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{display:none;padding:0 22px 18px;color:var(--muted)}
.faq-item.open .faq-a{display:block}

/* Reveal animations — JS adds .js-ready to <html> so users w/o JS still see content */
.js-ready .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.js-ready .reveal.visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js-ready .reveal{opacity:1;transform:none;transition:none}}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{box-shadow:0 10px 28px rgba(37,211,102,.45)}50%{box-shadow:0 10px 28px rgba(37,211,102,.7),0 0 0 12px rgba(37,211,102,.0)}}

/* Two col layouts */
.two-col{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center}
@media (max-width:900px){.two-col{grid-template-columns:1fr}}

/* Legal */
.legal{padding:50px 0 30px}
.legal h2{margin-top:30px}
.legal p,.legal li{color:var(--text)}

/* ==========================================================================
   Mobile responsiveness hardening
   ========================================================================== */

/* Prevent any horizontal scroll on small screens */
html, body { overflow-x: hidden; max-width: 100%; }
img, svg, video, iframe { max-width: 100%; height: auto; }

/* Tablet adjustments */
@media (max-width: 1024px) {
  :root { --container: 100%; }
  section { padding: 64px 0; }
  .container { padding: 0 22px; }
  .cta-banner { padding: 40px; }
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
  body { font-size: 15px; line-height: 1.55; }
  section { padding: 50px 0; }
  .container { padding: 0 16px; }

  h1 { font-size: clamp(1.7rem, 7vw, 2.2rem); }
  h2 { font-size: clamp(1.35rem, 5.4vw, 1.75rem); }
  h3 { font-size: 1.05rem; }
  p  { font-size: .96rem; }

  /* Buttons full width when stacked */
  .btn { padding: 13px 22px; font-size: .95rem; }
  .btn-lg { padding: 14px 24px; font-size: .98rem; }
  .hero-cta { gap: 10px; }
  .hero-cta .btn { flex: 1 1 auto; justify-content: center; min-width: 140px; }

  /* Hero */
  .hero { padding: 30px 0 50px; }
  .hero p.lead { font-size: 1rem; }
  .trust-badges { gap: 12px; }
  .trust-badges .b { font-size: .85rem; }
  .hero-img-wrap { border-radius: 22px; }
  .hero-visual .glass { padding: 10px 12px; font-size: .82rem; gap: 8px; }
  .hero-visual .glass small { font-size: .68rem; }
  .icon-pill { width: 32px; height: 32px; }
  .hero-visual .g1 { top: 8%; left: -4px; }
  .hero-visual .g2 { bottom: 6%; right: -4px; }
  .hero-visual .g3 { top: -6px; right: 12px; }
  .hero::before { width: 280px; height: 280px; top: -90px; right: -80px; }
  .hero::after  { width: 240px; height: 240px; bottom: -100px; left: -60px; }

  /* Section heads */
  .section-head { margin-bottom: 32px; }
  .section-head p { font-size: .98rem; }

  /* Search */
  .search-bar { padding: 6px; gap: 6px; border-radius: 999px; }
  .search-bar input { padding: 11px 14px; font-size: .95rem; min-width: 0; }
  .search-bar .btn { padding: 11px 16px; font-size: .9rem; }

  /* Cards */
  .card { padding: 22px; border-radius: 16px; }
  .grid { gap: 16px; }

  /* CTA banner */
  .cta-banner { padding: 30px 22px; border-radius: 22px; text-align: center; gap: 18px; }
  .cta-banner > div { width: 100%; }
  .cta-banner .btn { width: 100%; justify-content: center; }

  /* Tables */
  th, td { padding: 11px 14px; font-size: .88rem; }

  /* Form */
  .form-card { padding: 24px; border-radius: 20px; }
  .field input, .field select, .field textarea { padding: 12px 14px; font-size: 16px; /* prevent iOS zoom */ }

  /* Page head */
  .page-head { padding: 40px 0 28px; }

  /* Footer */
  footer { padding: 50px 0 20px; margin-top: 40px; }
  footer h4 { margin-bottom: 12px; }
  .copyright { margin-top: 32px; }

  /* Reserve space so sticky mobile CTA + WhatsApp don't cover content */
  body { padding-bottom: 84px; }

  /* WhatsApp float — slightly smaller on mobile */
  .wa-float { width: 54px; height: 54px; right: 14px; bottom: 16px; }
  .wa-float svg { width: 26px; height: 26px; }

  /* Sticky mobile CTA tightening */
  .mobile-cta { left: 12px; right: 78px; bottom: 16px; }
  .mobile-cta .btn { padding: 13px 18px; font-size: .95rem; }

  /* Testimonials snap */
  .testi-card { min-width: 84vw; max-width: 84vw; padding: 22px; }
}

/* Small phones (≤420px) */
@media (max-width: 420px) {
  .container { padding: 0 14px; }
  h1 { font-size: 1.6rem; line-height: 1.18; }
  h2 { font-size: 1.3rem; }
  .nav-inner { height: 64px; }
  .nav.scrolled .nav-inner { height: 56px; }
  .nav-links { top: 64px; }
  .nav.scrolled .nav-links { top: 56px; }
  .logo { font-size: .98rem; }
  .logo img { width: 34px; height: 34px; }
  .logo small { font-size: .62rem; }
  .hero-cta .btn { width: 100%; }
  .hero-visual .glass { display: none; } /* Avoid clutter on tiny screens */
  .testi-card { min-width: 88vw; max-width: 88vw; }
  .cta-banner { padding: 26px 18px; }
}

/* Landscape phones — keep hero compact */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  .hero { padding: 24px 0 32px; }
  section { padding: 40px 0; }
}

/* Larger touch targets globally on touch devices */
@media (hover: none) and (pointer: coarse) {
  .nav-links a { min-height: 44px; display: flex; align-items: center; }
  .btn { min-height: 44px; }
  .faq-q { min-height: 52px; }
  .state-card, .card { -webkit-tap-highlight-color: rgba(42,167,255,.15); }
}
