/*
Theme Name: Guicciardini Strozzi
Theme URI: https://guicciardinistrozzi.it
Author: Federico Mazzoleni
Author URI: effeemmezeta
Description: Tema custom per Tenuta di Cusona — PHP classico, BEM, vanilla JS.
Version: 1.0.0
Requires at least: 6.5
Tested up to: 6.5
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: gs
*/

/* =========================================================
   0. FONT — self-hosted (woff2, subset latin)
   ========================================================= */

@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url('assets/fonts/fraunces-200-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/fraunces-300-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 200;
  font-display: swap;
  src: url('assets/fonts/fraunces-200-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/fraunces-300-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/geist-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/geist-400.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-300.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/jetbrains-mono-400.woff2') format('woff2');
}

/* =========================================================
   1. RESET + VARIABILI
   ========================================================= */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body { margin: 0; }
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, h5, h6, p { margin: 0; }
:focus-visible { outline: 2px solid currentColor; outline-offset: 4px; }
::selection { background: var(--accent); color: var(--bone); }

:root {
  /* Palette */
  --ink:           #0A0908;
  --ink-pure:      #000000;
  --bone:          #F2EDE2;
  --bone-deep:     #E8E2D2;
  --text-on-ink:   #E8E2D2;
  --text-on-bone:  #1A1612;
  --muted-on-ink:  #6E6759;
  --muted-on-bone: #7A6F60;
  --line-on-ink:   #2A2620;
  --line-on-bone:  #C9C0AE;
  --accent:        #7C1E1F;
  --pure-ink:      #000000;
  --white:         #ffffff;

  /* Font */
  --font-serif: 'Fraunces', Georgia, serif;
  --font-sans:  'Geist', system-ui, sans-serif;
  --font-mono:  'JetBrains Mono', monospace;

  /* Scala tipografica — fluid con clamp */
  --text-hero:     clamp(5rem, 16vw, 14rem);
  --text-counter:  clamp(0.7rem, 1vw, 1rem);
  --text-counter2: clamp(0.85rem, 1.5vw, 1.25rem);
  --text-h1:       clamp(2.5rem, 6vw, 5rem);
  --text-headline: clamp(2rem, 5.5vw, 5.5rem);
  --text-subhead:  clamp(1rem, 1.4vw, 1.25rem);
  --text-lead:     clamp(1.1rem, 1.6vw, 1.5rem);
  --text-body:     1rem;
  --text-eyebrow:  0.6rem;

  /* Spaziature — fluid */
  --pad-x:      clamp(1.5rem, 4vw, 2.5rem);
  --pad-x-mob:  1rem;
  --pad-y:      clamp(5rem, 8vw, 8rem);
  --pad-y-mob:  clamp(3rem, 6vw, 5rem);

  /* Layout */
  --container:  1280px;
  --nav-h:      64px;

  /* Motion */
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:   cubic-bezier(0.4, 0, 1, 1);
  --dur-fast:  0.25s;
  --dur-mid:   0.45s;
  --dur-slow:  0.7s;
}

/* =========================================================
   2. BODY + TIPOGRAFIA BASE
   ========================================================= */

body {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: var(--text-body);
  line-height: 1.65;
  background-color: var(--ink);
  color: var(--text-on-ink);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.menu-open { overflow: hidden; }

/* =========================================================
   3. STILI BLOCCO GUTENBERG
   ========================================================= */

/* --- PARAGRAFO --- */

p.is-style-lead {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.5rem);
  line-height: 1.55;
}
p.is-style-eyebrow {
  font-family: var(--font-mono);
  font-size: clamp(0.55rem, 0.7vw, 0.65rem);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
.has-bone-background-color p.is-style-eyebrow,
.wp-block-group.is-style-section-bone p.is-style-eyebrow {
  color: var(--muted-on-bone);
}
p.is-style-eyebrow-marker {
  font-family: var(--font-mono);
  font-size: clamp(0.55rem, 0.7vw, 0.65rem);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
p.is-style-eyebrow-marker::before {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: var(--muted-on-ink);
  flex-shrink: 0;
}
.has-bone-background-color p.is-style-eyebrow-marker,
.wp-block-group.is-style-section-bone p.is-style-eyebrow-marker {
  color: var(--muted-on-bone);
}
.has-bone-background-color p.is-style-eyebrow-marker::before,
.wp-block-group.is-style-section-bone p.is-style-eyebrow-marker::before {
  background: var(--muted-on-bone);
}
p.is-style-section-marker {
  font-size: clamp(0.9rem, 1.2vw, 1.1rem);
  padding-left: 1rem;
  border-left: 1px solid var(--muted-on-ink);
  line-height: 1.5;
}
p.is-style-muted {
  font-size: clamp(0.85rem, 1.1vw, 1rem);
  color: var(--muted-on-ink);
  line-height: 1.65;
}
.has-bone-background-color p.is-style-section-marker,
.wp-block-group.is-style-section-bone p.is-style-section-marker {
  border-left-color: var(--muted-on-bone);
}
.has-bone-background-color p.is-style-muted,
.wp-block-group.is-style-section-bone p.is-style-muted {
  color: var(--muted-on-bone);
}

/* --- HEADING --- */

h1.is-style-display {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(3rem, 7vw, 5.5rem)!important;
  line-height: 0.95;
  letter-spacing: -0.025em;
}
h2.is-style-display {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(2.5rem, 5.5vw, 4.5rem)!important;
  line-height: 0.95;
  letter-spacing: -0.022em;
}
h3.is-style-display {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(2rem, 4vw, 3.5rem)!important;
  line-height: 1;
  letter-spacing: -0.02em;
}
h1.is-style-italic,
h2.is-style-italic,
h3.is-style-italic {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 200;
  font-variation-settings: "SOFT" 100;
  font-size: inherit;
  line-height: inherit;
}
h1.is-style-section-marker,
h2.is-style-section-marker,
h3.is-style-section-marker {
  padding-left: 1rem;
  border-left: 1px solid var(--muted-on-ink);
  font-size: inherit;
}
.has-bone-background-color h1.is-style-section-marker,
.has-bone-background-color h2.is-style-section-marker,
.has-bone-background-color h3.is-style-section-marker,
.wp-block-group.is-style-section-bone h1.is-style-section-marker,
.wp-block-group.is-style-section-bone h2.is-style-section-marker,
.wp-block-group.is-style-section-bone h3.is-style-section-marker {
  border-left-color: var(--muted-on-bone);
}

/* --- GRUPPO SEZIONE --- */

.wp-block-group.is-style-section-ink {
  background-color: var(--ink);
  color: var(--text-on-ink);
  padding: var(--pad-y) var(--pad-x);
}
.wp-block-group.is-style-section-bone {
  background-color: var(--bone);
  color: var(--text-on-bone);
  padding: var(--pad-y) var(--pad-x);
}

/* --- COLONNE --- */

.wp-block-columns.is-style-split { align-items: center; }

/* --- SEPARATORE --- */

.wp-block-separator.is-style-thin {
  border-color: var(--line-on-ink);
  border-width: 1px;
  opacity: 1;
}
.wp-block-group.is-style-section-bone .wp-block-separator.is-style-thin {
  border-color: var(--line-on-bone);
}

/* --- CITAZIONE --- */

.wp-block-quote,
.wp-block-quote.is-style-editorial {
  border-left: 2px solid var(--accent);
  padding-left: 1.5rem;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  line-height: 1.55;
  margin: 2rem 0;
}

/* --- BOTTONI --- */

.wp-block-button .wp-block-button__link {
  border-radius: 0;
  font-family: var(--font-mono);
  font-size: clamp(0.6rem, 0.75vw, 0.72rem);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  transition: opacity var(--dur-fast) ease;
}
.wp-block-button .wp-block-button__link:hover { opacity: 0.72; }

.wp-block-button.is-style-outline-ink .wp-block-button__link {
  background: transparent;
  border: 1px solid var(--bone-deep);
  color: var(--bone-deep);
  padding: clamp(0.7rem, 1vw, 0.875rem) clamp(1.25rem, 2vw, 2rem);
  border-radius: 0;
}
.wp-block-button.is-style-outline-bone .wp-block-button__link {
  background: transparent;
  border: 1px solid var(--text-on-bone);
  color: var(--text-on-bone);
  padding: clamp(0.7rem, 1vw, 0.875rem) clamp(1.25rem, 2vw, 2rem);
  border-radius: 0;
}
.wp-block-button.is-style-filled-ink .wp-block-button__link {
  background: var(--ink);
  border: 1px solid var(--ink);
  color: var(--bone-deep);
  padding: clamp(0.7rem, 1vw, 0.875rem) clamp(1.25rem, 2vw, 2rem);
  border-radius: 0;
}
.wp-block-button.is-style-filled-bone .wp-block-button__link {
  background: var(--bone);
  border: 1px solid var(--bone);
  color: var(--ink);
  padding: clamp(0.7rem, 1vw, 0.875rem) clamp(1.25rem, 2vw, 2rem);
  border-radius: 0;
}
.wp-block-button.is-style-link-arrow .wp-block-button__link {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  font-family: var(--font-mono);
  font-size: clamp(0.6rem, 0.75vw, 0.72rem);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: inherit !important;
  border-radius: 0 !important;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  box-shadow: none !important;
}
.wp-block-button.is-style-link-arrow .wp-block-button__link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
}
.wp-block-button.is-style-link-arrow .wp-block-button__link::before {
  content: '→';
  display: inline-block;
  transition: transform var(--dur-fast) ease;
  order: 2;
}
.wp-block-button.is-style-link-arrow .wp-block-button__link:hover::before {
  transform: translateX(5px);
}

/* Read More link-arrow */
a.wp-block-read-more.is-style-link-arrow {
  font-family: var(--font-mono);
  font-size: clamp(0.55rem, 0.7vw, 0.65rem);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 0.1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: opacity var(--dur-fast) ease;
}
a.wp-block-read-more.is-style-link-arrow::after {
  content: '→';
  display: inline-block;
  transition: transform var(--dur-fast) ease;
}
a.wp-block-read-more.is-style-link-arrow:hover::after {
  transform: translateX(5px);
}
a.wp-block-read-more.is-style-link-arrow:hover {
  opacity: 0.7;
}

/* =========================================================
   4. SKIP LINK
   ========================================================= */

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 9999;
  padding: 0.75rem 1.5rem;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.skip-link:focus-visible { left: 1rem; top: 1rem; }

/* =========================================================
   5. LAYOUT CONTAINER
   ========================================================= */

.gs-container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--pad-x-mob);
}
@media (min-width: 48em) {
  .gs-container { padding-inline: var(--pad-x); }
}

