﻿/* ============================================
   ENOTECA CIPOLLA D'ORO
   ============================================ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

/* Reset Elementor wrapper per widget HTML full-width */
.elementor-widget-html .elementor-widget-container {
  width: 100%;
}
.elementor-widget-html {
  width: 100%;
}
/* Rimuovi padding di default da Elementor sulla sezione contenuto */
.elementor-location-single .elementor-widget-wrap,
.elementor-location-single .e-con-inner {
  padding: 0;
}
/* Pagina Elementor full-width senza gap */
.elementor.elementor-page .e-con {
  --padding-top: 0px;
  --padding-bottom: 0px;
  --padding-left: 0px;
  --padding-right: 0px;
}
/* Fix overflow per sezioni con posizionamento assoluto e sticky */
.elementor .e-con.e-parent {
  overflow: visible;
}
/* Fix per hero e wow sections che usano position absolute/fixed interni */
.elementor .e-con .hero,
.elementor .e-con .wow,
.elementor .e-con .cta,
.elementor .e-con .story,
.elementor .e-con .premium-hero {
  overflow: hidden;
}

:root {
  --bg:         #FAF8F5;
  --sand:       #E8E0D4;
  --sand-light: #F3EEE7;
  --ink:        #1A1610;
  --ink-2:      #5E5549;
  --ink-3:      #9E9184;
  --white:      #FEFDFB;
  --black:      #0F0D0B;
  --ease:       cubic-bezier(0.22, 1, 0.36, 1);
  --pad:        clamp(2rem, 5vw, 6rem);
}

html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: 'Inter', -apple-system, sans-serif; background: var(--bg); color: var(--ink); line-height: 1.7; overflow-x: hidden; }

/* Skip to content - Accessibility */
.skip-to-content {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--ink);
  color: var(--white);
  padding: 0.8rem 1.5rem;
  font-size: 0.9rem;
  font-weight: 500;
  z-index: 9999;
  transition: top 0.3s ease;
}
.skip-to-content:focus {
  top: 0;
}

img { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }

h1, h2, h3 { font-family: 'Playfair Display', Georgia, serif; font-weight: 400; font-style: italic; letter-spacing: -0.04em; line-height: 0.92; }
p { font-size: clamp(0.84rem, 1vw, 0.94rem); line-height: 1.8; color: var(--ink-2); font-weight: 300; }

/* ═══════════════════════════════════════
   NAV
   ═══════════════════════════════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  padding: 0 var(--pad);
  transition: background 0.6s var(--ease), box-shadow 0.6s var(--ease);
}
/* Nell'editor Elementor, l'header non deve essere fisso */
.elementor-editor-active .nav { position: relative; z-index: 1; }
.elementor-editor-active .nav__logo img { max-width: none !important; width: auto !important; }
.elementor-editor-active .nav__logo-light { height: 100px !important; }
.elementor-editor-active .nav__logo-dark { height: 60px !important; }
.elementor-editor-active .foot__logo { height: 90px !important; max-width: none !important; width: auto !important; }
/* Fix WooCommerce img reset sui loghi */
.woocommerce-page .nav__logo img,
.woocommerce-page .foot__logo,
body.single-product .nav__logo img,
body.single-product .foot__logo {
  max-width: none !important;
  width: auto !important;
}
.woocommerce-page .nav__logo-light,
body.single-product .nav__logo-light { height: 100px !important; }
.woocommerce-page .nav__logo-dark,
body.single-product .nav__logo-dark { height: 60px !important; }
.woocommerce-page .nav.is-solid .nav__logo-light,
body.single-product .nav.is-solid .nav__logo-light { height: 60px !important; }
.woocommerce-page .foot__logo,
body.single-product .foot__logo { height: 90px !important; }
.nav.is-solid {
  background: rgba(250,248,245,0.97);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 1px 0 rgba(26,22,16,0.06);
}
.nav__wrap {
  display: flex; align-items: center; justify-content: space-between;
  max-width: 1440px; margin: 0 auto;
  height: 130px; transition: height 0.6s var(--ease);
}
.nav.is-solid .nav__wrap { height: 80px; }

.nav__logo { position: relative; display: block; line-height: 0; flex-shrink: 0; }
.nav__logo img { display: block; transition: opacity 0.6s var(--ease), height 0.6s var(--ease); }
.nav__logo-light { height: 100px; opacity: 1; }
.nav__logo-dark { height: 60px; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); opacity: 0; }
.nav.is-solid .nav__logo-light { opacity: 0; height: 60px; }
.nav.is-solid .nav__logo-dark { opacity: 1; }
.nav__logo:hover img { opacity: 0.5; }

.nav__menu { display: flex; align-items: center; gap: clamp(1.4rem,2.5vw,3rem); }
.nav__menu a {
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 500; color: rgba(255,255,255,0.92);
  transition: color 0.5s var(--ease), opacity 0.5s var(--ease);
}
.nav.is-solid .nav__menu a { color: var(--ink-2); }
.nav__menu a:hover { opacity: 0.4; }

/* ── nav actions: search, burger ── */
.nav__actions {
  display: flex; align-items: center; gap: clamp(0.8rem,1.5vw,1.4rem);
}
.nav__icon {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; position: relative;
  background: none; border: none; cursor: pointer; padding: 0;
  color: rgba(255,255,255,0.85);
  transition: color 0.5s var(--ease), opacity 0.5s var(--ease);
}
.nav__icon:hover { opacity: 0.45; }
.nav__icon svg { display: block; }
.nav.is-solid .nav__icon { color: var(--ink-2); }
.nav__actions--dark .nav__icon { color: var(--ink-2); }
.nav__actions--dark .nav__icon:hover { opacity: 0.45; }
.nav__lang {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  transition: opacity 0.4s var(--ease);
  padding: 4px 0;
}
.nav__lang:hover { opacity: 0.45; }
.nav.is-solid .nav__lang { color: var(--ink-2); }
.nav__actions--dark .nav__lang { color: var(--ink-2); }

/* ── search overlay ── */
.search-overlay {
  position: fixed; inset: 0; z-index: 600;
  background: rgba(250,248,245,0.98);
  backdrop-filter: blur(32px); -webkit-backdrop-filter: blur(32px);
  display: none; flex-direction: column;
  align-items: center; justify-content: center;
  padding: var(--pad);
}
.search-overlay.is-open { display: flex; }
.search-overlay__wrap {
  width: 100%; max-width: 640px;
  display: flex; flex-direction: column;
  gap: clamp(1.5rem,3vw,2.5rem);
}
.search-overlay__label {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.search-overlay__field {
  display: flex; align-items: center;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 0.8rem; gap: 1rem;
}
.search-overlay__input {
  flex: 1; background: none; border: none; outline: none;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.8rem,4vw,3rem);
  color: var(--ink); letter-spacing: -0.02em;
}
.search-overlay__input::placeholder { color: var(--sand); }
.search-overlay__close {
  background: none; border: none; cursor: pointer;
  color: var(--ink-3); padding: 4px;
  transition: color 0.4s var(--ease);
}
.search-overlay__close:hover { color: var(--ink); }
.search-overlay__hints {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 0.8rem;
}
.search-overlay__hint-label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  margin-right: 0.4rem;
}
.search-overlay__hint {
  font-family: 'Inter', sans-serif; font-size: 0.72rem;
  font-weight: 400; color: var(--ink-2);
  padding: 0.4rem 1rem; border: 1px solid var(--sand);
  transition: all 0.4s var(--ease);
}
.search-overlay__hint:hover {
  background: var(--ink); color: var(--bg);
  border-color: var(--ink);
}

/* ── hamburger ── */
.nav__burger {
  display: none; background: none; border: none; cursor: pointer;
  width: 28px; height: 20px; position: relative; padding: 0;
  z-index: 501;
}
.nav__burger span {
  display: block; width: 100%; height: 2px;
  background: rgba(255,255,255,0.92);
  position: absolute; left: 0;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
              opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
              background 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.nav__burger span:first-child { top: 0; }
.nav__burger span:last-child { bottom: 0; }

/* Solid nav state */
.nav.is-solid .nav__burger span { background: var(--ink-2); }

/* Open state - Transform to X */
.nav__burger.is-open span:first-child { 
  top: 50%; 
  transform: translateY(-50%) rotate(45deg);
  background: var(--ink);
}
.nav__burger.is-open span:last-child { 
  bottom: auto; 
  top: 50%; 
  transform: translateY(-50%) rotate(-45deg);
  background: var(--ink);
}

/* ── mobile overlay ── */
.nav__overlay {
  display: none; position: fixed; inset: 0; z-index: 499;
  background: rgba(250,248,245,0.98);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  flex-direction: column; align-items: center; justify-content: center;
  gap: 2rem;
}
.nav__overlay.is-open { display: flex; }
.nav__overlay a {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.6rem,4vw,2.4rem);
  color: var(--ink); letter-spacing: -0.02em;
  transition: opacity 0.4s var(--ease);
}
.nav__overlay a:hover { opacity: 0.4; }

/* ═══════════════════════════════════════
   BUTTON
   ═══════════════════════════════════════ */
.btn {
  display: inline-block; padding: 1rem 3rem; border: 1px solid var(--ink);
  font-size: 0.6rem; letter-spacing: 0.24em; text-transform: uppercase;
  font-weight: 500; font-family: 'Inter', sans-serif; cursor: pointer;
  background: transparent; color: var(--ink);
  transition: background 0.5s var(--ease), color 0.5s var(--ease), border-color 0.5s var(--ease);
}
.btn:hover { background: var(--ink); color: var(--bg); }
.btn--ghost { border-color: rgba(255,255,255,0.45); background: transparent; color: rgba(255,255,255,0.9); }
.btn--ghost:hover { background: var(--white); color: var(--ink); border-color: var(--white); }

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero { position: relative; height: 100vh; height: 100dvh; min-height: 700px; overflow: hidden; background: var(--black); }
.hero__video { position: absolute; inset: 0; }
.hero__video-player {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}
.hero__video-player.is-active {
  opacity: 1;
  z-index: 1;
}
.hero__slides { position: absolute; inset: 0; }
.hero__slide { position: absolute; inset: 0; opacity: 0; }
.hero__slide.is-active { opacity: 1; }
.hero__slide img { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: none;
}
.hero__body { position: absolute; bottom: 0; left: 0; z-index: 2; padding: 0 var(--pad) clamp(3.5rem,8vh,8rem); }
.hero__label { display: block; font-family: 'Inter', sans-serif; font-size: 0.7rem; letter-spacing: 0.25em; text-transform: uppercase; font-weight: 500; color: rgba(255,255,255,0.45); margin-bottom: clamp(0.6rem,1.2vw,1rem); }
.hero__title { color: var(--white); font-size: clamp(2.8rem,7vw,7rem); max-width: 75vw; line-height: 0.92; letter-spacing: -0.03em; }
.hero__counter { position: absolute; bottom: clamp(3.5rem,8vh,8rem); right: var(--pad); z-index: 2; display: flex; align-items: center; gap: 0.8rem; }
.hero__current, .hero__total { font-family: 'Inter', sans-serif; font-size: 0.72rem; font-weight: 400; letter-spacing: 0.05em; color: rgba(255,255,255,0.5); }
.hero__current { color: rgba(255,255,255,0.9); }
.hero__sep { display: block; width: 28px; height: 1px; background: rgba(255,255,255,0.25); }

/* ═══════════════════════════════════════
   INTRO
   ═══════════════════════════════════════ */
.intro {
  padding: clamp(5rem, 10vw, 10rem) var(--pad);
}
.intro__wrap {
  max-width: 720px; margin: 0 auto; text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: clamp(1rem, 2vw, 1.6rem);
}
.intro__label { font-family: 'Inter', sans-serif; font-size: 0.62rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; }
.intro__heading { font-size: clamp(2.2rem, 5.5vw, 5rem); line-height: 1.0; letter-spacing: -0.03em; }
.intro__text { max-width: 480px; }

/* ═══════════════════════════════════════
   CATEGORIE — editorial / luxury
   ═══════════════════════════════════════ */
.cats {
  padding: clamp(4rem,8vw,8rem) 0 clamp(3rem,6vw,6rem);
  max-width: 1500px; margin: 0 auto;
}

/* ── row: image + text side-by-side ── */
.cats__row {
  display: grid; grid-template-columns: 1.2fr 0.8fr;
  gap: 0; align-items: center;
  margin-bottom: clamp(1.5rem,3vw,3rem);
}
.cats__row--flip {
  grid-template-columns: 0.8fr 1.2fr;
}

/* ── image frame ── */
.cats__frame {
  position: relative;
  overflow: hidden; 
  background: #000;
  line-height: 0;
}
.cats__frame img {
  width: 100%; 
  height: 100%; 
  object-fit: cover;
  aspect-ratio: 4/3;
  filter: saturate(0.92);
}

/* Slideshow styles - Simple and reliable */
.cats__slide {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1.5s ease-in-out, transform 0.6s ease-out;
  z-index: 1;
}

.cats__slide.is-active {
  position: relative;
  opacity: 1;
  z-index: 2;
}

/* Hover effects */
.cats__card:hover .cats__slide {
  transform: scale(1.05);
}

.cats__card:hover .cats__slide.is-active {
  filter: saturate(1.1) brightness(1.05);
}

.cats__frame--portrait img { aspect-ratio: 3/4; }
.cats__card:hover .cats__frame img {
  transform: scale(1.03);
  filter: saturate(1);
}

/* ── text block ── */
.cats__text {
  padding: clamp(2rem,4vw,5rem) clamp(2.5rem,5vw,6rem);
  display: flex; flex-direction: column;
  gap: clamp(0.6rem,1.2vw,1rem);
  justify-content: center;
}
.cats__text--end { align-items: flex-start; }

/* ── index number ── */
.cats__idx {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.3em;
  color: var(--ink-3); font-weight: 400;
  display: flex; align-items: center; gap: 1rem;
}
.cats__idx::after {
  content: ''; display: block;
  width: 32px; height: 1px; background: var(--sand);
}

/* ── category name ── */
.cats__name {
  font-size: clamp(2.4rem,5vw,5.5rem);
  line-height: 0.9; letter-spacing: -0.04em;
  color: var(--ink);
  transition: color 0.5s var(--ease);
}
.cats__card:hover .cats__name,
.cats__row:hover .cats__name { color: var(--ink-2); }

/* ── description ── */
.cats__desc {
  font-size: clamp(0.82rem,0.95vw,0.92rem);
  line-height: 1.8; color: var(--ink-2); font-weight: 300;
  max-width: 320px;
}

/* ── link / cta ── */
.cats__link {
  display: inline-flex; align-items: center; gap: 0.8rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.6rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 500; color: var(--ink);
  padding-top: 0.4rem;
  transition: gap 0.5s var(--ease), color 0.5s var(--ease);
}
.cats__link::after {
  content: '→'; display: inline-block;
  transition: transform 0.5s var(--ease);
}
.cats__card:hover .cats__link::after,
.cats__row:hover .cats__link::after { transform: translateX(4px); }
.cats__card:hover .cats__link,
.cats__row:hover .cats__link { color: var(--ink-2); }

/* ── duo: two portrait cards side-by-side ── */
.cats__duo {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem,3vw,3rem);
  padding: clamp(1.5rem,3vw,3rem) var(--pad) 0;
}
.cats__card--duo {
  display: flex; flex-direction: column;
}
.cats__meta {
  padding: clamp(1.2rem,2vw,1.8rem) 0 0;
  display: flex; flex-direction: column;
  gap: clamp(0.4rem,0.8vw,0.7rem);
}
.cats__card--duo .cats__name {
  font-size: clamp(1.6rem,3vw,2.8rem);
}
.cats__card--duo .cats__desc {
  max-width: 300px;
}

/* ═══════════════════════════════════════
   WOW
   ═══════════════════════════════════════ */
