/* ================================================================
   SIAMO — worlds.css
   Ground-up design system for the three-brand storefront:
     .tre-mondi / .mondo      — homepage gateway
     .st-*                    — STRADA (street line)
     .casa-*                  — SIAMO Apparel (house line)
     .soon-detail             — coming-soon / locked previews
   Loaded after main.css (home) or brand-sites.css (brand pages),
   which keep powering the shared nav, footer, and cart drawer.
   ================================================================ */

:root {
  /* STRADA */
  --st-coal: #0a0a0a;
  --st-char: #1c1c1c;
  --st-bone: #f4f1eb;
  --st-gold: #c8a05d;
  --st-green: #008c45;
  --st-red: #cd212a;
  /* SIAMO Apparel */
  --ca-nero: #0d0d0d;
  --ca-carbone: #1f1f1f;
  --ca-avorio: #f5f3ef;
  --ca-crema: #f2efe6;
  --ca-tortora: #8a8173;
  --ca-sabbia: #c9b8a6;
  --ca-bordeaux: #5b0f1a;
  --ca-oro: #cba96a;
  --ca-oro-deep: #8a6f3c;
  /* Per Lei (gateway accents only) */
  --pl-plum: #4b1e3f;
  --pl-blush: #f4c7d5;
  --pl-ivory: #f7e6e3;
  --pl-gold: #d4af37;

  --w-serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --w-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --w-street: "Bebas Neue", "Anton", "Barlow Condensed", Impact, sans-serif;
  --w-ease: cubic-bezier(.22, 1, .36, 1);
}

/* ================================================================
   GATEWAY — Tre Mondi
   ================================================================ */

.tre-mondi {
  display: flex;
  min-height: calc(100svh - var(--header-h, 64px));
  background: #060606;
  overflow: hidden;
}

.mondo {
  position: relative;
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: calc(100svh - var(--header-h, 64px));
  overflow: hidden;
  isolation: isolate;
  color: #f6f2ea;
  text-decoration: none;
  border-right: 1px solid rgba(246, 242, 234, .12);
  opacity: 0;
  transition: flex-grow .7s var(--w-ease), filter .5s ease;
}

.mondo:last-child { border-right: 0; }

.mondo--enter-up   { animation: mondoUp .9s var(--w-ease) forwards; animation-delay: var(--mondo-delay, 0ms); }
.mondo--enter-down { animation: mondoDown .9s var(--w-ease) forwards; animation-delay: var(--mondo-delay, 0ms); }

@keyframes mondoUp   { from { opacity: 0; transform: translateY(4rem); }  to { opacity: 1; transform: none; } }
@keyframes mondoDown { from { opacity: 0; transform: translateY(-4rem); } to { opacity: 1; transform: none; } }

.mondo__media,
.mondo__shade {
  position: absolute;
  inset: 0;
  z-index: -1;
}

.mondo__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.03);
  filter: saturate(.88);
  transition: transform .9s var(--w-ease), filter .9s ease;
}

.mondo__shade {
  background: linear-gradient(180deg, rgba(6,6,6,.42) 0%, rgba(6,6,6,.05) 38%, rgba(6,6,6,.78) 100%);
  transition: background .5s ease;
}

.mondo--perlei .mondo__shade {
  background: linear-gradient(180deg, rgba(43,18,36,.38) 0%, rgba(43,18,36,.04) 38%, rgba(43,18,36,.74) 100%);
}

.mondo--apparel .mondo__shade {
  background: linear-gradient(180deg, rgba(13,13,13,.40) 0%, rgba(13,13,13,.05) 38%, rgba(13,13,13,.78) 100%);
}

/* top meta row */
.mondo__head {
  position: absolute;
  inset: 1.4rem 1.4rem auto;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  opacity: .85;
}

.mondo__number {
  padding-bottom: .2rem;
  border-bottom: 1px solid currentColor;
}

/* bottom content */
.mondo__content {
  display: grid;
  justify-items: start;
  gap: .9rem;
  padding: 0 clamp(1.4rem, 3vw, 2.6rem) clamp(2rem, 4vh, 3.2rem);
}

.mondo__logo {
  width: clamp(11rem, 16vw, 17rem);
  height: auto;
}

.mondo__logo--screen { mix-blend-mode: screen; }

.mondo--perlei .mondo__logo {
  width: clamp(9rem, 13vw, 13rem);
  border: 1px solid rgba(255,255,255,.35);
}

.mondo__tagline {
  max-width: 24rem;
  font-family: var(--w-sans);
  font-size: .92rem;
  line-height: 1.5;
  color: rgba(246,242,234,.86);
}

.mondo--apparel .mondo__tagline { font-family: var(--w-serif); font-size: 1.12rem; font-style: italic; }

.mondo__cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding-bottom: .35rem;
  font-family: var(--w-sans);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 2.4rem 1px;
  background-position: left bottom;
  transition: background-size .45s var(--w-ease);
}

.mondo__cta-arrow {
  transition: transform .45s var(--w-ease);
}

/* hover behavior: hovered panel grows, image zooms, CTA underlines */
@media (hover: hover) and (min-width: 941px) {
  .tre-mondi:hover .mondo:not(:hover) { filter: brightness(.62) saturate(.7); }
  .mondo:hover,
  .mondo:focus-visible { flex-grow: 1.45; }
  .mondo:hover .mondo__media img,
  .mondo:focus-visible .mondo__media img { transform: scale(1.085); filter: saturate(1); }
  .mondo:hover .mondo__cta,
  .mondo:focus-visible .mondo__cta { background-size: 100% 1px; }
  .mondo:hover .mondo__cta-arrow { transform: translateX(.35rem); }
}

.mondo:focus-visible {
  outline: 2px solid #f6f2ea;
  outline-offset: -6px;
}

/* brand-site nav refinements (markup lives in layout/brand-site.php) */
.brand-nav__wordmark--ink {
  width: clamp(7.5rem, 11vw, 10.5rem);
}

.brand-site--apparel .brand-nav {
  background: rgba(245,243,239,.82);
  color: var(--ca-nero);
  border-bottom: 1px solid rgba(13,13,13,.1);
}

.brand-site--strada .brand-nav {
  background: rgba(10,10,10,.72);
  color: var(--st-bone);
  border-bottom: 1px solid rgba(244,241,235,.12);
}

/* ================================================================
   Shared signup form
   ================================================================ */

.world-signup-form {
  position: relative;
  display: grid;
  gap: .8rem;
  align-content: start;
}

.world-signup-hp {
  position: absolute;
  left: -5000px;
}

.world-signup-form label {
  font-family: var(--w-sans);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .7;
}

.world-signup-row {
  display: flex;
  border: 1px solid currentColor;
}

