@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@300;400;500;600;700&display=swap');
:root{
  --cream:#f6f5f2; --cream-2:#efece5;
  --ink:#111111; --ink-2:#2a2a2a; --ink-3:#5a5a5a; --ink-4:#999999;
  --line:#e3dfd6; --line-2:#d4cfc2;
  --antracite:#1a1a1a; --sabbia:#c9b89d; --terra:#b8442e; --ottone:#7a6b58;
  --font-sans:'Hanken Grotesk','Inter',-apple-system,sans-serif;
  --font-disp:'Hanken Grotesk','Inter Tight',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  /* — scala di spaziatura modulare · base 8px (Swiss grid) — */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s6:48px; --s8:64px; --s12:96px; --s16:128px;
  --mx:6vw;                              /* margine esterno (gabbia) */
  --gutter:clamp(16px,2vw,32px);         /* gutter griglia 12 colonne (s2→s4) */
  --gap-lg:clamp(24px,3vw,48px);         /* gutter ampio (s3→s6) */
  --wrap:1480px;                         /* griglia larga (liste, gallerie a 3 col) */
  --wrap-text:1040px;                     /* colonna contenuti standard */
  --wrap-narrow:860px;                    /* colonna prosa / articoli */
  --sec-y:clamp(48px,5.5vh,96px);        /* ritmo verticale sezioni (s6→s12) */
  --sec-y-sm:clamp(24px,3.5vh,48px);     /* distacco contenuto (s3→s6) */
  --sec-y-lg:clamp(64px,8vh,128px);      /* respiro maggiore (s8→s16) */
  --foot-gap:clamp(64px,8vh,96px);       /* (s8→s12) */
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-sans);background:var(--cream);color:var(--ink);
  line-height:1.55;font-weight:400;-webkit-font-smoothing:antialiased;}
::selection{background:var(--ink);color:var(--cream);}
img{display:block;}
a{color:inherit;}

/* lang toggle */
.lang-en{display:none;}
body.en .lang-it{display:none;}
body.en .lang-en{display:inline;}
body.en .lang-en.block{display:block;}

/* nav (solido sulle sotto-pagine) */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;
  justify-content:space-between;padding:16px var(--mx);background:var(--cream);
  border-bottom:1px solid transparent;}
nav .wordmark{display:flex;align-items:center;text-decoration:none;}
nav .wordmark img{height:17px;width:auto;display:block;}
nav .nav-right{display:flex;align-items:center;gap:20px;}
nav .nav-links{display:flex;gap:28px;}
@media(min-width:761px){nav .nav-links{position:absolute;left:50%;top:0;bottom:0;transform:translate(-50%,4px);align-items:center;}}
@media(min-width:761px){nav .lang-switch,nav .nav-search{transform:translateY(4px);}}
nav .nav-search{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:none;border:0;cursor:pointer;padding:0;color:var(--ink);opacity:.78;transition:opacity .3s,color .4s;}
nav .nav-search:hover{opacity:1;}
nav .nav-search svg{width:16px;height:16px;display:block;}
nav .nav-links a{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;line-height:1;
  letter-spacing:0.14em;color:var(--ink);text-decoration:none;opacity:.78;transition:opacity .3s;}
nav .nav-links a:hover,nav .nav-links a.active{opacity:1;color:var(--terra);}
.lang-switch{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;color:var(--ink);line-height:1;
  background:none;border:none;cursor:pointer;padding:0;text-decoration:none;}
.lang-switch:hover{text-decoration:none;}
.lang-switch span{opacity:.4;transition:opacity .3s;}
body.en .lang-switch .en{opacity:1;}
body:not(.en) .lang-switch .it{opacity:1;}
@media(max-width:760px){nav .nav-links{display:none;}}
/* nav trasparente sopra la copertina (pagine con article-hero) — come in home */
body.has-hero nav{background:transparent;border-bottom:0;transition:background .4s ease;}
body.has-hero nav::before{content:"";position:absolute;left:0;right:0;top:0;height:172px;z-index:-1;
  pointer-events:none;background:linear-gradient(to bottom,rgba(15,13,11,.62),rgba(15,13,11,.28) 45%,rgba(15,13,11,0));
  transition:opacity .4s ease;}
body.has-hero nav .wordmark img{filter:brightness(0) invert(1);transition:filter .4s ease;}
body.has-hero nav .nav-links a{color:#f6f5f2;}
body.has-hero nav .lang-switch{color:#f6f5f2;}
body.has-hero nav .nav-search{color:#f6f5f2;}
body.has-hero nav.solid .nav-search{color:var(--ink);}
body.has-hero nav.solid{background:var(--cream);}
body.has-hero nav.solid::before{opacity:0;}
body.has-hero nav.solid .wordmark img{filter:none;}
body.has-hero nav.solid .nav-links a{color:var(--ink);}
body.has-hero nav .nav-links a:hover,body.has-hero nav .nav-links a.active,
body.has-hero nav.solid .nav-links a:hover,body.has-hero nav.solid .nav-links a.active{color:var(--terra);}
body.has-hero nav.solid .lang-switch{color:var(--ink);}
/* ── menu mobile (hamburger) — solo telefono/tablet ── */
.nav-burger{display:none;background:none;border:0;cursor:pointer;width:24px;height:16px;position:relative;padding:0;margin-left:6px;color:var(--ink);}
.nav-burger span{position:absolute;left:0;right:0;height:1.5px;background:currentColor;transition:transform .3s,opacity .3s;}
.nav-burger span:nth-child(1){top:1px;} .nav-burger span:nth-child(2){top:7px;} .nav-burger span:nth-child(3){top:13px;}
body.nav-open .nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg);}
body.nav-open .nav-burger span:nth-child(2){opacity:0;}
body.nav-open .nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}
.nav-mobile{position:fixed;top:0;left:0;right:0;z-index:49;background:var(--cream);
  transform:translateY(-110%);transition:transform .42s cubic-bezier(.2,.7,.3,1);
  padding:64px var(--mx) 26px;display:none;flex-direction:column;box-shadow:0 22px 44px rgba(0,0,0,.10);}
body.nav-open .nav-mobile{transform:translateY(0);}
.nav-mobile a{font-family:var(--font-mono);font-size:13px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;padding:15px 0;border-bottom:1px solid var(--line);}
.nav-mobile a:last-child{border-bottom:0;}
body.has-hero nav .nav-burger{color:#f6f5f2;}
body.has-hero nav.solid .nav-burger{color:var(--ink);}
body.nav-open nav .nav-burger{color:var(--ink);}
@media(max-width:760px){.nav-burger{display:block;} .nav-mobile{display:flex;}}

/* ── ricerca nel sito (overlay) ── */
.search-modal{position:fixed;inset:0;z-index:60;display:none;}
.search-modal.open{display:block;}
.search-modal .sm-backdrop{position:absolute;inset:0;background:rgba(15,13,11,.55);}
.search-modal .sm-panel{position:relative;max-width:640px;margin:11vh auto 0;background:var(--cream);
  padding:clamp(24px,3vw,36px);box-shadow:0 30px 70px rgba(0,0,0,.24);
  transform:translateY(-10px);opacity:0;transition:transform .32s cubic-bezier(.2,.7,.3,1),opacity .32s;}
.search-modal.open .sm-panel{transform:none;opacity:1;}
.search-modal .sm-field{display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--ink);padding-bottom:13px;}
.search-modal .sm-field svg{width:19px;height:19px;color:var(--ink-3);flex:none;}
.search-modal input{flex:1;font-family:var(--font-disp);font-weight:300;font-size:clamp(20px,3vw,28px);
  letter-spacing:-0.01em;border:0;background:none;color:var(--ink);outline:none;}
.search-modal input::placeholder{color:var(--ink-4);}
.search-modal .sm-close{position:absolute;top:14px;right:16px;background:none;border:0;font-size:24px;
  line-height:1;color:var(--ink-3);cursor:pointer;padding:4px;}
.search-modal .sm-close:hover{color:var(--ink);}
.search-modal .sm-hint{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-4);margin-top:15px;}
.search-modal .sm-results{margin-top:14px;max-height:48vh;overflow:auto;}
.search-modal .sm-res{display:block;padding:13px 2px;border-bottom:1px solid var(--line);text-decoration:none;}
.search-modal .sm-res:last-child{border-bottom:0;}
.search-modal .sm-res .rt{font-size:15px;color:var(--ink);transition:color .25s;}
.search-modal .sm-res .rk{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ottone);margin-top:4px;}
.search-modal .sm-res:hover .rt{color:var(--terra);}
@media(max-width:760px){.search-modal .sm-panel{margin:8vh var(--mx) 0;}}

