/* =========================================================
   CLAUDIO TROVATO — Monografia
   A photo-book about a chef. Paper + ink + one Sicilian accent.
   New surface (replaces the v1 navy/gold/Playfair build).
   ========================================================= */

:root{
  /* --- paper & ink (NOT cream: bright fine-art paper, chroma ~0) --- */
  --paper:      oklch(0.976 0.002 250);
  --paper-2:    oklch(0.945 0.003 250);
  --ink:        oklch(0.205 0.008 60);
  --ink-soft:   oklch(0.42 0.012 60);
  --ink-faint:  oklch(0.55 0.012 60);

  /* --- plate pages (photography on near-black) --- */
  --plate:      oklch(0.175 0.006 60);
  --plate-2:    oklch(0.135 0.006 60);
  --plate-ink:  oklch(0.95 0.004 80);
  --plate-soft: oklch(0.80 0.006 80);

  /* --- the one accent: Sicilian oxblood / blood-orange --- */
  --accent:     oklch(0.47 0.14 32);
  --accent-ink: oklch(0.43 0.135 32);
  --accent-hi:  oklch(0.64 0.17 40);

  /* --- hairlines --- */
  --line:        oklch(0.205 0.008 60 / .16);
  --line-soft:   oklch(0.205 0.008 60 / .09);
  --line-plate:  oklch(0.95 0.004 80 / .20);

  /* --- type --- */
  --serif:  "Spectral", Georgia, "Times New Roman", serif;
  --grotesk:"Bricolage Grotesque", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* --- metrics --- */
  --measure: 64ch;
  --maxw:    1320px;
  --gut:     clamp(22px, 5.2vw, 88px);
  --nav-h:   72px;

  /* --- motion --- */
  --ease:     cubic-bezier(.22,.61,.36,1);   /* ease-out-quart-ish */
  --ease-exp: cubic-bezier(.16,1,.3,1);      /* ease-out-expo */

  /* --- z-scale --- */
  --z-nav: 100;
  --z-dialog: 300;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:clamp(16.5px,.42vw + 15px,19px);
  line-height:1.68;
  font-weight:400;
  font-feature-settings:"kern","liga","onum","pnum";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--paper)}

h1,h2,h3{
  font-family:var(--serif);font-weight:600;line-height:1.03;
  letter-spacing:-.018em;margin:0;color:var(--ink);text-wrap:balance;
}
p{margin:0 0 1.15em;text-wrap:pretty}
p:last-child{margin-bottom:0}
em{font-style:italic}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}

/* small structural label — grotesk, sentence-cased, NOT a tracked eyebrow */
.label{
  font-family:var(--grotesk);font-weight:500;
  font-size:.78rem;letter-spacing:.01em;color:var(--ink-faint);
}

/* book folio mark (deliberate system, used sparingly) */
.folio{
  font-family:var(--grotesk);font-weight:500;font-size:.74rem;
  letter-spacing:.02em;color:var(--ink-faint);
  display:inline-flex;align-items:center;gap:.6em;
}
.folio::before{content:"";width:26px;height:1px;background:var(--accent)}

/* link with oxblood underline */
.link{
  color:var(--accent-ink);
  text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:3px;text-decoration-color:oklch(0.43 0.135 32 / .4);
  transition:text-decoration-color .3s var(--ease);
}
.link:hover{text-decoration-color:var(--accent-ink)}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.head{
  position:fixed;inset:0 0 auto 0;z-index:var(--z-nav);height:var(--nav-h);
  display:flex;align-items:center;color:var(--plate-ink);
  transition:background .45s var(--ease),color .45s var(--ease),
             border-color .45s var(--ease),height .4s var(--ease);
  border-bottom:1px solid transparent;
}
.head .wrap{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}
.head.solid{
  background:var(--paper);color:var(--ink);
  border-bottom-color:var(--line);height:60px;
}
.brand{
  font-family:var(--serif);font-weight:600;font-size:1.16rem;letter-spacing:-.01em;
  display:inline-flex;align-items:baseline;gap:.55rem;color:currentColor;
}
.brand small{
  font-family:var(--grotesk);font-weight:500;font-size:.6rem;
  letter-spacing:.22em;text-transform:uppercase;opacity:.72;transform:translateY(-1px);
}
.nav{display:flex;align-items:center;gap:clamp(1.1rem,2.4vw,2.3rem)}
.nav a:not(.langs a){
  font-family:var(--grotesk);font-weight:500;font-size:.86rem;letter-spacing:.005em;
  color:currentColor;opacity:.82;position:relative;padding:.4em 0;transition:opacity .3s
}
.nav a:not(.langs a)::after{
  content:"";position:absolute;left:0;bottom:.05em;height:1px;width:0;
  background:var(--accent-hi);transition:width .35s var(--ease)
}
.head.solid .nav a:not(.langs a)::after{background:var(--accent)}
.nav a:hover{opacity:1}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{opacity:1}

