/* ════════════════════════════════════════════════════════════════════
   RC VOCE PRODUZIONE — Design System v2 (Taste-Skill restyle 27/04/2026)
   ────────────────────────────────────────────────────────────────────
   Direzione: dark premium OLED editorial · accademia di perfezionamento
   Settings:
     DESIGN_VARIANCE = 7  → griglie asimmetriche, aspect ratio mixati
     MOTION_INTENSITY = 7 → scroll-reveal cubic-bezier(0.16,1,0.3,1)
     VISUAL_DENSITY = 3   → whitespace generoso, vibe luxury label
   ════════════════════════════════════════════════════════════════════ */

/* ── Tokens ───────────────────────────────────────────────────────── */
:root {
  /* Colore — palette mono moderna 2026 (B/W + 1 accent calibrato) */
  --bg:        #0a0a0a;
  --bg-2:      #131313;          /* card / surface */
  --bg-3:      #1c1c1c;          /* elevated */
  --ink:       #fafafa;          /* near-white */
  --ink-2:     #b5b5b5;          /* subdued */
  --ink-3:     #7a7a7a;          /* muted */
  --ink-4:     #4a4a4a;
  --accent:    #c79a52;          /* oro più sobrio, meno luxury cliché */
  --accent-2:  #a87f3a;
  --accent-mute: rgba(199, 154, 82, 0.10);
  --line:      rgba(244, 243, 238, 0.07);
  --line-2:    rgba(244, 243, 238, 0.14);
  --shadow-1:  0 1px 0 rgba(255, 255, 255, 0.04) inset;
  --shadow-2:  0 24px 48px -24px rgba(0, 0, 0, 0.6), 0 1px 0 rgba(255, 255, 255, 0.03) inset;
  --tint:      rgba(14, 16, 17, 0.65);   /* overlay tinted nel bg color */

  /* Light surface — accademia premium editorial (palette caldo-paper) */
  --paper:      #f6f4ee;        /* warm paper, leggera dominante crema */
  --paper-2:    #ecead6;        /* surface card / elevation */
  --paper-3:    #d9d4c2;        /* divider / strong border */
  --paper-card: #ffffff;        /* card su paper bg */
  --on-paper:   #1c1a14;        /* near-black caldo, NON puro */
  --on-paper-2: #4a463c;        /* body text caldo */
  --on-paper-3: #7a7361;        /* muted */
  --line-paper:    rgba(28, 26, 20, 0.10);
  --line-paper-2:  rgba(28, 26, 20, 0.18);

  /* Tipografia 2026 — variable, moderna, NON Barlow Condensed (datato) */
  --font-display: 'Manrope', 'Inter Display', system-ui, sans-serif;
  --font-body:    'Manrope', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  --type-eyebrow:  0.78rem;
  --type-body-sm:  0.92rem;
  --type-body:     1.04rem;
  --type-body-lg:  1.24rem;
  --type-h4:       1.4rem;
  --type-h3:       1.8rem;
  --type-h2:       clamp(2.4rem, 5vw, 4rem);
  --type-h1:       clamp(3.2rem, 9vw, 8.5rem);

  --lead-tight:    0.96;
  --lead-snug:     1.12;
  --lead-normal:   1.55;
  --lead-relax:    1.7;
  --track-tight:   -0.04em;
  --track-display: -0.025em;
  --track-eyebrow: 0.06em;

  /* Spazio (luxury whitespace) */
  --s-1: 0.25rem;  --s-2: 0.5rem;   --s-3: 0.75rem;
  --s-4: 1rem;     --s-5: 1.5rem;   --s-6: 2rem;
  --s-7: 3rem;     --s-8: 4rem;     --s-9: 6rem;
  --s-10: 8rem;    --s-11: 10rem;   --s-12: 14rem;

  /* Sezioni — padding verticale generoso */
  --sec-pad-y: clamp(5rem, 10vw, 9rem);
  --container: 1240px;
  --container-narrow: 880px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);

  /* Motion — Taste-Skill ease */
  --ease:       cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out:   cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in:    cubic-bezier(0.4, 0, 1, 1);
  --t-fast:     0.24s;
  --t-base:     0.42s;
  --t-slow:     0.72s;

  /* Layout */
  --nav-h:     76px;
  --radius:    4px;
  --radius-lg: 10px;
  --radius-pill: 999px;
}

/* ── Reset moderno ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
}
body {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--type-body);
  line-height: var(--lead-normal);
  color: var(--on-paper);
  background: var(--paper);     /* paper-first: accademia premium editorial */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
/* Default sec senza modificatore = paper */
section:not([class*="sec-"]):not(.hero):not(.marquee) {
  background: var(--paper);
  color: var(--on-paper);
}
img, svg, video, picture { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button, input, textarea, select {
  font: inherit; color: inherit; background: none; border: none; outline: none;
}
button { cursor: pointer; }
::selection { background: var(--accent); color: var(--bg); }

.mobile-break { display: none; }
.exp-hero h1 span { display: block; }

/* Skip link accessibility */
.skip-link {
  position: absolute; left: var(--s-4); top: var(--s-4);
  background: var(--bg); color: var(--accent);
  padding: var(--s-2) var(--s-4); border: 1px solid var(--accent);
  border-radius: var(--radius); transform: translateY(-200%);
  transition: transform var(--t-fast) var(--ease);
  z-index: 1000;
}
.skip-link:focus-visible { transform: translateY(0); }

/* Focus visibile globale */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ── Tipografia ──────────────────────────────────────────────────── */
.eyebrow {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  margin-bottom: var(--s-3);
  line-height: 1;
  /* Più editoriale moderno: lowercase + mono + grigio */
}
.eyebrow::before {
  content: '— ';
  color: var(--accent);
  margin-right: 4px;
}
.eyebrow.muted { color: var(--ink-3); }

h1, .h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--type-h1);
  line-height: var(--lead-tight);
  letter-spacing: var(--track-tight);
  /* No uppercase — feeling 2026 type-driven */
  color: var(--ink);
  text-wrap: balance;
}
h2, .h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--type-h2);
  line-height: var(--lead-snug);
  letter-spacing: var(--track-display);
  color: var(--ink);
  text-wrap: balance;
}
h3, .h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--type-h3);
  line-height: var(--lead-snug);
  letter-spacing: -0.015em;
  color: var(--ink);
}
h4, .h4 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--type-h4);
  line-height: var(--lead-snug);
  letter-spacing: -0.01em;
  color: var(--ink);
}
.lead {
  font-size: var(--type-body-lg);
  line-height: 1.55;
  color: var(--ink-2);
  font-weight: 400;
  max-width: 60ch;
  letter-spacing: -0.005em;
}
.body-sm { font-size: var(--type-body-sm); color: var(--ink-2); }
em { color: var(--accent); font-style: italic; }
strong { color: var(--ink); font-weight: 600; }

/* Accent line — micro elemento editorial sotto i titoli (più discreto) */
.accent-line {
  display: inline-block;
  width: 36px; height: 2px;
  background: var(--accent);
  margin-bottom: var(--s-4);
}

/* ── Container & Sections ────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--gutter);
}
.container.narrow { max-width: var(--container-narrow); }

section { position: relative; }
.sec-pad   { padding-block: var(--sec-pad-y); }
.sec-pad-t { padding-top: var(--sec-pad-y); }
.sec-pad-b { padding-bottom: var(--sec-pad-y); }

.sec-dark   { background: var(--bg);   color: var(--ink); }
.sec-darker { background: #0a0c0d;     color: var(--ink); }
.sec-elev   { background: var(--bg-2); color: var(--ink); }
.sec-paper  { background: var(--paper); color: var(--on-paper); }
.sec-paper-2{ background: var(--paper-2); color: var(--on-paper); }

/* Alias retrocompat — vecchie classi del style.css originale */
.sec-light  { background: var(--paper); color: var(--on-paper); }
.sec-light2 { background: var(--paper-2); color: var(--on-paper); }
.sec-light3 { background: var(--paper-2); color: var(--on-paper); }
.sec-border-light { border-color: var(--line-paper) !important; }

.sec-paper .eyebrow,
.sec-paper-2 .eyebrow,
.sec-light .eyebrow,
.sec-light2 .eyebrow,
.sec-light3 .eyebrow,
.sec-paper .sec-label,
.sec-paper-2 .sec-label,
.sec-light .sec-label,
.sec-light2 .sec-label,
.sec-light3 .sec-label { color: var(--accent-2); }

.sec-paper .lead, .sec-paper-2 .lead,
.sec-light .lead, .sec-light2 .lead, .sec-light3 .lead,
.sec-paper .sec-body, .sec-paper-2 .sec-body,
.sec-light .sec-body, .sec-light2 .sec-body, .sec-light3 .sec-body { color: var(--on-paper-2); }

.sec-paper p, .sec-paper-2 p,
.sec-light p, .sec-light2 p, .sec-light3 p { color: var(--on-paper-2); }

.sec-paper h1, .sec-paper h2, .sec-paper h3, .sec-paper h4,
.sec-paper-2 h1, .sec-paper-2 h2, .sec-paper-2 h3, .sec-paper-2 h4,
.sec-light h1, .sec-light h2, .sec-light h3, .sec-light h4,
.sec-light2 h1, .sec-light2 h2, .sec-light2 h3, .sec-light2 h4,
.sec-light3 h1, .sec-light3 h2, .sec-light3 h3, .sec-light3 h4,
.sec-paper .sec-title, .sec-paper-2 .sec-title,
.sec-light .sec-title, .sec-light2 .sec-title, .sec-light3 .sec-title { color: var(--on-paper); }

.sec-paper strong, .sec-paper-2 strong,
.sec-light strong, .sec-light2 strong, .sec-light3 strong { color: var(--on-paper); }
.sec-paper em, .sec-paper-2 em,
.sec-light em, .sec-light2 em, .sec-light3 em { color: var(--accent-2); }

/* Border sottile interno (Taste Skill: depth via border, non glow) */
.sec-border-top    { border-top: 1px solid var(--line); }
.sec-border-bottom { border-bottom: 1px solid var(--line); }
.sec-paper.sec-border-top    { border-top-color: var(--line-paper); }
.sec-paper.sec-border-bottom { border-bottom-color: var(--line-paper); }

/* Header di sezione — centrato simmetrico per coerenza con card uniformi */
.sec-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 60rem;
  margin: 0 auto var(--s-9);
  gap: var(--s-3);
}
.sec-head > div { display: contents; }
.sec-head .lead {
  margin-top: var(--s-3);
  margin-inline: auto;
}
.sec-head--centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 56rem;
  margin: 0 auto var(--s-9);
}

/* ── Navbar ──────────────────────────────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 100;
  display: flex; align-items: center;
  background: rgba(14, 16, 17, 0.7);
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.navbar.scrolled {
  background: rgba(14, 16, 17, 0.94);
  border-bottom-color: var(--line);
}
.nav-inner {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5);
}
.nav-logo img { height: 28px; width: auto; }
.nav-links {
  display: flex; align-items: center; gap: var(--s-6);
}
.nav-links a {
  font-size: 0.86rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink-2);
  position: relative;
  padding: var(--s-2) 0;
  transition: color var(--t-fast) var(--ease);
}
.nav-links a:hover { color: var(--ink); }
.nav-links a.active { color: var(--accent); }
.nav-links a.active::after {
  content: ''; position: absolute;
  left: 0; right: 0; bottom: -2px; height: 1px;
  background: var(--accent);
}
.nav-cta {
  padding: 0.55rem 1.1rem !important;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-pill);
  color: var(--ink) !important;
  transition: all var(--t-fast) var(--ease);
}
.nav-cta:hover {
  border-color: var(--accent);
  color: var(--accent) !important;
}
.nav-cta.active::after { display: none; }

.hamburger {
  display: none;
  width: 28px; height: 22px;
  flex-direction: column; justify-content: space-between;
  cursor: pointer;
}
.hamburger span {
  display: block; width: 100%; height: 1.5px;
  background: var(--ink);
  transition: transform var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease);
  transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(10px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

@media (max-width: 920px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
}

.mobile-menu {
  position: fixed; inset: var(--nav-h) 0 0 0;
  background: var(--bg);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: var(--s-5);
  transform: translateX(100%);
  transition: transform var(--t-base) var(--ease);
  z-index: 99;
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu a {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink);
  transition: color var(--t-fast) var(--ease);
}
.mobile-menu a:hover, .mobile-menu a.active { color: var(--accent); }

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn,
.btn-fill,
.btn-outline,
.btn-ghost {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 0.85rem 1.6rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  transition: all var(--t-fast) var(--ease);
  cursor: pointer;
  white-space: nowrap;
}
.btn-fill {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.btn-fill:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--bg);
}
.btn-outline {
  background: transparent;
  color: var(--ink);
  border-color: var(--line-2);
}
.btn-outline:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-mute);
}
.btn-ghost {
  background: transparent;
  color: var(--ink-2);
  border-color: transparent;
  padding-inline: var(--s-3);
}
.btn-ghost:hover { color: var(--accent); }

.sec-paper .btn-outline { border-color: var(--line-paper); color: var(--on-paper); }
.sec-paper .btn-outline:hover { border-color: var(--accent-2); color: var(--accent-2); background: var(--accent-mute); }
.sec-paper .btn-fill { background: var(--on-paper); color: var(--paper); border-color: var(--on-paper); }
.sec-paper .btn-fill:hover { background: var(--accent-2); border-color: var(--accent-2); color: var(--paper); }

/* ── Values list (numerata editorial, no flip card 3D) ─────────── */
.values-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--line);
}
.sec-paper .values-list,
.sec-paper-2 .values-list { border-top-color: var(--line-paper-2); }

