/* =====================================================================
   ATLANTIS · giochiamoinsieme.it
   Design system — petrolio abissale + ottone antico + Cinzel lapidario.
   Coordinate del tono in /.planning/PICK.md.
   ===================================================================== */

:root {
  /* Palette — abyss + brass */
  --atl-bg:        #0B1A20;
  --atl-bg-2:      #10262E;
  --atl-paper:     #0F2128;        /* card surface (darker than bg) */
  --atl-paper-inv: #F1E6CF;        /* inverse (parchment) band */
  --atl-paper-inv-2: #E5D6B6;
  --atl-ink:       #E9DBC6;        /* bone */
  --atl-ink-2:     #C9BB9F;
  --atl-mute:      #7B8C92;
  --atl-line:      #1F3640;
  --atl-line-2:    #2D4A55;
  --atl-accent:    #E0A33C;        /* brass */
  --atl-accent-2:  #C68A26;
  --atl-accent-pale: #3D2F14;
  --atl-warn:      #C44A36;

  /* Spacing scale (8-px grid) */
  --atl-s1: 4px;
  --atl-s2: 8px;
  --atl-s3: 12px;
  --atl-s4: 16px;
  --atl-s5: 24px;
  --atl-s6: 32px;
  --atl-s7: 48px;
  --atl-s8: 64px;
  --atl-s9: 96px;

  /* Type */
  --atl-display: "Cinzel", "Cormorant Garamond", Georgia, serif;
  --atl-body:    "Public Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  --atl-mono:    "Roboto Mono", ui-monospace, "Cascadia Code", monospace;

  /* Type scale */
  --atl-fs-xs: 11px;
  --atl-fs-sm: 13px;
  --atl-fs-base: 15px;
  --atl-fs-lg: 19px;
  --atl-fs-xl: 26px;
  --atl-fs-2xl: 38px;
  --atl-fs-display: clamp(2.6rem, 5.5vw, 4.4rem);

  /* Layout */
  --atl-wrap-max: 1280px;
  --atl-wrap-pad: clamp(16px, 4vw, 40px);
}

/* ---------- Reset light ----------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body, h1, h2, h3, h4, h5, h6, p, ul, ol, dl, dd, figure, blockquote { margin: 0; }
ul, ol { padding: 0; list-style: none; }
img, svg, video { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; min-width: 0; max-width: 100%; }
a { color: inherit; }
:focus-visible { outline: 2px solid var(--atl-accent); outline-offset: 2px; }

/* ---------- Body shell ------------ */
.atl-body {
  background-color: var(--atl-bg);
  color: var(--atl-ink);
  font-family: var(--atl-body);
  font-size: var(--atl-fs-base);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  position: relative;
}
/* Decorative archive + gaming motifs tiled in brass at low opacity, fixed
   so content scrolls over them. Sections that have their own background
   color (hero feat, sched, process, sport, mod, box, foot) cover this layer. */
.atl-body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  background-image: url("/img/bg-pattern.svg");
  background-repeat: repeat;
  background-size: 360px 360px;
  opacity: 0.55;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.atl-body > * { position: relative; z-index: 1; }

.atl-wrap {
  width: 100%;
  max-width: var(--atl-wrap-max);
  margin: 0 auto;
  padding: 0 var(--atl-wrap-pad);
}

.atl-skip {
  position: absolute;
  left: -9999px; top: 0;
}
.atl-skip:focus {
  left: 8px; top: 8px;
  background: var(--atl-accent); color: var(--atl-bg);
  padding: 6px 12px; z-index: 9999; font-weight: 700;
}

.atl-sr { position: absolute; left: -9999px; }

/* ===== HEADER ====== "Quadro di bordo" =================================== */

.atl-head { position: relative; z-index: 50; }

/* Strip — registro di bordo */
.atl-strip {
  background: var(--atl-bg-2);
  border-bottom: 1px solid var(--atl-line);
  font-family: var(--atl-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-strip__row {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--atl-s5);
  align-items: center;
  height: 32px;
  overflow-x: auto;
  scrollbar-width: none;
}
.atl-strip__row::-webkit-scrollbar { display: none; }
.atl-strip__cell {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  white-space: nowrap;
  flex-shrink: 0;
}
.atl-strip__lab { color: var(--atl-accent); font-weight: 700; }
.atl-strip__val { color: var(--atl-ink-2); }

/* Bridge — main band */
.atl-bridge {
  background: var(--atl-bg);
  border-bottom: 1px solid var(--atl-line);
}
.atl-bridge__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--atl-s6);
  min-height: 96px;
  padding: var(--atl-s4) 0;
}

/* Brand (porthole) */
.atl-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--atl-s4);
  text-decoration: none;
  color: var(--atl-ink);
}
.atl-brand__porthole {
  width: 56px; height: 56px;
  flex-shrink: 0;
  border-radius: 50%;
  border: 2px solid var(--atl-accent);
  background: var(--atl-bg-2);
  display: grid;
  place-items: center;
  position: relative;
}
.atl-brand__porthole::before {
  content: "";
  position: absolute; inset: 4px;
  border-radius: 50%;
  border: 1px solid var(--atl-line-2);
  pointer-events: none;
}
.atl-brand__porthole-inner {
  color: var(--atl-accent);
  display: grid; place-items: center;
  width: 28px; height: 28px;
}
.atl-brand__type {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.atl-brand__name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: .12em;
  color: var(--atl-ink);
}
.atl-brand__sub {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--atl-mute);
  margin-top: 6px;
}

/* Nav */
.atl-nav__list {
  display: flex;
  gap: var(--atl-s5);
  justify-content: center;
}
.atl-nav__link {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-ink-2);
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 2px solid transparent;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  transition: color .15s ease, border-color .15s ease;
}
.atl-nav__num {
  font-family: var(--atl-mono);
  font-size: 9px;
  color: var(--atl-accent);
  letter-spacing: .12em;
}
.atl-nav__link:hover,
.atl-nav__link[aria-current="page"] {
  color: var(--atl-accent);
  border-bottom-color: var(--atl-accent);
}

.atl-nav__has-sub { position: relative; }
.atl-nav__sub {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  /* 12px transparent buffer so hover doesn't break crossing the gap */
  padding: 12px var(--atl-s3) 0;
  margin-top: 0;
  display: none;
  z-index: 99;
  /* visible card is built via inner ul background, see below */
}
.atl-nav__sub::before {
  content: "";
  position: absolute;
  inset: 12px 0 0 0;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  z-index: -1;
}
.atl-nav__sub > ul {
  min-width: 320px;
  padding: var(--atl-s3);
}
.atl-nav__has-sub:hover .atl-nav__sub,
.atl-nav__has-sub:focus-within .atl-nav__sub { display: block; }
.atl-nav__sub ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}
.atl-nav__sub a {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 12px;
  font-family: var(--atl-body);
  font-size: 13px;
  color: var(--atl-ink-2);
  text-transform: none;
  letter-spacing: 0;
  text-decoration: none;
  border-bottom: 1px solid var(--atl-line);
}
.atl-nav__sub a:hover { background: var(--atl-paper); color: var(--atl-accent); }
.atl-nav__sub-count {
  font-family: var(--atl-mono);
  font-size: 11px;
  color: var(--atl-mute);
}

/* Right pill: search + cart */
.atl-bridge__right {
  display: inline-flex;
  align-items: center;
  gap: var(--atl-s3);
}

.atl-search {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-bg-2);
  height: 40px;
  padding: 0 8px 0 12px;
  width: 280px;
}
.atl-search input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--atl-ink);
  font-family: var(--atl-mono);
  font-size: 12.5px;
}
.atl-search input::placeholder { color: var(--atl-mute); }
.atl-search__go {
  background: transparent;
  border: 0;
  color: var(--atl-accent);
  display: grid; place-items: center;
  padding: 6px;
}

.atl-cart {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--atl-accent);
  color: var(--atl-bg);
  padding: 0 16px;
  height: 40px;
  text-decoration: none;
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  border: 1px solid var(--atl-accent);
}
.atl-cart:hover { background: var(--atl-accent-2); border-color: var(--atl-accent-2); }
.atl-cart__icon { display: inline-grid; place-items: center; }
.atl-cart__count {
  font-family: var(--atl-mono);
  font-size: 11px;
  font-weight: 700;
  background: var(--atl-bg);
  color: var(--atl-accent);
  padding: 2px 6px;
  min-width: 22px;
  text-align: center;
}
.atl-cart__count.is-empty { opacity: .55; }

.atl-burger {
  display: none;
  background: transparent;
  border: 1px solid var(--atl-line-2);
  width: 40px; height: 40px;
  padding: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
}
.atl-burger span {
  display: block;
  width: 18px; height: 2px;
  background: var(--atl-ink);
}

/* ===== Buttons ========================================================== */

.atl-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 22px;
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  background: transparent;
  color: var(--atl-ink);
  transition: background .15s, color .15s, border-color .15s;
}
.atl-btn--brass {
  background: var(--atl-accent);
  color: var(--atl-bg);
  border-color: var(--atl-accent);
}
.atl-btn--brass:hover { background: var(--atl-accent-2); border-color: var(--atl-accent-2); }
.atl-btn--ghost {
  border-color: var(--atl-ink-2);
  color: var(--atl-ink);
}
.atl-btn--ghost:hover { border-color: var(--atl-accent); color: var(--atl-accent); }
.atl-btn--inv-brass { /* used inside inverse band */
  background: var(--atl-bg);
  color: var(--atl-paper-inv);
  border-color: var(--atl-bg);
}
.atl-btn--sm { padding: 8px 14px; font-size: 11.5px; }

/* ===== Kicker / numerali ================================================ */

.atl-kicker {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--atl-accent);
  display: inline-block;
}
.atl-kicker--ink { color: var(--atl-ink-2); }

.atl-rule {
  border: 0;
  border-top: 1px solid var(--atl-line);
  margin: var(--atl-s5) 0;
}
.atl-rule--accent {
  border-top: 2px solid var(--atl-accent);
}
.atl-rule--ink {
  border-top: 6px solid var(--atl-ink);
}

/* ===== HERO (busta-di-benvenuto) ======================================= */

.atl-bv {
  position: relative;
  padding: var(--atl-s9) 0 0;
  border-bottom: 1px solid var(--atl-line);
  overflow: hidden;
}
.atl-bv::before {
  /* Single hairline grid behind the letter — distinct from previous sonar */
  content: "";
  position: absolute;
  right: -10%;
  top: 50%;
  transform: translateY(-50%);
  width: 720px; height: 720px;
  border-radius: 50%;
  border: 1px solid var(--atl-line-2);
  pointer-events: none;
}
.atl-bv::after {
  content: "";
  position: absolute;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
  width: 460px; height: 460px;
  border-radius: 50%;
  border: 1px solid var(--atl-line);
  pointer-events: none;
}
.atl-bv__row {
  position: relative;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: var(--atl-s8);
  align-items: stretch;
  gap: var(--atl-s7);
  z-index: 1;
  margin-bottom: var(--atl-s7);
}

/* === Left: real photo of envelope pile, on a paper-card frame === */
.atl-bv__photo {
  position: relative;
  margin: 0;
  align-self: stretch;
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: 14px 14px 18px;
  transform: rotate(-1.2deg);
  transform-origin: top left;
}
.atl-bv__photo::before {
  /* corner "tape" */
  content: "";
  position: absolute;
  top: -10px; left: 22px;
  width: 88px; height: 22px;
  background: rgba(224,163,60,.55);
  border: 1px dashed rgba(0,0,0,.18);
  transform: rotate(-6deg);
}
.atl-bv__photo img {
  display: block;
  width: 100%;
  height: 360px;
  object-fit: cover;
  filter: sepia(.05) contrast(1.02);
}
.atl-bv__photo figcaption {
  margin-top: 12px;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--atl-mute);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.atl-bv__photo-credit { color: var(--atl-accent); }

/* === Right: typed letter on cream paper === */
.atl-bv__letter {
  background: #f7eed8;          /* warm cream paper */
  color: #2a1f0a;
  padding: var(--atl-s7) var(--atl-s6) var(--atl-s6);
  position: relative;
  border: 1px solid #d6c69a;
  box-shadow: 0 18px 48px rgba(0,0,0,.18);
  font-family: var(--atl-body);
  display: flex;
  flex-direction: column;
  gap: var(--atl-s4);
}
.atl-bv__letter::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px dashed rgba(0,0,0,.12);
  pointer-events: none;
}
.atl-bv__letter-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--atl-s4);
  align-items: start;
}
.atl-bv__letter-stamp {
  color: #8b5a13;
  display: inline-block;
  transform: rotate(4deg);
}
.atl-bv__letter-head .atl-kicker {
  color: #8b5a13;
  display: block;
  margin-bottom: 4px;
}
.atl-bv__letter-meta {
  display: block;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: #6e5524;
  text-transform: uppercase;
}
.atl-bv__h {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  letter-spacing: .02em;
  line-height: 1.18;
  color: #2a1f0a;
  margin: var(--atl-s2) 0 var(--atl-s2);
  text-transform: none;
}
.atl-bv__h em {
  font-style: italic;
  font-family: var(--atl-display);
  color: #8b5a13;
}
.atl-bv__gifts {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--atl-s4);
  border-top: 1px solid rgba(0,0,0,.18);
  padding-top: var(--atl-s4);
}
.atl-bv__gifts > li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--atl-s3);
  align-items: start;
}
.atl-bv__gift-no {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 38px;
  color: #8b5a13;
  line-height: 1;
  letter-spacing: -.02em;
}
.atl-bv__gifts h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #2a1f0a;
  margin-bottom: 4px;
}
.atl-bv__gifts p {
  font-size: 14px;
  line-height: 1.55;
  color: #4a3818;
  margin: 0;
}
.atl-bv__gifts em { font-style: italic; }
.atl-bv__letter-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--atl-s3);
  border-top: 1px solid rgba(0,0,0,.18);
  padding-top: var(--atl-s4);
  margin-top: var(--atl-s2);
}
.atl-bv__sign {
  font-family: var(--atl-display);
  font-style: italic;
  font-size: 15px;
  color: #4a3818;
}

/* Stats strip (replaces the old hero__stats grid) */
.atl-bv__strip {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: var(--atl-s3);
  align-items: baseline;
  padding: var(--atl-s4) 0;
  border-top: 1px solid var(--atl-line);
  margin-top: 0;
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--atl-mute);
  z-index: 1;
}
.atl-bv__strip b {
  color: var(--atl-accent);
  font-weight: 700;
  font-size: 13px;
}
.atl-bv__strip-sep { color: var(--atl-line-2); }

/* legacy hero leftover — kept blank to avoid bleed if any other page uses */
.atl-hero__copy { max-width: 640px; }
.atl-hero__crumb {
  display: inline-flex;
  gap: var(--atl-s4);
  margin-bottom: var(--atl-s4);
  font-family: var(--atl-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--atl-mute);
}
.atl-hero__crumb b { color: var(--atl-accent); font-weight: 700; }

/* legacy .atl-hero h1 removed — see new .atl-hero__h below */

.atl-hero__lede {
  font-size: 17px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  margin-bottom: var(--atl-s5);
  max-width: 56ch;
}
.atl-hero__lede strong { color: var(--atl-ink); font-weight: 600; }

.atl-hero__cta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--atl-s3);
  margin-bottom: var(--atl-s7);
}

.atl-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
  padding: var(--atl-s4) 0;
}
.atl-hero__stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: var(--atl-s4);
  border-right: 1px solid var(--atl-line);
}
.atl-hero__stat:last-child { border-right: 0; }
.atl-hero__stat dt {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-mute);
}
.atl-hero__stat dd {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 24px;
  letter-spacing: .04em;
  color: var(--atl-accent);
}

