/* CONTENT CONTAINER - Common styles for all content blocks */
.content > * > .content,
main > * > .content {
  max-width: 144rem;
  margin: 0 auto;
  padding: 0 9.6rem;
  width: 100%;
}

/* Exclude phone section and section-online-doctor */
main > .section-phone .content,
main > * .section-phone .content,
.content > .section-online-doctor,
.content > .section-online-doctor .content {
  max-width: none;
  margin: 0;
  padding: 0;
  width: auto;
}

/* DOCTOR DETAILS SECTION STYLES */

.doctor-details-section {
  background: var(--color-gray-50);
  padding: 4.2rem 0;
  margin: 4rem 0;
  width: 100%;
  position: relative;
}

/* .doctor-details-container uses .content class */

/* Doctor Details Heading - Uses common .section-heading from components.css */
.doctor-details-heading {
  font: var(--font-heading-2);
  color: var(--color-blue-900);
  text-align: center;
  font-weight: 700;
}

.doctor-details-card {
  background: var(--color-white);
  border-radius: var(--radius-primary);
  padding: 0.8rem;
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
}

.doctor-details-content {
  display: flex;
  grid-template-columns: 1fr 1.5fr;
  gap: 3.2rem;
  align-items: start;
}

.doctor-details-image {
  flex: 1;
  max-width: 380px;
  min-width: 380px;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-secondary);
}

.doctor-details-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.doctor-details-info {
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  padding: 2.4rem 4.6rem 2.4rem 0;
}

.doctor-details-description {
  font: var(--font-md);
  color: var(--color-gray-800);
  line-height: 1.6;
  margin: 0;
}

.doctor-details-name {
  font: var(--font-heading-6);
  color: var(--color-blue-900);
  line-height: 1.3;
  font-weight: 700;
}

.doctor-details-cta {
  display: flex;
  justify-content: center;
  padding-top: 4.6rem;
}

/* Doctor Details Button - Uses common .gradient-button-container from components.css */
.doctor-details-button-container {
  width: fit-content;
  border-radius: 40px;
  background: linear-gradient(to left, var(--color-blue-200) 0%, var(--color-blue-500) 100%);
}

.doctor-details-button-container .button {
  background: transparent;
  border-color: transparent;
}

.doctor-details-button-container a {
  width: 100%;
}

.doctor-details-button-container .button span {
  color: var(--color-white);
}

.doctor-details-button {
  background: transparent;
  color: var(--color-white);
  border-top: solid 15px transparent;
  border-bottom: solid 15px transparent;
}

.doctor-details-button span {
  color: var(--color-white);
}
/* ARTICLE HEADER SECTION STYLES */

.article-header-section {
  background: var(--color-white);
  margin: 0 0 4.6rem;
  width: 100%;
}

/* .article-header-container uses .content class */

.article-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 6.4rem;
  font: var(--font-caption);
  color: var(--color-gray-600);
}

a.article-breadcrumb-link {
  color: var(--color-gray-800);
  text-decoration: none;
  transition: color 0.3s ease;
}

a.article-breadcrumb-link:hover {
  color: var(--color-blue-900);
}

.article-breadcrumb-separator {
  color: var(--color-gray-400);
}

.article-breadcrumb-current {
  font: var(--font-caption);
  color: var(--color-gray-700);
  text-transform: uppercase;
}

.article-header-top {
  margin-bottom: 2.4rem;
}

.article-header-tags {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  flex-wrap: wrap;
}

.article-header-tags-wrapper {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  flex-wrap: wrap;
}

.article-header-tag {
  display: inline-block;
  padding: 0.7rem 1.2rem;
  background: var(--color-gray-50);
  border-radius: 2rem;
  font: var(--font-caption);
  color: var(--color-gray-800);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-decoration: none;
  transition: background-color 0.3s ease;
}

.article-header-tag:hover {
  background: var(--color-gray-300);
  color: var(--color-gray-800);
}

.article-header-read-time {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-transform: uppercase;
  font: var(--font-caption);
  color: var(--color-gray-800);
}

.article-header-read-time svg {
  width: 1.8rem;
  height: 1.8rem;
  flex-shrink: 0;
  color: var(--color-gray-800);
}

.article-header-title {
  font: var(--font-heading-2);
  color: var(--color-blue-900);
  margin: 0 0 2.4rem;
  line-height: 1.2;
  font-weight: 700;
}

.article-header-author {
  display: flex;
  align-items: center;
  gap: 2.4rem;
}

.article-header-author-image {
  border-radius: 18px;
  width: 64px;
  height: 64px;
  overflow: hidden;
  flex-shrink: 0;
}

.article-header-author-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-header-author-info {
  flex: 1;
  display: flex;
  gap: 0.2rem;
  flex-direction: column;
}

.article-header-section .article-header-author-text {
  font: var(--font-sm);
  color: var(--color-gray-800);
  margin: 0;
}

.article-header-section .article-header-author-link {
  color: var(--color-blue-900);
  text-decoration: underline;
  font-weight: 500;
  transition: color 0.3s ease;
}

.article-header-section .article-header-author-link:hover {
  color: var(--color-blue-500);
}

