*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;--off-white:#fafaf8;--gray-50:#f5f5f3;--gray-100:#ededeb;--gray-200:#e0e0dc;--gray-300:#c8c8c4;--gray-400:#9e9e98;--gray-500:#787874;--gray-600:#5c5c58;--gray-800:#1a1a18;--black:#0f1c33;--navy:#0f1c33;
  --teal:#009d91;--teal-light:#00c4b6;--teal-pale:rgba(0,157,145,.06);
  --font-h:'Syne',sans-serif;--font-b:'Figtree',sans-serif;
  --mw:860px;--ease:cubic-bezier(.4,0,.2,1);--eout:cubic-bezier(0,0,.2,1);
  --red:#EF4444;--orange:#F97316;--yellow:#EAB308;--green:#22C55E;--blue:#3B82F6;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);background:var(--white);color:var(--gray-800);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6;padding-top:64px}
a{text-decoration:none;color:inherit}
::selection{background:var(--teal);color:var(--white)}

/* ── Navbar ── */
.sidemenu{position:fixed;top:0;left:0;right:0;height:64px;background:#0f1c33;z-index:300;display:flex;align-items:center;padding:0 clamp(20px,3vw,40px);gap:12px}
.sidemenu__logo{font-family:var(--font-h);font-size:.68rem;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:#fff;margin-right:auto;flex-shrink:0}
.btn-home-nav{font-family:var(--font-b);font-size:.78rem;font-weight:500;color:rgba(255,255,255,.7);border:1.5px solid rgba(255,255,255,.2);background:transparent;padding:7px 20px;border-radius:980px;cursor:pointer;transition:all .25s;flex-shrink:0}
.btn-home-nav:hover{border-color:var(--teal-light);color:var(--teal-light)}
.lang-wrap{display:flex;gap:6px;flex-shrink:0;border-left:1px solid rgba(255,255,255,.08);padding-left:12px}
.lang-btn{font-size:.8rem;font-weight:700;letter-spacing:.1em;padding:5px 12px;border-radius:20px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.7);cursor:pointer;transition:all .3s;font-family:var(--font-b)}
.lang-btn.active,.lang-btn:hover{border-color:var(--teal);color:var(--teal);background:rgba(0,157,145,.1)}

/* ── Views ── */
.view{display:none}
.view.active{display:block}
.container{max-width:var(--mw);margin:0 auto;padding:2rem 1.5rem}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-b);font-size:.88rem;font-weight:600;background:var(--teal);color:var(--white);padding:16px 36px;border-radius:980px;border:none;cursor:pointer;transition:background .25s,transform .2s,box-shadow .3s}
.btn-primary:hover{background:var(--teal-light);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,157,145,.35)}
.btn-block{width:100%;justify-content:center;border-radius:12px}
.btn-secondary{display:inline-flex;align-items:center;gap:.375rem;background:none;border:1.5px solid var(--gray-200);border-radius:980px;padding:10px 24px;font-family:var(--font-b);font-size:.875rem;font-weight:500;color:var(--gray-600);cursor:pointer;transition:border-color .15s,color .15s}
.btn-secondary:hover:not(:disabled){border-color:var(--gray-400);color:var(--gray-800)}
.btn-secondary:disabled{opacity:.35;cursor:not-allowed}
.btn-success{display:inline-flex;align-items:center;gap:.5rem;background:#16a34a;color:white;border:none;border-radius:980px;padding:14px 32px;font-family:var(--font-b);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}
.btn-success:hover{background:#15803d}
.btn-ghost{display:flex;align-items:center;gap:.5rem;background:none;border:1.5px solid var(--gray-200);border-radius:980px;padding:10px 24px;font-family:var(--font-b);font-size:.875rem;font-weight:500;color:var(--gray-600);cursor:pointer;transition:border-color .15s;margin:0 auto;width:fit-content}
.btn-ghost:hover{border-color:var(--gray-400)}
.btn-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--teal);color:white;border:none;border-radius:980px;padding:14px 32px;font-family:var(--font-b);font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s,transform .2s}
.btn-cta:hover{background:var(--teal-light);transform:translateY(-2px)}

