[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;
}

:root {
  /* Backgrounds */
  --im-dark: #0a1a2f;
  --im-deep: #071426;
  --im-light: #f4f8fc;

  /* Accent (главный цвет) */
  --im-accent: #5ec6ff;

  /* Secondary accent */
  --im-soft-blue: #9fdcff;

  /* Text */
  --im-text: #0f172a;
  --im-text-light: #ffffff;

  /* Glass */
  --im-glass: rgba(255, 255, 255, 0.08);
}

/* 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 LUXURY HEADER / MENU / FOOTER
   Global premium styling for homepage
======================================== */

/* ========================================
   
======================================== */

#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(94, 198, 255, 0),
    rgba(94, 198, 255, 0.95),
    rgba(94, 198, 255, 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;
}

.im-btn-outline,
.im-btn-primary {
  min-width: 190px !important;
}

@media (max-width: 767px) {
  .im-btn-outline,
  .im-btn-primary {
    min-width: 0 !important;
  }
}

/* ========================================
   HEADER CTA BUTTON
======================================== */
/* ========================================
   HEADER CTA BUTTON — PREMIUM EFFECT
======================================== */

#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 rgba(94, 198, 255, 0.34) !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  color: #ffffff !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(94, 198, 255, 0.28),
    0 8px 18px rgba(16, 34, 60, 0.08) !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    color 0.45s ease,
    border-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.38) 50%,
    rgba(255, 255, 255, 0) 100%
  ) !important;
  transform: skewX(-24deg) !important;
  transition: left 0.8s ease !important;
  pointer-events: none !important;
}

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

#header .ct-header-cta .ct-button:hover {
  color: #ffffff !important;
  transform: translateY(-3px) scale(1.015) !important;
  border-color: rgba(159, 220, 255, 0.7) !important;
  box-shadow:
    0 22px 44px rgba(94, 198, 255, 0.42),
    0 12px 24px rgba(16, 34, 60, 0.12) !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(94, 198, 255, 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(94, 198, 255, 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(94, 198, 255, 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(94, 198, 255, 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(94, 198, 255, 0.26) !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 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;
}

/* ========================================
   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(94, 198, 255, 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(94, 198, 255, 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: #f6fbff !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(94, 198, 255, 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(94, 198, 255, 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(94, 198, 255, 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: #0a1a2f !important;
  transform: translateX(4px) !important;
}

.cp-footer__cta-box {
  padding: 22px 22px !important;
  border-radius: 24px !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.14),
    rgba(255, 255, 255, 0.05)
  ) !important;
  border: 1px solid rgba(94, 198, 255, 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: #0a1a2f !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 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;
}

/* 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: #5ec6ff !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(94, 198, 255, 0.9) 50%),
    linear-gradient(135deg, rgba(94, 198, 255, 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(94, 198, 255, 0.42) !important;
  background: rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 0 0 4px rgba(94, 198, 255, 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(94, 198, 255, 0.26) !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

#wpforms-26 input[type="radio"] {
  accent-color: #5ec6ff !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-radius: 999px !important;
  background: linear-gradient(
    135deg,
    #0a1a2f 0%,
    #5ec6ff 42%,
    #f7efe6 100%
  ) !important;
  color: #111827 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    filter 0.45s ease !important;
}

#wpforms-submit-26:hover {
  transform: translateY(-5px) !important;
  filter: brightness(1.02) !important;
  background: linear-gradient(
    315deg,
    #0a1a2f 0%,
    #5ec6ff 42%,
    #f7efe6 100%
  ) !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(94, 198, 255, 0.4);
  border-radius: 10px;
}

.gama-modal__body::-webkit-scrollbar-thumb:hover {
  background: rgba(94, 198, 255, 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;
}

/* ========================================
   
======================================== */

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

/* ========================================
   
======================================== */

/* ========================================
  IMPERIAL MEDICAL SUPPLIES — GLOBAL BUTTON SYSTEM
  Reusable button classes for the whole website
======================================== */

/* ========================================
  IMPERIAL MEDICAL SUPPLIES — HERO SECTION
======================================== */
.im-hero {
  position: relative !important;
  min-height: calc(100vh - 90px) !important;
  min-height: calc(100svh - 90px) !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  background: #07111f !important;
  isolation: isolate !important;
}

.im-hero__bg {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
}

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

.im-hero__overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background:
    linear-gradient(
      90deg,
      rgba(6, 14, 26, 0.9) 0%,
      rgba(6, 14, 26, 0.72) 38%,
      rgba(6, 14, 26, 0.44) 62%,
      rgba(6, 14, 26, 0.58) 100%
    ),
    linear-gradient(180deg, rgba(3, 8, 16, 0.22) 0%, rgba(3, 8, 16, 0.48) 100%) !important;
}

.im-hero__glow {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(80px) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.im-hero__glow--one {
  top: 8% !important;
  right: 8% !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(214, 190, 154, 0.18) !important;
}

.im-hero__glow--two {
  bottom: 4% !important;
  left: -40px !important;
  width: 240px !important;
  height: 240px !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

.im-hero__container {
  position: relative !important;
  z-index: 3 !important;
  width: 100% !important;
  max-width: 1320px !important;
  margin: 0 auto !important;
  padding: 56px 24px !important;
}

.im-hero__content {
  max-width: 760px !important;
}

.im-hero__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
  padding: 10px 16px !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  color: #f3ede4 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.im-hero__eyebrow::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #f4ede1 0%, #d9c4a4 100%) !important;
  box-shadow: 0 0 16px rgba(244, 237, 225, 0.55) !important;
}

.im-hero__title {
  margin: 0 0 20px !important;
  color: #ffffff !important;
  font-size: clamp(40px, 6vw, 76px) !important;
  font-weight: 800 !important;
  line-height: 1.02 !important;
  letter-spacing: -0.03em !important;
  max-width: 720px !important;
}

.im-hero__text {
  max-width: 640px !important;
  margin: 0 0 32px !important;
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 17px !important;
  line-height: 1.8 !important;
}

.im-hero__actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
  margin-bottom: 36px !important;
}

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

.im-hero__highlight {
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  min-height: 118px !important;
  padding: 22px 20px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.07) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.16) !important;
}

.im-hero__highlight-number {
  display: inline-block !important;
  color: #3aa0e6 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  letter-spacing: 0.18em !important;
}

.im-hero__highlight-text {
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
}

/* ========================================
  GLOBAL IMAGE HOVER SYSTEM
  Reusable for future image blocks
======================================== */
.im-media {
  overflow: hidden !important;
  border-radius: 24px !important;
}

.im-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.7s ease !important;
}

.im-media:hover img {
  transform: scale(1.15) !important;
}

/* ========================================
   IMPERIAL HERO BUTTONS — FIXED / PREMIUM
======================================== */

.im-hero-v2__actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
  margin-bottom: 36px !important;
}

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

/* Shine effect */
.im-btn::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: -130% !important;
  width: 62% !important;
  height: 100% !important;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.42) 50%,
    rgba(255, 255, 255, 0) 100%
  ) !important;
  transform: skewX(-24deg) !important;
  transition: left 0.8s ease !important;
  pointer-events: none !important;
}

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

/* Primary button */
.im-btn-primary {
  color: #ffffff !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  border-color: rgba(94, 198, 255, 0.4) !important;
  box-shadow:
    0 16px 38px rgba(94, 198, 255, 0.28),
    0 8px 20px rgba(7, 20, 38, 0.16) !important;
}

.im-btn-primary:hover {
  transform: translateY(-4px) !important;
  box-shadow:
    0 24px 54px rgba(94, 198, 255, 0.46),
    0 10px 24px rgba(7, 20, 38, 0.18) !important;
}

/* Outline button */
.im-btn-outline {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  box-shadow:
    0 14px 32px rgba(0, 0, 0, 0.14),
    inset 0 0 0 1px rgba(94, 198, 255, 0.06) !important;
}

.im-btn-outline:hover {
  color: #ffffff !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.18) 0%,
    rgba(58, 160, 230, 0.16) 100%
  ) !important;
  border-color: rgba(94, 198, 255, 0.46) !important;
  transform: translateY(-4px) !important;
  box-shadow:
    0 20px 44px rgba(94, 198, 255, 0.2),
    inset 0 0 0 1px rgba(94, 198, 255, 0.12) !important;
}

/* ========================================
  REVEAL FOUNDATION
  Uses your existing JS script
======================================== */
.sr-item {
  opacity: 0;
  transform: translateY(70px);
  transition:
    opacity 0.9s ease,
    transform 0.9s ease !important;
  transition-delay: var(--sr-delay, 0s) !important;
  will-change: opacity, transform !important;
}

.sr-item.sr-left {
  transform: translateX(-70px);
}

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

