@font-face {
  font-family: "Marcellus-Regular";
  src: url("../fonts/Marcellus-Regular.woff2") format("woff2"),
    url("../fonts/Marcellus-Regular.ttf") format("truetype");
  font-display: swap;
}

@font-face {
  font-family: "Montserrat-Medium";
  src: url("../fonts/monserat/Montserrat-Medium.woff2") format("woff2"),
    url("../fonts/monserat/Montserrat-Medium.ttf") format("truetype");
  font-display: swap;
}

@font-face {
  font-family: "Montserrat-SemiBold";
  src: url("../fonts/monserat/Montserrat-SemiBold.woff2") format("woff2"),
    url("../fonts/monserat/Montserrat-SemiBold.ttf") format("truetype");
  font-display: swap;
}

:root {
  --t: #0a3d38;
  --tm: #14675d;
  --t3: #0f4c46;
  --co: #e8673a;
  --co2: #d4552b;
  --go: #f4a55a;
  --e1: #e8f4f1;
  --cr: #faf8f4;
  --wh: #ffffff;
  --bd: #dcebe7;
  --bd2: #c8dbd6;
  --tx: #18332f;
  --tx2: #2d5048;
  --mu: #607772;
  --ok: #1b8a4c;
  --okl: #edf9f0;
  --wa: #25d366;
  --red: #7c1d1d;
  --cl: #fef0eb;
  --och: #b8864b;
  --ochl: #f2e5cc;
  --r: 10px;
  --rl: 18px;
  --rp: 999px;
  --c-line: #e5d5da;
    --shadow-1: 0 1px 2px rgba(42, 14, 34, 0.05), 0 4px 14px rgba(42, 14, 34, 0.06);
  --sh: 0 4px 16px rgba(10, 61, 56, 0.09);
  --shs: 0 1px 4px rgba(10, 61, 56, 0.07);
  --shl: 0 12px 35px rgba(10, 61, 56, 0.1);
  --tr: 0.18s ease;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
.rehab-page * {
  box-sizing: border-box;
}
.rehab-page {
  font-family: var(--ff);
  color: var(--tx);
  line-height: 1.65;
}
.rehab-page img {
  max-width: 100%;
  height: auto;
  display: block;
}
.rehab-page a {
  color: var(--t);
  text-decoration: none;
  transition: color var(--tr);
}
.rehab-page a:hover {
  color: var(--co);
}
.rehab-page :focus-visible {
  outline: 2.5px solid var(--co);
  outline-offset: 3px;
  border-radius: 4px;
}
.rehab-page .wrap {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 22px;
}
.rehab-page .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

/* Live ticker + floats */
.rehab-page .live-ticker {
  background: linear-gradient(135deg, var(--cl), #fde0d0);
  border-bottom: 1px solid var(--bd);
  padding: 8px 0;
  font-size: 0.78rem;
  color: var(--tx2);
  text-align: center;
}
.rehab-page .live-ticker strong {
  color: var(--co);
  font-weight: 700;
}
.rehab-page .ticker-av {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--co);
  color: #fff;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.7rem;
  margin-right: 5px;
  vertical-align: middle;
}
.rehab-page .float-side {
  position: fixed;
  right: 18px;
  bottom: 96px;
  z-index: 500;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rehab-page .float-side a {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--sh);
}
.rehab-page .float-side a img {
  width: 28px;
  height: 28px;
}
.rehab-page .float-wa {
  background: var(--wa);
}
.rehab-page .float-call {
  background: var(--t);
}

/* Breadcrumb */
.rehab-page .breadcrumb {
  padding: 9px 0;
  font-size: 14px;
  margin-bottom: 8px;
}
.rehab-page .breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 5px;
  list-style: none;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.rehab-page .breadcrumb li {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--mu);
}
.rehab-page .breadcrumb li a {
  color: #ffffff;
  font-weight: 600;
}
.rehab-page .breadcrumb li:not(:last-child)::after {
  content: "›";
  color: var(--bd2);
}
.rehab-page .breadcrumb li:last-child {
  color: #ffffff;
  font-weight: 700;
}

/* Live counter */
.rehab-page .live-counter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #edf9f0;
    color: var(--ok);
    padding: 8px 16px;
    font-size: 0.8rem;
    font-weight: 600;
    border-bottom: 1px solid rgba(27, 138, 76, 0.18);
    border-radius: 100px;
    border: 1px solid #078f63;
    margin-bottom: 15px;
}
.rehab-page .live-counter::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--ok);
  border-radius: 50%;
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(27, 138, 76, 0.5);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(27, 138, 76, 0);
  }
}

/* Hero */
.rehab-page .hero {
  background: linear-gradient(155deg, #0a3d38 0%, #0d4f47 60%, #124a43 100%);
  padding: 48px 0 42px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.rehab-page .hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 70% 80% at 82% 50%,
    rgba(244, 165, 90, 0.08) 0%,
    transparent 70%
  );
  pointer-events: none;
}
.rehab-page .hero-in {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 36px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.rehab-page .hero h1 {
  color: #fff;
}
.rehab-page .hero h1 em {
  font-style: italic;
  color: var(--go);
  font-weight: 700;
}
.rehab-page .hero-sub {
  font-size: 0.96rem;
  color: rgb(255 255 255);
  line-height: 1.65;
  margin-bottom: 18px;
  max-width: 560px;
  font-family: Montserrat-Medium;
}
.rehab-page .hero-sub strong {
  color: #fff;
}
.rehab-page .hero ul {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px 14px;
}
.rehab-page .hero ul li {
  font-size: 0.86rem;
  color: rgba(255, 255, 255, 0.86);
  padding-left: 22px;
  position: relative;
}
.rehab-page .hero ul li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--go);
  font-weight: 700;
}
.rehab-page .hero-cta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.rehab-page .btn-pri {
  background: var(--co);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  padding: 12px 22px;
  font-size: 0.92rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
  transition: all var(--tr);
  box-shadow: 0 4px 14px rgba(232, 103, 58, 0.35);
  cursor: pointer;
}
.rehab-page .btn-pri:hover {
  background: var(--co2);
  transform: translateY(-1px);
  color: #fff;
}
.rehab-page .btn-wa {
  background: var(--wa);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  padding: 12px 20px;
  font-size: 0.92rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
  transition: all var(--tr);
}
.rehab-page .btn-wa:hover {
  background: #1eb558;
  color: #fff;
}
.rehab-page .hero-stat-line {
  font-size: 0.84rem;
  color: rgba(255, 255, 255, 0.7);
  margin-top: 14px;
}
.rehab-page .hero-stat-line strong {
  color: var(--go);
  font-weight: 700;
}

/* Booking widget — 4-step */
.rehab-page .bk-widget {
  background: rgba(255, 255, 255, 0.97);
  border-radius: var(--rl);
  padding: 20px;
  color: var(--tx);
  box-shadow: var(--shl);
}
.rehab-page .bk-discount {
  background: linear-gradient(90deg, var(--co), var(--go));
  color: #fff;
  padding: 8px 14px;
  border-radius: var(--r);
  font-size: 0.78rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 14px;
}
.rehab-page .bk-h {
  
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--t);
  margin-bottom: 4px;
}
.rehab-page .bk-sub {
  font-size: 0.78rem;
  color: var(--mu);
  margin-bottom: 14px;
}
.rehab-page .bk-steps {
  display: flex;
  gap: 5px;
  margin-bottom: 16px;
}
.rehab-page .bk-step {
  flex: 1;
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 7px;
  text-align: center;
  font-size: 0.7rem;
  color: var(--mu);
}
.rehab-page .bk-step strong {
  display: block;
  font-size: 0.95rem;
  color: var(--t);
  
  font-weight: 700;
  margin-bottom: 2px;
}
.rehab-page .bk-step.on {
  background: var(--t);
  color: #fff;
  border-color: var(--t);
}
.rehab-page .bk-step.on strong {
  color: var(--go);
}
.rehab-page .bk-step.done {
  background: var(--okl);
  border-color: var(--ok);
  color: var(--ok);
}
.rehab-page .bk-step.done strong {
  color: var(--ok);
}

.rehab-page .bk-pane {
  display: none;
}
.rehab-page .bk-pane.on {
  display: block;
}

