/* =========================================================
   ORTIQA — Venture home (page-specific, v2)
   Ink-on-paper · olive accent. Builds on ortiqa-home.css.
   Intro (Manifesto Loader), founder story, verticals,
   product showcase, logo marquee.
   ========================================================= */

:root{
  --brand:#4A553C; --brand-2:#3C5A38; --brand-soft:#D7E0BE; --marker:#C6D072;
  --on-brand:#F4ECCF;
  /* category accents, retuned into the earthy palette */
  --gold:#94782E; --sage:#76813B; --terra:#A8603E;
  --intro-ms:1;
}

/* ============== INTRO / MANIFESTO LOADER ============== */
.intro{position:fixed;inset:0;z-index:1000;overflow:hidden;background:var(--bg)}
.intro::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  opacity:.06;mix-blend-mode:multiply}
.intro[hidden]{display:none}
body.intro-lock{overflow:hidden}

/* column strips that wipe away to reveal the home */
.intro-cols{position:absolute;inset:0;display:flex;z-index:1}
.intro-cols i{flex:1;background:var(--bg);border-right:1px solid var(--line-2);transform:translateY(0)}
.intro-cols i:last-child{border-right:none}

.intro-stage{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:40px clamp(24px,6vw,80px)}

.intro-mark{position:absolute;top:clamp(26px,4vw,40px);left:clamp(26px,4vw,48px);
  display:flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:700;
  font-size:21px;letter-spacing:-0.03em;color:var(--ink);
  opacity:0;animation:introFade .8s var(--ease) .15s forwards}
.intro-mark .bdot{width:8px;height:8px;border-radius:50%;background:var(--brand);margin-top:6px}

/* soft blurred circles — brand motif, slow drift in from edges */
.semi{position:absolute;border-radius:50%;opacity:0;will-change:transform,opacity;
  filter:blur(8px);mix-blend-mode:multiply}
.semi-gold{width:42vw;height:42vw;max-width:520px;max-height:520px;left:-15vw;top:8%;
  background:radial-gradient(circle at 60% 50%, color-mix(in oklab,var(--gold) 50%,transparent), transparent 68%);
  animation:semiL calc(2.2s * var(--intro-ms)) var(--ease) .25s forwards}
.semi-terra{width:40vw;height:40vw;max-width:480px;max-height:480px;right:-16vw;top:6%;
  background:radial-gradient(circle at 35% 55%, color-mix(in oklab,var(--terra) 45%,transparent), transparent 68%);
  animation:semiR calc(2.2s * var(--intro-ms)) var(--ease) .4s forwards}
.semi-peri{width:48vw;height:48vw;max-width:580px;max-height:580px;left:50%;margin-left:-24vw;bottom:-26vw;
  background:radial-gradient(circle at 50% 35%, color-mix(in oklab,var(--sage) 42%,transparent), transparent 66%);
  animation:semiB calc(2.4s * var(--intro-ms)) var(--ease) .5s forwards}
@keyframes semiL{from{opacity:0;transform:translateX(-60px) scale(.92)}to{opacity:.55;transform:none}}
@keyframes semiR{from{opacity:0;transform:translateX(70px) scale(.92)}to{opacity:.5;transform:none}}
@keyframes semiB{from{opacity:0;transform:translateY(80px) scale(.94)}to{opacity:.5;transform:none}}

/* MOTTO — horizontal, stacked, centered */
.intro-motto{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.06em}
.intro-motto .line{overflow:hidden;display:block}
.intro-motto .line > span{display:block;
  font-family:var(--serif);font-weight:600;letter-spacing:-0.02em;line-height:1.04;
  font-size:clamp(28px,5.2vw,76px);color:var(--ink);text-transform:uppercase;white-space:nowrap;
  transform:translateY(112%);will-change:transform}
.intro-motto .hl{display:inline-block;position:relative;color:var(--ink);padding:0 .1em}
.intro-motto .hl::before{content:"";position:absolute;left:-.04em;right:-.04em;top:.14em;bottom:.08em;z-index:-1;
  background:var(--marker);border-radius:.6em .35em .5em .4em / .8em .55em .7em .5em;
  transform:rotate(-.8deg) scaleX(0);transform-origin:left;mix-blend-mode:multiply}
.intro.run .intro-motto .line:nth-child(1) > span{animation:mottoUp calc(.85s * var(--intro-ms)) var(--ease) .35s forwards}
.intro.run .intro-motto .line:nth-child(2) > span{animation:mottoUp calc(.85s * var(--intro-ms)) var(--ease) calc(.35s + .12s) forwards}
.intro.run .intro-motto .line:nth-child(3) > span{animation:mottoUp calc(.85s * var(--intro-ms)) var(--ease) calc(.35s + .24s) forwards}
.intro.run .intro-motto .hl::before{animation:hlIn calc(.55s * var(--intro-ms)) var(--ease) calc(1s * var(--intro-ms)) forwards}
@keyframes mottoUp{to{transform:none}}
@keyframes hlIn{to{transform:rotate(-.8deg) scaleX(1)}}