main#main-content { display: block; }

/* =========================================================
   5. SITE HEADER + NAV
   ========================================================= */

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  height: var(--nav-h);
  background: rgba(10, 9, 8, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: background-color var(--dur-mid) ease,
              border-color var(--dur-mid) ease;
}

body.front-page .site-header:not(.site-header--scrolled) {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

html body.home.front-page .site-header .site-nav__logo,
html body.home.front-page .site-header .site-nav__pill {
  opacity: 0 !important;
  pointer-events: none !important;
}
html body.home.front-page .site-header.site-header--scrolled .site-nav__logo,
html body.home.front-page .site-header.site-header--scrolled .site-nav__pill {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.site-header--scrolled {
  background: rgba(10, 9, 8, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line-on-ink);
}
@media (min-width: 48em) {
  .site-header--scrolled .site-nav__pill { display: inline-flex; }
}

.site-nav {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 100%;
  padding-inline: var(--pad-x-mob);
  gap: 1rem;
}
@media (min-width: 48em) {
  .site-nav { padding-inline: var(--pad-x); }
}

.site-nav__logo {
  justify-self: start;
  display: inline-flex;
  align-items: center;
}

.site-nav__logo img,
.site-nav__logo .custom-logo { height: 36px; width: auto; display: block; }

.site-nav__logo-text {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

.site-nav__menu {
  justify-self: center;
  display: none;
  gap: 2rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-on-ink);
}
.site-nav__menu a { transition: color var(--dur-fast) ease; }
.site-nav__menu a:hover { color: var(--accent); }
.site-nav__menu .current-menu-item > a {
  border-bottom: 1px solid var(--accent);
  padding-bottom: 2px;
  color: var(--bone);
}

.site-nav__right {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}

.site-nav__pill {
  display: none;
  align-items: center;
  gap: 0.25rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  color: var(--text-on-ink);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-mid) ease;
}
.site-header--scrolled .site-nav__pill {
  opacity: 1;
  pointer-events: auto;
}

/* Hamburger — 3 barre che animano in X */
.site-nav__toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: none;
  color: var(--text-on-ink);
  cursor: pointer;
}
.site-nav__bar {
  display: block;
  width: 22px;
  height: 1px;
  background-color: currentColor;
  transform-origin: center;
  transition: transform 0.4s var(--ease-out),
              opacity 0.3s ease;
}
.site-nav__toggle.is-open .site-nav__bar--top {
  transform: translateY(6px) rotate(45deg);
}
.site-nav__toggle.is-open .site-nav__bar--mid {
  opacity: 0;
  transform: scaleX(0);
}
.site-nav__toggle.is-open .site-nav__bar--bot {
  transform: translateY(-6px) rotate(-45deg);
}

/* =========================================================
   6. NAV DRAWER
   ========================================================= */

.nav-drawer {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  padding: 5rem var(--pad-x-mob) 3rem;
  background: #0A0908;
  color: var(--text-on-ink);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity var(--dur-mid) ease,
              transform var(--dur-mid) ease,
              visibility 0s linear var(--dur-mid);
  overflow-y: auto;
}
.nav-drawer[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity var(--dur-mid) ease,
              transform var(--dur-mid) ease,
              visibility 0s;
}

body.menu-open {
  overflow: hidden;
}
body.menu-open .site-header {
  z-index: 600;
}
.nav-drawer__menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(2rem, 8vw, 3rem);
  line-height: 1;
}

