/* ============================================================
   FONTI — direzione AUDACE
   Immersivo · materico · tipografia-paesaggio · le sorgenti come sistema grafico
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Instrument+Serif:ital@0;1&family=Space+Mono:wght@400;700&display=swap');

:root{
  --ink0:#14180f;          /* quasi-nero bosco, caldo */
  --ink1:#1b2014;
  --ink2:#252d1d;
  --cream:#f2ede1;
  --cream-2:#e6e0d0;
  --dim: rgba(242,237,225,.60);
  --dim-2: rgba(242,237,225,.54);  /* tier meta più tenue, ma sopra WCAG AA (≈5:1 su --ink0) */
  --terra:#c66a42;         /* terracotta caldo, meno neon */
  --terra-2:#d97c52;
  --sand:#cdbf9e;
  --line: rgba(242,237,225,.12);
  --line-2: rgba(242,237,225,.07);
  --r: 14px;               /* raggio morbido */

  --display:'Bricolage Grotesque', system-ui, sans-serif;
  --serif:'Instrument Serif', Georgia, serif;
  --mono:'Space Mono', ui-monospace, monospace;

  --gut: clamp(18px, 4.5vw, 64px);
}

*{ box-sizing:border-box; }
html{ -webkit-font-smoothing:antialiased; scroll-behavior:smooth; background:var(--ink0); }
body{
  margin:0;
  font-family:var(--display);
  background:var(--ink0);
  color:var(--cream);
  font-size:18px;
  line-height:1.55;
  overflow-x:clip;
}
@media (max-width:640px){ body{ font-size:16px; } }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--terra); color:var(--ink0); }

.wrap{ width:100%; padding-inline:var(--gut); }
.mono{ font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; }
.serif{ font-family:var(--serif); font-style:italic; font-weight:400; }

/* grain + vignette overlay on whole page */
.grain{ position:fixed; inset:0; pointer-events:none; z-index:60; opacity:.3;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  mix-blend-mode:soft-light; }

/* ---------- ripple / contour system (le sorgenti) ---------- */
.ripple{ position:absolute; border-radius:50%; border:1px solid var(--line); pointer-events:none; }
@keyframes breathe{
  0%{ transform:translate(-50%,-50%) scale(.82); opacity:.05; }
  50%{ opacity:.5; }
  100%{ transform:translate(-50%,-50%) scale(1.6); opacity:0; }
}
.ripplefield{ position:absolute; inset:0; overflow:hidden; pointer-events:none; transition:transform .9s cubic-bezier(.2,.7,.2,1); }
.ripplefield > i{
  position:absolute; left:var(--cx,50%); top:var(--cy,46%);
  width:42vmax; height:42vmax; border-radius:50%;
  border:1px solid var(--line);
  transform:translate(-50%,-50%) scale(1);
  animation:breathe 9s linear infinite;
}
@media (prefers-reduced-motion:reduce){ .ripplefield > i{ animation:none; opacity:.18; } }

/* ---------- nav ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:50; display:flex; align-items:center; justify-content:space-between;
  padding:clamp(16px,2.4vw,26px) var(--gut); transition:background .4s, padding .4s, border-color .4s; border-bottom:1px solid transparent; }
.nav.scrolled{ background:color-mix(in srgb, var(--ink0) 80%, transparent); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-2); padding-block:12px; }
.brand{ display:inline-flex; align-items:center; gap:.5em; font-weight:700; font-size:1.35rem; letter-spacing:-0.02em; }
.brand b{ width:18px; height:18px; border-radius:50%; border:2px solid var(--cream); display:inline-block; position:relative; }
.brand b::after{ content:""; position:absolute; inset:3px; border-radius:50%; border:1px solid var(--terra); }
.navlinks{ display:flex; gap:26px; }
@media (max-width:880px){ .navlinks{ display:none; } }
.navlink{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); transition:color .3s; }
.navlink:hover,.navlink.active{ color:var(--cream); }
.navlink.active{ color:var(--terra); }
.navcta{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; border:1px solid var(--line); padding:.85em 1.3em; border-radius:999px; transition:background .35s,color .35s,border-color .35s; }
.navcta:hover{ background:var(--cream); color:var(--ink0); border-color:var(--cream); }

/* azioni a destra: la telefonata è l'azione primaria, sempre visibile */
.nav__actions{ display:flex; align-items:center; gap:10px; }
.navcta--call{ display:inline-flex; align-items:center; gap:.55em; white-space:nowrap; }
.navcta__ico{ flex:none; }
.navcta__short{ display:none; }
/* su schermi stretti il numero cede il posto a un'etichetta breve; le cifre restano nel menu e nel footer */
@media (max-width:520px){
  .navcta--call .navcta__num{ display:none; }
  .navcta--call .navcta__short{ display:inline; }
  .navcta{ padding:.8em 1.1em; }
}

