/* =====================================================================
   Dr Sameer Ghoderao (MBBS, D-Ortho) — public site styles
   ===================================================================== */
:root{
  --blue:#0B3357;        /* deep forest/teal */
  --blue-2:#1d4d7a;      /* medium blue */
  --blue-soft:#eaf0f3;   /* light-blue section bg */
  --accent:#f4733b;       /* coral-orange */
  --accent-dark:#e05f29;
  --ink:#1c212b;
  --muted:#5d636b;
  --line:#e3e9ec;
  --white:#fff;
  --hero-1:#10324a;
  --hero-2:#0B3357;
  --radius:18px;
  --radius-lg:28px;
  --shadow:0 18px 50px rgba(16,50,45,.10);
  --shadow-sm:0 8px 24px rgba(16,50,45,.08);
  --container:1200px;
  --font:'Plus Jakarta Sans',system-ui,Segoe UI,Roboto,sans-serif;
  --display:'Poppins',var(--font);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--white);line-height:1.65;font-size:16px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);color:var(--blue);line-height:1.2;margin:0 0 .5em}
p{margin:0 0 1em}
.container{width:min(var(--container),92%);margin-inline:auto}
svg{width:1em;height:1em}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--display);font-weight:600;
  border:none;cursor:pointer;border-radius:999px;padding:.85em 1.6em;font-size:.95rem;transition:.2s;text-align:center}