/* Hero feature card on the right (one product as "ritrovamento") */
.atl-hero__feat {
  position: relative;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-paper);
}
.atl-hero__feat-media {
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--atl-bg-2);
}
.atl-hero__feat-media img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.atl-hero__feat-stamp {
  position: absolute;
  top: 16px; left: 16px;
  background: var(--atl-accent);
  color: var(--atl-bg);
  padding: 6px 10px;
  font-family: var(--atl-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-hero__feat-meta {
  padding: var(--atl-s4);
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 1px solid var(--atl-line-2);
}
.atl-hero__feat-no {
  font-family: var(--atl-mono);
  font-size: 11px;
  color: var(--atl-mute);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-hero__feat-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  text-decoration: none;
}
.atl-hero__feat-name:hover { color: var(--atl-accent); }
.atl-hero__feat-foot {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 8px;
}
.atl-hero__feat-price {
  font-family: var(--atl-mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--atl-accent);
}

/* ===== Product card (shared) ============================================ */

.atl-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  background: var(--atl-paper);
  border: 1px solid var(--atl-line);
  text-decoration: none;
  color: var(--atl-ink);
  transition: border-color .15s, transform .15s;
}
.atl-card:hover {
  border-color: var(--atl-accent);
  transform: translateY(-2px);
}
.atl-card__media {
  display: block;
  aspect-ratio: 4 / 3;
  background: var(--atl-bg-2);
  overflow: hidden;
  border-bottom: 1px solid var(--atl-line);
}
.atl-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.atl-card:hover .atl-card__media img { transform: scale(1.04); }
.atl-card__no {
  position: absolute;
  top: 8px; left: 8px;
  background: var(--atl-bg);
  color: var(--atl-accent);
  font-family: var(--atl-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  padding: 3px 7px;
  border: 1px solid var(--atl-accent);
}
.atl-card__discount {
  position: absolute;
  top: 8px; right: 8px;
  background: var(--atl-warn);
  color: var(--atl-ink);
  font-family: var(--atl-mono);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 7px;
}
.atl-card__body {
  padding: var(--atl-s4);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.atl-card__kick {
  font-family: var(--atl-mono);
  font-size: 10px;
  color: var(--atl-mute);
  letter-spacing: .14em;
  text-transform: uppercase;
  display: flex;
  gap: 8px;
  align-items: baseline;
}
.atl-card__kick b { color: var(--atl-accent); font-weight: 700; }
.atl-card__name {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 16px;
  line-height: 1.25;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
}
.atl-card__cond {
  font-family: var(--atl-mono);
  font-size: 11px;
  color: var(--atl-ink-2);
}
.atl-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px var(--atl-s4) var(--atl-s4);
  border-top: 1px solid var(--atl-line);
  gap: 10px;
}
.atl-card__price {
  font-family: var(--atl-mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--atl-accent);
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.atl-card__price s {
  color: var(--atl-mute);
  font-size: 12px;
  font-weight: 400;
}
.atl-card__add {
  background: transparent;
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink);
  padding: 6px 10px;
  font-family: var(--atl-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.atl-card__add:hover {
  background: var(--atl-accent);
  color: var(--atl-bg);
  border-color: var(--atl-accent);
}

/* ===== HOME · ritrovamento-strisciato (banner row) ====================== */

.atl-banner {
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
  background: var(--atl-bg-2);
  padding: var(--atl-s7) 0;
}
.atl-banner__row {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: var(--atl-s7);
  align-items: center;
}
.atl-banner__copy h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 32px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: var(--atl-s3) 0 var(--atl-s4);
  line-height: 1.1;
}
.atl-banner__copy p { color: var(--atl-ink-2); margin-bottom: var(--atl-s4); }
.atl-banner__cta { display: flex; gap: var(--atl-s3); }
.atl-banner__media {
  position: relative;
  border: 1px solid var(--atl-line-2);
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
.atl-banner__media img { width: 100%; height: 100%; object-fit: cover; }
.atl-banner__media-stamp {
  position: absolute;
  bottom: 12px; left: 12px;
  background: var(--atl-bg);
  color: var(--atl-accent);
  border: 1px solid var(--atl-accent);
  padding: 6px 10px;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

/* ===== HOME · schedario centrale (white editorial, replaces depths) ===== */

.atl-sched {
  background: #ffffff;
  color: #1a140a;
  padding: var(--atl-s9) 0;
  border-top: 6px solid var(--atl-bg);
  border-bottom: 6px solid var(--atl-bg);
}
.atl-sched__row {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: var(--atl-s7);
  align-items: start;
}
.atl-sched__photo {
  position: sticky;
  top: var(--atl-s5);
  margin: 0;
  background: #fafafa;
  padding: 12px 12px 16px;
  border: 1px solid #d4d4d4;
}
.atl-sched__photo img {
  display: block;
  width: 100%;
  height: 460px;
  object-fit: cover;
  filter: grayscale(.18) contrast(1.04);
}
.atl-sched__photo figcaption {
  margin-top: 12px;
  font-family: var(--atl-body);
  font-size: 13px;
  line-height: 1.5;
  color: #5e5648;
  font-style: italic;
}
.atl-sched__photo figcaption i { color: #8b5a13; font-style: italic; }
.atl-sched .atl-kicker { color: #8b5a13; }
.atl-sched__h {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 3.6vw, 2.8rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.08;
  letter-spacing: .02em;
  text-transform: none;
  color: #1a140a;
  margin: var(--atl-s3) 0 var(--atl-s4);
}
.atl-sched__h em {
  font-style: italic;
  color: #8b5a13;
  font-family: var(--atl-display);
}
.atl-sched__lede {
  max-width: 60ch;
  color: #4a3a20;
  font-size: 17px;
  line-height: 1.65;
  margin-bottom: var(--atl-s6);
}
.atl-sched__lede strong { color: #1a140a; font-weight: 600; }
.atl-sched__lede i { color: #8b5a13; font-style: italic; }
.atl-sched__cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid #e6e0d2;
}
.atl-sched__card {
  padding: var(--atl-s5) 0 var(--atl-s4);
  border-bottom: 1px solid #e6e0d2;
  display: flex;
  flex-direction: column;
  flex-direction: column;
  gap: var(--atl-s3);
  position: relative;
}
.atl-sched__card-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--atl-s4);
  align-items: baseline;
}
.atl-sched__card-tab {
  font-family: var(--atl-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #8b5a13;
  border: 1px solid currentColor;
  padding: 4px 8px;
  letter-spacing: .14em;
}
.atl-sched__card h3 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #1a140a;
  line-height: 1.05;
}
.atl-sched__card-range {
  font-family: var(--atl-mono);
  font-size: 12px;
  color: #6e5524;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.atl-sched__card-num {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 44px;
  line-height: 1;
  color: #1a140a;
  letter-spacing: .02em;
  line-height: 1;
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  text-align: right;
}
.atl-sched__card-num small {
  font-family: var(--atl-mono);
  font-size: 11px;
  font-weight: 400;
  margin-left: 8px;
  color: #4a3818;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #6e5524;
}
.atl-sched__card-quote {
  font-size: 15.5px;
  line-height: 1.65;
  color: #3d3220;
  font-style: italic;
  border-left: 2px solid #d4af6a;
  padding-left: var(--atl-s4);
  margin: 4px 0 8px;
}
.atl-sched__card-pick {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--atl-s4);
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid #c1b48f;
  text-decoration: none;
  color: #1a140a;
  align-items: baseline;
  padding: 10px 14px;
  background: #fafafa;
  border: 1px solid #e6e0d2;
  transition: border-color .15s, background .15s;
}
.atl-sched__card-pick:hover {
  border-color: #8b5a13;
  background: #fff;
}
.atl-sched__card-pick-lab {
  font-family: var(--atl-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #8b5a13;
}
.atl-sched__card-pick-name {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 14.5px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.2;
  letter-spacing: .03em;
}
.atl-sched__card-pick-meta {
  font-family: var(--atl-mono);
  font-size: 12px;
  color: #6e5524;
  letter-spacing: .04em;
}
.atl-sched__card-pick-meta b {
  color: #8b5a13;
  font-weight: 700;
}

/* ===== HOME · inventario-fenestra (asymmetric MOSAIC, WOW 5.2) ========== */

.atl-mosaic {
  padding: var(--atl-s9) 0 var(--atl-s8);
}
.atl-mosaic__h {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--atl-s7);
  align-items: end;
  margin-bottom: var(--atl-s6);
}
.atl-mosaic__h h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin-top: var(--atl-s2);
}
.atl-mosaic__h p { color: var(--atl-ink-2); }

.atl-mosaic__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap: 4px;
}
.atl-mosaic__cell {
  position: relative;
  display: block;
  background: var(--atl-bg-2);
  overflow: hidden;
  text-decoration: none;
  border: 1px solid var(--atl-line);
}
.atl-mosaic__cell img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.atl-mosaic__cell:hover img { transform: scale(1.05); }
.atl-mosaic__cell:hover { border-color: var(--atl-accent); }
.atl-mosaic__cell--big   { grid-column: span 2; grid-row: span 2; }
.atl-mosaic__cell--tall  { grid-row: span 2; }
.atl-mosaic__overlay {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: var(--atl-s4);
  background: linear-gradient(180deg, transparent 0%, rgba(11,26,32,.85) 75%, rgba(11,26,32,.95) 100%);
  /* exception to no-gradients-on-large-surfaces: required for legible
     overlay text on photos per WOW 5.2 contract. Subtle, single direction. */
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--atl-ink);
}
.atl-mosaic__overlay-name {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.2;
}
.atl-mosaic__cell--big .atl-mosaic__overlay-name { font-size: 22px; }
.atl-mosaic__overlay-meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--atl-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-ink-2);
}
.atl-mosaic__overlay-meta b { color: var(--atl-accent); font-weight: 700; }

/* ===== HOME · schede-di-catalogazione SLIDER ============================ */

.atl-slider {
  background: var(--atl-bg-2);
  padding: var(--atl-s8) 0;
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
}
.atl-slider__h {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--atl-s7);
  align-items: end;
  margin-bottom: var(--atl-s6);
}
.atl-slider__h h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin-top: var(--atl-s2);
}
.atl-slider__h p { color: var(--atl-ink-2); margin-top: var(--atl-s4); }
.atl-slider__nav {
  display: inline-flex;
  align-items: center;
  gap: var(--atl-s3);
  justify-self: end;
  align-self: end;
}
.atl-slider__btn {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink);
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
}
.atl-slider__btn:hover {
  border-color: var(--atl-accent);
  background: var(--atl-accent);
  color: var(--atl-bg);
}
.atl-slider__counter {
  font-family: var(--atl-mono);
  font-size: 13px;
  letter-spacing: .12em;
  color: var(--atl-mute);
  display: inline-flex;
  gap: 4px;
  align-items: baseline;
  padding: 0 6px;
}
.atl-slider__counter b {
  color: var(--atl-accent);
  font-weight: 700;
  font-size: 16px;
}
.atl-slider__counter-sep { color: var(--atl-line-2); }

/* Track — horizontal CSS scroll-snap carousel */
.atl-slider__track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(360px, 32%);
  gap: var(--atl-s4);
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 24px;
  padding: 28px 4px 32px;
  margin: 0 -4px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--atl-line-2) transparent;
}
.atl-slider__track::-webkit-scrollbar { height: 6px; }
.atl-slider__track::-webkit-scrollbar-track { background: transparent; }
.atl-slider__track::-webkit-scrollbar-thumb {
  background: var(--atl-line-2);
  border-radius: 3px;
}
.atl-slider__track:focus-visible {
  outline: 2px solid var(--atl-accent);
  outline-offset: 4px;
}

/* Single scheda card */
.atl-slider__card {
  position: relative;
  scroll-snap-align: start;
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  display: grid;
  grid-template-rows: auto auto auto auto auto;
  padding: var(--atl-s5) var(--atl-s4) var(--atl-s4);
  gap: var(--atl-s3);
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
  min-height: 540px;
}
.atl-slider__clip {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  width: 64px; height: 18px;
  background: linear-gradient(180deg, #d4af6a 0%, #a37928 100%);
  border: 1px solid #6f4e10;
  border-radius: 2px 2px 4px 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,.3);
}
.atl-slider__clip::after {
  content: "";
  position: absolute;
  inset: 4px 6px;
  border-top: 1px solid rgba(255,255,255,.4);
  border-bottom: 1px solid rgba(0,0,0,.3);
}
.atl-slider__card-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-bottom: 1px dashed var(--atl-line-2);
  padding-bottom: 8px;
}
.atl-slider__card-no { color: var(--atl-accent); font-weight: 700; }
.atl-slider__card-date { color: var(--atl-mute); }
.atl-slider__card-media {
  display: block;
  aspect-ratio: 4 / 3;
  background: var(--atl-bg-2);
  overflow: hidden;
  border: 1px solid var(--atl-line);
}
.atl-slider__card-media img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.atl-slider__card-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.atl-slider__card-kick {
  font-family: var(--atl-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-slider__card-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.15;
  margin: 0;
}
.atl-slider__card-name a {
  color: var(--atl-ink);
  text-decoration: none;
}
.atl-slider__card-name a:hover { color: var(--atl-accent); }
.atl-slider__card-note {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--atl-ink-2);
  font-style: italic;
  border-left: 2px solid var(--atl-accent);
  padding-left: 12px;
  margin: 4px 0 8px;
}
.atl-slider__card-spec {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  font-family: var(--atl-mono);
  font-size: 10.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-top: 1px solid var(--atl-line);
  padding-top: 10px;
}
.atl-slider__card-spec dt {
  color: var(--atl-mute);
  font-size: 9.5px;
  margin-bottom: 2px;
}
.atl-slider__card-spec dd {
  color: var(--atl-ink);
  font-weight: 700;
  font-size: 11px;
}
.atl-slider__card-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--atl-line);
  padding-top: var(--atl-s3);
  margin-top: auto;
}
.atl-slider__card-price {
  font-family: var(--atl-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--atl-accent);
}

/* Dot indicators */
.atl-slider__dots {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin-top: var(--atl-s4);
}
.atl-slider__dot {
  width: 28px;
  height: 4px;
  background: var(--atl-line-2);
  border: 0;
  cursor: pointer;
  padding: 0;
  transition: background .2s, width .2s;
}
.atl-slider__dot:hover { background: var(--atl-mute); }
.atl-slider__dot.is-active {
  background: var(--atl-accent);
  width: 44px;
}

/* ===== HOME · quartieri-archivio (genre tiles) ========================= */

.atl-quartieri {
  padding: var(--atl-s8) 0;
}
.atl-quartieri__h {
  margin-bottom: var(--atl-s6);
}
.atl-quartieri__h h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-top: var(--atl-s2);
  line-height: 1.1;
}
.atl-quartieri__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.atl-quartieri__tile {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: var(--atl-paper);
  border: 1px solid var(--atl-line);
  padding: var(--atl-s5) var(--atl-s4) var(--atl-s4);
  min-height: 200px;
  text-decoration: none;
  color: #f6efde;
  overflow: hidden;
  isolation: isolate;
}
.atl-quartieri__tile-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
  filter: grayscale(.35) contrast(1.05);
  transition: transform .4s ease;
}
.atl-quartieri__tile-shade {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg,
      rgba(8,32,42,.62) 0%,
      rgba(8,32,42,.78) 60%,
      rgba(8,32,42,.92) 100%);
  transition: background .25s;
}
.atl-quartieri__tile:hover {
  border-color: var(--atl-accent);
}
.atl-quartieri__tile:hover .atl-quartieri__tile-bg { transform: scale(1.04); }
.atl-quartieri__tile:hover .atl-quartieri__tile-shade {
  background:
    linear-gradient(180deg,
      rgba(8,32,42,.45) 0%,
      rgba(8,32,42,.72) 60%,
      rgba(8,32,42,.92) 100%);
}
.atl-quartieri__tile-no {
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s2);
  position: relative;
}
.atl-quartieri__tile-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  position: relative;
  text-shadow: 0 1px 2px rgba(0,0,0,.4);
}
.atl-quartieri__tile-foot {
  display: flex;
  justify-content: space-between;
  margin-top: var(--atl-s5);
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(246,239,222,.7);
  position: relative;
}
.atl-quartieri__tile-foot b { color: var(--atl-accent); font-weight: 700; }

/* ===== HOME · dispaccio (newsletter) ==================================== */

.atl-dispaccio {
  background: var(--atl-bg-2);
  border-top: 1px solid var(--atl-line);
  padding: var(--atl-s8) 0;
}
.atl-dispaccio__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s8);
  align-items: center;
}
.atl-dispaccio__copy h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin: var(--atl-s3) 0 var(--atl-s3);
}
.atl-dispaccio__copy p { color: var(--atl-ink-2); margin-bottom: var(--atl-s4); }
.atl-dispaccio__form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--atl-s2);
}
.atl-dispaccio__form input {
  background: var(--atl-bg);
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink);
  padding: 14px 16px;
  font-family: var(--atl-mono);
  font-size: 13px;
}
.atl-dispaccio__samples {
  border-left: 2px solid var(--atl-accent);
  padding: var(--atl-s4) var(--atl-s5);
}
.atl-dispaccio__samples h3 {
  font-family: var(--atl-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s3);
}
.atl-dispaccio__samples ol {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--atl-s3);
  counter-reset: dispaccio;
}
.atl-dispaccio__samples li {
  counter-increment: dispaccio;
  padding-left: 38px;
  position: relative;
  color: var(--atl-ink-2);
  font-size: 14px;
  line-height: 1.5;
}
.atl-dispaccio__samples li::before {
  content: "№ " counter(dispaccio, decimal-leading-zero);
  position: absolute;
  left: 0; top: 1px;
  font-family: var(--atl-mono);
  font-size: 10.5px;
  color: var(--atl-mute);
  letter-spacing: .14em;
}

/* ===== FOOTER =========================================================== */

