:root {
  --ink: #101113;
  --paper: #f4f0e8;
  --soft: #dfd6ca;
  --muted: #827a70;
  --cyan: #59c8d2;
  --rose: #d64f6f;
  --gold: #c89f4f;
  --green: #587a63;
  --line: rgba(16, 17, 19, 0.14);
  --header-h: 72px;
  --hero-image: url("./assets/gallery/gioia-press.jpg");
  --vertical-hero-image: var(--hero-image);
  --epk-hero-image: var(--hero-image);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  /* NB: l'offset anti-header è su `section { scroll-margin-top }`. Non aggiungere
     anche scroll-padding-top qui: i due si SOMMANO e l'ancora (#date) atterra
     troppo in alto, mostrando la sezione precedente (#reel). */
}

body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: Inter, system-ui, sans-serif;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

.site-header {
  position: fixed;
  z-index: 20;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  /* Contenuto header allineato/centrato col contenuto pagina sui monitor larghi */
  padding: 0 max(clamp(18px, 4vw, 56px), calc((100% - 1320px) / 2));
  color: #fff;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.66), rgba(0, 0, 0, 0));
}

.site-header.solid {
  background: rgba(16, 17, 19, 0.92);
  backdrop-filter: blur(14px);
}

.brand-mark {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: Archivo, sans-serif;
  text-transform: uppercase;
}

.brand-mark img {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.26);
}

.brand-mark span {
  color: var(--cyan);
  font-weight: 800;
}

.brand-mark strong {
  font-size: 1.05rem;
  letter-spacing: 0;
}

.nav-links {
  display: flex;
  gap: 28px;
  font-size: 0.88rem;
  font-weight: 700;
}

.header-cta,
.primary-btn,
.ghost-btn {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 8px;
  font-weight: 800;
}

.header-cta {
  padding: 0 16px;
  background: rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(14px);
}

.primary-btn {
  border: 0;
  color: #0b0c0d;
  background: var(--cyan);
  padding: 0 20px;
  cursor: pointer;
}

.ghost-btn {
  border: 1px solid rgba(255, 255, 255, 0.42);
  color: #fff;
  padding: 0 18px;
}

.lucide {
  width: 18px;
  height: 18px;
  stroke-width: 2.2;
}

.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--header-h) + 64px) clamp(20px, 6vw, 84px) 88px;
  overflow: hidden;
  color: #fff;
}

section {
  scroll-margin-top: calc(var(--header-h) + 18px);
}

.hero-media,
.hero-shade {
  position: absolute;
  inset: 0;
}

.hero-media {
  --parallax: 0px;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.76), rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.78)),
    var(--hero-image) center / cover;
  transform: translate3d(0, var(--parallax), 0) scale(1.06);
  animation: slowPresence 18s ease-in-out infinite alternate;
  will-change: transform;
}

.hero-shade {
  background:
    linear-gradient(to top, rgba(0, 0, 0, 0.75), transparent 45%),
    radial-gradient(circle at 20% 80%, rgba(89, 200, 210, 0.22), transparent 28%);
}

.hero-copy {
  position: relative;
  max-width: 820px;
  --hero-shift: 0px;
  animation: riseIn 900ms ease both;
}

.eyebrow,
.section-kicker {
  margin: 0 0 14px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--cyan);
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1,
h2,
h3 {
  font-family: Archivo, sans-serif;
  letter-spacing: 0;
}

h1 {
  margin-bottom: 18px;
  font-size: clamp(4rem, 11vw, 10rem);
  line-height: 0.84;
  text-transform: uppercase;
}

h2 {
  font-size: clamp(2.2rem, 5vw, 5.2rem);
  line-height: 0.96;
}

h3 {
  font-size: 1.35rem;
}

.hero-line {
  max-width: 660px;
  font-size: clamp(1.08rem, 2vw, 1.45rem);
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.86);
}

.hero-deal-strip {
  width: min(760px, 100%);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  margin-top: 28px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(16px);
  animation: riseIn 900ms 140ms ease both;
}

.hero-deal-strip div {
  display: grid;
  gap: 6px;
  padding: 16px;
  background: rgba(16, 17, 19, 0.44);
}

.hero-deal-strip span {
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
}

.hero-deal-strip strong {
  font-family: Archivo, sans-serif;
  font-size: clamp(1rem, 1.7vw, 1.36rem);
  line-height: 1;
}

.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.hero-proof {
  position: absolute;
  left: clamp(20px, 6vw, 84px);
  right: clamp(20px, 6vw, 84px);
  bottom: 22px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.84rem;
  font-weight: 700;
}

.hero-proof span {
  border-left: 2px solid var(--cyan);
  padding-left: 12px;
}

.primary-btn,
.ghost-btn,
.header-cta,
.feed-card {
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    color 180ms ease;
}

.primary-btn:hover,
.ghost-btn:hover,
.header-cta:hover,
.feed-card:hover {
  transform: translateY(-2px);
}

.primary-btn:focus-visible,
.ghost-btn:focus-visible,
.header-cta:focus-visible,
.mobile-booking-bar a:focus-visible,
.brand-mark:focus-visible,
.nav-links a:focus-visible {
  outline: 3px solid rgba(89, 200, 210, 0.72);
  outline-offset: 4px;
}

.mobile-booking-bar {
  display: none;
}

.section-grid,
.social-live,
.pricing-section,
.format-finder,
.booking-section,
.faq-section {
  /* Sfondo full-bleed, contenuto centrato e capnato a 1320px sui monitor larghi
     (prima il contenuto restava spinto tutto a destra). */
  padding: clamp(50px, 7vw, 96px) max(clamp(20px, 6vw, 84px), calc((100% - 1320px) / 2));
}

.epk-press-links a {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  padding: 20px 0;
}

.section-grid {
  display: grid;
  /* Kicker sopra, contenuto a piena larghezza centrato (niente più colonna
     laterale che spingeva tutto a destra sui monitor larghi). */
  grid-template-columns: 1fr;
  gap: clamp(16px, 2.4vw, 28px);
  background:
    linear-gradient(180deg, #f4f0e8 0%, #ede5d9 100%);
}

.event-list,
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 40px;
}

.section-lede {
  max-width: 780px;
  margin: 18px 0 0;
  color: #5e594f;
  font-size: clamp(1.02rem, 1.7vw, 1.28rem);
  line-height: 1.55;
}

.event-list article,
.pricing-grid article,
.feed-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  background: rgba(255, 255, 255, 0.34);
}

.event-list article {
  min-height: 220px;
}

.event-list .lucide {
  color: var(--rose);
  width: 28px;
  height: 28px;
  margin-bottom: 34px;
}

.event-list p,
.sound-copy p,
.booking-copy p,
.pricing-grid p,
.feed-card p {
  color: #5e594f;
  line-height: 1.6;
}

/* Photo-fills pass 2 — foto pro di Gioia come sfondo attenuato nei blocchi vuoti.
   Ken-Burns transform-only (GPU-safe), overlay forte, testo in risalto. */
@media (prefers-reduced-motion: no-preference) {
  .photo-kb { animation: photoKenBurns 14s ease forwards; }
}
@keyframes photoKenBurns { from { transform: scale(1); } to { transform: scale(1.05); } }

/* #eventi — banner foto + 3 chip. Foto ombreggiata in modo uniforme (testo
   domina), contenuto centrato, kicker bianco ad alto contrasto. */
.event-sound-banner {
  position: relative;
  margin-top: 24px;
  min-height: clamp(260px, 32vw, 380px);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  background: #111315;
  display: flex;
  align-items: center;
  justify-content: center;
}
.event-sound-banner > img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 24%; transform-origin: 60% 40%;
}
.event-sound-banner::before {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(0deg, rgba(12,13,15,.86) 0%, rgba(12,13,15,.72) 52%, rgba(12,13,15,.82) 100%),
    radial-gradient(100% 120% at 50% 50%, transparent 30%, rgba(12,13,15,.55) 100%),
    radial-gradient(80% 70% at 50% 46%, rgba(89,200,210,.14), transparent 60%);
}
.event-sound-banner__inner {
  position: relative;
  padding: clamp(24px, 3vw, 40px);
  width: 100%;
  color: #fff;
  text-align: center;
}
.event-sound-banner__kicker {
  font-family: Archivo, sans-serif; font-size: .74rem; letter-spacing: .24em;
  text-transform: uppercase; color: #fff; margin: 0 0 18px;
  text-shadow: 0 2px 14px rgba(0,0,0,.6);
}
.event-sound-chips { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.event-sound-chip {
  display: grid; gap: 4px; padding: 14px 18px; border-radius: 14px;
  background: rgba(12,13,15,.5); border: 1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  box-shadow: 0 14px 34px -18px rgba(0,0,0,.8);
  text-align: left;
}
.event-sound-chip span { font-family: Archivo, sans-serif; font-weight: 900; font-size: .72rem; color: var(--cyan); }
.event-sound-chip strong { font-family: Archivo, sans-serif; font-size: 1.06rem; line-height: 1.05; }
.event-sound-chip p { margin: 0; font-size: .82rem; color: rgba(255,255,255,.82); line-height: 1.4; }

/* booking — accent media */
.booking-media {
  position: relative; margin: 0 0 28px; height: clamp(230px, 26vw, 300px);
  border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: #111315;
}
.booking-media > img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 16%; transform-origin: 50% 40%;
}
.booking-media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(17,19,21,0) 38%, rgba(17,19,21,.7) 100%);
}
.booking-media figcaption {
  position: absolute; left: 18px; bottom: 14px; z-index: 1; color: #fff;
  font-family: Archivo, sans-serif; font-size: .78rem; letter-spacing: .04em;
}
.booking-media figcaption b { color: var(--cyan); font-weight: 900; }

