    :root{
      --teal:#0F6E56;
      --teal-dark:#085041;
      --aqua:#00A79D;
      --navy:#1a3a5c;
      --red:#cc2929;
      --cream:#f7f7f5;
      --white:#ffffff;
      --border:#e8e8e5;
      --muted:#60717c;
      --soft:#E1F5EE;
      --aqua-soft:#E8FAF7;
      --shadow:0 28px 80px rgba(26,58,92,.14);
      --max:1180px;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;background:var(--cream);font-family:'DM Sans',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:#1a1a1a;overflow-x:hidden}
    img{display:block;max-width:100%}
    a{text-decoration:none;color:inherit}
    button,input{font-family:inherit}
    .container{width:min(var(--max),calc(100% - 40px));margin:0 auto}

    .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:14px 24px;border-radius:999px;border:0;font-size:15px;font-weight:800;cursor:pointer;transition:.2s ease;white-space:nowrap}
    .btn:hover{transform:translateY(-2px)}
    .btn.primary{background:var(--teal);color:white;box-shadow:0 16px 35px rgba(15,110,86,.22)}
    .btn.primary:hover{background:var(--teal-dark)}
    .btn.secondary{background:white;color:var(--teal);border:2px solid rgba(15,110,86,.5)}
    .btn.light{background:white;color:var(--teal);box-shadow:0 14px 30px rgba(0,0,0,.14)}
    .btn.ghost-white{background:transparent;color:white;border:2px solid rgba(255,255,255,.58)}

    .topbar{position:sticky;top:0;z-index:50;background:rgba(247,247,245,.9);backdrop-filter:blur(18px);border-bottom:1px solid rgba(0,0,0,.06)}
    .nav{height:76px;display:flex;align-items:center;justify-content:space-between;gap:22px}
    .brand{display:flex;align-items:center;gap:11px;font-weight:900;color:var(--navy);font-size:25px}
    .brand img{width:44px;height:auto}
    .links{display:flex;align-items:center;gap:22px;font-size:14px;font-weight:800;color:#53606b}
    .links a:hover{color:var(--teal)}
    .mobile-toggle{display:none;background:white;border:0;border-radius:999px;width:44px;height:44px;font-size:22px}
    .mobile-menu{display:none}

    .hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#075d51 0%,#0F6E56 48%,#1a3a5c 100%);color:white;padding:82px 0 96px}
    .hero:before{content:"";position:absolute;right:-230px;top:-210px;width:680px;height:680px;border-radius:50%;background:rgba(0,167,157,.45);filter:blur(10px)}
    .hero:after{content:"";position:absolute;left:-180px;bottom:-260px;width:760px;height:460px;border-radius:50%;background:rgba(255,255,255,.08)}
    .hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
    .hero-kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);padding:10px 14px;border-radius:999px;color:rgba(255,255,255,.88);font-size:13px;font-weight:900;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px}
    .hero-logo{width:210px;margin:0 auto 24px;filter:drop-shadow(0 12px 20px rgba(0,0,0,.14))}
    .hero h1{font-family:'DM Serif Display',Georgia,serif;font-size:clamp(48px,6.2vw,78px);line-height:.94;letter-spacing:-.035em;margin:0;max-width:760px}
    .hero-subtitle{font-size:25px;font-weight:800;margin:20px 0 0;color:white}
    .hero-lead{text-align:left;font-size:19px;line-height:1.75;color:rgba(255,255,255,.78);max-width:660px;margin:20px 0 0}
    .hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
    body.home-page .hero .hero-actions{justify-content:flex-start}
    .microtrust{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:30px;max-width:760px}
    .microtrust span{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:13px 14px;font-weight:800;font-size:14px;color:rgba(255,255,255,.9)}
    .contact-microtrust{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:30px;max-width:760px}
    .contact-microtrust span{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:13px 14px;font-weight:800;font-size:14px;color:rgba(255,255,255,.9)}

    .visual-card{background:white;border-radius:34px;padding:18px;box-shadow:var(--shadow);position:relative;color:#1a1a1a;overflow:hidden}
    .visual-card:before{content:"";position:absolute;right:-90px;bottom:-110px;width:280px;height:280px;border-radius:50%;background:var(--soft)}
    .hero-photo{position:relative;z-index:2;width:100%;border-radius:26px;object-fit:cover;box-shadow:0 16px 40px rgba(26,58,92,.12)}
    .visual-caption{position:relative;z-index:3;margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
    .caption-card{background:var(--cream);border:1px solid var(--border);border-radius:18px;padding:14px}
    .caption-card strong{display:block;color:var(--navy);font-size:14px}.caption-card span{display:block;color:var(--muted);font-size:12px;margin-top:4px;line-height:1.4}

    section{scroll-margin-top:86px}.section{padding:94px 0}.white{background:white}.cream{background:var(--cream)}
    .eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.22em;font-weight:900;color:var(--teal);margin-bottom:12px}
    .section-head{max-width:820px;margin:0 auto;text-align:center}.section-head.left{text-align:left;margin:0}
    h2{font-family:'DM Serif Display',Georgia,serif;color:var(--navy);font-size:clamp(35px,4.8vw,60px);line-height:1.03;letter-spacing:-.02em;margin:0}
    .intro{font-size:18px;line-height:1.75;color:#5d6b76;margin:22px 0 0}

    .problem-band{position:relative;background:white;overflow:hidden}.problem-band:before{content:"";position:absolute;left:-240px;top:90px;width:520px;height:520px;border-radius:50%;background:var(--soft)}.problem-band .container{position:relative;z-index:1}
    .problem-layout{position:relative;display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;align-items:stretch;margin-top:52px}
    .problem-panel{background:var(--navy);color:white;border-radius:38px;padding:38px;overflow:hidden;position:relative}.problem-panel:after{content:"";position:absolute;right:-120px;bottom:-140px;width:340px;height:340px;border-radius:50%;background:rgba(0,167,157,.34)}.problem-panel h3{font-family:'DM Serif Display',Georgia,serif;font-size:44px;line-height:1;margin:0;position:relative;z-index:2}.problem-panel p{position:relative;z-index:2;color:rgba(255,255,255,.72);font-size:18px;line-height:1.7}
    .friction-list{display:grid;gap:16px}.friction-item{display:flex;gap:16px;align-items:flex-start;background:white;border:1px solid var(--border);border-radius:26px;padding:24px;box-shadow:0 8px 24px rgba(26,58,92,.04)}.friction-icon{width:54px;height:54px;border-radius:18px;background:var(--soft);display:grid;place-items:center;font-size:26px;flex:0 0 auto}.friction-item strong{display:block;color:var(--navy);font-size:20px;margin-bottom:6px}.friction-item span{color:#60707c;line-height:1.6}

    .solution{background:var(--cream)}.solution-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:center;margin-top:56px}.solution-phone-wrap{position:relative;min-height:530px;display:grid;place-items:center}.solution-orbit{position:absolute;width:430px;height:430px;border-radius:50%;background:linear-gradient(135deg,var(--soft),rgba(0,167,157,.18));filter:drop-shadow(0 20px 50px rgba(26,58,92,.1))}.app-stack{position:relative;width:min(360px,100%);display:grid;gap:12px}.app-card{background:white;border:1px solid var(--border);border-radius:24px;padding:18px;box-shadow:0 16px 35px rgba(26,58,92,.09)}.app-card.top{background:var(--teal);color:white}.app-card h4{margin:0;font-size:17px}.app-card p{margin:6px 0 0;color:#64727d;line-height:1.5;font-size:14px}.app-card.top p{color:rgba(255,255,255,.72)}.app-row{display:flex;align-items:center;gap:12px}.app-dot{width:42px;height:42px;border-radius:16px;background:var(--soft);display:grid;place-items:center;font-weight:900;color:var(--teal)}
    .feature-list{display:grid;gap:15px}.feature-row{display:grid;grid-template-columns:58px 1fr;gap:16px;background:white;border:1px solid var(--border);border-radius:26px;padding:22px}.feature-row h3{margin:0;color:var(--navy);font-size:21px}.feature-row p{margin:7px 0 0;color:#5d6b76;line-height:1.65}.feature-pill{display:inline-flex;margin-top:12px;background:#eef7ff;color:#2d72b8;border-radius:999px;padding:7px 10px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}
    .solution-phone-wrap{position:relative;min-height:560px;display:grid;place-items:center}
    .phone-frame{width:320px;border:10px solid #111;border-radius:42px;background:#000;box-shadow:0 30px 80px rgba(0,0,0,.35);overflow:hidden;position:relative}
    .phone-notch{width:120px;height:22px;background:#111;border-radius:0 0 18px 18px;margin:0 auto}
    .phone-screen{background:var(--cream);padding:14px 14px 18px}
    .how-it-works{background:white}.how-it-works h2{font-size:clamp(32px,4vw,50px)}.care-path{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}.care-path:before{content:"";position:absolute;left:7%;right:7%;top:29px;border-top:2px solid rgba(15,110,86,.22)}.path-card{position:relative;z-index:2;background:white;border:1px solid var(--border);border-radius:22px;padding:20px;box-shadow:0 8px 22px rgba(26,58,92,.045)}.path-number{width:54px;height:54px;border-radius:999px;background:var(--teal);color:white;display:grid;place-items:center;font-weight:900;margin-bottom:16px;box-shadow:0 10px 22px rgba(15,110,86,.16)}.path-card h3{margin:0;color:var(--navy);font-size:19px;line-height:1.2}.path-card p{margin:9px 0 0;color:#5d6b76;line-height:1.55;font-size:15px}
    .care-circle-audience{background:white}.care-circle-diagram{position:relative;width:min(720px,100%);aspect-ratio:1.65;margin:48px auto 0}.care-circle-diagram:before{content:"";position:absolute;inset:14% 20%;border:3px solid var(--soft);border-radius:50%;background:linear-gradient(135deg,rgba(225,245,238,.56),rgba(232,250,247,.26))}.care-heart{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:132px;height:132px;border-radius:999px;background:white;border:1px solid var(--border);display:grid;place-items:center;align-content:center;gap:3px;color:var(--teal);box-shadow:0 18px 45px rgba(26,58,92,.12);z-index:2}.care-heart span{font-size:38px;line-height:1;color:#cc2929}.care-heart strong{color:var(--navy);font-size:14px}.care-role{position:absolute;z-index:3;display:inline-flex;align-items:center;justify-content:center;min-height:56px;padding:14px 22px;border-radius:999px;background:var(--cream);border:1px solid var(--border);color:var(--navy);font-weight:900;text-align:center;box-shadow:0 10px 28px rgba(26,58,92,.08)}.role-top{left:50%;top:32px;transform:translateX(-50%)}.role-right{right:34px;top:42%;transform:translateY(-50%)}.role-bottom{left:50%;bottom:32px;transform:translateX(-50%)}.role-left{left:34px;top:48%;transform:translateY(-50%);max-width:235px}
    .quiet-alert{background:linear-gradient(135deg,var(--teal),var(--navy));color:white;overflow:hidden;position:relative}.quiet-alert:before{content:"";position:absolute;right:-190px;top:-190px;width:520px;height:520px;border-radius:50%;background:rgba(0,167,157,.38)}.quiet-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr .9fr;gap:50px;align-items:center}.quiet-alert h2{color:white}.quiet-alert .intro{color:rgba(255,255,255,.76)}.alert-card{background:white;color:#1a1a1a;border-radius:34px;padding:26px;box-shadow:0 26px 70px rgba(0,0,0,.22)}.alert-top{display:flex;align-items:center;gap:14px}.alert-icon{width:54px;height:54px;border-radius:18px;background:#fff4df;display:grid;place-items:center;font-size:26px}.alert-card h3{margin:0;color:var(--navy);font-size:24px}.alert-card p{color:#5d6b76;line-height:1.7}.alert-timeline{display:grid;gap:10px;margin-top:18px}.time-pill{background:var(--cream);border:1px solid var(--border);border-radius:18px;padding:13px;font-size:14px;color:#5d6b76}.time-pill strong{color:var(--teal)}

    .canada{background:white}.canada-wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:34px;align-items:stretch;margin-top:52px}.canada-map{background:var(--teal);color:white;border-radius:38px;padding:38px;position:relative;overflow:hidden}.canada-map:after{content:"🍁";position:absolute;right:28px;bottom:12px;font-size:160px;opacity:.12}.canada-map h3{font-family:'DM Serif Display',Georgia,serif;font-size:44px;line-height:1;margin:0;position:relative;z-index:2}.canada-map p{color:rgba(255,255,255,.74);line-height:1.75;font-size:18px;position:relative;z-index:2}.canada-cards{display:grid;gap:16px}.canada-card{display:flex;gap:16px;background:var(--cream);border:1px solid var(--border);border-radius:26px;padding:24px}.iconbox{width:54px;height:54px;border-radius:18px;background:var(--soft);display:grid;place-items:center;color:var(--teal);font-size:25px;flex:0 0 auto}.canada-card h3{margin:0;color:var(--navy);font-size:21px}.canada-card p{margin:8px 0 0;color:#5d6b76;line-height:1.65}

    .audience{background:var(--cream)}.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}.audience-card{background:white;border:1px solid var(--border);border-radius:32px;padding:30px;box-shadow:0 8px 24px rgba(26,58,92,.04);display:flex;flex-direction:column}.audience-card h3{font-size:25px;color:var(--navy);margin:0}.audience-card p{color:#5d6b76;line-height:1.7}.details{display:none;margin-top:16px;color:#5d6b76;line-height:1.7}.details.open{display:block}.details ul{padding-left:20px;margin:0 0 16px}.toggle-btn{margin-top:auto;align-self:flex-start}.details .btn{margin-top:8px}

    .split-cta{background:white}.cta-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;margin-top:54px}.waitlist-card,.survey-card{border-radius:38px;padding:38px;position:relative;overflow:hidden}.waitlist-card{background:var(--cream);border:1px solid var(--border)}.survey-card{background:var(--teal);color:white}.waitlist-card h3,.survey-card h3{font-family:'DM Serif Display',Georgia,serif;font-size:42px;line-height:1;margin:14px 0 0;color:var(--navy)}.survey-card h3{color:white}.waitlist-card p{color:#5d6b76;line-height:1.7}.survey-card p{color:rgba(255,255,255,.76);line-height:1.7}.klaviyo-holder{margin-top:22px}.survey-actions{display:grid;gap:12px;margin-top:24px}.survey-mini{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:14px;font-weight:800;color:rgba(255,255,255,.9)}

    .founder{background:var(--cream);text-align:center}.leaf{width:62px;height:62px;border-radius:999px;background:white;display:grid;place-items:center;margin:0 auto 24px;font-size:28px;box-shadow:0 14px 30px rgba(26,58,92,.08)}.founder p{max-width:850px;margin:22px auto 0;color:#5d6b76;font-size:18px;line-height:1.75}
    .founder-final{background:var(--navy);color:white}.founder-final h2{color:white}.founder-final p{color:rgba(255,255,255,.72)}.founder-final .leaf{box-shadow:0 14px 30px rgba(0,0,0,.18)}.founder-final .btn.secondary{background:transparent;color:white;border-color:rgba(255,255,255,.38)}
    .final-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:30px}

    .footer{background:var(--cream);border-top:1px solid var(--border);padding:38px 0}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .9fr;gap:30px;color:#66727c}.footer-icon{width:190px}.footer a:hover{color:var(--teal)}

    @media(max-width:980px){.links{display:none}.mobile-toggle{display:block}.mobile-menu.open{display:grid;gap:12px;padding:16px 20px 22px;background:white;border-top:1px solid rgba(0,0,0,.06)}.hero-grid,.problem-layout,.solution-grid,.quiet-grid,.canada-wrap,.cta-layout,.care-path{grid-template-columns:1fr}.care-path:before{left:27px;right:auto;top:28px;bottom:28px;border-top:0;border-left:2px solid rgba(15,110,86,.22)}.path-card{padding-left:78px}.path-number{position:absolute;left:20px;top:20px}.microtrust,.audience-grid,.footer-grid{grid-template-columns:1fr}.hero{padding:62px 0 78px}.solution-phone-wrap{min-height:420px}.solution-orbit{width:340px;height:340px}}
    @media(max-width:560px){.container{width:min(100% - 28px,var(--max))}.hero-logo{width:175px}.hero-actions,.final-actions{flex-direction:column}.btn{width:100%}.section{padding:72px 0}.problem-band:before{display:none}.visual-caption{grid-template-columns:1fr}.waitlist-card,.survey-card,.problem-panel,.canada-map{padding:26px;border-radius:28px}.friction-item,.feature-row,.canada-card{grid-template-columns:1fr;display:grid}.care-circle-diagram{aspect-ratio:auto;display:grid;gap:12px;margin-top:32px}.care-circle-diagram:before{display:none}.care-heart,.care-role{position:static;transform:none;width:auto;height:auto;max-width:none}.care-heart{width:118px;height:118px;margin:0 auto 4px}.care-role{min-height:52px}.footer-icon{width:160px}}

    /* =========================
   ABOUT PAGE STYLES
========================= */

.hero {
  background: linear-gradient(135deg, #0F6E56, #1a3a5c);
  color: white;
  padding: 110px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* =========================
   STORY HOMEPAGE REVAMP
========================= */

.story-home {
  --story-ink: #26322f;
  --story-teal: #0f6e56;
  --story-teal-dark: #084c40;
  --story-sage: #dce9df;
  --story-cream: #f5efe4;
  --story-stone: #ebe4d8;
  --story-clay: #b86f4c;
  --story-paper: #fffaf2;
  --story-muted: #6d746f;
  --story-line: rgba(38, 50, 47, .12);
  background: var(--story-cream);
  color: var(--story-ink);
}

.mobile-break {
  display: none;
}

.story-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 60;
  background: linear-gradient(to bottom, rgba(245, 239, 228, .86), rgba(245, 239, 228, .52));
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(38, 50, 47, .08);
}

.story-nav {
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.story-brand {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--story-ink);
  font-weight: 800;
  font-size: 20px;
}

.story-brand img {
  width: 34px;
  height: auto;
}

.story-links {
  display: flex;
  align-items: center;
  gap: 22px;
  color: rgba(38, 50, 47, .72);
  font-size: 14px;
  font-weight: 700;
}

.story-links a:hover,
.story-text-link:hover,
.story-footer a:hover {
  color: var(--story-teal);
}

.facebook-icon, .facebook-icon-button {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

.facebook-icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.facebook-icon-button svg {
  width: 100%;
  height: 100%;
  fill: white;
}

.story-nav-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.story-nav-cta,
.story-mobile-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 16px;
  border-radius: 999px;
  color: white;
  background: var(--story-teal);
  font-size: 13px;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(15, 110, 86, .18);
}

.story-nav-cta-secondary,
.story-mobile-cta-secondary {
  border: 2px solid rgba(15, 110, 86, .36);
  background: rgba(255, 250, 242, .5);
  color: var(--story-teal-dark);
  box-shadow: none;
}

.story-nav-cta-secondary:hover,
.story-mobile-cta-secondary:hover {
  background: rgba(15, 110, 86, .08);
  color: var(--story-teal);
}

.story-mobile-cta {
  width: 100%;
  margin-top: 6px;
}

.story-toggle {
  background: rgba(255, 250, 242, .82);
  color: var(--story-ink);
  border: 1px solid var(--story-line);
}

.story-mobile-menu.open {
  background: rgba(255, 250, 242, .96);
}

.story-hero {
  position: relative;
  min-height: 94vh;
  overflow: hidden;
  background: var(--story-cream);
  display: flex;
  align-items: flex-end;
  padding: 112px 0 52px;
}

.story-hero-photo {
  position: absolute;
  inset: 0;
  background-image: url("assets/care-table-night.png");
  background-size: cover;
  background-position: center;
  transform: scale(1.01);
}

.story-hero-wash {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(19, 24, 22, .68) 0%, rgba(19, 24, 22, .35) 42%, rgba(19, 24, 22, .16) 100%),
    linear-gradient(0deg, rgba(245, 239, 228, .98) 0%, rgba(245, 239, 228, .08) 34%, rgba(245, 239, 228, 0) 64%);
}

.story-hero-inner {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 40px));
}

.story-hero-logo {
  width: 130px;
  height: auto;
  filter: drop-shadow(0 8px 24px rgba(0, 0, 0, .24));
  margin-bottom: 86px;
}

.story-hero-copy {
  max-width: 660px;
  color: white;
  text-shadow: 0 18px 50px rgba(0, 0, 0, .3);
}

.story-hero h1,
.story-section h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  letter-spacing: 0;
}

.story-hero h1 {
  margin: 0;
  font-size: clamp(58px, 8vw, 108px);
  line-height: .92;
  max-width: 720px;
}

.story-hero p {
  margin: 28px 0 0;
  color: rgba(255, 255, 255, .86);
  font-size: clamp(18px, 2.2vw, 26px);
  line-height: 1.7;
  max-width: 600px;
}

.story-scroll {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 48px;
  color: rgba(255, 255, 255, .82);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .16em;
}

.story-scroll:after {
  content: "";
  width: 1px;
  height: 42px;
  background: rgba(255, 255, 255, .44);
}

.story-section {
  position: relative;
  padding: 118px 0;
  scroll-margin-top: 84px;
}

.story-section h2 {
  margin: 0;
  color: var(--story-ink);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1;
  max-width: 920px;
}

.story-kicker {
  margin: 0 0 18px;
  color: var(--story-teal);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .2em;
  text-transform: uppercase;
}

.story-narrow {
  width: min(820px, calc(100% - 40px));
  margin: 0 auto;
}

.story-prose {
  margin-top: 34px;
}

.story-prose p,
.story-section-head p,
.story-action-panel p,
.story-close p,
.story-founder p {
  color: var(--story-muted);
  font-size: 19px;
  line-height: 1.85;
}

.story-prose p {
  margin: 0 0 22px;
}

.story-prose strong {
  color: var(--story-ink);
  font-weight: 800;
}

.story-photo {
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(38, 50, 47, .1);
  box-shadow: 0 28px 80px rgba(38, 50, 47, .12);
  background: var(--story-paper);
}

.story-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-essay-photo {
  aspect-ratio: 16 / 8.4;
  margin-top: 52px;
}

.story-essay {
  background: var(--story-cream);
}

.story-reality {
  background: var(--story-paper);
}

.story-two-col {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .85fr);
  gap: clamp(42px, 6vw, 86px);
  align-items: center;
}

.story-scatter {
  display: grid;
  gap: 13px;
  padding: 34px;
  border-left: 1px solid var(--story-line);
}

.story-scatter span {
  display: block;
  width: fit-content;
  max-width: 100%;
  background: var(--story-cream);
  border: 1px solid var(--story-line);
  border-radius: 8px;
  padding: 13px 16px;
  color: rgba(38, 50, 47, .78);
  box-shadow: 0 12px 34px rgba(38, 50, 47, .06);
}

.story-scatter span:nth-child(2),
.story-scatter span:nth-child(4) {
  justify-self: end;
}

.story-scatter strong {
  display: block;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(15, 110, 86, .2);
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(31px, 3.1vw, 42px);
  line-height: 1.05;
}

.story-hope {
  background: #dfe9df;
  overflow: hidden;
}

.story-relief-card {
  display: grid;
  gap: 14px;
  max-width: 440px;
}

.story-relief-card span,
.story-outcomes article,
.story-notification,
.story-founder {
  border: 1px solid rgba(38, 50, 47, .1);
  background: rgba(255, 250, 242, .72);
  box-shadow: 0 24px 70px rgba(38, 50, 47, .08);
}

.story-relief-card span {
  display: block;
  border-radius: 8px;
  padding: 20px 22px;
  color: var(--story-ink);
  font-weight: 800;
}

.story-relief-card span:nth-child(2),
.story-relief-card span:nth-child(4) {
  margin-left: 58px;
}

.story-intro {
  background: var(--story-cream);
  text-align: center;
}

.story-intro .story-prose {
  text-align: left;
}

.story-tagline-icon {
  width: 54px;
  height: auto;
  margin: 36px auto 0;
  filter: drop-shadow(0 12px 24px rgba(38, 50, 47, .12));
}

.story-tagline {
  display: inline-flex;
  margin: 14px auto 0;
  color: var(--story-teal-dark);
  font-weight: 900;
  font-size: 18px;
}

.story-pilot {
  background:
    linear-gradient(180deg, rgba(255, 250, 242, .64), rgba(255, 250, 242, 0) 34%),
    #dfe9df;
  overflow: hidden;
}

.story-pilot .story-two-col {
  align-items: stretch;
}

.story-pilot .story-actions .btn.secondary {
  background: transparent;
  border-color: rgba(15, 110, 86, .42);
  color: var(--story-teal-dark);
}

.story-pilot .story-actions .btn.secondary:hover {
  background: rgba(15, 110, 86, .08);
}

.pilot-card-stack {
  align-self: center;
  display: grid;
  gap: 12px;
  padding: clamp(26px, 4vw, 38px);
  border: 1px solid rgba(38, 50, 47, .1);
  border-radius: 8px;
  background: rgba(255, 250, 242, .78);
  box-shadow: 0 28px 80px rgba(38, 50, 47, .1);
}

.pilot-card-title {
  margin: 0 0 10px;
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(30px, 3vw, 42px);
  line-height: 1.06;
}

.pilot-card-stack article {
  padding: 16px 18px;
  border: 1px solid rgba(15, 110, 86, .13);
  border-radius: 8px;
  background: rgba(255, 250, 242, .82);
  color: rgba(38, 50, 47, .84);
  font-size: 16px;
  font-weight: 800;
  line-height: 1.5;
}

.pilot-local-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 54px;
  padding-top: 24px;
  border-top: 1px solid rgba(15, 110, 86, .18);
}

.pilot-local-strip span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 1px solid rgba(15, 110, 86, .14);
  border-radius: 999px;
  background: rgba(255, 250, 242, .62);
  color: var(--story-teal-dark);
  padding: 8px 13px;
  font-size: 13px;
  font-weight: 900;
}

.story-product {
  background: var(--story-paper);
}

.story-section-head {
  max-width: 840px;
  margin: 0 auto;
  text-align: center;
}

.story-section-head p {
  margin: 24px auto 0;
  max-width: 760px;
}

.story-outcomes {
  display: grid;
  gap: 14px;
  max-width: 900px;
  margin: 58px auto 0;
}

.story-outcomes article {
  display: grid;
  grid-template-columns: minmax(220px, .42fr) 1fr;
  gap: 28px;
  align-items: baseline;
  border-radius: 8px;
  padding: 24px 26px;
}

.story-outcomes h3 {
  margin: 0;
  color: var(--story-teal-dark);
  font-size: 22px;
}

.story-outcomes p {
  margin: 0;
  color: var(--story-muted);
  font-size: 17px;
  line-height: 1.65;
}

.story-silence {
  background: #253530;
  color: white;
}

.story-silence h2,
.story-close h2 {
  color: white;
}

.story-silence .story-kicker {
  color: #b8d8c9;
}

.story-silence .story-prose p {
  color: rgba(255, 255, 255, .76);
}

.story-silence .story-prose strong {
  color: white;
  font-size: 24px;
}

.story-notification {
  padding: 34px;
  border-radius: 8px;
  background: #fffaf2;
  color: var(--story-ink);
}

.story-notification-top {
  display: inline-flex;
  color: var(--story-clay);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.story-notification p {
  margin: 20px 0 0;
  color: var(--story-ink);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.02;
}

.story-notification span {
  display: block;
  margin-top: 26px;
  color: var(--story-muted);
  font-size: 17px;
  line-height: 1.7;
}

.story-canada {
  background: var(--story-cream);
}

.story-trust-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  max-width: 940px;
  margin: 44px auto 0;
}

.story-trust-list span {
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(15, 110, 86, .18);
  background: rgba(255, 250, 242, .72);
  color: var(--story-teal-dark);
  padding: 11px 16px;
  font-size: 14px;
  font-weight: 800;
}

.story-survey {
  background: var(--story-paper);
}

.story-action-panel {
  max-width: 920px;
  padding: clamp(34px, 6vw, 72px);
  border: 1px solid rgba(15, 110, 86, .14);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(220, 233, 223, .9), rgba(255, 250, 242, .92));
}

.story-action-panel h2 {
  max-width: 780px;
}

.story-action-panel p {
  max-width: 740px;
}

.story-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  margin-top: 34px;
}