.rehab-page .bk-plan {
  border: 2px solid var(--co);
  border-radius: var(--rl);
  padding: 13px;
  margin-bottom: 10px;
  position: relative;
  background: var(--cr);
}
.rehab-page .bk-plan-tag {
  position: absolute;
  top: -9px;
  left: 14px;
  background: var(--co);
  color: #fff;
  border-radius: var(--rp);
  padding: 2px 10px;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.rehab-page .bk-plan-name {
  font-weight: 700;
  color: var(--tx);
  font-size: 0.92rem;
  margin-bottom: 3px;
}
.rehab-page .bk-plan-price {
  
  font-size: 1.35rem;
  color: var(--co);
  font-weight: 700;
}
.rehab-page .bk-plan-price s {
  color: var(--mu);
  font-size: 0.78rem;
  font-weight: 400;
  margin-right: 5px;
}
.rehab-page .bk-plan-price .off {
  background: var(--okl);
  color: var(--ok);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 1px 8px;
  border-radius: 99px;
  margin-left: 5px;
}
.rehab-page .bk-plan-mode {
  font-size: 0.72rem;
  color: var(--mu);
  margin-top: 3px;
}

.rehab-page .bk-slots-h {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--tx);
  margin: 14px 0 8px;
  display: flex;
  justify-content: space-between;
}
.rehab-page .bk-slots-h a {
  font-size: 0.74rem;
  color: var(--t);
  font-weight: 600;
}
.rehab-page .bk-slots {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 10px;
}
.rehab-page .bk-slot {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 9px 5px;
  text-align: center;
  font-size: 0.78rem;
  color: var(--tx);
  cursor: pointer;
  font-family: inherit;
}
.rehab-page .bk-slot:hover {
  border-color: var(--t);
}
.rehab-page .bk-slot.on {
  background: var(--t);
  color: #fff;
  border-color: var(--t);
}
.rehab-page .bk-slot.unav {
  opacity: 0.45;
  cursor: not-allowed;
  background: #f3eee0;
}

.rehab-page .bk-help {
  font-size: 0.74rem;
  color: var(--mu);
  text-align: center;
  margin: 8px 0;
}
.rehab-page .bk-help a {
  color: var(--t);
  font-weight: 600;
  text-decoration: underline;
}

.rehab-page .bk-cta {
  background: var(--t);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  width: 100%;
  padding: 11px;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  margin-top: 8px;
}
.rehab-page .bk-cta:hover {
  background: var(--co);
  color: #fff;
}
.rehab-page .bk-foot {
  font-size: 0.7rem;
  color: var(--mu);
  text-align: center;
  margin-top: 9px;
}

.rehab-page .bk-back {
  background: none;
  border: none;
  font-size: 0.78rem;
  color: var(--t);
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  padding: 0;
  margin-bottom: 10px;
}
.rehab-page .bk-back:hover {
  color: var(--co);
}

.rehab-page .bk-field {
  margin-bottom: 10px;
}
.rehab-page .bk-field label {
  display: block;
  font-size: 0.74rem;
  color: var(--mu);
  font-weight: 600;
  margin-bottom: 4px;
}
.rehab-page .bk-field input,
.rehab-page .bk-field select {
  width: 100%;
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 9px 11px;
  font-size: 0.86rem;
  font-family: inherit;
  outline: none;
  background: #fff;
}
.rehab-page .bk-field input:focus,
.rehab-page .bk-field select:focus {
  border-color: var(--t);
}
.rehab-page .bk-err {
  font-size: 0.72rem;
  color: var(--red);
  margin-top: 3px;
  display: none;
}
.rehab-page .bk-err.show {
  display: block;
}

.rehab-page .bk-summary {
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 14px;
  margin-bottom: 12px;
}
.rehab-page .bk-summary table {
  width: 100%;
  font-size: 0.83rem;
  border-collapse: collapse;
}
.rehab-page .bk-summary td {
  padding: 5px 0;
  color: var(--tx2);
}
.rehab-page .bk-summary td:first-child {
  color: var(--mu);
}
.rehab-page .bk-summary td:last-child {
  font-weight: 700;
  color: var(--tx);
  text-align: right;
}
.rehab-page .bk-summary tr.save td {
  color: var(--ok);
}

.rehab-page .bk-confetti {
  text-align: center;
  margin: 14px 0;
}
.rehab-page .bk-confetti img {
  max-width: 120px;
  margin: 0 auto;
}
.rehab-page .bk-discount-applied {
  background: linear-gradient(135deg, #fef0eb, #fde0d0);
  border: 1px dashed var(--co);
  border-radius: var(--rl);
  padding: 14px;
  text-align: center;
  margin-bottom: 12px;
}
.rehab-page .bk-discount-applied .pct {
  
  font-size: 1.6rem;
  color: var(--co);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
}
.rehab-page .bk-discount-applied p {
  font-size: 0.82rem;
  color: var(--tx2);
  margin: 0;
}
.rehab-page .bk-discount-applied .code {
  display: inline-block;
  background: #fff;
  border: 1.5px dashed var(--co);
  color: var(--co);
  padding: 3px 12px;
  font-family: monospace;
  font-weight: 700;
  border-radius: 6px;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  margin-top: 6px;
}

/* Section wrappers */
.rehab-page .sec {
  padding: 60px 0;
}
.rehab-page .sec-cream {
  background: var(--cr);
}
.rehab-page .sec-white {
  background: var(--wh);
}
.rehab-page .sec-tl {
  background: var(--e1);
}
.rehab-page .sec-eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--co);
  margin-bottom: 7px;
}
.rehab-page .sec h2 {
  font-weight: 700;
  margin: 0 0 12px;
  line-height: 1.2;
  font-size: 36px;
}
.rehab-page .sec h2 em {
  font-style: italic;
  color: var(--co);
  font-weight: 700;
}
.rehab-page .sec-lede {
  font-size: 0.96rem;
  color: var(--mu);
  max-width: 780px;
  line-height: 1.65;
  margin-bottom: 24px;
}

/* TOC */
.rehab-page .toc {
  background: var(--wh);
  border-bottom: 1px solid var(--bd);
  padding: 11px 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.rehab-page .toc::-webkit-scrollbar {
  display: none;
}
.rehab-page .toc-in {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 12px;
  padding: 18px 18px;
  margin: 20px auto 20px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.rehab-page .toc-lbl {
 font-family: var(--fh);
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--c-ink);
    padding-right: 12px;
    border-right: 1px solid var(--c-line);
    margin-right: 6px;
}
.rehab-page .toc a {
  display: inline-flex;
  padding: 6px 10px;
  font-size: 12px;
  border-radius: var(--rp);
  color: var(--tx2);
  background: var(--cr);
  border: 1px solid var(--bd);
  font-weight: 500;
  font-family: Montserrat-SemiBold;
}
.rehab-page .toc a:hover {
  background: var(--t1);
  color: #fff;
  border-color: var(--t1);
}

/* Concern tabs */
.rehab-page .concern-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}
.rehab-page .concern-tab {
  padding: 9px 16px;
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rp);
  font-size: 0.83rem;
  color: var(--tx2);
  cursor: pointer;
  font-family: inherit;
  font-weight: 500;
  transition: all var(--tr);
}
.rehab-page .concern-tab:hover,
.rehab-page .concern-tab.on {
  background: var(--t1);
  color: #fff;
  border-color: var(--t1);
}

/* Doctor cards */
.rehab-page .doc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}
.rehab-page .doc-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 16px;
  transition: all var(--tr);
  position: relative;
}
.rehab-page .doc-card:hover {
  box-shadow: var(--sh);
  transform: translateY(-2px);
  border-color: var(--bd2);
}
.rehab-page .doc-photo-wrap {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
  position: relative;
}
.rehab-page .doc-photo {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ochl), #e4d2a8);
  color: var(--t);
  display: flex;
  align-items: center;
  justify-content: center;
  
  font-size: 1.2rem;
  font-weight: 700;
  font-style: italic;
  flex-shrink: 0;
  border: 2px solid var(--bd2);
}
.rehab-page .doc-photo img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}
.rehab-page .doc-verified {
  position: absolute;
  top: -2px;
  left: 50px;
  width: 18px;
  height: 18px;
  background: var(--ok);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 800;
  border: 2px solid #fff;
}
.rehab-page .doc-info h3 {
  font-size: 0.96rem;
  font-weight: 700;
  color: var(--tx);
  margin: 0 0 2px;
  line-height: 1.25;
}
.rehab-page .doc-deg {
  font-size: 0.74rem;
  color: var(--mu);
}
.rehab-page .doc-spec {
  font-size: 0.78rem;
  color: var(--co);
  font-weight: 600;
  margin-bottom: 3px;
}
.rehab-page .doc-yrs {
  font-size: 0.74rem;
  color: var(--tx2);
  margin-bottom: 6px;
}
.rehab-page .doc-yrs span {
  margin-right: 8px;
}
.rehab-page .doc-nmc {
  font-size: 0.7rem;
  color: var(--ok);
  font-weight: 600;
  margin-bottom: 8px;
}
.rehab-page .doc-nmc a {
  color: var(--ok);
  text-decoration: underline;
}
.rehab-page .doc-status {
  font-size: 0.72rem;
  color: var(--mu);
  margin-bottom: 8px;
  font-style: italic;
}
.rehab-page .doc-exp {
  font-size: 0.78rem;
  color: var(--tx2);
  margin-bottom: 6px;
  line-height: 1.5;
}
.rehab-page .doc-exp b {
  color: var(--t);
  font-weight: 700;
}
.rehab-page .doc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 8px;
}
.rehab-page .doc-tag {
  font-size: 0.66rem;
  padding: 2px 8px;
  background: var(--e1);
  color: var(--t);
  border-radius: var(--rp);
  font-weight: 600;
  border: 1px solid var(--bd);
}
.rehab-page .doc-meta {
  font-size: 0.74rem;
  color: var(--tx2);
  margin-bottom: 5px;
}
.rehab-page .doc-meta b {
  color: var(--t);
  font-weight: 700;
}
.rehab-page .doc-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 7px;
  margin-top: 11px;
}
.rehab-page .btn-view {
  background: var(--wh);
  color: var(--t);
  border: 1.5px solid var(--bd2);
  border-radius: var(--rp);
  padding: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
}
.rehab-page .btn-view:hover {
  background: var(--e1);
  border-color: var(--t);
}
.rehab-page .btn-bk {
  background: var(--co);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  padding: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  font-family: inherit;
  cursor: pointer;
}
.rehab-page .btn-bk:hover {
  background: var(--co2);
  color: #fff;
}