.atl-foot {
  background: var(--atl-bg);
  border-top: 6px solid var(--atl-accent);
  padding: var(--atl-s7) 0 var(--atl-s5);
  margin-top: var(--atl-s9);
}
.atl-foot__top {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: var(--atl-s7);
  margin-bottom: var(--atl-s7);
}
.atl-foot__icon {
  display: inline-block;
  width: 28px;
  height: 28px;
  vertical-align: middle;
  margin-right: 10px;
}
.atl-foot__brand .atl-foot__mark {
  display: flex;
  align-items: center;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: .14em;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s3);
}
.atl-foot__legal-line { color: var(--atl-ink-2); margin-bottom: var(--atl-s3); font-size: 13.5px; line-height: 1.55; }
.atl-foot__address { color: var(--atl-mute); font-size: 12.5px; line-height: 1.6; font-family: var(--atl-mono); }
.atl-foot__h {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s4);
  padding-bottom: var(--atl-s2);
  border-bottom: 1px solid var(--atl-line);
}
.atl-foot__col ul { display: flex; flex-direction: column; gap: 6px; }
.atl-foot__col a {
  display: flex;
  justify-content: space-between;
  text-decoration: none;
  color: var(--atl-ink-2);
  font-size: 13.5px;
  padding: 4px 0;
}
.atl-foot__col a:hover { color: var(--atl-accent); }
.atl-foot__col a span {
  font-family: var(--atl-mono);
  font-size: 11px;
  color: var(--atl-mute);
}

.atl-foot__pay {
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
  padding: var(--atl-s4) 0;
  margin-bottom: var(--atl-s5);
}
.atl-foot__pay-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--atl-s5);
}
.atl-foot__pay-lab {
  font-family: var(--atl-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-accent);
}
.atl-foot__pay-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--atl-s2);
}
.atl-pay {
  border: 1px solid var(--atl-line-2);
  padding: 6px 12px;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--atl-ink-2);
}

.atl-foot__pay {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--atl-s4);
  padding: var(--atl-s4) 0 var(--atl-s4);
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
  margin-bottom: var(--atl-s4);
}
.atl-foot__pay-lab {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-foot__pay-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.atl-foot__pay-list li { display: inline-flex; align-items: center; }
.atl-foot__pay-list img {
  height: 24px;
  width: auto;
  display: block;
  background: #fff;
  border-radius: 3px;
  padding: 2px 4px;
  box-shadow: 0 0 0 1px var(--atl-line-2);
}
/* SVG-text badges (sepa/satispay/postepay/contrassegno) keep their own bg */
.atl-foot__pay-list img[src$="sepa.svg"],
.atl-foot__pay-list img[src$="satispay.svg"],
.atl-foot__pay-list img[src$="postepay.svg"],
.atl-foot__pay-list img[src$="contrassegno.svg"] {
  background: transparent;
  padding: 0;
  box-shadow: none;
  border-radius: 0;
}

.atl-foot__base {
  display: flex;
  flex-wrap: wrap;
  gap: var(--atl-s5);
  font-family: var(--atl-mono);
  font-size: 11px;
  color: var(--atl-mute);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.atl-foot__base-mono {
  margin-left: auto;
  color: var(--atl-ink-2);
}

/* ===== Cookie banner ================================================= */
.atl-cookie {
  position: fixed;
  left: var(--atl-s4);
  right: var(--atl-s4);
  bottom: var(--atl-s4);
  max-width: 640px;
  margin: 0 auto;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-accent);
  z-index: 9999;
  font-family: var(--atl-body);
}
.atl-cookie__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--atl-s4);
  align-items: center;
  padding: var(--atl-s4) var(--atl-s5);
}
.atl-cookie__copy h3 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: 6px;
}
.atl-cookie__copy p {
  font-size: 13px;
  line-height: 1.55;
  color: var(--atl-ink-2);
  margin: 0;
}
.atl-cookie__copy a { color: var(--atl-accent); }
.atl-cookie__cta {
  display: inline-flex;
  gap: var(--atl-s2);
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .atl-cookie__inner { grid-template-columns: 1fr; }
}

/* ===== Card grid (shared across genre + cart + PDP related) =========== */

.atl-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--atl-s4);
}
.atl-card-grid > li { display: contents; }

/* ===== Genre landing ================================================= */

.atl-genre-head {
  padding: var(--atl-s7) 0 var(--atl-s5);
  border-bottom: 1px solid var(--atl-line);
}
.atl-genre-head__h {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.05;
  margin: var(--atl-s2) 0 var(--atl-s4);
}
.atl-genre-head__row {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--atl-s7);
  align-items: end;
  margin-top: var(--atl-s4);
}
.atl-genre-head__lede {
  color: var(--atl-ink-2);
  font-size: var(--atl-fs-base);
  line-height: 1.65;
  max-width: 64ch;
}
.atl-genre-head__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
  padding: var(--atl-s3) 0;
}
.atl-genre-head__stats > div {
  border-right: 1px solid var(--atl-line);
  padding-left: var(--atl-s3);
}
.atl-genre-head__stats > div:first-child { padding-left: 0; }
.atl-genre-head__stats > div:last-child { border-right: 0; }
.atl-genre-head__stats dt {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  color: var(--atl-mute);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-genre-head__stats dd {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  color: var(--atl-accent);
}

.atl-genre-list { padding: var(--atl-s6) 0 var(--atl-s8); }
.atl-genre-list__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--atl-s5);
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-genre-list__sort {
  display: inline-flex;
  align-items: center;
  gap: var(--atl-s2);
}
.atl-genre-list__sort label { font-family: var(--atl-mono); font-size: 11px; color: var(--atl-accent); letter-spacing: .14em; }
.atl-genre-list__sort select {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink);
  padding: 6px 10px;
  font-family: var(--atl-mono);
  font-size: 12px;
}
.atl-genre-list__empty {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s7);
  text-align: center;
  color: var(--atl-ink-2);
}
.atl-genre-list__empty h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 26px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: var(--atl-s3);
  color: var(--atl-ink);
}
.atl-genre-list__empty a { color: var(--atl-accent); text-decoration: none; border-bottom: 1px solid currentColor; }

/* ===== Product Detail Page ========================================== */

.atl-pdp-head {
  border-bottom: 1px solid var(--atl-line);
  padding: var(--atl-s5) 0 var(--atl-s4);
}
.atl-pdp-crumb {
  display: inline-flex;
  gap: var(--atl-s2);
  align-items: center;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-pdp-crumb a { text-decoration: none; color: var(--atl-ink-2); }
.atl-pdp-crumb a:hover { color: var(--atl-accent); }
.atl-pdp-crumb span[aria-current] { color: var(--atl-accent); }

.atl-pdp { padding: var(--atl-s7) 0; border-bottom: 1px solid var(--atl-line); }
.atl-pdp__grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--atl-s8);
  align-items: start;
}
.atl-pdp__main {
  margin: 0;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-bg-2);
}
.atl-pdp__main img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.atl-pdp__main-cap {
  padding: var(--atl-s2) var(--atl-s3);
  border-top: 1px solid var(--atl-line-2);
  font-family: var(--atl-mono);
  font-size: 10.5px;
  color: var(--atl-mute);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.atl-pdp__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--atl-s2);
  margin-top: var(--atl-s3);
}
.atl-pdp__thumb {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line);
  padding: 0;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  cursor: pointer;
}
.atl-pdp__thumb img { width: 100%; height: 100%; object-fit: cover; }
.atl-pdp__thumb.is-active { border-color: var(--atl-accent); }
.atl-pdp__thumb:hover { border-color: var(--atl-accent-2); }

.atl-pdp__copy { padding-top: var(--atl-s4); }
.atl-pdp__name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 2.8rem);
  letter-spacing: .03em;
  text-transform: uppercase;
  line-height: 1.05;
  margin: var(--atl-s3) 0 var(--atl-s5);
}
.atl-pdp__spec {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
}
.atl-pdp__spec > div {
  padding: var(--atl-s3) var(--atl-s4) var(--atl-s3) 0;
  border-bottom: 1px solid var(--atl-line);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.atl-pdp__spec > div:nth-last-child(-n+2) { border-bottom: 0; }
.atl-pdp__spec dt {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  color: var(--atl-mute);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-pdp__spec dd {
  margin: 0;
  font-family: var(--atl-body);
  font-size: 14px;
  color: var(--atl-ink);
}

.atl-pdp__buy {
  display: grid;
  gap: var(--atl-s3);
  margin-top: var(--atl-s5);
  padding: var(--atl-s5);
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
}
.atl-pdp__price {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 36px;
  letter-spacing: .02em;
  color: var(--atl-accent);
  display: flex;
  align-items: baseline;
  gap: var(--atl-s3);
}
.atl-pdp__price s {
  font-family: var(--atl-mono);
  font-size: 16px;
  color: var(--atl-mute);
  font-weight: 400;
}
.atl-pdp__ship {
  font-family: var(--atl-mono);
  font-size: 12px;
  color: var(--atl-ink-2);
  letter-spacing: .1em;
  text-transform: uppercase;
}
.atl-pdp__add {
  width: 100%;
  padding: 16px 20px;
  font-size: 13px;
}

/* PDP nota */
.atl-pdp-nota { background: var(--atl-bg-2); padding: var(--atl-s8) 0; border-bottom: 1px solid var(--atl-line); }
.atl-pdp-nota__grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--atl-s7);
  align-items: start;
}
.atl-pdp-nota__copy h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 2rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin: var(--atl-s2) 0 var(--atl-s3);
}
.atl-pdp-nota__copy p { color: var(--atl-ink-2); }
.atl-pdp-nota__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s4);
}
.atl-pdp-nota__item {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s4) var(--atl-s5);
  display: flex;
  flex-direction: column;
  gap: var(--atl-s2);
}
.atl-pdp-nota__num {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 36px;
  line-height: 1;
  color: var(--atl-accent);
  letter-spacing: .04em;
}
.atl-pdp-nota__item h3 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.atl-pdp-nota__item p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--atl-ink-2);
  margin: 0;
}

/* PDP description */
.atl-pdp-desc { padding: var(--atl-s8) 0; border-bottom: 1px solid var(--atl-line); }
.atl-pdp-desc__grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--atl-s7);
}
.atl-pdp-desc__intro h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 24px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: var(--atl-s2) 0 var(--atl-s3);
}
.atl-pdp-desc__src {
  color: var(--atl-mute);
  font-size: 13.5px;
  line-height: 1.6;
}
.atl-pdp-desc__body p {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  margin-bottom: var(--atl-s3);
}

/* PDP related */
.atl-pdp-rel { padding: var(--atl-s7) 0 var(--atl-s8); }
.atl-pdp-rel__h { margin-bottom: var(--atl-s5); }
.atl-pdp-rel__h h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.6rem, 2.4vw, 2rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-top: var(--atl-s2);
}
.atl-pdp-rel__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--atl-s4);
}

/* ===== Cart / Checkout / Order pages ================================ */

.atl-page {
  padding: var(--atl-s7) 0 var(--atl-s8);
  min-height: 60vh;
}
.atl-page__h {
  display: flex;
  flex-direction: column;
  gap: var(--atl-s2);
  margin-bottom: var(--atl-s6);
  border-bottom: 1px solid var(--atl-line);
  padding-bottom: var(--atl-s4);
}
.atl-page__h h1 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 2.8rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.05;
}
.atl-page__lede {
  color: var(--atl-ink-2);
  font-size: var(--atl-fs-base);
  max-width: 70ch;
  line-height: 1.65;
}

.atl-page__grid {
  display: grid;
  grid-template-columns: 1.4fr 0.6fr;
  gap: var(--atl-s7);
  align-items: start;
}

.atl-cart-row {
  display: grid;
  grid-template-columns: 90px 1fr auto auto auto;
  gap: var(--atl-s4);
  align-items: center;
  padding: var(--atl-s3) 0;
  border-bottom: 1px solid var(--atl-line);
}
.atl-cart-row__img {
  width: 90px; height: 90px;
  object-fit: cover;
  border: 1px solid var(--atl-line);
  background: var(--atl-bg-2);
}
.atl-cart-row__name a {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  text-decoration: none;
  line-height: 1.2;
}
.atl-cart-row__name a:hover { color: var(--atl-accent); }
.atl-cart-row__plat { font-family: var(--atl-mono); font-size: 11px; color: var(--atl-mute); letter-spacing: .1em; text-transform: uppercase; }

.atl-cart-row__qty input {
  width: 56px; padding: 6px 8px; text-align: center;
  background: var(--atl-bg-2); color: var(--atl-ink);
  border: 1px solid var(--atl-line-2); font-family: var(--atl-mono); font-size: 13px;
}
.atl-cart-row__price {
  font-family: var(--atl-mono); font-size: 14px; font-weight: 700; color: var(--atl-accent);
  text-align: right; min-width: 80px;
}
.atl-cart-row__del {
  background: transparent; border: 1px solid var(--atl-line-2); color: var(--atl-warn);
  padding: 6px 10px; font-family: var(--atl-mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase;
}
.atl-cart-row__del:hover { background: var(--atl-warn); color: var(--atl-ink); border-color: var(--atl-warn); }

.atl-summary {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s5);
  position: sticky; top: var(--atl-s4);
}
.atl-summary h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s4);
}
.atl-summary__row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--atl-line);
  font-family: var(--atl-mono);
  font-size: 13px;
  color: var(--atl-ink-2);
}
.atl-summary__row b { color: var(--atl-ink); }
.atl-summary__row--total {
  font-family: var(--atl-display);
  font-size: 22px;
  letter-spacing: .04em;
  color: var(--atl-accent);
  border-bottom: 0;
  padding-top: var(--atl-s3);
}
.atl-summary__cta { width: 100%; margin-top: var(--atl-s4); }

.atl-empty {
  text-align: center;
  padding: var(--atl-s8) var(--atl-s5);
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink-2);
}
.atl-empty h2 {
  font-family: var(--atl-display); font-weight: 700;
  font-size: 24px; letter-spacing: .04em; text-transform: uppercase;
  margin-bottom: var(--atl-s3); color: var(--atl-ink);
}

/* Form fields */
.atl-form { display: grid; gap: var(--atl-s4); }
.atl-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--atl-s3); }
.atl-form label { font-family: var(--atl-mono); font-size: 11px; color: var(--atl-mute); text-transform: uppercase; letter-spacing: .12em; }
.atl-form input,
.atl-form select,
.atl-form textarea {
  background: var(--atl-bg-2); color: var(--atl-ink);
  border: 1px solid var(--atl-line-2);
  padding: 12px 14px;
  font-family: var(--atl-body);
  font-size: 14px;
  width: 100%;
}
.atl-form input:focus,
.atl-form select:focus,
.atl-form textarea:focus { border-color: var(--atl-accent); outline: 0; }
.atl-form fieldset {
  border: 0; padding: 0; margin: 0;
  display: grid; gap: var(--atl-s4);
}
.atl-form legend {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s2);
  padding-bottom: var(--atl-s2);
  border-bottom: 1px solid var(--atl-line);
  width: 100%;
}
.atl-form-radio {
  display: flex;
  flex-direction: column;
  gap: var(--atl-s2);
}
.atl-form-radio label {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  text-transform: none;
  letter-spacing: 0;
  color: var(--atl-ink);
  font-size: 13px;
  font-family: var(--atl-body);
  cursor: pointer;
}
.atl-form-radio label:has(input:checked) { border-color: var(--atl-accent); }

/* ===== Order confirmed (success) ================================== */

.atl-success {
  padding: var(--atl-s8) 0;
  background:
    linear-gradient(180deg, var(--atl-bg) 0%, var(--atl-bg-2) 100%);
}
.atl-success__hero {
  text-align: center;
  margin-bottom: var(--atl-s7);
  padding-bottom: var(--atl-s5);
  border-bottom: 1px solid var(--atl-line);
}
.atl-success__seal {
  display: inline-block;
  border: 2px solid var(--atl-accent);
  color: var(--atl-accent);
  padding: 14px 28px;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .2em;
  text-transform: uppercase;
  margin-bottom: var(--atl-s4);
}
.atl-success__h {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
}
.atl-success__h em { color: var(--atl-accent); font-style: italic; }
.atl-success__sub {
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-ink-2);
  margin-top: var(--atl-s3);
}
.atl-success__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--atl-s7);
}
.atl-success__steps {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--atl-s3);
  margin-top: var(--atl-s5);
}
.atl-success__steps li {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s4);
}
.atl-success__steps b {
  font-family: var(--atl-display); font-weight: 700;
  font-size: 14px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--atl-accent); display: block; margin-bottom: 6px;
}
.atl-success__steps p { font-size: 13.5px; color: var(--atl-ink-2); margin: 0; }

/* ===== Static editorial pages ====================================== */