.story-actions span {
  color: var(--story-muted);
  font-weight: 800;
}

.story-text-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 13px 22px;
  border: 2px solid rgba(15, 110, 86, .48);
  border-radius: 999px;
  background: transparent;
  color: var(--story-teal-dark);
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
  transition: .2s ease;
  white-space: nowrap;
}

.story-text-button:hover {
  background: rgba(15, 110, 86, .08);
  color: var(--story-teal);
  transform: translateY(-2px);
}

.story-text-button-dark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 13px 22px;
  border: 2px solid rgba(255, 255, 255, .58);
  border-radius: 999px;
  background: transparent;
  color: white;
  font-size: 15px;
  font-weight: 900;
  cursor: pointer;
  transition: .2s ease;
  white-space: nowrap;
}

.story-text-button-dark:hover {
  background: rgba(255, 255, 255, .1);
  color: var(--story-stone);
  transform: translateY(-2px);
}

.story-small-note {
  margin: 14px 0 0;
  color: var(--story-muted);
  font-size: 14px;
  font-weight: 700;
}

.story-support {
  background: var(--story-cream);
}

body.email-modal-open {
  overflow: hidden;
}

.email-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(20, 32, 29, .56);
  backdrop-filter: blur(10px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}

.email-modal[hidden],
.email-modal:not(.is-open) {
  display: none !important;
  visibility: hidden;
  pointer-events: none;
}