/* ========================================
  IMPERIAL MEDICAL SUPPLIES — HERO V2
  Medical equipment / supplies focused
======================================== */
.im-hero-v2 {
  position: relative !important;
  min-height: calc(100vh - 90px) !important;
  min-height: calc(100svh - 90px) !important;
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
  background: #071426 !important;
  isolation: isolate !important;
}

.im-hero-v2__bg {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
}

.im-hero-v2__bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scale(1.04) !important;
}

.im-hero-v2__overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background:
    linear-gradient(
      90deg,
      rgba(7, 20, 38, 0.94) 0%,
      rgba(7, 20, 38, 0.86) 28%,
      rgba(7, 20, 38, 0.55) 56%,
      rgba(7, 20, 38, 0.74) 100%
    ),
    linear-gradient(
      180deg,
      rgba(6, 14, 28, 0.18) 0%,
      rgba(6, 14, 28, 0.36) 100%
    ) !important;
}

.im-hero-v2__glow {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(85px) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.im-hero-v2__glow--one {
  top: 7% !important;
  right: 10% !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(94, 198, 255, 0.16) !important;
}

.im-hero-v2__glow--two {
  bottom: 0 !important;
  left: -20px !important;
  width: 240px !important;
  height: 240px !important;
  background: rgba(159, 220, 255, 0.12) !important;
}

.im-hero-v2__container {
  position: relative !important;
  z-index: 3 !important;
  width: 100% !important;
  max-width: 1320px !important;
  margin: 0 auto !important;
  padding: 58px 24px !important;
}

.im-hero-v2__grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, 420px) !important;
  align-items: center !important;
  gap: 28px !important;
}

.im-hero-v2__content {
  max-width: 760px !important;
}

.im-hero-v2__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(94, 198, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  color: #dff4ff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.im-hero-v2__eyebrow::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #9fdcff 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.55) !important;
}

.im-hero-v2__title {
  margin: 0 0 20px !important;
  max-width: 760px !important;
  color: #ffffff !important;
  font-size: clamp(40px, 6vw, 78px) !important;
  font-weight: 800 !important;
  line-height: 1.02 !important;
  letter-spacing: -0.035em !important;
}

.im-hero-v2__text {
  max-width: 640px !important;
  margin: 0 0 34px !important;
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 17px !important;
  line-height: 1.82 !important;
}

/* ========================================
  Premium button hover upgrade
======================================== */

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

.im-hero-v2__feature {
  min-height: 118px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding: 22px 20px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.07) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.14) !important;
}

.im-hero-v2__feature-label {
  display: inline-block !important;
  color: #9fdcff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  line-height: 1 !important;
}

.im-hero-v2__feature-text {
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
}

.im-hero-v2__side {
  display: flex !important;
  justify-content: flex-end !important;
}

.im-hero-v2__card {
  width: 100% !important;
  max-width: 400px !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

.im-hero-v2__card-media {
  aspect-ratio: 4 / 3 !important;
}

.im-hero-v2__card-content {
  padding: 22px 22px 24px !important;
}

.im-hero-v2__card-tag {
  display: inline-flex !important;
  margin-bottom: 12px !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  background: rgba(94, 198, 255, 0.14) !important;
  color: #dff4ff !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.im-hero-v2__card-title {
  margin: 0 0 12px !important;
  color: #ffffff !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.24 !important;
}

.im-hero-v2__card-text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 15px !important;
  line-height: 1.78 !important;
}

.im-hero-v2__overlay {
  background: linear-gradient(
    90deg,
    rgba(7, 20, 38, 0.97) 0%,
    rgba(7, 20, 38, 0.9) 30%,
    rgba(7, 20, 38, 0.65) 60%,
    rgba(7, 20, 38, 0.85) 100%
  ) !important;
}

/* ========================================
  Tablet
======================================== */
@media (max-width: 1100px) {
  .im-hero-v2__grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  .im-hero-v2__side {
    justify-content: flex-start !important;
  }

  .im-hero-v2__card {
    max-width: 520px !important;
  }
}

/* ========================================
  Mobile
======================================== */
@media (max-width: 767px) {
  .im-hero-v2__container {
    padding: 38px 16px !important;
  }

  .im-hero-v2__title {
    margin-bottom: 16px !important;
    font-size: clamp(31px, 9vw, 44px) !important;
    line-height: 1.05 !important;
  }

  .im-hero-v2__text {
    margin-bottom: 24px !important;
    font-size: 15px !important;
    line-height: 1.72 !important;
  }

  .im-hero-v2__actions {
    gap: 10px !important;
    justify-content: flex-start !important;
  }

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

  .im-hero-v2__features {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .im-hero-v2__feature {
    min-height: 108px !important;
    padding: 18px 16px !important;
    border-radius: 20px !important;
  }

  .im-hero-v2__feature-text {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  .im-hero-v2__card {
    border-radius: 24px !important;
  }

  .im-hero-v2__card-content {
    padding: 18px 18px 20px !important;
  }

  .im-hero-v2__card-title {
    font-size: 20px !important;
  }
}

/* ========================================
  Small mobile
======================================== */
@media (max-width: 480px) {
  .im-hero-v2__container {
    padding: 34px 14px !important;
  }

  .im-hero-v2__title {
    font-size: clamp(28px, 8.8vw, 38px) !important;
  }

  .im-hero-v2__text {
    font-size: 14px !important;
  }

  .im-btn {
    min-height: 50px !important;
    padding: 12px 10px !important;
    font-size: 10px !important;
  }
}

/* ========================================
   IMPERIAL CATEGORIES SECTION
======================================== */

.im-categories {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
  background:
    radial-gradient(
      circle at 15% 20%,
      rgba(94, 198, 255, 0.15),
      transparent 30%
    ),
    radial-gradient(
      circle at 85% 80%,
      rgba(159, 220, 255, 0.12),
      transparent 30%
    ),
    linear-gradient(180deg, #f7fbff 0%, #eef6fc 100%);
}

/* subtle grid overlay */
.im-categories::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(10, 26, 47, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 26, 47, 0.03) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: 0.4;
  pointer-events: none;
}

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

/* header */
.im-categories__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 60px;
}

.im-categories__title {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 800;
  color: #0f172a;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}

.im-categories__text {
  color: #475569;
  font-size: 16px;
  line-height: 1.8;
}

/* grid */
.im-categories__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

/* card */
.im-category {
  position: relative;
  padding: 34px 24px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(94, 198, 255, 0.15);
  backdrop-filter: blur(10px);
  text-align: center;
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease;
}

.im-category__icon {
  font-size: 28px;
  margin-bottom: 16px;
}

/* title */
.im-category h3 {
  font-size: 16px;
  font-weight: 700;
  color: #0f172a;
}

/* hover */
.im-category:hover {
  transform: translateY(-8px);
  border-color: rgba(94, 198, 255, 0.4);
  box-shadow:
    0 20px 40px rgba(94, 198, 255, 0.15),
    0 8px 20px rgba(15, 23, 42, 0.08);
}

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

@media (max-width: 1024px) {
  .im-categories__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .im-categories {
    padding: 70px 0;
  }

  .im-categories__grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
  IMPERIAL WHY CHOOSE US SECTION
======================================== */

.im-why {
  position: relative !important;
  overflow: hidden !important;
  padding: 110px 0 !important;
  background: linear-gradient(
    180deg,
    #ffffff 0%,
    #f6fbff 52%,
    #eef6fc 100%
  ) !important;
}

.im-why__bg {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(80px) !important;
  pointer-events: none !important;
}

.im-why__bg--one {
  top: -80px !important;
  left: -80px !important;
  width: 260px !important;
  height: 260px !important;
  background: rgba(94, 198, 255, 0.14) !important;
}

.im-why__bg--two {
  right: -100px !important;
  bottom: -80px !important;
  width: 300px !important;
  height: 300px !important;
  background: rgba(159, 220, 255, 0.14) !important;
}

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

.im-why__grid {
  display: grid !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
  align-items: center !important;
  gap: 42px !important;
}

/* ========================================
  Left side image composition
======================================== */

.im-why__media-wrap {
  position: relative !important;
}

.im-why__media-card {
  position: relative !important;
  border-radius: 32px !important;
  overflow: hidden !important;
  box-shadow:
    0 28px 60px rgba(15, 23, 42, 0.12),
    0 10px 24px rgba(94, 198, 255, 0.08) !important;
}

.im-why__media-card--main {
  min-height: 620px !important;
}

.im-why__media-card--main img {
  width: 100% !important;
  height: 100% !important;
  min-height: 620px !important;
  object-fit: cover !important;
}

.im-why__floating {
  position: absolute !important;
  right: -20px !important;
  bottom: 34px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  width: 240px !important;
  padding: 24px 22px !important;
  border-radius: 24px !important;
  background: rgba(10, 26, 47, 0.92) !important;
  border: 1px solid rgba(94, 198, 255, 0.22) !important;
  box-shadow:
    0 20px 44px rgba(15, 23, 42, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
}

.im-why__floating-number {
  color: #5ec6ff !important;
  font-size: 34px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  letter-spacing: -0.03em !important;
}

.im-why__floating-text {
  color: rgba(255, 255, 255, 0.84) !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  font-weight: 500 !important;
}

/* ========================================
  Right content
======================================== */

.im-why__content {
  max-width: 700px !important;
}

.im-why__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  background: rgba(94, 198, 255, 0.1) !important;
  border: 1px solid rgba(94, 198, 255, 0.14) !important;
  color: #1c4b73 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.im-why__eyebrow::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.36) !important;
}

.im-why__title {
  margin: 0 0 18px !important;
  color: #0f172a !important;
  font-size: clamp(34px, 4vw, 54px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}

.im-why__text {
  margin: 0 0 30px !important;
  color: #475569 !important;
  font-size: 16px !important;
  line-height: 1.85 !important;
  max-width: 620px !important;
}

/* ========================================
  Benefit cards
======================================== */

.im-why__cards {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin-bottom: 28px !important;
}

.im-why__card {
  display: flex !important;
  align-items: flex-start !important;
  gap: 16px !important;
  min-height: 168px !important;
  padding: 22px 20px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.86) !important;
  border: 1px solid rgba(94, 198, 255, 0.12) !important;
  box-shadow:
    0 18px 40px rgba(15, 23, 42, 0.06),
    0 8px 20px rgba(94, 198, 255, 0.06) !important;
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease !important;
}

.im-why__card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(94, 198, 255, 0.28) !important;
  box-shadow:
    0 26px 52px rgba(15, 23, 42, 0.1),
    0 14px 28px rgba(94, 198, 255, 0.1) !important;
}

.im-why__card-icon {
  flex: 0 0 52px !important;
  width: 52px !important;
  height: 52px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  line-height: 1 !important;
  box-shadow: 0 12px 24px rgba(94, 198, 255, 0.24) !important;
}

.im-why__card-body h3 {
  margin: 0 0 10px !important;
  color: #0f172a !important;
  font-size: 19px !important;
  line-height: 1.32 !important;
  font-weight: 700 !important;
}

.im-why__card-body p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.75 !important;
}

/* ========================================
  Actions
======================================== */

.im-why__actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* ========================================
  Tablet
======================================== */

@media (max-width: 1100px) {
  .im-why__grid {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }

  .im-why__content {
    max-width: 100% !important;
  }

  .im-why__media-card--main,
  .im-why__media-card--main img {
    min-height: 520px !important;
  }

  .im-why__floating {
    right: 18px !important;
    bottom: 18px !important;
  }
}

/* ========================================
  Mobile
======================================== */

@media (max-width: 767px) {
  .im-why {
    padding: 78px 0 !important;
  }

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

  .im-why__title {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.08 !important;
  }

  .im-why__text {
    font-size: 15px !important;
    line-height: 1.78 !important;
  }

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

  .im-why__card {
    min-height: 190px !important;
    padding: 18px 16px !important;
    border-radius: 20px !important;
    gap: 12px !important;
  }

  .im-why__card-icon {
    width: 44px !important;
    height: 44px !important;
    flex: 0 0 44px !important;
    border-radius: 14px !important;
    font-size: 11px !important;
  }

  .im-why__card-body h3 {
    font-size: 16px !important;
    margin-bottom: 8px !important;
  }

  .im-why__card-body p {
    font-size: 14px !important;
    line-height: 1.6 !important;
  }

  .im-why__media-card--main,
  .im-why__media-card--main img {
    min-height: 360px !important;
  }

  .im-why__floating {
    position: static !important;
    width: 100% !important;
    margin-top: 14px !important;
    border-radius: 20px !important;
  }

  .im-why__actions {
    gap: 10px !important;
    justify-content: flex-start !important;
  }

  .im-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
  }
}