/* ── Benefits ── */
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.5rem}
.benefit-card{background:var(--white);border:1px solid var(--gray-100);border-radius:14px;padding:1.5rem;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.benefit-card:hover{transform:translateY(-4px);border-color:var(--teal);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.benefit-icon{width:40px;height:40px;background:var(--teal-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--teal)}
.benefit-icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5}
.benefit-title{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--black);margin-bottom:.375rem}
.benefit-text{font-size:.78rem;color:var(--gray-500);line-height:1.65;font-weight:300}
.trust-strip{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;font-size:.72rem;color:var(--gray-400);font-weight:300;padding:.75rem 0}
.trust-strip span{display:flex;align-items:center;gap:.375rem}
@media(max-width:600px){.benefit-grid{grid-template-columns:1fr}}

/* ── Category toast ── */
.cat-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:var(--navy);border:1px solid rgba(0,196,182,.3);border-radius:16px;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;z-index:500;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;box-shadow:0 8px 32px rgba(0,0,0,.2);min-width:260px}
.cat-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}
.cat-toast__icon{width:36px;height:36px;border-radius:50%;background:rgba(0,196,182,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal-light)}
.cat-toast__title{font-family:var(--font-h);font-size:.85rem;font-weight:700;color:#fff;margin-bottom:.1rem}
.cat-toast__score{font-size:.75rem;color:rgba(255,255,255,.5);font-weight:300}

/* ── Live category chips ── */
.cat-chips{display:flex;gap:.5rem;flex-wrap:wrap;padding:.75rem 2rem .25rem;background:var(--white)}
.cat-chip{display:inline-flex;align-items:center;gap:.375rem;font-size:.65rem;font-weight:600;padding:.25rem .625rem;border-radius:20px;border:1px solid var(--gray-200);color:var(--gray-400);font-family:var(--font-h);transition:all .3s}
.cat-chip.done{border-color:var(--teal);color:var(--teal);background:var(--teal-pale)}
.cat-chip__dot{width:5px;height:5px;border-radius:50%;background:currentColor}

/* ── Progress milestones ── */
.progress-milestones{position:relative;height:8px;margin-bottom:.5rem}
.progress-track-wrap{position:relative;width:100%;height:4px;background:var(--gray-100);border-radius:2px;overflow:visible}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-light));border-radius:2px;transition:width .3s ease;width:0%}
.milestone-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--gray-200);border:2px solid var(--white);transition:background .3s}
.milestone-dot.passed{background:var(--teal)}

