/* ── Reset & Base ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0e0b08;--surface:rgba(255,255,255,0.04);--surface-solid:#16120d;
  --border:rgba(255,255,255,0.08);--border-hover:rgba(255,255,255,0.15);
  --text:#f0ece6;--muted:#8a8070;--accent:#f5b942;--accent-dim:#c98f20;
  --accent-green:#5ddf7a;--orange:#f97316;
  --green:#4caf50;--yellow:#f5c842;--red:#e05252;
  --font-display:'Outfit',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --radius:12px;--radius-lg:20px;--max-w:1100px;--max-w-narrow:680px;
  --glass-bg:rgba(20,15,9,0.7);--glass-border:rgba(255,255,255,0.08);
  --glass-blur:blur(24px);
}
html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;min-height:100vh;overflow-x:hidden;position:relative}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:#c4ff7a}

/* ── Animated Background ──────────────────────────────────────────────────── */
.orb{position:fixed;border-radius:50%;filter:blur(80px);opacity:.35;pointer-events:none;z-index:0;transition:transform .3s ease-out}
.orb--1{width:540px;height:540px;background:radial-gradient(circle,var(--accent),transparent 70%);top:-12%;left:-8%;animation:orbDrift1 18s ease-in-out infinite alternate}
.orb--2{width:420px;height:420px;background:radial-gradient(circle,var(--orange),transparent 70%);bottom:5%;right:-10%;animation:orbDrift2 22s ease-in-out infinite alternate}
.orb--3{width:360px;height:360px;background:radial-gradient(circle,#c2410c,transparent 70%);top:45%;left:38%;animation:orbDrift3 20s ease-in-out infinite alternate}
@keyframes orbDrift1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(60px,80px) scale(1.15)}}
@keyframes orbDrift2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-50px,-60px) scale(1.1)}}
@keyframes orbDrift3{0%{transform:translate(0,0) scale(.9)}100%{transform:translate(40px,-50px) scale(1.05)}}

/* ── Scroll Animations ────────────────────────────────────────────────────── */
[data-animate]{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
[data-animate].is-visible{opacity:1;transform:translateY(0)}

/* ── Layout ───────────────────────────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px;position:relative;z-index:1}
.container--narrow{max-width:var(--max-w-narrow)}

/* ── Glass Card ───────────────────────────────────────────────────────────── */
.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}

/* ── Nav ──────────────────────────────────────────────────────────────────── */
.nav{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(14,11,8,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:100}
.nav__logo{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text);letter-spacing:-.5px}
.nav__logo-accent{color:var(--accent)}
.nav__lang{display:flex;gap:8px;align-items:center;font-size:.875rem;color:var(--muted)}
.nav__lang a{color:var(--muted);transition:color .2s}
.nav__lang-active{color:var(--text)!important;font-weight:600}
.nav--scorecard{flex-direction:column;gap:12px;padding-bottom:0}

/* ── Progress Bar (thin, for scorecard) ───────────────────────────────────── */
.nav__progress-wrap{width:100%;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.nav__progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--orange));transition:width .5s cubic-bezier(.16,1,.3,1);border-radius:2px;box-shadow:0 0 12px rgba(245,185,66,.4)}

