*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy-950:#0f172a;--navy-900:#0f172a;--navy-800:#1e293b;--navy-700:#334155;--navy-600:#475569;
  --navy-500:#64748b;--navy-400:#94a3b8;--navy-300:#cbd5e1;--navy-200:#e2e8f0;--navy-100:#f1f5f9;
  --emerald-600:#059669;--emerald-500:#10b981;--emerald-400:#34d399;
  --green-600:#16a34a;--green-500:#22c55e;--green-400:#4ade80;
  --blue-600:#2563eb;--blue-500:#3b82f6;--blue-400:#60a5fa;--blue-300:#93c5fd;
  --amber-500:#f59e0b;--amber-400:#fbbf24;--amber-300:#fcd34d;
  --red-600:#dc2626;--red-500:#ef4444;--red-400:#f87171;
  --purple-600:#9333ea;--purple-500:#a855f7;--purple-400:#c084fc;--purple-300:#d8b4fe;
  --orange-500:#f97316;--orange-400:#fb923c;
  --cyan-500:#06b6d4;--cyan-400:#22d3ee;
  --font:Inter,system-ui,-apple-system,sans-serif;
  --radius:12px;--radius-lg:16px;--radius-xl:24px;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--navy-950);color:var(--navy-100);min-height:100vh;overflow-x:hidden;line-height:1.6}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 25% 10%,rgba(16,185,129,.08) 0%,transparent 50%),radial-gradient(ellipse at 75% 90%,rgba(34,197,94,.06) 0%,transparent 50%);pointer-events:none;z-index:0}

/* HERO */
.hero{position:relative;padding:4rem 2rem 3rem;text-align:center;z-index:1;max-width:800px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;border-radius:999px;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);color:var(--emerald-400);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--emerald-400);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:800;line-height:1.15;background:linear-gradient(135deg,#fff 0%,var(--emerald-400) 50%,var(--green-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}
.hero>p{font-size:1.05rem;color:var(--navy-400);max-width:620px;margin:0 auto 2rem;line-height:1.7}
.hero-stats{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-stat{text-align:center}
.hero-stat .val{font-size:1.6rem;font-weight:700;color:var(--emerald-400)}
.hero-stat .label{font-size:.72rem;color:var(--navy-500);text-transform:uppercase;letter-spacing:.06em}
.hero-insight{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.12);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin:0 auto 2rem;max-width:600px;display:flex;gap:.75rem;align-items:flex-start;text-align:left}
.hero-insight .insight-icon{font-size:1.2rem;margin-top:.1rem}
.hero-insight p{font-size:.88rem;color:var(--navy-300);line-height:1.6}
.hero-insight strong{color:var(--emerald-400)}
.hero-trust{display:flex;justify-content:center;gap:1.5rem;margin-top:1.25rem;font-size:.78rem;color:var(--navy-500);flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;border-radius:var(--radius);font-family:var(--font);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all .3s ease;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--emerald-500),var(--green-500));color:#fff;box-shadow:0 4px 15px rgba(16,185,129,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(16,185,129,.4)}
.btn-secondary{background:rgba(255,255,255,.05);color:var(--navy-200);border:1px solid rgba(255,255,255,.1)}
.btn-secondary:hover{background:rgba(255,255,255,.1)}
.btn-sm{padding:0.5rem 1rem;font-size:0.85rem;}

/* PROGRESS */
.progress-container{position:sticky;top:0;z-index:100;background:linear-gradient(top, 135deg, #1e293b 0%, #0f172a 100%);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.06);padding:1rem 2rem}
.progress-inner{max-width:800px;margin:0 auto}
.progress-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;color:var(--navy-400)}
.progress-meta .pillar-name{color:var(--emerald-400);font-weight:600}
.progress-track{width:100%;height:5px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--emerald-600),var(--emerald-400),var(--green-400));border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.pillar-steps{display:flex;justify-content:center;gap:2px;margin-top:.5rem}
.pillar-step{height:3px;flex:1;border-radius:99px;background:rgba(255,255,255,.06);transition:background .3s}
.pillar-step.active{background:var(--emerald-500)}
.pillar-step.done{background:var(--green-500)}

