/* ===========================================================
   Climbid: foglio di stile condiviso (tutte le pagine)
   =========================================================== */
:root{
  --ink:#150E2B;
  --ink-2:#1E1542;
  --ink-3:#281C58;
  --paper:#F4F1F9;
  --muted:#A99FC4;
  --arancio:#F59A1A;
  --arancio-d:#E07F00;
  --oro:#FBB040;
  --ciano:#2BB8D9;
  --line:rgba(244,241,249,.10);
  --line-2:rgba(244,241,249,.16);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--ink);color:var(--paper);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
:focus-visible{outline:3px solid var(--ciano);outline-offset:3px;border-radius:6px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--oro);margin-bottom:18px;
}
h2.sec{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.08;max-width:22ch}
.lead{color:var(--muted);font-size:clamp(16px,1.6vw,18px);font-weight:500;max-width:64ch;margin-top:16px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:60;background:rgba(21,14,43,.74);
  backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:34px;height:74px}
.logo{display:flex;align-items:center;font-weight:800;font-size:22px;letter-spacing:-.02em}
.logo-img{height:38px;width:auto;margin-right:9px;display:block}
.nav-menu{display:flex;gap:26px;font-size:15px;font-weight:600;color:var(--muted)}
.nav-menu a{transition:color .15s;padding:4px 0;border-bottom:2px solid transparent}
.nav-menu a:hover{color:var(--paper)}
.nav-menu a.active{color:var(--paper);border-bottom-color:var(--arancio)}
.nav-cta{margin-left:auto}
.btn{font-family:inherit;font-weight:700;font-size:15px;cursor:pointer;border:none;border-radius:11px;
  padding:12px 22px;transition:transform .12s,background .2s,box-shadow .2s,border-color .2s;
  display:inline-flex;align-items:center;gap:8px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--arancio);color:var(--ink);box-shadow:0 10px 28px -12px var(--arancio)}
.btn-primary:hover{background:var(--oro)}
.btn-ghost{background:transparent;color:var(--paper);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--ciano);color:var(--ciano)}
.menu-toggle{display:none;background:none;border:none;color:var(--paper);font-size:26px;cursor:pointer;margin-left:auto}
.mobile-menu{display:none;border-bottom:1px solid var(--line);background:rgba(21,14,43,.97)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:14px 24px;font-weight:600;color:var(--paper);border-top:1px solid var(--line)}

/* ---------- generic section ---------- */
section{padding:84px 0}

/* ---------- page sub-hero (interior pages) ---------- */
.subhero{position:relative;padding:72px 0 36px}
.subhero::before{content:"";position:absolute;top:-120px;right:-100px;width:460px;height:460px;
  background:radial-gradient(circle,rgba(43,184,217,.20),transparent 62%);pointer-events:none}
.crumb{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:18px}
.crumb a:hover{color:var(--paper)}
.crumb .sep{opacity:.5;margin:0 8px}
.subhero h1{position:relative;font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-.03em;line-height:1.04;max-width:18ch}
.subhero h1 .g{background:linear-gradient(100deg,var(--arancio),var(--ciano));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.subhero p.intro{position:relative;margin-top:22px;font-size:clamp(17px,1.9vw,20px);color:var(--muted);font-weight:500;max-width:56ch}

/* ---------- prose / content blocks ---------- */
.content{padding:30px 0 70px}
.block{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin:54px 0}
.block.rev{direction:rtl}.block.rev>*{direction:ltr}
.block h2{font-size:clamp(24px,3vw,32px);font-weight:800;letter-spacing:-.02em;line-height:1.12}
.block p{color:var(--muted);font-size:17px;margin-top:16px}
.block p+p{margin-top:14px}
.prose{max-width:70ch}
.prose h2{font-size:clamp(24px,3vw,32px);font-weight:800;letter-spacing:-.02em;margin-top:48px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--muted);font-size:17px;margin-top:16px}

/* panel / card */
.panel{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:30px}
.panel h3{font-size:19px;font-weight:800;display:flex;align-items:center;gap:11px}
.panel .ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;
  background:rgba(245,154,26,.16);color:var(--arancio)}
