/* ===========================================================================
   MedImpact Advisory — shared stylesheet
   Design system: "Clean Clinical" (homepage variant 16)
   Manrope · teal/ink palette · parallax medical motifs · scroll-reveal
   =========================================================================== */

:root{
  --ink:#0f2c30; --teal:#0aa3a3; --teal-d:#06807f; --teal-l:#e6f7f6; --mint:#d6f0ec;
  --paper:#fff; --bg:#f4fafa; --slate:#4f6b6e; --muted:#7d9598; --line:#dceaea;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.65;overflow-x:hidden}
.wrap{max-width:1160px;margin:0 auto;padding:0 30px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{line-height:1.08;letter-spacing:-.025em;font-weight:800}
.kicker{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--teal-d)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.92rem;padding:.95rem 1.9rem;border-radius:12px;transition:.25s;cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 12px 28px -14px rgba(10,163,163,.7)}
.btn-primary:hover{background:var(--teal-d);transform:translateY(-2px)}
.btn-out{border-color:var(--line);color:var(--ink)}
.btn-out:hover{border-color:var(--teal);color:var(--teal-d)}

/* ---- Header / nav ---- */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.3s}
header.scrolled{background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{font-weight:800;font-size:1.25rem;color:var(--ink)}.brand b{color:var(--teal)}
.navlinks{display:flex;gap:1.7rem}
.navlinks a{font-size:.9rem;font-weight:600;color:var(--slate)}
.navlinks a:hover{color:var(--teal-d)}
.navlinks a.active{color:var(--teal-d)}
.navlinks .navcta{display:none}
.nav-r{display:flex;align-items:center;gap:1.2rem}
.lang{font-size:.8rem;font-weight:700;color:var(--slate)}.lang b{color:var(--teal)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--ink)}

/* ---- Hero (home, full viewport) ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(180deg,var(--teal-l),#fff 70%)}
.hero .motif{position:absolute;will-change:transform;opacity:.9}
.m1{top:14%;right:8%;color:var(--teal);opacity:.18}
.m2{bottom:16%;right:24%;color:var(--teal-d);opacity:.14}
.m3{top:30%;left:4%;color:var(--teal);opacity:.12}
.hero .blob{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(10,163,163,.18),transparent 70%);will-change:transform}
.hb1{width:420px;height:420px;top:-100px;right:-60px}
.hb2{width:300px;height:300px;bottom:-80px;left:-60px;background:radial-gradient(circle,rgba(10,163,163,.12),transparent 70%)}
.hero .wrap{position:relative;z-index:4;max-width:760px}
.hero h1{font-size:clamp(2.8rem,6.6vw,5.4rem);margin:20px 0 22px;color:var(--ink)}
.hero h1 span{color:var(--teal)}
.hero p{font-size:1.18rem;color:var(--slate);max-width:54ch}
.actions{display:flex;gap:16px;margin-top:36px;flex-wrap:wrap}

/* ---- Page banner (inner pages, compact hero) ---- */
.pagehero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--teal-l),#fff 85%);padding:160px 0 70px}
.pagehero .blob{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(10,163,163,.16),transparent 70%);will-change:transform}
.pagehero .pb1{width:380px;height:380px;top:-120px;right:-60px}
.pagehero .motif{position:absolute;color:var(--teal);opacity:.14;will-change:transform;top:30px;left:3%}
.pagehero .wrap{position:relative;z-index:3;max-width:760px}
.pagehero h1{font-size:clamp(2.4rem,5vw,3.8rem);margin:16px 0 18px;color:var(--ink)}
.pagehero h1 span{color:var(--teal)}
.pagehero p{font-size:1.14rem;color:var(--slate);max-width:60ch}