.article-header-section .article-header-meta {
  margin: 0;
  gap: 0.2rem;
  display: flex;
  flex-direction: column;
  font: var(--font-sm);
  color: var(--color-gray-800);
}

.article-header-section .article-header-meta-item {
  display: block;
  margin: 0;
}

.article-header-section .article-header-meta-item strong {
  font-weight: 600;
  color: var(--color-blue-900);
}

/* ARTICLE CONTENT SECTION STYLES */

.article-content-section {
  margin: 9.4rem 0 1.2rem;
  border-radius: var(--radius-primary);
  width: 100%;
}

/* .article-content-container uses .content class */

.article-content-layout {
  padding: 8.2rem 0;
  margin: 0;
  display: grid;
  grid-template-columns: 200px auto;
  gap: 11rem;
  align-items: start;
}

.article-sidebar {
  align-self: start;
}

.sticky-wrapper {
  width: 100%;
}

.sticky-inside-block {
  position: sticky;
  width: 100%;
  top: 0;
}

.table-of-contents {
  background: var(--color-white);
  width: 100%;
  padding: 0;
}

.table-of-contents-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1.8rem;
}

.table-of-contents h5 {
  font: var(--font-heading-6);
  color: var(--color-blue-900);
  margin: 0;
  font-weight: 700;
  flex: 1;
}

.table-of-contents-toggle {
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 50%;
  background: var(--color-white);
  border: 1px solid var(--color-gray-600);
  display: none;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-700);
  cursor: pointer;
  transition: all 0.3s ease;
  flex-shrink: 0;
  padding: 0;
}

.table-of-contents-toggle:hover {
  background: var(--color-gray-600);
}

.table-of-contents-toggle svg {
  width: 1.6rem;
  height: 1.6rem;
  transition: transform 0.3s ease;
}

.table-of-contents-toggle[aria-expanded='true'] svg {
  transform: rotate(180deg);
}

.table-of-contents-content {
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.4s ease, margin 0.3s ease;
  max-height: 2000px;
  opacity: 1;
}

.sidebar-nav {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

.sidebar-nav li {
  margin: 0;
  padding: 0;
}

.sidebar-nav a {
  font: var(--font-sm);
  color: var(--color-gray-800);
  text-decoration: none;
  display: block;
  padding: 0.4rem 0;
  transition: color 0.3s ease;
}

.sidebar-nav a.active {
  color: var(--color-blue-900);
}

.sidebar-nav a:hover {
  color: var(--color-blue-900);
}

/* Legacy class support */
.table-of-contents-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

.table-of-contents-list li {
  margin: 0;
  padding: 0;
}

.table-of-contents-list a {
  font: var(--font-sm);
  color: var(--color-gray-800);
  text-decoration: none;
  display: block;
  padding: 0.4rem 0;
  transition: color 0.3s ease;
}

.table-of-contents-list a:hover {
  color: var(--color-blue-900);
}

/* Article Content Typography */
main h2 {
  font-size: 3.2rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--color-blue-900);
  margin: 4.6rem 0 3.2rem;
}

main h3 {
  font-size: 2.4rem;
  line-height: 1.3;
  font-weight: 700;
  color: var(--color-blue-900);
  margin: 3.2rem 0 2.4rem;
}

main h4 {
  font-size: 2rem;
  line-height: 1.3;
  font-weight: 600;
  color: var(--color-blue-900);
  margin: 1.8rem 0 2.4rem;
}

main h5 {
  font-size: 1.8rem;
  line-height: 1.4;
  font-weight: 600;
  color: var(--color-blue-900);
  margin: 1.6rem 0 2.4rem;
}

main h6 {
  font-size: 1.6rem;
  line-height: 1.4;
  font-weight: 600;
  color: var(--color-blue-900);
  margin: 1.4rem 0 2.4rem;
}

main p {
  font-size: 2.2rem;
  line-height: 1.6;
  color: var(--color-gray-800);
  margin: 0 0 2.4rem;
}

main p:has(+ h2),
main p:has(+ h3),
main p:has(+ h4),
main p:has(+ h5),
main p:has(+ h6),
main ul:has(+ h2),
main ul:has(+ h3),
main ul:has(+ h4),
main ul:has(+ h5),
main ul:has(+ h6),
main table:has(+ h2),
main table:has(+ h3),
main table:has(+ h4),
main table:has(+ h5),
main table:has(+ h6),
.table-wrapper:has(+ h2),
.table-wrapper:has(+ h3),
.table-wrapper:has(+ h4),
.table-wrapper:has(+ h5),
.table-wrapper:has(+ h6),
.bordered-block:has(+ h2),
.bordered-block:has(+ h3),
.bordered-block:has(+ h4),
.bordered-block:has(+ h5),
.bordered-block:has(+ h6),
.cta-block:has(+ h2),
.cta-block:has(+ h3),
.cta-block:has(+ h4),
.cta-block:has(+ h5),
.cta-block:has(+ h6),
.block-slider:has(+ h2),
.block-slider:has(+ h3),
.block-slider:has(+ h4),
.block-slider:has(+ h5),
.block-slider:has(+ h6) {
  margin-bottom: 0;
}

