/* =========================================================
   My Diabetes Benefits — Shared site styles
   ========================================================= */

:root{
  --primary:#0B6E6E;
  --primary-dark:#094D4D;
  --primary-light:#E6F5F5;
  --accent:#D4922A;
  --accent-hover:#B87A1F;
  --accent-light:#FFF5E6;
  --text:#1A2332;
  --text-secondary:#4A5568;
  --border:#E2E8F0;
  --bg:#FAFCFC;
  --white:#fff;
  --footer-bg:#1A2332;
  --danger:#C53030;
  --danger-bg:#FFF5F5;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow-md:0 4px 12px rgba(0,0,0,.08);
  --shadow-lg:0 12px 32px rgba(0,0,0,.12);
  --shadow-nav:0 2px 12px rgba(0,0,0,.06);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Source Sans 3',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  font-size:18px;line-height:1.75;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}

h1,h2,h3,h4,h5,h6{font-family:'Inter',sans-serif;font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-0.01em}
h1{font-size:48px}
h2{font-size:36px}
h3{font-size:24px;line-height:1.25}
h4{font-size:20px;line-height:1.3}
p{text-wrap:pretty}

@media (max-width:768px){
  h1{font-size:32px}
  h2{font-size:28px}
  h3{font-size:22px}
  body{font-size:16px}
}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
section{padding:80px 0;position:relative}
@media (max-width:768px){section{padding:48px 0}}

/* ------- Buttons ------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:8px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:16px;
  transition:all 200ms cubic-bezier(.4,0,.2,1);
  white-space:nowrap;
}
.btn .arrow{width:18px;height:18px;transition:transform 200ms}
.btn:hover .arrow{transform:translateX(3px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(212,146,42,.3)}
.btn-primary:hover{background:var(--accent-hover);transform:scale(1.02);box-shadow:0 4px 12px rgba(212,146,42,.35)}
.btn-secondary{background:var(--primary);color:#fff}
.btn-secondary:hover{background:var(--primary-dark);transform:scale(1.02)}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-large{padding:16px 32px;font-size:17px;min-height:52px}

.text-link{color:var(--primary);font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:color 200ms}
.text-link:hover{color:var(--primary-dark)}
.text-link .arrow{width:16px;height:16px;transition:transform 200ms}
.text-link:hover .arrow{transform:translateX(3px)}

.eyebrow{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.1em;color:var(--primary);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow.with-bar::before{content:"";width:24px;height:2px;background:var(--accent)}

.section-header{text-align:center;margin-bottom:56px;max-width:820px;margin-left:auto;margin-right:auto}
.section-header h2{margin-bottom:20px}
.section-header.center::after{content:"";display:block;width:48px;height:4px;background:var(--accent);margin:18px auto 0;border-radius:2px}
.section-header p{font-size:18px;color:var(--text-secondary);max-width:680px;margin:0 auto}
.section-header.left{text-align:left;margin-left:0;margin-right:0;max-width:none}
.section-header.left p{margin-left:0}

.card{
  background:var(--white);border-radius:12px;padding:28px;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms ease, box-shadow 300ms ease, border-color 300ms ease;
  border-left:4px solid transparent;
  position:relative;
}
.card-hover{cursor:pointer}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-left-color:var(--accent)}
.card-icon{width:48px;height:48px;color:var(--primary);margin-bottom:16px}
.card h3,.card h4{margin-bottom:8px}
.card p{color:var(--text-secondary);font-size:16px;line-height:1.65}

.badge{
  position:absolute;top:18px;right:18px;
  background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.06em;
  padding:5px 10px;border-radius:6px;
}

/* ===========================================================
   NAV (same as homepage)
=========================================================== */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--white);
  height:72px;
  transition:box-shadow 250ms ease;
}
.nav.scrolled{box-shadow:var(--shadow-nav)}
.nav__inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  height:100%;display:flex;align-items:center;justify-content:space-between;
  gap:24px;
}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;font-weight:700;font-size:18px;letter-spacing:-0.01em}
.logo svg{width:28px;height:28px;flex-shrink:0}
.logo .l-my{color:var(--primary)}
.logo .l-d{color:var(--accent)}
.logo .l-b{color:var(--primary)}

.nav__links{display:flex;align-items:center;gap:32px}
.nav__item{position:relative}
.nav__link{
  font-family:'Source Sans 3',sans-serif;font-size:16px;font-weight:600;
  color:var(--text);
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 0;
  transition:color 150ms;
  cursor:pointer;
}
.nav__link:hover,.nav__item:hover .nav__link{color:var(--primary)}
.nav__link .chev{width:12px;height:12px;transition:transform 200ms}
.nav__item:hover .nav__link .chev{transform:rotate(180deg)}

.nav__dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);
  padding:24px;min-width:280px;
  opacity:0;visibility:hidden;
  transition:opacity 200ms ease, transform 200ms ease, visibility 200ms;
  transition-delay:0ms;
}
.nav__item:hover .nav__dropdown{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
  transition-delay:150ms;
}
.nav__item::after{content:"";position:absolute;left:0;right:0;top:100%;height:16px}
.nav__dropdown a{
  display:block;padding:8px 12px;border-radius:6px;
  font-size:15px;color:var(--text);
  transition:background 150ms,color 150ms;
}
.nav__dropdown a:hover{background:var(--primary-light);color:var(--primary)}
.nav__dropdown.wide{min-width:560px;left:auto;right:0;transform:translateX(0) translateY(8px)}
.nav__item:hover .nav__dropdown.wide{transform:translateX(0) translateY(0)}
.nav__dropdown.wide .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px 16px}
.nav__dropdown.wide a{display:flex;align-items:center;gap:10px;padding:10px}
.nav__dropdown.wide svg{width:18px;height:18px;color:var(--primary);flex-shrink:0}
.nav__dropdown .footer-link{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-weight:600;color:var(--primary)}

.nav__right{display:flex;align-items:center;gap:20px}
.nav__phone{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--primary);font-weight:600;font-size:15px;
}
.nav__phone svg{width:16px;height:16px}
.nav__divider{width:1px;height:24px;background:var(--border)}
.nav__hamburger{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:var(--text)}
.nav__hamburger svg{width:24px;height:24px}

.mobile-menu{
  position:fixed;inset:0;background:#fff;z-index:200;
  transform:translateX(100%);transition:transform 300ms ease;
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;border-bottom:1px solid var(--border);
  height:64px;
}
.mobile-menu__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.mobile-menu__close svg{width:24px;height:24px}
.mobile-menu__body{padding:16px 24px 80px}
.m-section{border-bottom:1px solid var(--border)}
.m-section summary{
  list-style:none;padding:18px 4px;font-weight:600;font-size:17px;
  display:flex;justify-content:space-between;align-items:center;cursor:pointer;
}
.m-section summary::-webkit-details-marker{display:none}
.m-section summary::after{content:"+";color:var(--primary);font-size:22px;font-weight:400;transition:transform 200ms}
.m-section[open] summary::after{content:"−"}
.m-section .m-sublinks{padding:0 4px 16px;display:flex;flex-direction:column;gap:8px}
.m-section .m-sublinks a{padding:8px 0;color:var(--text-secondary)}
.m-static{padding:18px 4px;font-weight:600;font-size:17px;display:block;border-bottom:1px solid var(--border)}
.mobile-menu__cta{margin-top:24px}
.mobile-menu__cta .btn{width:100%}
.mobile-menu__phone{
  margin-top:20px;text-align:center;color:var(--primary);font-weight:600;font-size:16px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}

@media (max-width:1023px){
  .nav{height:64px}
  .nav__links,.nav__phone,.nav__divider{display:none}
  .nav__hamburger{display:flex}
  .nav__inner{justify-content:space-between}
  .nav .logo{order:2}
  .nav__hamburger{order:1}
  .nav__right{order:3}
  .btn-evaluate-mobile{padding:10px 16px;font-size:14px}
}
@media (min-width:1024px){
  .btn-evaluate-mobile{display:none}
  .nav__cta-desktop{display:inline-flex}
}
@media (max-width:1023px){
  .nav__cta-desktop{display:none}
}

