/* ============================================================
   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); }
.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); 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; }

.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; }

/* ---------- 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; }
