@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--bg:#0f172a;--surface:#1e293b;--surface2:#334155;--border:#475569;--border-light:#334155;--accent:#3b82f6;--accent-light:#1e3a5f;--accent2:#059669;--accent2-light:#064e3b;--red:#dc2626;--red-light:#450a0a;--amber:#f59e0b;--amber-light:#451a03;--purple:#8b5cf6;--purple-light:#2e1065;--text:#f1f5f9;--text-sec:#94a3b8;--text-muted:#64748b;--radius:8px;--shadow:0 1px 3px rgba(0,0,0,0.3);--glow:0 0 20px rgba(59,130,246,0.15);}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;}

.app-header{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border-bottom:1px solid var(--border-light);padding:16px 24px;}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;}
.header-left{display:flex;align-items:baseline;gap:16px;}
.logo{font-size:20px;font-weight:700;color:var(--accent);letter-spacing:-0.5px;}
.tagline{font-size:13px;color:var(--text-sec);}
.version{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text-muted);background:var(--bg);padding:1px 6px;border-radius:3px;}
.header-right{display:flex;gap:8px;}

.app-main{max-width:1200px;margin:0 auto;padding:24px;}

/* Tabs */
.tab-bar{display:flex;gap:2px;background:var(--surface);border-radius:var(--radius);padding:4px;margin-bottom:24px;overflow-x:auto;}
.tab-btn{font-family:inherit;font-size:13px;font-weight:500;padding:10px 20px;background:transparent;color:var(--text-sec);border:none;border-radius:6px;cursor:pointer;transition:all 0.15s;white-space:nowrap;position:relative;}
.tab-btn:hover{color:var(--text);background:var(--surface2);}
.tab-btn.active{background:var(--accent);color:white;}
.tab-btn .tab-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--red);}
.tab-content{display:none;}
.tab-content.active{display:block;animation:fadeIn 0.2s ease;}

@keyframes fadeIn{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:20px;transition:border-color 0.15s;}
.card:hover{border-color:var(--border);}
.card h2{font-size:18px;margin-bottom:16px;color:var(--text);}
.card h3{font-size:15px;margin:16px 0 8px;color:var(--text);border-left:3px solid var(--accent);padding-left:10px;}
.card-glow{box-shadow:var(--glow);}

/* Metrics - enhanced with gauge support */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px;}
.met{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px;text-align:center;transition:all 0.2s;}
.met:hover{border-color:var(--accent);transform:translateY(-1px);}
.met-val{font-family:'JetBrains Mono',monospace;font-size:28px;font-weight:700;color:var(--accent);}
.met-lbl{font-size:11px;color:var(--text-sec);margin-top:4px;text-transform:uppercase;letter-spacing:0.5px;}
.met-good .met-val{color:var(--accent2);}
.met-warn .met-val{color:var(--amber);}
.met-bad .met-val{color:var(--red);}

/* Gauge grid */
.gauge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-bottom:24px;}
.gauge-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;text-align:center;transition:all 0.2s;}
.gauge-card:hover{border-color:var(--accent);box-shadow:var(--glow);}
.gauge-svg{display:block;margin:0 auto 8px;}
.gauge-arc{transition:stroke-dashoffset 0.8s ease-out;}

/* Sparklines */
.sparkline{display:inline-block;vertical-align:middle;}
.trend-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.trend-label{font-size:12px;color:var(--text-sec);min-width:100px;}
.trend-val{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;min-width:40px;text-align:right;}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.form-group{display:flex;flex-direction:column;gap:4px;}
.form-group label{font-size:12px;font-weight:600;color:var(--text-sec);}
input[type="text"],input[type="email"],input[type="date"],select,textarea{font-family:'Inter',sans-serif;font-size:13px;padding:9px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);transition:border-color 0.15s;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,0.2);}
textarea{resize:vertical;min-height:60px;}
select{cursor:pointer;}

/* Search */
.search-bar{position:relative;margin-bottom:16px;}
.search-bar input{width:100%;padding-left:36px;}
.search-bar::before{content:'';position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid var(--text-muted);border-radius:50%;}
.search-bar::after{content:'';position:absolute;left:24px;top:62%;width:2px;height:6px;background:var(--text-muted);transform:rotate(-45deg);}

