[data-vertical-spacing*="bottom"] {
  padding-bottom: 0 !important;
}

[data-vertical-spacing*="top"] {
  padding-top: 0 !important;
}

section {
  margin-bottom: 0 !important;
}

html {
  scroll-behavior: smooth;
}

/* Add offset for sticky header when using anchors */
#home-care,
#medical-support,
#caregiver-assistance,
#in-home-solutions,
#cp-sv-faq,
#cp-sv-cta {
  scroll-margin-top: 120px;
}

/* ========================================
   CAREPRO HERO SECTION
   Clean full-width luxury hero
======================================== */

.cp-hero.alignfull {
  position: relative !important;
  overflow: hidden !important;
  background: #0b1220 !important;
  min-height: calc(100vh - 90px) !important;
  padding: 120px 0 80px !important;
}

/* Hero background */
.cp-hero__bg {
  position: absolute !important;
  inset: 0 !important;
}

.cp-hero__bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scale(1.06) !important;
}

/* ========================================
   HERO OVERLAY (LUXURY VERSION)
   Deep gradient + warm tone + focus
======================================== */

.cp-hero__overlay {
  position: absolute;
  inset: 0;

  background:
    /* Left dark focus for text */
    linear-gradient(
      90deg,
      rgba(8, 12, 20, 0.92) 0%,
      rgba(8, 12, 20, 0.82) 28%,
      rgba(8, 12, 20, 0.65) 48%,
      rgba(8, 12, 20, 0.38) 70%,
      rgba(8, 12, 20, 0.55) 100%
    ),
    /* Warm luxury tone */
    linear-gradient(
        120deg,
        rgba(215, 191, 156, 0.12) 0%,
        rgba(215, 191, 156, 0.05) 40%,
        rgba(255, 255, 255, 0.03) 100%
      ),
    /* Soft vertical depth */
    linear-gradient(180deg, rgba(6, 10, 18, 0.2) 0%, rgba(6, 10, 18, 0.55) 100%);

  z-index: 1;
}

/* Slight darkening + contrast for better readability */
.cp-hero__bg img {
  filter: brightness(0.85) contrast(1.05);
}

/* Decorative glow */
.cp-hero__glow {
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 2 !important;
}

.cp-hero__glow--one {
  background: radial-gradient(
    circle at 18% 28%,
    rgba(215, 191, 156, 0.16),
    transparent 36%
  ) !important;
}

.cp-hero__glow--two {
  background: radial-gradient(
    circle at 82% 72%,
    rgba(255, 255, 255, 0.1),
    transparent 32%
  ) !important;
}

/* Main container */
.cp-hero__container {
  position: relative !important;
  z-index: 3 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 450px) !important;
  gap: 36px !important;
  align-items: center !important;
}

/* Left content */
.cp-hero__content {
  max-width: 760px !important;
}

.cp-hero__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 16px !important;
  margin: 0 0 18px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  color: #e3cfb4 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.cp-hero__title {
  margin: 0 0 22px !important;
  color: #ffffff !important;
  font-size: clamp(48px, 6vw, 82px) !important;
  line-height: 1.02 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-hero__text {
  max-width: 640px !important;
  margin: 0 0 30px !important;
  color: rgba(255, 255, 255, 0.84) !important;
  font-size: clamp(16px, 1.4vw, 19px) !important;
  line-height: 1.75 !important;
}

/* ========================================
   GLOBAL BUTTON SYSTEM
======================================== */

.cp-btn-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 0 0 34px !important;
}

.cp-btn {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 58px !important;
  padding: 0 26px !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  overflow: hidden !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  line-height: 1 !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    border-color 0.45s ease,
    background-color 0.45s ease,
    color 0.45s ease !important;
  z-index: 1 !important;
}

.cp-btn__text {
  position: relative !important;
  z-index: 3 !important;
}

.cp-btn::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  border-radius: inherit !important;
  opacity: 0 !important;
  transition: opacity 0.45s ease !important;
  z-index: 1 !important;
}

.cp-btn::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: -120% !important;
  width: 70% !important;
  height: 100% !important;
  background: linear-gradient(
    115deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.32) 50%,
    rgba(255, 255, 255, 0) 100%
  ) !important;
  transform: skewX(-24deg) !important;
  transition: left 0.8s ease !important;
  z-index: 2 !important;
  pointer-events: none !important;
}

.cp-btn:hover {
  transform: translateY(-4px) scale(1.01) !important;
}

.cp-btn:hover::before {
  opacity: 1 !important;
}

.cp-btn:hover::after {
  left: 150% !important;
}

.cp-btn--primary {
  color: #111827 !important;
  background: linear-gradient(
    135deg,
    #f8f2ea 0%,
    #dcc5a7 40%,
    #f6efe7 100%
  ) !important;
  box-shadow: 0 10px 30px rgba(220, 197, 167, 0.25) !important;
}

.cp-btn--primary::before {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.46) 0%,
    rgba(255, 255, 255, 0.12) 46%,
    rgba(220, 197, 167, 0.2) 100%
  ) !important;
}

.cp-btn--primary:hover {
  color: #0b1220 !important;
  box-shadow:
    0 24px 48px rgba(220, 197, 167, 0.36),
    0 12px 24px rgba(0, 0, 0, 0.16) !important;
}

.cp-btn--outline {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.24) !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

.cp-btn--outline::before {
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.18) 0%,
    rgba(255, 255, 255, 0.12) 50%,
    rgba(255, 255, 255, 0.03) 100%
  ) !important;
}

.cp-btn--outline:hover {
  color: #ffffff !important;
  border-color: rgba(220, 197, 167, 0.58) !important;
  box-shadow:
    0 20px 40px rgba(0, 0, 0, 0.24),
    0 0 0 1px rgba(220, 197, 167, 0.14) inset !important;
}

/* ========================================
   FEATURE ITEMS
======================================== */

.cp-hero__features {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  max-width: 760px !important;
}

.cp-hero__feature {
  padding: 18px 18px !important;
  border-radius: 22px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  transition:
    transform 0.45s ease,
    background-color 0.45s ease,
    border-color 0.45s ease,
    box-shadow 0.45s ease !important;
}

.cp-hero__feature:hover {
  transform: translateY(-6px) !important;
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(220, 197, 167, 0.32) !important;
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.16) !important;
}

.cp-hero__feature-num {
  display: block !important;
  margin: 0 0 8px !important;
  color: #dcc5a7 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
}

.cp-hero__feature-text {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1.45 !important;
}

/* ========================================
   RIGHT GLASS CARD
======================================== */

.cp-hero__card-wrap {
  display: flex !important;
  justify-content: flex-end !important;
}

/* Luxury glass enhancement */
.cp-hero__card {
  width: 100% !important;
  max-width: 450px !important;
  border-radius: 34px !important;
  overflow: hidden !important;
  backdrop-filter: blur(18px) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.3) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.cp-hero__card-image {
  position: relative !important;
  overflow: hidden !important;
  aspect-ratio: 0.96 / 1 !important;
}

.cp-hero__card-image::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    180deg,
    rgba(8, 14, 24, 0.04) 0%,
    rgba(8, 14, 24, 0.42) 100%
  ) !important;
}

.cp-hero__card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scale(1) !important;
  transition: transform 0.8s ease !important;
}

.cp-hero__card:hover .cp-hero__card-image img {
  transform: scale(1.15) !important;
}

.cp-hero__card-content {
  padding: 24px 24px 26px !important;
}

.cp-hero__card-label {
  display: inline-block !important;
  margin: 0 0 12px !important;
  color: #dcc5a7 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.cp-hero__card-title {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: clamp(24px, 2.1vw, 31px) !important;
  line-height: 1.18 !important;
  font-weight: 700 !important;
}

.cp-hero__card-text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
}

/* ========================================
   REVEAL ANIMATION
======================================== */

.sr-item {
  opacity: 0 !important;
  transform: translateY(60px) !important;
  transition:
    opacity 0.85s ease,
    transform 0.85s ease !important;
  transition-delay: calc(var(--sr-delay, 0) * 140ms) !important;
}

.sr-left {
  transform: translateX(-60px) !important;
}

.sr-item.is-visible {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
}

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

