/* ==========================================================================
   LAYOUT FIXES — centering, blending, grid alignment (no redesign)
   ========================================================================== */

/* =============================================================================
   HERO DESKTOP — center trainer, seamless atmosphere
   ============================================================================= */

@media (min-width: 901px) {
  .hero__scene.hero-visual,
  .hero-visual {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .hero-trainer,
  .trainer-photo--hero {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin: 0 auto !important;
    height: 88vh !important;
    max-height: calc(100vh - var(--header-h) - 1rem) !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .hero__atmo {
    inset: 0 !important;
    left: 0 !important;
    right: 0 !important;
  }

  .hero::before {
    background:
      radial-gradient(ellipse 50% 60% at 72% 50%, rgba(182, 255, 0, 0.04) 0%, transparent 68%) !important;
  }

  .hero-visual::before,
  .hero-visual::after {
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    transform: none !important;
  }

  .hero-visual::before {
    background: radial-gradient(
      ellipse 38% 46% at 50% 50%,
      rgba(182, 255, 0, 0.42) 0%,
      rgba(182, 255, 0, 0.16) 32%,
      rgba(182, 255, 0, 0.04) 52%,
      transparent 68%
    ) !important;
    filter: blur(48px) !important;
    -webkit-mask-image: radial-gradient(ellipse 100% 95% at 50% 50%, #000 5%, transparent 72%);
    mask-image: radial-gradient(ellipse 100% 95% at 50% 50%, #000 5%, transparent 72%);
  }

  .hero-visual::after {
    background:
      radial-gradient(ellipse 40% 34% at 28% 46%, rgba(200, 200, 200, 0.1) 0%, transparent 62%),
      radial-gradient(ellipse 36% 32% at 72% 48%, rgba(160, 160, 160, 0.08) 0%, transparent 58%),
      radial-gradient(ellipse 48% 42% at 50% 42%, rgba(255, 255, 255, 0.04) 0%, transparent 65%) !important;
    -webkit-mask-image: radial-gradient(ellipse 95% 90% at 50% 50%, #000 8%, transparent 100%);
    mask-image: radial-gradient(ellipse 95% 90% at 50% 50%, #000 8%, transparent 100%);
  }

  .hero__atmo-spot-halo,
  .hero__atmo-glow,
  .hero__atmo-glow--soft,
  .hero__atmo-spot-core,
  .hero__atmo-floor-shadow {
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    transform: none !important;
    margin: 0 !important;
  }

  .hero__atmo-spot-halo {
    background: radial-gradient(
      ellipse 55% 58% at 50% 50%,
      rgba(182, 255, 0, 0.1) 0%,
      rgba(182, 255, 0, 0.04) 42%,
      transparent 72%
    ) !important;
    filter: blur(60px);
    -webkit-mask-image: radial-gradient(ellipse 96% 92% at 50% 50%, #000 10%, transparent 100%);
    mask-image: radial-gradient(ellipse 96% 92% at 50% 50%, #000 10%, transparent 100%);
  }

  .hero__atmo-glow {
    background: radial-gradient(
      ellipse 42% 48% at 50% 50%,
      rgba(182, 255, 0, 0.26) 0%,
      rgba(182, 255, 0, 0.1) 40%,
      transparent 74%
    ) !important;
    filter: blur(36px) !important;
    -webkit-mask-image: radial-gradient(ellipse 94% 90% at 50% 50%, #000 14%, transparent 100%);
    mask-image: radial-gradient(ellipse 94% 90% at 50% 50%, #000 14%, transparent 100%);
  }

  .hero__atmo-glow--soft {
    background: radial-gradient(
      ellipse 34% 40% at 50% 50%,
      rgba(182, 255, 0, 0.32) 0%,
      rgba(182, 255, 0, 0.1) 48%,
      transparent 76%
    ) !important;
    filter: blur(26px) !important;
    -webkit-mask-image: radial-gradient(ellipse 90% 86% at 50% 50%, #000 18%, transparent 100%);
    mask-image: radial-gradient(ellipse 90% 86% at 50% 50%, #000 18%, transparent 100%);
  }

  .hero__atmo-spot-core {
    background: radial-gradient(
      ellipse 28% 34% at 50% 50%,
      rgba(210, 255, 80, 0.45) 0%,
      rgba(182, 255, 0, 0.2) 42%,
      transparent 76%
    ) !important;
    filter: blur(22px);
    -webkit-mask-image: radial-gradient(ellipse 88% 84% at 50% 50%, #000 22%, transparent 100%);
    mask-image: radial-gradient(ellipse 88% 84% at 50% 50%, #000 22%, transparent 100%);
  }

  .hero__atmo-floor-shadow {
    top: auto !important;
    height: 18% !important;
    background: radial-gradient(ellipse 42% 90% at 50% 0%, rgba(0, 0, 0, 0.45) 0%, transparent 72%) !important;
    -webkit-mask-image: radial-gradient(ellipse 80% 100% at 50% 0%, #000 20%, transparent 100%);
    mask-image: radial-gradient(ellipse 80% 100% at 50% 0%, #000 20%, transparent 100%);
  }

  .hero__atmo-shoulder-smoke,
  .hero__atmo-smoke,
  .hero__atmo-smoke--2 {
    -webkit-mask-image: radial-gradient(ellipse 94% 88% at 50% 50%, #000 5%, transparent 100%);
    mask-image: radial-gradient(ellipse 94% 88% at 50% 50%, #000 5%, transparent 100%);
  }

  .hero__atmo-lines {
    -webkit-mask-image: radial-gradient(ellipse 92% 86% at 50% 50%, #000 10%, transparent 100%) !important;
    mask-image: radial-gradient(ellipse 92% 86% at 50% 50%, #000 10%, transparent 100%) !important;
  }

  .hero__atmo-edge-fade {
    inset: 0 !important;
    background: radial-gradient(
      ellipse 100% 95% at 50% 50%,
      transparent 20%,
      rgba(5, 5, 5, 0.2) 58%,
      rgba(5, 5, 5, 0.98) 88%
    ) !important;
  }

  .hero__atmo-vignette {
    inset: 0 !important;
    background: radial-gradient(
      ellipse 90% 86% at 50% 50%,
      transparent 22%,
      rgba(0, 0, 0, 0.3) 68%,
      rgba(0, 0, 0, 0.85) 100%
    ) !important;
  }

  .hero__atmo-particles {
    -webkit-mask-image: radial-gradient(ellipse 90% 85% at 50% 50%, #000 15%, transparent 100%);
    mask-image: radial-gradient(ellipse 90% 85% at 50% 50%, #000 15%, transparent 100%);
  }

  .hero__cinema-glow--center,
  .hero__cinema-glow--right {
    opacity: 0.2 !important;
  }
}

/* =============================================================================
   HERO MOBILE — center, 55vh, seamless fade
   ============================================================================= */

@media (max-width: 900px) {
  .hero__scene.hero-visual,
  .hero-visual {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    height: 55vh !important;
    min-height: 55vh !important;
    max-height: 55vh !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
  }

  .hero-trainer,
  .trainer-photo--hero {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    margin: 0 auto !important;
    height: 92% !important;
    max-height: 92% !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .hero__atmo {
    inset: 0 !important;
  }

  .hero-visual::before,
  .hero-visual::after {
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    transform: none !important;
  }

  .hero-visual::before {
    background: radial-gradient(
      ellipse 48% 50% at 50% 50%,
      rgba(182, 255, 0, 0.36) 0%,
      rgba(182, 255, 0, 0.1) 38%,
      transparent 68%
    ) !important;
    -webkit-mask-image: radial-gradient(ellipse 100% 96% at 50% 50%, #000 4%, transparent 70%);
    mask-image: radial-gradient(ellipse 100% 96% at 50% 50%, #000 4%, transparent 70%);
  }

  .hero__atmo-spot-halo,
  .hero__atmo-glow,
  .hero__atmo-glow--soft,
  .hero__atmo-spot-core,
  .hero__atmo-floor-shadow {
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    transform: none !important;
  }

  .hero__atmo-edge-fade {
    background: radial-gradient(
      ellipse 100% 96% at 50% 50%,
      transparent 22%,
      rgba(5, 5, 5, 0.25) 60%,
      rgba(5, 5, 5, 0.98) 88%
    ) !important;
  }

  .hero__content {
    width: 100% !important;
    max-width: 100% !important;
    padding-inline: 20px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  .hero > .container.hero__inner {
    overflow-x: hidden !important;
  }
}

/* =============================================================================
   ABOUT — three-column grid alignment
   ============================================================================= */

@media (min-width: 901px) {
  .about__inner {
    align-items: stretch !important;
    gap: clamp(1rem, 1.6vw, 1.35rem) !important;
    height: 100% !important;
  }

  .about__visual,
  .about__content,
  .about__certs {
    height: 72vh !important;
    min-height: 72vh !important;
    max-height: 72vh !important;
    align-self: start !important;
    box-sizing: border-box;
  }

  .about__visual {
    display: flex !important;
    align-items: stretch !important;
    justify-content: center !important;
  }

  .about__portrait-card {
    height: 100% !important;
    min-height: 0 !important;
    max-height: 100% !important;
    flex: 1 1 auto;
  }

  .about__content {
    display: grid !important;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto;
    justify-content: stretch !important;
    align-content: start;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    gap: 0 !important;
    overflow: hidden !important;
  }

  .about__highlights {
    margin-bottom: 0.5rem !important;
    overflow: hidden;
    align-self: start;
  }

  .about__content .btn {
    margin-top: 0 !important;
    align-self: start;
    flex-shrink: 0 !important;
    min-height: 46px !important;
    padding: 0.68rem 1.25rem !important;
    font-size: 0.72rem !important;
  }

  .about__certs {
    justify-content: flex-start !important;
    gap: 1rem !important;
  }

  .about__certs .edu-block:last-child {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .about__certs .cert-list--compact {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }

  .about__highlights li,
  .about__certs .cert-list--compact .cert-list__item {
    padding: 0.14rem 0 !important;
    line-height: 1.38 !important;
  }

  .about__certs .edu-block {
    margin-bottom: 0 !important;
  }

  .about__content > .eyebrow,
  .about__certs .edu-block:first-child > .eyebrow {
    margin-top: 0 !important;
    margin-bottom: 0.55rem !important;
    padding-top: 0 !important;
    line-height: 1.2 !important;
  }

  .about__certs .edu-block + .edu-block > .eyebrow {
    margin-top: 0 !important;
    margin-bottom: 0.55rem !important;
  }

  .about .section__title--left {
    margin-top: 0 !important;
  }

  .about__certs .cert-list--compact .cert-list__item {
    border-bottom: none !important;
  }
}

/* =============================================================================
   SERVICES — person-centered crops
   ============================================================================= */

.service-card__media img {
  object-fit: cover;
  object-position: center 42%;
}

.service-card[data-service-id="mfr"] .service-card__media img {
  object-position: center 40%;
}

.service-card[data-service-id="core-training"] .service-card__media img {
  object-position: center 38%;
}

.service-card[data-service-id="corrective"] .service-card__media img {
  object-position: center 52%;
}

.service-card[data-service-id="msk-rehab"] .service-card__media img {
  object-position: center 40%;
}

.service-card[data-service-id="pilates-back"] .service-card__media img {
  object-position: center 36%;
}

.service-card[data-service-id="nutrition"] .service-card__media img {
  object-position: center 38%;
}

.service-modal__visual .service-modal__image,
.service-modal__image-banner .service-modal__image {
  object-fit: contain;
  object-position: center center;
  background: #080808;
}

.service-modal[data-active-service="mfr"] .service-modal__image {
  object-position: center 45%;
  object-fit: cover;
}

.service-modal[data-active-service="core-training"] .service-modal__image {
  object-position: center 42%;
  object-fit: cover;
}

.service-modal[data-active-service="corrective"] .service-modal__image {
  object-position: center center;
  object-fit: contain;
}

.service-modal[data-active-service="msk-rehab"] .service-modal__image {
  object-position: center 44%;
  object-fit: cover;
}

.service-modal[data-active-service="pilates-back"] .service-modal__image {
  object-position: center 40%;
  object-fit: cover;
}

.service-modal[data-active-service="nutrition"] .service-modal__image {
  object-position: center 42%;
  object-fit: cover;
}

@media (max-width: 900px) {
  .service-card__media img {
    object-position: center 40% !important;
  }

  .service-card[data-service-id="mfr"] .service-card__media img {
    object-position: center 38% !important;
  }

  .service-card[data-service-id="core-training"] .service-card__media img {
    object-position: center 36% !important;
  }

  .service-card[data-service-id="corrective"] .service-card__media img {
    object-position: center 50% !important;
  }

  .service-card[data-service-id="msk-rehab"] .service-card__media img {
    object-position: center 38% !important;
  }

  .service-card[data-service-id="pilates-back"] .service-card__media img {
    object-position: center 34% !important;
  }

  .service-card[data-service-id="nutrition"] .service-card__media img {
    object-position: center 36% !important;
  }
}