/* Lists Styles */
main ul,
main ol {
  font-size: 2.2rem;
  line-height: 1.6;
  color: var(--color-gray-800);
  margin: 0 0 2.4rem;
  padding-left: 2.4rem;
  list-style-position: outside;
}

main ul {
  list-style-type: disc;
  list-style: disc outside;
}

main ol {
  list-style-type: decimal;
  list-style: decimal outside;
}

main li {
  display: list-item;
  margin: 0 0 1.2rem;
  padding-left: 0.8rem;
  line-height: 1.6;
  color: var(--color-gray-800);
}

main li:last-child {
  margin-bottom: 0;
}

/* Nested Lists */
main ul ul,
main ol ol,
main ul ol,
main ol ul {
  margin: 1.2rem 0 0;
  padding-left: 2.4rem;
  font-size: inherit;
}

main ul ul {
  list-style-type: circle;
  list-style: circle outside;
}

main ul ul ul {
  list-style-type: square;
  list-style: square outside;
}

main ol ol {
  list-style-type: lower-alpha;
  list-style: lower-alpha outside;
}

main ol ol ol {
  list-style-type: lower-roman;
  list-style: lower-roman outside;
}

main a {
  color: var(--color-blue-900);
  text-decoration: underline;
  transition: color 0.3s ease;
}

main a:hover {
  color: var(--color-blue-500);
}

main strong,
main b {
  color: var(--color-blue-900);
  font-weight: 700;
}

main span {
  font: inherit;
  color: inherit;
}

/* Table Styles */
main .table-wrapper {
  width: 100%;
  overflow-x: auto;
}

main table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-white);
  border-radius: var(--radius-secondary);
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  font-size: 2.4rem;
  margin-bottom: 2.4rem;
}

main table thead {
  background: var(--color-gray-100);
}

main table:not(:has(thead)) tbody tr:first-child {
  background: var(--color-gray-100);
}

main table:not(:has(thead)) tbody tr:first-child td p {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-blue-900);
  margin: 0;
}

main table th {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-blue-900);
  text-align: left;
  padding: 1.6rem;
  border: none;
}

main table th p {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-blue-900);
  margin: 0;
}

main table td {
  font-size: 2.4rem;
  font-weight: 500;
  color: var(--color-gray-800);
  padding: 1.6rem;
  border-bottom: 1px solid var(--color-gray-200);
  vertical-align: top;
}

/* Article Share styles moved to components.css */

.article-disclaimer {
  margin: 2.4rem 0 0;
}

.article-disclaimer-text {
  font: var(--font-sm);
  color: var(--color-gray-600);
  line-height: 1.6;
  margin: 0;
}

.article-related-section {
  padding: 8.2rem 0;
  margin: 0 0 1.2rem;
  background: var(--color-white);
  border-radius: var(--radius-primary);
}

.article-related-container {
  position: relative;
}

/* Article Related Heading - Uses common .section-heading from components.css */
.article-related-heading {
  font: var(--font-heading-2);
  color: var(--color-blue-900);
  margin: 0 0 3.2rem;
  text-align: center;
  font-weight: 700;
}

.article-related-heading span {
  color: var(--color-blue-500);
}

.article-related-slider-wrapper {
  width: 100%;
  position: relative;
}

.article-related-slider {
  width: 100%;
  position: relative;
  min-height: 44.2rem;
}

.article-related-slider .slide-item {
  padding: 0;
  height: auto;
}

.article-related-slider .slick-list {
  margin: 0 0 4.6rem;
}

.article-related-slider .slick-track {
  display: flex;
  gap: 0.8rem;
  align-items: stretch;
}

/* Article Card Styles in Slider - Uses base styles from common.css */
/* Only slider-specific overrides are defined here */

/* Slider Navigation Styles */
.article-related-slider-nav {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  position: absolute;
  right: 0;
  bottom: 0;
}

/* Article Related Slider Navigation - Uses common .slick-nav-button from components.css */
.article-related-slider-prev {
  order: 2;
}

.article-related-slider-next {
  order: 3;
}

/* Dots Navigation - Uses common .slick-dots-container from components.css */
.article-related-slider .slick-dots li:first-child button,
.article-related-slider .slick-dots li:last-child button {
  padding: 0;
}

/* Hide default slick arrows */
.article-related-slider .slick-arrow {
  display: none !important;
}

/* Block Slider and Treatment Card styles moved to components.css */

/* FLOATING CTA POPUP STYLES */

.floating-cta-popup {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1200;
  max-width: 64rem;
  width: calc(100% - 4rem);
  display: none;
}

.floating-cta-popup.show {
  display: block;
  animation: slideUpFadeIn 0.4s ease-out;
}

@keyframes slideUpFadeIn {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(2rem);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

.floating-cta-card {
  background: var(--color-white);
  border-radius: 2.4rem;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15);
  position: relative;
  padding: 0.8rem 0.8rem 0.8rem 3.2rem;
}

.floating-cta-close {
  position: absolute;
  top: 1.6rem;
  right: 1.6rem;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 50%;
  background: var(--color-gray-200);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-800);
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.3s ease;
  z-index: 10;
  padding: 0;
}