/* ── Hero ── */
.vhero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(80px,12vw,140px) clamp(24px,6vw,80px) clamp(60px,8vw,100px);position:relative;overflow:hidden;background:#0a1628}
.vhero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.10) 1px,transparent 1px);background-size:40px 40px;animation:gridDrift 22s linear infinite;pointer-events:none;z-index:0}
@keyframes gridDrift{from{background-position:0 0}to{background-position:40px 40px}}
.vhero__glow{position:absolute;bottom:-140px;right:-100px;width:700px;height:700px;background:radial-gradient(circle,rgba(0,196,182,.15) 0%,transparent 62%);pointer-events:none;z-index:1}
.vhero__badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-b);font-size:.63rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-light);border:1px solid rgba(0,196,182,.28);background:rgba(0,196,182,.07);padding:7px 20px;border-radius:40px;margin-bottom:32px;position:relative;z-index:2;opacity:0;animation:heroReveal .8s var(--eout) .1s forwards}
.vhero__title{font-family:var(--font-h);font-size:clamp(3rem,7vw,5.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:#fff;max-width:700px;margin:0 auto 8px;position:relative;z-index:2;opacity:0;animation:heroReveal 1s var(--eout) .28s forwards}
.vhero__sub-label{font-family:var(--font-b);font-size:clamp(.9rem,1.4vw,1.05rem);font-weight:600;color:var(--teal-light);margin-bottom:20px;position:relative;z-index:2;opacity:0;animation:heroReveal .9s var(--eout) .38s forwards}
.vhero__sub{font-size:clamp(.88rem,1.4vw,1rem);font-weight:300;color:rgba(255,255,255,.52);max-width:540px;margin:0 auto 40px;line-height:1.8;position:relative;z-index:2;opacity:0;animation:heroReveal 1s var(--eout) .46s forwards}
.vhero__cta{position:relative;z-index:2;opacity:0;animation:heroReveal 1s var(--eout) .56s forwards}
.vhero__meta{font-family:var(--font-b);font-size:.72rem;color:rgba(255,255,255,.3);margin-top:16px;position:relative;z-index:2;opacity:0;animation:heroReveal 1s var(--eout) .66s forwards}
@keyframes heroReveal{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* ── Sections ── */
.vsec{padding:clamp(56px,7vw,96px) clamp(24px,6vw,80px);max-width:var(--mw);margin:0 auto}
.vsec__num{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:10px;display:block}
.vsec__title{font-family:var(--font-h);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;letter-spacing:-.025em;color:var(--black);margin-bottom:10px}
.vsec__lead{font-size:.95rem;font-weight:300;color:var(--gray-500);max-width:520px;line-height:1.7;margin-bottom:40px}
.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.category-card{background:var(--white);border:1px solid var(--gray-100);border-radius:14px;padding:clamp(18px,2.4vw,26px);text-align:center;transition:transform .35s var(--ease),box-shadow .35s,border-color .3s}
.category-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.06);border-color:var(--teal)}
.cat-letter{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-weight:700;font-size:1.1rem;color:white;margin:0 auto .875rem;background:var(--teal)}
.category-card h3{font-family:var(--font-h);font-size:.88rem;font-weight:700;color:var(--black);margin-bottom:.2rem}
.category-card p{font-size:.75rem;color:var(--gray-400);font-weight:300}
.landing-tagline{text-align:center;font-size:.85rem;color:var(--teal);font-weight:600;padding:0 0 3rem}

/* ── Lead form ── */
.lead-card{background:var(--white);border:1px solid var(--gray-100);border-radius:16px;padding:clamp(28px,4vw,40px);box-shadow:0 2px 24px rgba(0,0,0,.05);max-width:500px;margin:3rem auto}
.lead-card h2{font-family:var(--font-h);font-size:1.75rem;font-weight:700;color:var(--black);margin-bottom:.5rem}
.lead-card .lead-sub{font-size:.9rem;font-weight:300;color:var(--gray-500);margin-bottom:2rem;line-height:1.7}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-600);margin-bottom:.375rem}
.form-group input{width:100%;padding:.75rem 1rem;border:1.5px solid var(--gray-200);border-radius:10px;font-size:.9rem;font-family:var(--font-b);color:var(--gray-800);outline:none;transition:border-color .15s;background:var(--white)}
.form-group input:focus{border-color:var(--teal)}
.form-group input::placeholder{color:var(--gray-300)}
.form-group select{width:100%;padding:.75rem 1rem;border:1.5px solid var(--gray-200);border-radius:10px;font-size:.9rem;font-family:var(--font-b);color:var(--gray-800);background:var(--white);outline:none;transition:border-color .15s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239e9e98' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.form-group select:focus{border-color:var(--teal)}
.form-privacy{font-size:.75rem;color:var(--gray-400);text-align:center;margin-top:1rem;line-height:1.5;font-weight:300}
.privacy-box{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:10px;padding:1rem 1.1rem;margin-bottom:1.25rem;font-size:.72rem;color:var(--gray-500);line-height:1.65;font-weight:300}
.privacy-box strong{color:var(--gray-600);font-weight:600}
.privacy-box a{color:var(--teal);text-decoration:underline}
.privacy-toggle{background:none;border:none;font-size:.72rem;color:var(--teal);cursor:pointer;padding:0;font-family:var(--font-b);display:block;margin:0 auto .75rem;text-decoration:underline}
.privacy-details{display:none;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--gray-200)}
.form-check{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:1rem}
.form-check input[type=checkbox]{width:16px;height:16px;min-width:16px;margin-top:.15rem;accent-color:var(--teal);cursor:pointer}
.form-check label{font-size:.78rem;color:var(--gray-600);line-height:1.55;cursor:pointer}
.form-check label a{color:var(--teal);text-decoration:underline}
.form-check label span.req{color:var(--red);margin-left:2px}