.wow { position: relative; height: 92vh; min-height: 550px; overflow: hidden; display: flex; align-items: flex-end; }
.wow__bg { position: absolute; inset: 0; background: var(--bg); }
.wow__bg img { width: 100%; height: 100%!important; object-fit: cover; }
.wow__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, transparent 35%, rgba(15,13,11,0.6) 100%); pointer-events: none; }
.wow__body { position: relative; z-index: 2; padding: clamp(2.5rem,5vw,5rem) var(--pad); display: flex; flex-direction: column; gap: clamp(0.6rem,1.2vw,1.2rem); }
.wow__tag { font-size: 0.62rem; letter-spacing: 0.28em; text-transform: uppercase; color: rgba(255,255,255,0.4); font-weight: 500; }
.wow__title { color: var(--white); font-size: clamp(3.5rem,11vw,12rem); line-height: 0.86; letter-spacing: -0.05em; max-width: 70vw; }

/* ═══════════════════════════════════════
   PRODOTTI
   ═══════════════════════════════════════ */
.prodotti { padding: clamp(5rem,10vw,10rem) var(--pad); }
.prodotti__head { text-align: center; margin-bottom: clamp(3rem,5vw,5rem); }
.prodotti__label { display: block; font-family: 'Inter', sans-serif; font-size: 0.62rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; margin-bottom: clamp(0.6rem,1vw,1rem); }
.prodotti__title { font-size: clamp(2rem,4.5vw,4rem); line-height: 1.0; letter-spacing: -0.03em; }
.prodotti__list { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(2.5rem,5vw,7rem); max-width: 1300px; margin: 0 auto; }
.prodotti__card { text-decoration: none; color: inherit; text-align: center; }
.prodotti__pic { aspect-ratio: 2/3; overflow: hidden; margin-bottom: 1.2rem; background: transparent; position: relative; }
.prodotti__pic img { width: 100%; height: 100% !important; object-fit: cover; transition: transform 0.8s var(--ease); }
.prodotti__card:hover .prodotti__pic img { transform: scale(1.02); }
.prodotti__card:hover .catalog__actions { opacity: 1; transform: translateY(0); }
.prodotti__card { text-decoration: none; color: inherit; text-align: center; }
.prodotti__info { display: block; text-decoration: none; color: inherit; text-align: center; }
.prodotti__name { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 1rem; display: block; margin-bottom: 0.25rem; }
.prodotti__price { font-size: 0.78rem; color: var(--ink-3); letter-spacing: 0.06em; }

/* ═══════════════════════════════════════
   STORY
   ═══════════════════════════════════════ */
.story { display: grid; grid-template-columns: 1.1fr 0.9fr; min-height: 70vh; }
.story__photo { overflow: hidden; background: transparent; }
.story__photo img { width: 100%; height: 100%; object-fit: cover; min-height: 450px; }
.story__body { display: flex; flex-direction: column; justify-content: center; padding: clamp(3rem,6vw,8rem); gap: 1.4rem; }
.story__tag { font-size: 0.62rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ink-3); font-weight: 500; }
.story__body h2 { font-size: clamp(2.2rem,5vw,5rem); line-height: 0.95; letter-spacing: -0.04em; }
.story__body p { max-width: 360px; }

/* ═══════════════════════════════════════
   CTA
   ═══════════════════════════════════════ */
.cta { position: relative; padding: clamp(5rem,10vw,10rem) var(--pad); text-align: center; overflow: hidden; }
.cta__bg { position: absolute; inset: 0; }
.cta__bg img { width: 100%; height: 100%!important; object-fit: cover; }
.cta__overlay { position: absolute; inset: 0; z-index: 1; background: rgba(15,13,11,0.55); pointer-events: none; }
.cta__wrap { position: relative; z-index: 2; max-width: 550px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: clamp(1rem,2vw,1.8rem); }
.cta__title { font-size: clamp(2.4rem,5.5vw,5rem); line-height: 1.0; letter-spacing: -0.03em; color: var(--white); }
.cta p { color: rgba(255,255,255,0.7); }

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.foot {
  background: var(--sand-light); color: var(--ink);
  padding: clamp(4rem,8vw,7rem) var(--pad) clamp(2rem,3vw,2.5rem);
}

/* ── brand block: logo + motto centrati ── */
.foot__brand {
  display: flex; flex-direction: column; align-items: center;
  gap: 1rem; text-align: center;
  margin-bottom: clamp(3rem,5vw,5rem);
}
.foot__logo { height: 90px; width: auto; opacity: 0.85; }
.foot__motto {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem;
  color: var(--ink-3); line-height: 1.5;
}

/* ── 4 columns ── */
.foot__cols {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem,4vw,4rem);
  max-width: 1100px; margin: 0 auto;
  padding-bottom: clamp(3rem,5vw,4.5rem);
}
.foot__col { display: flex; flex-direction: column; gap: 0.5rem; }
.foot__heading {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  font-style: normal; margin-bottom: 0.6rem;
}
.foot__col a, .foot__col p {
  font-size: 0.88rem; color: var(--ink-2);
  line-height: 1.7; font-weight: 300;
  transition: color 0.4s var(--ease);
}
.foot__col a:hover { color: var(--ink); }

/* ── divider ── */
.foot__line {
  width: 100%; height: 1px; max-width: 1100px; margin: 0 auto;
  background: var(--sand);
}

/* ── bottom bar ── */
.foot__bottom {
  display: flex; justify-content: space-between; align-items: center;
  max-width: 1100px; margin: 0 auto;
  padding-top: clamp(1.5rem,2.5vw,2rem);
}
.foot__bottom span {
  font-size: 0.58rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-3); font-weight: 400;
}
.foot__bottom a {
  color: var(--ink-3); text-decoration: none;
}
.foot__bottom a:hover {
  color: var(--gold);
}

/* Credits Clion */
.credits_link {
  color: #38B5E6 !important;
  font-weight: 700;
  font-family: sans-serif;
}
.credits_link:hover {
  color: #2c2c2c !important;
}
.credits_link::before {
  content: "";
  vertical-align: middle;
  width: 16px;
  height: 16px;
  display: inline-block;
  margin-right: 5px;
  margin-left: 5px;
  background-image: url(https://www.clion.it/favicon-96x96.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  transition: all 450ms ease;
}
.credits_link:hover::before {
  transform: rotateZ(360deg) rotateY(360deg);
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */

/* Tablet Large - 1024px */
@media (max-width: 1024px) {
  .cats__row, .cats__row--flip { grid-template-columns: 1fr 1fr; }
  .cats__text { padding: clamp(1.5rem,3vw,2.5rem) clamp(1.5rem,3vw,3rem); }
  .story { grid-template-columns: 1fr; }
  .foot__cols { grid-template-columns: repeat(2,1fr); }
  
  /* Hero adjustments */
  .hero__title { font-size: clamp(2.5rem,7vw,4rem); }
  .hero__subtitle { font-size: clamp(1rem,2.5vw,1.2rem); }
}

/* Tablet - 768px */
@media (max-width: 768px) {
  /* Navigation */
  .nav__menu { display: none; }
  .nav__burger { display: block; }
  .nav__actions { gap: 0.6rem; }
  .nav__wrap { height: 90px; padding: 0 clamp(1rem,4vw,2rem); }
  .nav.is-solid .nav__wrap { height: 64px; }
  .nav__logo-light { height: 70px; }
  .nav.is-solid .nav__logo-light { height: 44px; }
  .nav__logo-dark { height: 44px; }
  .nav__icon { width: 36px; height: 36px; }
  
  /* Hero */
  .hero { height: 85vh; min-height: 600px; }
  .hero__title { 
    font-size: clamp(2rem,6vw,3.5rem); 
    max-width: 92vw; 
    line-height: 1.15;
  }
  .hero__subtitle { font-size: clamp(0.95rem,2.2vw,1.1rem); }
  .hero__counter { display: none; }
  .hero__cta { padding: 0.9rem 2rem; font-size: 0.9rem; }
  
  /* Intro section */
  .intro { padding: clamp(4rem,8vw,6rem) var(--pad); }
  .intro__heading { font-size: clamp(1.8rem,5vw,3rem); line-height: 1.3; }
  .intro__text { font-size: clamp(1rem,2.5vw,1.15rem); }
  
  /* Categories */
  .cats { padding: clamp(3rem,6vw,5rem) 0; }
  .cats__row--a, .cats__row--b { grid-template-columns: 1fr; margin-left: 0; }
  .cats__row, .cats__row--flip { 
    grid-template-columns: 1fr; 
    gap: 0;
  }
  .cats__row--flip .cats__text { order: 2; }
  .cats__row--flip .cats__card { order: 1; }
  .cats__text { 
    padding: clamp(2rem,4vw,3rem) var(--pad); 
    text-align: center;
    align-items: center;
  }
  .cats__text--end { align-items: center; }
  .cats__name { font-size: clamp(2rem,5vw,2.8rem); }
  .cats__desc { font-size: clamp(0.95rem,2.2vw,1.05rem); }
  .cats__duo { 
    grid-template-columns: 1fr; 
    gap: clamp(2.5rem,5vw,4rem); 
    padding: clamp(1.5rem,3vw,3rem) 0 0; 
  }
  .cats__duo .cats__frame--portrait img { aspect-ratio: 4/3; }
  .cats__meta { 
    padding: clamp(1.5rem,3vw,2rem) var(--pad) 0; 
    text-align: center;
  }
  
  /* WOW sections */
  .wow { height: 75vh; min-height: 450px; }
  .wow__title { 
    font-size: clamp(2.8rem,11vw,5rem); 
    max-width: 90vw; 
    line-height: 1.1;
  }
  .wow__tag { font-size: 0.85rem; }
  .btn { padding: 0.9rem 2rem; font-size: 0.9rem; }
  
  /* Products section */
  .prodotti { padding: clamp(4rem,8vw,6rem) var(--pad); }
  .prodotti__title { font-size: clamp(2rem,5vw,3rem); }
  .prodotti__list { 
    grid-template-columns: 1fr; 
    gap: clamp(3rem,6vw,5rem); 
    max-width: 380px; 
    margin: 0 auto;
  }
  .prodotti__card { max-width: 100%; }
  
  /* Story section */
  .story { 
    grid-template-columns: 1fr; 
    min-height: auto;
  }
  .story__body { 
    padding: clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,3rem); 
    text-align: center;
  }
  .story__title { font-size: clamp(2rem,5vw,3rem); }
  
  /* Footer */
  .foot { padding: clamp(3rem,6vw,5rem) var(--pad) clamp(2rem,4vw,3rem); }
  .foot__cols { 
    grid-template-columns: repeat(2,1fr); 
    gap: clamp(2rem,4vw,3rem);
  }
  .foot__bottom { 
    flex-direction: column; 
    gap: 0.8rem; 
    text-align: center; 
    padding-top: 2rem;
  }
}

/* Mobile Large - 480px */
@media (max-width: 480px) {
  /* Navigation */
  .nav__wrap { padding: 0 1rem; }
  .nav__logo-light { height: 60px; }
  .nav.is-solid .nav__logo-light { height: 40px; }
  .nav__icon { width: 32px; height: 32px; }
  .nav__icon svg { width: 16px; height: 16px; }
  
  /* Hero */
  .hero { height: 80vh; min-height: 550px; }
  .hero__title { font-size: clamp(1.8rem,8vw,2.5rem); }
  .hero__subtitle { font-size: 0.9rem; }
  .hero__cta { padding: 0.85rem 1.8rem; font-size: 0.85rem; }
  
  /* Intro */
  .intro__heading { font-size: clamp(1.6rem,6vw,2.2rem); }
  .intro__text { font-size: 0.95rem; }
  
  /* Categories */
  .cats__name { font-size: clamp(1.8rem,6vw,2.4rem); }
  .cats__desc { font-size: 0.9rem; line-height: 1.6; }
  .cats__idx { font-size: 0.7rem; }
  .cats__link { font-size: 0.85rem; }
  
  /* WOW sections */
  .wow { height: 70vh; min-height: 400px; }
  .wow__title { font-size: clamp(2.4rem,10vw,3.5rem); }
  
  /* Products */
  .prodotti__title { font-size: clamp(1.8rem,6vw,2.5rem); }
  .prodotti__name { font-size: 0.95rem; }
  .prodotti__price { font-size: 1rem; }
  
  /* Footer */
  .foot__cols { 
    grid-template-columns: 1fr; 
    text-align: center; 
    gap: 2.5rem;
  }
  .foot__col { align-items: center; }
  .foot__col a { justify-content: center; }
  .foot__brand { text-align: center; align-items: center; }
  .foot__logo { height: 60px; }
}

/* Mobile Small - 375px */
@media (max-width: 375px) {
  .hero__title { font-size: 1.6rem; }
  .intro__heading { font-size: 1.5rem; }
  .cats__name { font-size: 1.8rem; }
  .wow__title { font-size: 2.2rem; }
  .prodotti__title { font-size: 1.7rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .rv, .rv-img { opacity: 1 !important; transform: none !important; clip-path: none !important; }
}

/* ═══════════════════════════════════════
   BLOG / ARCHIVE
   ═══════════════════════════════════════ */
.blog__hero {
  padding: clamp(8rem,12vh,11rem) var(--pad) clamp(2rem,4vh,3rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.5rem,1vw,0.8rem);
  border-bottom: 1px solid var(--sand);
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
}
.blog__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.blog__title {
  font-size: clamp(2.5rem,6vw,5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
}
.blog__desc {
  max-width: 500px;
  text-align: center;
}
.blog__content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--pad) clamp(4rem,8vw,6rem);
}
.blog__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: clamp(2rem,3vw,3rem);
}
.blog__card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.5s var(--ease);
}
.blog__card:hover { opacity: 0.7; }
.blog__card-img {
  aspect-ratio: 16/10;
  overflow: hidden;
  margin-bottom: 1rem;
}
.blog__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.blog__card:hover .blog__card-img img { transform: scale(1.03); }
.blog__card-body {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.blog__card-date {
  font-family: 'Inter', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.blog__card-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.1rem,1.8vw,1.4rem);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.2;
}
.blog__card-excerpt {
  font-size: 0.82rem;
  color: var(--ink-3);
  line-height: 1.6;
}
.blog__card-link {
  font-family: 'Inter', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 500;
  margin-top: 0.4rem;
}
.blog__pagination {
  margin-top: 3rem;
  display: flex;
  justify-content: center;
}

/* ═══════════════════════════════════════
   SINGLE POST
   ═══════════════════════════════════════ */