.world-signup-row input[type="email"] {
  flex: 1;
  min-width: 0;
  padding: 1rem 1.1rem;
  border: 0;
  background: transparent;
  color: inherit;
  font-family: var(--w-sans);
  font-size: .95rem;
}

.world-signup-row input[type="email"]::placeholder { color: inherit; opacity: .45; }
.world-signup-row input[type="email"]:focus { outline: none; }

.world-signup-row button {
  padding: 1rem 1.7rem;
  border: 0;
  border-left: 1px solid currentColor;
  background: transparent;
  color: inherit;
  font-family: var(--w-sans);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .25s ease, color .25s ease;
}

/* ================================================================
   STRADA — st-*
   ================================================================ */

body.brand-site--strada {
  background: var(--st-coal);
  color: var(--st-bone);
}

.st-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  isolation: isolate;
  color: var(--st-bone);
}

.st-hero__bg,
.st-hero__grade {
  position: absolute;
  inset: 0;
  z-index: -1;
}

.st-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: stSettle 1.6s var(--w-ease) both;
}

@keyframes stSettle {
  from { transform: scale(1.07); opacity: .6; }
  to { transform: scale(1.01); opacity: 1; }
}

.st-hero__grade {
  background:
    linear-gradient(180deg, rgba(10,10,10,.66) 0%, rgba(10,10,10,.18) 40%, rgba(10,10,10,.92) 100%);
}

.st-hero__inner {
  width: 100%;
  max-width: 78rem;
  margin-inline: auto;
  padding: clamp(7rem, 16vh, 11rem) clamp(1.1rem, 4vw, 3rem) clamp(3.4rem, 8vh, 5.5rem);
  display: grid;
  justify-items: start;
  gap: 1.15rem;
  animation: stRise .9s .15s var(--w-ease) both;
}

@keyframes stRise {
  from { opacity: 0; transform: translateY(1.6rem); }
  to { opacity: 1; transform: none; }
}

.st-hero__status {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin: 0;
  padding: .5rem .85rem;
  border: 1px solid rgba(244,241,235,.28);
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
}

.st-hero__status-dot {
  width: .5rem;
  height: .5rem;
  border-radius: 50%;
  background: var(--st-green);
  box-shadow: 0 0 .55rem rgba(0,140,69,.9);
}

.st-hero__wordmark {
  width: min(34rem, 78vw);
  height: auto;
}

.st-hero__tag {
  margin: 0;
  font-family: var(--w-sans);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--st-gold);
}

.st-hero__line {
  margin: 0;
  font-family: var(--w-street);
  font-size: clamp(2.6rem, 6.5vw, 5.6rem);
  font-weight: 400;
  line-height: .94;
  letter-spacing: .015em;
  text-transform: uppercase;
}

.st-hero__lede {
  max-width: 34rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: .98rem;
  line-height: 1.65;
  color: rgba(244, 241, 235, .76);
}

.st-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: .4rem;
}

.st-btn {
  padding: 1rem 1.9rem;
  font-family: var(--w-sans);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}