.email-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.email-modal-dialog {
  position: relative;
  width: min(75%, 100%);
  max-height: min(760px, calc(100vh - 48px));
  overflow: auto;
  border-radius: 8px;
  border: 1px solid rgba(38, 50, 47, .12);
  background: var(--story-paper);
  padding: clamp(28px, 5vw, 46px);
  box-shadow: 0 34px 110px rgba(12, 24, 21, .34);
  transform: translateY(12px) scale(.98);
  transition: transform .2s ease;
}

.email-modal.is-open .email-modal-dialog {
  transform: translateY(0) scale(1);
}

.email-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(38, 50, 47, .12);
  border-radius: 999px;
  background: rgba(255, 255, 255, .7);
  color: var(--story-ink);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.email-modal iframe {
  position: relative;
  z-index: 1;
  min-height: 434px;
}

.email-modal-close:hover {
  color: var(--story-teal);
  border-color: rgba(15, 110, 86, .28);
}

.email-modal-dialog h2 {
  margin: 0;
  color: var(--story-ink);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1;
}

.email-modal-dialog p:not(.story-kicker) {
  color: var(--story-muted);
  font-size: 17px;
  line-height: 1.7;
}

.email-modal-form-slot {
  margin-top: 28px;
  border: 1px dashed rgba(15, 110, 86, .3);
  border-radius: 8px;
  background: rgba(220, 233, 223, .58);
  padding: 26px;
  min-height: 150px;
  display: grid;
  place-items: center;
  text-align: center;
}

.email-modal-form-slot p {
  margin: 0;
  color: var(--story-teal-dark);
  font-weight: 900;
}

.email-modal-note {
  margin: 16px 0 0;
  font-size: 14px !important;
  font-weight: 800;
}

.story-actions-soft .btn.secondary {
  background: transparent;
  border-color: rgba(15, 110, 86, .48);
  color: var(--story-teal-dark);
  box-shadow: none;
}

.story-founder {
  padding: 34px;
  border-radius: 8px;
}

.story-founder-stack {
  display: grid;
  gap: 18px;
}

.story-founder-photo {
  aspect-ratio: 16 / 9.8;
}

.story-founder h3 {
  margin: 0;
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 34px;
  line-height: 1;
}

.story-founder p {
  margin: 18px 0 0;
  font-size: 17px;
}

.story-close {
  background: linear-gradient(135deg, #23342f, #0f6e56);
  color: white;
  text-align: center;
}

.story-close p {
  color: rgba(255, 255, 255, .76);
  max-width: 800px;
  margin: 28px auto 0;
}

.story-close-actions {
  justify-content: center;
}

.story-text-link {
  color: rgba(255, 255, 255, .82);
  font-weight: 900;
}

.story-footer {
  background: var(--story-paper);
}

.story-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 34px;
  align-items: center;
}

.story-footer p {
  margin: 14px 0 0;
  color: var(--story-muted);
}

.story-footer nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 18px;
  color: var(--story-muted);
  font-weight: 800;
}

.story-footer-social {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.story-footer-button {
  display: inline-flex;
  align-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.story-footer-button:hover {
  color: var(--story-teal);
}

.story-subpage main {
  padding-top: 68px;
}

.story-subpage .story-topbar + main {
  background: var(--story-sage);
}

/* =========================
   ABOUT STORY PAGE
========================= */

.about-story-page .story-topbar + main {
  background: var(--story-cream);
}

.about-hero {
  min-height: 68vh;
  display: flex;
  align-items: center;
  padding: 118px 0 76px;
  background:
    linear-gradient(135deg, rgba(35, 52, 47, .94), rgba(15, 110, 86, .86)),
    url("assets/care-table-night.png");
  background-size: cover;
  background-position: center;
  color: white;
}

.about-hero-inner {
  max-width: 900px;
}

.about-hero .story-kicker {
  color: rgba(255, 255, 255, .72);
}

.about-hero h1,
.about-section h2,
.about-cta h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  letter-spacing: 0;
}

.about-hero h1 {
  margin: 0;
  max-width: 860px;
  color: white;
  font-size: clamp(52px, 7vw, 96px);
  line-height: .94;
}

.about-hero p:not(.story-kicker) {
  max-width: 720px;
  margin: 28px 0 0;
  color: rgba(255, 255, 255, .8);
  font-size: clamp(19px, 2.1vw, 26px);
  line-height: 1.65;
}

.about-section {
  padding: 112px 0;
}

.about-founder,
.about-beliefs {
  background: var(--story-cream);
}

.about-reality {
  background: var(--story-sage);
}

.about-response,
.about-different {
  background: var(--story-paper);
}

.about-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .86fr);
  gap: clamp(42px, 6vw, 84px);
  align-items: center;
}

.about-narrow {
  width: min(850px, calc(100% - 40px));
  margin: 0 auto;
}

.about-section h2,
.about-cta h2 {
  margin: 0;
  color: var(--story-ink);
  font-size: clamp(40px, 5vw, 70px);
  line-height: 1;
}

.about-prose {
  margin-top: 30px;
}

.about-prose p,
.about-belief-list p,
.about-card-grid p,
.about-cta p {
  color: var(--story-muted);
  font-size: 18px;
  line-height: 1.78;
}

.about-prose p {
  margin: 0 0 20px;
}

.about-photo {
  aspect-ratio: 16 / 10.5;
}

.about-quote,
.about-bottom-quote {
  margin: 0;
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  line-height: 1.06;
}

.about-quote {
  padding: 34px 0 34px 34px;
  border-left: 1px solid rgba(15, 110, 86, .24);
  font-size: clamp(34px, 4vw, 56px);
}

.about-belief-list {
  display: grid;
  gap: 28px;
  margin-top: 44px;
  border-top: 1px solid rgba(38, 50, 47, .12);
}

.about-belief-list div {
  display: grid;
  grid-template-columns: minmax(220px, .4fr) 1fr;
  gap: 28px;
  padding-top: 28px;
  border-top: 1px solid rgba(38, 50, 47, .08);
}

.about-belief-list div:first-child {
  border-top: 0;
}

.about-belief-list h3,
.about-card-grid h3 {
  margin: 0;
  color: var(--story-teal-dark);
  font-size: 22px;
}

.about-belief-list p,
.about-card-grid p {
  margin: 0;
}

.about-section-head {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

.about-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 50px;
}

.about-card-grid article {
  padding: 28px;
  border-radius: 8px;
  border: 1px solid rgba(38, 50, 47, .1);
  background: rgba(255, 250, 242, .76);
  box-shadow: 0 22px 64px rgba(38, 50, 47, .07);
}

.about-card-grid p {
  margin-top: 12px;
  font-size: 16px;
}

.about-bottom-quote {
  max-width: 760px;
  margin: 64px auto 0;
  padding-top: 34px;
  border-top: 1px solid rgba(15, 110, 86, .2);
  text-align: center;
  font-size: clamp(32px, 4vw, 52px);
}