/* ===========================================================
   FOOTER (same as homepage)
=========================================================== */
.footer{background:var(--footer-bg);color:#E2E8F0;border-top:2px solid var(--accent);padding:64px 0 24px}
.footer__top{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
  flex-wrap:wrap;gap:24px;
}
.footer__brand{display:flex;flex-direction:column;gap:12px;max-width:380px}
.footer__brand .logo{color:#fff}
.footer__brand .logo .l-my,.footer__brand .logo .l-b{color:#fff}
.footer__brand p{color:#9CA3AF;font-size:15px;line-height:1.55}
.footer__phone{
  display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:18px;
  font-family:'Inter',sans-serif;
}
.footer__phone svg{width:20px;height:20px}

.footer__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:48px 0}
.footer__col summary{list-style:none;cursor:default}
.footer__col summary::-webkit-details-marker{display:none}
.footer__col summary::marker{display:none}
.footer__col h4{
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.08em;
  color:var(--accent);margin-bottom:18px;
  display:inline;
}
.footer__col a{
  display:block;font-size:15px;color:#E2E8F0;
  padding:6px 0;transition:color 200ms;
}
.footer__col a:hover{color:#fff}

.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 0 16px;border-top:1px solid rgba(255,255,255,.08);
  color:#9CA3AF;font-size:14px;flex-wrap:wrap;gap:16px;
}
.footer__bottom .links{display:flex;gap:20px}
.footer__bottom .links a:hover{color:#fff}
.footer__disclaimer{font-size:13px;color:#6B7280;line-height:1.55;padding-top:16px}

@media (max-width:1023px){
  .footer__cols{grid-template-columns:repeat(2,1fr);gap:32px}
}
@media (max-width:640px){
  .footer{padding:40px 0 24px;text-align:center}
  .footer__top{flex-direction:column;align-items:center}
  .footer__brand{align-items:center;text-align:center}
  .footer__cols{grid-template-columns:1fr;gap:0;padding:24px 0}
  .footer__col{border-bottom:1px solid rgba(255,255,255,.08)}
  .footer__col h4{
    padding:18px 0;margin:0;cursor:pointer;
    display:flex;justify-content:space-between;align-items:center;
  }
  .footer__col h4::after{content:"+";font-size:18px;font-weight:400}
  .footer__col[open] h4::after{content:"−"}
  .footer__col[open] .footer__col-links{padding-bottom:18px;display:block}
  .footer__col-links{display:none}
  .footer__col summary{cursor:pointer}
  .footer__bottom{flex-direction:column;text-align:center}
}

/* ===========================================================
   CHATBOT
=========================================================== */
.chatbot{position:fixed;bottom:24px;right:24px;z-index:90}
.chatbot__btn{
  width:56px;height:56px;border-radius:50%;
  background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(11,110,110,.35);
  transition:transform 200ms, background 200ms;
  position:relative;
}
.chatbot__btn:hover{background:var(--primary-dark);transform:scale(1.05)}
.chatbot__btn svg{width:26px;height:26px}
.chatbot__dot{
  position:absolute;top:6px;right:6px;
  width:12px;height:12px;border-radius:50%;
  background:var(--accent);border:2px solid var(--primary);
  animation:cb-pulse 1.5s ease-out 2;
}
@keyframes cb-pulse{
  0%{box-shadow:0 0 0 0 rgba(212,146,42,.6)}
  100%{box-shadow:0 0 0 14px rgba(212,146,42,0)}
}
.chatbot.open .chatbot__dot{display:none}

.chatbot__panel{
  position:absolute;bottom:72px;right:0;
  width:380px;max-width:calc(100vw - 48px);
  height:520px;max-height:calc(100vh - 120px);
  background:#fff;border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.20);
  display:flex;flex-direction:column;overflow:hidden;
  transform-origin:bottom right;
  transform:scale(.95) translateY(10px);opacity:0;visibility:hidden;
  transition:all 220ms cubic-bezier(.2,.8,.2,1);
}
.chatbot.open .chatbot__panel{transform:scale(1) translateY(0);opacity:1;visibility:visible}

.chatbot__head{background:var(--primary);color:#fff;padding:16px 18px;display:flex;align-items:center;justify-content:space-between}
.chatbot__head .title{font-family:'Inter',sans-serif;font-weight:600;font-size:15px;line-height:1.3}
.chatbot__head .sub{font-size:12px;opacity:.85;margin-top:2px}
.chatbot__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:#fff;transition:background 150ms}
.chatbot__close:hover{background:rgba(255,255,255,.15)}
.chatbot__close svg{width:18px;height:18px}

.chatbot__body{flex:1;background:var(--bg);padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.chatbot__bubble{
  background:#fff;border-radius:14px 14px 14px 4px;
  padding:14px 16px;font-size:14px;line-height:1.5;color:var(--text);
  max-width:85%;box-shadow:0 1px 2px rgba(0,0,0,.06);
}
.chatbot__quick{display:flex;flex-wrap:wrap;gap:8px;padding-top:6px}
.chatbot__quick button{
  background:#fff;border:1px solid var(--border);
  padding:8px 14px;border-radius:18px;
  font-size:13px;color:var(--primary);font-weight:500;
  transition:all 200ms;
}
.chatbot__quick button:hover{background:var(--primary-light);border-color:var(--primary)}
.chatbot__input{
  border-top:1px solid var(--border);padding:12px 14px;
  display:flex;gap:8px;align-items:center;background:#fff;
}
.chatbot__input input{
  flex:1;border:1px solid var(--border);border-radius:8px;
  padding:10px 14px;font-size:14px;font-family:inherit;color:var(--text);
  outline:none;transition:border-color 150ms;
}
.chatbot__input input:focus{border-color:var(--primary)}
.chatbot__send{
  width:40px;height:40px;border-radius:8px;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  opacity:.5;cursor:not-allowed;
}
.chatbot__send svg{width:18px;height:18px}

@media (max-width:480px){
  .chatbot__panel{position:fixed;bottom:88px;right:16px;left:16px;width:auto}
}

/* ===========================================================
   SCROLL ANIMATIONS
=========================================================== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 600ms ease, transform 600ms ease}
.reveal.in{opacity:1;transform:translateY(0)}
.stagger > *{opacity:0;transform:translateY(20px);transition:opacity 600ms ease, transform 600ms ease}
.stagger.in > *{opacity:1;transform:translateY(0)}
.stagger.in > *:nth-child(1){transition-delay:0ms}
.stagger.in > *:nth-child(2){transition-delay:100ms}
.stagger.in > *:nth-child(3){transition-delay:200ms}
.stagger.in > *:nth-child(4){transition-delay:300ms}
.stagger.in > *:nth-child(5){transition-delay:400ms}
.stagger.in > *:nth-child(6){transition-delay:500ms}
.stagger.in > *:nth-child(n+7){transition-delay:600ms}
.hero-anim{opacity:0;transform:translateY(20px);transition:opacity 700ms ease, transform 700ms ease}
.hero-anim.in{opacity:1;transform:translateY(0)}
.hero-anim-1{transition-delay:0ms}
.hero-anim-2{transition-delay:150ms}
.hero-anim-3{transition-delay:300ms}
.hero-anim-4{transition-delay:450ms}
.hero-anim-5{transition-delay:600ms}
.hero-image-anim{opacity:0;transform:translateX(40px);transition:opacity 800ms ease, transform 800ms ease}
.hero-image-anim.in{opacity:1;transform:translateX(0)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal,.stagger > *,.hero-anim,.hero-image-anim{opacity:1;transform:none}
}

/* ===========================================================
   PAGE-TEMPLATE (Qualify / Complications / sub-pages)
=========================================================== */

/* ---- Sub-page hero (lighter than homepage hero) ---- */
.page-hero{
  background:linear-gradient(180deg, var(--primary-light) 0%, var(--bg) 100%);
  padding:48px 0 64px;position:relative;overflow:hidden;
}
.page-hero__inner{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:center}
.page-hero__inner.full{grid-template-columns:1fr;max-width:880px;margin:0 auto;text-align:center}
.page-hero h1{font-size:44px;line-height:1.1;margin:18px 0 16px;letter-spacing:-0.02em}
.page-hero .sub{font-size:19px;color:var(--text-secondary);line-height:1.55;max-width:640px;margin-bottom:24px}
.page-hero__inner.full .sub{margin-left:auto;margin-right:auto}
.page-hero__inner.full .page-hero__cta-row{justify-content:center}
.page-hero__cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.page-hero__visual{
  aspect-ratio:1/1;max-width:340px;justify-self:end;width:100%;
  background:linear-gradient(135deg, #fff 0%, var(--primary-light) 100%);
  border-radius:24px;box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:32px;position:relative;overflow:hidden;
}
.page-hero__visual svg.hero-illo{width:120px;height:120px;color:var(--primary);opacity:.65}
.page-hero__visual .label{
  position:absolute;bottom:18px;left:18px;right:18px;
  background:rgba(255,255,255,0.75);backdrop-filter:blur(8px);
  padding:8px 12px;border-radius:8px;font-size:11px;line-height:1.4;
  font-family:'JetBrains Mono',monospace;color:var(--primary-dark);
}
.bluebook-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--primary);color:#fff;
  padding:6px 12px;border-radius:999px;
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:500;
  margin-top:14px;
}
.bluebook-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent)}

@media (max-width:1023px){
  .page-hero{padding:32px 0 48px}
  .page-hero__inner{grid-template-columns:1fr;gap:32px}
  .page-hero h1{font-size:34px}
  .page-hero__visual{justify-self:center;max-width:280px}
}

/* ---- Breadcrumb ---- */
.crumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.08em;
}
.crumb a{color:var(--primary);font-weight:500}
.crumb a:hover{text-decoration:underline}
.crumb span.sep{opacity:.4}

/* ---- Two-column body layout (article + sidebar) ---- */
.doc{padding:64px 0 96px;background:var(--bg)}
.doc__inner{display:grid;grid-template-columns:minmax(0,700px) 280px;gap:64px;align-items:start;max-width:1100px;margin:0 auto;padding:0 24px}
.doc__main > * + *{margin-top:36px}

.doc__main h2{font-size:28px;margin-bottom:14px;padding-top:8px;scroll-margin-top:96px}
.doc__main h2 + p,.doc__main h2 + ul,.doc__main h2 + ol{margin-top:14px}
.doc__main h3{font-size:21px;margin:24px 0 10px;line-height:1.3}
.doc__main p{font-size:17px;line-height:1.7;color:var(--text)}
.doc__main p + p{margin-top:14px}
.doc__main ul.dot,.doc__main ol.num{margin:14px 0;padding-left:0;display:flex;flex-direction:column;gap:10px}
.doc__main ul.dot li{padding-left:28px;position:relative;font-size:17px;line-height:1.6}
.doc__main ul.dot li::before{
  content:"";position:absolute;left:6px;top:11px;width:8px;height:8px;
  border-radius:50%;background:var(--accent);
}
.doc__main ol.num{counter-reset:nl}
.doc__main ol.num li{
  padding-left:40px;position:relative;font-size:17px;line-height:1.6;
  counter-increment:nl;
}
.doc__main ol.num li::before{
  content:counter(nl);position:absolute;left:0;top:0;width:28px;height:28px;
  border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;
}
.doc__main a{color:var(--primary);font-weight:500;text-decoration:underline;text-decoration-color:rgba(11,110,110,.3);text-underline-offset:3px}
.doc__main a:hover{text-decoration-color:var(--primary)}

/* ---- Sidebar ---- */
.sidebar{position:sticky;top:96px;display:flex;flex-direction:column;gap:20px}
.side-card{background:#fff;border-radius:12px;padding:22px;box-shadow:var(--shadow-sm)}
.side-card.toc{border-left:3px solid var(--primary)}
.side-card h4{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--primary);margin-bottom:14px}
.side-card.toc ul{display:flex;flex-direction:column;gap:8px}
.side-card.toc a{font-size:14px;color:var(--text);line-height:1.4;display:block;padding:6px 0;border-left:2px solid transparent;padding-left:10px;margin-left:-10px;transition:all 150ms}
.side-card.toc a:hover{border-color:var(--accent);color:var(--primary);background:var(--primary-light)}

.side-cta-accent{background:var(--accent);color:#fff;padding:24px;border-radius:12px;display:flex;flex-direction:column;gap:10px}
.side-cta-accent h4{color:#fff;font-family:'Inter',sans-serif;font-size:18px;font-weight:700;text-transform:none;letter-spacing:0;margin:0}
.side-cta-accent p{color:rgba(255,255,255,.92);font-size:14px;line-height:1.5;margin:0}
.side-cta-accent .btn{background:#fff;color:var(--accent-hover);margin-top:6px;width:100%;padding:11px 16px;font-size:14px;min-height:auto}
.side-cta-accent .btn:hover{background:var(--accent-light);color:var(--accent-hover);transform:none}

.side-cta-guide{padding:22px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm)}
.side-cta-guide .icon{width:36px;height:36px;color:var(--accent);margin-bottom:10px}
.side-cta-guide h4{font-family:'Inter',sans-serif;font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px;text-transform:none;letter-spacing:0}
.side-cta-guide p{font-size:13px;color:var(--text-secondary);margin-bottom:10px;line-height:1.5}
.side-cta-guide a{font-size:14px;color:var(--primary);font-weight:600}

.side-phone{padding:18px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);text-align:center}
.side-phone .icon{width:28px;height:28px;color:var(--primary);margin:0 auto 8px}
.side-phone .label{font-size:13px;color:var(--text-secondary);margin-bottom:4px}
.side-phone .number{font-family:'Inter',sans-serif;font-size:18px;font-weight:700;color:var(--primary)}

/* ---- Mobile floating bottom bar ---- */
.mbar{
  display:none;
  position:fixed;left:12px;right:12px;bottom:12px;z-index:80;
  background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);
  padding:10px;gap:8px;
}
.mbar .btn{flex:1;min-height:48px;font-size:15px}
.mbar a.phone-link{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  background:var(--primary-light);color:var(--primary);border-radius:10px;
  flex-shrink:0;
}
.mbar a.phone-link svg{width:22px;height:22px}

@media (max-width:1023px){
  .doc{padding:32px 0 120px}
  .doc__inner{grid-template-columns:1fr;gap:40px;padding:0 20px}
  .sidebar{position:static;flex-direction:row;flex-wrap:wrap;gap:14px;display:none}
  .sidebar .side-card.toc{display:none}
  .mbar{display:flex}
  .chatbot{bottom:84px}
}

/* ---- Info Callout (teal) ---- */
.callout-info{
  background:var(--primary-light);
  border-left:4px solid var(--primary);
  padding:22px 26px;border-radius:0 12px 12px 0;
  display:flex;flex-direction:column;gap:8px;
}
.callout-info .label{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:0.08em}
.callout-info .num{
  font-family:'Inter',sans-serif;font-weight:700;font-size:20px;color:var(--primary-dark);
  display:flex;align-items:center;gap:14px;
}
.callout-info .num .digit{
  width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;
}
.callout-info h3{font-size:18px;margin:0}
.callout-info p{font-size:16px;line-height:1.6;color:var(--text);margin:0}

/* ---- Amber Callout (warm) ---- */
.callout-amber{
  background:var(--accent-light);
  border-left:4px solid var(--accent);
  padding:22px 26px;border-radius:0 12px 12px 0;
  display:flex;flex-direction:column;gap:8px;
}
.callout-amber .label{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--accent-hover);text-transform:uppercase;letter-spacing:0.08em}
.callout-amber h3{font-size:18px;margin:0;color:var(--text)}
.callout-amber p{font-size:16px;line-height:1.6;color:var(--text);margin:0}
.callout-amber.pro::before{
  content:"PRO TIP";font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:0.1em;
  color:var(--accent-hover);background:rgba(212,146,42,.18);padding:3px 10px;border-radius:999px;align-self:flex-start;
}

/* ---- Two-column callouts row (side by side) ---- */
.callout-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:768px){.callout-row{grid-template-columns:1fr}}

/* ---- Mistake card (red border) ---- */
.mistake-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
@media (max-width:768px){.mistake-grid{grid-template-columns:1fr}}
.mistake-card{
  background:#fff;border-left:4px solid var(--danger);
  padding:18px 22px;border-radius:0 10px 10px 0;
  box-shadow:var(--shadow-sm);
}
.mistake-card .num{
  font-family:'Inter',sans-serif;font-weight:700;font-size:13px;
  color:var(--danger);text-transform:uppercase;letter-spacing:0.06em;
  margin-bottom:6px;display:flex;align-items:center;gap:8px;
}
.mistake-card .num::before{
  content:"!";width:22px;height:22px;border-radius:50%;background:var(--danger);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;
}
.mistake-card h4{font-size:16px;margin-bottom:4px;line-height:1.3}
.mistake-card p{font-size:14px;color:var(--text-secondary);line-height:1.55;margin:0}

/* ---- Evidence table ---- */
.ev-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow-sm);font-size:15px;
}
.ev-table th{
  text-align:left;background:var(--primary);color:#fff;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:0.06em;
  padding:14px 16px;
}
.ev-table td{
  padding:14px 16px;vertical-align:top;
  border-top:1px solid var(--border);
  line-height:1.5;color:var(--text);
}
.ev-table td:first-child{font-weight:600;color:var(--primary-dark)}
.ev-table tr:nth-child(even) td{background:var(--bg)}
@media (max-width:768px){
  .ev-table,.ev-table thead,.ev-table tbody,.ev-table tr,.ev-table td{display:block}
  .ev-table thead{display:none}
  .ev-table tr{margin-bottom:18px;background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}
  .ev-table tr:nth-child(even) td{background:transparent}
  .ev-table td{border-top:1px solid var(--border);padding:12px 16px}
  .ev-table td:first-child{background:var(--primary);color:#fff;border-top:0;font-size:13px;text-transform:uppercase;letter-spacing:0.06em;font-family:'Inter',sans-serif}
}

/* ---- Generic data table (RFC etc.) ---- */
.data-table{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow-sm);font-size:15px;
}
.data-table th{
  text-align:left;background:var(--primary-light);color:var(--primary-dark);
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:0.06em;
  padding:12px 16px;
}
.data-table td{padding:12px 16px;vertical-align:top;border-top:1px solid var(--border);line-height:1.5}
.data-table td:first-child{font-weight:600;color:var(--text);width:38%}