/* ========================================
   IMPERIAL GLOBAL BUTTON TOKENS
   One source of truth for all buttons
======================================== */
:root {
  --im-btn-radius: 999px;
  --im-btn-height: 56px;
  --im-btn-padding-x: 24px;
  --im-btn-font-size: 13px;
  --im-btn-font-weight: 800;
  --im-btn-letter-spacing: 0.08em;

  --im-btn-primary-bg: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%);
  --im-btn-primary-border: rgba(94, 198, 255, 0.4);
  --im-btn-primary-color: #ffffff;
  --im-btn-primary-shadow:
    0 16px 38px rgba(94, 198, 255, 0.28), 0 8px 20px rgba(7, 20, 38, 0.16);

  --im-btn-primary-shadow-hover:
    0 24px 54px rgba(94, 198, 255, 0.46), 0 10px 24px rgba(7, 20, 38, 0.18);

  --im-btn-outline-bg: rgba(255, 255, 255, 0.08);
  --im-btn-outline-bg-hover: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.18) 0%,
    rgba(58, 160, 230, 0.16) 100%
  );
  --im-btn-outline-border: rgba(255, 255, 255, 0.18);
  --im-btn-outline-border-hover: rgba(94, 198, 255, 0.46);
  --im-btn-outline-color: #ffffff;
  --im-btn-outline-shadow:
    0 14px 32px rgba(0, 0, 0, 0.14), inset 0 0 0 1px rgba(94, 198, 255, 0.06);

  --im-btn-outline-shadow-hover:
    0 20px 44px rgba(94, 198, 255, 0.2),
    inset 0 0 0 1px rgba(94, 198, 255, 0.12);
}

/* ========================================
   IMPERIAL GLOBAL BUTTON SYSTEM
   Reusable on all sections
======================================== */
.im-btn {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: var(--im-btn-height) !important;
  padding: 0 var(--im-btn-padding-x) !important;
  border-radius: var(--im-btn-radius) !important;
  font-size: var(--im-btn-font-size) !important;
  font-weight: var(--im-btn-font-weight) !important;
  line-height: 1 !important;
  letter-spacing: var(--im-btn-letter-spacing) !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  border: 1px solid transparent !important;
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background-color 0.35s ease,
    color 0.35s ease !important;
}

.im-btn::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: -130% !important;
  width: 62% !important;
  height: 100% !important;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.42) 50%,
    rgba(255, 255, 255, 0) 100%
  ) !important;
  transform: skewX(-24deg) !important;
  transition: left 0.8s ease !important;
  pointer-events: none !important;
}

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

.im-btn-primary {
  color: var(--im-btn-primary-color) !important;
  background: var(--im-btn-primary-bg) !important;
  border-color: var(--im-btn-primary-border) !important;
  box-shadow: var(--im-btn-primary-shadow) !important;
}

.im-btn-primary:hover {
  color: var(--im-btn-primary-color) !important;
  transform: translateY(-4px) !important;
  box-shadow: var(--im-btn-primary-shadow-hover) !important;
}

.im-btn-outline {
  color: var(--im-btn-outline-color) !important;
  background: var(--im-btn-outline-bg) !important;
  border-color: var(--im-btn-outline-border) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  box-shadow: var(--im-btn-outline-shadow) !important;
}

.im-btn-outline:hover {
  color: var(--im-btn-outline-color) !important;
  background: var(--im-btn-outline-bg-hover) !important;
  border-color: var(--im-btn-outline-border-hover) !important;
  transform: translateY(-4px) !important;
  box-shadow: var(--im-btn-outline-shadow-hover) !important;
}

/* Remove local button override inside Why section */
.im-why__actions .im-btn-outline {
  background: var(--im-btn-outline-bg) !important;
}

.im-why__actions .im-btn-outline:hover {
  background: var(--im-btn-outline-bg-hover) !important;
}

/* ========================================
   WHY SECTION IMAGE UPGRADE
   Makes the chosen image feel more premium
======================================== */
.im-why__media-wrap {
  position: relative !important;
  isolation: isolate !important;
}

.im-why__media-wrap::before {
  content: "" !important;
  position: absolute !important;
  inset: -30px auto auto -30px !important;
  width: 180px !important;
  height: 180px !important;
  border-radius: 50% !important;
  background: radial-gradient(
    circle,
    rgba(94, 198, 255, 0.2) 0%,
    rgba(94, 198, 255, 0) 72%
  ) !important;
  filter: blur(16px) !important;
  z-index: 0 !important;
  pointer-events: none !important;
}

.im-why__media-card {
  position: relative !important;
  border-radius: 34px !important;
  overflow: hidden !important;
  border: 1px solid rgba(94, 198, 255, 0.14) !important;
  background: #dceeff !important;
  box-shadow:
    0 34px 70px rgba(15, 23, 42, 0.13),
    0 14px 34px rgba(94, 198, 255, 0.1) !important;
}