.nav-drawer__menu .current-menu-item > a {
  color: var(--accent);
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Voci menu — partono nascoste e traslate */
.nav-drawer__menu li {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s var(--ease-out),
              transform 0.5s var(--ease-out);
}

/* Quando il drawer è aperto — stagger sulle voci */
.nav-drawer[aria-hidden="false"] .nav-drawer__menu li:nth-child(1) {
  opacity: 1; transform: none; transition-delay: 0.05s;
}
.nav-drawer[aria-hidden="false"] .nav-drawer__menu li:nth-child(2) {
  opacity: 1; transform: none; transition-delay: 0.1s;
}
.nav-drawer[aria-hidden="false"] .nav-drawer__menu li:nth-child(3) {
  opacity: 1; transform: none; transition-delay: 0.15s;
}
.nav-drawer[aria-hidden="false"] .nav-drawer__menu li:nth-child(4) {
  opacity: 1; transform: none; transition-delay: 0.2s;
}
.nav-drawer[aria-hidden="false"] .nav-drawer__menu li:nth-child(5) {
  opacity: 1; transform: none; transition-delay: 0.25s;
}

/* Counter e lang entrano dopo le voci */
.nav-drawer__lang,
.nav-drawer__counter {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.5s var(--ease-out),
              transform 0.5s var(--ease-out);
}
.nav-drawer[aria-hidden="false"] .nav-drawer__lang {
  opacity: 1; transform: none; transition-delay: 0.3s;
}
.nav-drawer[aria-hidden="false"] .nav-drawer__counter {
  opacity: 1; transform: none; transition-delay: 0.38s;
}

/* Reset immediato alla chiusura */
.nav-drawer[aria-hidden="true"] .nav-drawer__menu li,
.nav-drawer[aria-hidden="true"] .nav-drawer__lang,
.nav-drawer[aria-hidden="true"] .nav-drawer__counter {
  opacity: 0;
  transform: translateY(12px);
  transition: none;
}

.nav-drawer__menu a {
  transition: color var(--dur-fast) ease;
}
.nav-drawer__menu a:hover { color: var(--accent); }
.nav-drawer__menu .current-menu-item > a { color: var(--accent); }
.nav-drawer__menu a { transition: color var(--dur-fast) ease; }
.nav-drawer__menu a:hover { color: var(--accent); }
.nav-drawer__menu .current-menu-item > a { color: var(--accent); }

.nav-drawer__lang {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.nav-drawer__lang ul { display: inline-flex; gap: 1rem; }
.nav-drawer__lang li.current-lang a { color: var(--accent); }

.nav-drawer__counter {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  text-align: center;
  line-height: 1.6;
}

/* Toggle sempre sopra il drawer */
.site-nav__toggle {
  position: relative;
  z-index: 400;
}

/* =========================================================
   7. RESPONSIVE NAV
   ========================================================= */

@media (max-width: 47.99em) {
  .site-header { height: 56px; }
  .site-nav {
    grid-template-columns: 44px 1fr 44px;
    padding-inline: var(--pad-x-mob);
  }
  .site-nav__logo {
    grid-column: 2;
    justify-self: center;
  }
  .site-nav__menu { display: none !important; }
  .site-nav__pill { display: none !important; }
  .site-nav__right {
    grid-column: 3;
    justify-self: end;
  }
}
@media (min-width: 48em) {
  .site-nav__toggle { display: none; }
  .site-nav__menu   { display: flex; }
}

/* =========================================================
   8. BUTTON BASELINE + ALIAS LEGACY
   ========================================================= */

.gs-btn,
.wp-block-button .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.6rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  font-weight: 300;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border: 1px solid transparent;
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  transition: opacity var(--dur-fast) ease;
}
.gs-btn:hover { opacity: 0.75; }
.gs-btn--large { padding: 1.05rem 2rem; font-size: 0.8rem; }
.gs-btn--outline.gs-btn--su-ink  { border-color: var(--bone-deep);    color: var(--bone-deep); }
.gs-btn--filled.gs-btn--su-ink   { background:   var(--bone-deep);    color: var(--ink); }
.gs-btn--outline.gs-btn--su-bone { border-color: var(--text-on-bone); color: var(--text-on-bone); }
.gs-btn--filled.gs-btn--su-bone  { background:   var(--ink);          color: var(--bone-deep); }

.wp-block-button.is-style-outline-ink .wp-block-button__link:hover,
.wp-block-button.is-style-outline-bone .wp-block-button__link:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--white);
  opacity: 1;
}

/* =========================================================
   9. ANIMAZIONI — reveal on scroll
   ========================================================= */

.reveal {
  --reveal-delay: 0s;
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 1s var(--ease-out) var(--reveal-delay),
    transform 1s var(--ease-out) var(--reveal-delay);
}
.reveal.reveal-in-view {
  opacity: 1;
  transform: none;
}
.editor-styles-wrapper .reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* Stagger — Query Loop (variabile sul li padre) */
.wp-block-post-template > li:nth-child(1) { --reveal-delay: 0s;    }
.wp-block-post-template > li:nth-child(2) { --reveal-delay: 0.1s;  }
.wp-block-post-template > li:nth-child(3) { --reveal-delay: 0.2s;  }
.wp-block-post-template > li:nth-child(4) { --reveal-delay: 0.3s;  }
.wp-block-post-template > li:nth-child(5) { --reveal-delay: 0.4s;  }
.wp-block-post-template > li:nth-child(6) { --reveal-delay: 0.5s;  }

/* Stagger — siblings diretti con classe reveal */
.reveal:nth-child(2) { --reveal-delay: 0.1s;  }
.reveal:nth-child(3) { --reveal-delay: 0.2s;  }
.reveal:nth-child(4) { --reveal-delay: 0.3s;  }
.reveal:nth-child(5) { --reveal-delay: 0.4s;  }

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* =========================================================
   ONLOAD — animazione entrata (CSS keyframes, no page-loaded)
   ========================================================= */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

.gs-hero__years      { animation: fade-up 0.5s var(--ease-out) 0.05s both; }
.gs-hero__anni-label { animation: fade-up 0.5s var(--ease-out) 0.1s both; }
.gs-hero__counter    { animation: fade-up 0.5s var(--ease-out) 0.15s both; }
.gs-hero__claim      { animation: fade-up 0.5s var(--ease-out) 0.22s both; }
.gs-hero__cta        { animation: fade-up 0.5s var(--ease-out) 0.3s both; }
.gs-hero__scroll     { animation: fade-up 0.5s var(--ease-out) 0.4s both; }

.site-nav__logo  { animation: fade-up 0.5s var(--ease-out) 0.05s both; }
.site-nav__menu  { animation: fade-up 0.5s var(--ease-out) 0.1s both; }
.site-nav__right { animation: fade-up 0.5s var(--ease-out) 0.15s both; }

.gs-esp-hero__eyebrow { animation: fade-up 0.5s var(--ease-out) 0.05s both; }
.gs-esp-hero__title   { animation: fade-up 0.5s var(--ease-out) 0.15s both; }
.gs-esp-hero__excerpt { animation: fade-up 0.5s var(--ease-out) 0.25s both; }

.gs-vino-hero__eyebrow { animation: fade-up 0.5s var(--ease-out) 0.05s both; }
.gs-vino-hero__title   { animation: fade-up 0.5s var(--ease-out) 0.15s both; }
.gs-vino-hero__tag     { animation: fade-up 0.5s var(--ease-out) 0.2s both; }
.gs-vino-hero__excerpt { animation: fade-up 0.5s var(--ease-out) 0.25s both; }
.gs-vino-hero__media   { animation: fade-up 0.5s var(--ease-out) 0.1s both; }

/* Editor Gutenberg: niente animazione d'entrata */
.editor-styles-wrapper .gs-hero__years,
.editor-styles-wrapper .gs-hero__anni-label,
.editor-styles-wrapper .gs-hero__counter,
.editor-styles-wrapper .gs-hero__claim,
.editor-styles-wrapper .gs-hero__cta,
.editor-styles-wrapper .gs-hero__scroll {
  animation: none;
}

@media (prefers-reduced-motion: reduce) {
  .gs-hero__years, .gs-hero__anni-label,
  .gs-hero__counter, .gs-hero__claim,
  .gs-hero__cta, .gs-hero__scroll,
  .site-nav__logo, .site-nav__menu,
  .site-nav__right,
  .gs-esp-hero__eyebrow, .gs-esp-hero__title,
  .gs-esp-hero__excerpt,
  .gs-vino-hero__eyebrow, .gs-vino-hero__title,
  .gs-vino-hero__tag, .gs-vino-hero__excerpt,
  .gs-vino-hero__media {
    animation: none;
  }
}

