/* ============================================================
   MIRA — Design system condiviso (site.css)
   Brand LOCKED. Le pagine riusano queste classi, non le ridefiniscono.
   ============================================================ */

/* ---------- Token ---------- */
:root{
  --coral:#E8633A;       /* azione / impatto umano: riempimenti bottoni, icone */
  --coral-soft:rgba(232,99,58,.10);
  --coral-700:#cf5430;   /* hover bottoni coral / avatar gradient */
  --coral-text:#b04527;  /* corallo SOLO-TESTO/link su chiaro: >=4.5:1 anche su surface e coral-soft */
  --ai:#6A5AE0;          /* SOLO AI */
  --ai-soft:rgba(106,90,224,.10);
  --ai-700:#5949c9;
  --green:#1F9D6B;       /* impatto / esito: icone, barre, sfondi */
  --green-soft:rgba(31,157,107,.10);
  --green-700:#147049;   /* verde SOLO-TESTO su chiaro: >=4.5:1 anche su surface e green-soft */
  --ink:#1F1B17;
  --paper:#FAF6F1;
  --surface:#F1EBE3;
  --line:#E0D8CD;
  --muted:#6E665C;       /* testo informativo: >=4.5:1 su paper/surface/bianco */
  --body:#6B645B;
  --white:#fff;

  --r-sm:10px; --r-md:13px; --r-lg:16px; --r-xl:18px;
  --wrap:1180px;
  --pad-x:22px;
  --t:180ms cubic-bezier(.2,.6,.2,1);

  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-text:'Plus Jakarta Sans',system-ui,sans-serif;
}

@media (min-width:768px){ :root{ --pad-x:56px; } }

/* ---------- Reset leggero ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-text);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
::selection{ background:var(--coral); color:#fff; }

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

:focus-visible{ outline:3px solid var(--ai); outline-offset:2px; border-radius:4px; }

/* ---------- Layout ---------- */
.wrap{ max-width:var(--wrap); margin:0 auto; padding-left:var(--pad-x); padding-right:var(--pad-x); }
.section{ padding:56px 0; }
@media (min-width:768px){ .section{ padding:84px 0; } }
.section--surface{ background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.section--ink{ background:var(--ink); color:var(--paper); }
.section--ink .lead,.section--ink p{ color:rgba(250,246,241,.72); }

/* ---------- Eyebrow ---------- */
.eyebrow{ display:flex; align-items:baseline; gap:12px; margin-bottom:22px; }
.eyebrow__num{ font-family:var(--font-display); font-weight:700; font-size:13px; letter-spacing:.12em; color:var(--coral-text); }
.eyebrow__label{ font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.section--ink .eyebrow__label{ color:rgba(250,246,241,.55); }

/* ---------- Tipografia ---------- */
.h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(2rem,1.4rem + 3vw,3.25rem); line-height:1.06; letter-spacing:-.03em; }
.h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.55rem,1.2rem + 1.6vw,2.25rem); line-height:1.12; letter-spacing:-.025em; }
.h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.15rem,1.05rem + .5vw,1.4rem); line-height:1.2; letter-spacing:-.02em; }
.lead{ font-size:clamp(1.0625rem,1rem + .35vw,1.2rem); line-height:1.6; color:var(--body); }
.text-ai{ color:var(--ai); }
.text-coral{ color:var(--coral-text); }
.text-green{ color:var(--green-700); }
.muted{ color:var(--muted); }

/* ---------- Bottoni ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  min-height:44px; padding:11px 20px;
  font-family:var(--font-display); font-weight:600; font-size:15px; line-height:1;
  border:1.5px solid transparent; border-radius:11px;
  cursor:pointer; text-align:center;
  transition:transform var(--t),background var(--t),border-color var(--t),color var(--t);
}
.btn:active{ transform:translateY(1px); }
.btn svg{ width:18px; height:18px; }
.btn--lg{ min-height:52px; padding:15px 28px; font-size:16px; }

.btn--coral{ background:var(--coral); color:#fff; }
.btn--coral:hover{ background:var(--coral-700); }

.btn--ai{ background:var(--ai); color:#fff; }
.btn--ai:hover{ background:var(--ai-700); }

.btn--ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); background:rgba(31,27,23,.03); }
.section--ink .btn--ghost{ border-color:rgba(250,246,241,.28); color:var(--paper); }
.section--ink .btn--ghost:hover{ border-color:var(--paper); background:rgba(250,246,241,.06); }

.btn--ink{ background:var(--ink); color:var(--paper); }
.btn--ink:hover{ background:#000; }

/* ---------- Pill / badge ---------- */
.pill{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.02em;
  border-radius:999px; padding:5px 12px; border:1px solid var(--line); color:var(--body);
}
.pill::before{ content:""; width:7px; height:7px; border-radius:50%; background:currentColor; flex:none; }
.pill--coral{ color:var(--coral-text); background:var(--coral-soft); border-color:transparent; }
.pill--ai{ color:var(--ai-700); background:var(--ai-soft); border-color:transparent; }
.pill--green{ color:var(--green-700); background:var(--green-soft); border-color:transparent; }