.im-why__media-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.04) 0%,
      rgba(7, 20, 38, 0.08) 100%
    ),
    radial-gradient(
      circle at 18% 18%,
      rgba(255, 255, 255, 0.2) 0%,
      transparent 28%
    ) !important;
  pointer-events: none !important;
}

.im-why__media-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.28),
    inset 0 -90px 120px rgba(7, 20, 38, 0.1) !important;
  pointer-events: none !important;
}

.im-why__media-card--main {
  min-height: 620px !important;
}

.im-why__media-card--main img {
  width: 100% !important;
  height: 100% !important;
  min-height: 620px !important;
  object-fit: cover !important;
  object-position: center center !important;
  filter: brightness(0.9) saturate(0.86) contrast(1.04) !important;
  transform: scale(1.02) !important;
}

/* ========================================
   FLOATING BADGE UPGRADE
======================================== */
.im-why__floating {
  right: -16px !important;
  bottom: 28px !important;
  width: 255px !important;
  padding: 24px 22px !important;
  border-radius: 26px !important;
  background: linear-gradient(
    180deg,
    rgba(10, 26, 47, 0.55) 0%,
    rgba(8, 20, 36, 0.6) 100%
  ) !important;
  border: 1px solid rgba(94, 198, 255, 0.2) !important;
  box-shadow:
    0 24px 50px rgba(15, 23, 42, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.im-why__floating-number {
  color: #8fd8ff !important;
  font-size: 36px !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.im-why__floating-text {
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

/* ========================================
   WHY CONTENT REFINEMENT
======================================== */
.im-why__title {
  max-width: 680px !important;
}

.im-why__text {
  max-width: 600px !important;
}

.im-why__cards {
  margin-bottom: 30px !important;
}

.im-why__card {
  min-height: 174px !important;
  border-radius: 26px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid rgba(94, 198, 255, 0.1) !important;
  box-shadow:
    0 18px 40px rgba(15, 23, 42, 0.05),
    0 10px 24px rgba(94, 198, 255, 0.05) !important;
}

.im-why__card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(94, 198, 255, 0.24) !important;
  box-shadow:
    0 28px 56px rgba(15, 23, 42, 0.08),
    0 14px 28px rgba(94, 198, 255, 0.1) !important;
}

/* ========================================
   MOBILE REFINEMENT
======================================== */
@media (max-width: 1100px) {
  .im-why__media-card--main,
  .im-why__media-card--main img {
    min-height: 520px !important;
  }

  .im-why__floating {
    right: 18px !important;
    bottom: 18px !important;
  }
}

@media (max-width: 767px) {
  .im-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    min-height: 52px !important;
    padding: 12px 14px !important;
    font-size: 11px !important;
    letter-spacing: 0.06em !important;
  }

  .im-why__media-card {
    border-radius: 24px !important;
  }

  .im-why__media-card--main,
  .im-why__media-card--main img {
    min-height: 360px !important;
  }

  .im-why__floating {
    position: static !important;
    width: 100% !important;
    margin-top: 14px !important;
    border-radius: 20px !important;
  }
}

.im-why__actions .im-btn-outline,
.im-services-signature__actions .im-btn-outline,
.im-about-story__actions .im-btn-outline {
  background: rgb(17 31 50 / 50%) !important;
}

.im-why__actions .im-btn-outline:hover,
.im-services-signature__actions .im-btn-outline:hover,
.im-about-story__actions .im-btn-outline:hover {
  background: rgb(17 31 50 / 85%) !important;
}

/* ========================================
   FEATURED PRODUCTS SECTION — DARK LUXURY
======================================== */
.im-products {
  position: relative !important;
  overflow: hidden !important;
  padding: 120px 0 !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(94, 198, 255, 0.14) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 86% 22%,
      rgba(159, 220, 255, 0.1) 0%,
      transparent 22%
    ),
    radial-gradient(
      circle at 82% 82%,
      rgba(33, 90, 168, 0.12) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #102a4a 0%, #071426 42%, #102a4a 72%, #09182b 100%) !important;
  isolation: isolate !important;
}

/* Premium grid texture */
.im-products::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.22 !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

/* Extra luxury glow */
.im-products::after {
  content: "" !important;
  position: absolute !important;
  inset: auto auto -120px -120px !important;
  width: 340px !important;
  height: 340px !important;
  border-radius: 50% !important;
  background: radial-gradient(
    circle,
    rgba(94, 198, 255, 0.14) 0%,
    rgba(94, 198, 255, 0) 72%
  ) !important;
  filter: blur(30px) !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

.im-products__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: 52px !important;
  align-items: center !important;
}

/* ========================================
   INTRO
======================================== */
.im-products__intro {
  position: relative !important;
  max-width: 560px !important;
}

.im-products__label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 0 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(94, 198, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  color: #dff4ff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.im-products__label::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #9fdcff 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.55) !important;
}

.im-products__title {
  margin: 0 0 20px !important;
  color: #ffffff !important;
  font-size: clamp(34px, 4.2vw, 58px) !important;
  font-weight: 800 !important;
  line-height: 1.04 !important;
  letter-spacing: -0.035em !important;
}

.im-products__text {
  max-width: 520px !important;
  margin: 0 0 30px !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 16px !important;
  line-height: 1.85 !important;
}

.im-products__actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* ========================================
   GRID
======================================== */
.im-products__grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 20px !important;
}

/* ========================================
   CARD
======================================== */
.im-product-card {
  position: relative !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow:
    0 24px 54px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    border-color 0.45s ease !important;
}

.im-product-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.04) 0%,
      rgba(7, 20, 38, 0.06) 100%
    ),
    radial-gradient(
      circle at 18% 18%,
      rgba(255, 255, 255, 0.12) 0%,
      transparent 24%
    ) !important;
  pointer-events: none !important;
  z-index: 2 !important;
}

.im-product-card:hover {
  transform: translateY(-10px) !important;
  border-color: rgba(94, 198, 255, 0.24) !important;
  box-shadow:
    0 34px 68px rgba(0, 0, 0, 0.3),
    0 12px 28px rgba(94, 198, 255, 0.14) !important;
}

.im-product-card__img-wrap {
  position: relative !important;
  height: 230px !important;
  overflow: hidden !important;
}

.im-product-card__img-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    180deg,
    rgba(7, 20, 38, 0.06) 0%,
    rgba(7, 20, 38, 0.28) 100%
  ) !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.im-product-card__img-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.7s ease !important;
  filter: brightness(0.86) saturate(0.9) contrast(1.04) !important;
}

.im-product-card:hover .im-product-card__img-wrap img {
  transform: scale(1.15) !important;
}

.im-product-card__content {
  position: relative !important;
  z-index: 3 !important;
  padding: 22px 22px 24px !important;
}

.im-product-card__content h3 {
  margin: 0 0 8px !important;
  color: #ffffff !important;
  font-size: 20px !important;
  line-height: 1.28 !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}

.im-product-card__content p {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

/* Optional small top badge for cards */
.im-product-card__tag {
  display: inline-flex !important;
  margin-bottom: 12px !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  background: rgba(94, 198, 255, 0.14) !important;
  color: #dff4ff !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

/* ========================================
   TABLET
======================================== */
@media (max-width: 1100px) {
  .im-products__container {
    grid-template-columns: 1fr !important;
    gap: 34px !important;
  }

  .im-products__intro {
    max-width: 100% !important;
  }
}

/* ========================================
   MOBILE
======================================== */
@media (max-width: 767px) {
  .im-products {
    padding: 78px 0 !important;
  }

  .im-products__container {
    width: min(100%, calc(100% - 24px)) !important;
    gap: 28px !important;
  }

  .im-products__title {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.08 !important;
  }

  .im-products__text {
    font-size: 15px !important;
    line-height: 1.78 !important;
  }

  .im-products__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .im-product-card {
    border-radius: 22px !important;
  }

  .im-product-card__img-wrap {
    height: 170px !important;
  }

  .im-product-card__content {
    padding: 16px 16px 18px !important;
  }

  .im-product-card__content h3 {
    font-size: 16px !important;
    margin-bottom: 6px !important;
  }

  .im-product-card__content p {
    font-size: 13px !important;
    line-height: 1.55 !important;
  }

  .im-products__actions {
    gap: 10px !important;
    justify-content: flex-start !important;
  }

  .im-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
  }
}

/* ========================================
   IMPERIAL CATEGORIES — SEPARATE REVEAL
======================================== */

/* Head */
.im-categories__head {
  text-align: center !important;
  max-width: 720px !important;
  margin: 0 auto 60px !important;
}

.im-categories__title,
.im-categories__text {
  will-change: opacity, transform !important;
}

/* Card inner layout */
.im-category {
  position: relative !important;
  overflow: hidden !important;
}

.im-category__inner {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Separate icon reveal */
.im-category__icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 72px !important;
  height: 72px !important;
  margin: 0 auto 18px !important;
  border-radius: 20px !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.18) 0%,
    rgba(159, 220, 255, 0.08) 100%
  ) !important;
  border: 1px solid rgba(94, 198, 255, 0.16) !important;
  box-shadow:
    0 14px 28px rgba(94, 198, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
  font-size: 30px !important;
  line-height: 1 !important;
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background 0.35s ease !important;
}

