:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-tertiary: #1a2234;--bg-elevated: #222d42;--accent-primary: #22d3ee;--accent-success: #34d399;--accent-warning: #fbbf24;--accent-danger: #f87171;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--border-primary: #1e293b;--border-accent: rgba(34, 211, 238, .3);--gradient-glow: linear-gradient(135deg, rgba(34, 211, 238, .1) 0%, rgba(129, 140, 248, .1) 100%);--gradient-card: linear-gradient(180deg, rgba(26, 34, 52, .8) 0%, rgba(17, 24, 39, .9) 100%)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}#root{display:flex;min-height:100vh;animation:fadeIn .5s ease}.sidebar{width:260px;min-height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-primary);position:fixed;left:0;top:0;bottom:0;display:flex;flex-direction:column}.logo-section{padding:24px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#22d3ee,#818cf8);display:flex;align-items:center;justify-content:center;font-size:20px}.logo-text h1{font-size:18px;font-weight:700;background:linear-gradient(135deg,#22d3ee,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-text p{font-size:10px;color:var(--text-tertiary);letter-spacing:1px}.nav{padding:16px;flex:1}.nav-section{margin-bottom:16px}.nav-section-title{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;padding:8px 16px}.nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:4px;background:transparent;border:1px solid transparent;border-radius:10px;color:var(--text-secondary);cursor:pointer;font-size:14px;text-align:left;transition:all .2s}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--gradient-glow);border-color:var(--border-accent);color:var(--accent-primary)}.main{margin-left:260px;padding:32px 48px;flex:1;min-height:100vh}.main.full{margin-left:0;padding:0;display:flex;align-items:center;justify-content:center}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-primary)}.sidebar-footer{padding:24px;border-top:1px solid var(--border-primary)}.status-badge{padding:8px 16px;background:#34d39926;border-radius:9999px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--accent-success)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-success);animation:pulse 2s infinite}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#818cf8,#22d3ee);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#0a0e17;cursor:pointer}.card{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:16px;padding:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}.stat-card{position:relative;overflow:hidden}.stat-label{font-size:13px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;font-family:Courier New,monospace}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-icon.primary{background:#22d3ee26}.stat-icon.danger{background:#f8717126}.stat-icon.warning{background:#fbbf2426}.stat-icon.success{background:#34d39926}.stat-card-clickable:hover{background:linear-gradient(180deg,#22d3ee14,#111827e6);transform:translateY(-2px)}.stat-card-clickable:active{transform:translateY(0)}.charts-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;margin-bottom:32px}.chart-title{font-size:16px;font-weight:600;margin-bottom:24px}.chart-area{height:200px;background:var(--bg-secondary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);position:relative;overflow:hidden}.chart-bars{display:flex;align-items:flex-end;justify-content:space-around;height:100%;padding:20px;gap:8px}.chart-bar{width:30px;background:linear-gradient(to top,#22d3ee,#818cf8);border-radius:4px 4px 0 0;transition:height .5s ease}.coverage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.coverage-grid-matrix{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.coverage-item{padding:24px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border-primary);transition:background-color .2s,transform .1s}.coverage-clickable:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.coverage-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.coverage-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.coverage-icon.danger{background:#f8717126}.coverage-icon.warning{background:#fbbf2426}.coverage-icon.success{background:#34d39926}.coverage-label{font-size:13px;color:var(--text-tertiary)}.coverage-value{font-size:20px;font-weight:700;font-family:Courier New,monospace}.coverage-value span{font-size:14px;color:var(--text-tertiary);font-weight:400}.progress-bar{height:6px;background:var(--bg-tertiary);border-radius:9999px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;border-radius:9999px;transition:width .5s ease}.progress-fill.danger{background:var(--accent-danger)}.progress-fill.warning{background:var(--accent-warning)}.progress-fill.success{background:var(--accent-success)}.progress-label{font-size:12px;color:var(--text-tertiary);text-align:right}.table-card{padding:0;overflow:hidden}table{width:100%;border-collapse:collapse}th{text-align:left;padding:14px 16px;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border-primary)}tr:hover td{background:var(--bg-tertiary)}.asset-cell{display:flex;align-items:center;gap:12px}.asset-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.asset-name{font-weight:500}.asset-ip{font-size:12px;color:var(--text-tertiary);font-family:Courier New,monospace}.badge{display:inline-flex;padding:4px 10px;border-radius:9999px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.badge.default{background:var(--bg-elevated);color:var(--text-secondary)}.badge.critical{background:#f8717126;color:#f87171}.badge.high{background:#fb923c26;color:#fb923c}.badge.medium{background:#fbbf2426;color:#fbbf24}.badge.low{background:#34d39926;color:#34d399}.badge.primary{background:#22d3ee26;color:#22d3ee}.badge.warning{background:#fbbf2426;color:#fbbf24}.risk-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px}.risk-dot.critical{background:#f87171}.risk-dot.high{background:#fb923c}.risk-dot.medium{background:#fbbf24}.risk-dot.low{background:#34d399}.security-icons{display:flex;gap:8px}.security-icon{opacity:.3;font-size:16px}.security-icon.active{opacity:1}.tags{display:flex;gap:4px;flex-wrap:wrap}.page-header{margin-bottom:32px}.page-title{font-size:24px;font-weight:600;margin-bottom:8px}.page-subtitle{color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-size:14px;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:linear-gradient(135deg,#22d3ee,#818cf8);color:#0a0e17;font-weight:600}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary)}.btn-danger{background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.3)}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;filter:grayscale(30%)}.btn-secondary:disabled{background:#ffffff0d;color:#fff6}.oss-badge{padding:16px;background:var(--gradient-glow);border:1px solid var(--border-accent);border-radius:10px}.oss-badge-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;font-weight:600;color:var(--accent-primary)}.oss-badge p{font-size:12px;color:var(--text-tertiary)}.filter-bar{display:flex;gap:16px;align-items:center}.search-input,.form-input{flex:1;max-width:400px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;color:var(--text-primary);font-size:14px;outline:none}.search-input:focus,.form-input:focus{border-color:var(--accent-primary)}.form-input{max-width:none;width:100%}.filter-select{padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;color:var(--text-primary);font-size:14px;cursor:pointer}.login-container{width:400px}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:8px;color:var(--text-secondary);font-size:14px}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.alert-error{background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.3)}.alert-success{background:#34d39926;color:#34d399;border:1px solid rgba(52,211,153,.3)}.loading{display:flex;align-items:center;justify-content:center;padding:64px}.spinner{width:32px;height:32px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.user-menu{position:relative}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:8px;min-width:200px;z-index:100}.user-dropdown-item{display:block;width:100%;padding:10px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;text-align:left;cursor:pointer;border-radius:6px}.user-dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;padding:32px;max-width:500px;width:90%}.modal-title{font-size:20px;font-weight:600;margin-bottom:24px}.key-display{padding:16px;background:var(--bg-tertiary);border-radius:8px;font-family:Courier New,monospace;word-break:break-all;margin:16px 0}.copy-btn{padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;margin-top:8px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-close{width:32px;height:32px;background:transparent;border:none;border-radius:8px;color:var(--text-tertiary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-primary)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-tertiary);font-size:13px;text-transform:capitalize}.detail-value{color:var(--text-primary);font-size:14px;text-align:right}.detail-value.mono{font-family:Courier New,monospace}details.card>summary{list-style:none}details.card>summary::-webkit-details-marker{display:none}details.card[open]>summary{margin-bottom:8px}.lifecycle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}.lifecycle-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}.lifecycle-items{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.lifecycle-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-secondary);border-radius:10px;border:1px solid var(--border-primary);transition:background-color .2s,transform .1s}.lifecycle-clickable:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.lifecycle-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.lifecycle-icon.danger{background:#f8717126}.lifecycle-icon.warning{background:#fbbf2426}.lifecycle-icon.caution{background:#fb923c26}.lifecycle-icon.success{background:#34d39926}.lifecycle-info{flex:1}.lifecycle-label{font-size:12px;color:var(--text-tertiary);margin-bottom:2px}.lifecycle-count{font-size:24px;font-weight:700;font-family:Courier New,monospace}.lifecycle-count.danger{color:var(--accent-danger)}.lifecycle-count.warning{color:var(--accent-warning)}.lifecycle-count.caution{color:#fb923c}.lifecycle-count.success{color:var(--accent-success)}@media(max-width:1200px){.lifecycle-grid{grid-template-columns:1fr}.lifecycle-items{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.lifecycle-items{grid-template-columns:repeat(2,1fr)}}.risk-score-panel{padding:24px}.risk-score-header{margin-bottom:24px}.risk-score-main{display:flex;align-items:center;margin-bottom:12px}.risk-score-label{font-size:14px;color:var(--text-tertiary);margin-right:12px}.risk-score-value{font-size:32px;font-weight:700;font-family:Courier New,monospace}.risk-score-bar{height:8px;background:var(--bg-tertiary);border-radius:9999px;overflow:hidden}.risk-score-bar-fill{height:100%;border-radius:9999px;transition:width .5s ease}.risk-factors-section{border-top:1px solid var(--border-primary);padding-top:20px}.risk-factors-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:16px}.risk-factors-list{display:flex;flex-direction:column;gap:12px}.risk-factor-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;overflow:hidden;transition:border-color .2s}.risk-factor-card:hover{border-color:var(--border-accent)}.risk-factor-header{display:flex;align-items:center;gap:12px;padding:16px}.risk-factor-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.risk-factor-info{flex:1;min-width:0}.risk-factor-title{display:block;font-size:14px;font-weight:500;color:var(--text-primary)}.risk-factor-description{display:block;font-size:12px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.risk-factor-score{font-size:16px;font-weight:700;font-family:Courier New,monospace;flex-shrink:0}.risk-factor-expand{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:18px;flex-shrink:0}.risk-factor-details{padding:0 16px 16px;border-top:1px solid var(--border-primary);margin-top:0}.risk-factor-section{margin-top:16px}.risk-factor-section h5{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.risk-factor-evidence{display:grid;gap:6px}.evidence-item{display:flex;gap:8px;font-size:13px}.evidence-label{color:var(--text-tertiary);text-transform:capitalize}.evidence-value{color:var(--text-primary);font-family:Courier New,monospace}.risk-factor-remediation{font-size:13px;color:var(--text-secondary);line-height:1.5}.risk-factor-links{display:flex;flex-wrap:wrap;gap:8px}.risk-factor-link{display:inline-flex;padding:4px 10px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.2);border-radius:6px;font-size:12px;font-family:Courier New,monospace;color:var(--accent-primary);text-decoration:none;transition:all .2s}.risk-factor-link:hover{background:#22d3ee33;border-color:#22d3ee66}.risk-factors-total{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-primary)}.risk-factors-total span:first-child{font-size:14px;color:var(--text-secondary)}.risk-factors-total-value{font-size:20px;font-weight:700;font-family:Courier New,monospace;color:var(--text-primary)}.gauges-section{margin-bottom:32px}.gauges-section .chart-title{margin-bottom:20px}.gauges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;max-width:700px}.gauge-widget{display:flex;flex-direction:column;align-items:center;padding:20px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;transition:all .2s}.gauge-clickable:hover{background:var(--bg-tertiary);transform:translateY(-2px);border-color:var(--border-accent)}.gauge-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-top:8px;text-align:center}.gauge-target{font-size:12px;color:var(--text-tertiary);margin-top:4px}.gauge-fill{transition:stroke-dasharray .8s ease-out}@media(max-width:768px){.gauges-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.gauges-grid{grid-template-columns:1fr}}.executive-dashboard{max-width:1200px}.exec-header{display:flex;justify-content:space-between;align-items:flex-start}.exec-header-actions{display:flex;align-items:center;gap:16px}.exec-date{font-size:14px;color:var(--text-tertiary)}.exec-hero{display:grid;grid-template-columns:1fr 2fr;gap:32px;margin-bottom:32px}.exec-hero-left,.exec-hero-right{background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:16px;padding:32px}.exec-hero h3{font-size:14px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:24px}.posture-grade-container{text-align:center}.posture-grade{font-size:96px;font-weight:700;line-height:1;margin-bottom:8px}.posture-description{font-size:18px;font-weight:600;margin-bottom:8px}.posture-score{font-size:16px;color:var(--text-tertiary);margin-bottom:16px}.posture-trend{font-size:14px;display:flex;align-items:center;justify-content:center;gap:4px}.trend-icon{font-size:18px}.exec-metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.exec-metric-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:20px;text-align:center}.exec-metric-icon{font-size:24px;margin-bottom:8px}.exec-metric-label{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.exec-metric-value{font-size:28px;font-weight:700;font-family:Courier New,monospace}.exec-metric-unit{font-size:16px;color:var(--text-tertiary);font-weight:400}.exec-metric-trend{font-size:13px;margin-top:8px}.exec-section{margin-bottom:32px}.exec-section-title{font-size:18px;font-weight:600;margin-bottom:8px}.exec-section-subtitle{font-size:14px;color:var(--text-tertiary);margin-bottom:24px}.exec-no-data{padding:32px;text-align:center;color:var(--text-tertiary)}.business-unit-chart{display:flex;flex-direction:column;gap:16px}.bu-row{display:grid;grid-template-columns:150px 1fr 60px 90px;gap:16px;align-items:center}.bu-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bu-bar-container{height:24px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.bu-bar{height:100%;border-radius:4px;transition:width .5s ease}.bu-score{font-size:16px;font-weight:600;font-family:Courier New,monospace;text-align:right}.bu-level{font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:4px 8px;border-radius:4px;text-align:center}.bu-level.low{background:#34d39926;color:var(--accent-success)}.bu-level.medium{background:#fbbf2426;color:var(--accent-warning)}.bu-level.high{background:#f8717126;color:var(--accent-danger)}.action-item-list{display:flex;flex-direction:column;gap:12px}.action-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px}.action-priority{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:50%;font-size:14px;font-weight:700;color:var(--text-secondary)}.action-icon{font-size:20px}.action-content{flex:1}.action-title{font-size:15px;font-weight:600;margin-bottom:4px}.action-description{font-size:13px;color:var(--text-tertiary)}.action-count{font-size:24px;font-weight:700;font-family:Courier New,monospace}.exec-footer{text-align:center;padding:24px;color:var(--text-tertiary);font-size:12px;border-top:1px solid var(--border-primary);margin-top:32px}.exec-error{text-align:center;padding:64px}.exec-error h3{font-size:20px;margin-bottom:8px}.exec-error p{color:var(--text-tertiary)}@media print{:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-elevated: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--border-primary: #e2e8f0}body{background:#fff;color:#000}.sidebar{display:none!important}.main{margin-left:0!important;padding:20px!important}.header,.no-print{display:none!important}.executive-dashboard{max-width:none}.exec-hero{break-inside:avoid}.card{break-inside:avoid;box-shadow:none;border:1px solid #e2e8f0}.posture-grade{font-size:72px}.bu-bar,.bu-level{print-color-adjust:exact;-webkit-print-color-adjust:exact}@page{size:A4;margin:15mm}}@media(max-width:1024px){.exec-hero{grid-template-columns:1fr}.exec-metrics-grid{grid-template-columns:repeat(4,1fr)}.bu-row{grid-template-columns:120px 1fr 50px 80px}}@media(max-width:768px){.exec-metrics-grid{grid-template-columns:repeat(2,1fr)}.bu-row{grid-template-columns:1fr;gap:8px}.bu-name{order:1}.bu-bar-container{order:2}.bu-score{order:3;text-align:left}.bu-level{order:4;width:fit-content}}.ai-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#22d3ee,#818cf8);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#0a0e17;box-shadow:0 4px 20px #22d3ee66;transition:transform .2s,box-shadow .2s;z-index:900}.ai-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #22d3ee80}.ai-fab-hint{position:absolute;right:70px;top:50%;transform:translateY(-50%);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text-secondary);white-space:nowrap;opacity:0;transition:opacity .2s;pointer-events:none}.ai-fab:hover .ai-fab-hint{opacity:1}.ai-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.ai-modal{width:600px;max-width:90vw;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.ai-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600}.ai-icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#22d3ee,#818cf8);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#0a0e17}.ai-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-tertiary);font-size:20px;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center}.ai-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ai-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.ai-messages{flex:1;overflow-y:auto;padding:20px}.ai-welcome{text-align:center;padding:20px}.ai-welcome p{color:var(--text-secondary);margin-bottom:16px}.ai-examples{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.ai-example{padding:8px 14px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:20px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.ai-example:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-accent)}.ai-message{margin-bottom:16px}.ai-message-user{display:flex;justify-content:flex-end}.ai-message-user .ai-message-content{background:linear-gradient(135deg,#22d3ee33,#818cf833);border:1px solid var(--border-accent);border-radius:16px 16px 4px;padding:12px 16px;max-width:80%}.ai-message-assistant .ai-message-content{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:16px 16px 16px 4px;padding:12px 16px;max-width:90%}.ai-message-content p{margin:0;line-height:1.5}.ai-query-result{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-primary)}.ai-query-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.ai-query-code{display:block;background:var(--bg-secondary);padding:10px 14px;border-radius:8px;font-size:13px;color:var(--accent-primary);margin-bottom:12px;word-break:break-all}.ai-query-actions{display:flex;gap:8px}.btn-sm{padding:6px 12px;font-size:12px}.ai-typing{display:flex;gap:4px;padding:4px 0}.ai-typing span{width:8px;height:8px;background:var(--text-tertiary);border-radius:50%;animation:pulse 1.4s infinite}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}.ai-error{background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:8px;padding:12px 16px;color:#f87171;font-size:14px;margin-top:8px}.ai-input-form{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.ai-input{flex:1;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;color:var(--text-primary);font-size:14px;outline:none}.ai-input:focus{border-color:var(--accent-primary)}.ai-input::placeholder{color:var(--text-tertiary)}.ai-submit{padding:12px 20px;background:linear-gradient(135deg,#22d3ee,#818cf8);border:none;border-radius:10px;color:#0a0e17;font-weight:600;font-size:14px;cursor:pointer;transition:transform .2s}.ai-submit:hover:not(:disabled){transform:translateY(-1px)}.ai-submit:disabled{opacity:.5;cursor:not-allowed}.ai-footer{padding:12px 20px;border-top:1px solid var(--border-primary);display:flex;justify-content:space-between;font-size:11px;color:var(--text-tertiary)}.ai-footer kbd{padding:2px 6px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;font-family:Courier New,monospace}.ai-not-configured{text-align:center;padding:48px 24px}.ai-not-configured-icon{width:48px;height:48px;margin:0 auto 16px;background:#fbbf2426;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--accent-warning)}.ai-not-configured-title{font-size:18px;font-weight:600;margin-bottom:8px}.ai-not-configured p{color:var(--text-secondary);margin-bottom:20px}.ai-loading{text-align:center;padding:48px 24px}.ai-loading p{color:var(--text-secondary);margin-top:16px}.dashboard-container{width:100%}.dashboard-grid{position:relative}.dashboard-grid .react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.dashboard-grid .react-grid-item.cssTransforms{transition-property:transform,width,height}.dashboard-grid .react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.dashboard-grid .react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.dashboard-grid .react-grid-placeholder{background:var(--accent-primary);opacity:.2;transition-duration:.1s;z-index:2;border-radius:12px}.widget-container{height:100%}.widget-container .card{height:100%;overflow:hidden}.dashboard-grid.edit-mode .widget-container{cursor:move}.dashboard-grid.edit-mode .widget-container:hover{outline:2px dashed var(--accent-primary);outline-offset:-2px;border-radius:14px}.react-resizable-handle{position:absolute;width:20px;height:20px}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-se:after{content:"";position:absolute;right:4px;bottom:4px;width:10px;height:10px;border-right:2px solid var(--text-tertiary);border-bottom:2px solid var(--text-tertiary)}.customizable-dashboard{display:flex;flex-direction:column;height:calc(100vh - 120px)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.dashboard-header-left{display:flex;flex-direction:column;gap:4px}.dashboard-header-actions{display:flex;gap:12px;align-items:center}.dashboard-grid-container{flex:1;position:relative}.dashboard-grid-container.edit-mode{background:repeating-linear-gradient(0deg,transparent,transparent 80px,rgba(255,255,255,.03) 80px,rgba(255,255,255,.03) 81px),repeating-linear-gradient(90deg,transparent,transparent calc((100% - 176px) / 12),rgba(255,255,255,.03) calc((100% - 176px) / 12),rgba(255,255,255,.03) calc((100% - 176px) / 12 + 1px));border-radius:12px;padding:8px}.dashboard-grid{min-height:400px}.dashboard-widget-wrapper{background:transparent}.dashboard-widget-content{height:100%;position:relative}.dashboard-widget-content .card{height:100%;margin:0}.dashboard-widget-content.edit-mode{outline:2px dashed var(--border-accent);border-radius:12px}.widget-edit-controls{position:absolute;top:8px;right:8px;z-index:10;display:flex;gap:4px}.widget-drag-handle{width:28px;height:28px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:grab;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .2s}.widget-drag-handle:hover{background:var(--bg-elevated);color:var(--text-primary)}.widget-drag-handle:active{cursor:grabbing}.widget-remove-btn{width:28px;height:28px;background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#f87171;transition:all .2s}.widget-remove-btn:hover{background:#f8717140}.widget-unknown{height:100%;background:var(--bg-tertiary);border:1px dashed var(--border-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.empty-dashboard,.no-dashboard{text-align:center;padding:80px 40px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-dashboard h3,.no-dashboard h3{font-size:20px;margin-bottom:8px}.empty-dashboard p,.no-dashboard p{color:var(--text-secondary);margin-bottom:24px}.dashboard-selector{position:relative}.dashboard-selector-trigger{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;cursor:pointer;transition:all .2s}.dashboard-selector-trigger:hover{background:var(--bg-elevated);border-color:var(--border-accent)}.dashboard-selector-name{font-size:18px;font-weight:600}.dashboard-selector-icon{font-size:20px}.dashboard-selector-arrow{color:var(--text-tertiary);transition:transform .2s}.dashboard-selector-trigger.open .dashboard-selector-arrow{transform:rotate(180deg)}.dashboard-dropdown{position:absolute;top:100%;left:0;right:0;min-width:280px;margin-top:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 8px 32px #0006;z-index:100;overflow:hidden}.dashboard-dropdown-section{padding:8px;border-bottom:1px solid var(--border-primary)}.dashboard-dropdown-section:last-child{border-bottom:none}.dashboard-dropdown-title{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px}.dashboard-dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s}.dashboard-dropdown-item:hover{background:var(--bg-tertiary)}.dashboard-dropdown-item.active{background:var(--gradient-glow)}.dashboard-dropdown-item-icon{font-size:16px}.dashboard-dropdown-item-name{flex:1;font-size:14px}.dashboard-dropdown-item-badge{padding:2px 6px;font-size:10px;border-radius:4px;background:#22d3ee26;color:var(--accent-primary)}.dashboard-dropdown-item-actions{display:flex;gap:4px}.dashboard-dropdown-action{width:24px;height:24px;background:transparent;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .15s}.dashboard-dropdown-action:hover{background:var(--bg-elevated);color:var(--text-primary)}.dashboard-dropdown-action.delete:hover{color:#f87171}.dashboard-dropdown-create{display:flex;align-items:center;gap:8px;padding:10px 12px;color:var(--accent-primary);font-size:14px;cursor:pointer;border-radius:8px;transition:all .15s}.dashboard-dropdown-create:hover{background:var(--bg-tertiary)}.widget-palette-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center}.widget-palette{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.widget-palette-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.widget-palette-header h3{font-size:18px}.widget-palette-close{width:32px;height:32px;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center}.widget-palette-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.widget-palette-body{padding:24px;overflow-y:auto}.widget-palette-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.widget-palette-item{padding:20px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:12px;cursor:pointer;transition:all .2s}.widget-palette-item:hover{background:var(--bg-elevated);border-color:var(--border-accent)}.widget-palette-item-icon{font-size:28px;margin-bottom:12px}.widget-palette-item-name{font-size:15px;font-weight:600;margin-bottom:4px}.widget-palette-item-desc{font-size:12px;color:var(--text-tertiary)}.template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}.template-card{padding:16px;background:var(--bg-tertiary);border:2px solid var(--border-primary);border-radius:10px;cursor:pointer;text-align:center;transition:all .2s}.template-card:hover{background:var(--bg-elevated)}.template-card.selected{border-color:var(--accent-primary);background:#22d3ee1a}.template-icon{font-size:28px;margin-bottom:8px}.template-name{font-size:13px;font-weight:600;margin-bottom:4px}.template-desc{font-size:11px;color:var(--text-tertiary)}.react-grid-item.react-grid-placeholder{background:#22d3ee33;border:2px dashed var(--accent-primary);border-radius:12px}.react-grid-item>.react-resizable-handle{opacity:0;transition:opacity .2s}.dashboard-grid-container.edit-mode .react-grid-item>.react-resizable-handle{opacity:1}.react-resizable-handle:after{border-color:var(--accent-primary)!important}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px;opacity:0}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}