/* ── Segmented Progress ───────────────────────────────────────────────────── */
.progress-segments{display:flex;align-items:center;gap:0;width:100%;padding:8px 0 4px;position:relative}
.progress-segments__step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.progress-segments__dot{width:10px;height:10px;border-radius:50%;background:var(--border);border:2px solid var(--border);transition:all .4s;position:relative;z-index:2}
.progress-segments__dot--done{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px rgba(245,185,66,.3)}
.progress-segments__dot--active{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px rgba(245,185,66,.6);animation:dotPulse 2s ease-in-out infinite}
.progress-segments__label{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;transition:color .3s}
.progress-segments__dot--active+.progress-segments__label,.progress-segments__dot--done+.progress-segments__label{color:var(--text)}
.progress-segments__step:not(:last-child)::after{content:'';position:absolute;top:5px;left:calc(50% + 8px);width:calc(100% - 16px);height:2px;background:var(--border);z-index:1}
.progress-segments__step.step--done:not(:last-child)::after{background:var(--accent)}
@keyframes dotPulse{0%,100%{box-shadow:0 0 12px rgba(245,185,66,.6)}50%{box-shadow:0 0 20px rgba(249,115,22,.9)}}

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.hero{padding:120px 0 100px;text-align:center;position:relative}
.hero__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:100px;background:rgba(245,185,66,.1);border:1px solid rgba(245,185,66,.25);font-size:.8125rem;color:var(--accent);margin-bottom:28px;font-weight:500}
.hero__badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:badgePulse 2s ease-in-out infinite}
@keyframes badgePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
.hero__headline{font-family:var(--font-display);font-size:clamp(2.2rem,5.5vw,3.8rem);font-weight:700;letter-spacing:-1.5px;line-height:1.1;margin-bottom:24px;background:linear-gradient(135deg,var(--text) 0%,#fff 35%,var(--accent) 75%,var(--orange) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero__sub{font-size:1.125rem;color:var(--muted);max-width:580px;margin:0 auto 40px;line-height:1.7}
.hero__trust{font-size:.8125rem;color:var(--muted);margin-top:16px}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn{display:inline-block;padding:15px 32px;border-radius:var(--radius);font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:all .25s cubic-bezier(.16,1,.3,1);font-family:var(--font-body);position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .3s;pointer-events:none}
.btn:hover{transform:translateY(-2px);text-decoration:none}
.btn:active{transform:translateY(0)}
.btn--primary{background:linear-gradient(135deg,var(--accent),var(--orange));color:#0e0b08;box-shadow:0 4px 20px rgba(245,185,66,.3)}
.btn--primary:hover{box-shadow:0 8px 32px rgba(249,115,22,.4);color:#0e0b08}
.btn--primary::after{background:linear-gradient(135deg,transparent,rgba(255,255,255,.2))}
.btn--primary:hover::after{opacity:1}
.btn--secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}
.btn--secondary:hover{border-color:var(--border-hover);background:rgba(255,255,255,0.06);color:var(--text)}
.btn--full{display:block;width:100%;text-align:center}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn__arrow{display:inline-block;transition:transform .3s;margin-left:4px}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* ── Sections ─────────────────────────────────────────────────────────────── */
.section{padding:100px 0;position:relative}
.section--alt{background:rgba(255,255,255,0.02)}
.section--cta{text-align:center}
.section__title{font-family:var(--font-display);font-size:2.1rem;font-weight:700;margin-bottom:24px;letter-spacing:-.5px;line-height:1.2}
.section__body{color:var(--muted);margin-bottom:16px;font-size:1.0625rem;line-height:1.7}

/* ── Problem List ─────────────────────────────────────────────────────────── */
.problem-list{list-style:none;display:flex;flex-direction:column;gap:16px}
.problem-list li{padding:22px 24px;border-left:3px solid;border-image:linear-gradient(to bottom,var(--accent),var(--violet)) 1;background:var(--surface);border-radius:0 var(--radius) var(--radius) 0;font-size:1rem;color:var(--muted);line-height:1.7;transition:all .3s}
.problem-list li:hover{background:rgba(255,255,255,0.06);transform:translateX(4px)}
.problem-list em{color:var(--text);font-style:normal;font-weight:600}
.problem-list__icon{margin-right:10px;font-size:1.1rem}

/* ── Dimension Cards (landing mock) ───────────────────────────────────────── */
.dimensions{display:flex;flex-direction:column;gap:10px;margin:40px 0 16px}
.dimension-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:all .3s}
.dimension-card:hover{border-color:var(--border-hover);background:rgba(255,255,255,0.06)}
.dimension-card__label{flex:0 0 180px;font-size:.875rem;font-weight:500}
.dimension-card__track{flex:1;height:8px;border-radius:4px;background:var(--border);overflow:hidden;position:relative}
.dimension-card__bar{height:100%;border-radius:4px;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.dimension-card--green .dimension-card__bar{background:linear-gradient(90deg,var(--green),#6ee7b7)}
.dimension-card--yellow .dimension-card__bar{background:linear-gradient(90deg,var(--yellow),#fbbf24)}
.dimension-card--red .dimension-card__bar{background:linear-gradient(90deg,var(--red),#f87171)}
.dimension-card__pct{font-size:.8rem;font-weight:600;color:var(--muted);min-width:36px;text-align:right}
.dimensions__caption{font-size:.8125rem;color:var(--muted);text-align:center;margin-top:8px}

/* ── Steps ────────────────────────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;margin-top:48px}
.step{padding:32px 28px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);transition:all .4s}
.step:hover{border-color:rgba(163,245,66,.2);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.step__num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--orange));color:#0e0b08;font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:20px;box-shadow:0 4px 16px rgba(245,185,66,.25)}
.step__title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:10px}
.step__body{color:var(--muted);font-size:.9375rem;line-height:1.6}

/* ── Credential ───────────────────────────────────────────────────────────── */
.credential{display:flex;align-items:center;gap:16px;margin-top:32px;padding:18px 22px;border:1px solid rgba(245,200,66,.25);border-radius:var(--radius);font-size:.875rem;flex-wrap:wrap;background:rgba(245,200,66,.04);transition:all .3s}
.credential:hover{border-color:rgba(245,200,66,.4);background:rgba(245,200,66,.08)}
.credential__icon{font-size:1.2rem}
.credential__text{color:var(--muted)}
.credential__link{color:var(--yellow);font-weight:600;white-space:nowrap}

/* ── Footer ───────────────────────────────────────────────────────────────── */
.footer{text-align:center;padding:48px 24px;border-top:1px solid var(--border);color:var(--muted);font-size:.875rem;position:relative}
.footer::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:200px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--orange),transparent)}
.footer a{color:var(--muted);transition:color .2s}
.footer a:hover{color:var(--accent)}

/* ── Scorecard Layout ─────────────────────────────────────────────────────── */
.body--scorecard{background:var(--bg)}
.scorecard-wrap{display:flex;justify-content:center;align-items:flex-start;padding:48px 24px 80px;min-height:calc(100vh - 80px)}
.scorecard-card{width:100%;max-width:620px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:44px;position:relative;overflow:hidden;animation:cardIn .6s cubic-bezier(.16,1,.3,1)}
.scorecard-card::before{content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(245,185,66,.18),transparent 40%,transparent 60%,rgba(249,115,22,.12));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
@keyframes cardIn{0%{opacity:0;transform:translateY(20px) scale(.98)}100%{opacity:1;transform:translateY(0) scale(1)}}

/* ── Intro / Email Capture ────────────────────────────────────────────────── */
.scorecard-intro__pre{font-size:.875rem;color:var(--accent);margin-bottom:8px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}
.scorecard-intro__title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin-bottom:20px;line-height:1.2;letter-spacing:-.3px}
.scorecard-intro__body{color:var(--muted);margin-bottom:12px;line-height:1.7}
.email-form{margin-top:32px;display:flex;flex-direction:column;gap:22px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.875rem;font-weight:500;color:var(--text)}
.form-input{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);font-size:1rem;font-family:var(--font-body);transition:all .25s}
.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,185,66,.12);background:rgba(255,255,255,0.06)}
.form-input::placeholder{color:var(--muted)}
.form-hint{font-size:.8125rem;color:var(--muted);display:flex;align-items:center;gap:6px}
.form-hint__icon{color:var(--accent)}
.form-textarea{width:100%;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);font-size:1rem;font-family:var(--font-body);resize:vertical;min-height:120px;margin-bottom:20px;transition:all .25s}
.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(245,185,66,.12)}