/* menu mobile (disclosure nativa: funziona anche senza JS) */
.navmenu{ display:none; position:relative; }
@media (max-width:880px){ .navmenu{ display:block; } .navcta--call{ min-height:44px; } }
.navtoggle{ list-style:none; cursor:pointer; width:44px; height:44px; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--line); border-radius:999px; transition:border-color .3s; }
.navtoggle::-webkit-details-marker{ display:none; }
.navtoggle:hover{ border-color:rgba(242,237,225,.3); }
.navtoggle__bars{ position:relative; display:block; width:18px; height:1.5px; background:var(--cream); transition:background .2s; }
.navtoggle__bars::before, .navtoggle__bars::after{ content:""; position:absolute; left:0; width:18px; height:1.5px; background:var(--cream); transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.navtoggle__bars::before{ top:-6px; }
.navtoggle__bars::after{ top:6px; }
.navmenu[open] .navtoggle__bars{ background:transparent; }
.navmenu[open] .navtoggle__bars::before{ transform:translateY(6px) rotate(45deg); }
.navmenu[open] .navtoggle__bars::after{ transform:translateY(-6px) rotate(-45deg); }
.navmenu__panel{ position:absolute; top:calc(100% + 14px); right:0; min-width:236px;
  background:color-mix(in srgb, var(--ink0) 95%, transparent); backdrop-filter:blur(14px);
  border:1px solid var(--line); border-radius:var(--r); padding:12px; display:flex; flex-direction:column; gap:2px; }
.navmenu__link{ font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); padding:12px 12px; border-radius:9px; transition:background .25s, color .25s; }
.navmenu__link:hover{ color:var(--cream); background:var(--line-2); }
.navmenu__link.active{ color:var(--terra); }
.navmenu__call{ margin-top:8px; display:inline-flex; align-items:center; justify-content:center; gap:.55em; min-height:44px; font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink0); background:var(--cream); padding:13px 14px; border-radius:999px; transition:transform .25s cubic-bezier(.2,.7,.2,1); }
.navmenu__call:hover{ transform:translateY(-1px); }

/* focus visibile e coerente (mai affidarsi al solo hover) */
:focus-visible{ outline:2px solid var(--sand); outline-offset:3px; }
.bigrow:focus-visible, .bcard:focus-visible{ outline-offset:-3px; border-radius:var(--r); }

@media (prefers-reduced-motion:reduce){
  .navtoggle__bars, .navtoggle__bars::before, .navtoggle__bars::after{ transition:none; }
}