.btn svg{width:1.1em;height:1.1em}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:var(--accent-dark);transform:translateY(-2px)}
.btn--blue{background:var(--blue);color:#fff}
.btn--blue:hover{background:#0f233f}
.btn--ghost{background:#fff;color:var(--blue);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn--light{background:#fff;color:var(--blue)}
.btn--block{width:100%;justify-content:center}
.btn--sm{padding:.6em 1.1em;font-size:.85rem}

/* ---- top marquee ---- */
.topbar{background:#0B3357;color:#dfe8f0;display:flex;align-items:center;gap:1rem;
  padding:0 4%;font-size:.82rem;overflow:hidden;height:38px}
.topbar__text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar__social{display:flex;gap:.7rem;flex-shrink:0}
.topbar__social a{display:grid;place-items:center;width:26px;height:26px;color:#dfe8f0;opacity:.9}
.topbar__social a:hover{opacity:1;color:#fff}
.topbar__social svg{width:15px;height:15px}

/* ---- header / nav ---- */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  box-shadow:0 4px 24px rgba(16,50,45,.06)}
.header__inner{display:flex;align-items:center;gap:1.2rem;padding:.65rem 0}
.brand{display:flex;align-items:center;gap:.6rem}
.brand .logo-icon{width:160px;height:50px}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__text strong{font-family:var(--display);color:var(--blue);font-size:1.02rem;letter-spacing:.2px}
.brand__text small{color:var(--accent);font-size:.68rem;font-weight:600;letter-spacing:.4px;text-transform:uppercase}
.brand--light .brand__text strong{color:#fff}.brand--light .brand__text small{color:#9fc2e0}

.nav{margin-left:auto}
.nav__list{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.nav__list>li>a{display:flex;align-items:center;gap:.25rem;padding:.55rem .8rem;font-weight:600;font-size:.92rem;color:var(--ink);border-radius:10px}
.nav__list>li>a:hover,.nav__list>li>a.active{color:var(--blue);background:var(--blue-soft)}
.caret{font-size:.7rem}
.header__cta .btn--phone{background:var(--blue);color:#fff;font-size:.85rem;padding:.6em 1.1em}
.header__cta .btn--phone:hover{background:#0f233f}

/* mega menu + dropdown */
.has-mega,.has-dropdown{position:relative}
.mega,.dropdown{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border-radius:16px;
  box-shadow:var(--shadow);padding:1.2rem;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.2s;z-index:70}
.mega{display:flex;gap:2rem;min-width:520px}
.dropdown{min-width:230px;display:flex;flex-direction:column}
.has-mega:hover .mega,.has-dropdown:hover .dropdown,.mega.open,.dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.mega__col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.6px;color:var(--accent);margin-bottom:.6rem}
.mega__col a,.dropdown a{display:block;padding:.5rem .6rem;border-radius:8px;font-size:.9rem;color:var(--ink);font-weight:500}
.mega__col a:hover,.dropdown a:hover{background:var(--blue-soft);color:var(--blue)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{width:26px;height:2.5px;background:var(--blue);border-radius:2px;transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---- side tabs ---- */
.sidetab{position:fixed;top:50%;z-index:40;writing-mode:vertical-rl;transform:translateY(-50%);
  padding:1rem .5rem;font-family:var(--display);font-weight:600;font-size:.82rem;border:none;cursor:pointer;color:#fff}
.sidetab--left{left:0;background:var(--accent);border-radius:0 10px 10px 0}
.sidetab--right{right:0;background:var(--hero-1);border-radius:10px 0 0 10px;transform:translateY(-50%) rotate(180deg)}
.sidetab:hover{filter:brightness(1.08)}

/* ---- generic section ---- */
.section{padding:5rem 0}
.section--light-blue{background:var(--blue-soft)}
.section--blue{background:var(--blue);color:#dbe7ee}
.section--blue h2,.section--blue h3{color:#fff}
.eyebrow{display:inline-block;background:rgba(244,115,59,.12);color:var(--accent);font-weight:600;
  font-size:.78rem;padding:.4rem 1rem;border-radius:999px;margin-bottom:1rem;letter-spacing:.3px}
.section--blue .eyebrow{background:rgba(255,255,255,.12);color:#fff}
.section__head{text-align:center;max-width:760px;margin:0 auto 3rem}
.section__head h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}
.section__head p{color:var(--muted)}
.section--blue .section__head p{color:#bfd2e0}

/* ---- hero ---- */
.hero{background:linear-gradient(120deg,var(--hero-1),var(--hero-2));color:#fff;position:relative;overflow:hidden;padding:4.5rem 0 5rem}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.hero__label{display:inline-block;background:rgba(255,255,255,.14);padding:.5rem 1.1rem;border-radius:999px;font-size:.82rem;font-weight:600;margin-bottom:1.4rem}
.hero h1{color:#fff;font-size:clamp(2rem,4.6vw,3.3rem);margin-bottom:1rem}
.hero__sub{color:#cfdae3;max-width:34rem;margin-bottom:1.8rem}
.hero__reviews{display:flex;align-items:center;gap:.8rem;margin-top:2rem}
.hero__avatars{display:flex}
.hero__avatars span{width:38px;height:38px;border-radius:50%;border:2px solid #fff;margin-left:-10px;background:#cfdae3 center/cover;display:grid;place-items:center;color:var(--blue);font-weight:700}
.hero__avatars span:first-child{margin-left:0}
.hero__reviews small{display:block;color:#cfdae3;font-size:.8rem}
.hero__reviews strong{color:#fff}
.hero__media{position:relative}
.hero__media .hero__photo{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/4.2;object-fit:cover;background:rgba(255,255,255,.06)}
.hero__badge{position:absolute;background:#fff;color:var(--ink);border-radius:14px;padding:.7rem 1rem;box-shadow:var(--shadow);font-size:.8rem;display:flex;flex-direction:column;font-weight:700}
.hero__badge b{color:var(--blue);font-size:1.15rem}
.hero__badge--1{top:18px;left:-12px}
.hero__badge--2{bottom:22px;right:-10px}

/* ---- meet doctor ---- */
.meet{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.meet__media{position:relative;display:grid;place-items:center}
.meet__disc{width:min(420px,90%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 50% 40%,#cde0ee,#1d4d7a);display:grid;place-items:center;overflow:hidden}
.meet__disc img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.meet__card{position:absolute;bottom:6%;background:#fff;border-radius:14px;padding:.8rem 1.1rem;box-shadow:var(--shadow);max-width:80%}
.meet__card strong{display:block;color:var(--blue)}
.meet__card small{color:var(--muted)}

/* ---- service cards ---- */
.cards{display:grid;gap:1.5rem}
.cards--2{grid-template-columns:repeat(2,1fr)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.scard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;transition:.25s;display:flex;flex-direction:column}
.scard:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:transparent}
.scard__icon{width:64px;height:64px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;margin-bottom:1.2rem}
.scard__icon svg{width:30px;height:30px}
.scard h3{font-size:1.25rem}
.scard__tag{color:var(--accent);font-weight:600;font-size:.82rem;margin-bottom:.6rem}
.scard p{color:var(--muted);font-size:.94rem;flex:1}
.scard .link{color:var(--blue);font-weight:600;display:inline-flex;align-items:center;gap:.3rem;margin-top:.8rem}
.scard .link svg{width:1.1em}

/* ---- video testimonials ---- */
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.vcard{position:relative;border-radius:16px;overflow:hidden;background:#0d203b;aspect-ratio:9/12;box-shadow:var(--shadow-sm);cursor:pointer}
.vcard__thumb{width:100%;height:100%;object-fit:cover;opacity:.85}
.vcard__play{position:absolute;inset:0;display:grid;place-items:center}
.vcard__play span{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--blue);display:grid;place-items:center}
.vcard__play svg{width:24px;height:24px}
.vcard__cap{position:absolute;left:0;right:0;bottom:0;padding:.8rem;color:#fff;font-size:.82rem;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.center{text-align:center}
.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
[hidden]{display:none!important}

/* ---- CORI ---- */
.cori{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:center}
.cori__media{display:grid;place-items:center}
.cori__disc{width:min(380px,90%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,#cde0ee,#1d4d7a);display:grid;place-items:center;overflow:hidden}
.cori__disc img{width:78%}
.cori ul.ticks{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:1.2rem 0}
.cori ul.ticks li{display:flex;gap:.5rem;align-items:center;font-weight:600;color:var(--blue);font-size:.9rem}
.cori ul.ticks li svg{color:var(--accent);width:1.1em;flex-shrink:0}
.brochures{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:1.5rem}
.brochure{display:flex;align-items:center;gap:.5rem;background:var(--blue-soft);color:var(--blue);padding:.7rem 1rem;border-radius:10px;font-weight:600;font-size:.85rem}
.brochure:hover{background:#dce6eb}

/* ---- reviews marquee ---- */
.reviews-marquee{overflow:hidden;width:100%;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.reviews-track{display:flex;gap:1.3rem;animation:reviewScroll 30s linear infinite;width:max-content}
.reviews-track:hover{animation-play-state:paused}
@keyframes reviewScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.rcard{flex:0 0 340px;background:#fff;border-radius:16px;padding:1.6rem;box-shadow:var(--shadow-sm)}
.rcard .stars{color:#f5b301;margin-bottom:.6rem;font-size:1rem}
.rcard p{color:var(--ink);font-size:.92rem}
.rcard__by{display:flex;align-items:center;gap:.6rem;margin-top:1rem}
.rcard__g{width:34px;height:34px;border-radius:50%;background:var(--blue-soft);display:grid;place-items:center;color:#4285F4;font-weight:800}
.rcard__by strong{display:block;font-size:.9rem}
.rcard__by small{color:var(--muted);font-size:.78rem}
.star{color:#d9d9d9}.star.filled{color:#f5b301}

/* ---- benefits ---- */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.bchip{display:flex;gap:.7rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;font-weight:600;font-size:.9rem;color:var(--blue)}
.bchip__i{width:38px;height:38px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;flex-shrink:0}
.bchip__i svg{width:18px;height:18px}

/* ---- process ---- */
.process{display:grid;grid-template-columns:1fr 1.3fr;gap:3rem;align-items:start}
.steps{display:grid;gap:1rem}
.step{background:#fff;border-radius:14px;padding:1.3rem 1.5rem;box-shadow:var(--shadow-sm);display:flex;gap:1rem}
.step__n{width:40px;height:40px;flex-shrink:0;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--display);font-weight:700;display:grid;place-items:center}
.step h4{margin-bottom:.3rem;font-size:1.05rem}
.step p{color:var(--muted);font-size:.9rem;margin:0}

/* ---- press logos ---- */
.press{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center}
.press__item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.6rem;font-family:var(--display);font-weight:700;color:var(--blue);min-width:140px;text-align:center}

/* ---- faq ---- */
.faq{max-width:820px;margin:0 auto;display:grid;gap:.8rem}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.faq__q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.1rem 1.3rem;font-family:var(--display);
  font-weight:600;font-size:1rem;color:var(--blue);display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq__q .chev{transition:.3s;flex-shrink:0}
.faq__item.open .chev{transform:rotate(180deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq__a p{padding:0 1.3rem 1.2rem;color:var(--muted);margin:0}

/* ---- cta band ---- */
.ctaband{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:center;background:var(--blue);
  color:#fff;border-radius:var(--radius-lg);padding:3rem;overflow:hidden}
.ctaband h2{color:#fff}.ctaband p{color:#bfd2e0}
.ctaband__media img{border-radius:16px}

/* ---- page banner ---- */
.pagehead{background:var(--blue);color:#fff;border-radius:0 0 0 0;padding:3.2rem 0;text-align:center}
.pagehead h1{color:#fff;font-size:clamp(1.8rem,4vw,2.8rem)}
.crumb{display:inline-flex;gap:.5rem;background:rgba(255,255,255,.12);padding:.4rem 1rem;border-radius:999px;font-size:.85rem;margin-top:.6rem}
.crumb a{color:#cfdae3}

/* ---- about ---- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem;align-items:start}
.about-photo{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);position:sticky;top:120px}
.about-photo img{width:100%}
.about-photo__cap{padding:1.2rem}
.about-photo__cap .eyebrow{margin-bottom:.5rem}
.about-exp-badge{display:flex;align-items:center;gap:1.2rem;background:linear-gradient(135deg,var(--blue),var(--blue-2));
  color:#fff;border-radius:16px;padding:1.4rem 1.8rem;margin:1.5rem 0}
.about-exp-badge__number{font-family:var(--display);font-size:3rem;font-weight:800;line-height:1;letter-spacing:-1px}
.about-exp-badge__text{font-size:.9rem;font-weight:600;line-height:1.3;opacity:.9}
.infocards{display:grid;gap:1.2rem}
.infocard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.5rem;display:flex;gap:1rem;transition:.2s}
.infocard:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px);border-color:transparent}
.infocard__i{width:52px;height:52px;flex-shrink:0;border-radius:14px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center}
.infocard h4{margin-bottom:.4rem}
.infocard p{margin:0;color:var(--muted);font-size:.9rem}
.infocard ul{margin:.3rem 0 0;padding-left:1.1rem;color:var(--muted);font-size:.9rem}
.infocard ul li{margin-bottom:.4rem}
.infocard ul li strong{color:var(--blue)}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.form{display:grid;gap:1rem}
.form-row label{display:block;font-weight:600;font-size:.88rem;color:var(--blue)}
.form-row input,.form-row textarea,.form-row select{width:100%;margin-top:.35rem;padding:.8rem 1rem;border:1.5px solid var(--line);
  border-radius:10px;font:inherit;font-size:.95rem;background:#fff}
.form-row input:focus,.form-row textarea:focus{outline:none;border-color:var(--blue-2)}
.form-flash{padding:.8rem 1rem;border-radius:10px;font-size:.9rem;margin-bottom:.4rem}
.form-flash.ok{background:#e7f0f6;color:#164d79}
.form-flash.err{background:#fdeceb;color:#c0392b}
.contact-cards{display:grid;gap:1rem}
.ccard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.2rem;display:flex;gap:.9rem;align-items:flex-start}
.ccard__i{width:46px;height:46px;flex-shrink:0;border-radius:12px;background:var(--blue);color:#fff;display:grid;place-items:center}
.ccard h4{margin-bottom:.2rem;font-size:1rem}.ccard p{margin:0;color:var(--muted);font-size:.88rem}
.map-embed{margin-top:1rem;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.map-embed iframe{width:100%;height:280px;border:0;display:block}

/* ---- blog ---- */
.bloggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.post-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.post-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.post-card__img{aspect-ratio:16/10;object-fit:cover;background:var(--blue-soft);width:100%}
.post-card__body{padding:1.2rem;display:flex;flex-direction:column;flex:1}
.post-card__meta{font-size:.78rem;color:var(--muted);margin-bottom:.5rem}
.post-card h3{font-size:1.1rem;margin-bottom:.5rem}
.post-card p{color:var(--muted);font-size:.9rem;flex:1}
.chips{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.chips a{padding:.45rem 1rem;border-radius:999px;border:1.5px solid var(--line);font-size:.85rem;font-weight:600;color:var(--muted)}
.chips a.active,.chips a:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ---- single post ---- */
.post-wrap{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
.post-body{font-size:1.02rem}
.post-body img{border-radius:14px;margin:1.2rem 0}
.post-body h2{font-size:1.5rem;margin:1.6rem 0 .6rem}
.post-body ul{padding-left:1.2rem}
.post-body li{margin-bottom:.4rem}
.author-card{position:sticky;top:120px;background:var(--blue-soft);border-radius:16px;padding:1.5rem;text-align:center}
.author-card img{width:90px;height:90px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;background:#fff}
.author-card h4{margin-bottom:.2rem}
.author-card small{color:var(--muted)}
.author-card .btns{display:grid;gap:.5rem;margin-top:1rem}
.share{display:flex;gap:.6rem;margin:1.5rem 0;align-items:center}
.share a{width:38px;height:38px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center}

/* ---- floating buttons ---- */
.fab{position:fixed;right:18px;bottom:18px;z-index:55;display:flex;flex-direction:column;gap:.6rem}
.fab__btn{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow);transition:.2s}
.fab__btn:hover{transform:scale(1.08)}
.fab__btn svg{width:26px;height:26px}
.fab__btn--wa{background:#25a0d3}
.fab__btn--call{background:var(--blue)}

/* ---- footer ---- */
.footer{background:#0f213a;color:#bcc9d6;padding:3.5rem 0 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.4fr;gap:2.5rem;padding-bottom:2.5rem}
.footer h4{color:#fff;margin-bottom:1rem;font-size:1.05rem}
.footer__links{display:flex;flex-direction:column;gap:.5rem}
.footer__links a:hover{color:#fff}
.footer__about p{font-size:.9rem;margin-top:1rem}
.footer__social{display:flex;gap:.6rem;margin-top:1rem}
.footer__social a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;color:#fff}
.footer__social a:hover{background:var(--accent)}
.footer__social svg{width:16px;height:16px}
.footer__contact p{display:flex;gap:.5rem;font-size:.88rem;margin-bottom:.8rem}
.footer__contact svg{width:18px;flex-shrink:0;color:#7fa5c4;margin-top:3px}
.footer__phone{display:inline-flex;gap:.5rem;align-items:center;color:#fff;font-weight:600;margin-bottom:1rem}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.2rem 0;font-size:.82rem}
.footer__bottom .container{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

/* ---- modal ---- */
.modal{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;padding:1rem}
.modal.open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(10,30,24,.6)}
.modal__dialog{position:relative;background:#fff;border-radius:20px;padding:2rem;width:min(460px,100%);max-height:92vh;overflow:auto;box-shadow:var(--shadow)}
.modal__close{position:absolute;top:1rem;right:1.1rem;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--muted);line-height:1}
.modal__sub{color:var(--muted);font-size:.9rem;margin-bottom:1rem}

/* ---- 404 ---- */
.err404{text-align:center;padding:5rem 0}
.err404 h1{font-size:5rem;color:var(--accent)}

/* ---- responsive ---- */
@media(max-width:980px){
  .hero__grid,.meet,.cori,.process,.about-grid,.contact-grid,.ctaband,.post-wrap{grid-template-columns:1fr}
  .vgrid{grid-template-columns:repeat(3,1fr)}
  .bloggrid,.benefits{grid-template-columns:repeat(2,1fr)}
  .cards--3,.cards--4{grid-template-columns:repeat(2,1fr)}
  .about-photo,.author-card{position:static}
  .post-wrap{grid-template-columns:1fr}
}
@media(max-width:820px){
  .nav-toggle{display:flex}
  .nav{position:fixed;inset:0 0 0 auto;width:min(320px,85%);background:#fff;margin:0;padding:5rem 1.2rem 2rem;
    transform:translateX(100%);transition:.3s;box-shadow:-10px 0 40px rgba(0,0,0,.1);overflow-y:auto;z-index:65}
  .nav.open{transform:translateX(0)}
  .nav__list{flex-direction:column;align-items:stretch;gap:.2rem}
  .nav__list>li>a{padding:.8rem 1rem}
  .mega,.dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding:.4rem 0 .4rem 1rem;min-width:auto;display:block}
  .mega{display:block}
  .header__cta{display:none}
  .topbar__text{font-size:.75rem}
}
@media(max-width:560px){
  .vgrid{grid-template-columns:repeat(2,1fr)}
  .bloggrid,.benefits,.cards--2,.cards--3,.cards--4,.cori ul.ticks,.brochures{grid-template-columns:1fr}
  .section{padding:3.2rem 0}
  .footer__grid{grid-template-columns:1fr}
  .ctaband{padding:2rem}
  .sidetab{display:none}
}