/* ---- Final CTA (sub-page) ---- */
.subpage-cta{
  background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color:#fff;padding:64px 0;position:relative;overflow:hidden;text-align:center;
}
.subpage-cta::before{
  content:"";position:absolute;top:-100px;right:-100px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle, rgba(212,146,42,0.18) 0%, transparent 70%);pointer-events:none;
}
.subpage-cta h2{color:#fff;font-size:36px;margin-bottom:16px;position:relative}
.subpage-cta p{color:rgba(255,255,255,.9);font-size:17px;max-width:580px;margin:0 auto 24px;line-height:1.6;position:relative}
.subpage-cta .btn{position:relative}

/* ---- Related cards row ---- */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px}
.related-card{
  display:flex;flex-direction:column;gap:10px;
  background:#fff;padding:20px;border-radius:12px;
  box-shadow:var(--shadow-sm);
  border-left:3px solid transparent;
  transition:all 250ms ease;
}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-left-color:var(--accent)}
.related-card .icon-wrap{
  width:40px;height:40px;border-radius:8px;background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
}
.related-card .icon-wrap svg{width:22px;height:22px;color:var(--primary)}
.related-card h4{font-size:16px;margin:0;line-height:1.3}
.related-card p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0;flex:1}
.related-card .text-link{font-size:13px;margin-top:4px}
@media (max-width:768px){.related-grid{grid-template-columns:1fr}}

/* ---- Hub: complications full-width grid ---- */
.hub-intro{max-width:880px;margin:0 auto 48px;text-align:center;padding:0 24px}
.hub-intro p{font-size:18px;color:var(--text-secondary);line-height:1.7}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:0 auto;padding:0 24px}
.hub-card{
  background:#fff;border-radius:14px;padding:28px;
  box-shadow:var(--shadow-sm);
  border-left:4px solid transparent;
  transition:all 300ms ease;
  display:flex;flex-direction:column;gap:12px;
}
.hub-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-left-color:var(--accent)}
.hub-card .icon-wrap{
  width:56px;height:56px;border-radius:12px;background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;margin-bottom:8px;
}
.hub-card .icon-wrap svg{width:30px;height:30px;color:var(--primary)}
.hub-card h3{font-size:20px;line-height:1.3;margin:0}
.hub-card p{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0;flex:1}
.hub-card .bb-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--primary-light);color:var(--primary-dark);
  padding:5px 10px;border-radius:6px;
  font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:500;
  align-self:flex-start;
}
.hub-card .text-link{font-size:14px;margin-top:4px}
@media (max-width:1023px){.hub-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.hub-grid{grid-template-columns:1fr}}

/* ---- Type1 / Type2 side-by-side ---- */
.type-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:16px}
@media (max-width:768px){.type-pair{grid-template-columns:1fr}}
.type-pair .type-card{
  background:#fff;border-radius:12px;padding:28px;
  box-shadow:var(--shadow-sm);
  border-top:4px solid var(--primary);
  display:flex;flex-direction:column;gap:14px;
  transition:transform 300ms ease, box-shadow 300ms ease;
}
.type-pair .type-card.t2{border-top-color:var(--accent)}
.type-pair .type-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.type-pair .type-card .icon{width:44px;height:44px;color:var(--primary)}
.type-pair .type-card.t2 .icon{color:var(--accent)}
.type-pair .type-card h3{font-size:22px;margin:0}
.type-pair .type-card p{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0}
.type-pair .type-card ul{display:flex;flex-direction:column;gap:8px;margin:6px 0}
.type-pair .type-card li{padding-left:24px;position:relative;font-size:14px;line-height:1.5}
.type-pair .type-card li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;background:var(--primary-light)}
.type-pair .type-card li::after{content:"";position:absolute;left:3px;top:11px;width:6px;height:4px;border-left:2px solid var(--primary);border-bottom:2px solid var(--primary);transform:rotate(-45deg)}
.type-pair .type-card.t2 li::before{background:var(--accent-light)}
.type-pair .type-card.t2 li::after{border-color:var(--accent)}
.type-pair .type-card .btn{margin-top:6px;align-self:flex-start}

/* ---- Tier cards (age tiers for Type 2) ---- */
.tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px}
@media (max-width:1023px){.tier-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.tier-grid{grid-template-columns:1fr}}
.tier-card{
  background:#fff;border-radius:12px;padding:22px;
  box-shadow:var(--shadow-sm);
  border-top:4px solid var(--primary);
  display:flex;flex-direction:column;gap:8px;
}
.tier-card .age{font-family:'Inter',sans-serif;font-weight:700;font-size:24px;color:var(--primary);letter-spacing:-0.02em}
.tier-card h4{font-size:16px;margin:0;line-height:1.3}
.tier-card p{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0}
.tier-card.t1{border-top-color:#A8C9C9}
.tier-card.t2{border-top-color:var(--primary)}
.tier-card.t3{border-top-color:var(--accent)}
.tier-card.t4{border-top-color:var(--accent-hover)}

/* ---- FAQ accordion ---- */
.faq{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.faq details{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);overflow:hidden;border-left:3px solid var(--primary-light);transition:border-color 200ms}
.faq details[open]{border-left-color:var(--accent)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:17px;color:var(--text);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"";width:16px;height:16px;flex-shrink:0;
  background:url("data:image/svg+xml;utf8,<svg viewBox='0 0 24 24' fill='none' stroke='%230B6E6E' stroke-width='2.5' stroke-linecap='round' xmlns='http://www.w3.org/2000/svg'><path d='M6 9l6 6 6-6'/></svg>") center/contain no-repeat;
  transition:transform 200ms;
}
.faq details[open] summary::after{transform:rotate(180deg)}
.faq .faq-body{padding:0 22px 18px;color:var(--text);font-size:16px;line-height:1.65}

/* ---- Complication mini-cards (inside Qualify page Section E) ---- */
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
@media (max-width:1023px){.mini-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.mini-grid{grid-template-columns:1fr}}
.mini-card{
  background:#fff;border-radius:10px;padding:18px;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:8px;
  border-left:3px solid transparent;
  transition:all 250ms ease;
}
.mini-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-left-color:var(--accent)}
.mini-card .icon-wrap{
  width:36px;height:36px;border-radius:8px;background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
}
.mini-card .icon-wrap svg{width:20px;height:20px;color:var(--primary)}
.mini-card h4{font-size:15px;margin:0;line-height:1.3}
.mini-card p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0;flex:1}
.mini-card .text-link{font-size:13px;margin-top:2px}

