/* ==========================================================================
   miRoncol Health — clean rebuild (no WordPress / Elementor)
   Tokens measured from the original design.
   ========================================================================== */
:root{
  --navy:#171C60;
  --coral:#F16468;
  --coral-dark:#CF515B;
  --text:#414042;
  --muted:#5b5b66;
  --grey:#E7E7EF;
  --footer:#191927;
  --maxw:1170px;
  --head:'Poppins',sans-serif;
  --body:'Montserrat',sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--text);font-size:18px;line-height:1.7;background:#fff;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
ul{margin:0;padding:0;list-style:none}
a{color:var(--coral);text-decoration:none}

h1,h2,h3,h4{font-family:var(--head);color:var(--navy);margin:0 0 .4em;font-weight:600}
h1{font-size:clamp(2.4rem,4.5vw,3.5rem);line-height:1.07}
h2{font-size:clamp(1.9rem,3.2vw,2.5rem);line-height:1.12}
h3{font-size:1.25rem}
p{margin:0 0 1.1em}
.coral{color:var(--coral)}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.prose p{font-size:1.18rem;line-height:1.72;color:var(--text)}
.lead{font-size:1.25rem;color:var(--text)}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--head);font-weight:500;font-size:14px;text-transform:capitalize;
  padding:15px 30px;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:.2s;line-height:1.2}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:#10143f;color:#fff}
.btn-coral{background:var(--coral);color:#fff;border-color:var(--coral)}
.btn-coral:hover{background:var(--coral-dark);color:#fff}
.btn-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:1.6em}
/* keep buttons from butting against the next element */
.btn-row:not(:last-child){margin-bottom:1.8em}
/* miCheckup nav link stands out (keep brand casing) */
.nav-mc>a{color:var(--coral)!important;font-weight:600;text-transform:none!important}
.nav-mc>a:hover{color:var(--coral-dark)!important}
/* miCheckup buttons keep brand casing */
.btn-mc{text-transform:none}

/* ---------- coral accent bar before headings ---------- */
.bar{position:relative;padding-left:22px}
.bar::before{content:"";position:absolute;left:0;top:4px;bottom:8px;width:5px;background:var(--coral);border-radius:2px}

/* ---------- coral-circle check list ---------- */
.check li{position:relative;padding-left:38px;margin-bottom:14px;font-size:1.08rem;color:var(--text)}
.check li::before{content:"";position:absolute;left:0;top:3px;width:22px;height:22px;border-radius:50%;background:var(--coral);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/15px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/15px no-repeat}

/* dotted decoration */
.dots{position:absolute;width:150px;height:110px;background-image:radial-gradient(var(--coral) 1.7px,transparent 1.7px);background-size:15px 15px;opacity:.45;z-index:1;pointer-events:none}
.dots.tl{top:-26px;left:-26px}
.dots.tr{top:-26px;right:-26px}
.dots.bl{bottom:-26px;left:-26px}
.media{overflow:visible}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:100;background:#fff;box-shadow:0 2px 14px rgba(23,28,96,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;min-height:84px}
.brand{flex-shrink:0;display:inline-flex;align-items:center}
.brand img{height:46px;width:auto;max-width:none;flex-shrink:0}
.nav ul{display:flex;align-items:center;gap:22px}
.nav-item{position:relative}
.nav-item>a{font-family:var(--body);font-weight:500;font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--navy);display:flex;align-items:center;gap:6px;padding:14px 0;white-space:nowrap}
.nav-item>a:hover,.nav-item>a.active{color:var(--coral)}
.nav-item.has>a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-3px}
.dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:250px;background:#fff;border-radius:12px;
  box-shadow:0 20px 50px rgba(23,28,96,.16);padding:10px;opacity:0;visibility:hidden;transition:.18s}