.rehab-page .cant-find {
  background: var(--e1);
  border: 1px solid var(--bd2);
  border-radius: var(--rl);
  padding: 20px 24px;
  margin-top: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.rehab-page .cant-find h4 {
  
  font-size: 1.05rem;
  color: var(--t);
  margin: 0 0 4px;
  font-weight: 700;
}
.rehab-page .cant-find p {
  font-size: 0.85rem;
  color: var(--mu);
  margin: 0;
}
.rehab-page .cant-find a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--t);
  color: #fff;
  border-radius: var(--rp);
  padding: 9px 18px;
  font-size: 0.83rem;
  font-weight: 700;
  text-decoration: none;
}

.rehab-page .doc-foot {
  text-align: center;
  margin-top: 14px;
}
.rehab-page .doc-foot a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 22px;
  background: var(--wh);
  border: 1.5px solid var(--t);
  border-radius: var(--rp);
  color: var(--t);
  font-weight: 700;
  font-size: 0.86rem;
}
.rehab-page .doc-foot a:hover {
  background: var(--t);
  color: #fff;
}

/* TLDR / Quick Answer */
.rehab-page .tldr {
  background: linear-gradient(135deg, var(--cr), #f5efe0);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px 26px;
}
.rehab-page .tldr h3 {
  
font-size: 1.05rem;
  
color: var(--t1);
  
margin: 0 0 12px;
  
font-weight: 700;
}
.rehab-page .tldr ul {
  padding-left: 0;
    margin: 0;
    list-style: none;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
.rehab-page .tldr ul li {
  font-size: 15px;
  color: var(--muted);
  padding-left: 22px;
  position: relative;
  line-height: 1.5;
}
.rehab-page .tldr ul li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--ok);
  font-weight: 800;
}
.rehab-page .qa-box {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px 26px;
  border-left: 4px solid var(--co);
}
.rehab-page .qa-lbl {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--co);
  margin-bottom: 7px;
}
.rehab-page .qa-box h3 {
  
font-size: 1.15rem;
  
color: var(--t1);
  
margin: 0 0 9px;
  
font-weight: 700;
}
.rehab-page .qa-box p {
  font-size: 0.94rem;
  line-height: 1.7;
  margin: 0 0 10px;
}
.rehab-page .qa-box p strong {
  color: var(--tx);
}
.rehab-page .qa-box .qa-link {
  display: inline-block;
  background: var(--co);
  color: #fff;
  border-radius: var(--rp);
  padding: 7px 16px;
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
  margin-top: 6px;
}

/* Pricing */
.rehab-page .price-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .price-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px 16px;
  position: relative;
  transition: all var(--tr);
}
.rehab-page .price-card:hover {
  box-shadow: var(--sh);
  transform: translateY(-2px);
}
.rehab-page .price-card.popular {
  border: 2px solid var(--co);
  background: #fff3ee;
}
.rehab-page .price-tag {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--co);
  color: #fff;
  padding: 3px 12px;
  border-radius: var(--rp);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.rehab-page .price-name {
 font-family: var(--fh);
 font-size: 1rem;
 color: var(--t1);
 font-weight: 700;
 margin-bottom: 12px;
 line-height: 21px;
}
.rehab-page .price-amt {
  
  font-size: 1.95rem;
  color: var(--co);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 3px;
}
.rehab-page .price-amt s {
  font-size: 0.82rem;
  color: var(--mu);
  font-weight: 400;
  margin-right: 6px;
}
.rehab-page .price-save {
  font-size: 0.7rem;
  background: var(--okl);
  color: var(--ok);
  padding: 2px 9px;
  border-radius: var(--rp);
  font-weight: 700;
  display: inline-block;
  margin-bottom: 8px;
}
.rehab-page .price-dur {
  font-size: 0.74rem;
  color: var(--mu);
  margin-bottom: 5px;
  font-style: italic;
  font-weight: 600;
}
.rehab-page .price-mode {
  font-size: 0.72rem;
  color: var(--mu);
  margin-bottom: 11px;
  font-family: Montserrat-Medium;
}
.rehab-page .price-feat {
  font-size: 0.78rem;
  color: var(--tx2);
  text-align: left;
  margin: 0 0 12px;
  padding: 0;
  list-style: none;
}
.rehab-page .price-feat li {
  padding: 3px 0 3px 19px;
  position: relative;
  line-height: 1.5;
}
.rehab-page .price-feat li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--ok);
  font-weight: 700;
  font-size: 0.85rem;
}
.rehab-page .price-btn {
  background: var(--t);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  padding: 10px;
  font-size: 0.8rem;
  font-weight: 700;
  width: 100%;
  text-decoration: none;
  display: block;
  text-align: center;
  cursor: pointer;
  font-family: Montserrat-SemiBold;
}
.rehab-page .price-btn:hover {
  background: var(--co);
  color: #fff;
}
.rehab-page .price-card.popular .price-btn {
  background: var(--co);
}

/* Conditions grid */
.rehab-page .cond-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .cond-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 18px;
  transition: all var(--tr);
}
.rehab-page .cond-card:hover {
  box-shadow: var(--sh);
  transform: translateY(-2px);
  border-color: var(--bd2);
}
.rehab-page .cond-ic {
  width: 44px;
    height: 44px;
    background: var(--c-sage-soft);
    color: var(--c-primary);
    border-radius: 12px;
    display: grid;
    place-items: center;
    font-size: 1.2rem;
}
.rehab-page .cond-card h4 {
  
font-size: 0.98rem;
  
color: var(--t);
  
margin: 0 0 4px;
  
font-weight: 700;
  
letter-spacing: -0.005em;
}
.rehab-page .cond-card p {
  font-size: 0.78rem;
  color: var(--mu);
  line-height: 1.55;
  margin: 0;
}

/* Symptom table */
.rehab-page .symp-wrap {
  overflow-x: auto;
  border-radius: var(--rl);
  border: 1px solid var(--bd);
  background: var(--wh);
  margin-bottom: 16px;
}
.rehab-page table.symp {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
}
.rehab-page table.symp th {
  background: var(--e1);
  color: var(--t);
  padding: 11px 14px;
  font-weight: 700;
  text-align: left;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--bd);
      font-family: var(--fh);
      width: 21%;
}
.rehab-page table.symp td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--bd);
  color: var(--tx2);
  line-height: 1.55;
      font-family: Montserrat-Medium;
}
.rehab-page table.symp tr:nth-child(even) td {
  background: rgba(232, 244, 241, 0.18);
}
.rehab-page table.symp tr:last-child td {
  border-bottom: none;
}
.rehab-page table.symp td:first-child {
  font-weight: 600;
  color: var(--tx);
}

/* GP-vs-Specialist 2col */
.rehab-page .twocol {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.rehab-page .twocol-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px;
}
.rehab-page .twocol-card h3 {
  
  font-size: 1.1rem;
  color: var(--t);
  margin: 0 0 12px;
  font-weight: 700;
}
.rehab-page .twocol-card ul {
  padding-left: 0;
  margin: 0;
  list-style: none;
}
.rehab-page .twocol-card li {
  font-size: 0.88rem;
  color: var(--tx2);
  padding: 5px 0 5px 22px;
  position: relative;
  line-height: 1.55;
}
.rehab-page .twocol-card li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 5px;
  color: var(--ok);
  font-weight: 800;
}