@media (max-width: 1180px) {
  .cp-hero__container {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .cp-hero__card-wrap {
    justify-content: flex-start !important;
  }
}

@media (max-width: 767px) {
  .cp-hero.alignfull {
    min-height: auto !important;
    padding: 110px 0 70px !important;
  }

  .cp-hero__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-hero__title {
    font-size: clamp(36px, 10vw, 50px) !important;
    line-height: 1.04 !important;
  }

  .cp-hero__text {
    font-size: 15px !important;
  }

  .cp-btn-row {
    gap: 10px !important;
  }

  .cp-btn-row .cp-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    padding: 0 14px !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
  }

  .cp-hero__features {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .cp-hero__feature:last-child {
    grid-column: 1 / -1 !important;
  }

  .cp-hero__card {
    max-width: 100% !important;
  }

  .cp-hero__card-content {
    padding: 20px 18px 22px !important;
  }
}

@media (max-width: 480px) {
  .cp-hero__feature {
    padding: 14px 12px !important;
  }

  .cp-hero__feature-text {
    font-size: 13px !important;
  }
}

/* ========================================
   CAREPRO ABOUT SECTION
   Luxury full-width background and layout
======================================== */

.cp-about.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 110px 0 !important;
  background:
    radial-gradient(
      circle at 12% 18%,
      rgba(219, 196, 166, 0.12) 0%,
      transparent 28%
    ),
    radial-gradient(
      circle at 88% 78%,
      rgba(255, 255, 255, 0.06) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #07101f 0%, #06101d 48%, #050d18 100%) !important;
}

/* Decorative glow shapes */
.cp-about__bg-shape {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(60px) !important;
  pointer-events: none !important;
  opacity: 0.9 !important;
}

.cp-about__bg-shape--one {
  top: 80px !important;
  left: -80px !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(220, 197, 167, 0.12) !important;
}

.cp-about__bg-shape--two {
  right: -120px !important;
  bottom: 30px !important;
  width: 320px !important;
  height: 320px !important;
  background: rgba(53, 101, 173, 0.12) !important;
}

/* Fine grid texture */
.cp-about__grid {
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px) !important;
  background-size: 90px 90px !important;
  mask-image: radial-gradient(
    circle at center,
    black 40%,
    transparent 100%
  ) !important;
  opacity: 0.26 !important;
  pointer-events: none !important;
}

/* Main content container */
.cp-about__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 56px !important;
  align-items: center !important;
}

/* ========================================
   LEFT VISUAL SIDE
======================================== */
/* About section spacing refinement */

.cp-about__visual {
  position: relative !important;
  padding: 34px 0 34px 34px !important;
}

/* Main image card */
.cp-about__image-card {
  position: relative !important;
  max-width: 620px !important;
  margin: 0 !important;
}

.cp-about__image-card::before {
  content: "" !important;
  position: absolute !important;
  inset: -16px 60px 60px -16px !important;
  border-radius: 34px !important;
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.16),
    rgba(255, 255, 255, 0.03)
  ) !important;
  z-index: -1 !important;
}

.cp-about__image-wrap {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 34px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.28) !important;
}

.cp-about__image-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    180deg,
    rgba(7, 12, 22, 0.02) 0%,
    rgba(7, 12, 22, 0.22) 100%
  ) !important;
  pointer-events: none !important;
}

.cp-about__image-wrap img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1 / 1.02 !important;
  object-fit: cover !important;
  transform: scale(1) !important;
  transition: transform 0.8s ease !important;
}

.cp-about__image-wrap:hover img {
  transform: scale(1.15) !important;
}

/* Floating stat card */
.cp-about__stat-card {
  position: absolute !important;
  right: 0 !important;
  bottom: 0 !important;
  width: min(320px, 78%) !important;
  padding: 22px 22px !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.cp-about__stat-number {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  margin: 0 0 14px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #f8f2ea 0%, #dcc5a7 100%) !important;
  color: #111827 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
}

.cp-about__stat-title {
  margin: 0 0 10px !important;
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1.18 !important;
  font-weight: 700 !important;
}

.cp-about__stat-text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: 15px !important;
  line-height: 1.68 !important;
}

/* ========================================
   RIGHT CONTENT SIDE
======================================== */

.cp-about__content {
  position: relative !important;
}

.cp-about__label {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(220, 197, 167, 0.82) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

/* About section title size refinement */
.cp-about__title {
  margin: 0 0 24px !important;
  color: #ffffff !important;
  font-size: clamp(34px, 3.6vw, 58px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-about__text {
  max-width: 640px !important;
  margin: 0 0 28px !important;
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: clamp(16px, 1.25vw, 18px) !important;
  line-height: 1.9 !important;
}

/* ========================================
   FEATURE LIST
======================================== */

.cp-about__features {
  display: grid !important;
  gap: 14px !important;
  margin: 0 0 28px !important;
}

.cp-about__feature {
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: flex-start !important;
  padding: 18px 18px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  transition:
    transform 0.45s ease,
    background-color 0.45s ease,
    border-color 0.45s ease,
    box-shadow 0.45s ease !important;
}

.cp-about__feature:hover {
  transform: translateY(-6px) !important;
  background: rgba(255, 255, 255, 0.07) !important;
  border-color: rgba(220, 197, 167, 0.2) !important;
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.16) !important;
}

.cp-about__feature-number {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: #dcc5a7 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
}

.cp-about__feature-title {
  margin: 0 0 8px !important;
  color: #ffffff !important;
  font-size: 20px !important;
  line-height: 1.24 !important;
  font-weight: 700 !important;
}

.cp-about__feature-text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.74) !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
}

/* Reuse global button row spacing */
.cp-about__actions {
  margin-bottom: 0 !important;
}

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

@media (max-width: 1180px) {
  .cp-about__container {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  .cp-about__visual {
    padding: 0 0 120px !important;
  }

  .cp-about__image-card {
    max-width: 100% !important;
  }

  .cp-about__stat-card {
    right: 0 !important;
    bottom: 0 !important;
  }
}

@media (max-width: 767px) {
  .cp-about.alignfull {
    padding: 90px 0 !important;
  }

  .cp-about__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-about__visual {
    padding: 0 0 0 !important;
  }

  .cp-about__stat-card {
    position: relative !important;
    width: 100% !important;
    margin-top: 18px !important;
  }

  .cp-about__feature {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    gap: 14px !important;
    padding: 16px 14px !important;
  }

  .cp-about__feature-title {
    font-size: 18px !important;
  }

  .cp-about__feature-text {
    font-size: 14px !important;
  }
}

/* ========================================
   SERVICES SECTION (Luxury Cards)
======================================== */

.cp-services {
  padding: 120px 0 !important;
  background: #ffffff !important;
}

/* CONTAINER */
.cp-services__container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* INTRO */
.cp-services__label {
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.cp-services__title {
  font-size: clamp(32px, 3.5vw, 52px) !important;
  margin: 15px 0 !important;
}

.cp-services__text {
  color: rgba(0, 0, 0, 0.6) !important;
  max-width: 600px !important;
}

/* GRID */
.cp-services__grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  margin-top: 70px !important;
  gap: 35px !important;
  border: 1px solid rgba(0, 0, 0, 0.04) !important;
}

/* CARD */
.cp-service-card {
  border-radius: 20px !important;
  overflow: hidden !important;
  background: #fff !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05) !important;
  transition:
    transform 0.4s ease,
    box-shadow 0.4s ease !important;
}

.cp-service-card:hover {
  transform: translateY(-12px) !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.12) !important;
}

.cp-service-card img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

/* IMAGE */
.cp-service-card__image {
  overflow: hidden !important;
}

.cp-service-card__image img {
  width: 100% !important;
  height: 240px !important;
  object-fit: cover !important;
  transition: transform 0.7s ease !important;
}

.cp-service-card:hover img {
  transform: scale(1.15) !important;
}

/* CONTENT */
.cp-service-card__content {
  padding: 20px !important;
}

.cp-service-card__number {
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.cp-service-card h3 {
  margin: 10px 0 !important;
  font-size: 20px !important;
}

.cp-service-card p {
  color: rgba(0, 0, 0, 0.6) !important;
  font-size: 14px !important;
}

/* MOBILE */
@media (max-width: 900px) {
  .cp-services__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ========================================
   CAREPRO WHY CHOOSE US SECTION
   Luxury wow background + premium cards
======================================== */

.cp-why.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 125px 0 !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(220, 197, 167, 0.12) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 88% 80%,
      rgba(43, 97, 173, 0.16) 0%,
      transparent 24%
    ),
    linear-gradient(120deg, #06101d 0%, #04101b 42%, #030d17 100%) !important;
}

/* Soft glow shapes */
.cp-why__bg {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(80px) !important;
  pointer-events: none !important;
  opacity: 0.95 !important;
}

.cp-why__bg--one {
  top: -80px !important;
  left: -120px !important;
  width: 360px !important;
  height: 360px !important;
  background: rgba(220, 197, 167, 0.1) !important;
}

.cp-why__bg--two {
  right: -100px !important;
  bottom: -40px !important;
  width: 360px !important;
  height: 360px !important;
  background: rgba(42, 103, 190, 0.12) !important;
}

/* Subtle grid texture */
.cp-why__grid {
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px) !important;
  background-size: 84px 84px !important;
  mask-image: radial-gradient(
    circle at center,
    black 44%,
    transparent 100%
  ) !important;
  opacity: 0.28 !important;
  pointer-events: none !important;
}