/* ASSESSMENT */
.assessment{max-width:800px;margin:0 auto;padding:2rem;position:relative;z-index:1}
.question-card{background:rgba(30,41,59,.5);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-xl);padding:2.5rem;backdrop-filter:blur(10px);animation:card-in .45s ease}
@keyframes card-in{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.pillar-tag{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:.3rem .8rem;border-radius:999px;margin-bottom:1rem}
.pillar-tag.leadership{background:rgba(245,158,11,.1);color:var(--amber-400);border:1px solid rgba(245,158,11,.18)}
.pillar-tag.culture{background:rgba(168,85,247,.1);color:var(--purple-400);border:1px solid rgba(168,85,247,.18)}
.pillar-tag.capability{background:rgba(59,130,246,.1);color:var(--blue-400);border:1px solid rgba(59,130,246,.18)}
.pillar-tag.structure{background:rgba(6,182,212,.1);color:var(--cyan-400);border:1px solid rgba(6,182,212,.18)}
.question-card h2{font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:.4rem;line-height:1.3}
.question-card .context{font-size:.88rem;color:var(--navy-400);margin-bottom:1.5rem;line-height:1.6}

/* INSIGHT BOX */
.insight-box{display:flex;gap:.6rem;padding:.9rem 1rem;border-radius:var(--radius);background:rgba(16,185,129,.04);border:1px solid rgba(16,185,129,.1);margin-bottom:1.5rem;align-items:flex-start}
.insight-box .ib-icon{font-size:.9rem;margin-top:.1rem}
.insight-box .ib-text{font-size:.8rem;color:var(--navy-300);line-height:1.5}
.insight-box .ib-source{font-size:.68rem;color:var(--navy-500);font-style:italic;margin-top:.2rem;display:block}

/* OPTIONS */
.options{display:flex;flex-direction:column;gap:.6rem}
.option{display:flex;align-items:flex-start;gap:.9rem;padding:.9rem 1.1rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.015);cursor:pointer;transition:all .22s ease}
.option:hover{border-color:rgba(16,185,129,.25);background:rgba(16,185,129,.04)}
.option.selected{border-color:var(--emerald-500);background:rgba(16,185,129,.08);box-shadow:inset 0 0 0 1px rgba(16,185,129,.3)}
.option input{display:none}
.option .radio{width:18px;height:18px;min-width:18px;border-radius:50%;border:2px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;transition:all .22s;margin-top:2px}
.option.selected .radio{border-color:var(--emerald-500);background:var(--emerald-500)}
.option.selected .radio::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}
.option .opt-label{font-size:.92rem;font-weight:500;color:var(--navy-100)}
.option .opt-desc{font-size:.78rem;color:var(--navy-500);margin-top:.15rem;line-height:1.45}
.nav-buttons{display:flex;justify-content:space-between;margin-top:2rem;gap:1rem}
.nav-buttons .btn{min-width:130px;justify-content:center}