.value-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-7);
  padding-block: var(--s-7);
  border-bottom: 1px solid var(--line);
  transition: background 0.4s var(--ease);
}
.sec-paper .value-row,
.sec-paper-2 .value-row { border-bottom-color: var(--line-paper-2); }

.value-row:hover { background: rgba(199, 154, 82, 0.03); }

.value-num {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.04em;
  color: var(--accent);
}
.value-body h3 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  letter-spacing: -0.025em;
  margin-bottom: var(--s-3);
  max-width: 22ch;
}
.value-body p {
  max-width: 60ch;
  line-height: 1.65;
  font-size: 1.04rem;
}
@media (max-width: 760px) {
  .value-row { grid-template-columns: 1fr; gap: var(--s-3); padding-block: var(--s-5); }
}

/* ── Page hero (variante type-first per pagine secondarie) ───── */
.page-hero {
  position: relative;
  padding-top: calc(var(--nav-h) + var(--s-9));
  padding-bottom: var(--s-9);
  background: var(--bg);
  color: var(--ink);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before {
  content: '';
  position: absolute;
  top: 0; right: -10%;
  width: 50%; height: 100%;
  background:
    radial-gradient(ellipse at center, rgba(199, 154, 82, 0.08), transparent 60%);
  pointer-events: none;
  z-index: -1;
}
.page-hero h1 {
  font-size: clamp(2.45rem, 6vw, 5.2rem);
  line-height: 1;
  letter-spacing: 0;
  font-weight: 700;
  margin-bottom: var(--s-5);
  max-width: 20ch;
}
.page-hero h1 .accent {
  color: var(--accent);
  font-style: italic;
}
.page-hero__lead {
  font-size: clamp(1.04rem, 1.4vw, 1.24rem);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 60ch;
  margin-top: var(--s-3);
}
.page-hero__actions {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
  margin-top: var(--s-6);
}

/* ── Network strip (statement editoriale, no marquee) ──────────── */
.network-strip {
  background: var(--bg);
  color: var(--ink);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.network-strip__title {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  letter-spacing: -0.025em;
  margin-bottom: var(--s-7);
  max-width: 22ch;
}
.network-strip__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3) var(--s-5);
  font-family: var(--font-mono);
  font-size: 0.92rem;
  color: var(--ink-2);
  list-style: none;
  padding: 0;
}
.network-strip__list li {
  position: relative;
  padding-left: var(--s-3);
}
.network-strip__list li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.5em;
  width: 4px; height: 4px;
  background: var(--accent);
  border-radius: 50%;
}

/* ── Hero TYPE-FIRST (2026 — Linear/Vercel/Stripe-style) ─────────── */
.hero-type {
  position: relative;
  padding-top: calc(var(--nav-h) + var(--s-10));
  padding-bottom: var(--s-9);
  background: var(--bg);
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
  border-bottom: 1px solid var(--line);
}
.hero-type::before {
  content: '';
  position: absolute;
  top: -10%; left: -5%;
  width: 60%; height: 70%;
  background:
    radial-gradient(ellipse at center, rgba(199, 154, 82, 0.10), transparent 60%);
  pointer-events: none;
  z-index: -1;
}
.hero-type::after {
  content: '';
  position: absolute;
  bottom: -10%; right: -5%;
  width: 60%; height: 70%;
  background:
    radial-gradient(ellipse at center, rgba(199, 154, 82, 0.06), transparent 60%);
  pointer-events: none;
  z-index: -1;
}
.hero-type__title {
  font-size: clamp(3.4rem, 11vw, 11rem);
  line-height: 0.92;
  letter-spacing: -0.04em;
  font-weight: 700;
  margin-bottom: var(--s-7);
  max-width: 14ch;
}
.hero-type__title .accent {
  color: var(--accent);
  font-style: italic;
}
.hero-type__split {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--s-6);
  align-items: end;
  margin-bottom: var(--s-9);
  padding-top: var(--s-5);
  border-top: 1px solid var(--line);
}
.hero-type__lead {
  font-size: clamp(1.04rem, 1.5vw, 1.32rem);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 56ch;
}
.hero-type__actions {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
  justify-content: flex-end;
}
.hero-type__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
  padding-top: var(--s-6);
}
.hero-type__stats > div {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  border-left: 1px solid var(--line);
  padding-left: var(--s-4);
}
.hero-type__stats > div:first-child {
  border-left: 0;
  padding-left: 0;
}
.hero-type__stats .num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--ink);
}
.hero-type__stats .lab {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: var(--ink-3);
}
@media (max-width: 920px) {
  .hero-type__split { grid-template-columns: 1fr; align-items: start; }
  .hero-type__actions { justify-content: flex-start; }
  .hero-type__stats { grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
  .hero-type__stats > div:nth-child(3) { border-left: 0; padding-left: 0; }
}

/* ── Hero (legacy, alcune pagine ancora in uso) ──────────────────── */
.hero {
  position: relative;
  min-height: 92vh;
  padding-top: calc(var(--nav-h) + var(--s-7));
  padding-bottom: var(--s-9);
  display: flex; align-items: center;
  overflow: hidden;
}
.hero-photo { background-size: cover; background-position: center; }
.hero-photo::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,16,17,0.55) 0%, rgba(14,16,17,0.85) 60%, rgba(14,16,17,0.96) 100%);
  z-index: 1;
}
.hero-content {
  position: relative; z-index: 2;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
  gap: var(--s-7);
  align-items: end;
}
@media (max-width: 920px) {
  .hero-content { grid-template-columns: 1fr; gap: var(--s-5); }
}
.hero h1 {
  font-size: clamp(2.8rem, 9vw, 7.5rem);
  letter-spacing: -0.025em;
}
.hero h1 .accent { color: var(--accent); }
.hero-meta {
  display: flex; flex-direction: column; gap: var(--s-4);
  padding-bottom: var(--s-2);
}
.hero-meta .label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink-3);
  border-top: 1px solid var(--line);
  padding-top: var(--s-3);
}
.hero-meta .label strong { color: var(--ink); display: block; font-size: 0.9rem; margin-top: 4px; }
.hero-sub {
  font-size: var(--type-body-lg);
  line-height: var(--lead-relax);
  color: var(--ink-2);
  max-width: 56ch;
  margin-top: var(--s-5);
  font-weight: 300;
}
.hero-btns {
  display: flex; flex-wrap: wrap; gap: var(--s-3);
  margin-top: var(--s-6);
}
.scroll-ind {
  position: absolute;
  bottom: var(--s-6);
  right: var(--gutter);
  z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: var(--s-3);
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink-3);
  text-transform: uppercase;
  writing-mode: vertical-rl;
}
.scroll-ind .scroll-line {
  width: 1px; height: 60px;
  background: linear-gradient(180deg, var(--ink-3) 0%, transparent 100%);
  animation: scroll-pulse 2.4s var(--ease) infinite;
}
@keyframes scroll-pulse {
  0%, 100% { transform: scaleY(1); transform-origin: top; opacity: 0.4; }
  50%      { transform: scaleY(1); opacity: 1; }
}

/* ── Marquee (singolo, asciutto) ─────────────────────────────────── */
.marquee {
  position: relative;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding-block: var(--s-5);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, black 12%, black 88%, transparent);
          mask-image: linear-gradient(90deg, transparent, black 12%, black 88%, transparent);
}
.marquee-track {
  display: flex; gap: var(--s-9);
  white-space: nowrap;
  animation: marquee 42s linear infinite;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--ink-2);
}
.marquee-track span { display: inline-flex; align-items: center; gap: var(--s-4); }
.marquee-track .diamond { color: var(--accent); font-size: 0.6em; }
.marquee.sec-paper {
  background: var(--paper);
  border-color: var(--line-paper);
}
.marquee.sec-paper .marquee-track { color: var(--on-paper-3); }
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ── Stats (asimmetria intenzionale, no counter cliché) ─────────── */
.stats {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
  gap: var(--s-5);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding-block: var(--s-7);
}
.stat-item {
  display: flex; flex-direction: column; gap: var(--s-2);
  padding-inline: var(--s-3);
  border-left: 1px solid var(--line);
}
.stat-item:first-child { border-left: 0; padding-left: 0; }
.stat-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  line-height: 1;
  letter-spacing: var(--track-tight);
  color: var(--ink);
}
.stat-label {
  font-family: var(--font-body);
  font-size: 0.82rem;
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.sec-paper .stats,
.sec-paper-2 .stats { border-color: var(--line-paper); }
.sec-paper .stat-item,
.sec-paper-2 .stat-item { border-left-color: var(--line-paper); }
.sec-paper .stat-num,
.sec-paper-2 .stat-num   { color: var(--on-paper); }
.sec-paper .stat-label,
.sec-paper-2 .stat-label { color: var(--on-paper-3); }
.sec-paper .stat-item:hover .stat-num,
.sec-paper-2 .stat-item:hover .stat-num { color: var(--accent-2); }
@media (max-width: 760px) {
  .stats { grid-template-columns: 1fr 1fr; }
  .stat-item { border-left: 0; padding: 0; }
}

/* ── Pillars (uniformi 3-col, stesse dimensioni) ─────────────────── */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  align-items: stretch;
}
@media (max-width: 1080px) { .pillars { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px)  { .pillars { grid-template-columns: 1fr; } }

.pillar {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--s-7) var(--s-6);
  display: flex; flex-direction: column; gap: var(--s-4);
  position: relative;
  transition: border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.pillar:hover { border-color: var(--line-2); transform: translateY(-2px); }
.pillar h3 { margin-bottom: var(--s-2); }
.pillar p { color: var(--ink-2); }
.pillar ul { display: flex; flex-direction: column; gap: var(--s-2); margin-top: var(--s-3); }
.pillar li {
  position: relative;
  padding-left: var(--s-5);
  font-size: 0.94rem;
  color: var(--ink-2);
  line-height: var(--lead-snug);
}
.pillar li::before {
  content: ''; position: absolute;
  left: 0; top: 0.65em;
  width: 14px; height: 1px;
  background: var(--accent);
}
.pillar li strong { color: var(--ink); }

.sec-paper .pillar,
.sec-paper-2 .pillar {
  background: var(--paper-card);
  border-color: var(--line-paper);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 18px 36px -28px rgba(28,26,20,0.18);
}
.sec-paper .pillar:hover,
.sec-paper-2 .pillar:hover {
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 30px 60px -32px rgba(28,26,20,0.30);
}
.sec-paper .pillar p, .sec-paper .pillar li,
.sec-paper-2 .pillar p, .sec-paper-2 .pillar li { color: var(--on-paper-2); }
.sec-paper .pillar li strong,
.sec-paper-2 .pillar li strong { color: var(--on-paper); }

/* ── Services grid (uniforme — tutte stesse dimensioni) ─────────── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
.services-grid .card,
.services-grid .card.card-wide,
.services-grid .card.card-narrow { grid-column: span 1; }
@media (max-width: 1080px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .services-grid { grid-template-columns: 1fr; gap: var(--s-3); } }

.card {
  position: relative;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--s-7) var(--s-6);
  display: flex; flex-direction: column; gap: var(--s-3);
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
  min-height: 240px;
}
.card:hover { border-color: var(--line-2); background: var(--bg-3); }
.card .card-tag {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.7rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--s-2);
}
.card h3 { margin-bottom: var(--s-2); }
.card p { color: var(--ink-2); flex-grow: 1; }
.card-link {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--accent);
  letter-spacing: 0.02em;
  margin-top: var(--s-4);
  display: inline-flex; align-items: center; gap: var(--s-2);
  transition: gap var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.card-link:hover { gap: var(--s-3); color: var(--accent-2); }

.sec-paper .card,
.sec-paper-2 .card {
  background: var(--paper-card);
  border-color: var(--line-paper);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 18px 36px -28px rgba(28,26,20,0.18);
}
.sec-paper .card:hover,
.sec-paper-2 .card:hover {
  background: var(--paper-card);
  border-color: var(--accent-2);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 30px 60px -28px rgba(28,26,20,0.32);
}
.sec-paper .card p,
.sec-paper-2 .card p { color: var(--on-paper-2); }

/* ── Studenti / News cards (uniformi 4 col, aspect 4:5) ──────────── */
.student-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
.student-card {
  display: flex; flex-direction: column; gap: var(--s-3);
  position: relative;
}
@media (max-width: 1080px) { .student-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .student-grid { grid-template-columns: 1fr; } }

.student-avatar {
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.student-avatar img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.9s var(--ease);
}
.student-card:hover .student-avatar img { transform: scale(1.04); }
.student-avatar::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(14,16,17,0.6) 100%);
  pointer-events: none;
}
.student-avatar .badge {
  position: absolute;
  top: var(--s-3); left: var(--s-3);
  z-index: 2;
  background: rgba(14, 16, 17, 0.7);
  backdrop-filter: blur(6px);
  border: 1px solid var(--line-2);
  color: var(--ink);
  padding: 0.3rem 0.7rem;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  border-radius: var(--radius-pill);
}
.student-info h3 { font-size: 1.18rem; line-height: var(--lead-snug); }
.student-info p { color: var(--ink-2); font-size: 0.92rem; }