/* Main container */
.cp-why__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.02fr) !important;
  gap: 68px !important;
  align-items: center !important;
}

/* ========================================
   LEFT CONTENT
======================================== */

.cp-why__content {
  max-width: 620px !important;
}

.cp-why__label {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(220, 197, 167, 0.82) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.cp-why__title {
  margin: 0 0 24px !important;
  color: #ffffff !important;
  font-size: clamp(34px, 4vw, 60px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-why__text {
  max-width: 580px !important;
  margin: 0 0 34px !important;
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: clamp(16px, 1.2vw, 18px) !important;
  line-height: 1.9 !important;
}

.cp-why__actions {
  margin-bottom: 0 !important;
}

/* ========================================
   RIGHT CARD GRID
======================================== */

.cp-why__cards {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 22px !important;
}

/* Premium card */
.cp-why-card {
  position: relative !important;
  padding: 28px 26px !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.06) 0%,
    rgba(255, 255, 255, 0.04) 100%
  ) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.2) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  transition:
    transform 0.45s ease,
    border-color 0.45s ease,
    box-shadow 0.45s ease,
    background 0.45s ease !important;
}

.cp-why-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.08),
    transparent 45%,
    rgba(255, 255, 255, 0.04)
  ) !important;
  opacity: 0.9 !important;
  pointer-events: none !important;
}

.cp-why-card:hover {
  transform: translateY(-10px) !important;
  border-color: rgba(220, 197, 167, 0.22) !important;
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.28) !important;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.08) 0%,
    rgba(255, 255, 255, 0.05) 100%
  ) !important;
}

.cp-why-card__number {
  display: inline-block !important;
  margin: 0 0 14px !important;
  color: rgba(220, 197, 167, 0.7) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  line-height: 1 !important;
  position: relative !important;
  z-index: 1 !important;
}

.cp-why-card__title {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: 22px !important;
  line-height: 1.24 !important;
  font-weight: 700 !important;
  position: relative !important;
  z-index: 1 !important;
}

.cp-why-card__text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.74) !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
  position: relative !important;
  z-index: 1 !important;
}

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

@media (max-width: 1180px) {
  .cp-why__container {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }
}

@media (max-width: 767px) {
  .cp-why.alignfull {
    padding: 90px 0 !important;
  }

  .cp-why__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-why__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }

  .cp-why-card {
    padding: 18px 16px !important;
    border-radius: 20px !important;
  }

  .cp-why-card__title {
    font-size: 18px !important;
  }

  .cp-why-card__text {
    font-size: 14px !important;
  }
}

/* ========================================
   CAREPRO PROCESS SECTION
   Editorial luxury workflow section
======================================== */

.cp-process.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 125px 0 !important;
  background:
    radial-gradient(
      circle at 15% 20%,
      rgba(220, 197, 167, 0.15),
      transparent 30%
    ),
    radial-gradient(
      circle at 85% 80%,
      rgba(60, 110, 200, 0.08),
      transparent 30%
    ),
    linear-gradient(180deg, #f8fafc, #eef2f7) !important;
}

/* Decorative background shapes */
.cp-process__bg {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(72px) !important;
  pointer-events: none !important;
  opacity: 0.9 !important;
}

.cp-process__bg--one {
  top: -90px !important;
  left: -90px !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(220, 197, 167, 0.16) !important;
}

.cp-process__bg--two {
  right: -100px !important;
  bottom: -70px !important;
  width: 320px !important;
  height: 320px !important;
  background: rgba(42, 103, 190, 0.08) !important;
}

/* Fine texture */
.cp-process__texture {
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(16, 34, 60, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16, 34, 60, 0.03) 1px, transparent 1px) !important;
  background-size: 88px 88px !important;
  mask-image: radial-gradient(
    circle at center,
    black 46%,
    transparent 100%
  ) !important;
  opacity: 0.34 !important;
  pointer-events: none !important;
}

/* Main container */
.cp-process__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
  gap: 72px !important;
  align-items: center !important;
}

/* ========================================
   LEFT VISUAL
======================================== */

.cp-process__visual {
  position: relative !important;
  padding: 30px 70px 110px 0 !important;
}

.cp-process__image-card {
  position: relative !important;
  max-width: 560px !important;
}

.cp-process__image-card::before {
  content: "" !important;
  position: absolute !important;
  inset: -16px 70px 70px -16px !important;
  border-radius: 34px !important;
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.16),
    rgba(255, 255, 255, 0.06)
  ) !important;
  z-index: -1 !important;
}

.cp-process__image-wrap {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 34px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(16, 34, 60, 0.08) !important;
  box-shadow: 0 28px 70px rgba(18, 34, 58, 0.12) !important;
}

.cp-process__image-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    180deg,
    rgba(16, 34, 60, 0.02) 0%,
    rgba(16, 34, 60, 0.18) 100%
  ) !important;
  pointer-events: none !important;
}

.cp-process__image-wrap img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 0.96 / 1.08 !important;
  object-fit: cover !important;
  transform: scale(1) !important;
  transition: transform 0.8s ease !important;
}

.cp-process__image-wrap:hover img {
  transform: scale(1.15) !important;
}

/* Floating card */
.cp-process__floating-card {
  position: absolute !important;
  right: 0 !important;
  bottom: 0 !important;
  width: min(320px, 78%) !important;
  padding: 22px 22px !important;
  border-radius: 28px !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  background: linear-gradient(135deg, #0f223c, #1b3558) !important;
  box-shadow: 0 30px 80px rgba(16, 34, 60, 0.35) !important;
}

.cp-process__floating-number {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  margin: 0 0 14px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #f8f2ea 0%, #dcc5a7 100%) !important;
  color: #111827 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
}

.cp-process__floating-title {
  margin: 0 0 10px !important;
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1.18 !important;
  font-weight: 700 !important;
}

.cp-process__floating-text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: 15px !important;
  line-height: 1.68 !important;
}

/* ========================================
   RIGHT CONTENT
======================================== */

.cp-process__content {
  position: relative !important;
}

.cp-process__label {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(16, 34, 60, 0.54) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.cp-process__title {
  margin: 0 0 22px !important;
  color: #10223c !important;
  font-size: clamp(30px, 3vw, 48px) !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-process__text {
  max-width: 620px !important;
  margin: 0 0 34px !important;
  color: rgba(16, 34, 60, 0.72) !important;
  font-size: clamp(16px, 1.15vw, 18px) !important;
  line-height: 1.88 !important;
}

/* ========================================
   VERTICAL FLOW
======================================== */

.cp-process__flow {
  position: relative !important;
  display: grid !important;
  gap: 22px !important;
  margin: 0 0 34px !important;
  padding-left: 18px !important;
}

.cp-process__line {
  position: absolute !important;
  top: 10px !important;
  bottom: 10px !important;
  left: 23px !important;
  width: 2px !important;
  background: linear-gradient(
    180deg,
    rgba(220, 197, 167, 0.7) 0%,
    rgba(16, 34, 60, 0.12) 100%
  ) !important;
}

/* Step row */
.cp-process-step {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 46px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: start !important;
}

.cp-process-step__marker {
  position: relative !important;
  z-index: 2 !important;
}

.cp-process-step__marker span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 46px !important;
  height: 46px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #f8f2ea 0%, #dcc5a7 100%) !important;
  color: #111827 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  box-shadow: 0 14px 28px rgba(220, 197, 167, 0.22) !important;
}

.cp-process-step__card {
  padding: 22px 22px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid rgba(16, 34, 60, 0.06) !important;
  box-shadow: 0 18px 44px rgba(18, 34, 58, 0.08) !important;
  transition:
    transform 0.45s ease,
    border-color 0.45s ease,
    box-shadow 0.45s ease !important;
}

.cp-process-step__card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 30px 70px rgba(16, 34, 60, 0.12) !important;
  border-color: rgba(220, 197, 167, 0.28) !important;
}

.cp-process-step__title {
  margin: 0 0 10px !important;
  color: #10223c !important;
  font-size: 22px !important;
  line-height: 1.22 !important;
  font-weight: 700 !important;
}

.cp-process-step__text {
  margin: 0 !important;
  color: rgba(16, 34, 60, 0.72) !important;
  font-size: 15px !important;
  line-height: 1.72 !important;
}