/* page header */
.page-head{padding:calc(64px + 9vh) var(--mx) clamp(40px,6vh,80px);}
.sec-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:30px;display:flex;align-items:center;gap:14px;}
.sec-eyebrow::before{content:"";width:26px;height:1px;background:var(--line-2);}
.page-head h1{font-family:var(--font-disp);font-weight:300;
  font-size:clamp(40px,8vw,104px);line-height:0.98;letter-spacing:-0.03em;margin-bottom:26px;}
.page-head .lede{font-size:clamp(16px,1.5vw,19px);line-height:1.6;color:var(--ink-2);max-width:54ch;}
.page-head .lede p + p{margin-top:14px;}
.backlink{display:inline-block;margin-top:30px;font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--line-2);padding-bottom:4px;transition:border-color .3s;}
.backlink:hover{border-color:var(--ink);}

/* ── PROGETTI index · category rows + carousel ── */
.catrow{padding:var(--sec-y) 0;border-top:1px solid var(--line);}
.catrow:first-of-type{border-top:none;}
.catrow-head{padding:0 var(--mx);display:flex;justify-content:space-between;
  align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(26px,3.5vh,44px);}
.catrow-head .ci{max-width:62ch;}
.catrow-head .ix{font-family:var(--font-mono);font-size:12px;letter-spacing:0.12em;
  color:var(--ottone);margin-bottom:16px;}
.catrow-head h2{margin:0;}
.catrow-head h2 a{font-family:var(--font-disp);font-weight:300;
  font-size:clamp(30px,5.4vw,74px);line-height:0.98;letter-spacing:-0.03em;
  color:var(--ink);text-decoration:none;display:inline-block;transition:color .3s,transform .5s cubic-bezier(.2,.7,.3,1);}
.catrow-head h2 a .ar{display:inline-block;font-weight:300;margin-left:.2em;
  transform:translateX(0);transition:transform .45s cubic-bezier(.2,.7,.3,1);color:var(--ink-4);}
.catrow-head h2 a:hover{color:var(--terra);}
.catrow-head h2 a:hover .ar{transform:translateX(.25em);color:var(--terra);}
.catrow-head .cd{font-size:14.5px;line-height:1.6;color:var(--ink-3);margin-top:14px;}
.catrow-head .discover{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--ink);text-decoration:none;white-space:nowrap;
  border-bottom:1px solid var(--line-2);padding-bottom:4px;transition:border-color .3s;}
.catrow-head .discover:hover{border-color:var(--ink);}

.carwrap{position:relative;}
.carousel{display:flex;gap:var(--gutter);overflow-x:auto;scroll-snap-type:x mandatory;
  padding:0 var(--mx) 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.carousel::-webkit-scrollbar{display:none;}
.slide{flex:0 0 clamp(240px,30vw,400px);scroll-snap-align:start;text-decoration:none;color:inherit;}
.slide .sph{aspect-ratio:4/5;overflow:hidden;background:var(--cream-2);}
.slide .sph img{width:100%;height:100%;object-fit:cover;
  transition:transform 1.5s cubic-bezier(.2,.7,.3,1);}
.slide:hover .sph img{transform:scale(1.04);}
.slide .scn{font-family:var(--font-disp);font-weight:500;font-size:15px;margin-top:12px;letter-spacing:-0.01em;}
.slide .scx{font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--ink-3);margin-top:4px;}
.carbtns{display:flex;gap:10px;padding:18px var(--mx) 0;}
.carbtn{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);background:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);
  transition:background .3s,color .3s,border-color .3s;}
.carbtn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.carbtn svg{width:16px;height:16px;}

/* ── category page · cards grid ── */
.cards-wrap{padding:0 var(--mx) var(--sec-y-lg);}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter);}
.card{text-decoration:none;color:inherit;display:block;}
.card .ph{aspect-ratio:4/5;overflow:hidden;background:var(--cream-2);}
.card .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);
  transition:transform 1.5s cubic-bezier(.2,.7,.3,1),filter .7s ease;}
.card:hover .ph img{transform:scale(1.04);filter:grayscale(0);}
/* progetti · griglia anteprima per categoria (max 3) */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);padding:0 var(--mx);}
@media(max-width:760px){.cat-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.cat-grid{grid-template-columns:1fr;}}
.card .cn{font-family:var(--font-disp);font-weight:500;font-size:15px;letter-spacing:-0.01em;margin-top:13px;}
.card .cx{font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.07em;text-transform:uppercase;
  color:var(--ink-3);margin-top:5px;}
.card .ext{color:var(--ottone);opacity:0;transition:opacity .3s;}
.card:hover .ext{opacity:1;}
@media(max-width:900px){.cards{grid-template-columns:repeat(3,1fr);}}
@media(max-width:560px){.cards{grid-template-columns:repeat(2,1fr);}}

/* ── project page · gallery ── */
.proj-meta{padding:0 var(--mx);display:flex;gap:30px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--ink-3);margin-top:6px;}
.proj-cta{padding:26px var(--mx) 0;display:flex;gap:18px;flex-wrap:wrap;align-items:center;}
.proj-cta a.primary{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-mono);
  font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;
  border:1px solid var(--ink);padding:15px 26px;transition:all .35s cubic-bezier(.2,.7,.3,1);}
.proj-cta a.primary:hover{background:var(--ink);color:var(--cream);}
.pgallery{padding:var(--sec-y) var(--mx) var(--sec-y);
  max-width:var(--wrap-text);margin:0 auto;}
.pgallery figure{margin-bottom:clamp(20px,3vw,40px);}
.pgallery img{width:100%;height:auto;background:var(--cream-2);}
.pgallery .pg-cap{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--ink-4);margin-top:10px;}
@media(min-width:760px){
  .pgallery .pg-duo{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-lg);}
  .pgallery .pg-duo figure{margin-bottom:0;}
}

/* footer */
footer{background:var(--antracite);color:rgba(246,245,242,0.65);padding:var(--foot-gap) var(--mx) 40px;}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
  padding-bottom:var(--foot-gap);border-bottom:1px solid rgba(246,245,242,0.12);}
.foot-top .wm img{height:30px;width:auto;}
.foot-top .tag{font-size:13.5px;line-height:1.6;max-width:34ch;color:rgba(246,245,242,0.55);margin-top:18px;}
.foot-col h5{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;
  color:rgba(246,245,242,0.45);margin-bottom:18px;}
.foot-col a{display:block;font-size:13.5px;color:rgba(246,245,242,0.75);text-decoration:none;
  margin-bottom:11px;transition:color .3s;}
.foot-col a:hover{color:var(--cream);}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:30px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.08em;color:rgba(246,245,242,0.4);
  flex-wrap:wrap;gap:14px;}
@media(max-width:760px){.foot-top{grid-template-columns:1fr;gap:34px;}}

/* reveal (effetti misurati) */
.scrollprog{display:none;}
@media (prefers-reduced-motion: no-preference){
  html.js .reveal{opacity:0;transform:translateY(40px);
    transition:opacity 1.3s cubic-bezier(.2,.7,.3,1), transform 1.3s cubic-bezier(.2,.7,.3,1);will-change:opacity,transform;}
  html.js .reveal.in{opacity:1;transform:none;}
}

/* ── project story (scroll alternato, stile Apple) ── */
.phero{position:relative;width:100%;height:clamp(420px,80vh,880px);overflow:hidden;background:var(--cream-2);}
.phero img{width:100%;height:100%;object-fit:cover;display:block;}
.pintro{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y) var(--mx) clamp(30px,5vh,60px);}
.pintro .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:22px;}
.pintro p{font-family:var(--font-disp);font-weight:300;font-size:clamp(22px,3vw,40px);line-height:1.25;letter-spacing:-0.015em;color:var(--ink);max-width:24ch;}
.story{padding-bottom:clamp(30px,5vh,60px);}
.chap{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y) var(--mx);}
.chap.center{text-align:center;}
.chap .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:18px;}
.chap h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(26px,4vw,52px);line-height:1.08;letter-spacing:-0.02em;margin-bottom:20px;}
.chap p{font-size:clamp(16px,1.5vw,20px);line-height:1.62;color:var(--ink-2);max-width:60ch;}
.chap.center p{margin-left:auto;margin-right:auto;}
.media{width:100%;margin:0;background:var(--cream-2);overflow:hidden;}
.media img{width:100%;height:auto;display:block;}
.media.tall img{height:clamp(420px,86vh,900px);object-fit:cover;}
.media-duo{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
@media(max-width:700px){.media-duo{grid-template-columns:1fr;}}
.vidblock{position:relative;width:100%;aspect-ratio:16/9;background:#14110e;overflow:hidden;cursor:pointer;}
.vidblock>img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);
  transition:filter .7s ease,transform 1.3s cubic-bezier(.2,.7,.3,1);}