.intro-sub{position:relative;z-index:2;margin-top:clamp(24px,3vw,38px);
  font-family:var(--mono);font-size:clamp(12.5px,1.4vw,15px);line-height:1.6;
  letter-spacing:.02em;color:var(--muted);max-width:54ch;opacity:0}
.intro.run .intro-sub{animation:introFade calc(.9s * var(--intro-ms)) var(--ease) calc(1.2s * var(--intro-ms)) forwards}

.intro-enter{position:absolute;bottom:clamp(28px,4vw,46px);left:50%;transform:translateX(-50%);
  z-index:2;display:flex;align-items:center;gap:18px;opacity:0}
.intro.run .intro-enter{animation:introFade .9s var(--ease) calc(1.55s * var(--intro-ms)) forwards}
.intro-enter button{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);display:inline-flex;align-items:center;gap:9px;padding:11px 20px;
  border:1.5px solid var(--line);border-radius:999px;background:transparent;
  transition:border-color .25s var(--ease), background .25s, transform .25s}
.intro-enter button:hover{border-color:var(--ink);transform:translateY(-2px)}
.intro-enter button.ghost{border:none;color:var(--muted);padding:11px 6px}
.intro-enter button.ghost:hover{color:var(--ink);transform:none}
.intro-enter button svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none}
.intro-enter .prog{position:absolute;bottom:-12px;left:0;height:2px;background:var(--brand);width:0;border-radius:2px}
.intro.run .intro-enter .prog{animation:introProg calc(3.4s * var(--intro-ms)) linear calc(.9s * var(--intro-ms)) forwards}
@keyframes introProg{to{width:100%}}
@keyframes introFade{to{opacity:1}}

/* EXIT: fade content, then lift the column strips */
.intro.exit .intro-stage{opacity:0;transition:opacity .4s var(--ease)}
.intro.exit .intro-cols i{transition:transform .72s cubic-bezier(.76,0,.24,1)}
.intro.exit .intro-cols i:nth-child(1){transform:translateY(-101%);transition-delay:.02s}
.intro.exit .intro-cols i:nth-child(2){transform:translateY(101%);transition-delay:.09s}
.intro.exit .intro-cols i:nth-child(3){transform:translateY(-101%);transition-delay:.16s}
.intro.exit .intro-cols i:nth-child(4){transform:translateY(101%);transition-delay:.23s}
.intro.exit .intro-cols i:nth-child(5){transform:translateY(-101%);transition-delay:.30s}

@media (max-width:640px){ .intro-sub{display:none} }
@media (prefers-reduced-motion:reduce){
  .intro .semi{animation:none;opacity:.45}
  .intro-mark,.intro-sub,.intro-enter{animation:none!important;opacity:1!important}
  .intro-motto .line > span{transform:none!important;animation:none!important}
  .intro-motto .hl::before{transform:rotate(-.8deg) scaleX(1)!important;animation:none!important}
  .intro.exit{transition:opacity .4s ease;opacity:0}
  .intro.exit .intro-cols i{transition:none}
}

/* ============== HERO — centered manifesto ============== */
.hero.centered{padding:170px 0 56px;text-align:center}
.hero.centered .hero-wrap{max-width:980px;margin:0 auto}
.hero.centered .eyebrow{margin:0 auto}
.hero.centered h1{font-size:clamp(44px,6.6vw,96px);margin:26px auto 0;max-width:16ch}
.hero.centered .hl{white-space:normal}
.hero.centered .lead{margin:28px auto 0;max-width:60ch;font-size:clamp(18px,2.1vw,22px)}
.hero.centered .hero-actions{justify-content:center;margin-top:36px}

/* logo marquee */
.marquee{margin-top:clamp(56px,8vw,96px);position:relative}
.marquee .mq-k{text-align:center;font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.marquee-track{display:flex;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-track .row{display:flex;align-items:center;gap:clamp(40px,6vw,76px);padding-right:clamp(40px,6vw,76px);
  flex:none;animation:mq 36s linear infinite;will-change:transform}
.marquee:hover .row{animation-play-state:paused}
.marquee-track .logo{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.4vw,28px);
  letter-spacing:-0.02em;color:var(--ink);opacity:.4;white-space:nowrap;
  display:inline-flex;align-items:center;gap:10px;transition:opacity .3s}
.marquee-track .logo:hover{opacity:.85}
.marquee-track .logo .gd{width:9px;height:9px;border-radius:2px;background:var(--ink);opacity:.5}
@keyframes mq{to{transform:translateX(-100%)}}
@media (prefers-reduced-motion:reduce){ .marquee-track .row{animation:none} }

/* ============== ORIGINE / FOUNDER ============== */
.origin{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,72px);align-items:start}
.origin .o-copy h2{font-size:clamp(32px,4vw,56px);margin:18px 0 0}
.origin .o-copy h2 .hl{position:relative;color:var(--ink)}
.origin .o-copy h2 .hl::after{content:"";position:absolute;left:-1.5%;right:-1.5%;top:.14em;bottom:.06em;z-index:-1;
  background:var(--marker);border-radius:.7em .35em .6em .4em / .9em .6em .8em .5em;transform:rotate(-.7deg);mix-blend-mode:multiply}