/* ── Product CTA ── */
.product-card{border-radius:16px;padding:2rem;margin-bottom:1.5rem;border:2px solid}
.product-card--workshop{background:#fff7ed;border-color:#fed7aa;color:#7c2d12}
.product-card--sprint{background:#fefce8;border-color:#fde68a;color:#713f12}
.product-card--consulting{background:#0f1c33;border-color:#009d91;color:#ffffff}
.product-badge{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:.3rem .75rem;border-radius:100px;margin-bottom:1rem}
.product-badge--workshop{background:#fff7ed;color:#c2410c}
.product-badge--sprint{background:#fefce8;color:#854d0e}
.product-badge--consulting{background:#f0fdf4;color:#166534}
.product-cta-footer{margin-top:.6rem;font-size:.72rem;color:#6b7280;text-align:center}
.product-cta-email-link{color:#009d91;text-decoration:underline;cursor:pointer}
.product-name{font-family:var(--font-h);font-size:1.4rem;font-weight:800;margin-bottom:.75rem}
.product-desc{font-size:.9rem;line-height:1.7;margin-bottom:1.25rem;opacity:.85;font-weight:300}
.product-meta{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.product-meta-item{font-size:.8rem}
.product-meta-label{opacity:.6;display:block;margin-bottom:.15rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}
.product-meta-value{font-weight:600}

/* ── Assessment ── */
.progress-wrap{background:var(--white);border-bottom:1px solid var(--gray-100);padding:1rem 2rem}
.progress-track{width:100%;height:4px;background:var(--gray-100);border-radius:2px;overflow:hidden;margin-bottom:.5rem}
.progress-meta{display:flex;justify-content:space-between;font-size:.72rem;color:var(--gray-400);font-weight:300}
.results-banner{display:none;background:#f0fdf4;border-top:2px solid #22c55e;padding:1rem 2rem;text-align:center}
.results-banner.visible{display:block}
.question-card{background:var(--white);border:1px solid var(--gray-100);border-radius:16px;padding:clamp(24px,3vw,36px);box-shadow:0 2px 24px rgba(0,0,0,.05)}
.q-badge{display:inline-flex;align-items:center;padding:.35rem .875rem;border-radius:100px;font-family:var(--font-h);font-size:.72rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}
.q-number{font-size:.72rem;color:var(--gray-400);margin-bottom:.875rem;font-weight:300}
.q-text{font-family:var(--font-h);font-size:1.1rem;font-weight:600;color:var(--black);line-height:1.55;margin-bottom:1.5rem}
.levels-label{font-size:.78rem;color:var(--gray-500);margin-bottom:.75rem;font-weight:300}
.level-options{display:flex;flex-direction:column;gap:.5rem}
.level-option{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;border:1.5px solid var(--gray-200);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;background:var(--white)}
.level-option:hover{border-color:var(--lc,var(--teal));background:var(--lbg,#f0fafa)}
.level-option.sel{border-color:var(--lc,var(--teal));background:var(--lbg,#f0fafa)}
.level-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--gray-500);background:var(--gray-100);flex-shrink:0}
.level-option.sel .level-dot{background:var(--teal);color:white}
.level-text{font-size:.875rem;color:var(--gray-500);flex:1;line-height:1.4;font-weight:300}
.level-option.sel .level-text{color:var(--gray-800);font-weight:500}
.level-check{flex-shrink:0;opacity:0;color:#22c55e}
.level-option.sel .level-check{opacity:1}
.q-nav{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem}

/* ── Generating ── */
.generating-wrap{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center;padding:2rem}
.spinner{width:48px;height:48px;border:3px solid rgba(0,157,145,.15);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.gen-title{font-family:var(--font-h);font-size:1.4rem;font-weight:700;color:var(--black)}
.gen-sub{font-size:.9rem;color:var(--gray-500);max-width:360px;line-height:1.7;font-weight:300}

/* ── AI Disclaimer ── */
.ai-disclaimer{display:flex;align-items:flex-start;gap:.625rem;background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:1rem 1.25rem;margin:1.5rem 0;font-size:.78rem;color:#92400e;line-height:1.6;font-weight:400}
.ai-disclaimer svg{flex-shrink:0;margin-top:.15rem;stroke:#d97706}

/* ── Results ── */
.results-header{text-align:center;padding:3rem 1.5rem 1.5rem}
.results-header h1{font-family:var(--font-h);font-size:2rem;font-weight:700;color:var(--black);margin-bottom:.375rem}
.results-header p{font-size:.9rem;color:var(--gray-500);font-weight:300}
.score-card{background:var(--white);border-radius:16px;padding:1.75rem;box-shadow:0 2px 24px rgba(0,0,0,.05);border:2px solid var(--gray-200);margin-bottom:1.5rem}
.score-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.score-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gray-400);margin-bottom:.25rem}
.score-name{font-family:var(--font-h);font-size:1.25rem;font-weight:700}
.score-right{display:flex;align-items:baseline;gap:.2rem}
.score-num{font-family:var(--font-h);font-size:3.2rem;font-weight:800;line-height:1}
.score-den{font-size:1.25rem;color:var(--gray-400)}
.score-tagline{font-style:italic;color:var(--gray-500);font-size:.9rem;margin-bottom:.5rem;font-weight:300}
.score-desc{color:var(--gray-600);font-size:.9rem;line-height:1.7;font-weight:300}
.section-card{background:var(--white);border:1px solid var(--gray-100);border-radius:16px;padding:1.75rem;box-shadow:0 2px 24px rgba(0,0,0,.05);margin-bottom:1.5rem}
.section-card h2{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--black);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-100)}
.bar-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}
.bar-label{font-size:.875rem;font-weight:500;color:var(--gray-600);min-width:110px}
.bar-track{flex:1;height:16px;background:var(--gray-50);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width .6s ease}
.bar-value{font-size:.875rem;font-weight:600;min-width:36px;text-align:right}
.sg-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.sg-card{border-radius:12px;padding:1.25rem}
.sg-card.str{background:#f0fdf4;border:1px solid #bbf7d0}
.sg-card.gap{background:#fef2f2;border:1px solid #fecaca}
.sg-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.375rem}
.sg-card.str .sg-label{color:#16a34a}
.sg-card.gap .sg-label{color:#dc2626}
.sg-value{font-family:var(--font-h);font-size:1rem;font-weight:700}
#sg-str{color:#15803d}
#sg-gap{color:#b91c1c}
.exec-summary{background:rgba(0,157,145,.06);border-left:3px solid var(--teal);border-radius:0 12px 12px 0;padding:1.25rem 1.5rem;font-size:.95rem;color:var(--black);line-height:1.8;font-weight:300}
.priority-cards{display:flex;flex-direction:column;gap:1rem}
.priority-card{border:1.5px solid var(--gray-100);border-radius:12px;padding:1.25rem;transition:border-color .3s}
.priority-card:hover{border-color:var(--teal)}
.p-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--teal);color:white;border-radius:50%;font-size:.75rem;font-weight:700;margin-bottom:.75rem}
.p-title{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--black);margin-bottom:.625rem}
.p-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-400);margin-bottom:.2rem}
.p-detail{font-size:.875rem;color:var(--gray-500);line-height:1.7;margin-bottom:.625rem;font-weight:300}
.p-detail:last-child{margin-bottom:0}
.roadmap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.roadmap-phase{border:1.5px solid var(--gray-100);border-radius:12px;padding:1.25rem}
.rp-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:.2rem}
.rp-theme{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--black);margin-bottom:.875rem}
.rp-actions{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.rp-actions li{font-size:.8rem;color:var(--gray-500);line-height:1.5;font-weight:300;padding-left:1rem;position:relative}
.rp-actions li::before{content:'';position:absolute;left:0;top:.5em;width:5px;height:5px;background:var(--teal);border-radius:50%}
.hikari-cta{background:var(--navy);border-radius:16px;padding:2rem;color:white;text-align:center;margin-bottom:1.5rem}
.hikari-cta h2{font-family:var(--font-h);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}
.hikari-cta .hc-intro{font-size:.9rem;opacity:.7;max-width:460px;margin:0 auto 1.5rem;line-height:1.7;font-weight:300}
.hikari-services{display:flex;flex-direction:column;gap:.625rem;text-align:left;margin-bottom:1.75rem}
.hs-item{display:flex;align-items:flex-start;gap:.75rem;background:rgba(255,255,255,.06);border-radius:10px;padding:.875rem 1rem}
.hs-name{font-family:var(--font-h);font-size:.875rem;font-weight:700;color:var(--teal-light);margin-bottom:.2rem}
.hs-rel{font-size:.8rem;opacity:.65;line-height:1.5;font-weight:300}
.hc-link{font-size:.78rem;opacity:.4;margin-top:.875rem;display:block}
.hc-link a{color:white;text-decoration:underline}
.ai-loading{font-size:.875rem;color:var(--gray-400);font-style:italic;text-align:center;padding:1.5rem 0;font-weight:300}
.ai-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem;font-size:.875rem;color:#b91c1c;line-height:1.5}

/* ── Footer ── */
.footer{background:#0f1c33;border-top:1px solid rgba(255,255,255,.04);padding:24px clamp(24px,6vw,80px)}
.footer__inner{max-width:var(--mw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer__copy{font-size:.68rem;color:rgba(255,255,255,.15)}

/* ── Scroll reveal ── */
.rv{opacity:0;transform:translateY(32px);transition:opacity .8s var(--eout),transform .8s var(--eout)}
.rv.on{opacity:1;transform:none}

@media(max-width:600px){
  .vhero__title{font-size:2.5rem}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .roadmap-grid{grid-template-columns:1fr}
  .sg-grid{grid-template-columns:1fr}
  .question-card{padding:1.25rem}
  .progress-wrap{padding:1rem}
  .lead-card{margin:1.5rem 1rem;padding:1.75rem}
  .sidemenu{overflow-x:auto}
}
.btn-pdf{display:flex;align-items:center;gap:.5rem;background:var(--teal);color:white;border:none;border-radius:980px;padding:11px 28px;font-family:var(--font-b);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s,transform .2s;margin:0 auto 1rem;width:fit-content}
.btn-pdf:hover{background:var(--teal-light);transform:translateY(-1px)}
@media print{
  body{padding-top:0!important}
  .sidemenu,.lang-switcher,.btn-ghost,.btn-pdf,.results-banner,.hikari-cta,#product-cta,.footer,#view-landing,#view-assessment,#view-generating,.cat-chips,.cat-toast{display:none!important}
  #view-results{display:block!important}
  .view{display:block!important}
  .section-card{box-shadow:none!important;border:1px solid #e5e7eb!important;break-inside:avoid;margin-bottom:1rem}
  .score-card{break-inside:avoid}
  .roadmap-grid{grid-template-columns:1fr!important}
  .roadmap-phase{break-inside:avoid;margin-bottom:.75rem}
  a{color:inherit!important;text-decoration:none!important}
  .print-footer{display:block!important}
}
.print-footer{display:none;text-align:center;font-size:.75rem;color:#9ca3af;margin-top:2rem;padding-top:1rem;border-top:1px solid #e5e7eb}

/* ── LANGUAGE TOGGLE — CSS-based, no inline styles needed ── */
body:not(.lang-en) .en { display: none; }
body.lang-en .it { display: none; }

/* ── Initially hidden elements (JS-controlled) ── */
#btn-home { display: none; }
#altro-settore-wrap { display: none; }
#privacy-full { display: none; margin-top: .5rem; }
#hikari-services-block { display: none; }
.hp-field { display: none; }

/* ── Benefits section hero title overrides ── */
.vsec__title--hero { font-size: clamp(2rem,4.5vw,3.2rem); line-height: 1.15; margin-bottom: 16px; }
.vsec__lead--hero { font-size: 1.1rem; color: var(--gray-400); max-width: 600px; margin-bottom: 32px; }

/* ── MAIA brand label in footer ── */
#maia-brand { font-family: var(--font-h); font-size: .8rem; font-weight: 600; letter-spacing: .35em; text-transform: uppercase; color: rgba(255,255,255,.2); }

/* ── Trust strip separator ── */
.trust-sep { color: var(--gray-200); }

/* ── Background utility ── */
.bg-gray-50 { background: var(--gray-50); }

/* ── Hikari Solutions brand labels in footers ── */
#hikari-brand-landing, #hikari-brand-assessment { font-family: var(--font-h); font-size: .8rem; font-weight: 600; letter-spacing: .35em; text-transform: uppercase; color: rgba(255,255,255,.2); }

/* ── Privacy toggle wrapper ── */
.privacy-toggle-wrap { margin-bottom: 1.25rem; }

/* ── Milestone dot positions (6 categories) ── */
#ms-1 { left: 16.67%; }
#ms-2 { left: 33.33%; }
#ms-3 { left: 50%; }
#ms-4 { left: 66.67%; }
#ms-5 { left: 83.33%; }

/* ── Progress meta top margin ── */
.progress-meta { margin-top: .5rem; }

/* ── Results banner button ── */
#btn-view-results { font-size: 1rem; padding: .75rem 2rem; }

/* ── Spacer ── */
.spacer-3 { height: 3rem; }

/* ── Email toast ── */
#email-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px); background: #0f1c33; color: #fff; padding: .75rem 1.5rem; border-radius: 12px; font-size: .82rem; font-weight: 500; opacity: 0; pointer-events: none; transition: opacity .3s, transform .3s; z-index: 9999; border: 1px solid rgba(0,196,182,.3); }
#email-toast.visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ── Come funziona — 3 steps ── */
.maia-steps-sec { padding-bottom: 0; }
.maia-steps { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 28px; }
.maia-step { display: flex; align-items: center; gap: 14px; background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 18px 22px; flex: 1; min-width: 200px; }
.maia-step__num { font-family: var(--font-h); font-size: 1.6rem; font-weight: 800; color: var(--teal); line-height: 1; flex-shrink: 0; }
.maia-step__title { font-size: .88rem; font-weight: 600; color: var(--black); line-height: 1.4; }
.maia-step__follow { font-size: .78rem; font-weight: 500; color: var(--teal); display: block; margin-top: 2px; }
.maia-step__time { font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gray-400); margin-top: 5px; }
.maia-step__arrow { font-size: 1.2rem; color: var(--gray-300); flex-shrink: 0; }
@media (max-width: 600px) {
  .maia-steps { flex-direction: column; align-items: stretch; }
  .maia-step__arrow { transform: rotate(90deg); align-self: center; }
}