.vidblock:hover>img{filter:grayscale(0);transform:scale(1.03);}
.vidblock .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.vidblock .play i{width:74px;height:74px;border-radius:50%;background:rgba(246,245,242,.92);display:flex;align-items:center;justify-content:center;transition:transform .35s,background .35s;}
.vidblock:hover .play i{transform:scale(1.08);background:var(--cream);}
.vidblock .play i::before{content:"";display:block;width:0;height:0;margin-left:5px;border-left:18px solid var(--ink);border-top:12px solid transparent;border-bottom:12px solid transparent;}
.vidblock iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.vidcap{max-width:var(--wrap-text);margin:0 auto;padding:14px var(--mx) 0;font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-4);}
.pcredits{max-width:1280px;margin:0 auto;padding:clamp(24px,3.8vh,52px) var(--mx) 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:repeat(5,auto);justify-content:start;gap:18px clamp(34px,4.6vw,76px);}
@media(max-width:760px){.pcredits{grid-template-columns:repeat(3,auto);}}
@media(max-width:480px){.pcredits{grid-template-columns:repeat(2,auto);}}
.pcredits .cr{font-size:12.5px;color:var(--ink-3);line-height:1.5;}
.pcredits .cr b{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-4);display:block;margin-bottom:4px;font-weight:500;}
.pfooternav{max-width:1280px;margin:0 auto;padding:clamp(24px,3.8vh,52px) var(--mx) var(--sec-y);}

/* ════ PROJECT STORY · versione cinematografica ════ */
.phero{position:relative;width:100%;height:100vh;min-height:520px;overflow:hidden;background:#14110e;}
.phero img{position:absolute;inset:0;width:100%;height:112%;object-fit:cover;will-change:transform;}
.phero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top, rgba(14,12,10,.84) 0%, rgba(14,12,10,.34) 34%, rgba(14,12,10,.04) 62%, rgba(14,12,10,.18) 100%);}
.phero .ph-cap{position:absolute;left:var(--mx);right:var(--mx);bottom:9vh;z-index:2;color:var(--cream);}
.phero .ph-k{font-family:var(--font-mono);font-size:12px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--sabbia);margin-bottom:22px;}
.phero h1{font-family:var(--font-disp);font-weight:300;font-size:clamp(42px,8.4vw,118px);
  line-height:0.95;letter-spacing:-0.035em;color:var(--cream);max-width:16ch;}
.phero .ph-meta{display:flex;gap:26px;flex-wrap:wrap;margin-top:26px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(246,245,242,.72);}
.phero .scrollcue{position:absolute;left:var(--mx);bottom:3.4vh;z-index:2;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(246,245,242,.55);}

.statement{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y-lg) var(--mx) var(--sec-y);}
.statement .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:26px;}
.statement p{font-family:var(--font-disp);font-weight:200;font-size:clamp(26px,3.7vw,54px);
  line-height:1.18;letter-spacing:-0.02em;color:var(--ink);max-width:20ch;}

.media.par{height:clamp(440px,74vh,760px);overflow:hidden;}
.media.par img{width:100%;height:112%;object-fit:cover;will-change:transform;}

.chap{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y-lg) var(--mx);}
.chap .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:20px;}
.chap h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,4.4vw,60px);line-height:1.06;letter-spacing:-0.025em;margin-bottom:22px;}
.chap p{font-size:clamp(16px,1.55vw,21px);line-height:1.62;color:var(--ink-2);max-width:58ch;}
.chap.center{text-align:center;}
.chap.center p{margin:0 auto;}

/* testo sopra l'immagine (cinematic) */
.chap-over{position:relative;width:100%;min-height:clamp(440px,74vh,760px);overflow:hidden;display:flex;align-items:flex-end;background:#14110e;}
.chap-over img{position:absolute;inset:0;width:100%;height:112%;object-fit:cover;will-change:transform;}
.chap-over::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top, rgba(14,12,10,.80) 0%, rgba(14,12,10,.30) 42%, rgba(14,12,10,0) 72%);}
.chap-over .inner{position:relative;z-index:2;padding:0 var(--mx) 10vh;max-width:48ch;color:var(--cream);}
.chap-over .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--sabbia);margin-bottom:18px;}
.chap-over h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,4.4vw,62px);line-height:1.04;letter-spacing:-0.025em;color:var(--cream);margin-bottom:18px;}
.chap-over p{font-size:clamp(16px,1.5vw,20px);line-height:1.6;color:rgba(246,245,242,.86);max-width:52ch;}

/* banda scura · momento materico/atmosferico */
.darkband{background:var(--antracite);color:var(--cream);}
.darkband .inner{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y-lg) var(--mx);}
.darkband .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--sabbia);margin-bottom:22px;}
.darkband h2{font-family:var(--font-disp);font-weight:200;font-size:clamp(26px,3.8vw,54px);line-height:1.14;letter-spacing:-0.02em;color:var(--cream);max-width:22ch;margin-bottom:20px;}
.darkband p{font-size:clamp(16px,1.5vw,20px);line-height:1.62;color:rgba(246,245,242,.62);max-width:56ch;}

.vidblock{margin:0;}
.pcredits{border-top:1px solid var(--line);}

/* ════ LISTING DINAMICO (meno monotono) ════ */
/* carosello: slide a misure/altezze sfalsate */
.carousel{align-items:flex-end;}
.slide .sph{aspect-ratio:4/5;}
.slide:nth-child(3n) .sph{aspect-ratio:3/4;}
.slide:nth-child(4n) .sph{aspect-ratio:1/1;}
.slide:nth-child(5n) .sph{aspect-ratio:5/6;}
.slide:nth-child(3n){flex-basis:clamp(300px,36vw,520px);}
/* righe categoria alternate */
.catrow.alt .catrow-head{flex-direction:row-reverse;}
.catrow.alt .catrow-head .ci{text-align:right;}
.catrow.alt .catrow-head h2 a .ar{margin-left:0;margin-right:.2em;}
@media(max-width:760px){.catrow.alt .catrow-head{flex-direction:column;}.catrow.alt .catrow-head .ci{text-align:left;}}

/* griglia editoriale asimmetrica (pagine categoria) */
.egrid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.6vw,28px);grid-auto-flow:dense;}
.egrid .card{display:block;text-decoration:none;color:inherit;}
.egrid .card .ph{aspect-ratio:4/5;overflow:hidden;background:var(--cream-2);}
.egrid .card.land .ph{aspect-ratio:16/10;}
.egrid .card.sq .ph{aspect-ratio:1/1;}
.egrid .card .ph img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:transform 1.5s cubic-bezier(.2,.7,.3,1),filter .7s ease;}
.egrid .card:hover .ph img{transform:scale(1.05);filter:grayscale(0);}
@media(hover:none){.card .ph img,.egrid .card .ph img{filter:none;}}
.egrid .card.s4{grid-column:span 4;} .egrid .card.s5{grid-column:span 5;}
.egrid .card.s6{grid-column:span 6;} .egrid .card.s7{grid-column:span 7;}
.egrid .card.s8{grid-column:span 8;} .egrid .card.s12{grid-column:span 12;}
@media(max-width:820px){.egrid{grid-template-columns:repeat(2,1fr);gap:14px;}
  .egrid .card{grid-column:span 1 !important;} .egrid .card .ph{aspect-ratio:4/5 !important;}}
@media(max-width:480px){.egrid{grid-template-columns:1fr;}}

/* capitoli: allineamento a destra */
.chap.right{text-align:right;}
.chap.right p{margin-left:auto;}
.chap.right .k{}

/* ── capitolo affiancato testo+immagine (niente testo nel vuoto) ── */
.split{display:grid;grid-template-columns:1.04fr 0.96fr;gap:clamp(28px,5vw,84px);align-items:center;
  max-width:1280px;margin:0 auto;padding:var(--sec-y) var(--mx);}
