/* Final launch polish: premium homepage hero, compact header and responsive safety. */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

html {
  scroll-padding-top: 104px;
}

section,
[id] {
  scroll-margin-top: 112px;
}

.site-header {
  min-height: 82px !important;
  padding: 9px clamp(24px, 5vw, 72px) !important;
  background: rgba(255, 255, 255, 0.96) !important;
  border-bottom: 1px solid rgba(185, 216, 239, 0.82) !important;
  box-shadow: 0 8px 24px rgba(20, 35, 80, 0.08) !important;
}

.brand img {
  max-height: 64px !important;
  max-width: min(230px, 42vw) !important;
}

.nav-links {
  gap: clamp(14px, 1.55vw, 24px) !important;
  font-weight: 850 !important;
}

.hero {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(440px, 0.9fr) minmax(430px, 1fr) minmax(310px, 0.5fr) !important;
  grid-template-rows: auto !important;
  align-items: center !important;
  gap: clamp(22px, 2.4vw, 42px) !important;
  min-height: calc(100vh - 82px) !important;
  padding: clamp(58px, 7vw, 96px) clamp(34px, 6vw, 92px) clamp(44px, 5vw, 76px) !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(111, 174, 232, 0.20), transparent 32%),
    radial-gradient(circle at 76% 22%, rgba(106, 163, 66, 0.10), transparent 28%),
    linear-gradient(135deg, #f7fcff 0%, #eef8ff 48%, #ffffff 100%) !important;
}

.hero::after {
  content: "" !important;
  position: absolute !important;
  right: -120px !important;
  bottom: -170px !important;
  width: 460px !important;
  height: 460px !important;
  border-radius: 50% !important;
  background: rgba(111, 174, 232, 0.12) !important;
  pointer-events: none !important;
}

.hero-scrim {
  display: none !important;
}

.hero-content {
  position: relative !important;
  z-index: 2 !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: min(700px, 100%) !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  box-sizing: border-box !important;
}

.hero .eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 22px !important;
  color: #4f78bd !important;
  font-size: 0.84rem !important;
  font-weight: 950 !important;
  letter-spacing: 0.16em !important;
}

.hero .eyebrow::before {
  content: "" !important;
  width: 34px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: #6faee8 !important;
}

.hero h1 {
  max-width: 720px !important;
  margin: 0 0 24px !important;
  color: #25224f !important;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: clamp(2.85rem, 4vw, 4.2rem) !important;
  font-weight: 920 !important;
  line-height: 1.01 !important;
  letter-spacing: -0.02em !important;
}

.hero-copy {
  max-width: 650px !important;
  margin: 0 !important;
  color: #3e506c !important;
  font-size: clamp(1.06rem, 1.25vw, 1.22rem) !important;
  line-height: 1.7 !important;
}

.hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  align-items: stretch !important;
  margin-top: 34px !important;
}

.hero-actions .button {
  flex: 0 0 auto !important;
  min-width: 220px !important;
  max-width: 270px !important;
  min-height: 56px !important;
  padding: 14px 18px !important;
  border-radius: 10px !important;
  font-weight: 880 !important;
  white-space: nowrap !important;
  box-shadow: 0 14px 28px rgba(20, 35, 80, 0.10) !important;
}