.langs{display:inline-flex;align-items:center;gap:.1rem;border:1px solid currentColor;
  border-radius:999px;padding:.12rem;opacity:.85}
.langs a{font-family:var(--grotesk);font-weight:500;font-size:.66rem;letter-spacing:.08em;
  text-transform:uppercase;padding:.32em .7em;border-radius:999px;color:currentColor;transition:.3s}
.langs a.on{background:currentColor}
.langs a.on span{color:var(--plate);mix-blend-mode:normal}
.head.solid .langs a.on span{color:var(--paper)}

.burger{display:none;background:none;border:0;color:currentColor;cursor:pointer;
  width:44px;height:44px;padding:0;align-items:center;justify-content:center}
.burger svg{width:26px;height:26px}

/* =========================================================
   COVER (title page) — full-bleed B/W plate
   ========================================================= */
.cover{
  position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:flex-end;overflow:hidden;background:var(--plate-2);color:var(--plate-ink);
}
.cover__media{position:absolute;inset:0;z-index:0;overflow:hidden}
.cover__media img{
  width:100%;height:100%;object-fit:cover;object-position:56% 30%;
  filter:grayscale(1) contrast(1.04);
}
.cover__media::after{ /* photographic vignette + legibility scrim */
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(187deg, oklch(0.135 0.006 60 / .42) 0%, transparent 26%, transparent 50%, oklch(0.135 0.006 60 / .9) 100%),
    linear-gradient(95deg, oklch(0.135 0.006 60 / .62) 0%, transparent 52%);
}
.cover__inner{
  position:relative;z-index:1;width:100%;
  padding-top:calc(var(--nav-h) + 24px);
  padding-bottom:clamp(40px,8vh,84px);
}
.cover .kicker{ /* one named book line — voice, not an eyebrow on every section */
  font-family:var(--grotesk);font-weight:500;font-size:.84rem;letter-spacing:.04em;
  color:var(--plate-soft);margin:0 0 1.5rem;display:flex;align-items:center;gap:.8em
}
.cover .kicker::before{content:"";width:30px;height:1px;background:var(--accent-hi)}
.cover__name{
  font-family:var(--serif);font-weight:500;letter-spacing:-.028em;line-height:.92;
  font-size:clamp(3.2rem,11.5vw,8.2rem);margin:0;color:var(--paper);
}
.cover__name span{display:block;overflow:hidden}
.cover__name b{display:block;font-weight:500}
.cover__name .given{font-weight:300;opacity:.92}
.cover__name .family{font-style:italic;font-weight:500}
.cover__sub{
  max-width:34ch;margin:1.7rem 0 0;font-size:clamp(1.08rem,1.5vw,1.34rem);
  line-height:1.5;color:var(--plate-soft);
}
.cover__foot{
  position:relative;z-index:1;margin-top:clamp(28px,5vh,52px);
  display:flex;align-items:flex-end;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;
}
.cover__cta{display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--grotesk);font-weight:600;font-size:.9rem;letter-spacing:.01em;
  color:var(--paper);padding:.2em 0;border-bottom:1px solid var(--accent-hi);transition:gap .35s var(--ease)}
.cover__cta svg{width:1.05em;height:1.05em}
.cover__cta:hover{gap:1.1em}
.cover__index{font-family:var(--grotesk);font-weight:500;font-size:.76rem;letter-spacing:.02em;
  color:var(--plate-soft);text-align:right;line-height:1.9}
.cover__index b{color:var(--plate-ink);font-weight:600}

/* =========================================================
   FRONTISPIECE — opening statement on paper
   ========================================================= */
.frontis{padding:clamp(78px,12vw,160px) 0 clamp(60px,9vw,120px)}
.frontis__head{display:flex;align-items:baseline;justify-content:space-between;
  gap:1rem;margin-bottom:clamp(40px,6vw,76px);border-bottom:1px solid var(--line);padding-bottom:1.1rem}
.frontis blockquote{
  margin:0;max-width:20ch;font-family:var(--serif);font-weight:300;
  font-size:clamp(2.1rem,5.4vw,4.4rem);line-height:1.06;letter-spacing:-.02em;color:var(--ink);
}
.frontis blockquote em{font-style:italic;color:var(--accent-ink);font-weight:400}
.frontis__by{margin-top:clamp(28px,4vw,46px);max-width:46ch;color:var(--ink-soft);
  font-size:clamp(1.02rem,1.2vw,1.16rem)}