.split .s-txt .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:18px;}
.split .s-txt h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(26px,3.5vw,50px);line-height:1.05;letter-spacing:-0.025em;margin-bottom:20px;}
.split .s-txt p{font-size:clamp(16px,1.5vw,20px);line-height:1.62;color:var(--ink-2);max-width:46ch;}
.split .s-im{overflow:hidden;background:var(--cream-2);}
.split .s-im img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;display:block;transition:transform 1.6s cubic-bezier(.2,.7,.3,1);}
.split:hover .s-im img{transform:scale(1.04);}
/* foto verticali in B/N, a colori al passaggio del mouse */
.split:not(.vid-split) .s-im img{filter:grayscale(1);transition:transform 1.6s cubic-bezier(.2,.7,.3,1),filter .6s ease;}
.split:not(.vid-split):hover .s-im img{filter:grayscale(0);}
@media(hover:none){.split:not(.vid-split) .s-im img{filter:none;}}
.split.rev .s-txt{order:2;}
.split.rev .s-im{order:1;}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:22px;padding-top:var(--sec-y);padding-bottom:var(--sec-y);}
  .split.rev .s-txt{order:2;}.split.rev .s-im{order:1;}
  .split .s-im img{aspect-ratio:16/11;}}

/* ── respiro tra i blocchi a tutta larghezza + reveal a tendina ── */
.media,.vidblock{margin-top:clamp(16px,3vh,52px);margin-bottom:clamp(16px,3vh,52px);}
.chap-over{margin-top:clamp(16px,3vh,52px);margin-bottom:clamp(16px,3vh,52px);}
.vidblock{background:var(--antracite);}
@media (prefers-reduced-motion: no-preference){
  html.js .media.reveal{opacity:0;clip-path:inset(16% 0 0 0);transform:none;
    transition:opacity 1.4s cubic-bezier(.2,.7,.3,1), clip-path 1.5s cubic-bezier(.2,.7,.3,1);}
  html.js .media.reveal.in{opacity:1;clip-path:inset(0 0 0 0);}
  html.js .split .s-im.reveal{opacity:0;clip-path:inset(0 0 18% 0);transform:none;
    transition:opacity 1.4s cubic-bezier(.2,.7,.3,1), clip-path 1.5s cubic-bezier(.2,.7,.3,1);}
  html.js .split .s-im.reveal.in{opacity:1;clip-path:inset(0 0 0 0);}
}

/* ════ rifinitura schede: spaziatura uniforme + testo a sinistra + animazione ════ */
:root{--vsp:clamp(20px,3.4vh,56px);}
.media,.vidblock,.chap-over{margin-top:var(--vsp);margin-bottom:var(--vsp);}
.split{padding-top:var(--vsp);padding-bottom:var(--vsp);}
.pcarousel{margin:var(--vsp) 0 0;}
.pcarousel .ghead{padding:0 var(--mx) 22px;}
.pcarousel .ghead .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);}
/* .split.rev = foto a sinistra, testo a destra (alternanza, vedi regola sopra) */
.darkband .inner{max-width:62ch;margin:0;padding-left:var(--mx);padding-right:var(--mx);}
.chap.center,.chap.right{text-align:left;}
.chap.center p,.chap.right p{margin-left:0;}
/* animazione: titoli con wipe da sinistra all'ingresso */
@media (prefers-reduced-motion: no-preference){
  /* titolo: solo fade/rise col blocco — niente clip che taglia il testo */
  html.js .reveal h2{opacity:0;transform:translateY(14px);transition:opacity .9s cubic-bezier(.2,.7,.3,1) .05s, transform .9s cubic-bezier(.2,.7,.3,1) .05s;}
  html.js .reveal.in h2{opacity:1;transform:none;}
}

/* carosello scheda progetto: tutte le slide 4:5, stessa misura */
.pcarousel .carousel{align-items:flex-start;}
.pcarousel .slide{flex:0 0 clamp(240px,30vw,400px) !important;}
.pcarousel .slide .sph{aspect-ratio:4/5 !important;}

/* rete di sicurezza responsive: niente testo tagliato o scroll orizzontale */
h1,h2,h3,p{overflow-wrap:break-word;}
body.sub{overflow-x:hidden;}
.phero h1,.chap-over h2,.split .s-txt h2,.chap h2,.darkband h2{overflow-wrap:normal;}

/* leggibilità testo bianco su immagini chiare (hero + testo-su-immagine) */
.phero::after{background:
  linear-gradient(to top, rgba(14,12,10,.88) 0%, rgba(14,12,10,.34) 40%, rgba(14,12,10,0) 70%),
  linear-gradient(to right, rgba(14,12,10,.72) 0%, rgba(14,12,10,.26) 40%, rgba(14,12,10,0) 62%);}
.chap-over::after{background:
  linear-gradient(to top, rgba(14,12,10,.88) 0%, rgba(14,12,10,.34) 46%, rgba(14,12,10,0) 76%),
  linear-gradient(to right, rgba(14,12,10,.78) 0%, rgba(14,12,10,.30) 40%, rgba(14,12,10,0) 60%);}
.phero h1,.phero .ph-k,.phero .ph-meta{text-shadow:0 1px 30px rgba(14,12,10,.45);}
.chap-over h2,.chap-over p,.chap-over .k{text-shadow:0 1px 28px rgba(14,12,10,.5);}

/* intro uniforme alla banda scura: occhiello + titolo + testo leggibile */
.statement{max-width:var(--wrap-text);margin:0 auto;padding:var(--sec-y-lg) var(--mx) clamp(18px,4vh,56px);}
/* statement di chiusura (solo testo, senza titolo): ritmo uniforme come gli altri blocchi */
.statement:not(:has(h2)){padding-top:var(--vsp);padding-bottom:var(--vsp);}
.statement .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ottone);margin-bottom:18px;}
.statement h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,4.4vw,58px);line-height:1.06;letter-spacing:-0.025em;color:var(--ink);margin-bottom:22px;max-width:none;}
.statement p,.statement .lead{font-family:var(--font-sans);font-weight:400;font-size:clamp(16px,1.6vw,21px);line-height:1.62;color:var(--ink-2);max-width:58ch;}

/* ── pagina Progetti: caroselli con slide tutte 4:5 uguali + distanze regolate ── */
.catrow{padding:var(--sec-y) 0;}
.catrow-head{margin-bottom:clamp(30px,4vh,50px);}
.catrow .carousel{align-items:flex-start;padding-bottom:4px;}
.catrow .slide{flex:0 0 clamp(240px,30vw,400px) !important;}
.catrow .slide .sph{aspect-ratio:4/5 !important;}
.catrow .slide .scn{margin-top:14px;}
.carbtns{padding-top:22px;}

/* distanze più contenute su pagina Progetti e categorie */
.page-head{padding-top:calc(54px + 5vh);padding-bottom:clamp(22px,3.5vh,44px);}
.page-head h1{margin-bottom:20px;}
.catrow{padding:clamp(30px,4.5vh,58px) 0 !important;}
.catrow-head{margin-bottom:clamp(20px,2.6vh,34px) !important;}
.carbtns{padding-top:18px;}

/* blocco SEO/CTA in coda alle schede progetto */
.seo-block{border-top:none;}
.seo-block .si{max-width:1280px;margin:0 auto;padding:clamp(24px,3.8vh,52px) var(--mx) clamp(24px,3.8vh,52px);}
.seo-block p{font-size:14.5px;line-height:1.72;color:var(--ink-3);max-width:72ch;}
.seo-block p + p{margin-top:1.1em;}
/* variante "capitolo": occhiello + titolo display con accento + testo (come .mfase) */
.seo-block.seo-lead .si{max-width:var(--wrap);}
.seo-block.seo-lead .sl-eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-4);margin-bottom:clamp(20px,3vh,34px);}
.seo-block.seo-lead h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,3.3vw,46px);line-height:1.1;letter-spacing:-0.025em;color:var(--ink);margin-bottom:clamp(22px,3.4vh,34px);max-width:20ch;}
.seo-block.seo-lead h2 .ac{display:block;color:var(--terra);}
.seo-block.seo-lead p:not(.cta){font-size:clamp(15px,1.2vw,17px);line-height:1.72;color:var(--ink-2);max-width:48ch;}
.seo-block.seo-lead p:not(.cta) + p:not(.cta){margin-top:1em;}
.seo-block p.cta{margin-top:clamp(22px,3vh,34px);color:var(--ink-2);display:flex;flex-direction:column;align-items:flex-start;gap:clamp(14px,2vh,20px);}
.seo-block p.cta a{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;border:1px solid var(--ink);padding:15px 26px;margin-left:0;white-space:nowrap;transition:all .35s cubic-bezier(.2,.7,.3,1);}
.seo-block p.cta a:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* pagine categoria: anteprime tutte 4:5 uniformi (come i caroselli) */
.egrid{grid-template-columns:repeat(3,1fr) !important;gap:clamp(14px,1.7vw,28px) !important;}
.egrid .card{grid-column:auto !important;grid-row:auto !important;}
.egrid .card .ph{aspect-ratio:4/5 !important;}
@media(max-width:820px){.egrid{grid-template-columns:repeat(2,1fr) !important;}}
@media(max-width:520px){.egrid{grid-template-columns:1fr !important;}}

