/* Scheda immobile ambient — preset definitivo (PORTAL_DETAIL_AMBIENT=1) */

body.portal-detail-ambient {
  overflow-x: clip;
}

/* Hero + box prezzo: mai clip (part_01 overflow:hidden, CTA sticky, glass overflow) */
body.portal-detail-ambient .property-detail-premium-hero,
body.portal-detail-ambient .property-hero-shell-fix.property-detail-premium-hero,
body.portal-detail-ambient section.hero-shell.property-detail-premium-hero,
body.portal-detail-ambient .property-hero-shell-fix,
body.portal-detail-ambient .hero-shell.property-hero-shell-fix {
  overflow: visible !important;
}

body.portal-detail-ambient .property-detail-premium-hero .property-detail-hero-grid,
body.portal-detail-ambient .property-detail-premium-hero .property-hero-layout-fix {
  overflow: visible;
}

body.portal-detail-ambient .property-detail-premium-hero .property-detail-cta-card,
body.portal-detail-ambient .property-detail-premium-hero #detailContactBox {
  position: relative !important;
  top: 0 !important;
  inset: auto !important;
  overflow: visible !important;
  align-self: start;
}

body.portal-detail-ambient .property-hero-shell-fix {
  padding-bottom: 56px !important;
}

body.portal-detail-ambient .property-detail-login-note {
  margin-top: 14px;
  padding-bottom: 2px;
}

/* Aside simili desktop: card intera visibile, scroll solo nel track */
@media (min-width: 901px) {
  body.portal-detail-ambient #detailSplit.detail-split-root,
  body.portal-detail-ambient #detailSplit {
    width: calc(100% - 56px) !important;
    max-width: calc(100% - 56px) !important;
    box-sizing: border-box !important;
  }

  body.portal-detail-ambient #detailAside {
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
  }

  body.portal-detail-ambient #similarPropertiesCard {
    overflow: visible !important;
    flex: 0 1 auto !important;
    min-height: auto !important;
  }

  body.portal-detail-ambient #similarPropertiesCard::after {
    content: none !important;
    display: none !important;
  }

  body.portal-detail-ambient #similarTrack {
    max-height: min(560px, calc(100vh - var(--topbar-h, 84px) - 300px)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 16px !important;
    -webkit-overflow-scrolling: touch;
  }
}

body.portal-detail-ambient.is-hero-ambient-on .property-detail-premium-hero,
body.portal-detail-ambient.is-hero-ambient-on .property-hero-shell-fix.property-detail-premium-hero,
body.portal-detail-ambient.is-hero-ambient-on section.hero-shell.property-detail-premium-hero {
  position: relative;
  isolation: isolate;
  overflow: visible !important;
  background:
    linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.95),
      color-mix(in srgb, var(--brand-ghost) 90%, rgba(255, 255, 255, 0.5))
    ),
    linear-gradient(180deg, rgba(var(--brand-rgb), 0.07), transparent 58%);
  border-color: rgba(var(--brand-rgb), 0.12);
}

body.portal-detail-ambient.is-hero-ambient-on .property-detail-premium-hero::before {
  content: "";
  position: absolute;
  inset: -15% -8% auto;
  height: 65%;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(75% 75% at 12% 0%, rgba(var(--brand-rgb), 0.16), transparent 70%);
}

body.portal-detail-ambient.is-hero-ambient-on .property-detail-hero-grid {
  position: relative;
  z-index: 1;
  align-items: start;
}

body.portal-detail-ambient .property-detail-premium-hero .property-hero-copy-fix > .eyebrow {
  margin-bottom: 10px;
}

body.portal-detail-ambient .property-detail-cta-card > .eyebrow {
  margin-bottom: 6px;
}

body.portal-detail-ambient .property-detail-cta-card .property-detail-price-main {
  margin-top: 8px;
}

body.portal-detail-ambient #similarPropertiesCard > .eyebrow {
  margin-top: 2px;
}

body.portal-detail-ambient #similarPropertiesCard > .similar-properties-title {
  margin-top: 10px;
}

body.portal-detail-ambient #similarPropertiesCard > .similar-properties-lead {
  margin-top: 10px;
  margin-bottom: 16px;
}

body.portal-detail-ambient #detailMainColumn > .detail-section-card,
body.portal-detail-ambient #detailMainColumn > .section.card {
  padding: 24px 26px !important;
}

body.portal-detail-ambient #detailMainColumn .detail-section-card > .eyebrow,
body.portal-detail-ambient #detailMainColumn .section.card > .eyebrow {
  margin-bottom: 8px;
}

body.portal-detail-ambient #detailMainColumn .detail-section-title,
body.portal-detail-ambient #detailMainColumn .section.card > h2 {
  margin: 6px 0 14px;
}

