/* ============================================
   Luxy Builder — editorial / ultra-luxury front-end
   ============================================ */

:root {
  --color-bg: #090909;
  --color-bg-elevated: #0e0e0e;
  --color-surface: #141414;
  --color-gold: #d6c6a8;
  --color-gold-dim: rgba(214, 198, 168, 0.55);
  --color-white: #f7f6f3;
  --color-muted: #8a9396;
  --font-display: "Bodoni Moda", "Didot", "Libre Bodoni", Georgia, serif;
  --font-body: "Plus Jakarta Sans", system-ui, sans-serif;
  --hairline: rgba(214, 198, 168, 0.12);
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.75rem;
  --space-lg: 3.5rem;
  --space-xl: clamp(3.5rem, 8vw, 6.5rem);
  --space-2xl: clamp(5rem, 14vw, 11rem);
  --space-section-y: clamp(5.5rem, 12vw, 10rem);
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-lux: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-reveal: 1.2s;
  --header-h: 5.25rem;
  --readable: 38rem;
  --readable-wide: 44rem;
}

[data-theme="light"] {
  color-scheme: light;
  /* Tema sabbia/avorio: meno “ospedale”, più villa — niente bianchi freddi */
  --color-bg: #e7e0d4;
  --color-bg-elevated: #dbd3c6;
  --color-surface: #cec6b9;
  --color-gold: #5a4d36;
  --color-gold-dim: rgba(90, 77, 54, 0.78);
  --color-white: #1b1917;
  --color-muted: #525a5c;
  --hairline: rgba(27, 25, 23, 0.12);
  /* Rarissimi lift UI: caldo, mai #fff pieno */
  --color-paper: #f0e9df;
}

/* Optional full-screen splash (see site.splashScreen in content.json) */
html.luxy-splash-active body {
  overflow: hidden;
}

.luxy-splash-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0a0a0a;
  opacity: 0;
  transition: opacity var(--luxy-splash-fade-ms, 420ms) var(--ease-out);
  pointer-events: none;
}

[data-theme="light"] .luxy-splash-overlay {
  background: #e7e0d4;
}

.luxy-splash-overlay.luxy-splash-overlay--in {
  opacity: 1;
  pointer-events: auto;
}

.luxy-splash-overlay.luxy-splash-overlay--out {
  opacity: 0;
  pointer-events: none;
}

.luxy-splash-overlay__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  padding: 2rem;
}

.luxy-splash-overlay__logo {
  display: block;
  max-width: min(300px, 70vw);
  max-height: min(22vh, 160px);
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: center;
}

.luxy-splash-overlay__spinner {
  width: 44px;
  height: 44px;
  border: 3px solid rgba(255, 255, 255, 0.22);
  border-top-color: rgba(214, 198, 168, 0.9);
  border-radius: 50%;
  animation: luxy-splash-spin 0.72s linear infinite;
}

[data-theme="light"] .luxy-splash-overlay__spinner {
  border-color: rgba(27, 25, 23, 0.12);
  border-top-color: rgba(90, 77, 54, 0.85);
}

@media (prefers-reduced-motion: reduce) {
  .luxy-splash-overlay {
    transition-duration: 0.01ms;
  }

  .luxy-splash-overlay__spinner {
    animation: none;
    border-top-color: rgba(214, 198, 168, 0.55);
  }
}

@keyframes luxy-splash-spin {
  to {
    transform: rotate(360deg);
  }
}

/* No broken-image placeholder before JS sets src from JSON */
img[data-bind-src]:not([src]),
img[data-bind-src][src=""] {
  visibility: hidden;
}

[data-theme="light"] body {
  /* Sfondo pieno: i radial su grandi superfici creano bande (stepping) visibili soprattutto sotto la hero */
  background-color: var(--color-bg);
  background-image: none;
}

/* Header light: in cima = stesso gradiente trasparente del dark + testi chiari; sticky = barra bianca + testi scuri */
[data-theme="light"] .site-header:not(.is-scrolled) {
  background: linear-gradient(
    to bottom,
    rgba(9, 9, 9, 0.78) 0%,
    rgba(9, 9, 9, 0.12) 70%,
    transparent 100%
  );
  box-shadow: none;
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-logo,
[data-theme="light"] .site-header:not(.is-scrolled) .site-logo__text {
  color: rgba(247, 246, 243, 0.95);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-nav__list a {
  color: rgba(247, 246, 243, 0.5);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-nav__list a:hover {
  color: rgba(247, 246, 243, 0.92);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-nav__list a.is-active {
  color: #d6c6a8;
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-lang__btn {
  color: rgba(247, 246, 243, 0.45);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-lang__btn:hover {
  color: rgba(247, 246, 243, 0.85);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-lang__btn.is-active {
  color: var(--color-bg);
  background: rgba(214, 198, 168, 0.82);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-header__cta {
  color: rgba(214, 198, 168, 0.88);
  border-bottom-color: rgba(214, 198, 168, 0.42);
}

[data-theme="light"] .site-header:not(.is-scrolled) .site-header__cta:hover {
  color: rgba(247, 246, 243, 0.95);
  border-bottom-color: rgba(247, 246, 243, 0.45);
}

[data-theme="light"] .site-header:not(.is-scrolled) .nav-toggle__bar {
  background: rgba(247, 246, 243, 0.92);
}

[data-theme="light"] .site-header.is-scrolled {
  background: color-mix(in srgb, var(--color-bg-elevated) 92%, var(--color-gold) 5%);
  backdrop-filter: blur(16px) saturate(1.05);
  -webkit-backdrop-filter: blur(16px) saturate(1.05);
  box-shadow: 0 1px 0 rgba(27, 25, 23, 0.08);
}

[data-theme="light"] .site-header.is-scrolled .site-logo,
[data-theme="light"] .site-header.is-scrolled .site-logo__text {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] .site-header.is-scrolled .site-nav__list a {
  color: rgba(27, 25, 23, 0.5);
}

[data-theme="light"] .site-header.is-scrolled .site-nav__list a:hover {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] .site-header.is-scrolled .site-nav__list a.is-active {
  color: var(--color-gold);
}

[data-theme="light"] .site-header.is-scrolled .site-lang__btn {
  color: rgba(27, 25, 23, 0.45);
}

[data-theme="light"] .site-header.is-scrolled .site-lang__btn:hover {
  color: rgba(27, 25, 23, 0.85);
}

[data-theme="light"] .site-header.is-scrolled .site-lang__btn.is-active {
  color: #faf8f4;
  background: rgba(90, 77, 54, 0.88);
}

[data-theme="light"] .site-header.is-scrolled .site-header__cta {
  color: var(--color-gold-dim);
  border-bottom-color: rgba(90, 77, 54, 0.35);
}

[data-theme="light"] .site-header.is-scrolled .site-header__cta:hover {
  color: rgba(27, 25, 23, 0.88);
  border-color: rgba(27, 25, 23, 0.28);
}

[data-theme="light"] .site-header.is-scrolled .nav-toggle__bar {
  background: var(--color-white);
}

@media (max-width: 900px) {
  [data-theme="light"] .site-nav {
    background: color-mix(in srgb, var(--color-bg-elevated) 96%, var(--color-gold) 4%);
  }

  [data-theme="light"] .site-nav .site-nav__list a {
    color: rgba(27, 25, 23, 0.55);
  }

  [data-theme="light"] .site-nav .site-nav__list a:hover {
    color: rgba(27, 25, 23, 0.92);
  }

  [data-theme="light"] .site-nav .site-nav__list a.is-active {
    color: var(--color-gold);
  }
}

/* Light: pagine interne — niente fascia nera in alto; contrasto come barra bianca (logo scuro da logoUrlLight) */
[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) {
  background: transparent;
  box-shadow: none;
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-logo,
[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-logo__text {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-nav__list a {
  color: rgba(27, 25, 23, 0.5);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-nav__list a:hover {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-nav__list a.is-active {
  color: var(--color-gold);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-lang__btn {
  color: rgba(27, 25, 23, 0.45);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-lang__btn:hover {
  color: rgba(27, 25, 23, 0.85);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-lang__btn.is-active {
  color: #faf8f4;
  background: rgba(90, 77, 54, 0.88);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-header__cta {
  color: var(--color-gold-dim);
  border-bottom-color: rgba(90, 77, 54, 0.35);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .site-header__cta:hover {
  color: rgba(27, 25, 23, 0.88);
  border-color: rgba(27, 25, 23, 0.28);
}

[data-theme="light"] body:not([data-page="index"]) .site-header:not(.is-scrolled) .nav-toggle__bar {
  background: var(--color-white);
}

[data-theme="light"] .concierge-rail__box {
  background: color-mix(in srgb, var(--color-bg-elevated) 94%, var(--color-gold) 4%);
  box-shadow:
    -8px 0 28px rgba(0, 0, 0, 0.07),
    inset 0 1px 0 rgba(27, 25, 23, 0.06);
}

[data-theme="light"] .concierge-rail__tab {
  background: var(--color-bg);
}

[data-theme="light"] .site-footer__name {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] .site-footer__tagline {
  color: rgba(82, 90, 92, 0.9);
}

[data-theme="light"] .site-footer__instagram {
  color: rgba(27, 25, 23, 0.45);
}

[data-theme="light"] .gallery-space-nav {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-bg) 96%, transparent) 0%,
    color-mix(in srgb, var(--color-bg) 82%, transparent) 70%,
    transparent 100%
  );
  border-bottom-color: rgba(27, 25, 23, 0.08);
}

[data-theme="light"] .btn--ghost {
  color: rgba(27, 25, 23, 0.55);
  border-color: rgba(27, 25, 23, 0.15);
}

[data-theme="light"] .btn--ghost:hover {
  color: rgba(27, 25, 23, 0.88);
  border-color: rgba(27, 25, 23, 0.32);
}

[data-theme="light"] .skip-link {
  color: #f8f6f1;
}

[data-theme="light"] .prose a:not([class]),
[data-theme="light"] .body-large a:not([class]) {
  text-decoration-color: rgba(90, 77, 54, 0.32);
}

[data-theme="light"] .link-arrow--dim {
  color: rgba(27, 25, 23, 0.42);
}

[data-theme="light"] .body-large {
  color: rgba(27, 25, 23, 0.74);
}

[data-theme="light"] .page-intro__title {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] .section-head__lede {
  color: rgba(27, 25, 23, 0.68);
}

[data-theme="light"] .display-sub {
  color: var(--color-white);
}

[data-theme="light"] .display-hero {
  color: var(--color-white);
}

[data-theme="light"] .luxy-booking-search__submit {
  color: rgba(27, 25, 23, 0.92) !important;
  background: var(--color-surface) !important;
  border-color: var(--hairline) !important;
}

[data-theme="light"] .luxy-booking-search__submit:hover {
  color: var(--color-paper) !important;
  background: color-mix(in srgb, var(--color-gold) 38%, var(--color-surface)) !important;
  border-color: rgba(90, 77, 54, 0.35) !important;
}

[data-theme="light"] .luxy-booking-search__submit:hover .luxy-booking-search__submit-icon {
  color: color-mix(in srgb, var(--color-paper) 92%, var(--color-gold));
}

[data-theme="light"] .highlight-card__title {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] .highlight-card__body p {
  color: rgba(82, 90, 92, 0.92);
}

[data-theme="light"] .exp-list strong {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] .exp-list__thumb,
[data-theme="light"] .exp-list__icon-wrap {
  border-color: rgba(0, 0, 0, 0.08);
  background: rgba(0, 0, 0, 0.03);
}

[data-theme="light"] .exp-list__icon-wrap {
  color: rgba(60, 58, 55, 0.55);
}

[data-theme="light"] .fullbleed__caption {
  color: rgba(252, 251, 248, 0.72);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);
}

[data-theme="light"] .room-card__title {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] .room-card__meta {
  color: rgba(90, 77, 54, 0.72);
}

[data-theme="light"] .home-booking-strip {
  /* Stesso colore del body: niente striscia “diversa” che accentua le bande */
  background: var(--color-bg);
  border-bottom-color: var(--hairline);
}

[data-theme="light"] .luxy-booking-search__card {
  background: var(--color-bg-elevated);
  border-color: var(--hairline);
  box-shadow: 0 14px 36px rgba(27, 25, 23, 0.08);
}

[data-theme="light"] .reserve-booking-strip .luxy-booking-search__card {
  background: linear-gradient(165deg, var(--color-surface) 0%, var(--color-bg-elevated) 100%);
  border-color: var(--hairline);
  box-shadow: 0 10px 30px rgba(27, 25, 23, 0.08);
}

[data-theme="light"] .luxy-booking-search__rail {
  background: var(--color-surface);
}

[data-theme="light"] .luxy-booking-search__field-shell {
  background: color-mix(in srgb, var(--color-bg) 35%, var(--color-surface));
  border-color: var(--hairline);
}

[data-theme="light"] .luxy-booking-search__field-shell:focus-within {
  border-color: rgba(90, 77, 54, 0.35);
  background: color-mix(in srgb, var(--color-bg-elevated) 55%, var(--color-surface));
}

[data-theme="light"] .luxy-booking-search__date-value,
[data-theme="light"] .luxy-booking-search__guest-input {
  color: var(--color-white) !important;
}

[data-theme="light"] .luxy-booking-search__alt-input,
[data-theme="light"] input.luxy-booking-search__alt-input {
  color: var(--color-white) !important;
}

[data-theme="light"] .luxy-booking-search__alt-input::placeholder {
  color: rgba(82, 90, 92, 0.42);
}

[data-theme="light"] .luxy-booking-search__stepper-btn {
  background: var(--color-bg-elevated);
  color: rgba(90, 77, 54, 0.92);
  border-color: var(--hairline);
}

[data-theme="light"] .luxy-booking-search__stepper-btn:hover:not(:disabled) {
  color: var(--color-paper);
  background: color-mix(in srgb, var(--color-gold) 32%, var(--color-bg-elevated));
}

[data-theme="light"] .reserve-page__calendar {
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-elevated) 50%, var(--color-surface) 100%);
}

[data-theme="light"] .reserve-calendar-root--framed .calendar-widget {
  background: var(--color-paper);
  box-shadow: 0 16px 44px rgba(27, 25, 23, 0.09);
}

[data-theme="light"] .calendar-widget {
  background: color-mix(in srgb, var(--color-paper) 88%, var(--color-surface));
}

[data-theme="light"] .calendar-day {
  color: rgba(27, 25, 23, 0.38);
}

[data-theme="light"] .calendar-day--in-month {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] .calendar-day--unavailable {
  color: rgba(27, 25, 23, 0.32);
  background: rgba(82, 90, 92, 0.12);
}

[data-theme="light"] .legend-swatch {
  border-color: var(--hairline);
}

[data-theme="light"] .reserve-page__hero-backdrop {
  background:
    radial-gradient(ellipse 85% 55% at 78% 8%, rgba(214, 198, 168, 0.1), transparent 58%),
    radial-gradient(ellipse 55% 45% at 12% 92%, rgba(122, 138, 142, 0.05), transparent 52%),
    linear-gradient(165deg, color-mix(in srgb, var(--color-bg) 70%, var(--color-gold)) 0%, var(--color-bg) 40%, var(--color-bg) 100%);
}

[data-theme="light"] .booking-embed-zone {
  background: color-mix(in srgb, var(--color-bg-elevated) 78%, var(--color-surface));
  border-color: var(--hairline);
}

[data-theme="light"] .experience-detail__schedule {
  border-top-color: var(--hairline);
}

[data-theme="light"] .experience-detail__schedule-list,
[data-theme="light"] .experience-detail__schedule-item span {
  color: var(--color-muted);
}

[data-theme="light"] .experience-detail__schedule-item strong {
  color: var(--color-white);
}

[data-theme="light"] .experience-detail__meta-item {
  background: color-mix(in srgb, var(--color-bg-elevated) 75%, var(--color-surface));
  border-color: var(--hairline);
}

[data-theme="light"] .experience-detail__meta-label {
  color: rgba(82, 90, 92, 0.75);
}

[data-theme="light"] .experience-detail__meta-value {
  color: var(--color-white);
}

[data-theme="light"] .experience-detail__body {
  color: rgba(27, 25, 23, 0.82);
}

[data-theme="light"] .experience-detail__price {
  color: rgba(90, 77, 54, 0.9);
}

[data-theme="light"] .experiences-detail-placeholder {
  border-color: var(--hairline);
}

[data-theme="light"] .experience-tile {
  border-color: var(--hairline);
  background: var(--color-surface);
}

[data-theme="light"] .experience-tile:hover {
  background: var(--color-bg-elevated);
}

[data-theme="light"] .experience-tile__media {
  background: rgba(27, 25, 23, 0.06);
}

[data-theme="light"] .experience-tile__summary {
  color: rgba(82, 90, 92, 0.9);
}

[data-theme="light"] .experience-request-form {
  border-top-color: var(--hairline);
}

[data-theme="light"] .experience-request-form__hint,
[data-theme="light"] .experience-request-form__label,
[data-theme="light"] .experience-request-form__sub-label {
  color: rgba(82, 90, 92, 0.78);
}

[data-theme="light"] .experience-request-form input,
[data-theme="light"] .experience-request-form textarea,
[data-theme="light"] .experience-request-form select {
  border-color: var(--hairline);
  background: var(--color-paper);
  color: var(--color-white);
}

[data-theme="light"] .experience-request-form__stepper-btn {
  border-color: var(--hairline);
  background: var(--color-paper);
  color: var(--color-white);
}

[data-theme="light"] .contact-form input,
[data-theme="light"] .contact-form textarea {
  border-color: var(--hairline);
  background: var(--color-paper);
  color: var(--color-white);
}

[data-theme="light"] .contact-form__feedback.is-error {
  color: #b54a4a;
}

[data-theme="light"] .contact-form__feedback.is-success {
  color: #3d6b42;
}

[data-theme="light"] .experience-media-bento__more-label {
  color: var(--color-white);
  background: var(--color-bg-elevated);
  border-color: var(--hairline);
  box-shadow: 0 2px 14px rgba(27, 25, 23, 0.1);
}

[data-theme="light"] .experience-media-bento__more-icon {
  color: var(--color-white);
}

[data-theme="light"] .experience-media-bento__thumb--more:hover .experience-media-bento__more-label {
  box-shadow: 0 3px 18px rgba(27, 25, 23, 0.12);
}

[data-theme="light"] .gallery-grid {
  background: rgba(27, 25, 23, 0.04);
}

[data-theme="light"] .gallery-grid a:hover::after {
  background: rgba(27, 25, 23, 0.1);
}

[data-theme="light"] blockquote.quote-block {
  color: rgba(27, 25, 23, 0.82);
  border-left-color: rgba(90, 77, 54, 0.35);
}

[data-theme="light"] .site-footer__legal {
  color: rgba(82, 90, 92, 0.78);
}

[data-theme="light"] .site-footer__legal-meta {
  color: rgba(82, 90, 92, 0.62);
}

[data-theme="light"] .site-footer__creator {
  color: rgba(82, 90, 92, 0.68);
}

[data-theme="light"] .site-footer__creator-link:hover {
  color: rgba(90, 77, 54, 0.92);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  /* Public site + any page without admin-specific overrides: Luxy scrollbar (gold / charcoal) */
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.38) rgba(8, 8, 8, 0.52);
}

html::-webkit-scrollbar {
  width: 8px;
}

html::-webkit-scrollbar-track {
  background: rgba(8, 8, 8, 0.5);
}

html::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.3);
  border-radius: 4px;
  border: 2px solid rgba(0, 0, 0, 0.28);
  background-clip: padding-box;
}

html::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.48);
}

html[data-theme="light"] {
  scrollbar-color: rgba(90, 77, 54, 0.36) rgba(237, 233, 224, 0.92);
}

html[data-theme="light"]::-webkit-scrollbar-track {
  background: rgba(237, 233, 224, 0.88);
}

html[data-theme="light"]::-webkit-scrollbar-thumb {
  background: rgba(90, 77, 54, 0.28);
  border: 2px solid rgba(237, 233, 224, 0.55);
  background-clip: padding-box;
}

html[data-theme="light"]::-webkit-scrollbar-thumb:hover {
  background: rgba(90, 77, 54, 0.46);
}

/* Chromium sometimes paints the viewport scrollbar on body */
body:not(.admin-app)::-webkit-scrollbar {
  width: 8px;
}

body:not(.admin-app)::-webkit-scrollbar-track {
  background: rgba(8, 8, 8, 0.5);
}

body:not(.admin-app)::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.3);
  border-radius: 4px;
  border: 2px solid rgba(0, 0, 0, 0.28);
  background-clip: padding-box;
}

body:not(.admin-app)::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.48);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

body {
  margin: 0;
  background-color: var(--color-bg);
  background-image:
    radial-gradient(ellipse 100% 80% at 10% -30%, rgba(214, 198, 168, 0.045), transparent 55%),
    radial-gradient(ellipse 70% 50% at 90% 110%, rgba(122, 138, 142, 0.04), transparent 50%);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.85rem + 0.35vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.72;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}


img,
video {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--color-gold);
  text-decoration: none;
  text-underline-offset: 0.28em;
  transition:
    color 0.5s var(--ease-lux),
    opacity 0.5s var(--ease-lux);
}

a:hover {
  color: var(--color-white);
}

.prose a:not([ class ]),
.body-large a:not([class]) {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(214, 198, 168, 0.35);
}

p {
  margin: 0 0 var(--space-sm);
}

p:last-child {
  margin-bottom: 0;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  font-optical-sizing: auto;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-md);
  font-feature-settings: "kern" 1, "liga" 1;
}

h1 { font-size: clamp(2.75rem, 6vw + 1rem, 4.85rem); }
h2 { font-size: clamp(2rem, 4vw + 0.75rem, 3.5rem); }
h3 { font-size: clamp(1.35rem, 2vw + 0.5rem, 2rem); }

/* Titoli display: Bodoni ovunque; la hero sopra la foto ha trattamenti extra sotto (.hero .display-hero) */
.display-hero {
  font-size: clamp(3rem, 6.5vw + 0.85rem, 5.35rem);
  font-weight: 500;
  letter-spacing: -0.018em;
  line-height: 1.05;
  -webkit-font-smoothing: antialiased;
}

.display-sub {
  font-size: clamp(2rem, 3.5vw + 0.85rem, 3.45rem);
  font-weight: 500;
  letter-spacing: -0.018em;
  line-height: 1.08;
  max-width: min(26ch, 100%);
}

.is-hidden {
  display: none !important;
}

.page-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.main-content {
  flex: 1;
  position: relative;
  z-index: 1;
}

.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-sm);
  padding: 0.5rem 1rem;
  background: var(--color-gold);
  color: var(--color-bg);
  z-index: 10000;
}

.skip-link:focus {
  top: var(--space-sm);
}

/* ----- Header ----- */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background: linear-gradient(to bottom, rgba(9, 9, 9, 0.78) 0%, rgba(9, 9, 9, 0.12) 70%, transparent 100%);
  padding: 1.35rem clamp(1.25rem, 4vw, 2.75rem);
  transition:
    background 0.65s var(--ease-lux),
    box-shadow 0.65s var(--ease-lux);
}

.site-header.is-scrolled {
  background: rgba(9, 9, 9, 0.82);
  backdrop-filter: blur(16px) saturate(1.1);
  -webkit-backdrop-filter: blur(16px) saturate(1.1);
  box-shadow: 0 1px 0 var(--hairline);
}

/* Mobile menu open: avoid parent backdrop-filter making the drawer look “see-through” while scrolling. */
@media (max-width: 900px) {
  .site-header.site-header--nav-open {
    background: rgba(9, 9, 9, 0.98);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 1px 0 var(--hairline);
  }

  [data-theme="light"] .site-header.site-header--nav-open {
    background: rgba(231, 224, 212, 0.99);
  }
}

html.luxy-mobile-nav-open,
html.luxy-mobile-nav-open body {
  overflow: hidden;
}

.site-header__inner {
  max-width: 1480px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}

.site-logo {
  display: inline-flex;
  align-items: center;
  max-width: min(240px, 46vw);
  text-decoration: none;
  color: rgba(247, 246, 243, 0.95);
}

/* Avoid flash of site name before logo image hydrates (see syncSiteLogo in main.js). */
.site-logo.site-logo--pending {
  opacity: 0;
  pointer-events: none;
  min-width: clamp(5.5rem, 18vw, 9.5rem);
  transition: opacity 0s;
}

.site-logo.site-logo--pending .site-logo__text {
  visibility: hidden;
  opacity: 0;
}

.site-logo:not(.site-logo--pending) {
  transition: opacity 0.4s var(--ease-lux, ease);
}

.site-logo__img {
  display: block;
  height: clamp(1.85rem, 3.5vw, 2.55rem);
  width: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: left center;
}

.site-logo__img.is-hidden {
  display: none !important;
}

.site-logo__text {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.95);
}

.site-logo__text.is-hidden {
  display: none !important;
}

.site-logo:hover .site-logo__text {
  color: var(--color-gold);
}

.site-logo:hover .site-logo__img {
  opacity: 0.92;
}

.nav-toggle {
  display: none;
  background: none;
  border: none;
  padding: 0.5rem;
  cursor: pointer;
  flex-direction: column;
  gap: 6px;
}

.nav-toggle__bar {
  width: 24px;
  height: 1px;
  background: var(--color-white);
  transition: transform 0.35s var(--ease-out);
}

.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: clamp(1rem, 3vw, 2.25rem);
}

.site-nav__list a {
  position: relative;
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.5);
  padding: 0.35rem 0;
}

.site-nav__list a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 0.55s var(--ease-lux);
}

.site-nav__list a:hover {
  color: rgba(247, 246, 243, 0.92);
}

.site-nav__list a:hover::after {
  transform: scaleX(1);
  transform-origin: left center;
}

.site-nav__list a.is-active {
  color: var(--color-gold);
}

.site-header__tools {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  flex-shrink: 0;
}

.site-lang {
  display: inline-flex;
  gap: 2px;
  border: 1px solid rgba(214, 198, 168, 0.22);
  border-radius: 2px;
  overflow: hidden;
}

.site-lang__btn {
  margin: 0;
  padding: 0.35rem 0.5rem;
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-family: var(--font-body);
  color: rgba(247, 246, 243, 0.45);
  background: transparent;
  border: none;
  cursor: pointer;
  transition:
    color 0.35s var(--ease-lux),
    background 0.35s var(--ease-lux);
}

.site-lang__btn:hover {
  color: rgba(247, 246, 243, 0.85);
}

.site-lang__btn.is-active {
  color: var(--color-bg);
  background: rgba(214, 198, 168, 0.82);
}

.site-header__cta {
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-gold-dim);
  border-bottom: 1px solid rgba(214, 198, 168, 0.35);
  padding-bottom: 0.35rem;
  transition:
    color 0.55s var(--ease-lux),
    border-color 0.55s var(--ease-lux);
}

.site-header__cta:hover {
  color: var(--color-white);
  border-color: rgba(247, 246, 243, 0.45);
}

.site-header__cta span {
  display: inline-block;
  transition: transform 0.6s var(--ease-lux);
}

.site-header__cta:hover span {
  transform: translateX(2px);
}

.site-header__cta.is-active {
  color: var(--color-gold);
  border-bottom-color: rgba(214, 198, 168, 0.55);
}

@media (max-width: 900px) {
  .nav-toggle {
    display: flex;
  }
  .site-header__tools {
    margin-left: auto;
  }
  .site-header__cta {
    font-size: 0.58rem;
    letter-spacing: 0.22em;
    padding-bottom: 0.3rem;
    flex-shrink: 0;
  }
  .site-nav {
    position: fixed;
    inset: 0 0 0 0;
    top: var(--header-h);
    z-index: 2;
    isolation: isolate;
    background: #090909;
    padding: var(--space-xl) var(--space-lg);
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.45s var(--ease-out), opacity 0.35s, visibility 0.35s;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    min-height: calc(100vh - var(--header-h));
    max-height: calc(100vh - var(--header-h));
    min-height: calc(100dvh - var(--header-h));
    max-height: calc(100dvh - var(--header-h));
    box-sizing: border-box;
  }
  .site-nav.is-open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
  [data-theme="light"] .site-nav {
    background: #e7e0d4;
  }
  .site-nav__list {
    flex-direction: column;
    gap: var(--space-md);
  }
}

/* ----- Concierge rail — destra: tab verticale + tendina orizzontale ----- */
.concierge-rail {
  position: fixed;
  right: 0;
  left: auto;
  top: 50%;
  transform: translateY(-50%);
  z-index: 880;
  max-width: 100%;
}

.concierge-rail.is-hidden {
  display: none !important;
}

.concierge-rail__box {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: center;
  background: rgba(9, 9, 9, 0.92);
  backdrop-filter: blur(14px) saturate(1.08);
  -webkit-backdrop-filter: blur(14px) saturate(1.08);
  box-shadow:
    -8px 0 36px rgba(0, 0, 0, 0.48),
    inset 0 1px 0 rgba(214, 198, 168, 0.08);
  border-left: 1px solid var(--hairline);
}

.concierge-rail__box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(214, 198, 168, 0.35) 40%,
    rgba(214, 198, 168, 0.65) 50%,
    rgba(214, 198, 168, 0.35) 60%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