.post-single__hero {
  padding: clamp(8rem,12vh,11rem) var(--pad) clamp(2rem,4vh,3rem);
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.5rem,1vw,0.8rem);
}
.post-single__date {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.post-single__title {
  font-size: clamp(2.2rem,5vw,4rem);
  line-height: 1.0;
  letter-spacing: -0.03em;
}
.post-single__excerpt {
  max-width: 600px;
  text-align: center;
  font-size: 1rem;
  color: var(--ink-2);
}
.post-single__featured {
  max-width: 1000px;
  margin: 0 auto clamp(2.5rem,4vw,4rem);
  padding: 0 var(--pad);
}
.post-single__featured img {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.post-single__content {
  max-width: 700px;
  margin: 0 auto;
  padding: 0 var(--pad) clamp(3rem,5vw,4rem);
}
.post-single__content p {
  font-size: 0.95rem;
  line-height: 1.9;
  margin-bottom: 1.5rem;
}
.post-single__content h2 {
  font-size: clamp(1.5rem,3vw,2rem);
  margin: 2rem 0 0.8rem;
}
.post-single__content h3 {
  font-size: clamp(1.2rem,2vw,1.5rem);
  margin: 1.5rem 0 0.6rem;
}
.post-single__content img {
  margin: 1.5rem 0;
}
.post-single__content blockquote {
  border-left: 3px solid var(--sand);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--ink-2);
}
.post-single__footer {
  max-width: 700px;
  margin: 0 auto;
  padding: 0 var(--pad) clamp(4rem,6vw,5rem);
  border-top: 1px solid var(--sand);
  padding-top: 2rem;
}
.post-single__tags {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.post-single__tag {
  font-family: 'Inter', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border: 1px solid var(--sand);
  color: var(--ink-2);
  text-decoration: none;
  transition: all 0.4s var(--ease);
}
.post-single__tag:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.post-single__nav {
  display: flex;
  justify-content: space-between;
}
.post-single__nav-link {
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  color: var(--ink-2);
  text-decoration: none;
  transition: color 0.4s var(--ease);
}
.post-single__nav-link:hover { color: var(--ink); }

/* ═══════════════════════════════════════
   SEARCH RESULTS PAGE
   ═══════════════════════════════════════ */
.search-page {
  padding: 0 0 clamp(4rem,8vw,6rem);
}
.search-page__hero {
  padding: clamp(8rem,12vh,11rem) var(--pad) clamp(2rem,4vh,3rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.5rem,1vw,0.8rem);
  border-bottom: 1px solid var(--sand);
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
}
.search-page__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.search-page__title {
  font-size: clamp(2.5rem,6vw,4.5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.search-page__count {
  font-size: 0.85rem;
  color: var(--ink-3);
}
.search-page__content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--pad);
}
.search-page__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.search-page__card {
  display: flex;
  gap: 1rem;
  padding: 1.2rem;
  border: 1px solid var(--sand);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.4s var(--ease), background 0.4s var(--ease);
}
.search-page__card:hover {
  border-color: var(--ink);
  background: var(--sand-light);
}
.search-page__card--product {
  flex-direction: column;
  text-align: center;
  align-items: center;
}
.search-page__card-img {
  width: 100%;
  max-width: 180px;
  aspect-ratio: 2/3;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.search-page__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.search-page__card-info {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.search-page__card-type {
  font-family: 'Inter', sans-serif;
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.search-page__card-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1rem;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.3;
}
.search-page__card-price {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-2);
}
.search-page__card-excerpt {
  font-size: 0.8rem;
  color: var(--ink-3);
  line-height: 1.6;
}
.search-page__pagination {
  margin-top: 3rem;
  display: flex;
  justify-content: center;
}
.search-page__pagination .nav-links {
  display: flex;
  gap: 0.5rem;
}
.search-page__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  color: var(--ink-2);
  border: 1px solid var(--sand);
  text-decoration: none;
  transition: all 0.4s var(--ease);
}
.search-page__pagination .page-numbers.current,
.search-page__pagination .page-numbers:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.search-page__empty {
  text-align: center;
  padding: 3rem 0;
}
.search-page__empty-title {
  font-size: clamp(1.5rem,3vw,2rem);
  margin-bottom: 0.8rem;
}
.search-page__empty-links {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
}

/* ═══════════════════════════════════════
   404 PAGE
   ═══════════════════════════════════════ */
.error-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80vh;
  padding: clamp(6rem,12vh,10rem) var(--pad);
  text-align: center;
}
.error-page__wrap {
  max-width: 550px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.8rem,1.5vw,1.2rem);
}
.error-page__code {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(6rem,15vw,12rem);
  line-height: 0.85;
  letter-spacing: -0.05em;
  color: var(--sand);
  font-weight: 400;
}
.error-page__title {
  font-size: clamp(2rem,4vw,3rem);
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.error-page__desc {
  max-width: 400px;
  text-align: center;
}
.error-page__actions {
  display: flex;
  gap: 1rem;
  margin-top: 1rem;
}

@media (max-width: 480px) {
  .error-page__actions {
    flex-direction: column;
    width: 100%;
  }
  .error-page__actions .btn {
    width: 100%;
    text-align: center;
  }
}

/* ═══════════════════════════════════════
   INNER PAGES — NAV
   ═══════════════════════════════════════ */
.nav--inner {
  background: rgba(250,248,245,0.97);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 1px 0 rgba(26,22,16,0.06);
}
.nav--inner .nav__wrap { height: 80px; }
.nav__logo-dark--always {
  position: relative !important; top: auto !important; left: auto !important;
  transform: none !important; opacity: 1 !important; height: 60px;
}
.nav__menu--dark a { color: var(--ink-2) !important; }
.nav__menu--dark a.is-active { color: var(--ink) !important; }
.nav__burger--dark span { background: var(--ink-2) !important; }

/* ═══════════════════════════════════════
   PAGE HERO — minimal, text-only
   ═══════════════════════════════════════ */
.page-hero {
  padding: clamp(10rem,16vh,14rem) var(--pad) clamp(4rem,8vh,7rem);
  text-align: center;
  background: var(--bg);
  border-bottom: 1px solid var(--sand);
}
.page-hero__body {
  max-width: 700px; margin: 0 auto;
  display: flex; flex-direction: column; align-items: center;
  gap: clamp(0.8rem,1.5vw,1.4rem);
}
.page-hero__label {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.page-hero__title {
  font-size: clamp(3.5rem,9vw,8rem); line-height: 0.88;
  letter-spacing: -0.04em; color: var(--ink);
}
.page-hero__desc {
  max-width: 520px; text-align: center;
}

/* ═══════════════════════════════════════
   EDITORIAL SPLIT — image + text
   ═══════════════════════════════════════ */
.editorial {
  padding: clamp(4rem,8vw,8rem) 0;
  max-width: 1500px; margin: 0 auto;
}
.editorial__split {
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  gap: 0; align-items: center; min-height: 55vh;
}
.editorial__split--flip {
  grid-template-columns: 0.9fr 1.1fr;
}
.editorial__image {
  overflow: hidden; line-height: 0;
}
.editorial__image img {
  width: 100%; height: 100%; object-fit: cover;
  aspect-ratio: 4/3;
  filter: saturate(0.92);
  transition: transform 1.2s var(--ease);
}
.editorial__image:hover img { transform: scale(1.02); }
.editorial__text {
  padding: clamp(3rem,5vw,6rem);
  display: flex; flex-direction: column;
  gap: clamp(0.8rem,1.5vw,1.2rem);
}
.editorial__tag {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.editorial__heading {
  font-size: clamp(2.4rem,5vw,5rem); line-height: 0.95;
  letter-spacing: -0.04em;
}
.editorial__text p { max-width: 380px; }

/* ═══════════════════════════════════════
   CATALOG — filters + product grid
   ═══════════════════════════════════════ */
.catalog {
  padding: clamp(3rem,6vw,6rem) var(--pad) clamp(5rem,10vw,10rem);
  max-width: 1400px; margin: 0 auto;
}
.catalog__filters-bar {
  display: flex; flex-direction: column;
  gap: 1.2rem; margin-bottom: clamp(3rem,5vw,5rem);
  align-items: center;
}
.catalog__filters-row {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 0.4rem;
}
.catalog__selects {
  display: flex; gap: 0.8rem; justify-content: center;
  flex-wrap: wrap;
}
.catalog__select-wrap { position: relative; }
.catalog__select {
  appearance: none; -webkit-appearance: none;
  background: transparent;
  border: 1px solid var(--sand);
  padding: 0.7rem 2.5rem 0.7rem 1.2rem;
  font-family: 'Inter', sans-serif; font-size: 0.65rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 500; color: var(--ink-2);
  cursor: pointer; border-radius: 0;
  min-width: 160px;
  transition: border-color 0.4s var(--ease), color 0.4s var(--ease);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239E9184' stroke-width='1.2'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
}
.catalog__select:hover,
.catalog__select:focus {
  border-color: var(--ink); color: var(--ink);
  outline: none;
}
.catalog__select.has-value {
  border-color: var(--ink); color: var(--ink);
  background-color: var(--sand-light);
}
.catalog__filter {
  background: none; border: 1px solid var(--sand);
  padding: 0.7rem 1.8rem; cursor: pointer;
  font-family: 'Inter', sans-serif; font-size: 0.65rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 500; color: var(--ink-3);
  transition: all 0.4s var(--ease);
}
.catalog__filter:hover,
.catalog__filter.is-active {
  background: var(--ink); color: var(--bg);
  border-color: var(--ink);
}

.catalog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem,4vw,4rem) clamp(1.5rem,3vw,3rem);
}
.catalog__card {
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column;
  cursor: pointer;
}
.catalog__card .catalog__info {
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column; gap: 0.2rem;
}
.catalog__pic {
  aspect-ratio: 2/3; overflow: hidden;
  margin-bottom: 1rem; background: var(--sand-light);
}
.catalog__pic img {
  width: 100%; height: 100%!important; object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.catalog__card:hover .catalog__pic img { transform: scale(1.03); }
.catalog__info {
  display: flex; flex-direction: column; gap: 0.2rem;
}
.catalog__region {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.catalog__name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1rem,1.3vw,1.15rem);
  line-height: 1.3; color: var(--ink);
}
.catalog__producer {
  font-size: 0.78rem; color: var(--ink-3); font-weight: 300;
}
.catalog__price {
  font-family: 'Inter', sans-serif; font-size: 0.82rem;
  color: var(--ink-2); font-weight: 400;
  margin-top: 0.3rem; letter-spacing: 0.04em;
}
/* ── Quick actions on catalog cards ── */
.catalog__pic { position: relative; }
.catalog__actions {
  position: absolute; bottom: 0.8rem; right: 0.8rem;
  display: flex; gap: 0.5rem; opacity: 0;
  transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
  transform: translateY(6px);
}
.catalog__card:hover .catalog__actions {
  opacity: 1; transform: translateY(0);
}
.catalog__view,
.catalog__atc {
  width: 36px; height: 36px;
  background: var(--ink); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--white);
  transition: background 0.3s var(--ease);
  text-decoration: none;
}
.catalog__view:hover,
.catalog__atc:hover { background: var(--ink-2); }

/* hidden state for filter */
.catalog__card.is-hidden {
  display: none;
}
.catalog__empty {
  grid-column: 1 / -1;
  padding: clamp(3rem,6vw,5rem) 0;
  text-align: center;
  display: flex; flex-direction: column;
  align-items: center; gap: 1.5rem;
}
.catalog__reset-btn { cursor: pointer; }

/* ═══════════════════════════════════════
   PREMIUM HERO — full-bleed dark
   ═══════════════════════════════════════ */
.premium-hero {
  position: relative; height: 85vh; min-height: 600px;
  overflow: hidden; display: flex; align-items: flex-end;
  background: var(--black);
}
.premium-hero__bg {
  position: absolute; inset: 0;
}
.premium-hero__bg img {
  width: 100%; height: 100%!important; object-fit: cover;
}
.premium-hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(15,13,11,0.3) 0%, rgba(15,13,11,0.7) 100%);
  pointer-events: none;
}
.premium-hero__body {
  position: relative; z-index: 2;
  padding: clamp(3rem,6vw,6rem) var(--pad);
  display: flex; flex-direction: column;
  gap: clamp(0.6rem,1.2vw,1rem);
}
.premium-hero__label {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.4); font-weight: 500;
}
.premium-hero__title {
  color: var(--white); font-size: clamp(3.5rem,10vw,10rem);
  line-height: 0.88; letter-spacing: -0.05em;
}
.premium-hero__desc {
  color: rgba(255,255,255,0.6); max-width: 480px;
}

/* ═══════════════════════════════════════
   SHOWCASE — premium product editorial
   ═══════════════════════════════════════ */
.showcase {
  padding: clamp(4rem,8vw,8rem) 0;
  max-width: 1500px; margin: 0 auto;
}
.showcase__item {
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  gap: 0; align-items: center;
  margin-bottom: clamp(2rem,4vw,4rem);
  min-height: 70vh;
}
.showcase__item--flip {
  grid-template-columns: 0.9fr 1.1fr;
}
.showcase__image {
  overflow: hidden; line-height: 0; height: 100%;
}
.showcase__image img {
  width: 100%; height: 100%; object-fit: cover;
  min-height: 500px;
  filter: saturate(0.92);
  transition: transform 1.2s var(--ease);
}
.showcase__image:hover img { transform: scale(1.02); }
.showcase__body {
  padding: clamp(3rem,5vw,6rem);
  display: flex; flex-direction: column;
  gap: clamp(0.6rem,1vw,0.9rem);
}
.showcase__idx {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.3em; color: var(--ink-3); font-weight: 400;
  display: flex; align-items: center; gap: 1rem;
}
.showcase__idx::after {
  content: ''; display: block;
  width: 32px; height: 1px; background: var(--sand);
}
.showcase__category {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.showcase__name {
  font-size: clamp(2rem,4vw,3.8rem); line-height: 0.95;
  letter-spacing: -0.04em; color: var(--ink);
}
.showcase__producer {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem;
  color: var(--ink-2);
}
.showcase__desc {
  max-width: 380px; margin: 0.5rem 0;
}
.showcase__details {
  display: flex; flex-direction: column; gap: 0.5rem;
  padding: 1.2rem 0; border-top: 1px solid var(--sand);
  border-bottom: 1px solid var(--sand);
  margin: 0.5rem 0;
}
.showcase__detail {
  display: flex; gap: 1.5rem; align-items: baseline;
}
.showcase__detail-label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  min-width: 100px;
}
.showcase__detail-value {
  font-size: 0.85rem; color: var(--ink-2); font-weight: 300;
}
.showcase__price {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.6rem,2.5vw,2.2rem);
  color: var(--ink); letter-spacing: -0.02em;
}

/* ═══════════════════════════════════════
   CATALOG INTRO SECTION
   ═══════════════════════════════════════ */
.catalog-intro {
  display: grid; grid-template-columns: 1fr 1fr;
  max-width: 1400px; margin: 0 auto;
  background: var(--sand-light);
}
.catalog-intro__image {
  position: relative; overflow: hidden;
  min-height: 500px;
}
.catalog-intro__image img {
  width: 100%; height: 100%; object-fit: cover;
}
.catalog-intro__body {
  padding: clamp(3rem,6vw,6rem) clamp(2.5rem,5vw,5rem);
  display: flex; flex-direction: column;
  justify-content: center; gap: clamp(1.2rem,2vw,1.8rem);
}
.catalog-intro__label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.catalog-intro__title {
  font-size: clamp(2.5rem,5vw,4.5rem); line-height: 0.95;
  letter-spacing: -0.04em; color: var(--ink);
}
.catalog-intro__desc {
  font-size: clamp(0.88rem,1.1vw,1rem); line-height: 1.8;
  color: var(--ink-2); font-weight: 300;
  max-width: 480px;
}

@media (max-width: 768px) {
  .catalog-intro {
    grid-template-columns: 1fr;
  }
  .catalog-intro__image {
    min-height: 350px;
  }
}

/* ═══════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════ */
.contact {
  padding: clamp(4rem,8vw,8rem) var(--pad);
  max-width: 1300px; margin: 0 auto;
}
.contact__grid {
  display: grid; grid-template-columns: 0.45fr 0.55fr;
  gap: clamp(4rem,8vw,8rem);
  align-items: start;
}
.contact__info {
  display: flex; flex-direction: column;
  gap: clamp(2rem,3vw,3rem);
}
.contact__block {
  display: flex; flex-direction: column; gap: 0.4rem;
}
.contact__label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.contact__value {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.2rem,2vw,1.6rem);
  line-height: 1.3; letter-spacing: -0.02em;
  font-weight: 400;
}
.contact__value a {
  transition: opacity 0.4s var(--ease);
}
.contact__value a:hover { opacity: 0.5; }
.contact__social {
  display: flex; gap: 1.5rem;
}
.contact__social-link {
  font-family: 'Inter', sans-serif; font-size: 0.78rem;
  color: var(--ink-2); font-weight: 400;
  transition: color 0.4s var(--ease);
}
.contact__social-link:hover { color: var(--ink); }

