/* =====================================================================
   UBLOOM S.B. — Design System (brand ufficiale Codesygn)
   Palette: viola #44348B · magenta #E83085 · azzurro #588FCB
   Font: Montserrat (UI/titoli) · Cormorant (accenti, in luogo di Audrey)
   ===================================================================== */

:root {
  /* Palette brand */
  --bg:        #FFFFFF;
  --bg-2:      #F8F6FD;   /* card tint lilla chiarissimo */
  --bg-3:      #EFEBFA;
  --ink:       #0C0D0D;
  --ink-soft:  #2E2A3A;
  --muted:     #6B6680;
  --line:      rgba(68,52,139,.15);
  --line-soft: rgba(68,52,139,.08);

  --viola:     #44348B;
  --viola-deep:#2E2358;
  --clay:      #E83085;   /* accent primario (magenta) */
  --clay-deep: #C81E6E;
  --clay-soft: #FBD7E8;
  --plum:      #2E2358;   /* sezioni scure */
  --sage:      #588FCB;   /* azzurro */
  --gold:      #9DB8E6;   /* eyebrow su fondo scuro */
  --grad:      linear-gradient(135deg, #E83085 0%, #44348B 55%, #588FCB 100%);
  --grad-soft: linear-gradient(135deg, #F7C9DE, #D9D2F0);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --radius:   16px;
  --radius-s: 10px;
  --radius-l: 26px;
  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);
  --section: clamp(60px, 8.5vw, 132px);

  --shadow-s: 0 1px 2px rgba(46,35,88,.05), 0 6px 20px rgba(46,35,88,.06);
  --shadow-m: 0 12px 44px rgba(46,35,88,.14);
  --ease: cubic-bezier(.2, .7, .2, 1);
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} *{animation-duration:.001ms!important;transition-duration:.001ms!important} }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.65;
  font-size: clamp(15.5px, 1vw, 17px);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; }

/* Typography — Montserrat per i titoli */
h1, h2, h3, h4 { font-family: var(--sans); font-weight: 700; line-height: 1.12; letter-spacing: -.02em; color: var(--ink); }
.display { font-family: var(--sans); font-weight: 800; font-size: clamp(2.1rem, 4.6vw, 3.3rem); line-height: 1.07; letter-spacing: -.03em; }
.h2 { font-size: clamp(1.55rem, 3vw, 2.35rem); line-height: 1.13; letter-spacing: -.025em; font-weight: 700; }
.h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); font-weight: 700; letter-spacing: -.01em; }
.lead { font-size: clamp(1rem, 1.3vw, 1.18rem); color: var(--ink-soft); line-height: 1.55; font-weight: 400; }
.eyebrow {
  font-family: var(--sans); font-size: .74rem; font-weight: 700;
  letter-spacing: .15em; text-transform: uppercase; color: var(--clay);
  display: inline-flex; align-items: center; gap: .55rem;
}
.eyebrow::before { content:""; width: 24px; height: 2px; background: currentColor; opacity:.55; border-radius:2px; }
/* parola evidenziata in gradiente */
.serif-em {
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-style: normal;
}
.quote-serif { font-family: var(--serif); font-style: italic; font-weight: 500; }

