/* ─────────────────────────────────────────────
   HERO
──────────────────────────────────────────────*/
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--white);
}

.hero-landing{
  background:url('images/banner-anna.jpg') center/cover no-repeat;
}

.hero::before{
  z-index:1;
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.45),
    rgba(0,0,0,.25),
    rgba(0,0,0,.55)
  );
}

.hero-overlay{
  z-index:2;
  text-align:center;
  width:100%;
  margin:0 auto;
}

.hero-logo{
  font-size:clamp(64px,9vw,140px);
  letter-spacing:0.28em;
  font-weight:450;
  margin:0 0 20px;
  color:var(--white);
}

.hero-tagline{
  max-width:740px;
  margin:0 auto;
  line-height:1.4;
  font-size:18px;
}

.hero-scroll{
  display:flex;
  align-items:center;
  justify-content:center;
  width:50px;
  height:50px;
  border-radius:50%;
  border:1px solid var(--white);
  font-size:24px;
  color:var(--white);
  margin:40px auto 0 auto;
}

/* video wrapper */
.hero-video-wrapper{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
}
.hero-video{
  width:100%;
  height:100%;
  object-fit:cover;
}
.desktop-only{ display:block; }
.mobile-only{ display:none; }
@media (max-width: 768px){
  .desktop-only{ display:none; }
  .mobile-only{ display:block; }
}

@media (max-width: 768px){
  .hero-logo{
    font-size: clamp(48px, 10vw, 64px);
    letter-spacing: 0.20em; /* riduce la larghezza totale */
    padding: 0 14px;        /* evita “taglio” ai bordi */
    max-width: 100%;
    box-sizing: border-box;
  }
}


/* ─────────────────────────────────────────────
   ABOUT
──────────────────────────────────────────────*/
.about{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);
  gap:40px;
  align-items:flex-start;
}
.about-col{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.about-col-right{
  padding-top:6.2rem;
}

.about-img-main{
  position:relative;
}
.about-img-main img,
.about-img-secondary img{
  width:100%;
  border-radius:0;
  object-fit:cover;
}

.about-img-title{
  position:absolute;
  top:20px;
  left:20px;
  z-index:2;
  font-size:28px;
  letter-spacing:0.12em;
  color:white;
  margin:0;
  text-shadow:0 2px 12px rgba(0,0,0,0.45);
}

/* ─────────────────────────────────────────────
   WORKSHOPS / GIFTCARDS
──────────────────────────────────────────────*/
.giftcards, .workshops {
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "image text";
  gap:40px;
  align-items:start;
}

.giftcards-img, .workshops-img{
  grid-area: image;
}

.giftcards-text, .workshops-text {
  grid-area: text;
  display:flex;
  flex-direction:column;
  gap:14px;
}


.workshops-list,
.giftcards-list{
  margin:0;
  padding-left:18px;
  list-style:disc;
  color: var(--muted);
}
.workshops-list li,
.giftcards-list li{
  margin-bottom:4px;
}

.workshops-note,
.giftcards-note{
  margin:10px 0 0;
  font-size:1em;
  color:var(--muted);
}

.workshops-img img,
.giftcards-img img{
  width:100%;
  border-radius:0;
  object-fit:cover;
}
/* ─────────────────────────────────────────────
   CONTACT (layout come screenshot)
──────────────────────────────────────────────*/
.contact-block h3{
  margin:0 0 22px 0;
}

.contact-grid-2{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:40px;
  align-items:start;
}

.contact-row{
  margin-bottom:18px;
}

.contact-label{
  font-size:16px;
  color:var(--text);
  margin-bottom:2px;
}

.contact-value{
  font-size:16px;
  color:var(--muted);
  line-height:1.35;
}

.contact-maplink{
  text-decoration:none;
  color:inherit;
}

.contact-maplink,
.contact-maplink:visited,
.contact-maplink:hover,
.contact-maplink:active{
  color: var(--muted);
}


.contact-hours{
  margin-top:6px;
  font-size:14px;
  color:var(--muted);
}

.contact-hours-days{
  font-size:16px;
  color:var(--muted);
  margin-bottom:6px;
}

.contact-hours-line{
  display:flex;
  align-items:center;
  gap:16px;
}

.contact-hours-time{
  font-size:16px;
  color:var(--muted);
}

.contact-hours-dash{
  height:1px;
  width:60px;
  background:#d1d5db;
}

.contact-map{
  border-radius:0;
  overflow:hidden;
}
.contact-map iframe{
  width:100%;
  height:320px;
  border:0;
}

/* icons row */
/* icons row: piccoli e centrati */
.contact-icons-row{
  margin-top:26px;
  display:flex;
  justify-content:center;
  gap:18px;
}

/* bottone piccolo (non barra larga) */
.contact-icon-btn{
  width:64px;
  height:64px;
  background:var(--btn-primary);
  border-radius:90%;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* icone PNG */
.contact-icon-btn img{
  width:84px;
  height:84px;
  display:block;
  object-fit:contain;
}


/* mobile: 1 colonna */
@media (max-width: 768px){
  .contact-grid-2{
    grid-template-columns: 1fr;
    gap:22px;
  }
  .contact-map iframe{
    height:260px;
  }
  .contact-icons-row{
    grid-template-columns: 1fr;
  }
}

/* ─────────────────────────────────────────────
   FIX: masterclass title not uppercase
──────────────────────────────────────────────*/
#workshops h3[data-i18n="workshops.scheduleTitle"]{
  text-transform:none !important;
  margin-top:32px;
}

#giftcards h3[data-i18n="giftcards.cardsTitle"]{
  text-transform:none !important;
  margin-top:32px;
}



.spacer{ display:block; }
.spacer-24{ height:24px; }

.contact-social{
  display:flex;
  justify-content:center;
  gap:18px;
  margin-top:24px;
}

.social-btn{
  width:78px;          /* “corto” */
  height:56px;
  background:var(--btn-primary);
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.social-btn img{
  width:30px;
  height:30px;
  object-fit:contain;
  background:transparent;
}

.cart-item__remove{
  margin-top:8px;
  border:1px solid var(--border);
  background:#fff;
  border-radius:10px;
  padding:6px 10px;
  cursor:pointer;
  color:var(--muted);
}

Удалить