.st-btn--solid {
  background: var(--st-bone, #f4f1eb);
  color: var(--st-coal, #0a0a0a);
  -webkit-text-fill-color: var(--st-coal, #0a0a0a);
  border: 1px solid var(--st-bone, #f4f1eb);
}

.st-btn--solid:hover,
.st-btn--solid:focus-visible {
  background: var(--st-gold, #c8a05d);
  border-color: var(--st-gold, #c8a05d);
}

.st-btn--ghost {
  border: 1px solid rgba(244,241,235,.4);
  color: var(--st-bone, #f4f1eb);
  -webkit-text-fill-color: var(--st-bone, #f4f1eb);
}

.st-btn--ghost:hover,
.st-btn--ghost:focus-visible {
  border-color: var(--st-gold, #c8a05d);
  color: var(--st-gold, #c8a05d);
  -webkit-text-fill-color: var(--st-gold, #c8a05d);
}

.st-hero__stripe {
  position: absolute;
  inset: auto 0 0;
  height: 4px;
  background: linear-gradient(90deg,
    var(--st-green) 0 18%,
    var(--st-bone) 18% 20%,
    var(--st-coal) 20% 80%,
    var(--st-bone) 80% 82%,
    var(--st-red) 82% 100%);
}

/* ticker */
.st-ticker {
  overflow: hidden;
  border-block: 1px solid rgba(244,241,235,.16);
  background: var(--st-coal);
  color: var(--st-bone);
  padding: .85rem 0;
}

.st-ticker__track {
  display: flex;
  align-items: center;
  gap: 1.6rem;
  width: max-content;
  animation: stTicker 28s linear infinite;
}

@keyframes stTicker {
  from { transform: translateX(0); }
  to { transform: translateX(-33.333%); }
}

.st-ticker__item {
  font-family: var(--w-street);
  font-size: 1.25rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.st-ticker__sep { color: var(--st-gold); }

/* section heads */
.st-head {
  display: grid;
  gap: .7rem;
  margin-bottom: clamp(2.2rem, 4vw, 3.4rem);
}

.st-head__eyebrow {
  margin: 0;
  font-family: var(--w-sans);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--st-gold);
}

.st-head__title {
  margin: 0;
  font-family: var(--w-street);
  font-size: clamp(3rem, 7vw, 6.6rem);
  font-weight: 400;
  line-height: .9;
  text-transform: uppercase;
  color: var(--st-bone);
}

.st-head__note {
  max-width: 34rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: .95rem;
  line-height: 1.65;
  color: rgba(244,241,235,.62);
}

/* rotation grid */
.st-rotation,
.st-estate,
.st-code,
.st-lista {
  padding: clamp(4.5rem, 9vw, 7.5rem) clamp(1.1rem, 4vw, 3rem);
  max-width: 86rem;
  margin-inline: auto;
}

.st-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: rgba(244,241,235,.18);
  border: 1px solid rgba(244,241,235,.18);
}

.st-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto auto;
  gap: .8rem;
  padding: 1.2rem;
  background: var(--st-char);
  color: var(--st-bone);
  text-decoration: none;
  transition: background .3s ease;
}

.st-card:hover,
.st-card:focus-visible { background: #242424; }

.st-card__index {
  font-family: var(--w-sans);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .2em;
  color: var(--st-gold);
}

.st-card__media {
  display: grid;
  place-items: center;
  min-height: 17rem;
  overflow: hidden;
}

.st-card__media img {
  width: 100%;
  height: 17rem;
  object-fit: contain;
  filter: drop-shadow(0 1.4rem 1.5rem rgba(0,0,0,.55));
  transition: transform .5s var(--w-ease);
}

.st-card:hover .st-card__media img { transform: scale(1.05) rotate(-1deg); }

.st-card__name {
  font-family: var(--w-street);
  font-size: clamp(1.9rem, 2.6vw, 2.7rem);
  line-height: .92;
  text-transform: uppercase;
}

.st-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: .8rem;
}

.st-card__line {
  font-family: var(--w-sans);
  font-size: .74rem;
  font-weight: 600;
  line-height: 1.45;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: rgba(244,241,235,.6);
}

.st-card__price {
  font-family: var(--w-sans);
  font-size: .82rem;
  font-weight: 800;
  color: var(--st-gold);
  white-space: nowrap;
}

.st-card__go {
  position: absolute;
  top: 1.1rem;
  right: 1.2rem;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateX(-.4rem);
  transition: opacity .3s ease, transform .3s var(--w-ease);
}

.st-card:hover .st-card__go,
.st-card:focus-visible .st-card__go { opacity: 1; transform: none; }

/* community block */
.st-block {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(20rem, .85fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding: clamp(4.5rem, 9vw, 7.5rem) clamp(1.1rem, 4vw, 3rem);
  background: var(--st-bone);
  color: var(--st-coal);
}

.st-block .st-head__eyebrow { color: var(--st-red); }

.st-block__media {
  margin: 0;
  overflow: hidden;
}

.st-block__media img {
  width: 100%;
  height: clamp(22rem, 46vw, 34rem);
  object-fit: cover;
  filter: contrast(1.06) saturate(.92);
}

.st-block__copy { display: grid; gap: 1rem; }

.st-block__title {
  margin: 0;
  font-family: var(--w-street);
  font-size: clamp(2.8rem, 5.6vw, 5.4rem);
  font-weight: 400;
  line-height: .9;
  text-transform: uppercase;
}

.st-block__copy p {
  max-width: 34rem;
  margin: 0;
  font-family: var(--w-sans);
  line-height: 1.75;
  color: rgba(10,10,10,.78);
}

.st-block__facts {
  display: flex;
  flex-wrap: wrap;
  gap: 1px;
  margin: .4rem 0 0;
  border: 1px solid rgba(10,10,10,.22);
  background: rgba(10,10,10,.22);
}

.st-block__facts div {
  flex: 1 1 8rem;
  display: grid;
  gap: .2rem;
  padding: .8rem .95rem;
  background: var(--st-bone);
}

.st-block__facts dt {
  font-family: var(--w-sans);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(10,10,10,.5);
}

.st-block__facts dd {
  margin: 0;
  font-family: var(--w-street);
  font-size: 1.25rem;
  text-transform: uppercase;
}

.st-link {
  width: max-content;
  font-family: var(--w-sans);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--st-coal);
  text-decoration: none;
  border-bottom: 2px solid var(--st-red);
  padding-bottom: .25rem;
}

.st-link:hover,
.st-link:focus-visible { border-color: var(--st-green); }

/* estate */
.st-estate__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: rgba(244,241,235,.18);
  border: 1px solid rgba(244,241,235,.18);
}

.st-soon {
  position: relative;
  display: grid;
  gap: .7rem;
  padding: 1.2rem;
  background: var(--st-char);
  color: var(--st-bone);
  text-decoration: none;
  transition: background .3s ease;
}

.st-soon:hover,
.st-soon:focus-visible { background: #242424; }

.st-soon__media {
  overflow: hidden;
  display: grid;
  place-items: center;
  background: #121212;
  aspect-ratio: 4 / 5;
}

.st-soon__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: saturate(.82);
  transition: transform .5s var(--w-ease), filter .5s ease;
}

.st-soon:hover .st-soon__media img { transform: scale(1.04); filter: saturate(1); }

.st-soon__badge {
  position: absolute;
  top: 1.9rem;
  left: 1.9rem;
  padding: .45rem .7rem;
  background: rgba(10,10,10,.78);
  border: 1px solid var(--st-gold);
  color: var(--st-gold);
  font-family: var(--w-sans);
  font-size: .64rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
}

.st-soon__name {
  font-family: var(--w-street);
  font-size: clamp(2.1rem, 3.4vw, 3.4rem);
  line-height: .92;
  text-transform: uppercase;
}

.st-soon__meta { display: flex; justify-content: space-between; align-items: baseline; gap: .8rem; }
.st-soon__line {
  font-family: var(--w-sans);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: rgba(244,241,235,.6);
}
.st-soon__price {
  font-family: var(--w-sans); font-size: .82rem; font-weight: 800;
  color: var(--st-gold); white-space: nowrap;
}

/* the code */
.st-code { color: var(--st-bone); }

.st-code__list {
  display: grid;
  gap: 1px;
  margin: 1.6rem 0 0;
  padding: 0;
  list-style: none;
  counter-reset: code;
  border: 1px solid rgba(244,241,235,.18);
  background: rgba(244,241,235,.18);
}

.st-code__list li {
  counter-increment: code;
  display: flex;
  align-items: baseline;
  gap: 1.4rem;
  padding: 1.5rem 1.4rem;
  background: var(--st-coal);
  font-family: var(--w-street);
  font-size: clamp(1.35rem, 2.6vw, 2.1rem);
  letter-spacing: .03em;
  text-transform: uppercase;
  line-height: 1.15;
}

.st-code__list li::before {
  content: "0" counter(code);
  font-family: var(--w-sans);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .2em;
  color: var(--st-gold);
}

/* la lista */
.st-lista {
  display: grid;
  grid-template-columns: minmax(18rem, .8fr) minmax(18rem, .6fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  color: var(--st-bone);
}

.st-lista .world-signup-row { border-color: rgba(244,241,235,.32); }
.st-lista .world-signup-row button { background: var(--st-gold); color: var(--st-coal); border-color: var(--st-gold); }
.st-lista .world-signup-row button:hover { background: var(--st-bone); }

/* ================================================================
   SIAMO APPAREL — casa-*
   ================================================================ */

body.brand-site--apparel { background: var(--ca-avorio); color: var(--ca-nero); }

.casa-hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
  text-align: center;
}

.casa-hero__bg,
.casa-hero__wash {
  position: absolute;
  inset: 0;
  z-index: -1;
}

.casa-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: casaSettle 2s var(--w-ease) both;
}

@keyframes casaSettle {
  from { transform: scale(1.05); }
  to { transform: scale(1); }
}

.casa-hero__wash {
  background: linear-gradient(180deg, rgba(242,239,230,.55) 0%, rgba(242,239,230,.18) 45%, rgba(242,239,230,.66) 100%);
}

.casa-hero__inner {
  display: grid;
  justify-items: center;
  gap: 1.3rem;
  padding: 6rem 1.2rem 3rem;
  animation: casaFade 1.1s .2s ease both;
}

@keyframes casaFade {
  from { opacity: 0; transform: translateY(.8rem); }
  to { opacity: 1; transform: none; }
}

.casa-hero__kicker {
  margin: 0;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(13,13,13,.62);
}

.casa-hero__wordmark {
  width: min(30rem, 76vw);
  height: auto;
}

.casa-hero__line {
  margin: 0;
  font-family: var(--w-serif);
  font-size: clamp(1.5rem, 3vw, 2.3rem);
  font-weight: 500;
  font-style: italic;
  color: rgba(13,13,13,.82);
}

.casa-hero__lede {
  max-width: 32rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: .92rem;
  line-height: 1.7;
  color: rgba(13, 13, 13, .6);
}

.casa-hero__cue {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  margin-top: 1.2rem;
  padding-bottom: .3rem;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ca-nero);
  text-decoration: none;
  border-bottom: 1px solid var(--ca-oro);
}

.casa-hero__cue span { animation: casaCue 2.4s ease-in-out infinite; }

@keyframes casaCue {
  0%, 100% { transform: translateY(0); opacity: .55; }
  50% { transform: translateY(.3rem); opacity: 1; }
}

/* statement */
.casa-statement {
  display: grid;
  justify-items: center;
  gap: 2rem;
  max-width: 52rem;
  margin-inline: auto;
  padding: clamp(5rem, 10vw, 8.5rem) 1.2rem;
  text-align: center;
}

.casa-rule {
  width: 4.5rem;
  height: 1px;
  background: var(--ca-oro);
}

.casa-statement h2 {
  margin: 0;
  font-family: var(--w-serif);
  font-size: clamp(2.4rem, 5.4vw, 4.4rem);
  font-weight: 500;
  line-height: 1.12;
  color: var(--ca-nero);
}

.casa-statement h2 em { font-style: italic; color: var(--ca-bordeaux); }

.casa-statement p {
  max-width: 36rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: 1rem;
  line-height: 1.85;
  color: rgba(13,13,13,.66);
}

/* heads */
.casa-head { display: grid; gap: .65rem; margin-bottom: clamp(2.2rem, 4vw, 3.2rem); }
.casa-head--center { justify-items: center; text-align: center; }

.casa-head__eyebrow {
  margin: 0;
  font-family: var(--w-sans);
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ca-tortora);
}

.casa-head__eyebrow--gold { color: var(--ca-oro-deep); }

.casa-head__title {
  margin: 0;
  font-family: var(--w-serif);
  font-size: clamp(2.3rem, 4.6vw, 3.9rem);
  font-weight: 500;
  line-height: 1.05;
  color: inherit;
}

.casa-head__note {
  max-width: 33rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: .92rem;
  line-height: 1.7;
  color: rgba(13,13,13,.58);
}

/* current edit */
.casa-edit,
.casa-estate,
.casa-atelier,
.casa-lista {
  max-width: 80rem;
  margin-inline: auto;
  padding: clamp(4rem, 8vw, 6.5rem) clamp(1.1rem, 4vw, 3rem);
}

.casa-edit__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.6rem, 3.4vw, 3rem);
}

.casa-card {
  display: grid;
  gap: .55rem;
  color: var(--ca-nero);
  text-decoration: none;
}

.casa-card__media {
  overflow: hidden;
  display: grid;
  place-items: center;
  background: #ece6da;
  border: 1px solid rgba(13,13,13,.08);
}

.casa-card__media img {
  width: 100%;
  height: clamp(22rem, 36vw, 32rem);
  object-fit: contain;
  padding: 1.4rem;
  transition: transform .8s var(--w-ease);
}

.casa-card:hover .casa-card__media img,
.casa-card:focus-visible .casa-card__media img { transform: scale(1.035); }

.casa-card__label {
  margin-top: .7rem;
  font-family: var(--w-sans);
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ca-oro-deep);
}

.casa-card__name {
  font-family: var(--w-serif);
  font-size: clamp(1.7rem, 2.6vw, 2.3rem);
  font-weight: 600;
  line-height: 1.05;
}

.casa-card__line {
  max-width: 28rem;
  font-family: var(--w-sans);
  font-size: .9rem;
  line-height: 1.6;
  color: rgba(13,13,13,.6);
}

.casa-card__price {
  font-family: var(--w-serif);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ca-bordeaux);
}

/* campaign banner */
.casa-campaign {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1rem 2rem;
  margin-top: clamp(2.4rem, 5vw, 4rem);
  padding: 1.5rem 1.6rem;
  border-block: 1px solid rgba(13,13,13,.7);
  color: var(--ca-nero);
  text-decoration: none;
  transition: background .3s ease;
}

.casa-campaign:hover,
.casa-campaign:focus-visible { background: #ece6da; }

.casa-campaign__kicker {
  font-family: var(--w-sans);
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ca-bordeaux);
}

.casa-campaign__title {
  flex: 1;
  font-family: var(--w-serif);
  font-size: clamp(1.2rem, 2.4vw, 1.7rem);
  font-weight: 600;
}

.casa-campaign__cta {
  font-family: var(--w-sans);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
}

/* craft */
.casa-craft {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(20rem, .8fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding: clamp(4.5rem, 9vw, 7rem) clamp(1.1rem, 4vw, 3rem);
  background: var(--ca-crema);
}

.casa-craft__media {
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(13,13,13,.08);
}

.casa-craft__media img {
  width: 100%;
  height: clamp(22rem, 44vw, 32rem);
  object-fit: cover;
}

.casa-craft__copy { display: grid; gap: 1rem; }

/* Solo (image-less) story band — centered text column. */
.casa-craft--solo { grid-template-columns: 1fr; justify-items: center; text-align: center; }
.casa-craft--solo .casa-craft__copy { max-width: 46rem; justify-items: center; }
.casa-craft--solo .casa-craft__copy p { margin-inline: auto; }
.casa-craft--solo .casa-link { justify-self: center; }

.casa-craft__copy p {
  max-width: 32rem;
  margin: 0;
  font-family: var(--w-sans);
  line-height: 1.85;
  color: rgba(13,13,13,.68);
}

.casa-link {
  width: max-content;
  padding-bottom: .25rem;
  font-family: var(--w-sans);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ca-nero);
  text-decoration: none;
  border-bottom: 1px solid var(--ca-oro);
}

.casa-link:hover,
.casa-link:focus-visible { color: var(--ca-bordeaux); border-color: var(--ca-bordeaux); }

/* estate */
.casa-estate__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.3rem, 2.6vw, 2.2rem);
}