/* ── Question View ────────────────────────────────────────────────────────── */
.scorecard-meta{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.scorecard-meta__dimension{font-size:.8125rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}
.scorecard-meta__followup{font-size:.75rem;color:var(--orange);border:1px solid rgba(249,115,22,.3);padding:3px 10px;border-radius:20px;background:rgba(249,115,22,.08)}
.scorecard-question{font-family:var(--font-display);font-size:1.4rem;font-weight:600;line-height:1.4;margin-bottom:32px;letter-spacing:-.2px}

/* ── Multiple Choice Options ──────────────────────────────────────────────── */
.options{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.option{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1)}
.option:hover{border-color:rgba(245,185,66,.35);background:rgba(245,185,66,.04);transform:translateX(4px)}
.option input[type="radio"]{display:none}
.option input[type="radio"]:checked~.option__key{background:linear-gradient(135deg,var(--accent),var(--orange));color:#0e0b08;border-color:var(--accent);box-shadow:0 0 12px rgba(245,185,66,.3)}
.option input[type="radio"]:checked~*{color:var(--text)}
.option:has(input:checked){border-color:var(--accent);background:rgba(245,185,66,.05)}
.option--pop{animation:optionPop .3s cubic-bezier(.16,1,.3,1)}
@keyframes optionPop{0%{transform:scale(.97)}50%{transform:scale(1.02)}100%{transform:scale(1)}}
.option__key{flex-shrink:0;width:30px;height:30px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;color:var(--muted);transition:all .25s;font-family:var(--font-display)}
.option__text{font-size:.9375rem;color:var(--muted);line-height:1.5;padding-top:4px}
.option__shortcut{margin-left:auto;font-size:.7rem;color:rgba(255,255,255,.15);padding-top:6px;font-family:var(--font-display)}

/* ── Results: Hero Score Ring ─────────────────────────────────────────────── */
.scorecard-card--results{max-width:680px}
.result-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:36px;padding-top:8px}
.score-ring{position:relative;width:140px;height:140px;margin-bottom:16px}
.score-ring__svg{width:100%;height:100%;transform:rotate(-90deg)}
.score-ring__track{fill:none;stroke:var(--border);stroke-width:6}
.score-ring__fill{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1.4s cubic-bezier(.16,1,.3,1)}
.score-ring__fill--s,.score-ring__fill--a{stroke:var(--green)}
.score-ring__fill--b{stroke:var(--accent)}
.score-ring__fill--c{stroke:var(--yellow)}
.score-ring__fill--d{stroke:var(--red)}
.score-ring__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.score-ring__value{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:-1px}
.score-ring__max{font-size:.75rem;color:var(--muted);margin-top:-2px}
.result-hero__label{display:flex;align-items:center;gap:10px}
.result-hero__band{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;font-family:var(--font-display);font-weight:700;font-size:1rem}
.result-hero__band--s,.result-hero__band--a{background:rgba(76,175,80,.15);color:var(--green);border:1px solid rgba(76,175,80,.3)}
.result-hero__band--b{background:rgba(245,185,66,.12);color:var(--accent);border:1px solid rgba(245,185,66,.25)}
.result-hero__band--c{background:rgba(245,200,66,.1);color:var(--yellow);border:1px solid rgba(245,200,66,.2)}
.result-hero__band--d{background:rgba(224,82,82,.1);color:var(--red);border:1px solid rgba(224,82,82,.2)}
.result-hero__band-name{font-family:var(--font-display);font-size:1.1rem;font-weight:600}

/* ── Results: Journey Path ───────────────────────────────────────────────── */
.journey{margin-bottom:36px}
.journey__title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:20px;letter-spacing:-.2px;color:var(--muted)}
.journey__path{display:flex;flex-direction:column;gap:0}
.journey__step{display:flex;gap:16px;align-items:stretch}
.journey__connector{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0;padding-top:18px}
.journey__dot{width:12px;height:12px;border-radius:50%;background:var(--border);border:2px solid var(--border);flex-shrink:0;position:relative;z-index:2;transition:all .4s}
.journey__step--strong .journey__dot{background:var(--green);border-color:var(--green);box-shadow:0 0 8px rgba(76,175,80,.3)}
.journey__step--good .journey__dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px rgba(245,185,66,.3)}
.journey__step--developing .journey__dot{background:var(--yellow);border-color:var(--yellow);box-shadow:0 0 8px rgba(245,200,66,.3)}
.journey__step--critical .journey__dot{background:var(--red);border-color:var(--red);box-shadow:0 0 8px rgba(224,82,82,.3)}
.journey__step--focus .journey__dot{width:14px;height:14px;animation:dotPulse 2s ease-in-out infinite}
.journey__line{flex:1;width:2px;background:var(--border);margin:4px 0}
.journey__card{flex:1;padding:16px 20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:12px;display:flex;align-items:center;gap:16px;transition:all .3s}
.journey__card:hover{border-color:var(--border-hover)}
.journey__card--focus{background:rgba(224,82,82,.04);border-color:rgba(224,82,82,.2);padding:20px 22px}
.journey__step--developing .journey__card--focus{background:rgba(245,200,66,.04);border-color:rgba(245,200,66,.2)}
.journey__card-header{flex:1;display:flex;flex-direction:column;gap:4px}
.journey__dim-name{font-family:var(--font-display);font-weight:600;font-size:.95rem}
.journey__card--focus .journey__dim-name{font-size:1.05rem}
.journey__tier{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:20px;align-self:flex-start}
.journey__tier--strong{color:var(--green);background:rgba(76,175,80,.12);border:1px solid rgba(76,175,80,.25)}
.journey__tier--good{color:var(--accent);background:rgba(245,185,66,.1);border:1px solid rgba(245,185,66,.2)}
.journey__tier--developing{color:var(--yellow);background:rgba(245,200,66,.1);border:1px solid rgba(245,200,66,.2)}
.journey__tier--critical{color:var(--red);background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.25)}
.journey__score-wrap{position:relative;width:52px;height:52px;flex-shrink:0}
.journey__card--focus .journey__score-wrap{width:64px;height:64px}
.journey__mini-ring{width:100%;height:100%;transform:rotate(-90deg)}
.journey__mini-track{fill:none;stroke:var(--border);stroke-width:4}
.journey__mini-fill{fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset 1.2s cubic-bezier(.16,1,.3,1)}
.journey__mini-fill--strong{stroke:var(--green)}
.journey__mini-fill--good{stroke:var(--accent)}
.journey__mini-fill--developing{stroke:var(--yellow)}
.journey__mini-fill--critical{stroke:var(--red)}
.journey__score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.8rem;color:var(--text)}
.journey__card--focus .journey__score-num{font-size:.95rem}
.journey__focus-label{font-size:.75rem;color:var(--red);font-weight:500;margin-top:6px;animation:fadeSlideIn .8s ease-out .6s both}
.journey__step--developing .journey__focus-label{color:var(--yellow)}
@keyframes fadeSlideIn{0%{opacity:0;transform:translateX(-8px)}100%{opacity:1;transform:translateX(0)}}