.badge-ai{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ai); border:1.5px solid var(--ai); border-radius:999px; padding:6px 13px; background:var(--white);
}
.badge-ai::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--ai); animation:miraPulse 2.6s ease-in-out infinite; }

/* ---------- Card / feature ---------- */
.card{ background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); padding:26px; }
.card--link{ display:block; transition:transform var(--t),border-color var(--t); }
.card--link:hover{ transform:translateY(-3px); border-color:var(--ink); }
.card--link:focus-visible{ transform:translateY(-3px); }

.feature .feature__icon{ margin-bottom:16px; }
.feature__title{ font-family:var(--font-display); font-weight:600; font-size:1.15rem; letter-spacing:-.01em; margin-bottom:8px; display:flex; align-items:center; gap:9px; }
.feature__text{ font-size:15px; line-height:1.55; color:var(--body); }
.feature__more{ display:inline-flex; align-items:center; gap:6px; margin-top:14px; font-family:var(--font-display); font-weight:600; font-size:13.5px; color:var(--coral-text); }
.feature__more svg{ width:15px; height:15px; transition:transform var(--t); }
.card--link:hover .feature__more svg{ transform:translateX(3px); }

.feature__icon{
  width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; flex:none;
  background:var(--coral-soft); color:var(--coral);
}
.feature__icon svg{ width:23px; height:23px; }
.feature__icon--ai{ background:var(--ai-soft); color:var(--ai); }
.feature__icon--green{ background:var(--green-soft); color:var(--green); }
.feature__icon--ink{ background:rgba(31,27,23,.07); color:var(--ink); }
.feature__icon--coral{ background:var(--coral-soft); color:var(--coral); }

/* ---------- Griglie ---------- */
.grid{ display:grid; gap:20px; }
.grid--2{ grid-template-columns:1fr; }
.grid--3{ grid-template-columns:1fr; }
.grid--4{ grid-template-columns:1fr; }
@media (min-width:640px){ .grid--2{ grid-template-columns:repeat(2,1fr); } .grid--4{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:900px){ .grid--3{ grid-template-columns:repeat(3,1fr); } .grid--4{ grid-template-columns:repeat(4,1fr); } }

/* ---------- Nav ---------- */
.site-nav{
  position:sticky; top:0; z-index:50;
  background:rgba(250,246,241,.82); backdrop-filter:saturate(160%) blur(12px); -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);
}
.site-nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:64px; }
.brand{ display:inline-flex; align-items:center; gap:11px; flex:none; }
.brand__mark{ width:30px; height:30px; flex:none; }
.brand__word{ font-family:var(--font-display); font-weight:600; font-size:23px; letter-spacing:-.04em; color:var(--ink); }
.brand__dot{ color:var(--coral); }