/* faq — proof photo (sezione scura) */
.faq-proof {
  position: relative; margin: 28px 0 0; max-height: 250px; height: 250px;
  border-radius: 12px; overflow: hidden; border: 1px solid rgba(255,255,255,.14); background: #0c0d0f;
}
.faq-proof > img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 14%; transform-origin: 50% 40%;
}
.faq-proof::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(12,13,15,0) 42%, rgba(12,13,15,.78) 100%);
}
.faq-proof figcaption { position: absolute; left: 16px; bottom: 12px; z-index: 1; color: rgba(255,255,255,.92); font-size: .78rem; }
.faq-proof figcaption b { color: var(--cyan); font-weight: 700; }

/* format-finder — accent decorativo */
.finder-media {
  position: relative; margin-top: 24px; height: clamp(200px, 22vw, 260px);
  border-radius: 12px; overflow: hidden; border: 1px solid var(--line); background: #111315;
}
.finder-media > img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 16%; transform-origin: 50% 50%;
}
.finder-media::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(120deg, rgba(214,79,111,.32) 0%, rgba(89,200,210,.18) 100%),
    linear-gradient(180deg, rgba(17,19,21,.1) 0%, rgba(17,19,21,.55) 100%);
}

.social-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 22px;
}

.social-heading h2 {
  max-width: 840px;
  margin-bottom: 0;
}

.social-heading a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
  color: var(--green);
}

.feed-grid {
  display: grid;
  grid-template-columns: 1.2fr repeat(2, minmax(0, 0.9fr));
  gap: 14px;
}

.feed-card {
  min-height: 320px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #151719;
  color: #fff;
  overflow: hidden;
  position: relative;
}

.feed-card.has-media {
  padding: 0;
}

.feed-card::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.46;
  background:
    radial-gradient(circle at 70% 18%, rgba(89, 200, 210, 0.72), transparent 28%),
    linear-gradient(150deg, #141618, #332236 42%, #d98273);
}

.feed-card > * {
  position: relative;
}

.feed-card.has-media::before {
  display: none;
}

.feed-card.has-media > span,
.feed-card.has-media > div:not(.feed-media) {
  padding: 0 22px 22px;
}

.feed-card.has-media > span {
  padding-top: 20px;
}

.feed-media {
  min-height: 210px;
  display: flex;
  align-items: flex-end;
  margin-bottom: 18px;
  padding: 14px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.72), transparent 60%) center / cover;
}

.feed-media span {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  border-radius: 8px;
  padding: 0 10px;
  color: #101113;
  background: var(--cyan);
}

.feed-card span {
  color: var(--cyan);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.feed-card .feed-media span {
  color: #101113;
}

.feed-card p {
  color: rgba(255, 255, 255, 0.82);
}

.music-console {
  display: grid;
  gap: 14px;
  align-content: center;
}

.music-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.music-tabs button {
  min-height: 118px;
  display: grid;
  gap: 8px;
  align-content: start;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  padding: 16px;
  color: #fff;
  text-align: left;
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
}

.music-tabs button.active {
  border-color: rgba(89, 200, 210, 0.74);
  background: rgba(89, 200, 210, 0.12);
}

.music-tabs span {
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.music-tabs strong {
  font-family: Archivo, sans-serif;
  font-size: 1.1rem;
  line-height: 1.05;
}

.music-tabs small {
  color: rgba(255, 255, 255, 0.66);
  line-height: 1.35;
}

.music-player {
  min-height: 220px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  overflow: hidden;
  background: #101113;
}

.music-player iframe {
  display: block;
  width: 100%;
  height: 220px;
  border: 0;
}

.music-empty {
  min-height: 220px;
  display: grid;
  align-content: center;
  gap: 10px;
  padding: clamp(22px, 4vw, 36px);
}

.music-empty strong {
  font-family: Archivo, sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
}

.music-empty p {
  max-width: 560px;
  margin: 0;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.55;
}

.music-empty a,
.music-meta {
  color: var(--cyan);
  font-weight: 800;
}

.music-consent-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.music-consent-actions .primary-btn {
  min-height: 42px;
  padding: 0 16px;
  border: 0;
}

.music-consent-actions a {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
}

.music-meta {
  margin: 0;
  font-size: 0.78rem;
  text-transform: uppercase;
}

/* #date — Editorial split: foto pro di Gioia (sfondo attenuato) + calendario double-bezel.
   #availabilityCalendar / #availabilityMeta invariati (li popola renderAvailability). */
.date-section {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1.08fr);
  align-items: stretch;
  padding: 0;
  background: #111315;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.date-aside {
  position: relative;
  min-height: 560px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(40px, 5vw, 76px) clamp(28px, 4.5vw, 66px) clamp(44px, 5vw, 72px);
  background-image:
    linear-gradient(180deg, rgba(17,19,21,.6) 0%, rgba(17,19,21,.76) 55%, rgba(17,19,21,.92) 100%),
    var(--date-aside-photo, none);
  background-size: cover;
  background-position: center 18%;
}
.date-aside::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(120% 80% at 12% 92%, rgba(89,200,210,.16), transparent 46%);
}
.date-aside > * { position: relative; z-index: 1; }
.date-aside .section-kicker { margin: 0 0 18px; color: var(--cyan); }
.date-aside h2 {
  margin: 0 0 18px;
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 600;
  font-size: clamp(2rem, 3.4vw, 3.05rem);
  line-height: 1.04;
  letter-spacing: -0.01em;
}
.date-aside p {
  max-width: 38ch;
  margin: 0;
  color: rgba(255, 255, 255, 0.74);
  line-height: 1.6;
}
.date-panel {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(40px, 4.5vw, 72px) clamp(28px, 4.5vw, 64px);
  background:
    radial-gradient(140% 120% at 100% 0%, rgba(200,159,79,.07), transparent 50%),
    #0f1113;
}
.calendar-shell {
  padding: 10px;
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 30px 80px -40px rgba(0, 0, 0, 0.9);
}
.calendar-core {
  padding: clamp(22px, 2.6vw, 32px);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.1);
}
.calendar-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 6px;
}
.calendar-month {
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 600;
  font-size: clamp(2.1rem, 3vw, 2.7rem);
  line-height: 1;
  letter-spacing: -0.01em;
}
.calendar-year {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.5);
}
.calendar-meta {
  margin: 0 0 22px;
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.calendar-weekhead {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 7px;
  margin-bottom: 9px;
}
.calendar-weekhead span {
  text-align: center;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.42);
  padding-bottom: 4px;
}
.availability {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 7px;
}
.day {
  position: relative;
  min-height: 54px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 4px;
  padding: 9px 10px 8px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.022);
  transition: transform .5s cubic-bezier(.32,.72,0,1), border-color .5s ease, background-color .5s ease;
}
.day strong { font-size: 1.06rem; font-weight: 600; line-height: 1; }
.day span {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.52);
}
.day.free { border-color: rgba(89,200,210,.6); background: rgba(89,200,210,.08); }
.day.free span { color: rgba(89, 200, 210, 0.9); }
.day.option { border-color: rgba(200,159,79,.66); background: rgba(200,159,79,.12); }
.day.option span { visibility: hidden; }
.day.option::after {
  content: "Opzione";
  position: absolute;
  top: 7px;
  right: 7px;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #0b0c0d;
  background: var(--gold);
  padding: 2px 5px;
  border-radius: 999px;
}
.day.busy { border-color: rgba(214,79,111,.5); background: rgba(214,79,111,.9); }
.day.busy strong { color: #fff; }
.day.busy span { color: rgba(255, 255, 255, 0.92); }
.day:hover { transform: translateY(-2px); border-color: rgba(255, 255, 255, 0.28); }
.calendar-cta { margin-top: 26px; display: flex; flex-direction: column; gap: 12px; }
.calendar-legend { display: flex; flex-wrap: wrap; gap: 14px; font-size: 0.68rem; color: rgba(255,255,255,.55); }
.calendar-legend i { display: inline-block; width: 9px; height: 9px; border-radius: 3px; margin-right: 6px; vertical-align: middle; }
.calendar-legend .lg-free { background: rgba(89, 200, 210, 0.85); }
.calendar-legend .lg-option { background: var(--gold); }
.calendar-legend .lg-busy { background: var(--rose); }
.date-section .primary-btn { align-self: flex-start; border-radius: 999px; }
.date-section .primary-btn .btn-icon {
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px; background: rgba(11, 12, 13, 0.12);
  transition: transform .5s cubic-bezier(.32,.72,0,1);
}
.date-section .primary-btn:hover .btn-icon { transform: translate(2px, -1px) scale(1.05); }
@media (max-width: 768px) {
  .date-aside { min-height: 0; padding: 56px 24px 44px; }
  .date-panel { padding: 36px 20px 52px; }
  .day { min-height: 50px; }
}

.pricing-section {
  background:
    radial-gradient(95% 80% at 100% 0%, rgba(89,200,210,.12), transparent 55%),
    radial-gradient(85% 75% at 0% 100%, rgba(214,79,111,.10), transparent 55%),
    linear-gradient(180deg, #f1ebe0, #e7dfd1);
}

.pricing-section h2 {
  max-width: 980px;
}

.pricing-grid article {
  min-height: 260px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  padding: 26px;
  border: 1px solid rgba(16, 17, 19, 0.1);
  background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, 0.62));
  box-shadow: 0 18px 40px -30px rgba(16, 17, 19, 0.45);
  transition: transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s ease;
}