/* Shared button row spacing */
.cp-process__actions {
  margin-bottom: 0 !important;
}

.cp-process__actions .cp-btn--outline,
.cp-sv-service__actions .cp-btn--outline {
  background: rgb(52 67 90) !important;
}

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

@media (max-width: 1180px) {
  .cp-process__container {
    grid-template-columns: 1fr !important;
    gap: 42px !important;
  }

  .cp-process__visual {
    padding: 0 0 120px !important;
  }

  .cp-process__image-card {
    max-width: 100% !important;
  }
}

@media (max-width: 767px) {
  .cp-process.alignfull {
    padding: 90px 0 !important;
  }

  .cp-process__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-process__visual {
    padding: 0 !important;
  }

  .cp-process__floating-card {
    position: relative !important;
    width: 100% !important;
    margin-top: 18px !important;
  }

  .cp-process__flow {
    gap: 16px !important;
    padding-left: 0 !important;
  }

  .cp-process__line {
    left: 22px !important;
  }

  .cp-process-step {
    grid-template-columns: 46px minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  .cp-process-step__card {
    padding: 18px 16px !important;
    border-radius: 20px !important;
  }

  .cp-process-step__title {
    font-size: 18px !important;
  }

  .cp-process-step__text {
    font-size: 14px !important;
  }
}

/* ========================================
   CAREPRO CTA SECTION
======================================== */

.cp-cta.alignfull {
  position: relative !important;
  overflow: hidden !important;
  min-height: 80vh !important;
  display: flex !important;
  align-items: center !important;
}

/* Background image */
.cp-cta__bg {
  position: absolute !important;
  inset: 0 !important;
  background: url("/wp-content/uploads/bg-cta.webp") center/cover no-repeat !important;
  background-attachment: fixed !important;
  transform: scale(1.05) !important;
  animation: subtleZoom 20s ease-in-out infinite alternate;
}

@keyframes subtleZoom {
  from {
    transform: scale(1.05);
  }
  to {
    transform: scale(1.12);
  }
}

/* Overlay */
.cp-cta__overlay {
  position: absolute !important;
  inset: 0 !important;

  background:
    linear-gradient(180deg, rgba(6, 16, 29, 0.65), rgba(6, 16, 29, 0.92)),
    radial-gradient(
      circle at 50% 40%,
      rgba(220, 197, 167, 0.15),
      transparent 60%
    ) !important;
}

/* Content */
.cp-cta__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1100px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.cp-cta__label {
  display: inline-block !important;
  color: rgba(220, 197, 167, 0.8) !important;
  letter-spacing: 2px !important;
  margin-bottom: 20px !important;
  position: relative;
}

.cp-cta__label::after {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  margin: 10px auto 0;
  background: rgba(220, 197, 167, 0.5);
}

/* Title */
.cp-cta__title {
  font-size: clamp(36px, 5vw, 64px) !important;
  line-height: 1.1 !important;
  color: #fff !important;
  margin-bottom: 20px !important;
  background: linear-gradient(180deg, #ffffff 0%, #e8e3da 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Text */
.cp-cta__text {
  max-width: 600px !important;
  margin: 0 auto 30px !important;
  color: rgba(255, 255, 255, 0.8) !important;
}

/* Buttons */
.cp-cta__actions {
  justify-content: center !important;
}

/* Mobile */
@media (max-width: 768px) {
  .cp-cta.alignfull {
    min-height: 70vh !important;
  }

  .cp-cta__title {
    font-size: 32px !important;
  }
}

/* ========================================
   CAREPRO FAQ SECTION
   Luxury accordion section
======================================== */

.cp-faq.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 125px 0 !important;
  background:
    radial-gradient(
      circle at 16% 20%,
      rgba(220, 197, 167, 0.12) 0%,
      transparent 22%
    ),
    radial-gradient(
      circle at 84% 78%,
      rgba(42, 103, 190, 0.08) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #1f3751 0%, #1b304c 48%, #1a304d 100%) !important;
}

/* Decorative glow layers */
.cp-faq__bg {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(78px) !important;
  pointer-events: none !important;
  opacity: 0.9 !important;
}

.cp-faq__bg--one {
  top: -90px !important;
  left: -100px !important;
  width: 320px !important;
  height: 320px !important;
  background: rgba(220, 197, 167, 0.12) !important;
}

.cp-faq__bg--two {
  right: -110px !important;
  bottom: -70px !important;
  width: 340px !important;
  height: 340px !important;
  background: rgba(38, 96, 179, 0.1) !important;
}

/* Subtle grid texture */
.cp-faq__grid {
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.024) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.024) 1px, transparent 1px) !important;
  background-size: 88px 88px !important;
  mask-image: radial-gradient(
    circle at center,
    black 46%,
    transparent 100%
  ) !important;
  opacity: 0.28 !important;
  pointer-events: none !important;
}

/* Main layout */
.cp-faq__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
  gap: 70px !important;
  align-items: start !important;
}

/* Left intro */
.cp-faq__intro {
  position: sticky !important;
  top: 120px !important;
}

.cp-faq__label {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(220, 197, 167, 0.82) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.cp-faq__title {
  margin: 0 0 22px !important;
  color: #ffffff !important;
  font-size: clamp(34px, 4vw, 58px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-faq__text {
  max-width: 560px !important;
  margin: 0 0 34px !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: clamp(16px, 1.15vw, 18px) !important;
  line-height: 1.88 !important;
}

.cp-faq__actions {
  margin-bottom: 0 !important;
}

/* Right accordion items */
.cp-faq__items {
  display: grid !important;
  gap: 16px !important;
}

/* FAQ item */
.cp-faq__item {
  border-radius: 28px !important;
  overflow: hidden !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.16) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  transition:
    border-color 0.4s ease,
    box-shadow 0.4s ease,
    transform 0.4s ease !important;
}

.cp-faq__item:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(220, 197, 167, 0.22) !important;
  box-shadow: 0 26px 56px rgba(0, 0, 0, 0.22) !important;
}

.cp-faq__question {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 20px !important;
  padding: 24px 26px !important;
  background: transparent !important;
  border: 0 !important;
  cursor: pointer !important;
  text-align: left !important;
}

.cp-faq__question span:first-child {
  color: #ffffff !important;
  font-size: 21px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
}

/* Plus / minus icon */
.cp-faq__icon {
  position: relative !important;
  flex: 0 0 22px !important;
  width: 22px !important;
  height: 22px !important;
}

.cp-faq__icon::before,
.cp-faq__icon::after {
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 18px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: #dcc5a7 !important;
  transform: translate(-50%, -50%) !important;
  transition:
    transform 0.3s ease,
    opacity 0.3s ease !important;
}

.cp-faq__icon::after {
  transform: translate(-50%, -50%) rotate(90deg) !important;
}

.cp-faq__item.is-open .cp-faq__icon::after {
  opacity: 0 !important;
  transform: translate(-50%, -50%) rotate(90deg) scaleX(0) !important;
}

/* Answer wrapper */
.cp-faq__answer {
  display: grid !important;
  grid-template-rows: 0fr !important;
  transition: grid-template-rows 0.4s ease !important;
}

.cp-faq__item.is-open .cp-faq__answer {
  grid-template-rows: 1fr !important;
}

.cp-faq__answer-inner {
  overflow: hidden !important;
  padding: 0 26px 0 !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 15px !important;
  line-height: 1.82 !important;
}

.cp-faq__item.is-open .cp-faq__answer-inner {
  padding: 0 26px 24px !important;
}

/* Responsive */
@media (max-width: 1180px) {
  .cp-faq__container {
    grid-template-columns: 1fr !important;
    gap: 38px !important;
  }

  .cp-faq__intro {
    position: relative !important;
    top: auto !important;
  }
}

@media (max-width: 767px) {
  .cp-faq.alignfull {
    padding: 90px 0 !important;
  }

  .cp-faq__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-faq__question {
    padding: 20px 18px !important;
  }

  .cp-faq__question span:first-child {
    font-size: 17px !important;
  }

  .cp-faq__answer-inner {
    font-size: 14px !important;
    line-height: 1.72 !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .cp-faq__item.is-open .cp-faq__answer-inner {
    padding: 0 18px 20px !important;
  }
}

/* ========================================
   CAREPRO LUXURY HEADER / MENU / FOOTER
   Global premium styling for homepage
======================================== */

/* ========================================
   HEADER BASE
======================================== */

#header.ct-header {
  position: relative !important;
  z-index: 9999 !important;
}

#header [data-row="middle"] {
  background: rgba(255, 255, 255, 0.88) !important;
  border-bottom: 1px solid rgba(16, 34, 60, 0.06) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  transition:
    background-color 0.4s ease,
    box-shadow 0.4s ease,
    border-color 0.4s ease,
    transform 0.4s ease !important;
}