/* ---- Hub: bottom callout cards (two-up) ---- */
.hub-bottom{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1100px;margin:48px auto 0;padding:0 24px}
@media (max-width:768px){.hub-bottom{grid-template-columns:1fr;padding:0 20px}}
.hub-bottom-card{
  background:#fff;border-radius:12px;padding:28px;
  box-shadow:var(--shadow-sm);
  border-top:4px solid var(--primary);
  display:flex;flex-direction:column;gap:10px;
}
.hub-bottom-card.amber{border-top-color:var(--accent)}
.hub-bottom-card h3{font-size:20px;margin:0}
.hub-bottom-card p{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0}
.hub-bottom-card a{align-self:flex-start;margin-top:4px}

/* ---- A11y skip link ---- */
.skip-link{
  position:absolute;left:-999px;top:8px;background:var(--primary);color:#fff;
  padding:10px 16px;border-radius:8px;font-weight:600;z-index:300;
}
.skip-link:focus{left:8px}

/* =========================================================
   Resources / Tools shared
   ========================================================= */

/* ---- Resources hero with search ---- */
.res-hero{
  background:linear-gradient(180deg,var(--primary-light) 0%,var(--bg) 70%);
  padding:88px 0 64px;
}
.res-hero .container{max-width:960px;text-align:center}
.res-hero .crumb{justify-content:center}
.res-hero h1{margin:18px 0 16px;font-size:48px}
.res-hero .sub{font-size:20px;color:var(--text-secondary);max-width:720px;margin:0 auto 32px}
@media (max-width:768px){.res-hero h1{font-size:32px}.res-hero .sub{font-size:17px}.res-hero{padding:48px 0 32px}}

.res-search{
  max-width:640px;margin:0 auto;position:relative;
}
.res-search input{
  width:100%;height:48px;padding:0 20px 0 48px;
  border:1px solid var(--border);border-radius:12px;background:#fff;
  font-family:'Source Sans 3',sans-serif;font-size:16px;color:var(--text);
  transition:border-color 200ms,box-shadow 200ms;
}
.res-search input::placeholder{font-style:italic;color:var(--text-secondary)}
.res-search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(11,110,110,.08)}
.res-search svg{
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:20px;height:20px;color:var(--primary);
}

/* ---- Filter pills bar ---- */
.filter-bar{
  background:#fff;border-bottom:1px solid var(--border);
  padding:14px 0;position:sticky;top:72px;z-index:50;
  transition:box-shadow 200ms;
}
.filter-bar.stuck{box-shadow:0 2px 10px rgba(0,0,0,.04)}
@media (max-width:768px){.filter-bar{top:64px;padding:10px 0}}
.filter-bar__inner{
  display:flex;align-items:center;gap:24px;max-width:1200px;
  margin:0 auto;padding:0 24px;
}
.filter-pills{display:flex;gap:8px;flex:1;overflow-x:auto;scrollbar-width:none}
.filter-pills::-webkit-scrollbar{display:none}
.pill{
  flex-shrink:0;display:inline-flex;align-items:center;height:36px;padding:0 14px;border-radius:20px;
  border:1px solid var(--border);background:#fff;color:var(--text-secondary);
  font-family:'Source Sans 3',sans-serif;font-weight:500;font-size:14px;
  cursor:pointer;transition:all 180ms;white-space:nowrap;text-decoration:none;
}
.pill:hover{border-color:var(--primary);color:var(--primary)}
.pill.active{background:var(--primary);border-color:var(--primary);color:#fff}
.filter-bar__selects{display:flex;gap:10px;flex-shrink:0}
.filter-bar select{
  height:36px;padding:0 32px 0 14px;border:1px solid var(--border);
  border-radius:8px;background:#fff;font-family:'Source Sans 3',sans-serif;
  font-size:14px;color:var(--text);cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%234A5568' stroke-width='2' stroke-linecap='round'><path d='M2 2l4 4 4-4'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center;
}
@media (max-width:768px){
  .filter-bar__inner{flex-direction:column;align-items:stretch;gap:10px}
  .filter-bar__selects{justify-content:space-between}
}

/* ---- Featured Resources / large amber-top cards ---- */
.featured-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
@media (max-width:1024px){.featured-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.featured-grid{grid-template-columns:1fr}}
.featured-card{
  background:#fff;border-radius:12px;padding:32px 28px;
  border-top:4px solid var(--accent);
  box-shadow:var(--shadow-md);
  transition:transform 300ms,box-shadow 300ms;
  display:flex;flex-direction:column;gap:14px;position:relative;
}
.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.featured-card .icon{
  width:40px;height:40px;color:var(--primary);
}
.featured-card .badge{
  position:absolute;top:18px;right:18px;
  background:var(--accent);color:#fff;font-family:'Inter',sans-serif;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  padding:5px 10px;border-radius:12px;
}
.featured-card h3{font-size:18px;line-height:1.3;margin:0}
.featured-card p{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0;flex:1}
.featured-card a{color:var(--primary);font-weight:600;font-size:15px}
.featured-card a:hover{color:var(--primary-dark)}

/* ---- Category grid (3x3 small cards) ---- */
.cat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:1024px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cat-grid{grid-template-columns:1fr}}
.cat-card{
  background:#fff;border-radius:12px;padding:24px;
  box-shadow:var(--shadow-sm);
  transition:transform 300ms,box-shadow 300ms,border-color 300ms;
  border-left:4px solid transparent;
  display:flex;flex-direction:column;gap:10px;cursor:pointer;
}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-left-color:var(--accent)}
.cat-card .icon{width:36px;height:36px;color:var(--primary)}
.cat-card .row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cat-card h3{font-size:17px;line-height:1.3;margin:0}
.cat-card .count{
  font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--primary);
  background:var(--primary-light);padding:3px 10px;border-radius:10px;
  font-weight:500;white-space:nowrap;
}
.cat-card p{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0}
.cat-card .more{color:var(--primary);font-weight:600;font-size:14px;margin-top:4px}

/* ---- Article list rows ---- */
.article-list{display:flex;flex-direction:column;background:#fff;border-radius:12px;border:1px solid var(--border)}
.article-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:start;
  padding:24px 28px;border-bottom:1px solid var(--border);
  transition:background-color 200ms;cursor:pointer;
}
.article-row:last-child{border-bottom:0}
.article-row:hover{background:var(--primary-light)}
.article-row .badge{
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  background:var(--accent);color:#fff;padding:6px 12px;border-radius:14px;
  white-space:nowrap;
}
.article-row .content h3{
  font-size:18px;line-height:1.35;margin:0 0 6px;color:var(--text);
}
.article-row .content p{font-size:15px;color:var(--text-secondary);line-height:1.5;margin:0}
.article-row .meta{
  font-size:13px;color:var(--text-secondary);white-space:nowrap;
  font-family:'Source Sans 3',sans-serif;
}
@media (max-width:768px){
  .article-row{grid-template-columns:1fr;gap:12px;padding:20px}
  .article-row .badge{justify-self:start}
  .article-row .meta{justify-self:start}
}

/* ---- Article card grid (Guides page) ---- */
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:1024px){.art-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.art-grid{grid-template-columns:1fr}}
.art-card{
  background:#fff;border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform 300ms,box-shadow 300ms;
  cursor:pointer;display:flex;flex-direction:column;
}
.art-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.art-card__img{
  aspect-ratio:16/9;background:var(--primary-light);position:relative;
  display:flex;align-items:center;justify-content:center;
}
.art-card__img svg{width:48px;height:48px;color:var(--primary);opacity:.55}
.art-card__img .badge{
  position:absolute;left:14px;bottom:14px;
  background:var(--accent);color:#fff;font-family:'Inter',sans-serif;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  padding:5px 11px;border-radius:12px;
}
.art-card__body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.art-card__body h3{font-size:19px;line-height:1.35;margin:0}
.art-card__body p{
  font-size:15px;color:var(--text-secondary);line-height:1.5;margin:0;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.art-card__meta{font-size:13px;color:var(--text-secondary);margin-top:4px}

.pagination{
  display:flex;align-items:center;justify-content:center;gap:8px;
  margin-top:48px;
}
.pagination a{
  min-width:36px;height:36px;padding:0 12px;border-radius:18px;
  border:1px solid var(--border);background:#fff;color:var(--text);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;
  transition:all 180ms;
}
.pagination a:hover{border-color:var(--primary);color:var(--primary)}
.pagination a.current{background:var(--accent);border-color:var(--accent);color:#fff}

/* ---- Newsletter strip ---- */
.newsletter{
  background:var(--primary-light);padding:48px 24px;
}
.newsletter__inner{
  max-width:720px;margin:0 auto;text-align:center;
}
.newsletter h3{font-size:24px;margin:0 0 8px}
.newsletter p{font-size:16px;color:var(--text-secondary);margin:0 0 22px}
.newsletter form{
  display:flex;gap:10px;max-width:480px;margin:0 auto;
}
.newsletter input{
  flex:1;height:48px;padding:0 16px;border:1px solid var(--border);
  border-radius:8px;background:#fff;font-family:'Source Sans 3',sans-serif;font-size:16px;
}
.newsletter input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,110,110,.1)}
.newsletter button{
  height:48px;padding:0 22px;border-radius:8px;background:var(--accent);
  color:#fff;font-family:'Inter',sans-serif;font-weight:600;font-size:15px;
  cursor:pointer;transition:background 180ms;
}
.newsletter button:hover{background:var(--accent-hover)}
@media (max-width:640px){.newsletter form{flex-direction:column}}

/* ---- Big tools detail card (Tools Hub) ---- */
.tool-card{
  background:#fff;border-radius:12px;padding:32px;
  box-shadow:var(--shadow-md);
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  border-left:4px solid transparent;
  transition:transform 300ms,box-shadow 300ms,border-color 300ms;
  position:relative;
}
.tool-card:hover{
  transform:translateY(-4px);box-shadow:var(--shadow-lg);
  border-left-color:var(--accent);
}
.tool-card__icon{
  width:48px;height:48px;color:var(--primary);flex-shrink:0;
}
.tool-card__body{display:flex;flex-direction:column;gap:10px}
.tool-card h3{font-size:22px;margin:0;font-weight:700}
.tool-card p{font-size:16px;color:var(--text-secondary);line-height:1.6;margin:0}
.tool-card__meta{
  font-family:'JetBrains Mono',monospace;font-size:13px;
  color:var(--primary);margin-top:2px;
}
.tool-card__cta{margin-top:8px;align-self:flex-start}
.tool-card .badge-pop{
  position:absolute;top:16px;right:16px;background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;padding:5px 11px;border-radius:12px;
}
@media (max-width:640px){
  .tool-card{grid-template-columns:1fr;padding:24px}
}