/* FAQ vecchio markup — toggle simulato con ::after */
.gs-faq__q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1.5rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--text-on-ink);
  transition: opacity var(--dur-fast) ease;
}
.gs-faq__q:hover { opacity: 0.72; }
.gs-faq__q::after {
  content: '+';
  font-family: var(--font-mono);
  font-size: 1.1rem;
  color: var(--muted-on-ink);
  transition: transform 0.4s var(--ease-out);
  flex-shrink: 0;
  margin-left: 2rem;
}
.gs-faq__item--open .gs-faq__q::after {
  transform: rotate(45deg);
}
.gs-faq__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.5s var(--ease-out);
  overflow: hidden;
}
.gs-faq__a > * {
  min-height: 0;
  overflow: hidden;
}
.gs-faq__item--open .gs-faq__a {
  grid-template-rows: 1fr;
}
.gs-faq__item--open .gs-faq__a > * {
  padding-bottom: 2rem;
}
.gs-faq__a p {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  font-weight: 300;
  color: var(--muted-on-ink);
  line-height: 1.75;
}

/* =========================================================
   10. BLOCK: gs-hero
   ========================================================= */

.gs-hero {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  background: var(--ink);
  color: var(--text-on-ink);
  position: relative;
}
.gs-hero__top {
  padding-top: calc(var(--nav-h) + 2rem);
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
.gs-hero__center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem var(--pad-x);
}
.gs-hero__bottom {
  padding-bottom: 2.5rem;
  display: flex;
  justify-content: center;
}
.gs-hero__image {
  max-height: 80px;
  width: auto;
  display: block;
}
.gs-hero__years {
  font-family: var(--font-mono);
  font-weight: 200;
  font-size: clamp(5.5rem, 17vw, 15rem);
  letter-spacing: -0.06em;
  line-height: 0.9;
  color: var(--bone-deep);
  margin-bottom: 0.2rem;
}
.gs-hero__anni-label {
  font-family: var(--font-mono);
  font-size: clamp(0.6rem, 0.9vw, 0.85rem);
  letter-spacing: 0.55em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  margin-bottom: 1.75rem;
}
.gs-hero__counter {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 2.5rem;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  min-width: max-content;
  font-variant-numeric: tabular-nums;
}
.gs-hero__counter [data-counter],
.gs-hero__counter-num {
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: 300;
  font-size: clamp(0.95rem, 1.8vw, 1.35rem);
  letter-spacing: normal;
  text-transform: none;
  color: var(--bone-deep);
  font-variant-numeric: tabular-nums;
}
.gs-hero__counter-num {
  display: inline-block;
  min-width: 2ch;
  text-align: right;
}
.gs-hero__counter-num[data-counter="clock"] { min-width: 5ch; }
.gs-hero__geo {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  margin-bottom: 1.25rem;
}
.gs-hero__claim {
  font-family: var(--font-serif);
  font-style: italic;
  font-variation-settings: "SOFT" 100;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  line-height: 1.3;
  color: var(--bone-deep);
  max-width: 680px;
  margin-inline: auto;
}
.gs-hero__cta { margin-top: 2.5rem; }
.gs-hero__scroll {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  transition: opacity var(--dur-slow) ease;
}
.gs-hero__scroll-line {
  display: block;
  width: 1px;
  height: 44px;
  position: relative;
  overflow: hidden;
}
.gs-hero__scroll-line::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 1px;
  height: 100%;
  background: var(--muted-on-ink);
  animation: line-reveal 2s var(--ease-out) infinite;
}
@keyframes line-reveal {
  0%   { transform: translateY(-100%); }
  50%  { transform: translateY(0%); }
  100% { transform: translateY(100%); }
}

@media (max-width: 37.49em) {
  .gs-hero { min-height: 95vh; }
  .gs-hero__years { font-size: clamp(4rem, 22vw, 6.5rem); }
  .gs-hero__counter { flex-wrap: wrap; gap: 0.3rem; }
  .gs-hero__image {max-height: 36px;}
}

/* =========================================================
   11. BLOCK: gs-cronologia (accordion)
   ========================================================= */

.gs-cronologia {
  padding: var(--pad-y-mob) var(--pad-x-mob);
}
@media (min-width: 48em) { .gs-cronologia { padding: var(--pad-y) var(--pad-x); } }
.gs-cronologia--ink  { background: var(--ink);  color: var(--text-on-ink); }
.gs-cronologia--bone { background: var(--bone); color: var(--text-on-bone); }
.gs-cronologia__inner { max-width: var(--container); margin-inline: auto; }

.gs-cronologia__voce { border-top: 1px solid var(--line-on-bone); }
.gs-cronologia--ink .gs-cronologia__voce { border-top-color: var(--line-on-ink); }
.gs-cronologia__voce:last-child { border-bottom: 1px solid var(--line-on-bone); }
.gs-cronologia--ink .gs-cronologia__voce:last-child { border-bottom-color: var(--line-on-ink); }

.gs-cronologia__header {
  display: grid;
  grid-template-columns: 120px 100px 1fr auto;
  align-items: center;
  column-gap: 2rem;
  padding: 1.5rem 0;
  width: 100%;
  cursor: pointer;
  border: none;
  background: none;
  text-align: left;
  color: inherit;
  font: inherit;
  transition: opacity var(--dur-fast) ease;
}
.gs-cronologia__header:hover { opacity: 0.75; }

.gs-cronologia__atto {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
  white-space: nowrap;
}
.gs-cronologia--ink .gs-cronologia__atto { color: var(--muted-on-ink); }

.gs-cronologia__anno {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  letter-spacing: -0.05em;
  white-space: nowrap;
}
.gs-cronologia__titolo {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.3rem, 1.8vw, 1.5rem);
  line-height: 1.4;
}
.gs-cronologia__icon {
  font-family: var(--font-mono);
  font-size: 1.25rem;
  line-height: 1;
  width: 1em;
  text-align: center;
  transition: transform var(--dur-mid) var(--ease-out);
}
.gs-cronologia__icon::before { content: "+"; display: inline-block; }
.gs-cronologia__header[aria-expanded="true"] .gs-cronologia__icon { transform: rotate(45deg); }

.gs-cronologia__corpo {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--dur-slow) var(--ease-out);
  overflow: hidden;
}
.gs-cronologia__corpo.is-open { grid-template-rows: 1fr; }
.gs-cronologia__corpo-inner {
  min-height: 0;
  overflow: hidden;
  padding-left: calc(120px + 163px);
  padding-right: 2rem;
  padding-top: 0;
  padding-bottom: 0;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.7;
  transition: padding var(--dur-slow) var(--ease-out);
}
.gs-cronologia__corpo.is-open .gs-cronologia__corpo-inner {
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
}
.gs-cronologia__corpo-inner p { margin: 0 0 1rem; }
.gs-cronologia__corpo-inner p:last-child { margin-bottom: 0; }
.gs-cronologia__corpo-inner h2,
.gs-cronologia__corpo-inner h3 {
  font-family: var(--font-serif);
  font-weight: 200;
  letter-spacing: -0.02em;
  margin: 1.5rem 0 0.75rem;
}
.gs-cronologia__corpo-inner blockquote {
  border-left: 2px solid var(--accent);
  padding-left: 1.5rem;
  margin: 1.5rem 0;
  font-family: var(--font-serif);
  font-style: italic;
}