/* Header container height and spacing */
#header .ct-sticky-container {
  height: 90px !important;
}

#header .ct-container {
  max-width: 1280px !important;
}

/* ========================================
   STICKY HEADER STATES
   Works for both:
   data-sticky="fixed:shrink"
   data-sticky="yes:shrink"
======================================== */

#header [data-sticky="fixed:shrink"] [data-row="middle"],
#header [data-sticky="yes:shrink"] [data-row="middle"] {
  background: rgba(255, 255, 255, 0.82) !important;
  border-bottom: 1px solid rgba(16, 34, 60, 0.08) !important;
  box-shadow: 0 18px 42px rgba(12, 24, 42, 0.08) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

/* Make shrink state feel more premium */
#header [data-sticky="yes:shrink"] [data-row="middle"] {
  box-shadow: 0 20px 48px rgba(12, 24, 42, 0.1) !important;
}

/* ========================================
   LOGO / SITE TITLE
======================================== */

#header .site-title a,
#header .site-branding .site-title a {
  color: #10223c !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  text-decoration: none !important;
  transition:
    color 0.35s ease,
    opacity 0.35s ease !important;
}

#header .site-title a:hover,
#header .site-branding .site-title a:hover {
  color: #1d3f6b !important;
}

/* ========================================
   DESKTOP MENU
======================================== */

#header nav[data-id="menu"] .menu {
  gap: 6px !important;
}

#header nav[data-id="menu"] .menu > li > a,
#header .header-menu-1 .ct-menu-link {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  color: #334155 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition:
    color 0.35s ease,
    background-color 0.35s ease,
    box-shadow 0.35s ease,
    transform 0.35s ease !important;
}

#header nav[data-id="menu"] .menu > li > a::after,
#header .header-menu-1 .ct-menu-link::after {
  content: "" !important;
  position: absolute !important;
  left: 14px !important;
  right: 14px !important;
  bottom: 8px !important;
  height: 1px !important;
  border-radius: 999px !important;
  background: linear-gradient(
    90deg,
    rgba(220, 197, 167, 0),
    rgba(220, 197, 167, 0.95),
    rgba(220, 197, 167, 0)
  ) !important;
  transform: scaleX(0) !important;
  transform-origin: center !important;
  transition: transform 0.35s ease !important;
}

#header nav[data-id="menu"] .menu > li > a:hover,
#header .header-menu-1 .ct-menu-link:hover {
  color: #10223c !important;
  background: rgba(16, 34, 60, 0.04) !important;
  transform: translateY(-1px) !important;
}

#header nav[data-id="menu"] .menu > li > a:hover::after,
#header .header-menu-1 .ct-menu-link:hover::after {
  transform: scaleX(1) !important;
}

/* Active menu item */
#header .current-menu-item > a,
#header .current_page_item > a,
#header .menu > .current-menu-item > .ct-menu-link,
#header .menu > .current_page_item > .ct-menu-link {
  color: #10223c !important;
  background: rgba(16, 34, 60, 0.05) !important;
  box-shadow: inset 0 0 0 1px rgba(16, 34, 60, 0.05) !important;
}

#header .current-menu-item > a::after,
#header .current_page_item > a::after,
#header .menu > .current-menu-item > .ct-menu-link::after,
#header .menu > .current_page_item > .ct-menu-link::after {
  transform: scaleX(1) !important;
}

/* ========================================
   HEADER CTA BUTTON
======================================== */

#header .ct-header-cta .ct-button {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  overflow: hidden !important;
  border: 1px solid transparent !important;
  background: linear-gradient(
    135deg,
    #f8f2ea 0%,
    #dcc5a7 42%,
    #f7efe6 100%
  ) !important;
  color: #111827 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow:
    0 14px 30px rgba(220, 197, 167, 0.26),
    0 8px 18px rgba(16, 34, 60, 0.08) !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    color 0.45s ease !important;
}

#header .ct-header-cta .ct-button::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: -120% !important;
  width: 70% !important;
  height: 100% !important;
  background: linear-gradient(
    115deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.34) 50%,
    rgba(255, 255, 255, 0) 100%
  ) !important;
  transform: skewX(-24deg) !important;
  transition: left 0.8s ease !important;
}

#header .ct-header-cta .ct-button:hover {
  color: #0b1220 !important;
  transform: translateY(-3px) !important;
  box-shadow:
    0 22px 44px rgba(220, 197, 167, 0.34),
    0 12px 24px rgba(16, 34, 60, 0.12) !important;
}

#header .ct-header-cta .ct-button:hover::before {
  left: 150% !important;
}

/* ========================================
   MOBILE HEADER BUTTON + BURGER
======================================== */

@media (max-width: 999px) {
  #header [data-device="mobile"] [data-row="middle"] {
    min-height: 90px !important;
  }

  #header [data-device="mobile"] .ct-header-cta .ct-button {
    min-height: 42px !important;
    padding: 0 16px !important;
    font-size: 11px !important;
    letter-spacing: 0.1em !important;
  }

  #header .ct-header-trigger {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: 10px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(16, 34, 60, 0.08) !important;
    background: rgba(255, 255, 255, 0.62) !important;
    box-shadow: 0 12px 24px rgba(16, 34, 60, 0.08) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    transition:
      transform 0.35s ease,
      box-shadow 0.35s ease,
      border-color 0.35s ease,
      background-color 0.35s ease !important;
  }

  #header .ct-header-trigger:hover {
    transform: translateY(-2px) !important;
    border-color: rgba(220, 197, 167, 0.32) !important;
    box-shadow: 0 18px 34px rgba(16, 34, 60, 0.12) !important;
    background: rgba(255, 255, 255, 0.78) !important;
  }

  #header .ct-header-trigger .ct-icon rect {
    fill: #10223c !important;
    transition: fill 0.35s ease !important;
  }

  #header .ct-header-trigger:hover .ct-icon rect {
    fill: #1d3f6b !important;
  }
}

/* ========================================
   MOBILE OFFCANVAS PANEL
======================================== */

#offcanvas,
.ct-panel,
.ct-panel-inner {
  background: linear-gradient(
    180deg,
    #08111d 0%,
    #06101a 52%,
    #050d17 100%
  ) !important;
}

#offcanvas .ct-panel-inner {
  position: relative !important;
  overflow: hidden !important;
}

#offcanvas .ct-panel-inner::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(
      circle at 18% 18%,
      rgba(220, 197, 167, 0.12) 0%,
      transparent 28%
    ),
    radial-gradient(
      circle at 86% 82%,
      rgba(42, 103, 190, 0.08) 0%,
      transparent 26%
    ) !important;
  pointer-events: none !important;
}

#offcanvas .ct-panel-actions {
  position: relative !important;
  z-index: 2 !important;
  padding: 20px 20px 0 !important;
}

#offcanvas .ct-toggle-close {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: #ffffff !important;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.14) !important;
  transition:
    transform 0.35s ease,
    border-color 0.35s ease,
    background-color 0.35s ease !important;
}

#offcanvas .ct-toggle-close:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(220, 197, 167, 0.3) !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

#offcanvas .ct-toggle-close .ct-icon path {
  fill: #ffffff !important;
}

#offcanvas .ct-panel-content[data-device="mobile"] .ct-panel-content-inner {
  position: relative !important;
  z-index: 2 !important;
  padding: 20px 20px 30px !important;
}

/* Mobile menu list */
#offcanvas .mobile-menu > ul,
#offcanvas .mobile-menu ul {
  gap: 10px !important;
}

#offcanvas .mobile-menu li {
  margin: 0 0 10px !important;
}

#offcanvas .mobile-menu .ct-menu-link,
#offcanvas .mobile-menu a {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-height: 58px !important;
  padding: 0 18px !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-decoration: none !important;
  transition:
    transform 0.35s ease,
    border-color 0.35s ease,
    background-color 0.35s ease,
    box-shadow 0.35s ease !important;
}

#offcanvas .mobile-menu .ct-menu-link:hover,
#offcanvas .mobile-menu a:hover {
  transform: translateX(4px) !important;
  border-color: rgba(220, 197, 167, 0.24) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.14) !important;
}

#offcanvas .mobile-menu .current-menu-item > .ct-menu-link,
#offcanvas .mobile-menu .current_page_item > .ct-menu-link {
  border-color: rgba(220, 197, 167, 0.26) !important;
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.14),
    rgba(255, 255, 255, 0.05)
  ) !important;
}