.origin .o-copy .lead{margin-top:24px}
.origin .o-copy p + p{margin-top:18px}
.origin .o-copy .body{color:var(--body);font-size:17px;line-height:1.65;max-width:52ch}
.origin .o-copy .body b{color:var(--ink);font-weight:600}
.origin .o-media{position:sticky;top:100px}
.origin .o-photo{position:relative;border-radius:var(--r);overflow:hidden;background:var(--brand-soft);
  border:1px solid var(--line-2);aspect-ratio:4/5;box-shadow:var(--shadow)}
.origin .o-photo image-slot{width:100%;height:100%;display:block}
.origin .o-cap{display:flex;align-items:center;gap:12px;margin-top:18px}
.origin .o-cap .pin{width:42px;height:42px;border-radius:12px;background:var(--brand-soft);
  display:grid;place-items:center;flex:none}
.origin .o-cap .pin svg{width:20px;height:20px;stroke:var(--brand);stroke-width:1.7;fill:none}
.origin .o-cap b{display:block;color:var(--ink);font-weight:600;font-size:15.5px}
.origin .o-cap span{font-size:13.5px;color:var(--muted)}

.tonoi{margin-top:48px;padding:28px 32px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.tonoi .tn-line{font-family:var(--serif);font-weight:500;font-size:clamp(19px,2.3vw,26px);
  color:var(--ink);line-height:1.22;letter-spacing:-0.02em;flex:1;min-width:240px}
.tonoi .tn-line em{font-style:italic;color:var(--brand)}
.tonoi .avs{display:flex}
.tonoi .avs span{width:44px;height:44px;border-radius:50%;border:3px solid var(--surface);margin-left:-14px;
  background:var(--brand-soft);display:grid;place-items:center;font-family:var(--serif);font-weight:600;
  font-size:15px;color:var(--brand-2);box-shadow:var(--shadow-sm)}
.tonoi .avs span:first-child{margin-left:0}
.tonoi .avs .more{background:var(--ink);color:var(--bg);font-family:var(--mono);font-size:12px}
@media (max-width:880px){
  .origin{grid-template-columns:1fr;gap:40px}
  .origin .o-media{position:static}
}

/* ============== CONTESTO (big stats) ============== */
.context{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:8px}
.context .c{padding:34px 30px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-sm)}
.context .c .big{font-family:var(--serif);font-weight:600;font-size:clamp(46px,5.2vw,68px);line-height:1;color:var(--brand);letter-spacing:-0.02em}
.context .c .t{margin-top:14px;color:var(--ink);font-weight:600;font-size:16.5px;line-height:1.35}
.context .c .src{margin-top:10px;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--muted)}
@media (max-width:820px){ .context{grid-template-columns:1fr} }

/* ============== ECOSISTEMA PRODOTTI (clean enterprise cards) ============== */
.eco-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line-2);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden}
.eco{position:relative;display:flex;flex-direction:column;
  background:var(--surface);padding:34px 32px 30px;min-height:264px;
  text-decoration:none;transition:background .3s var(--ease)}
.eco:hover{background:color-mix(in oklab,var(--surface) 84%,var(--bg))}
.eco .etag{align-self:flex-start;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ec,var(--brand));
  background:color-mix(in oklab,var(--ec,var(--brand)) 11%,transparent);
  padding:5px 11px;border-radius:999px}
.eco h3{font-size:22px;margin:20px 0 0;color:var(--ink);line-height:1.12}
.eco p{font-size:14.5px;line-height:1.5;color:var(--body);margin-top:11px;text-wrap:pretty}
.eco-foot{margin-top:auto;padding-top:22px;display:flex;align-items:center;
  justify-content:space-between;gap:12px}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;
  border:1px solid transparent}
.chip-live{color:var(--brand-2);background:color-mix(in oklab,var(--brand) 12%,transparent);
  border-color:color-mix(in oklab,var(--brand) 22%,transparent)}
.chip-live .dotlive{width:6px;height:6px;border-radius:50%;background:var(--sage);
  box-shadow:0 0 0 0 color-mix(in oklab,var(--sage) 55%,transparent);
  animation:ecoPulse 2.4s var(--ease) infinite}
@keyframes ecoPulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--sage) 55%,transparent)}
  70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}
.chip-pilota{color:var(--gold);background:color-mix(in oklab,var(--gold) 12%,transparent);
  border-color:color-mix(in oklab,var(--gold) 24%,transparent)}
.chip-misura{color:var(--terra);background:color-mix(in oklab,var(--terra) 11%,transparent);
  border-color:color-mix(in oklab,var(--terra) 22%,transparent)}
.eco-go{font-weight:600;font-size:13.5px;color:var(--ink);display:inline-flex;align-items:center;gap:7px}
.eco-go svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s var(--ease)}
.eco:hover .eco-go svg{transform:translateX(4px)}
@media (prefers-reduced-motion:reduce){ .chip-live .dotlive{animation:none} }
@media (max-width:900px){ .eco-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:600px){ .eco-grid{grid-template-columns:1fr} }