/* ── Form ── */
.contact__form-wrap {
  display: flex; flex-direction: column;
  gap: clamp(0.8rem,1.5vw,1.2rem);
}
.contact__form-label {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.contact__form-title {
  font-size: clamp(2rem,4vw,3.5rem); line-height: 0.95;
  letter-spacing: -0.04em; margin-bottom: 0.5rem;
}
.contact__form {
  display: flex; flex-direction: column;
  gap: 1.5rem;
}
.form__group {
  display: flex; flex-direction: column; gap: 0.4rem;
}
.form__label {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.form__input {
  font-family: 'Inter', sans-serif; font-size: 0.88rem;
  font-weight: 300; color: var(--ink);
  background: transparent;
  border: none; border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0; outline: none;
  transition: border-color 0.4s var(--ease);
  -webkit-appearance: none; appearance: none;
  border-radius: 0;
  width: 100%!important;
}
.form__input:focus { border-color: var(--ink); }
.form__input::placeholder { color: var(--ink-3); }
.form__select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%239E9184' stroke-width='1.2'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding-right: 1.5rem;
}
/* CF7 select override */
.contact__form select,
.wpcf7 select,
.form__group select {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 1.5rem 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%239E9184' stroke-width='1.2'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  transition: border-color 0.4s var(--ease);
}
.contact__form select:focus,
.wpcf7 select:focus,
.form__group select:focus {
  border-color: var(--ink);
}
/* Stile opzioni nel dropdown (limitato dai browser) */
.contact__form select option,
.wpcf7 select option {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  padding: 0.5rem;
  background: var(--bg);
  color: var(--ink);
}

/* CF7 general overrides */
.wpcf7 .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  transition: border-color 0.4s var(--ease);
  box-shadow: none;
}
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus {
  border-color: var(--ink);
}
.wpcf7 textarea {
  border: 1px solid var(--sand);
  padding: 1rem;
  min-height: 120px;
  resize: vertical;
}
.wpcf7 textarea:focus {
  border-color: var(--ink);
}
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder {
  color: var(--ink-3);
  font-weight: 300;
}
/* CF7 submit button */
.wpcf7 input[type="submit"],
.wpcf7 .wpcf7-submit {
  display: inline-block;
  padding: 1rem 3rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: transparent;
  color: var(--ink);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
  -webkit-appearance: none;
}
.wpcf7 input[type="submit"]:hover,
.wpcf7 .wpcf7-submit:hover {
  background: var(--ink);
  color: var(--bg);
}
/* CF7 messaggi validazione */
.wpcf7-not-valid-tip {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  color: #c33;
  margin-top: 0.3rem;
}
.wpcf7-response-output {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  border: 1px solid var(--sand) !important;
  padding: 1rem !important;
  margin: 1rem 0 0 !important;
  border-radius: 0 !important;
}
.form__textarea {
  resize: vertical; min-height: 120px;
  border: 1px solid var(--sand); padding: 1rem;
}
.form__textarea:focus { border-color: var(--ink); }

/* ── Map ── */
.map {
  position: relative; height: 50vh; min-height: 350px;
  overflow: hidden;
}
.map__frame {
  width: 100%; height: 100%; position: relative;
}
.map__placeholder {
  width: 100%; height: 100%!important; object-fit: cover;
  filter: saturate(0.7) brightness(0.85);
}
.map__overlay-text {
  position: absolute; bottom: clamp(2rem,4vw,3rem);
  left: var(--pad); z-index: 2;
  display: flex; align-items: center; gap: 0.8rem;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1rem,1.5vw,1.3rem);
  color: var(--white);
  background: rgba(15,13,11,0.6);
  padding: 1rem 1.8rem;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.map__pin { font-style: normal; font-size: 1.2rem; }

/* ═══════════════════════════════════════
   BREADCRUMB
   ═══════════════════════════════════════ */
.breadcrumb {
  padding: clamp(7rem,12vh,10rem) var(--pad) 0;
  max-width: 1400px; margin: 0 auto;
  display: flex; align-items: center; gap: 0.6rem;
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 500;
}
.breadcrumb a {
  color: var(--ink-3);
  transition: color 0.4s var(--ease);
}
.breadcrumb a:hover { color: var(--ink); }
.breadcrumb__sep { color: var(--sand); }
.breadcrumb__current { color: var(--ink); }

/* ═══════════════════════════════════════
   PRODUCT PAGE
   ═══════════════════════════════════════ */
.product {
  padding: clamp(2rem,4vw,4rem) var(--pad) clamp(5rem,10vw,10rem);
  max-width: 1400px; margin: 0 auto;
}
.product__grid {
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(3rem,6vw,6rem); align-items: start;
}
.product__gallery {
  display: flex; flex-direction: column; gap: 1rem;
  position: sticky; top: 100px;
}
.product__main-img {
  aspect-ratio: 3/4; overflow: hidden;
  background: var(--sand-light);
}
.product__main-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.product__thumbs {
  display: flex; gap: 0.8rem;
}
.product__thumb {
  width: 72px; height: 72px; overflow: hidden;
  border: 1px solid var(--sand); cursor: pointer;
  background: none; padding: 0;
  opacity: 0.5;
  transition: opacity 0.4s var(--ease), border-color 0.4s var(--ease);
}
.product__thumb.is-active,
.product__thumb:hover {
  opacity: 1; border-color: var(--ink);
}
.product__thumb img {
  width: 100%; height: 100%; object-fit: cover;
}

/* ── Product info ── */
.product__info {
  display: flex; flex-direction: column;
  gap: clamp(0.5rem,1vw,0.8rem);
  padding-top: 1rem;
}
.product__category {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.product__name {
  font-size: clamp(2.4rem,5vw,4.5rem); line-height: 0.92;
  letter-spacing: -0.04em;
}
.product__producer {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem;
  color: var(--ink-2); margin-bottom: 0.5rem;
}
.product__price {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.8rem,3vw,2.5rem);
  color: var(--ink); letter-spacing: -0.02em;
}
.product__desc {
  max-width: 440px; margin: 0.5rem 0;
}

/* ── Specs ── */
.product__specs {
  display: flex; flex-direction: column;
  padding: 1.5rem 0; margin: 0.5rem 0;
  border-top: 1px solid var(--sand);
  border-bottom: 1px solid var(--sand);
  gap: 0.6rem;
}
.product__spec {
  display: flex; gap: 1.5rem; align-items: baseline;
}
.product__spec-label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  min-width: 110px;
}
.product__spec-value {
  font-size: 0.85rem; color: var(--ink-2); font-weight: 300;
}

/* ═══════════════════════════════════════
   TASTING NOTES
   ═══════════════════════════════════════ */
.tasting {
  background: var(--sand-light);
  padding: clamp(5rem,10vw,10rem) var(--pad);
}
.tasting__wrap {
  max-width: 1200px; margin: 0 auto;
}
.tasting__label {
  display: block; text-align: center;
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  margin-bottom: clamp(3rem,5vw,5rem);
}
.tasting__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(2rem,4vw,4rem);
}
.tasting__note {
  display: flex; flex-direction: column; gap: 0.8rem;
}
.tasting__title {
  font-size: clamp(1.2rem,2vw,1.6rem); line-height: 1.1;
  letter-spacing: -0.02em;
}

/* ═══════════════════════════════════════
   RELATED PRODUCTS
   ═══════════════════════════════════════ */
.related {
  padding: clamp(5rem,10vw,10rem) var(--pad);
  max-width: 1300px; margin: 0 auto;
}
.related__head {
  text-align: center; margin-bottom: clamp(3rem,5vw,5rem);
}
.related__label {
  display: block; font-family: 'Inter', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.28em;
  text-transform: uppercase; color: var(--ink-3);
  font-weight: 500; margin-bottom: clamp(0.6rem,1vw,1rem);
}
.related__title {
  font-size: clamp(2rem,4.5vw,4rem); line-height: 1.0;
  letter-spacing: -0.03em;
}
.related__list {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(2.5rem,5vw,7rem);
}

/* ═══════════════════════════════════════
   INNER PAGES — RESPONSIVE
   ═══════════════════════════════════════ */
@media (max-width: 1024px) {
  .editorial__split,
  .editorial__split--flip { grid-template-columns: 1fr 1fr; }
  .showcase__item,
  .showcase__item--flip { grid-template-columns: 1fr 1fr; }
  .showcase__body { padding: clamp(2rem,3vw,3rem); }
  .contact__grid { grid-template-columns: 1fr 1fr; gap: clamp(3rem,5vw,5rem); }
  .product__grid { grid-template-columns: 1fr 1fr; gap: clamp(2rem,4vw,4rem); }
  .tasting__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .page-hero { padding: clamp(8rem,14vh,11rem) var(--pad) clamp(3rem,6vh,5rem); }
  .page-hero__title { font-size: clamp(2.8rem,8vw,5rem); }

  .editorial__split,
  .editorial__split--flip { grid-template-columns: 1fr; }
  .editorial__text { padding: clamp(2rem,4vw,3rem) var(--pad); }

  .catalog__grid { grid-template-columns: 1fr 1fr; }
  .catalog__filters { gap: 0.4rem; }
  .catalog__filter { padding: 0.5rem 1.2rem; font-size: 0.58rem; }

  .premium-hero { height: 65vh; min-height: 450px; }
  .premium-hero__title { font-size: clamp(2.8rem,9vw,5rem); }

  .showcase__item,
  .showcase__item--flip { grid-template-columns: 1fr; min-height: auto; }
  .showcase__image img { min-height: 350px; }
  .showcase__body { padding: clamp(2rem,4vw,3rem) var(--pad); }

  .contact__grid { grid-template-columns: 1fr; }

  .product__grid { grid-template-columns: 1fr; }
  .product__gallery { position: static; }

  .tasting__grid { grid-template-columns: 1fr; }

  .related__list { grid-template-columns: 1fr; max-width: 380px; margin: 0 auto; gap: clamp(3rem,6vw,5rem); }
}

@media (max-width: 480px) {
  .catalog__grid { grid-template-columns: 1fr; max-width: 380px; margin: 0 auto; }
}

/* ═══════════════════════════════════════
   PAGE HERO — compact variant
   ═══════════════════════════════════════ */
.page-hero--compact {
  padding: clamp(9rem,14vh,12rem) var(--pad) clamp(3rem,5vh,5rem);
  border-bottom: 1px solid var(--sand);
}
.page-hero--compact .page-hero__title {
  font-size: clamp(2.8rem,7vw,6rem);
}

/* ═══════════════════════════════════════
   VALUES (chi-siamo)
   ═══════════════════════════════════════ */
.values {
  background: var(--sand-light);
  padding: clamp(5rem,10vw,10rem) var(--pad);
}
.values__wrap { max-width: 1200px; margin: 0 auto; }
.values__label {
  display: block; text-align: center;
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
  margin-bottom: clamp(3rem,5vw,5rem);
}
.values__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(2rem,4vw,4rem);
}
.values__item { display: flex; flex-direction: column; gap: 0.8rem; }
.values__idx {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.3em; color: var(--ink-3);
}
.values__title {
  font-size: clamp(1.2rem,2vw,1.6rem); line-height: 1.1;
  letter-spacing: -0.02em;
}

/* ═══════════════════════════════════════
   NUMBERS (chi-siamo)
   ═══════════════════════════════════════ */
.numbers {
  padding: clamp(5rem,10vw,10rem) var(--pad);
}
.numbers__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(2rem,4vw,4rem);
  max-width: 1100px; margin: 0 auto;
  text-align: center;
}
.numbers__item { display: flex; flex-direction: column; gap: 0.5rem; }
.numbers__value {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(2.5rem,5vw,4.5rem);
  line-height: 1; letter-spacing: -0.04em; color: var(--ink);
}
.numbers__label {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}

/* ═══════════════════════════════════════
   PRODUCERS
   ═══════════════════════════════════════ */
.producers {
  padding: clamp(3rem,6vw,5rem) var(--pad) clamp(5rem,10vw,10rem);
  max-width: 1400px; margin: 0 auto;
}
.producers__grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: clamp(2rem,4vw,4rem);
}
.producers__card {
  display: flex; flex-direction: column;
  transition: opacity 0.5s var(--ease);
}
.producers__card:hover { opacity: 0.85; }
.producers__img {
  aspect-ratio: 16/9; overflow: hidden;
  margin-bottom: 1.2rem; background: var(--sand-light);
}
.producers__img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.producers__card:hover .producers__img img { transform: scale(1.03); }
.producers__info { display: flex; flex-direction: column; gap: 0.3rem; }
.producers__region {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.producers__name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: clamp(1.3rem,2vw,1.8rem);
  line-height: 1.15; letter-spacing: -0.02em; color: var(--ink);
}
.producers__desc {
  font-size: 0.82rem; color: var(--ink-2); font-weight: 300;
  max-width: 380px; margin: 0.2rem 0 0.4rem;
}

/* ── Producer detail hero ── */
.producer-hero {
  padding: clamp(8rem,12vh,10rem) var(--pad) clamp(4rem,8vw,6rem);
  max-width: 1400px; margin: 0 auto;
}
.producer-hero__grid {
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(3rem,6vw,6rem); align-items: center;
}
.producer-hero__image {
  overflow: hidden; line-height: 0;
}
.producer-hero__image img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover;
}
.producer-hero__body {
  display: flex; flex-direction: column;
  gap: clamp(0.5rem,1vw,0.8rem);
}
.producer-hero__region {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.producer-hero__name {
  font-size: clamp(2.4rem,5vw,5rem); line-height: 0.92;
  letter-spacing: -0.04em;
}
.producer-hero__desc {
  max-width: 420px; margin: 0.3rem 0;
}
.producer-hero__details {
  display: flex; flex-direction: column; gap: 0.5rem;
  padding: 1.2rem 0; border-top: 1px solid var(--sand);
  margin-top: 0.5rem;
}

/* ═══════════════════════════════════════
   LEGAL / INFO PAGES
   ═══════════════════════════════════════ */
.legal {
  padding: clamp(3rem,6vw,5rem) var(--pad) clamp(5rem,10vw,10rem);
}
.legal__wrap {
  max-width: 1400px; margin: 0 auto;
  display: flex; flex-direction: column;
  gap: clamp(2.5rem,4vw,3.5rem);
}
.legal__intro p {
  font-size: clamp(0.92rem,1.1vw,1.05rem);
  line-height: 1.8; color: var(--ink-2);
}
.legal__section { display: flex; flex-direction: column; gap: 1rem; }
.legal__section h2 {
  font-size: clamp(1.3rem,2.5vw,1.8rem); line-height: 1.1;
  letter-spacing: -0.02em; padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--sand);
}
.legal__section h3 {
  font-size: 1rem; font-style: normal; font-weight: 500;
  font-family: 'Inter', sans-serif; letter-spacing: 0;
  line-height: 1.4;
}
.legal__link {
  color: var(--ink); text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.4s var(--ease);
}
.legal__link:hover { opacity: 0.5; }
.legal__list {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.legal__list li {
  padding-left: 1.2rem; position: relative;
  font-size: clamp(0.84rem,1vw,0.94rem);
  color: var(--ink-2); font-weight: 300; line-height: 1.8;
}
.legal__list li::before {
  content: '—'; position: absolute; left: 0;
  color: var(--ink-3);
}
.legal__meta {
  padding-top: 1rem; border-top: 1px solid var(--sand);
}
.legal__meta p {
  font-size: 0.72rem; color: var(--ink-3);
  letter-spacing: 0.1em;
}
.legal__cta {
  padding: 1.5rem 2rem; background: var(--sand-light);
  text-align: center;
}
.legal__cta p { font-size: 0.88rem; color: var(--ink-2); }

/* ── Legal steps (recesso) ── */
.legal__steps {
  display: flex; flex-direction: column; gap: 1.5rem;
}
.legal__step {
  display: flex; gap: 1.5rem; align-items: flex-start;
}
.legal__step-num {
  font-family: 'Inter', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.3em; color: var(--ink-3);
  min-width: 32px; padding-top: 0.3rem;
}

/* ── Legal table ── */
.legal__table-wrap { overflow-x: auto; }
.legal__table {
  width: 100%; border-collapse: collapse;
}
.legal__table th,
.legal__table td {
  text-align: left; padding: 0.8rem 1rem;
  font-size: 0.82rem; border-bottom: 1px solid var(--sand);
}
.legal__table th {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--bg); font-weight: 500;
  background: var(--ink);
}
.legal__table-subheader th {
  background: var(--sand-light);
  color: var(--ink-3);
}

.legal__table td { color: var(--ink-2); font-weight: 300; }
.legal__table-footer td {
  background: var(--sand-light);
  color: var(--ink-3);
}

/* ── Info cards (spedizioni, pagamenti) ── */
.info-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.info-card {
  border: 1px solid var(--sand); padding: 1.5rem;
  display: flex; flex-direction: column; gap: 0.5rem;
}
.info-card__icon { font-size: 1.5rem; margin-bottom: 0.3rem; }
.info-card__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1.1rem;
  letter-spacing: -0.02em;
}
.info-card__detail {
  font-family: 'Inter', sans-serif; font-size: 0.72rem;
  font-weight: 500; color: var(--ink); letter-spacing: 0.05em;
}

/* ═══════════════════════════════════════
   NEW PAGES — RESPONSIVE
   ═══════════════════════════════════════ */