.container { width:100%; max-width: var(--maxw); margin-inline:auto; padding-inline: var(--gut); }
.section { padding-block: var(--section); }
.center { text-align:center; }
.grid { display:grid; gap: clamp(16px,2.2vw,28px); }
@media (min-width:760px){ .cols-2{grid-template-columns:repeat(2,1fr)} .cols-3{grid-template-columns:repeat(3,1fr)} .cols-4{grid-template-columns:repeat(4,1fr)} }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:.55em; padding:.9em 1.5em; border-radius:999px; font-weight:600; font-size:.95rem; letter-spacing:-.01em; border:1.5px solid transparent; transition:all .35s var(--ease); }
.btn svg{ width:1.05em; height:1.05em; transition:transform .35s var(--ease); }
.btn:hover svg{ transform:translateX(3px); }
.btn-primary{ background: var(--grad); color:#fff; background-size:140% 140%; }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(232,48,133,.32); background-position:100% 0; }
.btn-ghost{ background:transparent; color:var(--viola); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--viola); transform:translateY(-2px); }
.btn-light{ background:var(--viola); color:#fff; border-color:var(--viola); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-m); }
.btn-onplum{ background:#fff; color:var(--viola); }
.btn-onplum:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(0,0,0,.22); }
.link-arrow{ display:inline-flex; align-items:center; gap:.45em; font-weight:600; color:var(--clay); transition:gap .3s var(--ease); }
.link-arrow svg{ width:1em; height:1em; transition:transform .3s var(--ease); }
.link-arrow:hover{ gap:.7em; } .link-arrow:hover svg{ transform:translateX(2px); }

/* Header */
.site-header{ position:sticky; top:0; z-index:100; background:color-mix(in srgb, var(--bg) 84%, transparent); backdrop-filter:saturate(140%) blur(14px); border-bottom:1px solid transparent; transition:border-color .3s, background .3s; }
.site-header.scrolled{ border-bottom-color:var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.4rem; height:88px; }
.brand{ display:inline-flex; align-items:center; }
.brand img{ display:block; height:56px; width:auto; }
.nav-links{ display:none; align-items:center; gap:.2rem; }
.nav-links a{ padding:.45rem .62rem; border-radius:8px; font-size:.9rem; font-weight:500; color:var(--ink); transition:all .25s; white-space:nowrap; }
.nav-links a:hover{ color:var(--viola); background:var(--line-soft); }
.nav-cta{ display:none; }
.burger{ display:inline-flex; flex-direction:column; gap:5px; width:44px; height:44px; align-items:center; justify-content:center; border-radius:10px; border:1px solid var(--line); background:transparent; }
.burger span{ width:20px; height:2px; background:var(--viola); border-radius:2px; transition:.3s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media(min-width:1000px){ .nav-links,.nav-cta{display:flex} .burger{display:none} }

.mobile-menu{ position:fixed; inset:88px 0 0; z-index:99; background:var(--bg); padding:2rem var(--gut); display:flex; flex-direction:column; gap:.2rem; transform:translateY(-12px); opacity:0; pointer-events:none; transition:.35s var(--ease); }
.mobile-menu.open{ transform:none; opacity:1; pointer-events:auto; }
.mobile-menu a{ font-family:var(--sans); font-weight:600; font-size:1.5rem; padding:.55rem 0; border-bottom:1px solid var(--line-soft); color:var(--ink); }
.mobile-menu .btn{ margin-top:1.5rem; justify-content:center; }
.mobile-menu .mm-sub{ font-size:1.05rem; font-weight:500; padding:.4rem 0 .4rem 1.1rem; color:var(--viola); opacity:.85; }

/* Dropdown menu (Servizi) */
.nav-dd{ position:relative; display:inline-flex; align-items:center; }
.nav-dd>a{ display:inline-flex; align-items:center; gap:.3rem; }
.dd-caret{ font-size:.7rem; line-height:1; transition:transform .25s var(--ease); }
.nav-dd:hover .dd-caret, .nav-dd:focus-within .dd-caret{ transform:rotate(180deg); }
.nav-dd::after{ content:""; position:absolute; top:100%; left:0; right:0; height:14px; }
.nav-dd-menu{ position:absolute; top:calc(100% + 6px); left:0; min-width:230px; background:var(--bg); border:1px solid var(--line); border-radius:14px; box-shadow:0 14px 36px rgba(12,13,13,.12); padding:.4rem; display:flex; flex-direction:column; gap:.1rem; opacity:0; visibility:hidden; transform:translateY(6px); transition:.22s var(--ease); z-index:120; }
.nav-dd:hover .nav-dd-menu, .nav-dd:focus-within .nav-dd-menu{ opacity:1; visibility:visible; transform:none; }
.nav-dd-menu a{ font-size:.88rem; padding:.55rem .7rem; border-radius:8px; white-space:nowrap; }

/* Floating CTA (pulsing, every page) */
.float-cta{ position:fixed; right:clamp(14px,3vw,28px); bottom:clamp(14px,3vw,28px); z-index:200; display:inline-flex; align-items:center; gap:.5em; padding:.85em 1.4em; border-radius:999px; background:var(--grad); color:#fff; font-family:var(--sans); font-weight:700; font-size:.92rem; letter-spacing:-.01em; box-shadow:0 10px 30px rgba(68,52,139,.32); animation:floatPulse 2.2s var(--ease) infinite; transition:transform .25s var(--ease); }
.float-cta::before{ content:""; width:.55em; height:.55em; border-radius:50%; background:#fff; box-shadow:0 0 0 0 rgba(255,255,255,.7); animation:floatDot 2.2s var(--ease) infinite; }
.float-cta:hover{ transform:translateY(-2px) scale(1.03); }
@keyframes floatPulse{ 0%,100%{ box-shadow:0 10px 30px rgba(68,52,139,.30), 0 0 0 0 rgba(232,48,133,.45); } 50%{ box-shadow:0 10px 30px rgba(68,52,139,.30), 0 0 0 14px rgba(232,48,133,0); } }
@keyframes floatDot{ 0%,100%{ box-shadow:0 0 0 0 rgba(255,255,255,.6); } 50%{ box-shadow:0 0 0 6px rgba(255,255,255,0); } }
@media(max-width:600px){ .float-cta{ font-size:.85rem; padding:.75em 1.15em; } }
@media (prefers-reduced-motion: reduce){ .float-cta, .float-cta::before{ animation:none; } }

/* Hero */
.hero{ position:relative; padding-top:clamp(44px,6vw,84px); padding-bottom:clamp(36px,5vw,72px); overflow:hidden; }
.hero-eyebrow{ margin-bottom:1.5rem; }
.hero h1{ max-width:16ch; margin-bottom:1.6rem; }
.hero .lead{ max-width:56ch; margin-bottom:2.2rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:.75rem; }
.hero-bloom{ position:absolute; right:-6%; top:50%; transform:translateY(-50%); width:min(42vw,520px); opacity:.92; pointer-events:none; z-index:-1; }
@media(max-width:860px){ .hero-bloom{ opacity:.16; right:-20%; } }

/* Hero a due colonne + riquadro aree */
.hero-grid{ display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(1.8rem,4vw,3.4rem); align-items:center; }
.hero-areas{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-l); padding:1.4rem 1.5rem; box-shadow:0 24px 60px rgba(46,35,88,.10); }
.hero-areas h3{ font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--clay); font-weight:800; margin-bottom:.9rem; }
.hero-areas .a-row{ display:flex; align-items:center; gap:.85rem; padding:.62rem 0; border-top:1px solid var(--line-soft); }
.hero-areas .a-row:first-of-type{ border-top:0; }
.hero-areas .a-ic{ width:40px; height:40px; border-radius:10px; background:var(--grad-soft); display:grid; place-items:center; flex:0 0 auto; }
.hero-areas .a-ic img{ width:22px; height:22px; }
.a-tx{ display:flex; flex-direction:column; line-height:1.25; }
.hero-areas .a-t{ font-weight:700; font-size:.98rem; color:var(--ink); }
.hero-areas .a-d{ font-size:.8rem; color:var(--muted); }
.hero-areas .a-link{ display:inline-flex; margin-top:1rem; font-weight:700; color:var(--viola); font-size:.9rem; }
@media(max-width:860px){ .hero-grid{ grid-template-columns:1fr; } }

/* Sezione Aree di formazione */
.aree-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:2.6rem; }
@media(max-width:900px){ .aree-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .aree-grid{ grid-template-columns:1fr; } }
.area-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-l); padding:1.5rem; transition:transform .35s, box-shadow .35s; display:flex; flex-direction:column; }
.area-card:hover{ transform:translateY(-5px); box-shadow:0 24px 60px rgba(46,35,88,.12); }
.area-card .a-ic{ width:48px; height:48px; border-radius:12px; background:var(--grad-soft); display:grid; place-items:center; margin-bottom:.9rem; color:var(--viola); }
.area-card .a-ic img{ width:26px; height:26px; }
.area-card .a-ic svg{ width:26px; height:26px; }
.area-card h3{ font-size:1.1rem; font-weight:800; color:var(--viola); margin-bottom:.35rem; }
.area-card p{ color:var(--muted); font-size:.92rem; margin-bottom:1rem; }
.area-card .a-actions{ margin-top:auto; display:flex; flex-wrap:wrap; gap:.35rem 1.1rem; align-items:center; }
.area-card .a-actions a{ font-weight:700; font-size:.85rem; color:var(--viola); }
.area-card .a-actions a.cat{ color:var(--clay); }