/* ============== MANIFESTO ============== */
.manifesto{text-align:center;max-width:1000px;margin:0 auto}
.manifesto blockquote{font-family:var(--serif);font-weight:600;letter-spacing:-0.025em;
  font-size:clamp(32px,5.2vw,68px);line-height:1.08;color:var(--ink);text-wrap:balance}
.manifesto blockquote .mk{color:var(--brand)}
.manifesto .mf-p{margin:34px auto 0;max-width:60ch;font-size:clamp(17px,2vw,20px);color:var(--body);line-height:1.6;text-wrap:pretty}

/* ============== VERTICALI — 2 big horizontal cards ============== */
.vert-list{display:flex;flex-direction:column;gap:20px}
.vrow{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr auto;gap:clamp(24px,4vw,56px);
  align-items:center;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);
  padding:clamp(28px,3.4vw,46px) clamp(28px,3.6vw,52px);text-decoration:none;
  transition:transform .4s var(--ease),box-shadow .4s,border-color .3s}
.vrow::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--vc);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.vrow:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line)}
.vrow:hover::before{transform:scaleY(1)}
.vrow .vsemi{position:absolute;right:-60px;top:50%;margin-top:-130px;width:260px;height:260px;border-radius:50%;
  background:var(--vc);opacity:.08;transition:transform .5s var(--ease)}
.vrow:hover .vsemi{transform:scale(1.18)}
.vrow .vnum{font-family:var(--serif);font-weight:600;font-size:clamp(40px,5vw,72px);line-height:1;color:var(--vc);opacity:.32;letter-spacing:-0.03em}
.vrow .vmain{position:relative;z-index:1;min-width:0}
.vrow .vk{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.vrow .vbadge{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:999px;color:#fff;background:var(--vc)}
.vrow h3{font-size:clamp(28px,3.2vw,40px);margin:10px 0 0;color:var(--ink)}
.vrow p{font-size:15.5px;color:var(--body);margin-top:12px;max-width:62ch}
.vrow .vgo{position:relative;z-index:1;flex:none;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--vc);
  border:1.5px solid var(--line);border-radius:999px;padding:11px 18px;white-space:nowrap;
  transition:background .3s,border-color .3s,color .3s,transform .3s}
.vrow .vgo::before{content:attr(data-label)}
.vrow .vgo svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .3s var(--ease)}
.vrow:hover .vgo{background:var(--vc);border-color:var(--vc);color:#fff}
.vrow:hover .vgo svg{transform:translateX(3px)}
@media (max-width:760px){
  .vrow{grid-template-columns:1fr;gap:18px;text-align:left}
  .vrow .vnum{font-size:42px}
}

/* work modes */
.modes{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:26px}
.modes .m{background:var(--surface);padding:26px 28px}
.modes .m .mtag{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--brand-2)}
.modes .m h4{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink);margin:8px 0 2px;letter-spacing:-0.01em}
.modes .m .dur{font-size:13px;color:var(--muted)}
@media (max-width:820px){ .modes{grid-template-columns:1fr} }

/* ============== SMB RESULTS (micro-sectors) ============== */
.smb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.smb{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r);padding:28px 30px;overflow:hidden;text-decoration:none;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .3s}
.smb::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--pc,var(--brand));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.smb:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line)}
.smb:hover::before{transform:scaleX(1)}
.smb .stag{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--pc,var(--brand));
  background:color-mix(in oklab,var(--pc,var(--brand)) 13%,transparent);padding:5px 11px;border-radius:999px;align-self:flex-start}
.smb h3{font-size:23px;margin:16px 0 0;color:var(--ink)}
.smb .sline{font-size:14.5px;color:var(--body);margin-top:10px}
.smb .splace{margin-top:18px;padding:12px 14px;border:1px dashed var(--line);border-radius:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:var(--muted);background:color-mix(in oklab,var(--ink) 2.5%,transparent)}
.smb .sgo{margin-top:auto;padding-top:20px;font-weight:600;font-size:14px;color:var(--pc,var(--brand));display:inline-flex;align-items:center;gap:8px}
.smb .sgo svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s var(--ease)}
.smb:hover .sgo svg{transform:translateX(4px)}
@media (max-width:900px){ .smb-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:620px){ .smb-grid{grid-template-columns:1fr} }

/* ============== PRODOTTI PRONTI ============== */
.products{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.prod{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r);padding:30px 32px;overflow:hidden;text-decoration:none;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .3s}
.prod::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--pc,var(--brand));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.prod:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line)}
.prod:hover::before{transform:scaleX(1)}
.prod .ph{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.prod .picon{width:48px;height:48px;border-radius:13px;background:color-mix(in oklab,var(--pc,var(--brand)) 15%,transparent);
  color:var(--pc,var(--brand));display:grid;place-items:center;flex:none}
.prod .picon svg{width:23px;height:23px;stroke:currentColor;stroke-width:1.7;fill:none}
.prod .ptag{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--pc,var(--brand));
  background:color-mix(in oklab,var(--pc,var(--brand)) 13%,transparent);padding:5px 11px;border-radius:999px}