@media (max-width: 1024px) {
  .producer-hero__grid { grid-template-columns: 1fr 1fr; }
  .values__grid { grid-template-columns: repeat(2, 1fr); }
  .numbers__grid { grid-template-columns: repeat(2, 1fr); }
  .info-cards { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .form__row { flex-direction: column; gap: 1.2rem; }

  .producers__grid { grid-template-columns: 1fr; }
  .producer-hero__grid { grid-template-columns: 1fr; }
  .producer-hero__image { order: -1; }

  .values__grid { grid-template-columns: 1fr; }
  .numbers__grid { grid-template-columns: 1fr 1fr; }
  .info-cards { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════
   PAGINATION
   ============================================ */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: clamp(3rem, 5vw, 4rem);
  padding: 2.5rem 0;
  flex-wrap: wrap;
}

.pagination__btn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--paper);
  border: 1.5px solid rgba(0, 0, 0, 0.12);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.pagination__btn svg {
  width: 18px;
  height: 18px;
  stroke: var(--ink);
  stroke-width: 2;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.pagination__btn:hover:not(:disabled) {
  background: var(--ink);
  border-color: var(--ink);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.pagination__btn:hover:not(:disabled) svg {
  stroke: var(--paper);
}

.pagination__btn:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.pagination__btn:disabled {
  cursor: not-allowed;
  opacity: 0.25;
  background: rgba(0, 0, 0, 0.02);
}

.pagination__numbers {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0.75rem;
}

.pagination__number {
  min-width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1.5px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 0 0.9rem;
  position: relative;
}

.pagination__number::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.04);
  opacity: 0;
  transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: -1;
}

.pagination__number:hover::before {
  opacity: 1;
}

.pagination__number:hover {
  color: var(--ink);
  transform: translateY(-1px);
}

.pagination__number.is-active {
  background: var(--ink);
  border-color: var(--ink);
  color: #FFFFFF !important;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.pagination__number.is-active::before {
  opacity: 0;
}

.pagination__number.is-active:hover {
  transform: none;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  color: #FFFFFF !important;
}

.pagination__dots {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--ink-3);
  padding: 0 0.5rem;
  letter-spacing: 0.1em;
}

.pagination__info {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--ink-3);
  margin-left: 1.25rem;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

@media (max-width: 768px) {
  .pagination {
    gap: 0.5rem;
    padding: 2rem 0;
  }
  
  .pagination__btn {
    width: 40px;
    height: 40px;
  }
  
  .pagination__btn svg {
    width: 16px;
    height: 16px;
  }
  
  .pagination__number {
    min-width: 40px;
    height: 40px;
    font-size: 0.85rem;
    padding: 0 0.75rem;
  }
  
  .pagination__numbers {
    margin: 0 0.5rem;
    gap: 0.4rem;
  }
  
  .pagination__info {
    width: 100%;
    text-align: center;
    margin: 0.75rem 0 0 0;
    font-size: 0.78rem;
  }
}

@media (max-width: 480px) {
  .pagination__btn {
    width: 36px;
    height: 36px;
  }
  
  .pagination__number {
    min-width: 36px;
    height: 36px;
    font-size: 0.8rem;
    padding: 0 0.6rem;
  }
  
  .pagination__numbers {
    gap: 0.3rem;
  }
}


/* ═══════════════════════════════════════


/* ═══════════════════════════════════════
   WOOCOMMERCE — Solo pagine native (non Elementor)
   ═══════════════════════════════════════ */

/* Padding-top SOLO su pagine WooCommerce native (non gestite da Elementor) */
.wc-page-content {
  padding-top: clamp(8rem, 14vh, 12rem);
  padding-left: var(--pad);
  padding-right: var(--pad);
  padding-bottom: clamp(4rem, 8vw, 6rem);
  max-width: 1400px;
  margin: 0 auto;
}

body.single-product:not(.elementor-page) .wc-page-content {
  padding-top: clamp(7rem, 12vh, 10rem);
}

body.single-product:not(.elementor-page) .woocommerce {
  padding-top: clamp(7rem, 12vh, 10rem);
}

/* Titoli WooCommerce */
body.woocommerce-page:not(.elementor-page) .woocommerce h1,
body.woocommerce-page:not(.elementor-page) .woocommerce h2 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 400;
  font-style: italic;
  letter-spacing: -0.04em;
}

body.woocommerce-page:not(.elementor-page) .product_title {
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 0.95;
  margin-bottom: 1rem;
}

/* Prezzi */
body.woocommerce-page:not(.elementor-page) .price {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  color: var(--ink);
}

body.woocommerce-page:not(.elementor-page) .price del { color: var(--ink-3); font-size: 0.8em; }
body.woocommerce-page:not(.elementor-page) .price ins { text-decoration: none; }

/* Pulsanti WooCommerce nativi */
body.woocommerce-page:not(.elementor-page) .woocommerce .button,
body.woocommerce-page:not(.elementor-page) .woocommerce a.button,
body.woocommerce-page:not(.elementor-page) .woocommerce button.button,
body.woocommerce-page:not(.elementor-page) .woocommerce input.button {
  display: inline-block;
  padding: 0.9rem 2.5rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: var(--ink);
  color: var(--bg);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
}

body.woocommerce-page:not(.elementor-page) .woocommerce .button:hover,
body.woocommerce-page:not(.elementor-page) .woocommerce a.button:hover {
  background: transparent;
  color: var(--ink);
}

/* Badge sconto */
body.woocommerce-page:not(.elementor-page) span.onsale {
  background: var(--ink);
  color: var(--bg);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-family: 'Inter', sans-serif;
  padding: 0.4rem 0.8rem;
  border-radius: 0;
  min-height: auto;
  min-width: auto;
  line-height: 1.4;
}

/* Form WooCommerce */
body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row label {
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}

body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row input.input-text,
body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row textarea,
body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row select {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  background: transparent;
  border-radius: 0;
  width: 100%;
}

body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row input.input-text:focus,
body.woocommerce-page:not(.elementor-page) .woocommerce form .form-row select:focus {
  border-color: var(--ink);
  outline: none;
  box-shadow: none;
}

/* Account navigation — override handled by .acct__nav styles */

/* Tabella carrello */
body.woocommerce-page:not(.elementor-page) .woocommerce table.shop_table {
  border: none;
  border-collapse: collapse;
}

body.woocommerce-page:not(.elementor-page) .woocommerce table.shop_table th,
body.woocommerce-page:not(.elementor-page) .woocommerce table.shop_table td {
  border-bottom: 1px solid var(--sand);
  padding: 1rem;
  font-size: 0.85rem;
}

body.woocommerce-page:not(.elementor-page) .woocommerce table.shop_table th {
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}

/* Messaggi */
body.woocommerce-page:not(.elementor-page) .woocommerce-message,
body.woocommerce-page:not(.elementor-page) .woocommerce-info,
body.woocommerce-page:not(.elementor-page) .woocommerce-error {
  border-top: none;
  border-left: 3px solid var(--ink);
  background: var(--sand-light);
  padding: 1rem 1.5rem !important;
  font-size: 0.85rem;
}

.woocommerce-error li{padding-left: 15px !important;}

.woocommerce-info::before{display: none !important;}

@media (max-width: 768px) {
  body.woocommerce-page:not(.elementor-page) .woocommerce {
    padding-top: clamp(6rem, 10vh, 8rem);
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }
}


/* Fix: override WooCommerce img reset sui loghi nav/footer */


/* ═══════════════════════════════════════
   CART BADGE + TOAST
   ═══════════════════════════════════════ */
.nav__badge {
  position: absolute; top: 0; right: -2px;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: #C8102E; color: #fff;
  font-family: 'Inter', sans-serif; font-size: 0.54rem;
  font-weight: 600; letter-spacing: 0;
  line-height: 18px; text-align: center;
  border-radius: 9px; pointer-events: none;
  transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.nav__badge.is-pop { transform: scale(1.35); }
.nav__icon--cart { position: relative; }

.toast {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 700;
  background: var(--ink); color: var(--white);
  padding: 1.2rem 1.8rem; min-width: 280px; max-width: 380px;
  display: flex; flex-direction: column; gap: 0.3rem;
  transform: translateY(120%); opacity: 0;
  transition: transform 0.5s cubic-bezier(0.22,1,0.36,1), opacity 0.5s cubic-bezier(0.22,1,0.36,1);
  box-shadow: 0 8px 32px rgba(15,13,11,0.2);
}
.toast.is-visible { transform: translateY(0); opacity: 1; }
.toast__title {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  font-weight: 500; color: rgba(255,255,255,0.5);
}
.toast__msg {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem; color: var(--white);
}
.toast__link {
  font-family: 'Inter', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 500; color: rgba(255,255,255,0.6);
  margin-top: 0.3rem; transition: color 0.4s var(--ease);
  text-decoration: none;
}
.toast__link:hover { color: var(--white); }

@media (max-width: 768px) {
  .toast { bottom: 1rem; right: 1rem; left: 1rem; max-width: none; min-width: 0; }
}


/* ═══════════════════════════════════════
   SEARCH RESULTS (live)
   ═══════════════════════════════════════ */
.search-overlay__results {
  display: flex; flex-direction: column; gap: 0.5rem;
  max-height: 400px; overflow-y: auto;
}
.search-overlay__result {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.8rem 0; border-bottom: 1px solid var(--sand);
  text-decoration: none; color: var(--ink);
  transition: opacity 0.3s var(--ease);
}
.search-overlay__result:hover { opacity: 0.6; }
.search-overlay__result-img {
  width: 50px; height: 65px; object-fit: cover; flex-shrink: 0;
}
.search-overlay__result-info {
  display: flex; flex-direction: column; gap: 0.2rem;
}
.search-overlay__result-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem; color: var(--ink);
}
.search-overlay__result-price {
  font-family: 'Inter', sans-serif; font-size: 0.8rem;
  color: var(--ink-2);
}
.search-overlay__no-results {
  font-family: 'Inter', sans-serif; font-size: 0.85rem;
  color: var(--ink-3); padding: 1rem 0;
}


/* ═══════════════════════════════════════
   SINGLE PRODUCT — Fix stili
   ═══════════════════════════════════════ */

/* Prezzo prodotto singolo */
.product__price .woocommerce-Price-amount {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  color: var(--ink);
  text-decoration: none;
}
.product__price del {
  color: var(--ink-3);
  font-size: 0.7em;
  text-decoration: line-through;
}
.product__price ins {
  text-decoration: none;
}

/* Aggiungi al carrello — override WooCommerce default */
.product__actions .single_add_to_cart_button,
.product__actions button.single_add_to_cart_button {
  display: inline-block !important;
  padding: 1rem 3rem !important;
  border: 2px solid var(--ink) !important;
  font-size: 0.6rem !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  background: transparent !important;
  color: var(--ink) !important;
  border-radius: 0 !important;
  transition: background 0.5s var(--ease), color 0.5s var(--ease) !important;
  flex: 1 !important;
}
.product__actions .single_add_to_cart_button:hover {
  background: var(--ink) !important;
  color: var(--bg) !important;
}

/* Quantita' input con + e - */
.product__actions .quantity {
  display: flex;
  align-items: center;
  border: 1px solid var(--sand);
  flex-shrink: 0;
}
.product__actions .quantity input.qty,
.product__actions input.qty {
  width: 44px;
  height: 44px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--sand);
  border-right: 1px solid var(--sand);
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 500;
  background: transparent;
  border-radius: 0;
  -moz-appearance: textfield;
  appearance: textfield;
}
.product__actions .quantity input.qty::-webkit-inner-spin-button,
.product__actions .quantity input.qty::-webkit-outer-spin-button,
.product__actions input.qty::-webkit-inner-spin-button,
.product__actions input.qty::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.product__actions form.cart {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  width: 100%;
  padding: 0px;
}

/* Hover su prodotti correlati */
.prodotti__card:hover .catalog__actions {
  opacity: 1;
  transform: translateY(0);
}
.prodotti__pic { position: relative; }
.prodotti__pic .catalog__actions {
  position: absolute; bottom: 0.8rem; right: 0.8rem;
  display: flex; gap: 0.5rem; opacity: 0;
  transition: opacity 0.4s var(--ease), transform 0.4s var(--ease);
  transform: translateY(6px);
}


/* Related cards come div (no link annidati) */
.related__list .prodotti__card {
  text-decoration: none; color: inherit; text-align: center; cursor: pointer;
}
.related__list .prodotti__card-link {
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column; align-items: center; gap: 0.25rem;
}


/* Pulsanti +/- quantity */
.qty-btn {
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.1rem;
  color: var(--ink-2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s var(--ease), color 0.3s var(--ease);
}
.qty-btn:hover { background: var(--sand-light); color: var(--ink); }

/* Quantity generico WooCommerce */
.woocommerce .quantity {
  display: flex;
  align-items: center;
  border: 1px solid var(--sand);
  flex-shrink: 0;
}
.woocommerce .quantity input[type="number"] {
  width: 44px;
  height: 44px;
  text-align: center;
  border: none;
  border-left: 1px solid var(--sand);
  border-right: 1px solid var(--sand);
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 500;
  background: transparent;
  border-radius: 0;
  -moz-appearance: textfield;
  appearance: textfield;
}
.woocommerce .quantity input[type="number"]::-webkit-inner-spin-button,
.woocommerce .quantity input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}


/* Nascondi messaggi WooCommerce nella pagina carrello */
.woocommerce-cart .woocommerce-info,
.woocommerce-cart .woocommerce-message {
  display: none;
}


/* Carrello: page-hero più compatto */
.woocommerce-cart .page-hero--compact {
  padding-top: clamp(7rem, 10vh, 9rem);
  padding-bottom: clamp(2rem, 3vh, 3rem);
}


/* ═══════════════════════════════════════
   CART PAGE — Layout fix
   ═══════════════════════════════════════ */

/* Immagine prodotto più grande */
.woocommerce-cart .cart__item img,
.woocommerce-cart .woocommerce-cart-form img {
  width: 80px;
  height: 100px;
  object-fit: cover;
}

/* Pulsante checkout pieno */
.cart__summary .btn {
  background: var(--ink);
  color: var(--bg);
  border: 1px solid var(--ink);
}
.cart__summary .btn:hover {
  background: transparent;
  color: var(--ink);
}

/* Pulsante aggiorna carrello più discreto */
.woocommerce-cart button[name="update_cart"] {
  background: transparent !important;
  color: var(--ink-2) !important;
  border-color: var(--sand) !important;
}
.woocommerce-cart button[name="update_cart"]:hover {
  border-color: var(--ink) !important;
  color: var(--ink) !important;
}

/* Responsive carrello */
@media (max-width: 768px) {
  .cart__grid {
    grid-template-columns: 1fr !important;
  }
  .cart__summary {
    position: static !important;
  }
  .cart__header {
    display: none !important;
  }
  .cart__item {
    grid-template-columns: 1fr !important;
    gap: 0.8rem !important;
  }
}


/* ═══════════════════════════════════════
   CART — Layout originale
   ═══════════════════════════════════════ */
.cart {
  padding: clamp(3rem,6vw,5rem) var(--pad) clamp(5rem,10vw,10rem);
  max-width: 1400px; margin: 0 auto;
}
.cart__grid {
  display: grid; grid-template-columns: 1fr 380px;
  gap: clamp(3rem,6vw,6rem); align-items: start;
}
.cart__header {
  display: grid; grid-template-columns: 1fr 120px 100px;
  gap: 1rem; padding-bottom: 1rem;
  border-bottom: 1px solid var(--sand);
}
.cart__col-label {
  font-family: 'Inter', sans-serif; font-size: 0.58rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.cart__item {
  display: grid; grid-template-columns: 1fr 120px 100px;
  gap: 1rem; padding: 1.5rem 0;
  border-bottom: 1px solid var(--sand);
  align-items: center;
}
.cart__item-product {
  display: flex; gap: 1.2rem; align-items: center;
}
.cart__item-img {
  width: 80px; height: 100px; flex-shrink: 0;
  overflow: hidden; background: var(--sand-light);
}
.cart__item-img img { width: 100%; height: 100%; object-fit: cover; }
.cart__item-info { display: flex; flex-direction: column; gap: 0.15rem; }
.cart__item-category {
  font-family: 'Inter', sans-serif; font-size: 0.55rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 500;
}
.cart__item-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1rem; color: var(--ink);
  text-decoration: none;
  transition: opacity 0.4s var(--ease);
}
.cart__item-name:hover { opacity: 0.5; }
.cart__item-unit-price { font-size: 0.78rem; color: var(--ink-2); margin-top: 0.2rem; }
.cart__item-qty { display: flex; justify-content: center; }
.cart__item-total {
  display: flex; align-items: center; gap: 0.8rem; justify-content: flex-end;
}
.cart__item-price {
  font-family: 'Inter', sans-serif; font-size: 0.9rem;
  font-weight: 500; color: var(--ink);
}
.cart__item-remove {
  background: none; border: none; cursor: pointer;
  color: var(--ink-3); padding: 4px; font-size: 1.2rem;
  transition: color 0.4s var(--ease); text-decoration: none;
}
.cart__item-remove:hover { color: var(--ink); }