.hero-actions .button.primary {
  border-color: transparent !important;
  background: linear-gradient(135deg, #2f93dc, #4f78bd) !important;
}

.hero-actions .button.secondary {
  border-color: #9ec8e8 !important;
  background: rgba(255, 255, 255, 0.88) !important;
}

.hero-image {
  position: relative !important;
  z-index: 1 !important;
  inset: auto !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: 100% !important;
  height: clamp(560px, 64vh, 710px) !important;
  max-height: none !important;
  aspect-ratio: auto !important;
  padding: 0 !important;
  object-fit: cover !important;
  object-position: center top !important;
  opacity: 1 !important;
  border: 1px solid rgba(185, 216, 239, 0.95) !important;
  border-radius: 34px !important;
  background: #ffffff !important;
  box-shadow: 0 30px 72px rgba(20, 35, 80, 0.18) !important;
  box-sizing: border-box !important;
}

.rating-panel {
  z-index: 3 !important;
  grid-column: 3 !important;
  grid-row: 1 !important;
  align-self: center !important;
  justify-self: stretch !important;
  width: min(340px, 100%) !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 20px !important;
  border: 1px solid rgba(185, 216, 239, 0.95) !important;
  border-top: 6px solid #6aa342 !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.96) !important;
  box-shadow: 0 22px 52px rgba(20, 35, 80, 0.16) !important;
  backdrop-filter: blur(10px) !important;
  box-sizing: border-box !important;
}

.rating-panel .cqc-label {
  margin-bottom: 10px !important;
  font-size: 0.96rem !important;
  line-height: 1.35 !important;
}

.rating-panel strong {
  margin-top: 12px !important;
}

.cqc-good {
  font-size: 1.55rem !important;
}

.cqc-date,
.cqc-activity {
  font-size: 0.92rem !important;
}

.rating-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  margin-top: 12px !important;
}

.rating-list span {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 12px !important;
  min-width: 0 !important;
  padding: 8px 10px !important;
}

.rating-list b {
  flex: 0 0 auto !important;
  padding: 5px 12px !important;
  font-size: 0.8rem !important;
  white-space: nowrap !important;
}

.trust-strip {
  margin-top: 0 !important;
  padding-top: clamp(22px, 3vw, 34px) !important;
}

@media (max-width: 1180px) {
  .hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: clamp(50px, 8vw, 82px) clamp(22px, 6vw, 56px) !important;
  }

  .hero-content,
  .hero-image,
  .rating-panel {
    grid-column: 1 !important;
    width: min(860px, 100%) !important;
    max-width: 100% !important;
    justify-self: center !important;
  }

  .hero-content {
    grid-row: 1 !important;
  }

  .hero-image {
    grid-row: 2 !important;
    height: clamp(430px, 54vw, 560px) !important;
    object-fit: cover !important;
  }

  .rating-panel {
    position: relative !important;
    grid-row: 3 !important;
    align-self: auto !important;
    justify-self: center !important;
    margin: 0 !important;
  }
}

@media (max-width: 720px) {
  html {
    scroll-padding-top: 84px;
  }

  section,
  [id] {
    scroll-margin-top: 88px;
  }

  .site-header {
    min-height: 70px !important;
    padding: 8px 18px !important;
  }

  .brand img {
    max-height: 52px !important;
    max-width: min(188px, 58vw) !important;
  }

  .hero {
    gap: 24px !important;
    padding: 42px 16px 48px !important;
  }

  .hero h1 {
    font-size: clamp(2.55rem, 13vw, 3.8rem) !important;
    line-height: 1.03 !important;
    letter-spacing: -0.035em !important;
  }

  .hero-copy {
    font-size: 1rem !important;
    line-height: 1.62 !important;
  }

  .hero-actions,
  .hero-actions .button {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    white-space: normal !important;
  }

  .hero-image {
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
    object-position: center top !important;
    border-radius: 22px !important;
  }

  .rating-panel {
    padding: 20px !important;
  }
}

/* Final public KPI dashboard */
#performance.kpi-section {
  background:
    radial-gradient(circle at 18% 12%, rgba(111, 174, 232, 0.18), transparent 28%),
    linear-gradient(180deg, #eef8ff 0%, #ffffff 100%) !important;
  padding: 76px 6vw 90px !important;
}

#performance .section-heading {
  display: block !important;
  max-width: 980px !important;
  margin: 0 auto 38px !important;
  text-align: center !important;
}

#performance .section-heading > div {
  margin: 0 !important;
}

#performance .section-kicker {
  margin: 0 0 12px !important;
  color: #517fbe !important;
  font-size: 0.82rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}