/* ---- FAQ accordion ---- */
.faq-tabs{
  display:flex;gap:0;border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;
}
.faq-tabs::-webkit-scrollbar{display:none}
.faq-tab{
  padding:14px 20px;font-family:'Inter',sans-serif;font-weight:600;
  font-size:15px;color:var(--text-secondary);
  border-bottom:3px solid transparent;cursor:pointer;
  transition:all 180ms;white-space:nowrap;
}
.faq-tab:hover{color:var(--primary)}
.faq-tab.active{color:var(--primary);border-bottom-color:var(--primary)}

.faq-group{margin-top:40px}
.faq-group h2{
  font-size:24px;margin:0 0 16px;padding-left:14px;
  border-left:3px solid var(--primary);
}
.faq-item{
  background:#fff;border:1px solid var(--border);border-radius:8px;
  margin-bottom:8px;overflow:hidden;
}
.faq-item summary{
  list-style:none;padding:18px 22px;cursor:pointer;
  font-family:'Inter',sans-serif;font-weight:600;font-size:17px;color:var(--text);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  transition:background-color 180ms;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{background:var(--primary-light)}
.faq-item summary::after{
  content:"";width:14px;height:14px;flex-shrink:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230B6E6E' stroke-width='2.5' stroke-linecap='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-size:contain;background-repeat:no-repeat;
  transition:transform 200ms;
}
.faq-item[open] summary::after{transform:rotate(180deg)}
.faq-item .answer{padding:0 22px 20px;color:var(--text-secondary);font-size:16px;line-height:1.7}

/* ---- Story cards ---- */
.story-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:768px){.story-grid{grid-template-columns:1fr}}
.story-card{
  background:#fff;border-radius:12px;padding:32px;
  border-left:3px solid var(--accent);
  box-shadow:var(--shadow-sm);position:relative;
  display:flex;flex-direction:column;gap:18px;
}
.story-card::before{
  content:"\201C";position:absolute;top:4px;left:18px;
  font-family:'Iowan Old Style',Georgia,serif;font-size:64px;
  color:var(--accent);opacity:.18;line-height:1;
}
.story-card blockquote{
  font-family:'Inter',sans-serif;font-weight:500;font-style:italic;
  font-size:18px;line-height:1.55;color:var(--text);
  margin:0;padding-top:18px;position:relative;
}
.story-card .divider{height:1px;background:var(--border)}
.story-card .person{display:flex;flex-direction:column;gap:6px}
.story-card .name{font-family:'Inter',sans-serif;font-weight:600;font-size:16px}
.story-card .loc{font-size:14px;color:var(--text-secondary)}
.story-card .badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.story-card .badge{
  background:var(--primary-light);color:var(--primary);
  font-family:'Inter',sans-serif;font-size:12px;font-weight:600;
  padding:4px 10px;border-radius:12px;
}
.story-card a{color:var(--primary);font-weight:600;font-size:14px;margin-top:4px}

/* ---- Checklist cards (printable) ---- */
.check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:768px){.check-grid{grid-template-columns:1fr}}
.check-card{
  background:#fff;border-radius:12px;padding:28px;
  box-shadow:var(--shadow-sm);
  display:flex;gap:20px;align-items:flex-start;position:relative;
  transition:transform 300ms,box-shadow 300ms;
}
.check-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.check-card .icon{
  width:44px;height:44px;color:var(--primary);flex-shrink:0;
  background:var(--primary-light);border-radius:10px;padding:8px;
}
.check-card .body{flex:1;display:flex;flex-direction:column;gap:8px}
.check-card h3{font-size:18px;margin:0}
.check-card p{font-size:15px;color:var(--text-secondary);line-height:1.55;margin:0}
.check-card .actions{display:flex;gap:14px;margin-top:6px;flex-wrap:wrap}
.check-card .actions a{color:var(--primary);font-weight:600;font-size:14px}
.check-card .free-badge{
  position:absolute;top:16px;right:16px;background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:10px;
}

/* ---- Lead magnet strip ---- */
.lead-strip{
  background:var(--accent-light);padding:48px 24px;margin-top:48px;
  border-radius:12px;
}
.lead-strip__inner{max-width:760px;margin:0 auto;text-align:center}
.lead-strip h3{font-size:24px;margin:0 0 8px}
.lead-strip p{color:var(--text-secondary);margin:0 0 22px}
.lead-strip form{display:flex;gap:10px;max-width:600px;margin:0 auto;flex-wrap:wrap}
.lead-strip input{
  flex:1;min-width:140px;height:48px;padding:0 14px;
  border:1px solid var(--border);border-radius:8px;background:#fff;
  font-family:'Source Sans 3',sans-serif;font-size:15px;
}
.lead-strip input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,110,110,.1)}
.lead-strip button{
  height:48px;padding:0 22px;background:var(--accent);color:#fff;
  border-radius:8px;font-family:'Inter',sans-serif;font-weight:600;font-size:15px;
  cursor:pointer;transition:background 180ms;
}
.lead-strip button:hover{background:var(--accent-hover)}

/* ---- Tool page simplified header ---- */
.tool-head{
  background:#fff;border-bottom:1px solid var(--border);
  height:64px;display:flex;align-items:center;
  position:sticky;top:0;z-index:50;
}
.tool-head__inner{
  max-width:1200px;margin:0 auto;padding:0 24px;width:100%;
  display:flex;align-items:center;justify-content:space-between;
}
.tool-head .back{
  color:var(--text-secondary);font-size:14px;font-family:'Source Sans 3',sans-serif;
  display:inline-flex;align-items:center;gap:6px;
}
.tool-head .back:hover{color:var(--primary)}

.tool-shell{
  max-width:1100px;margin:48px auto;padding:0 24px;
  display:grid;grid-template-columns:480px 1fr;gap:32px;align-items:start;
}
@media (max-width:960px){.tool-shell{grid-template-columns:1fr;max-width:720px}}
.tool-panel{
  background:#fff;border-radius:12px;padding:32px;box-shadow:var(--shadow-sm);
}
.tool-panel h2{font-size:28px;margin:0 0 8px}
.tool-panel .sub{color:var(--text-secondary);font-size:16px;margin:0 0 24px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:var(--text);
}
.field input,.field select{
  height:46px;padding:0 14px;border:1px solid var(--border);border-radius:8px;
  background:#fff;font-family:'Source Sans 3',sans-serif;font-size:16px;color:var(--text);
}
.field input:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,110,110,.1)}
.field .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field .with-prefix{position:relative}
.field .with-prefix::before{
  content:"$";position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--text-secondary);font-family:'JetBrains Mono',monospace;font-size:15px;
}
.field .with-prefix input{padding-left:30px}

.progress{
  height:8px;background:var(--border);border-radius:4px;overflow:hidden;
  margin:6px 0 16px;
}
.progress__fill{height:100%;background:var(--accent);border-radius:4px;transition:width 300ms}
.progress-label{font-size:14px;color:var(--text-secondary);font-weight:500}