.concierge-rail__drawer {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 0;
  max-height: 0;
  min-height: 0;
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
  /* Chiuso: niente altezza “fantasma” dal pannello — evita fasce nere sopra/sotto la tab. */
  pointer-events: none;
  transition:
    max-width 0.5s var(--ease-lux),
    max-height 0.45s var(--ease-lux),
    opacity 0.35s var(--ease-out),
    visibility 0.5s;
  border-right: 1px solid transparent;
}

.concierge-rail.is-open .concierge-rail__drawer {
  width: max-content;
  max-width: min(96vw, 34rem);
  max-height: min(92vh, 42rem);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  border-right-color: var(--hairline);
}

.concierge-rail .is-hidden {
  display: none !important;
}

.concierge-rail__drawer-inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: clamp(0.65rem, 1.75vw, 1.15rem);
  padding: 0.58rem 0.5rem 0.58rem 0.85rem;
  width: max-content;
  max-width: min(96vw, 34rem);
  min-width: 0;
  box-sizing: border-box;
}

.concierge-rail__lead {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(0.7rem, 2vw, 1.05rem);
  flex: 0 1 auto;
  min-width: 0;
}

.concierge-rail__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 0.4rem;
  flex: 0 0 auto;
  min-width: 7.25rem;
  width: min(34vw, 9.75rem);
}

.concierge-rail__icon-ring {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 50%;
  border: 1px solid rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.07);
  color: var(--color-gold);
  flex-shrink: 0;
}

.concierge-rail__icon-ring--agent {
  width: 2.75rem;
  height: 2.75rem;
}

.concierge-rail__icon {
  width: 1rem;
  height: 1rem;
}

.concierge-rail__icon--agent {
  width: 1.28rem;
  height: 1.28rem;
}

.concierge-rail__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  min-width: 0;
  text-align: left;
}

.concierge-rail__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 0.82rem + 0.45vw, 1.15rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.15;
  color: var(--color-white);
}

.concierge-rail__hours {
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  line-height: 1.35;
}

.concierge-rail__actions--col .concierge-rail__pill {
  width: 100%;
  flex: 0 0 auto;
  white-space: nowrap;
}

.concierge-rail__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  padding: 0.5rem 0.45rem;
  font-family: var(--font-body);
  font-size: 0.48rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-gold-dim);
  border: 1px solid rgba(214, 198, 168, 0.35);
  transition:
    color 0.45s var(--ease-lux),
    border-color 0.45s var(--ease-lux),
    background 0.45s var(--ease-lux);
}

.concierge-rail__pill--ghost {
  background: transparent;
  color: rgba(247, 246, 243, 0.72);
  border-color: rgba(214, 198, 168, 0.28);
}

.concierge-rail__pill:hover,
.concierge-rail__pill:focus-visible {
  color: var(--color-white);
  border-color: rgba(247, 246, 243, 0.4);
  background: rgba(214, 198, 168, 0.08);
  outline: none;
}

.concierge-rail__pill--ghost:hover,
.concierge-rail__pill--ghost:focus-visible {
  color: var(--color-gold);
  border-color: rgba(214, 198, 168, 0.48);
}

.concierge-rail__tab {
  flex-shrink: 0;
  align-self: center;
  box-sizing: border-box;
  width: 2.5rem;
  min-height: 0;
  margin: 0;
  padding: 0.42rem 0.28rem 0.48rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  border: none;
  border-left: 1px solid var(--hairline);
  background: rgba(14, 14, 14, 0.92);
  color: var(--color-gold-dim);
  cursor: pointer;
  transition:
    background 0.45s var(--ease-lux),
    color 0.45s var(--ease-lux);
}

.concierge-rail__tab:hover,
.concierge-rail__tab:focus-visible {
  background: rgba(214, 198, 168, 0.09);
  color: var(--color-gold);
  outline: none;
}

.concierge-rail.is-open .concierge-rail__tab {
  background: rgba(18, 18, 18, 0.95);
  color: var(--color-white);
}

.concierge-rail__tab-chev {
  display: block;
  font-size: 0.95rem;
  line-height: 1;
  color: var(--color-gold);
  transform: rotate(0deg);
  transition: transform 0.45s var(--ease-lux);
}

.concierge-rail__tab-chev::before {
  content: "‹";
}

.concierge-rail.is-open .concierge-rail__tab-chev {
  transform: rotate(180deg);
}

.concierge-rail__tab-label {
  display: block;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  font-family: var(--font-body);
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  line-height: 1.3;
  color: inherit;
  pointer-events: none;
}

@media (max-width: 900px) {
  .concierge-rail__drawer-inner {
    justify-content: center;
  }

  .concierge-rail__actions--col {
    width: 100%;
    min-width: 0;
    max-width: 12rem;
    align-self: center;
  }
}

@media (max-width: 720px) {
  .concierge-rail {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .concierge-rail__drawer,
  .concierge-rail__tab-chev {
    transition-duration: 0.01ms !important;
  }
}

/* ----- CTAs: editorial links (primary interaction pattern) ----- */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--color-gold);
  text-decoration: none;
  margin-top: var(--space-md);
  transition: color 0.55s var(--ease-lux);
}

.link-arrow::after {
  content: "";
  width: 2.75rem;
  height: 1px;
  background: currentColor;
  transform-origin: left center;
  transition:
    transform 0.65s var(--ease-lux),
    opacity 0.65s var(--ease-lux);
  opacity: 0.65;
}

.link-arrow:hover {
  color: var(--color-white);
}

.link-arrow:hover::after {
  transform: scaleX(1.15);
  opacity: 1;
}

.link-arrow--dim {
  color: rgba(247, 246, 243, 0.48);
}

.link-arrow--dim:hover {
  color: var(--color-gold);
}

/* Forms / booking: minimal capsule — never chunky template buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.65rem;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  border: 1px solid var(--hairline);
  background: transparent;
  color: var(--color-white);
  cursor: pointer;
  transition:
    border-color 0.55s var(--ease-lux),
    color 0.55s var(--ease-lux),
    background 0.55s var(--ease-lux);
}

.btn--primary {
  background: transparent;
  color: var(--color-gold);
  border-color: rgba(214, 198, 168, 0.42);
}

.btn--primary:hover {
  background: rgba(214, 198, 168, 0.08);
  border-color: var(--color-gold);
  color: var(--color-white);
}

.btn--ghost {
  background: transparent;
  color: rgba(247, 246, 243, 0.55);
  border-color: rgba(247, 246, 243, 0.12);
}

.btn--ghost:hover {
  border-color: rgba(247, 246, 243, 0.35);
  color: var(--color-white);
}

.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-top: var(--space-md);
  align-items: center;
}

/* ----- Page shell ----- */
.section {
  padding: var(--space-section-y) clamp(1.25rem, 4vw, 2.75rem);
  position: relative;
}

.section--tight {
  padding-bottom: var(--space-lg);
}

/* Dopo l’hero pagina (villa / rooms / gallery): meno “buco” nero prima del contenuto. */
.main-content > .hero.hero--page + .section {
  padding-top: clamp(1.5rem, 4vw, 2.75rem);
}

.section--editorial {
  /* Meno “buco” nero tra copy e blocco successivo (es. citazione → Highlights). */
  padding-top: clamp(1.75rem, 4vw, 3rem);
  padding-bottom: clamp(1.75rem, 4vw, 3rem);
  overflow-x: clip;
}

/* Onda leggera in chiusura editorial: rompe il nero pieno senza competere col testo. */
.editorial-wave {
  width: 100vw;
  max-width: none;
  position: relative;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  pointer-events: none;
  line-height: 0;
}

/* Ingresso sezione: onda più bassa e “lenta”, tratto più fine — non speculare alla wave finale. */
.editorial-wave--lead {
  margin-top: clamp(-0.75rem, -1vw, -0.25rem);
  margin-bottom: clamp(1.1rem, 3vw, 2rem);
  height: clamp(2.35rem, 6.5vw, 3.85rem);
}

/* Chiusura sezione: curva più pronunciata + tratto leggermente più marcato. */
.editorial-wave:not(.editorial-wave--lead) {
  margin-top: clamp(1.25rem, 3.5vw, 2.25rem);
  margin-bottom: calc(-0.35 * clamp(1.75rem, 4vw, 3rem));
  height: clamp(3rem, 9vw, 5.25rem);
}

.editorial-wave__svg {
  display: block;
  width: 100%;
  height: 100%;
}

.section--highlights {
  padding-top: clamp(2.25rem, 5vw, 3.75rem);
  padding-bottom: clamp(1.75rem, 4vw, 3rem);
}

.section--rooms-preview {
  padding-top: clamp(1.75rem, 4vw, 3rem);
}

/* ----- Reserve page (hero + search + calendar) ----- */
.main-content--reserve {
  overflow-x: clip;
}

.reserve-page__hero {
  position: relative;
  padding-top: calc(var(--header-h) + clamp(1.75rem, 4vw, 3.25rem));
  padding-bottom: clamp(3rem, 9vw, 5.75rem);
  padding-left: clamp(1.25rem, 4vw, 2.75rem);
  padding-right: clamp(1.25rem, 4vw, 2.75rem);
}

.reserve-page__hero-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 85% 55% at 78% 8%, rgba(214, 198, 168, 0.07), transparent 58%),
    radial-gradient(ellipse 55% 45% at 12% 92%, rgba(122, 138, 142, 0.055), transparent 52%),
    linear-gradient(165deg, rgba(7, 7, 7, 0.4) 0%, var(--color-bg) 42%, var(--color-bg) 100%);
}

.reserve-page__hero-backdrop::before {
  content: "";
  position: absolute;
  top: clamp(4rem, 14vh, 7rem);
  left: clamp(0.5rem, 3vw, 1.5rem);
  width: 1px;
  height: clamp(3.5rem, 12vh, 6rem);
  background: linear-gradient(180deg, rgba(214, 198, 168, 0.45), transparent);
  opacity: 0.65;
}

.reserve-page__hero-content {
  position: relative;
  z-index: 1;
  max-width: min(1180px, 100%);
  margin: 0 auto;
}

.reserve-page__hero-grid {
  display: grid;
  gap: clamp(2rem, 5vw, 3.75rem);
  align-items: center;
}

@media (min-width: 960px) {
  .reserve-page__hero-grid {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.08fr);
    gap: clamp(2.5rem, 5vw, 4.25rem);
    align-items: start;
  }

  .reserve-page__search-col {
    padding-top: 0.35rem;
  }
}

.reserve-page__intro .display-sub {
  margin-bottom: var(--space-md);
  letter-spacing: -0.02em;
}

.reserve-page__lede {
  margin: 0;
  max-width: 36ch;
  color: var(--color-muted);
  font-weight: 400;
  line-height: 1.68;
}

.reserve-page__form-label {
  margin: 0 0 var(--space-sm);
  letter-spacing: 0.18em;
  color: rgba(138, 147, 150, 0.95);
}

.reserve-booking-strip {
  background: transparent;
  border: none;
  padding: 0;
}

.reserve-booking-strip.is-hidden {
  display: none;
}

.reserve-page__search-col:has(.reserve-booking-strip.is-hidden) .reserve-page__form-label {
  display: none;
}

.reserve-booking-strip .home-booking-strip__inner {
  justify-content: stretch;
  width: 100%;
}

.reserve-booking-strip .luxy-booking-search {
  max-width: none;
  margin: 0;
}

.reserve-booking-strip .luxy-booking-search__card {
  border-radius: calc(var(--luxy-booking-radius, 1.125rem) + 0.06rem);
  background: linear-gradient(165deg, rgba(22, 22, 22, 0.98) 0%, rgba(12, 12, 12, 0.99) 100%);
  border: 1px solid rgba(214, 198, 168, 0.14);
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.28),
    0 28px 64px rgba(0, 0, 0, 0.42);
}

.reserve-page__calendar {
  position: relative;
  background: linear-gradient(180deg, var(--color-bg) 0%, #060606 55%, #050505 100%);
  border-top: 1px solid var(--hairline);
}

.reserve-page__calendar-inner {
  max-width: min(52rem, 100%);
}

.section-head--reserve {
  max-width: 40rem;
}

.section-head--reserve .display-sub {
  margin-bottom: var(--space-sm);
}

.section-head--reserve .eyebrow {
  margin-bottom: var(--space-sm);
}

.reserve-page__calendar-lede {
  margin-top: 0;
}

.reserve-calendar-root--framed {
  display: flex;
  justify-content: center;
}

@media (min-width: 720px) {
  .reserve-calendar-root--framed {
    justify-content: flex-start;
  }
}

.reserve-calendar-root--framed .calendar-widget {
  margin-top: var(--space-md);
  border-radius: 1.05rem;
  max-width: 28rem;
  background: rgba(14, 14, 14, 0.72);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 22px 56px rgba(0, 0, 0, 0.4);
}

.reserve-calendar-status:not([hidden]) {
  margin-top: var(--space-sm);
  margin-bottom: 0;
  font-size: 0.9rem;
  max-width: 40rem;
}

/* Homepage: fascia ricerca prenotazioni (tra hero e editorial) */
.home-booking-strip {
  background: #070707;
  border-top: none;
  border-bottom: 1px solid rgba(214, 198, 168, 0.06);
  padding: clamp(1rem, 2.5vw, 1.75rem) clamp(1rem, 5vw, 2.75rem);
}

.home-booking-strip__inner {
  max-width: 1480px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.luxy-booking-search {
  width: 100%;
  max-width: min(1020px, 94vw);
  margin: 0 auto;
  --luxy-booking-radius: 1.125rem;
  --luxy-booking-rail-radius: 0.875rem;
  /* Riga etichetta + riga controllo: allineate su tutte le celle */
  --luxy-booking-label-row: 1rem;
  --luxy-booking-control-row: 2.05rem;
  --luxy-booking-cell-pad-y: 0.42rem;
  --luxy-booking-rail-h: calc(
    var(--luxy-booking-label-row) + var(--luxy-booking-control-row) + 2 * var(--luxy-booking-cell-pad-y)
  );
}

.luxy-booking-search__card {
  position: relative;
  border-radius: var(--luxy-booking-radius);
  padding: clamp(0.85rem, 2vw, 1.05rem) clamp(1rem, 2.4vw, 1.5rem);
  background: var(--color-surface);
  border: 1px solid var(--hairline);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.38);
  overflow: visible;
}

.luxy-booking-search__rail {
  display: flex;
  align-items: stretch;
  min-height: var(--luxy-booking-rail-h);
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid var(--hairline);
  border-radius: var(--luxy-booking-rail-radius);
  overflow: hidden;
}

.luxy-booking-search__rail-dates {
  position: relative;
  display: flex;
  align-items: stretch;
  flex: 1.2;
  min-width: 0;
  gap: 0.65rem;
  padding: 0 var(--luxy-booking-cell-pad-y) 0 0.85rem;
}

.luxy-booking-search__rail-rule {
  width: 1px;
  flex-shrink: 0;
  background: var(--hairline);
  align-self: stretch;
}

.luxy-booking-search__rail-guests {
  flex: 0 0 auto;
  min-width: 0;
  display: flex;
  align-items: stretch;
  padding: 0;
  max-width: 100%;
}

.luxy-booking-search__field-shell {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 0;
  padding: 0.4rem 0.65rem;
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid var(--hairline);
  border-radius: var(--luxy-booking-rail-radius);
  transition: border-color 0.2s ease, background 0.2s ease;
}

.luxy-booking-search__field-shell:focus-within {
  border-color: rgba(214, 198, 168, 0.28);
  background: rgba(0, 0, 0, 0.38);
}

.luxy-booking-search__date-pair-icon {
  flex-shrink: 0;
  align-self: center;
  color: rgba(214, 198, 168, 0.65);
  display: flex;
}

.luxy-booking-search__field-icon {
  flex-shrink: 0;
  color: rgba(214, 198, 168, 0.65);
  display: flex;
}

.luxy-booking-search__date-pair {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: stretch;
  gap: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  overflow: hidden;
  min-height: 100%;
}

.luxy-booking-search__date-box {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: var(--luxy-booking-cell-pad-y) 0.65rem;
  display: grid;
  grid-template-rows: var(--luxy-booking-label-row) var(--luxy-booking-control-row);
  align-content: center;
  box-sizing: border-box;
  text-align: left;
  font: inherit;
  color: inherit;
  cursor: pointer;
  background: transparent;
  border: none;
  border-radius: 0;
  align-self: stretch;
  transition: background 0.2s ease;
}

.luxy-booking-search__date-box:hover {
  background: rgba(214, 198, 168, 0.06);
}

.luxy-booking-search__date-box:focus {
  outline: none;
}

.luxy-booking-search__date-box:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.55);
  outline-offset: -2px;
  z-index: 1;
}

.luxy-booking-search__rail .luxy-booking-search__micro-label {
  margin: 0;
  align-self: end;
  line-height: 1.05;
}

.luxy-booking-search__date-value {
  font-family: var(--font-body);
  font-size: 1.0625rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  color: var(--color-cream, #f7f6f3);
  line-height: 1.2;
  align-self: center;
}

.luxy-booking-search__date-divider {
  width: 1px;
  align-self: stretch;
  flex-shrink: 0;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(214, 198, 168, 0.22) 20%,
    rgba(214, 198, 168, 0.22) 80%,
    transparent
  );
}

.luxy-booking-search__dates-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

.luxy-booking-search__alt-input,
input.luxy-booking-search__alt-input {
  flex: 1;
  min-width: 0;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-cream, #f7f6f3) !important;
  background: transparent !important;
  border: none !important;
  padding: 0.5rem 0.35rem !important;
  min-height: 2.25rem !important;
  box-shadow: none !important;
}

.luxy-booking-search__alt-input::placeholder {
  color: rgba(247, 246, 243, 0.38);
}

.luxy-booking-search__alt-input:focus {
  outline: none;
}

.luxy-booking-search__guest-pair {
  flex: 0 1 auto;
  display: flex;
  align-items: stretch;
  gap: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  overflow: hidden;
  min-height: 100%;
  width: auto;
}

.luxy-booking-search__guest-pair .luxy-booking-search__field-shell {
  flex: 0 1 auto;
  min-width: 0;
  border: none;
  border-radius: 0;
  align-self: stretch;
  padding: var(--luxy-booking-cell-pad-y) 0.28rem;
  display: grid;
  grid-template-rows: var(--luxy-booking-label-row) var(--luxy-booking-control-row);
  align-content: center;
  box-sizing: border-box;
  background: transparent;
  box-shadow: none;
}

.luxy-booking-search__guest-pair .luxy-booking-search__field-shell:focus-within {
  background: transparent;
  box-shadow: none;
}

.luxy-booking-search__guest-divider {
  width: 1px;
  align-self: stretch;
  background: linear-gradient(
    180deg,
    transparent,
    rgba(214, 198, 168, 0.2) 20%,
    rgba(214, 198, 168, 0.2) 80%,
    transparent
  );
}

.luxy-booking-search__micro-label {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-gold-dim);
}

.luxy-booking-search__guest-input {
  font-family: var(--font-body);
  font-size: 1.125rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--color-cream, #f7f6f3);
  background: transparent;
  border: none;
  padding: 0;
  width: 100%;
  min-height: 1.35rem;
  caret-color: transparent;
  -moz-appearance: textfield;
  appearance: textfield;
}

.luxy-booking-search__guest-input:focus {
  outline: none;
  background: transparent;
}

.luxy-booking-search__guest-stepper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.22rem;
  width: 100%;
  max-width: 7.15rem;
  margin: 0;
  height: var(--luxy-booking-control-row);
  align-self: center;
  justify-self: center;
}

.luxy-booking-search__guest-stepper .luxy-booking-search__guest-input {
  flex: 0 1 auto;
  min-width: 0;
  width: 1.65rem;
  max-width: 2rem;
  text-align: center;
  pointer-events: none;
  user-select: none;
}

.luxy-booking-search__stepper-btn {
  flex: 0 0 2.05rem;
  width: 2.05rem;
  height: 2.05rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1;
  color: rgba(214, 198, 168, 0.88);
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid transparent;
  border-radius: 0.5rem;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition:
    color 0.2s ease,
    background 0.2s ease,
    border-color 0.2s ease,
    transform 0.15s ease;
}

.luxy-booking-search__stepper-btn:hover:not(:disabled) {
  color: var(--color-white);
  border-color: rgba(214, 198, 168, 0.3);
  background: rgba(214, 198, 168, 0.07);
}

.luxy-booking-search__stepper-btn:active:not(:disabled) {
  transform: scale(0.96);
}

.luxy-booking-search__stepper-btn:focus {
  outline: none;
}

.luxy-booking-search__stepper-btn:focus-visible {
  outline: 1px solid rgba(214, 198, 168, 0.45);
  outline-offset: 1px;
}

.luxy-booking-search__stepper-btn:focus:not(:focus-visible) {
  outline: none;
}

.luxy-booking-search__stepper-btn:disabled {
  opacity: 0.32;
  cursor: not-allowed;
}

/* Nascondi frecce spin number (WebKit) */
.luxy-booking-search__guest-input::-webkit-outer-spin-button,
.luxy-booking-search__guest-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.luxy-booking-search__submit {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  min-height: 0;
  padding: 0 1.35rem;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.92) !important;
  background: rgba(214, 198, 168, 0.08) !important;
  border: 1px solid rgba(214, 198, 168, 0.22) !important;
  border-radius: 0.5rem;
  box-shadow: none;
  transition:
    color 0.2s var(--ease-lux),
    background 0.2s var(--ease-lux),
    border-color 0.2s var(--ease-lux),
    transform 0.15s ease;
}

.luxy-booking-search__submit--rail {
  min-height: 0;
  height: auto;
  align-self: stretch;
  border-radius: 0;
  /* Stesso trattamento su tutti i lati visibile: la regola base usa border !important */
  border: none !important;
  border-top-right-radius: var(--luxy-booking-rail-radius);
  border-bottom-right-radius: var(--luxy-booking-rail-radius);
  box-shadow:
    inset 0 1px 0 0 var(--hairline),
    inset 0 -1px 0 0 var(--hairline),
    inset -1px 0 0 0 var(--hairline);
  min-width: 7.85rem;
  padding: 0 1.2rem;
}

.luxy-booking-search__submit:hover {
  color: var(--color-white) !important;
  background: rgba(214, 198, 168, 0.14) !important;
  border-color: rgba(214, 198, 168, 0.38) !important;
}

.luxy-booking-search__submit--rail:hover {
  border-color: transparent !important;
  box-shadow:
    inset 0 1px 0 0 rgba(214, 198, 168, 0.32),
    inset 0 -1px 0 0 rgba(214, 198, 168, 0.32),
    inset -1px 0 0 0 rgba(214, 198, 168, 0.32);
}

.luxy-booking-search__submit:active {
  transform: scale(0.985);
}

.luxy-booking-search__submit-icon {
  color: rgba(214, 198, 168, 0.88);
  transition: color 0.2s var(--ease-lux);
}

.luxy-booking-search__submit:hover .luxy-booking-search__submit-icon {
  color: var(--color-white);
}

.luxy-booking-search__submit-text {
  position: relative;
  top: 0.05em;
}

.luxy-booking-search__err {
  position: relative;
  z-index: 1;
  margin: 0.85rem 0 0;
  font-size: 0.875rem;
  color: #e8b4b4;
}

@media (max-width: 768px) {
  .luxy-booking-search__rail {
    flex-direction: column;
    min-height: 0;
  }

  .luxy-booking-search__rail-rule {
    width: 100%;
    height: 1px;
  }

  .luxy-booking-search__rail-dates {
    padding: 0.5rem 0.75rem 0.45rem;
  }

  .luxy-booking-search__rail-guests {
    padding: 0.35rem 0.45rem 0.5rem;
  }

  .luxy-booking-search__submit--rail {
    border-radius: 0;
    border: none !important;
    box-shadow:
      inset 0 1px 0 0 var(--hairline),
      inset 1px 0 0 0 var(--hairline),
      inset -1px 0 0 0 var(--hairline),
      inset 0 -1px 0 0 var(--hairline);
    width: 100%;
    min-width: 0;
    min-height: 3.5rem;
    padding: 0.95rem 1rem;
  }

  .luxy-booking-search__submit--rail:hover {
    box-shadow:
      inset 0 1px 0 0 rgba(214, 198, 168, 0.3),
      inset 1px 0 0 0 rgba(214, 198, 168, 0.3),
      inset -1px 0 0 0 rgba(214, 198, 168, 0.3),
      inset 0 -1px 0 0 rgba(214, 198, 168, 0.3);
  }
}

/* Flatpickr (calendario periodo) — tema scuro luxury */
.flatpickr-calendar.luxy-booking-fp {
  font-family: var(--font-body), system-ui, sans-serif;
  background: var(--color-surface) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 0.875rem !important;
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.55) !important;
  color: var(--color-white) !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-months {
  background: transparent !important;
  border-bottom: 1px solid rgba(214, 198, 168, 0.1);
  padding: 0.35rem 0;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-current-month {
  color: #f7f6f3 !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-weekdays {
  background: transparent !important;
}

.flatpickr-calendar.luxy-booking-fp span.flatpickr-weekday {
  color: rgba(214, 198, 168, 0.75) !important;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.12em;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day {
  border-radius: 0.375rem !important;
  color: rgba(247, 246, 243, 0.92) !important;
  border-color: transparent !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day:hover {
  background: rgba(214, 198, 168, 0.14) !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day.today {
  border-color: rgba(214, 198, 168, 0.45) !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day.selected,
.flatpickr-calendar.luxy-booking-fp .flatpickr-day.startRange,
.flatpickr-calendar.luxy-booking-fp .flatpickr-day.endRange {
  background: #d6c6a8 !important;
  color: #1a1814 !important;
  border-color: #d6c6a8 !important;
  font-weight: 600;
  /* Flatpickr default loads after this file and applies
     `box-shadow: -10px 0 0 #569ff7` between adjacent range ends — remove it. */
  box-shadow: none !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day.inRange {
  background: rgba(214, 198, 168, 0.2) !important;
  box-shadow: -4px 0 0 rgba(214, 198, 168, 0.2), 4px 0 0 rgba(214, 198, 168, 0.2);
  border-color: transparent !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-day.flatpickr-disabled {
  color: rgba(138, 147, 150, 0.35) !important;
}

.flatpickr-calendar.luxy-booking-fp .flatpickr-prev-month,
.flatpickr-calendar.luxy-booking-fp .flatpickr-next-month {
  fill: rgba(214, 198, 168, 0.85) !important;
}

.section__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.section__inner--narrow {
  max-width: 720px;
}

.section__inner--readable {
  max-width: var(--readable);
  margin: 0 auto;
  padding-left: clamp(0rem, 4vw, 2rem);
}

.section__inner--wide {
  max-width: 1480px;
}

.section-head {
  margin-bottom: clamp(2.5rem, 6vw, 4.5rem);
  max-width: var(--readable-wide);
}

.section--highlights .section-head {
  padding-right: min(28%, 14rem);
}

.section--experiences {
  padding-top: calc(var(--space-section-y) * 1.05);
}

.eyebrow {
  font-size: max(0.625rem, 0.6rem);
  font-weight: 400;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: var(--color-gold-dim);
  position: relative;
  display: inline-block;
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-md);
}

.eyebrow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 2.65rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(214, 198, 168, 0.82), rgba(214, 198, 168, 0.06));
}

.body-large {
  font-size: clamp(1.0625rem, 1.05rem + 0.45vw, 1.1875rem);
  font-weight: 300;
  color: rgba(247, 246, 243, 0.68);
  line-height: 1.78;
  max-width: var(--readable);
  letter-spacing: 0.012em;
}

/* Intro pagina editoriale (Villa hero, Rooms, Gallery): stesso “box” — eyebrow + titolo corsivo + incipit */
.page-intro-section {
  padding-top: calc(var(--header-h) + clamp(0.85rem, 2.5vw, 1.35rem));
}

.page-intro-section__after {
  padding-top: 0;
}

.page-intro {
  max-width: min(42rem, 100%);
  padding-bottom: clamp(1.25rem, 3.5vw, 2rem);
}

.page-intro .eyebrow {
  margin-bottom: clamp(0.55rem, 1.5vw, 0.85rem);
  color: rgba(138, 147, 150, 0.88);
}

.page-intro__title {
  margin: 0 0 clamp(0.55rem, 1.5vw, 0.85rem);
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.75vw + 0.85rem, 3.35rem);
  font-weight: 500;
  font-style: italic;
  font-optical-sizing: auto;
  letter-spacing: -0.02em;
  line-height: 1.06;
  color: rgba(247, 246, 243, 0.96);
  max-width: min(22ch, 100%);
}

@media (max-width: 639px) {
  .page-intro__title {
    max-width: none;
  }
}

.page-intro__lede {
  margin: 0;
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.9rem + 0.28vw, 1.0625rem);
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.02em;
  color: rgba(138, 147, 150, 0.92);
  max-width: min(40rem, 100%);
}

.page-intro__lede:empty {
  display: none;
}

.text-muted {
  color: var(--color-muted);
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.68;
}

.fade-in {
  opacity: 0;
  transform: translate3d(0, 1.25rem, 0);
  transition:
    opacity var(--dur-reveal) var(--ease-lux) calc(var(--fade-order, 0) * 0.06s),
    transform calc(var(--dur-reveal) + 0.1s) var(--ease-lux) calc(var(--fade-order, 0) * 0.06s);
  will-change: opacity, transform;
}

.fade-in.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

/*
 * Hero: il titolo sta dentro .hero__content.fade-in. translate3d sul contenitore + Bodoni grande +
 * text-shadow fa spesso “strisce” orizzontali (bug di compositing GPU in Chrome/Edge). Solo opacity qui.
 */
.hero__content.fade-in {
  transform: none;
  transition:
    opacity var(--dur-reveal) var(--ease-lux) calc(var(--fade-order, 0) * 0.06s);
  will-change: opacity;
}

.hero__content.fade-in.is-visible {
  transform: none;
  will-change: auto;
}

/* ----- Hero fullscreen ----- */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--header-h) + var(--space-xl)) clamp(1.25rem, 4vw, 3rem) clamp(2.5rem, 6vw, 4rem);
  overflow: hidden;
}