/* Severity triage */
.rehab-page .triage-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.rehab-page .triage-card {
  border: 2px solid var(--bd);
  border-radius: var(--rl);
  padding: 20px;
  background: var(--wh);
}
.rehab-page .triage-card.routine {
  border-color: rgba(27, 138, 76, 0.35);
  background: linear-gradient(135deg, #f3fbf5, #e7f3eb);
}
.rehab-page .triage-card.urgent {
  border-color: rgba(244, 165, 90, 0.4);
  background: linear-gradient(135deg, #fff8f0, #fbedd9);
}
.rehab-page .triage-card.emergency {
  border-color: rgba(124, 29, 29, 0.35);
  background: linear-gradient(135deg, #fff0ee, #fcd9d3);
}
.rehab-page .triage-lbl {
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 5px;
}
.rehab-page .triage-card.routine .triage-lbl {
  color: var(--ok);
}
.rehab-page .triage-card.urgent .triage-lbl {
  color: #8a5e1a;
}
.rehab-page .triage-card.emergency .triage-lbl {
  color: var(--red);
}
.rehab-page .triage-card h3 {
  
  font-size: 1.05rem;
  color: var(--tx);
  margin: 0 0 8px;
  font-weight: 700;
}
.rehab-page .triage-card p {
  font-size: 0.85rem;
  color: var(--tx2);
  margin: 0 0 12px;
  line-height: 1.6;
}
.rehab-page .triage-card ul {
  padding-left: 0;
  margin: 0 0 12px;
  list-style: none;
}
.rehab-page .triage-card li {
  font-size: 0.8rem;
  color: var(--tx2);
  padding: 3px 0 3px 18px;
  position: relative;
  line-height: 1.5;
}
.rehab-page .triage-card.routine li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--ok);
  font-weight: 800;
}
.rehab-page .triage-card.urgent li::before {
  content: "⚠";
  position: absolute;
  left: 0;
  color: #8a5e1a;
  font-weight: 800;
}
.rehab-page .triage-card.emergency li::before {
  content: "✕";
  position: absolute;
  left: 0;
  color: var(--red);
  font-weight: 800;
}
.rehab-page .triage-card a {
  display: inline-block;
  background: var(--t);
  color: #fff;
  border-radius: var(--rp);
  padding: 7px 16px;
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
  margin-top: 6px;
}

/* Compare table */
.rehab-page .cmp-wrap {
  overflow-x: auto;
  border-radius: var(--rl);
  border: 1px solid var(--bd);
  background: var(--wh);
}
.rehab-page table.cmp {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}
.rehab-page table.cmp caption {
  background: var(--e1);
  padding: 11px 14px;
  font-weight: 700;
  color: var(--t);
  text-align: left;
  font-size: 0.96rem;
  border-bottom: 1px solid var(--bd);
  text-align: center;
}
.rehab-page table.cmp th {
  background: var(--cr);
  color: var(--t);
  padding: 11px 14px;
  font-weight: 700;
  text-align: left;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-family: Montserrat-Medium;
}
.rehab-page table.cmp td {
  padding: 15px 14px;
  border-bottom: 1px solid var(--bd);
  color: var(--tx2);
  line-height: 1.5;
  font-family: Montserrat-Medium;
}
.rehab-page table.cmp td:first-child {
  font-weight: 600;
  color: var(--tx);
}
.rehab-page table.cmp tr:nth-child(2n) td {
   background: rgb(255 252 245);
}
.rehab-page table.cmp tr:last-child td {
  border-bottom: none;
}
.rehab-page table.cmp .yes {
  color: var(--ok);
  font-weight: 500;
}
.rehab-page table.cmp .no {
  color: var(--red);
  font-weight: 500;
}
.rehab-page table.cmp .partial {
  color: #8a5e1a;
  font-weight: 500;
}

/* Pillars + Whole-person */
.rehab-page .pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .pillar-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 20px 15px;
}
.rehab-page .pillar-card .pic {
  font-size: 1.9rem;
  margin-bottom: 8px;
  display: block;
}
.rehab-page .pillar-card .plbl {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--co);
  margin-bottom: 5px;
}
.rehab-page .pillar-card h3 {
  
font-size: 15px;
  
color: var(--t);
  
margin: 0 0 8px;
  
font-weight: 700;
  
line-height: 20px;
}
.rehab-page .pillar-card ul {
  padding-left: 0;
  margin: 0 0 10px;
  list-style: none;
}
.rehab-page .pillar-card li {
  font-size: 0.8rem;
  color: var(--tx2);
  padding: 3px 0 3px 14px;
  position: relative;
  line-height: 1.5;
}
.rehab-page .pillar-card li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--co);
  font-weight: 800;
  font-size: 1.1rem;
  line-height: 1;
}
.rehab-page .pillar-card a {
  font-size: 0.78rem;
  color: var(--co);
  font-weight: 700;
  text-decoration: none;
}

.rehab-page .wp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}
.rehab-page .wp-card {
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 18px;
  text-align: center;
}
.rehab-page .wp-card .ic {
  font-size: 2rem;
  margin-bottom: 7px;
  display: block;
}
.rehab-page .wp-card h4 {
  
  font-size: 0.95rem;
  color: var(--t);
  margin: 0 0 5px;
  font-weight: 700;
}
.rehab-page .wp-card p {
  font-size: 0.78rem;
  color: var(--mu);
  line-height: 1.55;
  margin: 0;
}

/* Awards */
.rehab-page .awards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.rehab-page .award-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 18px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.rehab-page .award-card .ai {
  font-size: 1.7rem;
  flex-shrink: 0;
}
.rehab-page .award-tag {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--co);
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.rehab-page .award-card h4 {
  
  font-size: 0.92rem;
  color: var(--tx);
  margin: 0 0 4px;
  font-weight: 700;
  line-height: 1.3;
}
.rehab-page .award-card p {
  font-size: 0.74rem;
  color: var(--mu);
  margin: 0;
  line-height: 1.5;
}

/* Insurance */
.rehab-page .ins-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.rehab-page .ins-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 14px;
  text-align: center;
}
.rehab-page .ins-card .ic {
  font-size: 1.5rem;
  display: block;
  margin-bottom: 5px;
}
.rehab-page .ins-card h4 {
  font-size: 0.85rem;
  color: var(--tx);
  margin: 0 0 2px;
  font-weight: 700;
}
.rehab-page .ins-card p {
  font-size: 0.7rem;
  color: var(--mu);
  margin: 0;
}

/* Languages */
.rehab-page .lang-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.rehab-page .lang-pill {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rp);
  padding: 8px 16px;
  font-size: 0.83rem;
  color: var(--tx2);
  text-decoration: none;
  font-weight: 500;
}
.rehab-page .lang-pill:hover {
  background: var(--t);
  color: #fff;
  border-color: var(--t);
}
.rehab-page .lang-pill strong {
  color: var(--t);
  font-weight: 700;
}
.rehab-page .lang-pill:hover strong {
  color: var(--go);
}

/* Outcomes */
.rehab-page .outcomes {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .out-card {
  background: linear-gradient(135deg, var(--e1), var(--bd));
  border: 1px solid var(--bd2);
  border-radius: var(--rl);
  padding: 22px;
  text-align: center;
}
.rehab-page .out-card .out-num {
  
font-size: 25px;
  
color: var(--t1);
  
font-weight: 700;
  
line-height: 1;
  
margin-bottom: 6px;
  
letter-spacing: -0.015em;
}
.rehab-page .out-card p {
  font-size: 0.82rem;
  color: var(--tx2);
  margin: 0;
  line-height: 1.5;
}

/* Journey */
.rehab-page .journey {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  margin-top: 48px;
}
.rehab-page .jrn-step {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 28px 14px 18px;
  text-align: center;
  position: relative;
}
.rehab-page .jrn-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: var(--co);
  color: #fff;
  border-radius: 50%;
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 8px;
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  margin: auto;
}
.rehab-page .jrn-step .ic {
  font-size: 40px;
  display: block;
  margin-bottom: 5px;
}
.rehab-page .jrn-step h4 {
  
  font-size: 0.88rem;
  color: var(--t);
  margin: 0 0 5px;
  font-weight: 700;
  line-height: 1.3;
}
.rehab-page .jrn-step p {
  font-size: 0.74rem;
  color: var(--mu);
  margin: 0;
  line-height: 1.5;
}