/* ---- Big result panel (right column on tool pages) ---- */
.result-panel{
  background:#fff;border-radius:12px;padding:32px;box-shadow:var(--shadow-sm);
}
.result-row{padding:18px 0;border-bottom:1px solid var(--border)}
.result-row:last-child{border-bottom:0}
.result-row .label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.result-row .big{
  font-family:'JetBrains Mono',monospace;font-weight:600;font-size:48px;
  color:var(--accent);line-height:1.05;margin:4px 0 8px;
}
.result-row .big.green{color:#22876B;font-size:36px}
.result-row .big.date{color:var(--text);font-family:'Inter',sans-serif;font-size:22px;font-weight:500}
.result-row details summary{
  list-style:none;color:var(--primary);font-weight:600;font-size:14px;cursor:pointer;
}
.result-row details summary::-webkit-details-marker{display:none}
.result-row details summary::after{content:" ▾"}
.result-row details[open] summary::after{content:" ▴"}
.result-row details p{
  font-size:14px;color:var(--text-secondary);margin-top:8px;line-height:1.55;
}

/* ---- Likert (4-button row) ---- */
.likert{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0 24px;
}
@media (max-width:640px){.likert{grid-template-columns:1fr}}
.likert button{
  padding:12px 10px;border:1px solid var(--border);background:#fff;
  border-radius:12px;text-align:left;cursor:pointer;
  font-family:'Source Sans 3',sans-serif;font-size:14px;font-weight:500;
  color:var(--text-secondary);transition:all 180ms;
  display:flex;flex-direction:column;gap:4px;
}
.likert button .lbl{font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:var(--text)}
.likert button:hover{border-color:var(--primary)}
.likert button.selected{background:var(--primary);border-color:var(--primary);color:#fff}
.likert button.selected .lbl{color:#fff}

.q-block{margin-bottom:28px}
.q-block .q{font-family:'Inter',sans-serif;font-weight:600;font-size:17px;color:var(--text);margin-bottom:4px}

/* ---- Symptom checker checkbox groups ---- */
.symp-group{margin-bottom:28px}
.symp-group h3{
  font-size:17px;padding-left:12px;border-left:3px solid var(--primary);
  margin:0 0 12px;
}
.symp-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:640px){.symp-list{grid-template-columns:1fr}}
.check-row{
  display:flex;align-items:center;gap:12px;padding:10px 14px;
  border-radius:10px;background:var(--bg);
  cursor:pointer;transition:background 180ms;
}
.check-row:hover{background:var(--primary-light)}
.check-row input{
  appearance:none;-webkit-appearance:none;
  width:22px;height:22px;border:2px solid var(--border);border-radius:6px;
  flex-shrink:0;cursor:pointer;transition:all 180ms;position:relative;
}
.check-row input:checked{background:var(--primary);border-color:var(--primary)}
.check-row input:checked::after{
  content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.check-row label{font-size:15px;cursor:pointer;flex:1}

/* ---- Severity bar (result cards) ---- */
.sev{
  display:flex;align-items:center;gap:10px;
  margin:6px 0 12px;
}
.sev .bar{flex:1;height:8px;border-radius:4px;background:var(--border);overflow:hidden;max-width:200px}
.sev .fill{height:100%;border-radius:4px}
.sev .fill.mild{width:25%;background:#22876B}
.sev .fill.mod{width:55%;background:var(--accent)}
.sev .fill.sev{width:80%;background:#C53030}
.sev .fill.ext{width:95%;background:#7B0F0F}
.sev .lbl{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text-secondary)}

.bb-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--primary-light);color:var(--primary);
  padding:6px 12px;border-radius:14px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;
}

/* ---- Timeline (vertical) ---- */
.timeline{display:flex;flex-direction:column;gap:0;margin:24px 0}
.tl-stage{
  display:grid;grid-template-columns:120px 1fr;gap:16px;
  padding:18px 22px;border-radius:12px;border:1px solid var(--border);
  background:#fff;position:relative;
}
.tl-stage + .tl-connector{
  width:2px;height:28px;background:var(--border);margin-left:64px;
  border-radius:1px;
}
.tl-stage.past{background:#F4F6F8;color:var(--text-secondary)}
.tl-stage.current{border-color:var(--accent);border-width:2px;background:var(--accent-light)}
.tl-stage.future-key{border-left:4px solid var(--primary)}
.tl-stage .label{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:var(--text-secondary)}
.tl-stage .stage-name{font-family:'Inter',sans-serif;font-weight:700;font-size:18px;color:var(--text);margin:2px 0 4px}
.tl-stage .duration{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text-secondary)}
.tl-badge{
  display:inline-block;background:var(--primary);color:#fff;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:10px;text-transform:uppercase;letter-spacing:.06em;
  margin-top:6px;
}
.tl-badge.red{background:var(--danger)}
.tl-badge.amber{background:var(--accent)}

/* ---- Back pay bar chart ---- */
.bp-chart{
  display:grid;grid-template-columns:repeat(6,1fr);gap:12px;
  align-items:end;height:160px;margin:24px 0 12px;
}
.bp-bar{
  background:linear-gradient(180deg,#22876B 0%, #156248 100%);
  border-radius:6px 6px 0 0;position:relative;text-align:center;
}
.bp-bar::after{
  content:attr(data-month);position:absolute;bottom:-20px;left:0;right:0;
  font-size:11px;color:var(--text-secondary);font-family:'JetBrains Mono',monospace;
}
.bp-total{
  font-family:'JetBrains Mono',monospace;font-weight:600;font-size:28px;
  color:#22876B;text-align:right;
}

/* ---- Lead magnet modal styles (for guide page) ---- */
.lm-shell{
  max-width:960px;margin:48px auto;padding:0 24px;
  display:grid;grid-template-columns:38% 1fr;gap:48px;align-items:start;
}
@media (max-width:768px){.lm-shell{grid-template-columns:1fr;gap:24px;max-width:480px}}
.book-cover{
  aspect-ratio:3/4;background:var(--primary);border-radius:8px;
  box-shadow:0 12px 40px rgba(11,110,110,.32);padding:28px 24px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:#fff;position:relative;overflow:hidden;
}
.book-cover::before{
  content:"";position:absolute;left:0;right:0;bottom:0;height:20%;
  background:var(--accent);
}
.book-cover h3{
  font-family:'Inter',sans-serif;font-size:22px;font-weight:700;color:#fff;
  line-height:1.2;margin:0;
}
.book-cover .ksub{font-size:13px;color:rgba(255,255,255,.85);line-height:1.5;margin-top:10px}
.book-cover .brand{
  position:relative;z-index:1;display:flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:15px;
}
.lm-form h1{font-size:36px;margin:0 0 12px;line-height:1.15}
.lm-form .sub{font-size:18px;color:var(--text-secondary);margin:0 0 22px}
.lm-form .perks{display:flex;flex-direction:column;gap:10px;margin:0 0 22px}
.lm-form .perks li{display:flex;gap:10px;align-items:flex-start;font-size:15px}
.lm-form .perks svg{width:18px;height:18px;color:var(--accent);flex-shrink:0;margin-top:3px}
.lm-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
@media (max-width:640px){.lm-form .form-row{grid-template-columns:1fr}}
.lm-form input{
  height:48px;padding:0 14px;border:1px solid var(--border);border-radius:8px;
  background:#fff;font-family:'Source Sans 3',sans-serif;font-size:16px;width:100%;
}
.lm-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,110,110,.1)}
.lm-form .submit{
  width:100%;height:52px;background:var(--accent);color:#fff;
  border-radius:8px;font-family:'Inter',sans-serif;font-weight:600;font-size:16px;
  cursor:pointer;transition:background 180ms;
}
.lm-form .submit:hover{background:var(--accent-hover)}
.lm-form .fine{font-size:13px;color:var(--text-secondary);margin-top:10px}
.lm-form .trust-row{display:flex;flex-wrap:wrap;gap:18px;margin-top:14px;font-size:13px;color:var(--text-secondary)}
.lm-form .trust-row span{display:inline-flex;align-items:center;gap:6px}

/* ---- Tooltip ---- */
.tip{position:relative;display:inline-flex;align-items:center;margin-left:6px}
.tip svg{width:14px;height:14px;color:var(--text-secondary);cursor:help}
.tip .body{
  position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);
  background:var(--text);color:#fff;font-size:13px;font-weight:400;line-height:1.45;
  padding:8px 12px;border-radius:6px;width:240px;text-align:left;
  opacity:0;pointer-events:none;transition:opacity 200ms;z-index:30;
}
.tip:hover .body{opacity:1}
.tip .body::after{
  content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--text);
}