.prod .pstatus{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.prod h3{font-size:24px;margin:0;color:var(--ink)}
.prod p{font-size:15px;color:var(--body);margin-top:10px;flex:1}
.prod .pgo{margin-top:22px;font-weight:600;font-size:14.5px;color:var(--pc,var(--brand));display:inline-flex;align-items:center;gap:8px}
.prod .pgo svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s var(--ease)}
.prod:hover .pgo svg{transform:translateX(4px)}
.prod.feat{grid-column:1 / -1;flex-direction:row;align-items:center;gap:clamp(28px,4vw,56px)}
.prod.feat .pbody{flex:1}
.prod.feat .pmedia{flex:none;width:min(42%,420px);aspect-ratio:16/10;border-radius:var(--r-sm);overflow:hidden;background:color-mix(in oklab,var(--pc,var(--brand)) 12%,transparent);border:1px solid var(--line-2)}
.prod.feat .pmedia image-slot{width:100%;height:100%;display:block}
.prod.feat h3{font-size:clamp(26px,3vw,36px)}
@media (max-width:820px){
  .products{grid-template-columns:1fr}
  .prod.feat{flex-direction:column;align-items:flex-start}
  .prod.feat .pmedia{width:100%}
}

/* ============== CASI ============== */
.cases{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.case{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s}
.case:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.case .c-media{height:200px;background:var(--brand-soft);border-bottom:1px solid var(--line-2)}
.case .c-media image-slot{width:100%;height:100%;display:block}
.case .c-body{padding:28px 30px}
.case .c-tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-2)}
.case .c-body h3{font-size:23px;margin:10px 0 18px}
.case .psr{display:flex;flex-direction:column;gap:14px}
.case .psr .row{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start}
.case .psr .lab{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding-top:3px;min-width:74px}
.case .psr .val{font-size:15px;color:var(--body);line-height:1.5}
.case .psr .row.res .val{color:var(--ink);font-weight:600}
.case .psr .row.res .lab{color:var(--brand)}
@media (max-width:820px){ .cases{grid-template-columns:1fr} }

/* ============== CHECKLIST + dark band ============== */
.results{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,5vw,64px);align-items:center}
.results .checks{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:26px}
.results .checks li{display:flex;gap:14px;align-items:flex-start;font-size:16.5px;color:var(--body)}
.results .checks .tick{flex:none;width:26px;height:26px;border-radius:50%;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;margin-top:1px}
.results .checks .tick svg{width:14px;height:14px;stroke:currentColor;stroke-width:2.4;fill:none}
.results .dark{background:linear-gradient(155deg,var(--dark),var(--dark-2));color:#fff;border-radius:calc(var(--r) + 8px);padding:clamp(36px,4vw,52px);position:relative;overflow:hidden}
.results .dark::after{content:"";position:absolute;right:-12%;top:-30%;width:55%;height:160%;background:radial-gradient(circle, color-mix(in oklab,var(--brand) 60%,transparent), transparent 64%);opacity:.6}
.results .dark .dg{display:grid;grid-template-columns:1fr 1fr;gap:28px 24px;position:relative;z-index:1}
.results .dark .num{font-family:var(--serif);font-weight:600;font-size:clamp(34px,4vw,48px);line-height:1;color:#fff}
.results .dark .lbl{margin-top:10px;font-size:13.5px;color:rgba(243,240,233,.66);line-height:1.4}
@media (max-width:880px){ .results{grid-template-columns:1fr;gap:36px} .results .dark .dg{grid-template-columns:1fr 1fr} }

/* ============== I DUE APPROCCI (accordion) ============== */
.approaches{display:flex;flex-direction:column;gap:18px}
.appr{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);
  box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .35s var(--ease),border-color .3s}
.appr.open{box-shadow:var(--shadow);border-color:var(--line)}
.appr-head{width:100%;display:flex;align-items:center;gap:22px;text-align:left;background:none;border:none;
  cursor:pointer;padding:clamp(24px,3vw,34px) clamp(24px,3.4vw,40px);color:inherit}
.appr-head .anum{font-family:var(--serif);font-weight:600;font-size:clamp(30px,3.4vw,46px);line-height:1;
  color:var(--brand);opacity:.32;letter-spacing:-0.03em;flex:none}
.appr-head .amain{flex:1;min-width:0}
.appr-head .atop{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.appr-head h3{font-size:clamp(24px,2.8vw,34px);margin:0;color:var(--ink);letter-spacing:-0.01em}
.appr-head .abadge{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--brand-2);background:var(--brand-soft);padding:5px 11px;border-radius:999px}
.appr-head .adesc{margin-top:8px;font-size:15.5px;color:var(--body);line-height:1.5;max-width:70ch}
.appr-head .achev{flex:none;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line);
  display:grid;place-items:center;color:var(--ink);transition:transform .4s var(--ease),background .3s,border-color .3s}