/* Concern chips */
.rehab-page .chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.rehab-page .chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rp);
  font-size: 0.82rem;
  color: var(--tx2);
  text-decoration: none;
  font-weight: 500;
}
.rehab-page .chip:hover {
  background: var(--co);
  color: #fff;
  border-color: var(--co);
}

/* Calculators */
.rehab-page .calc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.rehab-page .calc-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 20px;
}
.rehab-page .calc-card h4 {
  
  font-size: 1rem;
  color: var(--t);
  margin: 0 0 5px;
  font-weight: 700;
}
.rehab-page .calc-card .cdesc {
  font-size: 0.78rem;
  color: var(--mu);
  margin-bottom: 12px;
  line-height: 1.5;
}
.rehab-page .calc-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
.rehab-page .calc-row label {
  display: block;
  font-size: 0.74rem;
  color: var(--mu);
  margin-bottom: 4px;
  font-weight: 600;
}
.rehab-page .calc-row input {
  width: 100%;
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 0.86rem;
  font-family: inherit;
  outline: none;
}
.rehab-page .calc-row input:focus {
  border-color: var(--t);
}
.rehab-page .calc-result {
  
  font-size: 1.45rem;
  color: var(--co);
  font-weight: 700;
  margin-bottom: 4px;
  line-height: 1;
}
.rehab-page .calc-label {
  font-size: 0.78rem;
  color: var(--tx2);
  margin-bottom: 11px;
}
.rehab-page .calc-card a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.78rem;
  color: var(--t);
  font-weight: 700;
  text-decoration: none;
}

/* Protocols */
.rehab-page .proto-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.rehab-page .proto-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px;
  border-top: 4px solid var(--co);
}
.rehab-page .proto-id {
  font-family: monospace;
  font-size: 0.7rem;
  background: var(--co);
  color: #fff;
  padding: 3px 9px;
  border-radius: 4px;
  display: inline-block;
  margin-bottom: 8px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.rehab-page .proto-card h3 {
  
  font-size: 1.06rem;
  color: var(--t);
  margin: 0 0 11px;
  font-weight: 700;
}
.rehab-page .proto-card ol {
  padding-left: 0;
  margin: 0;
  list-style: none;
  counter-reset: p;
}
.rehab-page .proto-card li {
  counter-increment: p;
  font-size: 0.83rem;
  color: var(--tx2);
  padding: 6px 0 6px 28px;
  position: relative;
  line-height: 1.55;
}
.rehab-page .proto-card li::before {
  content: counter(p);
  position: absolute;
  left: 0;
  top: 6px;
  width: 20px;
  height: 20px;
  background: var(--e1);
  color: var(--t);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 700;
}

/* Personas */
.rehab-page .pers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .pers-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 20px;
}
.rehab-page .pers-card .ic {
  font-size: 1.9rem;
  display: block;
  margin-bottom: 8px;
}
.rehab-page .pers-card h4 {
  
  font-size: 0.98rem;
  color: var(--t);
  margin: 0 0 8px;
  font-weight: 700;
}
.rehab-page .pers-card ul {
  padding-left: 0;
  margin: 0;
  list-style: none;
}
.rehab-page .pers-card li {
  font-size: 0.78rem;
  color: var(--tx2);
  padding: 3px 0 3px 18px;
  position: relative;
  line-height: 1.5;
}
.rehab-page .pers-card li::before {
  content: "·";
  position: absolute;
  left: 6px;
  top: -2px;
  color: var(--co);
  font-weight: 800;
  font-size: 1.4rem;
  line-height: 1;
}

/* Testimonials */
.rehab-page .testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.rehab-page .testi-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 22px;
  border-left: 3px solid var(--co);
}
.rehab-page .testi-stars {
  color: var(--go);
  font-size: 0.86rem;
  letter-spacing: 1.5px;
  margin-bottom: 9px;
}
.rehab-page .testi-quote {
  
  font-style: italic;
  font-size: 0.94rem;
  color: var(--tx2);
  line-height: 1.62;
  margin-bottom: 12px;
}
.rehab-page .testi-author {
  display: flex;
  align-items: center;
  gap: 9px;
  padding-top: 11px;
  border-top: 1px solid var(--bd);
}
.rehab-page .testi-av {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--e1), var(--bd));
  color: var(--t);
  display: flex;
  align-items: center;
  justify-content: center;
  
  font-weight: 700;
  font-size: 0.78rem;
  flex-shrink: 0;
}
.rehab-page .testi-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--tx);
}
.rehab-page .testi-loc {
  font-size: 0.7rem;
  color: var(--mu);
}

/* Compliance */
.rehab-page .comp-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.rehab-page .comp-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 14px 10px;
  text-align: center;
}
.rehab-page .comp-card .ic {
  font-size: 1.4rem;
  display: block;
  margin-bottom: 4px;
}
.rehab-page .comp-card h4 {
  font-size: 0.78rem;
  color: var(--t);
  margin: 0 0 2px;
  font-weight: 700;
}
.rehab-page .comp-card p {
  font-size: 0.66rem;
  color: var(--mu);
  margin: 0;
  line-height: 1.4;
}

/* FAQ */
.rehab-page details.faq {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 14px 18px;
  margin-bottom: 8px;
}
.rehab-page details[open].faq {
  border-color: var(--bd2);
  box-shadow: var(--shs);
}
.rehab-page details.faq summary {
  
  font-weight: 700;
  font-size: 0.96rem;
  color: var(--t);
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rehab-page details.faq summary::-webkit-details-marker {
  display: none;
}
.rehab-page details.faq summary::after {
  content: "+";
  color: var(--co);
  font-size: 1.3rem;
  font-weight: 300;
  margin-left: 12px;
  transition: transform var(--tr);
}
.rehab-page details[open].faq summary::after {
  transform: rotate(45deg);
}
.rehab-page details.faq .ans {
  font-size: 0.88rem;
  color: var(--tx2);
  line-height: 1.72;
  margin-top: 10px;
}
.rehab-page details.faq .ans a {
  color: var(--t);
  text-decoration: underline;
  font-weight: 600;
}

.rehab-page .faq-help {
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 20px;
  text-align: center;
  margin-top: 14px;
}
.rehab-page .faq-help h4 {
  
  font-size: 1rem;
  color: var(--t);
  margin: 0 0 12px;
  font-weight: 700;
}
.rehab-page .faq-help .links {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.rehab-page .faq-help .links a {
  padding: 7px 14px;
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rp);
  font-size: 0.78rem;
  color: var(--tx2);
  text-decoration: none;
}
.rehab-page .faq-help .links a:hover {
  background: var(--t);
  color: #fff;
  border-color: var(--t);
}

/* Related chips */
.rehab-page .rel-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.rehab-page .rel-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rp);
  font-size: 0.8rem;
  color: var(--t);
  text-decoration: none;
  font-weight: 500;
}
.rehab-page .rel-chip:hover {
  background: var(--t);
  color: #fff;
  border-color: var(--t);
}

/* Cities */
.rehab-page .cities {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 9px;
}
.rehab-page .city {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 11px 14px;
  font-size: 0.82rem;
  color: var(--tx2);
  text-decoration: none;
  line-height: 1.4;
}
.rehab-page .city:hover {
  background: var(--e1);
  border-color: var(--t);
  color: var(--t);
}
.rehab-page .city b {
  display: block;
  color: var(--t);
  font-weight: 700;
  font-size: 0.88rem;
  margin-bottom: 1px;
}

/* Glossary */
.rehab-page .glos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.rehab-page .glos-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 16px;
}
.rehab-page .glos-card .ic {
  font-size: 1.55rem;
  margin-bottom: 6px;
  display: block;
}
.rehab-page .glos-card h4 {
  
  font-size: 0.94rem;
  color: var(--t);
  margin: 0 0 5px;
  font-weight: 700;
}
.rehab-page .glos-card p {
  font-size: 0.76rem;
  color: var(--mu);
  margin: 0;
  line-height: 1.55;
}

/* References */
.rehab-page .ref-section h3 {
  
  font-size: 1rem;
  color: var(--co);
  margin: 18px 0 10px;
  font-weight: 700;
}
.rehab-page .ref-section h3:first-child {
  margin-top: 0;
}
.rehab-page .ref-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.rehab-page .ref-card {
  background: var(--wh);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 14px;
}
.rehab-page .ref-year {
  font-size: 0.72rem;
  color: var(--mu);
  font-weight: 600;
}
.rehab-page .ref-card h4 {
  
  font-size: 0.86rem;
  color: var(--t);
  margin: 3px 0 5px;
  font-weight: 700;
  line-height: 1.35;
}
.rehab-page .ref-card p {
  font-size: 0.74rem;
  color: var(--tx2);
  margin: 0;
  line-height: 1.55;
}
.rehab-page .ref-disclaim {
  margin-top: 18px;
  padding: 14px 18px;
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  font-size: 0.82rem;
  color: var(--tx2);
  line-height: 1.65;
}
.rehab-page .ref-disclaim strong {
  color: var(--tx);
}