/* ── Recommendation Cards ────────────────────────────────────────────────── */
.recommendations{margin-bottom:32px}
.recommendations__title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-bottom:16px;letter-spacing:-.2px}
.recommendation-card{padding:22px 24px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-bottom:12px;transition:all .3s;position:relative;overflow:hidden}
.recommendation-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}
.recommendation-card--critical::before{background:linear-gradient(to bottom,var(--red),var(--orange))}
.recommendation-card--developing::before{background:linear-gradient(to bottom,var(--yellow),var(--accent))}
.recommendation-card:hover{border-color:var(--border-hover);transform:translateX(4px)}
.recommendation-card__eyebrow{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.recommendation-card__dimension{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}
.recommendation-card__tier{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:20px}
.recommendation-card__tier--critical{color:var(--red);background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.2)}
.recommendation-card__tier--developing{color:var(--yellow);background:rgba(245,200,66,.08);border:1px solid rgba(245,200,66,.18)}
.recommendation-card__title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;margin-bottom:8px;line-height:1.3;letter-spacing:-.1px}
.recommendation-card__body{color:var(--muted);font-size:.9rem;line-height:1.65;margin-bottom:12px}
.recommendation-card__tool{display:inline-flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--muted);font-weight:500}
.recommendation-card__tool-icon{font-size:.75rem;opacity:.7}