.atl-doc {
  padding: var(--atl-s7) 0 var(--atl-s8);
}
.atl-doc__h {
  margin-bottom: var(--atl-s6);
  border-bottom: 1px solid var(--atl-line);
  padding-bottom: var(--atl-s4);
}
.atl-doc__h h1 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 2.8rem);
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.05;
  margin-top: var(--atl-s2);
}
.atl-doc__body {
  display: grid;
  grid-template-columns: 0.8fr 1.6fr;
  gap: var(--atl-s7);
  align-items: start;
}
.atl-doc__toc {
  position: sticky; top: var(--atl-s4);
  border-left: 2px solid var(--atl-accent);
  padding-left: var(--atl-s4);
}
.atl-doc__toc h3 {
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s3);
}
.atl-doc__toc ol { display: flex; flex-direction: column; gap: 6px; counter-reset: doctoc; }
.atl-doc__toc li { counter-increment: doctoc; }
.atl-doc__toc a {
  display: block;
  padding-left: 28px;
  position: relative;
  color: var(--atl-ink-2);
  text-decoration: none;
  font-size: 13.5px;
}
.atl-doc__toc a::before {
  content: counter(doctoc, decimal-leading-zero);
  position: absolute; left: 0;
  font-family: var(--atl-mono); font-size: 11px; color: var(--atl-mute);
  letter-spacing: .12em;
}
.atl-doc__toc a:hover { color: var(--atl-accent); }
.atl-doc__art h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: var(--atl-s5) 0 var(--atl-s3);
  color: var(--atl-accent);
}
.atl-doc__art h2:first-child { margin-top: 0; }
.atl-doc__art p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--atl-ink);
  margin-bottom: var(--atl-s4);
}
.atl-doc__art ul { list-style: disc; padding-left: 24px; margin-bottom: var(--atl-s4); }
.atl-doc__art ul li { font-size: 14.5px; line-height: 1.65; color: var(--atl-ink-2); margin-bottom: 6px; }
.atl-doc__art strong { color: var(--atl-accent); }

/* ===== Diario (news) =============================================== */

.atl-news-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--atl-s5);
}
.atl-news-card {
  display: grid;
  grid-template-rows: auto 1fr;
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  text-decoration: none;
  color: var(--atl-ink);
}
.atl-news-card:hover { border-color: var(--atl-accent); }
.atl-news-card__media {
  display: block;
  aspect-ratio: 16 / 9;
  background: var(--atl-bg-2);
  overflow: hidden;
}
.atl-news-card__media img { width: 100%; height: 100%; object-fit: cover; }
.atl-news-card__body { padding: var(--atl-s5); }
.atl-news-card__date {
  font-family: var(--atl-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--atl-accent); display: block;
  margin-bottom: var(--atl-s3);
}
.atl-news-card__name {
  font-family: var(--atl-display); font-weight: 700;
  font-size: 24px; letter-spacing: .04em; text-transform: uppercase;
  line-height: 1.15; margin-bottom: var(--atl-s3);
}
.atl-news-card__lede { font-size: 14.5px; color: var(--atl-ink-2); line-height: 1.6; }

/* ===== HOME · hero (selling-pillars + featured) — overrides legacy ===== */

.atl-hero {
  position: relative;
  padding: var(--atl-s8) 0 var(--atl-s7);
  border-bottom: 1px solid var(--atl-line);
}
.atl-hero__row {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: var(--atl-s7);
  align-items: start;
}
.atl-hero__copy {
  max-width: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.atl-hero__h {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.9rem, 3.4vw, 2.9rem);
  line-height: 1.08;
  letter-spacing: 0;
  text-transform: none;
  color: var(--atl-ink);
  margin: var(--atl-s2) 0 var(--atl-s4);
}
.atl-hero__h em {
  font-style: italic;
  color: var(--atl-accent);
  font-family: var(--atl-display);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
}
.atl-hero .atl-hero__lede {
  font-size: 16.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  margin-bottom: var(--atl-s5);
  max-width: 60ch;
}
.atl-hero .atl-hero__cta { margin-bottom: var(--atl-s6); }

/* 4-pillar trust grid — generic e-commerce, no narrative */
.atl-hero__pillars {
  list-style: none;
  margin: 0;
  padding: var(--atl-s5) 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s4) var(--atl-s5);
  border-top: 1px solid var(--atl-line);
}
.atl-hero__pillars > li {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: var(--atl-s3);
  row-gap: 4px;
  align-items: baseline;
}
.atl-hero__pillar-no {
  grid-row: 1 / span 2;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 26px;
  line-height: 1;
  color: var(--atl-accent);
  letter-spacing: -.01em;
  align-self: start;
  padding-top: 2px;
}
.atl-hero__pillars b {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
}
.atl-hero__pillars span {
  font-family: var(--atl-sans);
  font-size: 13px;
  line-height: 1.55;
  color: var(--atl-ink-2);
}

/* Featured-product card on the right side of hero */
.atl-hero__feat-card {
  display: block;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-paper);
  transition: border-color .15s, transform .15s;
}
.atl-hero__feat-card:hover {
  border-color: var(--atl-accent);
  transform: translateY(-2px);
}
.atl-hero__feat-card:hover .atl-hero__feat-name { color: var(--atl-accent); }
.atl-hero__feat-card:hover .atl-hero__feat-media img { transform: scale(1.03); }
.atl-hero__feat-media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--atl-bg-2);
}
.atl-hero__feat-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.atl-hero__feat-platform {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--atl-bg);
  color: var(--atl-accent);
  border: 1px solid var(--atl-accent);
  padding: 5px 9px;
  font-family: var(--atl-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-hero__feat-body {
  padding: var(--atl-s4);
  border-top: 1px solid var(--atl-line-2);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.atl-hero__feat-kicker { margin-bottom: 2px; }
.atl-hero__feat-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--atl-ink);
  transition: color .15s;
  margin: 0;
}
.atl-hero__feat-blurb {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--atl-ink-2);
  margin: 0;
}
.atl-hero__feat-spec {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px var(--atl-s3);
  margin: var(--atl-s3) 0 var(--atl-s2);
  padding: var(--atl-s3) 0;
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
}
.atl-hero__feat-spec > div { display: flex; flex-direction: column; gap: 3px; }
.atl-hero__feat-spec dt {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-hero__feat-spec dd {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 12px;
  color: var(--atl-ink);
  font-weight: 600;
}
.atl-hero__feat-foot {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.atl-hero__feat-price {
  font-family: var(--atl-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--atl-accent);
}
.atl-hero__feat-cta {
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  display: inline-block;
  margin-top: var(--atl-s3);
}
.atl-hero__feat-add {
  appearance: none;
  border: 0;
  background: var(--atl-accent);
  color: var(--atl-bg);
  font-family: var(--atl-mono);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 10px 14px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.atl-hero__feat-add:hover { background: #d9b56e; }
.atl-hero__feat-add:disabled { background: #5fa07a; color: var(--atl-bg); cursor: default; }

/* Slider card footer: add-to-cart + open-link */
.atl-slider__card-foot { flex-wrap: wrap; gap: var(--atl-s2) var(--atl-s3); }
.atl-slider__card-open {
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--atl-mute);
  text-decoration: none;
  flex: 1 0 100%;
  text-align: right;
}
.atl-slider__card-open:hover { color: var(--atl-accent); }

/* ============================================================ *
 * QUARTIERI INDEX · atypical illustrated vertical index       *
 * ============================================================ */

.atl-qua { padding: var(--atl-s7) 0 var(--atl-s8); }

.atl-qua__h {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s7);
  align-items: end;
  padding-bottom: var(--atl-s6);
  border-bottom: 1px solid var(--atl-line-2);
  margin-bottom: var(--atl-s7);
}
.atl-qua__h-title {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.05;
  letter-spacing: 0;
  color: var(--atl-ink);
  margin: var(--atl-s2) 0 0;
}
.atl-qua__h-title em { font-style: italic; color: var(--atl-accent); font-weight: 600; }
.atl-qua__h-lede {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  margin: 0 0 var(--atl-s4);
  max-width: 60ch;
}
.atl-qua__h-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--atl-s4);
  border-top: 1px solid var(--atl-line);
  padding-top: var(--atl-s4);
  margin: 0;
}
.atl-qua__h-meta > div { display: flex; flex-direction: column; gap: 2px; }
.atl-qua__h-meta dt {
  font-family: var(--atl-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-mute);
}
.atl-qua__h-meta dd {
  margin: 0;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--atl-accent);
  letter-spacing: 0;
}

/* === Vertical illustrated rows === */
.atl-qua__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.atl-qua__row {
  position: relative;
  display: grid;
  grid-template-columns: 80px 1fr 320px;
  gap: var(--atl-s5);
  align-items: center;
  padding: var(--atl-s6) 0;
  border-bottom: 1px solid var(--atl-line);
  transition: background .2s;
}
.atl-qua__row:hover { background: rgba(200, 160, 98, .04); }
.atl-qua__row--left { grid-template-columns: 80px 320px 1fr; }
.atl-qua__row--left .atl-qua__row-stack { grid-column: 2; grid-row: 1; }
.atl-qua__row--left .atl-qua__row-copy  { grid-column: 3; grid-row: 1; }
.atl-qua__row-link {
  position: absolute;
  inset: 0;
  z-index: 2;
}
.atl-qua__row-no {
  font-family: var(--atl-display);
  font-weight: 700;
  font-style: italic;
  font-size: clamp(3rem, 5vw, 4.8rem);
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--atl-accent);
  opacity: .55;
  align-self: start;
  padding-top: 4px;
}
.atl-qua__row-copy { display: flex; flex-direction: column; gap: var(--atl-s3); position: relative; z-index: 1; }
.atl-qua__row-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 2.6vw, 2.1rem);
  letter-spacing: .02em;
  color: var(--atl-ink);
  margin: 0;
  line-height: 1.15;
  transition: color .15s;
}
.atl-qua__row:hover .atl-qua__row-name { color: var(--atl-accent); }
.atl-qua__row-blurb {
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  margin: 0;
  max-width: 55ch;
}
.atl-qua__row-stats {
  display: flex;
  gap: var(--atl-s4);
  flex-wrap: wrap;
  margin: 0;
  padding: 10px 0 0;
  border-top: 1px solid var(--atl-line);
}
.atl-qua__row-stats > div { display: flex; flex-direction: column; gap: 2px; }
.atl-qua__row-stats dt {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--atl-mute);
}
.atl-qua__row-stats dd {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 12.5px;
  font-weight: 700;
  color: var(--atl-ink);
  letter-spacing: .04em;
}
.atl-qua__row-cta {
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--atl-accent);
  padding-top: var(--atl-s2);
}

/* Staggered cover stack */
.atl-qua__row-stack {
  position: relative;
  height: 240px;
  z-index: 1;
}
.atl-qua__row-cover {
  position: absolute;
  margin: 0;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  overflow: hidden;
  transition: transform .25s ease;
  width: 150px;
}
.atl-qua__row-cover img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
.atl-qua__row-cover figcaption { display: none; }

.atl-qua__row-cover--0 {
  top: 0;
  left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  z-index: 3;
}
.atl-qua__row-cover--1 {
  top: 12px;
  left: 0;
  transform: rotate(-7deg);
  z-index: 2;
  width: 130px;
  opacity: .92;
}
.atl-qua__row-cover--2 {
  top: 12px;
  right: 0;
  transform: rotate(5deg);
  z-index: 2;
  width: 130px;
  opacity: .92;
}
.atl-qua__row:hover .atl-qua__row-cover--0 { transform: translateX(-50%) rotate(-1deg) translateY(-4px); }
.atl-qua__row:hover .atl-qua__row-cover--1 { transform: rotate(-9deg) translateX(-6px); }
.atl-qua__row:hover .atl-qua__row-cover--2 { transform: rotate(7deg) translateX(6px); }

.atl-qua__foot {
  margin-top: var(--atl-s6);
  padding-top: var(--atl-s5);
  border-top: 1px solid var(--atl-line-2);
}
.atl-qua__foot p {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  margin: 0;
  max-width: 70ch;
}
.atl-qua__foot a { color: var(--atl-accent); }


/* ============================================================ *
 * GENRE LANDING · atypical "schede di registro" view          *
 * ============================================================ */

/* Header */
.atl-gen { padding: var(--atl-s5) 0 var(--atl-s6); border-bottom: 1px solid var(--atl-line); }
.atl-gen__h {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-areas:
    "left  cover"
    "stats stats";
  gap: var(--atl-s5);
  margin-top: var(--atl-s4);
}
.atl-gen__h-l    { grid-area: left; }
.atl-gen__h-cover {
  grid-area: cover;
  display: block;
  position: relative;
  border: 1px solid var(--atl-line-2);
  overflow: hidden;
  background: var(--atl-bg-2);
  max-width: 320px;
  justify-self: end;
}
.atl-gen__h-cover img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
.atl-gen__h-cover-tag {
  position: absolute;
  bottom: 10px; left: 10px;
  background: var(--atl-bg);
  color: var(--atl-accent);
  border: 1px solid var(--atl-accent);
  padding: 4px 8px;
  font-family: var(--atl-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-gen__h-title {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  line-height: 1.05;
  letter-spacing: -.01em;
  color: var(--atl-ink);
  margin: var(--atl-s2) 0 var(--atl-s4);
}
.atl-gen__h-lede {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  max-width: 60ch;
  margin: 0;
}
.atl-gen__h-lede strong { color: var(--atl-accent); font-weight: 700; }
.atl-gen__h-stats {
  grid-area: stats;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--atl-s4);
  margin: 0;
  padding-top: var(--atl-s4);
  border-top: 1px solid var(--atl-line);
}
.atl-gen__h-stats > div { display: flex; flex-direction: column; gap: 2px; }
.atl-gen__h-stats dt {
  font-family: var(--atl-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-mute);
}
.atl-gen__h-stats dd {
  margin: 0;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--atl-accent);
  letter-spacing: 0;
}
.atl-gen__pl {
  list-style: none;
  margin: var(--atl-s5) 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--atl-s2);
}
.atl-gen__pl li {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-bg-2);
  font-family: var(--atl-mono);
  font-size: 11.5px;
}
.atl-gen__pl b { color: var(--atl-accent); font-weight: 700; }
.atl-gen__pl span { color: var(--atl-mute); font-size: 10.5px; letter-spacing: .04em; }

/* List w/ sticky sidebar */
.atl-genl { padding: var(--atl-s6) 0 var(--atl-s8); }
.atl-genl__wrap {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--atl-s6);
  align-items: start;
}
.atl-genl__side { position: sticky; top: 96px; display: flex; flex-direction: column; gap: var(--atl-s5); }
.atl-genl__side-block { padding-bottom: var(--atl-s4); border-bottom: 1px solid var(--atl-line); }
.atl-genl__side-block:last-child { border-bottom: 0; }
.atl-genl__side-block .atl-kicker { display: block; margin-bottom: var(--atl-s2); }
.atl-genl__side-state {
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  margin: 0;
}
.atl-genl__side-state b { color: var(--atl-accent); font-weight: 700; }

.atl-genl__side-sort {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.atl-genl__side-sort li { border-top: 1px solid var(--atl-line); }
.atl-genl__side-sort li:first-child { border-top: 0; }
.atl-genl__side-sort label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  font-family: var(--atl-body);
  font-size: 13px;
  color: var(--atl-ink-2);
  cursor: pointer;
}
.atl-genl__side-sort input[type="radio"] {
  appearance: none;
  width: 14px; height: 14px;
  border: 1.5px solid var(--atl-line-2);
  border-radius: 50%;
  position: relative;
  cursor: pointer;
}
.atl-genl__side-sort input[type="radio"]:checked { border-color: var(--atl-accent); }
.atl-genl__side-sort input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  inset: 2px;
  background: var(--atl-accent);
  border-radius: 50%;
}
.atl-genl__side-sort input[type="radio"]:checked + span { color: var(--atl-accent); font-weight: 600; }