/* ---------- HERO ---------- */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:flex-end; overflow:hidden; }
.hero__rail{ position:absolute; left:var(--gut); top:50%; transform:translateY(-50%) rotate(180deg); writing-mode:vertical-rl; font-family:var(--mono); font-size:.66rem; letter-spacing:.3em; text-transform:uppercase; color:var(--dim-2); }
@media (max-width:880px){ .hero__rail{ display:none; } }
.hero__top{ position:absolute; top:clamp(86px,12vh,140px); left:var(--gut); right:var(--gut); display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; z-index:4; }
.hero__eyebrow{ color:var(--sand); }
.hero__counter{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; color:var(--dim); text-shadow:0 1px 14px rgba(16,19,12,.75), 0 0 3px rgba(16,19,12,.55); }
.hero__counter b{ color:var(--terra); font-weight:700; }
/* altimetro: righello discreto sul lato della "M" (destra), tacche differenziate */
.quota-ruler{ position:absolute; width:15px; z-index:3; pointer-events:none;
  background-image:
    linear-gradient(to bottom, rgba(205,191,158,.30) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(205,191,158,.52) 1px, transparent 1px);
  background-size:6px 15px, 15px 75px;
  background-position:left top, left top;
  background-repeat:repeat-y, repeat-y;
  -webkit-mask-image:linear-gradient(to top, transparent 0, #000 14%, #000 86%, transparent 100%);
          mask-image:linear-gradient(to top, transparent 0, #000 14%, #000 86%, transparent 100%);
  opacity:.85; }
.quota-ruler::after{ content:""; position:absolute; left:0; bottom:0; width:15px; height:2px; background:var(--terra); }
@media (max-width:880px){ .quota-ruler{ display:none; } }

.hero__inner{ position:relative; z-index:3; padding:0 var(--gut) clamp(28px,6vh,72px); }
.hero__kicker{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,3vw,2.6rem); color:var(--cream); margin:0 0 -.12em; }
.hero__word{
  font-weight:700; letter-spacing:-0.035em; line-height:.84;
  font-size:clamp(5rem, 21.5vw, 22rem);
  margin:0; white-space:nowrap;
  background:linear-gradient(180deg,var(--cream),var(--cream-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__foot{ display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap; margin-top:clamp(20px,3vh,38px); padding-top:20px; border-top:1px solid var(--line); }
.hero__tag{ font-size:clamp(1.05rem,1.6vw,1.4rem); max-width:32ch; line-height:1.4; color:var(--cream); }
.hero__tag .serif{ color:var(--sand); }
.scrollcue{ font-family:var(--mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--dim); display:inline-flex; align-items:center; gap:.6em; }
.scrollcue i{ width:1px; height:34px; background:var(--terra); display:inline-block; animation:drip 2.4s ease-in-out infinite; transform-origin:top; }
@keyframes drip{ 0%,100%{ transform:scaleY(.3); opacity:.4; } 50%{ transform:scaleY(1); opacity:1; } }
@media (prefers-reduced-motion:reduce){ .scrollcue i{ animation:none; transform:scaleY(1); opacity:.7; } }

/* ---------- marquee ---------- */
.marquee{ border-block:1px solid var(--line); overflow:hidden; padding-block:clamp(16px,2.4vw,28px); background:var(--ink1); }
.marquee__track{ display:flex; gap:0; width:max-content; animation:slide 38s linear infinite; }
@media (prefers-reduced-motion:reduce){ .marquee__track{ animation:none; } }
@keyframes slide{ to{ transform:translateX(-50%); } }
.marquee__item{ font-family:var(--serif); font-style:italic; font-size:clamp(1.8rem,4vw,3.4rem); padding-inline:clamp(20px,3vw,48px); color:var(--cream); white-space:nowrap; display:inline-flex; align-items:center; gap:clamp(20px,3vw,48px); }
.marquee__item::after{ content:"\2022"; font-family:var(--display); font-style:normal; font-size:.5em; color:var(--terra); }

/* ---------- sezione generica ---------- */
.sec{ position:relative; padding-block:clamp(80px,12vh,170px); }
.sec__label{ font-family:var(--mono); font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--terra); display:flex; align-items:center; gap:.7em; }
.sec__label::before{ content:""; width:32px; height:1px; background:var(--terra); }

/* manifesto */
.mani{ font-size:clamp(2rem,5.4vw,4.6rem); line-height:1.04; letter-spacing:-0.03em; font-weight:600; max-width:18ch; margin:clamp(24px,4vh,52px) 0 0; }
.mani .serif{ color:var(--terra); }
.mani__cols{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(28px,5vw,64px); max-width:880px; margin-top:clamp(40px,6vh,72px); }
@media (max-width:680px){ .mani__cols{ grid-template-columns:1fr; gap:22px; } }
.mani__cols p{ color:var(--dim); font-size:1.08rem; margin:0; }

/* ---------- BIG ROWS (le tre porte) ---------- */
.rows{ }
.bigrow{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,64px); align-items:center; overflow:hidden; padding:clamp(40px,5vw,80px) var(--gut); }
.bigrow--rev .bigrow__media{ order:2; }
@media (max-width:820px){ .bigrow{ grid-template-columns:1fr; min-height:0; } .bigrow--rev .bigrow__media{ order:0; } }
.bigrow__ghost{ position:absolute; top:50%; transform:translateY(-50%); font-weight:700; font-size:clamp(14rem,40vw,46rem); line-height:.7; color:rgba(242,237,225,.045); letter-spacing:-0.03em; z-index:0; pointer-events:none; }
.bigrow__ghost--l{ left:-.1em; }
.bigrow__ghost--r{ right:-.1em; }
.bigrow__media{ position:relative; z-index:1; }
.bigrow__media .ph{ height:auto; aspect-ratio:4/4.2; min-height:0; border-radius:999px 999px clamp(20px,3vw,40px) clamp(20px,3vw,40px); }
.bigrow__text{ position:relative; z-index:2; display:flex; flex-direction:column; justify-content:center; padding:clamp(8px,2.5vw,44px); gap:18px; }
@media (max-width:820px){ .bigrow__text{ padding-block:48px; } }
.bigrow__idx{ font-family:var(--mono); font-size:.72rem; letter-spacing:.2em; color:var(--terra); }
.bigrow__title{ font-size:clamp(2.6rem,5.5vw,5.2rem); font-weight:700; letter-spacing:-0.03em; line-height:.96; margin:0; }
.bigrow__title .serif{ color:var(--sand); }
.bigrow__desc{ color:var(--dim); max-width:34ch; font-size:1.06rem; }
.bigrow__link{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; display:inline-flex; align-items:center; gap:.7em; width:max-content; padding-bottom:5px; border-bottom:1px solid var(--terra); transition:gap .3s, color .3s; margin-top:6px; }
.bigrow__link:hover{ gap:1.2em; color:var(--terra); }

/* placeholder (materico, scuro) */
.ph{ position:relative; width:100%; height:100%; min-height:inherit; overflow:hidden; border-radius:var(--r);
  background:repeating-linear-gradient(125deg, rgba(242,237,225,.05) 0 2px, transparent 2px 12px), var(--ink2);
  display:flex; align-items:flex-end; }
.ph--terra{ background:repeating-linear-gradient(125deg, rgba(16,19,12,.16) 0 2px, transparent 2px 12px), #7a3c24; }
.ph__tag{ font-family:var(--mono); font-size:.64rem; letter-spacing:.13em; text-transform:uppercase; color:var(--cream); border-radius:999px;
  background:rgba(16,19,12,.55); border:1px solid var(--line); padding:.55em .95em; margin:16px; max-width:calc(100% - 32px); }
.ph__rings{ position:absolute; inset:0; background:repeating-radial-gradient(circle at 60% 40%, transparent 0 28px, rgba(242,237,225,.16) 28px 30px); transition:transform 1.3s cubic-bezier(.2,.7,.2,1); transform-origin:60% 40%; will-change:transform; }
.bigrow:hover .ph__rings, .maggio__media:hover .ph__rings, .archfig:hover .ph__rings{ transform:scale(1.22); }
.bigrow__media,.archfig .ph,.maggio__media .ph{ transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.bigrow:hover .bigrow__media,.archfig:hover .ph{ transform:translateY(-6px); }

/* increspatura che segue il cursore nell'hero (acqua) */
.cursor-ring{ position:absolute; z-index:2; width:8px; height:8px; margin:-4px 0 0 -4px; border-radius:50%; border:1px solid var(--terra); pointer-events:none; opacity:.55; animation:ringout 1.7s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes ringout{ to{ width:300px; height:300px; margin:-150px 0 0 -150px; opacity:0; border-color:var(--sand); } }

/* ---------- MAGGIO (archivio) ---------- */
.maggio{ position:relative; }
.maggio__inner{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,72px); align-items:center; }
@media (max-width:820px){ .maggio__inner{ grid-template-columns:1fr; gap:34px; } }
.maggio__big{ font-size:clamp(2.2rem,5vw,4rem); line-height:1.02; letter-spacing:-0.03em; font-weight:600; margin:18px 0 22px; }
.maggio__big .serif{ color:var(--terra); }
.maggio__meta{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; margin-top:24px; }
.maggio__media{ position:relative; aspect-ratio:4/5; }
.maggio__media .ph{ border-radius:999px 999px clamp(20px,3vw,40px) clamp(20px,3vw,40px); }
.tag-archive{ font-family:var(--mono); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink0); background:var(--sand); padding:.5em .9em; border-radius:999px; }

/* link generico sottolineato */
.ulink{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; display:inline-flex; align-items:center; gap:.6em; padding-bottom:4px; border-bottom:1px solid var(--terra); transition:gap .3s,color .3s; }
.ulink:hover{ gap:1.1em; color:var(--terra); }

/* ---------- FOOTER ---------- */
.foot{ border-top:1px solid var(--line); padding-block:clamp(56px,8vh,100px); position:relative; overflow:hidden; }
.foot__huge{ font-weight:700; font-size:clamp(5rem,22vw,20rem); line-height:.82; letter-spacing:-0.035em; color:rgba(242,237,225,.05); margin:0 0 clamp(28px,5vh,56px); }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
@media (max-width:760px){ .foot__grid{ grid-template-columns:1fr; gap:30px; } }
.foot h3{ font-family:var(--mono); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--sand); margin:0 0 16px; font-weight:400; }
.foot a.fl{ display:block; padding:6px 0; color:var(--dim); transition:color .3s, transform .3s; }
.foot a.fl:hover{ color:var(--cream); transform:translateX(4px); }
.foot__tel{ display:inline-flex; align-items:center; gap:.5em; font-weight:700; font-size:clamp(1.4rem,3.2vw,1.7rem); letter-spacing:-0.01em; color:var(--cream); transition:color .3s; }
.foot__tel svg{ color:var(--terra); flex:none; }
.foot__tel:hover{ color:var(--terra); }
.foot__sign{ display:flex; justify-content:space-between; gap:18px 40px; flex-wrap:wrap; align-items:baseline; margin-top:clamp(40px,6vh,72px); padding-top:24px; border-top:1px solid var(--line-2); color:var(--dim-2); }

/* ---------- sottopagine ---------- */
.hero__meta{ position:relative; z-index:3; display:flex; gap:34px; flex-wrap:wrap; padding:18px var(--gut) 22px; border-top:1px solid var(--line-2); margin-top:18px; }
.hero__meta > div{ display:flex; flex-direction:column; gap:6px; }
.hero__meta .mono{ color:var(--dim-2); }
.hero__meta strong{ font-weight:600; font-size:1.05rem; letter-spacing:-0.01em; white-space:nowrap; }

.lead{ font-size:clamp(1.1rem,1.6vw,1.45rem); line-height:1.45; color:var(--dim); max-width:32ch; }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); max-width:880px; }
@media (max-width:680px){ .two{ grid-template-columns:1fr; gap:22px; } }
.two p{ color:var(--dim); font-size:1.08rem; margin:0; }
.statement{ font-family:var(--serif); font-style:italic; font-size:clamp(1.9rem,4.6vw,3.6rem); line-height:1.16; max-width:22ch; margin:clamp(20px,3vh,40px) 0 0; }
.statement .hl{ color:var(--terra); }

.dogrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(22px,2.6vw,44px); }
@media (max-width:900px){ .dogrid{ grid-template-columns:1fr 1fr; gap:40px 28px; } }
@media (max-width:520px){ .dogrid{ grid-template-columns:1fr; } }
.doitem{ border-top:1px solid var(--line-2); padding-top:18px; }
.doitem .ix{ font-family:var(--mono); font-size:.74rem; letter-spacing:.16em; color:var(--terra); display:block; margin-bottom:22px; }
.doitem h3{ font-size:clamp(1.3rem,2vw,1.7rem); font-weight:600; letter-spacing:-0.01em; margin:0 0 10px; }
.doitem p{ color:var(--dim); font-size:1rem; margin:0; }

.archgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,34px); align-items:end; }
@media (max-width:760px){ .archgrid{ grid-template-columns:1fr; max-width:460px; } }
.archfig{ margin:0; }
.archfig .ph{ aspect-ratio:4/5.2; border-radius:999px 999px clamp(20px,3vw,40px) clamp(20px,3vw,40px); }
.archfig figcaption{ margin-top:16px; color:var(--dim); }

.bridge{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,32px); }
@media (max-width:760px){ .bridge{ grid-template-columns:1fr; } }
.bcard{ display:block; border:1px solid var(--line); border-radius:var(--r); padding:clamp(28px,4vw,52px); transition:transform .5s cubic-bezier(.2,.7,.2,1), border-color .4s; }
.bcard:hover{ transform:translateY(-5px); border-color:rgba(242,237,225,.28); }
.bcard .ix{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--terra); display:block; margin-bottom:18px; }
.bcard h3{ font-size:clamp(1.8rem,3.2vw,2.8rem); font-weight:700; letter-spacing:-0.025em; line-height:1; margin:0 0 16px; }
.bcard h3 .serif{ color:var(--sand); }
.bcard p{ color:var(--dim); margin:0 0 22px; max-width:34ch; }