.frontis__sign{font-family:var(--grotesk);font-weight:600;color:var(--ink);margin-top:1.4rem;
  font-size:.92rem;letter-spacing:.01em}

/* =========================================================
   SPREAD — figure + text (asymmetric, photo bleeds to edge)
   ========================================================= */
.spread{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr);align-items:center;
  gap:clamp(30px,5vw,76px)}
.spread__fig{position:relative;margin-left:calc(-1 * var(--gut));align-self:stretch}
.spread__fig img{width:100%;height:100%;min-height:420px;object-fit:cover;object-position:50% 26%;
  filter:grayscale(1) contrast(1.03)}
.spread__cap{position:absolute;left:clamp(14px,2vw,26px);bottom:clamp(14px,2vw,22px);
  font-family:var(--grotesk);font-weight:500;font-size:.72rem;letter-spacing:.02em;
  color:var(--plate-ink);background:oklch(0.135 0.006 60 / .55);
  padding:.45em .8em;backdrop-filter:blur(2px);max-width:30ch;line-height:1.4}
.spread__body{padding:clamp(40px,7vw,90px) 0}
.spread__body h2{font-size:clamp(1.9rem,3.6vw,3.1rem);margin-bottom:.7em;font-weight:500}
.spread__body h2 em{color:var(--accent-ink)}
.spread__body p{color:var(--ink-soft);max-width:48ch}
.spread__body p strong{color:var(--ink);font-weight:600}
.spread__pull{font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.35;color:var(--ink);
  margin:1.7rem 0 0;padding-top:1.4rem;border-top:1px solid var(--line)}

/* =========================================================
   PLATE PAGE — one decisive photo, caption in his voice
   ========================================================= */
.plate{position:relative;background:var(--plate);color:var(--plate-ink);
  min-height:min(92svh,820px);display:flex;align-items:flex-end;overflow:hidden}
.plate__media{position:absolute;inset:0;z-index:0}
.plate__media img{width:100%;height:100%;object-fit:cover;object-position:50% 12%}
.plate__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(transparent 34%, oklch(0.135 0.006 60 / .86) 100%),
             linear-gradient(96deg, oklch(0.135 0.006 60 / .5) 0%, transparent 55%)}
.plate__inner{position:relative;z-index:1;padding-block:clamp(44px,8vw,92px);width:100%}
.plate__quote{font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.8rem,4.4vw,3.4rem);line-height:1.12;letter-spacing:-.018em;
  color:var(--paper);max-width:24ch;margin:0}
.plate__quote em{font-style:normal;color:var(--accent-hi)}
.plate__cap{margin-top:clamp(22px,3vw,38px);max-width:52ch;color:var(--plate-soft);
  font-size:clamp(1rem,1.15vw,1.12rem);line-height:1.55}
.plate__cap .folio{color:var(--plate-soft);margin-bottom:.7rem;display:flex}
.plate__cap .folio::before{background:var(--accent-hi)}

/* =========================================================
   INDICE — book table of contents (NOT a card grid)
   ========================================================= */
.indice{padding:clamp(78px,11vw,150px) 0}
.indice__head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  margin-bottom:clamp(18px,3vw,34px)}
.indice__head h2{font-size:clamp(1.7rem,3vw,2.5rem);font-weight:500}
.toc{border-top:1px solid var(--ink)}
.toc__row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:clamp(18px,4vw,52px);padding:clamp(22px,3.4vw,40px) 0;
  border-bottom:1px solid var(--line);position:relative;isolation:isolate;
  transition:padding-left .5s var(--ease-exp);
}
.toc__row:hover{padding-left:clamp(10px,1.4vw,22px)}
.toc__no{font-family:var(--grotesk);font-weight:500;font-size:.86rem;color:var(--ink-faint);
  align-self:start;padding-top:.5em}
.toc__main{min-width:0}
.toc__main h3{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,5vw,3.6rem);
  line-height:.98;letter-spacing:-.022em;margin:0 0 .35em}
.toc__main h3 em{font-style:italic;color:var(--accent-ink);transition:color .4s var(--ease)}
.toc__row:hover .toc__main h3 em{color:var(--accent)}
.toc__main p{color:var(--ink-soft);max-width:44ch;font-size:clamp(.98rem,1.1vw,1.08rem);margin:0}
.toc__thumb{width:clamp(96px,11vw,148px);aspect-ratio:4/5;overflow:hidden;flex:0 0 auto}
.toc__thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.03);
  transition:transform 1.1s var(--ease),filter .6s var(--ease)}