.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__media img,
.hero__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.001);
}

.hero__media img.luxy-img-fit--contain,
.hero__media video.luxy-img-fit--contain {
  background: var(--color-surface, #0a0a0c);
}

.hero__media img {
  opacity: 0;
  transition: opacity 0.5s var(--ease-lux, ease);
}

.hero__media img.luxy-hero-img--ready {
  opacity: 1;
  animation: heroDrift 32s var(--ease-lux) infinite alternate;
}

.hero__media img.luxy-hero-img--error {
  opacity: 0;
  animation: none;
  pointer-events: none;
}

/* Builder preview: keep hero image opaque and clickable (public site still fades in until load) */
body.luxy-builder-target .hero__media img {
  opacity: 1;
  animation: heroDrift 32s var(--ease-lux) infinite alternate;
}

body.luxy-builder-target .hero__media img.luxy-hero-img--error {
  opacity: 0.42;
  pointer-events: auto;
  animation: none;
}

@keyframes heroDrift {
  from {
    transform: scale(1) translate3d(0, 0, 0);
  }
  to {
    transform: scale(1.07) translate3d(-0.6%, -0.35%, 0);
  }
}

.hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  /* Meno strati e meno nero pieno: meno “banda” e meno buco nero sul bordo inferiore */
  background: linear-gradient(
      to top,
      rgba(8, 8, 10, 0.78) 0%,
      rgba(8, 8, 10, 0.28) 44%,
      rgba(8, 8, 10, 0.1) 68%,
      rgba(8, 8, 10, 0.38) 100%
    ),
    radial-gradient(ellipse 95% 68% at 50% 100%, rgba(0, 0, 0, 0.34), transparent 74%);
  pointer-events: none;
}

/* Strato scuro solo in basso: Bodoni resta leggibile sopra la foto senza cambiare font */
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: min(52vh, 560px);
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.68) 0%,
    rgba(0, 0, 0, 0.32) 46%,
    transparent 100%
  );
}

[data-theme="light"] .hero__media::after {
  background: linear-gradient(
    to top,
    rgba(45, 40, 34, 0.38) 0%,
    rgba(45, 40, 34, 0.14) 42%,
    transparent 100%
  );
}

[data-theme="light"] .hero::after {
  height: min(46vh, 500px);
  background: linear-gradient(
    to top,
    color-mix(in srgb, var(--color-bg) 88%, transparent) 0%,
    color-mix(in srgb, var(--color-bg) 38%, transparent) 40%,
    transparent 100%
  );
}

.hero__content {
  position: relative;
  z-index: 2;
  max-width: min(52rem, 92vw);
  padding-bottom: 0.5rem;
}

/* Allinea il blocco testo alla griglia sotto (section__inner--wide). */
.hero--page .hero__content {
  position: relative;
  z-index: 2;
  max-width: 1480px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.hero .display-hero {
  color: #faf9f7;
  /* Un’unica ombra morbida: meno strati = meno artefatti sul glyp */
  text-shadow: 0 0.06em 0.35em rgba(0, 0, 0, 0.92);
  -webkit-font-smoothing: antialiased;
}

/* Stesso problema se .fade-in è sullo h1 (es. villa): niente translate sul titolo */
.hero .display-hero.fade-in,
.hero--page .display-hero.fade-in,
.hero--page .page-intro__title.fade-in {
  transform: none;
  transition:
    opacity var(--dur-reveal) var(--ease-lux) calc(var(--fade-order, 0) * 0.06s);
  will-change: opacity;
}

.hero .display-hero.fade-in.is-visible,
.hero--page .display-hero.fade-in.is-visible,
.hero--page .page-intro__title.fade-in.is-visible {
  transform: none;
  will-change: auto;
}

.hero .hero__subtitle {
  color: rgba(252, 251, 248, 0.78);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.9), 0 4px 20px rgba(0, 0, 0, 0.55);
}

[data-theme="light"] .hero .hero__subtitle {
  color: rgba(252, 251, 248, 0.9);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45), 0 2px 14px rgba(0, 0, 0, 0.28);
}

.hero .eyebrow {
  margin-bottom: 1.25rem;
  color: rgba(232, 224, 200, 0.88);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.85);
}

.hero:not(.hero--page) .eyebrow::after {
  content: none;
}

.hero--page .eyebrow::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 2.65rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(214, 198, 168, 0.82), rgba(214, 198, 168, 0.06));
}

.hero__subtitle {
  font-family: var(--font-body);
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  font-weight: 300;
  font-style: italic;
  letter-spacing: 0.02em;
  color: rgba(247, 246, 243, 0.45);
  margin-top: 1.35rem;
  /* Larghezza del blocco hero (.hero__content); 22ch forzava 3+ righe su sottotitoli lunghi. */
  max-width: none;
  line-height: 1.5;
  text-wrap: balance;
}

.hero__actions {
  margin-top: 2.25rem;
}

.hero__actions .link-arrow {
  margin-top: 0;
}

@media (prefers-reduced-motion: reduce) {
  .hero__media img.luxy-hero-img--ready {
    animation: none;
  }

  body.luxy-builder-target .hero__media img {
    animation: none;
  }
}

/* Stessi margini orizzontali e sotto-header delle sezioni (.section padding). */
.hero--page {
  min-height: 72vh;
  align-items: center;
  padding: calc(var(--header-h) + clamp(0.85rem, 2.5vw, 1.35rem)) clamp(1.25rem, 4vw, 2.75rem) clamp(1.25rem, 3.5vw, 2.25rem);
}

.hero--page .page-intro {
  padding-bottom: 0;
}

/* Stesso trattamento fade del titolo: solo opacity sopra foto. */
.hero--page .page-intro > .fade-in {
  transform: none;
  transition:
    opacity var(--dur-reveal) var(--ease-lux) calc(var(--fade-order, 0) * 0.06s);
  will-change: opacity;
}

.hero--page .page-intro > .fade-in.is-visible {
  transform: none;
  will-change: auto;
}

.hero--page .page-intro .eyebrow {
  color: rgba(232, 224, 200, 0.88);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.85);
}

.hero--page .page-intro__title {
  color: #faf9f7;
  text-shadow: 0 0.06em 0.35em rgba(0, 0, 0, 0.92);
  -webkit-font-smoothing: antialiased;
}

.hero--page .page-intro__lede {
  color: rgba(232, 229, 222, 0.8);
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.75);
  max-width: min(36rem, 100%);
}

/* Mini builder preview mode */
body.luxy-builder-target [data-bind],
body.luxy-builder-target [data-bind-src],
body.luxy-builder-target [data-bind-href] {
  outline: 1px dashed rgba(214, 198, 168, 0.35);
  outline-offset: 4px;
  cursor: pointer;
}

/* Reveal bound blocks immediately so clicks reach [data-bind*] inside (IO can lag inside scaled iframe) */
body.luxy-builder-target .fade-in {
  opacity: 1;
  transform: none;
  will-change: auto;
}

/* ----- Intro / split ----- */
.split {
  display: grid;
  gap: clamp(2.5rem, 6vw, 4rem);
  align-items: end;
}

@media (min-width: 900px) {
  .split--2 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    gap: clamp(3rem, 7vw, 5.5rem);
    align-items: end;
  }

  .split--lux .split__text {
    padding-bottom: 4%;
  }

  .split--lux .split__media--offset {
    transform: translateY(clamp(1.5rem, 4vw, 3.5rem));
  }
}

.split__text .body-large {
  margin-top: 1.25rem;
}

@media (min-width: 900px) {
  .split--editorial-intro.split--2 {
    align-items: center;
  }

  .split--editorial-intro.split--lux .split__text {
    padding-bottom: 0;
  }
}

.split__text--editorial {
  text-align: left;
  max-width: var(--readable);
  margin-inline: 0;
}

.split__media {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  box-shadow: 0 2rem 5rem rgba(0, 0, 0, 0.35);
}

.split__media::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(214, 198, 168, 0.09);
  z-index: 1;
  pointer-events: none;
}

.split__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform 1.35s var(--ease-lux);
}

.split__media img.luxy-img-fit--contain {
  background: var(--color-surface, #0c0c0d);
}

/* Contain: drop fixed 3:4 frame so the box follows the image (no letterbox + no gap from align-items:end). */
.split__media:has(> img.luxy-img-fit--contain) {
  aspect-ratio: auto;
}

.split__media:has(> img.luxy-img-fit--contain) img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center center;
}

@media (min-width: 900px) {
  .split--2 > .split__media:has(> img.luxy-img-fit--contain) {
    align-self: start;
  }
}

.split__media:has(> img.luxy-img-fit--contain):hover img {
  transform: none;
}

.split__media:hover img {
  transform: scale(1.04);
}

blockquote.quote-block {
  margin: clamp(2.5rem, 5vw, 4rem) 0 0;
  padding: 0 0 0 1.5rem;
  border-left: 1px solid rgba(214, 198, 168, 0.45);
  font-family: var(--font-display);
  font-size: clamp(1.375rem, 2.2vw, 2rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.38;
  color: rgba(247, 246, 243, 0.82);
  letter-spacing: -0.01em;
}

.quote-block cite {
  display: block;
  margin-top: 1.25rem;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.85);
}

/* ----- Highlights: scorrimento orizzontale, card compatte ----- */
.highlights-scroll-hint {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 clamp(0.85rem, 2vw, 1.25rem);
  max-width: var(--readable-wide);
  font-family: var(--font-body);
  font-size: max(0.5625rem, 0.55rem);
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-gold-dim);
}

.highlights-scroll-hint::before {
  content: "\2194";
  font-size: 0.8rem;
  letter-spacing: 0;
  line-height: 1;
  opacity: 0.72;
  color: rgba(214, 198, 168, 0.65);
}

.highlights-scroller {
  width: 100vw;
  max-width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  box-sizing: border-box;
  padding-inline: clamp(1.25rem, 4vw, 2.75rem);
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: clamp(1.25rem, 4vw, 2.75rem);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  -ms-overflow-style: none;
  outline: none;
}

.highlights-scroller:focus-visible {
  box-shadow: 0 0 0 2px rgba(214, 198, 168, 0.35);
}

.highlights-scroller::-webkit-scrollbar {
  display: none;
}

.highlights-grid--lux {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: clamp(0.75rem, 2.2vw, 1.15rem);
  width: max-content;
  padding-bottom: 0.35rem;
  padding-inline-end: clamp(2rem, 6vw, 4rem);
}

.highlight-card--lux {
  flex: 0 0 clamp(13.25rem, 43.7vw, 17rem);
  width: clamp(13.25rem, 43.7vw, 17rem);
  max-width: 17rem;
  scroll-snap-align: start;
  background: transparent;
  display: flex;
  flex-direction: column;
}

.highlight-card__image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  position: relative;
  border-radius: 1px;
}

.highlight-card__image::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 0 1px rgba(214, 198, 168, 0.06);
  pointer-events: none;
}

.highlight-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform 1.45s var(--ease-lux), filter 1s var(--ease-lux);
  filter: contrast(1.02) saturate(0.95);
}

.highlight-card__image img.luxy-img-fit--contain {
  background: var(--color-surface, #0c0c0d);
}

.highlight-card__image:has(> img.luxy-img-fit--contain) {
  aspect-ratio: auto;
}

.highlight-card__image:has(> img.luxy-img-fit--contain) img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center center;
}

.highlight-card--lux .highlight-card__image:has(> img.luxy-img-fit--contain):hover img {
  transform: none;
  filter: contrast(1.02) saturate(0.95);
}

.highlight-card--lux:hover .highlight-card__image img {
  transform: scale(1.03);
  filter: contrast(1.04) saturate(1);
}

.highlight-card__body {
  padding: 0.85rem 0 0;
}

.highlight-card__title {
  font-family: var(--font-display);
  font-size: clamp(0.98rem, 1.1vw + 0.35rem, 1.15rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 0.65rem;
  color: rgba(247, 246, 243, 0.92);
}

.highlight-card__body p {
  font-size: 0.9375rem;
  font-weight: 300;
  color: rgba(138, 147, 150, 0.95);
  line-height: 1.65;
  max-width: 36ch;
}

/* ----- Experiences ----- */
.exp-list {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
  border-top: 1px solid var(--hairline);
}

.exp-list li {
  display: grid;
  gap: 0.65rem;
  padding: 1.65rem 0;
  border-bottom: 1px solid var(--hairline);
  transition: padding-left 0.6s var(--ease-lux);
}

.exp-list li:hover {
  padding-left: 0.35rem;
}

/* Optional narrow thumbnail per row (not on section title). */
.exp-list__thumb {
  width: 4.25rem;
  max-width: 100%;
  border-radius: 2px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  aspect-ratio: 4 / 5;
}

.exp-list__thumb img {
  display: block;
  width: 100%;
  height: 100%;
}

.exp-list__icon-wrap {
  box-sizing: border-box;
  width: 4.25rem;
  max-width: 100%;
  aspect-ratio: 1;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(247, 246, 243, 0.42);
}

.exp-list__icon-svg {
  width: 58%;
  height: 58%;
  display: block;
}

.exp-list li[data-exp-visual] {
  grid-template-columns: auto 1fr;
  column-gap: 1rem;
  align-items: start;
}

.exp-list li[data-exp-visual] .exp-list__thumb,
.exp-list li[data-exp-visual] .exp-list__icon-wrap {
  grid-row: 1 / span 2;
}

.exp-list li[data-exp-visual] strong {
  grid-column: 2;
}

.exp-list li[data-exp-visual] span {
  grid-column: 2;
}

@media (min-width: 700px) {
  .exp-list li {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.4fr);
    gap: 2rem;
    align-items: start;
  }

  .exp-list li[data-exp-visual] {
    grid-template-columns: 5.25rem minmax(0, 0.82fr) minmax(0, 1.32fr);
    column-gap: 1.75rem;
    align-items: start;
  }

  .exp-list li[data-exp-visual] .exp-list__thumb,
  .exp-list li[data-exp-visual] .exp-list__icon-wrap {
    grid-row: auto;
    grid-column: 1;
    width: 5.25rem;
  }

  .exp-list li[data-exp-visual] strong {
    grid-column: 2;
  }

  .exp-list li[data-exp-visual] span {
    grid-column: 3;
  }
}

.exp-list strong {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.3vw, 1.2rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  color: rgba(247, 246, 243, 0.88);
}

.exp-list span {
  color: rgba(138, 147, 150, 0.92);
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.65;
}

/* Subtle rhythm lines (low contrast; do not compete with content). */
.luxy-ambient-line {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 clamp(1.25rem, 4vw, 2.75rem);
  box-sizing: border-box;
  line-height: 0;
  pointer-events: none;
}

.luxy-ambient-line__svg {
  display: block;
  width: 100%;
  height: clamp(0.65rem, 1.2vw, 1rem);
  opacity: 0.85;
}

.luxy-ambient-line--between {
  margin-top: clamp(0.25rem, 1vw, 0.75rem);
  margin-bottom: clamp(0.5rem, 1.5vw, 1.1rem);
}

/* ----- Full bleed: single strip OR duo (two similar frames, diagonal overlap) ----- */
.fullbleed {
  position: relative;
  min-height: 58vh;
  overflow: hidden;
  margin: 0;
}

/* Duo: caption lives inside .fullbleed__layer--back (under first image); no extra figure padding. */
.fullbleed:has(> .fullbleed__stack > .fullbleed__layer--front > img[src]) {
  min-height: 0;
  padding-bottom: 0;
}

.fullbleed__stack {
  position: relative;
  width: 100%;
}

/*
 * Two images: one grid cell, large frames, centered wide band (not tiny 380px caps).
 * Stronger translate on the front layer so they actually read as stacked / overlapping.
 */
.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) {
  display: grid;
  width: min(96vw, 90rem);
  margin-inline: auto;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(48vh, min(66vh, 760px));
  padding: clamp(0.5rem, 2vw, 1.5rem);
  box-sizing: border-box;
}

.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--back {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
  justify-self: start;
  width: clamp(17.5rem, 44vw, 40rem);
  max-width: 100%;
  position: relative;
  z-index: 0;
  transform: translate(clamp(0.25rem, 1.5vw, 1rem), clamp(0.15rem, 1vh, 0.65rem));
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front {
  grid-column: 1;
  grid-row: 1;
  align-self: end;
  justify-self: end;
  width: clamp(17.5rem, 44vw, 40rem);
  max-width: 100%;
  position: relative;
  z-index: 1;
  pointer-events: none;
  transform: translate(-18%, -14%);
}

@media (max-width: 640px) {
  .fullbleed__stack:has(> .fullbleed__layer--front > img[src]) {
    width: min(100%, 100vw);
    grid-template-rows: minmax(46vh, min(68vh, 620px));
    padding: clamp(0.35rem, 1.5vw, 1rem);
  }

  .fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--back,
  .fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front {
    width: clamp(15.5rem, 82vw, 22rem);
  }

  .fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front {
    transform: translate(-12%, -10%);
  }
}

.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--back img,
.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center center;
  border-radius: 1px;
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.48);
  transition: transform 1.35s var(--ease-lux), box-shadow 1.2s var(--ease-lux);
}

.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front img {
  pointer-events: auto;
}

.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--back img.luxy-img-fit--contain,
.fullbleed__stack:has(> .fullbleed__layer--front > img[src]) .fullbleed__layer--front img.luxy-img-fit--contain {
  aspect-ratio: auto;
  max-height: min(48vh, 520px);
  object-fit: contain;
  background: var(--color-surface, #0c0c0d);
}

.fullbleed:has(> .fullbleed__stack > .fullbleed__layer--front > img[src]):hover .fullbleed__layer--back img {
  transform: scale(1.02);
}

.fullbleed:has(> .fullbleed__stack > .fullbleed__layer--front > img[src]):hover .fullbleed__layer--front img {
  transform: scale(1.02);
  box-shadow: 0 28px 72px rgba(0, 0, 0, 0.55);
}

/* Single background only (no second URL) */
.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])) {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(58vh, min(72vh, 820px));
}

.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])) .fullbleed__layer--back {
  grid-column: 1;
  grid-row: 1;
  min-height: 58vh;
  display: flex;
  flex-direction: column;
}

.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])) .fullbleed__layer--back img {
  width: 100%;
  flex: 1 1 auto;
  min-height: 58vh;
  object-fit: cover;
  object-position: center center;
  transition: transform 1.4s var(--ease-lux);
}

.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])) .fullbleed__layer--back img.luxy-img-fit--contain {
  background: var(--color-surface, #0c0c0d);
}

.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])):hover .fullbleed__layer--back img {
  transform: scale(1.02);
}

.fullbleed__layer--front:not(:has(> img[src])) {
  display: none;
}

/* Caption: always under the first (back) image — same column width as that frame */
.fullbleed__caption {
  margin: 0;
  flex-shrink: 0;
  padding: clamp(0.4rem, 1.2vh, 0.65rem) 0 0;
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.55);
  text-align: left;
}

.fullbleed__stack:not(:has(> .fullbleed__layer--front > img[src])) .fullbleed__caption {
  padding: clamp(0.65rem, 2vh, 1rem) clamp(1.25rem, 4vw, 2.75rem) clamp(0.5rem, 1.5vh, 0.85rem);
  text-align: center;
  max-width: 42rem;
  margin-inline: auto;
}

/* ----- CTA band ----- */
.cta-band {
  padding: var(--space-2xl) clamp(1.25rem, 4vw, 2.75rem);
  background: linear-gradient(180deg, var(--color-bg-elevated) 0%, var(--color-bg) 100%);
  border-top: 1px solid var(--hairline);
}

.cta-band--lux {
  position: relative;
  overflow: hidden;
}

.cta-band--lux::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 130% 85% at 92% -35%, rgba(214, 198, 168, 0.065), transparent 58%),
    radial-gradient(ellipse 90% 75% at 6% 108%, rgba(214, 198, 168, 0.045), transparent 52%);
}

.cta-band--lux .cta-band__inner {
  position: relative;
  z-index: 1;
  margin: 0;
  text-align: left;
  max-width: none;
  display: grid;
  gap: 1.25rem;
  padding-right: min(35%, 16rem);
}

.cta-band__lede {
  margin-top: 0.25rem;
}

.cta-band__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2.25rem;
  margin-top: 0.5rem;
}

.cta-band__actions .link-arrow {
  margin-top: 0;
}

/* Secondary pages: narrow centered closing band */
.cta-band:not(.cta-band--lux) .cta-band__inner {
  max-width: 40rem;
  margin: 0 auto;
  text-align: center;
}

.cta-band:not(.cta-band--lux) .cta-band__actions {
  justify-content: center;
}

.cta-band:not(.cta-band--lux) h2 {
  font-size: clamp(1.85rem, 3.5vw, 2.75rem);
  letter-spacing: -0.02em;
}

.cta-band__title {
  margin-left: auto;
  margin-right: auto;
  max-width: min(22ch, 92%);
}

/* ----- Footer ----- */
.site-footer {
  padding: clamp(3rem, 8vw, 5rem) clamp(1.25rem, 4vw, 2.75rem);
  border-top: 1px solid var(--hairline);
  margin-top: auto;
  position: relative;
}

.site-footer__grid {
  max-width: 1480px;
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 5vw, 3rem);
}

@media (min-width: 800px) {
  .site-footer__grid {
    grid-template-columns: 1.35fr 1fr;
    gap: 3rem;
  }
}

.site-footer__name {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  letter-spacing: 0.06em;
  color: rgba(247, 246, 243, 0.92);
}

.site-footer__tagline {
  color: rgba(138, 147, 150, 0.85);
  margin-top: 0.65rem;
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.55;
  max-width: 28ch;
}

.site-footer__bottom {
  max-width: 1480px;
  margin: clamp(2.5rem, 6vw, 3.5rem) auto 0;
  text-align: center;
}

.site-footer__instagram-row {
  margin: 0 0 1rem;
}

.site-footer__instagram-row.is-hidden {
  display: none;
}

.site-footer__instagram {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.38);
  text-decoration: none;
}

.site-footer__instagram:hover {
  color: var(--color-gold);
}

.site-footer__legal {
  margin: 0 auto;
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  color: rgba(138, 147, 150, 0.55);
}

.site-footer__legal-meta {
  margin-top: 1.25rem;
  font-size: 0.625rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.65;
  color: rgba(138, 147, 150, 0.45);
}

.site-footer__legal-meta.is-hidden {
  display: none;
}

.site-footer__vat,
.site-footer__company,
.site-footer__credits {
  margin: 0.35rem 0 0;
  white-space: pre-line;
}

.site-footer__vat.is-hidden,
.site-footer__company.is-hidden,
.site-footer__credits.is-hidden {
  display: none;
}

.site-footer__creator {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.35rem 0.55rem;
  margin: 1.15rem auto 0;
  max-width: 42rem;
  font-size: 0.625rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.55;
  color: rgba(138, 147, 150, 0.48);
}

.site-footer__creator.is-hidden {
  display: none;
}

.site-footer__creator-intro.is-hidden {
  display: none;
}

.site-footer__creator-link,
.site-footer__creator-plain {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  max-width: 100%;
}

.site-footer__creator-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.35s var(--ease-lux);
}

.site-footer__creator-link:hover {
  color: var(--color-gold);
}

.site-footer__creator-logo {
  max-height: 1.85rem;
  max-width: min(9.5rem, 38vw);
  width: auto;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
}

.site-footer__creator-logo.is-hidden {
  display: none;
}

.site-footer__creator-name:empty {
  display: none;
}

/* ----- Rooms ----- */
.rooms-grid {
  display: grid;
  gap: clamp(3rem, 7vw, 5rem);
}

@media (min-width: 800px) {
  .rooms-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 3vw, 2.25rem);
  }
}

.room-card--lux {
  background: transparent;
  overflow: visible;
  display: grid;
  grid-template-rows: auto 1fr;
  border-top: 1px solid var(--hairline);
  padding-top: 1.5rem;
}

.room-card__image {
  aspect-ratio: 5 / 3;
  overflow: hidden;
  position: relative;
}

.room-card__image::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 0 1px rgba(214, 198, 168, 0.07);
  pointer-events: none;
}

.room-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform 1.4s var(--ease-lux);
}

.room-card__image img.luxy-img-fit--contain {
  background: var(--color-surface, #0c0c0d);
}

.room-card__image:has(> img.luxy-img-fit--contain) {
  aspect-ratio: auto;
}

.room-card__image:has(> img.luxy-img-fit--contain) img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center center;
}

.room-card--lux .room-card__image:has(> img.luxy-img-fit--contain):hover img {
  transform: none;
}

.room-card--lux:hover .room-card__image img {
  transform: scale(1.03);
}

.room-card__body {
  padding: 1.75rem 0 0;
}

.room-card__meta {
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.65);
  margin-bottom: 0.85rem;
}

.room-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2vw, 1.65rem);
  letter-spacing: -0.02em;
  margin-bottom: 0.65rem;
  color: rgba(247, 246, 243, 0.94);
}

.room-card__desc {
  margin-top: 0.25rem;
}

.amenities {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.65rem;
  margin-top: 1.25rem;
}

.amenities--lux span {
  font-size: 0.8125rem;
  font-weight: 300;
  letter-spacing: 0.04em;
  text-transform: none;
  padding: 0;
  border: none;
  color: rgba(138, 147, 150, 0.9);
}

.amenities--lux span:not(:last-child)::after {
  content: "·";
  margin-left: 0.65rem;
  color: rgba(138, 147, 150, 0.35);
}

/* ----- Gallery ----- */
.gallery-grid {
  display: grid;
  gap: 2px;
  background: rgba(255, 255, 255, 0.04);
}

@media (min-width: 600px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1000px) {
  .gallery-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.gallery-grid a {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  position: relative;
  background: var(--color-bg);
}

.gallery-grid a::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(9, 9, 9, 0);
  transition: background 0.65s var(--ease-lux);
  pointer-events: none;
  z-index: 1;
}

.gallery-grid a:hover::after {
  background: rgba(9, 9, 9, 0.18);
}

.gallery-grid a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.35s var(--ease-lux);
}

.gallery-grid a:hover img {
  transform: scale(1.05);
}

.gallery-by-space {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 5vw, 3.5rem);
}

.gallery-space-nav {
  position: sticky;
  top: calc(var(--header-h) + 0.35rem);
  z-index: 6;
  margin: 0 0 0.25rem;
  padding: 0.65rem 0;
  background: linear-gradient(
    180deg,
    rgba(9, 9, 9, 0.97) 0%,
    rgba(9, 9, 9, 0.88) 70%,
    rgba(9, 9, 9, 0) 100%
  );
  border-bottom: 1px solid rgba(214, 198, 168, 0.08);
}

.gallery-space-nav__label {
  margin: 0 0 0.65rem;
  text-align: center;
}

.gallery-space-nav__label::after {
  left: 50%;
  transform: translateX(-50%);
}

.gallery-space-nav__scroll {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem 0.55rem;
}

.gallery-space-nav__link {
  display: inline-flex;
  align-items: center;
  padding: 0.38rem 0.85rem;
  font-family: var(--font-body);
  font-size: max(0.5625rem, 0.62rem);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  color: rgba(214, 198, 168, 0.88);
  border: 1px solid rgba(214, 198, 168, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  transition:
    color 0.35s var(--ease-lux),
    border-color 0.35s var(--ease-lux),
    background 0.35s var(--ease-lux);
}

.gallery-space-nav__link:hover {
  color: var(--color-white);
  border-color: rgba(214, 198, 168, 0.48);
  background: rgba(214, 198, 168, 0.08);
}

.gallery-spaces {
  display: flex;
  flex-direction: column;
  gap: clamp(2.75rem, 7vw, 4.5rem);
}

.gallery-space {
  scroll-margin-top: calc(var(--header-h) + 3.5rem);
}

.gallery-space__header {
  margin-bottom: 0.85rem;
  max-width: min(40rem, 100%);
}

.gallery-space__title.display-sub {
  max-width: none;
  width: 100%;
}

.gallery-space__summary {
  margin: 0.5rem 0 0;
  max-width: var(--readable);
}

.gallery-space__amenities {
  margin: 0 0 1rem;
}

.gallery-grid--in-space {
  margin-top: 0.15rem;
}

@media (max-width: 599px) {
  .gallery-space-nav {
    top: calc(var(--header-h) + 0.15rem);
  }

  .gallery-space-nav__scroll {
    justify-content: flex-start;
  }
}

/* ----- Experiences page (tiles + detail) ----- */
.experiences-page-intro {
  padding-top: calc(var(--header-h) + clamp(0.5rem, 1.5vw, 0.85rem));
  padding-bottom: clamp(0.4rem, 1.5vw, 0.75rem);
}

/* Intro leggera: chi arriva qui sa già il contesto; poche righe, tipografia piccola. */
.experiences-page-intro--compact .experiences-page-intro__masthead {
  max-width: min(40rem, 100%);
}

.experiences-page-intro__eyebrow {
  margin: 0 0 0.35rem;
  font-family: var(--font-body);
  font-size: max(0.5625rem, 0.58rem);
  font-weight: 500;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.55);
}