/* ========================================
   CAREPRO FINAL HEADER (LUXURY)
======================================== */

/* HEADER BASE */
#header.ct-header {
  position: relative !important;
  z-index: 9999 !important;
}

/* HEADER BACKGROUND */
#header [data-row="middle"] {
  background: rgba(255, 255, 255, 0.9) !important;
  border-bottom: 1px solid rgba(16, 34, 60, 0.06) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  transition: all 0.4s ease !important;
}

/* STICKY STATE */
#header [data-sticky="fixed:shrink"] [data-row="middle"],
#header [data-sticky="yes:shrink"] [data-row="middle"] {
  background: rgba(255, 255, 255, 0.82) !important;
  box-shadow: 0 18px 42px rgba(12, 24, 42, 0.08) !important;
  backdrop-filter: blur(18px) !important;
}

/* LOGO */
#header .site-title a {
  color: #10223c !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  text-decoration: none !important;
}

/* ========================================
   MENU BASE
======================================== */

#header nav[data-id="menu"] .menu {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* RESET LI */
#header nav[data-id="menu"] .menu > li {
  display: flex !important;
  align-items: center !important;
}

/* MENU LINK (CAPSULE STYLE) */
#header nav[data-id="menu"] .menu > li > a,
#header .header-menu-1 .ct-menu-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 44px !important;
  padding: 0 16px !important; /* 👈 уменьшили */
  border-radius: 999px !important;
  background: transparent !important;
  color: #334155 !important;
  font-size: 12.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: all 0.35s ease !important;
}

/* HOVER */
#header nav[data-id="menu"] .menu > li > a:hover,
#header .header-menu-1 .ct-menu-link:hover {
  background: rgba(16, 34, 60, 0.05) !important;
  color: #10223c !important;
  transform: translateY(-1px) !important;
}

/* ACTIVE (АККУРАТНАЯ КАПСУЛА) */
#header .current-menu-item > a,
#header .menu > .current-menu-item > .ct-menu-link {
  background: rgba(16, 34, 60, 0.06) !important;
  padding: 0 14px !important; /* 👈 чуть уже */
  box-shadow: inset 0 0 0 1px rgba(16, 34, 60, 0.05) !important;
  color: #10223c !important;
}

/* ========================================
   HEADER BUTTON (УЛУЧШЕННЫЙ)
======================================== */

#header .ct-header-cta .ct-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 46px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, #f8f2ea, #dcc5a7) !important;
  color: #111 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  box-shadow: 0 14px 30px rgba(220, 197, 167, 0.3) !important;
  transition: all 0.4s ease !important;
}

/* BUTTON HOVER */
#header .ct-header-cta .ct-button:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 20px 40px rgba(220, 197, 167, 0.4) !important;
}

/* ========================================
   MOBILE MENU BUTTON
======================================== */

#header .ct-header-trigger {
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.7) !important;
  border: 1px solid rgba(16, 34, 60, 0.08) !important;
  box-shadow: 0 12px 24px rgba(16, 34, 60, 0.08) !important;
}

/* ========================================
   MOBILE MENU PANEL
======================================== */

#offcanvas,
.ct-panel-inner {
  background: linear-gradient(180deg, #08111d, #050d17) !important;
}

#offcanvas .mobile-menu a {
  display: flex !important;
  align-items: center !important;
  height: 56px !important;
  padding: 0 16px !important;
  border-radius: 16px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  color: #fff !important;
  font-weight: 700 !important;
  margin-bottom: 10px !important;
  transition: all 0.3s ease !important;
}

#offcanvas .mobile-menu a:hover {
  transform: translateX(4px) !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

/* ========================================
   BACK TO TOP BUTTON
======================================== */

.ct-back-to-top {
  right: 22px !important;
  bottom: 22px !important;
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(220, 197, 167, 0.22) !important;
  background: linear-gradient(
    135deg,
    rgba(16, 34, 60, 0.88),
    rgba(22, 46, 80, 0.96)
  ) !important;
  box-shadow:
    0 20px 44px rgba(16, 34, 60, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  transition:
    transform 0.4s ease,
    box-shadow 0.4s ease,
    border-color 0.4s ease,
    background 0.4s ease !important;
}

.ct-back-to-top:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(220, 197, 167, 0.42) !important;
  background: linear-gradient(
    135deg,
    rgba(20, 42, 74, 0.96),
    rgba(29, 59, 102, 0.98)
  ) !important;
  box-shadow: 0 28px 56px rgba(16, 34, 60, 0.3) !important;
}

.ct-back-to-top .ct-icon {
  fill: #f8f2ea !important;
}

@media (max-width: 767px) {
  .ct-back-to-top {
    width: 50px !important;
    height: 50px !important;
    right: 16px !important;
    bottom: 16px !important;
  }
}

/* ========================================
   FOOTER SECTION
======================================== */

.cp-footer.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 90px 0 24px !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(220, 197, 167, 0.14) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 86% 78%,
      rgba(38, 96, 179, 0.08) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #07101d 0%, #06101a 52%, #050d17 100%) !important;
}

.cp-footer::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.024) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.024) 1px, transparent 1px) !important;
  background-size: 88px 88px !important;
  mask-image: radial-gradient(
    circle at center,
    black 48%,
    transparent 100%
  ) !important;
  opacity: 0.25 !important;
  pointer-events: none !important;
}

.cp-footer__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
}

.cp-footer__top {
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr) !important;
  gap: 40px !important;
  padding-bottom: 34px !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.cp-footer__brand {
  max-width: 720px !important;
}