.casa-soon {
  position: relative;
  display: grid;
  gap: .5rem;
  color: var(--ca-nero);
  text-decoration: none;
}

.casa-soon__media {
  overflow: hidden;
  display: grid;
  place-items: center;
  background: #ece6da;
  border: 1px solid rgba(13,13,13,.08);
  aspect-ratio: 4 / 5;
}

.casa-soon__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform .8s var(--w-ease);
}

.casa-soon:hover .casa-soon__media img,
.casa-soon:focus-visible .casa-soon__media img { transform: scale(1.04); }

.casa-soon__badge {
  position: absolute;
  top: .9rem;
  left: .9rem;
  padding: .4rem .65rem;
  background: rgba(245,243,239,.92);
  border: 1px solid var(--ca-oro);
  font-family: var(--w-sans);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ca-oro-deep);
}

.casa-soon__name {
  margin-top: .6rem;
  font-family: var(--w-serif);
  font-size: 1.45rem;
  font-weight: 600;
}

.casa-soon__line {
  font-family: var(--w-sans);
  font-size: .85rem;
  line-height: 1.55;
  color: rgba(13,13,13,.58);
}
.casa-soon__price {
  font-family: var(--w-serif); font-size: 1.1rem; font-weight: 600;
  color: var(--ca-bordeaux);
}