/* ── pagina Video (Beyond Space): video a sinistra, descrizione a destra ── */
.vpage{padding-bottom:var(--sec-y-lg);}
.vrow{display:grid;grid-template-columns:1.45fr 1fr;gap:clamp(30px,4.5vw,80px);align-items:center;
  max-width:1320px;margin:0 auto;padding:clamp(34px,5vh,66px) var(--mx);border-top:1px solid var(--line);}
.vrow:first-of-type{border-top:none;}
.vrow .vbody .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ottone);margin-bottom:14px;}
.vrow .vbody h2{font-family:var(--font-disp);font-weight:400;font-size:clamp(22px,2.6vw,34px);letter-spacing:-0.015em;line-height:1.08;margin-bottom:8px;}
.vrow .vbody .ep{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:18px;}
.vrow .vbody p{font-size:15px;line-height:1.68;color:var(--ink-3);max-width:48ch;}
.vrow .vbody .vlinks{margin-top:22px;display:flex;gap:22px;flex-wrap:wrap;}
.vrow .vbody .vlinks a{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:3px;transition:border-color .3s;}
.vrow .vbody .vlinks a:hover{border-color:var(--ink);}
@media(max-width:820px){.vrow{grid-template-columns:1fr;gap:22px;}}

/* ── pagina Video (Beyond Space) — stile Norm: media grande + caption due colonne ── */
.vlist{max-width:var(--wrap);margin:0 auto;padding:0 var(--mx);
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:var(--gap-lg);row-gap:clamp(40px,6vh,72px);}
.vitem{margin:0;}
.vitem .vidblock{width:100%;}
.vcap{display:flex;flex-direction:column;gap:6px;margin-top:16px;align-items:stretch;}
.vcap .vc-l .ep{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ottone);margin-bottom:8px;}
.vcap .vc-l h2{font-family:var(--font-disp);font-weight:400;font-size:clamp(19px,1.7vw,24px);letter-spacing:-0.015em;line-height:1.1;}
.vcap .vc-r{margin-top:6px;}
.vcap .vc-r p{font-size:14px;line-height:1.62;color:var(--ink-3);max-width:none;}
.vcap .vc-r .vlinks{margin-top:14px;display:flex;gap:18px;flex-wrap:wrap;}
.vcap .vc-r .vlinks a{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:3px;transition:border-color .3s;}
.vcap .vc-r .vlinks a:hover{border-color:var(--ink);}
@media(max-width:900px){.vlist{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:600px){.vlist{grid-template-columns:1fr;}}

/* ── Work in Progress tag ── */
.cx .wipt{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);}
.card.wipcard{cursor:default;}
.egrid .card.wipcard{grid-column:span 4;}
@media(max-width:760px){.egrid .card.wipcard{grid-column:span 6;}}
@media(max-width:480px){.egrid .card.wipcard{grid-column:span 12;}}

/* ── Transizione tra pagine: scorrimento verso destra (View Transitions API) ── */
@view-transition { navigation: none; }
@keyframes vt-out-left { to { transform: translateX(-100%); } }
@keyframes vt-in-right { from { transform: translateX(100%); } }
::view-transition-old(root){ animation: vt-out-left .55s cubic-bezier(.76,0,.24,1) both; }
::view-transition-new(root){ animation: vt-in-right .55s cubic-bezier(.76,0,.24,1) both; }
@media (prefers-reduced-motion: reduce){
  ::view-transition-old(root),::view-transition-new(root){ animation: none; }
}

/* indietro: scorrimento inverso (entra da sinistra) */
@keyframes vt-out-right { to { transform: translateX(100%); } }
@keyframes vt-in-left { from { transform: translateX(-100%); } }
html[data-vt="back"]::view-transition-old(root){ animation: vt-out-right .55s cubic-bezier(.76,0,.24,1) both; }
html[data-vt="back"]::view-transition-new(root){ animation: vt-in-left .55s cubic-bezier(.76,0,.24,1) both; }

/* ── Transizione pagine via JS (uscita + entrata laterale) ── */
html{overflow-x:hidden;}
@media (prefers-reduced-motion: no-preference){
  .pageslide.pt-out-fwd{animation:ptOutFwd .34s cubic-bezier(.4,0,.2,1) forwards;}
  .pageslide.pt-out-back{animation:ptOutBack .34s cubic-bezier(.4,0,.2,1) forwards;}
  html.ptin-fwd .pageslide{animation:ptInFwd .58s cubic-bezier(.2,.7,.3,1);}
  html.ptin-back .pageslide{animation:ptInBack .58s cubic-bezier(.2,.7,.3,1);}
  @keyframes ptOutFwd{to{transform:translateX(-100%);}}
  @keyframes ptOutBack{to{transform:translateX(100%);}}
  @keyframes ptInFwd{from{transform:translateX(100%);}to{transform:translateX(0);}}
  @keyframes ptInBack{from{transform:translateX(-100%);}to{transform:translateX(0);}}
}

/* breadcrumb: freccia ← al posto del trattino (solo eyebrow con link) */
.sec-eyebrow:has(a)::before{content:"\2190";width:auto;height:auto;background:none;color:var(--ink-3);
  font-family:var(--font-disp);font-size:15px;line-height:1;transform:translateY(-1px);}


/* ── Journal (blog) ── */
.jrnl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg);padding:0 var(--mx) var(--sec-y);}
.jrnl{display:flex;flex-direction:column;}
.jrnl .jcover{display:block;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2);margin:0 0 20px;}
.jrnl .jcover img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:filter .7s ease,transform 1.5s cubic-bezier(.2,.7,.3,1);}
.jrnl:hover .jcover img{filter:grayscale(0);transform:scale(1.04);}
.jrnl .jdate{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-4);margin-top:16px;}
.jrnl .jk{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ottone);margin-bottom:18px;}
.jrnl h2{font-family:var(--font-disp);font-weight:400;font-size:clamp(20px,1.9vw,26px);line-height:1.12;letter-spacing:-0.015em;margin-bottom:auto;}
.jrnl h2 a{text-decoration:none;color:var(--ink);transition:color .3s;}
.jrnl h2 a:hover{color:var(--terra);}
.jrnl .ex{font-size:14px;line-height:1.6;color:var(--ink-3);margin:18px 0 18px;}
.jrnl .more{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:3px;align-self:flex-start;transition:border-color .3s;}
.jrnl .more:hover{border-color:var(--ink);}
@media(max-width:860px){.jrnl-grid{grid-template-columns:1fr;gap:clamp(34px,6vw,48px);}}

/* ── articolo (post) ── */
.article{max-width:var(--wrap-narrow);margin:0;padding:0 var(--mx) var(--sec-y);}
.article-hero{position:relative;width:100%;overflow:hidden;background:#1a1714;
  min-height:clamp(440px,74vh,760px);display:flex;align-items:flex-end;
  margin:0 0 clamp(40px,6vh,72px);}
.article-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;display:block;}
.article-hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top, rgba(0,0,0,0.88) 0%, rgba(0,0,0,0.66) 18%, rgba(0,0,0,0.32) 42%, rgba(0,0,0,0.05) 70%, rgba(0,0,0,0) 100%);}
.article-hero .ah-content{position:relative;z-index:2;width:100%;padding:0 var(--mx) clamp(40px,6vh,72px);}
.article-hero .sec-eyebrow{color:rgba(246,245,242,0.75);margin-bottom:18px;}
.article-hero .sec-eyebrow::before{background:rgba(246,245,242,0.45);}
.article-hero .sec-eyebrow a{color:inherit;}
.article-hero h1{font-family:var(--font-disp);font-weight:300;font-size:clamp(32px,5vw,68px);line-height:1.04;letter-spacing:-0.02em;color:var(--cream);max-width:20ch;margin:0;}
.article-hero .ameta{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(246,245,242,0.7);margin-top:20px;display:flex;gap:18px;flex-wrap:wrap;}
@keyframes ahrise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
html.js .article-hero .ah-content{opacity:0;animation:ahrise .9s .15s forwards cubic-bezier(.2,.7,.3,1);}
.article .ameta{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-4);margin-top:18px;display:flex;gap:18px;flex-wrap:wrap;}
.article .body{margin-top:clamp(30px,4.5vh,52px);}
.article .body p{font-size:17px;line-height:1.78;color:var(--ink-2);margin-bottom:1.15em;max-width:70ch;}
.article .body > p:first-of-type{font-family:var(--font-disp);font-weight:400;
  font-size:clamp(20px,2vw,26px);line-height:1.5;color:var(--ink);margin-bottom:1.4em;letter-spacing:-0.01em;}