.nav-item.has:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{display:block;padding:10px 14px;border-radius:8px;font-size:13px;color:var(--text)}
.dropdown a:hover{background:var(--grey);color:var(--coral)}
.header-cta{margin-left:6px}
.nav-item.header-cta>a{color:#fff;font-size:14px;letter-spacing:normal;text-transform:capitalize;padding:15px 30px}
.nav-item.header-cta>a:hover{color:#fff}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;background:none;border:0;cursor:pointer}
.nav-toggle span{height:3px;width:26px;background:var(--navy);border-radius:3px;transition:.25s}

/* ==========================================================================
   Hero slider (split: text panel + image)
   ========================================================================== */
.hero{position:relative;overflow:hidden}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s;display:grid;grid-template-columns:1fr 1fr}
.hero-slide.active{opacity:1;position:relative}
.hero-text{background:var(--grey);display:flex;align-items:center}
.hero-text .inner{margin:0;padding:70px 56px 70px clamp(24px,8vw,180px)}
.hero-text h1{margin-bottom:.25em;max-width:640px}
.hero-tag{display:inline-block;background:rgba(241,100,104,.92);color:#fff;font-family:var(--head);font-weight:500;font-size:1rem;padding:6px 12px;margin:0 0 1em;max-width:640px}
.hero-text p{font-size:1.18rem;color:var(--text);max-width:560px}
.hero-img{background-size:cover;background-position:center;min-height:600px}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:60px;border:0;cursor:pointer;
  background:rgba(23,28,96,.25);color:#fff;font-size:1.6rem;line-height:1}
.hero-arrow:hover{background:rgba(23,28,96,.5)}
.hero-arrow.prev{left:0}.hero-arrow.next{right:0}
.hero-deco{position:absolute;left:0;bottom:-40px;width:330px;height:150px;background:var(--navy);z-index:-1}

/* ==========================================================================
   Sections & split layouts
   ========================================================================== */
.section{padding:84px 0}
.section.grey{background:var(--grey)}
.section.navy{background:var(--navy)}
.section.navy h2,.section.navy h3,.section.navy p,.section.navy li{color:#fff}
.section.navy .check li{color:#fff}
/* cards/panels keep their own colors even inside navy sections (white bg) */
.section.navy .icard h3,.section.navy .card h3{color:var(--coral)}
.section.navy .tcard h3{color:var(--navy)}
.section.navy .icard p,.section.navy .card p,.section.navy .tcard p,.section.navy .tcard li,.section.navy .duo .panel p,.section.navy .duo .panel li{color:var(--text)}
.section.navy .duo .panel h2{color:var(--navy)}
.section.navy .duo .panel .pt h3{color:var(--coral)}
/* points/plain content directly on navy must stay light (not the dark card-body color) */
.section.navy .points .pt p,.section.navy .container > .points .pt p{color:rgba(255,255,255,.9)}
.section.navy .points .pt h3{color:var(--coral)}

/* full-bleed split: image column reaches the viewport edge */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0}
.split .media{position:relative;align-self:stretch;min-height:460px;background-size:cover;background-position:center}
.split .body{padding-top:84px;padding-bottom:84px}
/* image on the left -> body is the right column: align text to the container's right edge */
.split.left .body{padding-left:55px;padding-right:max(24px,calc((100vw - 1170px)/2 + 24px))}
/* image on the right -> body is the left column: align text to the container's left edge */
.split.right .body{padding-right:55px;padding-left:max(24px,calc((100vw - 1170px)/2 + 24px))}
.split .body-inner{max-width:600px}
.split.right .media{order:2}

/* navy decorative block behind split images */
.media .nb{position:absolute;width:60%;height:64px;background:var(--navy);z-index:-1}
.media .nb.bl{left:-30px;bottom:-30px}
.media .nb.tl{left:-30px;top:-30px}

/* Science Behind It: cards on the left, full-height image bleeding right */
.science{display:grid;grid-template-columns:minmax(0,1fr) 30%;align-items:stretch;padding:0}
.science .left{padding:84px 50px 84px max(24px,calc((100vw - 1170px)/2 + 24px))}
.science-img{background-size:cover;background-position:center}
@media (max-width:900px){ .science{grid-template-columns:1fr} .science .left{padding:56px 24px} .science-img{min-height:260px} }

/* science cards */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.card-navy{background:var(--navy);color:#fff;border-radius:6px;padding:36px;display:flex;flex-direction:column;justify-content:center}
.card-navy h2{color:#fff;margin-bottom:.2em}
.card-navy p{color:rgba(255,255,255,.85);margin:0;font-size:1rem}
.card{background:#fff;border-radius:6px;padding:34px 28px;text-align:center;box-shadow:0 10px 30px rgba(23,28,96,.07)}
.card h3{color:var(--navy);margin:.4em 0 .3em;font-size:1.15rem}
.card p{margin:0;font-size:.98rem;color:var(--text)}
.card .ico{width:54px;height:54px;margin:0 auto 6px;color:var(--coral)}

/* pill list / two-column cancer list */
.col2{column-count:2;column-gap:40px}
.col2 li{break-inside:avoid}

/* coral highlight bar for sub-labels */
.hl{display:inline-block;background:var(--coral);color:#fff;font-family:var(--head);font-weight:500;padding:5px 12px;margin:.2em 0 .6em}

/* ==========================================================================
   Interior pages
   ========================================================================== */
.page-hero{background:var(--navy);text-align:center;padding:60px 0}
.page-hero h1{color:#fff;margin:0}
.page-hero .crumb{color:rgba(255,255,255,.6);font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.6em}

.section-narrow{max-width:900px;margin:0 auto}
.center{text-align:center}
.center .btn-row{justify-content:center}
.section h2.center,.section .center h2{margin-bottom:.6em}

/* big coral hand-check mark */
.mark{display:block;width:62px;height:46px;margin:0 auto 16px;color:var(--coral)}

/* icon cards (3-up) */
.icards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:10px}
.icard{background:#fff;border-radius:6px;padding:40px 28px 34px;text-align:center;box-shadow:0 12px 34px rgba(23,28,96,.08)}
.icard h3{color:var(--coral);font-size:1.12rem;margin:.2em 0 .4em}
.icard p{margin:0;color:var(--text);font-size:1rem}
.icard .more,.pt .more{margin-top:14px}
.icard .more a,.pt .more a{color:var(--coral);font-weight:600;text-decoration:none}
.icard .more a:hover,.pt .more a:hover{text-decoration:underline}
/* column overrides driven by live Elementor grid settings */
.icards.two{grid-template-columns:repeat(2,1fr)}
.icards.four{grid-template-columns:repeat(4,1fr)}

/* About Us > Principles + Next Step — two side-by-side cards */
.principles-duo{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch}
.principles-card{background:var(--grey);border-radius:14px;padding:40px 36px}
.principles-card .mark{color:var(--coral);width:48px;height:auto;display:block;margin:0 0 18px}
.principles-card h3{color:var(--navy);font-size:1.4rem;margin:0 0 18px;font-family:var(--head);font-weight:600}
.principles-card .check{margin:0;display:block;column-count:initial;columns:initial}
.principles-card .check li{display:list-item;width:100%;float:none;font-size:1rem;color:var(--text);margin-bottom:14px;line-height:1.55}
.principles-card > p{font-size:1.02rem;color:var(--text);margin-bottom:22px;line-height:1.55}
.principles-buttons{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.principles-buttons .btn{width:100%;text-align:center}
.principles-buttons .btn-wide{grid-column:1 / -1}
.btn-row-center{justify-content:center}

/* principles cards on navy sections: keep white background and dark text */
.section.navy .principles-card{background:#fff}
.section.navy .principles-card h3,.section.navy .principles-card p,.section.navy .principles-card li{color:var(--text)}
.section.navy .principles-card h3{color:var(--navy)}
.section.navy .principles-card .check li{color:var(--text)}
@media (max-width:760px){
  .principles-duo{grid-template-columns:1fr}
  .principles-buttons{grid-template-columns:1fr}
  .principles-buttons .btn-wide{grid-column:auto}
}

/* two white panels side by side */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.duo .panel{background:#fff;border-radius:6px;padding:46px 42px;box-shadow:0 12px 34px rgba(23,28,96,.08)}
.duo .panel .mark{margin:0 0 18px}
.duo .panel h2{font-size:1.8rem;margin-bottom:.5em}
/* labelled points (h3 + para) used inside panels */
.points .pt{margin-bottom:16px}
.points .pt h3{color:var(--coral);font-size:1.05rem;margin:0 0 .15em}
.points .pt p{margin:0;color:var(--text);font-size:1rem}

@media (max-width:900px){ .icards,.duo{grid-template-columns:1fr} }

/* three white cards in a row (left-aligned content, centered icon) */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;align-items:stretch;margin-top:10px}
.trio .tcard{background:#fff;border-radius:6px;padding:40px 32px;box-shadow:0 12px 34px rgba(23,28,96,.08);display:flex;flex-direction:column;text-align:center}
.trio .tcard .mark{margin:0 auto 18px}
.trio .tcard h3{color:var(--navy);font-size:1.3rem;margin-bottom:.5em}
.trio .tcard .check li{font-size:1rem}
@media (max-width:900px){ .trio{grid-template-columns:1fr} }

/* ==========================================================================
   Forms
   ========================================================================== */
.form-card{background:#fff;border:1px solid var(--grey);border-radius:10px;box-shadow:0 12px 34px rgba(23,28,96,.08);padding:40px;max-width:660px;margin:0 auto}
.form-row{display:grid;gap:6px;margin-bottom:18px}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row label{font-family:var(--head);font-weight:600;font-size:.9rem;color:var(--navy)}
.form-row .req{color:var(--coral)}
.form-row input,.form-row select,.form-row textarea{font-family:var(--body);font-size:1rem;padding:12px 14px;border:1px solid var(--grey);border-radius:8px;width:100%;color:var(--text)}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:2px solid var(--coral);border-color:var(--coral)}
.form-consent{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;margin:6px 0 20px}
.form-consent input{width:auto;margin-top:4px}
.form-note{font-size:.84rem;color:var(--muted);margin-top:14px}
@media (max-width:560px){.form-2{grid-template-columns:1fr}.form-card{padding:26px}}

/* ---------- signup form ---------- */
.signup-form{max-width:760px}
.signup-form .form-row-half{max-width:50%}
@media (max-width:560px){.signup-form .form-row-half{max-width:100%}}
.signup-form .form-row .req{color:var(--coral);font-weight:500;font-style:italic;font-size:.82rem;margin-left:2px}
.signup-form input::placeholder,.signup-form textarea::placeholder{color:#9a9aa6}
.referral-group{gap:10px}
.referral-group .referral-title{margin-bottom:6px}
.referral-group .radio-row{display:flex;align-items:center;gap:10px;font-family:var(--head);font-weight:600;font-size:.95rem;color:var(--navy);margin:0;cursor:pointer}
.referral-group .radio-row input[type=radio]{width:18px;height:18px;flex:0 0 18px;margin:0;padding:0;accent-color:var(--coral)}
.referral-group .radio-row span{display:inline-block}
.referral-other-input{margin-top:4px}
.signup-form .form-consent{align-items:flex-start;gap:12px;margin:8px 0 22px;font-size:.95rem;color:var(--navy)}
.signup-form .form-consent strong{font-family:var(--head);font-weight:600}
.signup-form .form-consent .req{color:var(--coral);font-style:italic;font-weight:500;font-size:.82rem}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:var(--footer);color:rgba(255,255,255,.8)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;padding:64px 24px 40px}
.site-footer h4{color:#fff;font-size:1.05rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1.4em;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.18)}
.footer-logo{height:54px;margin-bottom:22px}
.site-footer a{color:rgba(255,255,255,.8)}
.site-footer a:hover{color:#fff}
.footer-links li{margin-bottom:10px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.footer-bottom-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding:20px 24px;font-size:.85rem}

/* footer LinkedIn icon button */
.footer-social{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--coral);color:#fff!important;transition:.18s}
.footer-social:hover{background:var(--coral-dark);transform:translateY(-2px)}
.footer-social svg{display:block}

/* footer contact with icon */
.footer-contact{display:flex;align-items:flex-start;gap:12px;text-decoration:none}
.footer-contact .footer-icon{color:var(--coral);flex-shrink:0;margin-top:3px}
.footer-contact span{display:inline-block;line-height:1.5}

/* footer quick links with coral check bullets */
.footer-links li{margin-bottom:10px;display:flex;align-items:center;gap:10px}
.footer-links li::before{content:"";display:inline-block;width:18px;height:18px;flex-shrink:0;border-radius:50%;background:var(--coral);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat}
.footer-legal{display:flex;gap:22px}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:900px){
  .nav-toggle{display:flex}
  .nav{position:fixed;inset:84px 0 0 auto;width:min(360px,86vw);background:#fff;transform:translateX(100%);transition:.28s;
    box-shadow:-10px 0 40px rgba(23,28,96,.12);overflow-y:auto;padding:16px}
  .nav.open{transform:translateX(0)}
  .nav ul{flex-direction:column;align-items:stretch;gap:0}
  .nav-item>a{padding:14px 8px;border-bottom:1px solid var(--grey)}
  /* Submenus collapsed by default on mobile — tap parent to expand */
  .dropdown,
  .nav-item.has:hover .dropdown{position:static !important;opacity:1 !important;visibility:visible !important;
    transform:none !important;box-shadow:none;padding:0;min-width:0;width:100%;
    max-height:0;overflow:hidden;transition:max-height .28s ease;background:#fafafe;border-radius:8px;left:auto;top:auto}
  .nav-item.has.open .dropdown{max-height:900px;padding:6px 0;margin:4px 0 8px}
  .dropdown a{display:block;padding:12px 18px;border-bottom:1px solid #ececf3;font-size:14px;border-radius:0}
  .dropdown a:last-child{border-bottom:0}
  .nav-item.has>a::after{transition:transform .25s;margin-left:8px}
  .nav-item.has.open>a::after{transform:rotate(225deg);margin-top:1px}
  .hero-slide,.split,.cards,.footer-grid,.col2{grid-template-columns:1fr;column-count:1}
  .hero-img{min-height:300px}
  .hero-text .inner{margin:0;padding:48px 24px}
  .split .media{order:-1;min-height:300px}
  .split .body,.split.left .body,.split.right .body{padding:48px 24px}
  .footer-bottom-inner{flex-direction:column}
}

/* ============ NEWS & ANNOUNCEMENTS ============ */
/* top block: big featured (left) + list (right) */
.news-feature{display:grid;grid-template-columns:1.55fr 1fr;gap:36px;align-items:start}
.feature-main{position:relative;display:block;border-radius:8px;overflow:hidden;min-height:430px;text-decoration:none;color:#fff;
  box-shadow:0 14px 38px rgba(23,28,96,.12)}
.feature-img{position:absolute;inset:0;background-size:cover;background-position:center;background-color:var(--navy)}
.feature-main::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,13,45,.92) 0%,rgba(10,13,45,.45) 45%,rgba(10,13,45,0) 70%)}
.feature-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:32px 34px}
.feature-cap h2{color:#fff;font-size:1.7rem;line-height:1.18;margin:0 0 .35em}
.feature-meta{color:var(--coral);font-weight:600;font-size:.86rem;margin:0 0 .6em}
.feature-ex{color:rgba(255,255,255,.9);font-size:1rem;margin:0}
.news-list{display:flex;flex-direction:column;gap:18px}
.news-row{display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:center;text-decoration:none;color:inherit}
.news-row-thumb{width:96px;height:78px;border-radius:6px;background-size:cover;background-position:center;background-color:var(--grey)}
.news-row-body h3{color:var(--navy);font-size:1rem;line-height:1.3;margin:0 0 .25em;transition:color .15s}
.news-row:hover .news-row-body h3{color:var(--coral)}
.news-row-body .news-date{margin:0}
/* In the Media grid */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.news-card{display:flex;flex-direction:column;background:#fff;border-radius:8px;overflow:hidden;
  box-shadow:0 12px 34px rgba(23,28,96,.08);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}
.news-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(23,28,96,.16)}
.news-thumb{height:200px;background-size:cover;background-position:center;background-color:var(--grey)}
.news-thumb--blank{background:linear-gradient(135deg,var(--navy),#2a3170)}
.news-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.news-date{color:var(--coral);font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 .5em}
.news-card h3{color:var(--coral);font-size:1.16rem;line-height:1.35;margin:0 0 .5em}
.news-ex{color:var(--text);font-size:.96rem;margin:0 0 1.1em}
.news-more{color:var(--navy);font-weight:600;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase}
.news-foot{margin:1em 0 0;padding-top:1em;border-top:1px solid var(--grey);color:var(--muted);font-size:.85rem}
@media (max-width:900px){.news-grid{grid-template-columns:1fr}.news-feature{grid-template-columns:1fr}}

/* ============ SINGLE POST / ARTICLE ============ */
.post-hero .eyebrow a{color:var(--coral);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.82rem;text-decoration:none}
.post-hero .post-meta{color:rgba(255,255,255,.8);margin-top:1em;font-size:.95rem}
.article{max-width:820px}
.article-hero{margin:0 0 36px}
.article-hero img{width:100%;height:auto;border-radius:8px;display:block}
.article-body p{margin:0 0 1.2em;line-height:1.75}
.article-body h2{color:var(--navy);font-size:1.5rem;margin:1.4em 0 .5em}
.article-body h3{color:var(--navy);font-size:1.22rem;margin:1.3em 0 .4em}
.article-body figure{margin:1.8em 0}
.article-body figure img{width:100%;height:auto;border-radius:8px;display:block}
.article-body figcaption{color:#6b6b78;font-size:.86rem;text-align:center;margin-top:.6em}
.article-body ul,.article-body ol{margin:0 0 1.2em;padding-left:1.3em}
.article-body li{margin-bottom:.5em;line-height:1.7}
.article-body blockquote{border-left:4px solid var(--coral);margin:1.5em 0;padding:.4em 0 .4em 1.2em;color:var(--navy);font-style:italic}
.article-body a{color:var(--coral)}
.embed{position:relative;padding-bottom:56.25%;height:0;margin:1.8em 0;border-radius:8px;overflow:hidden}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ==========================================================================
   Our Team — card layout
   ========================================================================== */
.team-section-title{text-align:center;color:var(--navy);font-size:clamp(1.8rem,3vw,2.3rem);margin-bottom:40px}
.team-card{background:#fff;border-radius:14px;box-shadow:0 12px 34px rgba(23,28,96,.08);overflow:hidden;display:grid;grid-template-columns:1fr 1.4fr;gap:0;margin-bottom:36px}
.team-card:last-child{margin-bottom:0}
.team-photo{background-size:cover;background-position:center top;min-height:380px}
.team-info{padding:42px 44px;display:flex;flex-direction:column;align-items:flex-start}
.team-info h3{color:var(--navy);font-size:1.9rem;line-height:1.1;margin:0 0 12px;font-family:var(--head);font-weight:600}
.team-linkedin{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:#0a66c2;color:#fff!important;border-radius:4px;margin-bottom:16px;transition:.18s}
.team-linkedin:hover{background:#084c93;transform:translateY(-2px)}
.team-linkedin svg{display:block;width:16px;height:16px}
.team-title{display:inline-block;background:var(--coral);color:#fff;padding:8px 18px;border-radius:6px;font-family:var(--head);font-weight:500;font-size:.95rem;margin-bottom:20px;line-height:1.3}
.team-info p{margin:0;color:var(--text);font-size:1rem;line-height:1.7}
@media (max-width:760px){
  .team-card{grid-template-columns:1fr}
  .team-photo{min-height:280px}
  .team-info{padding:30px 26px}
  .team-info h3{font-size:1.5rem}
}

/* Team affiliation logos row */
.team-affiliations{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px;align-items:center}
.team-affiliations img{height:50px;width:auto;max-width:140px;object-fit:contain;border:1px solid var(--grey);border-radius:6px;padding:8px;background:#fff}
@media (max-width:760px){.team-affiliations img{height:40px;max-width:110px}}

/* Navy sections with trio cards: center the trailing summary paragraph and button row */
.section.navy .container > .trio + p{text-align:center;max-width:780px;margin:34px auto 8px;font-size:1.08rem;color:#fff}
.section.navy .container > .trio ~ .btn-row{justify-content:center;margin-top:1.4em}

/* principles cards on grey sections: white card on grey bg */
.section.grey .principles-card{background:#fff}
.section.grey .principles-card .check li{color:var(--text)}

/* single column button stack inside principles-card */
.principles-buttons.single-col{grid-template-columns:1fr}
.principles-buttons.single-col .btn-wide{grid-column:auto}

/* How It Works: 2x2 grid of white step cards on navy section */
.steps-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch}
.step-card{background:#fff;border-radius:14px;padding:36px 36px 30px;color:var(--text);display:flex;flex-direction:column}
.step-pill{display:inline-block;background:var(--coral);color:#fff;padding:7px 18px;border-radius:6px;font-family:var(--head);font-weight:500;font-size:.92rem;letter-spacing:.5px;line-height:1.3;margin-bottom:18px;align-self:flex-start}
.section.navy .step-card h3,.step-card h3{color:var(--navy);font-size:1.6rem;line-height:1.2;margin:0 0 16px;font-family:var(--head);font-weight:600}
.section.navy .step-card p,.step-card p{color:var(--text);font-size:1rem;line-height:1.65;margin:0 0 14px}
.step-card .btn-row{margin-top:auto;padding-top:14px}
.report-outcomes{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:6px 0 14px}
.report-outcomes .outcome{background:var(--grey);border-radius:10px;padding:18px;text-align:center}
.report-outcomes .outcome .mark{color:var(--coral);width:36px;height:auto;display:block;margin:0 auto 8px}
.section.navy .report-outcomes .outcome h4,.report-outcomes .outcome h4{color:var(--coral);font-family:var(--head);font-weight:600;font-size:1rem;margin:0 0 6px}
.section.navy .report-outcomes .outcome p,.report-outcomes .outcome p{font-size:.9rem;margin:0;color:var(--text);line-height:1.5}
@media (max-width:900px){
  .steps-grid{grid-template-columns:1fr}
  .report-outcomes{grid-template-columns:1fr}
}

/* Coral section variant (used on cancer/real-time "Why Real-Time Matters") */
.section.coral{background:var(--coral)}
.section.coral h2,.section.coral h3,.section.coral p,.section.coral li{color:#fff}
.section.coral .tcard h3{color:var(--navy)}
.section.coral .tcard p{color:var(--text)}
.section.coral .tcard .mark{color:var(--coral)}
.section.coral .btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.section.coral .btn-navy:hover{background:#10143f}

/* 3-column variant of principles-duo */
.principles-trio{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;align-items:stretch}
.section.grey .principles-trio .principles-card{background:#fff}
@media (max-width:900px){.principles-trio{grid-template-columns:1fr}}

/* HSA page specific */
.hsa-pill{display:inline-block;background:var(--coral);color:#fff;padding:7px 18px;border-radius:6px;font-family:var(--head);font-weight:500;font-size:.95rem;letter-spacing:.5px;line-height:1.3}
.hsa-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:stretch;margin-top:36px}
.hsa-cta{background:var(--navy);border-radius:14px;padding:50px 40px;text-align:center;color:#fff}
.hsa-cta .mark{color:var(--coral);width:48px;height:auto;display:block;margin:0 auto 14px}
.hsa-cta h3{color:#fff;font-size:1.6rem;margin:0 0 12px;font-family:var(--head);font-weight:600}
.hsa-cta p{color:rgba(255,255,255,.85);margin:0 0 22px;font-size:1.05rem}
.section.coral .coral-inline em{color:var(--navy);font-style:normal;font-weight:600}
@media (max-width:760px){.hsa-grid{grid-template-columns:1fr}}

/* HSA grid step cards must override navy section text color */
.section.navy .hsa-grid .step-card h3{color:var(--navy)}
.section.navy .hsa-grid .step-card p{color:var(--text)}
.section.navy .hsa-grid .step-card .mark{color:var(--coral)}

/* Coral section feature: image on left (rounded, co