.im-category__title {
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #0f172a !important;
  line-height: 1.45 !important;
  transition: color 0.35s ease !important;
}

/* Hover refinement */
.im-category:hover .im-category__icon {
  transform: translateY(-4px) scale(1.04) !important;
  border-color: rgba(94, 198, 255, 0.34) !important;
  box-shadow:
    0 20px 38px rgba(94, 198, 255, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.26) !important;
}

/* ========================================
   CATEGORIES CUSTOM REVEAL FEEL
======================================== */
.im-categories .sr-item {
  opacity: 0 !important;
  transform: translateY(64px) scale(0.96) !important;
  transition:
    opacity 0.85s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.85s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
  will-change: opacity, transform !important;
}

.im-categories .sr-item.sr-left {
  transform: translateX(-64px) !important;
}

.im-categories .sr-item.is-visible {
  opacity: 1 !important;
  transform: translate(0, 0) scale(1) !important;
}

/* Card itself starts a bit stronger */
.im-categories .im-category.sr-item {
  transform: translateY(78px) scale(0.94) !important;
}

.im-categories .im-category.sr-item.is-visible {
  transform: translateY(0) scale(1) !important;
}

/* Icon appears slightly softer */
.im-categories .im-category__icon.sr-item {
  transform: translateY(34px) scale(0.9) !important;
}

.im-categories .im-category__icon.sr-item.is-visible {
  transform: translateY(0) scale(1) !important;
}

/* Title inside card appears separately */
.im-categories .im-category__title.sr-item {
  transform: translateY(24px) !important;
}

.im-categories .im-category__title.sr-item.is-visible {
  transform: translateY(0) !important;
}

/* Mobile */
@media (max-width: 767px) {
  .im-category__icon {
    width: 64px !important;
    height: 64px !important;
    margin-bottom: 14px !important;
    border-radius: 18px !important;
    font-size: 26px !important;
  }

  .im-category__title {
    font-size: 15px !important;
  }
}

/* ========================================
   PROCESS SECTION — LUXURY FLOW
======================================== */
.im-process {
  position: relative !important;
  padding: 120px 0 !important;
  overflow: hidden !important;

  background:
    radial-gradient(
      circle at 20% 20%,
      rgba(94, 198, 255, 0.12),
      transparent 30%
    ),
    radial-gradient(
      circle at 80% 80%,
      rgba(94, 198, 255, 0.08),
      transparent 30%
    ),
    linear-gradient(180deg, #f8fbff 0%, #eef5fc 50%, #f6faff 100%) !important;
}

/* subtle grid */
.im-process::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;

  background-image:
    linear-gradient(rgba(15, 23, 42, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 23, 42, 0.04) 1px, transparent 1px) !important;

  background-size: 90px 90px !important;
  opacity: 0.4 !important;

  mask-image: radial-gradient(circle, black 50%, transparent 100%) !important;
}

/* container */
.im-process__container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
}

/* head */
.im-process__head {
  text-align: center !important;
  max-width: 700px !important;
  margin: 0 auto 80px !important;
}

.im-process__label {
  color: #273954 !important;
  font-size: 12px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
}

.im-process__title {
  font-size: 40px !important;
  margin: 16px 0 !important;
}

/* steps */
.im-process__steps {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 30px !important;
  position: relative !important;
}

/* line between */
.im-process__steps::before {
  content: "" !important;
  position: absolute !important;
  top: 30px !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(
    90deg,
    transparent,
    #5ec6ff,
    transparent
  ) !important;
  opacity: 0.3 !important;
}

.im-step {
  background: rgba(255, 255, 255, 0.7) !important;
  border-radius: 20px !important;
  padding: 30px !important;
  backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(94, 198, 255, 0.12) !important;
  transition: all 0.4s ease !important;
}

.im-step:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08) !important;
}

/* step */
.im-step {
  text-align: center !important;
  position: relative !important;
}

.im-process__title {
  color: #0f172a !important;
}

.im-process__text {
  color: rgba(15, 23, 42, 0.7) !important;
}

.im-step h3 {
  color: #0f172a !important;
}

.im-step p {
  color: rgba(15, 23, 42, 0.6) !important;
}

/* number */
.im-step__number {
  width: 60px !important;
  height: 60px !important;
  margin: 0 auto 20px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff, #3aa0e6) !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
  box-shadow: 0 10px 30px rgba(94, 198, 255, 0.3) !important;
}

/* title */
.im-step h3 {
  margin-bottom: 10px !important;
}

/* text */
.im-step p {
  font-size: 14px !important;
  line-height: 1.6 !important;
}

/* hover */
.im-step:hover .im-step__number {
  transform: scale(1.1) !important;
}

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

  .im-process__steps::before {
    display: none !important;
  }
}

/* ========================================
   IMPERIAL CTA SECTION — LUXURY PARALLAX V2
======================================== */
.im-cta {
  position: relative !important;
  overflow: hidden !important;
  padding: 130px 0 !important;
  background: #071426 !important;
  isolation: isolate !important;
}

.im-cta__bg {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
}

.im-cta__bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: scale(1.05) !important;
  filter: brightness(0.82) saturate(0.92) contrast(1.03) !important;
}

/* Softer overlay so the image stays visible */
.im-cta__overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background:
    linear-gradient(
      90deg,
      rgba(7, 20, 38, 0.72) 0%,
      rgba(7, 20, 38, 0.56) 34%,
      rgba(7, 20, 38, 0.42) 64%,
      rgba(7, 20, 38, 0.6) 100%
    ),
    linear-gradient(180deg, rgba(6, 14, 28, 0.12) 0%, rgba(6, 14, 28, 0.2) 100%) !important;
}

.im-cta__glow {
  position: absolute !important;
  border-radius: 999px !important;
  filter: blur(90px) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.im-cta__glow--one {
  top: 8% !important;
  left: 6% !important;
  width: 280px !important;
  height: 280px !important;
  background: rgba(94, 198, 255, 0.12) !important;
}

.im-cta__glow--two {
  right: 8% !important;
  bottom: 4% !important;
  width: 260px !important;
  height: 260px !important;
  background: rgba(159, 220, 255, 0.1) !important;
}

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

/* Main shell */
.im-cta__shell {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr) !important;
  gap: 26px !important;
  align-items: stretch !important;
  padding: 28px !important;
  border-radius: 34px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow:
    0 26px 70px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* Left */
.im-cta__content {
  padding: 18px 20px 18px 20px !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.im-cta__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(94, 198, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  color: #dff4ff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.im-cta__eyebrow::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #9fdcff 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.55) !important;
}

.im-cta__title {
  margin: 0 0 18px !important;
  color: #ffffff !important;
  font-size: clamp(34px, 4.4vw, 60px) !important;
  line-height: 1.04 !important;
  font-weight: 800 !important;
  letter-spacing: -0.035em !important;
  max-width: 760px !important;
}

.im-cta__text {
  max-width: 640px !important;
  margin: 0 0 30px !important;
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 16px !important;
  line-height: 1.85 !important;
}

.im-cta__actions {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: nowrap !important;
}

/* Right side */
.im-cta__side {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 18px !important;
  min-height: 100% !important;
}

.im-cta__info-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 190px !important;
  padding: 28px 24px !important;
  border-radius: 28px !important;
  background: linear-gradient(
    180deg,
    rgba(12, 32, 56, 0.88) 0%,
    rgba(9, 24, 42, 0.82) 100%
  ) !important;
  border: 1px solid rgba(94, 198, 255, 0.16) !important;
  box-shadow:
    0 20px 48px rgba(0, 0, 0, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
}

.im-cta__info-number {
  display: block !important;
  margin-bottom: 8px !important;
  color: #8fd8ff !important;
  font-size: 52px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
}

.im-cta__info-text {
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  max-width: 260px !important;
}

.im-cta__mini-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.im-cta__mini-card {
  min-height: 180px !important;
  padding: 22px 20px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.03) inset !important;
}

.im-cta__mini-label {
  display: inline-flex !important;
  margin-bottom: 12px !important;
  color: #9fdcff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
}

.im-cta__mini-card h3 {
  margin: 0 0 10px !important;
  color: #ffffff !important;
  font-size: 20px !important;
  line-height: 1.28 !important;
  font-weight: 700 !important;
}

.im-cta__mini-card p {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.72) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

/* Brighter outline in CTA */
.im-cta .im-btn-outline {
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
}

.im-cta .im-btn-outline:hover {
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.2) 0%,
    rgba(58, 160, 230, 0.18) 100%
  ) !important;
  border-color: rgba(94, 198, 255, 0.46) !important;
}