/* comparsa morbida allo scroll (articoli) */
html.js .article .body > p.reveal,html.js .article .body h3.reveal,html.js .article-hero.reveal{will-change:opacity,transform;}
.article .body h3{font-family:var(--font-disp);font-weight:500;font-size:clamp(18px,2vw,24px);letter-spacing:-0.01em;color:var(--ink);margin:1.7em 0 .5em;}
.article .body .sign{font-family:var(--font-mono);font-size:12px;letter-spacing:0.08em;color:var(--ink-3);margin-top:2.4em;line-height:1.7;text-transform:none;padding-top:1.6em;border-top:1px solid var(--line);}
/* ── layout editoriale articoli ── */
.article .body > p:first-of-type::first-letter{font-family:var(--font-disp);font-size:2.7em;line-height:0.82;float:left;font-weight:500;margin:.06em .14em 0 0;color:var(--ink);}
.article .body h3{margin:2.3em 0 .55em;position:relative;padding-top:24px;font-size:clamp(21px,2.5vw,29px);font-weight:400;}
.article .body h3::before{content:"";position:absolute;top:0;left:0;width:34px;height:2px;background:var(--terra);}
.article .body .pq{font-family:var(--font-disp);font-weight:300;font-size:clamp(23px,3vw,36px);line-height:1.22;letter-spacing:-0.02em;color:var(--ink);margin:1.7em 0;padding-left:28px;border-left:2px solid var(--terra);max-width:24ch;}
@media(max-width:640px){.article .body .pq{font-size:22px;padding-left:20px;}}

/* ── pagina Metodo (fasi editoriali, stile spread) ── */
.metodo-fasi{margin-top:var(--sec-y);padding-bottom:clamp(10px,2vh,28px);}
.mfase{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(32px,5vw,64px);
  align-items:start;max-width:var(--wrap);margin:0 auto;
  padding:clamp(14px,2.2vh,30px) var(--mx);}
.mfase.flip .mf-txt{order:2;}
.mfase.flip{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
.mf-txt{max-width:34rem;}
.mf-txt{max-width:31rem;}
.mf-num{font-family:var(--font-mono);font-size:12px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--ink-4);margin-bottom:clamp(20px,3vh,34px);}
.mf-txt h2{font-family:var(--font-disp);font-weight:300;
  font-size:clamp(28px,3.3vw,46px);line-height:1.1;letter-spacing:-0.025em;
  color:var(--ink);margin-bottom:clamp(20px,3vh,32px);overflow-wrap:break-word;}
.mf-txt h2 .ac{display:block;color:var(--terra);}
.mf-txt p{font-size:clamp(15px,1.2vw,17px);line-height:1.72;color:var(--ink-2);max-width:40ch;}
.mf-img{aspect-ratio:4/5;overflow:hidden;background:var(--cream-2);}
.mf-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;
  filter:grayscale(1);transition:filter .8s ease,transform 1.6s cubic-bezier(.2,.7,.3,1);}
.mfase:hover .mf-img img{filter:grayscale(0);transform:scale(1.03);}
@media(max-width:1024px){.mfase,.mfase.flip{grid-template-columns:1fr;gap:clamp(20px,3vh,30px);
  padding:clamp(30px,5vh,52px) var(--mx);}
  .mfase.flip .mf-txt{order:0;}.mfase .mf-txt{order:0;}.mfase .mf-img{order:1;}
  .mf-txt{max-width:none;}.mf-txt p{max-width:62ch;}
  .mf-img{aspect-ratio:3/2;}}
.mf-link{margin-top:clamp(20px,3vh,30px);}
.mf-txt p+p{margin-top:1.1em;}
.article-hero:has(+ .inv-intro){margin-bottom:0;}   /* spazio sopra l'intro = padding intro (sopra/sotto uguali) */
.inv-intro{max-width:var(--wrap);margin:0 auto;padding:var(--sec-y) var(--mx);text-align:left;}
.inv-intro-eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--ink-4);margin-bottom:clamp(16px,2.4vh,26px);}
.inv-intro-lead{font-family:var(--font-disp);font-weight:300;
  font-size:clamp(20px,2.1vw,30px);line-height:1.42;letter-spacing:-0.01em;
  color:var(--ink);max-width:46rem;}
.article-hero .ah-lede{font-family:var(--font-disp);font-weight:300;color:rgba(246,245,242,0.88);
  font-size:clamp(16px,1.6vw,21px);line-height:1.5;max-width:40ch;margin-top:22px;}

/* ── Investire · perché DIDEA (scuro) ── */
.whydidea{background:var(--antracite);color:rgba(246,245,242,0.65);padding:var(--sec-y) var(--mx);}
.whydidea .wd-head{max-width:var(--wrap-text);margin-bottom:clamp(40px,6vh,72px);}
.whydidea .sec-eyebrow{color:rgba(246,245,242,0.45);}
.whydidea .sec-eyebrow::before{background:rgba(246,245,242,0.3);}
.whydidea h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,4vw,56px);
  line-height:1.07;letter-spacing:-0.028em;color:var(--cream);margin:8px 0 clamp(22px,3vh,32px);max-width:20ch;}
.whydidea h2 .ac{color:var(--terra);}
.whydidea .wd-lead{font-family:var(--font-disp);font-weight:300;font-size:clamp(17px,1.6vw,22px);
  line-height:1.5;color:rgba(246,245,242,0.78);max-width:58ch;}
.wd-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--gap-lg);}
.wd-pillar .wd-n{font-family:var(--font-mono);font-size:12px;letter-spacing:0.16em;
  color:var(--terra);margin-bottom:clamp(14px,2vh,20px);}
.wd-pillar h3{font-family:var(--font-disp);font-weight:400;font-size:clamp(17px,1.4vw,21px);
  letter-spacing:-0.01em;line-height:1.15;color:var(--cream);margin-bottom:12px;}
.wd-pillar p{font-size:14.5px;line-height:1.62;color:rgba(246,245,242,0.6);}
@media(max-width:900px){.wd-grid{grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,40px);}}
@media(max-width:560px){.wd-grid{grid-template-columns:1fr;}}
/* variante chiara della sezione garanzie (su fondo crema, non scuro) */
.whydidea.whydidea-light{background:#ffffff;color:var(--ink-3);padding:var(--sec-y) var(--mx);}
.whydidea.whydidea-light .sec-eyebrow{color:var(--ink-4);}
.whydidea.whydidea-light .sec-eyebrow::before{background:var(--line-2);}
.whydidea.whydidea-light h2{color:var(--ink);}
.whydidea.whydidea-light .wd-lead{color:var(--ink-3);}
.whydidea.whydidea-light .wd-pillar h3{color:var(--ink);}
.whydidea.whydidea-light .wd-pillar p{color:var(--ink-3);}

/* ── Investire · sezione dati ── */
.inv-data{max-width:var(--wrap);margin:0 auto;padding:var(--sec-y) var(--mx);}
.inv-data>.sec-eyebrow{margin-bottom:18px;}
.inv-data h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(28px,3.6vw,52px);
  line-height:1.05;letter-spacing:-0.025em;color:var(--ink);max-width:18ch;margin-bottom:clamp(34px,5vh,60px);}
.inv-data h2 .ac{color:var(--terra);}
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);
  column-gap:clamp(24px,4vw,64px);row-gap:clamp(34px,5.5vh,60px);
  background:transparent;border:0;margin-bottom:clamp(40px,6vh,72px);}
.stat{background:transparent;padding:0;}
.stat .statnum{font-family:var(--font-disp);font-weight:300;font-size:clamp(34px,5vw,66px);
  line-height:1;letter-spacing:-0.03em;color:var(--ink);display:block;}
