/* ============================================================
 * SANDRO BOSSI ATELIER · main.css
 * Port integrale di atelier.css (Direzione 1 — Atelier).
 * Tokens, reset e stile completo del front-end.
 * ============================================================ */

:root {
  /* ---------- Brand brown ---------- */
  --sb-brown-900: #2b1d14;
  --sb-brown-800: #3d2a1e;
  --sb-brown-700: #563a2a;
  --sb-brown-600: #6a4836;
  --sb-brown-500: #775743;
  --sb-brown-400: #8d7160;
  --sb-brown-300: #a89384;
  --sb-brown-200: #c8b8ad;
  --sb-brown-100: #e3d8d0;
  --sb-brown-50:  #f3ece6;

  /* ---------- Cream ---------- */
  --sb-cream-50:  #fbf8f4;
  --sb-cream-100: #f5efe7;
  --sb-cream-200: #ece3d6;
  --sb-cream-300: #ddd0bd;

  /* ---------- Stone ---------- */
  --sb-stone-900: #1c1917;
  --sb-stone-700: #44403c;
  --sb-stone-500: #78716c;
  --sb-stone-300: #b8aea4;
  --sb-stone-100: #e7e1d9;

  /* ---------- Accents ---------- */
  --sb-gold:     #b08a4a;
  --sb-burgundy: #6e2c2c;
  --sb-olive:    #5a5a3a;
  --sb-ink:      #16110d;

  /* ---------- Semantic ---------- */
  --bg-default:  var(--sb-cream-100);
  --bg-paper:    var(--sb-cream-50);
  --fg-1:        var(--sb-brown-900);
  --fg-2:        var(--sb-brown-700);
  --fg-3:        var(--sb-brown-400);

  /* ---------- Lines ---------- */
  --line-soft:    rgba(43, 29, 20, 0.10);
  --line-medium:  rgba(43, 29, 20, 0.20);
  --line-strong:  rgba(43, 29, 20, 0.45);
  --line-on-dark: rgba(245, 239, 231, 0.18);

  /* ---------- Type ---------- */
  --ff-display: 'Cormorant Garamond', 'Garamond', 'Times New Roman', serif;
  --ff-sans:    'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --ff-mono:    ui-monospace, 'SF Mono', Menlo, monospace;

  /* ---------- Motion ---------- */
  --ease-standard: cubic-bezier(0.32, 0.08, 0.24, 1);
  --ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--sb-cream-100);
  color: var(--fg-1);
  font-family: var(--ff-sans);
  font-size: 15px; line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }
ul, ol { margin: 0; padding: 0; list-style: none; }

.eyebrow {
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); font-weight: 500;
}
.eyebrow--light { color: var(--sb-cream-200); }

.sba-skip {
  position: absolute; left: -9999px; top: 0;
}
.sba-skip:focus {
  left: 12px; top: 12px; padding: 12px 16px; background: var(--sb-brown-900); color: #fff; z-index: 9999;
}

/* shared decorative film grain on dark surfaces */
.grain { position: relative; }
.grain::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: .04; mix-blend-mode: overlay;
}

/* DIREZIONE 1 — ATELIER
   Editorial, slow, generous whitespace.
   Cream grounds, serif italic moments, numbered sections like a monograph.
   Loro Piana / Cassina restraint. */

.atelier {
  background: var(--sb-cream-100);
  color: var(--fg-1);
  font-family: var(--ff-sans);
  position: relative;
}

/* ============ CURSOR ============ */
.atelier .at-cursor-dot { background: var(--sb-brown-900); }
.atelier .at-cursor-ring { border-color: var(--sb-brown-700); }