.sec-paper .student-avatar,
.sec-paper-2 .student-avatar { background: var(--paper-2); border-color: var(--line-paper); }
.sec-paper .student-info p,
.sec-paper-2 .student-info p { color: var(--on-paper-2); }

/* ── Steps 4 con numerazione editorial ──────────────────────────── */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
  counter-reset: step;
}
.step {
  display: flex; flex-direction: column; gap: var(--s-3);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line);
  position: relative;
  counter-increment: step;
}
.step::before {
  content: counter(step, decimal-leading-zero);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: var(--track-eyebrow);
  color: var(--accent);
}
.step h4 { margin-top: var(--s-2); }
.step p { color: var(--ink-2); }
.sec-paper .step,
.sec-paper-2 .step { border-top-color: var(--line-paper-2); }
.sec-paper .step p,
.sec-paper-2 .step p { color: var(--on-paper-2); }
@media (max-width: 920px) { .steps-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .steps-grid { grid-template-columns: 1fr; } }

/* ── Blog cards (uniformi 3 col, aspect 4:3) ────────────────────── */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
.blog-grid .blog-card,
.blog-grid .blog-card:first-child { grid-column: span 1; }
@media (max-width: 920px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
  display: flex; flex-direction: column; gap: var(--s-4);
  background: transparent;
  position: relative;
}
.blog-card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.blog-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.9s var(--ease);
}
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-body { display: flex; flex-direction: column; gap: var(--s-3); }
.blog-card-meta {
  display: flex; align-items: center; gap: var(--s-3);
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-3);
}
.blog-card-meta .tag { color: var(--accent); }
.blog-card h3 { font-size: 1.32rem; line-height: var(--lead-snug); }
.blog-card h3 a { transition: color var(--t-fast) var(--ease); }
.blog-card:hover h3 a { color: var(--accent); }
.blog-card .excerpt { color: var(--ink-2); font-size: 0.96rem; }
.sec-paper .blog-card-img,
.sec-paper-2 .blog-card-img { background: var(--paper-2); border-color: var(--line-paper); }
.sec-paper .blog-card .excerpt,
.sec-paper-2 .blog-card .excerpt { color: var(--on-paper-2); }

/* ── Form ────────────────────────────────────────────────────────── */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
}
@media (max-width: 640px) { .form-grid { grid-template-columns: 1fr; } }
.form-group { display: flex; flex-direction: column; gap: var(--s-2); }
.form-group.full { grid-column: 1 / -1; }
.form-group label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink-3);
}
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0.85rem var(--s-4);
  color: var(--ink);
  font-size: 0.96rem;
  font-family: var(--font-body);
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
  width: 100%;
}
.form-group textarea { min-height: 130px; resize: vertical; }
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--ink-4); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--accent);
  background: var(--bg-3);
  outline: none;
}
.form-check { display: flex; align-items: flex-start; gap: var(--s-3); }
.form-check input[type="checkbox"] {
  appearance: none; -webkit-appearance: none;
  width: 18px; height: 18px;
  border: 1px solid var(--line-2);
  border-radius: 3px;
  background: var(--bg-2);
  cursor: pointer; flex-shrink: 0;
  margin-top: 2px;
  position: relative;
  transition: all var(--t-fast) var(--ease);
}
.form-check input[type="checkbox"]:checked {
  background: var(--accent);
  border-color: var(--accent);
}
.form-check input[type="checkbox"]:checked::after {
  content: ''; position: absolute;
  left: 5px; top: 1px; width: 6px; height: 11px;
  border-right: 2px solid var(--bg);
  border-bottom: 2px solid var(--bg);
  transform: rotate(45deg);
}
.form-check label { color: var(--ink-2); font-size: 0.86rem; line-height: var(--lead-snug); cursor: pointer; }
.form-status { padding: var(--s-3) var(--s-4); border-radius: var(--radius); font-size: 0.9rem; margin-top: var(--s-3); display: none; }
.form-status.loading { background: var(--bg-2); color: var(--ink-2); border: 1px solid var(--line); }
.form-status.success { background: rgba(122,229,130,0.08); color: #7ae582; border: 1px solid rgba(122,229,130,0.3); }
.form-status.error   { background: rgba(255,84,84,0.08); color: #ff8a8a; border: 1px solid rgba(255,84,84,0.3); }

.sec-paper .form-group input,
.sec-paper .form-group select,
.sec-paper .form-group textarea,
.sec-paper-2 .form-group input,
.sec-paper-2 .form-group select,
.sec-paper-2 .form-group textarea {
  background: var(--paper-card); border-color: var(--line-paper); color: var(--on-paper);
}
.sec-paper .form-group input::placeholder,
.sec-paper .form-group textarea::placeholder,
.sec-paper-2 .form-group input::placeholder,
.sec-paper-2 .form-group textarea::placeholder { color: var(--on-paper-3); }
.sec-paper .form-group input:focus,
.sec-paper .form-group select:focus,
.sec-paper .form-group textarea:focus,
.sec-paper-2 .form-group input:focus,
.sec-paper-2 .form-group select:focus,
.sec-paper-2 .form-group textarea:focus { border-color: var(--accent-2); background: var(--paper-card); }
.sec-paper .form-group label,
.sec-paper-2 .form-group label { color: var(--on-paper-2); }
.sec-paper .form-check input[type="checkbox"],
.sec-paper-2 .form-check input[type="checkbox"] { background: var(--paper-card); border-color: var(--line-paper-2); }
.sec-paper .form-check label,
.sec-paper-2 .form-check label { color: var(--on-paper-2); }

/* ── FAQ ─────────────────────────────────────────────────────────── */
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-bottom: 1px solid var(--line);
  padding-block: var(--s-5);
}
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center; gap: var(--s-4);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.18rem;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--ink);
  cursor: pointer;
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  padding: 0;
}
.faq-q::after {
  content: ''; flex-shrink: 0;
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none'><path d='M7 1v12M1 7h12' stroke='%23c8a55a' stroke-width='1.5'/></svg>");
  background-size: contain; background-repeat: no-repeat;
  transition: transform var(--t-fast) var(--ease);
}
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height var(--t-base) var(--ease);
}
.faq-item.open .faq-a { max-height: 600px; }
.faq-a p { padding-top: var(--s-3); color: var(--ink-2); max-width: 70ch; }
.sec-paper .faq-item { border-bottom-color: var(--line-paper); }
.sec-paper .faq-item:first-child { border-top-color: var(--line-paper); }
.sec-paper .faq-q { color: var(--on-paper); }
.sec-paper .faq-a p { color: var(--on-paper-2); }

/* ── Footer ─────────────────────────────────────────────────────── */
.footer {
  background: #0a0c0d;
  border-top: 1px solid var(--line);
  padding-block: var(--s-9) var(--s-6);
  color: var(--ink-2);
}
.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-7);
  margin-bottom: var(--s-8);
}
@media (max-width: 760px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }

.footer-brand img { height: 30px; width: auto; margin-bottom: var(--s-4); }
.footer-brand p { font-size: 0.9rem; color: var(--ink-3); max-width: 36ch; line-height: var(--lead-relax); }
.footer h5 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink);
  margin-bottom: var(--s-4);
}
.footer-col ul { display: flex; flex-direction: column; gap: var(--s-2); }
.footer-col a {
  font-size: 0.92rem;
  color: var(--ink-3);
  transition: color var(--t-fast) var(--ease);
}
.footer-col a:hover { color: var(--accent); }
.footer-bottom {
  display: flex; flex-wrap: wrap; gap: var(--s-4);
  justify-content: space-between; align-items: center;
  padding-top: var(--s-5);
  border-top: 1px solid var(--line);
  font-size: 0.82rem;
  color: var(--ink-3);
}
.footer-social { display: flex; gap: var(--s-3); }
.footer-social a {
  width: 36px; height: 36px;
  border: 1px solid var(--line);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-2);
  transition: all var(--t-fast) var(--ease);
}
.footer-social a:hover { border-color: var(--accent); color: var(--accent); }
.footer-social svg { width: 16px; height: 16px; }

/* ── Cookie banner ──────────────────────────────────────────────── */
.cookie-banner {
  position: fixed; left: var(--s-5); right: var(--s-5); bottom: var(--s-5);
  max-width: 580px; margin: 0 auto;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
  display: flex; flex-wrap: wrap; gap: var(--s-4); align-items: center;
  z-index: 200;
  transform: translateY(calc(100% + var(--s-5)));
  transition: transform var(--t-base) var(--ease);
  box-shadow: var(--shadow-2);
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner p { font-size: 0.86rem; color: var(--ink-2); flex: 1 1 240px; }
.cookie-banner a { color: var(--accent); }
.cookie-accept {
  background: var(--ink); color: var(--bg);
  border: 0; border-radius: var(--radius-pill);
  padding: 0.6rem 1.2rem;
  font-weight: 600; font-size: 0.86rem;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
}
.cookie-accept:hover { background: var(--accent); }

/* ── Reveal animation v2 (MOTION_INTENSITY 7 — full) ─────────────── */
.rv {
  opacity: 0;
  transform: translateY(48px) scale(0.96);
  transition:
    opacity 1s var(--ease),
    transform 1.1s var(--ease);
  will-change: opacity, transform;
}
.rv.vis { opacity: 1; transform: translateY(0) scale(1); }
.rv.d1 { transition-delay: 0.08s; }
.rv.d2 { transition-delay: 0.16s; }
.rv.d3 { transition-delay: 0.24s; }
.rv.d4 { transition-delay: 0.32s; }
.rv.d5 { transition-delay: 0.40s; }

/* Reveal varianti per effetti diversi (usate ad-hoc) */
.rv-left  { opacity: 0; transform: translateX(-40px); transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease); }
.rv-right { opacity: 0; transform: translateX(40px);  transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease); }
.rv-left.vis, .rv-right.vis { opacity: 1; transform: translateX(0); }

/* ── 3D Tilt cards (perspective globale, mousemove tracking via JS) ── */
.tilt-wrap {
  perspective: 1200px;
  perspective-origin: center;
}
.tilt {
  transform-style: preserve-3d;
  transition: transform 0.6s var(--ease);
  will-change: transform;
}
.tilt-inner {
  transform: translateZ(0);
  transition: transform 0.6s var(--ease);
}
.tilt:hover .tilt-inner { transform: translateZ(28px); }

/* Default: rendi tutte le .card e .pillar e .student-card tilt-aware */
.card, .pillar, .student-card, .blog-card {
  transform-style: preserve-3d;
  transition:
    transform 0.6s var(--ease),
    border-color var(--t-fast) var(--ease),
    background var(--t-fast) var(--ease),
    box-shadow var(--t-fast) var(--ease);
  will-change: transform;
}
.card:hover, .pillar:hover {
  transform: translateY(-6px);
  box-shadow:
    0 30px 60px -30px rgba(0, 0, 0, 0.7),
    0 1px 0 rgba(255, 255, 255, 0.06) inset;
}

/* ── Hero parallax + shimmer ──────────────────────────────────── */
.hero-photo::before {
  /* Vignette + scura più drammatica */
  background:
    radial-gradient(ellipse at 30% 40%, rgba(200,165,90,0.12), transparent 55%),
    linear-gradient(180deg, rgba(14,16,17,0.5) 0%, rgba(14,16,17,0.85) 60%, rgba(14,16,17,0.98) 100%);
}
.hero-photo {
  /* Background layer parallax: il JS sposta solo background-position-y */
  will-change: background-position;
}