.appr-head .achev svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .4s var(--ease)}
.appr.open .achev{background:var(--brand);border-color:var(--brand);color:#fff}
.appr.open .achev svg{transform:rotate(180deg)}
.appr-head:hover .achev{border-color:var(--ink)}
.appr-head:focus-visible{outline:2px solid var(--brand);outline-offset:-4px;border-radius:var(--r)}

/* expanding body via grid-rows trick */
.appr-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s var(--ease)}
.appr.open .appr-body{grid-template-rows:1fr}
.appr-body > .appr-inner{overflow:hidden;min-height:0;opacity:0;transition:opacity .4s var(--ease) .05s}
.appr.open .appr-body > .appr-inner{opacity:1}
.appr-inner{padding:0 clamp(24px,3.4vw,40px) clamp(28px,3.4vw,40px) clamp(24px,3.4vw,40px)}
.appr-inner .divider{height:1px;background:var(--line-2);margin-bottom:30px}

/* numbered steps inside an approach */
.appr-steps{display:flex;flex-direction:column;gap:20px}
.astep{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start}
.astep .sn{flex:none;width:34px;height:34px;border-radius:50%;background:var(--brand-soft);color:var(--brand-2);
  font-family:var(--mono);font-size:13px;font-weight:500;display:grid;place-items:center;margin-top:2px}
.astep h4{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--ink);margin:4px 0 6px;letter-spacing:-0.01em}
.astep p{font-size:15px;color:var(--body);line-height:1.6;margin:0;max-width:74ch}
.astep p b{color:var(--ink);font-weight:600}

/* PRIORA block */
.priora{margin-top:22px;background:color-mix(in oklab,var(--brand) 7%,var(--surface));
  border:1px solid var(--line-2);border-radius:var(--r);padding:clamp(22px,2.6vw,32px)}
.priora .pk{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.priora .pname{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4vw,46px);color:var(--brand);
  letter-spacing:-0.02em;line-height:1;margin:8px 0 0}
.priora .pdesc{font-size:15px;color:var(--body);line-height:1.6;margin:14px 0 0;max-width:72ch}
.priora .pdesc b{color:var(--ink);font-weight:600}

/* chart */
.priora-chart{position:relative;margin-top:24px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r-sm);padding:18px 18px 12px;box-shadow:var(--shadow-sm)}
.priora-canvas{position:relative}
.priora-svg{display:block;width:100%;height:auto}
.priora-axlabel{font-family:var(--mono);font-size:12px;letter-spacing:.16em;fill:var(--muted)}
.priora-corner{font-family:var(--mono);font-size:10px;letter-spacing:.04em;fill:var(--muted);opacity:.85}
.priora-note{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;fill:var(--brand-2)}
.priora-plabel{font-family:var(--sans);font-size:11px;font-weight:500}
.priora-dot{cursor:pointer;outline:none}
.priora-dot circle{transition:r .2s var(--ease)}
.priora-dot:focus-visible circle{stroke:var(--brand);stroke-width:2.5}
.priora-dot{opacity:0;transform:scale(.6);transform-origin:center;transform-box:fill-box}
.priora.animate .priora-dot{animation:prioraIn .5s var(--ease) forwards;animation-delay:var(--d,0ms)}
@keyframes prioraIn{to{opacity:1;transform:scale(1)}}
.priora.animate .priora-dot{opacity:1}

/* tooltip */
.priora-tip{position:absolute;z-index:5;pointer-events:none;
  background:var(--ink);color:var(--bg);border-radius:12px;padding:10px 13px;min-width:150px;
  box-shadow:var(--shadow);opacity:0;transition:opacity .18s var(--ease);
  transform:translate(-50%,calc(-100% - 14px))}
.priora-tip.flip{transform:translate(-50%,calc(-100% - 14px))}
.priora-tip b{display:block;font-family:var(--serif);font-weight:600;font-size:14px;line-height:1.2}
.priora-tip .d{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}
.priora-tip .m{display:block;font-size:12px;color:rgba(243,240,233,.7);margin-top:6px}
.priora-tip .m i{font-style:normal;color:#fff;font-weight:600}

/* legend */
.priora-legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:18px}
.priora-legend .lg{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--body)}
.priora-legend .lg i{width:9px;height:9px;border-radius:50%;flex:none}

@media (max-width:760px){
  .appr-head{gap:14px;padding:22px}
  .appr-head .anum{display:none}
  .priora-chart{overflow-x:auto}
  .priora-svg{min-width:560px}
  .priora-corner{font-size:9px}
}
@media (prefers-reduced-motion:reduce){
  .appr-body{transition:none}
  .appr-body > .appr-inner{transition:none}
}

/* sector pills */
.sectors{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.sectors .s{font-size:14px;font-weight:500;color:var(--ink);background:var(--surface);border:1px solid var(--line-2);padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-sm)}