.toc__row:hover .toc__thumb img{transform:scale(1.05);filter:grayscale(0) contrast(1.02)}
.toc__go{position:absolute;right:0;bottom:clamp(22px,3.4vw,40px);z-index:-1;opacity:0;
  color:var(--accent);transition:opacity .4s var(--ease),transform .5s var(--ease-exp);transform:translateX(-8px)}
.toc__go svg{width:1.4em;height:1.4em}
.toc__row:hover .toc__go{opacity:1;transform:none}

/* =========================================================
   COLOPHON (closing + contacts) — dark plate
   ========================================================= */
.colophon{background:var(--plate-2);color:var(--plate-ink);
  padding:clamp(80px,12vw,150px) 0 clamp(36px,5vw,52px)}
.colophon__lead{max-width:24ch;font-family:var(--serif);font-weight:300;
  font-size:clamp(2rem,5vw,3.8rem);line-height:1.04;letter-spacing:-.02em;color:var(--paper);margin:0 0 1.6rem}
.colophon__lead em{font-style:italic;color:var(--accent-hi)}
.colophon__sub{max-width:46ch;color:var(--plate-soft);margin:0 0 clamp(34px,5vw,54px);
  font-size:clamp(1.05rem,1.3vw,1.2rem)}
.colophon__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(34px,6vw,80px);
  padding-top:clamp(34px,5vw,52px);border-top:1px solid var(--line-plate)}
.contacts{display:flex;flex-direction:column;gap:.85rem}
.contacts a{display:inline-flex;align-items:center;gap:.75em;color:var(--plate-soft);
  font-size:1rem;transition:color .3s var(--ease);width:fit-content}
.contacts a:hover{color:var(--paper)}
.contacts svg{width:1.15em;height:1.15em;flex:0 0 auto;color:var(--accent-hi)}
.colophon__nav{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start}
.colophon__nav a{font-family:var(--grotesk);font-weight:500;font-size:.94rem;color:var(--plate-soft);
  transition:color .3s}
.colophon__nav a:hover{color:var(--paper)}
.colophon__legal{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  margin-top:clamp(48px,7vw,80px);font-family:var(--grotesk);font-size:.76rem;
  letter-spacing:.01em;color:var(--plate-soft);opacity:.8}
.colophon__legal a{transition:color .3s}.colophon__legal a:hover{color:var(--paper)}

/* =========================================================
   MOTION — orchestrated cover load + per-section reveals
   ========================================================= */
.js .reveal{opacity:0;transform:translateY(22px);
  transition:opacity .9s var(--ease-exp),transform .9s var(--ease-exp)}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.09s}.js .reveal.d2{transition-delay:.18s}
.js .reveal.d3{transition-delay:.27s}

/* cover orchestration (only when JS marks ready) */
.js .cover__media img{transform:scale(1.06);transition:transform 1.5s var(--ease-exp)}
.js .cover.ready .cover__media img{transform:scale(1)}
.js .cover__name span b,.js .cover .kicker,.js .cover__sub,.js .cover__foot{
  opacity:0;transform:translateY(26px);
  transition:opacity 1s var(--ease-exp),transform 1.1s var(--ease-exp)}
.js .cover.ready .kicker{opacity:1;transform:none;transition-delay:.15s}
.js .cover.ready .cover__name span:nth-child(1) b{opacity:1;transform:none;transition-delay:.28s}
.js .cover.ready .cover__name span:nth-child(2) b{opacity:1;transform:none;transition-delay:.4s}
.js .cover.ready .cover__sub{opacity:1;transform:none;transition-delay:.56s}
.js .cover.ready .cover__foot{opacity:1;transform:none;transition-delay:.68s}

@media (prefers-reduced-motion:reduce){
  .js .reveal,.js .cover__name span b,.js .cover .kicker,.js .cover__sub,.js .cover__foot{
    opacity:1!important;transform:none!important;transition:none!important}
  .js .cover__media img{transform:none!important;transition:none!important}
  .toc__row,.toc__row:hover{padding-left:0}
  .cover__media img,.spread__fig img,.toc__thumb img{transition:none!important}
}

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie{position:fixed;left:clamp(14px,3vw,28px);right:clamp(14px,3vw,28px);
  bottom:clamp(14px,3vw,24px);z-index:var(--z-dialog);max-width:540px;
  background:var(--paper);border:1px solid var(--line);
  box-shadow:0 26px 60px -28px oklch(0.135 0.006 60 / .5);
  padding:clamp(16px,2vw,22px);display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.cookie p{margin:0;flex:1;min-width:220px;font-family:var(--grotesk);font-size:.84rem;
  line-height:1.5;color:var(--ink-soft)}
.cookie a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:2px}
.cookie button{font-family:var(--grotesk);font-weight:600;font-size:.82rem;cursor:pointer;
  background:var(--ink);color:var(--paper);border:0;padding:.7em 1.4em;transition:background .3s}