/* ── No Recommendations (congratulations) ────────────────────────────────── */
.result-congrats{padding:22px 24px;border-radius:var(--radius);background:rgba(76,175,80,.06);border:1px solid rgba(76,175,80,.2);margin-bottom:32px;font-size:.9375rem;color:var(--muted);line-height:1.6}
.result-congrats__icon{margin-right:8px}

/* ── Route Preview Card ──────────────────────────────────────────────────── */
.route-card{padding:24px 28px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);margin-bottom:20px;position:relative;overflow:hidden}
.route-card::before{content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(245,185,66,.12),transparent 50%,transparent 70%,rgba(249,115,22,.08));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.route-card__eyebrow{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:10px}
.route-card__title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:6px;letter-spacing:-.2px}
.route-card__desc{font-size:.875rem;color:var(--muted);margin-bottom:16px;line-height:1.6}
.route-card__tools{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.route-card__tool-item{display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:500}
.route-card__tool-arrow{color:var(--accent);font-size:.8rem}
.route-card__teaser{font-size:.8125rem;color:var(--muted);font-style:italic;padding-left:22px}

/* ── Email Nudge ─────────────────────────────────────────────────────────── */
.email-nudge{padding:22px 24px;border-radius:var(--radius);background:rgba(245,185,66,.04);border:1px solid rgba(245,185,66,.15);margin-bottom:24px;display:flex;align-items:flex-start;gap:14px}
.email-nudge__icon{font-size:1.5rem;flex-shrink:0;line-height:1}
.email-nudge__text{font-size:.9375rem;color:var(--muted);line-height:1.6}
.email-nudge__strong{color:var(--text);font-weight:500}

/* ── Processing State ─────────────────────────────────────────────────────── */
.processing{text-align:center;padding:48px 0}
.processing__rings{position:relative;width:64px;height:64px;margin:0 auto 32px}
.processing__ring{position:absolute;inset:0;border:3px solid transparent;border-radius:50%}
.processing__ring:nth-child(1){border-top-color:var(--accent);animation:spin .9s linear infinite}
.processing__ring:nth-child(2){inset:6px;border-right-color:var(--orange);animation:spin 1.4s linear infinite reverse}
.processing__ring:nth-child(3){inset:12px;border-bottom-color:var(--accent-dim);animation:spin 1.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.processing__title{font-family:var(--font-display);font-size:1.375rem;font-weight:600;margin-bottom:12px}
.processing__body{color:var(--muted)}
.processing__dots{display:inline-flex;gap:4px;margin-left:4px}
.processing__dots span{width:4px;height:4px;border-radius:50%;background:var(--muted);animation:dotBounce 1.4s ease-in-out infinite}
.processing__dots span:nth-child(2){animation-delay:.2s}
.processing__dots span:nth-child(3){animation-delay:.4s}
@keyframes dotBounce{0%,80%,100%{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}

/* ── Confetti ─────────────────────────────────────────────────────────────── */
#confetti-container{position:fixed;top:50%;left:50%;pointer-events:none;z-index:1000}
.confetti-particle{position:absolute;width:8px;height:8px;border-radius:2px;animation:confettiFall var(--d) cubic-bezier(.16,1,.3,1) forwards}
@keyframes confettiFall{0%{transform:translate(0,0) rotate(0);opacity:1}100%{transform:translate(var(--x),var(--y)) rotate(var(--r));opacity:0}}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media(max-width:640px){
  .scorecard-card{padding:28px 20px}
  .hero{padding:80px 0 60px}
  .section{padding:64px 0}
  .section__title{font-size:1.5rem}
  .dimension-card__label{flex:0 0 120px}
  .nav{padding:16px 20px}
  .hero__headline{font-size:clamp(1.8rem,6vw,2.5rem)}
  .step{padding:24px 20px}
  .orb{opacity:.2}
  .progress-segments__label{font-size:.5rem}
  .option__shortcut{display:none}
  .score-ring{width:120px;height:120px}
  .score-ring__value{font-size:1.6rem}
  .journey__card{padding:14px 16px;gap:12px}
  .journey__card--focus{padding:16px 18px}
  .journey__score-wrap{width:44px;height:44px}
  .journey__card--focus .journey__score-wrap{width:52px;height:52px}
  .recommendation-card{padding:18px 20px}
  .route-card{padding:20px 22px}
}