.about-cta {
  padding: 112px 0;
  background: linear-gradient(135deg, #23342f, #0f6e56);
  color: white;
  text-align: center;
}

.about-cta h2 {
  color: white;
}

.about-cta p {
  max-width: 740px;
  margin: 24px auto 0;
  color: rgba(255, 255, 255, .76);
}

.about-cta-actions {
  justify-content: center;
}

@media (max-width: 980px) {
  .about-split,
  .about-card-grid,
  .about-belief-list div {
    grid-template-columns: 1fr;
  }

  .about-quote {
    padding: 28px 0 0;
    border-left: 0;
    border-top: 1px solid rgba(15, 110, 86, .24);
  }
}

@media (max-width: 640px) {
  .about-hero {
    min-height: 62vh;
    padding: 98px 0 64px;
  }

  .about-section,
  .about-cta {
    padding: 78px 0;
  }

  .about-hero h1,
  .about-section h2,
  .about-cta h2 {
    font-size: clamp(38px, 12vw, 56px);
  }

  .about-hero p:not(.story-kicker),
  .about-prose p,
  .about-belief-list p,
  .about-cta p {
    font-size: 17px;
  }
}

@media (max-width: 980px) {
  .story-links,
  .story-nav-actions {
    display: none;
  }

  .story-two-col,
  .story-outcomes article,
  .story-footer-grid {
    grid-template-columns: 1fr;
  }

  .story-footer nav {
    justify-content: flex-start;
  }

  .story-hero {
    min-height: 88vh;
  }

  .story-hero-logo {
    margin-bottom: 56px;
  }
}

@media (max-width: 640px) {
  .mobile-break {
    display: block;
  }

  .story-nav {
    height: 62px;
  }

  .story-hero {
    min-height: 86vh;
    padding: 92px 0 38px;
  }

  .story-hero-photo {
    background-position: 56% center;
  }

  .story-hero-wash {
    background:
      linear-gradient(90deg, rgba(19, 24, 22, .72), rgba(19, 24, 22, .32)),
      linear-gradient(0deg, rgba(245, 239, 228, .98), rgba(245, 239, 228, .08) 48%);
  }

  .story-hero-logo {
    width: 108px;
    margin-bottom: 42px;
  }

  .story-hero h1 {
    font-size: clamp(48px, 17vw, 68px);
  }

  .story-hero p {
    font-size: 18px;
    line-height: 1.72;
  }

  .story-section {
    padding: 82px 0;
  }

  .story-section h2 {
    font-size: clamp(36px, 12vw, 52px);
  }

  .story-prose p,
  .story-section-head p,
  .story-action-panel p,
  .story-close p {
    font-size: 17px;
    line-height: 1.72;
  }

  .story-scatter {
    padding: 0;
    border-left: 0;
  }

  .story-scatter span:nth-child(2),
  .story-scatter span:nth-child(4),
  .story-relief-card span:nth-child(2),
  .story-relief-card span:nth-child(4) {
    justify-self: stretch;
    margin-left: 0;
  }

  .story-action-panel,
  .story-notification,
  .story-founder,
  .pilot-card-stack {
    padding: 26px;
  }

  .story-actions,
  .story-close-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .story-actions .btn {
    width: 100%;
  }

  .pilot-local-strip {
    justify-content: flex-start;
    margin-top: 38px;
  }
}

/* =========================
   PILOT PAGE
========================= */

.pilot-page {
  background: var(--story-cream);
}

.pilot-hero {
  position: relative;
  overflow: hidden;
  padding: 150px 0 96px;
  background:
    linear-gradient(90deg, rgba(35, 52, 47, .94), rgba(35, 52, 47, .68) 52%, rgba(35, 52, 47, .28)),
    url("assets/care-table-night.png");
  background-size: cover;
  background-position: center;
  color: white;
}

.pilot-hero-grid,
.pilot-two-col,
.pilot-letter-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .82fr);
  gap: clamp(42px, 6vw, 84px);
  align-items: center;
}

.pilot-hero h1,
.pilot-section h2,
.pilot-final h2 {
  font-family: 'DM Serif Display', Georgia, serif;
  letter-spacing: 0;
}

.pilot-hero h1 {
  max-width: 860px;
  margin: 0;
  color: white;
  font-size: clamp(48px, 6.8vw, 92px);
  line-height: .96;
}

.pilot-hero .story-kicker {
  color: #c9e1d2;
}

.pilot-hero-lead {
  max-width: 760px;
  margin: 28px 0 0;
  color: rgba(255, 255, 255, .84);
  font-size: clamp(19px, 2.2vw, 25px);
  line-height: 1.55;
}

.pilot-hero-copy {
  max-width: 760px;
  margin-top: 28px;
}

.pilot-hero-copy p {
  margin: 0 0 18px;
  color: rgba(255, 255, 255, .76);
  font-size: 18px;
  line-height: 1.75;
}

.pilot-hero .btn.secondary {
  border-color: rgba(255, 255, 255, .58);
  background: transparent;
  color: white;
}

.pilot-hero .btn.secondary:hover {
  background: rgba(255, 255, 255, .1);
}

.pilot-reassurance {
  max-width: 660px;
  margin: 18px 0 0;
  color: rgba(255, 255, 255, .72);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.6;
}

.pilot-hero-card {
  display: grid;
  gap: 18px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 8px;
  background: rgba(255, 250, 242, .9);
  color: var(--story-ink);
  padding: clamp(28px, 4vw, 42px);
  box-shadow: 0 30px 100px rgba(12, 24, 21, .24);
}

.pilot-hero-card span {
  color: var(--story-teal);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.pilot-hero-card strong {
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(32px, 3.4vw, 48px);
  line-height: 1.03;
}

.pilot-hero-card p {
  margin: 0;
  color: var(--story-muted);
  font-size: 17px;
  line-height: 1.75;
}

.pilot-section {
  padding: 112px 0;
  scroll-margin-top: 84px;
}

.pilot-section h2,
.pilot-final h2 {
  max-width: 900px;
  margin: 0;
  color: var(--story-ink);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1;
}

.pilot-prose {
  margin-top: 30px;
}

.pilot-prose p,
.pilot-section-head p,
.pilot-guide-grid p,
.pilot-feature-list p,
.pilot-learning-card li,
.pilot-timeline p,
.pilot-faq-list p,
.pilot-final p {
  color: var(--story-muted);
  font-size: 18px;
  line-height: 1.75;
}

.pilot-prose p {
  margin: 0 0 20px;
}

.pilot-editorial {
  max-width: 960px;
}

.pilot-need {
  background: var(--story-cream);
}

.pilot-editorial blockquote {
  max-width: 840px;
  margin: 52px auto 0;
  border-top: 4px solid var(--story-teal);
  border-bottom: 1px solid rgba(15, 110, 86, .18);
  padding: 32px 26px;
  color: var(--story-teal-dark);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(34px, 4.6vw, 58px);
  line-height: 1.08;
  text-align: center;
}

.pilot-local,
.pilot-tool,
.pilot-roadmap {
  background: #dfe9df;
}

.pilot-community-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 54px;
  padding-top: 24px;
  border-top: 1px solid rgba(15, 110, 86, .18);
}

.pilot-community-line p {
  flex: 0 0 100%;
  margin: 0 0 4px;
  color: var(--story-teal-dark);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.pilot-community-line span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  border: 1px solid rgba(15, 110, 86, .14);
  border-radius: 999px;
  background: rgba(255, 250, 242, .62);
  color: var(--story-teal-dark);
  padding: 8px 13px;
  font-size: 13px;
  font-weight: 900;
}

.pilot-early-cta {
  background: var(--story-teal-dark);
  color: white;
  padding: 34px 0;
}

.pilot-early-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.pilot-early-cta h2 {
  margin: 0;
  color: white;
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.05;
  letter-spacing: 0;
}

.pilot-early-cta p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, .78);
  font-size: 17px;
  line-height: 1.55;
}

.pilot-focus,
.pilot-professional,
.pilot-faq {
  background: var(--story-paper);
}

.pilot-section-head {
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}

.pilot-section-head h2 {
  margin: 0 auto;
}

.pilot-section-head p {
  max-width: 800px;
  margin: 24px auto 0;
}

.pilot-guide-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 58px;
}

.pilot-guide-grid article,
.pilot-feature-list article,
.pilot-learning-card,
.pilot-timeline article,
.pilot-faq-list details {
  border: 1px solid rgba(38, 50, 47, .1);
  border-radius: 8px;
  background: rgba(255, 250, 242, .76);
  box-shadow: 0 24px 70px rgba(38, 50, 47, .07);
}

.pilot-guide-grid article {
  padding: 26px;
}

.pilot-guide-grid h3,
.pilot-feature-list h3,
.pilot-learning-card h3,
.pilot-timeline h3,
.pilot-interest-form h3 {
  margin: 0;
  color: var(--story-teal-dark);
  font-size: 22px;
  line-height: 1.2;
}

.pilot-guide-grid p,
.pilot-feature-list p,
.pilot-timeline p {
  margin: 14px 0 0;
  font-size: 16px;
}

.pilot-feature-list {
  display: grid;
  gap: 12px;
}

.pilot-feature-list article {
  padding: 20px 22px;
}

.pilot-letter {
  background: var(--story-cream);
}

.pilot-letter-grid {
  align-items: start;
}

.pilot-letter-goal {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  margin: 24px 0 0;
  border: 1px solid rgba(15, 110, 86, .18);
  border-radius: 999px;
  background: rgba(255, 250, 242, .78);
  color: var(--story-teal-dark);
  padding: 8px 15px;
  font-size: 14px;
  font-weight: 900;
}

.pilot-note {
  margin-top: 28px;
  border: 1px solid rgba(15, 110, 86, .18);
  border-radius: 8px;
  background: rgba(220, 233, 223, .54);
  color: var(--story-teal-dark);
  padding: 18px 20px;
  font-weight: 800;
  line-height: 1.65;
}

.pilot-interest-form {
  display: grid;
  gap: 16px;
  border: 1px solid rgba(38, 50, 47, .1);
  border-radius: 8px;
  background: var(--story-paper);
  padding: clamp(26px, 4vw, 38px);
  box-shadow: 0 28px 80px rgba(38, 50, 47, .12);
}

.pilot-interest-form h3 {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(30px, 3vw, 42px);
}

.pilot-form-context {
  margin: 0;
  color: var(--story-muted);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.55;
}

.pilot-interest-form label {
  display: grid;
  gap: 8px;
}

.pilot-interest-form label > span {
  color: var(--story-ink);
  font-size: 14px;
  font-weight: 900;
}

.pilot-interest-form input,
.pilot-interest-form select,
.pilot-interest-form textarea {
  width: 100%;
  border: 1px solid rgba(38, 50, 47, .16);
  border-radius: 8px;
  background: rgba(255, 255, 255, .78);
  color: var(--story-ink);
  font: inherit;
  min-height: 50px;
  padding: 12px 14px;
}

.pilot-interest-form textarea {
  resize: vertical;
}

.pilot-interest-form input:focus,
.pilot-interest-form select:focus,
.pilot-interest-form textarea:focus {
  outline: 3px solid rgba(15, 110, 86, .16);
  border-color: rgba(15, 110, 86, .42);
}

.pilot-check {
  grid-template-columns: 20px 1fr;
  align-items: start;
  gap: 10px !important;
  color: var(--story-muted);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
}

.pilot-check input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.pilot-check span {
  font-size: 14px !important;
}

.pilot-interest-form .btn {
  width: 100%;
  margin-top: 6px;
}

.pilot-learning-card {
  padding: clamp(26px, 4vw, 36px);
}

.pilot-learning-card ul {
  display: grid;
  gap: 12px;
  margin: 22px 0 0;
  padding-left: 20px;
}

.pilot-learning-card li {
  font-size: 16px;
}

.pilot-timeline {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin-top: 56px;
}

.pilot-timeline article {
  padding: 22px;
}

.pilot-timeline span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 18px;
  border-radius: 999px;
  background: var(--story-teal);
  color: white;
  font-weight: 900;
}

.pilot-faq-list {
  display: grid;
  gap: 13px;
  max-width: 940px;
  margin: 46px auto 0;
}

.pilot-faq-list details {
  padding: 20px 22px;
}

.pilot-faq-list summary {
  color: var(--story-ink);
  cursor: pointer;
  font-weight: 900;
  line-height: 1.4;
}

.pilot-faq-list p {
  margin: 14px 0 0;
  font-size: 16px;
}

.pilot-final {
  padding: 112px 0;
  background: linear-gradient(135deg, #23342f, #0f6e56);
  color: white;
  text-align: center;
}

.pilot-final h2 {
  margin: 0 auto;
  color: white;
}

.pilot-final p {
  max-width: 760px;
  margin: 22px auto 0;
  color: rgba(255, 255, 255, .76);
}

.pilot-final-actions {
  justify-content: center;
}

.pilot-final span {
  display: block;
  margin-top: 24px;
  color: rgba(255, 255, 255, .72);
  font-size: 14px;
  font-weight: 900;
}

@media (max-width: 1120px) {
  .pilot-guide-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pilot-timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .pilot-hero-grid,
  .pilot-two-col,
  .pilot-letter-grid {
    grid-template-columns: 1fr;
  }

  .pilot-early-cta-inner {
    align-items: flex-start;
    flex-direction: column;
  }

  .pilot-hero {
    padding: 124px 0 82px;
  }
}

@media (max-width: 640px) {
  .pilot-hero,
  .pilot-section,
  .pilot-final {
    padding: 82px 0;
  }

  .pilot-hero {
    padding-top: 108px;
  }

  .pilot-hero h1,
  .pilot-section h2,
  .pilot-final h2 {
    font-size: clamp(36px, 12vw, 54px);
  }

  .pilot-guide-grid,
  .pilot-timeline {
    grid-template-columns: 1fr;
  }

  .pilot-hero-card,
  .pilot-guide-grid article,
  .pilot-feature-list article,
  .pilot-learning-card,
  .pilot-timeline article,
  .pilot-interest-form {
    padding: 24px;
  }
}

.hero:after {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  top: -200px;
  right: -200px;
}

.hero h1 {
  font-size: 64px;
  margin: 0;
  line-height: 1;
}

.hero p {
  margin-top: 24px;
  font-size: 20px;
  color: rgba(255,255,255,.8);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.section {
  padding: 110px 0;
}

.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.quote {
  background: var(--teal);
  color: white;
  border-radius: 40px;
  padding: 50px;
  font-size: 26px;
  line-height: 1.6;
  box-shadow: var(--shadow);
}

.card {
  background: var(--white);
  padding: 40px;
  border-radius: 30px;
  box-shadow: var(--shadow);
}

.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 60px;
}

.value {
  background: white;
  padding: 32px;
  border-radius: 24px;
  border: 1px solid var(--border);
  transition: .3s;
}

.value:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow);
}