/* Summary */
.cart__summary {
  background: var(--sand-light); padding: clamp(2rem,3vw,2.5rem);
  display: flex; flex-direction: column; gap: 1rem;
  position: sticky; top: 100px;
}
.cart__summary-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic; font-size: 1.3rem;
  letter-spacing: -0.02em; margin-bottom: 0.5rem;
}
.cart__summary-row {
  display: flex; justify-content: space-between;
  font-size: 0.85rem; color: var(--ink-2);
}
.cart__summary-row--total {
  font-weight: 500; color: var(--ink); font-size: 1rem;
}
.cart__summary-line {
  height: 1px; background: var(--sand); margin: 0.3rem 0;
}
.cart__free { color: var(--ink); font-weight: 500; }
.cart__checkout-btn { width: 100%; text-align: center; margin-top: 0.5rem; }
.cart__summary-note {
  font-size: 0.7rem; color: var(--ink-3); text-align: center;
}
.cart__coupon { display: flex; flex-direction: column; gap: 0.5rem; }
.cart__coupon-field { display: flex; gap: 0.5rem; }
.cart__coupon-field input { flex: 1; }

@media (max-width: 768px) {
  .cart__grid {
    grid-template-columns: 1fr;
  }
  .cart__summary { position: static; }
  .cart__header { display: none; }
  .cart__item {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
  .cart__item-total { justify-content: flex-start; }
}


/* ═══════════════════════════════════════
   CHECKOUT — Layout originale
   ═══════════════════════════════════════ */

/* Steps */
.chk-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  padding: clamp(8rem,12vh,11rem) var(--pad) clamp(2.5rem,4vh,3.5rem);
}
.chk-steps__item {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  text-decoration: none;
  transition: color 0.4s var(--ease);
}
.chk-steps__item:hover { color: var(--ink-2); }
.chk-steps__item--active {
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 2px;
}
.chk-steps__sep {
  width: 40px;
  height: 1px;
  background: var(--sand);
}

/* Main grid */
.chk__grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: clamp(3rem,6vw,6rem);
  align-items: start;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--pad) clamp(5rem,10vw,10rem);
}

/* Form area */
.chk__form {
  display: flex;
  flex-direction: column;
  gap: clamp(2.5rem,4vw,3.5rem);
}

/* Sections */
.chk__section { }
.chk__heading {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: clamp(1.2rem, 2vw, 1.8rem);
  line-height: 1.2;
}

/* Form fields — WooCommerce overrides */
.chk .form-row {
  margin-bottom: 1.2rem;
}
.chk .form-row label,
.woocommerce-checkout .form-row label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  display: block;
  margin-bottom: 0.3rem;
}
.chk .form-row label .optional,
.woocommerce-checkout .form-row label .optional {
  font-weight: 300;
  color: var(--ink-3);
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.55rem;
}
.chk .form-row input.input-text,
.chk .form-row textarea,
.chk .form-row select,
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .select2-container .select2-selection {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  transition: border-color 0.4s var(--ease);
  -webkit-appearance: none;
  appearance: none;
  box-shadow: none;
}
.chk .form-row textarea {
  border: 1px solid var(--sand);
  padding: 1rem;
  min-height: 100px;
  resize: vertical;
  margin-top: 0.3rem;
}
.chk .form-row input.input-text:focus,
.chk .form-row select:focus,
.chk .form-row textarea:focus,
.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus {
  border-color: var(--ink);
  box-shadow: none;
  outline: none;
}
.chk .form-row input.input-text::placeholder {
  color: var(--ink-3);
  font-weight: 300;
}

/* Form row layout — due colonne */
.chk .woocommerce-billing-fields__field-wrapper,
.chk .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 0 clamp(1.5rem, 3vw, 2.5rem);
}
.chk .form-row-first,
.chk .form-row-last,
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  flex: 1;
  min-width: 180px;
}
.chk .form-row-wide,
.woocommerce-checkout .form-row-wide {
  width: 100%;
  flex-basis: 100%;
}

/* Tre colonne: Città, Provincia, CAP */
.chk__fields--shipping .woocommerce-billing-fields__field-wrapper,
.chk__fields--shipping {
  display: flex;
  flex-wrap: wrap;
  gap: 0 clamp(1.5rem, 3vw, 2.5rem);
}
.chk__fields--shipping #shipping_country_field {
  flex-basis: 100%;
}
.chk__fields--shipping #shipping_address_1_field {
  flex-basis: 100%;
}
.chk__fields--shipping #shipping_city_field {
  flex-basis: 100%;
}
.chk__fields--shipping #shipping_state_field {
  flex: 1;
  min-width: 150px;
}
.chk__fields--shipping #shipping_postcode_field {
  flex: 1;
  min-width: 100px;
}

/* Contact fields layout */
.chk__fields--contact {
  display: flex;
  flex-wrap: wrap;
  gap: 0 clamp(1.5rem, 3vw, 2.5rem);
}
.chk__fields--contact #billing_first_name_field {
  flex: 1;
  min-width: 180px;
}
.chk__fields--contact #billing_last_name_field {
  flex: 1;
  min-width: 180px;
}
.chk__fields--contact #billing_email_field,
.chk__fields--contact #billing_phone_field,
.chk__fields--contact #billing_country_field {
  flex-basis: 100%;
}

/* Notes */
.chk__fields--notes {
  margin-top: 1.5rem;
}

/* Select2 override */
.chk .select2-container--default .select2-selection--single,
.woocommerce-checkout .select2-container--default .select2-selection--single {
  border: none !important;
  border-bottom: 1px solid var(--sand) !important;
  border-radius: 0 !important;
  height: auto !important;
  padding: 0.8rem 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.chk .select2-container--default .select2-selection--single .select2-selection__rendered,
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  padding-left: 0;
  line-height: 1.5;
}
.chk .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50%;
  transform: translateY(-50%);
  right: 0;
}

/* Payment methods */
.chk #payment,
.woocommerce-checkout #payment {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}
.chk #payment ul.payment_methods,
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  border: none;
}
.chk #payment ul.payment_methods li,
.woocommerce-checkout #payment ul.payment_methods li {
  padding: 1rem 1.2rem;
  border: 1px solid var(--sand);
  margin-bottom: -1px;
  cursor: pointer;
  transition: border-color 0.4s var(--ease), background 0.4s var(--ease);
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.chk #payment ul.payment_methods li:first-child {
  border-radius: 0;
}
.chk #payment ul.payment_methods li:last-child {
  border-radius: 0;
}
.chk #payment ul.payment_methods li:hover,
.chk #payment ul.payment_methods li.wc_payment_method input:checked ~ label,
.woocommerce-checkout #payment ul.payment_methods li:hover {
  border-color: var(--ink);
  z-index: 1;
  position: relative;
}
.chk #payment ul.payment_methods li label,
.woocommerce-checkout #payment ul.payment_methods li label {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-2);
  cursor: pointer;
  font-weight: 400;
}
.chk #payment .payment_box {
  background: var(--sand-light);
  border: 1px solid var(--sand);
  border-top: none;
  padding: 1.2rem 1.5rem;
  margin: 0 0 0.5rem;
}
.chk #payment .payment_box p {
  font-size: 0.8rem;
  color: var(--ink-2);
  margin: 0;
}

/* Override WooCommerce default payment_box styles */
.woocommerce-checkout #payment .payment_box,
#payment .payment_box {
  background: var(--sand-light) !important;
  border: 1px solid var(--sand) !important;
  border-top: none !important;
  padding: 1.2rem 1.5rem !important;
  margin: -1px 0 0.5rem !important;
  border-radius: 0 !important;
  color: var(--ink-2) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.8rem !important;
  line-height: 1.7 !important;
}
.woocommerce-checkout #payment .payment_box::before,
#payment .payment_box::before {
  display: none !important;
}
.woocommerce-checkout #payment .payment_box p,
#payment .payment_box p {
  font-size: 0.8rem !important;
  color: var(--ink-2) !important;
  margin: 0 !important;
  font-family: 'Inter', sans-serif !important;
}

/* Payment methods list override */
.woocommerce-checkout #payment ul.payment_methods,
#payment ul.payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  border: none !important;
  background: transparent !important;
}
.woocommerce-checkout #payment ul.payment_methods li,
#payment ul.payment_methods li {
  padding: 1rem 1.2rem !important;
  border: 1px solid var(--sand) !important;
  margin-bottom: -1px !important;
  cursor: pointer !important;
  transition: border-color 0.4s var(--ease) !important;
  background: transparent !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.8rem !important;
  border-radius: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods li:hover,
#payment ul.payment_methods li:hover {
  border-color: var(--ink) !important;
  z-index: 1 !important;
  position: relative !important;
}
.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
  accent-color: var(--ink) !important;
}
.woocommerce-checkout #payment ul.payment_methods li label,
#payment ul.payment_methods li label {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.85rem !important;
  color: var(--ink-2) !important;
  cursor: pointer !important;
  font-weight: 400 !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Metodo selezionato */
.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method input[type="radio"]:checked ~ label,
#payment ul.payment_methods li.wc_payment_method input[type="radio"]:checked ~ label {
  color: var(--ink) !important;
  font-weight: 500 !important;
}

/* Campi carta dentro payment box */
.chk #payment .payment_box .form-row {
  margin-bottom: 1rem;
}
.chk #payment .payment_box input {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.6rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
}

/* Place order button */
.chk #place_order,
.woocommerce-checkout #place_order {
  display: block;
  width: 100%;
  padding: 1.1rem 3rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: var(--ink);
  color: var(--bg);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
  margin-top: 1.5rem;
}
.chk #place_order:hover,
.woocommerce-checkout #place_order:hover {
  background: transparent;
  color: var(--ink);
}

/* Privacy e termini */
.chk .woocommerce-terms-and-conditions-wrapper,
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  font-size: 0.78rem;
  color: var(--ink-3);
  margin: 1rem 0 0;
}
.chk .woocommerce-terms-and-conditions-wrapper a {
  color: var(--ink-2);
  text-decoration: underline;
}

/* Nascondi coupon toggle */
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.chk .woocommerce-form-coupon-toggle {
  display: none;
}

/* Nascondi info message default */
.woocommerce-checkout .woocommerce-info:not(.chk .woocommerce-info) {
  display: none;
}

/* Messaggio nessun metodo di pagamento (lo mostriamo stilizzato) */
.chk .woocommerce-info {
  background: var(--sand-light);
  border: 1px solid var(--sand);
  color: var(--ink-2);
  padding: 1rem 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  border-radius: 0;
  margin-bottom: 1rem;
}
.chk .woocommerce-info::before {
  color: var(--ink-3);
}

/* ── Sidebar: Il tuo ordine ── */
.chk__sidebar {
  position: sticky;
  top: 100px;
}
.chk__order {
  background: var(--sand-light);
  padding: clamp(1.5rem,2.5vw,2rem);
}
.chk__order-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 1.2rem;
  line-height: 1.2;
}
.chk__order-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--sand);
}
.chk__order-img {
  width: 50px;
  height: 65px;
  object-fit: cover;
  flex-shrink: 0;
}
.chk__order-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.chk__order-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 0.85rem;
  color: var(--ink);
  line-height: 1.3;
}
.chk__order-qty {
  font-size: 0.68rem;
  color: var(--ink-3);
}
.chk__order-price {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink);
  flex-shrink: 0;
}
.chk__order-line {
  height: 1px;
  background: var(--sand);
  margin: 0.8rem 0;
}
.chk__order-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-2);
  padding: 0.3rem 0;
}
.chk__order-row--total {
  font-weight: 600;
  color: var(--ink);
  font-size: 0.95rem;
}
.chk__free {
  color: var(--ink);
  font-weight: 500;
}

/* Campo Paese al checkout: visibile */
.chk #billing_country_field,
.chk #shipping_country_field {
  display: block;
}

/* ═══════════════════════════════════════
   MY ACCOUNT — Layout editoriale
   ═══════════════════════════════════════ */

/* Hero */
.acct-hero {
  padding: clamp(5rem,8vh,7rem) var(--pad) clamp(1.5rem,3vh,2rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.6rem,1.2vw,1rem);
}
.acct-hero__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.acct-hero__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(2.5rem,6vw,4.5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-weight: 400;
}

/* Account layout */
.acct {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--pad) clamp(3rem,6vw,5rem);
}
.acct__grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(3rem,5vw,5rem);
  align-items: start;
}

/* Navigation */
.woocommerce-account .woocommerce-MyAccount-navigation {
  float: none !important;
  width: 100% !important;
}
.woocommerce-account .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
}
.acct__nav .woocommerce-MyAccount-navigation,
.acct .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-navigation {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul,
.acct .woocommerce-MyAccount-navigation ul,
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul li,
.acct .woocommerce-MyAccount-navigation ul li,
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border: none !important;
  border-bottom: 1px solid var(--sand) !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  list-style: none !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul li:first-child,
.acct .woocommerce-MyAccount-navigation ul li:first-child,
.woocommerce-account .woocommerce-MyAccount-navigation ul li:first-child {
  border-top: none !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul li a,
.acct .woocommerce-MyAccount-navigation ul li a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 0.75rem 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.02em !important;
  color: var(--ink-3) !important;
  font-weight: 400 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  transition: color 0.4s var(--ease) !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul li a:hover,
.acct .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--ink) !important;
  background: transparent !important;
}
.acct__nav .woocommerce-MyAccount-navigation ul li.is-active a,
.acct .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  color: var(--ink) !important;
  font-weight: 600 !important;
  background: var(--sand-light) !important;
  padding: 0.75rem 0.8rem !important;
  margin: 0 -0.8rem !important;
  width: calc(100% + 1.6rem) !important;
}

/* Content area */
.acct__content {
  min-height: 300px;
}
/* Messaggi WooCommerce nell'area account */
.acct__content .woocommerce-message,
.acct__content .woocommerce-info,
.acct__content .woocommerce-error,
.acct .woocommerce-message,
.acct .woocommerce-info {
  border: none !important;
  border-left: 3px solid var(--ink) !important;
  background: var(--sand-light) !important;
  padding: 1rem 1.5rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.82rem !important;
  color: var(--ink-2) !important;
  margin-bottom: 1.5rem !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
/* Nascondi messaggio password temporanea */
.woocommerce-MyAccount-content > .woocommerce-message:first-child,
.acct__content > .woocommerce-message:first-child,
.acct__content .woocommerce-message,
.acct .woocommerce-message,
.woocommerce-account .woocommerce-message {
  display: none !important;
}
.acct__content h2,
.acct__content h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.3rem,2vw,1.6rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 1.2rem;
}
.acct__content p {
  font-size: 0.88rem;
  color: var(--ink-2);
  line-height: 1.8;
}

/* Form dentro account (edit address, edit account) */
.acct__content .woocommerce-EditAccountForm .form-row,
.acct__content .woocommerce-address-fields .form-row {
  margin-bottom: 1.2rem;
}
.acct__content .woocommerce-EditAccountForm label,
.acct__content .woocommerce-address-fields label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  display: block;
  margin-bottom: 0.3rem;
}
.acct__content .woocommerce-EditAccountForm input.input-text,
.acct__content .woocommerce-EditAccountForm select,
.acct__content .woocommerce-address-fields input.input-text,
.acct__content .woocommerce-address-fields select {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  transition: border-color 0.4s var(--ease);
  box-shadow: none;
}
.acct__content .woocommerce-EditAccountForm input.input-text:focus,
.acct__content .woocommerce-address-fields input.input-text:focus {
  border-color: var(--ink);
}
.acct__content button[type="submit"],
.acct__content .button {
  display: inline-block;
  padding: 1rem 3rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: var(--ink);
  color: var(--bg);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
  margin-top: 1.5rem;
}
.acct__content button[type="submit"]:hover,
.acct__content .button:hover {
  background: transparent;
  color: var(--ink);
}