.site-nav__links{ display:none; align-items:center; gap:4px; }
.site-nav__links a{
  font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--body);
  padding:9px 13px; border-radius:9px; transition:color var(--t),background var(--t);
}
.site-nav__links a:hover{ color:var(--ink); background:rgba(31,27,23,.04); }
.site-nav__links a[aria-current="page"]{ color:var(--ink); }
.site-nav__links a[aria-current="page"] span{ box-shadow:inset 0 -2px 0 var(--coral); padding-bottom:2px; }
/* nav editoriale: numerini hairline opzionali + word più crisp */
.brand__word{ letter-spacing:-.045em; }
.site-nav__links a{ position:relative; }
.site-nav__meta{ display:none; }
@media (min-width:1024px){
  .site-nav__meta{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
  .site-nav__meta .reticle{ --reticle-size:16px; color:var(--coral); }
}

.site-nav__cta{ display:none; align-items:center; gap:10px; flex:none; }
@media (min-width:1024px){ .site-nav__links,.site-nav__cta{ display:flex; } }

.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border:1px solid var(--line); border-radius:11px;
  background:var(--white); color:var(--ink); cursor:pointer; flex:none;
}
.nav-toggle svg{ width:22px; height:22px; }
.nav-toggle .nav-toggle__close{ display:none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__open{ display:none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__close{ display:block; }
@media (min-width:1024px){ .nav-toggle{ display:none; } }

.nav-drawer{
  display:none; border-top:1px solid var(--line); background:var(--paper);
  padding:14px var(--pad-x) 26px;
}
.nav-drawer.is-open{ display:block; }
.nav-drawer a{
  display:block; font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink);
  padding:14px 4px; border-bottom:1px solid var(--line);
}
.nav-drawer a[aria-current="page"]{ color:var(--coral); }
.nav-drawer__cta{ display:grid; gap:12px; margin-top:20px; }
.nav-drawer__cta .btn{ width:100%; }
@media (min-width:1024px){ .nav-drawer{ display:none !important; } }

/* ---------- AI panel ---------- */
.ai-panel{
  background:linear-gradient(180deg,var(--ai-soft),rgba(106,90,224,.02));
  border:1px solid rgba(106,90,224,.22); border-radius:var(--r-lg); padding:24px;
}
.ai-panel__head{ display:flex; align-items:center; gap:9px; margin-bottom:18px; }
.ai-panel__ring{ width:24px; height:24px; border:1.6px solid var(--ai); border-radius:50%; display:flex; align-items:center; justify-content:center; flex:none; }
.ai-panel__dot{ width:8px; height:8px; border-radius:50%; background:var(--ai); animation:miraPulse 2.6s ease-in-out infinite; }
.ai-panel__title{ font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ai); }
.ai-card{ background:var(--white); border:1px solid rgba(106,90,224,.22); border-radius:var(--r-md); padding:18px; }
.ai-card__label{ font-family:var(--font-display); font-weight:600; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:9px; }
.ai-chips{ display:flex; gap:12px; margin-top:14px; flex-wrap:wrap; }
.ai-chip{ flex:1 1 130px; background:var(--white); border:1px solid var(--line); border-radius:11px; padding:13px 15px; }
.ai-chip__k{ font-size:11px; color:var(--muted); }
.ai-chip__v{ font-family:var(--font-display); font-weight:600; font-size:15px; margin-top:4px; }

/* ---------- Quote SÌ / EVITA ---------- */
.quote{ border:1px solid var(--line); border-radius:var(--r-lg); padding:26px 28px; background:var(--white); }
.quote__tag{ font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:14px; display:inline-flex; align-items:center; gap:8px; }
.quote__text{ font-size:1.0625rem; line-height:1.65; }
.quote--yes .quote__tag{ color:var(--green); }
.quote--avoid .quote__tag{ color:var(--coral); }
.quote--avoid .quote__text{ color:var(--muted); }
.section--ink .quote{ background:transparent; border-color:rgba(250,246,241,.16); }
.section--ink .quote--yes .quote__text{ color:rgba(250,246,241,.88); }
.section--ink .quote--avoid .quote__text{ color:rgba(250,246,241,.5); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--paper); }
.site-footer__top{ display:grid; gap:40px; padding:56px 0 44px; }
@media (min-width:768px){ .site-footer__top{ grid-template-columns:1.4fr repeat(4,1fr); gap:32px; } }
.site-footer .brand__word{ color:var(--paper); }
.site-footer__claim{ font-size:14px; line-height:1.6; color:rgba(250,246,241,.6); margin-top:16px; max-width:300px; }
.foot-cols__h{ font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:rgba(250,246,241,.5); margin-bottom:14px; }
.foot-cols ul{ display:grid; gap:10px; }
.foot-cols a{ font-size:14.5px; color:rgba(250,246,241,.78); transition:color var(--t); }
.foot-cols a:hover{ color:var(--paper); }
.site-footer__legal{ border-top:1px solid rgba(250,246,241,.14); padding:22px 0; font-size:13px; color:rgba(250,246,241,.5); line-height:1.6; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; }
/* footer editoriale: claim oversize sopra le colonne + watermark mirino */
.site-footer{ position:relative; overflow:hidden; }
.site-footer .reticle-wm{ background:var(--paper); opacity:.045; }
.site-footer__lead{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.6rem,1.2rem + 2vw,2.6rem); line-height:1.08; letter-spacing:-.03em; color:var(--paper); max-width:18ch; padding:56px 0 8px; }
.site-footer__lead .brand__dot{ color:var(--coral); }
.site-footer__divider{ height:1px; background:rgba(250,246,241,.14); margin:0; }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .5s ease,transform .5s ease; }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } }

/* ---------- App-shot (mockup prodotto) ---------- */
.app-shot{ background:var(--white); border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; }
.app-shot__bar{ height:46px; background:var(--surface); border-bottom:1px solid var(--line); display:flex; align-items:center; gap:8px; padding:0 16px; }
.app-shot__dots{ display:flex; gap:7px; }
.app-shot__dots i{ width:11px; height:11px; border-radius:50%; background:var(--line); }
.app-shot__brand{ display:flex; align-items:center; gap:8px; margin-left:14px; }
.app-shot__brand .brand__word{ font-size:15px; }
.app-shot__tab{ margin-left:12px; font-size:13px; color:var(--muted); }

.app-shot__body{ display:grid; grid-template-columns:1fr; }
@media (min-width:900px){ .app-shot__body{ grid-template-columns:248px 1fr 312px; } }

.app-col{ padding:26px 24px; }
.app-col--contact{ border-bottom:1px solid var(--line); }
.app-col--timeline{ border-bottom:1px solid var(--line); }
@media (min-width:900px){
  .app-col--contact,.app-col--timeline{ border-bottom:none; border-right:1px solid var(--line); }
}
.app-col--ai{ background:linear-gradient(180deg,rgba(106,90,224,.07),rgba(106,90,224,.02)); }

.app-avatar{ width:60px; height:60px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:#fff; font-family:var(--font-display); font-weight:600; font-size:20px; background:linear-gradient(135deg,var(--coral),var(--coral-700)); }
.app-name{ font-family:var(--font-display); font-weight:600; font-size:20px; margin-top:16px; }
.app-meta{ font-size:13px; color:var(--muted); margin-top:3px; }
.app-pills{ display:flex; flex-wrap:wrap; gap:7px; margin-top:16px; }
.app-stats{ margin-top:24px; border-top:1px solid var(--line); padding-top:18px; display:grid; gap:15px; }
.app-stat__n{ font-family:var(--font-display); font-weight:700; font-size:22px; }
.app-stat__k{ font-size:12px; color:var(--muted); }

.app-col__h{ font-family:var(--font-display); font-weight:600; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:20px; }
.app-time{ display:grid; gap:18px; }
.app-event{ display:flex; gap:13px; }
.app-event__dot{ width:9px; height:9px; border-radius:50%; margin-top:6px; flex:none; }
.app-event__t{ font-size:15px; font-weight:600; }
.app-event__s{ font-size:13px; color:var(--muted); margin-top:2px; }

/* ---------- Hero ---------- */
.hero{ padding-top:40px; }
.hero__grid{ display:grid; gap:40px; align-items:center; }
@media (min-width:1024px){
  .hero{ padding-top:64px; }
  .hero__grid{ grid-template-columns:1.05fr 1.1fr; gap:48px; }
}

/* ---------- Util ---------- */
.stack-sm{ display:grid; gap:10px; }
.cta-row{ display:flex; flex-wrap:wrap; gap:14px; }
.center{ text-align:center; }
.mx-auto{ margin-left:auto; margin-right:auto; }
.maxw-prose{ max-width:62ch; }
.maxw-640{ max-width:640px; }
.maxw-720{ max-width:720px; }

/* ---------- Pulse keyframe ---------- */
@keyframes miraPulse{ 0%,100%{ box-shadow:0 0 0 3px rgba(106,90,224,.22); } 50%{ box-shadow:0 0 0 9px rgba(106,90,224,0); } }
.brand__pulse{ animation:miraPulse 2.6s ease-in-out infinite; }


/* ============================================================
   WARM EDITORIAL — direzione artistica (additivo, non rompe nulla)
   Editoriale/magazine + griglia Swiss asimmetrica + calore organico.
   ============================================================ */

/* ---------- 1. GRANA / TEXTURE carta ----------
   Layer fisso di rumore SVG su tutto il fondo. Toglie il "flat gradient AI". */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0;
  pointer-events:none;
  mix-blend-mode:multiply;
  opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* il contenuto sta sopra la grana */
.site-nav, main, .site-footer{ position:relative; z-index:1; }
@media (prefers-reduced-motion:reduce){ body::before{ opacity:.035; } }

/* ---------- 2. OCCHIELLI NUMERATI (raffinati) ----------
   .eyebrow esiste già; qui la firma editoriale: hairline + tracking forte. */
.eyebrow{ align-items:center; }
.eyebrow__num{ font-size:12px; letter-spacing:.16em; }
.eyebrow__num::after{ content:""; display:inline-block; width:26px; height:1px; background:var(--coral); margin-left:12px; vertical-align:middle; opacity:.55; }
.eyebrow__label{ font-size:11px; letter-spacing:.24em; }
/* occhiello con label a sinistra stretta (Swiss): usalo su una colonna .col-rail */
.eyebrow--stack{ flex-direction:column; align-items:flex-start; gap:6px; }
.eyebrow--stack .eyebrow__num::after{ display:none; }

/* ---------- 3. TIPOGRAFIA EDITORIALE ----------
   Display oversize, tracking stretto, contrasto di scala forte. */
.display{
  font-family:var(--font-display); font-weight:600;
  font-size:clamp(2.6rem,1.6rem + 4.6vw,5rem);
  line-height:.98; letter-spacing:-.04em;
}
.display--xl{ font-size:clamp(3rem,1.8rem + 6vw,6rem); }
.kicker{ /* intro oversize sotto un display */
  font-size:clamp(1.15rem,1.05rem + .6vw,1.5rem); line-height:1.5; color:var(--body); font-weight:400;
}
.smallcaps{ font-family:var(--font-display); font-weight:600; font-size:.72em; letter-spacing:.18em; text-transform:uppercase; }
.serif-em{ font-style:italic; } /* enfasi editoriale */
.num{ font-family:var(--font-display); font-weight:700; font-feature-settings:"tnum" 1; letter-spacing:-.01em; }

/* drop-cap per un paragrafo d'apertura: <p class="dropcap"> */
.dropcap::first-letter{
  font-family:var(--font-display); font-weight:600; float:left;
  font-size:3.4em; line-height:.78; padding:.04em .12em 0 0; color:var(--coral);
}

/* hairline rules come divisori editoriali */
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.rule--ink{ background:rgba(250,246,241,.16); }
.overline{ border-top:1px solid var(--line); }
.section--ink .overline{ border-color:rgba(250,246,241,.16); }

/* ---------- 4. GRIGLIA SWISS ASIMMETRICA (12 col) ---------- */
.grid12{ display:grid; grid-template-columns:repeat(12,1fr); gap:24px; }
/* MOBILE-FIRST: ogni colonna è full width; l'asimmetria Swiss entra solo da 1024px */
.grid12 > *{ grid-column:1/-1; }
.col-12{ grid-column:1/-1; }
@media (min-width:1024px){
  .col-rail{ grid-column:1/4; }   /* colonna etichetta stretta a sinistra */
  .col-main{ grid-column:4/13; }  /* contenuto largo a destra (come brand book) */
  .col-7{ grid-column:1/8; }      /* hero testo */
  .col-5{ grid-column:8/13; }     /* hero visual */
  .col-8{ grid-column:1/9; }
  .col-4l{ grid-column:9/13; }
  .col-6a{ grid-column:1/7; }
  .col-6b{ grid-column:7/13; }
  .offset-1{ grid-column-start:2; }
  /* Donazioni: visual a sinistra, testo a destra (inversione editoriale) solo desktop */
  .don-copy{ order:2; }
}

/* ---------- 5. MOTIVO MIRINO (reticle) riutilizzabile ----------
   SVG inline tramite mask così eredita currentColor → si colora dove serve. */
.reticle{
  --rc:currentColor;
  width:var(--reticle-size,64px); height:var(--reticle-size,64px);
  flex:none; display:inline-block;
  background:var(--rc);
  -webkit-mask:var(--reticle-mask) center/contain no-repeat;
          mask:var(--reticle-mask) center/contain no-repeat;
}
:root{
  /* mirino aperto: cerchio esterno + 4 tacche + cerchio interno + punto.
     definito una volta come variabile riutilizzabile */
  --reticle-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Cg fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='16' cy='16' r='13.2'/%3E%3Cpath stroke-linecap='round' d='M16 1.4v4.4M16 26.2v4.4M1.4 16h4.4M26.2 16h4.4'/%3E%3Ccircle cx='16' cy='16' r='6.6' stroke-width='1.8'/%3E%3C/g%3E%3Ccircle cx='16' cy='16' r='2.7' fill='black'/%3E%3C/svg%3E");
}
.reticle--coral{ color:var(--coral); }
.reticle--ink{ color:var(--ink); }
.reticle--paper{ color:var(--paper); }

/* divisore di sezione col mirino al centro su una hairline */
.reticle-divider{ display:flex; align-items:center; gap:20px; color:var(--line); }
.reticle-divider::before,.reticle-divider::after{ content:""; flex:1; height:1px; background:var(--line); }
.reticle-divider .reticle{ --reticle-size:30px; color:var(--coral); opacity:.9; }
.section--ink .reticle-divider{ color:rgba(250,246,241,.16); }
.section--ink .reticle-divider::before,.section--ink .reticle-divider::after{ background:rgba(250,246,241,.16); }

/* watermark mirino grande e tenue di sfondo per una sezione */
.has-reticle-wm{ position:relative; overflow:hidden; isolation:isolate; }
.reticle-wm{
  position:absolute; pointer-events:none; z-index:0;
  width:min(560px,70vw); aspect-ratio:1;
  background:var(--coral);
  -webkit-mask:var(--reticle-mask) center/contain no-repeat;
          mask:var(--reticle-mask) center/contain no-repeat;
  opacity:.05;
}
.reticle-wm--tr{ top:-14%; right:-10%; }
.reticle-wm--bl{ bottom:-16%; left:-12%; }
.reticle-wm--br{ bottom:-16%; right:-10%; }
.section--ink .reticle-wm{ background:var(--paper); opacity:.06; }
.has-reticle-wm > *{ position:relative; z-index:1; }

/* mirino che INQUADRA un contenuto reale (un dato, uno score, un volto):
   cornice attiva, non watermark. Cerchio esterno corallo + 4 tacche-crocino,
   wrappa il figlio e lo "mette a fuoco". Almeno 1 per pagina. */
.reticle-frame{
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  padding:clamp(14px,3vw,22px);
}
.reticle-frame__lens{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  border:1.5px solid var(--coral); border-radius:50%;
}
/* le 4 tacche del crocino (alto/basso/sx/dx) sulle hairline del lens */
.reticle-frame__lens::before,
.reticle-frame__lens::after{
  content:""; position:absolute; background:var(--coral);
}
.reticle-frame__lens::before{ /* tacche verticali */
  left:50%; top:-7px; bottom:-7px; width:1.5px; transform:translateX(-.75px);
  -webkit-mask:linear-gradient(#000 0 7px,transparent 7px calc(100% - 7px),#000 calc(100% - 7px) 100%);
          mask:linear-gradient(#000 0 7px,transparent 7px calc(100% - 7px),#000 calc(100% - 7px) 100%);
}
.reticle-frame__lens::after{ /* tacche orizzontali */
  top:50%; left:-7px; right:-7px; height:1.5px; transform:translateY(-.75px);
  -webkit-mask:linear-gradient(90deg,#000 0 7px,transparent 7px calc(100% - 7px),#000 calc(100% - 7px) 100%);
          mask:linear-gradient(90deg,#000 0 7px,transparent 7px calc(100% - 7px),#000 calc(100% - 7px) 100%);
}
.reticle-frame__target{ position:relative; z-index:2; }
/* focus che pulsa lentamente: il mirino "aggancia" il dato */
.reticle-frame--pulse .reticle-frame__lens{ animation:reticleLock 3.2s ease-in-out infinite; }
@keyframes reticleLock{ 0%,100%{ box-shadow:0 0 0 0 rgba(232,99,58,.28); } 50%{ box-shadow:0 0 0 8px rgba(232,99,58,0); } }
.section--ink .reticle-frame__lens,
.section--ink .reticle-frame__lens::before,
.section--ink .reticle-frame__lens::after{ border-color:var(--coral); background:var(--coral); }
@media (prefers-reduced-motion:reduce){ .reticle-frame--pulse .reticle-frame__lens{ animation:none; } }

/* bullet mirino per le liste editoriali */
.list-reticle{ display:grid; gap:16px; }
.list-reticle li{ display:flex; gap:14px; align-items:flex-start; }
.list-reticle li::before{
  content:""; flex:none; width:18px; height:18px; margin-top:3px;
  background:var(--coral);
  -webkit-mask:var(--reticle-mask) center/contain no-repeat;
          mask:var(--reticle-mask) center/contain no-repeat;
}
.section--ink .list-reticle li::before{ background:var(--coral); }

/* lista diritti: righe editoriali numerate, hairline divisorie */
.rights-list{ list-style:none; margin:0; padding:0; }
.rights-list li{
  display:flex; gap:18px; align-items:baseline;
  padding:16px 0; border-top:1px solid var(--line);
  color:var(--body); line-height:1.5;
}
.rights-list li:last-child{ border-bottom:1px solid var(--line); }
.rights-list__n{
  flex:none; font-family:var(--font-display); font-weight:700;
  font-size:13px; letter-spacing:.06em; color:var(--coral);
}

/* ---------- 6. PULL-QUOTE editoriale ----------
   (.quote SÌ/EVITA resta; questa è la citazione-voce oversize) */
.pull-quote{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(1.5rem,1.2rem + 1.8vw,2.4rem);
  line-height:1.18; letter-spacing:-.02em;
  padding-left:26px; border-left:2px solid var(--coral);
}
.pull-quote cite{ display:block; margin-top:18px; font-family:var(--font-text); font-style:normal; font-weight:500; font-size:.62em; letter-spacing:0; color:var(--muted); }
.section--ink .pull-quote{ color:var(--paper); }
.section--ink .pull-quote cite{ color:rgba(250,246,241,.6); }

/* ---------- 7. MICRO-DETTAGLI / refinement editoriale ---------- */
/* card editoriale: bordi netti, raggio contenuto, niente ombre soft */
.card--editorial{ border-radius:var(--r-sm); }
.card--flush{ border-radius:0; }
/* numero d'ordine in alto a destra della card (pilastri) */
.feature{ position:relative; }
.index-n{ font-family:var(--font-display); font-weight:700; font-size:13px; letter-spacing:.06em; color:var(--coral); }
.feature > .index-n{ position:absolute; top:22px; right:24px; opacity:.75; }
.feature__icon{ margin-bottom:16px; }
/* tag metadati hairline */
.meta-row{ display:flex; flex-wrap:wrap; gap:0; font-family:var(--font-display); font-weight:500; font-size:12.5px; letter-spacing:.04em; color:var(--muted); border-top:1px solid var(--line); }
.meta-row > *{ padding:14px 22px 14px 0; }
/* pill editoriale a spigolo */
.pill--square{ border-radius:6px; }
/* fascia trust editoriale con tacche */
.trust-rail{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; font-family:var(--font-display); font-weight:600; font-size:13px; letter-spacing:.04em; color:var(--muted); }
.trust-rail .dot{ width:5px; height:5px; border-radius:50%; background:var(--coral); flex:none; }

/* visual che sborda / angolato (app-shot nell'hero) */
.bleed-right{ } /* mobile: niente */
@media (min-width:1024px){
  .bleed-right{ margin-right:calc(-1 * var(--pad-x)); }
  .tilt{ transform:rotate(-1.4deg); transition:transform var(--t); }
  .tilt:hover{ transform:rotate(0deg); }
}
@media (prefers-reduced-motion:reduce){ .tilt{ transform:none !important; } }

/* ---------- BENTO PILASTRI asimmetrico (sezione 02) ----------
   Griglia editoriale: mobile colonna unica; da 1024px 6 colonne con
   card 'large' che sbordano su 4 col, le altre su 2 col. Niente parete
   bianca uniforme: alternanza outline / ink / coral chiaro. */
.bento{ display:grid; grid-template-columns:1fr; gap:20px; }
@media (min-width:640px){ .bento{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){
  .bento{ grid-template-columns:repeat(6,1fr); gap:22px; align-items:start; }
  .bento__col2{ grid-column:span 2; }
  .bento__col4{ grid-column:span 4; }
}
/* numero in filigrana oversize: elemento grafico forte, non micro-label */
.feature--bento{ overflow:hidden; }
.feature--bento > .index-n{
  position:absolute; inset:auto 14px -10px auto;
  font-size:clamp(4.5rem,7vw,7rem); line-height:.8; letter-spacing:-.04em;
  opacity:.07; pointer-events:none; z-index:0;
}
.feature--bento > *:not(.index-n){ position:relative; z-index:1; }
/* card piena ink: spezza il bianco, ospita la pull-quote interna */
.feature--ink{ background:var(--ink); border-color:var(--ink); color:var(--paper); }
.feature--ink .feature__title{ color:var(--paper); }
.feature--ink .feature__text{ color:rgba(250,246,241,.74); }
.feature--ink .feature__more{ color:var(--coral); }
.feature--ink.card--link:hover{ border-color:var(--coral); }
.feature--ink > .index-n{ opacity:.12; color:var(--paper); }
/* card coral chiara: accento caldo */
.feature--coral{ background:var(--coral-soft); border-color:transparent; }
.feature--coral > .index-n{ color:var(--coral); opacity:.13; }
/* mini pull-quote interna alla card large */
.feature__quote{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(1.05rem,.95rem + .5vw,1.32rem); line-height:1.28; letter-spacing:-.015em;
  margin-top:18px; padding-left:16px; border-left:2px solid var(--coral);
}
.feature--ink .feature__quote{ color:var(--paper); }


/* ============================================================
   MOBILE REFINEMENT — rifiniture responsive (additivo)
   Solo telefoni/tablet. Nessuna regressione desktop.
   ============================================================ */

/* ---------- 1. ZERO overflow orizzontale, globale ---------- */
html,body{ overflow-x:hidden; }
img,svg,video,canvas{ max-width:100%; height:auto; }

/* padding orizzontale che rispetta le safe-area dei notch */
@supports(padding:max(0px)){
  .wrap{
    padding-left:max(var(--pad-x),env(safe-area-inset-left));
    padding-right:max(var(--pad-x),env(safe-area-inset-right));
  }
}

/* ---------- 2. Tabelle: wrapper scroll-x con hint visivo ----------
   .table-scroll wrappa qualsiasi tabella larga. Ombre laterali che
   appaiono solo quando c'è contenuto fuori vista (background-attachment
   local). Prima colonna "sticky" su mobile per non perdere la riga. */
.table-scroll{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  background:var(--white);
  /* gradienti ombra che segnalano lo scroll orizzontale */
  background-image:
    linear-gradient(to right, var(--white) 30%, rgba(255,255,255,0)),
    linear-gradient(to left,  var(--white) 30%, rgba(255,255,255,0)),
    linear-gradient(to right, rgba(31,27,23,.10), rgba(31,27,23,0)),
    linear-gradient(to left,  rgba(31,27,23,.10), rgba(31,27,23,0));
  background-position:left center, right center, left center, right center;
  background-repeat:no-repeat;
  background-size:36px 100%, 36px 100%, 14px 100%, 14px 100%;
  background-attachment:local, local, scroll, scroll;
}
.table-scroll table{ width:100%; min-width:680px; border-collapse:collapse; }

/* prima colonna (intestazione di riga) ancorata mentre si scorre orizzontale,
   così su mobile la riga resta leggibile */
@media (max-width:639px){
  .table-scroll th[scope="row"]{
    position:sticky; left:0; z-index:1;
    background:var(--white);
    box-shadow:1px 0 0 var(--line);
  }
}

/* ---------- 3. Drawer di navigazione mobile: overlay comodo ----------
   Su mobile il drawer copre l'altezza utile, ha scroll interno e tap
   target generosi. Lo scroll-lock del body lo gestisce site.js. */
@media (max-width:1023px){
  body.nav-open{ overflow:hidden; }
  /* il nav (e quindi il drawer) deve stare sopra <main> quando il menu è aperto:
     la regola della grana porta nav e main entrambi a z-index:1, qui ripristiniamo
     la precedenza del nav col drawer aperto */
  body.nav-open .site-nav{ z-index:60; }
  .nav-drawer{
    position:fixed; left:0; right:0;
    top:64px; bottom:0;
    height:calc(100vh - 64px);
    height:calc(100dvh - 64px);
    max-height:none; overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    z-index:49;
    padding-bottom:calc(26px + env(safe-area-inset-bottom));
    animation:navDrawerIn .18s ease;
  }
  .nav-drawer a{ padding:16px 4px; }      /* tap target >=44px */
  .nav-drawer__cta .btn{ min-height:52px; }
}
@keyframes navDrawerIn{ from{ opacity:0; transform:translateY(-6px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .nav-drawer{ animation:none; } }

/* ---------- 4. Hero: ordine colonne e bleed controllato su mobile ----------
   Su mobile il visual (app-shot) sta sotto il testo e non sborda mai. */
@media (max-width:1023px){
  .bleed-right{ margin-right:0; }
  .app-shot{ max-width:100%; }
  /* l'app-shot su telefono: barra e colonne più compatte, niente overflow */
  .app-shot__body{ grid-template-columns:1fr; }
}

/* ---------- 5. Touch target minimi su link/azioni inline ---------- */
@media (max-width:639px){
  .feature__more,
  .site-footer .foot-cols a{ min-height:32px; display:inline-flex; align-items:center; }
  .nav-toggle{ width:48px; height:48px; }   /* hamburger comodo */
}

/* ---------- 6. Tipografia: nessun testo sotto i 14px sul corpo mobile ---------- */
@media (max-width:430px){
  .feature__text,.lead{ font-size:15px; }
}