/* Buttons */
.btn{font-family:inherit;font-weight:600;font-size:13px;padding:9px 18px;border:none;border-radius:6px;cursor:pointer;transition:all 0.15s;}
.btn-primary{background:var(--accent);color:white;}
.btn-primary:hover{background:#2563eb;box-shadow:0 0 12px rgba(59,130,246,0.3);}
.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);}
.btn-secondary:hover{background:var(--border);}
.btn-danger{background:var(--red);color:white;}
.btn-danger:hover{background:#b91c1c;}
.btn-success{background:var(--accent2);color:white;}
.btn-success:hover{background:#047857;}
.btn-sm{font-size:11px;padding:6px 12px;}
.btn-lg{font-size:16px;padding:14px 32px;}
.btn-ghost{background:transparent;color:var(--text-sec);border:1px solid transparent;}
.btn-ghost:hover{color:var(--text);border-color:var(--border);}

/* Assessment list */
.assessment-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;margin-bottom:12px;cursor:pointer;transition:all 0.15s;}
.assessment-card:hover{border-color:var(--accent);box-shadow:var(--glow);transform:translateY(-1px);}
.ac-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.ac-name{font-size:16px;font-weight:600;}
.ac-score{font-family:'JetBrains Mono',monospace;font-size:20px;font-weight:700;}
.ac-meta{font-size:12px;color:var(--text-sec);}
.ac-bars{display:flex;gap:8px;margin-top:10px;}
.ac-bar{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden;}
.ac-bar-fill{height:100%;border-radius:3px;transition:width 0.6s ease-out;}
.ac-bar-labels{display:flex;gap:8px;margin-top:4px;}
.ac-bar-label{flex:1;font-size:10px;color:var(--text-muted);font-family:'JetBrains Mono',monospace;}

/* Strategy cards */
.strategy-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px;margin-bottom:12px;transition:border-color 0.15s;}
.strategy-card:hover{border-color:var(--border);}
.sc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.sc-name{font-size:14px;font-weight:600;}
.sc-cat{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:2px 8px;border-radius:3px;}
.sc-desc{font-size:12px;color:var(--text-sec);margin-bottom:12px;}
.sc-level{display:flex;gap:6px;margin-bottom:12px;}
.level-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;border:2px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all 0.15s;}
.level-dot.achieved{border-color:var(--accent2);background:var(--accent2-light);color:var(--accent2);}
.level-dot.target{border-color:var(--accent);background:var(--accent-light);color:var(--accent);}

/* Control rows */
.control-row{background:var(--bg);border:1px solid var(--border-light);border-radius:6px;padding:14px;margin-bottom:8px;transition:all 0.15s;}
.control-row:hover{border-color:var(--border);}
.cr-header{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.cr-text{font-size:13px;font-weight:500;flex:1;}
.cr-status{display:flex;gap:4px;flex-shrink:0;}
.status-badge{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:3px 10px;border-radius:3px;text-transform:uppercase;letter-spacing:0.5px;}
.status-compliant{background:var(--accent2-light);color:var(--accent2);}
.status-partial{background:var(--amber-light);color:var(--amber);}
.status-non_compliant,.status-non-compliant{background:var(--red-light);color:var(--red);}
.status-not_assessed{background:var(--surface2);color:var(--text-muted);}
.status-not_applicable{background:var(--surface2);color:var(--text-muted);}
.status-in_progress{background:var(--amber-light);color:var(--amber);}
.status-planned{background:var(--accent-light);color:var(--accent);}
.status-complete{background:var(--accent2-light);color:var(--accent2);}
.status-accepted{background:var(--purple-light);color:var(--purple);}

.cr-detail{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light);}
.cr-detail.open{display:block;animation:fadeIn 0.15s ease;}
.cr-requirement{font-size:12px;color:var(--text-sec);background:var(--surface);padding:10px;border-radius:4px;margin-bottom:10px;line-height:1.6;}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

/* Level picker inline */
.level-pick{display:flex;gap:4px;margin-bottom:8px;}
.level-btn{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;transition:all 0.15s;}
.level-btn.selected{border-color:var(--accent);background:var(--accent-light);color:var(--accent);}