/* atelier (locked) */
.casa-atelier {
  color: var(--ca-avorio);
}

.casa-atelier-wrap,
section.casa-atelier {
  background: var(--ca-nero);
  max-width: none;
}

.casa-atelier > .casa-head,
.casa-atelier > .casa-atelier__grid {
  max-width: 80rem;
  margin-inline: auto;
}

.casa-atelier .casa-head__eyebrow--gold { color: var(--ca-oro); }
.casa-atelier .casa-head__title { color: var(--ca-avorio); }
.casa-atelier .casa-head__note { color: rgba(245,243,239,.55); }

.casa-atelier__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.4rem, 3vw, 2.6rem);
}

.casa-locked {
  position: relative;
  display: grid;
  align-content: end;
  gap: .3rem;
  min-height: clamp(20rem, 34vw, 28rem);
  padding: 1.4rem;
  overflow: hidden;
  isolation: isolate;
  color: var(--ca-avorio);
  text-decoration: none;
  border: 1px solid rgba(203,169,106,.32);
}

.casa-locked__media {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.casa-locked__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(10px) saturate(.55) brightness(.6);
  transform: scale(1.08);
  transition: filter .8s ease;
}

.casa-locked:hover .casa-locked__media img,
.casa-locked:focus-visible .casa-locked__media img { filter: blur(7px) saturate(.7) brightness(.68); }

.casa-locked__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(13,13,13,.25), rgba(13,13,13,.72));
}

.casa-locked__seal {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  display: grid;
  place-items: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid var(--ca-oro);
  border-radius: 50%;
  font-family: var(--w-serif);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: .08em;
  color: var(--ca-oro);
}

.casa-locked__name {
  font-family: var(--w-serif);
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  font-weight: 600;
}

.casa-locked__status {
  font-family: var(--w-sans);
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ca-oro);
}

/* lista */
.casa-lista {
  display: grid;
  grid-template-columns: minmax(18rem, .8fr) minmax(18rem, .6fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
}

.casa-lista .world-signup-row { border-color: rgba(13,13,13,.3); }
.casa-lista .world-signup-row button { background: var(--ca-nero); color: var(--ca-avorio); border-color: var(--ca-nero); }
.casa-lista .world-signup-row button:hover { background: var(--ca-bordeaux); }

/* ================================================================
   Coming-soon detail
   ================================================================ */

.soon-detail {
  min-height: 100svh;
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(20rem, .65fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  max-width: 84rem;
  margin-inline: auto;
  padding: clamp(6.5rem, 12vh, 9rem) clamp(1.1rem, 4vw, 3rem) clamp(3.5rem, 7vh, 5rem);
}

.soon-detail--apparel { color: var(--ca-nero); }
.soon-detail--strada { color: var(--st-bone); }

.soon-detail__media {
  position: relative;
  display: grid;
  gap: 1px;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(128,120,108,.25);
}

.soon-detail__media img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

/* Locked teasers keep their cropped, blurred, veiled treatment. */
.soon-detail__media--locked img {
  height: clamp(26rem, 60vh, 38rem);
  object-fit: cover;
  filter: blur(10px) saturate(.55) brightness(.62);
  transform: scale(1.06);
}

.soon-detail__veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13,13,13,.2), rgba(13,13,13,.66));
}

.soon-detail__seal {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  display: grid;
  place-items: center;
  width: 3.2rem;
  height: 3.2rem;
  border: 1px solid var(--ca-oro);
  border-radius: 50%;
  font-family: var(--w-serif);
  font-size: 1.05rem;
  color: var(--ca-oro);
}

.soon-detail__copy { display: grid; gap: 1rem; align-content: center; }

.soon-detail__back {
  width: max-content;
  margin-bottom: .6rem;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: .25rem;
  opacity: .75;
}

.soon-detail__back:hover,
.soon-detail__back:focus-visible { opacity: 1; }

.soon-detail__status {
  margin: 0;
  font-family: var(--w-sans);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .26em;
  text-transform: uppercase;
}

.soon-detail--apparel .soon-detail__status { color: var(--ca-oro-deep); }
.soon-detail--strada .soon-detail__status { color: var(--st-gold); }

.soon-detail__name {
  margin: 0;
  line-height: 1;
}

.soon-detail--apparel .soon-detail__name {
  font-family: var(--w-serif);
  font-size: clamp(2.6rem, 5.4vw, 4.6rem);
  font-weight: 500;
}

.soon-detail--strada .soon-detail__name {
  font-family: var(--w-street);
  font-size: clamp(3rem, 6.4vw, 5.6rem);
  font-weight: 400;
  text-transform: uppercase;
}

.soon-detail__line {
  max-width: 30rem;
  margin: 0;
  font-family: var(--w-sans);
  font-size: 1rem;
  line-height: 1.7;
  opacity: .7;
}

.soon-detail__notice {
  max-width: 30rem;
  margin: .4rem 0 0;
  padding: .95rem 1.1rem;
  border: 1px solid currentColor;
  font-family: var(--w-sans);
  font-size: .85rem;
  line-height: 1.6;
  opacity: .65;
}

.soon-detail--strada .world-signup-row button { background: var(--st-gold); color: var(--st-coal); border-color: var(--st-gold); }
.soon-detail--apparel .world-signup-row button { background: var(--ca-nero); color: var(--ca-avorio); border-color: var(--ca-nero); }

/* ================================================================
   ABOUT / CONTACT — SIAMO Apparel (casa) aesthetic
   Rendered under body.brand-site--apparel.
   ================================================================ */