.pricing-grid article::before {
  content: "";
  position: absolute;
  left: 0; top: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--rose));
}

.pricing-grid article:hover {
  transform: translateY(-5px);
  box-shadow: 0 28px 60px -30px rgba(16, 17, 19, 0.55);
}

.pricing-grid span {
  color: var(--rose);
  font-weight: 800;
  text-transform: uppercase;
  font-size: 0.78rem;
}

.pricing-grid .featured {
  background: linear-gradient(165deg, #16191d, #0f1113);
  color: #fff;
  border-color: rgba(89, 200, 210, 0.4);
}

.pricing-grid .featured::before { height: 4px; }
.pricing-grid .featured span { color: var(--cyan); }

.pricing-grid .featured p {
  color: rgba(255, 255, 255, 0.78);
}

.format-finder {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 1.18fr);
  gap: clamp(28px, 5vw, 72px);
  background: #151719;
  color: #fff;
  align-items: center; /* niente più colonna sx molto più alta del pannello = meno nero */
}

.finder-copy { display: grid; gap: 18px; align-content: center; }
.finder-copy h2 {
  max-width: 620px;
  font-size: clamp(1.9rem, 3.2vw, 3rem);
  line-height: 1.04;
}

.finder-copy p {
  max-width: 620px;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.65;
}

.finder-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 1px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.12);
}

.finder-controls,
.finder-result {
  display: grid;
  align-content: start;
  gap: 18px;
  padding: clamp(22px, 4vw, 36px);
  background: #101113;
}

.finder-controls label {
  color: rgba(255, 255, 255, 0.76);
}

.finder-controls select,
.finder-controls input[type="range"] {
  width: 100%;
}

.finder-value {
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.82rem;
  font-weight: 800;
}

.finder-value strong {
  color: var(--cyan);
}

.finder-toggle {
  min-height: 48px;
  display: flex;
  grid-template-columns: none;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  padding: 12px;
}

.finder-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--cyan);
}

.finder-result {
  background: #f4f0e8;
  color: var(--ink);
}

.finder-result > span {
  width: fit-content;
  border-radius: 999px;
  padding: 8px 10px;
  color: #0b0c0d;
  background: var(--cyan);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.finder-result h3 {
  margin: 0;
  max-width: 100%;
  font-size: clamp(1.9rem, 3.2vw, 3.1rem);
  line-height: 0.92;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.finder-result p {
  margin: 0;
  color: #5e594f;
  line-height: 1.6;
}

.finder-result ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.finder-result li {
  position: relative;
  padding-left: 22px;
  color: #4f493f;
  line-height: 1.45;
}

.finder-result li::before {
  content: "";
  position: absolute;
  top: 0.62em;
  left: 0;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--rose);
}

.finder-result .primary-btn {
  width: fit-content;
  margin-top: 6px;
}

.booking-section {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(360px, 1.2fr);
  gap: clamp(28px, 7vw, 86px);
}

.faq-section {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 1.18fr);
  gap: clamp(28px, 7vw, 86px);
  background: #111315;
  color: #fff;
}
/* Home only: reverse so questions go left, heading+proof-photo right — la foto
   faq sta sul lato OPPOSTO rispetto a quella del booking (alternanza). */
.home .faq-section {
  grid-template-columns: minmax(360px, 1.18fr) minmax(0, 0.82fr);
  align-items: center;
}
.home .faq-section .faq-list { order: 1; }
.home .faq-section .faq-copy { order: 2; }

.faq-copy h2 {
  max-width: 760px;
}

.faq-list {
  display: grid;
  align-content: center;
}

.faq-list details {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  padding: 22px 0;
}

.faq-list details:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
}

.faq-list summary {
  cursor: pointer;
  font-family: Archivo, sans-serif;
  font-size: clamp(1.15rem, 2.4vw, 1.7rem);
  line-height: 1.1;
}

.faq-list p {
  margin: 16px 0 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.65;
}

.booking-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.booking-note {
  margin-top: 18px;
  color: #111315 !important;
  font-weight: 800;
}

.booking-assurance {
  display: grid;
  gap: 18px;
  margin-top: clamp(28px, 5vw, 54px);
  border-top: 1px solid var(--line);
}

.booking-assurance div {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 8px 14px;
  padding-top: 18px;
  border-bottom: 1px solid var(--line);
}

.booking-assurance span {
  grid-row: span 2;
  color: var(--cyan);
  font-family: Archivo, sans-serif;
  font-weight: 900;
}

.booking-assurance strong {
  font-family: Archivo, sans-serif;
  font-size: 1.08rem;
}

.booking-assurance p {
  margin: 0;
  color: #5e594f;
  line-height: 1.55;
}

.form-context {
  padding-bottom: 6px;
}

.form-context strong {
  display: block;
  margin-bottom: 6px;
  font-family: Archivo, sans-serif;
  font-size: 1.18rem;
  color: #111315;
}

.form-context p {
  margin: 0;
  color: #5e594f;
  line-height: 1.55;
}

label {
  display: grid;
  gap: 8px;
  color: #4e493f;
  font-size: 0.84rem;
  font-weight: 800;
}

label small {
  color: #71695d;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.35;
}

.consent {
  grid-template-columns: 20px 1fr;
  align-items: start;
  font-weight: 700;
  line-height: 1.45;
}

.consent input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.turnstile-slot {
  min-height: 66px;
  display: flex;
  align-items: center;
}

.turnstile-slot[hidden] {
  display: none;
}

.hp-field {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

input,
select,
textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 14px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.62);
}

textarea {
  resize: vertical;
}

.full {
  grid-column: 1 / -1;
}

.booking-form .primary-btn {
  min-height: 54px;
}

.form-status {
  min-height: 22px;
  margin: 0;
  color: var(--green);
  font-size: 0.9rem;
  font-weight: 800;
}

.form-status.error {
  color: var(--rose);
}

.form-trust {
  margin: -2px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.primary-btn.is-loading {
  opacity: 0.6;
  cursor: progress;
}

.cookie-banner {
  position: fixed;
  z-index: 40;
  left: clamp(14px, 3vw, 28px);
  right: clamp(14px, 3vw, 28px);
  bottom: clamp(14px, 3vw, 28px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  max-width: 960px;
  margin: 0 auto;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  color: #fff;
  background: rgba(16, 17, 19, 0.94);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
}

.cookie-banner strong {
  display: block;
  margin-bottom: 4px;
  font-family: Archivo, sans-serif;
}

.cookie-banner p {
  max-width: 560px;
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem;
  line-height: 1.45;
}

.cookie-banner > div:last-child {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.cookie-banner button,
.cookie-banner a {
  min-height: 40px;
  white-space: nowrap;
}

.cookie-banner a {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.88rem;
  font-weight: 800;
}

.site-footer {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  padding: 28px clamp(20px, 6vw, 84px);
  background: #101113;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem;
}

.site-footer span:first-child {
  color: #fff;
  font-weight: 800;
}

.site-footer nav {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.legal-page {
  background: #111315;
  color: #f4f0e8;
}

.legal-shell {
  width: min(860px, calc(100% - 36px));
  margin: 0 auto;
  padding: clamp(48px, 9vw, 96px) 0;
}

.legal-shell h1 {
  margin: 26px 0 24px;
  font-size: clamp(3rem, 8vw, 6rem);
}

.legal-shell h2 {
  margin: 0 0 12px;
  font-size: clamp(1.5rem, 4vw, 2.3rem);
}

.legal-shell section {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  padding: 28px 0;
}

.legal-shell p {
  color: rgba(244, 240, 232, 0.74);
  line-height: 1.7;
}

.legal-back,
.legal-note {
  color: var(--cyan);
  font-weight: 800;
}

.epk-page {
  background: #f4f0e8;
}

.vertical-page {
  background: #f4f0e8;
}

.thanks-page {
  background: #111315;
  color: #fff;
}

.thanks-shell {
  padding-top: var(--header-h);
}

.thanks-hero {
  min-height: 72svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(88px, 12vw, 150px) clamp(20px, 6vw, 84px);
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.86), rgba(0, 0, 0, 0.34)),
    var(--hero-image) center / cover;
}

.thanks-hero h1 {
  max-width: 1080px;
  margin-bottom: 18px;
  font-size: clamp(3rem, 8vw, 8rem);
  line-height: 0.9;
}

.thanks-hero p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.82);
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  line-height: 1.5;
}

.thanks-next {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  background: #191b1d;
}

.thanks-next article {
  min-height: 260px;
  padding: clamp(28px, 5vw, 58px);
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.thanks-next span {
  color: var(--cyan);
  font-weight: 900;
}

.thanks-next h2 {
  margin: 48px 0 16px;
  font-size: clamp(1.8rem, 3vw, 3rem);
}

.thanks-next p {
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.65;
}

.thanks-prep {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
  gap: clamp(28px, 7vw, 86px);
  padding: clamp(64px, 10vw, 132px) clamp(20px, 6vw, 84px);
  background: #f4f0e8;
  color: #111315;
}

.thanks-prep h2 {
  max-width: 860px;
}

.thanks-prep ul {
  margin: 0;
  padding-left: 20px;
  align-self: center;
}

.thanks-prep li {
  margin-bottom: 14px;
  color: #5e594f;
  line-height: 1.6;
}

.vertical-hero {
  position: relative;
  min-height: 86svh;
  display: flex;
  align-items: flex-end;
  padding: calc(var(--header-h) + 64px) clamp(20px, 6vw, 84px) 84px;
  color: #fff;
  overflow: hidden;
}

.vertical-hero-media {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.84), rgba(0, 0, 0, 0.32)),
    var(--vertical-hero-image) center / cover;
  transform: scale(1.03);
}