/* Perché Ubloom */
.why{ background:var(--grad-soft); border-radius:var(--radius-l); padding:clamp(1.8rem,4vw,2.8rem); }
.why-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; margin-top:1.8rem; }
.why-item{ text-align:center; }
.why-item .wi{ width:50px; height:50px; border-radius:14px; background:#fff; display:grid; place-items:center; margin:0 auto .7rem; color:var(--viola); box-shadow:0 8px 20px rgba(46,35,88,.08); }
.why-item .wi svg{ width:24px; height:24px; }
.why-item h4{ font-weight:800; font-size:.98rem; color:var(--ink); }
.why-item p{ font-size:.82rem; color:var(--muted); margin-top:.2rem; }
@media(max-width:860px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px){ .why-grid{ grid-template-columns:1fr; } }

/* Trust strip (prova sociale) */
.trust{ border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); background:#fff; }
.trust-row{ display:flex; flex-wrap:wrap; gap:1rem 2.2rem; align-items:center; justify-content:center; padding:1.1rem 0; }
.trust-row .ti{ display:flex; align-items:center; gap:.5rem; font-size:.86rem; font-weight:600; color:var(--ink-soft); }
.trust-row .ti svg{ width:20px; height:20px; color:var(--clay); flex:0 0 auto; }

/* Lead magnet Check-up */
.checkup{ background:linear-gradient(135deg,#2E2358,#44348B); color:#fff; border-radius:var(--radius-l); padding:clamp(1.8rem,4vw,3rem); position:relative; overflow:hidden; }
.checkup::before{ content:""; position:absolute; top:-30%; right:-10%; width:40vw; height:40vw; max-width:480px; max-height:480px; background:var(--grad); filter:blur(90px); opacity:.4; border-radius:50%; }
.cu-in{ position:relative; z-index:1; max-width:680px; margin-inline:auto; }
.cu-head{ text-align:center; margin-bottom:1.6rem; }
.cu-head .eyebrow{ color:#F178B6; }
.cu-head h2{ color:#fff; margin:.4rem 0 .5rem; }
.cu-head p{ color:#C7C0DB; }
.cu-prog{ height:5px; border-radius:99px; background:rgba(255,255,255,.14); margin:0 auto 1.6rem; max-width:680px; overflow:hidden; }
.cu-prog>span{ display:block; height:100%; width:0; background:var(--grad); transition:width .4s; }
.cu-step{ display:none; } .cu-step.active{ display:block; }
.cu-q{ font-weight:700; font-size:1.18rem; text-align:center; margin-bottom:1.2rem; }
.cu-opts{ display:grid; gap:.7rem; }
.cu-opt{ background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.18); border-radius:12px; padding:1rem 1.1rem; color:#fff; font-family:inherit; font-size:.96rem; font-weight:600; cursor:pointer; text-align:left; transition:.2s; }
.cu-opt:hover{ border-color:#F178B6; background:rgba(255,255,255,.12); }
.cu-result{ text-align:center; }
.cu-result .badge{ display:inline-block; font-weight:800; letter-spacing:.05em; font-size:.78rem; text-transform:uppercase; padding:.4rem .9rem; border-radius:99px; background:rgba(88,143,203,.25); color:#A9C7EE; margin-bottom:1rem; }
.cu-result .num{ font-weight:800; font-size:clamp(2rem,5vw,2.8rem); background:linear-gradient(120deg,#F178B6,#A9C7EE); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1.1; }
.cu-result .sub{ color:#fff; font-weight:600; margin:.6rem 0 .3rem; }
.cu-result .fine{ color:#b9b2d6; font-size:.82rem; max-width:48ch; margin:.6rem auto 1.6rem; }
.cu-back{ background:none; border:0; color:#C7C0DB; cursor:pointer; font-family:inherit; font-size:.88rem; font-weight:600; margin-top:.4rem; }
.cu-back:hover{ color:#fff; }

/* ROI simulator */
.roi{ background:var(--grad-soft); border-radius:var(--radius-l); padding:clamp(1.6rem,3.5vw,2.6rem); }
.roi-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:1.8rem 2.4rem; align-items:center; }
.roi-control label{ font-weight:700; display:block; margin-bottom:.3rem; color:var(--ink); }
.roi-control .roi-val{ font-weight:800; color:var(--viola); font-size:1.7rem; line-height:1.1; margin-bottom:.6rem; }
.roi-control input[type=range]{ width:100%; accent-color:var(--viola); height:6px; }
.roi-out{ display:grid; gap:.7rem; }
.roi-out .r{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; border-bottom:1px solid var(--line); padding-bottom:.55rem; }
.roi-out .r:last-child{ border-bottom:0; }
.roi-out .r .k{ color:var(--muted); font-size:.9rem; }
.roi-out .r .v{ font-weight:800; font-size:1.15rem; color:var(--ink); white-space:nowrap; }
.roi-out .r.hl .v{ color:var(--clay); }
.roi-out .r.ret .v{ color:#1B8A5A; }
@media(max-width:760px){ .roi-grid{ grid-template-columns:1fr; } }

/* Team grid */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-top:2rem; }
@media(max-width:820px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
.team-card{ text-align:center; }
.team-card .ph{ width:100%; max-width:180px; aspect-ratio:1/1; margin:0 auto .8rem; border-radius:22px; background:var(--grad-soft); display:grid; place-items:center; color:var(--viola); overflow:hidden; box-shadow:0 10px 26px rgba(46,35,88,.10); }
.team-card .ph img{ width:100%; height:100%; object-fit:cover; }
.team-card .ph svg{ width:46px; height:46px; opacity:.45; }
.team-card .tn{ font-weight:800; font-size:1rem; color:var(--ink); }
.team-card .tr{ font-size:.85rem; color:var(--muted); }
.team-card .te{ font-size:.82rem; margin-top:.2rem; }
.team-card .te a{ color:var(--viola); text-decoration:none; font-weight:600; }
.team-card .te a:hover{ text-decoration:underline; }
.trust-bar{ margin-top:clamp(36px,5vw,64px); padding-top:1.6rem; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:.8rem 1.8rem; align-items:center; color:var(--muted); font-size:.86rem; font-weight:500; }
.trust-bar span{ display:inline-flex; align-items:center; gap:.5rem; }
.trust-bar span::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--grad); flex:none; }

/* Cards */
.card{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,2.4vw,2rem); transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s; display:flex; flex-direction:column; height:100%; }
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-m); border-color:var(--clay-soft); }
.card .num{ font-family:var(--sans); font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--clay); margin-bottom:1.1rem; }
.card h3{ margin-bottom:.6rem; }
.card p{ color:var(--muted); margin-bottom:1.2rem; }
.card .link-arrow{ margin-top:auto; }

/* Door cards */
.door{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius-l); padding:clamp(1.5rem,2.6vw,2.2rem); transition:transform .4s var(--ease), box-shadow .4s var(--ease); position:relative; overflow:hidden; }
.door::after{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.door:hover{ transform:translateY(-6px); box-shadow:var(--shadow-m); }
.door:hover::after{ transform:scaleX(1); }
.door .icon{ width:48px; height:48px; border-radius:13px; background:var(--grad-soft); color:var(--viola); display:grid; place-items:center; margin-bottom:1.4rem; }
.door .icon svg{ width:24px; height:24px; }

/* Problem */
.problem{ background:var(--plum); color:#E7E2F2; border-radius:var(--radius-l); padding:clamp(2rem,5vw,4.2rem); }
.problem .eyebrow{ color:var(--gold); }
.problem h2{ color:#fff; max-width:20ch; margin-bottom:2.3rem; }
.problem-items{ display:grid; gap:1.2rem; }
@media(min-width:760px){ .problem-items{grid-template-columns:repeat(3,1fr)} }
.problem-item{ padding-top:1.3rem; border-top:1px solid rgba(255,255,255,.18); }
.problem-item .n{ font-family:var(--sans); font-weight:800; font-size:1.5rem; color:var(--clay-soft); display:block; margin-bottom:.5rem; }
.problem-item p{ color:#C7C0DB; font-size:.96rem; }
.problem-note{ margin-top:2.6rem; font-size:1.12rem; color:#fff; max-width:60ch; }

/* Pillars */
.pillar{ position:relative; padding:clamp(1.5rem,2.4vw,2rem); border-radius:var(--radius); background:var(--bg-2); border:1px solid var(--line); overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease); display:flex; flex-direction:column; height:100%; }
.pillar:hover{ transform:translateY(-5px); box-shadow:var(--shadow-m); }
.pillar .idx{ font-family:var(--sans); font-weight:800; font-size:2.6rem; line-height:1; color:var(--clay-soft); margin-bottom:.9rem; }
.pillar .pico{ width:54px; height:54px; margin-bottom:1rem; }
.pillar .pico img{ width:100%; height:100%; object-fit:contain; }
.pillar h3{ margin-bottom:.5rem; }
.pillar p{ color:var(--muted); margin-bottom:1.2rem; font-size:.94rem; }
.pillar .link-arrow{ margin-top:auto; }

/* GrowPlan / dark gradient block */
.gp{ background:linear-gradient(135deg,#3A2A6B,var(--plum)); color:#E7E2F2; border-radius:var(--radius-l); padding:clamp(2rem,5vw,4.2rem); }
.gp .eyebrow{ color:var(--gold); }
.gp h2{ color:#fff; margin-bottom:1rem; }
.gp .lead{ color:#C7C0DB; max-width:56ch; margin-bottom:2.4rem; }
.gp-levers{ display:grid; gap:1rem; margin-bottom:2.4rem; }
@media(min-width:760px){ .gp-levers{grid-template-columns:repeat(3,1fr)} }
.gp-lever{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-s); padding:1.4rem; }
.gp-lever .k{ font-family:var(--sans); font-weight:700; font-size:1.1rem; color:#fff; margin-bottom:.3rem; display:block; }
.gp-lever span.v{ color:#B4ACCB; font-size:.9rem; }
.gp-actions{ display:flex; flex-wrap:wrap; gap:.75rem; }

/* Steps */
.steps{ display:grid; gap:1.1rem; }
@media(min-width:760px){ .steps.cols-3{grid-template-columns:repeat(3,1fr)} }
.step{ padding:1.7rem; border-radius:var(--radius); background:var(--bg-2); border:1px solid var(--line); }
.step .s-n{ width:38px; height:38px; border-radius:50%; background:var(--grad); color:#fff; font-family:var(--sans); font-weight:700; display:grid; place-items:center; margin-bottom:1.1rem; }
.step h3{ font-size:1.15rem; margin-bottom:.45rem; }
.step p{ color:var(--muted); font-size:.93rem; }

/* Stats */
.stats{ display:grid; gap:1.4rem 1rem; }
@media(min-width:620px){ .stats{grid-template-columns:repeat(3,1fr)} }
.stat .v{ font-family:var(--sans); font-weight:800; font-size:clamp(2.2rem,4.6vw,3.2rem); line-height:1; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .l{ color:var(--muted); font-size:.92rem; margin-top:.4rem; }

/* Split */
.split{ display:grid; gap:clamp(1.8rem,4vw,3.6rem); align-items:center; }
@media(min-width:880px){ .split{grid-template-columns:1.05fr 1fr} .split.rev>:first-child{order:2} }

/* Quote */
.quote{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.5rem,3vw,2.3rem); line-height:1.3; max-width:26ch; color:var(--viola); }
.quote .author{ display:block; font-family:var(--sans); font-style:normal; font-size:.88rem; font-weight:600; color:var(--muted); margin-top:1.3rem; letter-spacing:.02em; }

/* CTA band */
.cta-band{ background:var(--grad); color:#fff; border-radius:var(--radius-l); padding:clamp(2.2rem,5vw,4.2rem); text-align:center; }
.cta-band h2{ color:#fff; max-width:22ch; margin:0 auto 1.3rem; }
.cta-steps{ display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem 1.3rem; margin-bottom:2.2rem; color:rgba(255,255,255,.95); font-weight:500; font-size:.94rem; }
.cta-steps span{ display:inline-flex; align-items:center; gap:.5rem; }
.cta-steps span b{ width:24px; height:24px; border-radius:50%; background:rgba(255,255,255,.22); display:grid; place-items:center; font-weight:700; }

/* HR teaser */
.hr-teaser{ background:var(--sage); color:#fff; border-radius:var(--radius-l); padding:clamp(2rem,5vw,3.8rem); }
.hr-teaser .eyebrow{ color:#EAF1FB; }
.hr-teaser h2{ color:#fff; max-width:24ch; }
.hr-teaser p{ color:#EAF1FB; max-width:56ch; }

/* ACCA / generic light panel */
.acca{ border:1px solid var(--line); border-radius:var(--radius-l); padding:clamp(2rem,4vw,3.4rem); background:var(--bg-2); }
.acca-tags{ display:flex; flex-wrap:wrap; gap:.55rem; margin:1.4rem 0; }
.tag{ border:1px solid var(--line); border-radius:999px; padding:.4rem .9rem; font-size:.82rem; font-weight:600; color:var(--viola); background:#fff; }

/* Brand cards (I nostri brand) */
.brand-grid{ display:grid; gap:clamp(16px,2.2vw,24px); }
@media(min-width:820px){ .brand-grid{grid-template-columns:repeat(3,1fr)} }
.brand-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-l); padding:clamp(1.6rem,2.6vw,2.2rem); position:relative; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease); display:flex; flex-direction:column; height:100%; }
.brand-card::before{ content:""; position:absolute; inset:0 0 auto 0; height:5px; background:var(--grad); }
.brand-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-m); }
.brand-card .bc-name{ font-family:var(--sans); font-weight:800; font-size:1.4rem; color:var(--viola); margin:.4rem 0 .2rem; letter-spacing:-.01em; }
.brand-card .bc-tag{ font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--clay); }
.brand-card p{ color:var(--muted); margin:.8rem 0 1.3rem; font-size:.95rem; }
.brand-card .link-arrow{ margin-top:auto; }
.brand-card .bc-logo{ display:block; height:clamp(34px,4.4vw,44px); width:auto; margin:.5rem 0 .1rem; }
.brand-strip-ico{ height:26px; width:26px; vertical-align:-8px; margin-right:.55rem; }
.site-footer a.f-brand{ display:inline-flex; align-items:center; }
.f-brand-ico{ height:20px; width:20px; margin-right:.55rem; flex:0 0 auto; }

/* Gruppo */
.group-strip{ background:var(--grad); color:#fff; border-radius:var(--radius-l); padding:clamp(2rem,5vw,3.6rem); }
.group-strip .eyebrow{ color:rgba(255,255,255,.9); }
.group-strip h2{ color:#fff; max-width:24ch; margin:.8rem 0 1rem; }
.group-strip p{ color:rgba(255,255,255,.92); max-width:60ch; }
.group-logos{ display:flex; flex-wrap:wrap; align-items:center; gap:1.2rem 2.4rem; margin-top:1.8rem; }
.group-logos .gl{ font-family:var(--sans); font-weight:800; font-size:1.5rem; color:#fff; }
.group-logos img{ height:38px; width:auto; filter:brightness(0) invert(1); opacity:.95; }

/* Logo row (partner) */
.logo-row{ display:flex; flex-wrap:wrap; align-items:center; gap:1.4rem 2.6rem; }
.logo-row img{ height:34px; width:auto; opacity:.7; filter:grayscale(1); transition:opacity .3s, filter .3s; }
.logo-row img:hover{ opacity:1; filter:none; }

/* Footer */
.site-footer{ background:var(--plum); color:#C7C0DB; padding-block:clamp(3rem,6vw,4.6rem) 2rem; margin-top:var(--section); }
.footer-top{ display:grid; gap:2.4rem; padding-bottom:2.8rem; border-bottom:1px solid rgba(255,255,255,.14); }
@media(min-width:880px){ .footer-top{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr} }
.footer-brand .brand img{ height:30px; }
.footer-news h4{ color:#fff; font-family:var(--sans); font-weight:700; font-size:1.15rem; margin:.9rem 0 .6rem; }
.footer-news p{ font-size:.88rem; margin-bottom:1rem; }
.news-form{ display:flex; gap:.5rem; flex-wrap:wrap; }
.news-form input{ flex:1; min-width:180px; padding:.78rem 1rem; border-radius:999px; border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.07); color:#fff; }
.news-form input::placeholder{ color:#9089A8; }
.news-form button{ background:var(--clay); color:#fff; border-radius:999px; padding:.78rem 1.3rem; font-weight:600; border:none; transition:background .25s; }
.news-form button:hover{ background:var(--clay-deep); }
.footer-col h5{ color:#fff; font-size:.76rem; text-transform:uppercase; letter-spacing:.12em; font-family:var(--sans); font-weight:700; margin-bottom:.9rem; }
.footer-col a{ display:block; padding:.3rem 0; font-size:.9rem; color:#C7C0DB; transition:color .25s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; padding-top:2rem; font-size:.8rem; color:#9089A8; }
.hp{ position:absolute; left:-9999px; }

/* Reveal */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s }

/* Marquee */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:3rem; width:max-content; animation:scroll 32s linear infinite; align-items:center; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--sans); font-weight:600; font-size:1.05rem; color:var(--muted); white-space:nowrap; }
@keyframes scroll{ to{ transform:translateX(-50%) } }

/* Section heading */
.sec-head{ max-width:62ch; margin-bottom:clamp(1.8rem,4vw,3rem); }
.sec-head.center{ margin-inline:auto; }
.sec-head .eyebrow{ margin-bottom:1rem; }
.sec-head p{ color:var(--muted); margin-top:.9rem; }

/* Inner page hero */
.page-hero{ padding-top:clamp(38px,5vw,72px); padding-bottom:clamp(26px,4vw,44px); }
.page-hero h1{ max-width:18ch; margin:1.2rem 0 1.1rem; }
.page-hero .lead{ max-width:60ch; }
.breadcrumb{ font-size:.84rem; color:var(--muted); }
.breadcrumb a:hover{ color:var(--clay); }

/* Misc */
.divider{ height:1px; background:var(--line); border:0; }
.pill-note{ display:inline-block; background:var(--grad-soft); color:var(--viola); border-radius:999px; padding:.4rem 1rem; font-size:.8rem; font-weight:600; }
.muted{ color:var(--muted); }

/* FAQ */
.faq-item{ border-top:1px solid var(--line); }
.faq-item:last-child{ border-bottom:1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; padding:1.25rem 2.5rem 1.25rem 0; font-family:var(--sans); font-weight:600; font-size:1.1rem; position:relative; transition:color .25s; color:var(--ink); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; position:absolute; right:.2rem; top:50%; transform:translateY(-50%); font-size:1.5rem; color:var(--clay); transition:transform .3s var(--ease); }
.faq-item[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faq-item summary:hover{ color:var(--clay); }
.faq-item p{ color:var(--muted); padding:0 2.5rem 1.4rem 0; max-width:70ch; }

/* Pain table */
.pain-table{ width:100%; border-collapse:collapse; min-width:520px; }
.pain-table th{ text-align:left; font-family:var(--sans); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--clay); padding:0 1.2rem 1rem; font-weight:700; }
.pain-table td{ padding:1.05rem 1.2rem; border-top:1px solid var(--line); vertical-align:top; }
.pain-table tbody tr:hover{ background:var(--bg-2); }
.pain-table td:first-child{ font-weight:600; color:var(--ink); width:44%; }
.pain-table td:last-child{ color:var(--muted); }

/* Form */
.form-card{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--radius-l); padding:clamp(1.6rem,3vw,2.6rem); }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-size:.84rem; font-weight:600; margin-bottom:.4rem; color:var(--ink-soft); }
.field label .req{ color:var(--clay); }
.field input, .field select, .field textarea{ width:100%; padding:.82rem 1rem; border-radius:var(--radius-s); border:1px solid var(--line); background:#fff; color:var(--ink); font:inherit; font-size:.96rem; transition:border-color .25s, box-shadow .25s; }
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--viola); box-shadow:0 0 0 3px rgba(68,52,139,.14); }
.field-row{ display:grid; gap:1.1rem; }
@media(min-width:640px){ .field-row.two{grid-template-columns:1fr 1fr} }
.checkbox{ display:flex; gap:.6rem; align-items:flex-start; font-size:.9rem; color:var(--muted); margin-bottom:1rem; }
.checkbox input{ width:auto; margin-top:.2rem; flex:none; }
.checkbox a{ color:var(--clay); text-decoration:underline; }
.contact-info{ display:grid; gap:1.3rem; }
.contact-info .ci{ padding-bottom:1.1rem; border-bottom:1px solid var(--line); }
.contact-info .ci .k{ font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--clay); font-weight:700; margin-bottom:.3rem; }
.contact-info .ci a, .contact-info .ci span{ font-size:1.02rem; color:var(--ink); }

/* Blog */
.post-grid{ display:grid; gap:clamp(18px,2.4vw,28px); }
@media(min-width:760px){ .post-grid{grid-template-columns:repeat(3,1fr)} }
.post-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease); height:100%; }
.post-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-m); }
.post-card .pc-cover{ aspect-ratio:16/10; background:var(--grad); }
.post-card .pc-body{ padding:1.4rem; display:flex; flex-direction:column; flex:1; }
.post-card .pc-meta{ font-size:.76rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--clay); margin-bottom:.5rem; }
.post-card h3{ font-size:1.15rem; margin-bottom:.5rem; }
.post-card p{ color:var(--muted); font-size:.92rem; margin-bottom:1rem; }
.post-card .link-arrow{ margin-top:auto; }
.article{ max-width:720px; margin-inline:auto; }
.article p{ margin:1.1rem 0; color:var(--ink-soft); }
.article h2{ margin:2rem 0 .8rem; }
.article h3{ margin:1.6rem 0 .6rem; }
.newsletter-box{ background:var(--plum); color:#E7E2F2; border-radius:var(--radius-l); padding:clamp(1.8rem,4vw,3rem); }
.newsletter-box h3{ color:#fff; }
.newsletter-box .eyebrow{ color:var(--gold); }

/* ---------- Eventi ---------- */
.ev-hero{ background:var(--grad); color:#fff; border-radius:var(--radius-l); padding:clamp(2.2rem,5vw,4.2rem); }
.ev-hero .eyebrow{ color:rgba(255,255,255,.92); }
.ev-hero h1{ color:#fff; margin:1rem 0 .6rem; }
.ev-hero .lead{ color:rgba(255,255,255,.95); max-width:56ch; }
.ev-meta{ display:flex; flex-wrap:wrap; gap:.6rem 1.6rem; margin-top:1.4rem; font-weight:600; font-size:.95rem; }
.ev-meta span{ display:inline-flex; align-items:center; gap:.5rem; }
.posti-badge{ display:inline-flex; align-items:center; gap:.55rem; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.32); border-radius:999px; padding:.5rem 1.1rem; font-weight:700; font-size:.9rem; }
.ev-actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.timeline{ display:grid; }
.tl{ display:grid; grid-template-columns:130px 1fr; gap:1.2rem; padding:.85rem 0; border-top:1px solid var(--line); }
.tl .t{ font-family:var(--sans); font-weight:700; color:var(--viola); font-size:.92rem; }
.tl .d{ color:var(--ink-soft); }
.tl.sub{ background:var(--bg-2); border-top:1px solid var(--line-soft); }
.tl.sub .t{ color:var(--clay); padding-left:1rem; }
.tl.magic .d{ font-family:var(--serif); font-style:italic; color:var(--clay); }
.collab{ display:flex; flex-wrap:wrap; align-items:center; gap:.8rem 1.6rem; color:var(--muted); font-weight:600; }
.collab .nm{ color:var(--ink); }