/* Shimmer sul titolo hero — riflesso dorato che passa */
.hero h1 .accent {
  background: linear-gradient(
    100deg,
    var(--accent) 0%,
    var(--accent) 35%,
    #fbecc6 50%,
    var(--accent) 65%,
    var(--accent) 100%
  );
  background-size: 200% 100%;
  background-position: 200% 0;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
  animation: shimmer 4.5s ease-in-out infinite;
  animation-delay: 1.2s;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  60%  { background-position: -200% 0; }
  100% { background-position: -200% 0; }
}

/* Outline letter glow sul hover dell'h1 */
.hero h1 .outline {
  transition: -webkit-text-stroke-color var(--t-base) var(--ease), color var(--t-base) var(--ease);
}
.hero h1:hover .outline {
  -webkit-text-stroke-color: var(--accent);
}

/* ── Magnetic button effect (CSS portion, JS handles tracking) ─── */
.btn-fill, .btn-outline, .nav-cta {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.3s var(--ease), background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.btn-fill::before, .btn-outline::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), var(--accent-mute) 0%, transparent 50%);
  opacity: 0;
  transition: opacity var(--t-fast) var(--ease);
  z-index: -1;
}
.btn-fill:hover::before, .btn-outline:hover::before { opacity: 1; }
.btn-fill:hover, .btn-outline:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px -16px rgba(0, 0, 0, 0.5);
}

/* ── Card-link arrow magnetic ───────────────────────────────────── */
.card-link {
  position: relative;
  overflow: hidden;
}
.card-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.5s var(--ease);
}
.card-link:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* ── Number counter — entrance bounce ────────────────────────── */
.stat-num {
  display: inline-block;
  transition: transform 0.4s var(--ease);
}
.stat-item:hover .stat-num {
  transform: scale(1.06);
  color: var(--accent);
}

/* ── Pillar — accent line che si estende su hover ─────────────── */
.pillar { position: relative; overflow: hidden; }
.pillar::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--accent), transparent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.7s var(--ease);
}
.pillar:hover::after { transform: scaleY(1); }

/* ── Studenti card — zoom + caption slide ─────────────────────── */
.student-card { transform-style: preserve-3d; }
.student-card:hover .student-info h3 { color: var(--accent); }
.student-info h3 { transition: color var(--t-base) var(--ease); }

/* ── Blog card — image scale + meta animate ─────────────────── */
.blog-card .blog-card-img {
  position: relative;
  overflow: hidden;
}
.blog-card .blog-card-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(14,16,17,0.5) 100%);
  opacity: 0;
  transition: opacity var(--t-base) var(--ease);
  pointer-events: none;
}
.blog-card:hover .blog-card-img::after { opacity: 1; }

/* ── Marquee — pausa su hover (sembra meno automatico) ───────── */
.marquee:hover .marquee-track { animation-play-state: paused; }

/* ── Scroll progress bar ─────────────────────────────────────── */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  z-index: 200;
  width: 0;
  transition: width 0.1s linear;
  pointer-events: none;
}

/* ── Section parallax bg (immagine drammatica con overlay) ─────── */
.sec-parallax {
  position: relative;
  background-color: var(--bg);
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  isolation: isolate;
  color: var(--ink);
}
.sec-parallax::before {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(14,16,17,0.75) 0%, rgba(14,16,17,0.92) 100%),
    radial-gradient(ellipse at 30% 30%, rgba(200,165,90,0.18), transparent 60%);
  z-index: -1;
}
.sec-parallax .lead { color: var(--ink-2); }
.sec-parallax p { color: var(--ink-2); }
@media (max-width: 920px) {
  .sec-parallax { background-attachment: scroll; }
}

/* Pulled quote / statement section */
.statement {
  text-align: center;
  max-width: 32ch;
  margin-inline: auto;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.statement .accent { color: var(--accent); }

/* ── Showcase gallery (immagini grandi, layout asymmetric mosaic) ── */
.showcase {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 180px;
  gap: var(--s-4);
}
.showcase-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--bg-2);
  isolation: isolate;
}
.showcase-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
}
.showcase-item:hover img { transform: scale(1.06); }
.showcase-item::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(14,16,17,0.78) 100%);
  pointer-events: none;
}
.showcase-caption {
  position: absolute;
  bottom: var(--s-4); left: var(--s-4); right: var(--s-4);
  z-index: 2;
  color: var(--ink);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.showcase-caption .pill { color: var(--accent); background: rgba(14,16,17,0.5); border-color: var(--line-2); margin-bottom: var(--s-2); display: inline-flex; }
.showcase-item.s-tall { grid-column: span 4; grid-row: span 3; }
.showcase-item.s-wide { grid-column: span 8; grid-row: span 2; }
.showcase-item.s-lg   { grid-column: span 6; grid-row: span 2; }
.showcase-item.s-md   { grid-column: span 4; grid-row: span 2; }
.showcase-item.s-sm   { grid-column: span 4; grid-row: span 1; }
@media (max-width: 920px) {
  .showcase { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 140px; }
  .showcase-item.s-tall { grid-column: span 6; grid-row: span 2; }
  .showcase-item.s-wide,
  .showcase-item.s-lg   { grid-column: span 6; grid-row: span 2; }
  .showcase-item.s-md,
  .showcase-item.s-sm   { grid-column: span 3; grid-row: span 2; }
}
@media (max-width: 560px) {
  .showcase { grid-template-columns: 1fr; grid-auto-rows: 200px; }
  .showcase-item.s-tall,
  .showcase-item.s-wide,
  .showcase-item.s-lg,
  .showcase-item.s-md,
  .showcase-item.s-sm { grid-column: 1 / -1; grid-row: span 1; }
}

/* ── Glass card variant (deep depth) ─────────────────────────── */
.glass {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.01) 100%),
    var(--bg-2);
  border: 1px solid var(--line-2);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.05) inset,
    0 24px 48px -24px rgba(0,0,0,0.5);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .rv, .rv-left, .rv-right { opacity: 1; transform: none; }
  .hero h1 .accent { animation: none; -webkit-text-fill-color: var(--accent); color: var(--accent); }
}

/* ── Utility ─────────────────────────────────────────────────────── */
.text-center { text-align: center; }
.mt-3 { margin-top: var(--s-7); }
.mt-4 { margin-top: var(--s-8); }
.mb-3 { margin-bottom: var(--s-7); }
.mb-4 { margin-bottom: var(--s-8); }
.gold { color: var(--accent); }
.outline {
  -webkit-text-stroke: 1px var(--ink);
  color: transparent;
  letter-spacing: 0.02em;
}
.divider {
  height: 1px; background: var(--line);
  margin-block: var(--s-7);
}
.pill {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 0.32rem 0.85rem;
  background: var(--accent-mute);
  border: 1px solid rgba(200, 165, 90, 0.28);
  color: var(--accent);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
}

/* ── Blog post layout (per pagine /blog/*.html) ─────────────────── */
.blog-post {
  max-width: 780px;
  margin: 0 auto;
  padding-top: calc(var(--nav-h) + var(--s-7));
  padding-bottom: var(--s-9);
  padding-inline: var(--gutter);
}
.blog-post header {
  margin-bottom: var(--s-7);
  border-bottom: 1px solid var(--line);
  padding-bottom: var(--s-6);
}
.blog-post h1 {
  font-size: clamp(2rem, 5vw, 3.4rem);
  line-height: var(--lead-tight);
  text-transform: none;
  letter-spacing: -0.01em;
  margin-bottom: var(--s-4);
}
.blog-post .meta {
  display: flex; gap: var(--s-3); flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: 0.74rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-3);
}
.blog-post .meta .tag { color: var(--accent); }
.blog-post .lead {
  font-size: 1.18rem;
  color: var(--ink-2);
  margin-top: var(--s-4);
  font-weight: 300;
  line-height: var(--lead-relax);
}
.blog-post article { font-size: 1.05rem; line-height: 1.8; color: var(--ink-2); }
.blog-post article h2 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.7rem;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin-top: var(--s-7);
  margin-bottom: var(--s-4);
}
.blog-post article h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.28rem;
  text-transform: none;
  color: var(--ink);
  margin-top: var(--s-5);
  margin-bottom: var(--s-3);
}
.blog-post article p { margin-bottom: var(--s-4); }
.blog-post article ul, .blog-post article ol { margin: var(--s-4) 0 var(--s-4) var(--s-5); }
.blog-post article ul li { list-style: disc; margin-bottom: var(--s-2); }
.blog-post article ol li { list-style: decimal; margin-bottom: var(--s-2); }
.blog-post article a { color: var(--accent); border-bottom: 1px solid var(--accent); }
.blog-post article a:hover { color: var(--accent-2); border-bottom-color: var(--accent-2); }
.blog-post article blockquote {
  border-left: 2px solid var(--accent);
  padding-left: var(--s-4);
  margin: var(--s-5) 0;
  color: var(--ink);
  font-style: italic;
  font-size: 1.12rem;
}
.toc {
  position: sticky; top: calc(var(--nav-h) + var(--s-4));
  border-left: 1px solid var(--line);
  padding-left: var(--s-4);
}
.toc h5 {
  font-family: var(--font-display);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: var(--track-eyebrow);
  color: var(--ink-3);
  margin-bottom: var(--s-3);
}
.toc-link {
  display: block;
  padding: var(--s-1) 0;
  font-size: 0.86rem;
  color: var(--ink-3);
  transition: color var(--t-fast) var(--ease);
}
.toc-link:hover, .toc-link.active { color: var(--accent); }

/* ── Page header generico (non-home) — leggibile, foto centrata ── */
.page-head {
  position: relative;
  padding-top: calc(var(--nav-h) + var(--s-9));
  padding-bottom: var(--s-9);
  min-height: 60vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}
.page-head.has-photo {
  background-color: var(--bg);
  background-size: cover;
  background-position: center;
  color: var(--ink);
}
.page-head.has-photo::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(200,165,90,0.12), transparent 55%),
    linear-gradient(180deg, rgba(14,16,17,0.6) 0%, rgba(14,16,17,0.85) 70%, rgba(14,16,17,0.96) 100%);
  z-index: -1;
}
.page-head .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--s-3);
  max-width: 56rem;
}
.page-head h1 {
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: var(--lead-tight);
  letter-spacing: var(--track-tight);
  /* NIENTE outline su page-head — testo leggibile, simmetrico */
}
.page-head h1 .accent { color: var(--accent); }
.page-head .lead {
  color: var(--ink-2);
  margin-top: var(--s-3);
  margin-inline: auto;
  max-width: 52ch;
}

/* ── Flip card 3D (front/back) ───────────────────────────────── */
.flip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  perspective: 1500px;
}
@media (max-width: 1080px) { .flip-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .flip-grid { grid-template-columns: 1fr; } }

.flip-card {
  position: relative;
  aspect-ratio: 4 / 5;
  transform-style: preserve-3d;
  transition: transform 0.9s var(--ease);
  cursor: pointer;
  will-change: transform;
}
.flip-card:hover,
.flip-card:focus-within { transform: rotateY(180deg); }

.flip-face {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  overflow: hidden;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  display: flex;
  flex-direction: column;
}
.flip-face--front {
  background: var(--bg-2);
}
.flip-face--front img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.flip-face--front::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(14,16,17,0.85) 100%);
  pointer-events: none;
}
.flip-face--front .flip-front-info {
  position: absolute;
  bottom: var(--s-5); left: var(--s-5); right: var(--s-5);
  z-index: 2;
  color: var(--ink);
}
.flip-face--front .flip-front-info .pill { margin-bottom: var(--s-2); display: inline-flex; }
.flip-face--front .flip-front-info h3 { font-size: 1.18rem; }

.flip-face--back {
  background: var(--bg-2);
  transform: rotateY(180deg);
  padding: var(--s-6);
  justify-content: space-between;
  color: var(--ink);
}
.flip-face--back .pill { align-self: flex-start; margin-bottom: var(--s-3); }
.flip-face--back h3 { color: var(--ink); margin-bottom: var(--s-3); }
.flip-face--back p { color: var(--ink-2); font-size: 0.94rem; line-height: var(--lead-snug); }
.flip-face--back ul { display: flex; flex-direction: column; gap: var(--s-2); margin-top: var(--s-3); }
.flip-face--back li {
  position: relative;
  padding-left: var(--s-4);
  font-size: 0.86rem;
  color: var(--ink-2);
}
.flip-face--back li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.65em;
  width: 10px; height: 1px;
  background: var(--accent);
}
.flip-face--back .flip-cta {
  margin-top: auto;
  padding-top: var(--s-4);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  color: var(--accent);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.88rem;
}