#performance h2 {
  margin: 0 0 16px !important;
  color: #25224f !important;
  font-size: 3.2rem !important;
  line-height: 1.05 !important;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-weight: 900 !important;
}

#performance .section-heading > p {
  max-width: 760px !important;
  margin: 0 auto !important;
  color: #52617a !important;
  font-size: 1.08rem !important;
  line-height: 1.62 !important;
}

#performance .public-kpi-grid {
  max-width: 1320px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

#performance .public-kpi-card {
  position: relative !important;
  min-height: 214px !important;
  padding: 22px 20px 20px !important;
  border: 1px solid #b9d8ef !important;
  border-radius: 20px !important;
  background: linear-gradient(180deg, #ffffff 0%, #fafdff 100%) !important;
  box-shadow: 0 14px 34px rgba(20, 35, 80, 0.08) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
  overflow: hidden !important;
}

#performance .public-kpi-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 0 auto 0 !important;
  height: 5px !important;
  background: linear-gradient(90deg, #6faee8, #c9e2f5) !important;
}

#performance .public-kpi-card.good::before {
  background: linear-gradient(90deg, #6aa342, #a9d18e) !important;
}

#performance .kpi-icon {
  width: 54px !important;
  height: 44px !important;
  margin: 0 0 16px !important;
  border: 1px solid #b9d8ef !important;
  border-radius: 14px !important;
  background: #eaf6ff !important;
  color: #25224f !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.72rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
}

#performance .public-kpi-card.good .kpi-icon {
  border-color: #a9d18e !important;
  background: #eef8e9 !important;
  color: #5f9838 !important;
}

#performance .kpi-label {
  margin: 0 0 8px !important;
  color: #627087 !important;
  font-size: 0.74rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.085em !important;
  line-height: 1.25 !important;
  text-transform: uppercase !important;
}

#performance .kpi-value,
#performance .kpi-value.small {
  display: block !important;
  margin: 0 0 10px !important;
  color: #25224f !important;
  font-size: 1.5rem !important;
  line-height: 1.12 !important;
  font-weight: 900 !important;
}

#performance .kpi-value.good,
#performance .public-kpi-card.good .kpi-value {
  color: #5f9838 !important;
}

#performance .public-kpi-card p {
  margin: 0 !important;
  color: #52617a !important;
  font-size: 0.96rem !important;
  line-height: 1.45 !important;
}

@media (max-width: 1100px) {
  #performance .public-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 720px) {
  #performance.kpi-section {
    padding: 56px 18px 66px !important;
  }

  #performance h2 {
    font-size: 2.15rem !important;
  }

  #performance .section-heading {
    margin-bottom: 28px !important;
  }

  #performance .public-kpi-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  #performance .public-kpi-card {
    min-height: auto !important;
    padding: 20px !important;
  }
}

/* Final professional standards logo cards */
#standards.standards-section {
  background:
    radial-gradient(circle at 12% 12%, rgba(111, 174, 232, 0.13), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f5fbff 100%) !important;
}

#standards .standards-grid {
  max-width: 1280px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 20px !important;
  align-items: stretch !important;
}

#standards .standards-carousel {
  max-width: 1280px !important;
  margin: 30px auto 0 !important;
  padding: 0 44px 44px !important;
  visibility: visible !important;
}

#standards .standards-carousel:not(.is-initialized) .splide__track {
  overflow: visible !important;
}

#standards .standards-carousel.is-initialized .splide__track {
  overflow: hidden !important;
}

#standards .standards-carousel.is-initialized .splide__list {
  display: flex !important;
  align-items: stretch !important;
}

#standards .standards-carousel:not(.is-initialized) .splide__list,
#standards .standards-carousel.carousel-fallback .splide__list {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 20px !important;
  align-items: stretch !important;
  transform: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

#standards .standards-carousel .splide__slide {
  display: flex !important;
  height: auto !important;
}

#standards .standards-carousel:not(.is-initialized) .splide__slide,
#standards .standards-carousel.carousel-fallback .splide__slide {
  width: auto !important;
}