.value h3 {
  margin: 0 0 12px 0;
  font-size: 20px;
}

.value p {
  color: var(--muted);
  line-height: 1.6;
}

.band {
  background: var(--navy);
  color: white;
  text-align: center;
  padding: 110px 0;
}

.band h2 {
  color: white;
  font-size: 52px;
  margin: 0;
}

.band p {
  margin-top: 20px;
  color: rgba(255,255,255,.75);
  font-size: 18px;
}

/* Responsive */
@media(max-width:900px){
  .split { grid-template-columns: 1fr; }
  .grid { grid-template-columns: 1fr; }
  .hero h1 { font-size: 42px; }
}

/* =========================
   CONTACT PAGE STYLES
========================= */

.contact-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg,#075d51 0%,#0F6E56 48%,#1a3a5c 100%);
  color: white;
  padding: 86px 0 104px;
}

.contact-hero:before {
  content:"";
  position:absolute;
  right:-220px;
  top:-210px;
  width:650px;
  height:650px;
  border-radius:50%;
  background:rgba(0,167,157,.42);
  filter:blur(10px);
}

.contact-hero:after {
  content:"";
  position:absolute;
  left:-180px;
  bottom:-260px;
  width:760px;
  height:460px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
}

.contact-hero-grid {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:54px;
  align-items:center;
}

.contact-card {
  background:white;
  border-radius:36px;
  padding:36px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

.contact-card:after {
  content:"";
  position:absolute;
  right:-90px;
  bottom:-100px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:var(--soft);
}

.contact-card > * {
  position:relative;
  z-index:1;
}

.contact-card-icon {
  width:62px;
  height:62px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:var(--soft);
  font-size:28px;
  margin-bottom:22px;
}

.contact-email {
  display:inline-flex;
  margin-top:18px;
  color:var(--teal);
  font-size:20px;
  font-weight:900;
}

.contact-location {
  margin-top:8px;
  color:#6a7781;
  font-weight:700;
}

/* PATH CARDS */

.contact-path-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:52px;
}

.contact-path-card {
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:32px;
  padding:30px;
  display:flex;
  flex-direction:column;
  min-height:320px;
}

.contact-path-card.featured {
  background:var(--teal);
  color:white;
  box-shadow:0 22px 60px rgba(15,110,86,.2);
}

.contact-path-card.featured h3,
.contact-path-card.featured p {
  color:white;
}

/* FORM */

.contact-form-section {
  position:relative;
  overflow:hidden;
}

.contact-form-section:before {
  content:"";
  position:absolute;
  left:-250px;
  top:80px;
  width:520px;
  height:520px;
  border-radius:50%;
  background:var(--soft);
}

.contact-form-grid {
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:44px;
}

.contact-form-copy {
  background:var(--navy);
  color:white;
  border-radius:38px;
  padding:38px;
}

.contact-form-shell {
  background:white;
  border:1px solid var(--border);
  border-radius:38px;
  padding:30px;
  box-shadow:var(--shadow);
}

/* SURVEY CTA */

.contact-survey-band {
  background:linear-gradient(135deg,#0F6E56,#1a3a5c);
  color:white;
  position:relative;
  overflow:hidden;
}

.contact-survey-grid {
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:36px;
}

.contact-survey-band h2 {
  color:white;
}

.contact-light-eyebrow {
  color:rgba(255,255,255,.7);
}

.survey-card-small {
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:30px;
  padding:28px;
  display:grid;
  gap:12px;
}

.survey-mini {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:12px;
  font-weight:800;
}

/* MOBILE */

@media(max-width:980px){
  .contact-hero-grid,
  .contact-form-grid,
  .contact-survey-grid {
    grid-template-columns:1fr;
  }

  .contact-path-grid {
    grid-template-columns:1fr;
  }
}

@media(max-width:560px){
  .contact-card:after,
  .contact-form-section:before {
    display:none;
  }
}

/* Humanized contact page */

.contact-story-page .story-topbar + main {
  background: var(--story-cream);
}

.contact-story-page .contact-hero {
  background:
    linear-gradient(135deg, rgba(35, 52, 47, .95), rgba(15, 110, 86, .84)),
    url("assets/founder-worktable.png");
  background-size: cover;
  background-position: center;
}

.contact-story-page .contact-hero:before,
.contact-story-page .contact-hero:after,
.contact-story-page .contact-card:after,
.contact-story-page .contact-form-section:before {
  display: none;
}

.contact-story-page .contact-kicker {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .16);
  color: rgba(255, 255, 255, .82);
  letter-spacing: .18em;
}

.contact-story-page .hero-lead {
  max-width: 720px;
}

.contact-quiet-line {
  margin: 28px 0 0;
  color: rgba(255, 255, 255, .74);
  font-size: 15px;
  font-weight: 800;
}

.contact-story-page {
  align-self: end;
  border-radius: 8px;
  padding: 30px;
  background: rgba(255, 250, 242, .92);
  box-shadow: 0 26px 70px rgba(20, 32, 29, .22);
}

.hero-contact-card {
  align-self: center;
  border-radius: 8px;
  padding: 30px;
  background: rgba(255, 250, 242, .92);
  box-shadow: 0 26px 70px rgba(20, 32, 29, .22);
}

.contact-story-page .hero-contact-card h2 {
  margin: 0;
  color: var(--story-ink);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 36px;
  line-height: 1;
}

.contact-story-page .hero-contact-card p {
  margin: 16px 0 0;
  color: var(--story-muted);
  line-height: 1.65;
}

.contact-story-page .contact-email {
  color: var(--story-teal-dark);
  font-size: clamp(22px, 2.3vw, 32px);
}

.contact-story-page .contact-paths-section {
  background: var(--story-sage);
}

.contact-story-page .contact-path-card {
  min-height: 0;
  border-radius: 8px;
  background: rgba(255, 250, 242, .74);
  border: 1px solid rgba(38, 50, 47, .1);
  box-shadow: 0 20px 60px rgba(38, 50, 47, .07);
}

.contact-story-page .contact-path-card h3 {
  margin: 0;
  color: var(--story-teal-dark);
  font-size: 23px;
}

.contact-story-page .contact-path-card p {
  margin: 14px 0 26px;
  color: var(--story-muted);
  line-height: 1.7;
}

.contact-story-page .contact-path-card .btn {
  width: fit-content;
  margin-top: auto;
  box-shadow: none;
}

.contact-story-page .contact-form-section {
  background: var(--story-cream);
}

.contact-story-page .contact-form-copy {
  border-radius: 8px;
  background: transparent;
  color: var(--story-ink);
  padding: 14px 0;
}

.contact-story-page .contact-form-copy h2 {
  margin: 0;
  color: var(--story-ink);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
}

.contact-story-page .contact-form-copy .intro {
  color: var(--story-muted);
  margin: 24px 0 0;
}

.contact-info-list {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.contact-info-item {
  color: var(--story-muted);
  line-height: 1.6;
}

.contact-info-item strong {
  color: var(--story-teal-dark);
}

.contact-info-item a {
  color: var(--story-teal-dark);
  font-weight: 900;
}

.contact-story-page .contact-form-shell {
  border-radius: 8px;
  padding: clamp(22px, 4vw, 38px);
  box-shadow: 0 28px 80px rgba(38, 50, 47, .11);
}

.contact-story-page .contact-survey-band {
  background: linear-gradient(135deg, #23342f, #0f6e56);
}

.contact-story-page .contact-survey-band p {
  color: rgba(255, 255, 255, .76);
  font-size: 18px;
  line-height: 1.75;
}

.contact-story-page .survey-card-small {
  border-radius: 8px;
  background: rgba(255, 250, 242, .12);
}

.contact-story-page .survey-mini {
  border-radius: 8px;
  background: rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .9);
}

@media(max-width:560px){
  .contact-story-page .contact-path-card .btn {
    width: 100%;
  }
}

/* =========================
   BLOG PAGE STYLES
========================= */

.blog-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg,#075d51 0%,#0F6E56 48%,#1a3a5c 100%);
  color: white;
  padding: 86px 0 104px;
}

.blog-hero:before {
  content:"";
  position:absolute;
  right:-220px;
  top:-210px;
  width:650px;
  height:650px;
  border-radius:50%;
  background:rgba(0,167,157,.42);
  filter:blur(10px);
}

.blog-hero-grid {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:54px;
  align-items:center;
}

.blog-hero h1 {
  font-family:'DM Serif Display', Georgia, serif;
  font-size:clamp(46px,6vw,76px);
  line-height:.95;
  letter-spacing:-.035em;
  margin:0;
  color:white;
}

.blog-featured-card {
  background:white;
  color:#1a1a1a;
  border-radius:36px;
  padding:36px;
  box-shadow:var(--shadow);
}

.featured-label,
.blog-pill {
  display:inline-flex;
  border-radius:999px;
  padding:8px 12px;
  background:var(--soft);
  color:var(--teal);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.blog-featured-card h2 {
  margin:22px 0 0;
  font-size:44px;
}

.blog-featured-card p {
  color:var(--muted);
  line-height:1.7;
}

.blog-intro-section {
  background:white;
}

.blog-intro-grid {
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:stretch;
}

.blog-intro-panel {
  background:var(--navy);
  color:white;
  border-radius:38px;
  padding:38px;
}

.blog-intro-panel h2 {
  color:white;
}

.blog-intro-panel p {
  color:rgba(255,255,255,.74);
  line-height:1.75;
  font-size:18px;
}

.blog-topic-list {
  display:grid;
  gap:16px;
}

.blog-topic {
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:26px;
  padding:24px;
}

.blog-topic span {
  display:inline-flex;
  margin-bottom:12px;
  color:var(--teal);
  font-weight:900;
  font-size:12px;
  letter-spacing:.12em;
}

.blog-topic strong {
  display:block;
  color:var(--navy);
  font-size:20px;
}

.blog-topic p {
  color:var(--muted);
  line-height:1.6;
}

.blog-library {
  background:var(--cream);
}

.blog-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:52px;
}

.blog-card {
  background:white;
  border:1px solid var(--border);
  border-radius:32px;
  padding:30px;
  box-shadow:0 8px 24px rgba(26,58,92,.04);
  display:flex;
  flex-direction:column;
  min-height:340px;
}

.blog-card-large {
  grid-column:span 2;
}

.blog-card-wide {
  grid-column:span 2;
}

.blog-card.dark {
  background:var(--navy);
  color:white;
}

.blog-card.teal-card {
  background:var(--teal);
  color:white;
}

.blog-card.dark h3,
.blog-card.dark p,
.blog-card.teal-card h3,
.blog-card.teal-card p {
  color:white;
}

.blog-card.dark p,
.blog-card.teal-card p {
  color:rgba(255,255,255,.74);
}

.blog-card-top {
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  margin-bottom:18px;
}

.light-pill {
  background:rgba(255,255,255,.14);
  color:white;
}

.read-time {
  color:#7a8791;
  font-size:12px;
  font-weight:800;
}

.blog-card.dark .read-time,
.blog-card.teal-card .read-time {
  color:rgba(255,255,255,.65);
}

.blog-card h3 {
  margin:0;
  color:var(--navy);
  font-size:26px;
  line-height:1.15;
}

.blog-card p {
  color:var(--muted);
  line-height:1.7;
  flex:1;
}

.blog-link {
  margin-top:18px;
  color:var(--teal);
  font-weight:900;
}

.light-link {
  color:white;
}