.vertical-hero-copy {
  position: relative;
  max-width: 980px;
}

.vertical-hero h1 {
  max-width: 1050px;
  font-size: clamp(3.2rem, 8vw, 8rem);
  line-height: 0.9;
}

.vertical-hero p:not(.eyebrow) {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.82);
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  line-height: 1.5;
}

.corporate-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  background: #111315;
  color: #f4f0e8;
}

.corporate-band article {
  min-height: 320px;
  padding: clamp(28px, 5vw, 58px);
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.corporate-band span {
  color: var(--cyan);
  font-weight: 900;
}

.corporate-band h2 {
  margin: 58px 0 18px;
  font-size: clamp(1.8rem, 3vw, 3.1rem);
}

.corporate-band p {
  color: rgba(244, 240, 232, 0.7);
  line-height: 1.65;
}

.corporate-detail {
  background: #f4f0e8;
}

.vertical-pricing {
  background: #e8dfd2;
}

.vertical-cta {
  padding: clamp(64px, 10vw, 132px) clamp(20px, 6vw, 84px);
  background: #111315;
  color: #fff;
}

.vertical-cta h2 {
  max-width: 980px;
}

.vertical-cta p {
  max-width: 680px;
  color: rgba(255, 255, 255, 0.74);
  line-height: 1.65;
}

.epk-shell {
  padding-top: var(--header-h);
}

.epk-hero {
  min-height: 70svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(88px, 12vw, 150px) clamp(20px, 6vw, 84px);
  color: #fff;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.82), rgba(0, 0, 0, 0.25)),
    var(--epk-hero-image) center / cover;
}

.epk-hero h1 {
  margin-bottom: 18px;
}

.epk-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.82);
  font-size: clamp(1.08rem, 2vw, 1.35rem);
  line-height: 1.5;
}

.epk-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: #111315;
  color: #fff;
}

.epk-grid article {
  min-height: 210px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(24px, 4vw, 46px);
  background: rgba(255, 255, 255, 0.045);
}

.epk-grid span {
  color: var(--cyan);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.epk-grid strong {
  font-family: Archivo, sans-serif;
  font-size: clamp(1.7rem, 4vw, 3.4rem);
  line-height: 0.95;
}

.epk-grid p {
  margin: 0;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.55;
}

.epk-section {
  padding: clamp(54px, 8vw, 104px) clamp(20px, 6vw, 84px);
  border-top: 1px solid var(--line);
}

.epk-section h2 {
  max-width: 760px;
}

.epk-section p,
.epk-section li {
  color: #5e594f;
  line-height: 1.7;
}

.epk-press-links {
  display: grid;
  max-width: 720px;
  margin-top: 28px;
}

.epk-press-links a {
  color: #111315;
  font-weight: 800;
}

.epk-section ul {
  margin: 0;
  padding-left: 20px;
}

.two-col {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(28px, 7vw, 84px);
}

/* ===== Centratura su monitor larghi (header + hero + sezioni allineati) ===== */
/* Heroes: contenuto allineato col resto della pagina (1320px), bg full-bleed. */
.hero, .vertical-hero, .epk-hero {
  padding-inline: max(clamp(20px, 6vw, 84px), calc((100% - 1320px) / 2));
}
/* Sezioni testo sottopagina: capnate un po' più strette e centrate. */
.epk-section, .vertical-cta {
  padding-inline: max(clamp(20px, 6vw, 84px), calc((100% - 1180px) / 2));
}
/* CTA finale sottopagina — centrata */
.vertical-cta { text-align: center; }
.vertical-cta .eyebrow, .vertical-cta .section-kicker { justify-self: center; }
.vertical-cta h2 { max-width: 900px; margin-left: auto; margin-right: auto; }
.vertical-cta p { max-width: 620px; margin-left: auto; margin-right: auto; }
.vertical-cta .primary-btn { margin-top: 8px; }
/* Accenti colore (coerenti col resto): card EPK + corporate band + righe titolo */
.epk-grid article, .corporate-band article { position: relative; overflow: hidden; }
.epk-grid article::before, .corporate-band article::before {
  content: ""; position: absolute; left: 0; top: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.epk-section h2::after {
  content: ""; display: block; width: 56px; height: 3px; margin-top: 16px;
  border-radius: 2px; background: linear-gradient(90deg, var(--cyan), var(--rose));
}

@keyframes riseIn {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slowPresence {
  from {
    transform: translate3d(-1%, var(--parallax, 0px), 0) scale(1.05);
  }
  to {
    transform: translate3d(1%, var(--parallax, 0px), 0) scale(1.1);
  }
}

@media (max-width: 900px) {
  :root {
    --header-h: 64px;
  }

  .site-header {
    padding: 0 16px;
  }

  .nav-links {
    display: none;
  }

  .header-cta {
    width: 44px;
    padding: 0;
    font-size: 0;
  }

  .hero {
    min-height: 94svh;
    padding: calc(var(--header-h) + 44px) 18px 86px;
  }

  .hero-media {
    background-position: 58% center;
  }

  .hero-deal-strip {
    grid-template-columns: 1fr;
    margin-top: 22px;
  }

  .hero-deal-strip div {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    align-items: center;
    padding: 12px 14px;
  }

  .section-grid,
  .booking-section,
  .format-finder,
  .finder-panel,
  .faq-section,
  .epk-grid,
  .corporate-band,
  .thanks-next,
  .thanks-prep,
  .two-col {
    grid-template-columns: 1fr;
  }

  /* On mobile restore natural reading order: heading+photo before questions. */
  .faq-section .faq-copy { order: 0; }
  .faq-section .faq-list { order: 0; }

  .vertical-hero {
    min-height: 84svh;
    padding: calc(var(--header-h) + 44px) 18px 68px;
  }

  .vertical-hero h1 {
    font-size: clamp(2.85rem, 15vw, 5.2rem);
  }

  .corporate-band article {
    min-height: 240px;
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .booking-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .music-tabs {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }

  .music-tabs::-webkit-scrollbar {
    display: none;
  }

  .music-tabs button {
    flex: 0 0 min(76vw, 280px);
    min-height: 104px;
    scroll-snap-align: start;
  }

  .finder-controls,
  .finder-result {
    padding: 22px;
  }

  .finder-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .finder-controls label {
    min-width: 0;
  }

  .finder-controls label:nth-child(2),
  .finder-toggle {
    grid-column: 1 / -1;
  }

  .finder-result {
    gap: 14px;
  }

  .event-sound-banner { min-height: 300px; }
  .event-sound-banner > img { object-position: 58% 34%; }
  .event-sound-chips { grid-template-columns: 1fr; gap: 10px; }
  /* Drop the live blur on mobile — cheaper compositing, solid glass instead. */
  .event-sound-chip {
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    background: rgba(20, 22, 24, 0.66);
  }
  .booking-media { height: 150px; }
  .faq-proof { display: none; }
  .finder-media { display: none; }

  .event-list,
  .pricing-grid,
  .feed-grid {
    display: flex;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    scrollbar-width: none;
  }

  .event-list::-webkit-scrollbar,
  .pricing-grid::-webkit-scrollbar,
  .feed-grid::-webkit-scrollbar {
    display: none;
  }

  .section-main,
  .social-live,
  .pricing-section {
    min-width: 0;
    overflow: hidden;
  }

  .event-list article,
  .pricing-grid article,
  .feed-card {
    flex: 0 0 min(82vw, 340px);
    scroll-snap-align: start;
  }

  .finder-result .primary-btn {
    width: 100%;
  }

  .social-heading {
    align-items: start;
    flex-direction: column;
  }

  .availability {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 5px;
  }

  .day {
    min-height: 50px;
    padding: 7px 5px;
  }

  .day span {
    font-size: 0.58rem;
    line-height: 1;
  }

  .cookie-banner {
    align-items: stretch;
    flex-direction: column;
  }

  .cookie-banner > div:last-child {
    justify-content: stretch;
  }

  .mobile-booking-bar {
    position: fixed;
    z-index: 30;
    left: 12px;
    right: 12px;
    bottom: calc(10px + env(safe-area-inset-bottom));
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    padding: 8px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 999px;
    background: rgba(16, 17, 19, 0.9);
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.32);
    backdrop-filter: blur(16px);
  }

  .mobile-booking-bar a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    border-radius: 999px;
    font-size: 0.86rem;
    font-weight: 900;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
  }

  .mobile-booking-primary {
    background: var(--cyan);
    color: #071012;
  }

  .mobile-booking-secondary {
    min-width: 74px;
    padding: 0 14px;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
  }

  .site-footer {
    padding-bottom: calc(88px + env(safe-area-inset-bottom));
  }
}

@media (max-width: 520px) {
  :root {
    --header-h: 58px;
  }

  .site-header {
    padding: 0 14px;
    background: rgba(16, 17, 19, 0.86);
    backdrop-filter: blur(14px);
  }

  .brand-mark {
    gap: 6px;
    min-width: 0;
  }

  .brand-mark span {
    font-size: 0.72rem;
  }

  .brand-mark strong {
    max-width: 150px;
    overflow: hidden;
    font-size: 0.92rem;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .header-cta {
    width: 42px;
    min-height: 42px;
  }

  .mobile-booking-bar {
    left: 8px;
    right: 8px;
    bottom: calc(8px + env(safe-area-inset-bottom));
  }

  h1 {
    font-size: clamp(3.35rem, 18vw, 5rem);
  }

  h2 {
    font-size: clamp(2rem, 11vw, 3.2rem);
  }

  .hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-deal-strip div {
    grid-template-columns: 1fr;
  }

  .ghost-btn,
  .primary-btn {
    width: 100%;
  }

  .cookie-banner button,
  .cookie-banner a {
    flex: 1 1 120px;
    justify-content: center;
    min-height: 34px;
  }

  .cookie-banner a {
    flex-basis: 100%;
  }

  .cookie-banner {
    left: 8px;
    right: 8px;
    bottom: calc(76px + env(safe-area-inset-bottom));
    gap: 10px;
    padding: 10px;
  }

  .cookie-banner strong {
    margin-bottom: 2px;
    font-size: 0.95rem;
  }

  .cookie-banner p {
    display: -webkit-box;
    overflow: hidden;
    font-size: 0.78rem;
    line-height: 1.35;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .cookie-banner > div:last-child {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
    gap: 8px;
  }

  .cookie-banner .ghost-btn,
  .cookie-banner .primary-btn,
  .cookie-banner a {
    width: auto;
    min-height: 34px;
    padding: 0 10px;
    font-size: 0.78rem;
  }

  .cookie-banner a {
    flex-basis: auto;
    padding: 0 4px;
  }

  .day {
    min-height: 46px;
  }
}

/* MOTION — scroll choreography. Gated under no-preference so reduced-motion
   users keep all content. JS tags only below-the-fold nodes (no hero flash). */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity 680ms cubic-bezier(0.22, 1, 0.36, 1),
      transform 680ms cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay, 0ms);
  }
  [data-reveal].is-visible {
    opacity: 1;
    transform: none;
  }
  h2[data-reveal] {
    transform: translateY(34px);
  }
  .section-kicker[data-reveal],
  .eyebrow[data-reveal] {
    transform: translateX(-16px);
  }
}

.site-header {
  transition: background-color 320ms ease, backdrop-filter 320ms ease,
    box-shadow 320ms ease;
}
.site-header.solid {
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}

/* Brand — Direzione A "Editorial Luxe" (Fraunces wordmark). Scoped to .home so
   subpages (which don't load Fraunces) keep their current header rendering. */
.home .brand-mark,
.epk-page .brand-mark,
.vertical-page .brand-mark,
.thanks-page .brand-mark {
  font-family: "Space Grotesk", sans-serif;
  text-transform: none;
  gap: 9px;
}
.home .brand-mark span,
.epk-page .brand-mark span,
.vertical-page .brand-mark span,
.thanks-page .brand-mark span {
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 3px;
}
.home .brand-mark strong,
.epk-page .brand-mark strong,
.vertical-page .brand-mark strong,
.thanks-page .brand-mark strong {
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 600;
  font-size: 1.22rem;
  letter-spacing: 0.2px;
}
.home .brand-mark img,
.epk-page .brand-mark img,
.vertical-page .brand-mark img,
.thanks-page .brand-mark img {
  border-radius: 0;
  box-shadow: none;
}
.home .hero .eyebrow {
  font-family: "Space Grotesk", sans-serif;
  letter-spacing: 4px;
}
.home .hero-mark {
  display: block;
  width: auto;
  height: clamp(64px, 8vw, 96px);
  margin-bottom: 14px;
  filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.5));
}
.home .hero h1 {
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 600;
  font-size: clamp(3.6rem, 10vw, 8.6rem);
  line-height: 0.96;
  letter-spacing: 0;
  text-transform: none;
}