.cookie button:hover{background:var(--accent)}
.cookie[hidden]{display:none}

/* focus */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:1px}
.cover :focus-visible,.plate :focus-visible,.colophon :focus-visible{outline-color:var(--accent-hi)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .spread{grid-template-columns:1fr}
  .spread__fig{margin-left:calc(-1 * var(--gut));margin-right:calc(-1 * var(--gut))}
  .spread__fig img{min-height:0;aspect-ratio:4/3}
  .spread__body{padding:clamp(30px,7vw,54px) 0 0}
  .colophon__grid{grid-template-columns:1fr;gap:clamp(34px,8vw,48px)}
}
@media (max-width:760px){
  :root{--nav-h:62px}
  .nav{position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--paper);color:var(--ink);padding:8px var(--gut) 22px;
    border-bottom:1px solid var(--line);box-shadow:0 24px 44px -28px oklch(0.135 0.006 60 / .4);
    transform:translateY(-130%);transition:transform .5s var(--ease-exp);visibility:hidden}
  .nav.open{transform:none;visibility:visible}
  .nav a:not(.langs a){width:100%;padding:1rem 0;border-bottom:1px solid var(--line-soft);
    font-size:1.05rem;opacity:1;font-family:var(--serif);font-weight:500}
  .nav a:not(.langs a)::after{display:none}
  .langs{margin-top:1rem;border-color:var(--line)}
  .langs a{color:var(--ink)}.langs a.on span{color:var(--paper)}
  .head:not(.solid) .langs a{color:var(--ink)}
  .burger{display:inline-flex}
  .cover__media img{object-position:50% 18%}
  .cover__index{display:none}
  .toc__row{grid-template-columns:auto 1fr;gap:18px}
  .toc__thumb{display:none}
}
@media (max-width:420px){
  .frontis__head .folio{display:none}
}

/* =========================================================
   INNER PAGES
   ========================================================= */

/* ---- chapter opener (inner-page cover plate) ---- */
.chapter{position:relative;min-height:clamp(460px,72svh,760px);display:flex;align-items:flex-end;
  overflow:hidden;background:var(--plate-2);color:var(--plate-ink)}
.chapter__media{position:absolute;inset:0;z-index:0}
.chapter__media img{width:100%;height:100%;object-fit:cover}
.chapter__media.bw img{filter:grayscale(1) contrast(1.04)}
.chapter__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, oklch(0.135 0.006 60 / .52) 0%, transparent 16%),
             linear-gradient(transparent 28%, oklch(0.135 0.006 60 / .9) 100%),
             linear-gradient(96deg, oklch(0.135 0.006 60 / .64) 0%, transparent 58%)}
.chapter__inner{position:relative;z-index:1;width:100%;
  padding-top:calc(var(--nav-h) + 30px);padding-bottom:clamp(40px,7vw,86px)}
.chapter__folio{font-family:var(--grotesk);font-weight:500;font-size:.84rem;letter-spacing:.04em;
  color:var(--plate-soft);margin:0 0 1.3rem;display:flex;align-items:center;gap:.8em}
.chapter__folio::before{content:"";width:30px;height:1px;background:var(--accent-hi)}
.chapter__title{font-family:var(--serif);font-weight:500;letter-spacing:-.022em;line-height:.98;
  font-size:clamp(2.7rem,7.6vw,5.6rem);color:var(--paper);margin:0;max-width:17ch;text-wrap:balance}
.chapter__title em{font-style:italic;color:var(--plate-ink)}
.chapter__sub{max-width:52ch;margin:1.5rem 0 0;color:var(--plate-soft);
  font-size:clamp(1.06rem,1.5vw,1.32rem);line-height:1.52}
.chapter__hint{margin:clamp(26px,4vw,44px) 0 0;font-family:var(--grotesk);font-weight:500;
  font-size:.78rem;letter-spacing:.02em;color:var(--plate-soft);display:inline-flex;align-items:center;gap:.6em}
.chapter__hint svg{width:1.05em;height:1.05em}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:no-preference){
  .js .chapter__folio{animation:rise .8s var(--ease-exp) both .10s}
  .js .chapter__title{animation:rise .9s var(--ease-exp) both .22s}
  .js .chapter__sub{animation:rise .9s var(--ease-exp) both .36s}
  .js .chapter__hint{animation:rise .9s var(--ease-exp) both .48s}
}