/* ---- Doc-checklist categories ---- */
.dc-cat{margin-bottom:32px}
.dc-cat__head{
  display:flex;align-items:center;justify-content:space-between;
  padding-left:14px;border-left:3px solid var(--primary);margin-bottom:14px;
}
.dc-cat__head h3{font-size:19px;margin:0}
.dc-cat__head .count{
  background:var(--primary-light);color:var(--primary);
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:500;
  padding:4px 10px;border-radius:10px;
}
.dc-list{display:flex;flex-direction:column;gap:6px}
.dc-row{
  display:flex;align-items:center;gap:12px;padding:10px 14px;
  border-radius:8px;background:var(--bg);transition:background 180ms;
}
.dc-row:hover{background:var(--primary-light)}
.dc-row input{
  appearance:none;-webkit-appearance:none;width:22px;height:22px;
  border:2px solid var(--border);border-radius:6px;flex-shrink:0;cursor:pointer;
  position:relative;transition:all 180ms;
}
.dc-row input:checked{background:var(--primary);border-color:var(--primary)}
.dc-row input:checked::after{
  content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.dc-row input:checked ~ label{color:var(--text-secondary);text-decoration:line-through;text-decoration-color:#cbd5e0}
.dc-row label{flex:1;cursor:pointer;font-size:15px}

.dc-missing{
  background:var(--accent-light);border-radius:12px;padding:28px;margin-top:32px;
}
.dc-missing h3{font-size:20px;margin:0 0 14px}
.dc-missing__group{margin-bottom:18px}
.dc-missing__group h4{font-family:'Inter',sans-serif;font-size:15px;margin:0 0 10px;display:flex;align-items:center;gap:8px}
.dc-missing__group h4 .dot{width:10px;height:10px;border-radius:50%}
.dc-missing__group .dot.red{background:var(--danger)}
.dc-missing__group .dot.amber{background:var(--accent)}
.dc-missing__group .dot.teal{background:var(--primary)}
.dc-missing__group ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.dc-missing__group li{font-size:14px;line-height:1.55}
.dc-missing__group li strong{font-family:'Inter',sans-serif;font-weight:600;color:var(--text)}

/* ---- Centered narrow page (checklists, faqs) ---- */
.narrow{max-width:880px;margin:0 auto;padding:0 24px}

/* ---- Featured + Disclaimer callouts ---- */
.callout-amber-soft{
  background:var(--accent-light);border-left:4px solid var(--accent);
  border-radius:10px;padding:18px 22px;font-size:14px;color:var(--text-secondary);
}
.callout-teal-soft{
  background:var(--primary-light);border-left:4px solid var(--primary);
  border-radius:10px;padding:18px 22px;
}

/* ---- Section-2 spacing tweaks ---- */
.section-tight{padding:56px 0}

/* ================================================================
   HOW IT WORKS — animated vertical process timeline
   ================================================================ */
.hiw-hero{
  background:#FAFCFC;padding:80px 0 32px;text-align:center;
}
.hiw-hero h1{font-family:'Inter',sans-serif;font-weight:700;font-size:clamp(32px,5vw,48px);line-height:1.15;color:var(--text);margin:0 0 16px;letter-spacing:-0.02em}
.hiw-hero p{font-family:'Source Sans 3',sans-serif;font-size:clamp(17px,2vw,20px);color:var(--text-secondary);line-height:1.6;max-width:720px;margin:0 auto}

.process-timeline{
  background:#fff;padding:80px 0 40px;position:relative;
}
.process-timeline__inner{
  max-width:960px;margin:0 auto;padding:0 24px;position:relative;
}
.process-timeline__line{
  position:absolute;left:50%;top:0;bottom:0;width:0;
  border-left:2px dashed var(--primary);
  transform:translateX(-1px);
  opacity:0.5;
}
.proc-step{
  position:relative;min-height:280px;margin-bottom:72px;
  display:grid;grid-template-columns:1fr 96px 1fr;gap:0;align-items:start;
}
.proc-step__circle{
  grid-column:2;justify-self:center;
  width:72px;height:72px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-weight:700;font-size:28px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(212,146,42,0.3);
  position:relative;z-index:2;
  opacity:0;transform:scale(0);
  transition:opacity 400ms ease-out, transform 400ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.proc-step__icon{
  grid-column:2;justify-self:center;
  margin-top:10px;color:var(--primary);
  width:48px;height:48px;
  opacity:0;transform:translateY(10px);
  transition:opacity 300ms ease-out 200ms, transform 300ms ease-out 200ms;
}
.proc-step__icon svg{width:48px;height:48px}
.proc-step__card{
  background:#fff;border-radius:12px;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  padding:32px;max-width:480px;position:relative;
  opacity:0;
  transition:opacity 500ms ease-out 300ms, transform 500ms ease-out 300ms;
}
.proc-step--left .proc-step__card{
  grid-column:1;justify-self:end;margin-right:24px;
  transform:translateX(-30px);
}
.proc-step--right .proc-step__card{
  grid-column:3;justify-self:start;margin-left:24px;
  transform:translateX(30px);
}
.proc-step__card::after{
  content:"";position:absolute;top:32px;width:12px;height:12px;
  background:#fff;border:1px solid rgba(0,0,0,0.04);transform:rotate(45deg);
  box-shadow:1px -1px 2px rgba(0,0,0,0.03);
}
.proc-step--left .proc-step__card::after{right:-7px}
.proc-step--right .proc-step__card::after{left:-7px}
.proc-step.in-view .proc-step__circle{opacity:1;transform:scale(1)}
.proc-step.in-view .proc-step__icon{opacity:1;transform:translateY(0)}
.proc-step.in-view .proc-step__card{opacity:1;transform:translateX(0)}
.proc-step__card h3{font-family:'Inter',sans-serif;font-weight:600;font-size:24px;margin:0 0 12px;color:var(--text)}
.proc-step__card p{font-family:'Source Sans 3',sans-serif;font-size:18px;line-height:1.75;color:var(--text-secondary);margin:0 0 18px}
.proc-pills{display:flex;flex-wrap:wrap;gap:8px}
.proc-pills span{
  display:inline-flex;align-items:center;height:28px;padding:0 12px;border-radius:16px;
  background:var(--primary-light);color:var(--primary);
  font-family:'Source Sans 3',sans-serif;font-weight:500;font-size:13px;
  opacity:0;transform:translateY(8px);
  transition:opacity 250ms ease-out, transform 250ms ease-out;
}
.proc-step.in-view .proc-pills span{opacity:1;transform:translateY(0)}
.proc-step.in-view .proc-pills span:nth-child(1){transition-delay:600ms}
.proc-step.in-view .proc-pills span:nth-child(2){transition-delay:680ms}
.proc-step.in-view .proc-pills span:nth-child(3){transition-delay:760ms}

@media (max-width:860px){
  .process-timeline__line{left:32px;transform:none}
  .proc-step{grid-template-columns:64px 1fr;gap:0;min-height:auto;margin-bottom:56px}
  .proc-step__circle{grid-column:1;grid-row:1;width:56px;height:56px;font-size:22px;justify-self:start}
  .proc-step__icon{grid-column:1;grid-row:2;justify-self:start;margin-left:4px;width:36px;height:36px}
  .proc-step__icon svg{width:36px;height:36px}
  .proc-step--left .proc-step__card,
  .proc-step--right .proc-step__card{
    grid-column:2;grid-row:1/span 2;justify-self:start;
    margin:0 0 0 20px;padding:24px;transform:translateX(20px);
  }
  .proc-step__card::after{left:-7px;right:auto}
}

@media (prefers-reduced-motion: reduce){
  .proc-step__circle,
  .proc-step__icon,
  .proc-step__card,
  .proc-pills span{
    opacity:1 !important;transform:none !important;transition:none !important;
  }
}

/* ---- "What You Never Pay" cost section ---- */
.cost-section{background:var(--primary-light);padding:80px 0}
.cost-section h2{font-family:'Inter',sans-serif;font-weight:700;font-size:clamp(28px,3.5vw,36px);text-align:center;margin:0 0 48px;color:var(--text)}
.cost-grid{
  max-width:880px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.cost-item{text-align:center;padding:24px 16px}
.cost-item svg{width:48px;height:48px;color:var(--primary);margin-bottom:16px}
.cost-item__label{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;color:var(--text);margin:0 0 8px}
.cost-item__amount{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:28px;margin:0 0 8px;color:#22876B}
.cost-item__amount.amber{color:var(--accent)}
.cost-item__sub{font-family:'Source Sans 3',sans-serif;font-size:14px;color:var(--text-secondary);line-height:1.55;margin:0}
.cost-note{
  max-width:880px;margin:32px auto 0;padding:24px;background:#fff;
  border:1px solid var(--primary);border-radius:12px;
  font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.7;color:var(--text-secondary);
}
.cost-note strong{color:var(--text);font-weight:600;font-family:'Inter',sans-serif}
@media (max-width:720px){.cost-grid{grid-template-columns:1fr}}

/* ---- FAQ accordion (How It Works) ---- */
.hiw-faq{background:#fff;padding:80px 0}
.hiw-faq__inner{max-width:800px;margin:0 auto;padding:0 24px}
.hiw-faq h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;text-align:center;margin:0 0 40px;color:var(--text)}
.faq-item{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  margin-bottom:12px;overflow:hidden;
}
.faq-item[open]{border-left:3px solid var(--primary);background:#FAFCFC}
.faq-item summary{
  cursor:pointer;list-style:none;
  font-family:'Inter',sans-serif;font-weight:600;font-size:18px;color:var(--text);
  padding:18px 56px 18px 24px;position:relative;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";position:absolute;right:24px;top:50%;
  width:12px;height:12px;border-right:2px solid var(--text-secondary);border-bottom:2px solid var(--text-secondary);
  transform:translateY(-50%) rotate(45deg);
  transition:transform 200ms ease;
}
.faq-item[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.faq-item p{
  font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.75;color:var(--text-secondary);
  margin:0;padding:0 24px 20px;
}

/* ================================================================
   AFTER DENIAL — hub page
   ================================================================ */
.denied-hero{
  background:linear-gradient(180deg, rgba(255, 245, 245, 0.5) 0%, var(--primary-light) 40%, var(--bg) 100%);
  padding:80px 0 64px;
}
.denied-hero__inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:center;
}
.denied-hero h1{font-family:'Inter',sans-serif;font-weight:700;font-size:clamp(32px,5vw,48px);line-height:1.15;margin:0 0 16px;color:var(--text);letter-spacing:-0.02em}
.denied-hero p.sub{font-family:'Source Sans 3',sans-serif;font-size:20px;line-height:1.6;color:var(--text-secondary);margin:0 0 28px}
.denied-hero .sub-cta{font-family:'Source Sans 3',sans-serif;font-size:14px;color:var(--text-secondary);margin:12px 0 0}

.denied-stat{
  background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,0.08);
  border-left:4px solid var(--primary);padding:32px;
}
.denied-stat__number{
  font-family:'JetBrains Mono',monospace;font-weight:700;font-size:48px;
  color:var(--danger);line-height:1;margin:0 0 8px;
}
.denied-stat__label{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;color:var(--text);margin:0}
.denied-stat__divider{border:0;border-top:1px solid var(--border);margin:16px 0}
.denied-stat__positive{
  display:flex;gap:10px;align-items:flex-start;
  font-family:'Source Sans 3',sans-serif;font-weight:500;font-size:16px;
  color:var(--primary);line-height:1.55;
}
.denied-stat__positive svg{width:24px;height:24px;flex-shrink:0;color:#22876B;margin-top:1px}

@media (max-width:860px){
  .denied-hero__inner{grid-template-columns:1fr;gap:32px}
}

/* ---- Denial reason cards ---- */
.denial-reasons{background:#fff;padding:80px 0}
.denial-reasons__head{max-width:960px;margin:0 auto 32px;padding:0 24px;text-align:left}
.denial-reasons__head h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;margin:0 0 12px;color:var(--text)}
.denial-reasons__head p{font-family:'Source Sans 3',sans-serif;font-size:18px;color:var(--text-secondary);margin:0;line-height:1.6}
.denial-reasons__list{max-width:720px;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;gap:16px}
.denial-card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);
  border-left:4px solid var(--danger);padding:24px;
  display:grid;grid-template-columns:48px 1fr;gap:20px;
}
.denial-card__num{
  width:36px;height:36px;border-radius:50%;background:var(--danger);color:#fff;
  font-family:'Inter',sans-serif;font-weight:700;font-size:16px;
  display:flex;align-items:center;justify-content:center;
}
.denial-card__body h3{font-family:'Inter',sans-serif;font-weight:600;font-size:20px;color:var(--text);margin:0 0 10px}
.denial-card__body p{font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.75;color:var(--text-secondary);margin:0 0 12px}
.denial-card__body a{font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:14px;color:var(--primary);text-decoration:none}
.denial-card__body a:hover{color:var(--primary-dark);text-decoration:underline}

/* ---- Appeal Process horizontal timeline (denied hub) ---- */
.appeal-timeline{background:var(--primary-light);padding:80px 0}
.appeal-timeline__head{max-width:960px;margin:0 auto 48px;padding:0 24px;text-align:center}
.appeal-timeline__head h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;color:var(--text);margin:0 0 12px}
.appeal-timeline__head p{font-family:'Source Sans 3',sans-serif;font-size:18px;color:var(--text-secondary);margin:0}
.appeal-timeline__row{
  max-width:1100px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:repeat(5, 1fr);gap:16px;align-items:stretch;
  position:relative;
}
.appeal-stage{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);
  padding:24px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;
  position:relative;
}
.appeal-stage svg{width:32px;height:32px;color:var(--primary)}
.appeal-stage h4{font-family:'Inter',sans-serif;font-weight:600;font-size:16px;color:var(--text);margin:0}
.appeal-stage p{font-family:'Source Sans 3',sans-serif;font-size:14px;color:var(--text-secondary);line-height:1.55;margin:0;flex:1}
.appeal-stage__duration{
  display:inline-block;background:var(--accent-light);color:var(--accent);
  font-family:'Inter',sans-serif;font-weight:500;font-size:13px;
  padding:4px 10px;border-radius:12px;
}
.appeal-stage.past{opacity:0.65}
.appeal-stage.past svg{color:var(--danger)}
.appeal-stage.highlight{
  transform:scale(1.05);border-left:4px solid #22876B;
  box-shadow:0 0 12px rgba(34, 135, 107, 0.15), 0 1px 3px rgba(0,0,0,0.08);
}
.appeal-stage.highlight svg{color:#22876B}
.appeal-stage.highlight .appeal-stage__badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:#22876B;color:#fff;font-family:'Inter',sans-serif;font-weight:600;font-size:12px;
  padding:4px 10px;border-radius:12px;white-space:nowrap;
}
.appeal-stage.light{opacity:0.85}
.appeal-stage.light svg,.appeal-stage.light h4{color:var(--text-secondary)}

.appeal-arrow{
  display:flex;align-items:center;justify-content:center;color:var(--primary);
}
@media (max-width:900px){
  .appeal-timeline__row{grid-template-columns:1fr;gap:16px}
  .appeal-arrow{transform:rotate(90deg);height:24px}
  .appeal-stage.highlight{transform:none}
  .appeal-stage.highlight .appeal-stage__badge{position:static;display:inline-block;transform:none;margin-bottom:6px}
}

/* ---- Hearing Differences 2x2 grid ---- */
.hearing-diff{background:#fff;padding:80px 0}
.hearing-diff__inner{max-width:800px;margin:0 auto;padding:0 24px}
.hearing-diff h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;color:var(--text);margin:0 0 12px}
.hearing-diff__lead{font-family:'Source Sans 3',sans-serif;font-size:18px;color:var(--text-secondary);line-height:1.7;margin:0 0 32px}
.hearing-diff__grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.hearing-diff__card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);
  border-top:3px solid var(--primary);padding:24px;text-align:center;
}
.hearing-diff__card svg{width:40px;height:40px;color:var(--primary);margin-bottom:14px}
.hearing-diff__card h4{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;margin:0 0 10px;color:var(--text)}
.hearing-diff__card p{font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.7;color:var(--text-secondary);margin:0}
@media (max-width:680px){.hearing-diff__grid{grid-template-columns:1fr}}

/* ---- Action steps (do this right now) ---- */
.action-steps{background:var(--bg);padding:80px 0}
.action-steps__inner{max-width:800px;margin:0 auto;padding:0 24px}
.action-steps h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;color:var(--text);margin:0 0 12px}
.action-steps__lead{font-family:'Source Sans 3',sans-serif;font-size:18px;color:var(--text-secondary);margin:0 0 40px}
.action-list{display:flex;flex-direction:column;position:relative}
.action-item{display:grid;grid-template-columns:48px 1fr;gap:24px;padding-bottom:32px;position:relative}
.action-item:not(:last-child)::before{
  content:"";position:absolute;left:23px;top:48px;bottom:0;width:2px;background:var(--accent);
}
.action-item__num{
  width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-weight:700;font-size:20px;
  display:flex;align-items:center;justify-content:center;z-index:1;
}
.action-item__body h3{font-family:'Inter',sans-serif;font-weight:600;font-size:20px;color:var(--text);margin:0 0 10px;line-height:1.3}
.action-item__body p{font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.75;color:var(--text-secondary);margin:0 0 12px}
.action-item__body .deadline{color:var(--danger);font-weight:700}
.action-item__body .inline-btn{
  display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 18px;
  background:var(--accent);color:#fff;border-radius:8px;text-decoration:none;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;transition:all 200ms;
}
.action-item__body .inline-btn:hover{background:var(--accent-hover);transform:scale(1.02)}