.editor-styles-wrapper .gs-cronologia__corpo { grid-template-rows: 1fr; }

@media (max-width: 47.99em) {
  .gs-cronologia__header {
    grid-template-columns: 70px 70px 1fr auto;
    column-gap: 0.75rem;
  }
  .gs-cronologia__corpo-inner { padding-left: 0; }
}
@media (max-width: 37.49em) {
  .gs-cronologia__header {
    grid-template-columns: 1fr auto;
    grid-template-areas: "atto icon" "anno icon" "titolo titolo";
    gap: 0.4rem 1rem;
  }
  .gs-cronologia__atto   { grid-area: atto; }
  .gs-cronologia__anno   { grid-area: anno; }
  .gs-cronologia__titolo { grid-area: titolo; margin-top: 0.4rem; }
  .gs-cronologia__icon   { grid-area: icon; align-self: center; }
}

/* =========================================================
   12. BLOCK: gs-vino-card (Query Loop home)
   ========================================================= */

.gs-vino-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 1.75rem;
  padding: 2rem var(--pad-x);
  border-bottom: 1px solid var(--line-on-bone);
  min-height: 185px;
  align-content: start;
}
.gs-vino-card__numero {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 200;
  color: var(--muted-on-bone);
  padding-top: 0.2rem;
}
.gs-vino-card__nome,
.gs-vino-card__nome a {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: clamp(1.3rem, 1.6vw, 1.5rem);
  color: var(--text-on-bone);
  text-decoration: none;
  line-height: 1.15;
  margin-bottom: 0.8rem;
  display: block;
}
.gs-vino-card__tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
  margin-bottom: 1.25rem;
}
.gs-vino-card__meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.35rem 1.25rem;
  margin-bottom: 1.1rem;
  align-items: center;
}
.gs-vino-card__meta-label {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
}
.gs-vino-card__meta-value {
  font-family: var(--font-serif);
  font-size: 0.85rem;
  font-style: italic;
  color: var(--text-on-bone);
}
.gs-vino-card__link {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  color: var(--text-on-bone);
  padding-bottom: 0.1rem;
  display: inline-block;
  transition: opacity var(--dur-fast) ease;
}
.gs-vino-card__link:hover { opacity: 0.6; }

ul.wp-block-post-template.columns-2 > li { min-height: 0; }
ul.wp-block-post-template.columns-2 > li.vino:nth-child(odd) {
  border-right: 1px solid var(--line-on-bone);
}
ul.wp-block-post-template.columns-2 > li.esperienza:nth-child(odd) {
  border-right: 1px solid var(--line-on-ink);
}
ul.wp-block-post-template.columns-2 > li:nth-child(even) {
  border-right: none;
}

/* =========================================================
   12-bis. BLOCK: gs-vino-row (pagina vini, lista con etichetta)
   ========================================================= */

.gs-vino-row {
  display: grid;
  grid-template-columns: 20px 180px 1fr auto;
  align-items: center;
  gap: 2rem;
  padding: 2.5rem 0px;
  border-bottom: 1px solid var(--line-on-bone);
}
.is-style-section-ink .gs-vino-row { border-bottom-color: var(--line-on-ink); }

.gs-vino-row__numero {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 200;
  color: var(--muted-on-bone);
  align-self: start;
  padding-top: 0.25rem;
}
.is-style-section-ink .gs-vino-row__numero { color: var(--muted-on-ink); }

.gs-vino-row__media {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 200px;
  width: 180px;
  overflow: hidden;
  flex-shrink: 0;
}
.gs-vino-row__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gs-vino-row__content { display: flex; flex-direction: column; gap: 0.4rem; }

.gs-vino-row__parola {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
}
.is-style-section-ink .gs-vino-row__parola { color: var(--muted-on-ink); }

.gs-vino-row__nome {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.6rem, 2.8vw, 2.5rem);
  color: var(--text-on-bone);
  line-height: 1;
  letter-spacing: -0.02em;
}
.is-style-section-ink .gs-vino-row__nome { color: var(--text-on-ink); }

.gs-vino-row__tag {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
}
.is-style-section-ink .gs-vino-row__tag { color: var(--muted-on-ink); }

.gs-vino-row__excerpt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-subhead);
  color: var(--text-on-bone);
  line-height: 1.4;
  margin-top: 0.5rem;
  max-width: 500px;
}
.is-style-section-ink .gs-vino-row__excerpt { color: var(--text-on-ink); }

.gs-vino-row__aside {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}
.gs-vino-row__annata {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--muted-on-bone);
  text-transform: uppercase;
}
.is-style-section-ink .gs-vino-row__annata { color: var(--muted-on-ink); }

/* Link foto */
.gs-vino-row__media-link {
  display: block;
  height: 100%;
  cursor: pointer;
}
.gs-vino-row__media-link:hover .gs-vino-row__img {
  opacity: 0.85;
  transition: opacity var(--dur-mid) ease;
}

/* Separatore aside */
.gs-vino-row__sep {
  border: none;
  border-top: 1px solid var(--line-on-bone);
  width: 100%;
  margin: 0.5rem 0;
}
.is-style-section-ink .gs-vino-row__sep {
  border-top-color: var(--line-on-ink);
}

/* CTA hover accent */
.gs-vino-row__link {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--text-on-bone);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: color var(--dur-fast) ease;
}
.gs-vino-row__link:hover {
  color: var(--accent);
}
.is-style-section-ink .gs-vino-row__link {
  color: var(--text-on-ink);
}
.is-style-section-ink .gs-vino-row__link:hover {
  color: var(--accent);
}

/* Cursore pointer sulla riga intera */
.gs-vino-row {
  cursor: default;
}
.gs-vino-row__media-link,
.gs-vino-row__link {
  cursor: pointer;
}