body.portal-detail-ambient #detailMainColumn .detail-prose-block,
body.portal-detail-ambient #detailMainColumn .section.card > p {
  margin: 12px 0 0;
  padding: 0;
  line-height: 1.75;
}

body.portal-detail-ambient .property-detail-excerpt {
  margin-bottom: 4px;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .portal-detail-entrance-target {
  opacity: 0;
  transform: translateY(20px);
  animation: portal-detail-hero-entrance 0.76s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .portal-detail-entrance-target:nth-child(1) {
  animation-delay: 0.04s;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .portal-detail-entrance-target:nth-child(2) {
  animation-delay: 0.14s;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .portal-detail-entrance-target:nth-child(3) {
  animation-delay: 0.24s;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .portal-detail-entrance-target:nth-child(4) {
  animation-delay: 0.34s;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .property-hero-copy-fix > .portal-detail-entrance-target:nth-child(5) {
  animation-delay: 0.44s;
}

body.portal-detail-ambient.is-hero-entrance-on.is-hero-entrance-play .property-detail-cta-card > .portal-detail-entrance-target:nth-child(3) {
  animation-delay: 0.54s;
}

@keyframes portal-detail-hero-entrance {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

body.portal-detail-ambient.is-bridge-on .detail-split-root {
  position: relative;
}

body.portal-detail-ambient.is-bridge-on .detail-split-root::before {
  content: "";
  position: absolute;
  top: -24px;
  left: 0;
  right: 0;
  height: 44px;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(var(--brand-rgb), 0.09), transparent);
}

body.portal-detail-ambient.is-gallery-glass-on .detail-gallery-card {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.74) !important;
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, 0.85) !important;
  box-shadow:
    0 20px 48px rgba(15, 23, 42, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

body.portal-detail-ambient.is-gallery-glass-on .detail-gallery-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(105deg, transparent, rgba(255, 255, 255, 0.42), transparent);
  transform: translateX(-120%);
}

body.portal-detail-ambient.is-gallery-glass-on .detail-gallery-card:hover::after {
  animation: portal-detail-shine-sweep 1.1s ease forwards;
}

body.portal-detail-ambient #detailMainStage {
  border-radius: 20px !important;
  overflow: hidden !important;
}

body.portal-detail-ambient #detailMainImage {
  border-radius: 20px !important;
}

body.portal-detail-ambient #detailThumbs .detail-thumb {
  padding: 0;
  margin: 0;
  border: 2px solid rgba(var(--brand-rgb), 0.1) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
}

body.portal-detail-ambient #detailThumbs .detail-thumb.is-active {
  border-color: rgba(var(--brand-rgb), 0.55) !important;
  box-shadow: 0 0 0 3px rgba(var(--brand-rgb), 0.12) !important;
  outline: none !important;
}

body.portal-detail-ambient #detailThumbs .detail-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
}

@keyframes portal-detail-shine-sweep {
  0% {
    transform: translateX(-120%);
    opacity: 0;
  }

  15% {
    opacity: 0.65;
  }

  100% {
    transform: translateX(120%);
    opacity: 0;
  }
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-card {
  position: relative;
  overflow: visible;
  background: rgba(255, 255, 255, 0.78) !important;
  backdrop-filter: blur(18px) saturate(1.25);
  -webkit-backdrop-filter: blur(18px) saturate(1.25);
  border: 1px solid rgba(255, 255, 255, 0.88) !important;
  box-shadow:
    0 18px 44px rgba(var(--brand-rgb), 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-premium-hero .property-detail-cta-card {
  overflow: visible !important;
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(105deg, transparent, rgba(255, 255, 255, 0.45), transparent);
  transform: translateX(-120%);
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-card:hover::after {
  animation: portal-detail-shine-sweep 1.05s ease forwards;
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-card:not(:hover)::after {
  opacity: 0 !important;
  animation: none !important;
  transform: translateX(-120%);
}

body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-btn.btn-primary {
  box-shadow: 0 8px 22px rgba(var(--brand-rgb), 0.28);
}

body.portal-detail-ambient.is-similar-glass-on #similarTrack .similar-card,
body.portal-detail-ambient.is-similar-glass-on .similar-card {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.94) !important;
  border: 1px solid rgba(var(--brand-rgb), 0.12) !important;
  border-radius: 18px !important;
  padding: 14px !important;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

body.portal-detail-ambient.is-similar-glass-on #similarTrack .similar-card {
  border-bottom: 1px solid rgba(var(--brand-rgb), 0.12) !important;
  margin-bottom: 14px !important;
}

body.portal-detail-ambient.is-similar-glass-on #similarTrack .similar-card:last-child {
  margin-bottom: 0 !important;
}

body.portal-detail-ambient.is-similar-glass-on .similar-card:hover {
  transform: none;
  border-color: rgba(var(--brand-rgb), 0.22) !important;
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.09);
}

body.portal-detail-ambient.is-similar-glass-on .similar-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  border-radius: inherit;
  background: linear-gradient(105deg, transparent, rgba(255, 255, 255, 0.42), transparent);
  transform: translateX(-120%);
}

body.portal-detail-ambient.is-similar-glass-on .similar-card:hover::after {
  animation: portal-detail-shine-sweep 0.95s ease forwards;
}

body.portal-detail-ambient.is-similar-glass-on .similar-card:not(:hover)::after {
  opacity: 0 !important;
  animation: none !important;
  transform: translateX(-120%);
}

body.portal-detail-ambient.is-similar-glass-on .similar-thumb {
  position: relative;
  overflow: hidden !important;
  border-radius: 18px;
}

body.portal-detail-ambient.is-similar-glass-on #similarTrack .similar-thumb {
  overflow: hidden !important;
}