.atl-genl__side-cross {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.atl-genl__side-cross li { border-top: 1px solid var(--atl-line); }
.atl-genl__side-cross li:first-child { border-top: 0; }
.atl-genl__side-cross a {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-family: var(--atl-body);
  font-size: 13px;
  color: var(--atl-ink-2);
  text-decoration: none;
}
.atl-genl__side-cross a:hover { color: var(--atl-accent); }
.atl-genl__side-cross b { color: var(--atl-accent); font-family: var(--atl-mono); font-weight: 700; }
.atl-genl__side-cross-all {
  display: inline-block;
  margin-top: var(--atl-s3);
  font-family: var(--atl-mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--atl-accent);
  text-decoration: none;
}

/* === Vertical product rows === */
.atl-genl__rows { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.atl-genl__row {
  position: relative;
  display: grid;
  grid-template-columns: 36px 200px 1fr 200px;
  gap: var(--atl-s5);
  align-items: stretch;
  padding: var(--atl-s5) 0;
  border-bottom: 1px solid var(--atl-line);
  transition: background .15s;
}
.atl-genl__row:hover { background: rgba(200, 160, 98, .03); }
.atl-genl__row-link { position: absolute; inset: 0; z-index: 1; }
.atl-genl__row-i {
  font-family: var(--atl-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--atl-mute);
  letter-spacing: .14em;
  padding-top: 4px;
}
.atl-genl__row-cover {
  margin: 0;
  position: relative;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  overflow: hidden;
  align-self: start;
}
.atl-genl__row-cover img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  transition: transform .3s ease;
}
.atl-genl__row:hover .atl-genl__row-cover img { transform: scale(1.04); }
.atl-genl__row-cover figcaption {
  position: absolute;
  top: 8px; left: 8px;
  background: var(--atl-warn);
  color: var(--atl-ink);
  font-family: var(--atl-mono);
  font-size: 10.5px;
  font-weight: 700;
  padding: 3px 7px;
  letter-spacing: .04em;
}

.atl-genl__row-body { display: flex; flex-direction: column; gap: var(--atl-s2); position: relative; z-index: 2; pointer-events: none; }
.atl-genl__row-head {
  display: flex;
  justify-content: space-between;
  gap: var(--atl-s3);
  font-family: var(--atl-mono);
  font-size: 10.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.atl-genl__row-no { color: var(--atl-mute); }
.atl-genl__row-depth {
  padding: 2px 8px;
  border: 1px solid var(--atl-line-2);
  font-weight: 700;
  letter-spacing: .14em;
}
.atl-genl__row-depth--superficie { color: #5fa07a; border-color: #5fa07a; }
.atl-genl__row-depth--mediomare  { color: var(--atl-accent); border-color: var(--atl-accent); }
.atl-genl__row-depth--fondale    { color: #c97f4a; border-color: #c97f4a; }
.atl-genl__row-depth--abisso     { color: #c34a4a; border-color: #c34a4a; }

.atl-genl__row-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  letter-spacing: .02em;
  color: var(--atl-ink);
  margin: 0;
  line-height: 1.2;
  transition: color .15s;
}
.atl-genl__row:hover .atl-genl__row-name { color: var(--atl-accent); }
.atl-genl__row-desc {
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  margin: 0;
  max-width: 60ch;
}
.atl-genl__row-spec {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 4px var(--atl-s4);
  margin: var(--atl-s2) 0 0;
  padding-top: var(--atl-s2);
  border-top: 1px dashed var(--atl-line);
}
.atl-genl__row-spec > div { display: flex; flex-direction: column; gap: 2px; }
.atl-genl__row-spec dt {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--atl-mute);
}
.atl-genl__row-spec dd {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 11.5px;
  color: var(--atl-ink);
  font-weight: 600;
}

.atl-genl__row-buy {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
  justify-content: center;
  padding-left: var(--atl-s4);
  border-left: 1px solid var(--atl-line);
  position: relative;
  z-index: 2;
}
.atl-genl__row-price {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 26px;
  letter-spacing: 0;
  color: var(--atl-accent);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.atl-genl__row-price s {
  color: var(--atl-mute);
  font-family: var(--atl-mono);
  font-size: 13px;
  font-weight: 400;
}
.atl-genl__row-add {
  background: var(--atl-accent);
  color: var(--atl-bg);
  border: 0;
  padding: 12px 14px;
  font-family: var(--atl-mono);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
  pointer-events: auto;
  border-radius: 0;
  transition: background .15s;
}
.atl-genl__row-add:hover { background: var(--atl-accent-2); }
.atl-genl__row-add:disabled { background: #4caf6d; }
.atl-genl__row-open {
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
  text-align: center;
  padding: 6px 0;
}
.atl-genl__row:hover .atl-genl__row-open { color: var(--atl-accent); }

.atl-genl__empty {
  background: var(--atl-paper);
  border: 1px dashed var(--atl-line-2);
  padding: var(--atl-s8) var(--atl-s5);
  text-align: center;
}
.atl-genl__empty h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--atl-ink);
  margin: 0 0 var(--atl-s2);
}
.atl-genl__empty p { font-size: 14px; color: var(--atl-ink-2); margin: 0; }
.atl-genl__empty a { color: var(--atl-accent); }


/* ============================================================ *
 * SPORTELLO · counter-window contact page                      *
 * ============================================================ */

.atl-sport { padding: var(--atl-s7) 0 var(--atl-s8); }

/* === Top board: brass-engraved counter sign === */
.atl-sport__board {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--atl-s5);
  align-items: stretch;
  padding: var(--atl-s5) var(--atl-s6);
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  border-top: 4px solid var(--atl-accent);
  position: relative;
  margin-bottom: var(--atl-s6);
}
.atl-sport__board::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed var(--atl-line);
  pointer-events: none;
}
.atl-sport__board-sign { position: relative; z-index: 1; }
.atl-sport__board-name {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  color: var(--atl-accent);
  letter-spacing: .04em;
  margin: var(--atl-s2) 0 var(--atl-s3);
}
.atl-sport__board-sub {
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  max-width: 50ch;
}

/* === Open/closed lamp box === */
.atl-sport__board-state {
  align-self: start;
  justify-self: end;
  background: var(--atl-bg);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s4) var(--atl-s5);
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 280px;
  position: relative;
  z-index: 1;
}
.atl-sport__lamp {
  display: inline-block;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--atl-warn);
  box-shadow: 0 0 8px rgba(220, 130, 60, .5);
  margin-bottom: 6px;
}
.atl-sport__board-state[data-open="yes"] .atl-sport__lamp {
  background: #4caf6d;
  box-shadow: 0 0 12px rgba(76, 175, 109, .6);
}
.atl-sport__state-lab {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 16px;
  color: var(--atl-ink);
  letter-spacing: .02em;
}
.atl-sport__state-sub {
  font-family: var(--atl-mono);
  font-size: 11.5px;
  color: var(--atl-mute);
  line-height: 1.5;
}

/* === Hours table === */
.atl-sport__hours {
  grid-column: 1 / -1;
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--atl-s4);
  font-family: var(--atl-mono);
  font-size: 12.5px;
  background: var(--atl-bg);
  border: 1px solid var(--atl-line);
  position: relative;
  z-index: 1;
}
.atl-sport__hours thead th {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-mute);
  text-align: left;
  padding: 8px 14px;
  border-bottom: 1px solid var(--atl-line);
  font-weight: 700;
}
.atl-sport__hours tbody th {
  text-align: left;
  padding: 9px 14px;
  font-weight: 700;
  color: var(--atl-ink);
  letter-spacing: .04em;
  width: 130px;
}
.atl-sport__hours tbody td {
  padding: 9px 14px;
  color: var(--atl-ink-2);
  border-top: 1px solid var(--atl-line);
}
.atl-sport__hours tbody th { border-top: 1px solid var(--atl-line); }
.atl-sport__hours .closed { color: var(--atl-mute); font-style: italic; }
.atl-sport__hours .is-today {
  background: rgba(200, 160, 98, .07);
}
.atl-sport__hours .is-today th,
.atl-sport__hours .is-today td { color: var(--atl-accent); font-weight: 700; }

/* === Tickets (4 channels) === */
.atl-sport__tickets {
  list-style: none;
  margin: 0 0 var(--atl-s7);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--atl-s4);
}
.atl-sport__ticket {
  background: var(--atl-paper);
  color: var(--atl-ink);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s5);
  position: relative;
}
.atl-sport__ticket::after {
  /* perforated edge — like a service ticket */
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 24px;
  width: 0;
  border-left: 1px dashed var(--atl-line);
}
.atl-sport__ticket header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--atl-line);
  padding-bottom: 10px;
  margin-bottom: var(--atl-s3);
  font-family: var(--atl-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.atl-sport__ticket-no { color: var(--atl-accent); font-weight: 700; }
.atl-sport__ticket-cat { color: var(--atl-mute); }
.atl-sport__ticket h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  margin: 0 0 var(--atl-s3);
  letter-spacing: .02em;
  word-break: break-word;
}
.atl-sport__ticket-name-sm { font-size: 17px !important; line-height: 1.2; }
.atl-sport__ticket h2 a { color: var(--atl-ink); text-decoration: none; border-bottom: 1px solid var(--atl-accent); }
.atl-sport__ticket h2 a:hover { color: var(--atl-accent); }
.atl-sport__ticket p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--atl-ink-2);
  margin: 0 0 var(--atl-s3);
}
.atl-sport__ticket dl {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px var(--atl-s3);
  border-top: 1px solid var(--atl-line);
  padding-top: 10px;
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 12px;
}
.atl-sport__ticket dl > div { display: flex; flex-direction: column; gap: 2px; }
.atl-sport__ticket dt {
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-sport__ticket dd { margin: 0; color: var(--atl-ink); font-weight: 600; }
.atl-sport__ticket dd a { color: var(--atl-accent); text-decoration: none; }

/* === Request slip (form) === */
.atl-sport__slip {
  background: #f7eed8;
  color: #2a1f0a;
  padding: var(--atl-s7) var(--atl-s7) var(--atl-s6);
  border: 1px solid #d8c69a;
  position: relative;
}
.atl-sport__slip::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(0,0,0,.13);
  pointer-events: none;
}
.atl-sport__slip-head { margin-bottom: var(--atl-s5); position: relative; }
.atl-sport__slip-head .atl-kicker { color: #8b5a13; }
.atl-sport__slip-head h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  color: #1a140a;
  margin: var(--atl-s2) 0 var(--atl-s3);
}
.atl-sport__slip-no { font-family: var(--atl-mono); font-size: .7em; color: #8b5a13; }
.atl-sport__slip-head p {
  font-size: 14.5px;
  line-height: 1.7;
  color: #3d3220;
  max-width: 65ch;
}
.atl-sport__form { position: relative; }
.atl-sport__fields {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s4);
}
.atl-sport__fields > li:nth-child(3),
.atl-sport__fields > li.atl-sport__field-msg,
.atl-sport__fields > li:nth-child(4):not(.atl-sport__field-msg) { grid-column: 1 / -1; }
.atl-sport__fields label {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 14.5px;
  color: #1a140a;
  margin-bottom: 6px;
}
.atl-sport__fields label span {
  font-family: var(--atl-mono);
  font-size: 10px;
  font-weight: 700;
  color: #8b5a13;
  letter-spacing: .14em;
  background: rgba(139, 90, 19, .12);
  padding: 2px 6px;
}
.atl-sport__fields label em { font-style: normal; color: #b03020; }
.atl-sport__fields input,
.atl-sport__fields select,
.atl-sport__fields textarea {
  display: block;
  width: 100%;
  background: #fff8e8;
  border: 1px solid #c8b078;
  border-bottom: 2px solid #8b5a13;
  color: #1a140a;
  padding: 12px 14px;
  font-family: var(--atl-body);
  font-size: 14px;
  border-radius: 0;
}
.atl-sport__fields input:focus,
.atl-sport__fields select:focus,
.atl-sport__fields textarea:focus {
  outline: 0;
  border-bottom-color: var(--atl-accent);
  background: #fff;
}
.atl-sport__fields textarea { resize: vertical; min-height: 140px; }

.atl-sport__slip-foot {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--atl-s5);
  align-items: center;
  margin-top: var(--atl-s5);
  padding-top: var(--atl-s4);
  border-top: 1px solid rgba(0,0,0,.18);
}
.atl-sport__slip-fineprint {
  font-size: 12px;
  line-height: 1.55;
  color: #6e5524;
  margin: 0;
  max-width: 50ch;
}
.atl-sport__slip-fineprint a { color: #8b5a13; }


/* ============================================================ *
 * MODULO · order-form (chiudi-ordine) carbon-copy aesthetic   *
 * ============================================================ */

.atl-mod { padding: var(--atl-s6) 0 var(--atl-s8); }

.atl-mod__head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--atl-s5);
  padding: var(--atl-s5) var(--atl-s6);
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line-2);
  border-top: 4px solid var(--atl-accent);
  margin-bottom: var(--atl-s6);
  align-items: start;
}
.atl-mod__head-mark { color: var(--atl-accent); padding-top: 4px; }
.atl-mod__head-copy h1 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.7rem, 2.8vw, 2.2rem);
  letter-spacing: .02em;
  color: var(--atl-ink);
  margin: var(--atl-s2) 0 var(--atl-s3);
  line-height: 1.1;
}
.atl-mod__head-lede {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  max-width: 60ch;
}
.atl-mod__head-lede em { font-style: italic; color: var(--atl-accent); }
.atl-mod__head-stamp {
  background: var(--atl-bg);
  border: 1px solid var(--atl-accent);
  padding: var(--atl-s3) var(--atl-s4);
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 220px;
  margin: 0;
}
.atl-mod__head-stamp > div { display: flex; justify-content: space-between; gap: 8px; }
.atl-mod__head-stamp dt {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-mod__head-stamp dd {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--atl-accent);
  letter-spacing: .04em;
}

/* alerts */
.atl-mod__alert {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s4) var(--atl-s5);
  margin-bottom: var(--atl-s5);
}
.atl-mod__alert h2 {
  font-family: var(--atl-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--atl-ink);
  margin: 0 0 6px;
}
.atl-mod__alert p { font-size: 14px; color: var(--atl-ink-2); margin: 0; }
.atl-mod__alert--warn { border-color: var(--atl-warn); }
.atl-mod__alert--err  { border-color: #c34a4a; }

/* === Form layout: main + slip === */
.atl-mod__form {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: var(--atl-s6);
  align-items: start;
}
.atl-mod__form-main { display: flex; flex-direction: column; gap: var(--atl-s5); }

/* fieldsets as paper sections */
.atl-mod__fs {
  border: 1px solid var(--atl-line-2);
  background: var(--atl-paper);
  padding: var(--atl-s5);
  margin: 0;
  position: relative;
}
.atl-mod__fs legend {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 8px;
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
}
.atl-mod__fs-no {
  display: inline-grid;
  place-items: center;
  width: 26px; height: 26px;
  background: var(--atl-accent);
  color: var(--atl-bg);
  font-family: var(--atl-display);
  font-size: 13px;
  font-weight: 700;
}
.atl-mod__fields {
  list-style: none;
  margin: var(--atl-s3) 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s3) var(--atl-s4);
}
.atl-mod__field-wide { grid-column: 1 / -1; }
.atl-mod__fields label {
  display: flex;
  gap: 8px;
  align-items: baseline;
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  margin-bottom: 6px;
}
.atl-mod__fields label span {
  font-family: var(--atl-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .14em;
  color: var(--atl-bg);
  background: var(--atl-accent);
  padding: 2px 6px;
}
.atl-mod__fields label em { font-style: normal; color: var(--atl-warn); }
.atl-mod__fields input,
.atl-mod__fields select,
.atl-mod__fields textarea {
  display: block;
  width: 100%;
  background: var(--atl-bg);
  color: var(--atl-ink);
  border: 1px solid var(--atl-line);
  border-bottom: 2px solid var(--atl-accent);
  padding: 11px 13px;
  font-family: var(--atl-body);
  font-size: 14px;
  border-radius: 0;
}
.atl-mod__fields input:focus,
.atl-mod__fields select:focus,
.atl-mod__fields textarea:focus {
  outline: 0;
  background: var(--atl-bg-2);
  border-color: var(--atl-accent);
}
.atl-mod__fields textarea { resize: vertical; min-height: 90px; }

/* radios as numbered options */
.atl-mod__radios {
  list-style: none;
  margin: var(--atl-s3) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.atl-mod__radios li { border-top: 1px solid var(--atl-line); }
.atl-mod__radios li:first-child { border-top: 0; }
.atl-mod__radios label {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: var(--atl-s3);
  align-items: center;
  padding: var(--atl-s3) 0;
  cursor: pointer;
}
.atl-mod__radios input[type="radio"] {
  appearance: none;
  width: 18px; height: 18px;
  border: 1.5px solid var(--atl-line-2);
  border-radius: 50%;
  position: relative;
  cursor: pointer;
  background: var(--atl-bg);
}
.atl-mod__radios input[type="radio"]:checked {
  border-color: var(--atl-accent);
}
.atl-mod__radios input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  inset: 3px;
  background: var(--atl-accent);
  border-radius: 50%;
}
.atl-mod__radio-no {
  font-family: var(--atl-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  color: var(--atl-accent);
  min-width: 26px;
}
.atl-mod__radio-body { display: flex; flex-direction: column; gap: 2px; }
.atl-mod__radio-body b {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--atl-ink);
  letter-spacing: .03em;
}
.atl-mod__radio-body span { font-size: 12.5px; color: var(--atl-ink-2); line-height: 1.5; }

/* signature footer */
.atl-mod__sign {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-accent);
  padding: var(--atl-s5);
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--atl-s5);
  align-items: center;
}
.atl-mod__sign-fineprint {
  font-size: 12.5px;
  line-height: 1.65;
  color: var(--atl-mute);
  margin: 0;
}
.atl-mod__sign-fineprint a { color: var(--atl-accent); }
.atl-mod__sign-btn { padding: 18px 22px; font-size: 14px; }