/* PART 2: STAKEHOLDER MAPPING */
#mapping-container { display: none; }
.mapping-layout{display:grid;grid-template-columns:300px 1fr;gap:2rem;max-width:1100px;margin:0 auto;padding:2rem;}
.mapping-sidebar{background:rgba(30,41,59,.5);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:1.5rem;backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:1.5rem;height:fit-content;}
.mapping-sidebar h3{font-size:1.1rem;font-weight:700;color:#fff;}

.add-stakeholder-form{display:flex;flex-direction:column;gap:1rem;}
.form-group{display:flex;flex-direction:column;gap:0.4rem;}
.form-group label{font-size:0.8rem;color:var(--navy-300);font-weight:600;}
.form-group input, .form-group select{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:0.75rem;color:#fff;font-family:var(--font);font-size:0.9rem;}
.form-group input:focus, .form-group select:focus{outline:none;border-color:var(--emerald-400);}
.form-group select option{background:var(--navy-900);color:#fff;}

.stakeholder-list{display:flex;flex-direction:column;gap:0.5rem;}
.stakeholder-item{display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);padding:0.75rem;border-radius:8px;}
.sh-info{display:flex;flex-direction:column;}
.sh-name{font-size:0.9rem;font-weight:600;color:#fff;}
.sh-role{font-size:0.75rem;color:var(--navy-400);}
.sh-actions button{background:none;border:none;color:var(--red-400);cursor:pointer;padding:0.2rem;opacity:0.6;transition:opacity 0.2s;}
.sh-actions button:hover{opacity:1;}

.matrix-container{background:rgba(30,41,59,.5);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;}
.matrix-container h2{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:0.5rem;}
.matrix-container p{color:var(--navy-400);font-size:0.95rem;margin-bottom:2rem;text-align:center;}

.grid-wrapper{position:relative;width:100%;max-width:600px;aspect-ratio:1;margin:0 auto;}
/* Axis Labels */
.axis-label{position:absolute;font-size:0.85rem;font-weight:600;color:var(--navy-300);text-transform:uppercase;letter-spacing:0.1em;}
.axis-y{top:50%;left:-40px;transform:translateY(-50%) rotate(-90deg);}
.axis-x{bottom:-35px;left:50%;transform:translateX(-50%);}
.axis-label-high-y{position:absolute;top:-25px;left:-25px;font-size:0.75rem;color:var(--navy-500);}
.axis-label-low-y{position:absolute;bottom:-25px;left:-25px;font-size:0.75rem;color:var(--navy-500);}
.axis-label-high-x{position:absolute;bottom:-25px;right:-25px;font-size:0.75rem;color:var(--navy-500);}
.axis-label-low-x{position:absolute;bottom:-25px;left:-10px;font-size:0.75rem;color:var(--navy-500);}

.grid-2x2{width:100%;height:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);position:relative;}

/* Quadrants */
.quadrant{position:relative;background:var(--navy-900);display:flex;flex-direction:column;padding:1rem;}
.q-tl{background:rgba(30,41,59,.6);} /* Keep Satisfied */
.q-tr{background:rgba(16,185,129,.06);} /* Manage Closely */
.q-bl{background:rgba(30,41,59,.3);} /* Monitor */
.q-br{background:rgba(59,130,246,.06);} /* Keep Informed */

.q-label{position:absolute;font-size:0.9rem;font-weight:700;opacity:0.3;text-transform:uppercase;pointer-events:none;color:#fff;}
.q-tl .q-label{top:1rem;left:1rem;color:var(--amber-400);}
.q-tr .q-label{top:1rem;right:1rem;color:var(--emerald-400);}
.q-bl .q-label{bottom:1rem;left:1rem;color:var(--navy-400);}
.q-br .q-label{bottom:1rem;right:1rem;color:var(--blue-400);}

/* Plot Points */
.plot-point{position:absolute;width:24px;height:24px;background:var(--emerald-500);border:2px solid #fff;border-radius:50%;transform:translate(-50%, -50%);cursor:pointer;box-shadow:0 4px 10px rgba(0,0,0,0.3);transition:all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);z-index:10;}
.plot-point:hover{transform:translate(-50%, -50%) scale(1.2);z-index:20;}
.plot-point .tooltip{position:absolute;bottom:120%;left:50%;transform:translateX(-50%);background:var(--navy-800);border:1px solid rgba(255,255,255,.1);padding:0.5rem 0.75rem;border-radius:6px;font-size:0.75rem;color:#fff;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 0.2s;}
.plot-point:hover .tooltip{opacity:1;}
.plot-point .tooltip .tt-role{color:var(--navy-400);font-size:0.7rem;display:block;margin-top:0.2rem;}

.continue-btn-container{margin-top:3rem;text-align:center;width:100%;}

/* RESULTS */
.results-container{display:none;z-index:1;position:relative}
.results-container.active{display:block}
.results-hero{text-align:center;padding:3rem 2rem 1.5rem;max-width:700px;margin:0 auto}
.results-hero h1{font-size:2rem;font-weight:800;color:#fff;margin-bottom:.4rem}
.results-hero>p{color:var(--navy-400);font-size:.95rem}
.score-ring-container{display:flex;justify-content:center;margin:1.5rem 0}
.score-ring{position:relative;width:180px;height:180px}
.score-ring svg{transform:rotate(-90deg)}
.score-ring .track{fill:none;stroke:rgba(255,255,255,.06);stroke-width:7}
.score-ring .fill-ring{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset 1.5s ease}
.score-ring .score-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.score-ring .score-number{font-size:2.8rem;font-weight:800;color:#fff}
.score-ring .score-label{font-size:.72rem;color:var(--navy-400);text-transform:uppercase;letter-spacing:.08em}
.severity-badge{display:inline-flex;padding:.45rem 1.25rem;border-radius:999px;font-weight:700;font-size:.92rem;margin:.8rem 0}
.severity-low{background:rgba(220,38,38,.2);color:#fca5a5;border:1px solid rgba(220,38,38,.4)}
.severity-moderate{background:rgba(245,158,11,.12);color:var(--amber-400);border:1px solid rgba(245,158,11,.25)}
.severity-high{background:rgba(34,197,94,.12);color:var(--green-400);border:1px solid rgba(34,197,94,.25)}

.results-grid{max-width:1000px;margin:0 auto;padding:0 2rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.result-card{background:rgba(30,41,59,.45);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:1.5rem;backdrop-filter:blur(10px)}
.result-card.full{grid-column:1/-1}
.result-card h3{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:.9rem;display:flex;align-items:center;gap:.45rem}

/* Result Grid Override */
.result-matrix-container{display:flex;gap:2rem;align-items:center;justify-content:center;margin-top:1rem;}
@media(max-width:800px) { .result-matrix-container{flex-direction:column;} }

.sh-action-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;}
.sh-action-category{background:rgba(255,255,255,.03);border-radius:8px;padding:1rem;border-left:3px solid transparent;}
.sh-action-category.manage-closely{border-left-color:var(--emerald-400);}
.sh-action-category.keep-satisfied{border-left-color:var(--amber-400);}
.sh-action-category.keep-informed{border-left-color:var(--blue-400);}
.sh-action-category.monitor{border-left-color:var(--navy-400);}
.sh-cat-title{font-size:0.9rem;font-weight:700;color:#fff;margin-bottom:0.5rem;}
.sh-cat-desc{font-size:0.8rem;color:var(--navy-400);margin-bottom:0.8rem;}
.sh-tags{display:flex;flex-wrap:wrap;gap:0.4rem;}
.sh-tag{font-size:0.75rem;padding:0.2rem 0.6rem;background:rgba(255,255,255,.08);color:#fff;border-radius:999px;}

/* CTA Section */
.cta-section{text-align:center;padding:2.5rem 2rem;max-width:700px;margin:0 auto}
.cta-section h2{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.cta-section p{color:var(--navy-400);margin-bottom:1.25rem;font-size:.92rem}
.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

@media(max-width:900px){
  .mapping-layout{grid-template-columns:1fr;}
  .matrix-container{padding:1rem;}
  .results-grid{grid-template-columns:1fr;}
}