.experiences-page-intro__h1 {
  margin: 0 0 0.35rem;
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.9rem + 0.35vw, 1.0625rem);
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.35;
  color: rgba(247, 246, 243, 0.9);
}

.experiences-page-intro__hint {
  margin: 0;
  max-width: min(36rem, 100%);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: 0.02em;
  color: rgba(138, 147, 150, 0.92);
}

.experiences-page-body {
  padding-top: 0;
  padding-bottom: clamp(3rem, 8vw, 5.5rem);
}

.experiences-layout {
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: start;
}

.experiences-layout__detail {
  min-width: 0;
}

.experience-detail {
  --exp-detail-block-spacing: clamp(0.85rem, 2vw, 1.15rem);
  width: 100%;
  max-width: 100%;
}

@media (min-width: 960px) {
  .experiences-layout {
    grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  }
}

/* Esperienze: carousel orizzontale su mobile */
.experiences-carousel {
  display: flex;
  align-items: stretch;
  gap: 0.4rem;
  width: 100%;
  min-width: 0;
}

.experiences-carousel__viewport {
  flex: 1;
  min-width: 0;
}

.experiences-carousel__btn {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  min-height: 2.75rem;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(214, 198, 168, 0.95);
  font-size: 1.65rem;
  line-height: 1;
  font-family: var(--font-display);
  cursor: pointer;
  transition:
    background 0.35s var(--ease-lux),
    border-color 0.35s var(--ease-lux),
    opacity 0.35s var(--ease-lux);
}

.experiences-carousel__btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(214, 198, 168, 0.35);
}

.experiences-carousel__btn:disabled {
  opacity: 0.28;
  cursor: default;
}

@media (min-width: 960px) {
  .experiences-carousel__btn {
    display: none;
  }

  .experiences-carousel__viewport {
    overflow: visible;
  }
}

@media (max-width: 959px) {
  .experiences-carousel__viewport {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: 0.35rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    touch-action: pan-x;
    cursor: grab;
  }

  .experiences-carousel__viewport.is-dragging {
    cursor: grabbing;
    scroll-snap-type: none;
  }

  .experiences-carousel__viewport.is-dragging,
  .experiences-carousel__viewport.is-dragging * {
    user-select: none;
  }

  .experiences-carousel__viewport::-webkit-scrollbar {
    display: none;
  }
}

.experiences-layout__tiles {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

@media (max-width: 959px) {
  .experiences-layout__tiles {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 0.65rem;
    padding-block: 0.2rem;
    width: max-content;
    min-height: min-content;
  }
}

.experience-tile {
  display: grid;
  grid-template-columns: 132px 1fr;
  align-items: start;
  gap: var(--space-sm);
  width: 100%;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  border-radius: 2px;
  overflow: hidden;
  transition:
    border-color 0.45s var(--ease-lux),
    background 0.45s var(--ease-lux),
    box-shadow 0.45s var(--ease-lux);
}

.experience-tile:hover {
  border-color: rgba(214, 198, 168, 0.35);
  background: rgba(255, 255, 255, 0.04);
}

.experience-tile.is-selected {
  border-color: rgba(214, 198, 168, 0.55);
  box-shadow: 0 0 0 1px rgba(214, 198, 168, 0.22);
}

/* Fixed frame so portrait/landscape uploads crop uniformly (desktop + mobile). */
.experience-tile__media {
  display: block;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4 / 3;
  min-height: 0;
  align-self: start;
  background: rgba(0, 0, 0, 0.25);
}

.experience-tile__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center center;
  transition: transform 1s var(--ease-lux);
}

.experience-tile:hover .experience-tile__media img {
  transform: scale(1.06);
}

.experience-request-form__options-host {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 0.25rem;
}

.experience-request-form__options-host[hidden] {
  display: none !important;
}

.experience-tile__body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 0.65rem 0.85rem 0.75rem 0;
}

.experience-tile__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.25;
}

.experience-tile__summary {
  font-size: 0.8125rem;
  line-height: 1.45;
  color: rgba(232, 229, 222, 0.72);
}

@media (max-width: 959px) {
  .experience-tile {
    flex: 0 0 auto;
    width: min(262px, 78vw);
    max-width: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    scroll-snap-align: center;
    scroll-snap-stop: normal;
  }

  .experience-tile__media {
    min-height: 0;
  }

  .experience-tile__media img {
    height: 100%;
  }

  .experience-tile__body {
    padding: 0.55rem 0.65rem 0.65rem;
  }
}

.experiences-detail-placeholder {
  margin: 0;
  padding: var(--space-lg);
  border: 1px dashed rgba(255, 255, 255, 0.12);
  border-radius: 2px;
}

.experience-detail__masthead {
  width: 100%;
}

.experience-detail__lead {
  margin: 0 0 0.35rem;
  padding: 0;
  width: 100%;
}

.experience-detail__location {
  margin: 0;
  min-width: 0;
  max-width: 100%;
  font-family: var(--font-body);
  font-size: max(0.5625rem, 0.6rem);
  font-weight: 500;
  letter-spacing: 0.24em;
  line-height: 1.35;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.82);
}

/* Titolo + prezzo sulla stessa riga: stesso livello verticale (baseline), non all’altezza dell’eyebrow */
.experience-detail__title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, max-content);
  align-items: baseline;
  gap: 0.35rem 1rem;
  margin: 0 0 var(--exp-detail-block-spacing);
  width: 100%;
}

.experience-detail__title {
  margin: 0;
  min-width: 0;
}

.experience-detail__price {
  font-family: var(--font-display);
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 500;
  color: rgba(214, 198, 168, 0.95);
  margin: 0;
  justify-self: end;
  text-align: right;
  max-width: 100%;
}

/* La classe globale .display-sub limita a ~26ch; qui serve tutta la colonna dettaglio. */
.experience-detail__title.display-sub {
  max-width: none;
  width: 100%;
}

.experience-detail__schedule-title.display-sub {
  max-width: none;
  width: 100%;
}

.experience-detail__media-wrap {
  width: 100%;
  max-width: 100%;
  margin-bottom: var(--space-md);
}

@media (max-width: 480px) {
  .experience-detail__title-row {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .experience-detail__price {
    justify-self: end;
    max-width: 100%;
  }
}

.experience-media-bento {
  --exp-bento-radius: clamp(10px, 2vw, 14px);
  --exp-bento-gap: 0.5rem;
  display: grid;
  gap: var(--exp-bento-gap);
  border-radius: var(--exp-bento-radius);
  overflow: hidden;
}

@media (min-width: 720px) {
  .experience-media-bento {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: minmax(220px, 42vh);
    min-height: min(42vh, 420px);
    max-height: min(50vh, 480px);
  }

  .experience-media-bento__hero {
    grid-row: 1 / -1;
    min-height: 0;
  }

  .experience-media-bento__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: var(--exp-bento-gap);
    min-height: 0;
  }
}

@media (max-width: 719px) {
  .experience-media-bento__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: var(--exp-bento-gap);
    min-height: 180px;
  }

  .experience-media-bento__hero {
    max-height: 52vw;
  }
}

.experience-media-bento__hero-btn {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 200px;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: var(--exp-bento-radius);
  overflow: hidden;
  cursor: zoom-in;
  background: rgba(0, 0, 0, 0.35);
  transition: box-shadow 0.4s var(--ease-lux);
}

.experience-media-bento__hero-btn:hover {
  box-shadow: 0 0 0 1px rgba(214, 198, 168, 0.35);
}

.experience-media-bento__hero-img {
  width: 100%;
  height: 100%;
  min-height: 200px;
  object-fit: cover;
  display: block;
}

@media (min-width: 720px) {
  .experience-media-bento__hero-btn,
  .experience-media-bento__hero-img {
    min-height: 0;
  }
}

.experience-media-bento__thumb {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: var(--exp-bento-radius);
  overflow: hidden;
  cursor: pointer;
  background: rgba(0, 0, 0, 0.35);
  transition:
    box-shadow 0.35s var(--ease-lux),
    opacity 0.35s var(--ease-lux);
}

.experience-media-bento__thumb:hover {
  opacity: 0.95;
}

.experience-media-bento__thumb.is-active {
  box-shadow: 0 0 0 2px rgba(214, 198, 168, 0.55);
}

.experience-media-bento__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  min-height: 88px;
}

.experience-media-bento__thumb--more .experience-media-bento__more-label {
  position: absolute;
  right: clamp(0.35rem, 1.4vw, 0.65rem);
  bottom: clamp(0.35rem, 1.4vw, 0.65rem);
  left: auto;
  transform: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  max-width: calc(100% - 0.75rem);
  padding: 0.48rem 0.85rem 0.48rem 0.55rem;
  box-sizing: border-box;
  font-family: var(--font-body);
  font-size: max(0.625rem, 0.68rem);
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1.2;
  color: #090909;
  background: #fff;
  border: 1px solid #090909;
  border-radius: 999px;
  text-align: left;
  text-shadow: none;
  pointer-events: none;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.14);
  transition:
    transform 0.35s var(--ease-lux),
    box-shadow 0.35s var(--ease-lux);
}

.experience-media-bento__more-icon {
  flex-shrink: 0;
  display: block;
  color: #090909;
}

.experience-media-bento__more-text {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.experience-media-bento__thumb--more:hover .experience-media-bento__more-label {
  transform: scale(1.02);
  box-shadow: 0 3px 18px rgba(0, 0, 0, 0.18);
}

.experience-media-bento__thumb--more:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.9);
  outline-offset: 2px;
  z-index: 1;
}

.experience-detail__schedule {
  margin: var(--space-lg) 0;
  padding-top: var(--space-md);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.experience-detail__schedule-title {
  margin: 0 0 var(--space-sm);
  font-size: clamp(1.35rem, 3vw, 1.85rem);
}

.experience-detail__schedule-list {
  margin: 0;
  padding-left: 1.1rem;
  list-style: decimal;
  color: rgba(232, 229, 222, 0.88);
}

.experience-detail__schedule-item {
  margin-bottom: 0.85rem;
  padding-left: 0.35rem;
  line-height: 1.55;
}

.experience-detail__schedule-item strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 500;
  margin-bottom: 0.2rem;
  color: rgba(247, 246, 243, 0.96);
}

.experience-detail__schedule-item span {
  display: block;
  font-size: 0.9375rem;
  color: rgba(232, 229, 222, 0.78);
}

.experience-detail__schedule-step {
  display: inline-block;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.85);
  margin-bottom: 0.2rem;
}

/* Lightbox esperienze */
.exp-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99990;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 3rem;
  box-sizing: border-box;
}

.exp-lightbox[hidden] {
  display: none !important;
}

.exp-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.92);
  cursor: pointer;
}

.exp-lightbox__frame {
  position: relative;
  z-index: 1;
  max-width: min(96vw, 1200px);
  max-height: 85vh;
  width: min(96vw, 1200px);
}

.exp-lightbox__img {
  max-width: min(96vw, 1200px);
  max-height: 85vh;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 4px;
}

.exp-lightbox__img[hidden] {
  display: none !important;
}

.exp-lightbox__video {
  width: min(96vw, 1200px);
  max-width: 100%;
  aspect-ratio: 16 / 9;
  max-height: 85vh;
  background: #0a0a0a;
  border-radius: 4px;
  overflow: hidden;
}

.exp-lightbox__video[hidden] {
  display: none !important;
}

.exp-lightbox__video iframe,
.exp-lightbox__video video {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  min-height: min(50vh, 360px);
}

.exp-lightbox__video video {
  object-fit: contain;
  background: #000;
}

.exp-lightbox__close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 2;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.3s var(--ease-lux);
}

.exp-lightbox__close:hover {
  background: rgba(214, 198, 168, 0.2);
}

.exp-lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 2.75rem;
  height: 3.5rem;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.45);
  color: rgba(247, 246, 243, 0.95);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.3s var(--ease-lux);
}

.exp-lightbox__nav:hover {
  background: rgba(214, 198, 168, 0.15);
}

.exp-lightbox__nav--prev {
  left: 0.5rem;
}

.exp-lightbox__nav--next {
  right: 0.5rem;
}

.exp-lightbox__counter {
  position: absolute;
  bottom: 0.75rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  margin: 0;
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  color: rgba(232, 229, 222, 0.75);
}

@media (max-width: 639px) {
  .exp-lightbox {
    padding: 3rem 0.5rem 2rem;
  }

  .exp-lightbox__nav--prev {
    left: 0.15rem;
  }

  .exp-lightbox__nav--next {
    right: 0.15rem;
  }
}

.experience-detail__meta {
  list-style: none;
  margin: 0 0 var(--space-md);
  padding: 0;
  display: grid;
  gap: 0.65rem;
}

@media (min-width: 600px) {
  .experience-detail__meta {
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem 1.25rem;
  }
}

.experience-detail__meta-item {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(214, 198, 168, 0.12);
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.02);
}

.experience-detail__meta-icon {
  flex-shrink: 0;
  display: flex;
  color: rgba(214, 198, 168, 0.88);
  margin-top: 0.1rem;
}

.experience-detail__meta-copy {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.experience-detail__meta-label {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(232, 229, 222, 0.55);
}

.experience-detail__meta-value {
  font-size: 0.875rem;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.92);
}

.experience-detail__body {
  max-width: none;
  width: 100%;
  white-space: pre-line;
  margin-bottom: var(--space-md);
  color: rgba(232, 229, 222, 0.88);
  font-size: 0.9375rem;
  line-height: 1.65;
}

.experience-request-form {
  display: grid;
  gap: var(--space-sm);
  padding-top: var(--space-md);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.experience-request-form--minimal .experience-request-form__grid {
  display: grid;
  gap: 0.75rem 1rem;
}

@media (min-width: 560px) {
  .experience-request-form--minimal .experience-request-form__grid {
    grid-template-columns: 1fr 1fr;
  }

  .experience-request-form--minimal .experience-request-form__field--wide {
    grid-column: 1 / -1;
  }
}

.experience-request-form__hint {
  margin: 0 0 0.25rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(232, 229, 222, 0.62);
}

.experience-request-form__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  font-weight: 500;
  margin: 0 0 0.25rem;
}

.experience-request-form__guest-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem 1.25rem;
  margin-top: 0.35rem;
}

@media (max-width: 520px) {
  .experience-request-form__guest-grid {
    grid-template-columns: 1fr;
  }
}

.experience-request-form__guest-col {
  min-width: 0;
}

.experience-request-form__sub-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.72;
  margin-bottom: 0.3rem;
}

.experience-request-form__stepper {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.25rem;
}

.experience-request-form__stepper-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 0.5rem;
  border-radius: 6px;
  border: 1px solid rgba(214, 198, 168, 0.45);
  background: rgba(255, 255, 255, 0.06);
  color: inherit;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
}

.experience-request-form__stepper-btn:hover {
  border-color: rgba(214, 198, 168, 0.75);
  background: rgba(255, 255, 255, 0.1);
}

.experience-request-form__stepper-val {
  min-width: 2rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

.experience-request-form__field {
  display: grid;
  gap: 0.35rem;
  margin: 0;
}

.experience-request-form__label {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(232, 229, 222, 0.55);
}

.experience-request-form input,
.experience-request-form textarea,
.experience-request-form select {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.28);
  color: var(--color-text);
  font: inherit;
}

.experience-request-form select {
  cursor: pointer;
  appearance: auto;
}

.experience-request-form__textarea {
  min-height: 4.5rem;
  resize: vertical;
  line-height: 1.45;
}

.experience-request-form__date-wrap {
  min-height: 2.75rem;
}

.experience-request-form__input.experience-request-form__date {
  cursor: pointer;
}

.experience-request-form input:focus,
.experience-request-form textarea:focus,
.experience-request-form select:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.4);
}

.experience-request-form__submit {
  justify-self: start;
  margin-top: 0.25rem;
}

.experience-request-form__feedback {
  margin: 0 0 0.75rem;
  padding: 0.55rem 0.65rem;
  border-radius: 4px;
  font-size: 0.9375rem;
  line-height: 1.45;
}

.experience-request-form__feedback:not([hidden]) {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.experience-request-form__feedback--below {
  margin-top: 0.85rem;
}

.experience-request-form__feedback.is-error {
  color: #f0b4b4;
}

.experience-request-form__feedback.is-success {
  color: rgba(186, 214, 186, 0.95);
}

/* ----- Villa story blocks ----- */
.story-block {
  margin-bottom: clamp(4rem, 10vw, 7rem);
}

.story-block:last-child {
  margin-bottom: 0;
}

.story-block .display-sub {
  max-width: 22ch;
}

/* Villa page: wide shell + two columns on large screens (deck | story), single column on small. */
.section--villa-narrative {
  padding-bottom: clamp(2.75rem, 7vw, 5rem);
}

.villa-narrative-layout {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 5vw, 3.25rem);
}

.villa-narrative-layout__aside {
  min-width: 0;
}

.villa-narrative-layout__main {
  min-width: 0;
}

@media (min-width: 1024px) {
  .villa-narrative-layout {
    display: grid;
    grid-template-columns: minmax(15.5rem, 0.38fr) minmax(0, 1fr);
    gap: clamp(2rem, 4.5vw, 3.75rem);
    align-items: start;
  }

  /* Sticky deck + single vertical rail (no bottom “box” on the deck). */
  .villa-narrative-layout__aside {
    position: sticky;
    top: clamp(5.25rem, 11vh, 7.5rem);
    align-self: flex-start;
    padding-right: clamp(1.25rem, 3vw, 2.5rem);
    margin-right: 0;
    border-right: 1px solid rgba(214, 198, 168, 0.16);
  }

  .villa-deck-head {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
    padding-right: 0;
    border-right: none;
  }

  .villa-deck-head__lede {
    max-width: none;
  }
}

/* No horizontal close under the deck — only the column border-right on the aside. */
.villa-deck-head {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

@media (max-width: 1023px) {
  .villa-deck-head {
    padding-bottom: clamp(1.25rem, 3vw, 1.75rem);
    border-bottom: 1px solid rgba(214, 198, 168, 0.1);
  }
}

.villa-deck-head > .eyebrow {
  margin-top: 0;
}

.villa-deck-head__title {
  margin-top: 0.35rem;
}

.villa-deck-head__lede {
  margin-top: 1rem;
  max-width: 52ch;
  color: rgba(247, 246, 243, 0.72);
}

.villa-deck-head__cta {
  margin-top: 1.35rem;
}

.villa-room-spotlights__eyebrow {
  margin: 0 0 clamp(0.85rem, 2vw, 1.15rem);
}

.villa-room-spotlights__eyebrow[hidden],
.villa-room-spotlights__eyebrow:empty {
  display: none !important;
}

.villa-room-spotlights {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3.5vw, 2.25rem);
  margin-bottom: clamp(2rem, 4.5vw, 3.25rem);
}

@media (min-width: 880px) {
  .villa-room-spotlights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1320px) {
  .villa-room-spotlights {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.villa-room-spotlight {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.03);
}

/* Serif title + image band + copy — visually separate from .villa-deck-head (.display-sub + .body-large). */
.villa-room-spotlight__body--head {
  padding: clamp(1rem, 2.5vw, 1.35rem) clamp(1rem, 2.5vw, 1.25rem) 0.65rem;
}

.villa-room-spotlight__body--copy {
  padding: 0 clamp(1rem, 2.5vw, 1.25rem) clamp(1rem, 2.5vw, 1.35rem);
}

.villa-room-spotlight__fig {
  margin: 0;
  line-height: 0;
  min-height: 11.5rem;
  background: rgba(0, 0, 0, 0.45);
  border-top: 1px solid rgba(214, 198, 168, 0.12);
  border-bottom: 1px solid rgba(214, 198, 168, 0.12);
}

.villa-room-spotlight__fig img {
  display: block;
  width: 100%;
  min-height: 11.5rem;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center center;
}

.villa-room-spotlight__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.1vw, 1.45rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  text-transform: none;
  font-style: normal;
  color: rgba(247, 246, 243, 0.94);
  line-height: 1.22;
}

.villa-room-spotlight__text {
  margin: 0;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 1.62;
  color: rgba(180, 186, 188, 0.96);
}

[data-theme="light"] .villa-room-spotlight {
  border-color: rgba(0, 0, 0, 0.08);
  background: rgba(255, 255, 255, 0.55);
}

[data-theme="light"] .villa-room-spotlight__title {
  color: rgba(27, 25, 23, 0.92);
}

[data-theme="light"] .villa-room-spotlight__text {
  color: rgba(72, 78, 80, 0.92);
}

[data-theme="light"] .villa-room-spotlight__fig {
  background: rgba(0, 0, 0, 0.06);
  border-top-color: rgba(0, 0, 0, 0.08);
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

.villa-story-stack {
  display: flex;
  flex-direction: column;
}

.villa-story-card {
  padding: clamp(1.75rem, 4vw, 2.75rem) 0;
  border-bottom: none;
}

.villa-story-card:first-of-type {
  padding-top: 0;
}

.villa-story-card:last-child {
  padding-bottom: 0;
}

.villa-story-card .story-block--villa {
  margin-bottom: 0;
}

/* Courtyards-style frame: text + split blocks share one shell; quote sits inside the same article. */
.villa-story-card--editorial {
  padding: clamp(1.5rem, 3.5vw, 2.25rem) 0;
}

.villa-story-card--editorial:first-of-type {
  padding-top: 0;
}

.villa-story-card--editorial .story-block--villa-editorial {
  margin: 0;
  padding: clamp(1.1rem, 2.5vw, 1.5rem) 0;
  border: none;
  border-radius: 0;
  background: transparent;
}

.villa-story-card--editorial.villa-story-card--split .story-block--villa-editorial {
  padding: clamp(1rem, 2.2vw, 1.35rem) 0;
}

/* Citation ribbon: rail + stack; dashed frames only in builder preview (see body.luxy-builder-target below). */
.villa-story-card__ribbon-quote {
  display: grid;
  grid-template-columns: 2px minmax(0, 1fr);
  gap: clamp(0.85rem, 2.2vw, 1.25rem);
  margin-top: clamp(1.35rem, 3vw, 2rem);
  align-items: stretch;
}

.villa-story-card__ribbon-quote__rail {
  display: block;
  width: 2px;
  min-height: 100%;
  border-radius: 1px;
  background: linear-gradient(180deg, rgba(214, 198, 168, 0.55), rgba(214, 198, 168, 0.12));
}

.villa-story-card__ribbon-quote__stack {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.villa-story-card__ribbon-quote__quote {
  margin: 0;
  padding: clamp(1rem, 2.5vw, 1.35rem);
  border: none;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.38;
  color: rgba(247, 246, 243, 0.9);
  letter-spacing: -0.01em;
}

.villa-story-card__ribbon-quote__quote p {
  margin: 0;
}

.villa-story-card__ribbon-quote__attr {
  margin: 0;
  padding: clamp(0.55rem, 1.5vw, 0.8rem) clamp(1rem, 2.5vw, 1.35rem);
  border: none;
  border-top: 1px solid rgba(247, 246, 243, 0.1);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.95);
}

.villa-story-card__ribbon-quote__attr cite {
  font-style: normal;
}

/* Builder / preview: dashed “editable region” chrome (not shown on the public site). */
body.luxy-builder-target .villa-story-card__ribbon-quote__quote {
  border: 1px dashed rgba(247, 246, 243, 0.22);
  border-bottom: none;
}

body.luxy-builder-target .villa-story-card__ribbon-quote__attr {
  border: 1px dashed rgba(247, 246, 243, 0.22);
}

.villa-story-card:first-of-type .story-block--villa-editorial > .eyebrow {
  margin-top: 0;
}

[data-theme="light"] .villa-story-card__ribbon-quote__rail {
  background: linear-gradient(180deg, rgba(90, 77, 54, 0.45), rgba(90, 77, 54, 0.12));
}

[data-theme="light"] .villa-story-card__ribbon-quote__quote {
  color: rgba(27, 25, 23, 0.9);
}

[data-theme="light"] .villa-story-card__ribbon-quote__attr {
  color: rgba(72, 78, 80, 0.92);
  border-top-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] body.luxy-builder-target .villa-story-card__ribbon-quote__quote {
  border-color: rgba(0, 0, 0, 0.2);
}

[data-theme="light"] body.luxy-builder-target .villa-story-card__ribbon-quote__attr {
  border-color: rgba(0, 0, 0, 0.2);
}

/* Main column can use width: split grids and copy read at a wider measure than the old single narrow stack. */
.villa-narrative-layout__main .villa-story-card .story-block--villa .display-sub {
  max-width: min(42ch, 100%);
}

.villa-narrative-layout__main .villa-story-card .story-block--villa .body-large {
  margin-top: 1rem;
  max-width: min(68ch, 100%);
}

.villa-story-card .story-block--villa .eyebrow {
  margin-bottom: 0.35rem;
}

.villa-story-card .story-text .body-large {
  margin-top: 0.85rem;
}

.villa-story-card .quote-block--villa {
  margin: 0;
  max-width: min(52rem, 100%);
}

.section--villa-plan:not(.villa-plan-tour--in-narrative) {
  padding-top: clamp(2.5rem, 6vw, 4rem);
  border-top: 1px solid rgba(214, 198, 168, 0.1);
}

/* Plan block lives in the narrative column after Living — no double horizontal shell padding. */
.villa-plan-tour--in-narrative.section {
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
  margin-top: clamp(1.5rem, 4vw, 2.75rem);
  padding-top: clamp(1.75rem, 4vw, 2.75rem);
  border-top: 1px solid rgba(214, 198, 168, 0.12);
}

.villa-plan-tour--in-narrative .villa-plan-tour__inner {
  padding-left: 0;
  padding-right: 0;
}

[data-theme="light"] .villa-narrative-layout__aside {
  border-right-color: rgba(0, 0, 0, 0.1);
}

[data-theme="light"] .villa-deck-head {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .villa-deck-head__lede {
  color: rgba(60, 58, 55, 0.78);
}


[data-theme="light"] .section--villa-plan:not(.villa-plan-tour--in-narrative) {
  border-top-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .villa-plan-tour--in-narrative {
  border-top-color: rgba(0, 0, 0, 0.08);
}

.story-block--split {
  display: grid;
  gap: var(--space-lg);
  align-items: center;
}

.villa-narrative-layout__main .story-block--split.story-block--villa-editorial {
  align-items: stretch;
}

@media (min-width: 900px) {
  .story-block--split.image-left {
    grid-template-columns: 1fr 1fr;
  }
  .story-block--split.image-right {
    grid-template-columns: 1fr 1fr;
  }
  .story-block--split.image-right .story-image {
    order: 2;
  }
  .story-block--split.image-right .story-text {
    order: 1;
  }
}

.story-image {
  overflow: hidden;
}

.villa-narrative-layout__main .story-block--split .story-image {
  min-height: clamp(11rem, 28vw, 17rem);
  align-self: stretch;
  background: rgba(0, 0, 0, 0.35);
  border: 1px dashed rgba(247, 246, 243, 0.14);
}

[data-theme="light"] .villa-narrative-layout__main .story-block--split .story-image {
  background: rgba(0, 0, 0, 0.06);
  border-color: rgba(0, 0, 0, 0.12);
}

.story-image img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
  object-position: center center;
}

.villa-narrative-layout__main .story-block--split .story-image img {
  min-height: clamp(11rem, 28vw, 17rem);
  height: 100%;
  aspect-ratio: auto;
}

.story-image img.luxy-img-fit--contain {
  background: var(--color-surface, #0c0c0d);
  aspect-ratio: auto;
  height: auto;
  object-fit: contain;
}

/* ----- Contact ----- */
.contact-grid {
  display: grid;
  gap: var(--space-xl);
}

@media (min-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.contact-form label {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.4rem;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 0.85rem 0;
  border: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  background: transparent;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 1rem;
  margin-bottom: var(--space-md);
  border-radius: 0;
}

.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--color-gold);
}

.contact-form textarea {
  min-height: 120px;
  resize: vertical;
}

.contact-form__feedback {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-muted);
}

.contact-form__feedback.is-error {
  color: #e8a0a0;
}

.contact-form__feedback.is-success {
  color: rgba(186, 212, 170, 0.95);
}

.contact-map {
  margin-top: clamp(2.5rem, 6vw, 4rem);
  padding-top: clamp(2rem, 5vw, 3rem);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  max-width: 100%;
}

.contact-map__title {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.contact-map__lede {
  margin: 0 0 0;
  max-width: var(--readable-wide);
  color: rgba(247, 246, 243, 0.72);
}

.contact-map__frame {
  position: relative;
  margin-top: var(--space-lg);
  aspect-ratio: 16 / 9;
  max-height: min(70vh, 560px);
  border: 1px solid rgba(214, 198, 168, 0.12);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
}

.contact-map__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* Villa · pianta + tour virtuale */
.villa-plan-tour__grid {
  display: grid;
  gap: clamp(1.75rem, 4vw, 2.75rem);
  align-items: start;
}

@media (min-width: 900px) {
  .villa-plan-tour__grid {
    grid-template-columns: 1fr 1fr;
  }

  .villa-plan-tour__grid--single {
    grid-template-columns: 1fr;
    max-width: min(52rem, 100%);
    margin-left: 0;
  }
}

.villa-plan-tour__plan-frame {
  border: 1px solid rgba(214, 198, 168, 0.12);
  background: rgba(255, 255, 255, 0.03);
  overflow: hidden;
}

.villa-plan-tour__plan-frame img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(85vh, 720px);
  object-fit: contain;
  object-position: center top;
}

.villa-plan-tour__caption {
  margin-top: 0.65rem;
  font-size: 0.875rem;
}

.villa-plan-tour__caption:empty {
  display: none;
}

.villa-plan-tour__embed-label {
  margin-bottom: 0.65rem;
}

.villa-plan-tour__frame {
  position: relative;
  aspect-ratio: 16 / 10;
  min-height: 280px;
  max-height: min(75vh, 640px);
  border: 1px solid rgba(214, 198, 168, 0.12);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
}

.villa-plan-tour__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.villa-plan-tour__link-row {
  margin-top: clamp(1.25rem, 3vw, 2rem);
}

.section-head__lede {
  margin-top: 0.35rem;
  margin-bottom: 0;
  max-width: var(--readable-wide);
  color: rgba(247, 246, 243, 0.7);
}

/* ----- Pagina prenotazioni (iframe / embed) ----- */
.booking-embed-zone {
  background: rgba(20, 20, 20, 0.35);
  padding: clamp(2.5rem, 6vw, 4rem);
  margin-top: var(--space-lg);
  min-height: 280px;
  border: 1px solid rgba(214, 198, 168, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.booking-embed-zone__note {
  max-width: 32rem;
  color: rgba(138, 147, 150, 0.88);
  font-size: 0.9375rem;
  font-weight: 300;
  line-height: 1.7;
}

.booking-embed-frame-wrap {
  margin-top: var(--space-lg);
  width: 100%;
  max-width: 960px;
  min-height: 480px;
  background: rgba(0, 0, 0, 0.3);
  border: none;
}

.booking-embed-frame-wrap iframe {
  width: 100%;
  min-height: 480px;
  border: 0;
}

.search-placeholder {
  width: 100%;
  max-width: 720px;
  margin: var(--space-lg) auto 0;
  display: grid;
  gap: var(--space-sm);
}

@media (min-width: 600px) {
  .search-placeholder {
    grid-template-columns: 1fr 1fr auto;
    align-items: end;
  }
}

.search-placeholder input {
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: var(--color-bg);
  color: var(--color-white);
  font-family: var(--font-body);
}

.search-placeholder input::placeholder {
  color: var(--color-muted);
}

/* ----- Calendar ----- */
.calendar-widget {
  margin-top: var(--space-lg);
  max-width: 420px;
  background: rgba(14, 14, 14, 0.65);
  padding: 1.35rem 1.25rem;
  border: 1px solid var(--hairline);
}

.calendar-widget__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

.calendar-widget__header button {
  background: none;
  border: 1px solid rgba(214, 198, 168, 0.35);
  color: var(--color-white);
  width: 2.25rem;
  height: 2.25rem;
  cursor: pointer;
  font-size: 1rem;
  transition: border-color 0.3s, color 0.3s;
}

.calendar-widget__header button:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.calendar-widget__month {
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: 0.06em;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  text-align: center;
  font-size: 0.7rem;
}

.calendar-grid__dow {
  color: var(--color-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0;
}

.calendar-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.5);
  border: 1px solid transparent;
}

.calendar-day--in-month {
  color: rgba(255, 255, 255, 0.88);
  cursor: default;
}

.calendar-day--unavailable {
  background: rgba(122, 138, 142, 0.25);
  color: rgba(255, 255, 255, 0.35);
  text-decoration: line-through;
}

.calendar-day--available {
  border-color: rgba(214, 198, 168, 0.15);
}

.calendar-legend {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-md);
  font-size: 0.7rem;
  color: var(--color-muted);
}

.calendar-legend span {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.legend-swatch {
  width: 12px;
  height: 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.legend-swatch--busy {
  background: rgba(122, 138, 142, 0.35);
}

/* ----- Admin — dashboard (content studio) ----- */
.admin-app {
  --admin-chrome-h: 4.25rem;
  --admin-statusbar-h: 3.65rem;
  --admin-border: rgba(214, 198, 168, 0.1);
  --admin-surface: #0c0c0c;
  --admin-elevated: #111111;
  --admin-muted: rgba(247, 246, 243, 0.42);
  min-height: 100vh;
  margin: 0;
  padding-bottom: calc(var(--admin-statusbar-h) + env(safe-area-inset-bottom, 0px));
  box-sizing: border-box;
  background: var(--admin-surface);
  color: rgba(247, 246, 243, 0.92);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
  max-width: 100%;
}

/* Content studio (admin.html): one viewport height, no document scrollbar — only preview + inspector scroll. */
html:has(body.admin-app .builder-layout) {
  height: 100%;
  overflow-x: clip;
  overflow-y: hidden;
}

body.admin-app:has(.builder-layout) {
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: 100%;
  max-height: 100%;
  overflow: hidden;
}

body.admin-app:has(.builder-layout) .builder-layout {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  /* Viewport band: without this, grid 1fr rows collapse and the preview becomes a thin strip. */
  min-height: calc(100vh - var(--admin-chrome-h) - var(--admin-statusbar-h));
  min-height: calc(100dvh - var(--admin-chrome-h) - var(--admin-statusbar-h));
  max-height: calc(100vh - var(--admin-chrome-h) - var(--admin-statusbar-h));
  max-height: calc(100dvh - var(--admin-chrome-h) - var(--admin-statusbar-h));
  overflow: hidden;
}

/* Studio / console: no horizontal page scroll; window scrollbar matches Luxy (gold on dark) */
html:has(body.admin-app) {
  overflow-x: clip;
  max-width: 100%;
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.42) rgba(10, 10, 10, 0.65);
}

html:has(body.admin-app)::-webkit-scrollbar {
  width: 8px;
}

html:has(body.admin-app)::-webkit-scrollbar-track {
  background: rgba(10, 10, 10, 0.55);
}

html:has(body.admin-app)::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.32);
  border-radius: 4px;
  border: 2px solid rgba(0, 0, 0, 0.35);
  background-clip: padding-box;
}