ul.wp-block-post-template:has(.gs-vino-row) {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
ul.wp-block-post-template:has(.gs-vino-row) > li {
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}

@media (max-width: 48em) {
  .gs-vino-row {
    grid-template-columns: 40px 1fr;
    gap: 1rem;
    padding: 2rem var(--pad-x-mob);
  }
  .gs-vino-row__media { display: none; }
  .gs-vino-row__aside {
    grid-column: 2;
    align-items: flex-start;
    flex-direction: row;
    gap: 1rem;
  }
}

/* =========================================================
   13. BLOCK: gs-esperienza-card e gs-esperienza-card-image
   ========================================================= */

/* Card compatta (home) */
.gs-esp-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem var(--pad-x);
  min-height: 265px;
}
.gs-esp-card__media { aspect-ratio: 4/3; overflow: hidden; }
.gs-esp-card__media img { width: 100%; height: 100%; object-fit: cover; }
.gs-esp-card__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: block;
  margin-bottom: 1rem;
}
.gs-esp-card__title {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.gs-esp-card__title a:hover { opacity: 0.7; }
.gs-esp-card__excerpt {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: 1.1rem;
  line-height: 1.25;
  max-width: 50ch;
  margin:10px 0px;
}
.gs-esp-card__meta {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.3em;
  color: var(--muted-on-ink);
  text-transform: uppercase;
}
.gs-esp-card__cta {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid var(--line-on-bone);
  color: var(--text-on-ink);
  padding-bottom: 0.1rem;
  display: inline-block;
  transition: opacity var(--dur-fast) ease;
}
.gs-esp-card__cta:hover { opacity: 0.6; }

/* Bordi griglia esperienze */
ul.wp-block-post-template.columns-2 > li .gs-esp-card {
  border-top: 1px solid var(--line-on-ink);
  border-bottom: none;
  border-left: none;
  border-right: none;
}

/* Bordo verticale centrale — solo li dispari */
ul.wp-block-post-template.columns-2 > li:nth-child(odd) .gs-esp-card {
  border-right: 1px solid var(--line-on-ink);
}

/* Ultima riga completa — bordo bottom */
ul.wp-block-post-template.columns-2 > li:nth-last-child(-n+2):nth-child(odd) ~ li .gs-esp-card,
ul.wp-block-post-template.columns-2 > li:last-child .gs-esp-card,
ul.wp-block-post-template.columns-2 > li:nth-last-child(2) .gs-esp-card {
  border-bottom: 1px solid var(--line-on-ink);
}

/* Ultimo item dispari da solo — niente bordo right */
ul.wp-block-post-template.columns-2 > li:last-child:nth-child(odd) .gs-esp-card {
  border-right: none;
}

/* Card con immagine (pagina esperienze) */
.gs-esp-card-img {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  border-bottom: 1px solid var(--line-on-ink);
  min-height: 520px;
  padding:40px 0px;
}
.wp-block-post:has(.gs-esp-card-img) { width: 100%; max-width: 100%; padding: 0; margin: 0; }
ul.wp-block-post-template:has(.gs-esp-card-img) {
  display: flex !important;
  flex-direction: column !important;
  gap: 0px !important;
  padding: 0 !important;
  margin: 0 !important;
}
ul.wp-block-post-template:has(.gs-esp-card-img) > li {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
.gs-esp-card-img--even { direction: rtl; }
.gs-esp-card-img--even > * { direction: ltr; }
.gs-esp-card-img__media { overflow: hidden; }
.gs-esp-card-img__photo { width: 100%; height: 100%; object-fit: cover; display: block; padding:0px; }
.gs-esp-card-img__content {
  padding: 5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.25rem;
  background: var(--ink);
}
.gs-esp-card-img__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
.gs-esp-card-img__title,
.gs-esp-card-img__title a {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.8rem, 3.5vw, 3.2rem);
  color: var(--text-on-ink);
  text-decoration: none;
  line-height: 1;
}
.gs-esp-card-img__excerpt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-subhead);
  color: var(--text-on-ink);
  line-height: 1.45;
}
.gs-esp-card-img__bullets {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  border-top: 1px solid var(--line-on-ink);
  padding-top: 1rem;
}
.gs-esp-card-img__bullet {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  color: var(--text-on-ink);
  font-weight: 300;
  padding-left: 1.25rem;
  position: relative;
}
.gs-esp-card-img__bullet::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--muted-on-ink);
}
.gs-esp-card-img__meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--line-on-ink);
  padding-top: 1rem;
}
.gs-esp-card-img__meta-val { font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-on-ink); }
.gs-esp-card-img__meta-lbl {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
.gs-esp-card-img__meta-sep { color: var(--muted-on-ink); }
.gs-esp-card-img__actions { display: flex; align-items: center; gap: 2rem; }
.gs-esp-card-img__link {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  color: var(--text-on-ink);
  padding-bottom: 0.1rem;
  transition: opacity var(--dur-fast) ease;
}
.gs-esp-card-img__link:hover { opacity: 0.6; }

@media (max-width: 48em) {
  .gs-esp-card-img,
  .gs-esp-card-img--even { grid-template-columns: 1fr; direction: ltr; }
  .gs-esp-card-img__media { height: 350px; }
  .gs-esp-card-img__content { padding: 2.5rem 0.1rem; }
}

/* =========================================================
   14. BLOCK: gs-counter
   ========================================================= */

.gs-counter {
  font-family: var(--font-mono);
  font-size: 1rem;
  color: var(--text-on-ink);
  letter-spacing: 0.05em;
  text-align: center;
}

/* =========================================================
   15. BLOCK: gs-tier-cards (Wine Club)
   ========================================================= */

.gs-tier-cards {
  padding: var(--pad-y-mob) var(--pad-x-mob);
}
@media (min-width: 48em) { .gs-tier-cards { padding: var(--pad-y) var(--pad-x); } }
.gs-tier-cards--ink  { background: var(--ink);  color: var(--text-on-ink); }
.gs-tier-cards--bone { background: var(--bone); color: var(--text-on-bone); }
.gs-tier-cards__inner {
  max-width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 56.25em) { .gs-tier-cards__inner { grid-template-columns: 1fr 1fr 1fr; gap: 2rem; } }

.gs-tier {
  display: flex;
  flex-direction: column;
  padding: 2.5rem;
  border: 1px solid var(--line-on-bone);
  background: var(--bone-deep);
  color: var(--text-on-bone);
  transition: transform var(--dur-mid) ease;
}
.gs-tier-cards--ink .gs-tier {
  border-color: var(--line-on-ink);
  background: rgba(232, 226, 210, 0.04);
  color: var(--text-on-ink);
}
.gs-tier--featured {
  background: var(--ink);
  color: var(--text-on-ink);
  border-color: var(--accent);
}
@media (min-width: 56.25em) { .gs-tier--featured { transform: translateY(-12px); } }

.gs-tier__level {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
}
.gs-tier-cards--ink .gs-tier__level,
.gs-tier--featured .gs-tier__level { color: var(--muted-on-ink); }
.gs-tier__name {
  margin-top: 0.5rem;
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.8rem, 2.8vw, 2.4rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.gs-tier__desc {
  margin-top: 1rem;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1rem;
  line-height: 1.5;
}
.gs-tier__price { margin-top: 2rem; font-family: var(--font-mono); font-size: 1.5rem; }
.gs-tier__freq {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
}
.gs-tier-cards--ink .gs-tier__freq,
.gs-tier--featured .gs-tier__freq { color: var(--muted-on-ink); }
.gs-tier__benefits {
  margin-top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  line-height: 1.5;
}
.gs-tier__benefits li::before { content: "— "; opacity: 0.55; }
.gs-tier__cta { margin-top: auto; padding-top: 2rem; }

@media (max-width: 56.24em) { .gs-tier--featured { transform: none; } }

/* =========================================================
   16. BLOCK: gs-faq
   ========================================================= */

.gs-faq { width: 100%; }
.gs-faq__lista { width: 100%; }

.gs-faq__item {
  border-top: 1px solid var(--line-on-ink);
}
.gs-faq__item:last-child {
  border-bottom: 1px solid var(--line-on-ink);
}
/* Bone context */
.wp-block-group.is-style-section-bone .gs-faq__item {
  border-top-color: var(--line-on-bone);
}
.wp-block-group.is-style-section-bone .gs-faq__item:last-child {
  border-bottom-color: var(--line-on-bone);
}

.gs-faq__header {
  display: grid;
  grid-template-columns: 1fr 20px;
  align-items: center;
  gap: 2rem;
  width: 100%;
  padding: 1.5rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: opacity var(--dur-fast) ease;
}
.gs-faq__header:hover { opacity: 0.72; }

.gs-faq__domanda {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.25rem, 1.5vw, 1.35rem);
  color: var(--text-on-ink);
  line-height: 1.35;
}
.wp-block-group.is-style-section-bone .gs-faq__domanda {
  color: var(--text-on-bone);
}

.gs-faq__toggle {
  position: relative;
  width: 16px;
  height: 16px;
  justify-self: end;
  flex-shrink: 0;
}
.gs-faq__toggle-bar {
  position: absolute;
  background: var(--bone);
  transition: transform 0.4s var(--ease-out), opacity var(--dur-mid) ease;
}
.wp-block-group.is-style-section-bone .gs-faq__toggle-bar {
  background: var(--muted-on-bone);
}
.gs-faq__toggle-bar--h {
  width: 16px;
  height: 1px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.gs-faq__toggle-bar--v {
  width: 1px;
  height: 16px;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.gs-faq__item--open .gs-faq__toggle-bar--v {
  transform: translateX(-50%) rotate(45deg);
  opacity: 1;
}
.gs-faq__item--open .gs-faq__toggle-bar--h {
  transform: translateY(-50%) rotate(45deg);
}

.gs-faq__risposta {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height var(--dur-slow) var(--ease-out),
              opacity var(--dur-mid) ease;
}
.gs-faq__item--open .gs-faq__risposta {
  max-height: 800px;
  opacity: 1;
}
.gs-faq__risposta-inner { padding: 0 2rem 2rem 0; }
.gs-faq__risposta-inner p {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  font-weight: 300;
  color: var(--bone);
  line-height: 1.75;
}
.wp-block-group.is-style-section-bone .gs-faq__risposta-inner p {
  color: var(--muted-on-bone);
}

/* Vecchio markup — compatibilità */
.gs-faq__q {
  display: grid;
  grid-template-columns: 1fr 20px;
  align-items: center;
  gap: 2rem;
  width: 100%;
  padding: 1.5rem 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--text-on-ink);
  transition: opacity var(--dur-fast) ease;
}
.gs-faq__q:hover { opacity: 0.72; }
.gs-faq__a {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height var(--dur-slow) var(--ease-out),
              opacity var(--dur-mid) ease;
}
.gs-faq__item--open .gs-faq__a {
  max-height: 800px;
  opacity: 1;
  padding-bottom: 2rem;
}

@media (max-width: 48em) { .gs-faq__header { padding: 1.25rem 0; } }

/* =========================================================
   17. BLOCK: gs-acf-field
   ========================================================= */

.gs-acf-field { display: flex; flex-direction: column; gap: 0.4rem; }
.gs-acf-field__label {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
.gs-acf-field__value {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1rem, 1.4vw, 1.25rem);
}

/* =========================================================
   18. SITE FOOTER
   ========================================================= */

.site-footer { padding: 5rem var(--pad-x-mob) 3rem; }
@media (min-width: 48em) { .site-footer { padding: 6rem var(--pad-x) 3rem; } }
.site-footer--ink  { background: var(--pure-ink); color: var(--text-on-ink); }
.site-footer--bone { background: var(--bone);     color: var(--text-on-bone); }

.site-footer__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 37.5em) { .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (min-width: 64em)   { .site-footer__grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; } }
@media (max-width: 47.99em) {.site-footer__grid,.site-footer__bottom {text-align: center;}.site-footer__grid {justify-items: center;}.site-footer .widget ul {align-items: center;} }

.site-footer .widget__title {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 300;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin-bottom: 1.25rem;
  color: var(--muted-on-ink);
}
.site-footer--bone .widget__title { color: var(--muted-on-bone); }
.site-footer .widget ul { display: flex; flex-direction: column; gap: 0.6rem; }
.site-footer .widget a { transition: opacity var(--dur-fast) ease; font-size: 0.95rem; }
.site-footer .widget a:hover { opacity: 0.65; }
.site-footer .widget { font-family: var(--font-sans); font-weight: 300; font-size: 0.95rem; }

.site-footer__bottom {
  margin-top: 4rem;
  padding-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

@media (max-width: 37.5em) {
  .site-footer__bottom { display: flex;justify-content: center; }
  .nav-drawer__lang { text-align:center; }
 }

.site-footer--ink .site-footer__bottom {
  border-top: 1px solid var(--line-on-ink);
  color: var(--muted-on-ink);
}
.site-footer--bone .site-footer__bottom {
  border-top: 1px solid var(--line-on-bone);
  color: var(--muted-on-bone);
}
.site-footer__lang { display: flex;flex-direction: row; gap:1rem; position:fixed; bottom: 1.5rem; right: 2.3rem;mix-blend-mode: difference; }
.site-footer__lang ul,
.site-footer__lang nav > ul {
  display: inline-flex !important;
  gap: 1rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.site-footer__lang li, .nav-drawer__lang li {
  list-style: none;
}
.site-footer__lang li::marker,
.site-footer__lang li::before, .nav-drawer__lang li::marker, .nav-drawer__lang li::before {
  display: none;
  content: none;
}
.site-footer__lang a {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  text-decoration: none;
  transition: color var(--dur-fast) ease;
}

.site-footer__lang a:hover { color: var(--bone-deep); }
.site-footer__lang .current-lang a,
.site-footer__lang [aria-current="true"] { 
  color: var(--bone-deep); 
}
.lang-switcher { display: none; }

@media (max-width: 37.5em) {
  .site-footer__lang { display: none }
 }

/* =========================================================
   19. PAGE TEMPLATES
   ========================================================= */

.gs-page {
  padding: calc(var(--nav-h) + 4rem) var(--pad-x-mob) var(--pad-y-mob);
}
@media (min-width: 48em) { .gs-page { padding-inline: var(--pad-x); padding-bottom: var(--pad-y); } }
.gs-page__inner { max-width: 1140px; margin-inline: auto; }
.gs-page__title {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: var(--text-headline);
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin-bottom: 2.5rem;
}
.gs-page__content { font-family: var(--font-sans); font-size: 1.05rem; line-height: 1.7; }
.gs-page__content p { margin-bottom: 1.25rem; }
.gs-page__content h2 {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 3rem 0 1rem;
}
.gs-page__content a { border-bottom: 1px solid currentColor; transition: opacity var(--dur-fast) ease; }
.gs-page__content a:hover { opacity: 0.7; }

/* Hero esperienza singola (sfondo immagine PHP) */
.gs-esp-hero {
  min-height: 80vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: 4rem;
  position: relative;
  background-size: cover;
  background-position: center;
  background-color: var(--ink);
  padding-top: var(--nav-h);
  overflow: hidden;
  animation: fade-in 0.8s var(--ease-out) both;
}
@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.gs-esp-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(10,9,8,0.25) 0%, rgba(10,9,8,0.72) 100%);
}
.gs-esp-hero__inner { position: relative; z-index: 1; }
.gs-esp-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bone-deep);
  opacity: 0.75;
  display: block;
  margin-bottom: 1rem;
}
.gs-esp-hero__title {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: var(--text-h1);
  color: var(--bone-deep);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
}
.gs-esp-hero__excerpt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-subhead);
  color: var(--bone-deep);
  opacity: 0.8;
  max-width: 480px;
  line-height: 1.45;
}

