/* =====================================================================
   MediVista Superspeciality Dental Clinic — Main Stylesheet
   Theme: Teal & White  |  Fonts: Poppins (headings) + Inter (body)
   ===================================================================== */

:root{
  --teal-900:#134e4a; --teal-800:#115e59; --teal-700:#0f766e;
  --teal-600:#0d9488; --teal-500:#14b8a6; --teal-400:#2dd4bf;
  --teal-200:#99f6e4; --teal-100:#ccfbf1; --teal-50:#f0fdfa;
  --amber:#f59e0b; --amber-dark:#d97706;
  --ink:#0f2e2b; --body:#41545f; --muted:#6b7d86;
  --line:#e2ebe9; --bg:#ffffff; --bg-soft:#f5fbfa;
  --white:#ffffff;
  --shadow-sm:0 1px 2px rgba(16,40,38,.06), 0 2px 6px rgba(16,40,38,.06);
  --shadow:0 8px 24px rgba(13,148,136,.10), 0 2px 6px rgba(16,40,38,.06);
  --shadow-lg:0 22px 50px rgba(13,98,90,.16);
  --radius:14px; --radius-lg:22px; --radius-pill:999px;
  --container:1180px;
  --ease:cubic-bezier(.4,0,.2,1);
  --header-h:76px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0; font-family:'Inter',system-ui,Arial,sans-serif;
  color:var(--body); background:var(--bg); line-height:1.65;
  font-size:16.5px; overflow-x:hidden; overflow-wrap:break-word;
}
h1,h2,h3,h4{font-family:'Poppins',sans-serif; color:var(--ink); line-height:1.2; margin:0 0 .5em; font-weight:600; overflow-wrap:break-word}
h1{font-size:clamp(2rem,4.5vw,3.1rem); letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.2vw,2.3rem); letter-spacing:-.01em}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
a{color:var(--teal-700); text-decoration:none; transition:color .2s var(--ease)}
a:hover{color:var(--teal-600)}
img{max-width:100%; display:block}
ul{margin:0; padding:0; list-style:none}

.container{width:100%; max-width:var(--container); margin:0 auto; padding:0 22px}
.skip-link{position:absolute; left:-999px; top:0; background:var(--teal-700); color:#fff; padding:10px 16px; z-index:200; border-radius:0 0 8px 0}
.skip-link:focus{left:0}

.ic{width:1.25em; height:1.25em; flex:none}
.ic--sm{width:1em; height:1em}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em; cursor:pointer;
  font-family:'Poppins',sans-serif; font-weight:600; font-size:.98rem;
  padding:.8em 1.5em; border-radius:var(--radius-pill); border:2px solid transparent;
  transition:transform .18s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
  line-height:1; text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--teal-600); color:#fff; box-shadow:0 8px 20px rgba(13,148,136,.32)}