.panel.cyan .ic{background:rgba(43,184,217,.16);color:var(--ciano)}
.panel ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:13px}
.panel li{display:flex;gap:11px;font-size:15px;color:var(--muted)}
.panel li::before{content:"·";color:var(--line-2);font-weight:700}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

/* feature card */
.feature{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:30px;
  transition:transform .25s,border-color .25s}
.feature:hover{transform:translateY(-6px);border-color:var(--line-2)}
.feature .fi{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(135deg,var(--arancio),var(--oro));color:var(--ink);font-size:20px}
.feature.c .fi{background:linear-gradient(135deg,var(--ciano),#5BD0EA)}
.feature.g .fi{background:linear-gradient(135deg,var(--oro),var(--ciano))}
.feature h3{font-size:19px;font-weight:800}
.feature p{font-size:15px;color:var(--muted);margin-top:11px}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:26px 22px}
.step .no{font-size:13px;font-weight:800;letter-spacing:.1em;color:var(--oro)}
.step h3{font-size:18px;font-weight:800;margin-top:12px;line-height:1.2}
.step p{font-size:14px;color:var(--muted);margin-top:9px}

/* callout */
.callout{background:var(--ink);border:1px dashed var(--line-2);border-radius:16px;padding:22px 24px;
  font-size:16px;color:var(--muted);margin:30px 0}
.callout b{color:var(--arancio)}
.callout.cyan b{color:var(--ciano)}

/* stat cards */
.mkt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.mkt{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:28px 22px}
.mkt .num{font-size:clamp(30px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1;
  background:linear-gradient(100deg,var(--arancio),var(--ciano));-webkit-background-clip:text;background-clip:text;color:transparent}
.mkt .lbl{font-size:14px;color:var(--muted);margin-top:10px}
.src{font-size:12px;color:var(--muted);opacity:.8;margin-top:20px}

/* next-page nav */
.nextnav{border-top:1px solid var(--line);margin-top:20px;padding-top:34px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.nextnav .label{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.nextnav .ntitle{font-size:22px;font-weight:800;margin-top:6px}
.nextnav a.nlink{display:inline-flex;align-items:center;gap:10px}

/* link inline */
.morelink{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--ciano);margin-top:20px;
  transition:gap .2s}
.morelink:hover{gap:14px}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);padding:40px 0;color:var(--muted);font-size:14px}
.foot-in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between}

/* ---------- RESPONSIVE ---------- */
@media (max-width:920px){
  .nav-menu,.nav-cta{display:none}
  .menu-toggle{display:block}
  .steps{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr}
  .mkt-grid{grid-template-columns:1fr 1fr}
  .block{grid-template-columns:1fr;gap:24px}
  .block.rev{direction:ltr}
}
@media (max-width:620px){
  .grid-2{grid-template-columns:1fr}
  section{padding:60px 0}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ===========================================================
   Stili specifici della HOME
   =========================================================== */
.hero{position:relative;padding:80px 0 66px}
.hero::before{content:"";position:absolute;top:-160px;right:-120px;width:560px;height:560px;
  background:radial-gradient(circle,rgba(43,184,217,.22),transparent 62%);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-200px;left:-140px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(245,154,26,.18),transparent 62%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(36px,5.6vw,62px);font-weight:800;letter-spacing:-.03em;line-height:1.02}
.hero h1 .g{background:linear-gradient(100deg,var(--arancio),var(--ciano));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{margin-top:24px;font-size:clamp(17px,1.9vw,20px);color:var(--muted);font-weight:500;max-width:46ch}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.hero-note{margin-top:22px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}
.hero-note .pulse{width:9px;height:9px;border-radius:50%;background:var(--ciano);
  box-shadow:0 0 0 0 rgba(43,184,217,.5);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(43,184,217,.5)}70%{box-shadow:0 0 0 12px rgba(43,184,217,0)}100%{box-shadow:0 0 0 0 rgba(43,184,217,0)}}

.stack{position:relative}
.req-card{background:var(--ink-2);border:1px solid var(--line-2);border-radius:16px;padding:18px 20px;
  box-shadow:0 26px 60px -30px rgba(0,0,0,.7);position:relative;z-index:3}
.req-card .tt{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ciano)}
.req-card .car{font-size:19px;font-weight:800;margin-top:6px}
.req-card .meta{font-size:13px;color:var(--muted);margin-top:3px}
.offers{margin-top:14px;display:flex;flex-direction:column;gap:11px}
.offer{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:14px 16px;
  display:flex;align-items:center;gap:14px;opacity:0;transform:translateX(26px);
  transition:opacity .55s ease,transform .55s cubic-bezier(.2,.7,.3,1),border-color .2s}