.blog-newsletter-band {
  background:linear-gradient(135deg,#0F6E56,#1a3a5c);
  color:white;
}

.blog-newsletter-grid {
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:36px;
  align-items:center;
}

.blog-newsletter-band h2 {
  color:white;
}

.blog-newsletter-band p {
  color:rgba(255,255,255,.74);
  line-height:1.75;
  font-size:18px;
}

.newsletter-card {
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:30px;
  padding:28px;
  display:grid;
  gap:12px;
}

.newsletter-mini {
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:12px;
  font-weight:800;
}

/* =========================
   BLOG ARTICLE STYLES
========================= */

.article {
  width:min(860px,calc(100% - 40px));
  margin:64px auto 88px;
  background:white;
  border:1px solid var(--border);
  border-radius:34px;
  padding:clamp(30px,5vw,58px);
  box-shadow:0 24px 70px rgba(26,58,92,.10);
  position:relative;
  overflow:hidden;
}

.article:before {
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:10px;
  background:linear-gradient(90deg,var(--teal),var(--aqua),var(--navy));
}

.article .meta {
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 18px;
  background:var(--soft);
  color:var(--teal);
  border:1px solid rgba(15,110,86,.12);
  border-radius:999px;
  padding:9px 13px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
}

.article .meta:before {
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--aqua);
  box-shadow:0 0 0 5px rgba(0,167,157,.12);
}

.article h1 {
  max-width:760px;
  margin:0 0 24px;
  color:var(--navy);
  font-family:'DM Serif Display', Georgia, serif;
  font-size:clamp(42px,6vw,66px);
  line-height:.98;
  letter-spacing:-.025em;
}

.article h1 + p {
  max-width:740px;
  margin:0 0 38px;
  color:#485966;
  font-size:20px;
  line-height:1.75;
}

.article h2 {
  margin:48px 0 14px;
  padding-top:26px;
  border-top:1px solid var(--border);
  color:var(--navy);
  font-size:clamp(28px,4vw,40px);
  line-height:1.08;
}

.article h2:before {
  content:"";
  display:block;
  width:52px;
  height:5px;
  margin-bottom:18px;
  border-radius:999px;
  background:var(--aqua);
}

.article p {
  margin:18px 0 0;
  color:#566672;
  font-size:18px;
  line-height:1.85;
}

.article p:not(.meta):not(.note) {
  max-width:720px;
}

.article p:not(.meta):not(.note) a {
  color:var(--teal);
  font-weight:800;
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:4px;
}

.article .note {
  margin-top:44px;
  padding:24px 26px;
  background:linear-gradient(135deg,var(--teal),var(--navy));
  color:white;
  border-radius:24px;
  font-weight:800;
  line-height:1.6;
  box-shadow:0 18px 40px rgba(15,110,86,.18);
}

.article .note:before {
  content:"Kinexus note";
  display:block;
  margin-bottom:8px;
  color:rgba(255,255,255,.72);
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.article-nav {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin-top:34px;
  padding-top:26px;
  border-top:1px solid var(--border);
}

.article-nav .btn {
  min-width:190px;
}

.article-next:after {
  content:"→";
  font-size:18px;
  line-height:1;
}

.article-back:before {
  content:"←";
  font-size:18px;
  line-height:1;
}

@media(max-width:980px){
  .blog-hero-grid,
  .blog-intro-grid,
  .blog-newsletter-grid {
    grid-template-columns:1fr;
  }

  .blog-grid {
    grid-template-columns:1fr;
  }

  .blog-card-large,
  .blog-card-wide {
    grid-column:auto;
  }
}

@media(max-width:640px){
  .article {
    width:min(100% - 28px,var(--max));
    margin:34px auto 64px;
    border-radius:26px;
    padding:30px 22px;
  }

  .article h1 {
    font-size:38px;
  }

  .article h1 + p,
  .article p {
    font-size:17px;
    line-height:1.75;
  }

  .article h2 {
    margin-top:38px;
  }

  .article-nav {
    display:grid;
    grid-template-columns:1fr;
  }

  .article-nav .btn {
    min-width:0;
  }
}

/* =========================
   FACILITIES PAGE STYLES
========================= */

body.facilities-page {
  --bg:#f7f7f5;
  --surface:#ffffff;
  --muted:#65727f;
  --light-teal:#E1F5EE;
  --soft-aqua:#E7FAF7;
  margin:0;
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--bg);
  color:#1a1a1a;
}

body.facilities-page .serif {
  font-family:'DM Serif Display',Georgia,serif;
}

body.facilities-page .btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:50px;
  padding:14px 24px;
  border-radius:999px;
  border:0;
  font-weight:800;
  font-size:15px;
  cursor:pointer;
  transition:.2s ease;
}

body.facilities-page .btn:hover {
  transform:translateY(-2px);
}

body.facilities-page .btn-primary {
  background:var(--teal);
  color:white;
  box-shadow:0 15px 35px rgba(15,110,86,.22);
}

body.facilities-page .btn-primary:hover {
  background:var(--teal-dark);
}

body.facilities-page .btn-secondary {
  background:white;
  color:var(--teal);
  border:1px solid rgba(15,110,86,.25);
}

body.facilities-page .btn-white {
  background:white;
  color:var(--teal);
  box-shadow:0 14px 30px rgba(0,0,0,.14);
}

body.facilities-page .btn-outline-white {
  background:transparent;
  color:white;
  border:1px solid rgba(255,255,255,.4);
}

body.facilities-page > header {
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(247,247,245,.9);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(0,0,0,.06);
}

body.facilities-page .nav {
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

body.facilities-page .brand {
  display:flex;
  align-items:center;
  gap:12px;
}

body.facilities-page .brand img {
  width:46px;
}

body.facilities-page .brand-name {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:28px;
  color:var(--teal);
  line-height:.9;
}

body.facilities-page .brand-sub {
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:#7c8791;
  font-weight:800;
  margin-top:3px;
}

body.facilities-page .nav-links {
  display:flex;
  align-items:center;
  gap:25px;
  font-size:14px;
  font-weight:800;
  color:#53606b;
}

body.facilities-page .nav-links a:hover {
  color:var(--teal);
}

body.facilities-page .nav-actions {
  display:flex;
  gap:10px;
}

body.facilities-page .hero {
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#075d51 0%,#0F6E56 48%,#1a3a5c 100%);
  color:white;
  padding:88px 0 110px;
  text-align:left;
}

body.facilities-page .hero:before {
  content:"";
  position:absolute;
  right:-220px;
  top:-180px;
  width:650px;
  height:650px;
  border-radius:50%;
  background:rgba(0,167,157,.45);
  filter:blur(10px);
}

body.facilities-page .hero:after {
  content:"";
  position:absolute;
  left:-180px;
  bottom:-260px;
  width:720px;
  height:420px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  top:auto;
  right:auto;
}

body.facilities-page .hero-grid {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.02fr .98fr;
  align-items:center;
  gap:56px;
}

body.facilities-page .eyebrow {
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:900;
  color:var(--teal);
  margin-bottom:12px;
}

body.facilities-page .hero .eyebrow {
  color:rgba(255,255,255,.72);
}

body.facilities-page h1 {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:clamp(44px,6vw,76px);
  line-height:.94;
  letter-spacing:-.035em;
  margin:0;
  max-width:760px;
}

body.facilities-page .hero-copy {
  font-size:20px;
  line-height:1.7;
  color:rgba(255,255,255,.78);
  max-width:670px;
  margin:26px 0 0;
}

body.facilities-page .hero-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:32px;
}

body.facilities-page .proof-row {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:32px;
  max-width:780px;
}

body.facilities-page .proof {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  padding:14px;
  font-weight:800;
  font-size:14px;
  color:rgba(255,255,255,.9);
}

body.facilities-page .hero-card {
  background:white;
  color:#1a1a1a;
  border-radius:34px;
  padding:22px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}

body.facilities-page .hero-card:before {
  content:"";
  position:absolute;
  inset:auto -40px -80px auto;
  width:220px;
  height:220px;
  background:var(--light-teal);
  border-radius:50%;
}

body.facilities-page .hero-card .hero-photo {
  position:relative;
  z-index:2;
  width:100%;
  border-radius:24px;
  box-shadow:none;
}

body.facilities-page .mock-photo {
  height:260px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(15,110,86,.1),rgba(26,58,92,.08)),url('facility-hero.jpg');
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:flex-end;
  padding:18px;
  position:relative;
  overflow:hidden;
}

body.facilities-page .mock-photo:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(26,58,92,.38),transparent 55%);
}

body.facilities-page .mock-badge {
  position:relative;
  z-index:1;
  background:white;
  border-radius:16px;
  padding:12px 14px;
  box-shadow:0 14px 30px rgba(0,0,0,.16);
  font-weight:900;
  color:var(--teal);
}

body.facilities-page .dashboard-preview {
  margin-top:16px;
  display:grid;
  gap:12px;
  position:relative;
  z-index:2;
}

body.facilities-page .dash-row {
  display:flex;
  align-items:center;
  gap:12px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
}

body.facilities-page .dash-icon {
  width:40px;
  height:40px;
  border-radius:14px;
  background:var(--light-teal);
  display:grid;
  place-items:center;
  color:var(--teal);
  font-weight:900;
}

body.facilities-page .dash-title {
  font-weight:900;
  color:var(--navy);
  font-size:14px;
}

body.facilities-page .dash-sub {
  font-size:12px;
  color:#64727d;
  margin-top:3px;
}

body.facilities-page section {
  scroll-margin-top:90px;
}

body.facilities-page .section {
  padding:92px 0;
}

body.facilities-page .white {
  background:white;
}

body.facilities-page .bg {
  background:var(--bg);
}

body.facilities-page .section-header {
  text-align:center;
  max-width:820px;
  margin:0 auto;
}

body.facilities-page .section-header h2 {
  font-family:'DM Serif Display',Georgia,serif;
  color:var(--navy);
  font-size:clamp(34px,4.6vw,58px);
  line-height:1.04;
  letter-spacing:-.02em;
  margin:0;
}

body.facilities-page .section-header p {
  font-size:18px;
  line-height:1.75;
  color:#5d6b76;
  margin:22px 0 0;
}

body.facilities-page .grid-2 {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
}