/* ---- generic page section + lede ---- */
.page{padding:clamp(64px,9vw,118px) 0}
.page--quiet{background:var(--paper-2)}
.lede{display:flex;align-items:baseline;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:1.2rem;margin-bottom:clamp(40px,6vw,72px)}
.lede h2{font-size:clamp(1.7rem,3vw,2.5rem);font-weight:500;max-width:18ch}
.lede h2 em{font-style:italic;color:var(--accent-ink)}
.lede p{max-width:46ch;color:var(--ink-soft);font-size:clamp(1rem,1.15vw,1.12rem)}

/* =========================================================
   PIATTI — catalogue of plates (colour; food stays appetising)
   ========================================================= */
.signature{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(0,.82fr);
  gap:clamp(28px,4vw,64px);align-items:center;margin-bottom:clamp(48px,7vw,92px)}
.signature__fig{position:relative;overflow:hidden;background:var(--paper-2);aspect-ratio:16/11}
.signature__fig img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.signature:hover .signature__fig img{transform:scale(1.035)}
.signature__tag{position:absolute;top:0;left:0;background:var(--accent);color:var(--paper);
  font-family:var(--grotesk);font-weight:600;font-size:.72rem;letter-spacing:.04em;padding:.5em .9em}
.signature__body .ix{font-family:var(--grotesk);font-weight:600;font-size:.82rem;color:var(--accent-ink);
  display:block;margin-bottom:.7rem}
.signature__body h3{font-size:clamp(1.6rem,2.8vw,2.5rem);font-weight:500;line-height:1.04;margin:0 0 .2em}
.signature__body h3 em{display:block;font-style:italic;font-weight:400;color:var(--ink-soft);
  font-size:.62em;margin-top:.35rem;letter-spacing:0}
.signature__body p{color:var(--ink-soft);margin-top:1rem;max-width:50ch}

.plates{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(240px,28vw,320px),1fr));
  gap:clamp(30px,3.4vw,52px) clamp(20px,2.4vw,34px)}
.plate-item{display:flex;flex-direction:column}
.plate-item__fig{position:relative;overflow:hidden;background:var(--paper-2);aspect-ratio:4/5}
.plate-item__fig img,.plate-item__fig video{position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform 1.1s var(--ease)}
.plate-item:hover .plate-item__fig img{transform:scale(1.05)}
.plate-item__badge{position:absolute;top:0;left:0;z-index:1;background:var(--paper);color:var(--accent-ink);
  font-family:var(--grotesk);font-weight:600;font-size:.66rem;letter-spacing:.04em;padding:.45em .7em}
.plate-item__cap{padding-top:clamp(.9rem,1.4vw,1.15rem)}
.plate-item__cap .ix{font-family:var(--grotesk);font-weight:600;font-size:.74rem;letter-spacing:.03em;
  color:var(--ink-faint);display:block;margin-bottom:.5rem}
.plate-item__cap h3{font-size:clamp(1.18rem,1.5vw,1.42rem);font-weight:500;line-height:1.12;letter-spacing:-.01em}
.plate-item__cap h3 em{display:block;font-style:italic;font-weight:400;color:var(--accent-ink);
  font-size:.82em;margin-top:.25rem}
.plate-item__cap p{font-family:var(--grotesk);font-size:.9rem;line-height:1.5;color:var(--ink-soft);
  margin-top:.6rem}
.plate-item.tall{grid-row:span 1}
.plate-item.tall .plate-item__fig{aspect-ratio:3/4}

/* =========================================================
   STORIA — horizontal pinned timeline (archival B/W)
   ========================================================= */
.timeline{position:relative;background:var(--paper)}
.timeline__sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;
  padding:calc(var(--nav-h) + 10px) 0 80px}
.timeline__rail{position:absolute;left:0;right:0;top:calc(50% + var(--nav-h)/2 - 30px);height:1px;
  background:var(--line);z-index:0}
.timeline__track{display:flex;align-items:stretch;will-change:transform}
.t-panel{flex:0 0 auto;width:min(86vw,540px);padding:0 clamp(18px,2.4vw,42px);
  display:flex;flex-direction:column;justify-content:center;position:relative}
.t-node{display:flex;align-items:baseline;gap:1rem;margin-bottom:.9rem}
.t-node .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 5px oklch(0.47 0.14 32 / .16);flex:0 0 auto;align-self:center}
.t-node .yr{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,4.6vw,3.6rem);
  line-height:.85;letter-spacing:-.022em;color:var(--ink)}