.casa-page-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: stretch;
  min-height: min(76vh, 44rem);
  background: var(--ca-crema);
}
.casa-page-hero__media { position: relative; overflow: hidden; }
.casa-page-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.casa-page-hero__copy {
  display: grid; align-content: center; gap: 1.2rem;
  padding: clamp(2.5rem, 6vw, 5.5rem);
}
.casa-page-hero__title {
  margin: 0;
  font-family: var(--w-serif);
  font-size: clamp(2.6rem, 5.5vw, 4.6rem);
  font-weight: 500; line-height: 1.02; color: var(--ca-nero);
}
.casa-page-hero__title em { font-style: italic; color: var(--ca-bordeaux); }
.casa-page-hero__lede {
  max-width: 32rem; margin: 0;
  font-family: var(--w-sans); font-size: 1rem; line-height: 1.8;
  color: rgba(13, 13, 13, .64);
}

.casa-values {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.6rem, 4vw, 3.5rem);
  max-width: 80rem; margin-inline: auto;
  padding: clamp(3.5rem, 8vw, 6rem) clamp(1.4rem, 4vw, 3rem);
}
.casa-value { display: grid; gap: .8rem; padding-top: 1.4rem; border-top: 1px solid var(--ca-oro); }
.casa-value__num {
  font-family: var(--w-serif); font-size: 1.6rem; font-weight: 600;
  font-style: italic; color: var(--ca-oro-deep);
}
.casa-value__title { margin: 0; font-family: var(--w-serif); font-size: 1.6rem; font-weight: 600; color: var(--ca-nero); }
.casa-value__body { margin: 0; font-family: var(--w-sans); font-size: .94rem; line-height: 1.8; color: rgba(13,13,13,.62); }

/* Contact */
.casa-contact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(22rem, .9fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
  max-width: 78rem; margin-inline: auto;
  padding: clamp(3.5rem, 8vw, 6.5rem) clamp(1.4rem, 4vw, 3rem);
}
.casa-contact__intro { display: grid; gap: 1.1rem; align-content: start; }
.casa-contact__title {
  margin: 0; font-family: var(--w-serif);
  font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 500; line-height: 1.04; color: var(--ca-nero);
}
.casa-contact__title em { font-style: italic; color: var(--ca-bordeaux); }
.casa-contact__body { max-width: 30rem; margin: 0; font-family: var(--w-sans); font-size: 1rem; line-height: 1.8; color: rgba(13,13,13,.64); }
.casa-contact__email {
  width: max-content; margin-top: .4rem; padding-bottom: .25rem;
  font-family: var(--w-serif); font-size: 1.25rem; color: var(--ca-nero);
  text-decoration: none; border-bottom: 1px solid var(--ca-oro);
}
.casa-contact__email:hover { color: var(--ca-bordeaux); border-color: var(--ca-bordeaux); }

.casa-contact__panel {
  padding: clamp(1.6rem, 3vw, 2.4rem);
  background: var(--ca-avorio);
  border: 1px solid rgba(13, 13, 13, .1);
}
.casa-form { display: grid; gap: 1.1rem; }
.casa-form__alert {
  margin: 0; padding: .8rem 1rem;
  background: rgba(91, 15, 26, .07); border-left: 2px solid var(--ca-bordeaux);
  font-family: var(--w-sans); font-size: .85rem; color: var(--ca-bordeaux);
}
.casa-field { display: grid; gap: .4rem; }
.casa-field label {
  font-family: var(--w-sans); font-size: .68rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; color: var(--ca-tortora);
}
.casa-field__opt { font-weight: 500; letter-spacing: .08em; text-transform: none; opacity: .7; }
.casa-field input,
.casa-field textarea {
  width: 100%; padding: .8rem .9rem;
  background: #fff; border: 1px solid rgba(13, 13, 13, .18);
  font-family: var(--w-sans); font-size: .95rem; color: var(--ca-nero);
  border-radius: 0;
}
.casa-field textarea { resize: vertical; min-height: 8rem; }
.casa-field input:focus,
.casa-field textarea:focus { outline: none; border-color: var(--ca-nero); }
.casa-field.is-error input,
.casa-field.is-error textarea { border-color: var(--ca-bordeaux); }
.casa-field__err { font-family: var(--w-sans); font-size: .76rem; color: var(--ca-bordeaux); }
.casa-form__submit {
  margin-top: .3rem; height: 3.3rem;
  background: var(--ca-nero); color: var(--ca-avorio); border: 1px solid var(--ca-nero);
  font-family: var(--w-sans); font-size: .74rem; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase; cursor: pointer;
  transition: background .25s ease, border-color .25s ease;
}
.casa-form__submit:hover { background: var(--ca-bordeaux); border-color: var(--ca-bordeaux); }

@media (max-width: 820px) {
  .casa-page-hero { grid-template-columns: 1fr; }
  .casa-page-hero__media { min-height: 16rem; order: -1; }
  .casa-values { grid-template-columns: 1fr; }
  .casa-contact { grid-template-columns: 1fr; }
}

/* ================================================================
   PRODUCT DETAIL (Gucci-refined, brand-themed)
   Shared markup in shop/detail.php; themed via body.brand-site--*.
   ================================================================ */

.pdp {
  /* themed tokens — overridden per brand below */
  --pdp-bg: var(--ca-avorio);
  --pdp-stage: #ece6da;
  --pdp-ink: var(--ca-nero);
  --pdp-muted: rgba(13, 13, 13, .58);
  --pdp-line: rgba(13, 13, 13, .14);
  --pdp-accent: var(--ca-bordeaux);
  --pdp-btn-bg: var(--ca-nero);
  --pdp-btn-ink: var(--ca-avorio);
  --pdp-name-ff: var(--w-serif);
  --pdp-name-tt: none;
  --pdp-name-size: clamp(2rem, 3.2vw, 2.9rem);
  --pdp-name-weight: 600;
  --pdp-nav-h: 4.6rem;

  display: grid;
  grid-template-columns: minmax(0, 1.32fr) minmax(22rem, .68fr);
  align-items: start;
  background: var(--pdp-bg);
  color: var(--pdp-ink);
}

body.brand-site--strada .pdp {
  --pdp-bg: var(--st-coal);
  --pdp-stage: #141414;
  --pdp-ink: var(--st-bone);
  --pdp-muted: rgba(244, 241, 235, .58);
  --pdp-line: rgba(244, 241, 235, .16);
  --pdp-accent: var(--st-gold);
  --pdp-btn-bg: var(--st-bone);
  --pdp-btn-ink: var(--st-coal);
  --pdp-name-ff: var(--w-street);
  --pdp-name-tt: uppercase;
  --pdp-name-size: clamp(2.4rem, 4vw, 3.6rem);
  --pdp-name-weight: 400;
}

body.brand-site--per-lei .pdp {
  --pdp-accent: var(--pl-plum);
  --pdp-btn-bg: var(--pl-plum);
}