/* Light variant per sezioni paper */
.sec-paper .flip-face,
.sec-paper-2 .flip-face,
.sec-light .flip-face,
.sec-light2 .flip-face,
.sec-light3 .flip-face { border-color: var(--line-paper); }
.sec-paper .flip-face--front,
.sec-paper-2 .flip-face--front,
.sec-light .flip-face--front,
.sec-light2 .flip-face--front,
.sec-light3 .flip-face--front { background: var(--paper-2); }
.sec-paper .flip-face--back,
.sec-paper-2 .flip-face--back,
.sec-light .flip-face--back,
.sec-light2 .flip-face--back,
.sec-light3 .flip-face--back {
  background: var(--paper-card);
  color: var(--on-paper);
}
.sec-paper .flip-face--back h3,
.sec-paper-2 .flip-face--back h3 { color: var(--on-paper); }
.sec-paper .flip-face--back p,
.sec-paper-2 .flip-face--back p,
.sec-paper .flip-face--back li,
.sec-paper-2 .flip-face--back li { color: var(--on-paper-2); }

/* ── Horizontal scroll (GSAP pinned su desktop, swipe nativo su mobile) ── */
.h-scroll {
  position: relative;
  overflow: hidden;
}
.h-scroll-track {
  display: flex;
  gap: var(--s-5);
  width: max-content;
  padding-inline: var(--gutter);
  will-change: transform;
}
.h-scroll-track .h-card {
  flex: 0 0 360px;
  aspect-ratio: 3 / 4;
  position: relative;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
  background: var(--bg-2);
  transition: transform 0.4s var(--ease), border-color 0.3s var(--ease);
}
.h-scroll-track .h-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease), filter 0.5s var(--ease);
  filter: brightness(0.85);
}
.h-scroll-track .h-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(14,16,17,0.92) 100%);
  pointer-events: none;
  z-index: 1;
}
.h-scroll-track .h-card:hover img { transform: scale(1.06); filter: brightness(1); }
.h-scroll-track .h-card:hover { border-color: var(--accent); }
.h-card-meta {
  position: absolute;
  bottom: var(--s-5); left: var(--s-5); right: var(--s-5);
  z-index: 2;
  color: var(--ink);
}
.h-card-meta .pill {
  background: rgba(14,16,17,0.6);
  border-color: var(--line-2);
  color: var(--accent);
  margin-bottom: var(--s-2);
  display: inline-flex;
}
.h-card-meta h3 {
  color: var(--ink);
  font-size: 1.32rem;
  line-height: var(--lead-tight);
  letter-spacing: var(--track-tight);
  text-transform: none;
}
.h-card-meta p {
  color: var(--ink-2);
  font-size: 0.88rem;
  margin-top: var(--s-2);
}

/* Hint scroll su desktop (compare prima dell'animazione) */
.h-scroll-hint {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-4);
  padding-inline: var(--gutter);
}
.h-scroll-hint::before {
  content: '↓';
  color: var(--accent);
  font-size: 1rem;
}
.h-scroll-hint::after {
  content: '→';
  color: var(--accent);
  font-size: 1rem;
  margin-left: var(--s-2);
}
.sec-paper .h-scroll-hint,
.sec-paper-2 .h-scroll-hint { color: var(--on-paper-3); }

/* Sec-paper override per le h-card */
.sec-paper .h-scroll-track .h-card,
.sec-paper-2 .h-scroll-track .h-card {
  background: var(--paper-2);
  border-color: var(--line-paper);
}
.sec-paper .h-scroll-track .h-card::after,
.sec-paper-2 .h-scroll-track .h-card::after {
  background: linear-gradient(180deg, transparent 35%, rgba(28,26,20,0.85) 100%);
}

/* MOBILE: scroll nativo orizzontale (swipe-friendly) */
@media (max-width: 920px) {
  .h-scroll {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: var(--gutter);
    /* Scrollbar nascosta visivamente ma scroll attivo */
    scrollbar-width: none;
  }
  .h-scroll::-webkit-scrollbar { display: none; }
  .h-scroll-track {
    transform: none !important;  /* ignora GSAP su mobile */
    padding-block: var(--s-3);
  }
  .h-scroll-track .h-card {
    flex: 0 0 78vw;
    max-width: 320px;
    scroll-snap-align: start;
  }
  .h-scroll-hint::after { content: '←  swipe'; margin-left: var(--s-3); }
  .h-scroll-hint::before { display: none; }
}

/* ── Stories spotlight (sostituisce fan-deck — carosello orizz.) ── */
.stories-spotlight {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  perspective: 1500px;
}
@media (max-width: 1080px) { .stories-spotlight { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .stories-spotlight { grid-template-columns: 1fr; } }

.story-card {
  position: relative;
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  overflow: hidden;
  background: var(--bg-2);
  cursor: pointer;
  transform-style: preserve-3d;
  isolation: isolate;
  /* GSAP gestisce stato iniziale via fromTo */
}
.story-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease), filter 0.5s var(--ease);
  filter: brightness(0.85) saturate(0.95);
}
.story-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(14,16,17,0.92) 100%);
  pointer-events: none;
  z-index: 1;
}
.story-card:hover img { transform: scale(1.06); filter: brightness(1) saturate(1); }
.story-card:hover { border-color: var(--accent); }

.story-meta {
  position: absolute;
  bottom: var(--s-5); left: var(--s-5); right: var(--s-5);
  z-index: 2;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.story-meta .pill {
  background: rgba(14,16,17,0.6);
  border-color: var(--line-2);
  color: var(--accent);
  align-self: flex-start;
}
.story-meta h3 {
  color: var(--ink);
  font-size: 1.42rem;
  line-height: var(--lead-tight);
  letter-spacing: var(--track-tight);
  text-transform: none;
}
.story-meta p {
  color: var(--ink-2);
  font-size: 0.92rem;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.5s var(--ease), opacity 0.4s var(--ease), margin-top 0.5s var(--ease);
  margin-top: 0;
}
.story-card:hover .story-meta p {
  max-height: 120px;
  opacity: 1;
  margin-top: var(--s-2);
}

/* ── Fan / Deck cards (DEPRECATA 27/04 — buggata cross-browser) ─── */
.fan-deck {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 460px;
  perspective: 1500px;
  margin-block: var(--s-7);
}
.fan-card {
  position: absolute;
  width: 280px;
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: var(--bg-2);
  overflow: hidden;
  box-shadow: 0 30px 60px -30px rgba(0,0,0,0.7);
  transition: transform 0.9s var(--ease), box-shadow 0.5s var(--ease);
  /* Pre-fan: tutte impilate al centro */
  transform: translateX(0) translateY(0) rotate(0deg) translateZ(0);
  will-change: transform;
}
.fan-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.85);
  transition: filter 0.5s var(--ease);
}
.fan-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(14,16,17,0.85) 100%);
  pointer-events: none;
}
.fan-caption {
  position: absolute;
  bottom: var(--s-4); left: var(--s-4); right: var(--s-4);
  z-index: 2;
  color: var(--ink);
  font-family: var(--font-display);
  font-weight: 700;
}
.fan-caption .pill {
  background: rgba(14,16,17,0.6);
  border-color: var(--line-2);
  color: var(--accent);
  margin-bottom: var(--s-2);
  display: inline-flex;
}

/* Stato "fanned" — applicato via JS quando la sezione entra in viewport */
.fan-deck.is-fanned .fan-card:nth-child(1) { transform: translateX(-360px) rotate(-12deg) translateZ(-40px); }
.fan-deck.is-fanned .fan-card:nth-child(2) { transform: translateX(-180px) rotate(-6deg)  translateZ(-20px); }
.fan-deck.is-fanned .fan-card:nth-child(3) { transform: translateX(0)      rotate(0deg)   translateZ(0); }
.fan-deck.is-fanned .fan-card:nth-child(4) { transform: translateX(180px)  rotate(6deg)   translateZ(-20px); }
.fan-deck.is-fanned .fan-card:nth-child(5) { transform: translateX(360px)  rotate(12deg)  translateZ(-40px); }

/* Hover: la card portata in primo piano e raddrizzata */
.fan-deck.is-fanned .fan-card:hover {
  transform: translateX(0) rotate(0deg) translateZ(80px) scale(1.06);
  z-index: 10;
}
.fan-deck.is-fanned .fan-card:hover img { filter: brightness(1); }

@media (max-width: 920px) {
  .fan-deck { min-height: auto; flex-direction: column; gap: var(--s-3); }
  .fan-card,
  .fan-deck.is-fanned .fan-card,
  .fan-deck.is-fanned .fan-card:nth-child(1),
  .fan-deck.is-fanned .fan-card:nth-child(2),
  .fan-deck.is-fanned .fan-card:nth-child(3),
  .fan-deck.is-fanned .fan-card:nth-child(4),
  .fan-deck.is-fanned .fan-card:nth-child(5) {
    position: relative;
    transform: none !important;
    width: 100%;
    aspect-ratio: 3 / 2;
  }
}

/* ── Timeline editorial (chi-siamo) ──────────────────────────── */
.timeline {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  padding-left: var(--s-6);
  border-left: 1px solid var(--line-paper-2);
}
.sec-dark .timeline,
.sec-darker .timeline { border-left-color: var(--line-2); }
.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-5);
  align-items: start;
}
.timeline-item::before {
  content: '';
  position: absolute;
  left: calc(var(--s-6) * -1 - 5px);
  top: 8px;
  width: 10px; height: 10px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 0 4px var(--paper);
}
.sec-dark .timeline-item::before,
.sec-darker .timeline-item::before { box-shadow: 0 0 0 4px var(--bg); }
.timeline-year {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.6rem;
  color: var(--accent);
  letter-spacing: 0;
}
.timeline-body h3 { font-size: 1.32rem; margin-bottom: var(--s-2); }
.timeline-body p { line-height: var(--lead-relax); }
@media (max-width: 600px) {
  .timeline-item { grid-template-columns: 1fr; gap: var(--s-2); }
}

/* ── Image zoom on hover (per gallery semplice) ──────────────── */
.zoom-card {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  isolation: isolate;
}
.zoom-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease), filter 0.5s var(--ease);
}
.zoom-card:hover img {
  transform: scale(1.08);
  filter: contrast(1.05) saturate(1.1);
}
.zoom-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(14,16,17,0.78) 100%);
  pointer-events: none;
  transition: opacity var(--t-base) var(--ease);
}
.zoom-caption {
  position: absolute;
  bottom: var(--s-4); left: var(--s-4); right: var(--s-4);
  z-index: 2;
  color: var(--ink);
}
.zoom-caption h3 {
  color: var(--ink);
  font-size: 1.18rem;
  margin-bottom: var(--s-1);
  transform: translateY(0);
  transition: transform var(--t-base) var(--ease);
}
.zoom-caption p {
  color: var(--ink-2);
  font-size: 0.86rem;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.zoom-card:hover .zoom-caption h3 { transform: translateY(-4px); color: var(--accent); }
.zoom-card:hover .zoom-caption p { opacity: 1; transform: translateY(0); }

/* ── Team grid (chi-siamo) ───────────────────────────────────── */
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6);
}
@media (max-width: 760px) { .team-grid { grid-template-columns: 1fr; } }
.team-member {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
  align-items: center;
  padding: var(--s-5);
  border: 1px solid var(--line-paper);
  border-radius: var(--radius-lg);
  background: var(--paper-card);
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.sec-dark .team-member,
.sec-darker .team-member {
  border-color: var(--line);
  background: var(--bg-2);
}
.team-member:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -28px rgba(0,0,0,0.4);
}
.team-photo {
  aspect-ratio: 4 / 5;
  border-radius: var(--radius);
  overflow: hidden;
}
.team-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); }
.team-member:hover .team-photo img { transform: scale(1.06); }
.team-info h3 { font-size: 1.42rem; margin-bottom: var(--s-1); }
.team-info .role {
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--s-3);
}
.team-info p { font-size: 0.94rem; }

.staff-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-5);
}

.staff-card {
  position: relative;
  overflow: hidden;
  min-height: 520px;
  border: 1px solid var(--line-paper);
  border-radius: var(--radius-lg);
  background: var(--paper-card);
  box-shadow: 0 28px 70px -48px rgba(0,0,0,0.48);
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}

.staff-card:hover {
  transform: translateY(-5px);
  border-color: rgba(181, 137, 62, 0.45);
  box-shadow: 0 36px 80px -52px rgba(0,0,0,0.62);
}

.staff-card figure {
  position: absolute;
  inset: 0;
  margin: 0;
  overflow: hidden;
}

.staff-card figure::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8,8,10,0.02) 20%, rgba(8,8,10,0.34) 58%, rgba(8,8,10,0.86) 100%);
  pointer-events: none;
}

.staff-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.06);
  transition: transform 1s var(--ease), filter var(--t-base) var(--ease);
}