html:has(body.admin-app)::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.52);
}

html:has(body.admin-app.admin-app--light) {
  scrollbar-color: rgba(90, 77, 54, 0.38) rgba(237, 233, 224, 0.95);
}

html:has(body.admin-app.admin-app--light)::-webkit-scrollbar-track {
  background: rgba(237, 233, 224, 0.9);
}

html:has(body.admin-app.admin-app--light)::-webkit-scrollbar-thumb {
  background: rgba(90, 77, 54, 0.3);
  border: 2px solid rgba(237, 233, 224, 0.6);
  background-clip: padding-box;
}

html:has(body.admin-app.admin-app--light)::-webkit-scrollbar-thumb:hover {
  background: rgba(90, 77, 54, 0.48);
}

.admin-shell {
  position: sticky;
  top: 0;
  z-index: 200;
  min-height: var(--admin-chrome-h);
  border-bottom: 1px solid var(--admin-border);
  background: rgba(12, 12, 12, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.admin-shell__inner {
  max-width: 100%;
  min-width: 0;
  min-height: var(--admin-chrome-h);
  padding: 0.45rem clamp(1rem, 3vw, 1.75rem);
  display: grid;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.55rem 1rem;
  box-sizing: border-box;
  overflow-x: clip;
}

.admin-shell__brand {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
}

.admin-shell__mark {
  width: 2px;
  height: 2rem;
  background: linear-gradient(180deg, var(--color-gold) 0%, rgba(214, 198, 168, 0.25) 100%);
  border-radius: 1px;
  flex-shrink: 0;
}

.admin-shell__kicker {
  margin: 0;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.75);
}

.admin-shell__title {
  margin: 0.15rem 0 0;
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 2vw, 1.125rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  color: rgba(247, 246, 243, 0.96);
  line-height: 1.15;
}

.admin-shell__actions {
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 0;
}

.admin-shell__data-tools.builder-toolbar-inline {
  margin-bottom: 0;
  justify-content: center;
}

.admin-shell__data-tools.builder-toolbar-inline .builder-btn:not(.builder-btn--icon) {
  padding: 0.38rem 0.45rem;
  font-size: 0.5625rem;
  letter-spacing: 0.08em;
}

.admin-shell__data-tools.builder-toolbar-inline .builder-btn--icon {
  flex: 0 0 1.95rem;
  width: 1.95rem;
  min-width: 1.95rem;
  max-width: 1.95rem;
  padding: 0.38rem 0;
  font-size: 0.875rem;
}

/* Space before server auth; separator after clear-draft (X) */
.admin-shell__data-tools.builder-toolbar-inline .builder-toolbar-clear-draft {
  margin-right: 0.75rem;
}

.admin-shell__data-tools.builder-toolbar-inline .builder-toolbar-server-auth {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-left: 0.35rem;
  padding-left: 1.35rem;
  border-left: 1px solid var(--admin-border, rgba(255, 255, 255, 0.12));
}

.admin-shell__data-tools.builder-toolbar-inline .builder-toolbar-server-auth .builder-btn--icon {
  flex: 0 0 2.15rem;
  width: 2.15rem;
  min-width: 2.15rem;
  max-width: 2.15rem;
}

.builder-inbox-server-login-banner {
  margin: 0 0 0.85rem;
  padding: 0.55rem 0.5rem 0.65rem;
  border-radius: 6px;
  border: 1px solid rgba(214, 198, 168, 0.22);
  background: rgba(214, 198, 168, 0.06);
}

.builder-inbox-server-login-banner .builder-hint {
  margin: 0 0 0.55rem;
}

.builder-inbox-server-login-banner .builder-btn {
  width: 100%;
  box-sizing: border-box;
}

.admin-app.admin-app--light .builder-inbox-server-login-banner {
  border-color: rgba(27, 25, 23, 0.12);
  background: rgba(255, 255, 255, 0.65);
}

.admin-shell__right {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 2vw, 1.5rem);
  flex-shrink: 0;
}

.admin-shell__typo-ur {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.admin-shell__typo-ur-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  margin: 0;
  padding: 0;
  border: 1px solid var(--admin-border);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(247, 246, 243, 0.72);
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    color 0.15s ease;
}

.admin-shell__typo-ur-btn:hover:not(:disabled) {
  border-color: rgba(214, 198, 168, 0.35);
  color: rgba(247, 246, 243, 0.95);
  background: rgba(255, 255, 255, 0.07);
}

.admin-shell__typo-ur-btn:disabled {
  opacity: 0.28;
  cursor: not-allowed;
}

.admin-shell__typo-ur-svg {
  display: block;
  opacity: 0.92;
}

.admin-app.admin-app--light .admin-shell__typo-ur-btn {
  background: rgba(0, 0, 0, 0.04);
  color: rgba(30, 28, 24, 0.65);
  border-color: rgba(0, 0, 0, 0.1);
}

.admin-app.admin-app--light .admin-shell__typo-ur-btn:hover:not(:disabled) {
  background: rgba(0, 0, 0, 0.06);
  color: rgba(30, 28, 24, 0.9);
  border-color: rgba(214, 198, 168, 0.45);
}

.admin-status {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.75rem;
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--admin-muted);
  border: 1px solid var(--admin-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.02);
}

.admin-status::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(138, 147, 150, 0.6);
  box-shadow: 0 0 0 3px rgba(138, 147, 150, 0.12);
}

.admin-status[data-state="success"] {
  color: rgba(214, 198, 168, 0.95);
  border-color: rgba(214, 198, 168, 0.22);
}

.admin-status[data-state="success"]::before {
  background: var(--color-gold);
  box-shadow: 0 0 10px rgba(214, 198, 168, 0.35);
}

.admin-status[data-state="warn"] {
  color: rgba(247, 200, 120, 0.9);
}

.admin-status[data-state="warn"]::before {
  background: rgba(247, 200, 120, 0.85);
}

.admin-status[data-state="ok"] {
  color: rgba(214, 198, 168, 0.95);
  border-color: rgba(214, 198, 168, 0.22);
}

.admin-status[data-state="ok"]::before {
  background: var(--color-gold);
  box-shadow: 0 0 10px rgba(214, 198, 168, 0.35);
}

/* Fixed footer for session / toast messages — keeps the header grid from breaking on long copy */
.admin-status-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 250;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  border-top: 1px solid var(--admin-border);
  background: rgba(12, 12, 12, 0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-sizing: border-box;
}

.admin-status-bar__inner {
  max-width: 100%;
  margin: 0 auto;
  padding: 0.5rem clamp(1rem, 3vw, 1.75rem);
  min-height: var(--admin-statusbar-h);
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

.admin-status-bar__inner--stack {
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
}

.admin-status-bar__inner--strip-row {
  flex-direction: row;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0.65rem 1rem;
}

.admin-status-bar__inner--strip-row .admin-connection-strip {
  flex: 1 1 auto;
  min-width: 0;
}

.admin-status-bar__inner--strip-row .admin-status--dock {
  flex-shrink: 0;
}

.admin-connection-strip {
  font-size: 0.625rem;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.72);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.3rem 0.55rem;
  overflow-x: hidden;
  scrollbar-width: thin;
}

.admin-connection-strip__item {
  display: inline-flex;
  align-items: baseline;
  gap: 0.2rem;
  white-space: nowrap;
}

.admin-connection-strip__k {
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.5625rem;
  color: rgba(214, 198, 168, 0.55);
}

.admin-connection-strip__ok {
  font-weight: 600;
  color: rgba(168, 214, 168, 0.95);
}

.admin-connection-strip__off {
  font-weight: 600;
  color: rgba(255, 168, 168, 0.92);
}

.admin-connection-strip__muted {
  font-weight: 500;
  color: rgba(247, 246, 243, 0.45);
}

.admin-connection-strip__sep {
  color: rgba(247, 246, 243, 0.22);
  user-select: none;
  margin: 0 0.05rem;
}

.admin-connection-strip__item--tip[title] {
  cursor: help;
}

.admin-connection-strip__a {
  color: rgba(180, 210, 255, 0.95);
  text-decoration: underline;
  text-underline-offset: 0.12em;
  cursor: pointer;
  font-weight: 600;
  white-space: nowrap;
}

.admin-connection-strip__a:hover {
  color: #fff;
}

.admin-app.admin-app--light .admin-connection-strip__a {
  color: rgba(30, 80, 160, 0.95);
}

.admin-app.admin-app--light .admin-connection-strip__a:hover {
  color: rgba(12, 40, 90, 1);
}

/* ----- Content studio: license recovery shell (server session + license_ok false) ----- */
.luxy-license-shell-banner {
  margin: 0;
  padding: 0.65rem 1.25rem;
  background: rgba(45, 28, 12, 0.97);
  color: #fde7c8;
  font-size: 0.8125rem;
  line-height: 1.45;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.admin-app.admin-app--light .luxy-license-shell-banner {
  background: rgba(255, 248, 230, 0.98);
  color: rgba(55, 35, 10, 0.95);
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

.luxy-license-shell-banner__link {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.12em;
  font-weight: 600;
}

.admin-app.admin-app--light .luxy-license-shell-banner__link {
  color: #1a4d8c;
}

.luxy-admin-license-shell-lock .builder-canvas {
  pointer-events: none;
  opacity: 0.42;
  filter: grayscale(0.2);
}

.luxy-admin-license-shell-lock .builder-studio-guide,
.luxy-admin-license-shell-lock .builder-sidebar-quick {
  display: none;
}

.luxy-license-admin-panel {
  font-size: 0.625rem;
  line-height: 1.35;
  color: rgba(247, 246, 243, 0.78);
  padding: 0.15rem 0.1rem 0;
  border-top: 1px solid rgba(214, 198, 168, 0.1);
}

.luxy-license-admin-panel__one {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem;
  cursor: help;
}

.luxy-license-admin-panel__k {
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.5625rem;
  color: rgba(214, 198, 168, 0.55);
}

.luxy-license-admin-panel__ok {
  font-weight: 700;
  color: rgba(168, 214, 168, 0.95);
}

.luxy-license-admin-panel__off {
  font-weight: 700;
  color: rgba(255, 168, 168, 0.92);
}

.luxy-license-admin-panel__a {
  color: rgba(180, 210, 255, 0.95);
  text-decoration: underline;
  text-underline-offset: 0.12em;
  cursor: pointer;
}

.luxy-license-admin-panel__a:hover {
  color: #fff;
}

.admin-app.admin-app--light .admin-connection-strip {
  color: rgba(27, 25, 23, 0.72);
}

.admin-app.admin-app--light .admin-connection-strip__k {
  color: rgba(27, 25, 23, 0.45);
}

.admin-app.admin-app--light .admin-connection-strip__ok {
  color: rgba(34, 110, 60, 0.92);
}

.admin-app.admin-app--light .admin-connection-strip__off {
  color: rgba(160, 45, 45, 0.9);
}

.admin-app.admin-app--light .admin-connection-strip__muted {
  color: rgba(27, 25, 23, 0.42);
}

.admin-app.admin-app--light .admin-connection-strip__sep {
  color: rgba(27, 25, 23, 0.18);
}

.admin-app.admin-app--light .luxy-license-admin-panel {
  color: rgba(27, 25, 23, 0.78);
  border-top-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .luxy-license-admin-panel__k {
  color: rgba(27, 25, 23, 0.45);
}

.admin-app.admin-app--light .luxy-license-admin-panel__a {
  color: rgba(30, 80, 160, 0.95);
}

.admin-status.admin-status--dock {
  flex: 1;
  min-width: 0;
  max-width: 100%;
  margin: 0;
  justify-content: flex-start;
  text-align: left;
  text-transform: none;
  letter-spacing: 0.02em;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 1.45;
  white-space: normal;
  word-break: break-word;
  border-radius: 6px;
  max-height: 5.25rem;
  overflow-x: hidden;
  overflow-y: auto;
}

.admin-app.admin-app--light .admin-status-bar {
  background: rgba(250, 248, 244, 0.97);
  border-top-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .admin-status.admin-status--dock {
  background: rgba(255, 255, 255, 0.9);
}

.admin-shell__to-console {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.72);
  text-decoration: none;
  padding: 0.45rem 0.55rem;
  border-radius: 4px;
  border: 1px solid rgba(214, 198, 168, 0.22);
  background: rgba(255, 255, 255, 0.03);
  transition:
    color 0.35s var(--ease-lux),
    border-color 0.35s var(--ease-lux),
    background 0.35s var(--ease-lux);
  white-space: nowrap;
}

.admin-shell__to-console:hover {
  color: rgba(247, 246, 243, 0.95);
  border-color: rgba(214, 198, 168, 0.4);
  background: rgba(214, 198, 168, 0.08);
}

.admin-shell__to-console--back {
  border-style: dashed;
}

.admin-app.admin-app--light .admin-shell__to-console {
  color: rgba(90, 77, 54, 0.85);
  border-color: rgba(27, 25, 23, 0.12);
  background: rgba(255, 255, 255, 0.55);
}

.admin-app.admin-app--light .admin-shell__to-console:hover {
  color: #1b1917;
  border-color: rgba(90, 77, 54, 0.3);
}

.admin-shell__exit {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.48);
  text-decoration: none;
  padding: 0.5rem 0;
  border-bottom: 1px solid transparent;
  transition:
    color 0.45s var(--ease-lux),
    border-color 0.45s var(--ease-lux);
}

.admin-shell__exit:hover {
  color: var(--color-gold);
  border-bottom-color: rgba(214, 198, 168, 0.35);
}

.admin-shell__exit-icon {
  width: 1.25rem;
  height: 1px;
  background: currentColor;
  opacity: 0.65;
  position: relative;
}

.admin-shell__exit-icon::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 5px;
  height: 5px;
  border-right: 1px solid currentColor;
  border-top: 1px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
  margin-top: 0.5px;
}

.admin-shell__theme {
  margin: 0;
  padding: 0.42rem 0.8rem;
  font-family: var(--font-body);
  font-size: 0.53125rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.88);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--admin-border);
  border-radius: 999px;
  cursor: pointer;
  transition:
    color 0.35s var(--ease-lux),
    border-color 0.35s var(--ease-lux),
    background 0.35s var(--ease-lux);
}

.admin-shell__theme:hover {
  color: rgba(247, 246, 243, 0.95);
  border-color: rgba(214, 198, 168, 0.32);
  background: rgba(214, 198, 168, 0.1);
}

.admin-app.admin-app--light {
  --admin-border: rgba(27, 25, 23, 0.1);
  --admin-surface: #ece8df;
  --admin-elevated: #f7f4ed;
  --admin-muted: rgba(27, 25, 23, 0.5);
  background: var(--admin-surface);
  color: rgba(27, 25, 23, 0.92);
}