body.facilities-page .grid-3 {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

body.facilities-page .grid-4 {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

body.facilities-page .facility-feature-grid {
  margin-top:52px;
}

body.facilities-page .card {
  background:white;
  border:1px solid var(--border);
  border-radius:30px;
  padding:30px;
  box-shadow:0 8px 24px rgba(26,58,92,.04);
}

body.facilities-page .card.soft {
  background:var(--bg);
}

body.facilities-page .iconbox {
  width:54px;
  height:54px;
  border-radius:18px;
  background:var(--light-teal);
  color:var(--teal);
  display:grid;
  place-items:center;
  font-size:25px;
  margin-bottom:20px;
}

body.facilities-page .card h3 {
  margin:0;
  color:var(--navy);
  font-size:23px;
  line-height:1.18;
}

body.facilities-page .card p {
  margin:13px 0 0;
  color:#5d6b76;
  line-height:1.7;
}

body.facilities-page .friction-wrap {
  margin-top:54px;
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:28px;
  align-items:stretch;
}

body.facilities-page .friction-panel {
  background:var(--teal);
  color:white;
  border-radius:36px;
  padding:36px;
  position:relative;
  overflow:hidden;
}

body.facilities-page .friction-panel:after {
  content:"";
  position:absolute;
  right:-140px;
  bottom:-160px;
  width:360px;
  height:360px;
  border-radius:50%;
  background:rgba(0,167,157,.45);
}

body.facilities-page .friction-panel h3 {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:42px;
  line-height:1;
  margin:0;
}

body.facilities-page .friction-panel p {
  color:rgba(255,255,255,.76);
  line-height:1.75;
  font-size:18px;
}

body.facilities-page .friction-list {
  display:grid;
  gap:16px;
}

body.facilities-page .friction-item {
  display:flex;
  gap:16px;
  align-items:flex-start;
  background:white;
  border:1px solid var(--border);
  border-radius:24px;
  padding:22px;
}

body.facilities-page .friction-item strong {
  display:block;
  color:var(--navy);
  font-size:18px;
  margin-bottom:6px;
}

body.facilities-page .friction-item span {
  color:#60707c;
  line-height:1.6;
}

body.facilities-page .solution-stack {
  margin-top:54px;
  display:grid;
  gap:16px;
}

body.facilities-page .solution-row {
  display:grid;
  grid-template-columns:64px 1fr auto;
  gap:18px;
  align-items:center;
  background:white;
  border:1px solid var(--border);
  border-radius:26px;
  padding:22px;
}

body.facilities-page .number {
  width:50px;
  height:50px;
  border-radius:18px;
  background:var(--light-teal);
  display:grid;
  place-items:center;
  font-weight:900;
  color:var(--teal);
}

body.facilities-page .solution-row h3 {
  margin:0;
  color:var(--navy);
  font-size:22px;
}

body.facilities-page .solution-row p {
  margin:6px 0 0;
  color:#61717c;
  line-height:1.6;
}

body.facilities-page .tag {
  border-radius:999px;
  background:#eef7ff;
  color:#2d72b8;
  padding:8px 11px;
  font-weight:900;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.05em;
  white-space:nowrap;
}

body.facilities-page .outcome-band {
  background:var(--navy);
  color:white;
  padding:90px 0;
}

body.facilities-page .outcome-band h2 {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:clamp(34px,4.6vw,58px);
  line-height:1.03;
  margin:0;
  text-align:center;
}

body.facilities-page .outcome-grid {
  margin-top:44px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

body.facilities-page .outcome {
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  padding:24px;
}

body.facilities-page .outcome strong {
  display:block;
  font-size:20px;
  margin-bottom:10px;
}

body.facilities-page .outcome span {
  color:rgba(255,255,255,.7);
  line-height:1.6;
  font-size:14px;
}

body.facilities-page .pilot-box {
  background:linear-gradient(135deg,var(--teal),var(--navy));
  color:white;
  border-radius:38px;
  padding:42px;
  display:grid;
  grid-template-columns:1fr .85fr;
  gap:36px;
  align-items:top;
  margin-top:54px;
  overflow:hidden;
  position:relative;
}

body.facilities-page .pilot-box:before {
  content:"";
  position:absolute;
  right:-160px;
  top:-160px;
  width:430px;
  height:430px;
  border-radius:50%;
  background:rgba(0,167,157,.36);
}

body.facilities-page .pilot-box > * {
  position:relative;
  z-index:2;
}

body.facilities-page .pilot-box h3 {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:44px;
  line-height:1;
  margin:0;
}

body.facilities-page .pilot-box p {
  color:rgba(255,255,255,.76);
  line-height:1.75;
  font-size:18px;
}

body.facilities-page .pilot-list {
  display:grid;
  gap:11px;
  margin-top:22px;
}

body.facilities-page .pilot-list div {
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:13px;
  font-weight:800;
}

body.facilities-page .pilot-eyebrow {
  color:rgba(255,255,255,.7);
}

body.facilities-page .facility-pilot-frame {
  width:100%;
  height:100%;
  border:none;
  border-radius:8px;
}

body.facilities-page .form {
  display:grid;
  gap:12px;
  background:white;
  border-radius:28px;
  padding:24px;
}

body.facilities-page .form input,
body.facilities-page .form textarea {
  width:100%;
  border:1px solid var(--border);
  border-radius:999px;
  padding:15px 18px;
  font-size:15px;
  outline:none;
}

body.facilities-page .form textarea {
  border-radius:20px;
  min-height:110px;
  resize:vertical;
}

body.facilities-page .form input:focus,
body.facilities-page .form textarea:focus {
  border-color:var(--teal);
}

body.facilities-page .form-note {
  font-size:12px;
  line-height:1.5;
  text-align:center;
  color:#6f7a83;
}

body.facilities-page .faq {
  max-width:860px;
  margin:52px auto 0;
  display:grid;
  gap:14px;
}

body.facilities-page .faq details {
  background:white;
  border:1px solid var(--border);
  border-radius:22px;
  padding:20px;
}

body.facilities-page .faq summary {
  font-weight:900;
  color:var(--navy);
  cursor:pointer;
}

body.facilities-page .faq p {
  color:#5d6b76;
  line-height:1.7;
  margin:14px 0 0;
}

body.facilities-page .final {
  background:var(--teal);
  color:white;
  text-align:center;
  padding:88px 0;
}

body.facilities-page .final h2 {
  font-family:'DM Serif Display',Georgia,serif;
  font-size:clamp(34px,4.8vw,58px);
  line-height:1.03;
  margin:0;
}

body.facilities-page .final p {
  font-size:18px;
  color:rgba(255,255,255,.74);
  line-height:1.7;
  max-width:720px;
  margin:18px auto 0;
}

body.facilities-page .final-actions {
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:30px;
}

body.facilities-page > footer {
  padding:34px 0;
  border-top:1px solid var(--border);
}

body.facilities-page .footer-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

body.facilities-page .footer-links {
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  color:#66727c;
  font-size:14px;
  font-weight:800;
}

@media(max-width:960px){
  body.facilities-page .nav-links,
  body.facilities-page .nav-actions {
    display:none;
  }

  body.facilities-page .hero-grid,
  body.facilities-page .friction-wrap,
  body.facilities-page .pilot-box,
  body.facilities-page .grid-2 {
    grid-template-columns:1fr;
  }

  body.facilities-page .grid-3,
  body.facilities-page .grid-4,
  body.facilities-page .outcome-grid {
    grid-template-columns:1fr;
  }

  body.facilities-page .proof-row {
    grid-template-columns:1fr;
  }

  body.facilities-page .solution-row {
    grid-template-columns:52px 1fr;
  }

  body.facilities-page .solution-row .tag {
    grid-column:2;
  }

  body.facilities-page .hero {
    padding:64px 0 82px;
  }

  body.facilities-page .mock-photo {
    height:220px;
  }
}

@media(max-width:560px){
  body.facilities-page .container {
    width:min(100% - 28px,var(--max));
  }

  body.facilities-page .hero-actions,
  body.facilities-page .final-actions {
    flex-direction:column;
  }

  body.facilities-page .btn {
    width:100%;
  }

  body.facilities-page .section {
    padding:72px 0;
  }

  body.facilities-page .card,
  body.facilities-page .pilot-box,
  body.facilities-page .friction-panel {
    padding:24px;
    border-radius:26px;
  }

  body.facilities-page .hero-card {
    padding:14px;
    border-radius:26px;
  }

  body.facilities-page .solution-row {
    grid-template-columns:1fr;
  }

  body.facilities-page .number {
    margin-bottom:4px;
  }
}

/* =========================
   SURVEY PAGE STYLES
========================= */

body.survey-page {
  background:var(--teal);
}

body.survey-page.story-home {
  background:#20352f;
}

body.survey-page.story-home main {
  padding-top:68px;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(135deg, rgba(32,53,47,.94), rgba(15,110,86,.78) 48%, rgba(220,233,223,.72)),
    url("assets/care-table-night.png");
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}

body.survey-page.story-home main:before {
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 12%, rgba(255,250,242,.22), transparent 34%),
    linear-gradient(0deg, rgba(255,250,242,.88), rgba(255,250,242,.18) 22%, rgba(255,250,242,0) 56%);
  pointer-events:none;
}

body.survey-page.story-home iframe {
  position:relative;
  z-index:1;
  display:block;
  width:min(1060px, calc(100% - 40px)) !important;
  min-height:calc(100vh - 68px);
  margin:0 auto;
  background:white;
  box-shadow:0 30px 90px rgba(20,32,29,.24);
}

body.survey-page .survey-frame {
  border:none;
  width:100%;
}

/* =========================
   HOME HOW IT WORKS OVERRIDE
========================= */

body.home-page .how-it-works {
  background: white;
}

body.home-page .how-it-works h2 {
  font-size: clamp(32px,4vw,50px);
}

body.home-page .care-path {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
  margin-top: 46px;
}

body.home-page .care-path:before {
  content: "";
  position: absolute;
  left: 7%;
  right: 7%;
  top: 29px;
  border-top: 2px solid rgba(15,110,86,.22);
}

body.home-page .path-card {
  position: relative;
  z-index: 2;
  background: white;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 8px 22px rgba(26,58,92,.045);
}

body.home-page .path-number {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: var(--teal);
  color: white;
  display: grid;
  place-items: center;
  font-weight: 900;
  margin-bottom: 16px;
  box-shadow: 0 10px 22px rgba(15,110,86,.16);
}

body.home-page .path-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 19px;
  line-height: 1.2;
}

body.home-page .path-card p {
  margin: 9px 0 0;
  color: #5d6b76;
  line-height: 1.55;
  font-size: 15px;
}

@media(max-width:980px) {
  body.home-page .care-path {
    grid-template-columns: 1fr;
  }

  body.home-page .care-path:before {
    left: 27px;
    right: auto;
    top: 28px;
    bottom: 28px;
    border-top: 0;
    border-left: 2px solid rgba(15,110,86,.22);
  }

  body.home-page .path-card {
    padding-left: 78px;
  }

  body.home-page .path-number {
    position: absolute;
    left: 20px;
    top: 20px;
  }
}

/* =========================
   PRICING PAGE
========================= */

body.pricing-page {
  background: var(--cream);
}

body.pricing-page .topbar {
  background: rgba(247,247,245,.94);
}

.pricing-hero {
  background: radial-gradient(circle at 84% 6%, rgba(15,110,86,.12), transparent 28%), linear-gradient(180deg, #ffffff 0%, var(--cream) 100%);
  padding: 88px 0 82px;
}

.pricing-hero-inner {
  max-width: 860px;
  text-align: center;
}

.pricing-hero h1 {
  color: var(--navy);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(43px, 5.5vw, 72px);
  line-height: .98;
  letter-spacing: -.02em;
  margin: 0;
}

.pricing-hero p {
  color: #5d6b76;
  font-size: 20px;
  line-height: 1.7;
  margin: 22px auto 0;
  max-width: 760px;
}

.pricing-hero .hero-actions,
.pricing-final .final-actions {
  justify-content: center;
}

.pricing-card-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 22px;
  align-items: stretch;
}

.consumer-card-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 940px;
  margin: 42px auto 0;
}

.pro-card-grid {
  margin-top: 42px;
}

.pricing-card,
.provider-plan-card,
.benefit-card,
.use-case-card,
.faq-list details {
  background: #ffffff;
  border: 1px solid var(--border);
  box-shadow: 0 18px 45px rgba(26,58,92,.07);
}

.pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 30px;
  padding: 28px;
}

.pricing-card.featured {
  border-color: rgba(15,110,86,.48);
  box-shadow: 0 28px 70px rgba(15,110,86,.13);
  transform: translateY(-10px);
}

.pricing-badge {
  position: absolute;
  right: 22px;
  top: 22px;
  border-radius: 999px;
  background: var(--teal);
  color: white;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  padding: 8px 12px;
  text-transform: uppercase;
}

.pricing-badge.soft-badge {
  background: rgba(15,110,86,.1);
  color: var(--teal);
}

.provider-card .pricing-badge {
  position: static;
  width: max-content;
  max-width: 100%;
  margin-bottom: 18px;
}

.pricing-icon {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: rgba(15,110,86,.08);
  color: var(--teal);
  font-size: 23px;
  font-weight: 900;
  margin-bottom: 20px;
}

.pricing-card h2 {
  color: var(--navy);
  font-size: 27px;
  line-height: 1.1;
  margin: 0;
}

.pricing-price {
  color: var(--navy);
  font-size: 42px;
  font-weight: 900;
  line-height: 1;
  margin-top: 18px;
}

.pricing-price span {
  display: inline-block;
  color: #66727c;
  font-size: 15px;
  font-weight: 800;
}

.pricing-annual {
  color: #66727c;
  font-size: 14px;
  font-weight: 800;
  margin-top: 8px;
}

.pricing-sub {
  color: #5d6b76;
  line-height: 1.65;
  margin: 18px 0 0;
}

.pricing-list {
  display: grid;
  gap: 10px;
  margin: 22px 0;
  padding-left: 20px;
  color: #53636f;
  line-height: 1.5;
}

.pricing-muted {
  border-top: 1px solid var(--border);
  color: #81909a;
  font-size: 14px;
  line-height: 1.6;
  margin: auto 0 20px;
  padding-top: 18px;
}

.pricing-highlight {
  border-radius: 18px;
  background: rgba(15,110,86,.08);
  color: var(--navy);
  font-weight: 800;
  line-height: 1.6;
  margin: auto 0 20px;
  padding: 16px;
}

.pricing-highlight.soft {
  background: var(--cream);
  color: #52636f;
}

.pricing-card .btn {
  width: 100%;
}

.pricing-small-note {
  color: #66727c;
  font-size: 13px;
  font-weight: 800;
  margin: 12px 0 0;
  text-align: center;
}

.pricing-link {
  color: var(--teal);
  font-weight: 900;
  line-height: 1.4;
  margin-top: 14px;
  text-align: center;
}

.pricing-compare {
  background: white;
}

.compare-table-wrap {
  margin-top: 42px;
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 26px;
  background: white;
  box-shadow: 0 18px 45px rgba(26,58,92,.05);
}

.compare-table {
  width: 100%;
  min-width: 780px;
  border-collapse: collapse;
}

.compare-table th,
.compare-table td {
  border-bottom: 1px solid var(--border);
  padding: 17px 18px;
  text-align: left;
  color: #596873;
}

.compare-table th {
  background: rgba(15,110,86,.07);
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.compare-table td:first-child {
  color: var(--navy);
  font-weight: 900;
}

.compare-table tr:last-child td {
  border-bottom: 0;
}

.table-note {
  color: #66727c;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.6;
  margin: 18px auto 0;
  max-width: 900px;
  text-align: center;
}

.pricing-benefits {
  background: var(--cream);
}

.benefit-grid,
.use-case-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 18px;
  margin-top: 42px;
}