/* Tablet */
@media (max-width: 1100px) {
  .im-cta__shell {
    grid-template-columns: 1fr !important;
  }

  .im-cta__side {
    grid-template-columns: 1fr !important;
  }

  .im-cta__info-card {
    min-height: 160px !important;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .im-cta {
    padding: 82px 0 !important;
  }

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

  .im-cta__shell {
    padding: 14px !important;
    border-radius: 24px !important;
    gap: 14px !important;
  }

  .im-cta__content,
  .im-cta__info-card,
  .im-cta__mini-card {
    border-radius: 20px !important;
  }

  .im-cta__content {
    padding: 18px 16px !important;
  }

  .im-cta__title {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.08 !important;
  }

  .im-cta__text {
    font-size: 15px !important;
    line-height: 1.75 !important;
    margin-bottom: 24px !important;
  }

  .im-cta__actions {
    gap: 10px !important;
    justify-content: flex-start !important;
  }

  .im-cta__info-number {
    font-size: 40px !important;
  }

  .im-cta__mini-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .im-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
  }
}

/* ========================================
   IMPERIAL MEDICAL SUPPLIES — FAQ SECTION
   Light luxury background + dark blue luxury cards
======================================== */
.im-faq {
  position: relative !important;
  overflow: hidden !important;
  padding: 110px 0 !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(94, 198, 255, 0.14) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 86% 82%,
      rgba(159, 220, 255, 0.1) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #f8fbff 0%, #eef6fc 52%, #f6fbff 100%) !important;
}

.im-faq::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(10, 26, 47, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 26, 47, 0.03) 1px, transparent 1px) !important;
  background-size: 88px 88px !important;
  opacity: 0.34 !important;
  mask-image: radial-gradient(
    circle at center,
    black 48%,
    transparent 100%
  ) !important;
  pointer-events: none !important;
}

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

.im-faq__head {
  max-width: 780px !important;
  margin: 0 auto 48px !important;
  text-align: center !important;
}

.im-faq__eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  background: rgba(94, 198, 255, 0.1) !important;
  border: 1px solid rgba(94, 198, 255, 0.16) !important;
  color: #1c4b73 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.im-faq__eyebrow::before {
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.36) !important;
}

.im-faq__title {
  margin: 0 0 18px !important;
  color: #0f172a !important;
  font-size: clamp(34px, 4vw, 54px) !important;
  line-height: 1.08 !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}

.im-faq__text {
  margin: 0 auto !important;
  max-width: 700px !important;
  color: #475569 !important;
  font-size: 16px !important;
  line-height: 1.85 !important;
}

/* ========================================
   FAQ list
======================================== */
.im-faq__list {
  display: grid !important;
  gap: 14px !important;
}

.im-faq__item {
  position: relative !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background:
    radial-gradient(
      circle at 18% 18%,
      rgba(94, 198, 255, 0.08) 0%,
      transparent 26%
    ),
    linear-gradient(
      135deg,
      rgba(17, 37, 64, 0.98) 0%,
      rgba(13, 31, 54, 0.98) 46%,
      rgba(9, 23, 42, 0.98) 100%
    ) !important;
  border: 1px solid rgba(94, 198, 255, 0.12) !important;
  box-shadow:
    0 22px 48px rgba(15, 23, 42, 0.08),
    0 0 0 1px rgba(255, 255, 255, 0.02) inset !important;
  transition:
    transform 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease !important;
}

.im-faq__item:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(94, 198, 255, 0.2) !important;
  box-shadow:
    0 28px 56px rgba(15, 23, 42, 0.12),
    0 10px 24px rgba(94, 198, 255, 0.08) !important;
}

/* ========================================
   Trigger
======================================== */
.im-faq__trigger {
  position: relative !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 28px 28px !important;
  border: none !important;
  background: transparent !important;
  text-align: left !important;
  cursor: pointer !important;
}

.im-faq__question {
  color: #ffffff !important;
  font-size: 22px !important;
  line-height: 1.4 !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
}

/* ========================================
   Arrow icon — blue like 10+
======================================== */
.im-faq__icon {
  position: relative !important;
  flex: 0 0 22px !important;
  width: 22px !important;
  height: 22px !important;
}

.im-faq__icon::before,
.im-faq__icon::after {
  content: "" !important;
  position: absolute !important;
  top: 9px !important;
  width: 14px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: #5ec6ff !important;
  transition:
    transform 0.35s ease,
    background-color 0.35s ease,
    opacity 0.35s ease !important;
}

.im-faq__icon::before {
  left: -1px !important;
  transform: rotate(45deg) !important;
  transform-origin: center !important;
}

.im-faq__icon::after {
  right: -1px !important;
  transform: rotate(-45deg) !important;
  transform-origin: center !important;
}

/* Open state arrow */
.im-faq__item.is-open .im-faq__icon::before {
  transform: rotate(-45deg) !important;
}

.im-faq__item.is-open .im-faq__icon::after {
  transform: rotate(45deg) !important;
}

.im-faq__item.is-open .im-faq__icon::before,
.im-faq__item.is-open .im-faq__icon::after {
  background: #8fd8ff !important;
}

/* ========================================
   Content
======================================== */
.im-faq__content {
  display: grid !important;
  grid-template-rows: 0fr !important;
  transition: grid-template-rows 0.45s ease !important;
}

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

.im-faq__content-inner {
  overflow: hidden !important;
  padding: 0 28px 0 28px !important;
  color: rgba(255, 255, 255, 0.76) !important;
  font-size: 16px !important;
  line-height: 1.9 !important;
}

.im-faq__item.is-open .im-faq__content-inner {
  padding-bottom: 28px !important;
}

/* Divider line */
.im-faq__item.is-open .im-faq__trigger::after {
  content: "" !important;
  position: absolute !important;
  left: 28px !important;
  right: 28px !important;
  bottom: 0 !important;
  height: 1px !important;
  background: linear-gradient(
    90deg,
    rgba(94, 198, 255, 0) 0%,
    rgba(94, 198, 255, 0.45) 50%,
    rgba(94, 198, 255, 0) 100%
  ) !important;
}

/* ========================================
   Mobile
======================================== */
@media (max-width: 767px) {
  .im-faq {
    padding: 78px 0 !important;
  }

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

  .im-faq__title {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.1 !important;
  }

  .im-faq__text {
    font-size: 15px !important;
    line-height: 1.78 !important;
  }

  .im-faq__trigger {
    padding: 22px 18px !important;
    gap: 14px !important;
  }

  .im-faq__question {
    font-size: 18px !important;
    line-height: 1.42 !important;
  }

  .im-faq__content-inner {
    padding: 0 18px 0 18px !important;
    font-size: 15px !important;
    line-height: 1.78 !important;
  }

  .im-faq__item.is-open .im-faq__content-inner {
    padding-bottom: 22px !important;
  }

  .im-faq__item.is-open .im-faq__trigger::after {
    left: 18px !important;
    right: 18px !important;
  }
}

/* ========================================
   IMPERIAL MEDICAL SUPPLIES — FOOTER
======================================== */
.im-footer {
  position: relative !important;
  overflow: hidden !important;
  padding: 96px 0 26px !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(94, 198, 255, 0.14) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 86% 78%,
      rgba(38, 96, 179, 0.08) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #07111d 0%, #06101a 52%, #050d17 100%) !important;
}

.im-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.24 !important;
  pointer-events: none !important;
}

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

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

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

.im-footer__eyebrow {
  display: inline-block !important;
  margin: 0 0 18px !important;
  color: rgba(94, 198, 255, 0.84) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

.im-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;
}

.im-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;
}

/* CTA card */
.im-footer__cta-card {
  align-self: end !important;
  padding: 26px 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;
}

.im-footer__cta-label {
  display: inline-block !important;
  margin: 0 0 10px !important;
  color: rgba(94, 198, 255, 0.82) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.im-footer__cta-text {
  margin: 0 0 18px !important;
  color: #ffffff !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  font-weight: 600 !important;
}

.im-footer__actions {
  justify-content: flex-start !important;
}

/* ========================================
   MIDDLE
======================================== */
.im-footer__middle {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr 1.1fr !important;
  gap: 24px !important;
  padding: 34px 0 !important;
}

.im-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;
}

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

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

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

/* ========================================
   BOTTOM
======================================== */
.im-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;
}

.im-footer__copy,
.im-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;
}

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