/* Console cinematic band (assembles on scroll) — integrated mid-homepage */
.console-stage{background:linear-gradient(180deg,#0c0d0f,#101113 58%,#0c0d0f)}
.console-track{position:relative;height:220vh}
.console-scene{position:relative;height:clamp(420px,58svh,560px);display:grid;place-items:center;overflow:hidden;border-radius:20px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.07),0 30px 90px -50px rgba(89,200,210,.4)}
.console-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:blur(22px) brightness(.78) saturate(1.25);transform:scale(1.18);opacity:.82}
.console-bg-scrim{position:absolute;inset:0;background:radial-gradient(90% 80% at 50% 48%,rgba(10,12,14,.12),rgba(10,12,14,.62))}
.console-scene::before{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(72% 56% at 50% 54%,rgba(89,200,210,.26),transparent 62%),radial-gradient(48% 42% at 80% 26%,rgba(168,84,192,.18),transparent 70%)}
.console-rig{position:relative;z-index:2;width:min(1180px,92vw);height:min(54vh,500px);perspective:1500px;perspective-origin:50% 36%;transform-style:preserve-3d}
.console-piece{position:absolute;left:50%;top:50%;will-change:transform,opacity}
.console-piece img{display:block;width:100%;height:auto}
.c-deck-l,.c-deck-r{width:40%;margin-left:-20%;margin-top:-18%}
.c-deck-r img{transform:scaleX(-1)}
.c-mixer{width:31%;margin-left:-15.5%;margin-top:-15%;z-index:4}
@media (prefers-reduced-motion: reduce){
  .console-track{height:auto}
  .console-scene{position:relative;height:auto;padding:80px 0}
}

/* Kinetic headings — words compose in on reveal */
@media (prefers-reduced-motion: no-preference){
  [data-reveal].word-split{opacity:1;transform:none;filter:none}
  [data-reveal].word-split .rw{display:inline-block;opacity:0;transform:translateY(.5em);
    transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);
    transition-delay:calc(var(--rwi,0)*55ms)}
  [data-reveal].word-split.is-visible .rw{opacity:1;transform:none}
}