/* nav text links (no center pill) */
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--body);padding:8px 14px;border-radius:999px;transition:color .2s,background .2s}
.nav-links a:hover{color:var(--ink);background:color-mix(in oklab,var(--ink) 5%,transparent)}
@media (max-width:860px){ .nav-links{display:none} }

/* replay intro pill */
.replay-intro{position:fixed;right:18px;bottom:18px;z-index:90;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  background:color-mix(in oklab,var(--surface) 75%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--line-2);border-radius:999px;padding:9px 15px;display:inline-flex;align-items:center;gap:8px;
  box-shadow:var(--shadow-sm);transition:color .2s,border-color .2s,transform .2s}
.replay-intro:hover{color:var(--ink);border-color:var(--line);transform:translateY(-2px)}
.replay-intro svg{width:13px;height:13px;stroke:currentColor;stroke-width:1.8;fill:none}

/* =========================================================
   CASE STUDIES v2 — narrativa + schema sistema AI (prima/dopo)
   ========================================================= */
.cases{display:flex;flex-direction:column;gap:22px}
.case{display:grid;grid-template-columns:0.92fr 1.08fr;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.case:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.case .c-head{padding:clamp(28px,3vw,40px);border-right:1px solid var(--line-2);
  display:flex;flex-direction:column}
.case .c-head .c-tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--brand-2)}
.case .c-head h3{font-family:var(--serif);font-weight:600;letter-spacing:-.015em;
  font-size:clamp(22px,2.4vw,29px);line-height:1.1;color:var(--ink);margin:13px 0 22px}
.case .c-head .psr{margin-top:auto}

/* system / schematic panel */
.c-system{padding:clamp(26px,2.6vw,34px);display:flex;flex-direction:column;
  gap:clamp(20px,2.4vw,30px);justify-content:center;
  background:
    radial-gradient(120% 100% at 100% 0%, color-mix(in oklab,var(--brand) 5%,transparent), transparent 60%),
    color-mix(in oklab,var(--bg) 55%,var(--surface))}
.track-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.track-head .tk{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;line-height:1}
.track-before .tk{color:var(--muted);background:color-mix(in oklab,var(--ink) 7%,transparent)}
.track-after .tk{color:var(--brand-2);background:color-mix(in oklab,var(--brand) 15%,transparent)}
.track-head .tmeta{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--muted)}
.track-after .tmeta{color:var(--brand-2);font-weight:500}

.flow{display:flex;align-items:stretch;flex-wrap:nowrap}
.fnode{flex:1 1 0;min-width:0;display:flex;flex-direction:column;justify-content:center;
  min-height:58px;padding:11px 12px;border-radius:13px;
  font-size:12px;line-height:1.22;text-align:center;text-wrap:balance;border:1px solid var(--line-2)}
.track-before .fnode{background:transparent;border-style:dashed;
  border-color:color-mix(in oklab,var(--ink) 18%,transparent);color:var(--muted)}
.track-after .fnode{background:var(--surface);border-color:var(--line);color:var(--ink);
  box-shadow:var(--shadow-sm);font-weight:500}
.fconn{flex:0 0 26px;align-self:center;height:1.5px;position:relative;border-radius:2px}
.track-before .fconn{background:repeating-linear-gradient(90deg,
  color-mix(in oklab,var(--ink) 30%,transparent) 0 4px,transparent 4px 8px)}
.track-after .fconn{background:var(--brand)}
.fconn::after{content:"";position:absolute;right:-2px;top:50%;transform:translateY(-50%);
  width:0;height:0;border-left:6px solid currentColor;
  border-top:4px solid transparent;border-bottom:4px solid transparent}
.track-before .fconn::after{color:color-mix(in oklab,var(--ink) 30%,transparent)}
.track-after .fconn::after{color:var(--brand)}

.fnode.core{flex:1.45 1 0;background:var(--brand);border-color:var(--brand);
  color:var(--on-brand);box-shadow:0 10px 24px -12px color-mix(in oklab,var(--brand) 80%,#000);gap:3px}
.fnode.core .core-t{display:flex;align-items:center;justify-content:center;gap:6px;
  font-weight:600;font-size:12.5px}
.fnode.core .core-glyph{font-size:11px;opacity:.85}
.fnode.core .core-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:.02em;
  opacity:.78;line-height:1.3}
.fnode.out{font-weight:600;color:var(--brand-2);
  border-color:color-mix(in oklab,var(--brand) 32%,transparent);
  background:color-mix(in oklab,var(--brand) 8%,var(--surface))}

@media (max-width:880px){
  .case{grid-template-columns:1fr}
  .case .c-head{border-right:none;border-bottom:1px solid var(--line-2)}
}
@media (max-width:520px){
  .flow{flex-direction:column}
  .fconn{flex:0 0 18px;width:1.5px;height:18px;align-self:center}
  .fconn::after{right:auto;top:auto;bottom:-2px;left:50%;transform:translateX(-50%);
    border-left:4px solid transparent;border-right:4px solid transparent;
    border-top:6px solid currentColor;border-bottom:none}
  .fnode{min-height:0;padding:12px}
}

/* =========================================================
   MANIFESTO v2 — visione di chiusura (banda scura)
   ========================================================= */
.manifesto2{position:relative;overflow:hidden;
  background:var(--crimson);color:var(--on-brand);
  border-radius:calc(var(--r) + 8px);
  padding:clamp(46px,5.4vw,86px) clamp(28px,5vw,80px);
  box-shadow:var(--shadow-lg)}
.manifesto2::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(80% 60% at 12% 0%, color-mix(in oklab,var(--peach) 16%,transparent), transparent 60%)}
.m2-semi{position:absolute;border-radius:999px 999px 0 0;pointer-events:none;opacity:.5;filter:blur(2px)}
.m2-semi-gold{width:220px;height:110px;right:-40px;top:-30px;
  background:radial-gradient(circle at 50% 100%, color-mix(in oklab,var(--peach) 50%,transparent), transparent 70%)}