.im-footer__bottom-links a:hover {
  color: #8fd8ff !important;
}

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

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

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

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

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

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

/* ========================================
   Footer Contact Styling Upgrade
======================================== */
.im-footer__company {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  margin-bottom: 6px !important;
}

.im-footer__address {
  color: rgba(255, 255, 255, 0.68) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.im-footer__phone {
  color: #8fd8ff !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  margin-top: 6px !important;
  display: inline-block !important;
  transition: transform 0.3s ease !important;
}

.im-footer__phone:hover {
  transform: translateX(4px) !important;
}

/* ========================================
   IMPERIAL FOOTER — MOBILE 2x2 GRID FIX
======================================== */
@media (max-width: 767px) {
  .im-footer__middle {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
    align-items: start !important;
  }

  /* Keep all 4 columns in a clean 2x2 layout */
  .im-footer__middle .im-footer__col {
    grid-column: auto !important;
  }

  .im-footer__heading {
    font-size: 14px !important;
    margin-bottom: 12px !important;
  }

  .im-footer__links,
  .im-footer__contact {
    gap: 8px !important;
  }

  .im-footer__links a,
  .im-footer__contact a,
  .im-footer__contact span {
    font-size: 14px !important;
    line-height: 1.6 !important;
  }
}

/* ========================================
   CONTACT PAGE — WPFORMS 26 LUXURY STYLE
======================================== */
.im-contact-form-wrap #wpforms-26 {
  position: relative !important;
}

.im-contact-form-wrap #wpforms-26 .wpforms-field-container {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  column-gap: 16px !important;
  row-gap: 16px !important;
  align-items: start !important;
}

.im-contact-form-wrap #wpforms-26 .wpforms-field {
  margin: 0 !important;
  padding: 0 !important;
}

/* Full width fields */
.im-contact-form-wrap #wpforms-26 .wpforms-field-textarea,
.im-contact-form-wrap #wpforms-26 .wpforms-field-name,
.im-contact-form-wrap #wpforms-26 .wpforms-submit-container {
  grid-column: 1 / -1 !important;
}

/* Labels */
.im-contact-form-wrap #wpforms-26 .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;
}

/* Inputs */
.im-contact-form-wrap #wpforms-26 input[type="text"],
.im-contact-form-wrap #wpforms-26 input[type="email"],
.im-contact-form-wrap #wpforms-26 input[type="tel"],
.im-contact-form-wrap #wpforms-26 textarea,
.im-contact-form-wrap #wpforms-26 select {
  width: 100% !important;
  min-height: 56px !important;
  padding: 0 18px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !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;
}

.im-contact-form-wrap #wpforms-26 textarea {
  min-height: 170px !important;
  padding: 16px 18px !important;
  resize: vertical !important;
}

.im-contact-form-wrap #wpforms-26 input::placeholder,
.im-contact-form-wrap #wpforms-26 textarea::placeholder {
  color: rgba(255, 255, 255, 0.44) !important;
}

.im-contact-form-wrap #wpforms-26 input:focus,
.im-contact-form-wrap #wpforms-26 textarea:focus,
.im-contact-form-wrap #wpforms-26 select:focus {
  outline: none !important;
  border-color: rgba(94, 198, 255, 0.42) !important;
  background: rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 0 0 4px rgba(94, 198, 255, 0.1) !important;
  transform: translateY(-1px) !important;
}

/* Submit */
.im-contact-form-wrap #wpforms-26 .wpforms-submit-container {
  margin-top: 8px !important;
  padding: 0 !important;
}

.im-contact-form-wrap #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-radius: 999px !important;
  border: 1px solid rgba(94, 198, 255, 0.34) !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  color: #ffffff !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(94, 198, 255, 0.28),
    0 8px 18px rgba(16, 34, 60, 0.08) !important;
  transition:
    transform 0.45s ease,
    box-shadow 0.45s ease,
    color 0.45s ease,
    border-color 0.45s ease !important;
}

.im-contact-form-wrap #wpforms-submit-26:hover {
  color: #ffffff !important;
  transform: translateY(-3px) scale(1.015) !important;
  border-color: rgba(159, 220, 255, 0.7) !important;
  box-shadow:
    0 22px 44px rgba(94, 198, 255, 0.42),
    0 12px 24px rgba(16, 34, 60, 0.12) !important;
}

/* Error */
.im-contact-form-wrap #wpforms-26 .wpforms-error {
  color: #ffd6d6 !important;
  font-size: 13px !important;
  margin-top: 8px !important;
}

.im-contact-form-wrap #wpforms-26 input.wpforms-error,
.im-contact-form-wrap #wpforms-26 select.wpforms-error,
.im-contact-form-wrap #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) {
  .im-contact-form-wrap #wpforms-26 .wpforms-field-container {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 14px !important;
  }

  .im-contact-form-wrap #wpforms-26 input[type="text"],
  .im-contact-form-wrap #wpforms-26 input[type="email"],
  .im-contact-form-wrap #wpforms-26 input[type="tel"],
  .im-contact-form-wrap #wpforms-26 textarea,
  .im-contact-form-wrap #wpforms-26 select {
    min-height: 52px !important;
    font-size: 14px !important;
    border-radius: 16px !important;
  }

  .im-contact-form-wrap #wpforms-26 textarea {
    min-height: 150px !important;
  }

  .im-contact-form-wrap #wpforms-submit-26 {
    width: 100% !important;
  }
}

/* ========================================
   IMPERIAL LEGAL PAGES
   Privacy Policy / Terms of Use
======================================== */
.im-legal {
  position: relative !important;
  overflow: hidden !important;
  padding: 120px 0 !important;
  background:
    radial-gradient(
      circle at 14% 18%,
      rgba(94, 198, 255, 0.14) 0%,
      transparent 24%
    ),
    radial-gradient(
      circle at 86% 82%,
      rgba(159, 220, 255, 0.1) 0%,
      transparent 24%
    ),
    linear-gradient(180deg, #f8fbff 0%, #eef6fc 52%, #f6fbff 100%) !important;
}

.im-legal::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image:
    linear-gradient(rgba(10, 26, 47, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 26, 47, 0.03) 1px, transparent 1px) !important;
  background-size: 88px 88px !important;
  opacity: 0.34 !important;
  mask-image: radial-gradient(
    circle at center,
    black 48%,
    transparent 100%
  ) !important;
  pointer-events: none !important;
}

.im-legal__container {
  position: relative !important;
  z-index: 2 !important;
  width: min(1000px, calc(100% - 40px)) !important;
  margin: 0 auto !important;
  padding: 42px 40px !important;
  border-radius: 34px !important;
  background: rgba(255, 255, 255, 0.82) !important;
  border: 1px solid rgba(94, 198, 255, 0.12) !important;
  box-shadow:
    0 28px 60px rgba(15, 23, 42, 0.08),
    0 10px 24px rgba(94, 198, 255, 0.05) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

/* Main title */
.im-legal__container h1 {
  margin: 0 0 18px !important;
  color: #0f172a !important;
  font-size: clamp(34px, 4vw, 56px) !important;
  line-height: 1.06 !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}

/* Intro text */
.im-legal__container > p:first-of-type {
  margin-top: 0 !important;
}

/* Section titles */
.im-legal__container h2 {
  margin: 34px 0 14px !important;
  color: #10223c !important;
  font-size: 24px !important;
  line-height: 1.3 !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  position: relative !important;
  padding-left: 18px !important;
}

.im-legal__container h2::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 6px !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #5ec6ff 0%, #3aa0e6 100%) !important;
  box-shadow: 0 0 14px rgba(94, 198, 255, 0.32) !important;
}

/* Paragraphs */
.im-legal__container p {
  margin: 0 0 16px !important;
  color: #475569 !important;
  font-size: 16px !important;
  line-height: 1.9 !important;
}

/* Lists */
.im-legal__container ul {
  margin: 0 0 18px 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 10px !important;
}

.im-legal__container ul li {
  position: relative !important;
  padding-left: 22px !important;
  color: #475569 !important;
  font-size: 16px !important;
  line-height: 1.85 !important;
}

.im-legal__container ul li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 10px !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: rgba(94, 198, 255, 0.9) !important;
  box-shadow: 0 0 10px rgba(94, 198, 255, 0.24) !important;
}

/* Strong text */
.im-legal__container strong {
  color: #0f172a !important;
  font-weight: 700 !important;
}

/* Links if any */
.im-legal__container a {
  color: #1c4b73 !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.im-legal__container a:hover {
  color: #3aa0e6 !important;
}