/* ── Gallery ─────────────────────────────────────────────────── */
.pdp__gallery {
  position: sticky;
  top: 0;
  display: grid;
  grid-template-columns: 4.75rem minmax(0, 1fr);
  gap: 1rem;
  padding: clamp(1rem, 2.4vw, 2rem);
}

.pdp__gallery:only-child,
.pdp__gallery:not(:has(.pdp__rail)) { grid-template-columns: 1fr; }

.pdp__rail {
  display: flex;
  flex-direction: column;
  gap: .6rem;
  max-height: calc(100svh - 2 * clamp(1rem, 2.4vw, 2rem));
  overflow-y: auto;
  scrollbar-width: thin;
}

.pdp__thumb {
  flex: 0 0 auto;
  width: 100%;
  aspect-ratio: 3 / 4;
  padding: 0;
  border: 1px solid transparent;
  background: var(--pdp-stage);
  cursor: pointer;
  opacity: .55;
  transition: opacity .25s ease, border-color .25s ease;
}
.pdp__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp__thumb:hover { opacity: .85; }
.pdp__thumb.active { opacity: 1; border-color: var(--pdp-ink); }

.pdp__stage {
  position: relative;
  aspect-ratio: 3 / 4;
  background: var(--pdp-stage);
  overflow: hidden;
  touch-action: pan-y pinch-zoom;
}
.pdp__main { width: 100%; height: 100%; object-fit: cover; display: block; }

.pdp__main-placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: flex-end; padding: 2rem;
}
.pdp__main-placeholder span {
  font-family: var(--pdp-name-ff);
  font-size: 2.4rem; font-weight: 600;
  color: var(--pdp-muted);
}

.pdp__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.6rem; height: 2.6rem;
  display: grid; place-items: center;
  background: color-mix(in srgb, var(--pdp-bg) 78%, transparent);
  border: 1px solid var(--pdp-line);
  color: var(--pdp-ink);
  font-size: 1.4rem; line-height: 1;
  cursor: pointer;
  opacity: 0;
  transition: opacity .25s ease, background .25s ease;
}
.pdp__stage:hover .pdp__arrow { opacity: 1; }
.pdp__arrow--prev { left: .8rem; }
.pdp__arrow--next { right: .8rem; }
.pdp__arrow:hover { background: var(--pdp-bg); }

/* ── Buy panel ───────────────────────────────────────────────── */
.pdp__panel {
  padding: clamp(1.6rem, 3vw, 3.2rem) clamp(1.4rem, 3vw, 3.4rem) clamp(3rem, 5vw, 4.5rem);
  border-left: 1px solid var(--pdp-line);
  min-height: 100svh;
}
.pdp__panel-inner { max-width: 30rem; }

.pdp__crumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
  font-family: var(--w-sans);
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--pdp-muted);
}
.pdp__crumbs a { color: inherit; text-decoration: none; }
.pdp__crumbs a:hover { color: var(--pdp-ink); }
.pdp__crumbs-current { color: var(--pdp-ink); }

.pdp__name {
  margin: 1.1rem 0 .5rem;
  font-family: var(--pdp-name-ff);
  font-weight: var(--pdp-name-weight);
  font-size: var(--pdp-name-size);
  line-height: 1.04;
  letter-spacing: .005em;
  text-transform: var(--pdp-name-tt);
}

.pdp__price {
  display: flex; align-items: baseline; gap: .7rem;
  font-family: var(--w-sans);
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: .01em;
}
.pdp__price-compare {
  font-size: .95rem; font-weight: 500;
  color: var(--pdp-muted); text-decoration: line-through;
}

.pdp__preorder-tag {
  margin: 0 0 .1rem;
  font-family: var(--w-sans); font-size: .66rem; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase; color: var(--pdp-accent);
}

/* ── Form fields ─────────────────────────────────────────────── */
.pdp__form { margin-top: 1.9rem; display: grid; gap: 1.5rem; }

.pdp__field { display: grid; gap: .7rem; }
.pdp__field-head { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; }
.pdp__field-label {
  font-family: var(--w-sans);
  font-size: .68rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--pdp-muted);
}
.pdp__field-value { font-family: var(--w-sans); font-size: .82rem; color: var(--pdp-ink); }
.pdp__field-link {
  font-family: var(--w-sans);
  font-size: .68rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--pdp-ink);
  text-underline-offset: 3px;
}

.pdp__swatches { display: flex; flex-wrap: wrap; gap: .65rem; }
.pdp__swatch { cursor: pointer; display: block; }
.pdp__swatch .color-swatch__input { position: absolute; opacity: 0; width: 0; height: 0; }
.pdp__swatch-dot {
  display: block; width: 2rem; height: 2rem; border-radius: 50%;
  border: 1px solid var(--pdp-line);
  outline: 1.5px solid transparent; outline-offset: 2px;
  transition: outline-color .15s ease, transform .15s ease;
}
.pdp__swatch:hover .pdp__swatch-dot { transform: scale(1.08); outline-color: var(--pdp-muted); }
.pdp__swatch .color-swatch__input:checked + .pdp__swatch-dot {
  outline-color: var(--pdp-ink); transform: scale(1.08);
}