.staff-card--aldo img {
  object-position: 56% center;
}

.staff-card:hover img {
  transform: scale(1.05);
  filter: grayscale(0.85) contrast(1.08);
}

.staff-card > div {
  position: absolute;
  inset-inline: var(--s-5);
  bottom: var(--s-5);
  z-index: 1;
}

.staff-card h3 {
  color: var(--ink);
  font-size: clamp(1.55rem, 2vw, 2.2rem);
  line-height: 1.05;
  margin-top: var(--s-2);
}

.staff-card .role {
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
}

@media (max-width: 980px) {
  .staff-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .staff-card { min-height: 480px; }
}

@media (max-width: 640px) {
  .staff-grid { grid-template-columns: 1fr; }
  .staff-card { min-height: 460px; }
}

/* ── FAQ migliorato (full width clean) ─────────────────────── */
.faq-list-wide { max-width: 880px; margin: 0 auto; }

/* ── CTA strip (banda contatti riusabile) ─────────────────── */
.cta-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-5);
  padding: var(--s-7);
  border-radius: var(--radius-lg);
  background: var(--bg-2);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.cta-strip::before {
  content: '';
  position: absolute;
  top: -50%; right: -20%;
  width: 60%; height: 200%;
  background: radial-gradient(ellipse at center, rgba(200,165,90,0.12), transparent 60%);
  pointer-events: none;
}
.cta-strip h3 { font-size: 1.62rem; margin-bottom: var(--s-2); position: relative; z-index: 1; }
.cta-strip p { color: var(--ink-2); position: relative; z-index: 1; }
.cta-strip .cta-strip-actions { display: flex; gap: var(--s-3); flex-wrap: wrap; position: relative; z-index: 1; }
.sec-paper .cta-strip,
.sec-paper-2 .cta-strip,
.sec-light .cta-strip,
.sec-light2 .cta-strip,
.sec-light3 .cta-strip {
  background: var(--paper-card);
  border-color: var(--line-paper);
}
.sec-paper .cta-strip h3,
.sec-paper-2 .cta-strip h3 { color: var(--on-paper); }
.sec-paper .cta-strip p,
.sec-paper-2 .cta-strip p { color: var(--on-paper-2); }

/* ════════════════════════════════════════════════════════════════════
   Home 2026 redesign: performance academy / label-lab
   ════════════════════════════════════════════════════════════════════ */

.home-redesign {
  --font-serif: 'Instrument Serif', Georgia, serif;
  background:
    radial-gradient(circle at 10% 8%, rgba(199,154,82,0.18), transparent 30rem),
    linear-gradient(180deg, #090a0c 0%, #0f1114 42%, var(--paper) 42%);
}

.home-redesign .navbar { background: rgba(7, 8, 10, 0.76); }
.home-redesign h1, .home-redesign h2 { letter-spacing: -0.055em; }

.rc-hero {
  min-height: 100vh;
  padding: calc(var(--nav-h) + clamp(2rem, 6vw, 5rem)) 0 0;
  background: #090a0c;
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
}

.rc-hero .rv {
  opacity: 1;
  transform: none;
}

.rc-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(9,10,12,0.96) 0%, rgba(9,10,12,0.74) 45%, rgba(9,10,12,0.28) 100%),
    radial-gradient(circle at 75% 18%, rgba(199,154,82,0.24), transparent 34rem);
  z-index: -1;
}

.rc-hero__media {
  position: absolute;
  inset: 0 0 0 auto;
  width: min(76vw, 1180px);
  opacity: 0.82;
  transform: translateX(6%);
  z-index: -2;
}

.rc-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(0.86) contrast(1.08);
}

.rc-hero__inner {
  min-height: calc(100vh - var(--nav-h) - 4rem);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.42fr);
  align-items: end;
  gap: clamp(2rem, 5vw, 5rem);
  padding-bottom: clamp(4rem, 8vw, 7rem);
}

.rc-hero__copy { max-width: 920px; }

.rc-hero h1 {
  max-width: 10.5ch;
  margin: 0;
  color: var(--ink);
  font-size: clamp(4.4rem, 12vw, 12.6rem);
  line-height: 0.82;
  text-wrap: balance;
}

.rc-hero h1::first-line {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
}

.rc-hero__lead {
  max-width: 68ch;
  margin-top: clamp(1.25rem, 3vw, 2.4rem);
  color: rgba(250,250,250,0.78);
  font-size: clamp(1.05rem, 1.45vw, 1.32rem);
  line-height: 1.65;
}

.rc-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: clamp(1.5rem, 3vw, 2.4rem);
}

.rc-hero__panel {
  align-self: end;
  display: grid;
  gap: var(--s-3);
  padding: var(--s-5);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 14px;
  background: rgba(9,10,12,0.58);
  backdrop-filter: blur(18px) saturate(130%);
  box-shadow: 0 36px 80px -44px rgba(0,0,0,0.85);
}

.rc-hero__panel > div {
  display: grid;
  grid-template-columns: 5rem 1fr;
  align-items: center;
  gap: var(--s-3);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.rc-hero__panel > div:last-child { padding-bottom: 0; border-bottom: 0; }

.rc-kpi {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 0.9;
  color: var(--accent);
}

.rc-hero__panel span:last-child {
  color: rgba(250,250,250,0.74);
  font-size: 0.92rem;
  line-height: 1.35;
}

.rc-hero__ticker {
  display: flex;
  gap: var(--s-7);
  padding: var(--s-4) 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  border-bottom: 1px solid rgba(255,255,255,0.12);
  overflow: hidden;
  color: rgba(250,250,250,0.62);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.rc-hero__ticker span {
  position: relative;
  animation: rcTicker 32s linear infinite;
}

.rc-hero__ticker span::after {
  content: '';
  position: absolute;
  right: calc(var(--s-7) * -0.5);
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
}

@keyframes rcTicker {
  from { transform: translateX(0); }
  to { transform: translateX(-28vw); }
}

.rc-proof, .rc-founders, .rc-method, .rc-services, .rc-loop, .rc-gallery, .rc-news, .rc-cta {
  padding-block: clamp(5rem, 10vw, 9rem);
}

.rc-section-head { max-width: 760px; margin-bottom: clamp(2.5rem, 6vw, 5rem); }

.rc-section-head h2, .rc-proof__intro h2, .rc-loop__copy h2, .rc-cta h2 {
  font-size: clamp(2.8rem, 7vw, 6.8rem);
  line-height: 0.92;
  max-width: 12ch;
  color: var(--on-paper);
}

.rc-section-head p:not(.eyebrow), .rc-loop__copy p, .rc-cta p {
  margin-top: var(--s-4);
  max-width: 62ch;
  color: var(--on-paper-2);
  font-size: clamp(1rem, 1.3vw, 1.18rem);
  line-height: 1.72;
}

.rc-section-head--dark h2, .rc-proof__intro h2, .rc-loop__copy h2, .rc-cta h2 { color: var(--ink); }
.rc-section-head--dark p:not(.eyebrow), .rc-loop__copy p, .rc-cta p { color: rgba(250,250,250,0.72); }

.rc-proof__intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.5fr);
  align-items: end;
  gap: var(--s-6);
  margin-bottom: var(--s-7);
}

.rc-proof__grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr 1fr;
  gap: var(--s-4);
}

.rc-proof-card, .rc-news-card {
  position: relative;
  overflow: hidden;
  min-height: 440px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  background: var(--bg-2);
  isolation: isolate;
}

.rc-proof-card:nth-child(2) { margin-top: var(--s-8); }

.rc-proof-card img, .rc-news-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  transition: transform 1s var(--ease);
}

.rc-proof-card::after, .rc-news-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 28%, rgba(7,8,10,0.9) 100%);
  z-index: 1;
}

.rc-proof-card div, .rc-news-card div {
  position: absolute;
  z-index: 2;
  left: var(--s-5);
  right: var(--s-5);
  bottom: var(--s-5);
}

.rc-proof-card span, .rc-news-card span, .rc-role {
  display: inline-flex;
  margin-bottom: var(--s-2);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.rc-proof-card h3, .rc-news-card h3 {
  color: var(--ink);
  font-size: clamp(1.35rem, 2vw, 2rem);
}

.rc-proof-card:hover img, .rc-news-card:hover img { transform: scale(1.05); }

.rc-founders__grid { display: grid; gap: var(--s-6); }

.rc-founder {
  display: grid;
  grid-template-columns: minmax(280px, 0.62fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(1.5rem, 5vw, 5rem);
  padding-block: var(--s-6);
  border-top: 1px solid var(--line-paper-2);
}

.rc-founder--alt { grid-template-columns: minmax(0, 1fr) minmax(280px, 0.62fr); }
.rc-founder--alt figure { order: 2; }

.rc-founder figure {
  aspect-ratio: 5 / 6;
  overflow: hidden;
  border-radius: 18px;
  background: var(--paper-2);
}

.rc-founder figure img { width: 100%; height: 100%; object-fit: cover; }

.rc-founder h3 {
  margin-bottom: var(--s-3);
  color: var(--on-paper);
  font-size: clamp(2.2rem, 5vw, 5rem);
  line-height: 0.95;
}

.rc-founder p:not(.rc-role) {
  color: var(--on-paper-2);
  max-width: 62ch;
  font-size: clamp(1rem, 1.25vw, 1.16rem);
  line-height: 1.75;
}

.rc-method__rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.14);
  border-bottom: 1px solid rgba(255,255,255,0.14);
}

.rc-method-step {
  min-height: 300px;
  padding: var(--s-6);
  border-right: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.rc-method-step:last-child { border-right: 0; }

.rc-method-step span {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 6vw, 6rem);
  color: rgba(199,154,82,0.72);
  line-height: 0.8;
}

.rc-method-step h3 { color: var(--ink); font-size: clamp(1.5rem, 2vw, 2.2rem); }
.rc-method-step p { color: rgba(250,250,250,0.66); line-height: 1.65; }

.rc-services__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--line-paper-2);
  border-left: 1px solid var(--line-paper-2);
}

.rc-service {
  min-height: 230px;
  padding: var(--s-6);
  border-right: 1px solid var(--line-paper-2);
  border-bottom: 1px solid var(--line-paper-2);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

.rc-service span { font-family: var(--font-mono); color: var(--accent-2); font-size: 0.78rem; }

.rc-service strong {
  display: block;
  color: var(--on-paper);
  font-size: clamp(1.35rem, 2vw, 2rem);
  line-height: 1.05;
  font-weight: 700;
}

.rc-service small {
  display: block;
  color: var(--on-paper-2);
  line-height: 1.55;
  font-size: 0.92rem;
}

.rc-service:hover { background: var(--on-paper); }
.rc-service:hover strong, .rc-service:hover small { color: var(--paper); }

.rc-loop__grid, .rc-cta__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(320px, 1fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
}

.rc-loop__copy .btn-outline { margin-top: var(--s-5); }

.rc-loop__media {
  display: grid;
  grid-template-columns: 0.82fr 0.58fr;
  align-items: end;
  gap: var(--s-4);
}

.rc-loop__media img {
  width: 100%;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.12);
}

.rc-loop__media img:first-child { aspect-ratio: 4 / 3; }
.rc-loop__media img:last-child { aspect-ratio: 4 / 5; margin-bottom: -3rem; }

.rc-mosaic {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: var(--s-3);
}

.rc-mosaic figure {
  position: relative;
  grid-column: span 2;
  overflow: hidden;
  border-radius: 16px;
  background: var(--paper-2);
}

.rc-mosaic figure.wide { grid-column: span 3; }
.rc-mosaic figure.tall { grid-row: span 2; }

.rc-mosaic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease);
}

.rc-mosaic figcaption {
  position: absolute;
  left: var(--s-3);
  bottom: var(--s-3);
  padding: 0.35rem 0.75rem;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--radius-pill);
  background: rgba(7,8,10,0.62);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.rc-mosaic figure:hover img { transform: scale(1.05); }

.rc-news__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}

.rc-news-card { min-height: 520px; border-color: var(--line-paper); }
.rc-news-card p { margin-top: var(--s-2); color: rgba(250,250,250,0.74); line-height: 1.55; }

.rc-contact-form {
  padding: clamp(1.25rem, 3vw, 2rem);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 18px;
  background: rgba(255,255,255,0.035);
}

.rc-contact-form .btn-fill { width: 100%; justify-content: center; }

@media (max-width: 1100px) {
  .rc-hero__inner, .rc-proof__grid, .rc-loop__grid, .rc-cta__grid { grid-template-columns: 1fr; }
  .rc-hero__panel { max-width: 620px; }
  .rc-proof-card:nth-child(2) { margin-top: 0; }
  .rc-method__rail { grid-template-columns: repeat(2, 1fr); }
  .rc-method-step:nth-child(2) { border-right: 0; }
}