/* Mobile */
@media (max-width: 767px) {
  .im-legal {
    padding: 78px 0 !important;
  }

  .im-legal__container {
    width: min(100%, calc(100% - 24px)) !important;
    padding: 24px 20px !important;
    border-radius: 24px !important;
  }

  .im-legal__container h1 {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.1 !important;
  }

  .im-legal__container h2 {
    font-size: 20px !important;
    margin-top: 28px !important;
    margin-bottom: 12px !important;
    padding-left: 16px !important;
  }

  .im-legal__container p,
  .im-legal__container ul li {
    font-size: 15px !important;
    line-height: 1.8 !important;
  }
}

/* ========================================
   SERVICES DROPDOWN MENU — LUXURY STYLE
======================================== */

.sub-menu {
  position: absolute !important;
  top: calc(100% + 12px) !important;
  left: 0 !important;
  min-width: 260px !important;
  padding: 12px !important;
  border-radius: 18px !important;

  /* Glass background */
  background: rgba(15, 30, 50, 0.75) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;

  border: 1px solid rgba(94, 198, 255, 0.15) !important;

  /* Shadow */
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.45),
    0 8px 20px rgba(94, 198, 255, 0.1) !important;

  display: grid !important;
  gap: 6px !important;

  opacity: 0 !important;
  transform: translateY(10px) scale(0.98) !important;
  pointer-events: none !important;
  transition: all 0.35s ease !important;
}

/* SHOW ON HOVER */
.menu-item:hover > .sub-menu {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  pointer-events: auto !important;
}

/* MENU ITEMS */
.sub-menu li {
  list-style: none !important;
}

/* LINKS */
.sub-menu li a {
  display: block !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;

  color: #dbeafe !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  text-decoration: none !important;

  background: transparent !important;

  transition: all 0.3s ease !important;
}

/* HOVER EFFECT */
.sub-menu li a:hover {
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.2),
    rgba(58, 160, 230, 0.15)
  ) !important;

  color: #ffffff !important;

  transform: translateX(4px) !important;

  box-shadow: 0 6px 16px rgba(94, 198, 255, 0.2) !important;
}

/* ACTIVE ITEM */
.sub-menu li.current-menu-item a {
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.25),
    rgba(58, 160, 230, 0.2)
  ) !important;

  color: #ffffff !important;
}

/* SMALL DIVIDER EFFECT */
.sub-menu li:not(:last-child) a {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

/* ========================================
   DESKTOP SERVICES DROPDOWN — CLEAN FIX
======================================== */

/* Parent menu item */
#header nav[data-id="menu"] .menu > li.menu-item-has-children {
  position: relative !important;
}

/* Invisible hover bridge so dropdown does not close */
#header nav[data-id="menu"] .menu > li.menu-item-has-children::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 100% !important;
  height: 16px !important;
}

/* Desktop dropdown only */
#header nav[data-id="menu"] .menu > li > .sub-menu {
  position: absolute !important;
  top: calc(100% + 6px) !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(10px) !important;
  min-width: 270px !important;
  margin: 0 !important;
  padding: 12px !important;
  list-style: none !important;
  border-radius: 18px !important;

  background: rgba(15, 30, 50, 0.9) !important;
  border: 1px solid rgba(94, 198, 255, 0.16) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;

  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.35),
    0 10px 24px rgba(94, 198, 255, 0.08) !important;

  display: grid !important;
  gap: 6px !important;

  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition:
    opacity 0.28s ease,
    visibility 0.28s ease,
    transform 0.28s ease !important;
  z-index: 9999 !important;
}

/* Show on hover/focus */
#header nav[data-id="menu"] .menu > li.menu-item-has-children:hover > .sub-menu,
#header
  nav[data-id="menu"]
  .menu
  > li.menu-item-has-children:focus-within
  > .sub-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translateX(-50%) translateY(0) !important;
}

/* Dropdown items */
#header nav[data-id="menu"] .menu > li > .sub-menu li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Dropdown links */
#header nav[data-id="menu"] .menu > li > .sub-menu li > a,
#header nav[data-id="menu"] .menu > li > .sub-menu li > .ct-menu-link {
  display: block !important;
  width: 100% !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;

  color: rgba(255, 255, 255, 0.94) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.45 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;

  background: transparent !important;
  border: 1px solid transparent !important;

  transition:
    color 0.3s ease,
    background-color 0.3s ease,
    border-color 0.3s ease,
    transform 0.3s ease,
    box-shadow 0.3s ease !important;
}

/* Hover state */
#header nav[data-id="menu"] .menu > li > .sub-menu li > a:hover,
#header nav[data-id="menu"] .menu > li > .sub-menu li > .ct-menu-link:hover {
  color: #ffffff !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.16),
    rgba(58, 160, 230, 0.12)
  ) !important;
  border-color: rgba(94, 198, 255, 0.18) !important;
  transform: translateX(4px) !important;
  box-shadow: 0 8px 18px rgba(94, 198, 255, 0.12) !important;
}

/* Active submenu item */
#header nav[data-id="menu"] .menu > li > .sub-menu li.current-menu-item > a,
#header
  nav[data-id="menu"]
  .menu
  > li
  > .sub-menu
  li.current-menu-item
  > .ct-menu-link {
  color: #ffffff !important;
  background: linear-gradient(
    135deg,
    rgba(94, 198, 255, 0.2),
    rgba(58, 160, 230, 0.14)
  ) !important;
  border-color: rgba(94, 198, 255, 0.2) !important;
}

/* ========================================
   MOBILE SERVICES SUBMENU — FINAL FIX
======================================== */
@media (max-width: 1024px) {
  /* Hide submenu by default */
  #offcanvas .mobile-menu .sub-menu {
    position: static !important;
    min-width: 100% !important;
    margin: 10px 0 0 !important;
    padding: 0 0 0 18px !important;
    list-style: none !important;

    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;

    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;

    display: none !important;
  }

  /* IMPORTANT: keep it hidden even on current Services page */
  /* #offcanvas
    .mobile-menu
    li.menu-item-has-children.current-menu-ancestor
    > .sub-menu,
  #offcanvas
    .mobile-menu
    li.menu-item-has-children.current-menu-parent
    > .sub-menu,
  #offcanvas
    .mobile-menu
    li.menu-item-has-children.current_page_parent
    > .sub-menu,
  #offcanvas
    .mobile-menu
    li.menu-item-has-children.current_page_ancestor
    > .sub-menu {
    display: none !important;
  } */

  /* Submenu links */
  #offcanvas .mobile-menu .sub-menu li > a,
  #offcanvas .mobile-menu .sub-menu li > .ct-menu-link {
    display: flex !important;
    align-items: center !important;
    min-height: 54px !important;
    padding: 0 18px !important;
    border-radius: 18px !important;

    background: linear-gradient(
      135deg,
      rgba(18, 42, 68, 0.92),
      rgba(10, 28, 48, 0.92)
    ) !important;
    border: 1px solid rgba(94, 198, 255, 0.18) !important;
    box-shadow:
      0 12px 22px rgba(0, 0, 0, 0.16),
      inset 0 0 0 1px rgba(255, 255, 255, 0.02) !important;

    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    letter-spacing: 0.02em !important;
    text-transform: none !important;
    text-decoration: none !important;

    transition:
      transform 0.3s ease,
      border-color 0.3s ease,
      box-shadow 0.3s ease !important;
  }

  #offcanvas .mobile-menu .sub-menu li > a:hover,
  #offcanvas .mobile-menu .sub-menu li > .ct-menu-link:hover {
    transform: translateX(4px) !important;
    border-color: rgba(94, 198, 255, 0.28) !important;
    box-shadow:
      0 16px 28px rgba(0, 0, 0, 0.18),
      0 6px 18px rgba(94, 198, 255, 0.08) !important;
  }

  /* Arrow button color */
  #offcanvas .mobile-menu .ct-toggle-dropdown-mobile {
    color: #5ec6ff !important;
  }

  #offcanvas .mobile-menu .ct-toggle-dropdown-mobile svg {
    fill: #5ec6ff !important;
    transition: transform 0.3s ease !important;
  }

  /* Rotate arrow when expanded */
  #offcanvas .mobile-menu .ct-toggle-dropdown-mobile[aria-expanded="true"] svg {
    transform: rotate(180deg) !important;
  }

  /* Show submenu only when JS adds the open class */
  #offcanvas .mobile-menu li.is-submenu-open > .sub-menu {
    display: grid !important;
    gap: 10px !important;
  }

  /* Rotate arrow when JS marks item as open */
  #offcanvas
    .mobile-menu
    li.is-submenu-open
    > .ct-sub-menu-parent
    .ct-toggle-dropdown-mobile
    svg,
  #offcanvas
    .mobile-menu
    li.is-submenu-open
    .ct-sub-menu-parent
    .ct-toggle-dropdown-mobile
    svg {
    transform: rotate(180deg) !important;
  }

  #offcanvas .mobile-menu .sub-menu {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  #offcanvas .mobile-menu li.is-submenu-open > .sub-menu {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
}