/* Live reel previews (muted autoplay video) */
.feed-media.feed-video{position:relative;overflow:hidden;background:#0c0d0f}
.feed-media.feed-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feed-media.feed-video span{position:relative;z-index:2}

/* Spinning vinyl in the music section */
.music-disc{position:relative;flex:0 0 auto;width:84px;height:84px;aspect-ratio:1;margin:0;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,#15171a 0 19%,#000 19% 21%,#1b1d20 21% 23%,#101113 23% 60%,#17191c 60% 62%,#101113 62% 100%);
  box-shadow:0 18px 40px rgba(0,0,0,.5),inset 0 0 0 1px rgba(247,241,227,.06);animation:spin 3.2s linear infinite}
.music-disc::before{content:"";position:absolute;inset:38%;border-radius:50%;background:radial-gradient(circle,var(--cyan),#2a6c72);box-shadow:inset 0 0 0 2px rgba(0,0,0,.4)}
.music-disc::after{content:"";position:absolute;left:50%;top:50%;width:5px;height:5px;border-radius:50%;background:#0b0c0e;transform:translate(-50%,-50%)}
.music-disc[data-playing="false"]{animation-play-state:paused}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion: reduce){.music-disc{animation:none}}

/* Vertical reel tiles (9:16, Instagram-style) */
.feed-grid:has(.reel-tile){grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.feed-card.reel-tile{aspect-ratio:9/16;min-height:0;padding:0;border:0;border-radius:14px;overflow:hidden;position:relative;background:#0c0d0f}
.feed-card.reel-tile video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.feed-card.reel-tile .reel-overlay{position:absolute;inset:auto 0 0 0;z-index:2;display:grid;gap:4px;padding:14px;background:linear-gradient(to top,rgba(8,9,11,.92),rgba(8,9,11,0))}
.feed-card.reel-tile .reel-overlay span{color:var(--cyan);font-size:.64rem;font-weight:800;letter-spacing:.4px;text-transform:uppercase}
.feed-card.reel-tile .reel-overlay strong{font-family:Archivo,sans-serif;font-size:.98rem;line-height:1.1;color:#fff}
@media (max-width:900px){
  .feed-grid:has(.reel-tile){display:grid;grid-template-columns:repeat(2,minmax(0,1fr));overflow:visible}
  .feed-card.reel-tile{flex:none}
}

/* Booth continuity — the reel section joins the dark console+music experience */
.social-live{background:#0c0d0f;color:#fff}
.social-live .social-heading h2{color:#fff}
.social-live .social-heading a{color:var(--cyan)}
.social-live .section-kicker{color:var(--cyan)}

/* Kicker/eyebrow readable on LIGHT sections (cyan fails contrast on cream) */
.section-grid .section-kicker,
.pricing-section .section-kicker,
.booking-section .section-kicker{color:#1c6a70}

/* ===== THE BOOTH — unified: title -> console assembles -> music (compact) ===== */
.booth{position:relative;background:radial-gradient(120% 70% at 50% 24%,#171b20,#0f1216 60%),linear-gradient(180deg,#0f1216,#13171b 46%,#0f1216);color:#fff;isolation:isolate}
.booth-head{position:relative;z-index:2;max-width:980px;margin:0 auto;padding:clamp(48px,7vw,88px) clamp(20px,6vw,40px) clamp(20px,3vw,36px);text-align:center}
.booth-kicker{display:inline-block;border-radius:999px;padding:7px 16px;margin:0 0 20px;font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--cyan);background:rgba(89,200,210,.08);box-shadow:inset 0 0 0 1px rgba(89,200,210,.26)}
.booth-head h2{font-family:"Playfair Display",Georgia,serif;font-weight:600;font-size:clamp(2.2rem,6vw,4.4rem);line-height:1.02;letter-spacing:-.01em;margin:0 auto;max-width:16ch}
.booth-head h2 em{font-style:italic;color:var(--cyan)}
.booth-head p{margin:22px auto 0;max-width:56ch;color:rgba(255,255,255,.66);font-size:clamp(1rem,1.4vw,1.1rem);line-height:1.6}
.booth .console-stage{background:transparent;padding:0 clamp(20px,6vw,40px)}
.booth .console-track{position:relative;z-index:1;height:auto;max-width:1240px;margin:0 auto}
.booth .console-scene::before{background:radial-gradient(72% 56% at 50% 54%,rgba(89,200,210,.26),transparent 62%),radial-gradient(48% 42% at 80% 26%,rgba(168,84,192,.18),transparent 70%)}
.booth .console-scene .scene-label{position:absolute;left:0;right:0;bottom:clamp(24px,5vh,52px);z-index:3;text-align:center;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.booth-music{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:clamp(26px,4vw,44px) clamp(20px,6vw,40px) clamp(40px,6vw,72px);display:grid;gap:clamp(24px,4vw,44px);grid-template-columns:minmax(0,.82fr) minmax(360px,1.18fr);align-items:center}
.booth-music .m-copy{display:grid;gap:16px;align-content:center}
.booth-music .m-copy-head{display:flex;align-items:center;gap:16px}
.booth-music .m-copy-head h3{margin:4px 0 0}
.booth-music .section-kicker{display:inline-block;width:max-content;border-radius:999px;padding:7px 14px;font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);background:rgba(89,200,210,.08);box-shadow:inset 0 0 0 1px rgba(89,200,210,.24)}
.booth-music .m-copy h3{font-family:"Playfair Display",Georgia,serif;font-weight:600;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.06;letter-spacing:-.01em;margin:0;color:#fff}
.booth-music .m-copy p{margin:0;max-width:46ch;color:rgba(255,255,255,.66);line-height:1.6}
.booth-music .music-console{display:grid;gap:18px;align-content:start}
.booth-music .music-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.booth-music .music-tabs button{min-height:118px;display:grid;gap:8px;align-content:start;text-align:left;cursor:pointer;padding:16px;border:0;border-radius:16px;color:#fff;background:rgba(255,255,255,.045);box-shadow:inset 0 0 0 1px rgba(255,255,255,.1);transition:transform .4s ease,box-shadow .4s ease,background .4s ease}
.booth-music .music-tabs button:hover{transform:translateY(-3px);box-shadow:inset 0 0 0 1px rgba(89,200,210,.4),0 18px 40px rgba(0,0,0,.4)}
.booth-music .music-tabs button.active{background:rgba(89,200,210,.1);box-shadow:inset 0 0 0 1px rgba(89,200,210,.6),0 14px 34px rgba(0,0,0,.4)}
.booth-music .music-tabs span{color:var(--cyan);font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.booth-music .music-tabs strong{font-family:Archivo,sans-serif;font-size:1.04rem;line-height:1.08;font-weight:700}
.booth-music .music-tabs small{color:rgba(255,255,255,.62);line-height:1.35}
.booth-music .music-player{position:relative;min-height:172px;padding:6px;border-radius:22px;overflow:hidden;background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
.booth-music .music-player iframe{display:block;width:100%;height:172px;border:0;border-radius:16px}
.booth-music .music-empty{min-height:158px;display:grid;align-content:center;gap:10px;padding:clamp(20px,4vw,30px)}
.booth-music .music-empty strong{font-family:"Playfair Display",Georgia,serif;font-weight:600;font-size:clamp(1.3rem,2.4vw,1.8rem)}
.booth-music .music-empty p{margin:0;max-width:52ch;color:rgba(255,255,255,.66);line-height:1.5}
.booth-music .music-meta{margin:0;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.music-disc[data-playing="false"]{animation-play-state:paused;opacity:.78}
@media (max-width:860px){
  .booth-music{grid-template-columns:1fr;gap:30px}
  .booth-music .m-copy{position:static;top:auto}
  .booth-music .music-tabs{grid-template-columns:1fr}
  .booth-music .music-tabs button{min-height:0}
  .booth .console-track{height:auto}
}

/* ===== Smooth scroll (Lenis), loading screen, hero cinematic grade ===== */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

/* Loading screen — micro brand intro; auto-fade via CSS so non resta mai bloccata */
.intro{position:fixed;inset:0;z-index:200;display:grid;place-items:center;
  background:radial-gradient(120% 100% at 50% 38%,#16191d,#0b0d0f);
  animation:introOut .7s ease 1s forwards}
.intro-inner{display:flex;flex-direction:column;align-items:center;gap:14px;
  animation:introIn .9s cubic-bezier(.22,1,.36,1) both}
.intro-mark{width:64px;height:64px;filter:drop-shadow(0 12px 28px rgba(0,0,0,.55))}
.intro-word{font-family:"Playfair Display",Georgia,serif;font-size:1.55rem;letter-spacing:.4px;color:#fff}
.intro--done{display:none!important}
@keyframes introIn{from{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:none}}
@keyframes introOut{to{opacity:0;visibility:hidden;pointer-events:none}}
@media (prefers-reduced-motion:reduce){
  .intro{animation:none;opacity:0;visibility:hidden;pointer-events:none}
  .intro-inner{animation:none}
}

/* Hero cinematic grade — vignette + grana fine sopra lo slow-zoom esistente */
.hero-copy{z-index:2}
.hero-proof{z-index:2}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(125% 95% at 50% 34%,transparent 46%,rgba(0,0,0,.62) 100%),
    repeating-linear-gradient(0deg,rgba(255,255,255,.015) 0 1px,transparent 1px 3px)}

/* Card accent bar (coerente con le pricing card): event cards home + subpage detail */
.event-list article {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  transition: transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s ease;
}
.event-list article::before {
  content: "";
  position: absolute; left: 0; top: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.event-list article:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 50px -30px rgba(16, 17, 19, 0.45);
}

/* Subpage — CTA finale: scura (testo bianco leggibile) con accenti colore */
.vertical-cta {
  background:
    radial-gradient(90% 80% at 100% 0%, rgba(89,200,210,.16), transparent 55%),
    radial-gradient(80% 70% at 0% 100%, rgba(214,79,111,.14), transparent 55%),
    linear-gradient(180deg, #13171b, #0f1216);
}

/* Music — invito "Ascolta" (niente gate "Attiva player": il play è l'azione) */
.booth-music .music-invite { display: grid; gap: 12px; align-content: center; justify-items: start; }
.booth-music .music-invite strong { font-family: "Playfair Display", Georgia, serif; font-weight: 600; font-size: clamp(1.3rem, 2.4vw, 1.8rem); }
.booth-music .music-invite p { margin: 0; max-width: 46ch; color: rgba(255,255,255,.66); line-height: 1.5; }
.music-play-btn { min-height: 50px; display: inline-flex; align-items: center; gap: 10px; padding: 0 24px; border: 0; border-radius: 999px; cursor: pointer; font-weight: 700; margin-top: 4px; }
.music-play-btn i, .music-play-btn svg { width: 18px; height: 18px; }

/* Farfalla del logo — micro-animazione su OGNI pagina (header), flutter all'hover */
@media (prefers-reduced-motion: no-preference) {
  .brand-mark img { animation: butterflyIdle 4.6s ease-in-out infinite; transform-origin: 50% 60%; }
  .brand-mark:hover img { animation-duration: 1.4s; }
  .intro-mark { animation: butterflyIdle 2.4s ease-in-out infinite; }
}
@keyframes butterflyIdle {
  0%, 100% { transform: translateY(0) rotate(-2deg) scale(1); }
  50% { transform: translateY(-2px) rotate(2deg) scale(1.04); }
}

/* EPK — blocchi testo come card "designed" (meno vuoto/piatto) */
.epk-section.two-col { gap: clamp(20px, 3vw, 36px); align-items: start; }
.epk-section.two-col > div {
  position: relative;
  overflow: hidden;
  padding: clamp(26px, 3vw, 40px);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, 0.62));
  border: 1px solid rgba(16, 17, 19, 0.08);
  box-shadow: 0 18px 40px -30px rgba(16, 17, 19, 0.4);
}
.epk-section.two-col > div::before {
  content: ""; position: absolute; left: 0; top: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.epk-section.two-col h2 { font-size: clamp(1.45rem, 2.4vw, 1.95rem); line-height: 1.1; }
.epk-section.two-col h2::after { display: none; }
.epk-section ul { list-style: none; padding-left: 0; display: grid; gap: 11px; margin-top: 18px; }
.epk-section li { position: relative; padding-left: 22px; }
.epk-section li::before {
  content: ""; position: absolute; left: 0; top: .5em; width: 8px; height: 8px;
  border-radius: 2px; background: linear-gradient(135deg, var(--cyan), var(--rose));
}

/* ===== EPK P1 redesign (2026-06-07): hero badges, bio+foto, materiali, cta ===== */
.epk-hero .primary-btn { margin-top: 22px; align-self: flex-start; }
.epk-badges {
  list-style: none; margin: 22px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 10px;
}
.epk-badges li {
  font-size: 0.8rem; font-weight: 700; letter-spacing: 0.2px;
  padding: 7px 14px; border-radius: 999px;
  background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.18);
  color: #fff;
}
.epk-bio { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.epk-portrait { margin: 0; border-radius: 16px; overflow: hidden; box-shadow: 0 24px 60px rgba(16, 17, 19, 0.18); }
.epk-portrait img { display: block; width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4 / 5; }
.epk-bio p { max-width: 56ch; }
.epk-bio .epk-press-links { margin-top: 22px; gap: 8px; }
.epk-bio .epk-press-links a { display: inline-flex; align-items: center; gap: 7px; }
.epk-bio .epk-press-links svg { width: 16px; height: 16px; }

.epk-materials-lede { margin-top: 8px; max-width: 640px; }
.epk-materials {
  margin-top: 34px; display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px;
}
.epk-materials article {
  display: flex; flex-direction: column; gap: 8px;
  padding: 24px 22px; border-radius: 14px;
  background: #fff; border: 1px solid var(--line);
}
.epk-materials svg { width: 26px; height: 26px; color: var(--cyan); }
.epk-materials h3 { margin: 4px 0 0; font-size: 1.06rem; }
.epk-materials p { margin: 0; font-size: 0.92rem; line-height: 1.55; flex: 1; }
.epk-materials a { margin-top: 6px; font-weight: 800; color: #111315; }

.epk-cta { text-align: center; }
.epk-cta h2 { max-width: none; margin-inline: auto; }
.epk-cta .primary-btn { margin: 22px auto 12px; }
.epk-cta p { color: var(--muted); }

@media (max-width: 820px) {
  .epk-bio { grid-template-columns: 1fr; }
  .epk-portrait img { aspect-ratio: 16 / 11; }
  .epk-materials { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .epk-materials { grid-template-columns: 1fr; }
}

/* =========================================================================
   Pass 2026-06-07 (richiesta Gabriele): densità (meno spazi vuoti) +
   colore/coerenza tutte le pagine + buyer segment selector.
   ========================================================================= */

/* ---- Densità: padding/min-height ridotti dove c'era aria morta ---- */
.section-grid, .social-live, .pricing-section, .format-finder, .booking-section, .faq-section {
  padding-block: clamp(40px, 5vw, 68px);
}
.booth-head { padding-block: clamp(34px, 5vw, 56px) clamp(14px, 2.2vw, 24px); }
.corporate-band article, .thanks-next article { min-height: 0; }
.corporate-band h2 { margin: clamp(22px, 3.2vw, 36px) 0 12px; }
.epk-section { padding-block: clamp(40px, 5.5vw, 72px); }
.vertical-hero { min-height: 76svh; }
.booking-assurance { margin-top: clamp(22px, 3vw, 36px); }
.thanks-prep { padding-block: clamp(46px, 6vw, 80px); }
.vertical-page .faq-section { align-items: start; }

/* ---- Colore: numeri 01/02/03 come signature gradient cyan→rose ---- */
.corporate-band span, .thanks-next span {
  display: block; font-family: Archivo, sans-serif; font-weight: 900; line-height: 1;
  font-size: clamp(2.4rem, 4.6vw, 3.8rem);
  background: linear-gradient(135deg, var(--cyan), var(--rose));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
@media (max-width: 900px) { .corporate-band h2 { margin-top: 16px; } }

/* underline accent sui titoli di sezione chiari */
.section-grid h2::after, .thanks-prep h2::after {
  content: ""; display: block; width: 48px; height: 3px; margin-top: 14px;
  border-radius: 2px; background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.thanks-prep .section-kicker { color: #1c6a70; }

/* ---- Colore: accenti radiali sulle sezioni chiare "piatte" ---- */
.booking-section {
  background:
    radial-gradient(80% 70% at 100% 0%, rgba(89,200,210,.10), transparent 52%),
    radial-gradient(70% 60% at 0% 100%, rgba(214,79,111,.08), transparent 52%),
    linear-gradient(180deg, #f4f0e8, #ece4d8);
}
.vertical-pricing {
  background:
    radial-gradient(95% 80% at 100% 0%, rgba(89,200,210,.11), transparent 55%),
    radial-gradient(85% 75% at 0% 100%, rgba(214,79,111,.08), transparent 55%),
    linear-gradient(180deg, #ede5d9, #e2d8ca);
}
.epk-materials-section {
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(89,200,210,.08), transparent 60%),
    linear-gradient(180deg, #ede5d9, #f4f0e8);
}

/* ---- Colore: hero scuri sottopagine con accento "luce scenica" ---- */
.epk-hero {
  background:
    radial-gradient(60% 50% at 82% 88%, rgba(89,200,210,.20), transparent 52%),
    radial-gradient(42% 36% at 8% 72%, rgba(214,79,111,.13), transparent 52%),
    linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.25)),
    var(--epk-hero-image) center / cover;
}
.thanks-hero {
  background:
    radial-gradient(60% 50% at 82% 88%, rgba(89,200,210,.18), transparent 52%),
    linear-gradient(90deg, rgba(0,0,0,.86), rgba(0,0,0,.34)),
    var(--hero-image) center / cover;
}

/* ---- Colore: EPK link e CTA finale dark coerente ---- */
.epk-materials a, .epk-press-links a { color: var(--cyan); transition: color 180ms ease; }
.epk-materials a:hover, .epk-press-links a:hover { color: var(--rose); }
.epk-cta {
  border-top: none; color: #fff;
  background:
    radial-gradient(90% 80% at 100% 0%, rgba(89,200,210,.16), transparent 55%),
    radial-gradient(80% 70% at 0% 100%, rgba(214,79,111,.13), transparent 55%),
    linear-gradient(180deg, #13171b, #0f1216);
}
.epk-cta h2 { color: #fff; }
.epk-cta p { color: rgba(255,255,255,.66); }

/* ---- Buyer segment selector (P1) ---- */
.buyer-selector {
  padding: clamp(44px, 6vw, 76px) max(clamp(20px, 6vw, 84px), calc((100% - 1320px) / 2));
  background:
    radial-gradient(90% 80% at 0% 0%, rgba(89,200,210,.10), transparent 50%),
    radial-gradient(80% 70% at 100% 100%, rgba(214,79,111,.10), transparent 50%),
    #111315;
  color: #f4f0e8;
}
.buyer-selector .section-kicker { color: var(--cyan); margin-bottom: clamp(22px, 3vw, 38px); }
.buyer-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px;
  border: 1px solid rgba(255,255,255,.12); border-radius: 14px; overflow: hidden;
  background: rgba(255,255,255,.10);
}
.buyer-card {
  position: relative; display: flex; flex-direction: column; gap: 12px;
  padding: clamp(24px, 3.2vw, 40px); background: #111315; overflow: hidden;
  text-decoration: none; color: #f4f0e8; transition: background-color 220ms ease;
}
.buyer-card::before {
  content: ""; position: absolute; left: 0; top: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.buyer-card:hover, .buyer-card:focus-visible { background: #16191d; }
.buyer-card:focus-visible { outline: 3px solid rgba(89,200,210,.72); outline-offset: -3px; }
.buyer-card__tag { font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--cyan); }
.buyer-card__head { margin: 0; font-family: Archivo, sans-serif; font-size: clamp(1.12rem, 1.9vw, 1.5rem); line-height: 1.14; font-weight: 700; flex: 1; }
.buyer-card__body { margin: 0; font-size: .9rem; color: rgba(244,240,232,.68); line-height: 1.55; }
.buyer-card__cta { display: inline-block; margin-top: 6px; font-size: .84rem; font-weight: 800; color: var(--cyan); }
@media (max-width: 900px) { .buyer-grid { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: no-preference) {
  .buyer-card__cta { transition: transform 200ms ease; }
  .buyer-card:hover .buyer-card__cta { transform: translateX(4px); }
}

/* ---- Header nav: uniforme su tutte le pagine, bottoni più grandi + stato attivo ---- */
.nav-links { gap: clamp(16px, 1.6vw, 26px); font-size: 0.98rem; }
.nav-links a {
  position: relative; padding: 6px 2px; color: rgba(255,255,255,.88);
  transition: color 180ms ease;
}
.nav-links a:hover, .nav-links a:focus-visible { color: #fff; }
.nav-links a[aria-current="page"] { color: var(--cyan); }
.nav-links a[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 2px;
  border-radius: 2px; background: linear-gradient(90deg, var(--cyan), var(--rose));
}
.header-cta { min-height: 48px; padding: 0 20px; font-size: 0.96rem; }

/* ---- Trust + press band (P1: differenziatore zero-rischio/24h + rassegna stampa) ---- */
.trust-band {
  display: grid;
  grid-template-columns: 1.55fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(40px, 5vw, 64px) max(clamp(20px, 6vw, 84px), calc((100% - 1320px) / 2));
  border-top: 1px solid var(--line);
  background:
    radial-gradient(70% 80% at 0% 0%, rgba(89,200,210,.10), transparent 55%),
    radial-gradient(60% 70% at 100% 100%, rgba(214,79,111,.08), transparent 55%),
    linear-gradient(180deg, #f4f0e8, #efe7da);
}
.trust-band__pitch h2 {
  margin: 10px 0 12px;
  font-size: clamp(1.5rem, 2.6vw, 2.15rem);
  line-height: 1.12;
}
.trust-band__pitch > p { max-width: 60ch; color: #5e594f; line-height: 1.6; }
.trust-band__points {
  list-style: none; margin: 18px 0 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 10px 22px;
}
.trust-band__points li { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: .92rem; }
.trust-band__points svg { width: 18px; height: 18px; color: var(--cyan); }
.trust-band__press {
  display: grid; gap: 10px; align-content: center;
  padding: clamp(22px, 2.6vw, 30px); border-radius: 16px;
  background: #13171b; color: #fff;
  box-shadow: 0 22px 50px rgba(16,17,19,.16);
}
.trust-band__press-kicker {
  margin: 0 0 2px; font-size: .72rem; font-weight: 800; letter-spacing: .08em;
  text-transform: uppercase; color: var(--cyan);
}
.trust-band__press a {
  display: inline-flex; align-items: center; gap: 8px;
  color: rgba(255,255,255,.92); font-weight: 700; font-size: .94rem;
  transition: color 180ms ease;
}
.trust-band__press a:hover { color: var(--cyan); }
.trust-band__press svg { width: 16px; height: 16px; color: var(--cyan); }
.trust-band__years { margin: 6px 0 0; color: rgba(255,255,255,.6); font-size: .84rem; }
@media (max-width: 820px) {
  .trust-band { grid-template-columns: 1fr; }
}

/* ---- Mobile refinement (≤560px): form/finder/date a colonna singola, no squish ---- */
@media (max-width: 560px) {
  .date-section { grid-template-columns: 1fr; }
  .date-aside { min-height: auto; }
  .booking-form { grid-template-columns: 1fr; }
  .finder-controls { grid-template-columns: 1fr; }
  .epk-bio { grid-template-columns: 1fr; }
  .trust-band__points { gap: 8px 16px; }
}

/* ===== Mobile-first density (≤600px): meno scroll, fluidità, console compatta =====
   Obiettivo (richiesta Gabriele): mobile più curato del desktop, homepage non
   interminabile. Riduce padding di sezione, comprime card e console-stage. ===== */
@media (max-width: 600px) {
  .section-grid, .social-live, .pricing-section, .format-finder,
  .booking-section, .faq-section, .buyer-selector, .trust-band, .epk-section,
  .corporate-band, .corporate-detail, .vertical-cta, .thanks-next, .thanks-prep {
    padding-block: 30px;
  }
  .hero { min-height: 88svh; }

  /* Console: glimpse compatto ma ben impaginato (era ~490-615px) */
  .booth-head { padding-block: 24px 6px; }
  .console-scene { height: auto; padding: 12px 0; }
  .console-rig { height: min(36vh, 260px); }
  .booth-music { padding-block: 18px 30px; gap: 22px; }

  /* event-sound banner: altezza da contenuto, niente blocco fisso alto */
  .event-sound-banner { min-height: 0; }

  /* Card più compatte */
  .buyer-card { padding: 20px 18px; gap: 8px; }
  .buyer-card__head { font-size: 1.16rem; }
  .pricing-grid article, .event-list article { min-height: 0; }
  .trust-band { gap: 20px; }
  .trust-band__pitch h2 { font-size: clamp(1.4rem, 6vw, 1.8rem); }

  /* Booking: meno aria attorno a step e campi */
  .booking-assurance { gap: 12px; margin-top: 16px; }
  .booking-form { gap: 14px; }
  .booking-media { display: none; } /* foto decorativa: la togliamo da mobile per accorciare */

  /* Sezioni testo sottopagina più compatte */
  .epk-bio { gap: 20px; }
}

/* Mobile density — pass 2 (≤600px): taglia ridondanze + comprime form/heading */
@media (max-width: 600px) {
  /* "Tre fasi/momenti" appare sia qui sia nel blocco Selezioni → ridondante su mobile */
  .event-sound-banner { display: none; }
  /* Heading editoriali enormi: ridimensionati per mobile */
  .booth-head h2 { font-size: clamp(1.9rem, 8.5vw, 2.6rem); }
  .booth-head p { margin-top: 12px; }
  .date-aside h2, .booking-copy h2 { font-size: clamp(1.7rem, 8vw, 2.3rem); }
  .section-main h2, .pricing-section h2, .finder-copy h2, .faq-copy h2 { font-size: clamp(1.55rem, 7.5vw, 2.1rem); }
  .section-lede { font-size: .98rem; }
  /* Form più compatto */
  .booking-form label { gap: 5px; font-size: .92rem; }
  .booking-form input, .booking-form select { min-height: 46px; }
  .booking-form textarea { min-height: 84px; }
  .form-context { padding: 16px; }
  .booking-copy > p { font-size: .96rem; }
  /* Reel: griglia 2 colonne compatta invece di card grandi impilate */
  .feed-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
}

/* ---- Booking: campi facoltativi sotto toggle (form più corto, soprattutto mobile) ---- */
.form-optional { grid-column: 1 / -1; border-top: 1px solid var(--line); padding-top: 14px; margin-top: 4px; }
.form-optional > summary {
  cursor: pointer; list-style: none; display: inline-flex; align-items: center; gap: 9px;
  font-weight: 800; color: var(--cyan); padding: 6px 0; user-select: none;
}
.form-optional > summary::-webkit-details-marker { display: none; }
.form-optional > summary::before {
  content: "+"; display: inline-grid; place-items: center; width: 22px; height: 22px;
  border-radius: 50%; background: rgba(89,200,210,.12); box-shadow: inset 0 0 0 1px rgba(89,200,210,.4);
  font-size: 1.05rem; line-height: 1;
}
.form-optional[open] > summary::before { content: "\2013"; }
.form-optional > summary span { font-weight: 500; color: var(--muted); font-size: .86rem; }
.form-optional__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 16px; }
.form-optional__grid .full { grid-column: 1 / -1; }
@media (max-width: 600px) { .form-optional__grid { grid-template-columns: 1fr; } }

/* OPTIMIZATION PASS 2026-06-09 — mobile overflow fix + coerenza visiva */
.booth{overflow-x:hidden}
.console-stage{overflow-x:clip}
.site-footer{border-top:1px solid rgba(255,255,255,.08)}
.social-heading a{color:var(--cyan)}
.trust-band__press a{min-height:44px}
.date-section{border-top:1px solid rgba(89,200,210,.16)}
.thanks-prep{background:#13171b;color:#f4f0e8;position:relative;isolation:isolate;overflow:hidden}
.thanks-prep::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 80% at 100% 0,rgba(89,200,210,.10),transparent 55%),radial-gradient(80% 80% at 0 100%,rgba(240,95,139,.08),transparent 55%);pointer-events:none;z-index:0}
.thanks-prep>*{position:relative;z-index:1}
.thanks-prep h2{color:#fff}
.thanks-prep ul,.thanks-prep li{color:rgba(244,240,232,.74)}
.booking-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:clamp(20px,3vw,28px);box-shadow:0 18px 40px -28px rgba(16,17,19,.20)}
.faq-section{border-top:1px solid rgba(255,255,255,.10)}
.faq-copy .faq-pull{margin:22px 0 0;padding:14px 0 6px 20px;border-left:3px solid;border-image:linear-gradient(180deg,var(--cyan),var(--rose)) 1;font-family:'Playfair Display',serif;font-size:clamp(1.05rem,2.2vw,1.35rem);line-height:1.42;color:rgba(255,255,255,.82)}
.epk-materials article{position:relative;overflow:hidden}
.epk-materials article::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cyan),var(--rose));z-index:2}
.vertical-pricing .pricing-grid article{box-shadow:0 16px 38px -20px rgba(16,17,19,.30);border-color:rgba(16,17,19,.16)}
.epk-section.two-col>div{position:relative}
.epk-section.two-col h3{display:flex;align-items:center;gap:10px}
.epk-section.two-col h3::before{content:"";width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--rose));box-shadow:0 0 10px rgba(89,200,210,.55);flex:0 0 auto}
body{overflow-x:hidden} /* difensivo; vero fix = .home .faq-section qui sotto */
@media (max-width: 600px){
  .home .faq-section{grid-template-columns:1fr}
}

/* ============ TOP-TIER ELEVATION PASS — 2026-06-09 ============ */
/* P0-2 hero: soggetto protagonista (meno overlay, niente scanline) */
.home .hero-media{background:linear-gradient(90deg,rgba(0,0,0,.50),rgba(0,0,0,.10),rgba(0,0,0,.54)),var(--hero-image) center/cover}
.hero::after{background:radial-gradient(125% 95% at 50% 34%,transparent 52%,rgba(0,0,0,.52) 100%)}
/* P0-3 serif monumentale */
.home .hero h1{letter-spacing:-.035em;font-variant-ligatures:common-ligatures}
.epk-hero h1{letter-spacing:-.03em}
/* P1-9 gerarchia editoriale */
.section-lede{font-weight:500;font-style:italic}
.hero-line{font-weight:400;line-height:1.5;letter-spacing:.005em}
/* P1-7 console money-shot con profondità (no cutout) */
.console-scene{position:relative}
.console-piece img{filter:drop-shadow(0 16px 36px rgba(0,0,0,.72)) drop-shadow(0 2px 8px rgba(89,200,210,.16))}
.console-scene::after{content:"";position:absolute;left:50%;bottom:6%;transform:translateX(-50%);width:60%;height:9%;background:radial-gradient(60% 100% at 50% 50%,rgba(0,0,0,.5),transparent 72%);filter:blur(6px);z-index:1;pointer-events:none}
/* P1-10 hover differenziato */
.primary-btn{transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s ease}
.primary-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(57,215,212,.34)}
.ghost-btn:hover{transform:translateY(-1px);border-color:rgba(89,200,210,.55);background:rgba(89,200,210,.06)}
/* P1-4 oro = 3° colore premium sul kicker booth */
.booth-kicker{color:var(--gold);background:linear-gradient(180deg,rgba(200,159,79,.14),rgba(200,159,79,.05));box-shadow:inset 0 0 0 1px rgba(200,159,79,.34)}

/* Anti layout-shift: riserva lo spazio dei blocchi popolati via JS (feed reel,
   music tabs/player) così gli anchor (#date) non atterrano fuori bersaglio
   mentre il contenuto si carica. Anche CLS migliore per SEO. */
.feed-grid:empty { min-height: 451px; }
.music-tabs:empty { min-height: 118px; }
.music-player:empty { min-height: 214px; }
@media (max-width: 600px) {
  .feed-grid:empty { min-height: 340px; }
}