.stat .statnum .u{color:var(--terra);}
.stat .statlab{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--ink-3);margin-top:16px;line-height:1.5;display:block;}
.airrow{margin-bottom:clamp(40px,6vh,72px);}
.airrow .chart-card{max-width:880px;}
.airrow .airfocus{margin-top:clamp(20px,2.6vh,28px);font-size:clamp(15px,1.25vw,17px);line-height:1.66;
  color:var(--ink-2);max-width:64ch;}
.airrow .airfocus strong{color:var(--terra);font-weight:500;}
.charts{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(36px,5vw,72px);align-items:start;}
.chart-card{display:flex;flex-direction:column;}
.chart-card .ct{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:6px;}
.chart-card .cs{font-family:var(--font-disp);font-weight:300;font-size:clamp(19px,1.9vw,26px);
  letter-spacing:-0.015em;color:var(--ink);line-height:1.12;margin-bottom:clamp(22px,3vh,34px);max-width:24ch;min-height:3.45em;}
.chart-card .cnote{font-size:13px;line-height:1.6;color:var(--ink-4);margin-top:clamp(20px,2.8vh,30px);max-width:46ch;}
/* area-grafico: stesso riquadro per barre e proiezione */
.cviz{position:relative;height:clamp(176px,20vw,216px);display:flex;flex-direction:column;}
/* barre comparative */
.cviz .bars{flex:1;justify-content:space-between;gap:0;}
.bars{display:flex;flex-direction:column;gap:clamp(13px,1.8vh,20px);}
.bar{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:14px;row-gap:7px;}
.bar .bl{grid-column:1 / -1;font-family:var(--font-mono);font-size:11.5px;letter-spacing:0.04em;
  color:var(--ink-2);text-align:left;}
.bar .bt{height:13px;background:var(--cream-2);position:relative;overflow:hidden;border-radius:1px;}
.bar .bf{position:absolute;inset:0 auto 0 0;width:0;background:var(--ottone);
  transition:width 1.3s cubic-bezier(.2,.7,.3,1);}
.inv-data.in .bar .bf{width:var(--w);}
.bar.hl .bf{background:var(--terra);}
.bar .bv{font-family:var(--font-mono);font-size:12px;color:var(--ink-3);white-space:nowrap;min-width:62px;text-align:right;}
.bar.hl .bv{color:var(--terra);font-weight:500;}
/* proiezione */
.proj{flex:1;width:100%;height:100%;display:block;}
.proj .grid{stroke:var(--line);stroke-width:1;vector-effect:non-scaling-stroke;}
.proj .band{fill:var(--terra);opacity:0.10;}
.proj .lineMid{fill:none;stroke:var(--terra);stroke-width:2;vector-effect:non-scaling-stroke;
  stroke-dasharray:1400;stroke-dashoffset:1400;}
.inv-data.in .proj .lineMid{animation:projdraw 1.6s .2s forwards ease;}
.proj-axis{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;
  color:var(--ink-4);letter-spacing:0.04em;padding-top:9px;}
.proj-base{position:absolute;left:0;bottom:30px;font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  background:var(--cream);padding-right:5px;}
.proj-end{position:absolute;top:-4px;right:0;font-family:var(--font-disp);font-size:16px;color:var(--terra);font-weight:500;}
@keyframes projdraw{to{stroke-dashoffset:0;}}
/* ROI */
.roi{margin-top:clamp(40px,6vh,72px);display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:transparent;border:0;padding:0;}
.roi-head{grid-column:1/-1;padding:0 0 clamp(24px,3.4vh,34px);}
.roi-head .ct{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px;}
.roi-head .cs{font-family:var(--font-disp);font-weight:300;font-size:clamp(20px,2.2vw,30px);letter-spacing:-0.015em;color:var(--ink);max-width:34ch;line-height:1.2;}
.roi-cell{padding:clamp(24px,3vh,32px) clamp(26px,3vw,40px) 0 0;}
.roi-cell+.roi-cell{padding-left:clamp(26px,3vw,40px);}
.roi-cell .rn{font-family:var(--font-disp);font-weight:300;font-size:clamp(26px,3.4vw,40px);line-height:1;letter-spacing:-0.03em;color:var(--ink);}
.roi-cell.acc .rn{color:var(--terra);}
.roi-cell .rl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);margin-top:14px;line-height:1.5;}
.roi-disc{grid-column:1/-1;padding:clamp(22px,3vh,30px) 0 0;font-size:12px;line-height:1.6;color:var(--ink-4);}
@media(max-width:820px){
  .statgrid{grid-template-columns:repeat(2,1fr);}
  .charts{grid-template-columns:1fr;gap:clamp(40px,6vh,60px);}
  .roi{grid-template-columns:1fr;}
  .roi-cell+.roi-cell{border-left:0;padding-left:0;}
}

/* ── FAQ (accordion nativo) ── */
.faq{max-width:var(--wrap);margin:0 auto;padding:var(--sec-y) var(--mx);}
.faq>*{max-width:900px;}
.faq .faq-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-4);margin-bottom:18px;}
.faq h2{font-family:var(--font-disp);font-weight:300;font-size:clamp(26px,3vw,40px);line-height:1.1;letter-spacing:-0.025em;color:var(--ink);margin-bottom:clamp(24px,4vh,44px);}
.faq details{border-radius:4px;transition:background .35s ease;}
.faq details[open]{background:#e7e1d5;
  margin-left:calc(-1*clamp(18px,2vw,30px));margin-right:calc(-1*clamp(18px,2vw,30px));
  padding-left:clamp(18px,2vw,30px);padding-right:clamp(18px,2vw,30px);}
.faq summary{cursor:pointer;list-style:none;padding:20px 38px 20px 0;position:relative;
  font-family:var(--font-disp);font-weight:400;font-size:clamp(16px,1.6vw,20px);
  letter-spacing:-0.01em;color:var(--ink);transition:color .3s;outline:none;}
.faq summary:focus,.faq summary:focus-visible{outline:none;}
.faq details:focus-within{background:#e7e1d5;
  margin-left:calc(-1*clamp(18px,2vw,30px));margin-right:calc(-1*clamp(18px,2vw,30px));
  padding-left:clamp(18px,2vw,30px);padding-right:clamp(18px,2vw,30px);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);
  font-family:var(--font-disp);font-weight:300;font-size:24px;color:var(--ottone);transition:transform .3s;}
.faq details[open] summary::after{content:"\2013";}
.faq summary:hover{color:var(--terra);}
.faq .fa{padding:0 38px 24px 0;max-width:74ch;font-size:15.5px;line-height:1.72;color:var(--ink-2);}
.faq-cta{margin-top:clamp(34px,5vh,56px);font-size:clamp(15px,1.4vw,17px);line-height:1.6;color:var(--ink-2);}
.faq-cta a:not(.cta-box){color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:3px;transition:border-color .3s;}
.faq-cta a:not(.cta-box):hover{border-color:var(--ink);}
.faq-cta-lead{margin-bottom:clamp(20px,3vh,28px);}
/* CTA su fondo chiaro (es. dopo i capitoli del metodo) */
.cta-light{max-width:var(--wrap);margin:0 auto;padding:var(--sec-y) var(--mx) var(--sec-y-lg);}
.cta-light .cl-lead{font-family:var(--font-disp);font-weight:300;font-size:clamp(20px,2.2vw,30px);line-height:1.3;letter-spacing:-0.01em;color:var(--ink);margin-bottom:clamp(22px,3vh,30px);max-width:30ch;}
.cta-box{display:inline-flex;align-items:center;gap:14px;font-family:var(--font-mono);
  font-size:12px;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;
  border:1px solid var(--ink);color:var(--ink);padding:18px 30px;
  transition:background .35s cubic-bezier(.2,.7,.3,1),color .35s cubic-bezier(.2,.7,.3,1),border-color .35s;}
.cta-box .arrow{transition:transform .35s cubic-bezier(.2,.7,.3,1);}
.cta-box:hover{background:var(--ink);color:var(--cream);}
.cta-box:hover .arrow{transform:translateX(4px);}
.faq-dark .cta-box{color:var(--cream);border-color:rgba(246,245,242,0.5);}
.faq-dark .cta-box:hover{background:var(--cream);color:var(--antracite);border-color:var(--cream);}
/* FAQ scura (come il footer) — solo dove serve */
.faq.faq-dark{max-width:none;margin:0;background:var(--antracite);color:rgba(246,245,242,0.65);
  padding:var(--sec-y) var(--mx) var(--foot-gap);position:relative;}