.admin-app.admin-app--light .admin-shell {
  background: rgba(247, 244, 238, 0.95);
  border-bottom-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .admin-shell__kicker {
  color: rgba(90, 77, 54, 0.75);
}

.admin-app.admin-app--light .admin-shell__title {
  color: rgba(27, 25, 23, 0.94);
}

.admin-app.admin-app--light .admin-status {
  border-color: var(--admin-border);
  background: rgba(255, 255, 255, 0.72);
}

.admin-app.admin-app--light .admin-shell__exit {
  color: rgba(27, 25, 23, 0.48);
}

.admin-app.admin-app--light .admin-shell__exit:hover {
  color: #5a4d36;
}

.admin-app.admin-app--light .admin-shell__theme {
  color: rgba(90, 77, 54, 0.92);
  border-color: rgba(27, 25, 23, 0.12);
  background: rgba(255, 255, 255, 0.72);
}

.admin-app.admin-app--light .admin-shell__theme:hover {
  color: #1b1917;
  border-color: rgba(90, 77, 54, 0.35);
}

.admin-app.admin-app--light .builder-layout {
  background: linear-gradient(180deg, #e5e1d8 0%, #ece8df 36%, #e3dfd4 100%);
}

.admin-app.admin-app--light .builder-sidebar-compact__tip {
  color: rgba(70, 76, 78, 0.9);
}

.admin-app.admin-app--light .builder-field input,
.admin-app.admin-app--light .builder-field textarea,
.admin-app.admin-app--light .builder-select {
  background: rgba(255, 255, 255, 0.9);
  color: rgba(27, 25, 23, 0.94);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-sidebar-compact__tip strong {
  color: rgba(53, 48, 40, 0.88);
}

.admin-app.admin-app--light .builder-sidebar-compact__tip a {
  color: #5a4d36;
}

.admin-app.admin-app--light .builder-sidebar-compact__tip a:hover {
  color: #1b1917;
}

.admin-app.admin-app--light .builder-card {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0.2) 48%);
}

.admin-app.admin-app--light .builder-card__title {
  color: rgba(90, 77, 54, 0.92);
}

.admin-app.admin-app--light .builder-card__desc,
.admin-app.admin-app--light .builder-card__hint {
  color: rgba(45, 48, 52, 0.72);
}

.admin-app.admin-app--light .builder-code {
  background: rgba(255, 255, 255, 0.75);
  color: rgba(53, 48, 40, 0.9);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-btn--gold {
  border-color: rgba(90, 77, 54, 0.28);
  background: rgba(255, 255, 255, 0.65);
  color: rgba(27, 25, 23, 0.9);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.admin-app.admin-app--light .builder-btn--gold:hover {
  background: rgba(214, 198, 168, 0.22);
  border-color: rgba(90, 77, 54, 0.45);
  box-shadow: 0 6px 20px rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-btn--line {
  color: rgba(27, 25, 23, 0.72);
}

.admin-app.admin-app--light .builder-btn--line:hover {
  color: rgba(90, 77, 54, 0.95);
}

.admin-app.admin-app--light .builder-btn--ghost {
  background: rgba(255, 255, 255, 0.45);
  color: rgba(27, 25, 23, 0.45);
}

.admin-app.admin-app--light .builder-btn--ghost:hover {
  color: rgba(27, 25, 23, 0.75);
  background: rgba(255, 255, 255, 0.72);
}

.admin-app.admin-app--light .builder-nav__label {
  color: rgba(70, 76, 78, 0.88);
}

.admin-app.admin-app--light .builder-filter {
  color: rgba(27, 25, 23, 0.92);
  background: rgba(255, 255, 255, 0.82);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-filter::placeholder {
  color: rgba(70, 76, 78, 0.45);
}

.admin-app.admin-app--light .builder-field-list {
  background: rgba(255, 255, 255, 0.55);
  scrollbar-color: rgba(90, 77, 54, 0.2) transparent;
}

.admin-app.admin-app--light .builder-field-list::-webkit-scrollbar-thumb {
  background: rgba(90, 77, 54, 0.22);
}

.admin-app.admin-app--light .builder-field-btn {
  color: rgba(27, 25, 23, 0.68);
}

.admin-app.admin-app--light .builder-field-btn:hover {
  background: rgba(214, 198, 168, 0.18);
  color: rgba(27, 25, 23, 0.95);
}

.admin-app.admin-app--light .builder-field-btn.is-active {
  background: rgba(214, 198, 168, 0.26);
  color: rgba(27, 25, 23, 0.98);
}

.admin-app.admin-app--light .builder-field-help-trigger {
  border-color: rgba(90, 77, 54, 0.28);
  background: rgba(214, 198, 168, 0.2);
  color: rgba(70, 60, 40, 0.95);
}

.admin-app.admin-app--light .builder-field-help-trigger:hover,
.admin-app.admin-app--light .builder-field-help-trigger:focus-visible {
  background: rgba(214, 198, 168, 0.35);
  border-color: rgba(90, 77, 54, 0.45);
  color: rgba(27, 25, 23, 0.98);
}

.admin-app.admin-app--light .builder-field-help-drawer {
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-inspector-field-help {
  color: rgba(70, 76, 78, 0.92);
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-checkbox {
  color: rgba(27, 25, 23, 0.72);
}

.admin-app.admin-app--light .builder-checkbox:hover {
  background: rgba(255, 255, 255, 0.45);
}

.admin-app.admin-app--light .builder-hint {
  color: rgba(70, 76, 78, 0.88);
}

.admin-app.admin-app--light .builder-inspector-group {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-inspector-group__title {
  border-bottom-color: rgba(27, 25, 23, 0.1);
  color: rgba(90, 77, 54, 0.88);
}

.admin-app.admin-app--light .builder-dim-row__label {
  color: rgba(45, 48, 52, 0.72);
}

.admin-app.admin-app--light .builder-dim-row__input {
  background: rgba(255, 255, 255, 0.88);
  color: rgba(27, 25, 23, 0.94);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-logo-height-modes__radios label,
.admin-app.admin-app--light label.builder-logo-radio-label {
  color: rgba(27, 25, 23, 0.78) !important;
}

.admin-app.admin-app--light .builder-logo-height-modes__legend {
  color: rgba(45, 48, 52, 0.72);
}

.admin-app.admin-app--light .builder-logo-dimensions__title {
  color: rgba(90, 77, 54, 0.88);
}

.admin-app.admin-app--light .builder-logo-height-modes {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-logo-height-modes__legend {
  color: rgba(45, 48, 52, 0.82);
}

.admin-app.admin-app--light .builder-logo-mode-option {
  background: rgba(255, 255, 255, 0.65);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-logo-preview {
  background: #eae6dc;
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-panel__scroll::-webkit-scrollbar-thumb {
  background: rgba(90, 77, 54, 0.22);
}

.admin-app.admin-app--light .builder-panel__scroll {
  scrollbar-color: rgba(90, 77, 54, 0.22) transparent;
}

.admin-app.admin-app--light .builder-canvas {
  background: #d8d4cb;
}

.admin-app.admin-app--light .builder-canvas__chrome {
  background: rgba(247, 244, 238, 0.97);
}

.admin-app.admin-app--light .builder-canvas__hint {
  color: rgba(70, 76, 78, 0.88);
}

.admin-app.admin-app--light .builder-canvas__label {
  color: rgba(90, 77, 54, 0.82);
}

.admin-app.admin-app--light .builder-select-wrap__label {
  color: rgba(70, 76, 78, 0.82);
}

.admin-app.admin-app--light .builder-select {
  color: rgba(27, 25, 23, 0.92);
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(27, 25, 23, 0.12);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235a4d36' fill-opacity='0.65' d='M1.4 0 6 4.6 10.6 0 12 1.4l-6 6-6-6z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
}

.admin-app.admin-app--light .builder-canvas__frame {
  background: transparent;
}

.admin-app.admin-app--light .builder-canvas__preview-zoom-note {
  color: rgba(70, 76, 78, 0.88);
  border-bottom-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-device-btn,
.admin-app.admin-app--light .builder-zoom-btn {
  color: rgba(27, 25, 23, 0.88);
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-device-btn:hover,
.admin-app.admin-app--light .builder-device-btn:focus,
.admin-app.admin-app--light .builder-zoom-btn:hover,
.admin-app.admin-app--light .builder-zoom-btn:focus {
  border-color: rgba(90, 77, 54, 0.38);
  background: rgba(214, 198, 168, 0.18);
}

.admin-app.admin-app--light .builder-device-btn.is-active,
.admin-app.admin-app--light .builder-zoom-btn.is-active {
  border-color: rgba(90, 77, 54, 0.5);
  background: rgba(214, 198, 168, 0.26);
  color: rgba(27, 25, 23, 0.98);
}

.admin-app.admin-app--light .builder-canvas__zoom-label {
  color: rgba(70, 76, 78, 0.85);
}

.admin-app.admin-app--light .builder-canvas__zoom-scroll {
  scrollbar-color: rgba(90, 77, 54, 0.22) transparent;
}

.admin-app.admin-app--light .builder-canvas__iframe {
  box-shadow:
    0 0 0 1px rgba(27, 25, 23, 0.12),
    0 18px 56px rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-typo-panel__title {
  color: rgba(90, 77, 54, 0.9);
}

.admin-app.admin-app--light .builder-typo-tbtn {
  color: rgba(27, 25, 23, 0.88);
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(27, 25, 23, 0.12);
}

.admin-app.admin-app--light .builder-typo-tbtn:hover,
.admin-app.admin-app--light .builder-typo-tbtn:focus {
  color: rgba(27, 25, 23, 0.98);
  background: rgba(214, 198, 168, 0.2);
}

.admin-app.admin-app--light .builder-typo-tbtn.is-on {
  color: rgba(27, 25, 23, 0.98);
  background: rgba(214, 198, 168, 0.32);
}

.admin-app.admin-app--light .builder-typo-advanced {
  border-color: rgba(27, 25, 23, 0.1);
  background: rgba(255, 255, 255, 0.5);
}

.admin-app.admin-app--light .builder-typo-advanced summary {
  color: rgba(90, 77, 54, 0.82);
}

.admin-app.admin-app--light .builder-inspector__head {
  border-bottom-color: rgba(27, 25, 23, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.65) 0%, transparent 100%);
}

.admin-app.admin-app--light .builder-inspector__label {
  color: rgba(90, 77, 54, 0.78);
}

.admin-app.admin-app--light .builder-inspector__title {
  color: rgba(27, 25, 23, 0.92);
}

.admin-app.admin-app--light .builder-inspector__body {
  scrollbar-color: rgba(90, 77, 54, 0.2) transparent;
}

.admin-app.admin-app--light .builder-inspector__body::-webkit-scrollbar-thumb {
  background: rgba(90, 77, 54, 0.26);
}

.admin-app.admin-app--light .builder-inspector__body::-webkit-scrollbar-thumb:hover {
  background: rgba(90, 77, 54, 0.42);
}

.admin-app.admin-app--light .builder-field > label {
  color: rgba(70, 76, 78, 0.82);
}

.admin-app.admin-app--light .builder-field input:focus,
.admin-app.admin-app--light .builder-field textarea:focus {
  border-color: rgba(90, 77, 54, 0.45);
  box-shadow: 0 0 0 3px rgba(214, 198, 168, 0.22);
}

.admin-app.admin-app--light .builder-media-modal__panel {
  background: #f7f4ed;
  border-color: rgba(27, 25, 23, 0.12);
  box-shadow: 0 24px 80px rgba(27, 25, 23, 0.18);
}

.admin-app.admin-app--light .builder-media-modal__title {
  color: rgba(27, 25, 23, 0.94);
}

.admin-app.admin-app--light .builder-media-modal__x {
  background: rgba(27, 25, 23, 0.06);
  color: rgba(27, 25, 23, 0.8);
}

.admin-app.admin-app--light .builder-media-modal__upload-status {
  background: rgba(255, 255, 255, 0.75);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-media-modal__upload-msg {
  color: rgba(53, 48, 40, 0.88);
}

.admin-app.admin-app--light .builder-media-tile {
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-media-tile__cap {
  color: rgba(27, 25, 23, 0.62);
}

.admin-app.admin-app--light .builder-img-field__thumb {
  background: rgba(255, 255, 255, 0.8);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-repeater-card {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-repeater-card__head {
  color: rgba(90, 77, 54, 0.82);
}

.admin-app.admin-app--light .builder-repeater-card__label {
  color: rgba(70, 76, 78, 0.78);
}

.admin-app.admin-app--light .builder-media-lib-card {
  background: rgba(255, 255, 255, 0.65);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-media-lib-card__name {
  color: rgba(27, 25, 23, 0.68);
}

.builder-layout {
  display: grid;
  grid-template-columns: minmax(210px, 248px) 1fr minmax(240px, 300px);
  min-height: calc(100vh - var(--admin-chrome-h) - var(--admin-statusbar-h));
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: clip;
  box-sizing: border-box;
  background: linear-gradient(180deg, #0a0a0a 0%, #0c0c0c 32%, #090909 100%);
}

@media (max-width: 1180px) {
  /* Single column: tree → preview (tall band) → Value (editor) below. */
  .builder-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(36vh, min(56vh, 620px)) minmax(260px, 1fr);
  }

  .builder-panel--left {
    grid-column: 1;
    grid-row: 1;
  }

  .builder-canvas {
    grid-column: 1;
    grid-row: 2;
    min-height: 0;
    max-height: none;
  }

  .builder-panel--right {
    grid-column: 1;
    grid-row: 3;
    min-height: 0;
    overflow: hidden;
    border-top: 1px solid var(--admin-border);
  }

  .admin-app {
    --admin-chrome-h: 4.5rem;
  }
}

@media (max-width: 1100px) {
  .admin-app {
    --admin-chrome-h: 7rem;
  }

  .admin-shell__inner {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
  }

  .admin-shell__brand {
    grid-column: 1;
    grid-row: 1;
  }

  .admin-shell__right {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
  }

  .admin-shell__actions {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-content: flex-start;
  }

  .admin-shell__data-tools.builder-toolbar-inline {
    justify-content: flex-start;
  }
}

.builder-panel {
  background: var(--admin-elevated);
  border-right: 1px solid var(--admin-border);
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
}

.builder-panel--left {
  border-right: 1px solid var(--admin-border);
  overflow: hidden;
}

/* Colonna sinistra compatta: tutto in “primo schermo”, scroll solo lista campi */
.builder-sidebar-compact {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: calc(100vh - var(--admin-chrome-h));
  padding: 0.7rem 0.55rem 0.85rem;
  box-sizing: border-box;
  overflow: hidden;
}

/* Interface updates (admin): remote manifest over HTTPS */
.builder-interface-updates {
  flex: 0 0 auto;
  margin-bottom: 0.65rem;
  padding: 0.55rem 0.45rem 0.6rem;
  border-radius: 6px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.12));
  background: rgba(0, 0, 0, 0.2);
}

.builder-interface-updates__title {
  margin: 0 0 0.35rem;
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--admin-muted, rgba(255, 255, 255, 0.72));
}

.builder-interface-updates__hint {
  margin: 0 0 0.5rem;
  font-size: 0.62rem;
  line-height: 1.45;
  color: var(--admin-muted-2, rgba(255, 255, 255, 0.55));
}

.builder-interface-updates__hint strong {
  color: rgba(255, 255, 255, 0.78);
}

.builder-interface-updates__label {
  display: block;
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.25rem;
  color: var(--admin-muted, rgba(255, 255, 255, 0.65));
}

.builder-interface-updates__input {
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 0.45rem;
  padding: 0.4rem 0.45rem;
  font-size: 0.65rem;
  border-radius: 4px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.14));
  background: rgba(0, 0, 0, 0.35);
  color: inherit;
}

.builder-interface-updates__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.35rem;
}

.builder-interface-updates__actions .builder-btn {
  width: auto;
  flex: 1 1 auto;
  min-width: 0;
}

.builder-interface-updates__status {
  margin: 0;
  font-size: 0.6rem;
  line-height: 1.4;
  min-height: 1.2em;
  color: var(--admin-muted-2, rgba(255, 255, 255, 0.55));
}

.builder-interface-updates__status[data-state="ok"] {
  color: rgba(160, 220, 180, 0.92);
}

.builder-interface-updates__status[data-state="warn"] {
  color: rgba(255, 200, 140, 0.95);
}

.admin-app.admin-app--light .builder-interface-updates {
  background: rgba(255, 255, 255, 0.65);
  border-color: rgba(0, 0, 0, 0.1);
}

.admin-app.admin-app--light .builder-interface-updates__hint,
.admin-app.admin-app--light .builder-interface-updates__status {
  color: rgba(0, 0, 0, 0.55);
}

.admin-app.admin-app--light .builder-interface-updates__status[data-state="ok"] {
  color: rgba(30, 120, 70, 0.95);
}

.admin-app.admin-app--light .builder-interface-updates__status[data-state="warn"] {
  color: rgba(160, 80, 20, 0.95);
}

.admin-app.admin-app--light .builder-interface-updates__input {
  background: #fff;
  border-color: rgba(0, 0, 0, 0.12);
  color: #1a1a1a;
}

.builder-interface-updates__auto {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  margin: 0 0 0.55rem;
  font-size: 0.64rem;
  line-height: 1.4;
  color: var(--admin-muted-2, rgba(255, 255, 255, 0.55));
  cursor: pointer;
}

.builder-interface-updates__auto input {
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.builder-interface-updates__hint--server {
  margin-top: -0.2rem;
  padding: 0.4rem 0.35rem;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.18);
}

.admin-app.admin-app--light .builder-interface-updates__hint--server {
  background: rgba(0, 0, 0, 0.04);
}

.builder-interface-updates--inspector {
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  max-width: none;
}

.builder-interface-updates--inspector .builder-interface-updates__hint {
  margin-top: 0;
  font-size: 0.68rem;
}

.builder-interface-updates--inspector .builder-interface-updates__actions .builder-btn {
  flex: 1 1 100%;
}

.builder-toolbar-inline {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.55rem;
  align-items: center;
}

.builder-autosave-label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  flex: 0 1 auto;
  margin-right: 0.2rem;
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: rgba(247, 246, 243, 0.62);
  cursor: pointer;
  user-select: none;
}

.builder-autosave-label input {
  width: 0.95rem;
  height: 0.95rem;
  accent-color: rgba(214, 198, 168, 0.9);
  cursor: pointer;
}

.admin-app.admin-app--light .builder-autosave-label {
  color: rgba(30, 28, 24, 0.58);
}

/* Inline actions: base .builder-btn is width:100% / block — undo for horizontal toolbars */
.builder-toolbar-inline .builder-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  box-sizing: border-box;
}

/* Testo leggibile: niente flex-grow che comprime tutto su una riga */
.builder-toolbar-inline .builder-btn:not(.builder-btn--icon) {
  flex: 0 1 auto;
  min-width: fit-content;
  max-width: 100%;
  padding: 0.5rem 0.55rem;
  font-size: 0.625rem;
  letter-spacing: 0.1em;
}

.builder-toolbar-inline .builder-btn--icon {
  flex: 0 0 2.15rem;
  width: 2.15rem;
  min-width: 2.15rem;
  max-width: 2.15rem;
  padding: 0.5rem 0;
  font-size: 0.95rem;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none;
}

/* —— Restore backup modal —— */
.builder-restore-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
}

.builder-restore-modal[hidden] {
  display: none !important;
}

.builder-restore-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  cursor: pointer;
  border: none;
  padding: 0;
}

.builder-restore-modal__panel {
  position: relative;
  z-index: 1;
  width: min(420px, 100%);
  margin: 0;
  border-radius: 6px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.12));
  background: #121418;
  padding: 1.1rem 1.2rem 1.25rem;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

.builder-restore-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.6rem;
}

.builder-restore-modal__title {
  margin: 0;
  font-size: 1rem;
  font-family: var(--font-display);
  font-weight: 500;
  color: rgba(247, 246, 243, 0.95);
}

.builder-restore-modal__x {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(247, 246, 243, 0.85);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
}

.builder-restore-modal__panel .builder-hint {
  margin-top: 0;
  margin-bottom: 1rem;
}

.builder-restore-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.admin-app.admin-app--light .builder-restore-modal__panel {
  background: #f4f2ec;
  border-color: rgba(0, 0, 0, 0.1);
}

.admin-app.admin-app--light .builder-restore-modal__title {
  color: rgba(18, 20, 24, 0.92);
}

.admin-app.admin-app--light .builder-restore-modal__x {
  background: rgba(0, 0, 0, 0.06);
  color: rgba(18, 20, 24, 0.8);
}

.builder-sidebar-compact__tip {
  font-size: 0.65625rem;
  font-weight: 400;
  line-height: 1.4;
  color: rgba(138, 147, 150, 0.88);
  margin: 0 0 0.65rem;
}

.builder-sidebar-compact__tip strong {
  color: rgba(214, 198, 168, 0.78);
  font-weight: 600;
}

.builder-sidebar-compact__tip a {
  color: rgba(214, 198, 168, 0.92);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.builder-sidebar-compact__tip a:hover {
  color: #f7f6f3;
}

/* Content studio — guida collassabile (non occupa spazio quando chiusa) */
.builder-studio-guide {
  flex: 0 0 auto;
  margin: 0 0 0.55rem;
  border-radius: 6px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.12));
  background: rgba(0, 0, 0, 0.22);
  overflow: hidden;
}

.builder-studio-guide__summary {
  list-style: none;
  cursor: pointer;
  padding: 0.45rem 0.5rem 0.48rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.88);
  user-select: none;
}

.builder-studio-guide__summary::-webkit-details-marker {
  display: none;
}

.builder-studio-guide__summary::after {
  content: "▸";
  float: right;
  font-size: 0.65rem;
  opacity: 0.75;
  transition: transform 0.2s ease;
}

.builder-studio-guide[open] > .builder-studio-guide__summary::after {
  transform: rotate(90deg);
}

/* Content studio — tema + Inbox sotto la guida, a colonna */
.builder-sidebar-quick {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.45rem;
  flex: 0 0 auto;
  margin: 0 0 0.55rem;
}

.builder-sidebar-quick .admin-shell__theme {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
}

.builder-sidebar-quick .admin-shell__to-console {
  width: 100%;
  box-sizing: border-box;
  justify-content: center;
  text-align: center;
  white-space: normal;
  line-height: 1.3;
}

.builder-sidebar-quick .admin-shell__to-console--secondary {
  margin-top: 0.35rem;
  font-size: 0.58rem;
  letter-spacing: 0.08em;
}

.builder-studio-guide__body {
  padding: 0 0.55rem 0.55rem;
  border-top: 1px solid rgba(138, 147, 150, 0.12);
  max-height: min(42vh, 320px);
  overflow-y: auto;
  scrollbar-width: thin;
}

.builder-studio-guide__section {
  margin: 0.55rem 0 0;
  padding: 0;
}

.builder-studio-guide__section:first-child {
  margin-top: 0.45rem;
}

.builder-studio-guide__title {
  margin: 0 0 0.25rem;
  font-size: 0.65625rem;
  font-weight: 600;
  color: rgba(214, 198, 168, 0.82);
}

.builder-studio-guide__text {
  margin: 0;
  font-size: 0.65625rem;
  line-height: 1.48;
  color: rgba(138, 147, 150, 0.92);
}

.builder-studio-guide__text + .builder-studio-guide__text {
  margin-top: 0.35rem;
}

.builder-studio-guide__text strong {
  color: rgba(214, 198, 168, 0.78);
  font-weight: 600;
}

.builder-studio-guide__text a {
  color: rgba(214, 198, 168, 0.92);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.builder-studio-guide__text a:hover {
  color: #f7f6f3;
}

.admin-app.admin-app--light .builder-studio-guide {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-studio-guide__summary {
  color: rgba(70, 60, 40, 0.95);
}

.admin-app.admin-app--light .builder-studio-guide__body {
  border-top-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-studio-guide__title {
  color: rgba(50, 45, 38, 0.9);
}

.admin-app.admin-app--light .builder-studio-guide__text {
  color: rgba(70, 76, 78, 0.92);
}

.admin-app.admin-app--light .builder-studio-guide__text strong {
  color: rgba(50, 45, 38, 0.88);
}

.admin-app.admin-app--light .builder-studio-guide__text a {
  color: rgba(90, 77, 54, 0.95);
}

.builder-panel--right {
  border-right: none;
  border-left: 1px solid var(--admin-border);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.builder-panel__scroll {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 1.25rem 1rem 2rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.2) transparent;
}

.builder-panel__scroll::-webkit-scrollbar {
  width: 6px;
}

.builder-panel__scroll::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.2);
  border-radius: 3px;
}

.builder-card {
  padding: 1.125rem 1rem;
  margin-bottom: 0.75rem;
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.025) 0%, transparent 48%);
}

.builder-card--flush {
  padding-bottom: 0.5rem;
}

.builder-card__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}

.builder-card__dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-gold);
  opacity: 0.85;
  box-shadow: 0 0 12px rgba(214, 198, 168, 0.25);
}

.builder-card__dot--muted {
  background: rgba(138, 147, 150, 0.55);
  box-shadow: none;
}

.builder-card__title {
  margin: 0;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.88);
}

.builder-card__desc,
.builder-card__hint {
  margin: 0 0 1rem;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.55;
  color: var(--admin-muted);
}

.builder-card__hint {
  margin-bottom: 0.65rem;
}

.builder-code {
  font-size: 0.68rem;
  padding: 0.1rem 0.35rem;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--admin-border);
  color: rgba(214, 198, 168, 0.85);
}

/* ----- Admin console page (inbox & operations, full width) ----- */
.admin-app.luxy-admin-console {
  background: linear-gradient(165deg, #0a0a0a 0%, #101010 40%, #0c0c0c 100%);
}

.admin-app.admin-app--light.luxy-admin-console {
  background: linear-gradient(180deg, #e5e1d8 0%, #ece8df 50%, #e3dfd4 100%);
}

.luxy-console-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 260px);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: start;
  width: 100%;
  max-width: min(100%, 1280px);
  min-width: 0;
  overflow-x: clip;
  box-sizing: border-box;
  margin: 0 auto;
  padding: clamp(1rem, 3vw, 2rem) clamp(1rem, 4vw, 2.5rem) 3rem;
  min-height: calc(100vh - var(--admin-chrome-h) - var(--admin-statusbar-h) - 1rem);
}

.luxy-console-primary {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.luxy-console-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  padding-bottom: 0.15rem;
  border-bottom: 1px solid var(--admin-border);
}

.luxy-console-subnav__btn {
  padding: 0.45rem 0.75rem;
  border-radius: 4px;
  border: 1px solid rgba(214, 198, 168, 0.2);
  background: rgba(0, 0, 0, 0.2);
  color: rgba(247, 246, 243, 0.65);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    color 0.25s ease,
    border-color 0.25s ease,
    background 0.25s ease;
}

.luxy-console-subnav__btn:hover {
  color: rgba(247, 246, 243, 0.92);
  border-color: rgba(214, 198, 168, 0.35);
}

.luxy-console-subnav__btn.is-active {
  color: rgba(247, 246, 243, 0.96);
  border-color: rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.1);
}

.admin-app.admin-app--light .luxy-console-subnav__btn {
  color: rgba(27, 25, 23, 0.55);
  border-color: rgba(27, 25, 23, 0.12);
  background: rgba(255, 255, 255, 0.5);
}

.admin-app.admin-app--light .luxy-console-subnav__btn.is-active {
  color: rgba(27, 25, 23, 0.92);
  border-color: rgba(90, 77, 54, 0.35);
  background: rgba(255, 255, 255, 0.85);
}

.admin-app.admin-app--light .luxy-console-subnav__btn:hover {
  color: rgba(27, 25, 23, 0.85);
  border-color: rgba(90, 77, 54, 0.22);
}

.luxy-console-panel[hidden] {
  display: none !important;
}

.luxy-console-operations-root .builder-operations__body {
  max-height: none;
  min-height: min(70vh, 36rem);
}

.luxy-form-email-guide p {
  margin: 0 0 0.65rem;
}

.luxy-form-email-guide p:last-child {
  margin-bottom: 0;
}

.luxy-form-email-zone {
  margin: 0 0 1rem;
  padding: 0.75rem 0.85rem 0.65rem;
  border-radius: 6px;
  border: 1px solid var(--admin-border);
  background: rgba(0, 0, 0, 0.12);
}

.luxy-form-email-zone:last-of-type {
  margin-bottom: 0;
}

.luxy-form-email-zone__head {
  margin-bottom: 0.6rem;
  padding-bottom: 0.45rem;
  border-bottom: 1px solid rgba(214, 198, 168, 0.12);
}

.luxy-form-email-zone__title {
  margin: 0 0 0.2rem;
  font-family: var(--font-display), serif;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: rgba(247, 246, 243, 0.92);
}

.luxy-form-email-zone__subtitle {
  margin: 0;
  font-size: 0.68rem;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.55);
}

.luxy-form-email-zone--shell {
  border-left: 3px solid rgba(214, 198, 168, 0.45);
}

.luxy-form-email-zone--staff {
  border-left: 3px solid rgba(120, 165, 220, 0.85);
  background: rgba(80, 120, 180, 0.08);
}

.luxy-form-email-zone--guest {
  border-left: 3px solid rgba(130, 190, 130, 0.85);
  background: rgba(90, 150, 100, 0.08);
}

.luxy-form-email-zone--closing {
  border-left: 3px solid rgba(214, 198, 168, 0.35);
}

.admin-app.admin-app--light .luxy-form-email-zone {
  background: rgba(255, 255, 255, 0.42);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .luxy-form-email-zone__head {
  border-bottom-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .luxy-form-email-zone__title {
  color: rgba(27, 25, 23, 0.9);
}

.admin-app.admin-app--light .luxy-form-email-zone__subtitle {
  color: rgba(27, 25, 23, 0.52);
}

.admin-app.admin-app--light .luxy-form-email-zone--staff {
  background: rgba(70, 110, 170, 0.06);
}

.admin-app.admin-app--light .luxy-form-email-zone--guest {
  background: rgba(60, 120, 70, 0.06);
}

.luxy-console-inbox-root {
  min-width: 0;
}

.luxy-console-inbox-host {
  display: block;
}

.luxy-console-page-head {
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--admin-border);
}

.luxy-console-page-head__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display), serif;
  font-size: clamp(1.35rem, 3.5vw, 1.85rem);
  font-weight: 400;
  letter-spacing: 0.03em;
  color: rgba(247, 246, 243, 0.96);
}

.luxy-console-page-head__lede {
  margin: 0;
  max-width: 52rem;
  line-height: 1.55;
}

.luxy-console-page-head__link {
  color: rgba(214, 198, 168, 0.95);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.luxy-console-page-head__link:hover {
  color: #f7f6f3;
}

.luxy-console-inbox__hint {
  max-width: 52rem;
}

.builder-inbox-list--console {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
  gap: 1rem;
  margin-top: 0.75rem;
}

.builder-inbox-list--console .builder-inbox-card {
  margin-bottom: 0;
  min-height: 0;
}

.luxy-console-aside {
  position: sticky;
  top: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 6px;
  border: 1px dashed var(--admin-border);
  background: rgba(255, 255, 255, 0.02);
}

.luxy-console-aside__title {
  margin: 0 0 0.5rem;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.45);
}

.luxy-console-aside__hint {
  margin: 0;
  font-size: 0.8125rem;
}

.admin-app.admin-app--light .luxy-console-page-head__title {
  color: rgba(27, 25, 23, 0.94);
}

.admin-app.admin-app--light .luxy-console-page-head__link {
  color: #5a4d36;
}

.admin-app.admin-app--light .luxy-console-aside {
  background: rgba(255, 255, 255, 0.45);
  border-color: rgba(27, 25, 23, 0.1);
}

@media (max-width: 860px) {
  .luxy-console-layout {
    grid-template-columns: 1fr;
  }

  .luxy-console-aside {
    position: static;
    order: -1;
  }
}

.builder-inbox__hint {
  margin-bottom: 0.85rem;
}

.builder-inbox__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}

.builder-inbox__filter {
  flex: 1 1 auto;
  min-width: 5.5rem;
  padding: 0.45rem 0.55rem;
  font-size: 0.68rem;
  font-family: var(--font-body);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(247, 246, 243, 0.65);
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    color 0.15s ease,
    background 0.15s ease;
}

.builder-inbox__filter:hover {
  border-color: rgba(214, 198, 168, 0.35);
  color: var(--color-gold);
}

.builder-inbox__filter.is-active {
  border-color: rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.12);
  color: rgba(247, 246, 243, 0.92);
}

.builder-inbox__export {
  margin-bottom: 0.65rem;
}

.builder-inbox-list {
  margin-top: 0.25rem;
}

.builder-inbox-card {
  border: 1px solid var(--admin-border);
  border-radius: 6px;
  padding: 0.85rem 0.9rem;
  margin-bottom: 0.65rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  background: rgba(255, 255, 255, 0.02);
}

.builder-inbox-card--new {
  border-left: 3px solid rgba(214, 198, 168, 0.95);
  background: rgba(214, 198, 168, 0.08);
}

.builder-inbox-card--handled {
  border-left: 3px solid rgba(120, 130, 140, 0.55);
  opacity: 0.92;
}

.builder-inbox-card__detail {
  display: grid;
  grid-template-columns: 6.5rem 1fr;
  gap: 0.35rem 0.65rem;
  align-items: start;
  margin-top: 0.35rem;
  font-size: 0.78rem;
}

.builder-inbox-card__detail-label {
  font-weight: 600;
  opacity: 0.75;
}

.builder-inbox-card__detail-value {
  word-break: break-word;
  white-space: pre-wrap;
}

.builder-inbox-card__details {
  margin-top: 0.45rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.builder-inbox-card__details .builder-inbox-card__detail {
  margin-top: 0;
}

.builder-inbox-card__badge {
  display: inline-block;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.2rem 0.45rem;
  border-radius: 3px;
  margin-bottom: 0.45rem;
  border: 1px solid rgba(214, 198, 168, 0.35);
  color: rgba(214, 198, 168, 0.9);
}

.builder-inbox-card__title {
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.builder-inbox-card__meta {
  opacity: 0.9;
  margin-bottom: 0.25rem;
}

.builder-inbox-card__line {
  margin-top: 0.35rem;
}

.builder-inbox-card__muted {
  margin-top: 0.25rem;
  opacity: 0.75;
  font-size: 0.78rem;
}

.builder-inbox-card__message {
  margin-top: 0.45rem;
  padding: 0.55rem 0.6rem;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.06);
  white-space: pre-wrap;
  word-break: break-word;
}

.builder-inbox-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin-top: 0.6rem;
}

.builder-inbox-card__actions .builder-btn {
  width: auto;
  display: inline-block;
  padding: 0.4rem 0.65rem;
  font-size: 0.72rem;
}

.builder-inbox-card__status {
  font-size: 0.72rem;
  opacity: 0.85;
  margin-right: 0.25rem;
}

.admin-app.admin-app--light .builder-inbox-card {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(27, 25, 23, 0.1);
}

.admin-app.admin-app--light .builder-inbox-card--new {
  border-left-color: rgba(90, 77, 54, 0.85);
  background: rgba(214, 198, 168, 0.14);
}

.admin-app.admin-app--light .builder-inbox-card--handled {
  border-left-color: rgba(27, 25, 23, 0.2);
  background: rgba(255, 255, 255, 0.45);
}

.admin-app.admin-app--light .builder-inbox-card__message {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(27, 25, 23, 0.08);
  color: rgba(27, 25, 23, 0.88);
}

.admin-app.admin-app--light .builder-inbox__filter {
  background: rgba(255, 255, 255, 0.65);
  border-color: rgba(27, 25, 23, 0.12);
  color: rgba(27, 25, 23, 0.55);
}

.admin-app.admin-app--light .builder-inbox__filter.is-active {
  background: rgba(214, 198, 168, 0.22);
  border-color: rgba(90, 77, 54, 0.25);
  color: rgba(27, 25, 23, 0.88);
}

.builder-actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.builder-actions--secondary {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--admin-border);
}

.builder-btn {
  display: block;
  width: 100%;
  padding: 0.72rem 1rem;
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  transition:
    background 0.45s var(--ease-lux),
    color 0.45s var(--ease-lux),
    border-color 0.45s var(--ease-lux),
    box-shadow 0.45s var(--ease-lux);
}

.builder-btn--gold {
  border: 1px solid rgba(214, 198, 168, 0.35);
  background: rgba(214, 198, 168, 0.12);
  color: rgba(247, 246, 243, 0.95);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.builder-btn--gold:hover {
  background: rgba(214, 198, 168, 0.2);
  border-color: rgba(214, 198, 168, 0.55);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
}

.builder-btn--line {
  border: 1px solid var(--admin-border);
  background: transparent;
  color: rgba(247, 246, 243, 0.65);
}

.builder-btn--line:hover {
  border-color: rgba(214, 198, 168, 0.3);
  color: var(--color-gold);
}

.builder-btn--ghost {
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.03);
  color: rgba(247, 246, 243, 0.45);
  font-weight: 500;
  letter-spacing: 0.16em;
}