.offer.show{opacity:1;transform:none}
.offer .av{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center;
  font-weight:800;font-size:14px;background:var(--ink-3);color:var(--paper)}
.offer .info{flex:1;min-width:0}
.offer .dn{font-size:14px;font-weight:700}
.offer .chips{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}
.offer .chip{font-size:11px;font-weight:600;color:var(--muted);background:var(--ink-3);border-radius:50px;padding:3px 9px}
.offer .price{font-size:18px;font-weight:800;color:var(--arancio);white-space:nowrap}
.offer.best{border-color:var(--ciano);box-shadow:0 0 0 1px var(--ciano) inset}
.offer.best .badge{position:absolute;top:-9px;right:14px;background:var(--ciano);color:var(--ink);
  font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:50px}

.section-head .morelink{margin-top:14px}

.ben-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:46px}
.ben{border-radius:20px;padding:34px;border:1px solid var(--line)}
.ben.b1{background:linear-gradient(160deg,rgba(43,184,217,.10),var(--ink-2))}
.ben.b2{background:linear-gradient(160deg,rgba(245,154,26,.10),var(--ink-2))}
.ben .tag{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.ben.b1 .tag{color:var(--ciano)}.ben.b2 .tag{color:var(--arancio)}
.ben h3{font-size:23px;font-weight:800;margin-top:8px}
.ben ul{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:15px}
.ben li{display:flex;gap:12px;font-size:15px}
.ben li .ck{flex:none;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800;margin-top:1px}
.ben.b1 li .ck{background:rgba(43,184,217,.18);color:var(--ciano)}
.ben.b2 li .ck{background:rgba(245,154,26,.18);color:var(--arancio)}
.ben li b{color:var(--paper)}.ben li span{color:var(--muted)}

.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:46px;max-width:760px}
.tm{background:var(--ink-2);border:1px solid var(--line);border-radius:18px;padding:28px;display:flex;gap:18px;align-items:center}
.tm .av{width:64px;height:64px;border-radius:16px;flex:none;display:grid;place-items:center;font-size:22px;font-weight:800;color:var(--ink)}
.tm:nth-child(1) .av{background:linear-gradient(135deg,var(--ciano),#5BD0EA)}
.tm:nth-child(2) .av{background:linear-gradient(135deg,var(--arancio),var(--oro))}
.tm .nm{font-size:18px;font-weight:800}
.tm .ro{font-size:13px;font-weight:700;color:var(--oro);margin-top:2px}
.tm .bio{font-size:14px;color:var(--muted);margin-top:8px}

.cta-band{background:linear-gradient(135deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-2);
  border-radius:26px;padding:54px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);
  width:480px;height:300px;background:radial-gradient(circle,rgba(245,154,26,.22),transparent 64%)}
.cta-band h2{position:relative;font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.02em}
.cta-band p{position:relative;color:var(--muted);margin-top:14px;max-width:52ch;margin-left:auto;margin-right:auto;font-size:17px}
.cta-band .actions{position:relative;margin-top:30px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.steps .step::after{content:"→";position:absolute;right:-15px;top:50%;transform:translateY(-50%);
  color:var(--line-2);font-size:20px;font-weight:700}
.steps .step:last-child::after{display:none}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .steps .step::after{display:none}
}
@media (max-width:620px){
  .ben-grid,.team-grid{grid-template-columns:1fr}
  .cta-band{padding:38px 24px}
}