.cp-footer__eyebrow {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(220, 197, 167, 0.82) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.cp-footer__title {
  margin: 0 0 16px !important;
  color: #ffffff !important;
  font-size: clamp(28px, 3vw, 46px) !important;
  line-height: 1.08 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-footer__text {
  max-width: 620px !important;
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 16px !important;
  line-height: 1.82 !important;
}

.cp-footer__mini-card {
  align-self: end !important;
  padding: 24px 24px !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.18) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.cp-footer__mini-label {
  display: inline-block !important;
  margin: 0 0 10px !important;
  color: rgba(220, 197, 167, 0.82) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.cp-footer__mini-text {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: 18px !important;
  line-height: 1.5 !important;
  font-weight: 600 !important;
}

/* Middle footer columns */
.cp-footer__middle {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr 1.15fr !important;
  gap: 24px !important;
  padding: 34px 0 !important;
}

.cp-footer__col {
  padding: 0 !important;
}

.cp-footer__heading {
  margin: 0 0 16px !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.cp-footer__links,
.cp-footer__contact {
  display: grid !important;
  gap: 10px !important;
}

.cp-footer__links a,
.cp-footer__contact a,
.cp-footer__contact span {
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  text-decoration: none !important;
  transition:
    color 0.35s ease,
    transform 0.35s ease !important;
}

.cp-footer__links a:hover,
.cp-footer__contact a:hover {
  color: #f8f2ea !important;
  transform: translateX(4px) !important;
}

.cp-footer__cta-box {
  padding: 22px 22px !important;
  border-radius: 24px !important;
  background: linear-gradient(
    135deg,
    rgba(220, 197, 167, 0.14),
    rgba(255, 255, 255, 0.05)
  ) !important;
  border: 1px solid rgba(220, 197, 167, 0.16) !important;
}

.cp-footer__cta-title {
  margin: 0 0 10px !important;
  color: #ffffff !important;
  font-size: 20px !important;
  line-height: 1.32 !important;
  font-weight: 700 !important;
}

.cp-footer__cta-text {
  margin: 0 0 18px !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

/* Reuse existing global button row */
.cp-footer__actions {
  justify-content: flex-start !important;
  margin-bottom: 0 !important;
}

/* Bottom footer */
.cp-footer__bottom {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding-top: 20px !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.cp-footer__copy,
.cp-footer__bottom-links a {
  color: rgba(255, 255, 255, 0.62) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  text-decoration: none !important;
}

.cp-footer__bottom-links {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

.cp-footer__bottom-links a:hover {
  color: #f8f2ea !important;
}

/* Footer responsive */
@media (max-width: 1180px) {
  .cp-footer__top {
    grid-template-columns: 1fr !important;
  }

  .cp-footer__middle {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  .cp-footer.alignfull {
    padding: 72px 0 20px !important;
  }

  .cp-footer__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-footer__middle {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .cp-footer__bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .cp-footer__bottom-links {
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
}

#footer .ct-container {
  width: 100%;
  max-width: 100%;
  padding: 0;
}

/* ========================================
   FOOTER MOBILE LAYOUT REFINEMENT
   Keep the first two footer columns in one row
======================================== */

@media (max-width: 767px) {
  /* Turn the middle footer area into a 2-column grid */
  .cp-footer__middle {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
    align-items: start !important;
  }

  /* Make the first and second columns stay side by side */
  .cp-footer__middle .cp-footer__col:nth-child(1),
  .cp-footer__middle .cp-footer__col:nth-child(2) {
    grid-column: auto !important;
  }

  /* Move the remaining columns below and make them full width */
  .cp-footer__middle .cp-footer__col:nth-child(3),
  .cp-footer__middle .cp-footer__col:nth-child(4) {
    grid-column: 1 / -1 !important;
  }
}

/* ========================================
   CAREPRO LEGAL PAGES CSS
   Privacy Policy + Terms of Use
======================================== */

/* Hero */
.cp-legal-hero.alignfull {
  position: relative !important;
  min-height: 48vh !important;
  padding: 140px 0 80px !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  background: #07101d !important;
}

.cp-legal-hero__bg,
.cp-legal-hero__overlay {
  position: absolute !important;
  inset: 0 !important;
}

.cp-legal-hero__bg {
  background:
    radial-gradient(
      circle at 18% 24%,
      rgba(220, 197, 167, 0.12),
      transparent 34%
    ),
    radial-gradient(
      circle at 84% 76%,
      rgba(42, 103, 190, 0.08),
      transparent 28%
    ),
    linear-gradient(180deg, #07101d 0%, #06101a 52%, #050d17 100%) !important;
}

.cp-legal-hero__overlay {
  background: linear-gradient(
    180deg,
    rgba(6, 10, 18, 0.18),
    rgba(6, 10, 18, 0.32)
  ) !important;
}

.cp-legal-hero__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1280px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  max-width: 760px !important;
}

.cp-legal-hero__label {
  display: inline-block !important;
  margin: 0 0 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: #e6d2b8 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
}

.cp-legal-hero__title {
  margin: 0 0 20px !important;
  color: #ffffff !important;
  font-size: clamp(40px, 5vw, 68px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.cp-legal-hero__text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 17px !important;
  line-height: 1.82 !important;
}

/* Content */
.cp-legal-content.alignfull {
  position: relative !important;
  overflow: hidden !important;
  padding: 100px 0 !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(220, 197, 167, 0.12) 0%,
      transparent 22%
    ),
    radial-gradient(
      circle at 84% 78%,
      rgba(42, 103, 190, 0.08) 0%,
      transparent 22%
    ),
    linear-gradient(180deg, #f8fafc 0%, #f2f5f9 100%) !important;
}

.cp-legal-content__bg {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(70px) !important;
  pointer-events: none !important;
}

.cp-legal-content__bg--one {
  top: -80px !important;
  left: -80px !important;
  width: 260px !important;
  height: 260px !important;
  background: rgba(220, 197, 167, 0.12) !important;
}

.cp-legal-content__bg--two {
  right: -90px !important;
  bottom: -60px !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(46, 106, 186, 0.08) !important;
}

.cp-legal-content__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1100px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
}

.cp-legal-content__card {
  padding: 34px 34px !important;
  border-radius: 34px !important;
  background: rgba(255, 255, 255, 0.82) !important;
  border: 1px solid rgba(16, 34, 60, 0.06) !important;
  box-shadow: 0 24px 60px rgba(18, 34, 58, 0.08) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* Legal sections */
.cp-legal-section {
  padding: 0 0 28px !important;
  margin: 0 0 28px !important;
  border-bottom: 1px solid rgba(16, 34, 60, 0.08) !important;
}

.cp-legal-section:last-child {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: 0 !important;
}

.cp-legal-section__title {
  margin: 0 0 12px !important;
  color: #10223c !important;
  font-size: clamp(24px, 2.4vw, 34px) !important;
  line-height: 1.22 !important;
  font-weight: 700 !important;
}

.cp-legal-section__text {
  margin: 0 !important;
  color: rgba(16, 34, 60, 0.74) !important;
  font-size: 16px !important;
  line-height: 1.9 !important;
}

.cp-legal-section__text a {
  color: #1d3f6b !important;
  text-decoration: none !important;
}

.cp-legal-section__text a:hover {
  color: #10223c !important;
  text-decoration: underline !important;
}

/* Responsive */
@media (max-width: 767px) {
  .cp-legal-hero.alignfull {
    min-height: auto !important;
    padding: 120px 0 70px !important;
  }

  .cp-legal-content.alignfull {
    padding: 80px 0 !important;
  }

  .cp-legal-hero__container,
  .cp-legal-content__container {
    width: min(100%, calc(100% - 24px)) !important;
  }

  .cp-legal-content__card {
    padding: 22px 18px !important;
    border-radius: 24px !important;
  }

  .cp-legal-section {
    padding-bottom: 22px !important;
    margin-bottom: 22px !important;
  }

  .cp-legal-section__text {
    font-size: 15px !important;
    line-height: 1.82 !important;
  }
}

/* ========================================
   CAREPRO CONTACT FORM (WPForms ID 26)
   Luxury / compact / premium styling
======================================== */

#wpforms-26 {
  position: relative !important;
}

/* Form container */
#wpforms-26 .wpforms-field-container {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  column-gap: 18px !important;
  row-gap: 18px !important;
  align-items: start !important;
}

/* Hide honeypot / hidden helper fields */
#wpforms-26-field_3-container,
#wpforms-26-field_5-container {
  display: none !important;
}

/* Default field block */
#wpforms-26 .wpforms-field {
  margin: 0 !important;
  padding: 0 !important;
}

/* Full width fields */
#wpforms-26-field_1-container,
#wpforms-26-field_10-container,
#wpforms-26-field_8-container {
  grid-column: 1 / -1 !important;
}

/* Two-column rows */
#wpforms-26-field_2-container,
#wpforms-26-field_4-container,
#wpforms-26-field_6-container,
#wpforms-26-field_9-container {
  grid-column: auto !important;
}

/* Labels */
#wpforms-26 .wpforms-field-label,
#wpforms-26 legend.wpforms-field-label {
  display: block !important;
  margin: 0 0 10px !important;
  color: rgba(255, 255, 255, 0.92) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.35 !important;
}

#wpforms-26 .wpforms-required-label {
  color: #dcc5a7 !important;
}

/* Inputs / selects / textarea */
#wpforms-26 input[type="text"],
#wpforms-26 input[type="email"],
#wpforms-26 select,
#wpforms-26 textarea {
  width: 100% !important;
  min-height: 58px !important;
  padding: 0 18px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03) !important;
  transition:
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    background-color 0.35s ease,
    transform 0.35s ease !important;
}

/* Select needs a little right padding */
#wpforms-26 select {
  padding-right: 44px !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(220, 197, 167, 0.9) 50%),
    linear-gradient(135deg, rgba(220, 197, 167, 0.9) 50%, transparent 50%) !important;
  background-position:
    calc(100% - 20px) calc(50% - 3px),
    calc(100% - 14px) calc(50% - 3px) !important;
  background-size:
    6px 6px,
    6px 6px !important;
  background-repeat: no-repeat !important;
}

/* Textarea */
#wpforms-26 textarea {
  min-height: 170px !important;
  padding: 16px 18px !important;
  resize: vertical !important;
}

/* Placeholder */
#wpforms-26 input::placeholder,
#wpforms-26 textarea::placeholder {
  color: rgba(255, 255, 255, 0.44) !important;
}

/* Focus state */
#wpforms-26 input[type="text"]:focus,
#wpforms-26 input[type="email"]:focus,
#wpforms-26 select:focus,
#wpforms-26 textarea:focus {
  outline: none !important;
  border-color: rgba(220, 197, 167, 0.42) !important;
  background: rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 0 0 4px rgba(220, 197, 167, 0.1) !important;
  transform: translateY(-1px) !important;
}

/* Field descriptions */
#wpforms-26 .wpforms-field-description {
  margin: 8px 0 0 !important;
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

/* Radio field */
#wpforms-26-field_10-container ul {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

#wpforms-26-field_10-container li {
  margin: 0 !important;
}

#wpforms-26-field_10-container label.wpforms-field-label-inline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  min-height: 56px !important;
  padding: 0 16px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition:
    border-color 0.35s ease,
    background-color 0.35s ease,
    transform 0.35s ease,
    box-shadow 0.35s ease !important;
}

#wpforms-26-field_10-container label.wpforms-field-label-inline:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(220, 197, 167, 0.26) !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

#wpforms-26 input[type="radio"] {
  accent-color: #dcc5a7 !important;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  flex: 0 0 16px !important;
}