.t-node .yr.small{font-size:clamp(1.5rem,2.8vw,2.1rem);font-style:italic;font-weight:400}
.t-place{font-family:var(--grotesk);font-weight:600;font-size:.76rem;letter-spacing:.04em;
  color:var(--accent-ink);margin-bottom:.95rem}
.t-card{background:var(--paper);border:1px solid var(--line);overflow:hidden;
  box-shadow:0 32px 60px -46px oklch(0.135 0.006 60 / .5)}
.t-card .pic{height:clamp(168px,28vh,290px);overflow:hidden}
.t-card .pic img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.04)}
.t-card .txt{padding:clamp(18px,1.8vw,28px)}
.t-card h3{font-size:clamp(1.35rem,2.2vw,1.85rem);font-weight:500;margin-bottom:.5rem}
.t-card h3 em{font-style:italic;color:var(--accent-ink)}
.t-card p{font-family:var(--grotesk);font-size:.92rem;line-height:1.55;color:var(--ink-soft)}
.t-card .aside{font-family:var(--serif);font-style:italic;font-size:1.12rem;color:var(--ink);
  margin-top:.85rem;line-height:1.3}
.t-open .big,.t-end .big{font-family:var(--serif);font-weight:400;letter-spacing:-.02em}
.t-open .big{font-size:clamp(2.6rem,6vw,4.8rem);line-height:.98;color:var(--ink)}
.t-open .big em,.t-end .big em{font-style:italic;color:var(--accent-ink)}
.t-end{align-items:flex-start}
.t-end .big{font-size:clamp(2.4rem,5vw,3.8rem);line-height:1;margin-bottom:1.2rem;color:var(--ink)}
.timeline__hud{position:absolute;left:var(--gut);right:var(--gut);bottom:clamp(20px,4vh,38px);z-index:5;
  display:flex;align-items:center;gap:1.2rem}
.timeline__bar{flex:1;height:2px;background:var(--line);position:relative;overflow:hidden}
.timeline__bar i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--accent)}
.timeline__hint{font-family:var(--grotesk);font-weight:500;font-size:.72rem;letter-spacing:.03em;
  color:var(--ink-soft);display:flex;align-items:center;gap:.5em}
.timeline__hint svg{width:1.05em;height:1.05em}
/* static fallback (mobile / reduced motion): native horizontal swipe */
.timeline.is-static .timeline__sticky{position:static;height:auto;display:block;overflow:visible;padding:0}
.timeline.is-static .timeline__rail{display:none}
.timeline.is-static .timeline__track{overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;transform:none!important;padding-bottom:1.4rem;
  scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.timeline.is-static .t-panel{scroll-snap-align:center;width:min(85vw,420px)}
.timeline.is-static .timeline__hud{position:static;margin:.6rem var(--gut) 0}
.timeline.is-static .timeline__bar{display:none}

/* =========================================================
   ADESSO — places (colour), video band, book
   ========================================================= */
.place{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.place + .place{margin-top:clamp(56px,9vw,120px)}
.place--rev .place__media{order:2}
.place__media{position:relative;overflow:hidden;background:var(--paper-2)}
.place__media img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.2s var(--ease)}
.place__media:hover img{transform:scale(1.04)}
.place__loc{font-family:var(--grotesk);font-weight:600;font-size:.78rem;letter-spacing:.03em;
  color:var(--accent-ink);display:flex;align-items:center;gap:.55em;margin-bottom:1.1rem}
.place__loc svg{width:1.1em;height:1.1em}
.place h2{font-size:clamp(1.9rem,3.8vw,3rem);font-weight:500;margin-bottom:.3em}
.place h2 em{font-style:italic;color:var(--accent-ink)}
.place .sub{font-family:var(--serif);font-style:italic;color:var(--ink-soft);
  font-size:clamp(1.1rem,1.5vw,1.3rem);margin-bottom:1.1rem}
.place p{color:var(--ink-soft);max-width:50ch}
.place p em{font-style:italic;color:var(--ink)}

.vband{position:relative;height:clamp(280px,46vw,560px);overflow:hidden;background:var(--plate-2)}
.vband video{width:100%;height:100%;object-fit:cover;opacity:.66}
.vband__cap{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;gap:.9rem;padding-inline:var(--gut);
  background:linear-gradient(oklch(0.135 0.006 60 / .42), oklch(0.135 0.006 60 / .68))}
.vband__cap .e{font-family:var(--grotesk);font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--accent-hi)}
.vband__cap .t{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.7rem,4vw,3.2rem);color:var(--paper);line-height:1.12;max-width:22ch}