/* Stay healthy + final CTA */
.rehab-page .stay-healthy {
  background: linear-gradient(135deg, var(--t), var(--tm));
  color: #fff;
  border-radius: var(--rl);
  padding: 30px 36px;
  text-align: center;
}
.rehab-page .stay-healthy h3 {
  
  font-size: 1.3rem;
  color: #fff;
  margin: 0 0 9px;
  font-weight: 700;
}
.rehab-page .stay-healthy p {
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.85);
  margin: 0 0 15px;
  line-height: 1.65;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}
.rehab-page .stay-healthy a {
  display: inline-block;
  background: var(--co);
  color: #fff;
  border-radius: var(--rp);
  padding: 11px 22px;
  font-size: 0.88rem;
  font-weight: 700;
  text-decoration: none;
}
.rehab-page .stay-healthy .meta {
  font-size: 0.74rem;
  color: rgba(255, 255, 255, 0.65);
  margin-top: 12px;
}

.rehab-page .final-cta {
  background: var(--cr);
  border: 1px solid var(--bd);
  border-radius: var(--rl);
  padding: 34px 38px;
  text-align: center;
}
.rehab-page .final-cta h2 {
  
  font-size: 1.55rem;
  color: var(--t);
  margin: 0 0 10px;
  font-weight: 700;
}
.rehab-page .final-cta h2 em {
  font-style: italic;
  color: var(--co);
  font-weight: 700;
}
.rehab-page .final-cta p {
  font-size: 0.95rem;
  color: var(--tx2);
  margin: 0 0 18px;
  line-height: 1.65;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
.rehab-page .final-cta .ctas {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.rehab-page .final-cta .ctas a {
  padding: 11px 22px;
  border-radius: var(--rp);
  font-size: 0.86rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.rehab-page .final-cta .ctas .c1 {
  background: var(--co);
  color: #fff;
}
.rehab-page .final-cta .ctas .c2 {
  background: var(--wa);
  color: #fff;
}
.rehab-page .final-cta .ctas .c3 {
  background: var(--wh);
  color: var(--t);
  border: 1.5px solid var(--t);
}
.rehab-page .final-cta .meta {
  font-size: 0.78rem;
  color: var(--mu);
  margin-top: 14px;
}

/* Sticky bottom */
.rehab-page .sticky-bottom {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: #fff;
  border-top: 1px solid var(--bd);
  box-shadow: 0 -4px 18px rgba(10, 61, 56, 0.1);
  padding: 11px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.rehab-page .sb-l {
  font-size: 0.86rem;
  color: var(--tx);
}
.rehab-page .sb-l b {
  color: var(--co);
  font-weight: 700;
}
.rehab-page .sb-l span {
  color: var(--mu);
  font-size: 0.78rem;
  margin-left: 8px;
}
.rehab-page .sb-r a {
  background: var(--co);
  color: #fff;
  border-radius: var(--rp);
  padding: 10px 22px;
  font-size: 0.86rem;
  font-weight: 700;
  text-decoration: none;
}

/* Modals */
.rehab-page .modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(31, 24, 18, 0.55);
  backdrop-filter: blur(3px);
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.rehab-page .modal.show {
  display: flex;
}
.rehab-page .modal-card {
  background: #fff;
  border-radius: var(--rl);
  max-width: 480px;
  width: 100%;
  padding: 26px;
  position: relative;
  box-shadow: var(--shl);
  max-height: 90vh;
  overflow-y: auto;
}
.rehab-page .modal-close {
  position: absolute;
  top: 10px;
  right: 12px;
  background: none;
  border: none;
  font-size: 1.6rem;
  color: var(--mu);
  cursor: pointer;
  width: 32px;
  height: 32px;
  border-radius: 50%;
}
.rehab-page .modal-close:hover {
  background: var(--cr);
}
.rehab-page .modal-card h3 {
  
  font-size: 1.15rem;
  color: var(--t);
  margin: 0 0 5px;
  font-weight: 700;
}
.rehab-page .modal-card .ms {
  font-size: 0.85rem;
  color: var(--mu);
  margin-bottom: 14px;
}
.rehab-page .modal-card label {
  display: block;
  font-size: 0.74rem;
  color: var(--mu);
  font-weight: 600;
  margin-bottom: 4px;
}
.rehab-page .modal-card input,
.rehab-page .modal-card select {
  width: 100%;
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 9px 11px;
  font-size: 0.86rem;
  font-family: inherit;
  outline: none;
  margin-bottom: 10px;
}
.rehab-page .modal-card button.submit {
  background: var(--co);
  color: #fff;
  border: none;
  border-radius: var(--rp);
  width: 100%;
  padding: 11px;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  margin-top: 5px;
}
.rehab-page .modal-card .mfoot {
  font-size: 0.72rem;
  color: var(--mu);
  text-align: center;
  margin-top: 10px;
}

.rehab-page .discount-modal .modal-card {
  max-width: 420px;
  text-align: center;
  padding: 30px 26px;
  background: linear-gradient(135deg, #fff, #fcf3e8);
}
.rehab-page .discount-modal img {
  width: 120px;
  height: auto;
  margin: 0 auto 12px;
}
.rehab-page .discount-modal h3 {
  font-size: 1.35rem;
}
.rehab-page .discount-modal .pct {
  
  font-size: 2.6rem;
  color: var(--co);
  font-weight: 700;
  line-height: 1;
  margin: 6px 0;
}
.rehab-page .discount-modal .code {
  display: inline-block;
  background: #fff;
  border: 2px dashed var(--co);
  color: var(--co);
  padding: 8px 24px;
  font-family: monospace;
  font-size: 1.05rem;
  font-weight: 800;
  border-radius: 8px;
  margin: 9px 0 14px;
  letter-spacing: 0.1em;
}
.rehab-page .discount-modal a {
  display: inline-block;
  background: var(--co);
  color: #fff;
  border-radius: var(--rp);
  padding: 10px 26px;
  font-size: 0.88rem;
  font-weight: 700;
  text-decoration: none;
}

@media (max-width: 1024px) {
  .rehab-page .hero-in {
    grid-template-columns: 1fr;
    gap: 26px;
  }
  .rehab-page .doc-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .price-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .pillar-grid,
  .rehab-page .wp-grid,
  .rehab-page .pers-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .awards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .ins-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .rehab-page .outcomes {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .journey {
    grid-template-columns: repeat(5, 1fr);
    font-size: 0.86em;
  }
  .rehab-page .ref-grid,
  .rehab-page .testi-grid,
  .rehab-page .glos-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rehab-page .triage-grid,
  .rehab-page .calc-grid,
  .rehab-page .proto-grid,
  .rehab-page .twocol {
    grid-template-columns: 1fr;
  }
  .rehab-page .cities {
    grid-template-columns: repeat(3, 1fr);
  }
  .rehab-page .comp-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .rehab-page .cond-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 640px) {
  .rehab-page .doc-grid,
  .rehab-page .price-grid,
  .rehab-page .cond-grid,
  .rehab-page .pillar-grid,
  .rehab-page .wp-grid,
  .rehab-page .pers-grid,
  .rehab-page .awards-grid,
  .rehab-page .ins-grid,
  .rehab-page .outcomes,
  .rehab-page .journey,
  .rehab-page .ref-grid,
  .rehab-page .testi-grid,
  .rehab-page .glos-grid,
  .rehab-page .cities,
  .rehab-page .comp-grid {
    grid-template-columns: 1fr;
  }
  .rehab-page .tldr ul,
  .rehab-page .hero ul {
    grid-template-columns: 1fr;
  }
  .rehab-page .float-side {
    bottom: 78px;
    right: 12px;
  }
  .rehab-page .sec {
    padding: 30px 0;
  }
  .rehab-page .final-cta,
  .rehab-page .stay-healthy {
    padding: 24px 22px;
  }
}


/* Preview-only header/footer shell */
body {
  margin: 0;
  /* font-family: "Inter", sans-serif; */
  background: #fff;
}
.mp-banner {
  background: linear-gradient(90deg, #0a3d38, #0e4d45);
  color: #fff;
  padding: 10px 0;
  text-align: center;
  font-size: 0.78rem;
}
.mp-banner b {
  color: #f4a55a;
}
.mp-nav {
  background: #fff;
  border-bottom: 1px solid #e7e2d6;
  padding: 14px 0;
  position: sticky;
  top: 0;
  z-index: 500;
}
.mp-nav-in {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 18px;
  display: flex;
  align-items: center;
  gap: 18px;
}
.mp-logo {
  font-family: Georgia, serif;
  font-size: 1.3rem;
  font-weight: 800;
  color: #0a3d38;
  text-decoration: none;
}
.mp-links {
  display: flex;
  gap: 18px;
  font-size: 0.85rem;
  margin-left: auto;
}
.mp-links a {
  color: #3a4a4a;
  text-decoration: none;
}
.mp-links a:hover {
  color: #e8673a;
}
.mp-foot {
  background: #0a3d38;
  color: #fff;
  padding: 30px 18px 20px;
  text-align: center;
  font-size: 0.84rem;
  margin-top: 30px;
}
.mp-foot a {
  color: #f4a55a;
  text-decoration: none;
}
@media (max-width: 768px) {
  .mp-links {
    display: none;
  }
  .rehab-rights-grid,
  .rehab-cmp3,
  .rehab-editorial {
    grid-template-columns: 1fr !important;
  }
}


.rehab-page .breadcrumb li a:hover{
  text-decoration: underline;
}

.price-card.popular::before{
  content: initial;
}

li {
    color: var(--muted);
}

.price-card li {
    font-size: 13px;
}

.prcng_iner {
    margin-bottom: 50px;
}

.prcng_pra {
    font-family: Montserrat-Medium;
    margin-top: 30px !important;
    color: var(--muted) !important;
}

.rehab-page .cond-card{
  display: block;
}

.rehab-med-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-bottom:18px;
}

.rehab-med-card{
  background:var(--wh);
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:22px;
}

.rehab-med-card-left{
  border-left:4px solid var(--t);
}

.rehab-med-card-right{
  border-left:4px solid var(--co);
}

.rehab-med-title{
  font-size: 22px;
  color: var(--t1);
  font-weight:700;
  margin-bottom:6px;
  font-family: var(--fh);
}

.rehab-med-list{
  padding:0;
  margin:0;
  list-style:none;
}

.rehab-med-list li{
  position:relative;
  padding:6px 0 6px 22px;
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.55;
}

.rehab-med-list li:not(:last-child){
  border-bottom:1px dashed var(--bd);
}

.rehab-arrow{
  position:absolute;
  left:0;
  color:var(--co);
  font-weight:800;
}

.rehab-check{
  position:absolute;
  left:0;
  color:var(--ok);
  font-weight:800;
}

.rehab-bold{
  color:var(--tx);
}

.rehab-med-note{
  background:linear-gradient(135deg,#fff8f0,#fbedd9);
  border:1px solid rgba(244,165,90,.4);
  border-radius:var(--rl);
  padding:18px 22px;
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.7;
   font-family: Montserrat-Medium;
}

.rehab-med-note a{
  color:var(--t);
  font-weight:700;
  text-decoration:underline;
}

@media(max-width:768px){
  .rehab-med-grid{
    grid-template-columns:1fr;
  }
}

a{
      font-family: Montserrat-Medium;
}

.bx_heding {
    font-size: 20px !important;
}

/* Session Walkthrough */

.rehab-session-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-bottom:18px;
}

.rehab-session-card{
  background:var(--wh);
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:22px;
}

.rehab-session-card-left{
  border-left:4px solid var(--co);
}

.rehab-session-card-right{
  border-left:4px solid var(--t);
}

.rehab-session-title{
  font-size:1.05rem;
  color: var(--t1);
  font-weight:700;
  margin-bottom:4px;
  font-family: var(--fh);
}

.rehab-session-subtitle{
  font-size:.74rem;
  color:var(--mu);
  margin-bottom:12px;
  font-style:italic;
  font-weight: 600;
}

.rehab-session-list{
  padding-left:0;
  margin:0;
  list-style:none;
}

.rehab-session-list li{
  font-size:.85rem;
  color:var(--tx2);
  padding: 8px 0 7px 32px;
  position:relative;
  line-height:1.6;
}

.rehab-session-list li:not(:last-child){
  border-bottom:1px dashed var(--bd);
}

.rehab-session-step{
  position:absolute;
  left:0;
  top:7px;
  width:22px;
  height:22px;
  color:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.72rem;
  font-weight:800;
}

.rehab-session-step-co{
  background:var(--co);
}

.rehab-session-step-t{
  background:var(--t);
}

.rehab-session-bold{
  color:var(--tx);
}

.rehab-session-faq{
  background:var(--cr);
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:18px 22px;
}

.rehab-session-faq-title{
  font-size:1rem;
  color:var(--t);
  margin: 0 0 14px;
  font-weight:700;
}



.rehab-session-faq-list{
  margin:0;
  padding:0;
  list-style:none;
}

.rehab-session-faq-item{
  font-size:.83rem;
  color:var(--tx2);
  line-height:1.6;
}

.rehab-session-faq-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap: 12px 18px;
}

@media (max-width:768px){

  .rehab-session-grid{
    grid-template-columns:1fr;
  }

  .rehab-session-faq-grid{
    grid-template-columns:1fr;
  }
  .rehab-session-faq-list{
    grid-template-columns:1fr;
  }
}

.rehab-care-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:18px;
}

.rehab-care-card{
  padding:22px;
  border-radius:var(--rl);
}

.rehab-care-green{
  background:#f5fdf7;
  border:1px solid #bfe3c9;
  border-left:4px solid var(--ok);
}

.rehab-care-orange{
  background:#fff5f0;
  border:2px solid #f3a890;
}

.rehab-care-heading{
  font-size: 18px;
  font-weight:700;
  margin-bottom:8px;
  font-family: var(--fh);
}

.rehab-care-heading-green{
  color:#15532a;
}

.rehab-care-heading-orange{
  color:#7C2D1B;
}

.rehab-care-list{
  margin:0;
  padding:0;
  list-style:none;
}

.rehab-care-list li{
  position:relative;
  padding:5px 0 5px 22px;
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.55;
}

.rehab-care-list li span{
  position:absolute;
  left:0;
  color:var(--ok);
  font-weight:800;
}

.rehab-care-list-orange li{
  padding:6px 0 6px 26px;
}

.rehab-care-list-orange li:not(:last-child){
  border-bottom:1px solid #f3c8b0;
}

.rehab-care-list-orange li span{
  color:#7C2D1B;
  font-size:1rem;
  font-weight:800;
}

.rehab-care-list-orange li b{
  color:var(--tx);
}

.rehab-care-list-orange li a{
  color:var(--t);
  font-weight:700;
}

.rehab-care-promise{
  background:#fff;
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:18px 22px;
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.7;
  font-family: Montserrat-Medium;
}

.rehab-care-promise b{
  color:var(--tx);
}

@media(max-width:768px){

  .rehab-care-grid{
    grid-template-columns:1fr;
  }

}

.rehab-track-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.rehab-track-card{
  background:var(--wh);
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:22px;
}

.rehab-track-card-co{
  border-top:4px solid var(--co);
}

.rehab-track-card-go{
  border-top:4px solid var(--go);
}

.rehab-track-card-t{
  border-top:4px solid var(--t);
}

.rehab-track-title{
  font-size:1.05rem;
  color:var(--t);
  margin:0 0 4px;
  font-weight:700;
}

.rehab-track-subtitle{
  font-size:.74rem;
  color:var(--mu);
  font-style:italic;
  font-weight:600;
  margin-bottom:11px;
}

.rehab-track-list{
  padding:0;
  margin:0;
  list-style:none;
}

.rehab-track-list li{
  position:relative;
  padding:4px 0 4px 20px;
  font-size:.83rem;
  color:var(--tx2);
  line-height:1.55;
}

.rehab-track-dot{
  position:absolute;
  left:0;
  top:12px;
  width:7px;
  height:7px;
  border-radius:50%;
}

.rehab-track-dot-co{
  background:var(--co);
}

.rehab-track-dot-go{
  background:var(--go);
}

.rehab-track-dot-t{
  background:var(--t);
}

.rehab-track-note{
  text-align:center;
  margin-top:25px;
  font-size:.86rem;
  color:var(--mu);
}

.rehab-track-note a{
  color:var(--t);
  font-weight:700;
  text-decoration:underline;
}

@media(max-width:991px){

  .rehab-track-grid{
    grid-template-columns:1fr;
  }

}

.piler_iner {
    display: flex;
    align-items: center;
    gap: 9px;
}

.rehab-page .pillar-card .pic{
  font-size: 1.9rem;
    background: rgb(255 220 208 / 65%);
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: rgb(255 228 218 / 46%) 0px 2px 8px 0px;
    border-radius: 10px;
    margin-bottom: 12px;
}

.onge_btn a {
    background: var(--co);
    border: 1px solid var(--co);
    padding: 10px;
    border-radius: 10px;
    width: 100%;
    display: block;
    text-align: center;
    margin-top: 20px;
    transition: 400ms ease-in-out;
    color: rgb(255, 255, 255) !important;
}

.onge_btn a:hover {
    background: rgb(255, 255, 255);
    color: var(--co) !important;
}

.cmn_dibts .chip-grid {
    gap: 13px 10px;
}

.cmn_dibts .chip-grid a {
    width: inherit;
    color: var(--t1);
    background: #f0fffe;
    border: 1px solid #80c6c1;
}

.hlt_scn {
    padding: 60px 24px !important;
}

.rehab-page .calc-card label{
  font-family: Montserrat-Medium;
  color: var(--muted);
}

.calc-label{
    font-family: Montserrat-Medium;
}

.rehab-page .calc-card a{
  display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.78rem;
    color: var(--co);
    font-weight: 700;
    text-decoration: none;
    background: rgb(255, 255, 255);
    border: 1px solid var(--co);
    padding: 8px 10px;
    border-radius: 10px;
    box-shadow: rgb(255, 245, 244) 0px 2px 8px 0px;
    margin-top: 10px;
}

.rehab-page .calc-result {
   
    border-top: 1px solid #ccc;
    padding-top: 14px;
    margin-top: 20px;
}

.rehab-page .calc-result{
  font-size: 20px;
}

.rehab-page .calc-card h4 {
    font-size: 20px;
   
}

.cal_card_cntnt input{
    font-family: Montserrat-Medium !important;
    color: var(--muted);
}

.frm_teen .segments-grid {
    width: 100%;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.frm_teen .segment-card {
    padding: 20px 10px;
}

.frm_teen .segment-card li {
    font-size: 13.5px;
    line-height: 20px;
}

.clncl_rhb_crd {
    gap: 20px !important;
}

.clncl_rhb_crd ol li {
    list-style: auto;
    margin-bottom: 8px;
}

.review_scn p {
    color: var(--muted) !important;
}

.rehab-page .testi-quote {

    font-size: 15px;
    color: var(--muted);
  
    font-family: Montserrat-Medium;
}

.editorial-history-box{
    background:#fff;
    border:1px solid var(--bd);
    border-radius:28px;
    padding:35px;
    box-shadow: rgb(99 99 99 / 9%) 0px 2px 8px 0px;
}

.editorial-history-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:30px;
    padding-bottom:18px;
    border-bottom:1px solid var(--bd);
}

.editorial-history-head h3{
    margin:0;
    color:var(--t1);
    font-size:1.2rem;
}

.editorial-history-head span{
    background:#f3f6fb;
    padding:8px 14px;
    border-radius:30px;
    color:var(--mu);
    font-size:.8rem;
    font-weight:600;
}

.editorial-history-timeline{
    position:relative;
    padding-left:35px;
}

.editorial-history-timeline::before{
    content:"";
    position:absolute;
    left:8px;
    top:0;
    bottom:0;
    width:2px;
    background:#e4e9ef;
}

.editorial-history-item{
    position:relative;
    padding-bottom:28px;
}

.editorial-history-item:last-child{
    padding-bottom:0;
}

.editorial-history-item::before{
    content:"";
    width:18px;
    height:18px;
    border-radius:50%;
    background:var(--co);
    border:4px solid #fff;
    box-shadow:0 0 0 2px var(--co);
    position:absolute;
    left:-35px;
    top:4px;
}

.editorial-history-date{
    font-size:.9rem;
    font-weight:700;
    color:var(--t1);
    margin-bottom:6px;
}

.editorial-history-content{
    color: var(--muted);
    line-height:1.8;
    font-size:.87rem;
    font-family: Montserrat-Medium;
}

/*==================================
RESPONSIVE
===================================*/

@media(max-width:991px){

    .editorial-process-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:767px){

    .editorial-process-grid{
        grid-template-columns:1fr;
    }

    .editorial-history-box{
        padding:22px;
    }

    .editorial-history-head{
        flex-direction:column;
        align-items:flex-start;
        gap:12px;
    }

    .editorial-history-timeline{
        padding-left:28px;
    }

    .editorial-history-item::before{
        left:-28px;
    }

}


.rehab-compliance-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.rehab-compliance-card{
  background:#fff;
  border:1px solid var(--bd);
  border-radius:var(--rl);
  padding:16px;
  font-size:.84rem;
  color: var(--muted);
  font-family: Montserrat-Medium;
}

.rehab-compliance-card b{
  color:var(--t);
  font-family: var(--fh);
  font-size: 14px;
}

@media(max-width:991px){
  .rehab-compliance-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:767px){
  .rehab-compliance-grid{
    grid-template-columns:1fr;
  }
}

.quick_answe_bx .qa-box {
    padding: 20px;
}

.quick_answe_bx {
    margin-top: 40px;
}

.rehab-page .qa-box h3{
      line-height: 27px;
}

.sec-hdr-btns p a {
    color: rgb(255, 255, 255);
    transition: 400ms ease-in-out;
}

.spclst_scn .chip-grid a.chip {
    width: inherit;
}

.glsry b{
  font-family: var(--fh);
}

.rehab-habits-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.rehab-habit-card{
  background:#fff;
  border:1px solid var(--bd);
  border-radius:18px;
  padding:22px;
  transition:.3s ease;
  position:relative;
  overflow:hidden;
}

.rehab-habit-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg,var(--co),var(--t));
}

.rehab-habit-card:hover{
  transform:translateY(-5px);
  box-shadow:0 12px 30px rgba(0,0,0,.08);
}

.rehab-habit-icon{
  width:58px;
  height:58px;
  border-radius:14px;
  background:#f6f9ff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.8rem;
  margin-bottom:16px;
}

.rehab-habit-card h4{
  margin:0 0 10px;
  font-size:1rem;
  color:var(--t);
  font-weight:700;
  line-height:1.4;
}

.rehab-habit-card p{
  margin:0;
  font-size:.88rem;
  color:var(--tx2);
  line-height:1.7;
}

@media(max-width:991px){
  .rehab-habits-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:767px){
  .rehab-habits-grid{
    grid-template-columns:1fr;
  }

  .rehab-habit-card{
    padding:18px;
  }
}

.rehab-cta-section{
  padding:70px 0;
  background:linear-gradient(135deg,var(--t),#0E2A2C);
  position:relative;
  overflow:hidden;
}

.rehab-cta-section::before{
  content:"";
  position:absolute;
  width:350px;
  height:350px;
  border-radius:50%;
  background:rgba(255,255,255,.05);
  top:-120px;
  right:-120px;
}

.rehab-cta-section::after{
  content:"";
  position:absolute;
  width:250px;
  height:250px;
  border-radius:50%;
  background:rgba(255,255,255,.04);
  bottom:-100px;
  left:-80px;
}

.rehab-cta-box{
  position:relative;
  z-index:2;
  text-align:center;
  margin:auto;
}

.rehab-cta-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 18px;
  padding:10px 18px;
  border-radius:50px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.15);
  color:var(--go);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
}

.rehab-cta-title{
  margin:0 0 15px;
  color:#fff;
  font-size: 34px;
  font-weight:800;
  line-height:1.2;
}

.rehab-cta-desc{
  max-width:720px;
  margin:0 auto 30px;
  color:rgba(255,255,255,.85);
  font-size:1rem;
  line-height:1.8;
}

.rehab-cta-btns{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.rehab-cta-primary{
  background:var(--co);
  color: #fff !important;
  padding:16px 32px;
  border-radius:14px;
  text-decoration:none;
  font-weight:800;
  font-size:1rem;
  transition:.3s ease;
  box-shadow:0 10px 30px rgba(232,103,58,.35);
}

.rehab-cta-primary:hover{
  transform:translateY(-3px);
}

.rehab-cta-secondary{
  background:rgba(255,255,255,.12);
  color:  #fff !important;
  padding:16px 28px;
  border-radius:14px;
  text-decoration:none;
  font-weight:700;
  font-size:.96rem;
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(8px);
  transition:.3s ease;
}

.rehab-cta-secondary:hover{
  background:rgba(255,255,255,.18);
  transform:translateY(-3px);
}

.rehab-cta-trust{
  margin-top:24px;
  color:rgba(255,255,255,.70);
  font-size:.82rem;
  line-height:1.7;
}

@media(max-width:767px){

  .rehab-cta-section{
    padding:55px 0;
  }

  .rehab-cta-btns{
    flex-direction:column;
  }

  .rehab-cta-primary,
  .rehab-cta-secondary{
    width:100%;
    max-width:340px;
  }

  .rehab-cta-desc{
    font-size:.92rem;
  }

}