/* Hero vino singolo */
.gs-vino-hero {
  background: var(--ink);
  padding-top: calc(var(--nav-h) + 4rem);
  padding-bottom: 4rem;
}
.gs-vino-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.gs-vino-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: block;
  margin-bottom: 1.5rem;
}
.gs-vino-hero__title {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: var(--text-h1);
  color: var(--text-on-ink);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin-bottom: 0.75rem;
}
.gs-vino-hero__tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  margin-bottom: 2rem;
}
.gs-vino-hero__excerpt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lead);
  color: var(--text-on-ink);
  line-height: 1.55;
  max-width: 480px;
}
.gs-vino-hero__media { display: flex; justify-content: center; align-items: center; }
.gs-vino-hero__img { max-height: 100%; width: auto; display: block; object-fit: contain; }

@media (max-width: 48em) {
  .gs-vino-hero__inner { grid-template-columns: 1fr; }
  .gs-vino-hero__media { order: -1; max-height: 300px; overflow: hidden; }
}

/* Correlati vino */
.gs-vino-correlati {
  background: var(--ink);
  padding: var(--pad-y) 0;
  border-top: 1px solid var(--line-on-ink);
  align-items: center;
  text-align: center;
}
.gs-vino-correlati__label {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: block;
  margin-bottom: 3rem;
}
.gs-vino-correlati__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap:40px;
}
.gs-vino-correlati__card {
  padding: 2rem var(--pad-x);
  border: 1px solid var(--line-on-ink)!important;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition: opacity var(--dur-mid) ease;
}