.m2-semi-terra{width:160px;height:80px;right:120px;bottom:-20px;
  background:radial-gradient(circle at 50% 100%, color-mix(in oklab,var(--terra) 55%,transparent), transparent 70%)}
.m2-kicker{position:relative;font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--peach);display:block;margin-bottom:26px}
.m2-quote{position:relative;font-family:var(--serif);font-weight:500;letter-spacing:-.02em;
  font-size:clamp(30px,4.4vw,58px);line-height:1.08;color:#F7EFDB;text-wrap:balance;max-width:20ch}
.m2-quote .m2-hl{color:var(--peach)}
.m2-body{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:26px 44px;
  max-width:980px;margin-top:34px}
.m2-body p{font-size:clamp(15px,1.5vw,17px);line-height:1.62;
  color:color-mix(in oklab,var(--on-brand) 82%,transparent);text-wrap:pretty}
.m2-body p b{color:#F7EFDB;font-weight:600}
.m2-pillars{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  margin-top:clamp(36px,4vw,52px);
  background:color-mix(in oklab,var(--on-brand) 12%,transparent);
  border:1px solid color-mix(in oklab,var(--on-brand) 12%,transparent);border-radius:16px;overflow:hidden}
.m2-pillar{background:var(--crimson);padding:24px 26px;display:flex;flex-direction:column;gap:7px}
.m2-pillar .mp-n{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--peach)}
.m2-pillar .mp-t{font-family:var(--serif);font-size:20px;font-weight:600;color:#F7EFDB}
.m2-pillar .mp-d{font-size:13.5px;line-height:1.5;color:color-mix(in oklab,var(--on-brand) 72%,transparent)}
.m2-sign{position:relative;display:flex;flex-direction:column;gap:2px;
  margin-top:clamp(30px,3.4vw,42px);padding-top:24px;
  border-top:1px solid color-mix(in oklab,var(--on-brand) 14%,transparent)}
.m2-sign-name{font-family:var(--serif);font-style:italic;font-size:22px;color:#F7EFDB}
.m2-sign-role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:color-mix(in oklab,var(--on-brand) 62%,transparent)}
@media (max-width:680px){ .m2-body{grid-template-columns:1fr} .m2-pillars{grid-template-columns:1fr} }

/* =========================================================
   FOOTER v2
   ========================================================= */
.footer-v2{padding-top:clamp(56px,6vw,84px)}
.footer-v2 .foot-top{display:grid;grid-template-columns:1.3fr 2fr;gap:clamp(36px,5vw,72px);
  padding-bottom:44px;border-bottom:1px solid var(--line)}
.footer-v2 .foot-brand{display:flex;flex-direction:column;align-items:flex-start}
.footer-v2 .brand-lg{font-size:30px;margin-bottom:18px}
.footer-v2 .foot-tag{font-size:15.5px;line-height:1.55;color:var(--body);max-width:34ch;text-wrap:pretty}
.footer-v2 .foot-mail{margin-top:22px;display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:13.5px;letter-spacing:.01em;color:var(--ink);
  padding-bottom:4px;border-bottom:1.5px solid var(--line);transition:border-color .2s,gap .2s}
.footer-v2 .foot-mail svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .2s}
.footer-v2 .foot-mail:hover{border-color:var(--brand)}
.footer-v2 .foot-mail:hover svg{transform:translateX(3px)}
.footer-v2 .foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer-v2 .foot-col h4{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.footer-v2 .foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-v2 .foot-col ul a{font-size:14.5px;color:var(--body);transition:color .2s}
.footer-v2 .foot-col ul a:hover{color:var(--ink)}
@media (max-width:820px){
  .footer-v2 .foot-top{grid-template-columns:1fr;gap:36px}
  .footer-v2 .foot-cols{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:540px){ .footer-v2 .foot-cols{grid-template-columns:1fr;gap:26px} }

/* =========================================================
   CRIMSON eyebrow card (hero) — crimson lives ONLY here + manifesto
   ========================================================= */
.hero .eyebrow{background:var(--crimson);color:var(--on-brand);
  box-shadow:0 8px 22px -12px color-mix(in oklab,var(--crimson) 80%,#000)}
.hero .eyebrow .dot{background:var(--peach)}