/* === Slip (right column) — calculation paper === */
.atl-mod__slip {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s5);
  position: sticky;
  top: 96px;
  align-self: start;
}
.atl-mod__slip-head { margin-bottom: var(--atl-s4); padding-bottom: var(--atl-s3); border-bottom: 1px solid var(--atl-line); }
.atl-mod__slip-head h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 19px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  margin: 4px 0 0;
}
.atl-mod__slip-list { display: flex; flex-direction: column; gap: 0; max-height: 360px; overflow-y: auto; }
.atl-mod__slip-row {
  display: flex;
  justify-content: space-between;
  gap: var(--atl-s2);
  padding: 8px 0;
  border-bottom: 1px dashed var(--atl-line);
  font-family: var(--atl-mono);
  font-size: 12px;
}
.atl-mod__slip-row-name { color: var(--atl-ink-2); }
.atl-mod__slip-row-amt { color: var(--atl-accent); font-weight: 700; }
.atl-mod__slip-totals { margin: var(--atl-s4) 0 var(--atl-s4); }
.atl-mod__slip-tot-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-family: var(--atl-mono);
  font-size: 13px;
  color: var(--atl-ink-2);
  border-bottom: 1px solid var(--atl-line);
}
.atl-mod__slip-tot-row b { color: var(--atl-ink); }
.atl-mod__slip-tot-row--big {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  border-bottom: 0;
  border-top: 2px solid var(--atl-accent);
  padding: 14px 0 4px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-accent);
}
.atl-mod__slip-note {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 11px;
  line-height: 1.55;
  color: var(--atl-mute);
  letter-spacing: .04em;
}
.atl-mod__slip-note a { color: var(--atl-accent); }
.atl-mod__slip-empty {
  font-family: var(--atl-mono);
  font-size: 12.5px;
  color: var(--atl-mute);
  line-height: 1.6;
  margin: 0;
  padding: var(--atl-s3) 0;
}
.atl-mod__slip-empty a { color: var(--atl-accent); }


/* ============================================================ *
 * BOX · cart as physical shipping box (scatola)               *
 * ============================================================ */

.atl-box { padding: var(--atl-s6) 0 var(--atl-s8); }

/* shipping label header */
.atl-box__label {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--atl-s5);
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  border-left: 6px solid var(--atl-accent);
  padding: var(--atl-s5) var(--atl-s6);
  margin-bottom: var(--atl-s6);
  position: relative;
}
.atl-box__label::after {
  /* corrugated cardboard pattern stripe */
  content: "";
  position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 4px;
  background: repeating-linear-gradient(
    90deg,
    var(--atl-accent) 0 8px,
    transparent 8px 16px
  );
  opacity: .55;
}
.atl-box__label-l h1 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  color: var(--atl-ink);
  margin: var(--atl-s2) 0 var(--atl-s3);
  letter-spacing: .02em;
}
.atl-box__label-lede {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  max-width: 60ch;
  margin: 0;
}
.atl-box__label-r {
  background: var(--atl-bg);
  border: 1px solid var(--atl-line);
  padding: var(--atl-s4);
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0;
}
.atl-box__label-r > div {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--atl-s3);
  align-items: baseline;
  font-family: var(--atl-mono);
  font-size: 12px;
}
.atl-box__label-r dt {
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-mute);
}
.atl-box__label-r dd {
  margin: 0;
  color: var(--atl-ink);
  font-weight: 700;
}

.atl-box__app { min-height: 200px; }

.atl-box__noscript {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s5);
}
.atl-box__noscript h2 { font-family: var(--atl-display); font-size: 20px; margin: 0 0 8px; color: var(--atl-ink); }
.atl-box__noscript p { font-size: 14px; line-height: 1.7; color: var(--atl-ink-2); margin: 0; }
.atl-box__noscript a { color: var(--atl-accent); }

/* Empty state — shows a SVG box outline */
.atl-box__empty {
  text-align: center;
  padding: var(--atl-s8) var(--atl-s5);
  background: var(--atl-paper);
  border: 1px dashed var(--atl-line-2);
  color: var(--atl-ink);
}
.atl-box__empty-art { color: var(--atl-accent); margin-bottom: var(--atl-s4); }
.atl-box__empty h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 24px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  margin: 0 0 var(--atl-s3);
}
.atl-box__empty p { font-size: 14.5px; color: var(--atl-ink-2); margin: 0; max-width: 50ch; margin-inline: auto; }
.atl-box__empty a { color: var(--atl-accent); }

/* Grid: manifest left, totals slip right */
.atl-box__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--atl-s6);
  align-items: start;
}

/* Manifest (cart rows) */
.atl-box__manifest {
  background: var(--atl-paper);
  border: 1px solid var(--atl-line-2);
  padding: var(--atl-s5) var(--atl-s5) var(--atl-s4);
}
.atl-box__manifest-head {
  padding-bottom: var(--atl-s3);
  border-bottom: 1px solid var(--atl-line);
  margin-bottom: var(--atl-s3);
}
.atl-box__manifest-head h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-ink);
  margin: 4px 0 0;
}
.atl-box__rows { list-style: none; margin: 0; padding: 0; }
.atl-box__row {
  display: grid;
  grid-template-columns: 36px 64px 1fr 80px 90px 32px;
  gap: var(--atl-s3);
  align-items: center;
  padding: var(--atl-s3) 0;
  border-bottom: 1px dashed var(--atl-line);
}
.atl-box__row:last-child { border-bottom: 0; }
.atl-box__row-no {
  font-family: var(--atl-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--atl-mute);
  letter-spacing: .04em;
}
.atl-box__row-img {
  display: block;
  width: 64px; height: 64px;
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-line);
  overflow: hidden;
}
.atl-box__row-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.atl-box__row-meta { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.atl-box__row-name {
  font-family: var(--atl-display);
  font-weight: 600;
  font-size: 15px;
  color: var(--atl-ink);
  letter-spacing: .03em;
  text-decoration: none;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.atl-box__row-name:hover { color: var(--atl-accent); }
.atl-box__row-spec {
  font-family: var(--atl-mono);
  font-size: 11.5px;
  color: var(--atl-mute);
  letter-spacing: .04em;
}
.atl-box__row-qty input {
  width: 64px;
  padding: 8px 10px;
  background: var(--atl-bg);
  border: 1px solid var(--atl-line-2);
  color: var(--atl-ink);
  font-family: var(--atl-mono);
  font-size: 13px;
  text-align: center;
}
.atl-box__row-tot {
  font-family: var(--atl-mono);
  font-weight: 700;
  font-size: 14px;
  color: var(--atl-accent);
  text-align: right;
}
.atl-box__row-del {
  width: 32px; height: 32px;
  background: transparent;
  border: 1px solid var(--atl-line-2);
  color: var(--atl-mute);
  font-size: 18px;
  cursor: pointer;
  border-radius: 0;
  line-height: 1;
}
.atl-box__row-del:hover {
  background: var(--atl-warn);
  border-color: var(--atl-warn);
  color: var(--atl-bg);
}

/* Totals slip (right col) */
.atl-box__totals {
  background: var(--atl-bg-2);
  border: 1px solid var(--atl-accent);
  padding: var(--atl-s5);
  position: sticky;
  top: 96px;
  display: flex;
  flex-direction: column;
  gap: var(--atl-s4);
  align-self: start;
}
.atl-box__totals header { padding-bottom: var(--atl-s3); border-bottom: 1px solid var(--atl-line); }
.atl-box__totals h2 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-accent);
  margin: 4px 0 0;
}

.atl-box__progress { display: flex; flex-direction: column; gap: 8px; }
.atl-box__progress-bar {
  height: 8px;
  background: var(--atl-bg);
  border: 1px solid var(--atl-line);
  position: relative;
  overflow: hidden;
}
.atl-box__progress-bar > span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--atl-accent-2), var(--atl-accent));
  transition: width .3s ease;
}
.atl-box__progress[data-free="yes"] .atl-box__progress-bar > span {
  background: linear-gradient(90deg, #4caf6d, #6cd285);
}
.atl-box__progress-lab {
  font-family: var(--atl-mono);
  font-size: 11.5px;
  color: var(--atl-mute);
  display: flex;
  justify-content: space-between;
  gap: var(--atl-s3);
  letter-spacing: .04em;
}
.atl-box__progress-lab b { color: var(--atl-accent); font-weight: 700; }

.atl-box__sum { display: flex; flex-direction: column; gap: 0; }
.atl-box__sum-row {
  display: flex;
  justify-content: space-between;
  padding: 9px 0;
  border-bottom: 1px solid var(--atl-line);
  font-family: var(--atl-mono);
  font-size: 13px;
  color: var(--atl-ink-2);
}
.atl-box__sum-row b { color: var(--atl-ink); }
.atl-box__sum-row--total {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--atl-accent);
  border-bottom: 0;
  border-top: 2px solid var(--atl-accent);
  padding: 14px 0 4px;
}

.atl-box__cta { width: 100%; text-align: center; padding: 16px; font-size: 14px; }

.atl-box__guarantees {
  list-style: none;
  margin: 0;
  padding: var(--atl-s4) 0 0;
  border-top: 1px solid var(--atl-line);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.atl-box__guarantees li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--atl-s3);
  font-family: var(--atl-mono);
  font-size: 11.5px;
  align-items: baseline;
}
.atl-box__guarantees b {
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--atl-accent);
  font-weight: 700;
}
.atl-box__guarantees span { color: var(--atl-mute); line-height: 1.45; }


/* ===== HOME · process · 5 tappe (editorial, alternating side) ========= */

.atl-process {
  position: relative;
  background:
    /* hairline registry-card grid */
    linear-gradient(var(--atl-line) 1px, transparent 1px) 0 0/100% 48px,
    var(--atl-bg);
  border-top: 6px solid var(--atl-accent);
  padding: var(--atl-s9) 0 var(--atl-s8);
}

/* === Header: kicker+title left, lede+meta right === */
.atl-process__h {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--atl-s7);
  margin-bottom: var(--atl-s8);
  padding-bottom: var(--atl-s6);
  border-bottom: 1px solid var(--atl-line-2);
}
.atl-process__h-copy { display: flex; flex-direction: column; gap: var(--atl-s3); }
.atl-process__h-title {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.7rem, 2.8vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: 0;
  color: var(--atl-ink);
  margin: 0;
}
.atl-process__h-title em {
  font-style: italic;
  color: var(--atl-accent);
  font-weight: 600;
}
.atl-process__h-lede {
  font-size: 16px;
  line-height: 1.75;
  color: var(--atl-ink-2);
  margin: 0 0 var(--atl-s5);
  max-width: 60ch;
}
.atl-process__h-meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--atl-s3);
  border-top: 1px solid var(--atl-line);
  padding-top: var(--atl-s4);
}
.atl-process__h-meta li {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.atl-process__h-meta b {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: 0;
  color: var(--atl-accent);
  line-height: 1;
}
.atl-process__h-meta span {
  font-family: var(--atl-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--atl-mute);
  line-height: 1.3;
}

/* === The 5 alternating steps === */
.atl-process__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--atl-s9);
  counter-reset: process;
}
.atl-process__step {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--atl-s7);
  align-items: center;
  position: relative;
  counter-increment: process;
}
.atl-process__step--left .atl-process__photo  { grid-column: 1; grid-row: 1; }
.atl-process__step--left .atl-process__copy   { grid-column: 2; grid-row: 1; }
.atl-process__step--right .atl-process__photo { grid-column: 2; grid-row: 1; }
.atl-process__step--right .atl-process__copy  { grid-column: 1; grid-row: 1; }
.atl-process__step--full { grid-template-columns: minmax(0, 880px); justify-content: center; }
.atl-process__step--full .atl-process__copy { grid-column: 1; grid-row: 1; }

/* hairline brass divider between steps */
.atl-process__step + .atl-process__step::before {
  content: "";
  position: absolute;
  top: calc(var(--atl-s9) * -0.5);
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--atl-accent) 30%,
    var(--atl-accent) 70%,
    transparent 100%);
  opacity: .5;
}

/* === Photo === */
.atl-process__photo {
  position: relative;
  margin: 0;
  border: 1px solid var(--atl-line-2);
  background: var(--atl-bg-2);
  overflow: hidden;
}
.atl-process__photo img {
  display: block;
  width: 100%;
  aspect-ratio: 7 / 5;
  object-fit: cover;
  /* light sepia + warmth, distinct from product covers */
  filter: sepia(.18) saturate(.85) contrast(1.04);
  transition: filter .25s ease;
}
.atl-process__photo:hover img { filter: sepia(.05) saturate(1) contrast(1.02); }
.atl-process__photo figcaption {
  padding: 10px 14px;
  border-top: 1px solid var(--atl-line);
  background: var(--atl-bg);
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--atl-mute);
  line-height: 1.5;
}

/* === Copy column === */
.atl-process__copy {
  display: flex;
  flex-direction: column;
  gap: var(--atl-s3);
}
.atl-process__no {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(3rem, 5vw, 4.5rem);
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--atl-accent);
  opacity: .85;
  margin-bottom: var(--atl-s2);
}
.atl-process__copy h3 {
  font-family: var(--atl-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 2.2vw, 1.85rem);
  line-height: 1.18;
  letter-spacing: 0;
  color: var(--atl-ink);
  margin: 0 0 var(--atl-s3);
}
.atl-process__copy p {
  font-size: 15.5px;
  line-height: 1.78;
  color: var(--atl-ink-2);
  margin: 0;
}
.atl-process__copy p strong {
  color: var(--atl-accent);
  font-weight: 600;
}

/* === Stats at bottom of each step === */
.atl-process__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--atl-s3);
  margin-top: var(--atl-s4);
  padding-top: var(--atl-s4);
  border-top: 1px solid var(--atl-line);
}
.atl-process__stats > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.atl-process__stats dt {
  font-family: var(--atl-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--atl-mute);
}
.atl-process__stats dd {
  margin: 0;
  font-family: var(--atl-mono);
  font-size: 12.5px;
  font-weight: 700;
  color: var(--atl-ink);
  letter-spacing: .02em;
}

/* === Section foot === */
.atl-process__foot {
  margin-top: var(--atl-s9);
  padding-top: var(--atl-s6);
  border-top: 1px solid var(--atl-line-2);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--atl-s5);
  align-items: center;
}
.atl-process__foot p {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  margin: 0;
  max-width: 70ch;
}
.atl-process__foot a { color: var(--atl-accent); }

/* ===== HOME · schedario thumbs / cta (replaces deleted card-num/pick) === */