.faq.faq-dark::after{content:"";position:absolute;left:var(--mx);right:var(--mx);bottom:0;
  height:1px;background:rgba(246,245,242,0.12);}
/* divisore tra una sezione scura (es. garanzie) e la FAQ scura adiacente */
.whydidea+.faq.faq-dark::before{content:"";position:absolute;left:var(--mx);right:var(--mx);top:0;
  height:1px;background:rgba(246,245,242,0.12);}
.faq-dark .faq-eyebrow{color:rgba(246,245,242,0.45);}
.faq-dark h2{color:var(--cream);}
.faq-dark summary{color:rgba(246,245,242,0.92);}
.faq-dark summary::after{color:rgba(246,245,242,0.5);}
.faq-dark .fa{color:rgba(246,245,242,0.72);}
.faq-dark details[open],.faq-dark details:focus-within{background:rgba(246,245,242,0.07);}
.faq-dark .faq-cta{color:rgba(246,245,242,0.72);}
.faq-dark .faq-cta a:not(.cta-box){color:var(--cream);border-bottom-color:rgba(246,245,242,0.32);}
.faq-dark .faq-cta a:not(.cta-box):hover{border-color:var(--cream);}

/* ── lightbox anteprime foto (schede progetto) ── */
.carousel .slide img,.media img,.pgallery img{cursor:zoom-in;}
.lbox{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;
  background:rgba(10,9,8,0.95);padding:24px;}
.lbox.open{display:flex;animation:lbfade .3s ease;}
@keyframes lbfade{from{opacity:0}to{opacity:1}}
.lbox img{max-width:92vw;max-height:88vh;object-fit:contain;display:block;box-shadow:0 24px 70px rgba(0,0,0,0.45);}
.lbox .lb-close{position:absolute;top:18px;right:24px;background:none;border:0;
  color:rgba(246,245,242,0.82);font-size:30px;line-height:1;cursor:pointer;transition:color .3s;}
.lbox .lb-close:hover{color:#fff;}
.lbox .lb-prev,.lbox .lb-next{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;
  color:rgba(246,245,242,0.7);font-family:var(--font-disp);font-size:46px;font-weight:300;line-height:1;
  cursor:pointer;padding:18px 22px;transition:color .3s;}
.lbox .lb-prev{left:6px;} .lbox .lb-next{right:6px;}
.lbox .lb-prev:hover,.lbox .lb-next:hover{color:#fff;}
.lbox .lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;color:rgba(246,245,242,0.7);}
@media(max-width:640px){.lbox .lb-prev,.lbox .lb-next{font-size:32px;padding:10px 12px;}}

/* ── premi & pubblicazioni · etichette di sezione ── */
.prammeta{padding-top:clamp(12px,2.5vh,28px);}
.prammeta .sec-eyebrow{margin-bottom:clamp(18px,2.6vh,30px);}

/* ── scheda premio / pubblicazione ── */
.premio{max-width:var(--wrap-narrow);margin:0;padding:0 var(--mx) var(--sec-y);}
.premio .premio-img{width:100%;aspect-ratio:4/3;background:var(--cream);border:0;
  overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:clamp(28px,4vh,48px);}
.premio .premio-img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;padding:clamp(18px,3vw,40px);}
.premio .premio-body p{font-size:clamp(16px,1.5vw,19px);line-height:1.7;color:var(--ink-2);max-width:64ch;margin-bottom:1.2em;}
.premio .ext-link{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-mono);
  font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);text-decoration:none;
  border:1px solid var(--ink);padding:15px 26px;transition:all .35s cubic-bezier(.2,.7,.3,1);}
.premio .ext-link:hover{background:var(--ink);color:var(--cream);}
.premio .backlink{margin-top:clamp(34px,5vh,56px);}

/* premi · ritagli/loghi su bianco → fondono nel crema (multiply) */
.premi-page .jrnl .jcover{background:var(--cream);}
.premi-page .jrnl .jcover img{mix-blend-mode:multiply;}
.premio .premio-img img{mix-blend-mode:multiply;}

/* video ridotto (non a tutta pagina) */
.vid-narrow{max-width:920px;margin:clamp(40px,7vh,96px) auto;padding:0 var(--mx);}
/* video dentro una sezione testo+video (.split) */
.split.vid-split .s-im{background:none;overflow:visible;}
.split.vid-split .s-im .vidblock{width:100%;}
.split.vid-split .s-im img{aspect-ratio:auto;height:100%;}
/* pianta di progetto · fondo bianco eliminato col multiply (come i premi) */
.pianta{max-width:var(--wrap-text);margin:0 auto;padding:clamp(44px,7vh,96px) var(--mx);}
.pianta .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-4);margin-bottom:clamp(22px,3.5vh,40px);}
.pianta-img img{display:block;width:100%;max-width:760px;margin:0 auto;mix-blend-mode:multiply;}
/* pianta dentro la banda scura "Concettuale" · a destra del testo (linee chiare via screen) */
.darkband .inner.db-grid{max-width:var(--wrap);}
.darkband .db-grid{display:grid;grid-template-columns:1fr minmax(340px,460px);gap:clamp(32px,5vw,80px);align-items:center;}
.darkband .db-plan{justify-self:end;text-align:right;width:100%;}
.darkband .db-plan-k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(246,245,242,0.45);margin-bottom:16px;}
.darkband .db-plan img{display:block;width:100%;margin-left:auto;}
@media(max-width:860px){.darkband .db-grid{grid-template-columns:1fr;}.darkband .db-plan{justify-self:start;text-align:left;margin-top:clamp(22px,4vh,34px);max-width:420px;}.darkband .db-plan img{margin-left:0;}}

/* ── Citazioni / Dicono di noi · modulo a rotazione (Swiss, riusabile) ── */
.quotes{background:var(--antracite);color:var(--cream);padding:var(--sec-y-lg) var(--mx);}
.quotes-inner{max-width:var(--wrap-text);margin:0 auto;text-align:center;}
.q-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(246,245,242,0.45);margin-bottom:clamp(28px,4vh,46px);}
.q-track{position:relative;list-style:none;min-height:clamp(220px,30vh,330px);display:flex;align-items:center;justify-content:center;}
.q-item{position:absolute;inset:0;margin:auto;opacity:0;transition:opacity .9s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;}
.q-item.is-active{opacity:1;pointer-events:auto;}
.q-item blockquote{font-family:var(--font-disp);font-weight:300;font-size:clamp(21px,2.8vw,38px);line-height:1.32;letter-spacing:-0.015em;color:var(--cream);max-width:30ch;margin:0 auto;}
.q-by{margin-top:clamp(22px,3.2vh,34px);}
.q-by::before{content:"";display:block;width:30px;height:1px;background:var(--terra);margin:0 auto clamp(16px,2.2vh,22px);}
.q-author{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(246,245,242,0.9);}
.q-src{display:block;font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(246,245,242,0.42);margin-top:7px;}
.q-dots{display:flex;gap:10px;justify-content:center;margin-top:clamp(30px,4vh,46px);}
.q-dot{width:7px;height:7px;border-radius:50%;border:0;background:rgba(246,245,242,0.26);cursor:pointer;padding:0;transition:background .3s,transform .3s;}
.q-dot.on{background:var(--terra);transform:scale(1.3);}
@media(max-width:560px){.q-item blockquote{max-width:24ch;}}
/* variante chiara (fondo crema del sito) */
.quotes.quotes-light{background:transparent;color:var(--ink-3);}
.quotes.quotes-light .q-eyebrow{color:var(--ink-4);}
.quotes.quotes-light .q-item blockquote{color:var(--ink);}
.quotes.quotes-light .q-author{color:var(--ink);}
.quotes.quotes-light .q-src{color:var(--ink-4);}
.quotes.quotes-light .q-dot{background:rgba(17,17,17,0.18);}
.quotes.quotes-light .q-dot.on{background:var(--terra);}
/* allineato a sinistra, sulla stessa colonna del testo */
.quotes.quotes-light{text-align:left;}
.quotes.quotes-light .quotes-inner{max-width:var(--wrap);text-align:left;}
.quotes.quotes-light .q-track{justify-content:flex-start;}
.quotes.quotes-light .q-item{align-items:flex-start;}
.quotes.quotes-light .q-item blockquote{margin-left:0;margin-right:0;max-width:34ch;}
.quotes.quotes-light .q-by::before{margin-left:0;margin-right:0;}
.quotes.quotes-light .q-dots{justify-content:flex-start;}