/* ---- Trust bar ---- */
.trustbar{background:var(--ink);padding:30px 0;color:#fff}
.trustbar .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:18px;text-align:center}
.trustbar b{display:block;font-size:1.9rem;color:#6fe0db}
.trustbar span{font-size:.8rem;color:#a7c4c5}

/* ---- Generic section ---- */
section{padding:106px 0;position:relative}
.sec-head{max-width:680px;margin-bottom:52px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,4vw,3.1rem);margin:14px 0;color:var(--ink)}
.sec-head p{color:var(--slate)}

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

/* ---- Values grid (home) ---- */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.value{padding:30px 24px;border-radius:18px;background:var(--bg);border:1px solid var(--line);transition:.3s}
.value:hover{transform:translateY(-5px);box-shadow:0 24px 50px -32px rgba(15,44,48,.4);border-color:var(--teal)}
.value .ic{width:48px;height:48px;border-radius:14px;background:var(--mint);display:flex;align-items:center;justify-content:center;color:var(--teal-d);margin-bottom:16px}
.value h3{font-size:1.12rem;margin-bottom:10px;color:var(--ink)}
.value p{font-size:.9rem;color:var(--slate)}

/* ---- Parallax stat band ---- */
.statband{position:relative;overflow:hidden;background:var(--teal);color:#fff;text-align:center;padding:120px 0}
.statband .motif{position:absolute;will-change:transform;color:#fff;opacity:.12}
.sm1{top:-30px;left:6%}.sm2{bottom:-40px;right:8%}
.statband .wrap{position:relative;z-index:2}
.statband h2{font-size:clamp(1.8rem,4vw,2.8rem);max-width:24ch;margin:0 auto;color:#fff}
.statband .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:44px}
.statband .grid b{display:block;font-size:2.6rem;font-weight:800;color:#fff}
.statband .grid span{font-size:.9rem;color:#cdeeec}

/* ---- Services teaser / cards ---- */
.services{background:var(--bg)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px;transition:.3s}
.svc:hover{transform:translateY(-5px);box-shadow:0 24px 50px -32px rgba(15,44,48,.4);border-color:var(--teal)}
.svc .n{color:var(--teal);font-size:.9rem;font-weight:800}
.svc h3{font-size:1.42rem;margin:8px 0 12px;color:var(--ink)}
.svc p{color:var(--slate);font-size:.94rem}

/* ---- "Who we are" feature block ---- */
.founder{overflow:hidden}
.founder .grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.founder .fig{position:relative;height:480px;border-radius:22px;overflow:hidden;background:var(--teal-l)}
.founder .fig .img{position:absolute;inset:-16% 0;background:linear-gradient(0deg,rgba(15,44,48,.25),transparent 50%),url('https://images.unsplash.com/photo-1576091160550-2173dba999ef?auto=format&fit=crop&w=1400&q=70') center/cover no-repeat,var(--teal-l);will-change:transform}
.founder .fig .motif{position:absolute;bottom:24px;right:24px;color:#fff;opacity:.5;will-change:transform;z-index:2}
.founder h2{font-size:clamp(2rem,3.8vw,2.9rem);color:var(--ink);margin:14px 0 18px}
.founder p{color:var(--slate);margin-bottom:16px}
.founder .pull{font-size:1.3rem;font-weight:700;color:var(--teal-d);border-left:3px solid var(--teal);padding-left:18px;margin:22px 0}

/* ---- Clients / sectors strip ---- */
.clients .logos{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.clients .logos span{background:var(--bg);border:1px solid var(--line);border-radius:50px;padding:.7rem 1.4rem;font-size:.86rem;color:var(--slate);font-weight:600;transition:.2s}
.clients .logos span:hover{border-color:var(--teal);color:var(--teal-d)}

/* ---- CTA band ---- */
.cta{position:relative;overflow:hidden;text-align:center;background:linear-gradient(135deg,var(--teal),var(--teal-d));color:#fff}
.cta .blob{position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);top:-160px;left:50%;transform:translateX(-50%);will-change:transform}
.cta .wrap{position:relative;z-index:2}
.cta h2{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff}
.cta p{max-width:50ch;margin:18px auto 32px;color:#dff5f3}
.cta .btn-primary{background:#fff;color:var(--teal-d)}.cta .btn-primary:hover{background:var(--teal-l)}

/* ===========================================================================
   Inner-page components
   =========================================================================== */

/* ---- Prose / lead text ---- */
.prose{max-width:760px}
.prose.center{margin:0 auto;text-align:center}
.lead{font-size:1.22rem;color:var(--slate);line-height:1.7}
.prose p{color:var(--slate);margin-bottom:18px}
.prose h2{font-size:clamp(1.8rem,3.4vw,2.5rem);color:var(--ink);margin:8px 0 18px}
.prose h3{font-size:1.3rem;color:var(--ink);margin:30px 0 12px}

/* ---- Two-column intro (about) ---- */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start}
.split .fig{position:relative;height:440px;border-radius:22px;overflow:hidden;background:var(--teal-l)}
.split .fig .img{position:absolute;inset:-14% 0;background:linear-gradient(0deg,rgba(15,44,48,.28),transparent 55%),url('https://images.unsplash.com/photo-1576091160550-2173dba999ef?auto=format&fit=crop&w=1400&q=70') center/cover no-repeat;will-change:transform}

/* ---- "Why it matters" list ---- */
.matters{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:18px}
.matters .item{background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:28px 24px;transition:.3s}
.matters .item:hover{border-color:var(--teal);transform:translateY(-4px)}
.matters .item h4{font-size:1.02rem;color:var(--ink);margin-bottom:10px}
.matters .item p{font-size:.9rem;color:var(--slate)}

/* ---- Value proposition checklist ---- */
.vplist{display:grid;grid-template-columns:1fr 1fr;gap:14px 36px;margin-top:10px}
.vplist li{list-style:none;display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--slate)}
.vplist li b{color:var(--ink)}
.vplist .ck{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--mint);color:var(--teal-d);display:flex;align-items:center;justify-content:center;margin-top:2px}

/* ---- Detailed service blocks ---- */
.svc-detail{display:grid;gap:26px}
.svc-block{background:#fff;border:1px solid var(--line);border-radius:22px;padding:42px;transition:.3s}
.svc-block:hover{box-shadow:0 30px 60px -42px rgba(15,44,48,.4);border-color:var(--teal)}
.svc-block .head{display:flex;align-items:baseline;gap:18px;margin-bottom:6px}
.svc-block .num{font-size:2.4rem;font-weight:800;color:var(--mint);line-height:1;letter-spacing:-.04em}
.svc-block h3{font-size:1.55rem;color:var(--ink)}
.svc-block .desc{color:var(--slate);margin:6px 0 22px;max-width:70ch}
.svc-block .cols{display:grid;grid-template-columns:1.2fr .8fr;gap:34px;align-items:start}
.svc-block ul{list-style:none}
.svc-block ul li{display:flex;gap:12px;padding:9px 0;color:var(--ink);font-size:.96rem;font-weight:500}
.svc-block ul li svg{flex:0 0 auto;color:var(--teal);margin-top:5px}
.outcome{background:var(--teal-l);border-radius:16px;padding:24px;border-left:3px solid var(--teal)}
.outcome b{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-d);margin-bottom:8px}
.outcome p{color:var(--ink);font-size:.96rem;font-weight:500;margin:0}

/* ---- Approach / methodology steps ---- */
.method{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.method .col{background:var(--bg);border:1px solid var(--line);border-radius:22px;padding:40px}
.method .col h3{font-size:1.5rem;color:var(--ink);margin-bottom:8px}
.method .col .sub{color:var(--slate);font-size:.95rem;margin-bottom:24px}
.steps{counter-reset:step;display:grid;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start}
.step .dot{counter-increment:step;flex:0 0 auto;width:40px;height:40px;border-radius:12px;background:var(--teal);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center}
.step .dot::before{content:counter(step,decimal-leading-zero)}
.step h4{font-size:1.05rem;color:var(--ink);margin-bottom:4px}
.step p{font-size:.9rem;color:var(--slate)}

/* ---- Sectors / segment cards ---- */
.seg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.seg{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px;transition:.3s}
.seg:hover{transform:translateY(-5px);box-shadow:0 24px 50px -32px rgba(15,44,48,.4);border-color:var(--teal)}
.seg .ic{width:48px;height:48px;border-radius:14px;background:var(--mint);color:var(--teal-d);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.seg h3{font-size:1.18rem;color:var(--ink);margin-bottom:8px}
.seg p{font-size:.9rem;color:var(--slate)}
.seg .eg{display:block;margin-top:12px;font-size:.82rem;color:var(--muted);font-weight:600}

/* ---- Insights / article cards ---- */
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.art{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:.3s}
.art:hover{transform:translateY(-6px);box-shadow:0 30px 60px -40px rgba(15,44,48,.45);border-color:var(--teal)}
.art .top{height:150px;background:linear-gradient(135deg,var(--teal-l),var(--mint));position:relative;overflow:hidden}
.art .top svg{position:absolute;bottom:-10px;right:-6px;color:var(--teal);opacity:.22}
.art .body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.art .cat{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-d);font-weight:700;margin-bottom:10px}
.art h3{font-size:1.16rem;color:var(--ink);margin-bottom:14px;line-height:1.25}
.art .more{margin-top:auto;font-size:.86rem;font-weight:700;color:var(--teal-d)}
.soon{display:inline-block;margin-top:8px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}

/* ---- Contact form ---- */
.contact-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:56px;align-items:start}
.form{background:#fff;border:1px solid var(--line);border-radius:22px;padding:40px}
.field{margin-bottom:20px}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.field label .req{color:var(--teal-d)}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(10,163,163,.1)}
.field textarea{resize:vertical;min-height:130px}
.consent{display:flex;gap:12px;align-items:flex-start;font-size:.88rem;color:var(--slate)}
.consent input{width:auto;margin-top:4px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px}
.formok{display:none;background:var(--teal-l);border:1px solid var(--teal);border-radius:16px;padding:22px 24px;color:var(--ink);font-weight:600}
.formok.show{display:block}
.contact-side .card{background:var(--ink);color:#cdeeec;border-radius:22px;padding:34px;margin-bottom:20px}
.contact-side .card h3{color:#fff;font-size:1.2rem;margin-bottom:18px}
.contact-side .row2{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:.92rem}
.contact-side .row2:last-child{border-bottom:none}
.contact-side .row2 svg{flex:0 0 auto;color:#6fe0db;margin-top:3px}
.contact-side .row2 a{color:#cdeeec}.contact-side .row2 a:hover{color:#6fe0db}
.contact-side .label{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#7fb6b6;margin-bottom:2px}

/* ---- Footer ---- */
footer{background:var(--ink);color:#a7c4c5;padding:64px 0 32px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px}
.foot-brand{font-weight:800;font-size:1.3rem;color:#fff}.foot-brand b{color:#6fe0db}
footer h4{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:16px}
footer a{display:block;padding:5px 0;color:#a7c4c5;font-size:.9rem}footer a:hover{color:#6fe0db}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem}

/* ===========================================================================
   Responsive
   =========================================================================== */
@media(max-width:900px){
  .navlinks{display:none}.burger{display:flex}
  .nav-r .btn,.nav-r .lang{display:none}
  .navlinks.open{display:flex;position:absolute;top:78px;left:0;right:0;background:#fff;flex-direction:column;padding:22px 30px;gap:16px;box-shadow:0 20px 40px -24px rgba(15,44,48,.4)}
  .navlinks.open .navcta{display:inline-flex;align-self:flex-start;color:#fff}
  .navlinks.open .navcta:hover{color:#fff}
  .values{grid-template-columns:1fr 1fr}.svc-grid{grid-template-columns:1fr}
  .statband .grid{grid-template-columns:1fr}
  .founder .grid{grid-template-columns:1fr;gap:32px}.founder .fig{height:340px}
  .split{grid-template-columns:1fr;gap:36px}.split .fig{height:320px}
  .matters{grid-template-columns:1fr}
  .vplist{grid-template-columns:1fr;gap:0}
  .svc-block{padding:32px}.svc-block .cols{grid-template-columns:1fr;gap:24px}
  .method{grid-template-columns:1fr}
  .seg-grid{grid-template-columns:1fr 1fr}
  .art-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .foot-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
  .values{grid-template-columns:1fr}section{padding:80px 0}
  .hero .motif{display:none}.pagehero{padding:130px 0 56px}
  .field.row{grid-template-columns:1fr}
  .seg-grid{grid-template-columns:1fr}.art-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .motif,.blob,.founder .img,.split .img{transform:none!important}
  .reveal{opacity:1;transform:none;transition:none}
}

/* WP admin bar offset for the fixed header */
.admin-bar header{top:32px}
@media(max-width:782px){.admin-bar header{top:46px}}
body{overflow-x:clip}

/* ---- Language switcher (Polylang renders a <ul>) ---- */
.lang ul{list-style:none;display:inline-flex;align-items:center;gap:.5rem;margin:0;padding:0}
.lang li{display:inline-flex;align-items:center}
.lang li:not(:last-child)::after{content:"·";margin-left:.5rem;color:var(--muted)}
.lang a{color:var(--slate);font-weight:700;text-transform:uppercase;font-size:.8rem;text-decoration:none}
.lang a:hover,.lang .current-lang a,.lang .current-lang>a{color:var(--teal-d)}
.navlinks .lang-m{display:none}

/* footer switcher + powered-by */
.foot-lang ul{list-style:none;display:inline-flex;align-items:center;gap:.5rem;margin:0;padding:0}
.foot-lang li{display:inline-flex;align-items:center}
.foot-lang li:not(:last-child)::after{content:"·";margin-left:.5rem;color:#5f7d80}
.foot-lang a{color:#a7c4c5;font-weight:700;text-transform:uppercase;font-size:.8rem;text-decoration:none}
.foot-lang a:hover,.foot-lang .current-lang a{color:#6fe0db}
.foot-powered{text-align:center;margin-top:14px;font-size:.78rem;color:#7d9598}
.foot-powered a{color:#a7c4c5;text-decoration:none}
.foot-powered a:hover{color:#6fe0db}

/* show the language switcher inside the mobile overlay nav */
@media(max-width:900px){
  .navlinks.open .lang-m{display:block;margin-top:6px}
  .navlinks.open .lang-m ul{gap:1.2rem}
}