.atl-sched__card-thumbs {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.atl-sched__card-thumbs li { margin: 0; }
.atl-sched__card-thumbs a {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f4eee0;
  border: 1px solid #e6e0d2;
  transition: border-color .15s, transform .15s;
}
.atl-sched__card-thumbs a:hover {
  border-color: #8b5a13;
  transform: translateY(-1px);
}
.atl-sched__card-thumbs img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.atl-sched__card-cta {
  align-self: flex-start;
  font-family: var(--atl-mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 700;
  color: #8b5a13;
  text-decoration: none;
  padding: 8px 0;
  border-bottom: 1px solid #8b5a13;
}
.atl-sched__card-cta:hover { color: #1a140a; border-bottom-color: #1a140a; }

/* ===== Responsive ====================================================== */

@media (max-width: 1100px) {
  .atl-bridge__row { grid-template-columns: auto 1fr auto; gap: var(--atl-s4); }
  .atl-search { width: 200px; }
  .atl-nav__list { gap: var(--atl-s4); }
  .atl-nav__link { font-size: 12px; }

  .atl-bv__row { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-bv__photo { transform: rotate(0); max-width: 100%; }
  .atl-hero__row { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-hero__feat { max-width: 480px; }

  .atl-process { padding: var(--atl-s7) 0 var(--atl-s6); }
  .atl-process__h { grid-template-columns: 1fr; gap: var(--atl-s5); margin-bottom: var(--atl-s7); }
  .atl-process__h-meta { grid-template-columns: repeat(2, 1fr); }
  .atl-process__list { gap: var(--atl-s8); }
  .atl-process__step { grid-template-columns: 1fr; gap: var(--atl-s4); }
  .atl-process__step--left .atl-process__photo,
  .atl-process__step--right .atl-process__photo,
  .atl-process__step--left .atl-process__copy,
  .atl-process__step--right .atl-process__copy { grid-column: 1; grid-row: auto; }
  .atl-process__stats { grid-template-columns: 1fr 1fr; }
  .atl-process__foot { grid-template-columns: 1fr; gap: var(--atl-s4); }

  /* sportello */
  .atl-sport__board { grid-template-columns: 1fr; }
  .atl-sport__board-state { justify-self: stretch; min-width: 0; }
  .atl-sport__tickets { grid-template-columns: 1fr; }
  .atl-sport__fields { grid-template-columns: 1fr; }
  .atl-sport__slip-foot { grid-template-columns: 1fr; gap: var(--atl-s3); }

  /* modulo */
  .atl-mod__head { grid-template-columns: 1fr; gap: var(--atl-s4); }
  .atl-mod__head-stamp { min-width: 0; }
  .atl-mod__form { grid-template-columns: 1fr; }
  .atl-mod__fields { grid-template-columns: 1fr; }
  .atl-mod__sign { grid-template-columns: 1fr; gap: var(--atl-s4); }
  .atl-mod__slip { position: static; }

  /* box */
  .atl-box__label { grid-template-columns: 1fr; }
  .atl-box__grid { grid-template-columns: 1fr; }
  .atl-box__totals { position: static; }
  .atl-box__row { grid-template-columns: 28px 56px 1fr 80px 32px; gap: var(--atl-s2); }
  .atl-box__row-tot { display: none; }

  /* quartieri index */
  .atl-qua__h { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-qua__row,
  .atl-qua__row--left { grid-template-columns: 60px 1fr; gap: var(--atl-s4); padding: var(--atl-s5) 0; }
  .atl-qua__row--left .atl-qua__row-stack,
  .atl-qua__row--left .atl-qua__row-copy { grid-column: auto; grid-row: auto; }
  .atl-qua__row-stack { grid-column: 1 / -1; height: 200px; max-width: 320px; margin-top: var(--atl-s3); }

  /* genre landing */
  .atl-gen__h {
    grid-template-columns: 1fr;
    grid-template-areas: "left" "cover" "stats";
  }
  .atl-gen__h-cover { justify-self: start; max-width: 240px; }
  .atl-gen__h-stats { grid-template-columns: repeat(3, 1fr); }
  .atl-genl__wrap { grid-template-columns: 1fr; }
  .atl-genl__side { position: static; flex-direction: row; flex-wrap: wrap; gap: var(--atl-s4); }
  .atl-genl__side-block { flex: 1 1 220px; }
  .atl-genl__row { grid-template-columns: 28px 140px 1fr 160px; gap: var(--atl-s4); }
  .atl-genl__row-spec { grid-template-columns: repeat(2, auto); }
  .atl-sched__row { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-sched__photo { position: static; }
  .atl-sched__photo img { height: 280px; }

  .atl-banner__row { grid-template-columns: 1fr; }
  .atl-mosaic__h, .atl-slider__h, .atl-dispaccio__row { grid-template-columns: 1fr; gap: var(--atl-s4); }
  .atl-slider__nav { justify-self: start; align-self: start; }

  .atl-quartieri__grid { grid-template-columns: repeat(3, 1fr); }
  .atl-foot__top { grid-template-columns: 1fr 1fr; }

  .atl-card-grid { grid-template-columns: repeat(3, 1fr); }
  .atl-genre-head__row { grid-template-columns: 1fr; gap: var(--atl-s4); }
  .atl-pdp__grid { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-pdp-nota__grid,
  .atl-pdp-desc__grid,
  .atl-doc__body,
  .atl-page__grid,
  .atl-success__grid { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-pdp-nota__list { grid-template-columns: 1fr 1fr; }
  .atl-pdp-rel__grid { grid-template-columns: repeat(3, 1fr); }
  .atl-doc__toc { position: static; }
  .atl-success__steps { grid-template-columns: 1fr; }
  .atl-news-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .atl-bridge__row {
    grid-template-columns: auto 1fr;
    grid-auto-rows: auto;
  }
  .atl-nav, .atl-search { display: none; }
  .atl-burger { display: inline-flex; }
  .atl-cart__lab { display: none; }
  .atl-cart { padding: 0 12px; }
  .atl-strip__row { gap: var(--atl-s3); }
  .atl-strip__cell--port { display: none; }

  /* Mobile nav drawer */
  .atl-nav.is-open {
    display: block;
    grid-column: 1 / -1;
    background: var(--atl-bg-2);
    margin-top: var(--atl-s3);
    padding: var(--atl-s4);
    border: 1px solid var(--atl-line);
  }
  .atl-nav.is-open .atl-nav__list {
    flex-direction: column;
    gap: var(--atl-s3);
  }
  .atl-nav.is-open .atl-nav__sub {
    position: static;
    transform: none;
    display: block;
    margin-top: var(--atl-s2);
    min-width: 0;
  }
  .atl-nav.is-open .atl-nav__sub ul { grid-template-columns: 1fr; }

  .atl-brand__sub { display: none; }
  .atl-brand__name { font-size: 22px; }
  .atl-brand__porthole { width: 44px; height: 44px; }

  .atl-bv { padding: var(--atl-s7) 0 0; }
  .atl-bv__letter { padding: var(--atl-s5) var(--atl-s4); }
  .atl-bv__h { font-size: 1.3rem; }
  .atl-bv__strip { font-size: 11px; padding: var(--atl-s3) 0; }
  .atl-bv__strip-sep { display: none; }

  .atl-mosaic__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 160px;
  }
  .atl-mosaic__cell--big { grid-column: span 2; grid-row: span 1; }

  .atl-sched__card-head { grid-template-columns: auto 1fr; }

  .atl-hero { padding: var(--atl-s6) 0 var(--atl-s5); }
  .atl-hero__pillars { grid-template-columns: 1fr; gap: var(--atl-s4); padding-top: var(--atl-s4); }
  .atl-hero__h { font-size: 1.6rem; }
  .atl-hero__feat-spec { grid-template-columns: 1fr 1fr; }

  .atl-slider__track {
    grid-auto-columns: 88vw;
    scroll-padding-left: 16px;
  }
  .atl-slider__card { min-height: 480px; }

  .atl-quartieri__grid { grid-template-columns: 1fr 1fr; }
  .atl-foot__top { grid-template-columns: 1fr; }

  .atl-card-grid { grid-template-columns: 1fr 1fr; gap: var(--atl-s2); }
  .atl-pdp-nota__list { grid-template-columns: 1fr; }
  .atl-pdp-rel__grid { grid-template-columns: 1fr 1fr; }
  .atl-cart-row {
    grid-template-columns: 70px 1fr;
    grid-template-areas:
      "img name"
      "img qty"
      "price price"
      "del del";
    gap: var(--atl-s2);
  }
  .atl-cart-row__img { width: 70px; height: 70px; grid-area: img; }
  .atl-cart-row__name { grid-area: name; }
  .atl-cart-row__qty { grid-area: qty; }
  .atl-cart-row__price { grid-area: price; text-align: left; padding-top: 8px; border-top: 1px solid var(--atl-line); }
  .atl-cart-row__del { grid-area: del; align-self: flex-start; }
  .atl-form-row { grid-template-columns: 1fr; }
}

/* ======================================================================
   SITE-WIDE GIFT BANNER (above Registro di Bordo strip)
   ====================================================================== */
.atl-gbar {
  background: linear-gradient(90deg, #3d2818 0%, #5a3a22 50%, #3d2818 100%);
  color: #f4e3c4;
  border-bottom: 1px solid rgba(200, 160, 98, 0.35);
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .04em;
}
.atl-gbar__row {
  display: flex;
  align-items: center;
  gap: var(--atl-s4);
  padding: 8px var(--atl-wrap-pad);
  min-height: 34px;
}
.atl-gbar__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--atl-accent);
  flex-shrink: 0;
}
.atl-gbar__label { flex: 1 1 auto; }
.atl-gbar__label b { color: var(--atl-accent); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.atl-gbar__meta {
  flex-shrink: 0;
  color: var(--atl-accent);
  font-size: 10.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  border-left: 1px solid rgba(200, 160, 98, 0.35);
  padding-left: var(--atl-s4);
}
@media (max-width: 720px) {
  .atl-gbar { font-size: 11px; }
  .atl-gbar__row { padding: 6px var(--atl-wrap-pad); gap: var(--atl-s3); }
  .atl-gbar__meta { display: none; }
  .atl-gbar__label { font-size: 11px; line-height: 1.4; }
}

/* ======================================================================
   PRODUCT DETAIL · GIFT BLOCK · EMPIRE TOTAL WAR (tavolo-di-guerra)
   Aesthetic: military dispatch, brass stamp, cards = field orders.
   ====================================================================== */
.atl-gift { padding: var(--atl-s8) 0; position: relative; }

.atl-gift--war {
  background: #12232b;
  background-image:
    linear-gradient(rgba(10, 37, 48, 0.94), rgba(10, 37, 48, 0.94)),
    repeating-linear-gradient(45deg, transparent 0, transparent 18px, rgba(200,160,98,0.04) 18px, rgba(200,160,98,0.04) 19px);
  color: var(--atl-ink);
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
}
.atl-gift--war__dossier {
  border: 1px solid var(--atl-line-2);
  background: rgba(18, 40, 50, 0.5);
  padding: var(--atl-s7);
  position: relative;
}
.atl-gift--war__dossier::before {
  content: "DISPACCIO · CONFIDENZIALE · CLIENTI NUOVI · №07";
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--atl-mono);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--atl-mute);
}
.atl-gift--war__hd {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--atl-s6);
  align-items: start;
  padding-top: var(--atl-s6);
  padding-bottom: var(--atl-s5);
  border-bottom: 1px dashed var(--atl-line-2);
  margin-bottom: var(--atl-s6);
}
.atl-gift--war__stamp {
  display: block;
  border: 3px double var(--atl-accent);
  border-radius: 4px;
  padding: 14px 10px;
  color: var(--atl-accent);
  text-align: center;
  font-family: var(--atl-mono);
  transform: rotate(-6deg);
  background: rgba(200, 160, 98, 0.04);
  box-shadow: inset 0 0 0 1px rgba(200, 160, 98, 0.3);
}
.atl-gift--war__stamp-top { display: block; font-size: 12px; letter-spacing: .3em; font-weight: 700; }
.atl-gift--war__stamp-mid { display: block; font-family: var(--atl-serif); font-size: 20px; line-height: 1.05; margin: 6px 0; letter-spacing: .04em; }
.atl-gift--war__stamp-btm { display: block; font-size: 9.5px; letter-spacing: .24em; opacity: .85; }
.atl-gift--war__hd h2 {
  font-family: var(--atl-serif);
  font-size: clamp(26px, 3.4vw, 40px);
  line-height: 1.1;
  margin-top: var(--atl-s2);
  margin-bottom: var(--atl-s4);
}
.atl-gift--war__hd h2 em { color: var(--atl-accent); font-style: italic; }
.atl-gift--war__lede { font-size: 15.5px; line-height: 1.65; color: var(--atl-ink-2); }

.atl-gift--war__figure {
  margin: 0 0 var(--atl-s6);
  border: 1px solid var(--atl-line-2);
  background: #0a2530;
}
.atl-gift--war__figure img {
  width: 100%;
  max-height: 380px;
  object-fit: cover;
  filter: sepia(0.35) saturate(0.8) contrast(0.95) brightness(0.92);
}
.atl-gift--war__figure figcaption {
  padding: var(--atl-s3) var(--atl-s5);
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--atl-mute);
  border-top: 1px solid var(--atl-line-2);
}

.atl-gift--war__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--atl-s6);
}
.atl-gift--war__card {
  border-left: 3px solid var(--atl-accent);
  padding: var(--atl-s4) var(--atl-s5) var(--atl-s4) var(--atl-s5);
  background: rgba(10, 37, 48, 0.5);
}
.atl-gift--war__card-no {
  display: inline-block;
  font-family: var(--atl-serif);
  font-style: italic;
  font-size: 13px;
  color: var(--atl-accent);
  letter-spacing: .1em;
  margin-bottom: var(--atl-s2);
}
.atl-gift--war__card h3 {
  font-family: var(--atl-serif);
  font-size: 19px;
  line-height: 1.25;
  margin-bottom: var(--atl-s3);
}
.atl-gift--war__card p { font-size: 14.5px; line-height: 1.6; color: var(--atl-ink-2); }
.atl-gift--war__card a { color: var(--atl-accent); text-decoration: underline; text-underline-offset: 3px; }

.atl-gift--war__ft {
  margin-top: var(--atl-s6);
  padding-top: var(--atl-s5);
  border-top: 1px dashed var(--atl-line-2);
  font-size: 13.5px;
  color: var(--atl-mute);
  line-height: 1.6;
}
.atl-gift--war__ft a { color: var(--atl-accent); }

/* ======================================================================
   PRODUCT DETAIL · GIFT BLOCK · SCRABBLE (tavoliere)
   Aesthetic: wooden Scrabble tiles spelling PRESENT × BENVENUTO.
   ====================================================================== */
.atl-gift--tiles {
  background: #eee3cd;
  color: #2a2015;
  border-top: 1px solid rgba(42, 32, 21, 0.15);
  border-bottom: 1px solid rgba(42, 32, 21, 0.15);
}
.atl-gift--tiles__hd { text-align: center; margin-bottom: var(--atl-s7); }
.atl-gift--tiles__hd .atl-kicker { color: #7a5a2a; }
.atl-gift--tiles__hd h2 {
  font-family: var(--atl-serif);
  font-size: clamp(30px, 4vw, 46px);
  color: #2a2015;
  margin: var(--atl-s3) 0 var(--atl-s6);
}
.atl-gift--tiles__rack {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  list-style: none;
  padding: 16px 18px;
  margin: 0 auto var(--atl-s6);
  max-width: 720px;
  background: #c9a66b;
  border: 2px solid #8b6d3f;
  border-radius: 4px;
  box-shadow: inset 0 3px 6px rgba(0,0,0,.25), 0 4px 10px rgba(0,0,0,.12);
}
.atl-gift--tiles__tile {
  position: relative;
  width: 42px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f4dfb2;
  background-image: linear-gradient(180deg, #faecc3 0%, #e8cf96 100%);
  border: 1px solid #a67e3c;
  border-radius: 3px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -2px 2px rgba(0,0,0,.18),
    0 2px 3px rgba(0,0,0,.2);
  font-family: var(--atl-serif);
  color: #2a2015;
  transform: rotate(calc((var(--atl-gift-i, 0) * 7deg - 21deg) * 0.1));
  transition: transform .18s ease, box-shadow .18s ease;
}
.atl-gift--tiles__tile:hover {
  transform: translateY(-3px) rotate(calc((var(--atl-gift-i, 0) * 7deg - 21deg) * 0.1));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -2px 2px rgba(0,0,0,.18),
    0 6px 10px rgba(0,0,0,.28);
}
.atl-gift--tiles__tile--x {
  width: 18px;
  background: transparent;
  border: none;
  box-shadow: none;
  color: #7a5a2a;
  font-size: 20px;
  font-style: italic;
}
.atl-gift--tiles__letter { font-size: 22px; font-weight: 700; line-height: 1; }
.atl-gift--tiles__pts {
  position: absolute;
  right: 3px;
  bottom: 2px;
  font-family: var(--atl-mono);
  font-size: 9px;
  color: #5a4520;
}
.atl-gift--tiles__lede {
  max-width: 760px;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.65;
  color: #3a2e1e;
  text-align: center;
}

.atl-gift--tiles__row {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: var(--atl-s7);
  align-items: start;
}
.atl-gift--tiles__photo {
  margin: 0;
  border: 1px solid #8b6d3f;
  background: #fff;
  padding: 10px 10px 0;
  box-shadow: 0 6px 22px rgba(42, 32, 21, 0.18);
  transform: rotate(-1.2deg);
}
.atl-gift--tiles__photo img {
  width: 100%;
  aspect-ratio: 1.2/1;
  object-fit: cover;
}
.atl-gift--tiles__photo figcaption {
  padding: var(--atl-s3) 2px var(--atl-s3);
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .06em;
  color: #6a5330;
  text-align: center;
  border-top: 1px dashed #c9a66b;
  margin-top: 10px;
}
.atl-gift--tiles__copy h3 {
  font-family: var(--atl-serif);
  font-size: 22px;
  color: #2a2015;
  margin: var(--atl-s5) 0 var(--atl-s3);
}
.atl-gift--tiles__copy h3:first-child { margin-top: 0; }
.atl-gift--tiles__copy p { font-size: 15.5px; line-height: 1.7; color: #3a2e1e; }
.atl-gift--tiles__copy strong { color: #2a2015; }
.atl-gift--tiles__list {
  list-style: none;
  padding: 0;
  margin: var(--atl-s3) 0 var(--atl-s5);
  display: grid;
  gap: var(--atl-s3);
}
.atl-gift--tiles__list li {
  padding: var(--atl-s4);
  background: rgba(255,255,255,0.5);
  border-left: 3px solid #8b6d3f;
  font-size: 14.5px;
  line-height: 1.6;
}
.atl-gift--tiles__fine {
  margin-top: var(--atl-s4);
  padding-top: var(--atl-s4);
  border-top: 1px dashed #c9a66b;
  font-size: 13px;
  color: #6a5330;
  line-height: 1.6;
}

/* ======================================================================
   SECRET GIFT LANDING · /baule-segreto/chiave-di-benvenuto/
   Aesthetic: a chest with a wax seal, dossier cards, archive mood.
   ====================================================================== */
.atl-baule { background: var(--atl-bg); }

/* ---- hero chest ------------------------------------------------------- */
.atl-baule__hero {
  padding: var(--atl-s9) 0 var(--atl-s8);
  background: radial-gradient(ellipse at 70% 40%, rgba(200,160,98,0.18), transparent 60%), var(--atl-bg);
  border-bottom: 1px solid var(--atl-line);
}
.atl-baule__hero-wrap {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--atl-s8);
  align-items: center;
}
.atl-baule__hero-title {
  font-family: var(--atl-serif);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
  margin: var(--atl-s3) 0 var(--atl-s5);
}
.atl-baule__hero-title em { color: var(--atl-accent); font-style: italic; }
.atl-baule__hero-lede {
  font-size: 17px;
  line-height: 1.7;
  color: var(--atl-ink-2);
  max-width: 62ch;
}
.atl-baule__hero-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--atl-s4);
  list-style: none;
  padding: 0;
  margin: var(--atl-s6) 0 0;
  border-top: 1px solid var(--atl-line);
  padding-top: var(--atl-s5);
}
.atl-baule__hero-meta li { display: flex; flex-direction: column; gap: 4px; }
.atl-baule__hero-meta span { font-family: var(--atl-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--atl-mute); }
.atl-baule__hero-meta b { font-family: var(--atl-serif); font-size: 22px; color: var(--atl-accent); }

/* chest illustration, pure CSS */
.atl-baule__hero-r { margin: 0; display: flex; justify-content: center; }
.atl-baule__chest {
  position: relative;
  width: 100%;
  max-width: 360px;
  aspect-ratio: 1 / 1;
  perspective: 800px;
}
.atl-baule__chest-lid {
  position: absolute;
  top: 10%; left: 5%;
  width: 90%; height: 35%;
  background: linear-gradient(180deg, #6b4a26 0%, #4a321a 80%);
  border: 2px solid #2a1d10;
  border-radius: 14px 14px 0 0;
  box-shadow: inset 0 3px 0 rgba(255,255,255,.08), inset 0 -4px 8px rgba(0,0,0,.4);
}
.atl-baule__chest-body {
  position: absolute;
  top: 42%; left: 5%;
  width: 90%; height: 50%;
  background: linear-gradient(180deg, #5a3e20 0%, #3d2715 100%);
  border: 2px solid #2a1d10;
  border-radius: 0 0 10px 10px;
  box-shadow: inset 0 3px 0 rgba(255,255,255,.06), inset 0 -6px 14px rgba(0,0,0,.55);
}
.atl-baule__chest-strap {
  position: absolute;
  top: 0; left: 46%;
  width: 8%; height: 100%;
  background: #2a1d10;
  box-shadow: inset 0 0 0 1px rgba(200,160,98,0.3);
}
.atl-baule__chest-keyhole {
  position: absolute;
  bottom: 18%; left: 50%;
  transform: translateX(-50%);
  width: 14px; height: 20px;
  background: #0a0605;
  border-radius: 50% 50% 30% 30%;
  box-shadow: 0 0 0 2px #c8a062, 0 2px 3px rgba(0,0,0,.5);
}
.atl-baule__chest-keyhole::after {
  content: "";
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 4px; height: 8px;
  background: #0a0605;
}
.atl-baule__chest-rivet {
  position: absolute;
  width: 10px; height: 10px;
  background: radial-gradient(circle at 30% 30%, #e8c98a, #8b6d3f);
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,.5);
}
.atl-baule__chest-rivet--1 { top: 8%; left: 12%; }
.atl-baule__chest-rivet--2 { top: 8%; right: 12%; }
.atl-baule__chest-rivet--3 { top: 28%; left: 12%; }
.atl-baule__chest-rivet--4 { top: 28%; right: 12%; }
.atl-baule__chest-wax {
  position: absolute;
  bottom: -8%; right: 18%;
  width: 70px; height: 70px;
  background: radial-gradient(circle at 35% 30%, #d64531, #7a2010);
  border-radius: 50% 50% 42% 58% / 55% 45% 55% 45%;
  box-shadow: inset 2px 2px 6px rgba(255,255,255,0.3), 0 6px 18px rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  transform: rotate(-12deg);
}
.atl-baule__chest-wax-letter {
  font-family: var(--atl-serif);
  font-style: italic;
  font-size: 36px;
  color: rgba(255,255,255,0.9);
  text-shadow: 0 1px 2px rgba(0,0,0,.45);
}
.atl-baule__chest-shadow {
  position: absolute;
  bottom: 2%; left: 8%; right: 8%;
  height: 20px;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.5), transparent 70%);
  filter: blur(4px);
}

/* ---- manifesto -------------------------------------------------------- */
.atl-baule__manifesto {
  background: var(--atl-surface);
  padding: var(--atl-s9) 0;
  border-bottom: 1px solid var(--atl-line);
}
.atl-baule__manifesto-hd { text-align: center; margin-bottom: var(--atl-s7); }
.atl-baule__manifesto-hd h2 {
  font-family: var(--atl-serif);
  font-size: clamp(28px, 3.6vw, 40px);
  margin-top: var(--atl-s3);
}
.atl-baule__manifesto-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--atl-s7);
  list-style: none;
  padding: 0;
  margin: 0;
}
.atl-baule__manifesto-list li {
  position: relative;
  padding-top: var(--atl-s6);
  border-top: 1px solid var(--atl-line);
}
.atl-baule__manifesto-no {
  display: block;
  font-family: var(--atl-serif);
  font-style: italic;
  font-size: 40px;
  color: var(--atl-accent);
  line-height: 1;
  margin-bottom: var(--atl-s3);
}
.atl-baule__manifesto-list h3 {
  font-family: var(--atl-serif);
  font-size: 22px;
  line-height: 1.25;
  margin-bottom: var(--atl-s3);
}
.atl-baule__manifesto-list p { font-size: 15px; line-height: 1.7; color: var(--atl-ink-2); }

/* ---- present grid ----------------------------------------------------- */
.atl-baule__grid { padding: var(--atl-s9) 0; }
.atl-baule__grid-hd { max-width: 760px; margin-bottom: var(--atl-s7); }
.atl-baule__grid-hd h2 {
  font-family: var(--atl-serif);
  font-size: clamp(28px, 3.6vw, 40px);
  margin: var(--atl-s3) 0 var(--atl-s4);
}
.atl-baule__grid-hd p { font-size: 15.5px; color: var(--atl-ink-2); line-height: 1.7; }

.atl-baule__grid-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--atl-s5);
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: baule;
}
.atl-baule__card {
  position: relative;
  background: var(--atl-surface);
  border: 1px solid var(--atl-line);
  padding: var(--atl-s5) var(--atl-s5) var(--atl-s5);
  transition: transform .2s ease, border-color .2s ease;
}
.atl-baule__card:hover {
  transform: translateY(-3px);
  border-color: var(--atl-accent);
}
.atl-baule__card-hd {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: var(--atl-s3);
  border-bottom: 1px dashed var(--atl-line-2);
  margin-bottom: var(--atl-s4);
}
.atl-baule__card-no {
  font-family: var(--atl-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--atl-accent);
  letter-spacing: .12em;
}
.atl-baule__card-value {
  font-family: var(--atl-mono);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--atl-accent);
  background: rgba(200, 160, 98, 0.1);
  padding: 3px 8px;
  border: 1px solid var(--atl-accent);
}
.atl-baule__card-name {
  font-family: var(--atl-serif);
  font-size: 22px;
  line-height: 1.2;
  margin-bottom: var(--atl-s3);
}
.atl-baule__card-desc { font-size: 14.5px; line-height: 1.65; color: var(--atl-ink-2); margin-bottom: var(--atl-s4); }
.atl-baule__card-for {
  padding-top: var(--atl-s3);
  border-top: 1px solid var(--atl-line);
  font-size: 13px;
  line-height: 1.6;
  color: var(--atl-ink-2);
}
.atl-baule__card-for span {
  display: inline-block;
  font-family: var(--atl-mono);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--atl-mute);
  margin-right: 6px;
}
.atl-baule__card-for a { color: var(--atl-accent); }