/* Submit area */
#wpforms-26 .wpforms-submit-container {
  margin-top: 24px !important;
  padding: 0 !important;
}

/* Button */
#wpforms-submit-26 {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 56px !important;
  padding: 0 28px !important;
  border: 1px solid transparent !important;
  border-radius: 999px !important;
  background: linear-gradient(
    135deg,
    #f8f2ea 0%,
    #dcc5a7 42%,
    #f7efe6 100%
  ) !important;
  color: #111827 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  box-shadow:
    0 14px 30px rgba(220, 197, 167, 0.28),
    0 8px 18px rgba(16, 34, 60, 0.08) !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    filter 0.45s ease !important;
}

#wpforms-submit-26:hover {
  transform: translateY(-3px) !important;
  box-shadow:
    0 22px 44px rgba(220, 197, 167, 0.34),
    0 12px 24px rgba(16, 34, 60, 0.12) !important;
  filter: brightness(1.02) !important;
}

#wpforms-submit-26:active {
  transform: translateY(-1px) !important;
}

/* Validation errors */
#wpforms-26 .wpforms-error {
  color: #ffd6d6 !important;
  font-size: 13px !important;
  margin-top: 8px !important;
}

#wpforms-26 input.wpforms-error,
#wpforms-26 select.wpforms-error,
#wpforms-26 textarea.wpforms-error {
  border-color: rgba(255, 120, 120, 0.6) !important;
  box-shadow: 0 0 0 4px rgba(255, 120, 120, 0.08) !important;
}

/* Responsive */
@media (max-width: 767px) {
  #wpforms-26 .wpforms-field-container {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 16px !important;
  }

  #wpforms-26-field_2-container,
  #wpforms-26-field_4-container,
  #wpforms-26-field_6-container,
  #wpforms-26-field_9-container {
    grid-column: 1 / -1 !important;
  }

  #wpforms-26-field_10-container ul {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  #wpforms-26 input[type="text"],
  #wpforms-26 input[type="email"],
  #wpforms-26 select,
  #wpforms-26 textarea {
    min-height: 54px !important;
    font-size: 14px !important;
  }

  #wpforms-26 textarea {
    min-height: 150px !important;
  }

  #wpforms-submit-26 {
    width: 100% !important;
  }
}

/* FIX INPUT WIDTH (ВАЖНО) */
#wpforms-26 .wpforms-field input,
#wpforms-26 .wpforms-field select,
#wpforms-26 .wpforms-field textarea {
  width: 100% !important;
  max-width: 100% !important;
}

/* Убираем внутреннее ограничение WPForms */
#wpforms-26 .wpforms-field-medium {
  width: 100% !important;
}

/* Делаем поля визуально длиннее */
#wpforms-26 input[type="text"],
#wpforms-26 input[type="email"],
#wpforms-26 select {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

/* ========================================
   MODAL DARK LUXURY STYLE
======================================== */

.gama-modal__dialog {
  background: linear-gradient(
    135deg,
    #0b1623 0%,
    #0f1e30 60%,
    #0b1623 100%
  ) !important;
  border-radius: 28px !important;
  padding: 40px !important;
  box-shadow:
    0 40px 100px rgba(0, 0, 0, 0.6),
    0 10px 40px rgba(0, 0, 0, 0.4) !important;
  color: #ffffff !important;
}

/* Overlay (если есть фон затемнения) */
.gama-modal {
  background: rgba(5, 12, 20, 0.75) !important;
  backdrop-filter: blur(10px);
}

/* Title */
.gama-modal__title {
  font-size: 28px !important;
  font-weight: 700 !important;
  margin-bottom: 10px !important;
  color: #ffffff !important;
}

/* Subtitle */
.gama-modal__subtitle {
  color: rgba(255, 255, 255, 0.65) !important;
  margin-bottom: 30px !important;
  font-size: 15px !important;
}

/* Close button */
.gama-modal__close {
  position: absolute !important;
  top: 20px !important;
  right: 20px !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  border: none !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  font-size: 18px !important;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 100;
}

.gama-modal__close:hover {
  background: rgba(255, 255, 255, 0.15) !important;
  transform: rotate(90deg);
}

/* ========================================
   MODAL SCROLL FIX (RESPONSIVE HEIGHT)
======================================== */

/* Ограничиваем высоту модалки */
.gama-modal__dialog {
  max-height: 90vh !important;
  display: flex;
  flex-direction: column;
  overflow: hidden; /* важно */
}

/* Внутренняя часть скроллится */
.gama-modal__body {
  overflow-y: auto;
  padding-right: 10px;
}

/* Красивый скролл (luxury) */
.gama-modal__body::-webkit-scrollbar {
  width: 6px;
}

.gama-modal__body::-webkit-scrollbar-track {
  background: transparent;
}

.gama-modal__body::-webkit-scrollbar-thumb {
  background: rgba(220, 197, 167, 0.4);
  border-radius: 10px;
}

.gama-modal__body::-webkit-scrollbar-thumb:hover {
  background: rgba(220, 197, 167, 0.7);
}

.gama-modal__title {
  position: sticky;
  top: 0;
  background: inherit;
  z-index: 10;
  display: inline-block;
}

.gama-modal__body {
  padding: 0 !important;
}

/* ========================================
   MOBILE MODAL COMPACT LAYOUT FIX
======================================== */

@media (max-width: 767px) {
  /* Make modal itself a bit narrower and cleaner */
  .gama-modal__dialog {
    width: min(94vw, 560px) !important;
    max-height: 90vh !important;
    padding: 22px 18px !important;
    border-radius: 24px !important;
  }

  .gama-modal__title {
    font-size: 24px !important;
    line-height: 1.15 !important;
    margin-bottom: 10px !important;
  }

  .gama-modal__subtitle {
    font-size: 14px !important;
    margin-bottom: 22px !important;
  }

  /* Keep the body scrollable */
  .gama-modal__body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 6px !important;
  }

  /* Keep grid compact on mobile */
  #wpforms-26 .wpforms-field-container {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 12px !important;
    row-gap: 14px !important;
  }

  /* Full width fields */
  #wpforms-26-field_1-container,
  #wpforms-26-field_10-container,
  #wpforms-26-field_8-container {
    grid-column: 1 / -1 !important;
  }

  /* Keep these pairs in one row */
  #wpforms-26-field_2-container,
  #wpforms-26-field_4-container,
  #wpforms-26-field_6-container,
  #wpforms-26-field_9-container {
    grid-column: auto !important;
  }

  /* Make fields slightly more compact */
  #wpforms-26 input[type="text"],
  #wpforms-26 input[type="email"],
  #wpforms-26 select,
  #wpforms-26 textarea {
    min-height: 50px !important;
    padding: 0 14px !important;
    font-size: 14px !important;
    border-radius: 16px !important;
  }

  #wpforms-26 textarea {
    min-height: 140px !important;
    padding: 14px !important;
  }

  #wpforms-26 .wpforms-field-label,
  #wpforms-26 legend.wpforms-field-label {
    margin-bottom: 8px !important;
    font-size: 13px !important;
  }

  #wpforms-26 .wpforms-field-description {
    margin-top: 6px !important;
    font-size: 10px !important;
    line-height: 1.5 !important;
  }

  /* Radio buttons in one row */
  #wpforms-26-field_10-container ul {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  #wpforms-26-field_10-container label.wpforms-field-label-inline {
    min-height: 50px !important;
    padding: 0 12px !important;
    font-size: 13px !important;
    border-radius: 16px !important;
    gap: 8px !important;
  }

  /* Button */
  #wpforms-submit-26 {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 11px !important;
    letter-spacing: 0.12em !important;
  }
}

/* ========================================
   MODAL OVERLAY / CLOSE FIX
======================================== */

/* Hide modal by default properly */
.gama-modal {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease !important;
}

/* Visible modal state */
.gama-modal.is-active,
.gama-modal[aria-hidden="false"] {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* When modal is not active, kill overlay completely */
.gama-modal:not(.is-active):not([aria-hidden="false"]) {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Also prevent ghost layer on inner wrapper */
.gama-modal:not(.is-active):not([aria-hidden="false"]) .gama-modal__dialog {
  opacity: 0 !important;
  transform: translateY(8px) scale(0.98) !important;
}

/* Active dialog */
.gama-modal.is-active .gama-modal__dialog,
.gama-modal[aria-hidden="false"] .gama-modal__dialog {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  transition:
    opacity 0.3s ease,
    transform 0.3s ease !important;
}

.header-logo img {
  height: 44px;
  width: auto;
}

.header-logo {
  display: flex;
  align-items: center;
  gap: 12px;
}