body.portal-detail-ambient.is-similar-glass-on #similarTrack .similar-thumb > img {
  border-radius: 18px;
}

body.portal-detail-ambient.is-section-reveal-on [data-portal-detail-section] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

body.portal-detail-ambient.is-section-reveal-on [data-portal-detail-section].is-section-revealed {
  opacity: 1;
  transform: translateY(0);
}

body.portal-detail-ambient.is-section-reveal-on #detailAside.is-section-revealed,
body.portal-detail-ambient.is-section-reveal-on #detailGalleryHost.is-section-revealed {
  transition: none !important;
}

/* —— WOW leggero (PORTAL_DETAIL_AMBIENT_WOW_LIGHT=1) —— */

body.portal-detail-ambient.is-wow-light-on.is-bridge-on .detail-split-root::before {
  animation: portal-detail-bridge-pulse 3.2s ease-in-out infinite alternate;
}

@keyframes portal-detail-bridge-pulse {
  from {
    opacity: 0.55;
    transform: scaleY(0.92);
  }

  to {
    opacity: 1;
    transform: scaleY(1);
  }
}

/* Sticky quick-nav: main.container con overflow-x:hidden forza overflow-y:auto e taglia il kicker */
body.portal-detail-ambient main.container {
  overflow: visible !important;
}

body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-shell {
  position: sticky;
  top: calc(var(--portal-topbar-sticky-h, var(--topbar-h, 88px)) + 12px);
  z-index: 18;
  margin: 0 0 20px;
  padding: 12px 16px 14px;
  overflow: visible;
  box-sizing: border-box;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(var(--brand-rgb), 0.08));
  border: 1px solid rgba(var(--brand-rgb), 0.22);
  box-shadow: 0 16px 40px rgba(var(--brand-rgb), 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

@media (min-width: 901px) {
  body.portal-detail-ambient.is-wow-light-on #detailSplit.detail-split-root {
    grid-template-rows: auto auto auto !important;
  }

  body.portal-detail-ambient.is-wow-light-on #detailSplit > .portal-detail-quicknav-shell {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  body.portal-detail-ambient.is-wow-light-on #detailGalleryHost {
    grid-row: 2 !important;
  }

  body.portal-detail-ambient.is-wow-light-on #detailMainColumn {
    grid-row: 3 !important;
  }

  body.portal-detail-ambient.is-wow-light-on #detailAside {
    grid-row: 1 / -1 !important;
    z-index: 38;
    isolation: isolate;
  }

  body.portal-detail-ambient.is-wow-light-on #similarPropertiesCard {
    position: relative;
    z-index: 1;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.9)),
      rgba(255, 255, 255, 0.94) !important;
    backdrop-filter: blur(14px) saturate(1.25);
    -webkit-backdrop-filter: blur(14px) saturate(1.25);
  }
}

body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-kicker {
  display: block;
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-strong);
}

body.portal-detail-ambient.is-wow-light-on .property-detail-quicknav.portal-detail-quicknav-bar,
body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-bar {
  position: static !important;
  top: auto !important;
  z-index: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  width: auto !important;
  max-width: none !important;
}