#standards .standard-card {
  min-height: 258px !important;
  width: 100% !important;
  padding: 22px 20px 20px !important;
  border: 1px solid #b9d8ef !important;
  border-top: 5px solid #6faee8 !important;
  border-radius: 20px !important;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
  box-shadow: 0 14px 34px rgba(20, 35, 80, 0.08) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
  gap: 10px !important;
}

#standards .standard-card::before,
#standards .standard-card.text-standard::before,
#standards .standard-card::after {
  content: none !important;
  display: none !important;
}

#standards .standard-card img {
  width: 100% !important;
  max-width: 240px !important;
  height: 112px !important;
  max-height: 112px !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block !important;
  margin: 0 auto 8px !important;
  padding: 6px !important;
  border-radius: 14px !important;
  background: #ffffff !important;
}

#standards .standard-card.logo-standard img {
  max-width: 250px !important;
  height: 126px !important;
  max-height: 126px !important;
  border: 1px solid #d6e8f6 !important;
  background: #f8fcff !important;
}

#standards .standard-card.iso-card img {
  max-width: 150px !important;
  height: 150px !important;
  max-height: 150px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: transparent !important;
}

#standards .standard-card.ico-card img {
  max-width: 230px !important;
  height: 118px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 10px !important;
  background: #053f78 !important;
}

#standards .standard-card.aoht-card img {
  max-width: 150px !important;
  height: 150px !important;
  max-height: 150px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: #ffffff !important;
}

#standards .standard-card.atc-card img {
  max-width: 170px !important;
  height: 154px !important;
  max-height: 154px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

#standards .standard-card.dspt-standard img {
  max-width: 310px !important;
  height: 124px !important;
  max-height: 124px !important;
  padding: 4px !important;
  border: 0 !important;
  border-radius: 10px !important;
  background: #ffffff !important;
}

#standards .standard-card.dementia-card img {
  max-width: 210px !important;
  height: 118px !important;
  max-height: 118px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: #ffffff !important;
}

#standards .standard-card h3 {
  margin: 2px 0 0 !important;
  color: #25224f !important;
  font-size: 1.02rem !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
}

#standards .standard-card p {
  margin: 0 !important;
  color: #52617a !important;
  font-size: 0.92rem !important;
  line-height: 1.42 !important;
}

#standards .certificate-link {
  margin-top: auto !important;
  color: #4f78bd !important;
  font-size: 0.86rem !important;
  font-weight: 900 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

#standards .standards-carousel .splide__arrow {
  width: 40px !important;
  height: 40px !important;
  border: 1px solid #9ec8e8 !important;
  background: #ffffff !important;
  box-shadow: 0 10px 22px rgba(20, 35, 80, 0.12) !important;
  opacity: 1 !important;
}

#standards .standards-carousel .splide__arrow svg {
  fill: #25224f !important;
}

#standards .standards-carousel .splide__pagination {
  bottom: 2px !important;
}

#standards .standards-carousel .splide__pagination__page {
  width: 22px !important;
  height: 4px !important;
  border-radius: 999px !important;
  background: #b9d8ef !important;
  opacity: 1 !important;
}

#standards .standards-carousel .splide__pagination__page.is-active {
  background: #4f78bd !important;
  transform: scale(1) !important;
}

@media (max-width: 1100px) {
  #standards .standards-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #standards .standards-carousel:not(.is-initialized) .splide__list,
  #standards .standards-carousel.carousel-fallback .splide__list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #standards .standards-carousel {
    padding-inline: 38px !important;
  }
}

@media (max-width: 640px) {
  #standards .standards-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  #standards .standards-carousel:not(.is-initialized) .splide__list,
  #standards .standards-carousel.carousel-fallback .splide__list {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  #standards .standards-carousel {
    padding: 0 22px 42px !important;
  }

  #standards .standard-card {
    min-height: 226px !important;
  }
}