/* ---- Resources article cards (denied hub) ---- */
.denied-resources{background:#fff;padding:80px 0}
.denied-resources__inner{max-width:960px;margin:0 auto;padding:0 24px}
.denied-resources h2{font-family:'Inter',sans-serif;font-weight:700;font-size:36px;color:var(--text);margin:0 0 12px}
.denied-resources__lead{font-family:'Source Sans 3',sans-serif;font-size:18px;color:var(--text-secondary);margin:0 0 32px}
.dr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.dr-card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);overflow:hidden;
  display:flex;flex-direction:column;transition:transform 300ms, box-shadow 300ms, border-left-color 300ms;
  border-left:0 solid var(--accent);text-decoration:none;color:inherit;
}
.dr-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.12);border-left-width:4px}
.dr-card__image{
  aspect-ratio:16/9;background:var(--primary-light);position:relative;
  display:flex;align-items:center;justify-content:center;
}
.dr-card__image svg{width:64px;height:64px;color:var(--primary);opacity:0.65}
.dr-card__badge{
  position:absolute;bottom:12px;right:12px;
  background:var(--accent);color:#fff;font-family:'Inter',sans-serif;font-weight:600;font-size:12px;
  padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:0.05em;
}
.dr-card__body{padding:24px;flex:1;display:flex;flex-direction:column}
.dr-card__body h4{font-family:'Inter',sans-serif;font-weight:600;font-size:20px;color:var(--text);margin:0 0 10px;line-height:1.35}
.dr-card__body p{font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.6;color:var(--text-secondary);margin:0 0 14px;flex:1}
.dr-card__meta{font-family:'Source Sans 3',sans-serif;font-size:14px;color:var(--text-secondary);margin:0 0 10px}
.dr-card__more{font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:14px;color:var(--primary)}
@media (max-width:860px){.dr-grid{grid-template-columns:1fr}}

/* ---- After-Denial Lead Magnet Strip ---- */
.denial-lm{background:var(--accent-light);padding:48px 0}
.denial-lm__inner{max-width:800px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:0.6fr 1fr;gap:32px;align-items:center}
.denial-lm__book{
  aspect-ratio:3/4;background:var(--primary);border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,0.15);padding:20px;color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
}
.denial-lm__book::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:18%;background:var(--accent);
}
.denial-lm__book h4{font-family:'Inter',sans-serif;font-weight:700;font-size:16px;line-height:1.25;margin:0 0 6px}
.denial-lm__book p{font-family:'Source Sans 3',sans-serif;font-size:11px;line-height:1.4;color:rgba(255,255,255,0.85);margin:0}
.denial-lm__book .brand{
  font-family:'Inter',sans-serif;font-weight:700;font-size:11px;letter-spacing:0.03em;
  position:relative;z-index:1;color:#fff;
}
.denial-lm__body h3{font-family:'Inter',sans-serif;font-weight:600;font-size:24px;color:var(--text);margin:0 0 10px}
.denial-lm__body p{font-family:'Source Sans 3',sans-serif;font-size:16px;color:var(--text-secondary);line-height:1.6;margin:0 0 14px}
.denial-lm__bullets{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:6px}
.denial-lm__bullets li{display:flex;align-items:flex-start;gap:8px;font-family:'Source Sans 3',sans-serif;font-size:15px;color:var(--text-secondary);line-height:1.5}
.denial-lm__bullets li::before{content:"✓";color:var(--accent);font-weight:700}
.denial-lm__form{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.denial-lm__form input{
  width:100%;height:44px;padding:0 14px;border:1px solid var(--border);border-radius:8px;
  font-family:'Source Sans 3',sans-serif;font-size:15px;background:#fff;
}
.denial-lm__form input:focus{outline:none;border-color:var(--primary)}
.denial-lm__form .btn{grid-column:1/-1;height:44px}
.denial-lm__small{font-family:'Source Sans 3',sans-serif;font-size:13px;color:var(--text-secondary);margin:0}
@media (max-width:680px){.denial-lm__inner{grid-template-columns:1fr;gap:24px}.denial-lm__book{max-width:180px;margin:0 auto}}

/* ---- Do / Don't columns (hearing prep) ---- */
.dodont-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
.dodont-card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);padding:24px;
}
.dodont-card.do{border-top:3px solid #22876B}
.dodont-card.dont{border-top:3px solid var(--danger)}
.dodont-card h3{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;margin:0 0 14px;color:var(--text)}
.dodont-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.dodont-card li{display:flex;align-items:flex-start;gap:10px;font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.55;color:var(--text-secondary)}
.dodont-card.do li::before{
  content:"";display:inline-block;width:20px;height:20px;flex-shrink:0;margin-top:1px;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2322876B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}
.dodont-card.dont li::before{
  content:"";display:inline-block;width:20px;height:20px;flex-shrink:0;margin-top:1px;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C53030' stroke-width='2.5' stroke-linecap='round'><path d='M6 6l12 12M18 6L6 18'/></svg>");
}
@media (max-width:680px){.dodont-grid{grid-template-columns:1fr}}

/* ---- Outcome cards (after hearing) ---- */
.outcome-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.outcome-card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);padding:24px;
}
.outcome-card.green{border-top:4px solid #22876B}
.outcome-card.amber{border-top:4px solid var(--accent)}
.outcome-card.red{border-top:4px solid var(--danger)}
.outcome-card h4{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;margin:0 0 10px;color:var(--text)}
.outcome-card p{font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.6;color:var(--text-secondary);margin:0}
@media (max-width:760px){.outcome-grid{grid-template-columns:1fr}}

/* ---- Sidebar deadline reminder card ---- */
.side-deadline{
  background:#fff;border-radius:12px;border-left:3px solid var(--danger);
  box-shadow:0 1px 3px rgba(0,0,0,0.08);padding:20px;
}
.side-deadline__head{
  display:flex;align-items:center;gap:8px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;color:var(--danger);margin-bottom:6px;
}
.side-deadline svg{width:18px;height:18px;flex-shrink:0}
.side-deadline a{font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:13px;color:var(--primary);text-decoration:none}
.side-deadline a:hover{text-decoration:underline}

/* ---- Side info-box (right-floated, used in /denied/appeal/) ---- */
.side-info{
  float:right;clear:right;
  background:var(--primary-light);border-radius:12px;padding:20px;
  max-width:280px;margin:0 0 20px 20px;
}
.side-info.green{background:rgba(34, 135, 107, 0.08);border-left:3px solid #22876B}
.side-info .row{font-family:'Source Sans 3',sans-serif;font-size:14px;color:var(--text-secondary);margin:6px 0;line-height:1.5}
.side-info .row b{font-family:'Inter',sans-serif;color:var(--text);font-weight:600;display:block;font-size:13px}
.side-info .timeline{font-family:'Inter',sans-serif;font-weight:600;font-size:18px;color:var(--primary)}
@media (max-width:760px){.side-info{float:none;max-width:none;margin:16px 0}}

/* ---- Trust signal row (final CTA) ---- */
.trust-row{
  display:flex;justify-content:center;gap:32px;flex-wrap:wrap;margin:20px 0 28px;
}
.trust-row .item{
  display:flex;align-items:center;gap:8px;
  font-family:'Source Sans 3',sans-serif;font-weight:500;font-size:14px;color:#fff;
}
.trust-row svg{width:18px;height:18px;color:#fff;opacity:0.85}

/* ---- Numbered prep timeline (hearing prep page) ---- */
.prep-timeline{display:flex;flex-direction:column;gap:28px;margin-top:20px;position:relative}
.prep-timeline::before{
  content:"";position:absolute;left:17px;top:0;bottom:0;width:2px;background:var(--accent);
}
.prep-stage{display:grid;grid-template-columns:36px 1fr;gap:20px;position:relative}
.prep-stage__dot{
  width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;
  font-family:'Inter',sans-serif;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.04em;
  display:flex;align-items:center;justify-content:center;text-align:center;line-height:1;padding:4px;z-index:1;
}
.prep-stage__body h4{font-family:'Inter',sans-serif;font-weight:600;font-size:16px;color:var(--text);margin:0 0 8px}
.prep-stage__body ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.prep-stage__body li{font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.55;color:var(--text-secondary);padding-left:16px;position:relative}
.prep-stage__body li::before{content:"•";color:var(--primary);position:absolute;left:0;font-weight:700}

/* ---- Step walkthrough cards (hearing day) ---- */
.walkthrough{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.walk-row{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);
  padding:20px 24px;display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:flex-start;
}
.walk-row__icon{
  width:48px;height:48px;border-radius:50%;background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;color:var(--primary);
}
.walk-row__icon svg{width:24px;height:24px}
.walk-row__body h4{font-family:'Inter',sans-serif;font-weight:600;font-size:16px;color:var(--text);margin:0 0 6px}
.walk-row__body p{font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.6;color:var(--text-secondary);margin:0}

/* ---- Diabetes-specific strategy cards (hearing page) ---- */
.strat-list{display:flex;flex-direction:column;gap:14px;margin-top:20px}
.strat-card{
  background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,0.08);
  border-left:3px solid var(--primary);padding:22px 24px;
}
.strat-card h4{font-family:'Inter',sans-serif;font-weight:600;font-size:17px;color:var(--text);margin:0 0 8px}
.strat-card p{font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.7;color:var(--text-secondary);margin:0}

/* ---- Green-check list (what denial doesn't mean) ---- */
.green-list{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:18px}
.green-list li{display:grid;grid-template-columns:24px 1fr;gap:14px;align-items:flex-start;font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.7;color:var(--text-secondary)}
.green-list li svg{width:24px;height:24px;color:#22876B;margin-top:2px}
.green-list li strong{display:block;font-family:'Inter',sans-serif;font-weight:600;color:var(--text);margin-bottom:4px}

/* ---- Appeal action checklist (final card) ---- */
.appeal-checklist{
  background:#fff;border-radius:12px;border-top:4px solid var(--accent);
  box-shadow:0 1px 3px rgba(0,0,0,0.08);padding:24px;margin-top:24px;
}
.appeal-checklist ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.appeal-checklist li{
  display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:center;
  font-family:'Source Sans 3',sans-serif;font-size:15px;line-height:1.55;color:var(--text);
}
.appeal-checklist li::before{
  content:"";width:22px;height:22px;border:2px solid var(--border);border-radius:6px;
}
.appeal-checklist li.bold{font-weight:600;color:var(--danger)}