/* Risk register */
.risk-row{display:grid;grid-template-columns:1fr auto auto auto auto;gap:12px;align-items:center;background:var(--bg);border:1px solid var(--border-light);border-radius:6px;padding:12px;margin-bottom:8px;}
.risk-level{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:3px 10px;border-radius:3px;text-transform:uppercase;color:white;}
.risk-low{background:#059669;}
.risk-medium{background:#f59e0b;color:#000;}
.risk-high{background:#dc2626;}
.risk-extreme{background:#7c2d12;}

/* Visual Risk Matrix */
.risk-matrix-container{display:flex;gap:24px;align-items:flex-start;margin-bottom:20px;}
.risk-matrix-svg rect{transition:opacity 0.15s;}
.risk-matrix-svg rect:hover{opacity:1!important;}
.matrix-legend{font-size:12px;color:var(--text-sec);}
.matrix-legend-item{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.matrix-legend-dot{width:16px;height:16px;border-radius:3px;}

/* Compliance table */
.comp-table{width:100%;border-collapse:collapse;font-size:13px;}
.comp-table th{text-align:left;padding:8px;background:var(--bg);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-sec);border-bottom:2px solid var(--border);position:sticky;top:0;}
.comp-table td{padding:8px;border-bottom:1px solid var(--border-light);vertical-align:top;}
.comp-table tr:hover{background:var(--surface2);}
.mono{font-family:'JetBrains Mono',monospace;font-size:12px;}

/* Progress bar */
.progress-bar{height:8px;background:var(--bg);border-radius:4px;overflow:hidden;margin:4px 0;}
.progress-fill{height:100%;border-radius:4px;transition:width 0.6s ease-out;}
.fill-good{background:var(--accent2);}
.fill-warn{background:var(--amber);}
.fill-bad{background:var(--red);}
.fill-accent{background:var(--accent);}

/* Progress bar with label */
.progress-labeled{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.progress-labeled .progress-bar{flex:1;}
.progress-labeled .progress-pct{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-sec);min-width:32px;text-align:right;}

/* Wizard */
.wizard-overlay{display:none;position:fixed;inset:0;background:var(--bg);z-index:200;overflow-y:auto;}
.wizard-overlay.open{display:block;animation:fadeIn 0.3s ease;}
.wizard{max-width:700px;margin:0 auto;padding:40px 24px;}
.wizard-progress{display:flex;gap:4px;margin-bottom:40px;}
.wizard-step-dot{height:4px;flex:1;border-radius:2px;background:var(--surface2);transition:background 0.3s;}
.wizard-step-dot.done{background:var(--accent2);}
.wizard-step-dot.active{background:var(--accent);}
.wizard-title{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text);}
.wizard-subtitle{font-size:15px;color:var(--text-sec);margin-bottom:32px;}
.wizard-card{background:var(--surface);border:1px solid var(--border-light);border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow);}
.wizard-actions{display:flex;justify-content:space-between;margin-top:32px;}
.wizard-sector-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.wizard-sector-btn{background:var(--bg);border:2px solid var(--border-light);border-radius:8px;padding:14px 16px;cursor:pointer;text-align:left;transition:all 0.15s;font-family:inherit;color:var(--text);}
.wizard-sector-btn:hover{border-color:var(--accent);}
.wizard-sector-btn.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 1px var(--accent);}
.wizard-sector-btn .wsb-label{font-size:14px;font-weight:600;}
.wizard-sector-btn .wsb-note{font-size:11px;color:var(--text-muted);margin-top:2px;}
.wizard-scope-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--bg);border:1px solid var(--border-light);border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all 0.15s;}
.wizard-scope-item:hover{border-color:var(--accent);}
.wizard-scope-item.checked{border-color:var(--accent2);background:var(--accent2-light);}
.scope-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0;font-size:14px;color:transparent;}
.wizard-scope-item.checked .scope-check{border-color:var(--accent2);background:var(--accent2);color:white;}
.scope-label{font-size:13px;}
.wizard-review-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px;}
.wizard-review-row .label{color:var(--text-sec);}
.wizard-note{background:var(--accent-light);border:1px solid var(--accent);border-radius:8px;padding:14px;font-size:13px;color:var(--text);margin-top:16px;line-height:1.6;}