/* Tabella ordini */
.acct__content .woocommerce-orders-table {
  width: 100%;
  border-collapse: collapse;
}
.acct__content .woocommerce-orders-table th {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  text-align: left;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--sand);
}
.acct__content .woocommerce-orders-table td {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-2);
  padding: 1rem 0;
  border-bottom: 1px solid var(--sand);
  font-weight: 300;
}
.acct__content .woocommerce-orders-table td a {
  color: var(--ink);
  font-weight: 500;
  transition: opacity 0.4s var(--ease);
}
.acct__content .woocommerce-orders-table td a:hover {
  opacity: 0.5;
}
.acct__content .woocommerce-orders-table .button {
  padding: 0.6rem 1.5rem;
  font-size: 0.55rem;
  margin-top: 0;
}

/* Dashboard text */
.acct__section-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.4rem,2.5vw,1.8rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 0.8rem;
}
.acct__welcome {
  font-size: 0.88rem;
  color: var(--ink-2);
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: clamp(2rem,3vw,2.5rem);
}
.acct__welcome strong {
  color: var(--ink);
  font-weight: 500;
}

/* Dashboard cards */
.acct__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.acct__card {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: clamp(1.2rem,2vw,1.8rem);
  border: 1px solid var(--sand);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.4s var(--ease), background 0.4s var(--ease);
}
.acct__card:hover {
  border-color: var(--ink);
  background: var(--sand-light);
}
.acct__card-icon {
  color: var(--ink-3);
  margin-bottom: 0.3rem;
}
.acct__card:hover .acct__card-icon {
  color: var(--ink);
}
.acct__card-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.acct__card-desc {
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  color: var(--ink-3);
  font-weight: 400;
}

.acct__content .woocommerce-MyAccount-content > p:first-child {
  font-size: 0.9rem;
  margin-bottom: 2rem;
}
.acct__content .woocommerce-MyAccount-content a {
  color: var(--ink);
  font-weight: 500;
  border-bottom: 1px solid var(--sand);
  transition: border-color 0.4s var(--ease);
}
.acct__content .woocommerce-MyAccount-content a:hover {
  border-color: var(--ink);
}

/* Addresses — custom template */
.addr {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.addr__card {
  border: 1px solid var(--sand);
  padding: clamp(1.2rem,2vw,1.8rem);
}
.addr__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}
.addr__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.addr__edit {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
  border: 1px solid var(--ink);
  padding: 0.4rem 0.8rem;
  text-decoration: none;
  transition: background 0.4s var(--ease), color 0.4s var(--ease);
}
.addr__edit:hover {
  background: var(--ink);
  color: var(--bg);
}
.addr__body address {
  font-style: normal;
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-2);
  line-height: 1.8;
  font-weight: 300;
}
.addr__empty {
  font-size: 0.85rem;
  color: var(--ink-3);
  font-style: italic;
}

@media (max-width: 768px) {
  .addr {
    grid-template-columns: 1fr;
  }
}

/* Hide default WooCommerce address layout on account page */
.woocommerce-account .woocommerce-Addresses {
  display: none !important;
}

/* ── Edit Address form ── */
.woocommerce-account .woocommerce-address-fields .form-row,
.woocommerce-account .woocommerce-EditAccountForm .form-row {
  margin-bottom: 1.2rem !important;
}
.woocommerce-account .woocommerce-address-fields label,
.woocommerce-account .woocommerce-EditAccountForm label {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.58rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  font-weight: 500 !important;
  display: block !important;
  margin-bottom: 0.3rem !important;
}
.woocommerce-account .woocommerce-address-fields label .required {
  color: var(--ink-3) !important;
}
.woocommerce-account .woocommerce-address-fields input.input-text,
.woocommerce-account .woocommerce-address-fields select,
.woocommerce-account .woocommerce-address-fields textarea,
.woocommerce-account .woocommerce-EditAccountForm input.input-text,
.woocommerce-account .woocommerce-EditAccountForm select {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--sand) !important;
  padding: 0.8rem 0 !important;
  outline: none !important;
  border-radius: 0 !important;
  width: 100% !important;
  box-shadow: none !important;
  transition: border-color 0.4s var(--ease) !important;
  -webkit-appearance: none !important;
}
.woocommerce-account .woocommerce-address-fields input.input-text:focus,
.woocommerce-account .woocommerce-address-fields select:focus,
.woocommerce-account .woocommerce-EditAccountForm input.input-text:focus {
  border-color: var(--ink) !important;
}

/* Select2 dentro account edit-address */
.woocommerce-account .select2-container--default .select2-selection--single {
  border: none !important;
  border-bottom: 1px solid var(--sand) !important;
  border-radius: 0 !important;
  height: auto !important;
  padding: 0.8rem 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__rendered {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 300 !important;
  color: var(--ink) !important;
  padding-left: 0 !important;
  line-height: 1.5 !important;
}
.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%) !important;
  right: 0 !important;
}
/* Select2 dropdown (aperto) */
.select2-container--default .select2-dropdown {
  border: 1px solid var(--sand) !important;
  border-radius: 0 !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08) !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.85rem !important;
  border: none !important;
  border-bottom: 1px solid var(--sand) !important;
  border-radius: 0 !important;
  padding: 0.6rem !important;
  outline: none !important;
}
.select2-container--default .select2-results__option {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.82rem !important;
  padding: 0.6rem 0.8rem !important;
  color: var(--ink-2) !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--selected {
  background: var(--ink) !important;
  color: var(--bg) !important;
}

/* Layout due colonne nel form indirizzo */
.woocommerce-account .woocommerce-address-fields__field-wrapper {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0 clamp(1.5rem, 3vw, 2.5rem) !important;
}
.woocommerce-account .woocommerce-address-fields .form-row-first,
.woocommerce-account .woocommerce-address-fields .form-row-last {
  flex: 1 !important;
  min-width: 180px !important;
  float: none !important;
  width: auto !important;
}
.woocommerce-account .woocommerce-address-fields .form-row-wide {
  flex-basis: 100% !important;
  width: 100% !important;
  float: none !important;
}

/* Nascondi campo paese (default Italia) */
.woocommerce-account .woocommerce-address-fields #billing_country_field,
.woocommerce-account .woocommerce-address-fields #shipping_country_field {
  display: none !important;
}

/* Bottone salva indirizzo */
.woocommerce-account .woocommerce-address-fields button[type="submit"],
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"] {
  display: inline-block !important;
  padding: 1rem 3rem !important;
  border: 1px solid var(--ink) !important;
  font-size: 0.6rem !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  cursor: pointer !important;
  background: var(--ink) !important;
  color: var(--bg) !important;
  border-radius: 0 !important;
  transition: background 0.5s var(--ease), color 0.5s var(--ease) !important;
  margin-top: 1.5rem !important;
}
.woocommerce-account .woocommerce-address-fields button[type="submit"]:hover,
.woocommerce-account .woocommerce-EditAccountForm button[type="submit"]:hover {
  background: transparent !important;
  color: var(--ink) !important;
}

/* ── Edit Account form ── */
.acct-edit {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.acct-edit__row {
  display: flex;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
.acct-edit__row .acct-edit__field {
  flex: 1;
  min-width: 0;
}
.acct-edit__field {
  margin-bottom: 0.3rem;
}
.acct-edit__field label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  display: block;
  margin-bottom: 0.3rem;
}
.acct-edit__field input {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  transition: border-color 0.4s var(--ease);
  box-shadow: none;
}
.acct-edit__field input:focus {
  border-color: var(--ink);
}
.acct-edit__field input::placeholder {
  color: var(--ink-3);
  font-weight: 300;
}
.acct-edit__pw-wrap {
  position: relative;
}
.acct-edit__pw-wrap input {
  padding-right: 2.5rem;
}
.acct-edit__pw-toggle {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink-3);
  padding: 4px;
  transition: color 0.4s var(--ease);
}
.acct-edit__pw-toggle:hover {
  color: var(--ink);
}
.acct-edit__password {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
}
.acct-edit__password-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 1.2rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--sand);
}
.acct-edit__submit {
  display: block;
  width: 100%;
  padding: 1.1rem 3rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: transparent;
  color: var(--ink);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
  margin-top: 2rem;
}
.acct-edit__submit:hover {
  background: var(--ink);
  color: var(--bg);
}

@media (max-width: 768px) {
  .acct-edit__row {
    flex-direction: column;
    gap: 1.2rem;
  }
}

/* ── LOGIN PAGE ── */
.acct-login {
  display: flex;
  justify-content: center;
  padding: clamp(4rem,6vh,5rem) var(--pad) clamp(2rem,4vw,3rem);
}
.acct-login__wrap {
  width: 100%;
  max-width: 500px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.acct-login__header {
  margin-bottom: clamp(2rem,3vw,2.5rem);
}
.acct-login__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  display: block;
  margin-bottom: clamp(0.5rem,1vw,0.8rem);
}
.acct-login__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(2.5rem,5vw,4rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-weight: 400;
  margin-bottom: clamp(0.6rem,1vw,0.8rem);
}
.acct-login__desc {
  font-size: 0.88rem;
  color: var(--ink-2);
  line-height: 1.7;
  font-weight: 300;
}
.acct-login__field {
  margin-bottom: 1.5rem;
}
.acct-login__field label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  display: block;
  margin-bottom: 0.3rem;
}
.acct-login__field input {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--sand);
  padding: 0.8rem 0;
  outline: none;
  border-radius: 0;
  width: 100%;
  transition: border-color 0.4s var(--ease);
  box-shadow: none;
}
.acct-login__field input:focus {
  border-color: var(--ink);
}
.acct-login__field input::placeholder {
  color: var(--ink-3);
  font-weight: 300;
}
.acct-login__btn {
  display: block;
  width: 100%;
  padding: 1.1rem 3rem;
  border: 1px solid var(--ink);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  background: var(--ink);
  color: var(--bg);
  border-radius: 0;
  transition: background 0.5s var(--ease), color 0.5s var(--ease);
  margin-top: 1rem;
}
.acct-login__btn:hover {
  background: transparent;
  color: var(--ink);
}
.acct-login__register {
  text-align: center;
  margin-top: 2rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-2);
}
.acct-login__register a {
  color: var(--ink);
  font-weight: 500;
  border-bottom: 1px solid var(--ink);
  transition: opacity 0.4s var(--ease);
}
.acct-login__register a:hover {
  opacity: 0.5;
}
.acct-login__row {
  display: flex;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
.acct-login__field--half {
  flex: 1;
  min-width: 0;
}
.acct-login__optional {
  font-weight: 300;
  color: var(--ink-3);
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.55rem;
}

/* ── Orders list ── */
.orders {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* Status badges per tabella default WooCommerce */
.acct__content .woocommerce-orders-table td.woocommerce-orders-table__cell-order-status,
.acct__content table.shop_table td[data-title="Stato"] {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.55rem !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
/* Badge wrapper per status */
.acct__content .woocommerce-orders-table .woocommerce-orders-table__cell-order-status {
  position: relative;
}

/* Status via CSS attribute selectors on WooCommerce table */
.woocommerce-account .woocommerce-orders-table td {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.82rem !important;
  color: var(--ink-2) !important;
  padding: 1rem 0.5rem !important;
  border-bottom: 1px solid var(--sand) !important;
  font-weight: 300 !important;
  vertical-align: middle !important;
}
.woocommerce-account .woocommerce-orders-table th {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.55rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  font-weight: 500 !important;
  padding: 0.8rem 0.5rem !important;
  border-bottom: 1px solid var(--sand) !important;
}
.woocommerce-account .woocommerce-orders-table {
  width: 100% !important;
  border: none !important;
  border-collapse: collapse !important;
}

/* Order status badges */
.order-badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 0.55rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 0.35rem 0.8rem;
  border: 1px solid var(--sand);
  color: var(--ink-3);
}
.order-badge--completed {
  color: #2e7d32;
  border-color: #2e7d32;
  background: rgba(46,125,50,0.05);
}
.order-badge--processing {
  color: #1565c0;
  border-color: #1565c0;
  background: rgba(21,101,192,0.05);
}
.order-badge--pending {
  color: #b8860b;
  border-color: #b8860b;
  background: rgba(184,134,11,0.05);
}
.order-badge--cancelled {
  color: #c33;
  border-color: #c33;
  background: rgba(204,51,51,0.05);
}

/* Bottone visualizza nella tabella ordini */
.woocommerce-account .woocommerce-orders-table .woocommerce-button,
.woocommerce-account .woocommerce-orders-table .button {
  display: inline-block !important;
  padding: 0.6rem 1.5rem !important;
  border: 1px solid var(--ink) !important;
  font-size: 0.55rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  background: var(--ink) !important;
  color: var(--bg) !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  transition: background 0.4s var(--ease), color 0.4s var(--ease) !important;
}
.woocommerce-account .woocommerce-orders-table .woocommerce-button:hover,
.woocommerce-account .woocommerce-orders-table .button:hover {
  background: transparent !important;
  color: var(--ink) !important;
}
.orders__card {
  border: 1px solid var(--sand);
  padding: clamp(1.2rem,2vw,1.8rem);
}
.orders__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid var(--sand);
}
.orders__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.orders__number {
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink);
}
.orders__date {
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  color: var(--ink-3);
  font-weight: 300;
}
.orders__status {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-3);
  padding: 0.3rem 0.8rem;
  border: 1px solid var(--sand);
}
.orders__status--processing {
  color: #b8860b;
  border-color: #b8860b;
}
.orders__status--completed {
  color: #2e7d32;
  border-color: #2e7d32;
}
.orders__status--cancelled {
  color: #c33;
  border-color: #c33;
}
.orders__items {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1rem;
}
.orders__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.orders__item-left {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.orders__item-img {
  width: 40px;
  height: 50px;
  object-fit: cover;
  flex-shrink: 0;
}
.orders__item-name {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-2);
  font-weight: 300;
}
.orders__item-price {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ink);
}
.orders__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 0.8rem;
  border-top: 1px solid var(--sand);
}
.orders__total {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ink);
}
.orders__detail-link {
  font-family: 'Inter', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-2);
  transition: color 0.4s var(--ease);
}
.orders__detail-link:hover {
  color: var(--ink);
}

/* ── View Order detail ── */
.view-order__header {
  margin-bottom: 1.5rem;
}
.view-order__title-row {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.view-order__title-row .acct__section-title {
  margin-bottom: 0;
}
.view-order__meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  padding: clamp(1.2rem,2vw,1.8rem) 0;
  border-top: 1px solid var(--sand);
  border-bottom: 1px solid var(--sand);
  margin-bottom: clamp(2rem,3vw,2.5rem);
}
.view-order__meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.view-order__meta-label {
  font-family: 'Inter', sans-serif;
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.view-order__meta-value {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  color: var(--ink);
  font-weight: 500;
}
.view-order__subtitle {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.1rem,1.8vw,1.3rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 1rem;
}
.view-order__products {
  margin-bottom: clamp(2rem,3vw,2.5rem);
}
.view-order__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 0;
  border-bottom: 1px solid var(--sand);
}
.view-order__item-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.view-order__item-img {
  width: 50px;
  height: 65px;
  object-fit: cover;
  flex-shrink: 0;
}
.view-order__item-info {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.view-order__item-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 0.9rem;
  color: var(--ink);
}
.view-order__item-meta {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  color: var(--ink-3);
}
.view-order__item-price {
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--ink);
}
.view-order__totals {
  padding-top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.view-order__total-row {
  display: flex;
  justify-content: space-between;
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-2);
}
.view-order__total-row--final {
  padding-top: 0.8rem;
  border-top: 1px solid var(--sand);
  font-weight: 600;
  color: var(--ink);
  font-size: 0.95rem;
}
.view-order__addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: clamp(2rem,3vw,2.5rem);
}
.view-order__address-card {
  padding: 1.5rem;
  background: var(--sand-light);
  border: 1px solid var(--sand);
}
.view-order__address-card address {
  font-style: normal;
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-2);
  line-height: 1.8;
  font-weight: 300;
}
.view-order__address-detail {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-2);
  margin-top: 0.3rem;
}
.view-order__actions {
  padding-top: 1rem;
}