body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-bar a {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  min-height: 34px;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-bar a:hover,
body.portal-detail-ambient.is-wow-light-on .portal-detail-quicknav-bar a:focus-visible {
  background: rgba(var(--brand-rgb), 0.1) !important;
  color: var(--brand-strong) !important;
  box-shadow: inset 0 0 0 1px rgba(var(--brand-rgb), 0.18) !important;
}

body.portal-detail-ambient.is-wow-light-on #detailMainInfo,
body.portal-detail-ambient.is-wow-light-on #detailFeatures,
body.portal-detail-ambient.is-wow-light-on #detailMapSection,
body.portal-detail-ambient.is-wow-light-on #portalFinancialTools {
  scroll-margin-top: calc(var(--portal-topbar-sticky-h, var(--topbar-h, 88px)) + 96px);
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(1) {
  transition-delay: 0.02s;
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(2) {
  transition-delay: 0.08s;
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(3) {
  transition-delay: 0.14s;
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(4) {
  transition-delay: 0.2s;
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(5) {
  transition-delay: 0.26s;
}

body.portal-detail-ambient.is-wow-light-on.is-section-reveal-on #detailMainColumn > [data-portal-detail-section]:nth-child(6) {
  transition-delay: 0.32s;
}

body.portal-detail-ambient.is-wow-light-on #detailMainImage {
  transition: opacity 0.22s ease;
}

body.portal-detail-ambient.is-wow-light-on #detailMainImage.is-portal-detail-gallery-fading {
  opacity: 0.35;
}

body.portal-detail-ambient.is-wow-light-on .detail-main-stat,
body.portal-detail-ambient.is-wow-light-on .detail-feature-box,
body.portal-detail-ambient.is-wow-light-on .detail-territory-row,
body.portal-detail-ambient.is-wow-light-on .portal-financial-result-card {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

body.portal-detail-ambient.is-wow-light-on .detail-main-stat:hover,
body.portal-detail-ambient.is-wow-light-on .detail-feature-box:hover,
body.portal-detail-ambient.is-wow-light-on .detail-territory-row:hover,
body.portal-detail-ambient.is-wow-light-on .portal-financial-result-card:hover {
  transform: translateY(-4px) scale(1.02) !important;
  border-color: rgba(var(--brand-rgb), 0.32) !important;
  box-shadow: 0 18px 36px rgba(var(--brand-rgb), 0.16);
}

/* CTA hero: solo ombra (no transform — evita clip con hero) */
body.portal-detail-ambient.is-wow-light-on .property-detail-premium-hero .property-detail-cta-card {
  transition: box-shadow 0.22s ease, border-color 0.22s ease;
}

body.portal-detail-ambient.is-wow-light-on .property-detail-premium-hero .property-detail-cta-card:hover {
  transform: none;
  border-color: rgba(var(--brand-rgb), 0.28) !important;
  box-shadow: 0 14px 32px rgba(var(--brand-rgb), 0.14);
}

/* Simili: solo ombra/bordo — no transform (overflow sticky aside + reveal) */
body.portal-detail-ambient.is-wow-light-on #similarTrack .similar-card {
  transition: box-shadow 0.22s ease, border-color 0.22s ease;
  transform: none;
}

body.portal-detail-ambient.is-wow-light-on #similarTrack .similar-card:hover {
  transform: none;
  border-color: rgba(var(--brand-rgb), 0.28) !important;
  box-shadow: 0 14px 32px rgba(var(--brand-rgb), 0.12);
}

/* Freeze baseline screenshot (PORTAL_VISUAL=1) — stato statico post-entrance */

body.portal-detail-ambient[data-portal-detail-ambient-freeze="1"] .portal-detail-entrance-target,
body.portal-detail-ambient[data-portal-detail-ambient-freeze="1"] [data-portal-detail-section] {
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
  body.portal-detail-ambient.is-wow-light-on.is-bridge-on .detail-split-root::before {
    animation: none !important;
  }

  body.portal-detail-ambient.is-wow-light-on .detail-main-stat,
  body.portal-detail-ambient.is-wow-light-on .detail-feature-box,
  body.portal-detail-ambient.is-wow-light-on .detail-territory-row,
  body.portal-detail-ambient.is-wow-light-on .portal-financial-result-card,
  body.portal-detail-ambient.is-wow-light-on #detailMainImage {
    transition: none !important;
  }

  body.portal-detail-ambient.is-wow-light-on .detail-main-stat:hover,
  body.portal-detail-ambient.is-wow-light-on .detail-feature-box:hover,
  body.portal-detail-ambient.is-wow-light-on .detail-territory-row:hover,
  body.portal-detail-ambient.is-wow-light-on .portal-financial-result-card:hover {
    transform: none !important;
  }

  body.portal-detail-ambient.is-wow-light-on #similarTrack .similar-card,
  body.portal-detail-ambient.is-wow-light-on #similarTrack .similar-card:hover,
  body.portal-detail-ambient.is-wow-light-on .property-detail-premium-hero .property-detail-cta-card,
  body.portal-detail-ambient.is-wow-light-on .property-detail-premium-hero .property-detail-cta-card:hover {
    transition: none !important;
  }

  body.portal-detail-ambient.is-hero-entrance-on .portal-detail-entrance-target,
  body.portal-detail-ambient.is-section-reveal-on [data-portal-detail-section] {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  body.portal-detail-ambient.is-gallery-glass-on .detail-gallery-card::after,
  body.portal-detail-ambient.is-cta-glass-on .property-detail-cta-card::after,
  body.portal-detail-ambient.is-similar-glass-on .similar-card::after {
    opacity: 0 !important;
  }
}