/* Timeline */
.timeline{position:relative;padding-left:24px;}
.timeline::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:2px;background:var(--border-light);}
.timeline-item{position:relative;margin-bottom:16px;padding:12px 16px;background:var(--bg);border:1px solid var(--border-light);border-radius:8px;}
.timeline-item::before{content:'';position:absolute;left:-21px;top:16px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);}
.timeline-item.overdue::before{background:var(--red);}
.timeline-item.upcoming::before{background:var(--amber);}
.tl-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.tl-date{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;}
.tl-fw{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;}
.tl-body{font-size:12px;color:var(--text-sec);}
.tl-owner{font-size:11px;color:var(--text-muted);margin-top:4px;}

/* Cross-framework mapping */
.mapping-card{background:var(--bg);border:1px solid var(--border-light);border-radius:8px;padding:16px;margin-bottom:10px;}
.mapping-frameworks{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px;}
.mapping-fw-tag{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:3px 8px;border-radius:3px;}
.mapping-desc{font-size:12px;color:var(--text-sec);}

/* Two column layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.modal-overlay.open{display:flex;animation:fadeIn 0.15s ease;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;max-width:640px;width:90%;max-height:90vh;overflow-y:auto;}
.modal h2{margin-bottom:16px;}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-light);}

/* Empty state */
.empty{text-align:center;padding:60px 20px;color:var(--text-muted);}
.empty-title{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-sec);}
.empty-desc{font-size:13px;margin-bottom:20px;}
.empty-icon{font-size:48px;margin-bottom:16px;opacity:0.3;}

/* Dash header */
.dash-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;}
.dash-sub{font-size:13px;color:var(--text-sec);margin-top:4px;}
.dash-acts{display:flex;gap:8px;flex-wrap:wrap;}

.footer{max-width:1200px;margin:40px auto 0;padding:20px 24px;border-top:1px solid var(--border-light);text-align:center;}
.footer p{font-size:11px;color:var(--text-muted);margin-bottom:4px;}
.footer a{color:var(--accent);text-decoration:none;}
.footer strong{color:var(--text-sec);}

/* Filter chips */
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;}
.filter-chip{font-family:inherit;font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-sec);cursor:pointer;transition:all 0.15s;}
.filter-chip:hover{border-color:var(--accent);color:var(--text);}
.filter-chip.active{background:var(--accent);border-color:var(--accent);color:white;}

/* Responsive */
@media(max-width:768px){
  .form-grid,.two-col{grid-template-columns:1fr;}
  .three-col{grid-template-columns:1fr;}
  .metrics-grid{grid-template-columns:repeat(2,1fr);}
  .gauge-grid{grid-template-columns:repeat(2,1fr);}
  .detail-grid{grid-template-columns:1fr;}
  .risk-row{grid-template-columns:1fr;gap:6px;}
  .tab-bar{flex-wrap:nowrap;overflow-x:auto;}
  .dash-top{flex-direction:column;gap:12px;}
  .wizard-sector-grid{grid-template-columns:1fr;}
  .risk-matrix-container{flex-direction:column;}
}

/* AI Advisor */
.ai-panel{background:var(--accent-light);border:1px solid var(--accent);border-radius:8px;padding:16px;margin-top:16px;animation:fadeIn 0.2s ease;}
.ai-label{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;color:var(--accent);letter-spacing:1px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;}
.ai-section{margin-bottom:10px;}
.ai-section-title{font-size:11px;font-weight:600;margin-bottom:4px;}
.ai-section-title.evidence{color:var(--accent);}
.ai-section-title.gap{color:var(--amber);}
.ai-section-title.remediation{color:var(--accent2);}

@media print{
  .app-header,.tab-bar,.dash-acts,.modal-overlay,.footer,.btn,.wizard-overlay,.search-bar,.filter-bar{display:none!important;}
  body{background:white;color:#1f2937;}
  .card,.strategy-card,.control-row,.assessment-card{background:white;border-color:#d0d5dd;box-shadow:none;}
  .met{border-color:#d0d5dd;}
  .met-val{color:#1f2937!important;}
  .status-badge{border:1px solid #d0d5dd;}
  .gauge-arc{stroke:#1f2937!important;}
}