.builder-btn--ghost:hover {
  color: rgba(247, 246, 243, 0.75);
  background: rgba(255, 255, 255, 0.05);
}

.builder-field--typography {
  padding-top: 0.35rem;
}

/* Home experiences row icon: two stacked rows (preview + meta, then full-width actions — like Row image). */
.builder-exp-icon-field {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.35rem;
  padding: 0.5rem 0.55rem;
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.03);
}

.builder-exp-icon-field__top {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.65rem;
  min-width: 0;
}

.builder-exp-icon-field__preview {
  width: 2.75rem;
  height: 2.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.25);
  color: rgba(247, 246, 243, 0.42);
}

.builder-exp-icon-field__preview--empty {
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1;
}

.builder-exp-icon-field__preview svg {
  width: 70%;
  height: 70%;
  display: block;
}

.builder-exp-icon-field__meta {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
  flex: 1;
  min-width: 0;
}

.builder-exp-icon-field__name {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.82);
  line-height: 1.3;
}

.builder-exp-icon-field__id {
  font-size: 0.625rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  color: rgba(247, 246, 243, 0.38);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.builder-exp-icon-field__actions {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  width: 100%;
  align-items: stretch;
}

.builder-exp-icon-field__actions .builder-btn {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.builder-exp-icon-modal__body {
  margin-top: 0.5rem;
  max-height: min(58vh, 520px);
  overflow-y: auto;
  padding-right: 0.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.builder-exp-icon-modal__cat {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.36);
  margin: 0.15rem 0 0;
}

.builder-exp-icon-modal__row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
  gap: 0.45rem;
}

.builder-exp-icon-modal__row--none {
  grid-template-columns: minmax(76px, 104px);
}

.builder-exp-icon-modal__tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.22rem;
  padding: 0.4rem 0.28rem 0.32rem;
  border: 1px solid var(--admin-border);
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.03);
  color: rgba(247, 246, 243, 0.55);
  cursor: pointer;
  font: inherit;
  transition:
    border-color 0.2s ease,
    background 0.2s ease,
    color 0.2s ease;
}

.builder-exp-icon-modal__tile:hover {
  border-color: rgba(214, 198, 168, 0.38);
  color: rgba(247, 246, 243, 0.9);
}

.builder-exp-icon-modal__tile--current {
  border-color: rgba(214, 198, 168, 0.52);
  background: rgba(214, 198, 168, 0.1);
  color: rgba(247, 246, 243, 0.95);
}

.builder-exp-icon-modal__glyph {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1;
  color: rgba(247, 246, 243, 0.48);
}

.builder-exp-icon-modal__glyph svg {
  width: 100%;
  height: 100%;
  display: block;
}

.builder-exp-icon-modal__name {
  font-size: 0.5rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.2;
  color: inherit;
}

.admin-app.admin-app--light .builder-exp-icon-field {
  border-color: rgba(0, 0, 0, 0.1);
  background: rgba(255, 255, 255, 0.72);
}

.admin-app.admin-app--light .builder-exp-icon-field__preview {
  border-color: rgba(0, 0, 0, 0.08);
  background: rgba(0, 0, 0, 0.04);
  color: rgba(60, 58, 55, 0.45);
}

.admin-app.admin-app--light .builder-exp-icon-field__name {
  color: rgba(27, 25, 23, 0.88);
}

.admin-app.admin-app--light .builder-exp-icon-field__id {
  color: rgba(60, 58, 55, 0.45);
}

.admin-app.admin-app--light .builder-exp-icon-modal__cat {
  color: rgba(60, 58, 55, 0.42);
}

.admin-app.admin-app--light .builder-exp-icon-modal__tile {
  border-color: rgba(0, 0, 0, 0.1);
  background: rgba(255, 255, 255, 0.75);
  color: rgba(60, 58, 55, 0.68);
}

.admin-app.admin-app--light .builder-exp-icon-modal__tile:hover {
  border-color: rgba(0, 0, 0, 0.16);
  color: rgba(27, 25, 23, 0.92);
}

.admin-app.admin-app--light .builder-exp-icon-modal__tile--current {
  border-color: rgba(90, 77, 54, 0.35);
  background: rgba(255, 252, 246, 0.98);
}

.admin-app.admin-app--light .builder-exp-icon-modal__glyph {
  color: rgba(60, 58, 55, 0.48);
}

.builder-typo-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin: 0.5rem 0 0.65rem;
}

.builder-typo-icon {
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 700;
  font-style: normal;
  text-decoration: none;
  line-height: 1;
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(247, 246, 243, 0.75);
  cursor: pointer;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease;
}

.builder-typo-icon:hover {
  border-color: rgba(214, 198, 168, 0.35);
  color: var(--color-gold);
}

.builder-typo-icon.is-active {
  background: rgba(214, 198, 168, 0.18);
  border-color: rgba(214, 198, 168, 0.45);
  color: rgba(247, 246, 243, 0.95);
}

.builder-typo-icon[aria-pressed="true"] {
  box-shadow: inset 0 0 0 1px rgba(214, 198, 168, 0.25);
}

.builder-typo-row {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-top: 0.45rem;
}

.builder-select--typo {
  width: 100%;
  max-width: 100%;
}

.builder-input--typo-adv {
  width: 100%;
  max-width: 100%;
  padding: 0.45rem 0.5rem;
  font-size: 0.8125rem;
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.25);
  color: rgba(247, 246, 243, 0.9);
}

.admin-app.admin-app--light .builder-typo-icon {
  background: rgba(0, 0, 0, 0.04);
  color: rgba(30, 28, 24, 0.8);
  border-color: rgba(0, 0, 0, 0.12);
}

.admin-app.admin-app--light .builder-typo-icon:hover {
  color: rgba(30, 28, 24, 0.95);
}

.admin-app.admin-app--light .builder-typo-icon.is-active {
  background: rgba(214, 198, 168, 0.25);
}

.admin-app.admin-app--light .builder-input--typo-adv {
  background: #fff;
  color: rgba(30, 28, 24, 0.9);
  border-color: rgba(0, 0, 0, 0.12);
}

/* Tipografia studio (inspector) */
.builder-typo-studio {
  margin-top: 0.25rem;
}

.builder-typo-studio__root {
  margin: 0;
}

.builder-typo-studio__summary {
  cursor: pointer;
  list-style: none;
  user-select: none;
  position: relative;
  padding-right: 1.35rem;
}

.builder-typo-studio__summary::-webkit-details-marker {
  display: none;
}

.builder-typo-studio__summary::marker {
  content: "";
}

.builder-typo-studio__summary::after {
  content: "";
  position: absolute;
  right: 0.1rem;
  top: 0.32rem;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 1.5px solid rgba(214, 198, 168, 0.65);
  border-bottom: 1.5px solid rgba(214, 198, 168, 0.65);
  transform: rotate(45deg);
  transition: transform 0.2s ease, top 0.2s ease;
}

.builder-typo-studio__root[open] .builder-typo-studio__summary::after {
  transform: rotate(-135deg);
  top: 0.5rem;
}

.builder-typo-studio__head {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  margin-bottom: 0.5rem;
}

.builder-typo-studio__root:not([open]) .builder-typo-studio__summary {
  margin-bottom: 0;
}

.builder-typo-studio__title {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.88);
}

.builder-typo-studio__path {
  font-size: 0.7rem;
  font-family: ui-monospace, monospace;
  color: rgba(247, 246, 243, 0.45);
  word-break: break-all;
}

.builder-typo-studio__card {
  padding: 0.65rem 0.7rem 0.75rem;
  border-radius: 8px;
  border: 1px solid rgba(138, 147, 150, 0.28);
  background: rgba(38, 40, 44, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 6px 24px rgba(0, 0, 0, 0.35);
}

.builder-typo-seg {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
  margin: 0.35rem 0 0.6rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid rgba(138, 147, 150, 0.12);
}

.builder-typo-seg__label {
  flex: 0 0 auto;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.65);
}

.builder-typo-seg__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.builder-typo-studio__card .builder-typo-seg--style {
  margin-top: 0;
}

.builder-typo-studio__card .builder-typo-tbtn {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04);
}

.builder-typo-color-row {
  margin: 0.5rem 0 0.35rem;
}

.builder-typo-color-row__inner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.builder-typo-color-input {
  width: 2.75rem;
  height: 2.25rem;
  padding: 0;
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  cursor: pointer;
  background: transparent;
}

.builder-typo-color-reset {
  font-size: 0.7rem;
  padding: 0.35rem 0.6rem;
  border-radius: 4px;
  border: 1px solid var(--admin-border);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(247, 246, 243, 0.75);
  cursor: pointer;
}

.builder-typo-color-reset:hover {
  border-color: rgba(214, 198, 168, 0.4);
  color: var(--color-gold);
}

.builder-typo-size-block {
  margin-top: 0.5rem;
  padding-top: 0.45rem;
  border-top: 1px solid rgba(138, 147, 150, 0.1);
}

.builder-typo-slider-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-top: 0.4rem;
}

/* Traccia visibile: evita “pallini” su fondo nero (range senza track). */
.builder-typo-range-track {
  flex: 1;
  min-width: 0;
  padding: 0.45rem 0.35rem;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(138, 147, 150, 0.28);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.45);
}

.builder-typo-range {
  display: block;
  width: 100%;
  height: 1.35rem;
  margin: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

.builder-typo-range:focus {
  outline: none;
}

.builder-typo-range:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.55);
  outline-offset: 2px;
  border-radius: 4px;
}

.builder-typo-range::-webkit-slider-runnable-track {
  height: 0.5rem;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(90, 95, 102, 0.95) 0%,
    rgba(214, 198, 168, 0.45) 100%
  );
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25);
}

.builder-typo-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 1.05rem;
  height: 1.05rem;
  margin-top: -0.3rem;
  border-radius: 50%;
  background: linear-gradient(145deg, #faf9f7 0%, #e8dfd2 100%);
  border: 2px solid rgba(214, 198, 168, 0.95);
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(0, 0, 0, 0.12);
}

.builder-typo-range::-moz-range-track {
  height: 0.5rem;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(90, 95, 102, 0.95) 0%,
    rgba(214, 198, 168, 0.45) 100%
  );
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25);
}

.builder-typo-range::-moz-range-thumb {
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  border: 2px solid rgba(214, 198, 168, 0.95);
  background: linear-gradient(145deg, #faf9f7 0%, #e8dfd2 100%);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.builder-typo-range::-moz-range-progress {
  height: 0.5rem;
  border-radius: 999px 0 0 999px;
  background: rgba(214, 198, 168, 0.35);
}

.builder-typo-slider-row__val {
  flex: 0 0 auto;
  min-width: 4.25rem;
  font-size: 0.75rem;
  font-family: ui-monospace, monospace;
  color: rgba(247, 246, 243, 0.65);
  text-align: right;
}

.builder-typo-slider-hint {
  margin: 0.25rem 0 0;
  font-size: 0.65rem;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.38);
}

.admin-app.admin-app--light .builder-typo-studio__summary::after {
  border-right-color: rgba(90, 77, 54, 0.42);
  border-bottom-color: rgba(90, 77, 54, 0.42);
}

.admin-app.admin-app--light .builder-typo-studio__path {
  color: rgba(30, 28, 24, 0.45);
}

.admin-app.admin-app--light .builder-typo-studio__card {
  background: #f3f1ed;
  border-color: rgba(0, 0, 0, 0.1);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
}

.admin-app.admin-app--light .builder-typo-range-track {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.06);
}

.admin-app.admin-app--light .builder-typo-range::-webkit-slider-runnable-track {
  background: linear-gradient(90deg, rgba(200, 195, 186, 0.9) 0%, rgba(214, 198, 168, 0.55) 100%);
  border-color: rgba(0, 0, 0, 0.12);
}

.admin-app.admin-app--light .builder-typo-range::-moz-range-track {
  background: linear-gradient(90deg, rgba(200, 195, 186, 0.9) 0%, rgba(214, 198, 168, 0.55) 100%);
  border-color: rgba(0, 0, 0, 0.12);
}

.admin-app.admin-app--light .builder-typo-color-reset {
  background: #fff;
  color: rgba(30, 28, 24, 0.8);
  border-color: rgba(0, 0, 0, 0.12);
}

.admin-app.admin-app--light .builder-typo-slider-row__val {
  color: rgba(30, 28, 24, 0.55);
}

.admin-app.admin-app--light .builder-typo-slider-hint {
  color: rgba(30, 28, 24, 0.45);
}

.builder-tree {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.builder-nav {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  flex: 1;
  min-height: 0;
}

.builder-nav__label {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.82);
}

.builder-select--block {
  width: 100%;
  min-width: 0;
}

.builder-filter {
  width: 100%;
  box-sizing: border-box;
  padding: 0.45rem 0.55rem;
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: rgba(247, 246, 243, 0.92);
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--admin-border);
  border-radius: 2px;
}

.builder-filter:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.35);
}

.builder-filter::placeholder {
  color: rgba(138, 147, 150, 0.5);
}

.builder-field-list {
  flex: 1;
  min-height: 8rem;
  max-height: min(36vh, 260px);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0.3rem;
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.22);
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.18) transparent;
}

.builder-field-list:focus-within {
  border-color: rgba(214, 198, 168, 0.15);
}

.builder-field-list__entry {
  margin-bottom: 2px;
}

.builder-field-list__row {
  display: flex;
  align-items: stretch;
  gap: 0.28rem;
}

.builder-field-list__row .builder-field-btn {
  flex: 1;
  min-width: 0;
  margin-bottom: 0;
}

.builder-field-help-trigger {
  flex: 0 0 1.35rem;
  width: 1.35rem;
  min-width: 1.35rem;
  align-self: stretch;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(214, 198, 168, 0.22);
  border-radius: 2px;
  background: rgba(214, 198, 168, 0.06);
  color: rgba(214, 198, 168, 0.9);
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 600;
  font-style: italic;
  line-height: 1;
  cursor: help;
  transition:
    background 0.25s var(--ease-lux),
    border-color 0.25s var(--ease-lux),
    color 0.25s var(--ease-lux);
}

.builder-field-help-trigger:hover,
.builder-field-help-trigger:focus-visible {
  background: rgba(214, 198, 168, 0.14);
  border-color: rgba(214, 198, 168, 0.4);
  color: rgba(247, 246, 243, 0.95);
  outline: none;
}

.builder-field-help-drawer {
  margin: 0 0 0.35rem 0;
  padding: 0.5rem 0.55rem 0.55rem;
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(214, 198, 168, 0.1);
}

.builder-inspector-field-help {
  font-size: 0.75rem;
  line-height: 1.55;
  color: rgba(138, 147, 150, 0.92);
  margin: 0 0 0.65rem;
  padding: 0.55rem 0.65rem;
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.32);
  border: 1px solid rgba(214, 198, 168, 0.12);
}

.builder-inspector-field-help .builder-code {
  font-size: 0.7rem;
}

.builder-field-btn {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  border-left: 2px solid transparent;
  color: rgba(247, 246, 243, 0.58);
  padding: 0.48rem 0.45rem 0.48rem 0.55rem;
  margin-bottom: 2px;
  font-family: var(--font-body);
  font-size: 0.78125rem;
  font-weight: 400;
  line-height: 1.32;
  cursor: pointer;
  border-radius: 0 2px 2px 0;
  transition:
    background 0.35s var(--ease-lux),
    color 0.35s var(--ease-lux),
    border-color 0.35s var(--ease-lux);
}

.builder-field-btn:hover {
  background: rgba(214, 198, 168, 0.07);
  color: rgba(247, 246, 243, 0.9);
}

.builder-field-btn.is-active {
  background: rgba(214, 198, 168, 0.11);
  border-left-color: var(--color-gold);
  color: rgba(247, 246, 243, 0.98);
}

.builder-checkbox {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.45rem;
  padding: 0.35rem 0.5rem;
  font-size: 0.78rem;
  color: rgba(247, 246, 243, 0.58);
  border-radius: 2px;
  transition: background 0.3s;
}

.builder-checkbox:hover {
  background: rgba(255, 255, 255, 0.03);
}

.builder-checkbox input {
  accent-color: var(--color-gold);
  width: 0.9rem;
  height: 0.9rem;
}

.builder-hint {
  font-size: 0.75rem;
  color: rgba(138, 147, 150, 0.85);
  line-height: 1.55;
  margin: 0.75rem 0;
}

.builder-inspector-group {
  border: 1px solid var(--admin-border);
  border-radius: 4px;
  padding: 1rem 1.1rem 1.15rem;
  margin-bottom: 0.5rem;
  background: rgba(0, 0, 0, 0.22);
  min-width: 0;
}

.builder-inspector-group__title {
  margin: 0 0 0.85rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(214, 198, 168, 0.12);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.75);
}

.builder-inspector-group__subtitle {
  margin: 0 0 0.65rem;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.58);
}

.builder-operations {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-height: 0;
}

.builder-operations__intro {
  margin: 0;
}

.builder-operations__tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid rgba(214, 198, 168, 0.14);
}

.builder-operations__tab {
  padding: 0.4rem 0.55rem;
  border: 1px solid rgba(214, 198, 168, 0.2);
  border-radius: 3px;
  background: rgba(0, 0, 0, 0.2);
  color: rgba(247, 246, 243, 0.72);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  line-height: 1.2;
}

.builder-operations__tab:hover {
  border-color: rgba(214, 198, 168, 0.35);
  color: rgba(247, 246, 243, 0.9);
}

.builder-operations__tab.is-active {
  border-color: rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.12);
  color: rgba(247, 246, 243, 0.95);
}

.builder-operations__body {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  max-height: min(70vh, 42rem);
  padding-right: 0.15rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.22) transparent;
}

.builder-operations__body::-webkit-scrollbar {
  width: 7px;
}

.builder-operations__body::-webkit-scrollbar-track {
  background: transparent;
}

.builder-operations__body::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.24);
  border-radius: 4px;
}

.builder-operations__body::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.4);
}

.builder-operations__body .builder-inspector-group:last-child {
  margin-bottom: 0;
}

.builder-operations__sub {
  margin-top: 0.5rem;
}

.builder-operations__seo-meta {
  margin-top: 0.35rem;
}

.builder-inspector-group .builder-field:last-child {
  margin-bottom: 0;
}

.builder-dim-row {
  display: grid;
  grid-template-columns: minmax(5.5rem, auto) minmax(6.5rem, 1fr) minmax(4.25rem, auto);
  align-items: center;
  gap: 0.5rem 0.65rem;
  margin-bottom: 0.55rem;
  min-width: 0;
}

.builder-dim-row__label {
  font-size: 0.72rem;
  color: rgba(247, 246, 243, 0.55);
}

.builder-dim-row__input {
  width: 100%;
  min-width: 0;
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.35);
  color: rgba(247, 246, 243, 0.95);
  font-family: var(--font-body);
  font-size: 0.8125rem;
}

.builder-dim-row__input:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.4);
}

/* Logo inspector: narrow column — stack label above value+unit so nothing overlaps */
.builder-field--logo-dimensions .builder-dim-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(4.75rem, auto);
  grid-template-rows: auto auto;
  gap: 0.35rem 0.55rem;
  align-items: center;
  margin-bottom: 0.75rem;
  min-width: 0;
}

.builder-field--logo-dimensions .builder-dim-row__label {
  grid-column: 1 / -1;
  grid-row: 1;
}

.builder-field--logo-dimensions .builder-dim-row__input {
  grid-column: 1;
  grid-row: 2;
}

.builder-field--logo-dimensions .builder-dim-row .builder-select.builder-select--dim {
  grid-column: 2;
  grid-row: 2;
  width: auto;
  min-width: 4.75rem;
  max-width: 100%;
}

.builder-select--dim {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding: 0.45rem 0.4rem;
  font-size: 0.72rem;
}

.builder-logo-dim-block {
  margin-top: 0.35rem;
}

.builder-logo-dimensions__title {
  margin: 0 0 0.35rem;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.75);
}

.builder-field--logo-dimensions {
  min-width: 0;
}

.builder-field--logo-dimensions .builder-hint {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.builder-logo-height-modes {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.4rem;
  margin: 0.5rem 0 0.3rem;
  padding: 0.45rem 0.55rem 0.5rem;
  border: 1px solid var(--admin-border);
  border-radius: 5px;
  background: rgba(0, 0, 0, 0.28);
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
}

.builder-logo-height-modes__legend {
  font-size: 0.68rem;
  font-weight: 600;
  color: rgba(247, 246, 243, 0.72);
  line-height: 1.4;
  white-space: normal;
  margin: 0;
}

.builder-logo-height-modes__radios {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  width: 100%;
  min-width: 0;
}

/* Grid: radio in narrow col, label gets all remaining width (flex was shrinking label to ~0) */
.builder-logo-mode-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: 0.55rem;
  row-gap: 0;
  align-items: start;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding: 0.35rem 0.5rem;
  box-sizing: border-box;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.22);
}

.builder-field--logo-dimensions .builder-logo-height-modes__radios {
  width: 100%;
  max-width: 100%;
}

.builder-logo-mode-option > input[type="radio"] {
  accent-color: var(--color-gold);
  width: 1rem;
  height: 1rem;
  margin: 0.12rem 0 0;
  flex-shrink: 0;
  grid-column: 1;
  grid-row: 1;
  align-self: start;
}

.builder-logo-mode-option > label.builder-logo-radio-label {
  display: block;
  grid-column: 2;
  grid-row: 1;
  font-size: 0.8125rem !important;
  color: rgba(247, 246, 243, 0.88);
  cursor: pointer;
  margin: 0 !important;
  font-weight: 400 !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  line-height: 1.45;
  min-width: 0;
  max-width: 100%;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: normal;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

.builder-field--logo-dimensions label.builder-logo-radio-label {
  letter-spacing: normal !important;
  text-transform: none !important;
  margin-bottom: 0 !important;
}

.builder-field--logo-file {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.builder-logo-file-input {
  width: auto;
  max-width: 100%;
  padding: 0.55rem 0.65rem;
  font-size: 0.78rem;
  cursor: pointer;
}

.builder-logo-preview {
  display: block;
  max-width: 100%;
  max-height: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
  margin-top: 0.35rem;
  padding: 0.85rem;
  background: #1a1a1a;
  border: 1px solid var(--admin-border);
  border-radius: 2px;
}

.builder-logo-preview.is-empty {
  opacity: 0;
  visibility: hidden;
  margin: 0;
  padding: 0;
  min-height: 0;
  border: none;
  background: transparent;
}

/* Canvas (preview) */
.builder-canvas {
  background: #060606;
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
  border-left: 1px solid var(--admin-border);
  border-right: 1px solid var(--admin-border);
}

@media (max-width: 1180px) {
  .builder-canvas {
    border-left: none;
    border-right: none;
    border-top: 1px solid var(--admin-border);
    border-bottom: 1px solid var(--admin-border);
  }
}

.builder-canvas__chrome {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 0.35rem 1rem;
  padding: 0.55rem 1rem;
  background: rgba(8, 8, 8, 0.95);
  border-bottom: 1px solid var(--admin-border);
}

.builder-canvas__hint {
  grid-column: 1 / -1;
  grid-row: 2;
  margin: 0;
  font-size: 0.6875rem;
  line-height: 1.35;
  color: rgba(138, 147, 150, 0.82);
  font-weight: 400;
}

.builder-canvas__label {
  grid-column: 1;
  grid-row: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.7);
}

.builder-canvas__pulse {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #8fbc8f;
  box-shadow: 0 0 0 3px rgba(143, 188, 143, 0.2);
  animation: adminPulse 2.4s var(--ease-lux) infinite;
}

@keyframes adminPulse {
  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.65;
    transform: scale(0.92);
  }
}

@media (prefers-reduced-motion: reduce) {
  .builder-canvas__pulse {
    animation: none;
  }
}

.builder-canvas__controls {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.builder-select-wrap {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.builder-select-wrap__label {
  font-size: 0.5625rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.75);
}

.builder-select {
  appearance: none;
  min-width: 10.5rem;
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  color: rgba(247, 246, 243, 0.9);
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23d6c6a8' fill-opacity='0.55' d='M1.4 0 6 4.6 10.6 0 12 1.4l-6 6-6-6z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
  transition: border-color 0.35s var(--ease-lux);
}

.builder-select:hover,
.builder-select:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.35);
}

/* Logo dimension row: base .builder-select sets min-width: 10.5rem — must not spill over the value input */
.builder-dim-row .builder-select.builder-select--dim {
  min-width: 0;
  width: 100%;
  max-width: 100%;
}

.builder-canvas__frame {
  flex: 1;
  min-height: 0;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  background: transparent;
}

.builder-canvas__preview-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem 1.25rem;
  flex-shrink: 0;
  margin-bottom: 0.45rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--admin-border);
}

.builder-canvas__preview-zoom-note {
  margin: 0 0 0.75rem;
  padding: 0 0 0.65rem;
  font-size: 0.65625rem;
  line-height: 1.45;
  color: rgba(138, 147, 150, 0.88);
  border-bottom: 1px solid rgba(138, 147, 150, 0.12);
}

.builder-canvas__toolbar-cluster {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem 0.65rem;
}

.builder-canvas__toolbar-cluster--zoom {
  margin-left: auto;
}

@media (max-width: 1280px) {
  .builder-canvas__toolbar-cluster--zoom {
    margin-left: 0;
    width: 100%;
  }
}

.builder-canvas__device-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.builder-device-btn {
  font-family: var(--font-body, system-ui, sans-serif);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 0.35rem 0.65rem;
  color: rgba(247, 246, 243, 0.88);
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  cursor: pointer;
  transition: border-color 0.25s ease, background 0.25s ease;
}

.builder-device-btn:hover,
.builder-device-btn:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.4);
  background: rgba(214, 198, 168, 0.08);
}

.builder-device-btn.is-active {
  border-color: rgba(214, 198, 168, 0.55);
  background: rgba(214, 198, 168, 0.14);
  color: rgba(247, 246, 243, 0.98);
}

.builder-canvas__zoom-label {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.85);
}

.builder-canvas__zoom-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.builder-zoom-btn {
  font-family: var(--font-body, system-ui, sans-serif);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  padding: 0.35rem 0.65rem;
  color: rgba(247, 246, 243, 0.88);
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  cursor: pointer;
  transition: border-color 0.25s ease, background 0.25s ease;
}

.builder-zoom-btn:hover,
.builder-zoom-btn:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.4);
  background: rgba(214, 198, 168, 0.08);
}

.builder-zoom-btn.is-active {
  border-color: rgba(214, 198, 168, 0.55);
  background: rgba(214, 198, 168, 0.14);
  color: rgba(247, 246, 243, 0.98);
}

.builder-canvas__zoom-scroll {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 0.25rem 0 1.25rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.22) transparent;
}

.builder-canvas__zoom-scroll::-webkit-scrollbar {
  width: 7px;
}

.builder-canvas__zoom-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.builder-canvas__zoom-scroll::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.24);
  border-radius: 4px;
}

.builder-canvas__zoom-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.4);
}

.builder-canvas__viewport {
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  transition: max-width 0.35s var(--ease-lux, ease);
}

.builder-canvas__viewport[data-viewport="tablet"],
.builder-canvas__viewport[data-viewport="mobile"] {
  box-shadow:
    0 0 0 1px rgba(214, 198, 168, 0.22),
    0 12px 48px rgba(0, 0, 0, 0.35);
  border-radius: 3px;
}

/* Slot centrato in flex: niente translateX+scale (evita spostamenti a 50%). Zoom CSS su Chromium; fallback .scaler--transform-zoom */
.builder-canvas__zoom-slot {
  position: relative;
  width: 100%;
  flex-shrink: 0;
  min-height: min(85vh, 920px);
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
}

.builder-canvas__scaler {
  --preview-zoom: 1;
  position: relative;
  box-sizing: border-box;
  flex-shrink: 0;
  width: 100%;
  max-width: 1680px;
  margin: 0;
  transform: none;
  transform-origin: top center;
}

/* Firefox / browser senza zoom: scala con transform, larghezza compensata; centratura solo tramite flex sullo slot */
.builder-canvas__scaler--transform-zoom {
  transform: scale(var(--preview-zoom));
  width: calc(100% / var(--preview-zoom));
  max-width: calc(1680px / var(--preview-zoom));
}

.builder-canvas__iframe {
  display: block;
  width: 100%;
  min-height: min(85vh, 920px);
  border: none;
  border-radius: 2px;
  box-shadow:
    0 0 0 1px var(--admin-border),
    0 24px 80px rgba(0, 0, 0, 0.65);
  background: var(--color-bg);
}

/* Tipografia (pannello CMS) */
.builder-typo-panel {
  margin-top: 1.35rem;
  padding-top: 1.15rem;
  border-top: 1px solid var(--admin-border);
}

.builder-typo-panel__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.85);
}

.builder-typo-panel__hint {
  margin: 0 0 1rem;
  font-size: 0.75rem;
  line-height: 1.55;
  color: var(--admin-muted);
}

.builder-typo-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1rem;
  padding: 0.5rem 0;
}

.builder-typo-tbtn {
  min-width: 2.35rem;
  padding: 0.4rem 0.55rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.9375rem;
  font-weight: 600;
  font-style: normal;
  line-height: 1;
  color: rgba(247, 246, 243, 0.88);
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid var(--admin-border);
  border-radius: 3px;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.builder-typo-tbtn:hover,
.builder-typo-tbtn:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.1);
  color: rgba(247, 246, 243, 0.98);
}