.btn--primary:hover{background:var(--teal-700); color:#fff}
.btn--amber{background:var(--amber); color:#3a2a05; box-shadow:0 8px 20px rgba(245,158,11,.34)}
.btn--amber:hover{background:var(--amber-dark); color:#fff}
.btn--outline{background:transparent; color:var(--teal-700); border-color:var(--teal-200)}
.btn--outline:hover{background:var(--teal-50); border-color:var(--teal-600)}
.btn--white{background:#fff; color:var(--teal-700)}
.btn--white:hover{color:var(--teal-800)}
.btn--ghost-white{background:transparent; color:#fff; border-color:rgba(255,255,255,.55)}
.btn--ghost-white:hover{background:rgba(255,255,255,.14); color:#fff}
.btn--lg{padding:1em 1.8em; font-size:1.05rem}
.btn--block{display:flex; width:100%; justify-content:center}

/* ---------- Top bar ---------- */
.topbar{background:var(--teal-900); color:#cdeee9; font-size:.86rem}
.topbar__inner{display:flex; justify-content:space-between; align-items:center; min-height:38px; gap:12px}
.topbar a{color:#cdeee9; display:inline-flex; align-items:center; gap:.4em}
.topbar a:hover{color:#fff}
.topbar .ic{width:15px;height:15px}
.topbar__left{display:flex; align-items:center; gap:10px}
.topbar__sep{opacity:.5}
.topbar__right span{display:inline-flex; align-items:center; gap:.4em}

/* ---------- Header / nav ---------- */
.site-header{position:sticky; top:0; z-index:100; background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line); transition:box-shadow .25s var(--ease)}
.site-header.is-stuck{box-shadow:var(--shadow)}
.site-header__inner{display:flex; align-items:center; justify-content:space-between; min-height:var(--header-h); gap:18px}
.brand{display:flex; align-items:center; gap:11px}
.brand__text{display:flex; flex-direction:column; line-height:1.05}
.brand{gap:12px}
.brand img{width:52px; height:52px}
.brand__text strong{font-family:'Poppins',sans-serif; font-size:1.55rem; color:var(--teal-800); letter-spacing:-.01em; font-weight:700; line-height:1.05}
.brand__text small{font-size:.74rem; color:var(--teal-600); letter-spacing:.03em; text-transform:uppercase; font-weight:600; margin-top:2px}

.primary-nav .nav-list{display:flex; align-items:center; gap:4px}
.nav-list > li > a{display:inline-flex; align-items:center; gap:.3em; padding:.6em .85em; border-radius:10px; font-weight:500; color:var(--ink); font-size:.97rem}
.nav-list > li > a:hover{background:var(--teal-50); color:var(--teal-700)}
.nav-list > li > a.is-active{color:var(--teal-700)}
.nav-list > li > a.is-active::after{content:""; display:block}
.nav-cta{margin-left:8px}

/* Mega menu */
.has-mega{position:relative}
.mega{
  position:absolute; top:calc(100% + 14px); left:0; transform:translateY(10px);
  width:min(680px,90vw); background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:16px; opacity:0; visibility:hidden; transition:.22s var(--ease); z-index:120;
}
.has-mega:hover .mega, .has-mega:focus-within .mega{opacity:1; visibility:visible; transform:translateY(0)}
.mega::before{content:""; position:absolute; top:-8px; left:0; right:0; height:18px}
.mega__grid{display:grid; grid-template-columns:1fr 1fr; gap:6px}
.mega__item{display:flex; gap:12px; padding:11px 12px; border-radius:12px; align-items:flex-start}
.mega__item:hover{background:var(--teal-50)}
.mega__item strong{display:block; color:var(--ink); font-family:'Poppins',sans-serif; font-size:.96rem}
.mega__item small{display:block; color:var(--muted); font-size:.8rem; line-height:1.4}
.mega__icon{width:38px;height:38px; flex:none; display:grid; place-items:center; background:var(--teal-100); color:var(--teal-700); border-radius:10px}
.mega__icon .ic{width:20px;height:20px}
.mega__item--feature{grid-column:1/-1; background:linear-gradient(100deg,var(--teal-700),var(--teal-600)); color:#fff}
.mega__item--feature:hover{background:linear-gradient(100deg,var(--teal-800),var(--teal-700))}
.mega__item--feature strong,.mega__item--feature small{color:#fff}
.mega__item--feature small{opacity:.85}
.mega__item--feature .mega__icon{background:rgba(255,255,255,.18); color:#fff}

.nav-toggle{display:none; position:relative; z-index:140; background:var(--teal-50); border:1px solid var(--line); border-radius:10px; width:46px; height:46px; cursor:pointer; color:var(--teal-700); place-items:center}
.nav-toggle .ic{width:24px;height:24px}
.nav-toggle__close{display:none}

/* ---------- Sections ---------- */
section{position:relative}
.section{padding:clamp(56px,7vw,96px) 0}
.section--soft{background:var(--bg-soft)}
.section--teal{background:linear-gradient(160deg,var(--teal-900),var(--teal-700)); color:#dff5f2}
.section-head{max-width:720px; margin:0 auto clamp(34px,4vw,52px); text-align:center}
.section-head--left{margin-left:0; text-align:left}
.eyebrow{display:inline-flex; align-items:center; gap:.5em; font-family:'Poppins',sans-serif; font-weight:600; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--teal-600); background:var(--teal-50); padding:.5em 1em; border-radius:var(--radius-pill); margin-bottom:1rem}
.section--teal .eyebrow{color:#fff; background:rgba(255,255,255,.14)}
.section-head p{color:var(--muted); font-size:1.05rem}
.section--teal .section-head p{color:#cdeee9}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden; background:
  radial-gradient(1100px 540px at 78% -8%, var(--teal-100), transparent 60%),
  linear-gradient(180deg,var(--teal-50), #fff 72%);}
.hero__inner{display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:center; padding:clamp(26px,3.5vw,54px) 0}
.hero__rating{display:inline-flex; align-items:center; gap:.5em; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); padding:.45em 1em; border-radius:var(--radius-pill); font-size:.85rem; font-weight:600; color:var(--ink); margin-bottom:1rem}
.hero__rating .stars{color:var(--amber); display:inline-flex}
.hero__rating .stars .ic{width:16px;height:16px; fill:var(--amber); stroke:var(--amber)}
.hero h1{margin-bottom:.4em}
.hero h1 .accent{color:var(--teal-600)}
.hero__lead{font-size:1.1rem; color:var(--body); max-width:32em; margin-bottom:1.3rem}
.hero__cta{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:1.35rem}
.hero__trust{display:flex; flex-wrap:wrap; gap:10px 22px}
.hero__trust li{display:flex; align-items:center; gap:.5em; font-weight:500; color:var(--ink); font-size:.94rem}
.hero__trust .ic{color:var(--teal-600); width:20px;height:20px}

.hero__art{position:relative}
.hero__card{background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:14px; border:1px solid var(--line)}
.hero__photo{border-radius:16px; aspect-ratio:5/4; width:100%; object-fit:cover; object-position:center; background:
  linear-gradient(150deg,var(--teal-600),var(--teal-800));}
.hero__badge{position:absolute; background:#fff; border-radius:16px; box-shadow:var(--shadow-lg); padding:14px 16px; display:flex; gap:12px; align-items:center; border:1px solid var(--line)}
.hero__badge .ic{width:30px;height:30px}
.hero__badge--a{left:-22px; bottom:48px; color:var(--teal-700)}
.hero__badge--b{right:-14px; top:40px; color:var(--amber-dark)}
.hero__badge strong{display:block; font-family:'Poppins',sans-serif; color:var(--ink); font-size:1.15rem; line-height:1}
.hero__badge small{color:var(--muted); font-size:.78rem}
.hero__wave{display:block; width:100%; height:auto; margin-bottom:-6px}

/* ---------- Stats ---------- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.stat{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px; text-align:center; box-shadow:var(--shadow-sm)}
.stat__num{font-family:'Poppins',sans-serif; font-weight:700; font-size:2.1rem; color:var(--teal-600); line-height:1}
.stat__label{color:var(--muted); font-size:.92rem; margin-top:.3em}

/* ---------- Cards / service grid ---------- */
.grid{display:grid; gap:22px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

.card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow-sm); transition:transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease); height:100%; display:flex; flex-direction:column}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--teal-200)}
.card__icon{width:58px;height:58px; border-radius:16px; display:grid; place-items:center; background:linear-gradient(150deg,var(--teal-100),var(--teal-50)); color:var(--teal-700); margin-bottom:16px}
.card__icon .ic{width:28px;height:28px}
.card h3{margin-bottom:.4em}
.card p{color:var(--muted); font-size:.96rem; margin-bottom:1rem}
.card__link{margin-top:auto; font-weight:600; font-family:'Poppins',sans-serif; display:inline-flex; align-items:center; gap:.4em; color:var(--teal-700)}
.card__link .ic{transition:transform .2s var(--ease)}
.card:hover .card__link .ic{transform:translateX(4px)}

/* Why-us */
.why{display:flex; gap:16px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm)}
.why__icon{width:52px;height:52px; flex:none; border-radius:14px; background:var(--teal-600); color:#fff; display:grid; place-items:center}
.why__icon .ic{width:26px;height:26px}
.why h3{font-size:1.08rem; margin-bottom:.25em}
.why p{margin:0; color:var(--muted); font-size:.93rem}

/* ---------- About / split ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,60px); align-items:center}
.split__media{position:relative}
.split__media img, .media-frame{border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%}
.media-frame{aspect-ratio:4/3.4; background:linear-gradient(150deg,var(--teal-600),var(--teal-800)); display:grid; place-items:center; color:rgba(255,255,255,.9); text-align:center; padding:24px; border:1px solid var(--line)}
.media-frame small{display:block; opacity:.8; font-size:.8rem; margin-top:.5em}
.checklist{display:grid; gap:12px; margin:18px 0 26px}
.checklist li{display:flex; gap:12px; align-items:flex-start}
.checklist .ic{flex:none; width:24px;height:24px; color:#fff; background:var(--teal-600); border-radius:50%; padding:4px}
.checklist b{color:var(--ink); font-family:'Poppins',sans-serif; font-weight:600}

/* Credentials list */
.creds{display:grid; gap:14px}
.cred{display:flex; gap:14px; padding:16px; background:var(--teal-50); border-radius:var(--radius); border:1px solid var(--teal-100)}
.cred .ic{color:var(--teal-600); width:26px;height:26px; flex:none}
.cred b{font-family:'Poppins',sans-serif; color:var(--ink)}

/* ---------- Testimonials ---------- */
.testi{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow-sm); height:100%; display:flex; flex-direction:column}
.testi__quote{color:var(--teal-200); width:40px;height:40px; margin-bottom:6px}
.testi p{color:var(--body); font-size:1rem}
.testi__stars{color:var(--amber); display:flex; gap:2px; margin-bottom:10px}
.testi__stars .ic{width:18px;height:18px; fill:var(--amber); stroke:var(--amber)}
.testi__person{display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:14px; border-top:1px solid var(--line)}
.testi__avatar{width:46px;height:46px; border-radius:50%; background:var(--teal-600); color:#fff; display:grid; place-items:center; font-family:'Poppins',sans-serif; font-weight:600}
.testi__person b{color:var(--ink); display:block; font-size:.96rem}
.testi__person small{color:var(--muted)}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px; margin:0 auto; display:grid; gap:12px}
.faq__item{background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.faq__q{width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:20px 22px; font-family:'Poppins',sans-serif; font-weight:600; color:var(--ink); font-size:1.02rem; display:flex; justify-content:space-between; align-items:center; gap:16px}
.faq__q .ic{flex:none; color:var(--teal-600); transition:transform .25s var(--ease)}
.faq__item.is-open .faq__q .ic{transform:rotate(90deg)}
.faq__a{max-height:0; overflow:hidden; transition:max-height .3s var(--ease)}
.faq__a-inner{padding:0 22px 20px; color:var(--muted)}

/* ---------- Page hero / breadcrumb ---------- */
.page-hero{background:
  radial-gradient(800px 360px at 88% -20%, var(--teal-100), transparent 60%),
  linear-gradient(180deg,var(--teal-50),#fff); padding:clamp(40px,5vw,66px) 0 clamp(30px,4vw,44px); border-bottom:1px solid var(--line)}
.crumb{display:flex; flex-wrap:wrap; gap:.5em; font-size:.85rem; color:var(--muted); margin-bottom:1rem}
.crumb a{color:var(--teal-700)}
.crumb span{opacity:.6}
.page-hero h1{margin-bottom:.3em}
.page-hero p{max-width:46em; color:var(--body); font-size:1.08rem; margin:0}

/* ---------- Service detail ---------- */
.svc-layout{display:grid; grid-template-columns:1fr 320px; gap:46px; align-items:start}
.prose{color:var(--body)}
.prose h2{margin-top:1.6em}
.prose h2:first-child{margin-top:0}
.treatment{display:flex; gap:16px; padding:20px; border:1px solid var(--line); border-radius:var(--radius); background:#fff; box-shadow:var(--shadow-sm); margin-bottom:14px}
.treatment .ic{flex:none; width:26px;height:26px; color:#fff; background:var(--teal-600); border-radius:8px; padding:4px}
.treatment b{font-family:'Poppins',sans-serif; color:var(--ink); display:block; margin-bottom:.2em}
.treatment p{margin:0; color:var(--muted); font-size:.94rem}

.svc-aside{position:sticky; top:calc(var(--header-h) + 18px); display:grid; gap:18px}
.aside-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; box-shadow:var(--shadow-sm)}
.aside-card--teal{background:linear-gradient(160deg,var(--teal-700),var(--teal-800)); color:#fff; border:0}
.aside-card--teal h3{color:#fff}
.aside-card--teal p{color:#cdeee9}
.aside-list li{display:flex; gap:10px; padding:8px 0; border-bottom:1px solid var(--line); font-size:.95rem}
.aside-list li:last-child{border:0}
.aside-list .ic{color:var(--teal-600); flex:none}

/* ---------- Sedation benefits ---------- */
.benefit{display:flex; gap:14px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm); height:100%}
.benefit__n{width:40px;height:40px;flex:none;border-radius:12px;background:var(--teal-100);color:var(--teal-700);display:grid;place-items:center;font-family:'Poppins',sans-serif;font-weight:700}
.benefit b{font-family:'Poppins',sans-serif; color:var(--ink); display:block; margin-bottom:.2em}
.benefit p{margin:0; color:var(--muted); font-size:.93rem}

/* ---------- Gallery ---------- */
.gallery{columns:3; column-gap:18px}
.gallery figure{break-inside:avoid; margin:0 0 18px; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); position:relative}
.gallery img, .gallery .ph{width:100%; display:block}
.ph{aspect-ratio:4/3; background:linear-gradient(150deg,var(--teal-500),var(--teal-800)); display:grid; place-items:center; color:rgba(255,255,255,.92); text-align:center; padding:18px; font-family:'Poppins',sans-serif}
.ph--tall{aspect-ratio:3/4}
.gallery figcaption{position:absolute; inset:auto 0 0 0; background:linear-gradient(transparent,rgba(15,46,43,.82)); color:#fff; padding:26px 14px 12px; font-size:.88rem; font-weight:500}
.ba{display:grid; grid-template-columns:1fr 1fr; gap:4px}
.ba span{position:absolute; top:10px; left:10px; background:var(--ink); color:#fff; font-size:.7rem; padding:3px 10px; border-radius:var(--radius-pill); letter-spacing:.08em; text-transform:uppercase}
.ba > div{position:relative}
.ba > div:last-child span{background:var(--teal-600)}

/* ---------- Blog ---------- */
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),box-shadow .22s var(--ease);height:100%;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.post-card__img{aspect-ratio:16/9;width:100%;object-fit:cover;background:linear-gradient(150deg,var(--teal-500),var(--teal-800))}
.post-card__body{padding:22px;display:flex;flex-direction:column;flex:1}
.post-card__meta{font-size:.8rem;color:var(--muted);margin-bottom:.5em;display:flex;gap:.6em;align-items:center}
.post-card h3{font-size:1.16rem}
.post-card p{color:var(--muted);font-size:.94rem}
.post-card .card__link{margin-top:auto}
.tag{display:inline-block;background:var(--teal-50);color:var(--teal-700);font-size:.72rem;font-weight:600;padding:.3em .8em;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em}

.article{max-width:760px;margin:0 auto}
.article__cover{aspect-ratio:16/8;border-radius:var(--radius-lg);width:100%;object-fit:cover;margin-bottom:28px;box-shadow:var(--shadow);background:linear-gradient(150deg,var(--teal-500),var(--teal-800))}
.article-body{font-size:1.06rem;color:var(--body)}
.article-body h2{margin:1.5em 0 .5em}
.article-body ul{list-style:disc; padding-left:1.3em; margin:0 0 1.2em}
.article-body li{margin-bottom:.4em}

/* ---------- Forms ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,38px);box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-family:'Poppins',sans-serif;color:var(--ink);font-size:.92rem;margin-bottom:.45em}
.field .req{color:#dc2626}
.field input,.field select,.field textarea{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:12px;font:inherit;color:var(--ink);background:#fff;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal-500);box-shadow:0 0 0 4px var(--teal-100)}
.field textarea{min-height:130px;resize:vertical}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.85rem;color:var(--muted);margin-top:.4em}
.alert{padding:16px 18px;border-radius:12px;margin-bottom:20px;font-size:.95rem;display:flex;gap:.6em;align-items:flex-start}
.alert .ic{flex:none;margin-top:2px}
.alert--success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}
.alert--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.field-error{color:#dc2626;font-size:.82rem;margin-top:.35em;display:none}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:#dc2626}
.field.has-error .field-error{display:block}

/* contact info tiles */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start}
.info-tile{display:flex;gap:16px;padding:20px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm);margin-bottom:14px}
.info-tile__icon{width:50px;height:50px;flex:none;border-radius:14px;background:var(--teal-100);color:var(--teal-700);display:grid;place-items:center}
.info-tile b{font-family:'Poppins',sans-serif;color:var(--ink);display:block}
.info-tile a,.info-tile span{color:var(--muted)}
.map-embed{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);line-height:0}
.map-embed iframe{width:100%;height:340px;border:0}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--teal-700),var(--teal-600)); color:#fff}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:26px;padding:clamp(34px,4vw,54px) 0}
.cta-band h2{color:#fff;margin-bottom:.2em}
.cta-band p{color:#d8f5f0;margin:0}
.cta-band__actions{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-900);color:#bfe6e0;font-size:.94rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:34px;padding:clamp(44px,5vw,66px) 0 36px}
.brand--footer .brand__text strong{color:#fff}
.brand--footer .brand__text small{color:#8fc9c1}
.footer__about{margin:16px 0 18px;color:#9fd4cd;line-height:1.6}
.footer__social{display:flex;gap:10px}
.footer__social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;font-family:'Poppins',sans-serif;font-weight:600;font-size:.85rem}
.footer__social a:hover{background:var(--teal-600)}
.site-footer h3{color:#fff;font-size:1.02rem;margin-bottom:1em}
.footer__col ul li{margin-bottom:.55em}
.footer__col a{color:#9fd4cd}
.footer__col a:hover{color:#fff}
.footer__contact li{display:flex;gap:10px;margin-bottom:.9em;align-items:flex-start}
.footer__contact .ic{flex:none;color:var(--teal-400);width:20px;height:20px;margin-top:2px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer__bottom-inner{display:flex;justify-content:space-between;gap:12px;padding:18px 0;font-size:.84rem;color:#7fbfb7;flex-wrap:wrap}

/* ---------- Floating actions / to-top ---------- */
.float-actions{position:fixed;right:18px;bottom:18px;z-index:90;display:flex;flex-direction:column;gap:12px}
.float-btn{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-lg);transition:transform .2s var(--ease)}
.float-btn:hover{transform:scale(1.08);color:#fff}
.float-btn .ic{width:26px;height:26px}
.float-btn--wa{background:#25d366}
.float-btn--call{background:var(--teal-600)}
.to-top{position:fixed;left:18px;bottom:18px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--teal-700);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s var(--ease);z-index:90}
.to-top .ic{transform:rotate(-90deg)}
.to-top.is-visible{opacity:1;visibility:visible;transform:none}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Utilities ---------- */
.text-center{text-align:center}
.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}.mb-0{margin-bottom:0}
.lead{font-size:1.12rem;color:var(--body)}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr; gap:34px}
  .hero__art{max-width:440px;margin:0 auto}
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .svc-layout{grid-template-columns:1fr}
  .svc-aside{position:static}
  .gallery{columns:2}
}
@media (max-width:1080px){
  /* Switch to the hamburger drawer before the horizontal nav gets cramped */
  .nav-toggle{display:grid}
  /* backdrop-filter here would trap the fixed drawer inside the header box, so remove it on mobile */
  .site-header{background:#fff; backdrop-filter:none; -webkit-backdrop-filter:none}
  .primary-nav{position:fixed;inset:0 0 0 auto;width:min(342px,88vw);background:#fff;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .3s var(--ease);padding:104px 20px 32px;overflow-y:auto;z-index:130}
  body.nav-open .primary-nav{transform:none}
  body.nav-open .nav-toggle__open{display:none}
  body.nav-open .nav-toggle__close{display:block}
  body.nav-open{overflow:hidden}
  .nav-list{flex-direction:column;align-items:stretch;gap:2px}
  .nav-list > li > a{padding:.85em 1em;border-radius:10px;font-size:1.02rem}
  .nav-list > li > a .ic{margin-left:auto}
  .nav-cta{margin:14px 0 0}
  .nav-cta .btn{width:100%;justify-content:center}
  .mega{position:static;width:auto;transform:none;opacity:1;visibility:visible;box-shadow:none;border:0;padding:4px 0 8px 12px;display:none}
  .has-mega.is-expanded .mega{display:block}
  .mega__grid{grid-template-columns:1fr}
  .mega__item{padding:9px 10px}
  .nav-backdrop{position:fixed;inset:0;background:rgba(15,46,43,.5);opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s var(--ease);z-index:90}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible}
  body.nav-open .float-actions, body.nav-open .to-top, body.nav-open .mvchat{display:none}
  .grid--3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .split{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cta-band__inner{flex-direction:column;text-align:center;align-items:center}
  .footer__grid{grid-template-columns:1fr 1fr}
  .topbar__right{display:none}
}
@media (max-width:680px){
  .section{padding:clamp(46px,9vw,72px) 0}
  .section-head{margin-bottom:30px}
  .hero__lead{font-size:1.06rem}
  .hero__cta{gap:10px}
  .hero__cta .btn{flex:1 1 auto;justify-content:center}
  .btn--lg{padding:.92em 1.4em;font-size:1rem}
  .page-hero p{font-size:1rem}
}
@media (max-width:560px){
  .container{padding:0 18px}
  .grid--3,.grid--4,.grid--2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:14px}
  .field--row{grid-template-columns:1fr}
  .gallery{columns:1}
  .footer__grid{grid-template-columns:1fr;gap:26px}
  .card{padding:22px}
  .testi,.form-card{padding:22px}
  .cta-band__actions{width:100%}
  .cta-band__actions .btn{flex:1;justify-content:center}
  .hero__badge--a{left:8px}
  .hero__badge--b{right:8px}
  /* keep the MediVista name + tagline visible and prominent on phones */
  .brand img{width:46px;height:46px}
  .brand__text strong{font-size:1.35rem}
  .brand__text small{font-size:.64rem}
}
@media (max-width:480px){
  .topbar{font-size:.8rem}
  .topbar__left{gap:8px}
  .topbar__left .topbar__sep,.topbar__left a:last-child{display:none}
}
@media (max-width:400px){
  .container{padding:0 15px}
  h1{font-size:1.9rem}
  .section{padding:40px 0}
  .stat{padding:18px}
  .stat__num{font-size:1.8rem}
  .float-btn{width:50px;height:50px}
  .brand{gap:9px}
  .brand img{width:42px;height:42px}
  .brand__text strong{font-size:1.22rem}
  .brand__text small{font-size:.56rem;letter-spacing:.02em}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