@media (max-width: 860px) {
  .rc-hero { min-height: auto; }
  .rc-hero__media { inset: 0; width: 100%; opacity: 0.38; transform: none; }
  .rc-hero__inner { min-height: 86vh; padding-bottom: var(--s-7); }
  .rc-hero h1 { font-size: clamp(4rem, 18vw, 7rem); }
  .rc-hero__panel > div { grid-template-columns: 4.5rem 1fr; }
  .rc-founders__grid, .rc-founder, .rc-founder--alt { grid-template-columns: 1fr; }
  .rc-founder--alt figure { order: 0; }
  .rc-services__grid, .rc-news__grid { grid-template-columns: 1fr; }
  .rc-mosaic { grid-template-columns: 1fr 1fr; grid-auto-rows: 170px; }
  .rc-mosaic figure, .rc-mosaic figure.wide { grid-column: span 1; }
}

@media (max-width: 620px) {
  .rc-hero__actions, .rc-hero__actions a { width: 100%; }
  .rc-hero__actions a { justify-content: center; }
  .rc-hero__panel { padding: var(--s-4); }
  .rc-proof-card, .rc-news-card { min-height: 380px; }
  .rc-method__rail { grid-template-columns: 1fr; }
  .rc-method-step {
    min-height: 260px;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,0.12);
  }
  .rc-method-step:last-child { border-bottom: 0; }
  .rc-loop__media { grid-template-columns: 1fr; }
  .rc-loop__media img:last-child { margin-bottom: 0; }
  .rc-mosaic { grid-template-columns: 1fr; }
.rc-mosaic figure, .rc-mosaic figure.wide, .rc-mosaic figure.tall {
    grid-column: auto;
    grid-row: auto;
  }
}

/* ════════════════════════════════════════════════════════════════════
   RC Voce experience: current-brand content, richer journey
   ════════════════════════════════════════════════════════════════════ */

.rc-experience {
  background: #080808;
}

.rc-experience .rc-nav {
  background: rgba(4, 4, 4, 0.82);
}

.rc-experience .nav-links {
  gap: clamp(1rem, 2vw, 1.7rem);
}

.rc-experience .nav-links a {
  font-size: 0.78rem;
}

.exp-hero {
  position: relative;
  min-height: 112vh;
  padding-top: var(--nav-h);
  color: var(--ink);
  background: #070707;
  overflow: hidden;
  isolation: isolate;
}

.exp-hero .rv {
  opacity: 1;
  transform: none;
  visibility: visible !important;
}

.exp-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.exp-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(0.82) contrast(1.12);
}

.exp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(7,7,7,0.96) 0%, rgba(7,7,7,0.78) 44%, rgba(7,7,7,0.34) 100%),
    linear-gradient(180deg, rgba(7,7,7,0.1) 0%, rgba(7,7,7,0.42) 58%, #070707 100%);
  z-index: -1;
}

.exp-hero__inner {
  position: relative;
  z-index: 1;
  min-height: calc(100vh - var(--nav-h));
  display: grid;
  grid-template-columns: 0.35fr minmax(0, 1fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
  padding-block: clamp(4rem, 8vw, 7rem);
}

.exp-hero__brand {
  align-self: start;
  padding-top: var(--s-8);
}

.exp-hero__brand img {
  width: min(220px, 48vw);
  height: auto;
}

.exp-hero h1 {
  position: relative;
  z-index: 2;
  max-width: 11ch;
  color: var(--ink);
  font-size: clamp(3.8rem, 8.4vw, 8.6rem);
  line-height: 0.9;
  letter-spacing: -0.055em;
}

.exp-hero__lead {
  max-width: 50ch;
  margin-top: var(--s-5);
  color: rgba(250,250,250,0.78);
  font-size: clamp(1.08rem, 1.6vw, 1.42rem);
  line-height: 1.62;
}

.exp-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-6);
}

.exp-hero__cards {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  margin-top: calc(var(--s-8) * -1);
  padding-bottom: var(--s-8);
}

.exp-card {
  min-height: 310px;
  padding: var(--s-6);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 0;
  background: rgba(9,9,9,0.76);
  backdrop-filter: blur(18px) saturate(130%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease), background var(--t-base) var(--ease);
}

.exp-card:hover {
  transform: translateY(-8px);
  border-color: rgba(199,154,82,0.68);
  background: rgba(17,17,17,0.9);
}

.exp-card span,
.exp-news-card time {
  font-family: var(--font-mono);
  color: var(--accent);
  font-size: 0.78rem;
}

.exp-card h2 {
  color: var(--ink);
  font-size: clamp(1.55rem, 2.5vw, 2.45rem);
  line-height: 1.02;
}

.exp-card p {
  color: rgba(250,250,250,0.68);
  line-height: 1.62;
}

.exp-school,
.exp-founders,
.exp-news,
.exp-releases,
.exp-gallery,
.exp-contact {
  padding-block: clamp(5rem, 10vw, 9rem);
}

.exp-school__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.74fr) minmax(320px, 1fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
}

.exp-school__copy h2,
.exp-section-head h2,
.exp-releases h2,
.exp-contact h2 {
  color: var(--on-paper);
  max-width: 12ch;
  font-size: clamp(3rem, 7vw, 6.8rem);
  line-height: 0.94;
  letter-spacing: -0.055em;
}

.exp-school__copy .lead {
  margin-top: var(--s-5);
  color: var(--on-paper-2);
  font-size: clamp(1.15rem, 1.8vw, 1.55rem);
}

.exp-school__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-6);
}

.exp-school__media {
  display: grid;
  grid-template-columns: 0.72fr 1fr;
  gap: var(--s-4);
  align-items: end;
}

.exp-school__media img {
  width: 100%;
  object-fit: cover;
  border-radius: 0;
  border: 1px solid var(--line-paper-2);
}

.exp-school__media img:first-child {
  aspect-ratio: 4 / 5;
}

.exp-school__media img:last-child {
  aspect-ratio: 4 / 3;
  margin-bottom: var(--s-7);
}

.exp-section-head {
  max-width: 840px;
  margin-bottom: clamp(2.5rem, 6vw, 5rem);
}

.sec-dark .exp-section-head h2,
.exp-releases h2,
.exp-contact h2 {
  color: var(--ink);
}

.exp-founders__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}

.exp-founder {
  display: grid;
  grid-template-columns: minmax(180px, 0.58fr) 1fr;
  gap: var(--s-5);
  align-items: stretch;
  padding: var(--s-5);
  border: 1px solid rgba(255,255,255,0.12);
  background: #101010;
}

.exp-founder figure {
  min-height: 420px;
  overflow: hidden;
}

.exp-founder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.exp-founder h3 {
  color: var(--ink);
  margin-bottom: var(--s-4);
  font-size: clamp(2rem, 4vw, 4rem);
}

.exp-founder p:not(.eyebrow) {
  color: rgba(250,250,250,0.72);
  line-height: 1.75;
}

.exp-news__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}

.exp-news-card {
  background: var(--paper-card);
  border: 1px solid var(--line-paper);
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.exp-news-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.exp-news-card div {
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

.exp-news-card h3 {
  color: var(--on-paper);
  font-size: 1.24rem;
}

.exp-news-card p {
  color: var(--on-paper-2);
  font-size: 0.94rem;
  line-height: 1.6;
}

.exp-more {
  margin-top: var(--s-6);
  text-align: center;
}

.exp-releases__grid,
.exp-contact__grid {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(320px, 1fr);
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
}

.exp-releases .btn-outline {
  margin-top: var(--s-6);
}

.exp-release-wall {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid rgba(255,255,255,0.16);
  border-left: 1px solid rgba(255,255,255,0.16);
}

.exp-release-wall span {
  min-height: 132px;
  padding: var(--s-4);
  border-right: 1px solid rgba(255,255,255,0.16);
  border-bottom: 1px solid rgba(255,255,255,0.16);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--ink);
  font-size: clamp(1.1rem, 2vw, 1.7rem);
  line-height: 1.1;
}

.exp-release-wall small {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

.exp-gallery__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: var(--s-3);
}

.exp-gallery__grid figure {
  grid-column: span 2;
  overflow: hidden;
  border: 1px solid var(--line-paper);
}

.exp-gallery__grid figure.wide {
  grid-column: span 3;
}

.exp-gallery__grid figure.tall {
  grid-row: span 2;
}

.exp-gallery__grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease);
}

.exp-gallery__grid figure:hover img {
  transform: scale(1.05);
}

.exp-contact p {
  max-width: 56ch;
  color: rgba(250,250,250,0.72);
  line-height: 1.75;
  margin-top: var(--s-4);
}

.exp-contact__cards {
  display: grid;
  gap: var(--s-3);
}

.exp-contact__cards article {
  padding: var(--s-5);
  border: 1px solid rgba(255,255,255,0.14);
  background: #111;
}

.exp-contact__cards h3 {
  color: var(--ink);
  font-size: 1.45rem;
}

.exp-contact__cards p {
  margin-top: var(--s-2);
}

.exp-contact__cards a {
  display: inline-flex;
  margin-top: var(--s-3);
  color: var(--accent);
  font-weight: 700;
}

@media (max-width: 1180px) {
  .exp-founders__grid,
  .exp-news__grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 920px) {
  .exp-hero__inner,
  .exp-school__grid,
  .exp-releases__grid,
  .exp-contact__grid {
    grid-template-columns: 1fr;
  }

  .exp-hero__brand {
    padding-top: var(--s-5);
  }

  .exp-hero__cards {
    grid-template-columns: 1fr;
    margin-top: 0;
  }

  .exp-school__media {
    grid-template-columns: 1fr 1fr;
  }

  .exp-founder {
    grid-template-columns: 1fr;
  }

  .exp-founder figure {
    min-height: 320px;
  }

  .exp-gallery__grid {
    grid-template-columns: 1fr 1fr;
  }

  .exp-gallery__grid figure,
  .exp-gallery__grid figure.wide {
    grid-column: span 1;
  }
}

@media (max-width: 620px) {
  .exp-hero {
    min-height: auto;
  }

  .exp-hero__inner {
    min-height: 88vh;
    padding-top: var(--s-5);
    align-content: center;
    gap: var(--s-4);
  }

  .exp-hero__brand {
    display: none;
  }

  .exp-hero h1 {
    font-size: clamp(3.15rem, 15vw, 5.2rem);
  }

  .exp-hero__actions,
  .exp-hero__actions a,
  .exp-school__actions,
  .exp-school__actions a {
    width: 100%;
  }

  .exp-hero__actions {
    max-width: 300px;
  }

  .exp-hero__actions a,
  .exp-school__actions a {
    justify-content: center;
  }

  .exp-school__media,
  .exp-news__grid,
  .exp-release-wall,
  .exp-gallery__grid {
    grid-template-columns: 1fr;
  }

  .exp-school__media img:last-child {
    margin-bottom: 0;
  }

  .exp-gallery__grid figure,
  .exp-gallery__grid figure.wide,
  .exp-gallery__grid figure.tall {
    grid-column: auto;
    grid-row: auto;
  }
}

/* Compact editorial pass — 19/05 */
.rc-experience .nav-links {
  gap: clamp(1rem, 2.2vw, 2rem);
}

.rc-experience .nav-links a {
  font-size: 0.84rem;
}

.exp-hero {
  min-height: auto;
}

.exp-hero::before {
  background:
    linear-gradient(90deg, rgba(7,7,7,0.9) 0%, rgba(7,7,7,0.64) 52%, rgba(7,7,7,0.42) 100%),
    linear-gradient(180deg, rgba(7,7,7,0.04) 0%, rgba(7,7,7,0.36) 72%, #070707 100%);
}

.exp-hero__inner {
  min-height: min(760px, calc(100vh - var(--nav-h)));
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: clamp(5rem, 8vw, 7rem) clamp(4rem, 6vw, 5.5rem);
  text-align: center;
}

.exp-hero__text {
  max-width: 920px;
  margin-inline: auto;
}

.exp-hero .eyebrow::before {
  content: '';
}

.exp-hero h1 {
  max-width: min(1120px, 92vw);
  margin-inline: auto;
  font-size: clamp(3.1rem, 5.55vw, 5.9rem);
  line-height: 1.02;
  letter-spacing: 0;
}

.exp-hero__lead {
  max-width: 48rem;
  margin-inline: auto;
  margin-top: var(--s-4);
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.58;
}

.exp-hero__actions {
  justify-content: center;
  margin-top: var(--s-5);
}

.exp-hero__cards {
  margin-top: 0;
  padding-bottom: clamp(3rem, 5vw, 4.5rem);
  gap: var(--s-3);
}

.exp-card {
  min-height: 210px;
  padding: var(--s-5);
  justify-content: flex-start;
  gap: var(--s-4);
}

.exp-card h2 {
  font-size: clamp(1.25rem, 1.7vw, 1.7rem);
  line-height: 1.12;
}

.exp-card p {
  font-size: 0.94rem;
  line-height: 1.55;
}

.exp-school,
.exp-founders,
.exp-news,
.exp-gallery,
.exp-contact {
  padding-block: clamp(3.5rem, 6vw, 5.5rem);
}

.exp-school__grid,
.exp-contact__grid {
  gap: clamp(1.75rem, 4vw, 3.5rem);
}

.exp-school__copy h2,
.exp-section-head h2,
.exp-contact h2 {
  max-width: 22ch;
  font-size: clamp(2rem, 4vw, 3.8rem);
  line-height: 1.04;
}

.exp-school__copy .lead {
  margin-top: var(--s-4);
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.65;
}

.exp-section-head {
  margin-bottom: clamp(1.75rem, 4vw, 3rem);
}

.exp-school__media figure,
.exp-gallery__grid figure {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line-paper);
  background: var(--paper-card);
}