.gs-vino-correlati__card:hover { opacity: 0.65; }
.gs-vino-correlati__numero {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
.gs-vino-correlati__nome {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.1rem, 1.8vw, 1.7rem);
  color: var(--text-on-ink);
  line-height: 1.1;
}
.gs-vino-correlati__tag {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
@media (max-width: 48em) {
  .gs-vino-correlati__grid { grid-template-columns: 1fr; }
  .gs-vino-correlati__card { border-right: none; border-bottom: 1px solid var(--line-on-ink); }
}

/* Correlati esperienza */
.gs-esp-correlati {
  background: var(--ink);
  padding: var(--pad-y) 0;
  border-top: 1px solid var(--line-on-ink);
}
.gs-esp-correlati__label {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: block;
  margin-bottom: 3rem;
}
.gs-esp-correlati__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  border-top: 1px solid var(--line-on-ink);
  padding-top: 2rem;
}
.gs-esp-correlati__card {
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: opacity var(--dur-mid) ease;
}
.gs-esp-correlati__card:hover { opacity: 0.65; }
.gs-esp-correlati__media { overflow: hidden; aspect-ratio: 4/3; }
.gs-esp-correlati__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gs-esp-correlati__numero {
  font-family: var(--font-mono);
  font-size: var(--text-eyebrow);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
  display: block;
}
.gs-esp-correlati__nome {
  font-family: var(--font-serif);
  font-weight: 200;
  font-size: clamp(1.1rem, 1.8vw, 1.7rem);
  color: var(--text-on-ink);
  line-height: 1.1;
}
.gs-esp-correlati__meta {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted-on-ink);
}
@media (max-width: 48em) { .gs-esp-correlati__grid { grid-template-columns: 1fr; } }

@media (max-width: 48em) {
  .gs-vino-hero__inner {
    grid-template-columns: 1fr;
  }
  .gs-vino-hero__media {
    order: -1;
    max-height: 100%;
    overflow: hidden;
  }
  /* Scheda tecnica — reset padding su mobile */
  .single-vino .wp-block-columns {
    padding-left: 0 !important;
    margin-left: 0 !important;
  }
  .single-vino .wp-block-column {
    padding-left: 0 !important;
  }
}

/* 404 */
.gs-404 {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: calc(var(--nav-h) + 3rem) var(--pad-x-mob) var(--pad-y-mob);
}
.gs-404__code {
  font-family: var(--font-mono);
  font-size: clamp(5rem, 14vw, 10rem);
  line-height: 1;
  letter-spacing: -0.05em;
}
.gs-404__title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 200;
  font-size: clamp(1.4rem, 2.8vw, 2.4rem);
  margin-top: 1rem;
}
.gs-404__text { margin-top: 1.5rem; max-width: 45ch; line-height: 1.65; }
.gs-404__cta { margin-top: 2.5rem; }
.gs-404 .wp-block-button.is-style-outline-bone .wp-block-button__link {
  border-color: var(--bone-deep);
  color: var(--bone-deep);
}

/* =========================================================
   20. CONTACT FORM 7
   ========================================================= */

.wpcf7 { margin-top: 2rem; }
.wpcf7-form { display: flex; flex-direction: column; gap: 1.5rem; }
.wpcf7 label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 300;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted-on-bone);
  margin-bottom: 0.5rem;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
  width: 100%;
  padding: 0.85rem 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line-on-bone);
  font-family: var(--font-serif);
  font-size: 1.05rem;
  color: inherit;
  border-radius: 0;
  transition: border-color var(--dur-fast) ease;
}
.wpcf7 textarea { min-height: 120px; resize: vertical; }
.wpcf7 input:focus,
.wpcf7 textarea:focus { outline: none; border-bottom-color: var(--accent); }
.wpcf7-submit {
  align-self: flex-start;
  padding: 0.85rem 1.6rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 300;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--bone-deep);
  border: 1px solid var(--ink);
  cursor: pointer;
  transition: opacity var(--dur-fast) ease;
}
.wpcf7-submit:hover { opacity: 0.75; }
.wpcf7-not-valid-tip {
  display: block;
  margin-top: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  color: var(--accent);
}
.wpcf7-response-output {
  margin-top: 1.5rem !important;
  padding: 1rem !important;
  border: 1px solid currentColor !important;
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

/* =========================================================
   21. BLOCCHI NATIVI GUTENBERG
   ========================================================= */

.wp-block-image.alignfull img { width: 100%; }
.wp-block-gallery.alignfull {
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
}
.wp-block-gallery.alignfull .wp-block-image img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}

/* WIDGET social link */
.wp-block-social-link:hover{transition: none!important;transform: scale(1)!important;}
.wp-block-social-link-label{font-size: 0.95rem!important}

/* Map embed responsive */
.gs-map-embed { position: relative; aspect-ratio: 16/9; display: block !important;
  width: 100% !important; }
.gs-map-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block !important;
  filter: grayscale(1) contrast(1.05);
  min-height: 300px;
} 
@media (max-width: 48em) { .gs-map-embed { aspect-ratio: 4/3; } }

/* =========================================================
   22. EDITOR GUTENBERG = FRONTEND
   ========================================================= */

.editor-styles-wrapper {
  background-color: var(--bone);
  color: var(--text-on-bone);
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: 1.65;
  padding: 2rem !important;
}
.editor-styles-wrapper h1,
.editor-styles-wrapper h2,
.editor-styles-wrapper h3,
.editor-styles-wrapper h4 {
  font-family: var(--font-serif);
  font-weight: 200;
  line-height: 0.95;
  letter-spacing: -0.03em;
}
.editor-styles-wrapper blockquote {
  border-left: 2px solid var(--accent);
  padding-left: 1.5rem;
  font-family: var(--font-serif);
  font-style: italic;
}
.editor-styles-wrapper .wp-block { max-width: var(--container); }
.editor-styles-wrapper .wp-block[data-align="full"] { max-width: 100%; }
.editor-styles-wrapper .gs-cronologia__corpo { grid-template-rows: 1fr; }

/* =========================================================
   24. RESPONSIVE GLOBALE
   ========================================================= */

/* Mobile nav */
@media (max-width: 47.99em) {
  .site-header { height: 56px; }
  .site-nav { grid-template-columns: 44px 1fr 44px; }
  .site-nav__logo { justify-self: center; grid-column: 2; }
  .site-nav__menu  { display: none !important; }
  .site-nav__pill  { display: none !important; }
  .site-nav__right { grid-column: 3; justify-self: end; }
}
@media (min-width: 48em) {
  .site-nav__toggle { display: none; }
  .site-nav__menu   { display: flex; }
}

.gs-esp-content {
  animation: fade-in 0.4s var(--ease-out) 0.1s both;
}

.none{display:none!important;}