.book{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.book__media{overflow:hidden;border:1px solid var(--line);background:var(--paper)}
.book__media img{width:100%;display:block}
.book__body h2{font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:500;margin-bottom:.5em}
.book__body h2 em{font-style:italic;color:var(--accent-ink)}
.book__body p{color:var(--ink-soft);max-width:52ch}
.book__body p strong{color:var(--ink);font-weight:600}
.awards{margin-top:1.8rem;border-top:1px solid var(--ink)}
.award-row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding:.95rem 0;border-bottom:1px solid var(--line)}
.award-row b{font-family:var(--serif);font-weight:500;font-size:1.05rem;color:var(--ink)}
.award-row span{font-family:var(--grotesk);font-size:.82rem;color:var(--ink-soft);text-align:right;flex:0 0 auto}

/* ---- inner-page responsive ---- */
@media (max-width:900px){
  .signature{grid-template-columns:1fr;gap:clamp(20px,5vw,32px)}
  .signature__fig{aspect-ratio:16/10}
  .place{grid-template-columns:1fr;gap:clamp(22px,6vw,34px)}
  .place--rev .place__media{order:0}
  .book{grid-template-columns:1fr;gap:clamp(26px,7vw,40px)}
  .book__media{max-width:440px}
}
@media (max-width:760px){
  .lede{gap:.6rem}
  .award-row{flex-direction:column;gap:.15rem}
  .award-row span{text-align:left}
}

/* =========================================================
   LEGAL / DOCUMENT PAGES (paper, header solid by default)
   ========================================================= */
body.doc .head{background:var(--paper);color:var(--ink);border-bottom-color:var(--line)}
.doc-page{padding-top:calc(var(--nav-h) + clamp(40px,7vw,84px));padding-bottom:clamp(64px,9vw,120px)}
.doc-page .label{display:block;margin-bottom:1.1rem}
.doc-page h1{font-family:var(--serif);font-weight:500;letter-spacing:-.02em;
  font-size:clamp(2.1rem,5vw,3.4rem);line-height:1.05;margin:0 0 1.5rem;text-wrap:balance}
.doc-page h1 em{font-style:italic;color:var(--accent-ink)}
.doc-wrap{max-width:72ch}
.doc-wrap h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.2rem,2.1vw,1.5rem);
  color:var(--ink);margin:2.5rem 0 .6rem;letter-spacing:-.01em}
.doc-wrap h2:first-of-type{margin-top:1.2rem}
.doc-wrap p,.doc-wrap li{color:var(--ink-soft);font-size:1.02rem;line-height:1.72}
.doc-wrap ul{padding-left:1.2rem;margin:0 0 1.15em}
.doc-wrap li{margin-bottom:.5rem}
.doc-wrap a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:2px;
  text-decoration-color:oklch(0.43 0.135 32 / .42);transition:text-decoration-color .3s var(--ease)}
.doc-wrap a:hover{text-decoration-color:var(--accent-ink)}
.doc-wrap strong{color:var(--ink);font-weight:600}
.doc-note{background:var(--paper-2);border:1px solid var(--line);border-radius:2px;
  padding:1.05rem 1.25rem;margin:1.6rem 0;font-size:.95rem;line-height:1.6;color:var(--ink-soft)}
.doc-updated{font-family:var(--grotesk);font-size:.78rem;letter-spacing:.02em;
  color:var(--ink-faint);margin-top:2.8rem}

/* =========================================================
   STORIA — la mia storia attraverso gli amici (guest wall)
   B/N by default, colour on hover/focus
   ========================================================= */
.amici{padding:clamp(64px,9vw,118px) 0;background:var(--paper-2)}
.amici__grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(clamp(168px,21vw,228px),1fr));
  gap:clamp(22px,2.6vw,38px) clamp(16px,1.8vw,26px)}
.amico{display:flex;flex-direction:column}
.amico__fig{position:relative;overflow:hidden;background:var(--paper);aspect-ratio:1/1}
.amico__fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 28%;
  filter:grayscale(1) contrast(1.04);transition:filter .6s var(--ease),transform 1.2s var(--ease)}
.amico:hover .amico__fig img,.amico:focus-within .amico__fig img{
  filter:grayscale(0) contrast(1.02);transform:scale(1.045)}
.amico__cap{padding-top:.85rem}
.amico__cap h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.04rem,1.25vw,1.24rem);
  line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
.amico__cap p{font-family:var(--grotesk);font-size:.84rem;line-height:1.46;color:var(--ink-soft);margin-top:.35rem}
@media (max-width:520px){
  .amici__grid{grid-template-columns:1fr 1fr;gap:18px 14px}
}