.builder-typo-tbtn.is-on {
  border-color: rgba(214, 198, 168, 0.65);
  background: rgba(214, 198, 168, 0.22);
  color: #fff;
}

.builder-typo-tbtn--italic {
  font-style: italic;
}

.builder-typo-tbtn--underline {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.builder-typo-tbtn--align {
  min-width: 2.35rem;
  min-height: 2.35rem;
  padding: 0.35rem;
  font-family: var(--font-body, system-ui, sans-serif);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.builder-typo-align-icon {
  display: block;
  width: 1.2rem;
  height: 1.2rem;
  flex-shrink: 0;
  opacity: 0.88;
}

.builder-typo-tbtn--align.is-on .builder-typo-align-icon {
  opacity: 1;
}

.builder-typo-advanced {
  margin-top: 1rem;
  border: 1px solid rgba(138, 147, 150, 0.2);
  border-radius: 3px;
  padding: 0.35rem 0.65rem 0.65rem;
  background: rgba(0, 0, 0, 0.2);
}

.builder-typo-advanced summary {
  cursor: pointer;
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  color: rgba(214, 198, 168, 0.75);
  padding: 0.35rem 0;
  user-select: none;
}

.builder-typo-advanced__body {
  padding-top: 0.35rem;
}

.builder-select--typo {
  width: 100%;
}

/* Inspector (right): flex chain + min-height 0 so scroll stays inside __body (no giant empty track). */
.builder-inspector {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  max-height: 100%;
}

.builder-panel--right .builder-inspector {
  min-height: 0;
}

@media (max-width: 1180px) {
  .builder-inspector {
    min-height: 280px;
  }
}

.builder-inspector__head {
  padding: 1.25rem 1rem 1rem;
  border-bottom: 1px solid var(--admin-border);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, transparent 100%);
}

.builder-inspector__label {
  display: block;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.65);
  margin-bottom: 0.35rem;
}

.builder-inspector__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: rgba(247, 246, 243, 0.92);
}

.builder-inspector__body {
  flex: 1 1 0;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 1rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(214, 198, 168, 0.28) transparent;
}

.builder-inspector__body::-webkit-scrollbar {
  width: 7px;
}

.builder-inspector__body::-webkit-scrollbar-track {
  background: transparent;
}

.builder-inspector__body::-webkit-scrollbar-thumb {
  background: rgba(214, 198, 168, 0.26);
  border-radius: 4px;
}

.builder-inspector__body::-webkit-scrollbar-thumb:hover {
  background: rgba(214, 198, 168, 0.44);
}

.builder-inspector__empty {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--admin-muted);
}

.builder-field {
  margin-bottom: 1.15rem;
}

.builder-field > label {
  display: block;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.8);
  margin-bottom: 0.45rem;
}

/* Boolean toggles (admin inspector) */
.builder-field--toggle {
  margin-bottom: 1rem;
}

.builder-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(138, 147, 150, 0.12);
}

.builder-toggle-row__label {
  font-size: 0.78rem;
  font-weight: 500;
  line-height: 1.4;
  color: rgba(247, 246, 243, 0.9);
  flex: 1;
  min-width: 0;
}

.builder-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}

.builder-switch__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
}

.builder-switch__slider {
  display: block;
  width: 2.55rem;
  height: 1.38rem;
  border-radius: 999px;
  background: rgba(180, 60, 60, 0.55);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
  transition:
    background 0.22s ease,
    box-shadow 0.22s ease;
  position: relative;
}

.builder-switch__slider::after {
  content: "";
  position: absolute;
  width: 1.08rem;
  height: 1.08rem;
  left: 0.15rem;
  top: 0.15rem;
  border-radius: 50%;
  background: #f7f6f3;
  transition: transform 0.22s ease;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
}

.builder-switch__input:checked + .builder-switch__slider {
  background: rgba(45, 120, 72, 0.85);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.15);
}

.builder-switch__input:checked + .builder-switch__slider::after {
  transform: translateX(1.17rem);
}

.builder-switch__input:focus-visible + .builder-switch__slider {
  outline: 2px solid rgba(214, 198, 168, 0.55);
  outline-offset: 2px;
}

.admin-app.admin-app--light .builder-toggle-row {
  border-bottom-color: rgba(27, 25, 23, 0.08);
}

.admin-app.admin-app--light .builder-toggle-row__label {
  color: rgba(27, 25, 23, 0.9);
}

.admin-app.admin-app--light .builder-switch__slider {
  background: rgba(200, 80, 80, 0.45);
  box-shadow: inset 0 0 0 1px rgba(120, 40, 40, 0.2);
}

.admin-app.admin-app--light .builder-switch__input:checked + .builder-switch__slider {
  background: rgba(34, 130, 72, 0.75);
  box-shadow: inset 0 0 0 1px rgba(0, 80, 40, 0.15);
}

.admin-app.admin-app--light .builder-switch__slider::after {
  background: #fff;
}

.builder-field input,
.builder-field textarea {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid var(--admin-border);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.35);
  color: rgba(247, 246, 243, 0.95);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  line-height: 1.45;
  transition:
    border-color 0.35s var(--ease-lux),
    box-shadow 0.35s var(--ease-lux);
}

.builder-field input:focus,
.builder-field textarea:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.4);
  box-shadow: 0 0 0 3px rgba(214, 198, 168, 0.08);
}

.builder-field textarea {
  min-height: 120px;
  resize: vertical;
}

.builder-field__translate {
  margin-top: 0.4rem;
}

/* —— Builder: media picker modal & repeaters —— */
.builder-media-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483645;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.builder-media-modal[hidden]:not(.builder-media-modal--open) {
  display: none !important;
}

.builder-media-modal--open {
  display: flex !important;
}

.builder-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.builder-media-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  cursor: pointer;
}

.builder-media-modal__panel {
  position: relative;
  z-index: 2;
  width: min(720px, 100%);
  max-height: min(85vh, 720px);
  overflow: auto;
  border-radius: 6px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.12));
  background: #121418;
  padding: 1rem 1.15rem 1.25rem;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

.builder-media-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.builder-media-modal__title {
  margin: 0;
  font-size: 1rem;
  font-family: var(--font-display);
  font-weight: 500;
  color: rgba(247, 246, 243, 0.95);
}

.builder-media-modal__x {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(247, 246, 243, 0.85);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
}

.builder-media-modal__hint {
  margin-top: 0 !important;
}

.builder-media-modal__toolbar {
  margin: 0.75rem 0 1rem;
}

.builder-media-modal__toolbar.is-disabled {
  opacity: 0.55;
  pointer-events: none;
}

.builder-media-modal__upload-status {
  margin: 0 0 1rem;
  padding: 0.65rem 0.75rem;
  border-radius: 4px;
  border: 1px solid rgba(214, 198, 168, 0.2);
  background: rgba(0, 0, 0, 0.35);
}

.builder-media-modal__upload-msg {
  margin: 0 0 0.5rem;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  line-height: 1.45;
  color: rgba(214, 198, 168, 0.88);
}

.builder-media-modal__progress {
  position: relative;
  height: 5px;
  border-radius: 99px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.08);
}

.builder-media-modal__progress-fill {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    rgba(214, 198, 168, 0.55),
    rgba(214, 198, 168, 0.9),
    rgba(214, 198, 168, 0.6)
  );
  transition: width 0.2s ease-out;
}

.builder-media-modal__progress-fill.is-indeterminate {
  width: 42% !important;
  animation: luxy-media-progress-indeterminate 0.95s ease-in-out infinite;
}

@keyframes luxy-media-progress-indeterminate {
  0% {
    transform: translateX(-120%);
  }
  100% {
    transform: translateX(320%);
  }
}

.builder-media-modal__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 0.65rem;
}

.builder-media-tile {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  margin: 0;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.1));
  border-radius: 4px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.35);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.25s;
}

.builder-media-tile:hover {
  border-color: rgba(214, 198, 168, 0.45);
}

.builder-media-tile img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}

.builder-media-tile__cap {
  font-size: 0.65rem;
  padding: 0.35rem 0.45rem;
  color: rgba(247, 246, 243, 0.55);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.builder-img-field {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 0.65rem;
  align-items: start;
}

.builder-img-field:has(.builder-img-field__thumb.is-empty) {
  grid-template-columns: minmax(0, 1fr);
}

.builder-img-field__main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.builder-img-field .builder-textarea {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 4.25rem;
  box-sizing: border-box;
  resize: vertical;
  font-family: ui-monospace, system-ui, sans-serif;
  font-size: 0.72rem;
  line-height: 1.4;
}

.builder-img-field__thumb {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.1));
  background: rgba(0, 0, 0, 0.4);
}

.builder-img-field__thumb.is-empty {
  display: none;
}

.builder-img-field__thumb--sm {
  width: 56px;
  height: 56px;
}

.builder-img-field__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0;
  align-items: center;
}

.builder-repeater {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.builder-repeater-card {
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.1));
  border-radius: 4px;
  padding: 0.75rem 0.85rem;
  background: rgba(0, 0, 0, 0.2);
}

.builder-repeater-card__head {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(214, 198, 168, 0.65);
  margin-bottom: 0.6rem;
}

.builder-repeater-card__label {
  display: block;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(138, 147, 150, 0.75);
  margin: 0.45rem 0 0.3rem;
}

.builder-repeater-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.65rem;
}

.builder-repeater-card__img-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.builder-media-lib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.builder-media-lib-card {
  border: 1px solid var(--admin-border, rgba(255, 255, 255, 0.1));
  border-radius: 4px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.25);
}

.builder-media-lib-card img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}

.builder-media-lib-card__name {
  font-size: 0.68rem;
  padding: 0.35rem 0.45rem;
  color: rgba(247, 246, 243, 0.6);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.builder-media-lib-card__actions {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.35rem 0.45rem 0.55rem;
}

/* ----- Public: maintenance mode (main.js) ----- */
body.luxy-maint-body {
  margin: 0;
  min-height: 100vh;
  background: #0a0a0a;
  color: rgba(247, 246, 243, 0.92);
  font-family: var(--font-body, system-ui, sans-serif);
}

.luxy-maint {
  --luxy-maint-accent: #d6c6a8;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1.5rem, 5vw, 2.5rem);
  box-sizing: border-box;
}

.luxy-maint__panel {
  width: 100%;
  max-width: 26rem;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--luxy-maint-accent) 28%, transparent);
  border-radius: 6px;
  background: rgba(18, 18, 18, 0.94);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
  overflow: hidden;
}

.luxy-maint__accent {
  height: 4px;
  background: var(--luxy-maint-accent);
  font-size: 0;
  line-height: 0;
}

.luxy-maint__logo-wrap {
  padding: clamp(1.35rem, 3vw, 1.75rem) clamp(1.75rem, 4vw, 2.25rem) 0;
  text-align: center;
}

.luxy-maint__logo {
  max-width: 200px;
  max-height: 56px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.luxy-maint__eyebrow {
  margin: 0;
  padding: 0.85rem clamp(1.75rem, 4vw, 2.25rem) 0;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--luxy-maint-accent) 75%, rgba(247, 246, 243, 0.5));
}

.luxy-maint__title {
  margin: 0;
  padding: clamp(1rem, 2.5vw, 1.35rem) clamp(1.75rem, 4vw, 2.25rem) 0.75rem;
  font-family: var(--font-display, Georgia, serif);
  font-size: clamp(1.35rem, 3.5vw, 1.65rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.25;
  color: rgba(247, 246, 243, 0.95);
}

.luxy-maint__body {
  margin: 0;
  padding: 0 clamp(1.75rem, 4vw, 2.25rem) 1.15rem;
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.65;
  color: rgba(138, 147, 150, 0.88);
}

.luxy-maint__hint {
  margin: 0;
  padding: 0 clamp(1.75rem, 4vw, 2.25rem) 1rem;
  font-size: 0.75rem;
  line-height: 1.55;
  color: rgba(138, 147, 150, 0.65);
}

.luxy-maint__label {
  display: block;
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--luxy-maint-accent) 65%, rgba(138, 147, 150, 0.5));
  margin: 0;
  padding: 0 clamp(1.75rem, 4vw, 2.25rem) 0.45rem;
}

.luxy-maint__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: stretch;
  padding: 0 clamp(1.75rem, 4vw, 2.25rem) clamp(1.5rem, 3vw, 1.85rem);
}

.luxy-maint__input {
  flex: 1 1 10rem;
  min-width: 0;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(138, 147, 150, 0.28);
  border-radius: 2px;
  background: rgba(0, 0, 0, 0.4);
  color: rgba(247, 246, 243, 0.95);
  font-size: 0.875rem;
}

.luxy-maint__input:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.45);
}

.luxy-maint__btn {
  flex: 0 0 auto;
  padding: 0.65rem 1rem;
  border: none;
  border-radius: 2px;
  background: color-mix(in srgb, var(--luxy-maint-accent) 28%, rgba(0, 0, 0, 0.35));
  color: rgba(247, 246, 243, 0.95);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    background 0.3s ease,
    color 0.3s ease;
}

.luxy-maint__btn:hover {
  background: color-mix(in srgb, var(--luxy-maint-accent) 48%, rgba(0, 0, 0, 0.25));
  color: #fff;
}

.luxy-maint__err {
  margin: 0;
  padding: 0 clamp(1.75rem, 4vw, 2.25rem) clamp(1.25rem, 2vw, 1.5rem);
  font-size: 0.78rem;
  color: #c9a090;
}

/* ----- Public: license inactive overlay (license_status from luxy-api) ----- */
.luxy-license-overlay {
  position: fixed;
  inset: 0;
  z-index: 100001;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  box-sizing: border-box;
  background: rgba(6, 6, 8, 0.42);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.luxy-license-overlay__panel {
  width: min(26rem, 100%);
  padding: 1.35rem 1.45rem 1.45rem;
  border-radius: 6px;
  border: 1px solid rgba(214, 198, 168, 0.22);
  background: rgba(18, 16, 14, 0.97);
  box-shadow: 0 20px 56px rgba(0, 0, 0, 0.5);
}

.luxy-license-overlay__title {
  margin: 0 0 0.55rem;
  font-family: var(--font-display), serif;
  font-size: 1.2rem;
  font-weight: 500;
  color: rgba(247, 246, 243, 0.96);
}

.luxy-license-overlay__body {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.5;
  color: rgba(247, 246, 243, 0.78);
}

html.luxy-license-overlay-is-active {
  overflow: hidden;
}

/* ----- Admin: server login overlay (luxy-api.php session) ----- */
.luxy-admin-gate {
  position: fixed;
  inset: 0;
  z-index: 100010;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
}

.luxy-admin-gate[hidden] {
  display: none !important;
}

.luxy-admin-gate__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 7, 6, 0.72);
  cursor: pointer;
}

.luxy-admin-gate__panel {
  position: relative;
  z-index: 1;
  width: min(26rem, 100%);
  max-height: min(90vh, 32rem);
  overflow: auto;
  padding: 1.35rem 1.4rem 1.5rem;
  border-radius: 4px;
  border: 1px solid rgba(214, 198, 168, 0.28);
  background: rgba(22, 20, 18, 0.98);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}

.luxy-admin-gate__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display), serif;
  font-size: 1.15rem;
  font-weight: 500;
  color: #f7f6f3;
  letter-spacing: 0.02em;
}

.luxy-admin-gate__hint {
  margin: 0 0 1rem;
}

.luxy-admin-gate__label {
  display: block;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(247, 246, 243, 0.55);
  margin-bottom: 0.35rem;
}

.luxy-admin-gate__input {
  width: 100%;
  box-sizing: border-box;
  padding: 0.55rem 0.65rem;
  margin-bottom: 1rem;
  border-radius: 2px;
  border: 1px solid rgba(214, 198, 168, 0.25);
  background: rgba(12, 11, 10, 0.85);
  color: #f7f6f3;
  font: inherit;
  font-size: 0.9rem;
}

.luxy-admin-gate__input:focus {
  outline: none;
  border-color: rgba(214, 198, 168, 0.55);
}

.luxy-admin-gate__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.65rem;
}

.luxy-admin-gate__err {
  margin: 0.85rem 0 0;
  font-size: 0.82rem;
  color: #e8a598;
}

.admin-app.admin-app--light .luxy-admin-gate__panel {
  background: rgba(252, 251, 248, 0.98);
  border-color: rgba(60, 55, 48, 0.15);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.12);
}

.admin-app.admin-app--light .luxy-admin-gate__title {
  color: #1a1814;
}

.admin-app.admin-app--light .luxy-admin-gate__label {
  color: rgba(26, 24, 20, 0.55);
}

.admin-app.admin-app--light .luxy-admin-gate__input {
  background: #fff;
  border-color: rgba(60, 55, 48, 0.2);
  color: #1a1814;
}

/* ----- Public site: new UI build prompt (see data/site-build.json) ----- */
.luxy-ui-update-banner {
  position: fixed;
  z-index: 99998;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.75rem 1rem;
  padding: 0.85rem 1rem;
  background: rgba(12, 11, 10, 0.94);
  border-top: 1px solid rgba(214, 198, 168, 0.2);
  font-family: var(--font-body), system-ui, sans-serif;
  font-size: 0.875rem;
  color: rgba(247, 246, 243, 0.92);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35);
}

.luxy-ui-update-banner__text {
  margin: 0;
  max-width: 42rem;
  text-align: center;
  line-height: 1.45;
}

.luxy-ui-update-banner__btn {
  flex-shrink: 0;
  cursor: pointer;
  font: inherit;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.7rem;
  padding: 0.55rem 1.1rem;
  border-radius: 2px;
  border: 1px solid rgba(214, 198, 168, 0.45);
  background: rgba(214, 198, 168, 0.18);
  color: #f7f6f3;
}

.luxy-ui-update-banner__btn:hover {
  background: rgba(214, 198, 168, 0.28);
}

[data-theme="light"] .luxy-ui-update-banner {
  background: rgba(252, 251, 248, 0.97);
  border-top-color: rgba(60, 55, 48, 0.12);
  color: rgba(26, 24, 20, 0.92);
  box-shadow: 0 -8px 28px rgba(0, 0, 0, 0.12);
}

[data-theme="light"] .luxy-ui-update-banner__btn {
  border-color: rgba(60, 55, 48, 0.25);
  background: rgba(214, 198, 168, 0.35);
  color: #1a1814;
}

/* ----- Public site — cookie / consent strip ----- */
.luxy-cookie-banner {
  position: fixed;
  z-index: 99990;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom, 0px));
  background: rgba(10, 10, 10, 0.94);
  border-top: 1px solid rgba(214, 198, 168, 0.2);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35);
  box-sizing: border-box;
}

.luxy-cookie-banner__inner {
  position: relative;
  max-width: 56rem;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1.25rem;
  padding-right: 2.25rem;
}

.luxy-cookie-banner__x {
  position: absolute;
  top: 0.35rem;
  right: 0.25rem;
  width: 2rem;
  height: 2rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: rgba(247, 246, 243, 0.55);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.luxy-cookie-banner__x:hover {
  color: #f7f6f3;
  background: rgba(214, 198, 168, 0.12);
}

.luxy-cookie-banner__x:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.75);
  outline-offset: 2px;
}

[data-theme="light"] .luxy-cookie-banner__x {
  color: rgba(26, 24, 20, 0.45);
}

[data-theme="light"] .luxy-cookie-banner__x:hover {
  color: #1a1814;
  background: rgba(214, 198, 168, 0.2);
}

.luxy-cookie-banner__text {
  margin: 0;
  flex: 1 1 16rem;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(247, 246, 243, 0.88);
}

.luxy-cookie-banner__link {
  flex: 0 0 auto;
  font-size: 0.75rem;
  color: rgba(214, 198, 168, 0.95);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.luxy-cookie-banner__link:hover {
  color: #f7f6f3;
}

.luxy-cookie-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-left: auto;
}

.luxy-cookie-banner__btn {
  font-family: inherit;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.5rem 0.85rem;
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid rgba(214, 198, 168, 0.35);
  background: transparent;
  color: rgba(247, 246, 243, 0.9);
}

.luxy-cookie-banner__btn--primary {
  background: rgba(214, 198, 168, 0.22);
  border-color: rgba(214, 198, 168, 0.45);
  color: #f7f6f3;
}

.luxy-cookie-banner__btn--primary:hover {
  background: rgba(214, 198, 168, 0.32);
}

.luxy-cookie-banner__btn--line:hover {
  border-color: rgba(214, 198, 168, 0.55);
}

.luxy-cookie-banner__btn:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.75);
  outline-offset: 2px;
}

.luxy-cookie-banner__link:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.75);
  outline-offset: 2px;
}

[data-theme="light"] .luxy-cookie-banner {
  background: rgba(252, 251, 248, 0.97);
  border-top-color: rgba(60, 55, 48, 0.12);
}

[data-theme="light"] .luxy-cookie-banner__text {
  color: rgba(26, 24, 20, 0.88);
}

[data-theme="light"] .luxy-cookie-banner__btn {
  border-color: rgba(60, 55, 48, 0.2);
  color: rgba(26, 24, 20, 0.85);
}

[data-theme="light"] .luxy-cookie-banner__btn--primary {
  background: rgba(214, 198, 168, 0.45);
  color: #1a1814;
}

/* ----- Legal pages (privacy, cookies, terms) ----- */
.luxy-legal-page {
  padding-bottom: var(--space-2xl);
}

.luxy-legal-page__nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.8125rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
  color: rgba(247, 246, 243, 0.55);
}

.luxy-legal-page__nav a {
  color: rgba(214, 198, 168, 0.9);
}

.luxy-legal-page__nav a:hover {
  color: #f7f6f3;
}

.luxy-legal-page__notice {
  max-width: 42rem;
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-lg);
  border-radius: 4px;
  border: 1px solid rgba(214, 198, 168, 0.22);
  background: rgba(214, 198, 168, 0.06);
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(247, 246, 243, 0.82);
}

.luxy-legal-page__body {
  max-width: 42rem;
}

.luxy-legal-page__body ul {
  margin: 0 0 var(--space-sm);
  padding-left: 1.2rem;
}

.luxy-legal-page__body li {
  margin-bottom: 0.35rem;
}

[data-theme="light"] .luxy-legal-page__nav {
  color: rgba(26, 24, 20, 0.45);
}

[data-theme="light"] .luxy-legal-page__nav a {
  color: rgba(60, 55, 48, 0.85);
}

[data-theme="light"] .luxy-legal-page__notice {
  border-color: rgba(60, 55, 48, 0.12);
  background: rgba(214, 198, 168, 0.12);
  color: rgba(26, 24, 20, 0.88);
}

.site-footer__legal-links {
  margin: 0 0 var(--space-xs);
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.site-footer__legal-links a {
  color: rgba(247, 246, 243, 0.55);
}

.site-footer__legal-links a:hover {
  color: rgba(214, 198, 168, 0.95);
}

.site-footer__legal-sep {
  margin: 0 0.35rem;
  color: rgba(247, 246, 243, 0.28);
  user-select: none;
}

[data-theme="light"] .site-footer__legal-links a {
  color: rgba(82, 90, 92, 0.65);
}

[data-theme="light"] .site-footer__legal-links a:hover {
  color: rgba(26, 24, 20, 0.9);
}

[data-theme="light"] .site-footer__legal-sep {
  color: rgba(60, 55, 48, 0.25);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-footer__cookie-reopen {
  font: inherit;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: rgba(247, 246, 243, 0.55);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.site-footer__cookie-reopen:hover {
  color: rgba(214, 198, 168, 0.95);
}

[data-theme="light"] .site-footer__cookie-reopen {
  color: rgba(82, 90, 92, 0.65);
}

[data-theme="light"] .site-footer__cookie-reopen:hover {
  color: rgba(26, 24, 20, 0.9);
}

.luxy-cookie-inventory {
  margin-bottom: var(--space-xl);
  max-width: 48rem;
}

.luxy-cookie-inventory__empty {
  font-size: 0.9rem;
  line-height: 1.55;
}

.luxy-cookie-inventory__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  line-height: 1.45;
}

.luxy-cookie-inventory__table th,
.luxy-cookie-inventory__table td {
  text-align: left;
  vertical-align: top;
  padding: 0.55rem 0.65rem;
  border-bottom: 1px solid rgba(214, 198, 168, 0.15);
}

.luxy-cookie-inventory__table th {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(247, 246, 243, 0.55);
}

[data-theme="light"] .luxy-cookie-inventory__table th {
  color: rgba(26, 24, 20, 0.55);
}

[data-theme="light"] .luxy-cookie-inventory__table th,
[data-theme="light"] .luxy-cookie-inventory__table td {
  border-bottom-color: rgba(60, 55, 48, 0.12);
}

/* Cookie preferences modal (public site) */
body.luxy-cookie-prefs-open {
  overflow: hidden;
}

.luxy-cookie-prefs-overlay {
  position: fixed;
  z-index: 99991;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 1rem;
  padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
  box-sizing: border-box;
}

@media (min-width: 600px) {
  .luxy-cookie-prefs-overlay {
    align-items: center;
  }
}

.luxy-cookie-prefs-panel {
  width: 100%;
  max-width: 28rem;
  max-height: min(90vh, 36rem);
  overflow: auto;
  padding: 1.25rem 1.35rem;
  border-radius: 6px;
  background: rgba(14, 13, 12, 0.98);
  border: 1px solid rgba(214, 198, 168, 0.22);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45);
  color: rgba(247, 246, 243, 0.92);
}

.luxy-cookie-prefs-title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 500;
  margin: 0 0 var(--space-sm);
  line-height: 1.15;
}

.luxy-cookie-prefs-intro,
.luxy-cookie-prefs-status,
.luxy-cookie-prefs-note {
  font-size: 0.875rem;
  line-height: 1.55;
  margin: 0 0 var(--space-sm);
  color: rgba(247, 246, 243, 0.82);
}

.luxy-cookie-prefs-status {
  padding: 0.5rem 0.65rem;
  border-radius: 4px;
  background: rgba(214, 198, 168, 0.08);
  border: 1px solid rgba(214, 198, 168, 0.15);
}

.luxy-cookie-prefs-link {
  display: inline-block;
  font-size: 0.8125rem;
  margin-bottom: var(--space-sm);
}

.luxy-cookie-prefs-recent-h {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: var(--space-md) 0 0.35rem;
  color: rgba(247, 246, 243, 0.45);
}

.luxy-cookie-prefs-recent-list {
  margin: 0;
  padding-left: 1.1rem;
  font-size: 0.78rem;
  line-height: 1.45;
  color: rgba(247, 246, 243, 0.65);
}

.luxy-cookie-prefs-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: var(--space-md);
  justify-content: flex-end;
}

.luxy-cookie-prefs-btn {
  font-family: inherit;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.5rem 0.85rem;
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid rgba(214, 198, 168, 0.35);
  background: transparent;
  color: rgba(247, 246, 243, 0.9);
}

.luxy-cookie-prefs-btn--primary {
  background: rgba(214, 198, 168, 0.22);
  border-color: rgba(214, 198, 168, 0.45);
}

.luxy-cookie-prefs-btn--ghost {
  border-color: transparent;
  opacity: 0.85;
}

.luxy-cookie-prefs-btn:focus-visible {
  outline: 2px solid rgba(214, 198, 168, 0.75);
  outline-offset: 2px;
}

[data-theme="light"] .luxy-cookie-prefs-panel {
  background: rgba(252, 251, 248, 0.98);
  border-color: rgba(60, 55, 48, 0.12);
  color: rgba(26, 24, 20, 0.92);
}

[data-theme="light"] .luxy-cookie-prefs-intro,
[data-theme="light"] .luxy-cookie-prefs-status,
[data-theme="light"] .luxy-cookie-prefs-note {
  color: rgba(26, 24, 20, 0.85);
}

[data-theme="light"] .luxy-cookie-prefs-recent-h {
  color: rgba(26, 24, 20, 0.45);
}

[data-theme="light"] .luxy-cookie-prefs-recent-list {
  color: rgba(26, 24, 20, 0.65);
}

[data-theme="light"] .luxy-cookie-prefs-btn {
  border-color: rgba(60, 55, 48, 0.2);
  color: rgba(26, 24, 20, 0.88);
}

[data-theme="light"] .luxy-cookie-prefs-btn--primary {
  background: rgba(214, 198, 168, 0.4);
}

/* Admin — consent log table */
.luxy-consent-log-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
  margin-top: 0.5rem;
}

.luxy-consent-log-table th,
.luxy-consent-log-table td {
  text-align: left;
  padding: 0.35rem 0.4rem;
  border-bottom: 1px solid rgba(214, 198, 168, 0.15);
}

.admin-app.admin-app--light .luxy-consent-log-table th,
.admin-app.admin-app--light .luxy-consent-log-table td {
  border-bottom-color: rgba(60, 55, 48, 0.1);
}

/*
 * PageSpeed (home): sezioni sotto la piega — meno lavoro di layout iniziale.
 * Il 100% Lighthouse dipende anche da immagini (peso/CDN), hosting, TTFB e terze parti.
 */
body[data-page="index"] .main-content > section:not(.hero) {
  content-visibility: auto;
  contain-intrinsic-size: auto 420px;
}