/* ---- how -------------------------------------------------------------- */
.atl-baule__how {
  background: var(--atl-surface);
  padding: var(--atl-s9) 0;
  border-top: 1px solid var(--atl-line);
  border-bottom: 1px solid var(--atl-line);
}
.atl-baule__how-wrap {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--atl-s8);
  align-items: start;
}
.atl-baule__how-fig { margin: 0; border: 1px solid var(--atl-line); padding: 10px; background: var(--atl-bg); }
.atl-baule__how-fig img { width: 100%; aspect-ratio: 4/5; object-fit: cover; filter: sepia(0.2) saturate(0.9); }
.atl-baule__how-fig figcaption {
  padding: var(--atl-s3) 2px 0;
  font-family: var(--atl-mono);
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--atl-mute);
  text-align: center;
  border-top: 1px dashed var(--atl-line);
  margin-top: 10px;
}
.atl-baule__how-copy h2 {
  font-family: var(--atl-serif);
  font-size: clamp(28px, 3.6vw, 40px);
  margin: var(--atl-s3) 0 var(--atl-s6);
}
.atl-baule__how-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--atl-s5);
}
.atl-baule__how-steps li {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--atl-s4);
  padding: var(--atl-s5);
  border-left: 3px solid var(--atl-accent);
  background: var(--atl-bg);
}
.atl-baule__how-steps b {
  font-family: var(--atl-serif);
  font-size: 38px;
  line-height: 1;
  color: var(--atl-accent);
}
.atl-baule__how-steps h4 {
  font-family: var(--atl-serif);
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: var(--atl-s2);
}
.atl-baule__how-steps p { font-size: 14.5px; line-height: 1.65; color: var(--atl-ink-2); }

/* ---- FAQ -------------------------------------------------------------- */
.atl-baule__faq { padding: var(--atl-s9) 0; }
.atl-baule__faq-hd { text-align: center; max-width: 720px; margin: 0 auto var(--atl-s7); }
.atl-baule__faq-hd h2 {
  font-family: var(--atl-serif);
  font-size: clamp(28px, 3.6vw, 40px);
  margin-top: var(--atl-s3);
}
.atl-baule__faq-list {
  display: grid;
  gap: 0;
  max-width: 860px;
  margin: 0 auto;
  border-top: 1px solid var(--atl-line);
}
.atl-baule__faq-list > div {
  padding: var(--atl-s5) 0;
  border-bottom: 1px solid var(--atl-line);
}
.atl-baule__faq-list dt {
  font-family: var(--atl-serif);
  font-size: 19px;
  line-height: 1.3;
  color: var(--atl-accent);
  margin-bottom: var(--atl-s3);
}
.atl-baule__faq-list dd { font-size: 15px; line-height: 1.7; color: var(--atl-ink-2); }
.atl-baule__faq-list a { color: var(--atl-accent); text-decoration: underline; text-underline-offset: 3px; }

/* ---- CTA -------------------------------------------------------------- */
.atl-baule__cta {
  background: linear-gradient(135deg, #0e2b36 0%, #163844 100%);
  padding: var(--atl-s9) 0;
  border-top: 1px solid var(--atl-accent);
}
.atl-baule__cta-wrap {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--atl-s7);
  align-items: center;
}
.atl-baule__cta h2 {
  font-family: var(--atl-serif);
  font-size: clamp(28px, 3.6vw, 40px);
  margin-bottom: var(--atl-s3);
}
.atl-baule__cta p { font-size: 15.5px; line-height: 1.65; color: var(--atl-ink-2); }
.atl-baule__cta-links {
  display: flex;
  flex-direction: column;
  gap: var(--atl-s3);
  align-items: flex-start;
}
.atl-baule__cta-links .atl-btn { min-width: 280px; text-align: center; }

/* ======================================================================
   NARROW MOBILE · quartieri index + genre landing (≤ 600px phones)
   At 1100px breakpoint the grids still used 4 columns and overflowed at
   typical phone widths (360–430px). This block collapses to one column.
   ====================================================================== */
@media (max-width: 600px) {

  /* /quartieri/ index · illustrated rows — single column, photo stack smaller */
  .atl-qua__row,
  .atl-qua__row--left {
    grid-template-columns: 1fr;
    gap: var(--atl-s3);
    padding: var(--atl-s5) 0;
  }
  .atl-qua__row-no {
    font-size: 2.4rem;
    padding-top: 0;
    align-self: start;
  }
  .atl-qua__row-stack {
    grid-column: 1;
    height: 170px;
    max-width: 280px;
    margin: var(--atl-s2) auto 0;
  }
  .atl-qua__row-cover img { aspect-ratio: 4 / 5; }
  .atl-qua__row-cover--0 { width: 130px; }
  .atl-qua__row-cover--1,
  .atl-qua__row-cover--2 { width: 110px; }
  .atl-qua__row-name { font-size: 1.65rem; }
  .atl-qua__h-meta { grid-template-columns: 1fr 1fr; gap: var(--atl-s3); }

  /* /quartieri/[slug]/ genre landing · header */
  .atl-gen__h-stats { grid-template-columns: repeat(2, 1fr); gap: var(--atl-s3); }
  .atl-gen__h-cover { max-width: 200px; }
  .atl-gen__h-title { font-size: clamp(1.8rem, 8vw, 2.4rem); }

  /* sidebar: keep stacked vertical, reduced padding */
  .atl-genl__side {
    flex-direction: column;
    gap: var(--atl-s4);
  }
  .atl-genl__side-block { flex: 1 1 auto; }
  .atl-genl__side-sort label { font-size: 13px; padding: 7px 0; }
  .atl-genl__side-cross a { padding: 7px 0; font-size: 13px; }

  /* product row: stack cover on top, then info, then buy button */
  .atl-genl__row {
    grid-template-columns: 1fr;
    gap: var(--atl-s4);
    padding: var(--atl-s5) 0;
  }
  .atl-genl__row-i {
    position: absolute;
    top: var(--atl-s4);
    right: 0;
    padding: 0;
    font-size: 11px;
  }
  .atl-genl__row-cover {
    max-width: 100%;
    margin: 0;
  }
  .atl-genl__row-cover img { aspect-ratio: 3 / 2; }
  .atl-genl__row-name { font-size: 1.25rem; }
  .atl-genl__row-desc { font-size: 14px; max-width: none; }
  .atl-genl__row-spec {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--atl-s2) var(--atl-s4);
  }
  .atl-genl__row-buy {
    border-left: 0;
    border-top: 1px solid var(--atl-line);
    padding: var(--atl-s4) 0 0;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--atl-s3);
  }
  .atl-genl__row-price { font-size: 22px; }
  .atl-genl__row-add { flex: 0 0 auto; }

  .atl-genl__row-head { flex-wrap: wrap; gap: var(--atl-s2); }
}

/* ======================================================================
   MOBILE · gift sections + baule secret page
   ====================================================================== */
@media (max-width: 900px) {
  /* war gift (empire) */
  .atl-gift--war__hd { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-gift--war__stamp { max-width: 220px; margin: 0 auto; transform: rotate(-3deg); }
  .atl-gift--war__grid { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-gift--war__dossier { padding: var(--atl-s5) var(--atl-s4); }

  /* tiles gift (scrabble) */
  .atl-gift--tiles__row { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-gift--tiles__photo { max-width: 420px; margin-left: auto; margin-right: auto; }
  .atl-gift--tiles__tile { width: 36px; height: 42px; }
  .atl-gift--tiles__letter { font-size: 18px; }

  /* baule */
  .atl-baule__hero-wrap { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-baule__hero-r { order: -1; }
  .atl-baule__chest { max-width: 240px; }
  .atl-baule__hero-meta { grid-template-columns: repeat(2, 1fr); }
  .atl-baule__manifesto-list { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-baule__grid-list { grid-template-columns: 1fr; }
  .atl-baule__how-wrap { grid-template-columns: 1fr; gap: var(--atl-s6); }
  .atl-baule__how-fig { max-width: 420px; }
  .atl-baule__cta-wrap { grid-template-columns: 1fr; gap: var(--atl-s5); }
  .atl-baule__cta-links { align-items: stretch; }
  .atl-baule__cta-links .atl-btn { min-width: 0; }
  .atl-baule__how-steps li { grid-template-columns: 48px 1fr; padding: var(--atl-s4); }
  .atl-baule__how-steps b { font-size: 30px; }
}