.trio{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,48px); }
@media (max-width:760px){ .trio{ grid-template-columns:1fr; gap:32px; } }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:start; }
@media (max-width:820px){ .split{ grid-template-columns:1fr; gap:34px; } }
.inforow{ display:grid; grid-template-columns:130px 1fr; gap:24px; padding:18px 0; border-top:1px solid var(--line-2); }
@media (max-width:520px){ .inforow{ grid-template-columns:1fr; gap:6px; } }
.inforow .mono{ color:var(--dim-2); }
.inforow p{ margin:0; color:var(--dim); }
.tag-archive{ display:inline-block; }

/* calendario / cartellone */
.catgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,2.6vw,40px) clamp(24px,3vw,52px); }
@media (max-width:760px){ .catgrid{ grid-template-columns:1fr 1fr; gap:34px 28px; } }
@media (max-width:480px){ .catgrid{ grid-template-columns:1fr; } }

.cal{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.4vw,28px); }
@media (max-width:760px){ .cal{ grid-template-columns:1fr; } }
.calcard{ border:1px solid var(--line); border-radius:var(--r); padding:clamp(24px,3vw,40px); transition:border-color .4s, transform .5s cubic-bezier(.2,.7,.2,1); }
.calcard:hover{ border-color:rgba(242,237,225,.26); transform:translateY(-4px); }
.calcard--edm{ grid-column:1/-1; background:linear-gradient(120deg,#7a3c24,#2a2018); border-color:rgba(242,237,225,.22); }
.calcard__hd{ display:flex; align-items:baseline; gap:.6em; margin-bottom:20px; flex-wrap:wrap; }
.calcard__d{ font-size:clamp(2.4rem,4.4vw,3.6rem); font-weight:700; letter-spacing:-0.035em; line-height:.9; }
.calcard__m{ font-family:var(--mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--terra); }
.calcard--edm .calcard__m{ color:var(--sand); }
.ev{ display:flex; gap:18px; padding:10px 0; border-top:1px solid var(--line-2); }
.ev:first-of-type{ border-top:0; }
.ev time{ font-family:var(--mono); font-size:.72rem; color:var(--dim-2); min-width:50px; padding-top:3px; flex:none; }
.ev p{ margin:0; color:var(--cream); font-size:1rem; }
.ev p small{ display:block; font-family:var(--mono); font-size:.6rem; letter-spacing:.13em; text-transform:uppercase; color:var(--sand); margin-top:3px; }
.calnote{ color:var(--dim-2); font-size:.95rem; margin:clamp(28px,4vh,44px) 0 0; max-width:60ch; }

/* rete territoriale */
.logos{ display:flex; flex-wrap:wrap; gap:12px; margin-top:8px; }
.logochip{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; color:var(--dim); border:1px solid var(--line); border-radius:999px; padding:.65em 1.1em; }
.patro{ display:flex; flex-wrap:wrap; gap:10px 14px; margin-top:14px; }
.patro span{ font-family:var(--mono); font-size:.72rem; color:var(--cream); }
.patro span + span::before{ content:"·"; color:var(--terra); margin-right:14px; }

/* hero con un'immagine ad arco a fianco (variante sottopagina) */
.lhero{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px); align-items:center; padding:clamp(120px,16vh,190px) var(--gut) clamp(40px,7vh,90px); }
@media (max-width:860px){ .lhero{ grid-template-columns:1fr; gap:40px; } }
.lhero__arch .ph{ aspect-ratio:4/5; border-radius:999px 999px clamp(20px,3vw,40px) clamp(20px,3vw,40px); }
.lword{ font-weight:700; letter-spacing:-0.035em; line-height:.86; font-size:clamp(4rem,12vw,11rem); margin:.05em 0 0;
  background:linear-gradient(180deg,var(--cream),var(--cream-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.lword .serif{ -webkit-text-fill-color:var(--sand); color:var(--sand); }

/* reveal — solo transform (mai opacità). Il contenuto è SEMPRE visibile:
   in ambienti che mettono in pausa le animazioni resta leggibile, solo non animato. */
.rv{ transition:transform .9s cubic-bezier(.2,.7,.2,1); }
html.reveal-ready .rv:not(.in){ transform:translateY(26px); }
.rv.in{ transform:none; }
@media (prefers-reduced-motion:reduce){ html.reveal-ready .rv:not(.in){ transform:none; } .rv{ transition:none; } html{ scroll-behavior:auto; } }