.benefit-card,
.use-case-card {
  border-radius: 26px;
  padding: 24px;
}

.benefit-card h3,
.use-case-card h3 {
  color: var(--navy);
  font-size: 22px;
  line-height: 1.18;
  margin: 18px 0 10px;
}

.use-case-card h3 {
  margin-top: 0;
}

.benefit-card p,
.use-case-card p,
.provider-plan-card p {
  color: #5d6b76;
  line-height: 1.65;
  margin: 0;
}

.provider-pricing {
  background: linear-gradient(180deg, rgba(15,110,86,.08) 0%, rgba(0,167,157,.05) 100%);
}

.provider-pricing .section-head {
  max-width: 920px;
}

.provider-pricing-grid {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 40px;
  align-items: center;
}

.provider-pricing h2 {
  font-size: clamp(36px, 4.8vw, 58px);
}

.provider-positioning {
  max-width: 860px;
  margin: 28px auto 0;
  border-left: 4px solid var(--teal);
  border-radius: 0 18px 18px 0;
  background: rgba(255,255,255,.74);
  color: var(--navy);
  font-weight: 900;
  line-height: 1.65;
  padding: 15px 18px;
}

.provider-plan-card {
  border-radius: 30px;
  padding: 30px;
}

.provider-plan-card h3 {
  color: var(--navy);
  font-size: 28px;
  margin: 0;
}

.provider-use-cases {
  background: white;
}

.addon-card {
  display: grid;
  grid-template-columns: 1fr .9fr;
  gap: 24px;
  align-items: center;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 28px;
  box-shadow: 0 18px 45px rgba(26,58,92,.07);
  margin-top: 24px;
  padding: 28px;
}

.addon-card h3 {
  color: var(--navy);
  font-size: 26px;
  margin: 0;
}

.addon-card p {
  color: #5d6b76;
  line-height: 1.65;
  margin: 12px 0 0;
}

.pro-compare-section {
  background: white;
}

.pro-how-section {
  background: var(--cream);
}

.three-card-grid {
  grid-template-columns: repeat(3,1fr);
}

.pricing-faq {
  background: var(--cream);
}

.faq-list {
  display: grid;
  gap: 14px;
  max-width: 900px;
  margin: 42px auto 0;
}

.faq-list details {
  border-radius: 22px;
  padding: 20px 22px;
}

.faq-list summary {
  color: var(--navy);
  cursor: pointer;
  font-weight: 900;
}

.faq-list p {
  color: #5d6b76;
  line-height: 1.7;
  margin: 14px 0 0;
}

.pricing-final {
  background: linear-gradient(135deg, var(--teal), var(--navy));
  color: white;
  padding: 88px 0;
  text-align: center;
}

.pricing-final h2 {
  color: white;
  font-size: clamp(36px, 4.8vw, 58px);
  margin: 0;
}

.pricing-final p {
  color: rgba(255,255,255,.78);
  font-size: 18px;
  line-height: 1.7;
  margin: 18px auto 0;
  max-width: 680px;
}

.pricing-final a {
  color: white;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 4px;
}

@media(max-width:980px) {
  .pricing-card-grid,
  .consumer-card-grid,
  .benefit-grid,
  .use-case-grid,
  .provider-pricing-grid,
  .addon-card,
  .three-card-grid {
    grid-template-columns: 1fr;
  }

  .pricing-card.featured {
    transform: none;
  }
}

@media(max-width:560px) {
  .pricing-hero {
    padding: 64px 0 72px;
  }

  .pricing-card,
  .provider-plan-card,
  .benefit-card,
  .use-case-card {
    border-radius: 24px;
    padding: 22px;
  }

  .pricing-price {
    font-size: 36px;
  }

  .pricing-badge {
    position: static;
    justify-self: start;
    width: max-content;
    margin-bottom: 16px;
  }
}

/* =========================
   PROFESSIONAL TEASER + PAGE
========================= */

body.home-page .professional-teaser {
  background: linear-gradient(180deg, #f7f7f5 0%, #ffffff 100%);
}

body.home-page .professional-teaser-grid {
  display: grid;
  grid-template-columns: 1.02fr .98fr;
  gap: 42px;
  align-items: center;
}

body.home-page .professional-teaser h2 {
  font-size: clamp(34px, 4vw, 52px);
}

.professional-panel,
.provider-dashboard,
.pro-bullet-card,
.pro-fit-panel,
.pro-feature-card,
.pilot-panel,
.provider-form {
  background: #ffffff;
  border: 1px solid var(--border);
  box-shadow: 0 18px 45px rgba(26,58,92,.07);
}

.professional-panel {
  border-radius: 30px;
  padding: 24px;
}

.professional-panel-top,
.dashboard-header,
.dashboard-card,
.dashboard-metrics {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.professional-panel-top,
.dashboard-header {
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
  color: #68747d;
  font-size: 14px;
}

.professional-panel-top strong,
.dashboard-header strong {
  color: var(--navy);
}

.professional-client-card,
.dashboard-card {
  border-radius: 20px;
  padding: 18px;
  background: var(--cream);
  margin-top: 12px;
}

.professional-client-card strong,
.dashboard-card strong {
  display: block;
  color: var(--navy);
}

.professional-client-card span,
.dashboard-card span {
  display: block;
  margin-top: 5px;
  color: #60707a;
  font-size: 14px;
}

body.professionals-page {
  background: var(--cream);
}

body.professionals-page .topbar {
  background: rgba(247,247,245,.94);
}

body.professionals-page .brand-stack {
  display: grid;
  gap: 0;
  line-height: 1;
}

body.professionals-page .brand-pro {
  color: var(--teal);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .18em;
  margin-top: 3px;
}

.pro-hero {
  background: radial-gradient(circle at 84% 15%, rgba(255,255,255,.16), transparent 28%), linear-gradient(135deg, #0f6e56 0%, #0b4f45 55%, #183a5c 100%);
  color: white;
  padding: 88px 0 96px;
  overflow: hidden;
}

.pro-hero h1 {
  color: white;
  font-size: clamp(41px, 5.4vw, 68px);
  line-height: .95;
  margin: 18px 0 20px;
}

.pro-hero-grid,
.pro-split {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 48px;
  align-items: center;
}

.pro-lead {
  color: rgba(255,255,255,.86);
  font-size: 20px;
  line-height: 1.65;
  max-width: 710px;
}

.pro-trust {
  margin-top: 22px;
  color: rgba(255,255,255,.78);
  font-weight: 700;
}

.provider-dashboard {
  border-radius: 34px;
  padding: 26px;
}

.pro-hero-image-wrap {
  position: relative;
  border-radius: 34px;
  padding: 16px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 28px 70px rgba(0,0,0,.22);
  overflow: visible;
}

.pro-hero-image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
}

.pro-zoom-callout {
  position: absolute;
  left: -34px;
  bottom: -92px;
  width: min(245px, 44%);
  z-index: 4;
  border-radius: 32px;
  filter: drop-shadow(0 24px 38px rgba(0,0,0,.26));
}

.pro-zoom-phone-image {
  display: block;
  width: 100%;
  height: auto;
}

.dashboard-card.active {
  background: rgba(15,110,86,.09);
  border: 1px solid rgba(15,110,86,.16);
}

.dashboard-card em {
  color: var(--teal);
  font-style: normal;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.dashboard-metrics {
  margin-top: 16px;
}

.dashboard-metrics span {
  flex: 1;
  border-radius: 16px;
  background: var(--navy);
  color: white;
  padding: 14px;
  text-align: center;
  font-size: 13px;
  font-weight: 800;
}

.pro-bullet-card {
  border-radius: 28px;
  padding: 28px;
}

.pro-bullet-card ul {
  margin: 0;
  padding-left: 20px;
  color: #596873;
  line-height: 1.9;
}

.pro-fit {
  background: white;
}

.pro-fit-panel {
  max-width: 980px;
  border-radius: 28px;
  padding: 36px;
}

.pro-fit-panel h2 {
  margin-top: 10px;
}

.pro-note {
  margin: 22px 0 0;
  border-left: 4px solid var(--teal);
  padding: 14px 18px;
  border-radius: 0 18px 18px 0;
  background: rgba(15,110,86,.07);
  color: var(--navy);
  font-weight: 800;
  line-height: 1.65;
}

.pro-bridge-actions {
  margin-top: 24px;
}

.pro-feature-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 18px;
  margin-top: 42px;
}

.pro-feature-card {
  border-radius: 26px;
  padding: 24px;
}

.pro-feature-card h3 {
  margin: 18px 0 8px;
  color: var(--navy);
}

.pro-feature-card p {
  margin: 0;
  color: #5d6b76;
  line-height: 1.65;
}

.pro-audience {
  background: white;
}

.pro-compare {
  background: white;
}

.pro-compare-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
  margin-top: 42px;
}

.pro-compare-card {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 18px 45px rgba(26,58,92,.07);
}

.pro-compare-card h3 {
  color: var(--navy);
  font-size: 24px;
  margin: 0 0 18px;
}

.pro-compare-card ul,
.pilot-plan-card ul {
  margin: 0;
  padding-left: 20px;
  color: #596873;
  line-height: 1.9;
}

.pro-pill-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 14px;
  margin-top: 36px;
}

.pro-pill-grid span {
  display: flex;
  min-height: 66px;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(15,110,86,.2);
  background: rgba(15,110,86,.06);
  color: var(--navy);
  font-weight: 800;
  padding: 14px 22px;
}

.pro-how {
  background: var(--cream);
}

.pro-path {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
  margin-top: 42px;
}

.pro-path:before {
  content: "";
  position: absolute;
  left: 7%;
  right: 7%;
  top: 29px;
  border-top: 2px solid rgba(15,110,86,.22);
}

.pro-path .path-card {
  min-height: 238px;
}

.provider-pilot {
  background: var(--navy);
}

.pilot-panel {
  border-radius: 34px;
  padding: 38px;
}

.pilot-plan-card {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items: start;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 28px;
  margin-top: 30px;
  box-shadow: 0 18px 45px rgba(26,58,92,.07);
}

.pilot-plan-card h3 {
  color: var(--navy);
  font-size: 25px;
  line-height: 1.18;
  margin: 0;
}

.pilot-plan-card p {
  color: #5d6b76;
  line-height: 1.7;
  margin: 14px 0 0;
}

.provider-form {
  border-radius: 28px;
  padding: 28px;
  margin-top: 30px;
}

.provider-form h3 {
  margin-top: 0;
  color: var(--navy);
  font-size: 26px;
}

.provider-form-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 16px;
  margin-bottom: 22px;
}

.provider-form label {
  display: grid;
  gap: 8px;
  color: var(--navy);
  font-weight: 800;
  font-size: 14px;
}

.provider-form input,
.provider-form textarea,
.provider-form select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--cream);
  padding: 13px 14px;
  font: inherit;
  color: var(--ink);
}

.provider-form textarea {
  resize: vertical;
}

.provider-form .wide {
  grid-column: 1 / -1;
}

@media(max-width:1120px) {
  .links {
    gap: 14px;
  }

  .links .btn {
    padding-left: 18px;
    padding-right: 18px;
  }
}

@media(max-width:980px) {
  body.home-page .professional-teaser-grid,
  .pro-hero-grid,
  .pro-split {
    grid-template-columns: 1fr;
  }

  .pro-feature-grid,
  .pro-pill-grid,
  .pro-compare-grid,
  .pilot-plan-card,
  .pro-path {
    grid-template-columns: 1fr;
  }

  .pro-path:before {
    left: 27px;
    right: auto;
    top: 28px;
    bottom: 28px;
    border-top: 0;
    border-left: 2px solid rgba(15,110,86,.22);
  }

  .pro-path .path-card {
    padding-left: 78px;
    min-height: 0;
  }

  .pro-path .path-number {
    position: absolute;
    left: 20px;
    top: 20px;
  }

  .pro-zoom-callout {
    left: 18px;
    bottom: -46px;
    width: min(230px, calc(100% - 36px));
  }

}

@media(max-width:560px) {
  .pro-hero {
    padding: 62px 0 96px;
  }

  .provider-form-grid {
    grid-template-columns: 1fr;
  }

  .pilot-panel,
  .provider-form,
  .provider-dashboard,
  .pro-hero-image-wrap,
  .professional-panel {
    padding: 22px;
    border-radius: 24px;
  }

  .dashboard-card,
  .dashboard-metrics {
    align-items: flex-start;
    flex-direction: column;
  }

  .dashboard-metrics span {
    width: 100%;
  }

  .pro-zoom-callout {
    position: relative;
    left: auto;
    bottom: auto;
    width: min(230px, 72%);
    margin: 14px auto 0;
    border-radius: 22px;
  }

}