/* Nascondi dettagli default WooCommerce nella view-order (duplicati) */
.view-order + .woocommerce-order-details,
.view-order ~ .woocommerce-order-details,
.view-order ~ .woocommerce-customer-details,
.acct__content .woocommerce-order-details,
.acct__content .woocommerce-customer-details {
  display: none !important;
}

@media (max-width: 768px) {
  .view-order__meta {
    grid-template-columns: 1fr 1fr;
  }
  .view-order__addresses {
    grid-template-columns: 1fr;
  }
}

/* ── View Order (dettaglio singolo ordine) ── */
.acct__content .woocommerce-order-details,
.acct__content .woocommerce-customer-details {
  margin-bottom: 2.5rem;
}
.acct__content .woocommerce-order-details {
  margin-top: 0.5rem;
}

/* Nascondi highlight giallo sui mark nel dettaglio ordine */
.acct__content > p:first-child mark,
.acct__content .woocommerce-MyAccount-content > p:first-child mark,
.woocommerce-account .woocommerce-MyAccount-content > p mark,
.woocommerce-account mark {
  background: transparent !important;
  color: var(--ink) !important;
  font-weight: 500 !important;
}
.acct__content > p:first-child,
.acct__content .woocommerce-MyAccount-content > p:first-child {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.82rem !important;
  color: var(--ink-2) !important;
  margin-bottom: 1.8rem !important;
  padding-bottom: 1.2rem !important;
  border-bottom: 1px solid var(--sand) !important;
  line-height: 1.7 !important;
}

/* Tabella dettagli ordine */
.acct__content .woocommerce-table--order-details,
.acct__content table.shop_table {
  width: 100% !important;
  border: none !important;
  border-collapse: collapse !important;
  margin-bottom: 0.5rem !important;
}
.acct__content .woocommerce-table--order-details thead th,
.acct__content table.shop_table thead th {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.55rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  font-weight: 500 !important;
  padding: 0 0 0.8rem !important;
  border-bottom: 1px solid var(--sand) !important;
  border-top: none !important;
  text-align: left !important;
}
.acct__content .woocommerce-table--order-details thead th:last-child,
.acct__content table.shop_table thead th:last-child {
  text-align: right !important;
}
.acct__content .woocommerce-table--order-details tbody td,
.acct__content table.shop_table tbody td {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.85rem !important;
  color: var(--ink-2) !important;
  padding: 1rem 0 !important;
  border-bottom: 1px solid var(--sand) !important;
  border-top: none !important;
  font-weight: 300 !important;
  vertical-align: middle !important;
}
.acct__content .woocommerce-table--order-details tbody td:last-child,
.acct__content table.shop_table tbody td:last-child {
  text-align: right !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
}
.acct__content .woocommerce-table--order-details td a {
  color: var(--ink) !important;
  font-weight: 400 !important;
}
/* Tfoot (subtotale, totale, metodo) */
.acct__content .woocommerce-table--order-details tfoot th,
.acct__content table.shop_table tfoot th {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.58rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  font-weight: 500 !important;
  padding: 0.8rem 0 !important;
  border-bottom: 1px solid var(--sand) !important;
  border-top: none !important;
  text-align: left !important;
}
.acct__content .woocommerce-table--order-details tfoot td,
.acct__content table.shop_table tfoot td {
  font-weight: 500 !important;
  color: var(--ink) !important;
  padding: 0.8rem 0 !important;
  border-bottom: 1px solid var(--sand) !important;
  border-top: none !important;
  text-align: right !important;
}

/* Sezione indirizzo fatturazione */
.acct__content .woocommerce-customer-details .woocommerce-columns {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1.5rem !important;
  margin-top: 0.5rem !important;
}
.acct__content .woocommerce-customer-details .woocommerce-column {
  float: none !important;
  width: 100% !important;
  padding: 1.5rem !important;
  background: var(--sand-light) !important;
  border: 1px solid var(--sand) !important;
  margin: 0 !important;
}
.acct__content .woocommerce-customer-details .woocommerce-column h2,
.acct__content .woocommerce-customer-details h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-style: italic !important;
  font-size: 1.1rem !important;
  font-weight: 400 !important;
  margin-bottom: 0.8rem !important;
  border: none !important;
  padding: 0 !important;
  letter-spacing: -0.02em !important;
}
.acct__content .woocommerce-customer-details address {
  font-style: normal !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.85rem !important;
  color: var(--ink-2) !important;
  line-height: 1.8 !important;
  font-weight: 300 !important;
}
.acct__content .woocommerce-customer-details address p {
  margin: 0.2rem 0 !important;
}

/* Section title nel dettaglio ordine */
.acct__content .woocommerce-order-details h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-style: italic !important;
  font-size: clamp(1.2rem,2vw,1.4rem) !important;
  letter-spacing: -0.02em !important;
  font-weight: 400 !important;
  margin-bottom: 1rem !important;
  border: none !important;
  padding: 0 !important;
}

@media (max-width: 768px) {
  .acct__content .woocommerce-customer-details .woocommerce-columns {
    grid-template-columns: 1fr !important;
  }
}

/* Responsive Account */
@media (max-width: 768px) {
  .acct__grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .acct__nav .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
  }
  .acct__nav .woocommerce-MyAccount-navigation ul li {
    border: 1px solid var(--sand);
    border-right: none;
  }
  .acct__nav .woocommerce-MyAccount-navigation ul li:last-child {
    border-right: 1px solid var(--sand);
  }
  .acct__nav .woocommerce-MyAccount-navigation ul li:first-child {
    border-top: 1px solid var(--sand);
  }
  .acct__nav .woocommerce-MyAccount-navigation ul li a {
    padding: 0.6rem 1rem;
    font-size: 0.7rem;
  }
  .acct__cards {
    grid-template-columns: 1fr;
  }
  .acct-login__grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .acct__content .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
}

/* ═══════════════════════════════════════
   THANKYOU — Ordine ricevuto
   ═══════════════════════════════════════ */
.thankyou {
  max-width: 800px;
  margin: 0 auto;
  padding: clamp(5rem,10vh,8rem) var(--pad) clamp(4rem,8vw,6rem);
  text-align: center;
}
.thankyou__header {
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
}
.thankyou__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(2.8rem,7vw,5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-weight: 400;
  margin-bottom: clamp(1rem,2vw,1.5rem);
}
.thankyou__desc {
  font-size: 0.9rem;
  color: var(--ink-2);
  line-height: 1.8;
  font-weight: 300;
  max-width: 500px;
  margin: 0 auto;
}

/* Meta grid */
.thankyou__meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  text-align: left;
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
  padding: clamp(1.5rem,2.5vw,2rem) 0;
  border-top: 1px solid var(--sand);
  border-bottom: 1px solid var(--sand);
}
.thankyou__meta-item {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.thankyou__meta-label {
  font-family: 'Inter', sans-serif;
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.thankyou__meta-value {
  font-family: 'Inter', sans-serif;
  font-size: 0.92rem;
  color: var(--ink);
  font-weight: 500;
}

/* Items */
.thankyou__items {
  text-align: left;
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
}
.thankyou__items-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.2rem,2vw,1.5rem);
  letter-spacing: -0.02em;
  font-weight: 400;
  margin-bottom: 1.2rem;
}
.thankyou__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 0;
  border-bottom: 1px solid var(--sand);
}
.thankyou__item-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.thankyou__item-img {
  width: 56px;
  height: 70px;
  object-fit: cover;
  flex-shrink: 0;
}
.thankyou__item-info {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.thankyou__item-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 0.92rem;
  color: var(--ink);
  font-weight: 400;
}
.thankyou__item-meta {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  color: var(--ink-3);
}
.thankyou__item-price {
  font-family: 'Inter', sans-serif;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--ink);
}

/* Actions */
.thankyou__actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
}
.thankyou__actions .btn {
  min-width: 180px;
  text-align: center;
}

/* Nascondi dettagli WooCommerce default nella thankyou (tranne banca) */
.thankyou .woocommerce-order-overview,
.thankyou .woocommerce-order-details,
.thankyou .woocommerce-customer-details {
  display: none !important;
}

/* Riferimenti bancari stilizzati */
.thankyou__bank {
  text-align: left;
  margin-bottom: clamp(2rem,3vw,3rem);
}
.thankyou__bank:empty {
  display: none;
}
.thankyou .woocommerce-bacs-bank-details,
.thankyou__bank .wc-bacs-bank-details-order-ref,
.thankyou__bank section {
  padding: clamp(1.5rem,2.5vw,2rem);
  background: var(--sand-light);
  border: 1px solid var(--sand);
  margin-bottom: 1rem;
}
.thankyou .woocommerce-bacs-bank-details h2,
.thankyou .wc-bacs-bank-details-heading,
.thankyou__bank h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-style: italic !important;
  font-size: clamp(1.2rem,2vw,1.4rem) !important;
  letter-spacing: -0.02em !important;
  font-weight: 400 !important;
  margin-bottom: 0.6rem !important;
  border: none !important;
  padding: 0 !important;
}
/* Account name */
.thankyou__bank .wc-bacs-bank-details-account-name,
.thankyou .woocommerce-bacs-bank-details .wc-bacs-bank-details-account-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: 0.9rem;
  color: var(--ink);
  margin-bottom: 1.2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--sand);
  display: block;
}
/* Lista dettagli banca come griglia orizzontale */
.thankyou .woocommerce-bacs-bank-details ul,
.thankyou__bank ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1.5rem 3rem !important;
}
.thankyou .woocommerce-bacs-bank-details ul li,
.thankyou__bank ul li {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.25rem !important;
  padding: 0 !important;
  border: none !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.82rem !important;
}
.thankyou .woocommerce-bacs-bank-details ul li strong,
.thankyou__bank ul li strong {
  font-size: 0.55rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--ink-3) !important;
  font-weight: 500 !important;
  display: block !important;
}
.thankyou .woocommerce-bacs-bank-details ul li span,
.thankyou__bank ul li span {
  font-size: 0.88rem !important;
  color: var(--ink) !important;
  font-weight: 500 !important;
}

@media (max-width: 768px) {
  .thankyou__meta {
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
  }
  .thankyou__actions {
    flex-direction: column;
    align-items: center;
  }
  .thankyou__actions .btn {
    width: 100%;
  }
}

/* Responsive checkout */
@media (max-width: 768px) {
  .chk__grid {
    grid-template-columns: 1fr;
  }
  .chk__sidebar {
    position: static;
    order: -1;
  }
  .chk .form-row-first,
  .chk .form-row-last,
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    flex-basis: 100%;
  }
  .chk-steps {
    padding-top: clamp(6rem,10vh,8rem);
    gap: 0.8rem;
  }
  .chk-steps__sep {
    width: 20px;
  }
  .chk-steps__item {
    font-size: 0.55rem;
  }
}

/* ═══════════════════════════════════════
   SEO CONTENT — Sezione informativa
   ═══════════════════════════════════════ */
.seo-content {
  padding: clamp(3rem,5vw,5rem) var(--pad);
  max-width: 800px;
  margin: 0 auto;
  border-top: 1px solid var(--sand);
}
.seo-content h2 {
  font-size: clamp(1.4rem,2.5vw,1.8rem);
  line-height: 1.2;
  margin-bottom: 1rem;
}
.seo-content h3 {
  font-size: clamp(1rem,1.5vw,1.2rem);
  line-height: 1.3;
  margin-top: 1.5rem;
  margin-bottom: 0.6rem;
}
.seo-content p {
  margin-bottom: 1rem;
}
.seo-content a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.3s var(--ease);
}
.seo-content a:hover {
  opacity: 0.5;
}

/* ═══════════════════════════════════════
   FAQ / ACCORDION
   ═══════════════════════════════════════ */
.faq {
  padding: clamp(3rem,5vw,5rem) var(--pad);
  max-width: 800px;
  margin: 0 auto;
}
.faq__title {
  font-size: clamp(1.6rem,3vw,2.4rem);
  line-height: 1.1;
  margin-bottom: clamp(1.5rem,3vw,2.5rem);
}
.faq__list {
  display: flex;
  flex-direction: column;
}
.faq__item {
  border-bottom: 1px solid var(--sand);
}
.faq__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: clamp(0.88rem,1vw,0.95rem);
  font-weight: 400;
  color: var(--ink);
  text-align: left;
  gap: 1rem;
  transition: color 0.3s var(--ease);
}
.faq__question:hover {
  color: var(--ink-2);
}
.faq__icon {
  flex-shrink: 0;
  transition: transform 0.4s var(--ease);
  color: var(--ink-3);
}
.faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--ease);
}
.faq__answer p {
  padding-bottom: 1.2rem;
  font-size: 0.88rem;
  line-height: 1.7;
  color: var(--ink-2);
}

/* ═══════════════════════════════════════
   BANNER / AVVISO
   ═══════════════════════════════════════ */
.banner {
  padding: 0.8rem var(--pad);
  text-align: center;
}
.banner__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  flex-wrap: wrap;
}
.banner__text {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
}
.banner__link {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.3s var(--ease);
}
.banner__link:hover {
  opacity: 0.6;
}
/* Stili varianti */
.banner--dark {
  background: var(--ink);
}
.banner--dark .banner__text,
.banner--dark .banner__link {
  color: rgba(255,255,255,0.9);
}
.banner--light {
  background: var(--sand-light);
}
.banner--light .banner__text,
.banner--light .banner__link {
  color: var(--ink);
}
.banner--gold {
  background: #C9A96E;
}
.banner--gold .banner__text,
.banner--gold .banner__link {
  color: var(--ink);
}

/* ═══════════════════════════════════════
   AGE GATE — Verifica età 18+
   ═══════════════════════════════════════ */
.age-gate {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(15, 13, 11, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--pad);
  opacity: 1;
  transition: opacity 0.6s var(--ease);
}
.age-gate.is-hidden {
  opacity: 0;
  pointer-events: none;
}
.age-gate__card {
  background: var(--bg);
  border: 1px solid var(--sand);
  padding: clamp(2.5rem, 4vw, 4rem) clamp(2rem, 4vw, 3.5rem);
  text-align: center;
  max-width: 460px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1rem, 1.8vw, 1.4rem);
}
.age-gate__logo {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  color: var(--ink-3);
  letter-spacing: -0.02em;
}
.age-gate__title {
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1.0;
  letter-spacing: -0.03em;
}
.age-gate__text {
  max-width: 360px;
  text-align: center;
}
.age-gate__check {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: var(--ink);
  margin-top: 0.5rem;
}
.age-gate__check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--ink);
  cursor: pointer;
}
.age-gate__selects {
  display: flex;
  gap: 1rem;
  width: 100%;
}
.age-gate__select {
  flex: 1;
  padding: 0.7rem 1rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  border: 1px solid var(--sand);
  background: var(--white);
  color: var(--ink);
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231A1610' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  cursor: pointer;
}
.age-gate__btn {
  margin-top: 0.5rem;
  opacity: 0.4;
  pointer-events: none;
  transition: opacity 0.4s var(--ease), background 0.5s var(--ease), color 0.5s var(--ease);
}
.age-gate__btn.is-active {
  opacity: 1;
  pointer-events: auto;
}
.age-gate__exit {
  font-family: 'Inter', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--ink-3);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.3s var(--ease);
}
.age-gate__exit:hover {
  color: var(--ink);
}

/* ═══════════════════════════════════════
   RESPONSIVE — Componenti aggiuntivi
   ═══════════════════════════════════════ */
@media (max-width: 480px) {
  .age-gate {
    padding: 1.5rem;
  }
  .age-gate__card {
    padding: 2rem 1.5rem;
  }
  .age-gate__title {
    font-size: 2rem;
  }
  .age-gate__check {
    font-size: 0.78rem;
  }

  .faq__question {
    font-size: 0.82rem;
    padding: 1rem 0;
  }

  .banner__text {
    font-size: 0.65rem;
    letter-spacing: 0.08em;
  }
  .banner__wrap {
    gap: 0.6rem;
  }
}