.exp-school__media figcaption,
.exp-gallery__grid figcaption {
  position: absolute;
  left: var(--s-3);
  bottom: var(--s-3);
  padding: 0.35rem 0.7rem;
  background: rgba(7,7,7,0.72);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 0.72rem;
}

.exp-school__media figure:first-child img { aspect-ratio: 4 / 5; }
.exp-school__media figure:last-child img { aspect-ratio: 4 / 3; }
.exp-school__media figure:last-child { margin-bottom: var(--s-5); }
.exp-school__media img { border: 0; height: 100%; object-fit: cover; }
.exp-school__media img:last-child { margin-bottom: 0; }

.exp-founders__grid {
  grid-template-columns: 1fr;
}

.exp-founder {
  grid-template-columns: minmax(180px, 0.34fr) 1fr;
  padding: var(--s-4);
  gap: var(--s-5);
}

.exp-founder figure {
  min-height: 260px;
}

.exp-founder h3 {
  font-size: clamp(1.7rem, 3vw, 2.7rem);
  margin-bottom: var(--s-3);
}

.exp-founder p:not(.eyebrow) {
  line-height: 1.62;
}

.exp-news__grid {
  grid-template-columns: repeat(2, 1fr);
}

.exp-news-card div {
  padding: var(--s-4);
  gap: var(--s-2);
}

.exp-news-card h3 {
  font-size: 1.08rem;
  line-height: 1.2;
}

.exp-gallery__grid {
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: auto;
}

.exp-gallery__grid figure,
.exp-gallery__grid figure.wide,
.exp-gallery__grid figure.tall {
  grid-column: auto;
  grid-row: auto;
  aspect-ratio: 4 / 3;
}

.exp-gallery__grid img {
  height: 100%;
}

.exp-contact__cards article {
  padding: var(--s-4);
}

/* Storie: make text readable without hover gymnastics */
.story-card::after,
.h-scroll-track .h-card::after {
  background: linear-gradient(180deg, rgba(0,0,0,0.12) 0%, rgba(0,0,0,0.42) 45%, rgba(0,0,0,0.92) 100%);
}

.story-meta,
.h-card-meta {
  background: rgba(5,5,5,0.72);
  border: 1px solid rgba(255,255,255,0.14);
  padding: var(--s-3);
  backdrop-filter: blur(12px);
}

.story-meta p {
  max-height: none;
  opacity: 1;
  overflow: visible;
  color: rgba(250,250,250,0.88);
  margin-top: var(--s-1);
}

.story-meta h3,
.h-card-meta h3 {
  color: #fff;
}

.h-card-meta p {
  color: rgba(250,250,250,0.86);
}

/* Content must remain readable if animation libraries are slow or unavailable. */
.rv,
.rv-left,
.rv-right {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.page-hero {
  background:
    linear-gradient(90deg, rgba(8,8,8,0.92), rgba(8,8,8,0.74) 48%, rgba(8,8,8,0.42)),
    var(--page-hero-image, url('../img/hero-concert.jpg')) center / cover no-repeat !important;
  color: var(--ink) !important;
  padding-top: calc(var(--nav-h) + clamp(3rem, 7vw, 6rem));
  padding-bottom: clamp(4rem, 8vw, 6.5rem);
}

body.page-chi-siamo {
  --page-hero-image: url('../img/hero-generated-chi-siamo.webp');
}

body.page-servizi {
  --page-hero-image: url('../img/hero-generated-servizi.webp');
}

body.page-storie {
  --page-hero-image: url('../img/hero-generated-storie.webp');
}

body.page-contatti {
  --page-hero-image: url('../img/hero-generated-contatti.webp');
}

.page-hero h1,
.page-hero .page-hero__lead {
  color: var(--ink) !important;
}

.page-hero .page-hero__lead {
  color: rgba(250,250,250,0.78) !important;
}

.stories-archive-grid {
  overflow: visible !important;
  padding-inline: var(--gutter);
}

.stories-archive-grid .h-scroll-track {
  width: 100% !important;
  max-width: var(--container);
  margin-inline: auto;
  padding: 0 !important;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-4);
  transform: none !important;
}

.stories-archive-grid .h-card {
  flex: none !important;
  width: 100%;
  min-width: 0;
  aspect-ratio: 4 / 5;
}

.blog-index .hero {
  min-height: 520px;
  padding-top: calc(var(--nav-h) + 5rem);
  padding-bottom: 5rem;
}

.blog-index .hero-photo::before {
  background:
    linear-gradient(90deg, rgba(8,8,8,0.92), rgba(8,8,8,0.7) 48%, rgba(8,8,8,0.34)),
    linear-gradient(180deg, rgba(8,8,8,0.1), rgba(8,8,8,0.92));
}

.blog-index .hero-content {
  display: block;
  max-width: 980px;
}

.blog-index .hero h1 {
  max-width: 100%;
  font-size: clamp(2.6rem, 4.4vw, 4.2rem);
  line-height: 1.04;
  text-transform: none;
  color: var(--ink);
}

.blog-index .page-hero__lead {
  color: rgba(250,250,250,0.74);
  max-width: 62ch;
  margin-top: var(--s-4);
}

.method-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-3);
  margin-block: var(--s-6);
}

.method-steps article,
.method-band article,
.route-card {
  border: 1px solid var(--line-paper);
  background: rgba(255,255,255,0.72);
  padding: var(--s-4);
}

.method-steps span,
.method-band span {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--accent);
  margin-bottom: var(--s-2);
}

.method-steps strong {
  display: block;
  color: var(--on-paper);
  font-size: 1rem;
  line-height: 1.2;
}

.method-steps em {
  display: block;
  margin-top: 0.35rem;
  color: var(--on-paper-2);
  font-style: normal;
  font-size: 0.9rem;
}

.method-band {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-4);
}

.method-band article {
  background: rgba(255,255,255,0.035);
  border-color: var(--line-2);
}

.method-band h3 {
  font-size: clamp(1.2rem, 1.7vw, 1.6rem);
  margin-bottom: var(--s-3);
}

.method-band p {
  color: var(--ink-2);
  font-size: 0.94rem;
}

.route-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-4);
}

.route-card {
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}

.route-card:hover {
  transform: translateY(-6px);
  border-color: rgba(199,154,82,0.45);
}

.route-card > span,
.story-filter-row span {
  font-family: var(--font-mono);
  color: var(--accent);
  font-size: 0.78rem;
}

.route-card h3 {
  color: var(--on-paper);
  margin-top: var(--s-4);
  font-size: clamp(1.35rem, 2vw, 1.8rem);
}

.route-card p {
  color: var(--on-paper-2);
  margin-block: var(--s-4);
}

.route-card a {
  color: var(--on-paper);
  font-weight: 700;
  border-bottom: 1px solid var(--accent);
  width: fit-content;
}

.story-filter-row {
  display: flex;
  justify-content: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  margin-bottom: var(--s-6);
}

.story-filter-row span {
  border: 1px solid var(--line-paper-2);
  color: var(--on-paper);
  background: rgba(255,255,255,0.62);
  padding: 0.55rem 0.85rem;
}

.story-wall {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--s-4);
}

.story-wall .h-card {
  width: 100%;
  min-width: 0;
  aspect-ratio: 4 / 5;
}

.reassurance-list {
  display: grid;
  gap: var(--s-3);
}

.reassurance-list li {
  border-left: 2px solid var(--accent);
  padding-left: var(--s-3);
  color: var(--on-paper-2);
}

.blog-index .sec-light {
  padding-block: clamp(3.5rem, 6vw, 5.5rem);
  background:
    linear-gradient(180deg, rgba(246,244,238,0.94), rgba(236,234,214,0.96)),
    url('../img/studio-detail.jpg') center / cover fixed;
}

.blog-index .article-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 280px !important;
  gap: clamp(1.5rem, 4vw, 3rem) !important;
}

.blog-index .blog-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: var(--s-4) !important;
}

.blog-index .blog-card {
  grid-row: auto !important;
  min-width: 0;
  background: rgba(255,255,255,0.86);
  border: 1px solid var(--line-paper);
  padding: var(--s-3);
  border-radius: 0;
  backdrop-filter: blur(10px);
}

.blog-index .blog-card-img {
  border-radius: 0;
  border: 0;
}

.blog-index .blog-card-body {
  padding: var(--s-2) var(--s-1) 0;
}

.blog-index .blog-card h3 {
  font-size: clamp(1.05rem, 1.35vw, 1.35rem);
}

.blog-index .blog-card .excerpt {
  color: var(--on-paper-2);
  font-size: 0.92rem;
}

.blog-index .blog-sidebar {
  background: rgba(255,255,255,0.78);
  border: 1px solid var(--line-paper);
  padding: var(--s-4);
  backdrop-filter: blur(12px);
}

.blog-index .sidebar-tags-link {
  border: 1px solid var(--line-paper-2);
  padding: 0.45rem 0.7rem;
  color: var(--on-paper);
  background: rgba(255,255,255,0.7);
  font-size: 0.82rem;
}

@media (max-width: 1100px) {
  .stories-archive-grid .h-scroll-track,
  .blog-index .blog-grid,
  .story-wall {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .method-band,
  .route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .blog-index .article-layout {
    grid-template-columns: 1fr !important;
  }

  .blog-index .blog-sidebar {
    position: static !important;
  }
}

@media (max-width: 640px) {
  .stories-archive-grid .h-scroll-track,
  .blog-index .blog-grid,
  .story-wall,
  .method-band,
  .method-steps,
  .route-grid {
    grid-template-columns: 1fr !important;
  }

  .blog-index .hero {
    min-height: auto;
    padding-top: calc(var(--nav-h) + 3rem);
  }

  .page-hero h1,
  .exp-hero h1 {
    font-size: clamp(2.2rem, 9.5vw, 2.65rem);
    line-height: 1.08;
    max-width: 100%;
    overflow-wrap: break-word;
  }

  .exp-hero h1 span {
    display: inline;
  }

  .mobile-break { display: block; }

  .page-hero__lead,
  .exp-hero__lead {
    max-width: 100%;
    overflow-wrap: break-word;
  }

  .page-hero .container,
  .sec-head,
  .route-card {
    width: min(100%, 300px);
    max-width: min(100%, 300px);
  }

  .page-hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .page-hero__actions a {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 920px) {
  .exp-hero__inner {
    min-height: auto;
    padding-block: calc(var(--nav-h) + var(--s-7)) var(--s-8);
  }

  .exp-hero__cards,
  .exp-news__grid,
  .exp-gallery__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .exp-hero__inner {
    padding-top: calc(var(--nav-h) + var(--s-5));
    text-align: left;
  }

  .exp-hero__text,
  .exp-hero__cards.container {
    width: min(100%, 300px);
    max-width: min(100%, 300px);
    min-width: 0;
    margin-inline: 0;
  }

  .exp-card {
    width: min(100%, 300px);
    max-width: min(100%, 300px);
  }

  .exp-hero h1 {
    margin-inline: 0;
    font-size: clamp(2.2rem, 9.5vw, 2.65rem);
    line-height: 1.08;
    max-width: 100%;
    overflow-wrap: break-word;
  }

  .exp-hero__lead {
    margin-inline: 0;
    max-width: 100%;
    overflow-wrap: break-word;
  }

  .exp-hero__actions,
  .exp-hero__actions a,
  .exp-school__actions,
  .exp-school__actions a {
    width: 100%;
  }

  .btn-fill,
  .btn-outline {
    white-space: normal;
    text-align: center;
  }

  .exp-hero__actions a,
  .exp-school__actions a {
    justify-content: center;
  }

  .exp-school__media,
  .exp-founder {
    grid-template-columns: 1fr;
  }

  .exp-school__media figure:last-child {
    margin-bottom: 0;
  }
}
