:root{
  --bg:#f5f7fb;
  --card:#fff;
  --text:#172033;
  --muted:#667085;
  --line:#e4e7ec;
  --primary:#0f62fe;
  --primary-dark:#0747b6;
  --danger:#b42318;
  --warning:#b54708;
  --success:#067647;
  --soft:#eef4ff;
  --shadow:0 16px 42px rgba(16,24,40,.08);
  --radius:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;position:relative}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(90deg,rgba(15,98,254,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(15,98,254,.03) 1px,transparent 1px);background-size:44px 44px;animation:techGrid 18s linear infinite}
button,input,textarea{font:inherit}
button:disabled{cursor:not-allowed;opacity:.55}
.app-shell{display:flex;min-height:100vh}
.sidebar{width:310px;background:#101828;color:#fff;padding:24px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;gap:14px;align-items:center;margin-bottom:26px}
.brand-mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#0f62fe,#49a6ff);display:grid;place-items:center;font-weight:800;box-shadow:0 14px 28px rgba(15,98,254,.24);animation:pulseMark 3.6s ease-in-out infinite}
.brand h1{font-size:16px;margin:0;line-height:1.2}
.brand p{margin:4px 0 0;color:#cbd5e1;font-size:12px}
.section-nav{display:flex;flex-direction:column;gap:7px;overflow:auto;padding-right:2px}
.nav-item{border:0;border-radius:12px;background:transparent;color:#cbd5e1;text-align:left;padding:11px 12px;cursor:pointer;font-size:14px;line-height:1.25;display:flex;justify-content:space-between;gap:10px;align-items:center;transition:background .18s ease,color .18s ease,transform .18s ease}
.nav-item:hover,.nav-item.active{background:#1d2939;color:#fff}
.nav-item:hover{transform:translateX(2px)}
.nav-item.done::after{content:"OK";font-size:11px;font-weight:800;color:#7dd3fc}
.sidebar-footer{margin-top:auto;display:grid;gap:10px;padding-top:16px}
.main{flex:1;padding:24px;max-width:1500px;margin:0 auto;width:100%}
.topbar{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:12px}
.eyebrow{display:inline-block;font-size:12px;color:var(--primary);font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.topbar h2,.results-header h2{font-size:28px;margin:4px 0 0;letter-spacing:0}
.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.progress-pill{background:var(--soft);color:var(--primary);border-radius:999px;padding:8px 12px;font-weight:800;min-width:58px;text-align:center}
.status-message{min-height:34px;margin-bottom:10px;color:#344054;font-size:14px}
.status-message.visible{background:#ecfdf3;border:1px solid #abefc6;color:#05603a;border-radius:12px;padding:8px 12px}
.content-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;align-items:start}
.content-card,.insight-panel,.results-section,.table-card,.guide-card,.gantt-card,.contact-card,.guide-appendix-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.content-card{padding:24px;animation:panelIn .34s ease both}
.intro-panel{background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid var(--line);border-radius:14px;padding:20px;margin-bottom:20px}
.intro-panel h3{margin:0 0 10px;font-size:22px}
.intro-panel p{margin:0 0 10px;line-height:1.55;color:#344054}
.intro-panel ul{margin:12px 0 0;padding-left:20px;color:#344054}
.questions-form{display:grid;gap:16px}
.question-card{border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff;animation:panelIn .26s ease both;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.question-card:hover{border-color:#c7d7fe;box-shadow:0 12px 28px rgba(16,24,40,.06);transform:translateY(-1px)}
.question-card label{display:block;font-weight:750;margin-bottom:10px}
.question-help{font-size:13px;color:var(--muted);margin-top:-4px;margin-bottom:12px}
.scale{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:7px}
.scale button{border:1px solid var(--line);background:#f9fafb;border-radius:10px;padding:10px 6px;cursor:pointer;color:#344054;min-height:46px;transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease}
.scale button:hover{border-color:#b2ccff;background:#f5f8ff}
.scale button:hover{transform:translateY(-1px)}
.scale button.active{border-color:var(--primary);background:var(--soft);color:var(--primary);font-weight:800;box-shadow:inset 0 0 0 1px var(--primary),0 8px 18px rgba(15,98,254,.12)}
.scale button.active:active{transform:scale(.97)}
.scale button:active{transform:scale(.98)}
.input,.select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px;color:var(--text);background:#fff;outline:none;transition:border-color .18s ease,box-shadow .18s ease}
.input:focus,textarea:focus,.scale button:focus-visible,.btn:focus-visible,.nav-item:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,98,254,.16)}
textarea{min-height:96px;resize:vertical}
.navigation-controls{display:flex;justify-content:space-between;gap:12px;margin-top:22px}
.btn{border:0;border-radius:12px;padding:11px 16px;font-weight:800;cursor:pointer;min-height:42px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(16,24,40,.10)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:#eef4ff;color:#1849a9}
.btn-secondary:hover{background:#dbeafe}
.btn-ghost{background:transparent;color:#cbd5e1;border:1px solid #344054}
.btn-ghost:hover{background:#1d2939;color:#fff}
.full{width:100%}
.insight-panel{padding:16px;display:grid;gap:12px;position:sticky;top:24px}
.chart-card{border:1px solid var(--line);border-radius:14px;padding:15px;background:#fff}
.chart-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px}
.chart-wrap{position:relative}
.metric-card,.alerts-card{border:1px solid var(--line);border-radius:14px;padding:15px;background:#fff}
.metric-card span{display:block;color:var(--muted);font-size:13px}
.metric-card strong{display:block;margin-top:6px;font-size:24px;line-height:1.12}
.bar{height:8px;background:#eaecf0;border-radius:99px;margin-top:10px;overflow:hidden}
.bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--primary),#49a6ff);transition:width .2s ease;box-shadow:0 0 16px rgba(15,98,254,.45)}
.alerts-card h3,.table-card h3{margin:0 0 12px}
.alert{border-left:4px solid var(--warning);background:#fffaeb;border-radius:12px;padding:10px;margin-bottom:8px;font-size:13px;line-height:1.4}
.alert.critical{border-color:var(--danger);background:#fef3f2}
.muted{color:var(--muted)}
.hidden{display:none}
.results-section{margin-top:20px;padding:22px}
.results-header{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}
.results-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}
.charts-section{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px}
.charts-section .chart-card{min-height:320px}
.dash-card{border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff;animation:panelIn .3s ease both;transition:transform .18s ease,box-shadow .18s ease}
.dash-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(16,24,40,.08)}
.dash-card span{font-size:13px;color:var(--muted)}
.dash-card strong{display:block;font-size:24px;margin-top:6px;line-height:1.12}
.guide-card{padding:20px;margin-top:16px;box-shadow:none}
.guide-card-header{display:flex;justify-content:space-between;gap:16px;align-items:end;margin-bottom:16px;border-bottom:1px solid var(--line);padding-bottom:14px}
.guide-card-header h3{margin:4px 0 0;font-size:22px}
.step-plan-list{display:grid;gap:14px}
.plan-step{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,#fff,#fbfcff);padding:16px;animation:panelIn .32s ease both}
.plan-step-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.plan-step h4{margin:4px 0 0;font-size:18px;line-height:1.3}
.step-id{font-size:12px;color:var(--primary);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.step-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.step-grid div{border:1px solid #edf0f5;border-radius:12px;padding:12px;background:#fff}
.step-grid span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;margin-bottom:6px}
.step-grid p{margin:0;color:#344054;line-height:1.45;font-size:14px}
.plan-empty{border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff}
.gantt-card{padding:20px;margin-top:16px;box-shadow:none}
.gantt-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px;background:#fff}
.gantt{min-width:980px;display:grid;grid-template-columns:230px repeat(24,34px);font-size:12px;color:#344054}
.gantt-left-head{grid-column:1;grid-row:1 / span 2;background:#f9fafb;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;place-items:center;font-weight:800;color:#344054}
.gantt-timeline-head{grid-column:2 / -1;display:grid;grid-template-rows:28px 28px;border-bottom:1px solid var(--line)}
.gantt-months,.gantt-weeks{display:grid;grid-template-columns:repeat(24,34px)}
.gantt-months span{display:grid;place-items:center;border-right:1px solid var(--line);font-weight:800;color:#1849a9;background:#eef4ff}
.gantt-weeks span{display:grid;place-items:center;border-right:1px solid #edf0f5;color:#667085;background:#fff;font-size:10px}
.gantt-row{display:contents}
.gantt-task{grid-column:1;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:9px 10px;min-height:42px;background:#fff}
.gantt-task strong{display:inline-block;min-width:38px;color:#172033}
.gantt-task span{display:block;margin-top:2px;color:#667085;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-line{grid-column:2 / -1;display:grid;grid-template-columns:repeat(24,34px);align-items:center;min-height:42px;border-bottom:1px solid var(--line);background:repeating-linear-gradient(90deg,#fff 0,#fff 33px,#edf0f5 34px)}
.gantt-bar{height:22px;border-radius:4px;display:flex;align-items:center;padding:0 8px;color:#172033;font-weight:700;position:relative;z-index:2;box-shadow:0 8px 14px rgba(16,24,40,.10);overflow:visible}
.gantt-bar span{white-space:nowrap;margin-left:2px;transform:translateX(100%);font-weight:600;color:#667085}
.gantt-bar.critical{background:#f97066}
.gantt-bar.high{background:#fdb022}
.gantt-bar.medium{background:#4ec3d3}
.gantt-bar.low{background:#84ca85}
.gantt-link{height:1px;border-top:2px solid #fdb022;align-self:center;position:relative;z-index:1}
.gantt-link::before{content:"";position:absolute;left:-4px;top:-4px;width:6px;height:6px;border-left:2px solid #fdb022;border-bottom:2px solid #fdb022}
.table-card{padding:18px;margin-top:16px;box-shadow:none}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px}
table{width:100%;border-collapse:collapse;font-size:13px;background:#fff}
th,td{border-bottom:1px solid var(--line);padding:11px;text-align:left;vertical-align:top}
tr:last-child td{border-bottom:0}
th{background:#f9fafb;color:#344054;font-size:12px;text-transform:uppercase;white-space:nowrap}
.badge{display:inline-block;border-radius:999px;padding:5px 9px;font-weight:800;font-size:12px;white-space:nowrap}
.badge.critical{background:#fef3f2;color:var(--danger)}
.badge.high{background:#fffaeb;color:var(--warning)}
.badge.medium{background:#eef4ff;color:#1849a9}
.badge.low{background:#ecfdf3;color:var(--success)}
.contact-card{margin-top:16px;padding:20px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;box-shadow:none;background:linear-gradient(180deg,#fff,#f8fbff)}
.contact-card h3{margin:4px 0 8px;font-size:22px}
.contact-card p{margin:0;color:#344054;line-height:1.5}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.contact-actions a{text-decoration:none;text-align:center}
.contact-details{grid-column:1/-1;display:flex;gap:10px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:14px;color:#344054;font-weight:700}
.contact-details span{background:#f9fafb;border:1px solid var(--line);border-radius:999px;padding:7px 10px;font-size:13px}
.guide-appendix-card{margin-top:16px;padding:20px;box-shadow:none;background:#fff}
.guide-appendix-note{margin:0 0 12px;color:#344054;font-size:14px;line-height:1.45}
.guide-doc-index{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.guide-doc-index span{background:#eef4ff;border:1px solid #dbeafe;color:#1849a9;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:800}
.guide-doc-content{max-height:520px;overflow:auto;border:1px solid var(--line);border-radius:12px;padding:14px;background:#fbfcff}
.guide-doc-section{padding:0 0 14px;margin:0 0 14px;border-bottom:1px solid var(--line)}
.guide-doc-section:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.guide-doc-section h3{font-size:20px;margin:0 0 10px;color:#172033}
.guide-doc-section h4{font-size:15px;margin:16px 0 7px;color:#172033}
.guide-doc-section p{font-size:13px;line-height:1.5;margin:0 0 8px;color:#344054}
.guide-doc-list{margin:8px 0 10px;padding-left:18px;color:#344054;font-size:13px;line-height:1.45}
.guide-doc-list li{margin-bottom:5px}
.guide-table-wrap{overflow:auto;margin:10px 0;border:1px solid var(--line);border-radius:10px;background:#fff}
.guide-doc-table{font-size:11px;min-width:640px}
.guide-doc-table th,.guide-doc-table td{padding:7px}
.guide-doc-code{white-space:pre-wrap;background:#101828;color:#e5edff;border-radius:10px;padding:10px;font-size:11px;line-height:1.35;overflow:auto}
@keyframes techGrid{from{background-position:0 0,0 0}to{background-position:44px 0,0 44px}}
@keyframes pulseMark{0%,100%{box-shadow:0 14px 28px rgba(15,98,254,.24)}50%{box-shadow:0 16px 34px rgba(15,98,254,.38)}}
@keyframes panelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.scale button{animation:scaleIn .25s ease both}
.scale button:nth-child(1){animation-delay:.02s}
.scale button:nth-child(2){animation-delay:.04s}
.scale button:nth-child(3){animation-delay:.06s}
.scale button:nth-child(4){animation-delay:.08s}
.scale button:nth-child(5){animation-delay:.10s}
.nav-item{animation:slideIn .2s ease both}
.nav-item:nth-child(1){animation-delay:.02s}
.nav-item:nth-child(2){animation-delay:.04s}
.nav-item:nth-child(3){animation-delay:.06s}
.nav-item:nth-child(4){animation-delay:.08s}
.nav-item:nth-child(5){animation-delay:.10s}
.nav-item:nth-child(6){animation-delay:.12s}
.nav-item:nth-child(7){animation-delay:.14s}
.nav-item:nth-child(8){animation-delay:.16s}
.nav-item:nth-child(9){animation-delay:.18s}
.nav-item:nth-child(10){animation-delay:.20s}
@media(max-width:1050px){
  .app-shell{display:block}
  .sidebar{position:relative;width:100%;height:auto}
  .section-nav{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));max-height:none;overflow:visible}
  .content-grid{grid-template-columns:1fr}
  .insight-panel{position:relative;top:0}
  .dashboard-grid{grid-template-columns:1fr 1fr}
  .step-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body::before{background-size:34px 34px}
  .sidebar{padding:12px 12px 10px}
  .brand{margin-bottom:10px;align-items:center;gap:10px}
  .brand-mark{width:34px;height:34px;border-radius:10px;flex:0 0 auto;font-size:13px}
  .brand h1{font-size:14px}
  .brand p{font-size:11px;margin-top:2px}
  .section-nav{display:flex;flex-direction:row;overflow-x:auto;gap:8px;padding:2px 2px 10px;scroll-snap-type:x proximity}
  .nav-item{flex:0 0 auto;min-width:128px;max-width:168px;scroll-snap-align:start;background:#172033;border-radius:999px;padding:8px 10px;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .nav-item:hover{transform:translateY(-1px)}
  .nav-item.done::after{font-size:9px}
  .sidebar-footer{grid-template-columns:1fr 1fr;padding-top:8px}
  .main{padding:10px}
  .topbar{display:grid;gap:8px;margin-bottom:8px}
  .topbar h2{font-size:20px}
  .eyebrow{font-size:10px}
  .top-actions{display:grid;grid-template-columns:auto 1fr 1fr;gap:6px;align-items:center}
  .progress-pill{grid-column:1/-1;padding:6px 10px;font-size:12px}
  .content-grid{gap:10px}
  .content-card{padding:10px}
  .intro-panel{padding:10px;margin-bottom:9px;border-radius:12px}
  .intro-panel h3{font-size:16px;margin-bottom:6px}
  .intro-panel p,.intro-panel li{font-size:12.5px;line-height:1.4}
  .intro-panel ul{margin-top:8px}
  .questions-form{gap:8px}
  .question-card{padding:9px;border-radius:11px}
  .question-card label{font-size:13px;margin-bottom:6px;line-height:1.3}
  .question-help{font-size:11.5px;margin-bottom:8px}
  .scale{grid-template-columns:repeat(6,minmax(42px,1fr));gap:5px}
  .scale button{min-height:34px;border-radius:9px;padding:6px 3px;font-size:11px;line-height:1.1}
  .input,textarea{padding:8px;border-radius:10px;font-size:13px}
  textarea{min-height:64px}
  .navigation-controls{margin-top:12px}
  .btn{min-height:36px;padding:9px 11px;font-size:12.5px;border-radius:10px}
  .insight-panel{grid-template-columns:1fr 1fr;padding:8px;gap:7px}
  .metric-card,.alerts-card{padding:8px;border-radius:11px}
  .metric-card span{font-size:11px}
  .alerts-card{grid-column:1/-1}
  .metric-card strong,.dash-card strong{font-size:17px}
  .results-section{margin-top:12px;padding:12px}
  .results-header{margin-bottom:10px}
  .results-header h2{font-size:20px}
  .results-actions{gap:7px}
  .dashboard-grid{gap:7px;margin-bottom:10px}
  .dash-card{padding:9px;border-radius:11px}
  .dash-card span{font-size:11px}
  .guide-card,.gantt-card,.table-card,.contact-card,.guide-appendix-card{padding:10px;border-radius:12px;margin-top:10px}
  .gantt{min-width:820px;grid-template-columns:170px repeat(24,27px);font-size:11px}
  .gantt-months,.gantt-weeks,.gantt-line{grid-template-columns:repeat(24,27px)}
  .gantt-task{padding:7px 8px}
  .gantt-bar{height:19px;padding:0 6px}
  .guide-card-header{margin-bottom:9px;padding-bottom:8px}
  .guide-card-header h3,.contact-card h3{font-size:16px}
  .step-plan-list{gap:9px}
  .plan-step{padding:9px;border-radius:11px}
  .plan-step h4{font-size:14px}
  .step-id{font-size:10px}
  .step-grid{gap:8px}
  .step-grid div{padding:8px;border-radius:10px}
  .step-grid span{font-size:10px}
  .step-grid p{font-size:12px;line-height:1.35}
  table{font-size:11.5px}
  th,td{padding:8px}
  .guide-doc-content{max-height:420px;padding:10px}
  .guide-doc-index{gap:5px;margin-bottom:10px}
  .guide-doc-index span{font-size:10px;padding:5px 7px}
  .guide-doc-section h3{font-size:17px}
  .guide-doc-section h4{font-size:13px}
  .guide-doc-section p,.guide-doc-list{font-size:11.5px;line-height:1.38}
  .guide-doc-code{font-size:10px}
  .contact-card{grid-template-columns:1fr}
  .contact-actions{justify-content:stretch}
  .contact-actions .btn{flex:1 1 180px}
}
@media(max-width:650px){
  .main{padding:9px}
  .topbar,.results-header{display:block}
  .top-actions{margin-top:8px}
  .results-actions{display:grid;grid-template-columns:1fr;margin-top:8px}
  .scale{grid-template-columns:repeat(6,minmax(38px,1fr))}
  .dashboard-grid{grid-template-columns:1fr 1fr}
  .charts-section{grid-template-columns:1fr}
  .guide-card-header,.plan-step-head{display:block}
  .step-grid{grid-template-columns:1fr}
  .content-card{padding:10px}
  .navigation-controls{display:grid;grid-template-columns:1fr}
  .btn{width:100%}
}
@media(max-width:430px){
  .sidebar{padding:10px}
  .brand p{font-size:11px}
  .nav-item{flex-basis:142px;font-size:11.5px;padding:7px 9px}
  .sidebar-footer{grid-template-columns:1fr}
  .top-actions{grid-template-columns:1fr}
  .intro-panel,.question-card,.guide-card,.gantt-card,.table-card,.contact-card,.guide-appendix-card{padding:9px}
  .insight-panel{grid-template-columns:1fr;padding:8px}
  .scale{grid-template-columns:repeat(6,minmax(34px,1fr));gap:4px}
  .scale button{font-size:10px;min-height:32px;padding:5px 2px}
  .results-section{padding:9px}
  .contact-details{display:grid}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
@media print{
  @page{margin:1.5cm 1.5cm 1.5cm 240px}
  .app-shell{
    display:block;
    background:#fff;
    min-height:100vh;
  }
  .sidebar{
    display:block!important;
    width:220px!important;
    position:fixed!important;
    top:0;
    left:0;
    height:100vh!important;
    border-right:2px solid #1d6ff3!important;
    padding:20px 16px!important;
    background:linear-gradient(180deg,#0f2d5e,#111827)!important;
  }
  .brand{display:flex!important;gap:10px!important;margin-bottom:20px!important}
  .brand-mark{
    width:36px!important;
    height:36px!important;
    font-size:14px!important;
    background:linear-gradient(135deg,#1d6ff3,#0d9488)!important;
    display:grid!important;
    place-items:center;
    color:#fff!important;
    font-weight:800!important;
  }
  .brand h1{font-size:14px!important;color:#fff!important;margin:0}
  .brand p{font-size:9px!important;color:#94a3b8!important;margin:2px 0 0 0}
  .section-nav{
    display:flex!important;
    flex-direction:column!important;
    gap:4px!important;
    overflow:visible!important;
  }
  .nav-item{
    display:block!important;
    padding:8px 10px!important;
    font-size:10px!important;
    color:#cbd5e1!important;
    background:transparent!important;
    border:1px solid transparent!important;
    border-radius:8px!important;
    margin-bottom:2px!important;
  }
  .nav-item.active{
    background:rgba(255,255,255,.12)!important;
    border-left:3px solid #60a5fa!important;
    color:#fff!important;
  }
  .nav-item.done::after{content:" ✓";font-size:9px;color:#4ade80}
  .topbar,.navigation-controls,.results-actions,#downloadJsonBtn,.status-message{display:none!important}
  .main{padding:0 0 0 240px;max-width:none}
  .content-grid{display:block}
  .insight-panel{display:block!important;width:280px!important;position:fixed!important;right:20px!important;top:20px!important}
  .metric-card,.alerts-card,.chart-card{
    border:1px solid #d0d5dd!important;
    border-radius:10px!important;
    padding:12px!important;
    background:#fff!important;
    margin-bottom:10px!important;
    page-break-inside:avoid;
  }
  .metric-card strong{display:block;font-size:18px!important;color:#0f2d5e!important}
  .results-section{display:block!important;border:0;box-shadow:none;margin:0;padding:0}
  .content-card{box-shadow:none;border:1px solid #d0d5dd;margin:0 0 16px 0;padding:0}
  .intro-panel{background:#f8fafc;border:1px solid #e2e8f0;margin:0 0 16px 0;padding:16px}
  .intro-panel h3{font-size:18px;color:#0f2d5e;margin:0 0 8px 0}
  .intro-panel p,.intro-panel ul{font-size:11px;line-height:1.4;color:#475569}
  .questions-form{display:block!important}
  .question-card{margin:0 0 12px 0;padding:12px;border:1px solid #e2e8f0;border-radius:10px;page-break-inside:avoid}
  .question-card label{font-size:12px;font-weight:600;color:#0f2d5e}
  .scale{display:flex!important;flex-wrap:wrap;gap:6px!important;margin-top:8px}
  .scale button{min-width:70px;padding:6px 8px!important;font-size:10px!important;border-radius:8px!important}
  .scale button.active{border:2px solid #1d6ff3!important;background:#eff6ff!important}
  input[type=text],input[type=number],textarea{font-size:11px;padding:8px;border:1px solid #e2e8f0;border-radius:8px}
  .navigation-controls{display:none!important}
  .charts-section{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:16px!important;margin:16px 0!important;page-break-inside:avoid}
  .chart-card{display:block!important;border:1px solid #d0d5dd!important;border-radius:12px!important;padding:16px!important;background:#fff!important;page-break-inside:avoid}
  .chart-title{font-size:14px!important;margin-bottom:10px!important;color:#0f2d5e!important}
  .chart-wrap{height:220px!important}
  .dashboard-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:10px!important;margin:16px 0!important}
  .dash-card{padding:12px!important;border:1px solid #d0d5dd!important;border-radius:10px!important;page-break-inside:avoid}
  .dash-card span{font-size:10px!important}
  .dash-card strong{font-size:18px!important}
  .print-answers-section{display:block!important;margin:0 0 24px 0;padding:20px;background:#fff;border:1px solid #d0d5dd;border-radius:12px;page-break-after:always}
  .print-header{margin:0 0 16px 0;border-bottom:2px solid #1d6ff3;padding-bottom:8px}
  .print-header h2{margin:0;font-size:20px;color:#0f2d5e}
  .print-section{margin:0 0 18px 0;page-break-inside:avoid}
  .print-section-title{margin:14px 0 10px 0;font-size:14px;font-weight:700;color:#0f2d5e;border-bottom:1px solid #e2e8f0;padding-bottom:4px}
  .print-answer-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid #f1f5f9}
  .print-question{flex:1;font-size:11px;color:#475569}
  .print-response{font-size:11px;font-weight:600;color:#0f2d5e;white-space:nowrap}
  .contact-actions{display:none}
  .contact-card{break-inside:avoid;border:1px solid #d0d5dd;box-shadow:none;margin-top:18px}
  .guide-appendix-card{border:0;box-shadow:none;margin-top:24px;padding:0;break-before:page}
  .guide-doc-content{max-height:none;overflow:visible;border:0;padding:0;background:#fff}
  .guide-doc-index{display:none}
  .guide-doc-section{break-inside:auto;page-break-inside:auto;border-bottom:0;margin-bottom:18px}
  .guide-doc-section h3{break-after:avoid;font-size:18px}
  .guide-doc-section h4{break-after:avoid;font-size:13px}
  .guide-doc-section p,.guide-doc-list{font-size:10.5px;line-height:1.35}
  .guide-table-wrap{overflow:visible;break-inside:auto}
  .guide-doc-table{min-width:0;font-size:8.5px}
  .guide-doc-table th,.guide-doc-table td{padding:4px}
.guide-doc-code{font-size:8px;break-inside:avoid}
  .app-shell{display:block}
  body{background:#fff}
 }
:root{
  --bg:#f5f7fa;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --primary:#1d6ff3;
  --primary-dark:#0f2d5e;
  --soft:#eff6ff;
  --danger:#dc2626;
  --warning:#d97706;
  --success:#059669;
  --shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.05);
  --shadow-md:0 4px 14px rgba(15,23,42,.09),0 2px 5px rgba(15,23,42,.05);
  --radius:14px;
}
body{
  background:
    radial-gradient(circle at top right,rgba(29,111,243,.08),transparent 30%),
    linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);
  color:var(--text);
}
body::before{
  background:
    linear-gradient(90deg,rgba(15,45,94,.045) 1px,transparent 1px),
    linear-gradient(180deg,rgba(15,45,94,.035) 1px,transparent 1px);
  background-size:38px 38px;
}
.sidebar{
  background:linear-gradient(180deg,#0f2d5e 0%,#111827 100%);
  border-right:1px solid rgba(255,255,255,.08);
  box-shadow:8px 0 24px rgba(15,23,42,.12);
}
.brand-mark{
  border-radius:12px;
  background:linear-gradient(135deg,#1d6ff3,#0d9488);
  box-shadow:0 10px 26px rgba(29,111,243,.28);
}
.brand h1{font-weight:800}
.brand p{color:#cbd5e1}
.nav-item{
  border-radius:10px;
  color:#dbeafe;
  border:1px solid transparent;
}
.nav-item:hover,.nav-item.active{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.12);
  box-shadow:inset 3px 0 0 #60a5fa;
}
.main{max-width:1320px}
.topbar{
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);
  border:1px solid rgba(226,232,240,.9);
  border-radius:var(--radius);
  padding:14px 16px;
  box-shadow:var(--shadow);
}
.content-card,.insight-panel,.results-section,.table-card,.guide-card,.gantt-card,.contact-card,.guide-appendix-card{
  border-color:#dbe3ee;
  box-shadow:var(--shadow);
}
.content-card,.results-section{
  background:linear-gradient(180deg,#fff,#fbfdff);
}
.intro-panel{
  background:linear-gradient(135deg,#eff6ff 0%,#fff 64%);
  border-color:#dbeafe;
}
.question-card,.metric-card,.alerts-card,.dash-card,.plan-step,.step-grid div{
  border-color:#e2e8f0;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.question-card:hover,.dash-card:hover{
  box-shadow:var(--shadow-md);
}
.question-card label,.table-card h3,.alerts-card h3,.guide-card-header h3{
  color:#0f172a;
}
.scale button{
  border-radius:9px;
  background:#f8fafc;
  color:#475569;
}
.scale button.active{
  background:#eff6ff;
  color:#1d4ed8;
  border-color:#1d6ff3;
  box-shadow:inset 0 0 0 1px #1d6ff3,0 6px 16px rgba(29,111,243,.14);
}
.btn{
  border-radius:10px;
  box-shadow:none;
}
.btn:hover{box-shadow:var(--shadow-md)}
.btn-primary{
  background:linear-gradient(135deg,#1d6ff3,#1b5cb5);
}
.btn-secondary{
  background:#eff6ff;
  color:#0f2d5e;
  border:1px solid #dbeafe;
}
.progress-pill,.guide-doc-index span,.badge.medium{
  background:#eff6ff;
  color:#1b5cb5;
  border:1px solid #dbeafe;
}
.dashboard-grid{gap:12px}
.dash-card{
  border-radius:12px;
  position:relative;
  overflow:hidden;
}
.dash-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:#1d6ff3;
}
.dash-card span,.metric-card span,.step-grid span{
  color:#64748b;
  letter-spacing:.03em;
}
.dash-card strong,.metric-card strong{
  color:#0f172a;
  font-weight:850;
}
.bar{background:#e2e8f0}
.bar-fill{background:linear-gradient(90deg,#1d6ff3,#0d9488)}
.badge.critical{background:#fef2f2;color:#dc2626}
.badge.high{background:#fffbeb;color:#d97706}
.badge.low{background:#ecfdf5;color:#059669}
.gantt-wrap,.table-wrap,.guide-table-wrap{
  border-color:#dbe3ee;
}
.gantt-months span{
  background:#eff6ff;
  color:#0f2d5e;
}
.gantt-bar{
  box-shadow:0 4px 10px rgba(15,23,42,.12);
}
.contact-card{
  background:linear-gradient(135deg,#fff 0%,#eff6ff 100%);
  border-color:#dbeafe;
}
.contact-details span{
  background:#fff;
  border-color:#dbeafe;
  color:#0f2d5e;
}
.guide-doc-content{
  background:#f8fafc;
  border-color:#dbe3ee;
}
.guide-doc-section h3{
  color:#0f2d5e;
}
@media print{
  *{
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }
  @page{
    size:A4 portrait;
    margin:1.5cm 1.5cm 1.5cm 240px;
  }
  body{background:#fff!important;color:#0f172a!important;font-size:11px}
  body::before{display:none!important}
  .app-shell{display:block;background:#fff;min-height:100vh}
  .sidebar{
    display:block!important;
    width:220px!important;
    position:fixed!important;
    top:0;left:0;height:100vh!important;
    border-right:2px solid #1d6ff3!important;
    padding:20px 16px!important;
    background:linear-gradient(180deg,#0f2d5e,#111827)!important;
  }
  .brand{display:flex!important;gap:10px!important;margin-bottom:20px!important}
  .brand-mark{
    width:36px!important;height:36px!important;font-size:14px!important;
    background:linear-gradient(135deg,#1d6ff3,#0d9488)!important;
    display:grid!important;place-items:center;color:#fff!important;font-weight:800!important;
  }
  .brand h1{font-size:14px!important;color:#fff!important;margin:0}
  .brand p{font-size:9px!important;color:#94a3b8!important}
  .section-nav{display:flex!important;flex-direction:column!important;gap:4px!important}
  .nav-item{
    display:block!important;padding:8px 10px!important;font-size:10px!important;
    color:#cbd5e1!important;background:transparent!important;
    border:1px solid transparent!important;border-radius:8px!important;
  }
  .nav-item.active{background:rgba(255,255,255,.12)!important;border-left:3px solid #60a5fa!important;color:#fff!important}
  .nav-item.done::after{content:" ✓";font-size:9px;color:#4ade80}
  .topbar,.navigation-controls,.results-actions,#downloadJsonBtn,.status-message,.contact-actions{display:none!important}
  .main{padding:0 0 0 240px;max-width:none}
  .content-grid{display:block}
  .insight-panel{
    display:block!important;width:280px!important;
    position:fixed!important;right:20px!important;top:20px!important;
  }
  .metric-card,.alerts-card,.chart-card{
    border:1px solid #d0d5dd!important;border-radius:10px!important;
    padding:12px!important;background:#fff!important;margin-bottom:10px!important;
    page-break-inside:avoid;
  }
  .results-section{display:block!important;border:0;box-shadow:none;margin:0;padding:0}
  .content-card{box-shadow:none;border:1px solid #d0d5dd;margin:0 0 16px 0;padding:0}
  .intro-panel{background:#f8fafc;border:1px solid #e2e8f0;margin:0 0 16px 0;padding:16px}
  .intro-panel h3{font-size:18px;color:#0f2d5e;margin:0 0 8px 0}
  .questions-form{display:block!important}
  .question-card{margin:0 0 12px 0;padding:12px;border:1px solid #e2e8f0;border-radius:10px;page-break-inside:avoid}
  .scale{display:flex!important;flex-wrap:wrap;gap:6px!important}
  .scale button{min-width:70px;padding:6px 8px!important;border-radius:8px!important}
  .charts-section{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:16px!important;margin:16px 0!important;page-break-inside:avoid}
  .chart-card{display:block!important;border:1px solid #d0d5dd!important;border-radius:12px!important;padding:16px!important;background:#fff!important}
  .chart-title{font-size:14px!important;color:#0f2d5e!important}
  .dashboard-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:10px!important;margin:16px 0!important}
  .dash-card{padding:12px!important;border:1px solid #d0d5dd!important;border-radius:10px!important;page-break-inside:avoid}
  .print-answers-section{display:block!important;margin:0 0 24px 0;padding:20px;background:#fff;border:1px solid #d0d5dd;border-radius:12px;page-break-after:always}
  .print-header{border-bottom:2px solid #1d6ff3;padding-bottom:8px}
  .print-header h2{font-size:20px;color:#0f2d5e}
  .print-section{page-break-inside:avoid}
  .print-section-title{font-size:14px;font-weight:700;color:#0f2d5e;border-bottom:1px solid #e2e8f0;padding-bottom:4px}
  .print-answer-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid #f1f5f9}
  .print-question{flex:1;font-size:11px;color:#475569}
  .print-response{font-size:11px;font-weight:600;color:#0f2d5e}
  .guide-card,.gantt-card,.table-card,.contact-card,.guide-appendix-card{background:#fff!important;border:1px solid #dbe3ee!important;border-radius:10px!important;margin:0 0 10px!important;padding:12px!important;page-break-inside:avoid}
}
  .results-header .eyebrow,.results-header h2{
    color:#fff!important;
  }
  .dashboard-grid{
    display:grid!important;
    grid-template-columns:repeat(4,1fr)!important;
    gap:8px!important;
    margin-bottom:10px!important;
  }
  .dash-card,.metric-card{
    background:#fff!important;
    border:1px solid #dbe3ee!important;
    border-radius:9px!important;
    padding:10px!important;
    box-shadow:0 1px 2px rgba(15,23,42,.06)!important;
    break-inside:avoid;
  }
  .dash-card span{font-size:9px!important}
  .dash-card strong{font-size:15px!important}
  .guide-card-header{
    border-bottom:1px solid #e2e8f0!important;
    margin-bottom:8px!important;
    padding-bottom:7px!important;
  }
  .guide-card-header h3,.table-card h3,.contact-card h3{
    font-size:15px!important;
  }
  .step-plan-list{gap:8px!important}
  .plan-step{
    border:1px solid #dbe3ee!important;
    border-radius:9px!important;
    padding:10px!important;
    background:#fff!important;
    break-inside:avoid;
  }
  .step-grid{
    display:grid!important;
    grid-template-columns:repeat(3,1fr)!important;
    gap:6px!important;
  }
  .step-grid div{
    padding:7px!important;
    border:1px solid #e2e8f0!important;
    background:#f8fafc!important;
  }
  .step-grid p{font-size:10px!important;line-height:1.3!important}
  .gantt-wrap,.table-wrap{
    overflow:visible!important;
    border:1px solid #dbe3ee!important;
  }
  .gantt{
    min-width:0!important;
    width:100%!important;
    grid-template-columns:145px repeat(24,1fr)!important;
    font-size:8px!important;
  }
  .gantt-months,.gantt-weeks,.gantt-line{
    grid-template-columns:repeat(24,1fr)!important;
  }
  .gantt-task,.gantt-line{min-height:28px!important}
  .gantt-bar{height:15px!important}
  table{
    font-size:9px!important;
    background:#fff!important;
  }
  th{
    background:#eff6ff!important;
    color:#0f2d5e!important;
  }
  th,td{padding:5px!important}
  .badge{
    padding:3px 6px!important;
    font-size:9px!important;
  }
  .contact-card{
    display:block!important;
    background:linear-gradient(135deg,#fff,#eff6ff)!important;
  }
  .contact-actions{display:none!important}
  .contact-details{
    display:flex!important;
    gap:6px!important;
    padding-top:8px!important;
  }
  .contact-details span{
    font-size:9px!important;
    padding:4px 6px!important;
    background:#fff!important;
  }
  .guide-appendix-card{
    break-before:page;
    page-break-before:always;
  }
  .guide-doc-content{
    max-height:none!important;
    overflow:visible!important;
    border:0!important;
    padding:0!important;
    background:#fff!important;
  }
  .guide-doc-index{display:none!important}
  .guide-doc-section{
    border-bottom:1px solid #e2e8f0!important;
    margin-bottom:10px!important;
    padding-bottom:8px!important;
    break-inside:auto!important;
  }
  .guide-doc-section h3{
    font-size:14px!important;
    color:#0f2d5e!important;
    break-after:avoid;
  }
  .guide-doc-section h4{
    font-size:11px!important;
    break-after:avoid;
  }
  .guide-doc-section p,.guide-doc-list{
    font-size:9.5px!important;
    line-height:1.32!important;
  }
  .guide-doc-table{
    min-width:0!important;
    font-size:8px!important;
  }
}