.floating-cta-close:hover {
  background: var(--color-gray-300);
}

.floating-cta-content {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 4.6rem;
  align-items: center;
}

.floating-cta-text {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  padding: 2.4rem 0;
}

.floating-cta-title {
  font: var(--font-heading-3);
  color: var(--color-blue-900);
  margin: 0;
  letter-spacing: -0.02em;
}

.floating-cta-subtitle {
  font: var(--font-caption);
  color: var(--color-blue-900);
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.floating-cta-description {
  font: var(--font-md);
  color: var(--color-gray-800);
  margin: 0;
}

/* Floating CTA Button - Uses common .gradient-button-container from components.css */
.floating-cta-button-container {
  width: fit-content;
  border-radius: 40px;
  background: linear-gradient(to left, var(--color-blue-200) 0%, var(--color-blue-500) 100%);
}

.floating-cta-button-container .button {
  width: 100%;
  border-color: transparent;
  background: transparent;
}

.floating-cta-button-container .button span {
  color: var(--color-white);
}

.floating-cta-button {
  background: transparent;
  color: var(--color-white);
  border-top: solid 15px transparent;
  border-bottom: solid 15px transparent;
}

.floating-cta-button span {
  color: var(--color-white);
}

.floating-cta-image {
  position: relative;
  width: 100%;
  height: 100%;
  background: var(--color-gray-50);
  border-radius: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.floating-cta-image img {
  position: absolute;
  width: 100%;
  height: auto;
  max-height: 29rem;
  object-fit: contain;
  display: block;
  bottom: 0;
}

/* BORDERED BLOCK STYLES */

.bordered-block {
  background: var(--color-gray-50);
  border-radius: var(--radius-secondary);
  padding: 2.4rem;
  margin: 0 0 2.4rem;
}

.bordered-block-title {
  font-size: 2.8rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--color-blue-900);
  margin: 0 0 1.6rem;
}

.bordered-block-content {
  font: var(--font-md);
  color: var(--color-gray-800);
  line-height: 1.6;
}

.bordered-block-content p {
  margin: 0 0 1.6rem;
}

.bordered-block-content p:last-child {
  margin-bottom: 0;
}

.bordered-block-content h1,
.bordered-block-content h2,
.bordered-block-content h3,
.bordered-block-content h4,
.bordered-block-content h5,
.bordered-block-content h6 {
  color: var(--color-blue-900);
  margin: 1.6rem 0;
}

.bordered-block-content a {
  color: var(--color-blue-900);
  text-decoration: underline;
  transition: color 0.3s ease;
}

.bordered-block-content a:hover {
  color: var(--color-blue-500);
}

.bordered-block-content ul,
.bordered-block-content ol {
  margin: 1.6rem 0;
  padding-left: 2rem;
}

.bordered-block-content li {
  margin: 0.8rem 0;
}

/* CTA BLOCK STYLES */

.cta-block {
  border-radius: var(--radius-primary);
  background: linear-gradient(270deg, var(--color-blue-200) 0%, var(--color-blue-500) 100%);
  padding: 0.8rem 0.8rem 0.8rem 4.6rem;
  margin: 0 0 4rem;
  width: 100%;
}

.cta-block-content {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 4.6rem;
  align-items: center;
}

.cta-block-text {
  display: flex;
  flex-direction: column;
}

.cta-block-title {
  color: var(--color-white);
  margin: 3.8rem 0 4.1rem;
}

.cta-block-description {
  font: var(--font-md);
  color: var(--color-white);
  margin: 0 0 3.2rem;
}

/* CTA Block Button - Uses common .gradient-button-container from components.css */
.cta-block-button-container {
  margin: 0 0 3.2rem;
  width: fit-content;
  border-radius: 40px;
  background: linear-gradient(to left, var(--color-blue-200) 0%, var(--color-blue-500) 100%);
}

.cta-block-button {
  width: fit-content;
  border-top: solid 15px transparent;
  border-bottom: solid 15px transparent;
}

.cta-block-button span {
  color: var(--color-blue-900);
}

.cta-block-image {
  width: 360px;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-radius: var(--radius-secondary);
}

.cta-block-image img {
  border-radius: var(--radius-secondary);
}

.cta-block-image-desktop {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.cta-block-image-mobile {
  display: none;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.article-related-slider-prev,
.article-related-slider-next {
  position: relative;
}

.category-weight-management .treatment-blue-button-container {
  background: linear-gradient(to left, var(--color-light-green) 0%, var(--color-green) 100%);
}

.category-womens-health .treatment-blue-button-container {
  background: linear-gradient(to right, var(--color-violet), var(--color-soft-violet));
}

.category-mental-health .treatment-blue-button-container {
  background: linear-gradient(to left, var(--color-deep-light-blue) 0%, var(--color-deep-blue) 100%);
}

/* ========================================
   RESPONSIVE STYLES
   ======================================== */

/* Breakpoint: 1439px */
@media all and (max-width: 1439px) {
  .cta-block-title,
  .cta-block-description {
    margin: 0 0 3.2rem;
  }

  .cta-block-button-container {
    margin: 0;
  }

  /* Doctor Details Section */
  .doctor-details-content {
    gap: 3.6rem;
  }

  .doctor-details-info {
    padding: 2rem 3.6rem 2rem 0;
  }

  .doctor-details-cta {
    padding-top: 3.6rem;
  }
}

/* Breakpoint: 1280px */
@media all and (max-width: 1280px) {
  .cta-block-title,
  .cta-block-description {
    margin: 0 0 2.4rem;
  }

  /* Doctor Details Section */
  .doctor-details-content {
    gap: 3.2rem;
  }

  .doctor-details-info {
    padding: 2rem 3.2rem 2rem 0;
  }

  .doctor-details-cta {
    padding-top: 3.2rem;
  }
}

/* Breakpoint: 1200px */
@media all and (max-width: 1200px) {
  .cta-block {
    padding: 0.8rem;
  }

  .cta-block-content {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 2.4rem;
  }

  .cta-block-image {
    grid-row: 1;
  }

  .cta-block-button-container {
    display: flex;
    justify-content: center;
    width: 100%;
  }

  .cta-block-button-container .button {
    width: 100%;
  }

  /* Doctor Details Section */
  .doctor-details-content {
    flex-direction: column;
    gap: 3rem;
  }

  .doctor-details-info {
    padding: 2rem;
  }

  .doctor-details-cta {
    padding-top: 3rem;
  }

  .cta-block-text {
    padding-left: 1.8rem;
    padding-right: 1.8rem;
    padding-bottom: 1.8rem;
  }
}

@media all and (max-width: 1024px) {
  .block-slider {
    padding: 3.2rem;
    padding-bottom: 4rem;
  }
}

/* Breakpoint: 991px */
@media all and (max-width: 991px) {
  /* Content container adaptive */
  .content > * > .content,
  main > * > .content {
    padding: 0 2.4rem;
  }

  /* Doctor Details Section */
  .doctor-details-section {
    padding: 4rem 0;
    margin: 3rem 0;
  }

  .doctor-details-container {
    padding: 0 2.4rem;
  }

  .doctor-details-heading {
    font: var(--font-mobile-heading-2);
    margin-bottom: 3rem;
  }

  .doctor-details-card {
    gap: 2rem;
  }

  .doctor-details-content {
    gap: 2.4rem;
  }

  .doctor-details-cta {
    padding-top: 3rem;
  }

  /* Article Content Section */
  .article-content-layout {
    padding: 4rem 0;
    margin: 0;
    gap: 2.4rem;
  }

  main h2 {
    font-size: 2.8rem;
    margin: 2rem 0 2.4rem;
  }

  main h3 {
    font-size: 2.2rem;
    margin: 1.8rem 0 2rem;
  }

  main h4 {
    font-size: 1.8rem;
    margin: 1.6rem 0 2rem;
  }

  main h5 {
    font-size: 1.6rem;
    margin: 1.4rem 0 2rem;
  }

  main h6 {
    font-size: 1.4rem;
    margin: 1.2rem 0 2rem;
  }

  main p {
    font-size: 2rem;
    margin: 0 0 2rem;
  }

  main ul,
  main ol {
    font-size: 2rem;
    margin: 0 0 2rem;
    padding-left: 2rem;
  }

  main li {
    margin: 0 0 1rem;
    padding-left: 0.6rem;
  }

  main ul ul,
  main ol ol,
  main ul ol,
  main ol ul {
    margin: 1rem 0 0;
    padding-left: 2rem;
  }

  .bordered-block {
    padding: 2rem;
    margin: 2rem 0;
  }

  .bordered-block-title {
    font-size: 2.6rem;
    margin: 0 0 1.4rem;
  }

  .cta-block {
    margin: 3rem 0;
  }

  .cta-block-title {
    font-size: 2.8rem;
  }

  .table-of-contents h5 {
    font: var(--font-mobile-heading-6);
    margin: 0;
  }

  .table-of-contents-list {
    gap: 0.6rem;
  }

  .table-of-contents-list a {
    font: var(--font-sm);
  }

  /* Article Share responsive styles moved to components.css */

  .article-related-section {
    padding: 4rem 0;
    margin: 0;
  }

  .article-related-heading {
    font: var(--font-mobile-heading-2);
    margin-bottom: 2.4rem;
  }

  .article-related-slider {
    min-height: auto;
    padding-bottom: 0;
  }

  .article-related-slider .slick-list {
    margin: 0 0 2.4rem;
  }

  .article-card-slide {
    padding: 0 1rem;
  }

  .article-card-content {
    padding: 1.6rem;
  }

  .article-card-title {
    font: var(--font-mobile-heading-4);
    margin-bottom: 1.2rem;
  }

  .article-card-meta {
    gap: 0.6rem;
  }

  /* Article Related Slider Navigation - Responsive styles moved to components.css */

  /* Article Header Section */
  .article-header-section {
    margin-bottom: 2rem;
  }

  .article-header-top {
    margin-bottom: 2rem;
  }

  .article-header-title {
    font: var(--font-mobile-heading-1);
    margin-bottom: 2rem;
  }

  /* Block Slider and Treatment Card responsive styles moved to components.css */

  /* Floating CTA */
  .floating-cta-popup {
    width: calc(100% - 3.2rem);
    bottom: 1.6rem;
  }

  .floating-cta-content {
    gap: 2.4rem;
  }

  .floating-cta-title {
    font-size: 2.8rem;
  }

  .floating-cta-subtitle {
    font-size: 1.4rem;
  }

  .floating-cta-description {
    font-size: 1.4rem;
  }

  .floating-cta-button {
    font-size: 1.4rem;
  }

  .floating-cta-image img {
    max-height: 24rem;
  }

  .block-slider {
    padding: 2.4rem;
    padding-bottom: 3.2rem;
  }

  .block-slider .slick-dots button {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .block-slider .slick-prev,
  .block-slider .slick-next {
    bottom: -35px;
  }
}

@media all and (max-width: 810px) {

}

/* Breakpoint: 767px */
@media all and (max-width: 767px) {
  /* Content container adaptive */
  .content > * > .content,
  main > * > .content {
    padding: 0 1.6rem;
  }

  /* Doctor Details Section */
  .doctor-details-section {
    padding: 3rem 0;
    margin: 2.4rem 0;
  }

  .doctor-details-container {
    padding: 0 1.6rem;
  }

  .doctor-details-heading {
    margin-bottom: 2.4rem;
  }

  .doctor-details-card {
    gap: 1.6rem;
  }

  .doctor-details-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .doctor-details-image {
    max-width: 100%;
    margin: 0 auto;
  }

  .doctor-details-name {
    font: var(--font-mobile-heading-4);
  }

  .doctor-details-cta {
    padding-top: 2.4rem;
  }

  .doctor-details-button {
    padding: 0 2.4rem;
  }

  .cta-block-content { 
    gap: 1.8rem;
  }

  .cta-block-title, .cta-block-description {
    margin-bottom: 1.8rem;
  }

  .line {
    margin-top: 2.4rem;
    margin-bottom: 2.4rem;
  }

  /* Article Content Section */
  .article-content-layout {
    padding: 3rem 0;
    margin: 0;
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .article-sidebar {
    position: static;
    border-top: 1px solid var(--color-gray-200);
    border-bottom: 1px solid var(--color-gray-200);
    padding: 1.2rem;
  }

  .sticky-wrapper {
    position: static;
  }

  .sticky-inside-block {
    position: static;
  }

  .table-of-contents {
    transition: box-shadow 0.3s ease;
  }

  .table-of-contents.toc-sticky {
    border-radius: var(--radius-secondary);
    padding: 1.2rem;
  }

  .table-of-contents-header {
    margin-bottom: 0;
  }

  .table-of-contents h5 {
    margin: 0;
  }

  .table-of-contents-toggle {
    display: flex;
  }

  .table-of-contents-list {
    gap: 0.5rem;
  }

  .table-of-contents-list a {
    font-size: 0.875rem;
    padding: 0.3rem 0;
  }

  .sidebar-nav {
    gap: 1.8rem;
  }

  .sidebar-nav > li:first-child {
    margin-top: 2.4rem;
  }

  .sidebar-nav a {
    padding: 0;
  }

  .table-of-contents.collapsed .table-of-contents-content {
    max-height: 0;
    opacity: 0;
    margin: 0;
    overflow: hidden;
  }

  /* Article Share responsive styles moved to components.css */

  main h2 {
    font-size: 2.4rem;
    margin: 1.8rem 0 2rem;
  }

  main h3 {
    font-size: 2rem;
    margin: 1.6rem 0 1.6rem;
  }

  main h4 {
    font-size: 1.8rem;
    margin: 1.4rem 0 1.6rem;
  }

  main h5 {
    font-size: 1.6rem;
    margin: 1.2rem 0 1.6rem;
  }

  main h6 {
    font-size: 1.4rem;
    margin: 1rem 0 1.6rem;
  }

  main p {
    font-size: 1.8rem;
    margin: 0 0 1.6rem;
  }

  main ul,
  main ol {
    font-size: 1.8rem;
    margin: 0 0 1.6rem;
    padding-left: 1.8rem;
  }

  main li {
    margin: 0 0 0.8rem;
    padding-left: 0.5rem;
  }

  main ul ul,
  main ol ol,
  main ul ol,
  main ol ul {
    margin: 0.8rem 0 0;
    padding-left: 1.8rem;
  }

  main .table-wrapper {
    margin-top: 1.6rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  main table {
    display: block;
    width: 100%;
    min-width: auto;
  }

  main table thead {
    display: none;
  }

  main table tbody {
    display: block;
    width: 100%;
  }

  main table:not(:has(thead)) tbody tr:first-child {
    display: none;
  }

  main table tbody tr {
    display: block;
    width: 100%;
    margin-bottom: 1.6rem;
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-secondary);
    padding: 1.6rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  }

  main table tbody tr:nth-child(even) {
    background: var(--color-white);
  }

  main table tbody td {
    display: block;
    width: 100%;
    padding: 0.8rem 0;
    border: none;
    border-bottom: 1px solid var(--color-gray-200);
    text-align: left;
  }

  main table tbody td:last-child {
    border-bottom: none;
  }

  main table tbody td:before {
    content: attr(data-label);
    font-weight: 600;
    color: var(--color-blue-900);
    display: block;
    margin-bottom: 0.4rem;
    font-size: 1.4rem;
  }

  main table:not(:has(thead)) tbody tr:first-child td p {
    font-size: 1.8rem;
    font-weight: 700;
  }

  main table th p {
    font-size: 1.8rem;
    font-weight: 700;
  }

  main table tbody td[data-label='Collected'] {
    text-align: left;
    padding-top: 1.2rem;
    border-top: 1px solid var(--color-gray-200);
    margin-top: 0.8rem;
  }

  main table tbody td[data-label='Collected']:before {
    margin-bottom: 0.8rem;
  }

  .bordered-block {
    padding: 1.8rem;
    margin: 1.8rem 0;
  }

  .bordered-block-title {
    font-size: 2.4rem;
    margin: 0 0 1.2rem;
  }

  .bordered-block-content {
    font-size: 1.6rem;
  }

  .bordered-block-content p {
    margin: 0 0 1.2rem;
  }

  .cta-block {
    margin: 2.4rem 0;
  }

  .cta-block-title {
    font-size: 2.4rem;
  }

  .cta-block-button {
    width: 100%;
  }

  .article-disclaimer {
    margin: 2rem 0 0;
  }

  .article-disclaimer-text {
    font-size: 1.4rem;
  }

  .article-related-section {
    padding: 3.2rem 0;
    margin: 0;
  }

  .article-related-heading {
    margin-bottom: 2rem;
  }

  .article-related-slider {
    min-height: auto;
    padding-bottom: 0;
  }

  .article-related-slider .slick-list {
    margin: 0 0 2rem;
  }

  .article-card-slide {
    padding: 0 0.8rem;
  }

  .article-card-content {
    padding: 1.4rem;
  }

  .article-card-title {
    margin-bottom: 1rem;
  }

  .article-card-meta-item {
    gap: 0.5rem;
  }

  .article-card-meta-item svg {
    width: 1.6rem;
    height: 1.6rem;
  }

  .article-related-slider-nav {
    gap: 1rem;
  }

  /* Article Related Slider Navigation - Responsive styles moved to components.css */

  /* Article Header Section */
  .article-header-section {
    margin-bottom: 1.6rem;
  }

  .article-breadcrumbs {
    margin-bottom: 2.4rem;
    gap: 0.6rem;
  }

  .article-header-tags {
    gap: 0.8rem;
  }

  .article-header-tag {
    padding: 0.6rem 1rem;
    font-size: 1.2rem;
  }

  .article-header-read-time {
    gap: 0.5rem;
  }

  .article-header-read-time svg {
    width: 1.6rem;
    height: 1.6rem;
  }

  .article-header-top {
    margin-bottom: 1.6rem;
  }

  .article-header-title {
    font: var(--font-mobile-heading-1);
    margin-bottom: 1.6rem;
  }

  .article-header-author {
    gap: 1rem;
  }

  /* Block Slider and Treatment Card responsive styles moved to components.css */

  /* Floating CTA */
  .floating-cta-popup {
    max-width: 100%;
    width: calc(100% - 2.4rem);
    bottom: 1.2rem;
  }

  .floating-cta-card {
    padding: 0.8rem;
  }

  .floating-cta-content {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .floating-cta-text {
    order: 1;
    padding: 0;
    gap: 0.6rem;
  }

  .floating-cta-image {
    grid-row: 1;
    min-height: 20rem;
  }

  .floating-cta-image img {
    max-height: 20rem;
    position: relative;
  }

  .floating-cta-title {
    font-size: 2.4rem;
  }

  .floating-cta-subtitle {
    font-size: 1.3rem;
  }

  .floating-cta-description {
    font-size: 1.3rem;
  }

  .floating-cta-button-container {
    width: 100%;
  }

  .floating-cta-button {
    width: 100%;
    border-top: solid 12px transparent;
    border-bottom: solid 12px transparent;
  }

  .floating-cta-close {
    width: 3.2rem;
    height: 3.2rem;
  }


  .block-slider .slick-prev, .block-slider .slick-next {
      bottom: -25px;
  }

  .block-slider .slick-prev {
    right: 65px;
  }
}

/* Breakpoint: 480px */
@media all and (max-width: 480px) {
  /* Content container adaptive */
  .content > * > .content,
  main > * > .content {
    padding: 0 1.2rem;
  }

  /* Doctor Details Section */
  .doctor-details-section {
    padding: 2.4rem 0;
    margin: 2rem 0;
  }

  .doctor-details-image {
    min-width: 100%;
  }

  .doctor-details-container {
    padding: 0 1.2rem;
  }

  .doctor-details-card {
    gap: 1.4rem;
  }

  .doctor-details-content {
    gap: 1.6rem;
  }

  .doctor-details-info {
    padding: 1rem;
    gap: 1.4rem;
  }

  .doctor-details-heading {
    margin-bottom: 2rem;
  }

  .doctor-details-cta {
    padding-top: 2rem;
  }

  .doctor-details-button-container {
    width: calc(100% - 2.4rem);
  }

  .doctor-details-button {
    padding: 0 2rem;
    width: 100%;
    font-size: 1.4rem;
  }

  /* Article Content Section */
  .article-content-layout {
    padding: 2.4rem 0;
    margin: 0;
  }

  main h2 {
    font-size: 2rem;
    margin: 1.6rem 0 1.6rem;
  }

  main h3 {
    font-size: 1.8rem;
    margin: 1.4rem 0 1.2rem;
  }

  main h4 {
    font-size: 1.6rem;
    margin: 1.2rem 0 1.2rem;
  }

  main h5 {
    font-size: 1.4rem;
    margin: 1rem 0 1.2rem;
  }

  main h6 {
    margin: 0.8rem 0 1.2rem;
  }

  main p {
    margin: 0 0 1.2rem;
  }

  main ul,
  main ol {
    font-size: 1.6rem;
    margin: 0 0 1.2rem;
    padding-left: 1.6rem;
  }

  main li {
    margin: 0 0 0.6rem;
    padding-left: 0.4rem;
  }

  main ul ul,
  main ol ol,
  main ul ol,
  main ol ul {
    margin: 0.6rem 0 0;
    padding-left: 1.6rem;
  }

  .bordered-block {
    padding: 1.6rem;
    margin: 1.6rem 0;
  }

  .bordered-block-title {
    font-size: 2rem;
    margin: 0 0 1rem;
  }

  .bordered-block-content {
    font-size: 1.4rem;
  }

  .doctor-details-image {
    width: 100%;
    height: auto;
  }

  .bordered-block-content p {
    margin: 0 0 1rem;
  }

  .bordered-block-content ul,
  .bordered-block-content ol {
    margin: 1rem 0;
    padding-left: 1.6rem;
  }

  .cta-block {
    margin: 2rem 0;
  }

  .cta-block-button-container {
    width: 100%;
  }

  .cta-block-image {
    width: 100%;
    height: auto;
  }

  .table-of-contents h5 {
    margin: 0;
  }

  .table-of-contents-toggle {
    display: flex;
  }

  main table tbody tr {
    padding: 1.2rem;
    margin-bottom: 1.2rem;
  }

  main table tbody td {
    font-size: 1.6rem;
    padding: 0.6rem 0;
  }

  main table tbody td:before {
    font-size: 1.3rem;
  }

  main table:not(:has(thead)) tbody tr:first-child td p {
    font-size: 1.6rem;
    font-weight: 700;
  }

  main table th p {
    font-size: 1.6rem;
    font-weight: 700;
  }

  .article-share {
    margin: 2rem 0 0;
    padding: 1.6rem 1.2rem;
  }

  .article-share-item-title {
    font: var(--font-mobile-heading-6);
    margin-bottom: 0.4rem;
  }

  .article-share-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.4rem;
  }

  .article-share-item {
    width: 100%;
  }

  .article-share-buttons {
    justify-content: flex-start;
    width: 100%;
    gap: 0.6rem;
    flex-wrap: wrap;
  }

  .article-share-buttons a svg {
    width: 1.4rem;
    height: 1.4rem;
  }

  .article-disclaimer {
    margin: 1.6rem 0 0;
  }

  .article-disclaimer-text {
    font-size: 1.3rem;
    line-height: 1.5;
  }

  .article-related-section {
    padding: 2.4rem 0;
    margin: 0;
  }

  .article-related-heading {
    margin-bottom: 1.6rem;
  }

  .article-related-slider {
    min-height: auto;
    padding-bottom: 0;
  }

  .article-related-slider .slick-list {
    margin: 0 0 1.6rem;
  }

  .article-card-slide {
    padding: 0 0.6rem;
  }

  .article-card-content {
    padding: 1.2rem;
  }

  .article-card-title {
    margin-bottom: 0.8rem;
  }

  .article-card-meta {
    gap: 0.5rem;
    font-size: 0.75rem;
  }

  .article-card-meta-item svg {
    width: 1.4rem;
    height: 1.4rem;
  }

  .article-card-category-tag {
    top: 1rem;
    left: 1rem;
    padding: 0.3rem 0.8rem;
    font-size: 0.65rem;
  }

  .article-related-slider-nav {
    gap: 0.8rem;
  }

  /* Article Related Slider Navigation - Responsive styles moved to components.css */

  /* Article Header Section */
  .article-header-section {
    margin-bottom: 1.2rem;
  }

  .article-header-tag {
    padding: 0.5rem 0.8rem;
  }

  /* Block Slider and Treatment Card responsive styles moved to components.css */

  /* Floating CTA */
  .floating-cta-popup {
    max-width: 100%;
    width: calc(100% - 1.6rem);
    bottom: 0.8rem;
  }

  .floating-cta-content {
    gap: 1.4rem;
  }

  .floating-cta-text {
    padding: 0;
    gap: 0.5rem;
  }

  .floating-cta-image {
    min-height: 16rem;
  }

  .floating-cta-image img {
    max-height: 16rem;
    position: relative;
  }

  .floating-cta-title {
    font-size: 2rem;
  }

  .floating-cta-button {
    border-top: solid 10px transparent;
    border-bottom: solid 10px transparent;
  }
}