.pdp__sizes { display: flex; flex-wrap: wrap; gap: .5rem; }
.pdp__size { position: relative; }
.pdp__size input { position: absolute; opacity: 0; width: 0; height: 0; }
.pdp__size label {
  display: flex; align-items: center; justify-content: center;
  min-width: 3.1rem; height: 2.9rem; padding-inline: .75rem;
  border: 1px solid var(--pdp-line);
  font-family: var(--w-sans); font-size: .82rem; font-weight: 600;
  letter-spacing: .04em;
  color: var(--pdp-ink); cursor: pointer;
  transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.pdp__size.size-option--os label { min-width: 4.5rem; }
.pdp__size label:hover { border-color: var(--pdp-ink); }
.pdp__size input:checked + label { background: var(--pdp-ink); border-color: var(--pdp-ink); color: var(--pdp-bg); }
.pdp__size.size-option--disabled label {
  opacity: .35; cursor: not-allowed; text-decoration: line-through;
}

.pdp__error {
  display: none;
  font-family: var(--w-sans); font-size: .72rem;
  color: #c0392b;
}
body.brand-site--strada .pdp__error { color: #ff6b5e; }
.pdp__error.is-visible { display: block; }

/* ── Buy row ─────────────────────────────────────────────────── */
.pdp__buy { display: flex; gap: .7rem; margin-top: .4rem; }
.pdp__qty {
  display: flex; align-items: center;
  border: 1px solid var(--pdp-line);
  flex: 0 0 auto;
}
.pdp__qty-btn {
  width: 2.9rem; height: 3.4rem;
  background: transparent; border: 0;
  color: var(--pdp-ink); font-size: 1.1rem; cursor: pointer;
}
.pdp__qty-input {
  width: 2.6rem; height: 3.4rem; text-align: center;
  background: transparent; border: 0; color: var(--pdp-ink);
  font-family: var(--w-sans); font-size: .95rem;
}
.pdp__qty-input::-webkit-outer-spin-button,
.pdp__qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.pdp__add {
  flex: 1;
  height: 3.4rem;
  background: var(--pdp-btn-bg); color: var(--pdp-btn-ink);
  border: 1px solid var(--pdp-btn-bg);
  font-family: var(--w-sans); font-size: .74rem; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase; cursor: pointer;
  transition: background .25s ease, color .25s ease;
}
.pdp__add:hover { background: var(--pdp-accent); border-color: var(--pdp-accent); color: #fff; }

.pdp__reassure {
  margin-top: 1.1rem;
  font-family: var(--w-sans); font-size: .8rem;
  color: var(--pdp-muted); line-height: 1.6;
}

.pdp__desc {
  margin-top: 1.6rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--pdp-line);
  font-family: var(--w-sans); font-size: .92rem;
  line-height: 1.85; color: var(--pdp-muted);
}

/* ── Accordions ──────────────────────────────────────────────── */
.pdp__accordions { margin-top: 1.6rem; border-top: 1px solid var(--pdp-line); }
.pdp-acc { border-bottom: 1px solid var(--pdp-line); }
.pdp-acc summary {
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; padding: 1.15rem 0; cursor: pointer; list-style: none;
  font-family: var(--w-sans); font-size: .74rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; color: var(--pdp-ink);
}
.pdp-acc summary::-webkit-details-marker { display: none; }
.pdp-acc__icon { position: relative; width: .8rem; height: .8rem; flex: 0 0 auto; }
.pdp-acc__icon::before,
.pdp-acc__icon::after {
  content: ""; position: absolute; background: var(--pdp-ink);
  transition: transform .25s ease, opacity .25s ease;
}
.pdp-acc__icon::before { top: 50%; left: 0; width: 100%; height: 1px; transform: translateY(-50%); }
.pdp-acc__icon::after { left: 50%; top: 0; width: 1px; height: 100%; transform: translateX(-50%); }
.pdp-acc[open] .pdp-acc__icon::after { opacity: 0; transform: translateX(-50%) scaleY(0); }
.pdp-acc__body { padding: 0 0 1.5rem; display: grid; gap: 1.1rem; }
.pdp-acc__body p {
  font-family: var(--w-sans); font-size: .88rem; line-height: 1.8; color: var(--pdp-muted);
}
.pdp-acc__body a { color: var(--pdp-ink); }
.pdp-acc__group h3 {
  font-family: var(--w-sans); font-size: .66rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--pdp-muted);
  margin-bottom: .55rem;
}
.pdp-acc__list { display: grid; gap: .4rem; list-style: none; }
.pdp-acc__list li {
  position: relative; padding-left: 1rem;
  font-family: var(--w-sans); font-size: .88rem; line-height: 1.7; color: var(--pdp-muted);
}
.pdp-acc__list li::before {
  content: ""; position: absolute; left: 0; top: .65em;
  width: 4px; height: 4px; background: var(--pdp-accent);
}

.pdp__size-table-wrap { overflow-x: auto; }
.pdp__size-table { width: 100%; min-width: 26rem; border-collapse: collapse; }
.pdp__size-table th, .pdp__size-table td {
  border-bottom: 1px solid var(--pdp-line); padding: .65rem .5rem; text-align: left;
  font-family: var(--w-sans); font-size: .82rem; color: var(--pdp-muted);
}
.pdp__size-table th {
  font-size: .66rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--pdp-ink);
}
.pdp__fine { font-family: var(--w-sans); font-size: .76rem; font-style: italic; color: var(--pdp-muted); }

.pdp__ai-note {
  margin-top: 1.6rem;
  font-family: var(--w-sans); font-size: .74rem; font-style: italic;
  line-height: 1.65; color: var(--pdp-muted);
}

/* ── PDP responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .pdp { grid-template-columns: 1fr; }
  .pdp__gallery {
    position: static;
    grid-template-columns: 1fr;
  }
  .pdp__rail {
    flex-direction: row;
    order: 2;
    max-height: none;
    overflow-x: auto;
  }
  .pdp__thumb { width: 4.5rem; flex: 0 0 4.5rem; }
  .pdp__stage { order: 1; }
  .pdp__arrow { opacity: 1; }
  .pdp__panel { border-left: 0; border-top: 1px solid var(--pdp-line); min-height: 0; }
  .pdp__panel-inner { max-width: none; }
}

/* ================================================================
   Responsive
   ================================================================ */

@media (max-width: 1100px) {
  .st-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .casa-estate__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 940px) {
  .tre-mondi {
    flex-direction: column;
    min-height: auto;
  }

  .mondo {
    min-height: max(33svh, 19rem);
    border-right: 0;
    border-bottom: 1px solid rgba(246,242,234,.12);
  }

  .mondo:last-child { border-bottom: 0; }

  .st-block,
  .st-lista,
  .casa-craft,
  .casa-lista,
  .soon-detail { grid-template-columns: 1fr; }

  .soon-detail { padding-top: 6.5rem; }
}

@media (max-width: 680px) {
  .st-grid,
  .st-estate__grid,
  .casa-edit__grid,
  .casa-estate__grid,
  .casa-atelier__grid { grid-template-columns: 1fr; }

  .st-rotation, .st-estate, .st-code, .st-lista,
  .casa-edit, .casa-estate, .casa-atelier, .casa-lista {
    padding-inline: 1rem;
  }

  .st-hero__inner { padding-bottom: 3rem; }

  .world-signup-row { display: grid; }
  .world-signup-row button {
    border-left: 0;
    border-top: 1px solid currentColor;
    min-height: 3rem;
  }
}

/* ================================================================
   Reduced motion
   ================================================================ */

@media (prefers-reduced-motion: reduce) {
  .mondo,
  .mondo__media img,
  .mondo__cta,
  .mondo__cta-arrow,
  .st-hero__bg img,
  .st-hero__inner,
  .st-card__media img,
  .st-soon__media img,
  .casa-hero__bg img,
  .casa-hero__inner,
  .casa-hero__cue span,
  .casa-card__media img,
  .casa-soon__media img,
  .casa-locked__media img {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }

  .mondo { opacity: 1; }

  .st-ticker__track {
    animation: none !important;
    width: auto;
    flex-wrap: wrap;
  }

  @media (hover: hover) and (min-width: 941px) {
    .mondo:hover { flex-grow: 1; }
    .tre-mondi:hover .mondo:not(:hover) { filter: none; }
  }
}