/* ============ HEADER ============ */
.at-header {
  position: absolute; top: 0; left: 0; right: 0; z-index: 50;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  padding: 28px 56px;
  border-bottom: 1px solid var(--line-soft);
  background: rgba(245, 239, 231, 0.0);
  backdrop-filter: blur(0px);
  transition: background 360ms var(--ease-standard), backdrop-filter 360ms var(--ease-standard), padding 360ms var(--ease-standard);
}
.at-header.scrolled {
  background: rgba(245, 239, 231, 0.88);
  backdrop-filter: blur(14px);
  padding: 18px 56px;
  position: fixed;
}
.at-header__nav { display: flex; gap: 36px; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-2); }
.at-header__nav a { transition: opacity .2s; }
.at-header__nav a:hover { opacity: .55; }
.at-header__brand { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.at-header__logo {
  display: block;
  height: 28px;
  width: auto;
  transition: opacity 360ms var(--ease-standard);
}
.at-header__logo--light { display: none; }

/* === HERO HEADER LIGHT (home + listing prodotti, pre-scroll) === */
body.at-light-hero .at-header:not(.scrolled) { color: var(--sb-cream-50, #faf6ef); }
body.at-light-hero .at-header:not(.scrolled) .at-header__nav a,
body.at-light-hero .at-header:not(.scrolled) .at-header__meta,
body.at-light-hero .at-header:not(.scrolled) .at-header__meta .lang span,
body.at-light-hero .at-header:not(.scrolled) .at-header__meta a { color: var(--sb-cream-50, #faf6ef) !important; }
body.at-light-hero .at-header:not(.scrolled) .at-header__logo--dark { display: none; }
body.at-light-hero .at-header:not(.scrolled) .at-header__logo--light { display: block; }
body.at-light-hero .at-header:not(.scrolled) .at-burger { color: var(--sb-cream-50, #faf6ef); }
body.at-light-hero .at-header:not(.scrolled) .at-burger__line { background: var(--sb-cream-50, #faf6ef); }
body.at-light-hero .at-header:not(.scrolled) .at-burger__label { color: var(--sb-cream-50, #faf6ef); }

/* === CUSTOM CURSOR (dot + ring) ============================== */
.at-cursor-dot,
.at-cursor-ring {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  border-radius: 999px;
  will-change: transform, width, height;
  opacity: 0;
  transition: opacity 280ms ease;
}
html.has-cursor .at-cursor-dot,
html.has-cursor .at-cursor-ring { opacity: 1; }
html.has-cursor,
html.has-cursor body { cursor: none; }
html.has-cursor a,
html.has-cursor button,
html.has-cursor [data-burger],
html.has-cursor input,
html.has-cursor textarea,
html.has-cursor label,
html.has-cursor .at-product,
html.has-cursor .at-cat,
html.has-cursor .at-listing-card,
html.has-cursor .at-events__row { cursor: none; }

.at-cursor-dot {
  width: 8px; height: 8px;
  background: var(--fg-1, #1f1b17);
  z-index: 10000;
  transition:
    width  .35s cubic-bezier(0.2, 0.7, 0.2, 1),
    height .35s cubic-bezier(0.2, 0.7, 0.2, 1),
    background-color .35s ease,
    opacity .28s ease;
}
.at-cursor-ring {
  width: 36px; height: 36px;
  border: 1px solid var(--fg-1, #1f1b17);
  z-index: 9999;
  mix-blend-mode: difference;
  transition:
    width  .42s cubic-bezier(0.2, 0.7, 0.2, 1),
    height .42s cubic-bezier(0.2, 0.7, 0.2, 1),
    border-color .35s ease,
    opacity .28s ease;
}
/* Difference inverte il colore sotto: serve un bordo chiaro per ottenere il classico contrasto */
.at-cursor-ring { border-color: var(--sb-cream-50, #faf6ef); }

/* Hover su elementi interattivi: dot collassa, ring si gonfia */
.at-cursor-dot.is-hover  { width: 0; height: 0; }
.at-cursor-ring.is-hover { width: 84px; height: 84px; border-color: var(--sb-cream-50, #faf6ef); }

/* Label "apri" (e varianti via data-cursor) dentro al ring */
.at-cursor-ring { display: flex; align-items: center; justify-content: center; }
.at-cursor-ring__label {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 16px;
  letter-spacing: 0.01em;
  color: var(--sb-cream-50, #faf6ef);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .28s ease .04s, transform .42s cubic-bezier(0.2, 0.7, 0.2, 1) .04s;
  white-space: nowrap;
  user-select: none;
  pointer-events: none;
}
.at-cursor-ring.is-hover .at-cursor-ring__label {
  opacity: 1;
  transform: translateY(0);
}

/* Click pulse */
.at-cursor-ring.is-down { transform-origin: center; }
.at-cursor-ring.is-down { width: 28px; height: 28px; }

/* Su hero/listing pre-scroll (sfondo scuro) — dot diventa crema */
body.at-light-hero .at-cursor-dot { background: var(--sb-cream-50, #faf6ef); }

/* Disattiva su touch o reduced motion */
@media (hover: none), (pointer: coarse) {
  .at-cursor-dot, .at-cursor-ring { display: none !important; }
}
@media (prefers-reduced-motion: reduce) {
  .at-cursor-dot, .at-cursor-ring { transition-duration: 1ms !important; }
}

/* === FILTER DRAWER (archivio prodotti / eventi) =============== */
.at-filter-overlay {
  position: fixed; inset: 0;
  background: rgba(20, 15, 10, 0);
  z-index: 1198;
  pointer-events: none;
  transition: background 480ms cubic-bezier(0.76, 0, 0.24, 1);
}
.at-filter-overlay.is-open {
  background: rgba(20, 15, 10, 0.42);
  pointer-events: auto;
}
.at-filter-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(520px, 92vw);
  background: var(--sb-cream-100, #f5efe7);
  z-index: 1199;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 620ms cubic-bezier(0.76, 0, 0.24, 1);
  box-shadow: -28px 0 80px rgba(20, 15, 10, 0.18);
  overflow: hidden;
}
.at-filter-drawer.is-open { transform: translateX(0); }

.at-filter-drawer__head {
  position: relative;
  padding: 40px 48px 28px;
  border-bottom: 1px solid var(--line-soft, rgba(31, 27, 23, 0.12));
}
.at-filter-drawer__eyebrow {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 28px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
}
.at-filter-drawer__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 16px;
  letter-spacing: 0; text-transform: none;
  color: var(--sb-brown-500, #6b4f2c);
}
.at-filter-drawer__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(40px, 4.4vw, 56px);
  line-height: 0.96; letter-spacing: -0.02em;
  color: var(--fg-1, #1f1b17);
  margin: 0;
  max-width: 14ch;
}
.at-filter-drawer__close {
  position: absolute; top: 36px; right: 32px;
  display: inline-flex; align-items: center; gap: 12px;
  background: transparent; border: 0; padding: 6px 4px;
  cursor: pointer; color: var(--fg-1);
  font-family: inherit;
}
.at-filter-drawer__close-label {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-2, #4a443c);
}
.at-filter-drawer__close svg { transition: transform 360ms cubic-bezier(0.2, 0.7, 0.2, 1); }
.at-filter-drawer__close:hover svg { transform: rotate(90deg); }

.at-filter-drawer__body {
  flex: 1; overflow-y: auto;
  padding: 36px 48px 28px;
  display: flex; flex-direction: column; gap: 44px;
}
.at-filter-group__title {
  display: flex; align-items: baseline; gap: 14px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-2, #4a443c);
  margin: 0 0 22px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line-soft, rgba(31, 27, 23, 0.12));
}
.at-filter-group__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 14px;
  letter-spacing: 0; text-transform: lowercase;
  color: var(--sb-brown-500, #6b4f2c);
}
.at-filter-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.at-filter-opt {
  display: flex; align-items: center; gap: 16px;
  padding: 10px 0;
  cursor: pointer;
  user-select: none;
}
.at-filter-opt input { position: absolute; opacity: 0; pointer-events: none; }
.at-filter-opt__bullet,
.at-filter-opt__square {
  position: relative;
  width: 16px; height: 16px;
  border: 1px solid var(--fg-2, #4a443c);
  flex: 0 0 16px;
  transition: border-color 240ms ease, background 240ms ease;
}
.at-filter-opt__bullet { border-radius: 999px; }
.at-filter-opt__bullet::after,
.at-filter-opt__square::after {
  content: ""; position: absolute; inset: 3px;
  background: var(--sb-brown-500, #6b4f2c);
  opacity: 0; transform: scale(0.4);
  transition: opacity 220ms ease, transform 320ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.at-filter-opt__bullet::after { border-radius: 999px; }
.at-filter-opt input:checked ~ .at-filter-opt__bullet,
.at-filter-opt input:checked ~ .at-filter-opt__square { border-color: var(--sb-brown-500, #6b4f2c); }
.at-filter-opt input:checked ~ .at-filter-opt__bullet::after,
.at-filter-opt input:checked ~ .at-filter-opt__square::after { opacity: 1; transform: scale(1); }
.at-filter-opt__label {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 22px;
  letter-spacing: -0.005em;
  color: var(--fg-1, #1f1b17);
  transition: color 220ms ease;
}
.at-filter-opt:hover .at-filter-opt__label { color: var(--sb-brown-500, #6b4f2c); }
.at-filter-opt input:checked ~ .at-filter-opt__label { color: var(--sb-brown-500, #6b4f2c); }

.at-filter-drawer__foot {
  display: grid; grid-template-columns: auto 1fr; gap: 0;
  border-top: 1px solid var(--line-soft, rgba(31, 27, 23, 0.12));
}
.at-filter-drawer__reset {
  background: transparent; border: 0; padding: 24px 32px;
  cursor: pointer; font-family: inherit;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-2, #4a443c);
  border-right: 1px solid var(--line-soft, rgba(31, 27, 23, 0.12));
  transition: color 220ms ease, background 220ms ease;
}
.at-filter-drawer__reset:hover { color: var(--fg-1); background: rgba(31, 27, 23, 0.04); }
.at-filter-drawer__apply {
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 18px;
  background: var(--sb-brown-500, #6b4f2c);
  color: var(--sb-cream-50, #faf6ef);
  border: 0; padding: 24px 32px;
  cursor: pointer; font-family: inherit;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  transition: background 220ms ease;
}
.at-filter-drawer__apply:hover { background: var(--fg-1, #1f1b17); }
.at-filter-drawer__apply-arrow {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 22px;
  letter-spacing: 0; text-transform: none;
}

@media (max-width: 640px) {
  .at-filter-drawer__head { padding: 32px 28px 24px; }
  .at-filter-drawer__body { padding: 28px 28px 24px; gap: 32px; }
  .at-filter-drawer__close { top: 28px; right: 18px; }
  .at-filter-drawer__title { font-size: 36px; }
  .at-filter-opt__label   { font-size: 19px; }
  .at-filter-drawer__reset { padding: 20px 22px; }
  .at-filter-drawer__apply { padding: 20px 22px; }
}
@media (prefers-reduced-motion: reduce) {
  .at-filter-drawer, .at-filter-overlay { transition-duration: 1ms !important; }
}

/* === SINGLE PRODOTTO (editorial) ============================== */
.at-prod { background: var(--sb-cream-100, #f5efe7); color: var(--fg-1, #1f1b17); }

/* Hero split asimmetrico */
.at-prod-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  gap: 0;
}
.at-prod-hero__col-l {
  padding: 56px 72px 72px;
  display: flex; flex-direction: column;
  position: relative;
}
.at-prod-hero__crumbs {
  display: flex; gap: 14px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  margin-bottom: auto;
}
.at-prod-hero__crumbs a { color: inherit; text-decoration: none; transition: color .25s ease; }
.at-prod-hero__crumbs a:hover { color: var(--sb-brown-500, #6b4f2c); }
.at-prod-hero__eyebrow {
  display: flex; justify-content: space-between; align-items: baseline; gap: 24px;
  margin-top: 64px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line-soft, rgba(31, 27, 23, 0.12));
}
.at-prod-hero__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 18px;
  color: var(--sb-brown-500, #6b4f2c);
}
.at-prod-hero__kicker {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
}
.at-prod-hero__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(72px, 9vw, 148px);
  line-height: 0.92; letter-spacing: -0.03em;
  margin: 28px 0 36px;
  color: var(--fg-1);
}
.at-prod-hero__dot { color: var(--sb-brown-500, #6b4f2c); }
.at-prod-hero__lede {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.45; color: var(--fg-2, #4a443c);
  max-width: 38ch; margin: 0 0 40px;
}
.at-prod-hero__cta { display: flex; gap: 28px; align-items: center; flex-wrap: wrap; }
.at-prod-hero__btn {
  display: inline-flex; align-items: center; gap: 18px;
  padding: 18px 28px;
  background: var(--sb-brown-500, #6b4f2c);
  color: var(--sb-cream-50, #faf6ef);
  text-decoration: none;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  transition: background .24s ease;
}
.at-prod-hero__btn:hover { background: var(--fg-1, #1f1b17); }
.at-prod-hero__btn-arrow {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 18px; letter-spacing: 0; text-transform: none;
}
.at-prod-hero__link {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--fg-2); text-decoration: none;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  border-bottom: 1px solid currentColor; padding-bottom: 4px;
  transition: color .25s ease;
}
.at-prod-hero__link:hover { color: var(--sb-brown-500); }
.at-prod-hero__index {
  display: flex; align-items: center; gap: 18px;
  margin-top: auto; padding-top: 72px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
}
.at-prod-hero__index-tick { display: inline-block; width: 96px; height: 1px; background: var(--fg-3); }
.at-prod-hero__col-r {
  background-size: cover; background-position: center;
  background-color: #1a1410;
  position: relative; min-height: 100vh;
  filter: saturate(0.85) contrast(1.02);
}
.at-prod-hero__caption {
  position: absolute; left: 32px; bottom: 32px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 16px;
  color: var(--sb-cream-50, #faf6ef);
  text-shadow: 0 2px 18px rgba(0,0,0,0.5);
}

/* Section heads numerati */
.at-prod-sec-head {
  display: grid; grid-template-columns: auto auto 1fr;
  align-items: baseline; gap: 24px;
  padding: 0 72px 28px;
}
.at-prod-sec-head__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 22px;
  color: var(--sb-brown-500, #6b4f2c);
}
.at-prod-sec-head__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(36px, 3.4vw, 52px);
  line-height: 1; letter-spacing: -0.02em;
  margin: 0; color: var(--fg-1);
}
.at-prod-sec-head__rule { display: block; height: 1px; background: var(--line-soft, rgba(31, 27, 23, 0.12)); }

/* i. il pezzo */
.at-prod-body { padding: 128px 0 0; }
.at-prod-body__grid {
  display: grid; grid-template-columns: 1fr 360px;
  gap: 96px; padding: 0 72px 128px;
}
.at-prod-body__rich p {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(20px, 1.5vw, 24px); line-height: 1.55;
  color: var(--fg-2, #4a443c);
  margin: 0 0 24px; max-width: 56ch;
}
.at-prod-body__rich p:first-of-type::first-letter {
  font-style: italic; font-size: 1.4em; color: var(--sb-brown-500); margin-right: 2px;
}
.at-prod-body__specs { position: sticky; top: 120px; align-self: start; }
.at-prod-body__specs-title {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); margin: 0 0 24px;
  padding-bottom: 14px; border-bottom: 1px solid var(--line-soft);
}
.at-prod-defs { margin: 0; padding: 0; display: flex; flex-direction: column; }
.at-prod-defs > div {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  padding: 14px 0; border-bottom: 1px solid var(--line-soft);
}
.at-prod-defs dt {
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--fg-3); margin: 0;
}
.at-prod-defs dd {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 18px;
  color: var(--fg-1); margin: 0; text-align: right;
}

/* ii. gallery asimmetrica */
.at-prod-gallery-sec { padding: 64px 0 128px; }
.at-prod-gallery {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 24px; padding: 0 72px;
}
.at-prod-gallery__cell { margin: 0; position: relative; overflow: hidden; }
.at-prod-gallery__cell img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s cubic-bezier(0.2, 0.7, 0.2, 1); }
.at-prod-gallery__cell:hover img { transform: scale(1.03); }
.at-prod-gallery__cell figcaption {
  position: absolute; top: 16px; left: 16px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 14px;
  color: var(--sb-cream-50, #faf6ef);
  text-shadow: 0 2px 10px rgba(0,0,0,0.6);
}
.at-prod-gallery__cell.g--wide  { grid-column: span 4; aspect-ratio: 16/10; }
.at-prod-gallery__cell.g--sm    { grid-column: span 2; aspect-ratio: 4/5; }
.at-prod-gallery__cell.g--tall  { grid-column: span 2; aspect-ratio: 3/4; }
.at-prod-gallery__cell.g--full  { grid-column: span 6; aspect-ratio: 21/9; }
.at-prod-gallery__cell.g--md    { grid-column: span 3; aspect-ratio: 4/3; }

/* iii. la materia */
.at-prod-mat { padding: 64px 0 128px; }
.at-prod-mat__lede {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: clamp(22px, 1.8vw, 28px);
  color: var(--fg-2); max-width: 48ch;
  padding: 0 72px; margin: 0 0 56px;
}
.at-prod-numlist {
  list-style: none; padding: 0 72px; margin: 0;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px 40px;
}
.at-prod-numlist li {
  padding-top: 22px; border-top: 1px solid var(--line-soft);
}
.at-prod-numlist .num {
  display: block;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 14px;
  color: var(--sb-brown-500, #6b4f2c);
  margin-bottom: 14px;
}
.at-prod-numlist h4 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(24px, 2.2vw, 32px);
  line-height: 1.05; letter-spacing: -0.01em;
  margin: 0 0 14px; color: var(--fg-1);
}
.at-prod-numlist p {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 17px; line-height: 1.55;
  color: var(--fg-2); margin: 0;
}

/* iv. finiture */
.at-prod-fin { padding: 0 0 128px; }
.at-prod-fin__lede {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: clamp(22px, 1.8vw, 28px);
  color: var(--fg-2); max-width: 48ch;
  padding: 0 72px; margin: 0 0 56px;
}
.at-prod-swatches {
  list-style: none; padding: 0 72px; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 32px 24px;
}
.at-prod-swatch {
  display: flex; flex-direction: column; gap: 14px;
  cursor: pointer;
}
.at-prod-swatch__chip {
  display: block; aspect-ratio: 1/1;
  border: 1px solid var(--line-soft);
  transition: transform .5s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.at-prod-swatch:hover .at-prod-swatch__chip { transform: scale(1.04); }
.at-prod-swatch__name {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 18px;
  color: var(--fg-1);
}

/* v. varianti */
.at-prod-var { padding: 0 0 128px; }
.at-prod-var__defs {
  max-width: 920px;
  padding: 0 72px;
}

/* CTA showroom */
.at-prod-cta {
  background: var(--sb-brown-500, #6b4f2c);
  color: var(--sb-cream-50, #faf6ef);
  padding: 128px 72px;
}
.at-prod-cta__inner { max-width: 1080px; margin: 0 auto; }
.at-prod-cta__eyebrow {
  display: inline-block;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(250, 246, 239, 0.65);
  margin-bottom: 32px;
}
.at-prod-cta__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(40px, 4vw, 64px);
  line-height: 1.08; letter-spacing: -0.02em;
  margin: 0 0 48px; max-width: 22ch;
  color: var(--sb-cream-50);
}
.at-prod-cta__title em {
  display: block; font-style: italic;
  color: rgba(250, 246, 239, 0.65);
  font-size: 0.55em; margin-top: 24px; line-height: 1.4; max-width: 36ch;
}
.at-prod-cta__btn {
  display: inline-flex; align-items: center; gap: 18px;
  padding: 20px 30px;
  background: var(--sb-cream-50, #faf6ef);
  color: var(--sb-brown-700, #3d2c19);
  text-decoration: none;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  transition: background .24s ease, color .24s ease;
}
.at-prod-cta__btn:hover { background: var(--fg-1, #1f1b17); color: var(--sb-cream-50); }
.at-prod-cta__btn-arrow {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 20px; letter-spacing: 0; text-transform: none;
}

/* vi. correlati */
.at-prod-related { padding: 64px 0 128px; }
.at-prod-related__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 64px 40px; padding: 0 72px;
}
.at-prod-related__card {
  text-decoration: none; color: inherit;
  display: flex; flex-direction: column;
}
.at-prod-related__meta {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 16px;
}
.at-prod-related__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 16px;
  color: var(--sb-brown-500);
}
.at-prod-related__img {
  aspect-ratio: 4/5;
  background-size: cover; background-position: center;
  margin-bottom: 22px;
  transition: filter .6s ease;
}
.at-prod-related__card:hover .at-prod-related__img { filter: brightness(0.94) saturate(1.05); }
.at-prod-related__foot {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  padding-top: 18px; border-top: 1px solid var(--line-soft);
}
.at-prod-related__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(28px, 2.4vw, 38px);
  line-height: 1; letter-spacing: -0.02em;
  margin: 0; color: var(--fg-1);
}
.at-prod-related__sub {
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--fg-2); white-space: nowrap; text-align: right;
}

/* Responsive single prodotto */
@media (max-width: 1023px) {
  .at-prod-hero { grid-template-columns: 1fr; min-height: auto; }
  .at-prod-hero__col-l { padding: 40px 28px 56px; }
  .at-prod-hero__col-r { min-height: 70vh; aspect-ratio: 4/5; }
  .at-prod-hero__index { padding-top: 48px; }
  .at-prod-sec-head { padding: 0 28px 22px; grid-template-columns: auto 1fr; }
  .at-prod-sec-head__rule { display: none; }
  .at-prod-body { padding: 80px 0 0; }
  .at-prod-body__grid { grid-template-columns: 1fr; gap: 48px; padding: 0 28px 80px; }
  .at-prod-body__specs { position: static; }
  .at-prod-gallery { grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 0 28px; }
  .at-prod-gallery__cell.g--wide,
  .at-prod-gallery__cell.g--full,
  .at-prod-gallery__cell.g--md { grid-column: span 2; aspect-ratio: 4/3; }
  .at-prod-gallery__cell.g--sm,
  .at-prod-gallery__cell.g--tall { grid-column: span 1; aspect-ratio: 4/5; }
  .at-prod-mat, .at-prod-fin, .at-prod-var, .at-prod-related, .at-prod-gallery-sec { padding-bottom: 80px; }
  .at-prod-mat__lede, .at-prod-fin__lede { padding: 0 28px; }
  .at-prod-numlist { grid-template-columns: 1fr; padding: 0 28px; gap: 40px; }
  .at-prod-swatches { padding: 0 28px; }
  .at-prod-var__defs { padding: 0 28px; }
  .at-prod-cta { padding: 80px 28px; }
  .at-prod-related__grid { grid-template-columns: 1fr; padding: 0 28px; }
}
@media (max-width: 640px) {
  .at-prod-hero__title { font-size: clamp(56px, 14vw, 88px); }
  .at-prod-hero__cta { gap: 16px; }
  .at-prod-hero__btn, .at-prod-hero__link { width: 100%; justify-content: center; }
  .at-prod-defs > div { grid-template-columns: 1fr; gap: 4px; }
  .at-prod-defs dd { text-align: left; }
}

/* === SINGLE PRODOTTO · LAYOUT "ARENIS" ====================== */
.at-prod-subnav {
  display: flex; justify-content: center; align-items: center;
  flex-wrap: wrap; gap: 0;
  padding: 18px 32px;
  border-top: 1px solid var(--line-soft, rgba(31,27,23,0.12));
  border-bottom: 1px solid var(--line-soft, rgba(31,27,23,0.12));
  background: var(--sb-cream-100, #f5efe7);
}
.at-prod-subnav__item {
  position: relative;
  padding: 6px 24px;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  text-decoration: none;
  transition: color .25s ease;
}
.at-prod-subnav__item:not(:last-child)::after {
  content: ""; position: absolute; right: 0; top: 50%;
  width: 1px; height: 11px; background: var(--line-soft, rgba(31,27,23,0.18));
  transform: translateY(-50%);
}
.at-prod-subnav__item.is-active,
.at-prod-subnav__item:hover { color: var(--fg-1, #1f1b17); }

.at-prod-arenis {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: 80px;
  padding: 72px 96px 96px;
  align-items: start;
  background: var(--sb-cream-100, #f5efe7);
}

/* COL SINISTRA */
.at-prod-arenis__col-l { display: flex; flex-direction: column; gap: 28px; }
.at-prod-arenis__eyebrow {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  margin: 0 0 6px;
}
.at-prod-arenis__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(96px, 11vw, 180px);
  line-height: 0.88; letter-spacing: -0.035em;
  color: var(--fg-1, #1f1b17);
  margin: 0 0 24px;
}
.at-prod-arenis__big { margin: 0; }
.at-prod-arenis__big img { width: 100%; height: auto; display: block; aspect-ratio: 4/3; object-fit: cover; }
.at-prod-arenis__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.at-prod-arenis__row figure { margin: 0; }
.at-prod-arenis__row figure img { width: 100%; height: auto; display: block; aspect-ratio: 4/3; object-fit: cover; }
.at-prod-arenis__wide { margin: 0; }
.at-prod-arenis__wide img { width: 100%; height: auto; display: block; aspect-ratio: 21/9; object-fit: cover; }
.at-prod-arenis__meta {
  display: flex; align-items: center; gap: 14px;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  padding-top: 8px;
}
.at-prod-arenis__meta a { color: var(--fg-2, #4a443c); text-decoration: none; }
.at-prod-arenis__meta-dots {
  flex: 1; height: 0;
  border-bottom: 1px dotted var(--line-soft, rgba(31,27,23,0.25));
}

/* COL DESTRA */
.at-prod-arenis__col-r {
  position: sticky; top: 100px;
  display: flex; flex-direction: column; gap: 36px;
}
.at-prod-arenis__lede {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--fg-1, #1f1b17);
  max-width: 36ch;
  margin: 0;
}
.at-prod-arenis__specs {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 22px 36px;
  margin: 0;
}
.at-prod-arenis__specs > div { display: flex; flex-direction: column; gap: 6px; }
.at-prod-arenis__specs dt {
  font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
}
.at-prod-arenis__specs dd {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 15px;
  color: var(--fg-1);
  margin: 0;
}
.at-prod-arenis__fin { display: flex; flex-direction: column; gap: 16px; }
.at-prod-arenis__fin-label {
  font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  margin: 0;
}
.at-prod-arenis__swatches {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px 12px;
}
.at-prod-arenis__swatch {
  display: flex; flex-direction: column; gap: 8px;
  cursor: pointer;
}
.at-prod-arenis__swatch-chip {
  display: block; aspect-ratio: 1/1;
  border: 1px solid var(--line-soft, rgba(31,27,23,0.12));
  transition: transform .4s cubic-bezier(0.2,0.7,0.2,1);
}
.at-prod-arenis__swatch:hover .at-prod-arenis__swatch-chip { transform: scale(1.04); }
.at-prod-arenis__swatch-name {
  font-size: 8.5px; letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
  text-align: center;
}
.at-prod-arenis__cta {
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 18px;
  padding: 20px 28px;
  background: var(--sb-brown-500, #6b4f2c);
  color: var(--sb-cream-50, #faf6ef);
  text-decoration: none;
  font-size: 10.5px; letter-spacing: 0.32em; text-transform: uppercase;
  transition: background .24s ease;
}
.at-prod-arenis__cta:hover { background: var(--fg-1, #1f1b17); }
.at-prod-arenis__cta-arrow {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic; font-size: 20px; letter-spacing: 0; text-transform: none;
}
.at-prod-arenis__foot {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 12px;
  font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #8c857a);
}

/* Lede editoriale sotto la scheda */
.at-prod-arenis-lede {
  padding: 128px 96px 128px;
  background: var(--sb-cream-100, #f5efe7);
  max-width: 920px; margin: 0 auto;
  text-align: left;
}
.at-prod-arenis-lede__rule {
  display: inline-block;
  width: 56px; height: 0; border-bottom: 1px solid var(--fg-3);
  margin-bottom: 48px;
  color: transparent;
}
.at-prod-arenis-lede__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400; font-style: normal;
  font-size: clamp(36px, 3.6vw, 56px);
  line-height: 1.15; letter-spacing: -0.015em;
  color: var(--fg-1, #1f1b17);
  margin: 0 0 56px;
  max-width: 24ch;
}
.at-prod-arenis-lede__title em {
  font-style: italic;
  color: var(--sb-brown-500, #6b4f2c);
}
.at-prod-arenis-lede__body p {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 17px; line-height: 1.7;
  color: var(--fg-2, #4a443c);
  margin: 0 0 22px;
  max-width: 62ch;
}

/* Responsive Arenis */
@media (max-width: 1023px) {
  .at-prod-subnav { gap: 0; padding: 14px 16px; overflow-x: auto; flex-wrap: nowrap; justify-content: flex-start; }
  .at-prod-subnav__item { padding: 6px 16px; white-space: nowrap; font-size: 9px; }
  .at-prod-arenis { grid-template-columns: 1fr; gap: 56px; padding: 48px 28px 64px; }
  .at-prod-arenis__col-r { position: static; }
  .at-prod-arenis__title { font-size: clamp(64px, 14vw, 110px); }
  .at-prod-arenis-lede { padding: 80px 28px; }
}
@media (max-width: 640px) {
  .at-prod-arenis__specs { grid-template-columns: 1fr; gap: 18px; }
  .at-prod-arenis__swatches { grid-template-columns: repeat(3, 1fr); }
  .at-prod-arenis__cta { padding: 18px 22px; font-size: 10px; }
  .at-prod-arenis-lede__title { font-size: 32px; max-width: none; }
}
.at-header__meta { display: flex; gap: 22px; align-items: center; justify-content: flex-end; font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); }
.at-header__meta .lang { display: inline-flex; gap: 8px; align-items: center; }
.at-header__meta .lang .active { color: var(--fg-1); }

/* ============ HERO ============ */
.at-hero {
  position: relative; min-height: 100vh;
  display: grid; grid-template-columns: 1fr 1fr;
  background: var(--sb-cream-100);
  overflow: hidden;
}

/* ---- Hero · video full-bleed (minimal) ---- */
.at-hero--video {
  display: block; min-height: 100vh; height: 100vh;
  background: #16110d;
}
.at-hero--video .at-hero__bgvideo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.at-hero--video .at-hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(22,17,13,.45) 0%, rgba(22,17,13,.25) 30%, rgba(22,17,13,.55) 100%);
}
.at-hero--video .at-hero__content {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 120px 64px;
  text-align: center;
  gap: 56px;
}
.at-hero__title-min {
  font-family: var(--ff-display); font-weight: 300;
  font-size: clamp(48px, 5.6vw, 96px);
  line-height: 1.02; letter-spacing: -0.018em;
  margin: 0; color: var(--sb-cream-50);
  max-width: 980px;
}
.at-hero__title-min em {
  font-style: italic; font-weight: 300;
  color: var(--sb-cream-100); opacity: .92;
}
.at-hero__title-min span {
  display: block; font-style: italic; font-weight: 300;
  color: var(--sb-cream-100); opacity: .8;
  margin-top: 8px;
}
.at-hero__cta {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 30px;
  border: 1px solid rgba(245,239,231,.55);
  background: rgba(245,239,231,.06);
  backdrop-filter: blur(6px);
  color: var(--sb-cream-50);
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  font-weight: 500;
  transition: background .3s var(--ease-standard), color .3s var(--ease-standard), border-color .3s var(--ease-standard);
  cursor: pointer;
}
.at-hero__cta:hover {
  background: var(--sb-cream-50);
  color: var(--sb-brown-900);
  border-color: var(--sb-cream-50);
}
.at-scroll-hint--light { color: var(--sb-cream-100); opacity: .8; z-index: 3; }
.at-scroll-hint--light .line { background: var(--sb-cream-100); opacity: .8; }

/* ============ MASK REVEAL (titoli editoriali) ============ */
.mask-reveal {
  display: block;
  overflow: hidden;
  line-height: 0.88;
}
.mask-reveal > span {
  display: inline-block;
  transform: translateY(105%);
  animation: maskRevealUp 1100ms cubic-bezier(0.7, 0, 0.2, 1) forwards;
  animation-delay: inherit;
  will-change: transform;
}
@keyframes maskRevealUp {
  0%   { transform: translateY(105%); }
  100% { transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .mask-reveal > span { transform: none; animation: none; }
}

/* ============ V2 · scroll indicator tick ============ */
@keyframes v2ScrollTick {
  0%   { transform: translateY(-100%); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateY(96px); opacity: 0; }
}
.v2-scroll-tick {
  animation: v2ScrollTick 2400ms cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
@media (prefers-reduced-motion: reduce) {
  .v2-scroll-tick { animation: none; opacity: 0.6; }
}

/* ============ V2 · scroll-pinned word reveal ============ */
.v2-line {
  display: block;
  overflow: hidden;
  line-height: 0.92;
}
.v2-word {
  display: inline-block;
  transform: translateY(105%);
  transition: transform 900ms cubic-bezier(0.7, 0, 0.2, 1);
  will-change: transform;
}
.v2-word.is-in { transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .v2-word { transform: none; transition: none; }
}
.at-hero__copy {
  padding: 180px 64px 96px 96px;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative;
}
.at-hero__eyebrow-group { display: flex; flex-direction: column; gap: 10px; }
.at-hero__eyebrow-num {
  font-family: var(--ff-display); font-style: italic;
  font-size: 14px; color: var(--fg-3);
}
.at-hero__title {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(64px, 7vw, 112px);
  line-height: 0.96; letter-spacing: -0.02em;
  margin: 56px 0 0; color: var(--fg-1);
}
.at-hero__title em {
  font-style: italic; font-weight: 300;
  color: var(--sb-brown-700); display: block;
}
.at-hero__sub {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: 22px; line-height: 1.5; color: var(--fg-2);
  max-width: 460px; margin-top: 40px;
}
.at-hero__foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-top: 64px;
}
.at-hero__foot-meta { font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); }
.at-hero__foot-meta strong { display: block; color: var(--fg-1); font-weight: 500; margin-top: 6px; font-size: 11px; }

/* Video / detail panel */
.at-hero__media {
  position: relative; overflow: hidden;
  background: var(--sb-brown-800);
}
.at-hero__video {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 65% 40%, rgba(245,239,231,.08) 0%, transparent 60%),
    radial-gradient(ellipse 50% 70% at 30% 80%, rgba(0,0,0,.5) 0%, transparent 60%),
    linear-gradient(160deg, #563a2a 0%, #2b1d14 60%, #16110d 100%);
}
/* Faux "stitching detail" SVG-ish lines */
.at-hero__video::before {
  content: ''; position: absolute; left: 18%; top: 30%; right: 12%; height: 220px;
  background:
    repeating-linear-gradient(90deg, transparent 0 18px, rgba(245,239,231,.18) 18px 22px, transparent 22px 32px),
    radial-gradient(ellipse at 30% 50%, rgba(245,239,231,.06) 0%, transparent 60%);
  border-radius: 20px;
  transform: rotate(-8deg);
  filter: blur(.4px);
}
.at-hero__video::after {
  content: ''; position: absolute; left: 28%; top: 46%; width: 380px; height: 380px;
  background: radial-gradient(circle at 40% 40%, rgba(245,239,231,.18) 0%, rgba(245,239,231,0) 65%);
}
.at-hero__media-label {
  position: absolute; bottom: 32px; left: 32px; right: 32px;
  display: flex; justify-content: space-between; align-items: flex-end;
  color: var(--sb-cream-100);
}
.at-hero__media-label .num {
  font-family: var(--ff-display); font-style: italic; font-size: 56px; line-height: 1;
  color: var(--sb-cream-50); opacity: .9;
}
.at-hero__media-label .cap {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--sb-cream-200); opacity: .75; max-width: 220px; line-height: 1.7;
  text-align: right;
}
/* play button */
.at-hero__play {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 84px; height: 84px; border-radius: 999px;
  border: 1px solid rgba(245,239,231,.3);
  display: grid; place-items: center;
  color: var(--sb-cream-50);
  font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase;
  backdrop-filter: blur(8px); background: rgba(245,239,231,.04);
}

/* scroll indicator */
.at-scroll-hint {
  position: absolute; bottom: 32px; left: 96px;
  display: flex; align-items: center; gap: 14px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--fg-3);
}
.at-scroll-hint .line { width: 48px; height: 1px; background: var(--fg-3); }

/* ============ MARQUEE / ROLLING TICKER ============ */
.at-ticker {
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  background: var(--sb-cream-100);
  overflow: hidden; padding: 22px 0;
  font-family: var(--ff-display); font-style: italic;
  font-size: 28px; color: var(--fg-2);
  white-space: nowrap;
}
.at-ticker__inner { display: inline-flex; gap: 64px; }
.at-ticker__inner span:nth-child(odd) { color: var(--sb-brown-500); }
.at-ticker .dot { color: var(--fg-3); font-style: normal; }

/* ============ SECTION HEADERS ============ */
.at-section-head {
  display: grid; grid-template-columns: 200px 1fr;
  padding: 128px 96px 56px;
  align-items: end; gap: 64px;
  border-top: 1px solid var(--line-soft);
}
.at-section-head__num {
  font-family: var(--ff-display); font-style: italic;
  font-size: 28px; color: var(--fg-3);
  border-top: 1px solid var(--fg-1);
  padding-top: 16px; width: 60px;
}
.at-section-head__title {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(56px, 6vw, 96px); line-height: 0.98;
  letter-spacing: -0.02em; margin: 0; color: var(--fg-1);
}
.at-section-head__title em { font-style: italic; color: var(--sb-brown-600); }
.at-section-head__lead {
  margin-top: 20px; max-width: 540px;
  font-size: 16px; line-height: 1.65; color: var(--fg-2); font-weight: 300;
}

/* ============ PRODUCT GRID — asymmetric editorial (4 cards) ============ */
.at-cats { }
.at-cat--a { grid-column: 1 / span 7; }
.at-cat--a .at-cat__img { aspect-ratio: 4/5; }
.at-cat--b { grid-column: 9 / span 4; margin-top: 96px; }
.at-cat--b .at-cat__img { aspect-ratio: 3/4; }
.at-cat--c { grid-column: 1 / span 5; margin-top: 32px; }
.at-cat--c .at-cat__img { aspect-ratio: 3/4; }
.at-cat--d { grid-column: 7 / span 6; margin-top: 80px; }
.at-cat--d .at-cat__img { aspect-ratio: 4/5; }
.at-cat__img > div, .at-cat__img { transition: transform 1100ms cubic-bezier(.2,.8,.2,1); }
.at-cat:hover .at-cat__img { transform: scale(1.02); }
.at-products {
  padding: 0 96px 128px;
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 48px 32px;
}
.at-product {
  position: relative; cursor: pointer;
}
.at-product__img {
  position: relative; overflow: hidden;
  background: var(--sb-cream-200);
}
.at-product__img > div {
  position: absolute; inset: 0;
  transition: transform 1100ms var(--ease-out);
}
.at-product:hover .at-product__img > div { transform: scale(1.04); }
.at-product__num {
  position: absolute; top: 18px; left: 18px;
  font-family: var(--ff-display); font-style: italic; font-size: 14px;
  color: var(--sb-cream-50); opacity: .9;
  z-index: 2;
}
.at-product__cap {
  position: absolute; top: 18px; right: 18px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--sb-cream-50); opacity: .75; z-index: 2;
}
.at-product__name {
  margin-top: 22px;
  font-family: var(--ff-display); font-style: italic;
  font-size: 32px; color: var(--fg-1);
}
.at-product__meta {
  margin-top: 6px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--fg-3);
}
/* span variants for asymmetry */
.at-product--lg { grid-column: span 7; }
.at-product--lg .at-product__img { aspect-ratio: 4/3; }
.at-product--md { grid-column: span 5; align-self: end; }
.at-product--md .at-product__img { aspect-ratio: 4/5; }
.at-product--sm { grid-column: span 4; }
.at-product--sm .at-product__img { aspect-ratio: 4/5; }
.at-product--full { grid-column: span 8; grid-column-start: 3; }
.at-product--full .at-product__img { aspect-ratio: 16/9; }
.at-product--tall { grid-column: span 5; grid-column-start: 1; margin-top: -180px; }
.at-product--tall .at-product__img { aspect-ratio: 3/4; }
.at-product--wide { grid-column: span 7; align-self: start; }
.at-product--wide .at-product__img { aspect-ratio: 4/3; }

/* ============ EDITORIAL QUOTE BAND ============ */
.at-quote-band {
  background: var(--sb-brown-500);
  color: var(--sb-cream-50);
  padding: 160px 96px;
  position: relative;
}
.at-quote-band::before {
  content: ''; position: absolute; inset: 0;
  opacity: .05; mix-blend-mode: overlay; pointer-events: none;
}
.at-quote-band__inner { max-width: 1100px; margin: 0 auto; }
.at-quote-band__eye { color: var(--sb-cream-200); opacity: .8; }
.at-quote-band__text {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(36px, 4vw, 64px); line-height: 1.2;
  letter-spacing: -0.01em; margin: 32px 0 0;
}
.at-quote-band__sig {
  margin-top: 56px;
  display: flex; gap: 32px; align-items: baseline;
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--sb-cream-200); opacity: .8;
}

/* ============ ABOUT / SAVOIR-FAIRE ============ */
.at-about {
  display: grid; grid-template-columns: 1fr 1fr;
  padding: 0;
}
.at-about__media {
  aspect-ratio: 4/5; min-height: 720px;
  position: relative; overflow: hidden;
}
.at-about__copy {
  padding: 128px 96px;
  display: flex; flex-direction: column; justify-content: center;
  max-width: 720px;
}
.at-about__copy .num {
  font-family: var(--ff-display); font-style: italic; font-size: 24px; color: var(--fg-3);
  border-top: 1px solid var(--fg-1); padding-top: 14px; width: 60px;
  margin-bottom: 40px;
}
.at-about__copy h2 {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(44px, 4.6vw, 72px); line-height: 1.04; letter-spacing: -0.015em;
  margin: 0 0 32px;
}
.at-about__copy h2 em { font-style: italic; color: var(--sb-brown-600); }
.at-about__copy p {
  font-size: 16px; line-height: 1.7; color: var(--fg-2); font-weight: 300;
  margin: 0 0 18px; max-width: 520px;
}
.at-about__stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
  margin-top: 56px;
  padding-top: 32px; border-top: 1px solid var(--line-soft);
}
.at-about__stats .num-big {
  font-family: var(--ff-display); font-style: italic;
  font-size: 56px; line-height: 1; color: var(--sb-brown-500);
}
.at-about__stats .lbl {
  margin-top: 10px;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3);
}

/* ============ EVENTS ============ */
.at-events {
  padding: 128px 96px;
  border-top: 1px solid var(--line-soft);
}
.at-events__list { list-style: none; padding: 0; margin: 56px 0 0; }
.at-events__row {
  display: grid;
  grid-template-columns: 60px 200px 1fr 200px auto;
  gap: 32px; align-items: center;
  padding: 32px 0;
  border-top: 1px solid var(--line-soft);
  position: relative;
  cursor: pointer;
  transition: padding 360ms var(--ease-out);
}
.at-events__row:hover { padding-left: 24px; }
.at-events__row:last-child { border-bottom: 1px solid var(--line-soft); }
.at-events__num { font-family: var(--ff-display); font-style: italic; font-size: 20px; color: var(--fg-3); }
.at-events__date { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); }
.at-events__name { font-family: var(--ff-display); font-style: italic; font-size: 32px; color: var(--fg-1); }
.at-events__loc { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--fg-2); }
.at-events__arrow {
  width: 36px; height: 36px; border-radius: 999px; border: 1px solid var(--line-medium);
  display: grid; place-items: center; transition: all .3s;
}
.at-events__row:hover .at-events__arrow { background: var(--fg-1); color: var(--sb-cream-50); border-color: var(--fg-1); }

/* ============ FOOTER ============ */
.at-footer {
  background: var(--sb-brown-500); color: var(--sb-cream-50);
  padding: 96px 96px 32px;
  position: relative;
}
.at-footer::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; opacity: .05; mix-blend-mode: overlay;
}
.at-footer__hero {
  padding-bottom: 96px;
  border-bottom: 1px solid var(--line-on-dark);
}
.at-footer__hero h3 {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(48px, 5vw, 88px); line-height: 1.05; letter-spacing: -0.015em;
  margin: 0; max-width: 1000px;
}
.at-footer__grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 56px;
  padding: 64px 0; border-bottom: 1px solid var(--line-on-dark);
}
.at-footer__grid h6 {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--sb-cream-200);
  font-weight: 500; margin: 0 0 20px; opacity: .7;
}
.at-footer__grid p, .at-footer__grid a { font-size: 14px; line-height: 1.7; color: var(--sb-cream-100); opacity: .9; }
.at-footer__grid a { display: block; margin-bottom: 6px; transition: opacity .2s; }
.at-footer__grid a:hover { opacity: .6; }
.at-footer__brand .lockup {
  display: flex; flex-direction: column; line-height: 1;
}
.at-footer__brand .lockup .name { font-weight: 700; letter-spacing: 0.14em; font-size: 18px; }
.at-footer__brand .lockup .city { font-size: 9px; letter-spacing: 0.42em; margin-top: 6px; opacity: .8; }
.at-footer__brand .quote { margin-top: 24px; font-family: var(--ff-display); font-style: italic; font-size: 16px; line-height: 1.5; opacity: .8; max-width: 320px; }
.at-footer__legal {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 32px;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--sb-cream-200); opacity: .55;
}
.at-footer__giant {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(120px, 18vw, 260px);
  line-height: 0.85; letter-spacing: -0.04em;
  color: var(--sb-cream-50); opacity: .14;
  margin: 80px 0 -40px; user-select: none;
}

/* ============================================================
   PAGINA EVENTI · LISTING (atelier-eventi.html)
   ============================================================ */
.ate-hero {
  padding: 200px 96px 120px;
  background: var(--sb-cream-100);
  border-bottom: 1px solid var(--line-soft);
}
.ate-hero__inner { max-width: 1200px; margin: 0 auto; text-align: center; }
.ate-hero__eyebrow {
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 40px;
}
.ate-hero__title {
  font-family: var(--ff-display); font-style: normal; font-weight: 300;
  font-size: clamp(72px, 9vw, 144px); line-height: 0.95; letter-spacing: -0.025em;
  margin: 0 0 40px; color: var(--fg-1);
}
.ate-hero__title em { font-style: italic; }
.ate-hero__lead {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(18px, 1.5vw, 22px); line-height: 1.55;
  color: var(--fg-2); max-width: 720px; margin: 0 auto 56px;
}
.ate-hero__counts {
  display: inline-flex; gap: 16px; align-items: baseline;
  font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--fg-3); padding-top: 32px; border-top: 1px solid var(--line-soft);
}
.ate-hero__counts b { color: var(--fg-1); font-weight: 500; letter-spacing: 0.18em; }
.ate-hero__counts .dot { opacity: .4; }

/* Section heads */
.ate-section { padding: 120px 96px; border-bottom: 1px solid var(--line-soft); }
.ate-section--archive { background: var(--sb-cream-50, #faf6f0); }
.ate-section__head {
  display: grid; grid-template-columns: 80px 1fr auto; align-items: end; gap: 32px;
  padding-bottom: 56px; border-bottom: 1px solid var(--line-soft);
  max-width: 1600px; margin: 0 auto;
}
.ate-section__num { font-family: var(--ff-display); font-style: italic; font-size: 28px; color: var(--fg-3); }
.ate-section__title {
  font-family: var(--ff-display); font-weight: 300; font-style: normal;
  font-size: clamp(48px, 5.5vw, 88px); line-height: 1; letter-spacing: -0.02em;
  margin: 0; color: var(--fg-1);
}
.ate-section__title em { font-style: italic; }
.ate-section__year {
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); padding-bottom: 8px;
}

/* List */
.ate-list { list-style: none; padding: 0; margin: 0; max-width: 1600px; margin: 0 auto; }
.ate-row { border-bottom: 1px solid var(--line-soft); }
.ate-row__link {
  display: grid;
  grid-template-columns: 80px 200px 1fr 280px 280px 56px;
  align-items: center; gap: 24px;
  padding: 36px 0;
  color: var(--fg-1); text-decoration: none;
  transition: padding 380ms var(--ease-out), background 380ms var(--ease-out);
}
.ate-row__link:hover { padding-left: 32px; padding-right: 32px; background: rgba(0,0,0,.015); }
.ate-row__num { font-family: var(--ff-display); font-style: italic; font-size: 22px; color: var(--fg-3); }
.ate-row__date { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); }
.ate-row__name { font-family: var(--ff-display); font-style: italic; font-size: clamp(28px, 2.6vw, 40px); line-height: 1; color: var(--fg-1); }
.ate-row__edition { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-3); }
.ate-row__loc { font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); }
.ate-row__arrow {
  width: 40px; height: 40px; border-radius: 999px; border: 1px solid var(--line-medium);
  display: grid; place-items: center; transition: all .35s var(--ease-out); color: var(--fg-1);
}
.ate-row__link:hover .ate-row__arrow {
  background: var(--fg-1); color: var(--sb-cream-50); border-color: var(--fg-1);
  transform: rotate(-45deg);
}
.ate-list--past .ate-row__name { color: var(--fg-2); }
.ate-list--past .ate-row__link { padding: 28px 0; }

/* Floating preview thumbnail */
.ate-preview {
  position: fixed; width: 200px; height: 140px;
  background-size: cover; background-position: center;
  pointer-events: none; z-index: 80;
  box-shadow: 0 24px 60px rgba(0,0,0,.25);
  transition: opacity .2s;
  display: grid; align-content: end;
  padding: 12px;
}
.ate-preview::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(transparent 40%, rgba(0,0,0,.55));
}
.ate-preview span {
  position: relative;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: #fff;
}

/* CTA shared */
.ate-cta { padding: 160px 96px; background: var(--sb-brown-500); color: var(--sb-cream-50); text-align: center; }
.ate-cta__inner { max-width: 800px; margin: 0 auto; }
.ate-cta__eyebrow { font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--sb-cream-200); opacity: .7; margin-bottom: 32px; }
.ate-cta__title {
  font-family: var(--ff-display); font-style: normal; font-weight: 300;
  font-size: clamp(48px, 5.5vw, 88px); line-height: 1.05; letter-spacing: -0.02em;
  margin: 0 0 32px;
}
.ate-cta__title em { font-style: italic; }
.ate-cta__lead {
  font-family: var(--ff-display); font-style: italic; font-size: 18px; line-height: 1.6;
  opacity: .82; max-width: 600px; margin: 0 auto 48px;
}
.ate-cta__btn {
  display: inline-flex; gap: 14px; align-items: center;
  padding: 18px 36px; border: 1px solid var(--sb-cream-100);
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--sb-cream-50); text-decoration: none;
  transition: all .3s var(--ease-out);
}
.ate-cta__btn span { font-size: 16px; transition: transform .3s var(--ease-out); }
.ate-cta__btn:hover { background: var(--sb-cream-50); color: var(--sb-brown-500); }
.ate-cta__btn:hover span { transform: translateX(6px); }

/* ============================================================
   PAGINA EVENTI · SINGOLO (atelier-evento.html)
   ============================================================ */
.atev-hero {
  position: relative; min-height: 86vh;
  background-size: cover; background-position: center;
  display: grid; align-items: end;
  padding: 0 96px 96px;
  color: var(--sb-cream-50);
}
.atev-hero__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.45) 0%, transparent 35%, transparent 60%, rgba(0,0,0,.7) 100%);
  pointer-events: none;
}
.atev-hero__content { position: relative; max-width: 1400px; }
.atev-hero__crumbs {
  display: flex; gap: 14px; align-items: center;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,.78); margin-bottom: 32px;
}
.atev-hero__crumbs a { color: rgba(255,255,255,.78); transition: color .2s; }
.atev-hero__crumbs a:hover { color: #fff; }
.atev-hero__crumbs .sep { opacity: .4; }
.atev-hero__title {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(72px, 10vw, 180px); line-height: 0.92; letter-spacing: -0.025em;
  margin: 0 0 32px; color: #fff;
}
.atev-hero__title .dot { color: var(--sb-cream-200); }
.atev-hero__meta {
  display: flex; gap: 18px; align-items: center; flex-wrap: wrap;
  font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,.85);
}
.atev-hero__meta .bar { opacity: .35; }
.atev-hero__badge {
  position: absolute; top: 120px; right: 96px;
  display: inline-flex; gap: 10px; align-items: center;
  padding: 10px 18px; border: 1px solid rgba(255,255,255,.4);
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: #fff; backdrop-filter: blur(8px); background: rgba(0,0,0,.18);
}
.atev-hero__badge .dot {
  width: 6px; height: 6px; border-radius: 50%; background: #f0c879;
  animation: atevPulse 1.8s ease-in-out infinite;
}
@keyframes atevPulse { 0%,100% { opacity: 1;} 50% { opacity: .35;} }

/* Sticky strip */
.atev-strip {
  position: sticky; top: 0; z-index: 30;
  display: grid; grid-template-columns: repeat(4, 1fr);
  background: var(--sb-cream-50, #faf6f0);
  border-bottom: 1px solid var(--line-soft);
}
.atev-strip__cell {
  padding: 22px 32px;
  border-right: 1px solid var(--line-soft);
  display: flex; flex-direction: column; gap: 4px;
}
.atev-strip__cell:last-child { border-right: 0; }
.atev-strip__cell .k { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--fg-3); }
.atev-strip__cell .v { font-family: var(--ff-display); font-style: italic; font-size: 18px; color: var(--fg-1); }

/* Intro */
.atev-intro {
  display: grid; grid-template-columns: 80px 1fr; gap: 56px;
  padding: 160px 96px; max-width: 1400px; margin: 0 auto;
}
.atev-intro__num { font-family: var(--ff-display); font-style: italic; font-size: 28px; color: var(--fg-3); }
.atev-intro__col { max-width: 760px; }
.atev-intro__lead {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: clamp(28px, 2.6vw, 40px); line-height: 1.3; letter-spacing: -0.01em;
  margin: 0 0 56px; color: var(--fg-1);
}
.atev-intro__p {
  font-size: 16px; line-height: 1.75; color: var(--fg-2);
  margin: 0 0 24px;
}

/* Programma */
.atev-program { padding: 120px 96px; border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); background: var(--sb-cream-50, #faf6f0); }
.atev-program__list { list-style: none; padding: 0; margin: 0; max-width: 1400px; margin: 56px auto 0; }
.atev-program__row {
  display: grid; grid-template-columns: 280px 1fr 1fr;
  gap: 32px; align-items: baseline;
  padding: 36px 0; border-bottom: 1px solid var(--line-soft);
}
.atev-program__row:last-child { border-bottom: 0; }
.atev-program__day { font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--fg-3); }
.atev-program__title { font-family: var(--ff-display); font-style: italic; font-size: clamp(24px, 2vw, 32px); color: var(--fg-1); }
.atev-program__detail { font-size: 14px; color: var(--fg-2); line-height: 1.6; }

/* Info */
.atev-info { padding: 120px 96px; }
.atev-info__grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
  max-width: 1400px; margin: 56px auto 0;
  background: var(--line-soft);
  border: 1px solid var(--line-soft);
}
.atev-info__cell {
  background: var(--sb-cream-100);
  padding: 36px 40px;
  display: flex; flex-direction: column; gap: 8px;
}
.atev-info__cell dt { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--fg-3); margin: 0; }
.atev-info__cell dd { font-family: var(--ff-display); font-style: italic; font-size: 22px; color: var(--fg-1); margin: 0; line-height: 1.4; }

/* CTA on event page */
.atev-cta { padding: 140px 96px; }

/* Altri eventi */
.atev-others { padding: 120px 96px; border-top: 1px solid var(--line-soft); }
.atev-others__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
  max-width: 1600px; margin: 56px auto 0;
}
.atev-others__card {
  display: flex; flex-direction: column; gap: 20px;
  text-decoration: none; color: var(--fg-1);
  transition: transform .4s var(--ease-out);
}
.atev-others__card:hover { transform: translateY(-4px); }
.atev-others__img {
  width: 100%; aspect-ratio: 4/3;
  background-size: cover; background-position: center;
  filter: saturate(.85);
  transition: filter .4s var(--ease-out);
}
.atev-others__card:hover .atev-others__img { filter: saturate(1); }
.atev-others__meta { display: flex; flex-direction: column; gap: 6px; padding: 0 4px; }
.atev-others__date { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); }
.atev-others__name { font-family: var(--ff-display); font-style: italic; font-size: 28px; margin: 0; color: var(--fg-1); }
.atev-others__loc { font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-2); }
.atev-others__back { text-align: center; margin-top: 80px; }
.atev-others__back a {
  font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-2); text-decoration: none; transition: color .2s;
}
.atev-others__back a:hover { color: var(--fg-1); }

/* Responsive */
@media (max-width: 980px) {
  .ate-section, .atev-program, .atev-info, .atev-others, .ate-cta { padding-left: 32px; padding-right: 32px; }
  .atev-hero { padding: 0 32px 64px; }
  .atev-hero__badge { right: 32px; top: 90px; }
  .atev-intro { padding: 96px 32px; grid-template-columns: 1fr; gap: 24px; }
  .atev-strip { grid-template-columns: repeat(2, 1fr); }
  .atev-strip__cell:nth-child(2) { border-right: 0; }
  .atev-strip__cell:nth-child(1), .atev-strip__cell:nth-child(2) { border-bottom: 1px solid var(--line-soft); }
  .ate-row__link { grid-template-columns: 50px 120px 1fr 50px; }
  .ate-row__edition, .ate-row__loc { display: none; }
  .atev-program__row { grid-template-columns: 1fr; gap: 8px; }
  .atev-others__grid { grid-template-columns: 1fr; }
  .atev-info__grid { grid-template-columns: 1fr; }
}


/* ============================================================
   LISTING · responsive (tablet + mobile)
   ============================================================ */

/* Top meta strip */
@media (max-width: 1023px) {
  .at-listing-meta { padding: 12px 48px !important; gap: 12px; }
  .at-listing-hero { padding: 140px 48px 0 !important; }
  .at-listing-section { padding: 72px 48px !important; }
  .at-listing-cta { padding: 96px 48px !important; }
  .at-listing-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 64px 32px !important; }
  .at-listing-title { font-size: clamp(72px, 12vw, 140px) !important; }
}

@media (max-width: 767px) {
  .at-listing-meta {
    padding: 10px 20px !important;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    gap: 18px;
    justify-content: flex-start !important;
  }
  .at-listing-meta::-webkit-scrollbar { display: none; }
  .at-listing-meta > span { white-space: nowrap; flex-shrink: 0; }
  .at-listing-meta > span:nth-child(3),
  .at-listing-meta > span:nth-child(4) { display: none; }

  .at-listing-hero { padding: 120px 20px 0 !important; }
  .at-listing-section { padding: 56px 20px 140px !important; }
  .at-listing-grid { grid-template-columns: 1fr !important; gap: 56px 0 !important; }
  .at-listing-cta {
    padding: 80px 20px !important;
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    text-align: left !important;
  }
  .at-listing-cta > div:last-child { text-align: left !important; }
  .at-listing-title { font-size: clamp(56px, 16vw, 96px) !important; }
  .at-listing-lede { font-size: 18px !important; margin-bottom: 32px !important; }

  /* Controls bar — stack vertically */
  .at-listing-controls {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 16px !important;
    padding: 18px 0 !important;
  }
  .at-listing-cats {
    overflow-x: auto;
    scrollbar-width: none;
    flex-wrap: nowrap !important;
    gap: 22px !important;
    margin: 0 -20px;
    padding: 4px 20px 6px !important;
    -webkit-overflow-scrolling: touch;
  }
  .at-listing-cats::-webkit-scrollbar { display: none; }
  .at-listing-cats > button { flex-shrink: 0; }

  /* Hide desktop filtra cluster, show sticky bar instead */
  .at-listing-filtra-cluster { display: none !important; }
  .at-listing-controls-meta { font-size: 9px !important; }

  /* Card aspect ratio: keep desktop 4:3 also on mobile (no stretching) */
}

/* ============================================================
   STICKY MOBILE FILTER BAR
   ============================================================ */
.at-mobile-filter-bar { display: none; }
@media (max-width: 767px) {
  .at-mobile-filter-bar {
    display: flex;
    position: fixed;
    bottom: 16px;
    left: 16px;
    right: 16px;
    z-index: 60;
    background: var(--fg-1);
    color: var(--sb-cream-50);
    border-radius: 999px;
    padding: 4px;
    box-shadow: 0 16px 44px rgba(43, 29, 20, 0.32), 0 0 0 1px rgba(43, 29, 20, 0.04);
    align-items: stretch;
    font-family: 'Montserrat', sans-serif;
  }
  .at-mobile-filter-bar__btn {
    flex: 1;
    background: transparent;
    border: 0;
    color: var(--sb-cream-50);
    padding: 14px 18px;
    cursor: pointer;
    font-family: inherit;
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .at-mobile-filter-bar__divider {
    width: 1px;
    background: rgba(245, 239, 231, 0.18);
    margin: 8px 0;
  }
  .at-mobile-filter-bar__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--sb-brown-500);
    color: var(--sb-cream-50);
    font-size: 9px;
    letter-spacing: 0.05em;
  }
  /* Pad the page bottom so sticky bar doesn't cover content */
  .at-listing-page { padding-bottom: 90px; }
}

/* ============================================================
   FILTER DRAWER · responsive
   ============================================================ */
.at-filter-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(43, 29, 20, 0.32);
  backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 320ms ease;
}
.at-filter-drawer-backdrop[data-open="true"] {
  opacity: 1;
  pointer-events: auto;
}

.at-filter-drawer {
  position: fixed;
  z-index: 81;
  background: var(--sb-cream-50, #faf6ef);
  display: flex;
  flex-direction: column;
  font-family: 'Montserrat', sans-serif;
  border-right: 1px solid var(--line-soft);
  /* Desktop default: side drawer from left */
  top: 0;
  left: 0;
  bottom: 0;
  width: min(480px, 92vw);
  transform: translateX(-100%);
  transition: transform 420ms cubic-bezier(0.7, 0, 0.2, 1), box-shadow 420ms ease;
}
.at-filter-drawer[data-open="true"] {
  transform: translateX(0);
  box-shadow: 0 0 60px rgba(43, 29, 20, 0.18);
}

@media (max-width: 767px) {
  .at-filter-drawer {
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 88vh;
    max-height: 88vh;
    border-right: 0;
    border-top-left-radius: 22px;
    border-top-right-radius: 22px;
    transform: translateY(100%);
    overflow: hidden;
  }
  .at-filter-drawer[data-open="true"] {
    transform: translateY(0);
  }
  .at-filter-drawer::before {
    content: '';
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 44px;
    height: 4px;
    border-radius: 999px;
    background: var(--line-soft);
    z-index: 2;
    pointer-events: none;
  }
  .at-filter-drawer__header { padding: 28px 24px 20px !important; padding-top: 32px !important; }
  .at-filter-drawer__body { padding: 24px 24px 20px !important; }
  .at-filter-drawer__footer { padding: 16px 24px max(20px, env(safe-area-inset-bottom)) !important; }
  .at-filter-drawer__title { font-size: clamp(40px, 11vw, 56px) !important; }
}

/* ============================================================
   LISTING V2 · disable scroll-pinned hero on tablet/mobile
   ============================================================ */
@media (max-width: 1023px) {
  .v2-pin-section { height: auto !important; }
  .v2-pin-stack {
    position: static !important;
    height: 80vh !important;
    min-height: 540px !important;
    overflow: hidden;
  }
  .v2-pin-stack .v2-pin-title { font-size: clamp(80px, 11vw, 140px) !important; left: 48px !important; right: 48px !important; bottom: 16vh !important; }
  .v2-pin-stack .v2-pin-meta-top { left: 48px !important; right: 48px !important; }
  .v2-pin-stack .v2-pin-meta-bottom { left: 48px !important; right: 48px !important; bottom: 32px !important; }
  .v2-pin-scroll-indicator { display: none !important; }
  .v2-pin-stack .v2-pin-counter { font-size: clamp(40px, 6vw, 64px) !important; }
}
@media (max-width: 767px) {
  .v2-pin-stack { height: 70vh !important; min-height: 460px !important; }
  .v2-pin-stack .v2-pin-title {
    left: 20px !important;
    right: 20px !important;
    bottom: 14vh !important;
    font-size: clamp(56px, 14vw, 88px) !important;
    line-height: .92 !important;
  }
  .v2-pin-stack .v2-pin-meta-top { left: 20px !important; right: 20px !important; top: 32px !important; }
  .v2-pin-stack .v2-pin-meta-bottom { left: 20px !important; right: 20px !important; bottom: 24px !important; }
  .v2-pin-stack .v2-pin-counter { font-size: clamp(36px, 7vw, 56px) !important; }
}

/* ============================================================
   GLOBAL RESPONSIVE · all atelier pages
   Tablet: 768–1023px · Mobile: <768px
   Overrides inline padding/grid via attribute selectors.
   ============================================================ */

/* ---- TABLET (768–1023px) ---- */
@media (max-width: 1023px) {
  /* Header */
  .at-header { padding: 22px 32px; grid-template-columns: auto auto auto; }
  .at-header.scrolled { padding: 14px 32px; }
  .at-header__nav { gap: 22px; font-size: 10px; letter-spacing: 0.22em; }
  .at-header__nav a:nth-child(3) { display: none; }
  .at-header__meta { gap: 14px; font-size: 9px; letter-spacing: 0.22em; }
  .at-header__meta > *:not(.lang) { display: none; }

  /* Hero (home) — stack the two columns */
  .at-hero { grid-template-columns: 1fr; min-height: auto; }
  .at-hero__copy { padding: 140px 48px 64px; }
  .at-hero__media { aspect-ratio: 4/3; min-height: 520px; }
  .at-scroll-hint { left: 48px; bottom: 24px; }

  /* Section heads */
  .at-section-head { grid-template-columns: 80px 1fr; padding: 96px 48px 48px; gap: 32px; }

  /* Editorial product layouts */
  .at-cats { padding: 32px 48px 96px !important; grid-template-columns: repeat(6, 1fr) !important; gap: 48px 24px !important; }
  .at-cat--a, .at-cat--d { grid-column: 1 / -1; }
  .at-cat--b { grid-column: 1 / span 3; margin-top: 48px; }
  .at-cat--c { grid-column: 4 / span 3; margin-top: 48px; }

  .at-products { padding: 0 48px 96px; grid-template-columns: repeat(8, 1fr); gap: 40px 24px; }
  .at-product--lg { grid-column: span 5; }
  .at-product--md { grid-column: span 3; }
  .at-product--sm { grid-column: span 4; }
  .at-product--full { grid-column: 2 / span 6; }
  .at-product--tall { grid-column: span 4; margin-top: -80px; }
  .at-product--wide { grid-column: span 4; }

  /* Quote band */
  .at-quote-band { padding: 120px 48px; }

  /* About / savoir-faire */
  .at-about { grid-template-columns: 1fr; }
  .at-about__media { aspect-ratio: 16/9; min-height: 480px; }
  .at-about__copy { padding: 96px 48px; max-width: 100%; }
  .at-about__stats { grid-template-columns: repeat(3, 1fr); gap: 24px; }

  /* Events list */
  .at-events { padding: 96px 48px; }
  .at-events__row { grid-template-columns: 40px 140px 1fr 56px; gap: 20px; }
  .at-events__row > :nth-child(4) { display: none; }
  .at-events__name { font-size: 26px; }

  /* Footer */
  .at-footer { padding: 72px 48px 24px; }
  .at-footer__hero { padding-bottom: 72px; }
  .at-footer__hero h3 { font-size: clamp(40px, 5vw, 64px); }
  .at-footer__grid { grid-template-columns: 1fr 1fr; gap: 48px 32px; padding: 56px 0; }
  .at-footer__giant { font-size: clamp(80px, 16vw, 180px); margin: 56px 0 -24px; }

  /* Inline-styled sections (atelier.jsx pages) — collapse 96px gutters */
  .atelier > section { padding-left: 48px !important; padding-right: 48px !important; }
  .atelier > section[style*="grid-template-columns"] { grid-template-columns: 1fr !important; gap: 48px !important; }
  .atelier > div[style*="14px 96px"] { padding: 12px 48px !important; gap: 16px; }
  .atelier > div[style*="18px 96px"] { padding: 14px 48px !important; }
  .atelier > div[style*="80px 96px"] { margin-left: 48px !important; margin-right: 48px !important; }

  /* Listing v1 (mirrors v2) */
  .at-listing-page > section { padding-left: 48px !important; padding-right: 48px !important; }

  /* Eventi listing */
  .ate-hero { padding: 140px 48px 80px; }
  .ate-section { padding: 80px 48px; }
  .ate-section__head { grid-template-columns: 60px 1fr auto; gap: 24px; }
  .ate-row__link { grid-template-columns: 60px 140px 1fr 220px 56px; gap: 18px; }
  .ate-row__link > :nth-child(5) { display: none; }
  .ate-cta { padding: 120px 48px; }

  /* Evento singolo */
  .atev-hero { padding: 0 48px 64px; min-height: 72vh; }
  .atev-hero__title { font-size: clamp(56px, 9vw, 120px); }
  .atev-hero__badge { right: 48px; top: 100px; }
  .atev-strip { grid-template-columns: repeat(2, 1fr); }
  .atev-strip__cell:nth-child(2) { border-right: 0; }
  .atev-strip__cell:nth-child(1), .atev-strip__cell:nth-child(2) { border-bottom: 1px solid var(--line-soft); }
  .atev-intro { padding: 96px 48px; grid-template-columns: 60px 1fr; gap: 32px; }
  .atev-program { padding: 80px 48px; }
  .atev-program__row { grid-template-columns: 200px 1fr 1fr; gap: 24px; }
  .atev-info { padding: 80px 48px; }
  .atev-others { padding: 80px 48px; }
  .atev-others__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }

  /* Ticker */
  .at-ticker { font-size: 22px; padding: 18px 0; }
}

/* ---- MOBILE (<768px) ---- */
@media (max-width: 767px) {
  /* Header — compact */
  .at-header { padding: 18px 20px; grid-template-columns: 1fr auto 1fr; }
  .at-header.scrolled { padding: 12px 20px; }
  .at-header__nav { display: none; }
  .at-header__logo { height: 22px; }
  .at-header__meta { font-size: 9px; }
  .at-header__meta > *:not(.lang) { display: none; }

  /* Hero — compact stack */
  .at-hero__copy { padding: 110px 20px 56px; }
  .at-hero__title { font-size: clamp(48px, 12vw, 72px); margin-top: 32px; }
  .at-hero__sub { font-size: 17px; margin-top: 24px; max-width: 100%; }
  .at-hero__foot { flex-direction: column; align-items: flex-start; gap: 20px; margin-top: 40px; }
  .at-hero__media { min-height: 380px; aspect-ratio: 4/5; }
  .at-hero--video .at-hero__content { padding: 80px 24px; gap: 32px; }
  .at-scroll-hint { display: none; }

  /* Section heads */
  .at-section-head { grid-template-columns: 1fr; padding: 72px 20px 32px; gap: 16px; }
  .at-section-head__num { font-size: 18px; padding-top: 10px; width: 48px; }
  .at-section-head__title { font-size: clamp(40px, 11vw, 64px); }
  .at-section-head__lead { font-size: 15px; }

  /* Editorial product layouts — single column */
  .at-cats { padding: 24px 20px 80px !important; grid-template-columns: 1fr !important; gap: 56px !important; }
  .at-cat--a, .at-cat--b, .at-cat--c, .at-cat--d { grid-column: 1 / -1 !important; margin-top: 0 !important; }
  .at-cat--a .at-cat__img,
  .at-cat--b .at-cat__img,
  .at-cat--c .at-cat__img,
  .at-cat--d .at-cat__img { aspect-ratio: 4/3 !important; }

  .at-products { padding: 0 20px 80px; grid-template-columns: 1fr; gap: 56px; }
  .at-product--lg, .at-product--md, .at-product--sm, .at-product--full, .at-product--tall, .at-product--wide {
    grid-column: 1 / -1 !important;
    grid-column-start: 1 !important;
    margin-top: 0 !important;
    align-self: auto !important;
  }
  .at-product--lg .at-product__img,
  .at-product--md .at-product__img,
  .at-product--sm .at-product__img,
  .at-product--full .at-product__img,
  .at-product--tall .at-product__img,
  .at-product--wide .at-product__img { aspect-ratio: 4/3 !important; }
  .at-product__name { font-size: 26px; }

  /* Quote band */
  .at-quote-band { padding: 80px 20px; }
  .at-quote-band__sig { flex-direction: column; gap: 8px; margin-top: 32px; }

  /* About / savoir-faire */
  .at-about__media { min-height: 320px; aspect-ratio: 4/3; }
  .at-about__copy { padding: 72px 20px; }
  .at-about__copy h2 { font-size: clamp(34px, 9vw, 48px); }
  .at-about__stats { grid-template-columns: 1fr; gap: 18px; }
  .at-about__stats .num-big { font-size: 44px; }

  /* Events list */
  .at-events { padding: 72px 20px; }
  .at-events__row { grid-template-columns: 32px 1fr 36px; gap: 12px; padding: 22px 0; }
  .at-events__row > :nth-child(2) { display: none; } /* date */
  .at-events__row > :nth-child(4) { display: none; } /* loc */
  .at-events__row:hover { padding-left: 0; }
  .at-events__name { font-size: 20px; }
  .at-events__num { font-size: 16px; }

  /* Footer */
  .at-footer { padding: 56px 20px 24px; }
  .at-footer__hero { padding-bottom: 48px; }
  .at-footer__hero h3 { font-size: clamp(32px, 8vw, 48px); }
  .at-footer__grid { grid-template-columns: 1fr; gap: 36px; padding: 40px 0; }
  .at-footer__legal { flex-direction: column; gap: 12px; align-items: flex-start; padding-top: 24px; }
  .at-footer__giant { font-size: clamp(56px, 22vw, 120px); margin: 32px 0 -12px; }

  /* Inline-styled atelier.jsx pages */
  .atelier > section { padding-left: 20px !important; padding-right: 20px !important; }
  .atelier > section[style*="180px"][style*="96px"] { padding-top: 110px !important; padding-bottom: 32px !important; }
  .atelier > section[style*="grid-template-columns"] { grid-template-columns: 1fr !important; gap: 32px !important; align-items: stretch !important; }
  .atelier > div[style*="14px 96px"] {
    padding: 10px 20px !important;
    overflow-x: auto;
    scrollbar-width: none;
    gap: 16px;
    justify-content: flex-start !important;
  }
  .atelier > div[style*="14px 96px"]::-webkit-scrollbar { display: none; }
  .atelier > div[style*="14px 96px"] > span { white-space: nowrap; flex-shrink: 0; }
  .atelier > div[style*="18px 96px"] { padding: 12px 20px !important; flex-wrap: wrap; gap: 8px; }
  .atelier > div[style*="80px 96px"] { margin-left: 20px !important; margin-right: 20px !important; margin-top: 56px !important; }

  /* Eventi listing */
  .ate-hero { padding: 110px 20px 64px; }
  .ate-hero__title { font-size: clamp(48px, 13vw, 80px); }
  .ate-hero__lead { font-size: 16px; }
  .ate-hero__counts { flex-wrap: wrap; gap: 8px; font-size: 10px; padding-top: 24px; }
  .ate-section { padding: 56px 20px; }
  .ate-section__head { grid-template-columns: 1fr; gap: 16px; padding-bottom: 32px; }
  .ate-section__title { font-size: clamp(40px, 11vw, 64px); }
  .ate-row__link { grid-template-columns: 32px 1fr 40px; gap: 12px; padding: 22px 0; }
  .ate-row__link > .ate-row__date,
  .ate-row__link > .ate-row__edition,
  .ate-row__link > .ate-row__loc { display: none; }
  .ate-row__link:hover { padding-left: 0; padding-right: 0; }
  .ate-row__name { font-size: 22px; }
  .ate-cta { padding: 80px 20px; }
  .ate-cta__title { font-size: clamp(36px, 10vw, 56px); }

  /* Evento singolo */
  .atev-hero { padding: 0 20px 48px; min-height: 60vh; }
  .atev-hero__title { font-size: clamp(48px, 13vw, 80px); }
  .atev-hero__crumbs { font-size: 9px; gap: 8px; flex-wrap: wrap; }
  .atev-hero__meta { font-size: 10px; gap: 10px; }
  .atev-hero__badge { right: 20px; top: 80px; padding: 8px 12px; font-size: 8px; }
  .atev-strip { grid-template-columns: 1fr; }
  .atev-strip__cell { padding: 14px 20px; border-right: 0 !important; border-bottom: 1px solid var(--line-soft); }
  .atev-strip__cell:last-child { border-bottom: 0; }
  .atev-intro { padding: 64px 20px; grid-template-columns: 1fr; gap: 16px; }
  .atev-intro__lead { font-size: 22px; margin-bottom: 32px; }
  .atev-program { padding: 64px 20px; }
  .atev-program__row { grid-template-columns: 1fr; gap: 8px; padding: 24px 0; }
  .atev-info { padding: 64px 20px; }
  .atev-info__grid { grid-template-columns: 1fr; }
  .atev-info__cell { padding: 22px 20px; }
  .atev-others { padding: 64px 20px; }
  .atev-others__grid { grid-template-columns: 1fr; gap: 32px; }
  .atev-cta { padding: 80px 20px; }

  /* Ticker */
  .at-ticker { font-size: 18px; padding: 14px 0; }
  .at-ticker__inner { gap: 36px; }

  /* Body padding for sticky bar on listing page */
  body { -webkit-text-size-adjust: 100%; }
}


/* ============================================================
 * Listing v2 · scroll-pinned reveal animations
 * ============================================================ */
.v2-line { display: block; overflow: hidden; }
.v2-word {
  display: inline-block;
  transform: translateY(105%);
  opacity: 0;
  transition: transform 1100ms cubic-bezier(0.2, 0.7, 0.2, 1), opacity 700ms ease;
  will-change: transform, opacity;
}
.v2-word.is-in {
  transform: translateY(0);
  opacity: 1;
}
.v2-scroll-tick {
  animation: v2ScrollTick 2200ms cubic-bezier(0.6, 0, 0.4, 1) infinite;
}
@keyframes v2ScrollTick {
  0%   { transform: translateY(-100%); }
  60%  { transform: translateY(380%); }
  100% { transform: translateY(380%); }
}

/* mask-reveal · titolo monumentale (azienda / archivio fallback) */
.mask-reveal {
  display: block;
  overflow: hidden;
}
.mask-reveal > span {
  display: inline-block;
  transform: translateY(110%);
  animation: maskRevealUp 1100ms cubic-bezier(0.2, 0.7, 0.2, 1) forwards;
}
@keyframes maskRevealUp {
  to { transform: translateY(0); }
}

/* Mobile fallback ≤1023px · stack 3 immagini in verticale, scroll naturale */
@media (max-width: 1023px) {
  .v2-pin-section { height: auto !important; }
  .v2-pin-stack   { height: auto !important; min-height: 100vh; }
  .v2-pin-bg      {
    position: relative !important;
    inset: auto !important;
    height: 60vh;
    opacity: 1 !important;
    transform: none !important;
  }
  .v2-pin-bg + .v2-pin-bg { margin-top: 0; }
  .v2-pin-meta-top,
  .v2-pin-meta-bottom,
  .v2-pin-scroll-indicator { display: none !important; }
  .v2-pin-title {
    position: relative !important;
    padding: 24px 24px 48px;
    font-size: clamp(64px, 14vw, 110px) !important;
  }
  .v2-word { transform: none; opacity: 1; }
  .at-listing-hero,
  .at-listing-section,
  .at-listing-cta { padding-left: 24px !important; padding-right: 24px !important; }
  .at-listing-grid { grid-template-columns: 1fr !important; gap: 56px 0 !important; }
  .at-listing-cta  { grid-template-columns: 1fr !important; gap: 32px !important; text-align: left !important; }
  .at-listing-cta > div { text-align: left !important; }
}


/* ============================================================
 * Form contatti · at-form
 * ============================================================ */
.at-form { display: flex; flex-direction: column; gap: 28px; }
.at-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.at-form__field { display: flex; flex-direction: column; gap: 8px; }
.at-form__field--full { width: 100%; }
.at-form__label {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); font-weight: 500;
}
.at-form input[type="text"],
.at-form input[type="email"],
.at-form input[type="tel"],
.at-form select,
.at-form textarea,
.at-cf7-wrap input[type="text"],
.at-cf7-wrap input[type="email"],
.at-cf7-wrap input[type="tel"],
.at-cf7-wrap select,
.at-cf7-wrap textarea {
  width: 100%; box-sizing: border-box;
  background: transparent; border: 0; border-bottom: 1px solid var(--fg-1);
  padding: 12px 0;
  font-family: var(--ff-display); font-style: italic; font-size: 22px;
  color: var(--fg-1); outline: none;
  transition: border-color 200ms ease;
}
.at-form input:focus,
.at-form select:focus,
.at-form textarea:focus,
.at-cf7-wrap input:focus,
.at-cf7-wrap select:focus,
.at-cf7-wrap textarea:focus {
  border-bottom-color: var(--sb-brown-500);
}
.at-form textarea { resize: vertical; min-height: 120px; }
.at-form select {
  appearance: none; -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--fg-1) 50%),
                    linear-gradient(135deg, var(--fg-1) 50%, transparent 50%);
  background-position: calc(100% - 18px) 22px, calc(100% - 13px) 22px;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 32px;
}
.at-form__check {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 12px; line-height: 1.55; color: var(--fg-2);
  cursor: pointer; max-width: 560px;
}
.at-form__check input { margin-top: 4px; accent-color: var(--sb-brown-500); }
.at-form__submit {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 18px;
  padding: 18px 28px;
  background: var(--sb-brown-500); color: var(--sb-cream-50);
  border: 0; cursor: pointer;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  font-family: var(--ff-sans);
  transition: background 200ms ease;
}
.at-form__submit:hover { background: var(--sb-brown-700); }
.at-form__submit-arrow {
  font-family: var(--ff-display); font-style: italic; font-size: 18px;
  letter-spacing: 0; text-transform: none;
}

/* CF7 fallback overrides */
.at-cf7-wrap .wpcf7-form { display: flex; flex-direction: column; gap: 28px; }
.at-cf7-wrap label {
  display: flex; flex-direction: column; gap: 8px;
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--fg-3);
}
.at-cf7-wrap .wpcf7-submit {
  align-self: flex-start;
  padding: 18px 28px;
  background: var(--sb-brown-500); color: var(--sb-cream-50);
  border: 0; cursor: pointer;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
}

@media (max-width: 1023px) {
  .at-form__row { grid-template-columns: 1fr; gap: 24px; }
  .atelier > section { padding-left: 24px !important; padding-right: 24px !important; }
  .atelier > section[style*="grid-template-columns:1fr 460px"] { grid-template-columns: 1fr !important; gap: 48px !important; }
  .atelier > section[style*="grid-template-columns:1fr 460px"] aside { position: static !important; }
}


/* ============================================================
 * INTERIOR PAGES · single-prodotto, single-evento, page-azienda,
 * archive-evento, page.php, index.php, 404.php
 * Tutto in chiave `at-*` coerente col resto del tema.
 * ============================================================ */

/* Sub-hero condiviso */
.at-sub-hero {
  padding: 200px 96px 96px;
  border-bottom: 1px solid var(--line-soft);
  display: grid; grid-template-columns: 1fr 1fr; gap: 96px;
  align-items: end;
}
.at-sub-hero__meta { display: flex; flex-direction: column; gap: 8px; }
.at-sub-hero__crumbs {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); display: flex; gap: 12px; align-items: center;
}
.at-sub-hero__crumbs a { color: var(--fg-2); transition: opacity .2s; }
.at-sub-hero__crumbs a:hover { opacity: .55; }
.at-sub-hero__title {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(64px, 7vw, 120px); line-height: 0.96; letter-spacing: -0.02em;
  margin: 32px 0 0; color: var(--fg-1);
}
.at-sub-hero__title em { font-style: italic; color: var(--sb-brown-600); display: block; }
.at-sub-hero__lede {
  font-family: var(--ff-display); font-style: italic; font-weight: 300;
  font-size: 22px; line-height: 1.55; color: var(--fg-2);
  max-width: 480px;
}
.at-sub-hero__img {
  aspect-ratio: 4/5; background: var(--sb-cream-200);
  background-size: cover; background-position: center;
}

/* Buttons */
.at-btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 30px; background: var(--sb-brown-900); color: var(--sb-cream-50);
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--sb-brown-900);
  transition: all 0.32s var(--ease-standard);
}
.at-btn:hover { background: var(--sb-cream-50); color: var(--sb-brown-900); }
.at-btn--ghost { background: transparent; color: var(--fg-1); border-color: var(--fg-1); }
.at-btn--ghost:hover { background: var(--fg-1); color: var(--sb-cream-50); }
.at-link {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--ff-display); font-style: italic; font-size: 18px; color: var(--fg-1);
  border-bottom: 1px solid var(--fg-1); padding-bottom: 4px;
  transition: opacity .2s;
}
.at-link:hover { opacity: .65; }

/* Rich text */
.at-rich p {
  font-size: 16px; line-height: 1.7; color: var(--fg-2); font-weight: 300;
  margin: 0 0 18px; max-width: 620px;
}
.at-rich h2, .at-rich h3 {
  font-family: var(--ff-display); font-weight: 400;
  letter-spacing: -0.01em; color: var(--fg-1); margin: 56px 0 20px;
}
.at-rich h2 { font-size: clamp(36px, 3.6vw, 56px); line-height: 1.05; }
.at-rich h3 { font-size: clamp(26px, 2.4vw, 36px); }

/* Body 2-col layout */
.at-body-2col {
  padding: 96px 96px;
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 96px;
  align-items: start;
  border-bottom: 1px solid var(--line-soft);
}
.at-aside {
  position: sticky; top: 120px;
  border-top: 1px solid var(--fg-1); padding-top: 32px;
}
.at-aside__title {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3); margin: 0 0 24px;
}
.at-defs { margin: 0; }
.at-defs > div {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  padding: 16px 0; border-bottom: 1px solid var(--line-soft);
}
.at-defs dt { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); margin: 0; }
.at-defs dd { font-family: var(--ff-display); font-style: italic; font-size: 18px; color: var(--fg-1); margin: 0; }

/* Gallery editorial */
.at-gallery {
  padding: 96px 96px; border-bottom: 1px solid var(--line-soft);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 32px 24px;
}
.at-gallery figure { margin: 0; position: relative; overflow: hidden; }
.at-gallery img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1100ms var(--ease-out); }
.at-gallery figure:hover img { transform: scale(1.03); }
.at-gallery figcaption {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--ff-display); font-style: italic; font-size: 14px; color: var(--sb-cream-50);
}
.at-gallery .g--wide { grid-column: span 8; aspect-ratio: 16/10; }
.at-gallery .g--sm   { grid-column: span 4; aspect-ratio: 4/5; }
.at-gallery .g--tall { grid-column: span 5; aspect-ratio: 3/4; }
.at-gallery .g--full { grid-column: span 7; aspect-ratio: 16/9; }
.at-gallery .g--md   { grid-column: span 6; aspect-ratio: 4/3; }

/* Numbered list (materiali, valori, programma) */
.at-numlist { list-style: none; padding: 0; margin: 56px 0 0; display: grid; gap: 0; }
.at-numlist li {
  display: grid; grid-template-columns: 80px 1fr 1.6fr; gap: 32px; align-items: start;
  padding: 32px 0; border-top: 1px solid var(--line-soft);
}
.at-numlist li:last-child { border-bottom: 1px solid var(--line-soft); }
.at-numlist .num { font-family: var(--ff-display); font-style: italic; font-size: 24px; color: var(--fg-3); }
.at-numlist h4 {
  font-family: var(--ff-display); font-weight: 400; font-style: italic;
  font-size: clamp(24px, 2.4vw, 36px); margin: 0; color: var(--fg-1);
}
.at-numlist p { margin: 0; font-size: 15px; line-height: 1.7; color: var(--fg-2); font-weight: 300; }

/* Stats strip */
.at-stats-strip {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
  padding: 96px; border-bottom: 1px solid var(--line-soft);
}
.at-stats-strip > div { border-top: 1px solid var(--fg-1); padding-top: 24px; }
.at-stats-strip .big {
  font-family: var(--ff-display); font-style: italic;
  font-size: clamp(56px, 5.4vw, 88px); line-height: 1; color: var(--sb-brown-500);
}
.at-stats-strip .lbl {
  margin-top: 12px;
  font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3);
}

/* Finiture chips */
.at-chips { display: flex; flex-wrap: wrap; gap: 16px 24px; padding: 32px 96px 96px; border-bottom: 1px solid var(--line-soft); }
.at-chip { display: inline-flex; align-items: center; gap: 12px; font-size: 13px; color: var(--fg-1); }
.at-chip .swatch { width: 26px; height: 26px; border-radius: 999px; border: 1px solid var(--line-medium); display: inline-block; }

/* CTA strip */
.at-cta-strip {
  padding: 128px 96px; text-align: center;
  background: var(--sb-cream-50); border-bottom: 1px solid var(--line-soft);
}
.at-cta-strip h2 {
  font-family: var(--ff-display); font-weight: 400; font-style: italic;
  font-size: clamp(40px, 4.4vw, 64px); margin: 0 0 16px; letter-spacing: -0.01em;
}
.at-cta-strip p { font-size: 16px; color: var(--fg-2); font-weight: 300; max-width: 520px; margin: 0 auto 32px; }

/* Persone grid (azienda) */
.at-persone {
  padding: 32px 96px 96px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px 32px;
  border-bottom: 1px solid var(--line-soft);
}
.at-persona figure { margin: 0; aspect-ratio: 3/4; overflow: hidden; background: var(--sb-cream-200); }
.at-persona figure img { width: 100%; height: 100%; object-fit: cover; transition: transform 1100ms var(--ease-out); }
.at-persona:hover figure img { transform: scale(1.03); }
.at-persona h3 { font-family: var(--ff-display); font-style: italic; font-size: 28px; margin: 18px 0 4px; color: var(--fg-1); }
.at-persona p { font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--fg-3); margin: 0; }

/* 404 */
.at-404 { padding: 200px 96px 160px; text-align: center; border-bottom: 1px solid var(--line-soft); }
.at-404 h1 {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(72px, 8vw, 140px); margin: 24px 0 24px; letter-spacing: -0.02em;
}
.at-404 p { font-size: 17px; color: var(--fg-2); font-weight: 300; max-width: 520px; margin: 0 auto 40px; }
.at-404 div { display: inline-flex; gap: 24px; align-items: center; }

/* Page generica */
.at-page-body {
  max-width: 820px; margin: 0 auto;
  padding: 200px 48px 160px;
  border-bottom: 1px solid var(--line-soft);
}
.at-page-body h1 {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(56px, 6vw, 96px); line-height: 1; letter-spacing: -0.02em;
  margin: 0 0 56px;
}

/* Responsive */
@media (max-width: 1023px) {
  .at-sub-hero { grid-template-columns: 1fr; gap: 48px; padding: 160px 48px 64px; }
  .at-sub-hero__img { aspect-ratio: 16/10; }
  .at-body-2col { grid-template-columns: 1fr; gap: 48px; padding: 64px 48px; }
  .at-aside { position: static; }
  .at-gallery { grid-template-columns: 1fr; padding: 64px 48px; }
  .at-gallery .g--wide,
  .at-gallery .g--sm,
  .at-gallery .g--tall,
  .at-gallery .g--full,
  .at-gallery .g--md { grid-column: 1 / -1; aspect-ratio: 4/3; }
  .at-stats-strip { grid-template-columns: 1fr; padding: 64px 48px; gap: 24px; }
  .at-numlist li { grid-template-columns: 60px 1fr; }
  .at-numlist li p { grid-column: 2 / -1; }
  .at-chips { padding: 24px 48px 64px; }
  .at-cta-strip { padding: 80px 48px; }
  .at-persone { grid-template-columns: repeat(2, 1fr); padding: 24px 48px 64px; }
  .at-404 { padding: 160px 48px 96px; }
  .at-page-body { padding: 160px 24px 96px; }
}
@media (max-width: 640px) {
  .at-sub-hero { padding: 140px 20px 48px; }
  .at-body-2col { padding: 48px 20px; }
  .at-gallery { padding: 48px 20px; }
  .at-stats-strip { padding: 48px 20px; }
  .at-chips { padding: 20px 20px 48px; }
  .at-cta-strip { padding: 64px 20px; }
  .at-persone { grid-template-columns: 1fr; padding: 20px 20px 48px; }
  .at-404 { padding: 140px 20px 64px; }
  .at-404 div { flex-direction: column; gap: 16px; }
  .at-page-body { padding: 140px 20px 64px; }
}

/* ============================================================
   MOBILE MENU · hamburger ↔ X + slide-up full screen overlay
   ============================================================ */

/* Quando il menu è aperto, l'header sale sopra l'overlay
   così la X (burger trasformato) resta cliccabile */
body.menu-open .at-header { z-index: 120; }

/* Burger button · nascosto su desktop */
.at-burger {
  display: none;
  position: relative;
  z-index: 110;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: 0;
  padding: 8px 10px;
  margin: -8px -10px -8px 0;
  cursor: pointer;
  font-family: inherit;
  color: var(--fg-1);
  -webkit-tap-highlight-color: transparent;
}
.at-burger__lines {
  position: relative;
  display: inline-block;
  width: 28px;
  height: 18px;
  flex: none;
}
.at-burger__line {
  position: absolute;
  left: 0;
  right: 0;
  height: 1.5px;
  background: currentColor;
  border-radius: 2px;
  transform-origin: 50% 50%;
  transition:
    transform 480ms cubic-bezier(0.6, 0.05, 0.2, 1),
    top 280ms cubic-bezier(0.6, 0.05, 0.2, 1) 160ms,
    opacity 200ms ease,
    width 360ms cubic-bezier(0.6, 0.05, 0.2, 1);
}
.at-burger__line--1 { top: 2px;  width: 100%; }
.at-burger__line--2 { top: 50%;  margin-top: -1px; width: 70%; }
.at-burger__line--3 { top: calc(100% - 4px); width: 100%; }

/* Hover · linee si allineano alla stessa larghezza con micro shift */
@media (hover: hover) {
  .at-burger:hover .at-burger__line--2 { width: 100%; }
  .at-burger:hover .at-burger__line--1 { transform: translateX(2px); }
  .at-burger:hover .at-burger__line--3 { transform: translateX(-2px); }
}

/* Aperto · diventa X */
.at-burger.is-open .at-burger__line {
  transition:
    top 280ms cubic-bezier(0.6, 0.05, 0.2, 1),
    transform 480ms cubic-bezier(0.6, 0.05, 0.2, 1) 200ms,
    opacity 160ms ease,
    width 280ms cubic-bezier(0.6, 0.05, 0.2, 1);
}
.at-burger.is-open .at-burger__line--1 {
  top: 50%; margin-top: -1px; width: 100%;
  transform: rotate(45deg);
}
.at-burger.is-open .at-burger__line--2 {
  width: 100%;
  opacity: 0;
}
.at-burger.is-open .at-burger__line--3 {
  top: 50%; margin-top: -1px; width: 100%;
  transform: rotate(-45deg);
}

.at-burger__label {
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--fg-1);
  transition: opacity .25s ease;
}

/* Overlay mobile menu */
.at-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  pointer-events: none;
  background: transparent;
  visibility: hidden;
  transition: visibility 0s linear 720ms;
}
.at-mobile-menu.is-open {
  pointer-events: auto;
  visibility: visible;
  transition: visibility 0s linear 0s;
}
.at-mobile-menu__panel {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 100dvh;
  width: 100%;
  background: var(--cream-100, #f4efe6);
  color: var(--fg-1);
  padding: 96px 28px 32px;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 720ms cubic-bezier(0.76, 0, 0.24, 1);
  box-shadow: 0 -32px 60px rgba(31, 27, 23, 0.18);
  overflow-y: auto;
}
.at-mobile-menu.is-open .at-mobile-menu__panel {
  transform: translateY(0);
}

/* Head */
.at-mobile-menu__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--fg-1, #1f1b17);
  margin-bottom: 8px;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 420ms ease 180ms, transform 480ms cubic-bezier(0.2, 0, 0.2, 1) 180ms;
}
.at-mobile-menu.is-open .at-mobile-menu__head {
  opacity: 1; transform: translateY(0);
}
.at-mobile-menu__eyebrow {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #7a715f);
}
.at-mobile-menu__meta {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 14px;
  color: var(--brown-500, #8b6f4e);
}

/* Nav */
.at-mobile-menu__nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 24px 0;
  gap: 4px;
}
.at-mobile-menu__nav a {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: baseline;
  gap: 20px;
  padding: 22px 0;
  border-bottom: 1px solid rgba(31, 27, 23, 0.08);
  text-decoration: none;
  color: var(--fg-1);
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 520ms cubic-bezier(0.2, 0, 0.2, 1) calc(220ms + var(--i) * 90ms),
    transform 620ms cubic-bezier(0.2, 0, 0.2, 1) calc(220ms + var(--i) * 90ms);
}
.at-mobile-menu.is-open .at-mobile-menu__nav a {
  opacity: 1;
  transform: translateY(0);
}
.at-mobile-menu__nav a .num {
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--brown-500, #8b6f4e);
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0;
}
.at-mobile-menu__nav a .lbl {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-size: clamp(38px, 9vw, 56px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--fg-1);
}
.at-mobile-menu__nav a .lbl em {
  font-style: italic;
  color: var(--brown-600, #6e5739);
}
.at-mobile-menu__nav a .arr {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 22px;
  color: var(--fg-3, #7a715f);
  transition: transform .35s ease, color .35s ease;
}
.at-mobile-menu__nav a:active .arr,
.at-mobile-menu__nav a:focus-visible .arr {
  transform: translateX(8px);
  color: var(--fg-1);
}

/* Foot */
.at-mobile-menu__foot {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-top: 22px;
  border-top: 1px solid var(--fg-1, #1f1b17);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 520ms ease 640ms, transform 620ms cubic-bezier(0.2, 0, 0.2, 1) 640ms;
}
.at-mobile-menu.is-open .at-mobile-menu__foot {
  opacity: 1; transform: translateY(0);
}
.at-mobile-menu__address {
  display: flex; flex-direction: column; gap: 4px;
}
.at-mobile-menu__address .lab {
  font-size: 9px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--fg-3, #7a715f);
}
.at-mobile-menu__address .val {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 16px;
  color: var(--fg-1);
  line-height: 1.35;
}
.at-mobile-menu__lang {
  display: inline-flex; gap: 8px; align-items: center;
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--fg-3, #7a715f);
}
.at-mobile-menu__lang .active { color: var(--fg-1); }
.at-mobile-menu__lang .dot { opacity: .5; }

/* Show burger ≤1023px, hide desktop nav/meta */
@media (max-width: 1023px) {
  .at-header { grid-template-columns: 1fr auto 1fr !important; }
  .at-header__nav,
  .at-header__meta { display: none !important; }
  .at-burger {
    display: inline-flex;
    justify-self: end;
    grid-column: 3;
  }
}

/* Mobile spacing */
@media (max-width: 640px) {
  .at-mobile-menu__panel { padding: 84px 22px 28px; }
  .at-burger__label { display: none; }
  .at-burger__lines { width: 26px; height: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  .at-mobile-menu__panel,
  .at-mobile-menu__head,
  .at-mobile-menu__nav a,
  .at-mobile-menu__foot,
  .at-burger__line { transition-duration: 1ms !important; }
}

/* ============================================================
 * AZIENDA · port pixel-per-pixel di AtAboutFullPage (atelier.jsx)
 * ============================================================ */
.at-about-page { background: var(--cream-50, #faf6ef); color: var(--fg-1); }

/* Hero */
.at-az-hero {
  padding: 180px 96px 64px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 96px;
  align-items: end;
}
.at-az-hero__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-style: italic;
  font-size: clamp(80px, 11vw, 180px);
  line-height: .88;
  letter-spacing: -0.025em;
  margin: 24px 0 0;
}
.at-az-hero__title em { font-style: italic; color: var(--sb-brown-600, #6e5739); }
.at-az-hero__lead {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 1.5;
  color: var(--fg-2);
  margin: 0;
  max-width: 540px;
}

/* Immagine wide 21:9 */
.at-az-wide {
  aspect-ratio: 21 / 9;
  margin: 80px 96px 0;
  background-size: cover;
  background-position: center;
}
.at-az-wide__cap {
  padding: 18px 96px 0;
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--fg-3, #7a715f);
}

/* Intro 2 col */
.at-az-intro {
  padding: 160px 96px;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 64px;
}
.at-az-intro__body { max-width: 820px; }
.at-az-intro__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-size: clamp(48px, 5vw, 72px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0 0 40px;
}
.at-az-intro__title em { font-style: italic; color: var(--sb-brown-600, #6e5739); }
.at-az-intro__p {
  font-size: 18px;
  line-height: 1.75;
  color: var(--fg-2);
  font-weight: 300;
  margin: 0 0 22px;
}
.at-az-intro__p:last-child { margin-bottom: 0; }

/* Principî · 2x2 */
.at-az-principles { padding: 0 96px 160px; }
.at-az-values {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 72px 96px;
}
.at-az-value { border-top: 1px solid var(--fg-1); padding-top: 24px; }
.at-az-value__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 18px;
}
.at-az-value__num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 36px;
  color: var(--sb-brown-500, #8a6f4d);
}
.at-az-value__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-style: italic;
  font-size: 48px;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.at-az-value__p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--fg-2);
  font-weight: 300;
  margin: 0;
  max-width: 440px;
}

/* Timeline */
.at-az-timeline { padding: 160px 96px; }
.at-az-timeline__list { display: flex; flex-direction: column; }
.at-az-timeline__row {
  display: grid;
  grid-template-columns: 120px 1fr 1.4fr;
  gap: 48px;
  padding: 48px 0;
  border-top: 1px solid var(--line-soft);
  align-items: start;
}
.at-az-timeline__row.is-last { border-bottom: 1px solid var(--line-soft); }
.at-az-timeline__yr {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-size: 48px;
  color: var(--sb-brown-500, #8a6f4d);
  line-height: 1;
}
.at-az-timeline__t {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  line-height: 1.2;
  margin: 0;
  max-width: 380px;
}
.at-az-timeline__d {
  font-size: 16px;
  line-height: 1.75;
  color: var(--fg-2);
  font-weight: 300;
  margin: 0;
  max-width: 520px;
}

/* Stats strip */
.at-az-stats-wrap { padding: 0 96px 160px; }
.at-az-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 48px;
  padding-top: 64px;
  border-top: 1px solid var(--fg-1);
}
.at-az-stats__big {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 96px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--fg-1);
}

/* Responsive */
@media (max-width: 1023px) {
  .at-az-hero { padding: 140px 32px 48px; grid-template-columns: 1fr; gap: 40px; }
  .at-az-wide { margin: 56px 32px 0; }
  .at-az-wide__cap { padding: 14px 32px 0; }
  .at-az-intro { padding: 96px 32px; grid-template-columns: 1fr; gap: 32px; }
  .at-az-principles { padding: 0 32px 96px; }
  .at-az-values { gap: 56px 48px; }
  .at-az-value__title { font-size: 36px; }
  .at-az-timeline { padding: 96px 32px; }
  .at-az-timeline__row { grid-template-columns: 90px 1fr; gap: 24px; }
  .at-az-timeline__d { grid-column: 1 / -1; }
  .at-az-stats-wrap { padding: 0 32px 96px; }
  .at-az-stats { grid-template-columns: repeat(2, 1fr); gap: 40px; }
  .at-az-stats__big { font-size: 72px; }
}
@media (max-width: 640px) {
  .at-az-hero { padding: 120px 20px 32px; }
  .at-az-wide { margin: 40px 20px 0; }
  .at-az-wide__cap { padding: 12px 20px 0; font-size: 9px; }
  .at-az-intro { padding: 72px 20px; }
  .at-az-principles { padding: 0 20px 72px; }
  .at-az-values { grid-template-columns: 1fr; gap: 48px; }
  .at-az-value__title { font-size: 32px; }
  .at-az-timeline { padding: 72px 20px; }
  .at-az-timeline__row { grid-template-columns: 1fr; gap: 12px; padding: 32px 0; }
  .at-az-timeline__yr { font-size: 36px; }
  .at-az-timeline__t { font-size: 24px; }
  .at-az-stats-wrap { padding: 0 20px 72px; }
  .at-az-stats { grid-template-columns: 1fr 1fr; gap: 28px; padding-top: 40px; }
  .at-az-stats__big { font-size: 56px; }
}
