.sidebar{position:fixed;left:0;top:0;width:256px;height:100vh;background:#3d5a80;color:#fff;display:flex;flex-direction:column;transition:transform .3s ease;z-index:1000;overflow-y:auto;box-shadow:2px 0 8px #00000026}.sidebar.collapsed{transform:translate(-256px)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.menu-toggle{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.menu-toggle:hover{transform:scale(1.1)}.logo{font-size:20px;font-weight:700;letter-spacing:.5px}.search-box{padding:20px;position:relative}.search-box input{width:100%;padding:10px 40px 10px 12px;border:none;border-radius:6px;background:#ffffff26;color:#fff;font-size:14px;outline:none;transition:background .2s ease}.search-box input::placeholder{color:#fff9}.search-box input:focus{background:#ffffff40}.search-btn{position:absolute;right:28px;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;cursor:pointer;font-size:16px;padding:4px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:14px 24px;background:none;border:none;color:#ffffffd9;font-size:14px;text-align:left;cursor:pointer;transition:all .2s ease;border-left:3px solid transparent}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;color:#fff;border-left-color:#98c1d9;font-weight:500}.nav-icon{font-size:18px;width:24px;display:flex;align-items:center;justify-content:center}.nav-label{flex:1}.sign-out{margin-top:auto;border-top:1px solid rgba(255,255,255,.1)}.sign-out:hover{background:#ff646433}.sidebar-expand-btn{position:fixed;left:12px;top:16px;z-index:1001;width:40px;height:40px;border:none;border-radius:8px;background:#3d5a80;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:all .2s ease}.sidebar-expand-btn:hover{background:#4a6fa5;transform:scale(1.05)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#3d5a80;color:#fff;box-shadow:0 2px 8px #0000001a}.header-title{font-size:20px;font-weight:500}.user-info{display:flex;align-items:center;gap:16px}.user-details{text-align:right}.user-name{font-size:14px;font-weight:500}.org-name{font-size:12px;opacity:.8}.user-avatar{width:36px;height:36px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:18px}.logo-badge{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff1a;border-radius:6px}.logo-icon{width:24px;height:24px;background:#fff;color:#3d5a80;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.logo-text{font-weight:500;font-size:14px}.voice-assistant-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #10b9814d}.voice-assistant-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.voice-assistant-btn:active{transform:translateY(0);box-shadow:0 2px 6px #10b9814d}.voice-assistant-btn svg{flex-shrink:0}.boxy-icon{width:24px;height:24px;object-fit:contain;flex-shrink:0}.voice-chat-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.voice-chat-modal{background:#1a1f3540;backdrop-filter:blur(25px) saturate(180%);-webkit-backdrop-filter:blur(25px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:0;width:calc(100% - 400px);height:100vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000001a;overflow:hidden;animation:slideUp .3s ease;margin-right:400px}.voice-chat-header{padding:32px 48px;border-bottom:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;align-items:center;background:#00000026;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.voice-chat-title{display:flex;align-items:center;gap:16px;font-size:28px;font-weight:600;color:#fff}.voice-chat-title svg{width:32px;height:32px;color:#3b82f6}.voice-chat-context{font-size:15px;color:#fff9;margin-top:6px;font-weight:400}.voice-language-selector{margin-top:8px}.voice-language-selector label{font-size:13px;color:#fff9;margin-right:8px}.voice-language-selector select{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.voice-language-selector select:hover{background:#ffffff26;border-color:#ffffff4d}.voice-language-selector select option{background:#1a1f35;color:#fff}.voice-chat-close{background:#ffffff1a;border:none;color:#fff;width:44px;height:44px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.voice-chat-close svg{width:24px;height:24px}.voice-chat-close:hover{background:#fff3;transform:scale(1.05)}.voice-chat-body{flex:1;overflow-y:auto;padding:48px;display:flex;flex-direction:column;gap:24px;max-width:1200px;margin:0 auto;width:100%}.voice-message{display:flex;gap:12px;animation:messageSlideIn .3s ease}.voice-message.user{flex-direction:row-reverse}.message-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-avatar.user{background:linear-gradient(135deg,#3b82f6,#2563eb)}.message-avatar.assistant{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.message-avatar svg{width:20px;height:20px;color:#fff}.message-content{max-width:80%;padding:18px 24px;border-radius:20px;font-size:17px;line-height:1.6;letter-spacing:.2px}.voice-message.user .message-content{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-bottom-right-radius:4px}.voice-message.assistant .message-content{background:#ffffff1f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.1);border-bottom-left-radius:4px}.voice-chat-controls{padding:32px 48px;border-top:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;gap:20px;background:#00000026;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.voice-status{display:flex;align-items:center;justify-content:center;gap:12px;min-height:32px}.voice-status-text{font-size:16px;color:#ffffffb3;font-weight:500}.listening-indicator{display:flex;gap:4px;align-items:center}.listening-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;animation:pulse 1.5s ease-in-out infinite}.listening-dot:nth-child(2){animation-delay:.2s}.listening-dot:nth-child(3){animation-delay:.4s}.speaking-indicator{display:flex;gap:3px;align-items:flex-end;height:20px}.speaking-wave{width:3px;background:linear-gradient(180deg,#f97316,#ea580c);border-radius:3px;animation:soundWave 1s ease-in-out infinite}.speaking-wave:nth-child(1){animation-delay:0s}.speaking-wave:nth-child(2){animation-delay:.2s}.speaking-wave:nth-child(3){animation-delay:.4s}.speaking-text{color:#f97316!important;font-weight:600}@keyframes soundWave{0%,to{height:8px}50%{height:20px}}.voice-transcript{background:#ffffff14;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:20px 24px;min-height:64px;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fffffff2;text-align:center;line-height:1.5;position:relative;gap:8px}.voice-clear-transcript-btn{background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ef4444;flex-shrink:0;transition:all .2s ease;padding:0}.voice-clear-transcript-btn:hover{background:#ef444459;border-color:#ef444499}.voice-buttons{display:flex;gap:12px;justify-content:center}.voice-record-btn{width:88px;height:88px;border-radius:50%;border:none;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 20px #ef444466;position:relative}.voice-record-btn:hover{transform:scale(1.05);box-shadow:0 6px 30px #ef444499}.voice-record-btn.recording{animation:recordPulse 1.5s ease-in-out infinite}.voice-record-btn.recording:before{content:"";position:absolute;top:-8px;left:-8px;right:-8px;bottom:-8px;border-radius:50%;border:2px solid #ef4444;animation:ripple 1.5s ease-out infinite}.voice-record-btn svg{width:40px;height:40px}.voice-record-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.voice-action-btn{padding:16px 32px;border-radius:14px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:10px}.voice-action-btn:hover{background:#ffffff1f;border-color:#ffffff4d}.voice-action-btn svg{width:20px;height:20px}.voice-stop-btn{padding:18px 36px;border-radius:14px;border:2px solid #f97316;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;cursor:pointer;font-size:17px;font-weight:600;transition:all .2s;display:flex;align-items:center;gap:12px;box-shadow:0 4px 16px #f9731666;animation:stopPulse 2s ease-in-out infinite}.voice-stop-btn:hover{background:linear-gradient(135deg,#ea580c,#c2410c);border-color:#ea580c;transform:scale(1.05);box-shadow:0 6px 24px #f9731699}.voice-stop-btn svg{width:24px;height:24px}.voice-stop-btn span{font-weight:600;letter-spacing:.3px}@keyframes stopPulse{0%,to{box-shadow:0 4px 16px #f9731666}50%{box-shadow:0 4px 24px #f97316b3}}.voice-empty-state{text-align:center;padding:80px 48px;color:#ffffff80}.voice-empty-state svg{width:96px;height:96px;margin:0 auto 24px;opacity:.5}.voice-empty-state h3{font-size:24px;margin-bottom:12px;color:#fff;font-weight:600}.voice-empty-state p{font-size:17px;line-height:1.6;max-width:600px;margin:0 auto}.loading-message{display:flex;align-items:center;gap:12px}.loading-dots{display:flex;gap:4px}.loading-dot{width:8px;height:8px;border-radius:50%;background:#ffffff80;animation:bounce 1.4s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes recordPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes ripple{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.chart-filters{position:relative;display:inline-block}.filters-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;color:#4a6fa5;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.filters-toggle-btn:hover{background:#f8f9fa;border-color:#4a6fa5;transform:translateY(-1px);box-shadow:0 2px 4px #4a6fa533}.filters-toggle-btn.has-filters{background:#f0f4ff;border-color:#2563eb;color:#2563eb}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#2563eb;color:#fff;border-radius:9px;font-size:11px;font-weight:700;line-height:1}.filters-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e0e0e0}.filters-header h4{margin:0;font-size:16px;font-weight:600;color:#1a1a1a}.filters-close-btn{background:transparent;border:none;font-size:18px;color:#666;cursor:pointer;width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.filters-close-btn:hover{background:#f0f0f0;color:#333}.filters-body{padding:20px;display:flex;flex-direction:column;gap:16px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-size:13px;font-weight:600;color:#333;display:flex;align-items:center;gap:6px}.date-input,.filter-select{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;background:#fff;transition:all .2s;outline:none}.date-input:focus,.filter-select:focus{border-color:#4a6fa5;box-shadow:0 0 0 3px #4a6fa51a}.date-input:hover,.filter-select:hover{border-color:#4a6fa5}.filter-select{cursor:pointer}.filters-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid #e0e0e0}.filter-reset-btn,.filter-apply-btn{flex:1;padding:10px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.filter-reset-btn{background:#f0f0f0;color:#666}.filter-reset-btn:hover{background:#e0e0e0;color:#333}.filter-apply-btn{background:#4a6fa5;color:#fff}.filter-apply-btn:hover{background:#3d5a80;transform:translateY(-1px);box-shadow:0 2px 6px #4a6fa54d}.drill-down-breadcrumb{background:linear-gradient(135deg,#667eea,#764ba2);padding:12px 24px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px #667eea33}.breadcrumb-container{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.breadcrumb-segment{display:flex;align-items:center;gap:4px}.breadcrumb-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff26;border:none;border-radius:4px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.breadcrumb-item:not(:disabled):hover{background:#ffffff40;transform:translateY(-1px)}.breadcrumb-item.active{background:#ffffff4d;cursor:default}.breadcrumb-item:disabled{cursor:default}.breadcrumb-home svg{width:14px;height:14px}.breadcrumb-separator{color:#fff9;margin:0 2px}.breadcrumb-context{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.2);font-size:12px}.context-label{color:#fffc;font-weight:500}.context-value{color:#fff;font-weight:600}.chart-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.chart-card:hover{box-shadow:0 6px 16px #0000001f}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#1a1a1a}.chart-actions{display:flex;align-items:center;gap:10px}.analyze-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #2563eb40;white-space:nowrap}.analyze-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #2563eb59}.drilldown-btn{display:flex;align-items:center;gap:5px;padding:7px 14px;background:#f0f4ff;color:#2563eb;border:1px solid #c7d7fe;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.drilldown-btn:hover{background:#dbeafe;border-color:#93b4fd}.drilldown-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.voice-chat-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#f8fafc;border:1px solid #e2e8f0;border-radius:50%;cursor:pointer;transition:all .2s ease;flex-shrink:0}.voice-chat-btn:hover{background:#e2e8f0;transform:scale(1.1);box-shadow:0 2px 8px #0000001a}.voice-btn-icon{width:20px;height:20px;border-radius:50%;object-fit:cover}.info-wrapper{position:relative;display:inline-flex}.info-btn{background:none;border:1px solid transparent;font-size:12px;font-weight:700;font-style:italic;font-family:Georgia,serif;color:#94a3b8;cursor:pointer;padding:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:50%}.info-btn:hover,.info-btn.active{background:#f0f4ff;color:#2563eb;border-color:#c7d7fe}.info-popover{position:absolute;top:calc(100% + 8px);left:0;width:360px;background:#fff;border-radius:12px;box-shadow:0 12px 40px #00000026,0 0 0 1px #0000000d;z-index:1000;animation:infoSlideIn .2s ease;overflow:hidden}@keyframes infoSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.info-popover-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #f1f5f9;background:#f8fafc}.info-popover-header h4{margin:0;font-size:14px;font-weight:600;color:#1e293b}.info-popover-close{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s}.info-popover-close:hover{background:#e2e8f0;color:#475569}.info-popover-body{padding:16px}.info-context{margin:0 0 14px;font-size:13px;line-height:1.5;color:#64748b}.info-stats{display:flex;gap:12px;margin-bottom:14px}.info-stat-item{flex:1;display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.info-stat-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.03em}.info-stat-value{font-size:18px;font-weight:700;color:#1e293b}.info-summary-table{border-radius:8px;overflow:hidden;border:1px solid #f1f5f9}.info-summary-table table{width:100%;border-collapse:collapse;font-size:12px}.info-summary-table thead{background:#f8fafc}.info-summary-table th{padding:8px 10px;text-align:left;font-weight:600;color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid #f1f5f9}.info-summary-table td{padding:7px 10px;color:#334155;border-bottom:1px solid #f8fafc}.info-summary-table tbody tr:last-child td{border-bottom:none}.info-summary-table tbody tr:hover{background:#fafbfc}.maximize-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#64748b;flex-shrink:0}.maximize-btn:hover{background:#e2e8f0;color:#2563eb;border-color:#c7d7fe;transform:scale(1.05)}.chart-maximize-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;animation:overlayFadeIn .25s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.chart-maximized{width:100%;max-width:1400px;max-height:calc(100vh - 48px);overflow-y:auto;animation:maximizeIn .3s ease;box-shadow:0 24px 64px #0000003d}@keyframes maximizeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.chart-maximized .chart-container{height:calc(100vh - 200px)}.chart-maximized .recharts-responsive-container{height:100%!important}.chart-maximized .drilldown-scroll{max-height:calc(100vh - 240px);overflow-y:auto}.chart-loading-spinner{display:flex;flex-direction:column;align-items:center;gap:12px;color:#94a3b8;font-size:13px}.spinner-ring{width:32px;height:32px;border:3px solid #f1f5f9;border-top-color:#2563eb;border-radius:50%;animation:spinnerRotate .8s linear infinite}@keyframes spinnerRotate{to{transform:rotate(360deg)}}.expand-btn{background:none;border:none;font-size:16px;color:#666;cursor:pointer;padding:4px;transition:all .2s ease;border-radius:4px}.expand-btn:hover{background:#f0f0f0;color:#4a6fa5;transform:scale(1.1)}.chart-container{margin:20px 0}.chart-info{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8f9fa;border-radius:6px;font-size:14px;color:#666;margin-top:16px;animation:slideIn .3s ease}.chart-info strong{color:#4a6fa5;margin:0 4px}.clear-btn{padding:4px 12px;background:#4a6fa5;color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease}.clear-btn:hover{background:#3d5a80;transform:scale(1.05)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.recharts-wrapper{cursor:crosshair}.recharts-surface{overflow:visible}.recharts-tooltip-wrapper{z-index:100}.drilldown-container{margin-top:8px;animation:slideIn .3s ease}.drilldown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 4px}.drilldown-count{font-size:12px;font-weight:600;color:#64748b}.drilldown-scroll{overflow-x:auto;border:1px solid #e2e8f0;border-radius:8px}.drilldown-table{width:100%;border-collapse:collapse;font-size:12px}.drilldown-table thead{background:#f8fafc;position:sticky;top:0}.drilldown-table th{padding:8px 12px;text-align:left;font-weight:600;color:#475569;font-size:11px;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid #e2e8f0;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.drilldown-table th:hover{background:#eef2f7}.drilldown-table th .sort-indicator{margin-left:3px;opacity:.35;font-size:10px}.drilldown-table th .sort-indicator.active{opacity:1;color:#2563eb}.drilldown-table td{padding:7px 12px;border-bottom:1px solid #f1f5f9;color:#334155;white-space:nowrap}.drilldown-table tbody tr:hover{background:#f8fafc}.drilldown-table tbody tr:last-child td{border-bottom:none}.drilldown-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 0 4px;font-size:12px;color:#64748b}.drilldown-pagination button{padding:4px 12px;border:1px solid #d1d5db;background:#fff;border-radius:4px;font-size:12px;cursor:pointer;color:#374151;transition:all .15s}.drilldown-pagination button:hover:not(:disabled){background:#f0f4ff;border-color:#2563eb;color:#2563eb}.drilldown-pagination button:disabled{opacity:.4;cursor:not-allowed}.drilldown-empty{padding:40px;text-align:center;color:#94a3b8;font-size:14px}.map-controls{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000d}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:#14b8a6}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-label{font-size:13px;font-weight:500;color:#475569}.map-container{position:relative;overflow:hidden;border-radius:8px;border:1px solid #e2e8f0}.chart-title-row{display:flex;align-items:center;gap:12px;flex:1}.info-filters-section{margin:16px 0;padding:12px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.info-filters-header{font-size:12px;font-weight:600;color:#475569;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.info-filters-list{display:flex;flex-wrap:wrap;gap:6px}.info-filter-tag{display:inline-flex;align-items:center;padding:4px 10px;background:#fff;border:1px solid #cbd5e1;border-radius:4px;font-size:12px;color:#1e293b;font-weight:500}.bookmarks-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.bookmarks-modal{background:#f8f9fa;border-radius:16px;width:95%;max-width:1600px;height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.bookmarks-header{padding:24px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0000001a}.bookmarks-header-left{display:flex;align-items:center;gap:16px}.bookmarks-header-icon{width:32px;height:32px;background:#fff3;border-radius:8px;display:flex;align-items:center;justify-content:center}.bookmarks-header h2{margin:0;font-size:24px;font-weight:700}.bookmarks-meta{display:flex;align-items:center;gap:24px;font-size:14px;color:#ffffffe6}.bookmarks-meta-item{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff26;border-radius:6px}.bookmarks-close{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:10px 16px;font-size:14px;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:8px}.bookmarks-close:hover{background:#ffffff4d;transform:translateY(-2px)}.bookmarks-content{flex:1;overflow-y:auto;padding:32px}.bookmarks-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;text-align:center}.bookmarks-empty-icon{font-size:80px;margin-bottom:24px;opacity:.3}.bookmarks-empty h3{font-size:24px;font-weight:600;margin:0 0 12px;color:#333}.bookmarks-empty p{font-size:16px;margin:0 0 24px;color:#666}.bookmarks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(600px,1fr));gap:24px}.bookmark-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;overflow:hidden}.bookmark-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.bookmark-card-header{padding:16px 20px;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between}.bookmark-card-title{font-size:16px;font-weight:600;color:#1a1a1a;margin:0;display:flex;align-items:center;gap:10px}.bookmark-card-actions{display:flex;gap:8px}.bookmark-action-btn{background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:6px 10px;cursor:pointer;font-size:12px;color:#666;transition:all .2s ease;display:flex;align-items:center;gap:4px}.bookmark-action-btn:hover{background:#f5f7fa;border-color:#2563eb;color:#2563eb}.bookmark-action-btn.remove{color:#dc2626}.bookmark-action-btn.remove:hover{border-color:#dc2626;background:#fef2f2}.bookmark-card-content{padding:20px;height:350px}@media (max-width: 1400px){.bookmarks-grid{grid-template-columns:repeat(auto-fill,minmax(500px,1fr))}}@media (max-width: 1200px){.bookmarks-grid{grid-template-columns:1fr}}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:24px}.metric-card{background:#fff;border-radius:8px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014;border-top:4px solid;cursor:pointer;transition:all .3s ease;position:relative}.metric-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0000001f}.metric-card.selected{box-shadow:0 6px 20px #00000026;transform:scale(1.02)}.metric-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.metric-content{flex:1}.metric-label{font-size:12px;color:#666;font-weight:500;margin-bottom:4px;letter-spacing:.5px}.metric-value{font-size:28px;font-weight:700;color:#1a1a1a}.metric-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.checkmark{color:#4caf50;font-size:20px;animation:checkmarkPop .3s ease}@keyframes checkmarkPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.filters-panel{position:fixed;right:0;top:0;width:400px;height:100vh;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;transition:transform .3s ease;z-index:999;overflow-y:auto;box-shadow:-2px 0 8px #00000026}.filters-panel.collapsed{transform:translate(400px)}@media (max-width: 1400px){.filters-panel{width:350px}.filters-panel.collapsed{transform:translate(350px)}}.filters-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.toggle-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;transition:transform .2s ease}.toggle-btn:hover{transform:scale(1.1)}.filters-header h3{font-size:18px;font-weight:600;color:#1a1a1a}.search-filter{position:relative;padding:16px;border-bottom:1px solid #e0e0e0}.search-filter input{width:100%;padding:10px 36px 10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s ease}.search-filter input:focus{border-color:#4a6fa5}.search-icon{position:absolute;right:28px;top:50%;transform:translateY(-50%);font-size:16px;color:#666}.filters-content{flex:1;padding:16px;overflow-y:auto}.filter-section{margin-bottom:12px}.filter-label{font-size:13px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.filter-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.filter-header span{font-size:14px;font-weight:500;color:#333}.pin-btn{background:none;border:none;font-size:14px;cursor:pointer;padding:4px;opacity:.5;transition:all .2s ease}.pin-btn:hover{opacity:1;transform:scale(1.1)}.filter-item select,.filter-input{width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;outline:none;transition:all .2s ease}.filter-item select:hover,.filter-input:hover{border-color:#4a6fa5}.filter-item select:focus,.filter-input:focus{border-color:#4a6fa5;box-shadow:0 0 0 3px #4a6fa51a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0}.modal-header h2{font-size:24px;font-weight:600;color:#1a1a1a;margin:0}.close-btn{background:none;border:none;font-size:32px;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.close-btn:hover{background:#f0f0f0;color:#1a1a1a}.modal-body{padding:24px}.info-section{margin-bottom:24px}.info-section h3{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:8px}.info-section p{color:#666;line-height:1.6;margin-bottom:16px}.status-indicator{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:600;font-size:14px}.status-indicator.active{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-indicator.inactive{background:#fff3cd;color:#856404;border:1px solid #ffc107}.status-icon{font-size:18px}.instructions code{background:#e9ecef;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:13px;color:#d63384}.instructions{background:#f8f9fa;padding:16px;border-radius:8px;border-left:4px solid #4a6fa5}.instructions h4{font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:12px}.instructions ol{margin-left:20px;color:#666;line-height:1.8}.instructions ol li{margin-bottom:4px}.instructions a{color:#4a6fa5;text-decoration:none;font-weight:500}.instructions a:hover{text-decoration:underline}.input-section{margin-bottom:20px}.input-section label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.input-wrapper{position:relative;display:flex;align-items:center}.api-key-input{flex:1;padding:12px 45px 12px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:monospace;outline:none;transition:border-color .2s ease}.api-key-input:focus{border-color:#4a6fa5}.toggle-visibility{position:absolute;right:8px;background:none;border:none;font-size:20px;cursor:pointer;padding:8px;border-radius:4px;transition:background .2s ease}.toggle-visibility:hover{background:#f0f0f0}.saved-indicator{margin-top:8px;color:#4caf50;font-size:13px;font-weight:500}.security-note{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px;font-size:13px;line-height:1.6;color:#856404}.security-note strong{font-weight:600}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e0e0e0}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary{background:#4a6fa5;color:#fff}.btn-primary:hover{background:#3d5a80;transform:translateY(-1px);box-shadow:0 4px 12px #4a6fa54d}.btn-secondary{background:#f0f0f0;color:#666}.btn-secondary:hover{background:#e0e0e0;color:#333}.rca-container{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;background:#fafbfc}.rca-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;transition:background .2s;-webkit-user-select:none;user-select:none}.rca-header:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.rca-header-left{display:flex;align-items:center;gap:8px}.rca-tree-icon{color:#2563eb;flex-shrink:0}.rca-header-title{font-size:13px;font-weight:600;color:#1e293b}.rca-badge{font-size:10px;font-weight:600;padding:2px 8px;background:#dbeafe;color:#2563eb;border-radius:10px;letter-spacing:.02em}.rca-collapse-icon{color:#94a3b8;transition:transform .2s ease;display:flex;align-items:center}.rca-collapse-icon.expanded{transform:rotate(180deg)}.rca-body{padding:16px;animation:rcaSlideIn .25s ease}@keyframes rcaSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.rca-summary{font-size:12px;line-height:1.6;color:#64748b;padding:10px 12px;background:#fff;border-radius:8px;border-left:3px solid #2563eb;margin-bottom:14px}.rca-legend{display:flex;gap:16px;margin-bottom:14px;padding:0 4px}.rca-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:#64748b}.rca-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rca-tree-root{padding-left:0}.rca-tree-node-wrapper{position:relative}.rca-tree-children{padding-left:20px;border-left:2px solid #e2e8f0;margin-left:14px;animation:rcaChildrenIn .2s ease}@keyframes rcaChildrenIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.rca-tree-children>.rca-tree-node-wrapper{position:relative}.rca-tree-children>.rca-tree-node-wrapper:before{content:"";position:absolute;left:-20px;top:18px;width:16px;height:2px;background:#e2e8f0}.rca-tree-node{display:flex;flex-direction:column;gap:6px;padding:10px 12px;margin:4px 0;background:#fff;border-radius:8px;border:1px solid #e2e8f0;transition:all .15s ease}.rca-tree-node:hover{border-color:#cbd5e1;box-shadow:0 2px 6px #0000000f}.rca-depth-0{background:linear-gradient(135deg,#fff,#f8fafc);border-width:2px}.rca-impact-high{border-left:3px solid #ef4444}.rca-impact-medium{border-left:3px solid #f59e0b}.rca-impact-low{border-left:3px solid #22c55e}.rca-node-header{display:flex;align-items:center;gap:6px}.rca-expand-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;color:#94a3b8;transition:transform .2s ease;flex-shrink:0}.rca-expand-icon.expanded{transform:rotate(90deg)}.rca-direction-badge{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:700;flex-shrink:0}.rca-direction-badge.positive{background:#dcfce7;color:#16a34a}.rca-direction-badge.negative{background:#fee2e2;color:#dc2626}.rca-direction-badge.neutral{background:#f1f5f9;color:#64748b}.rca-node-label{font-size:12px;font-weight:600;color:#1e293b;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rca-node-meta{display:flex;align-items:center;gap:8px;padding-left:44px}.rca-node-value{font-size:11px;font-weight:500;color:#64748b;white-space:nowrap}.rca-confidence-bar{flex:1;height:4px;background:#f1f5f9;border-radius:2px;overflow:hidden;min-width:40px}.rca-confidence-fill{height:100%;border-radius:2px;transition:width .5s ease}.rca-confidence-text{font-size:10px;font-weight:600;color:#94a3b8;white-space:nowrap;min-width:28px;text-align:right}.enh-container{display:flex;flex-direction:column;gap:16px}.enh-health-gauge{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;animation:enhFadeIn .4s ease}@keyframes enhFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.enh-gauge-ring{position:relative;width:120px;height:120px;margin:0 auto 12px}.enh-gauge-svg{width:100%;height:100%}.enh-gauge-progress{transition:stroke-dashoffset 1s ease}.enh-gauge-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.enh-gauge-score{font-size:28px;font-weight:800;line-height:1}.enh-gauge-label{font-size:11px;font-weight:600;color:#64748b;margin-top:2px;text-transform:uppercase;letter-spacing:.04em}.enh-health-factors{display:flex;flex-direction:column;gap:6px}.enh-factor-row{display:flex;align-items:center;gap:8px}.enh-factor-name{font-size:11px;color:#64748b;width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.enh-factor-bar-track{flex:1;height:4px;background:#f1f5f9;border-radius:2px;overflow:hidden}.enh-factor-bar-fill{height:100%;border-radius:2px;transition:width .8s ease}.enh-factor-score{font-size:11px;font-weight:600;color:#475569;width:24px;text-align:right}.enh-stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.enh-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;animation:enhFadeIn .4s ease}.enh-stat-label{font-size:10px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.enh-stat-value{font-size:18px;font-weight:700;color:#1e293b;line-height:1.2}.enh-stat-trend{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:4px}.enh-trend-arrow{font-size:12px}.enh-trend-up{color:#059669}.enh-trend-down{color:#dc2626}.enh-trend-flat{color:#64748b}.enh-sparkline-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px 8px;animation:enhFadeIn .5s ease}.enh-sparkline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.enh-sparkline-title{font-size:12px;font-weight:600;color:#1e293b}.enh-sparkline-range{font-size:10px;color:#94a3b8;font-weight:500}.enh-sparkline-svg{width:100%;height:48px;display:block}.enh-sparkline-labels{display:flex;justify-content:space-between;font-size:9px;color:#94a3b8;margin-top:4px}.enh-section-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;border-radius:8px 8px 0 0;background:#f8fafc;border:1px solid #e2e8f0;border-bottom:none;-webkit-user-select:none;user-select:none;transition:background .15s}.enh-section-header:hover{background:#f1f5f9}.enh-section-header-left{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#1e293b}.enh-anomaly-count,.enh-action-count{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;background:#fee2e2;color:#dc2626}.enh-action-count{background:#dbeafe;color:#2563eb}.enh-chevron{color:#94a3b8;transition:transform .2s ease;display:flex}.enh-chevron.expanded{transform:rotate(180deg)}.enh-anomaly-section,.enh-actions-section{animation:enhFadeIn .4s ease}.enh-anomaly-list,.enh-actions-list{border:1px solid #e2e8f0;border-top:none;border-radius:0 0 8px 8px;overflow:hidden;animation:enhSlideDown .25s ease}@keyframes enhSlideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:600px}}.enh-anomaly-item{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-bottom:1px solid #f1f5f9;background:#fff;transition:background .15s}.enh-anomaly-item:last-child{border-bottom:none}.enh-anomaly-item:hover{background:#fafbfc}.enh-severity-critical{border-left:3px solid #dc2626}.enh-severity-warning{border-left:3px solid #f59e0b}.enh-severity-info{border-left:3px solid #3b82f6}.enh-anomaly-icon{font-size:14px;flex-shrink:0;margin-top:1px}.enh-anomaly-content{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.enh-anomaly-msg{font-size:12px;color:#334155;line-height:1.4}.enh-anomaly-badge{display:inline-flex;align-self:flex-start;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:4px}.enh-badge-critical{background:#fee2e2;color:#dc2626}.enh-badge-warning{background:#fef3c7;color:#b45309}.enh-badge-info{background:#dbeafe;color:#2563eb}.enh-action-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid #f1f5f9;background:#fff;cursor:pointer;transition:all .15s}.enh-action-item:last-child{border-bottom:none}.enh-action-item:hover{background:#f8fafc}.enh-action-item.completed{opacity:.5}.enh-action-item.completed .enh-action-text{text-decoration:line-through}.enh-action-check{width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;transition:all .15s}.enh-action-check.checked{background:#2563eb;border-color:#2563eb}.enh-action-body{flex:1;min-width:0}.enh-action-text{font-size:12px;color:#334155;line-height:1.4;margin-bottom:4px}.enh-action-meta{display:flex;align-items:center;gap:6px}.enh-priority-dot{font-size:10px}.enh-dot-high{color:#dc2626}.enh-dot-medium{color:#f59e0b}.enh-dot-low{color:#22c55e}.enh-action-category{font-size:10px;font-weight:500;color:#94a3b8}.enh-priority-high{border-left:3px solid #dc2626}.enh-priority-medium{border-left:3px solid #f59e0b}.enh-priority-low{border-left:3px solid #22c55e}.enh-export-bar{display:flex;gap:8px}.enh-export-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;font-weight:500;color:#475569;cursor:pointer;transition:all .15s}.enh-export-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.enh-export-btn.copied{background:#dcfce7;border-color:#86efac;color:#059669}.analysis-panel{position:fixed;right:0;top:60px;width:400px;height:calc(100vh - 60px);background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;transition:transform .3s ease;z-index:10001;box-shadow:-2px 0 8px #0000000d}.analysis-panel.collapsed{transform:translate(400px)}.analysis-panel.empty{background:#fafafa}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;text-align:center;color:#666}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:20px;margin:0 0 12px;color:#333;font-weight:600}.empty-state p{font-size:14px;color:#666;line-height:1.6;margin:0}.analysis-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background:#fafafa}.analysis-title{display:flex;align-items:center;gap:10px}.analysis-icon{width:28px;height:28px;object-fit:contain;flex-shrink:0}.analysis-title h3{margin:0;font-size:18px;font-weight:600;color:#1a1a1a}.close-btn{background:transparent;border:none;font-size:20px;color:#666;cursor:pointer;width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#e0e0e0;color:#333}.header-actions{display:flex;align-items:center;gap:8px}.toggle-btn{background:transparent;border:none;font-size:14px;color:#666;cursor:pointer;width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;font-weight:700}.toggle-btn:hover{background:#e0e0e0;color:#4a6fa5;transform:scale(1.1)}.analysis-body{flex:1;overflow-y:auto;padding:20px}.panel-tabs{display:flex;gap:2px;padding:0 0 16px;border-bottom:2px solid #f0f0f0;margin-bottom:16px}.panel-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 4px;background:transparent;border:none;border-bottom:2px solid transparent;font-size:11px;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;margin-bottom:-18px}.panel-tab:hover{color:#475569;background:#f8fafc;border-radius:6px 6px 0 0}.panel-tab.active{color:#2563eb;border-bottom-color:#2563eb}.panel-tab svg{flex-shrink:0}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#2563eb;color:#fff;font-size:9px;font-weight:700;line-height:1}.chart-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.chart-info-header h4{margin:0;font-size:16px;font-weight:600;color:#1a1a1a}.refresh-btn{background:transparent;border:none;font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#f0f0f0}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#4a90e2;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-state p{color:#666;font-size:14px;margin:0}.error-state{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-state p{color:#d32f2f;font-size:14px;margin:0 0 16px;line-height:1.6}.error-state button{padding:8px 20px;background:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.error-state button:hover{background:#357abd}.insights-container{display:flex;flex-direction:column;gap:20px}.insight-section{display:flex;flex-direction:column;gap:10px}.insight-label{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:#1a1a1a}.insight-label .icon{font-size:18px}.insight-section .formatted-content{padding:16px;background:#fff;border-radius:8px;line-height:1.6;color:#333;font-size:14px;border-left:4px solid transparent}.insight-section.predictive .formatted-content{border-left-color:#4caf50;background:#f1f8f4}.insight-section.prescriptive .formatted-content{border-left-color:#ff9800;background:#fff8f0}.chat-history{margin-top:10px}.chat-label{font-weight:600;font-size:14px;color:#1a1a1a;margin-bottom:12px}.chat-message{margin-bottom:12px;animation:fadeIn .3s ease-in;display:flex;align-items:flex-start;gap:8px}.chat-message.user{flex-direction:row-reverse}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-avatar{flex-shrink:0;width:32px;height:32px;border-radius:8px;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.message-avatar img{width:100%;height:100%;object-fit:cover}.chat-message.user .message-content{background:#4a90e2;color:#fff;padding:12px 16px;border-radius:12px 12px 4px;font-size:14px;line-height:1.5;max-width:280px}.chat-message.assistant .message-content{background:#f5f5f5;color:#333;padding:12px 16px;border-radius:12px 12px 12px 4px;font-size:14px;line-height:1.5;max-width:280px}.suggested-prompts{margin-top:10px}.prompts-label{font-size:13px;font-weight:600;color:#666;margin-bottom:10px}.prompts-list{display:flex;flex-direction:column;gap:8px}.prompt-btn{background:#fff;border:1px solid #e0e0e0;padding:10px 14px;border-radius:8px;text-align:left;cursor:pointer;font-size:13px;color:#4a90e2;transition:all .2s;line-height:1.4}.prompt-btn:hover:not(:disabled){background:#f8f9fa;border-color:#4a90e2;transform:translate(2px)}.prompt-btn:disabled{opacity:.5;cursor:not-allowed}.follow-up-section{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.follow-up-form{display:flex;gap:8px}.follow-up-input{flex:1;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.follow-up-input:focus{border-color:#4a90e2}.follow-up-input:disabled{background:#f5f5f5;cursor:not-allowed}.send-btn{width:40px;height:40px;background:#4a90e2;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.send-btn:hover:not(:disabled){background:#357abd}.send-btn:disabled{opacity:.5;cursor:not-allowed}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.voice-active{background:#4caf50!important;color:#fff!important}.voice-control-section{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f5f5f5;border-radius:8px}.voice-status-inline{text-align:center;font-size:14px;font-weight:500}.voice-listening{color:#ef4444;animation:pulse 1.5s ease-in-out infinite}.voice-ready{color:#666}.voice-transcript-inline{padding:12px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;font-style:italic;color:#333;text-align:left;min-height:44px;display:flex;align-items:center;line-height:1.5;gap:8px}.voice-transcript-inline .voice-clear-transcript-btn{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:50%;width:24px;height:24px;min-width:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#ef4444;flex-shrink:0;transition:all .2s ease;padding:0;margin-left:auto}.voice-transcript-inline .voice-clear-transcript-btn:hover{background:#ef444433;border-color:#ef444480}.voice-buttons-row{display:flex;gap:8px;width:100%}.voice-record-btn-inline{flex:1;padding:12px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.voice-record-btn-inline:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.voice-record-btn-inline:disabled{opacity:.5;cursor:not-allowed}.voice-record-btn-inline.recording{background:#f97316;animation:pulse 1.5s ease-in-out infinite}.voice-send-btn{flex:1;padding:12px 24px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.voice-send-btn:hover:not(:disabled){background:#388e3c;transform:translateY(-1px)}.voice-send-btn:disabled{opacity:.5;cursor:not-allowed}.voice-speaking{color:#3b82f6;font-weight:500;animation:pulse 1.5s ease-in-out infinite}.voice-processing{color:#f59e0b;font-weight:500}.voice-stop-speaking-btn{flex:1;padding:12px 24px;background:#6b7280;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.voice-stop-speaking-btn:hover{background:#4b5563}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.formatted-content{display:block}.formatted-line{margin-bottom:8px}.formatted-line:last-child{margin-bottom:0}.formatted-bullet{margin-bottom:6px;padding-left:8px}.formatted-bullet:last-child{margin-bottom:0}.formatted-bold{font-weight:700;color:#1a1a1a}.message-content .formatted-content{padding:0;background:transparent;border:none}.message-content .formatted-line{margin-bottom:6px}.message-content .formatted-bold{font-weight:600}@media (max-width: 1400px){.analysis-panel{width:350px}}@media (max-width: 1200px){.analysis-panel{width:300px}.analysis-body{padding:16px}}.page-level-filters{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:20px 24px;margin-bottom:24px;box-shadow:0 4px 12px #667eea26;color:#fff}.page-level-filters.loading{display:flex;align-items:center;justify-content:center;padding:16px;font-size:14px;opacity:.8}.page-filter-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;opacity:.95}.page-filter-label svg{opacity:.9}.page-filter-controls{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.page-filter-group{display:flex;flex-direction:column;gap:6px;min-width:180px;flex:1}.page-filter-group label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.page-filter-select{padding:10px 14px;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;outline:none}.page-filter-select:hover{background:#ffffff40;border-color:#ffffff80}.page-filter-select:focus{background:#ffffff40;border-color:#ffffffb3;box-shadow:0 0 0 3px #ffffff1a}.page-filter-select option{background:#4a5568;color:#fff;padding:10px}.page-filter-select.locked-filter{background:#ffffff14;border-color:#ffffff26;cursor:not-allowed;opacity:.85}.page-filter-select.locked-filter:hover{background:#ffffff14;border-color:#ffffff26}.lock-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);opacity:.7;color:#fff}.page-filter-group{position:relative}.page-filter-reset{padding:10px 18px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .3s ease;white-space:nowrap}.page-filter-reset:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.page-filter-reset:active{transform:translateY(0)}.active-filters-indicator{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.2)}.filter-badge{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-tag{display:inline-block;padding:6px 12px;background:#ffffff40;border-radius:20px;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 1024px){.page-filter-controls{gap:12px}.page-filter-group{min-width:150px}}@media (max-width: 768px){.page-level-filters{padding:16px}.page-filter-controls{flex-direction:column;align-items:stretch}.page-filter-group{min-width:100%}.page-filter-reset{width:100%;justify-content:center}}.od-map-card{overflow:visible}.od-map-stats{display:flex;gap:16px;margin-bottom:16px}.od-stat{flex:1;display:flex;flex-direction:column;gap:2px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.od-stat-value{font-size:20px;font-weight:700;color:#1e293b}.od-stat-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.od-map-wrapper{position:relative;height:420px;border-radius:10px;overflow:hidden;border:1px solid #e2e8f0;background:#f0f0f0}.od-google-map{width:100%;height:100%}.od-map-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#ffffffd9;z-index:10;font-size:13px;color:#64748b}.spinner-ring{display:inline-block;width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.od-map-legend{position:absolute;bottom:16px;right:16px;background:#fff;padding:10px 16px;border-radius:8px;box-shadow:0 2px 8px #0000001f;display:flex;align-items:center;gap:14px;font-size:12px;z-index:5}.od-legend-title{font-weight:600;color:#1e293b}.od-legend-item{display:flex;align-items:center;gap:6px;color:#475569}.od-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.od-map-fallback{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.od-fallback-content{text-align:center;max-width:500px;padding:24px}.od-fallback-content p{color:#64748b;font-size:13px;line-height:1.6;margin:12px 0 20px}.od-fallback-content code{background:#e2e8f0;padding:2px 6px;border-radius:4px;font-size:12px;color:#334155}.od-route-list{text-align:left;width:100%}.od-route-list h4{font-size:13px;font-weight:600;color:#334155;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.od-route-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f1f5f9}.od-route-item:last-child{border-bottom:none}.od-route-names{display:flex;align-items:center;gap:6px;font-size:13px}.od-route-origin{font-weight:600;color:#14b8a6}.od-route-dest{font-weight:600;color:#3b82f6}.od-route-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:#64748b}.od-route-bar-wrap{width:60px;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden;display:inline-block}.od-route-bar{display:block;height:100%;background:linear-gradient(90deg,#14b8a6,#3b82f6);border-radius:3px;transition:width .3s ease}.toggle-label-left{font-size:13px;font-weight:500;color:#94a3b8}.toggle-switch input:checked~.toggle-label-left{color:#94a3b8}@media (max-width: 768px){.od-map-stats{flex-wrap:wrap}.od-stat{min-width:calc(50% - 8px)}.od-map-wrapper{height:300px}}.detail-page{position:fixed;top:0;left:0;right:0;bottom:0;background:#f8f9fa;z-index:9999;display:flex;flex-direction:column;overflow:hidden}.detail-page-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0000000d}.detail-page-header-left{display:flex;align-items:center;gap:16px}.detail-back-button{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px;transition:all .2s ease}.detail-back-button:hover{background:#f5f7fa;border-color:#2563eb;color:#2563eb;transform:translate(-2px)}.detail-page-title{font-size:20px;font-weight:700;color:#1a1a1a;margin:0}.detail-page-meta{display:flex;align-items:center;gap:12px;font-size:14px}.detail-meta-badge{background:#f5f7fa;border:1px solid #e0e0e0;border-radius:6px;padding:6px 12px;color:#666;font-weight:500}.detail-meta-badge.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.detail-page-content{flex:1;overflow-y:auto;padding:24px 32px}.detail-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}.detail-chart-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;transition:all .2s ease}.detail-chart-card:hover{box-shadow:0 4px 16px #0000001f}.detail-chart-header{font-size:16px;font-weight:600;color:#1a1a1a;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.detail-chart-container{height:300px}.detail-page-loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:16px;color:#666}.detail-page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;text-align:center}.detail-page-empty-icon{font-size:64px;margin-bottom:16px;opacity:.3}.detail-page-empty h3{font-size:20px;font-weight:600;margin:0 0 8px;color:#333}.detail-page-empty p{font-size:14px;margin:0;color:#666}@media (max-width: 1400px){.detail-charts-grid{grid-template-columns:1fr}}.app{display:flex;min-height:100vh;background:#f5f7fa;position:relative}.main-content{flex:1;margin-left:256px;margin-right:0;transition:margin-left .3s ease,margin-right .3s ease;min-height:100vh;width:100%;background:#f5f7fa}.main-content.sidebar-closed{margin-left:0}@media (min-width: 1400px){.main-content{margin-right:0}}.main-content.analysis-visible{margin-right:400px}@media (max-width: 1400px){.main-content.analysis-visible{margin-right:0}}.dashboard-container{padding:24px;max-width:1600px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard-header h1{font-size:24px;font-weight:600;color:#1a1a1a;margin:0}.ai-settings-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.ai-settings-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.settings-icon{font-size:18px}.control-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.last-refreshed{font-size:14px;color:#666}.view-controls{display:flex;gap:8px}.view-btn{padding:8px 16px;border:1px solid #e0e0e0;background:#fff;border-radius:4px;font-size:14px;color:#666;cursor:pointer;transition:all .2s ease}.view-btn:hover{background:#f5f7fa;border-color:#4a6fa5;color:#4a6fa5}.view-btn.active{background:#4a6fa5;color:#fff;border-color:#4a6fa5}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width: 1400px){.main-content{margin-right:0}.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.main-content{margin-left:0}.control-bar{flex-direction:column;gap:12px}.view-controls{flex-wrap:wrap}}.floating-show-btn{position:fixed;right:20px;bottom:20px;width:56px;height:56px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50%;font-size:24px;cursor:pointer;box-shadow:0 4px 16px #667eea66;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.floating-show-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #667eea99}.floating-show-btn:active{transform:scale(.95)}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.app-loading .loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.no-access-message{display:flex;align-items:center;justify-content:center;min-height:400px;padding:48px}.no-access-content{text-align:center;max-width:500px}.no-access-icon{display:flex;align-items:center;justify-content:center;width:100px;height:100px;margin:0 auto 24px;background:linear-gradient(135deg,#e8eaf6,#c5cae9);border-radius:50%;color:#5c6bc0}.no-access-content h2{font-size:24px;font-weight:600;color:#333;margin:0 0 12px}.no-access-content p{font-size:16px;color:#666;margin:0 0 8px;line-height:1.5}.no-access-content .redirect-hint{margin-top:20px;padding:16px;background:#e3f2fd;border-radius:8px;color:#1565c0}.no-access-content .redirect-hint strong{color:#0d47a1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease;padding:20px;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;animation:slideUp .3s ease;max-height:90vh;display:flex;flex-direction:column}.modal-large{max-width:800px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:24px 32px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-header h2{margin:0;font-size:22px;font-weight:600;color:#1a1a1a}.modal-close{background:none;border:none;font-size:32px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;line-height:1}.modal-close:hover{background:#f0f0f0;color:#333}.modal-body{padding:32px;overflow-y:auto;flex:1}.modal-footer{padding:20px 32px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;flex-shrink:0}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.form-group input[type=text],.form-group input[type=number],.form-group input[type=time],.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;padding:12px;border-radius:8px;transition:all .2s ease;font-weight:500}.checkbox-label:hover{background:#f8f9fa}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#4a90e2}.checkbox-group{display:grid;gap:8px}.radio-group{display:flex;gap:12px;flex-wrap:wrap}.radio-label{cursor:pointer}.radio-label input[type=radio]{display:none}.priority-badge{display:inline-block;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;border:2px solid #e0e0e0;transition:all .2s ease}.radio-label input:checked+.priority-badge.critical{background:linear-gradient(135deg,#e57373,#ef5350);color:#fff;border-color:#e57373}.radio-label input:checked+.priority-badge.high{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-color:#ff9800}.radio-label input:checked+.priority-badge.medium{background:linear-gradient(135deg,#ffb74d,#ffa726);color:#fff;border-color:#ffb74d}.radio-label input:checked+.priority-badge.low{background:linear-gradient(135deg,#81c784,#66bb6a);color:#fff;border-color:#81c784}.info-box{padding:16px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:8px;border-left:4px solid #2196f3;display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.5;color:#333;margin-top:16px}.info-box.warning{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left-color:#ff9800}.info-icon{font-size:18px;flex-shrink:0}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-secondary{background:#fff;color:#666;border:2px solid #e0e0e0}.btn-secondary:hover{background:#f8f9fa;border-color:#4a90e2;color:#4a90e2}.format-options{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.format-option{border:2px solid #e0e0e0;border-radius:12px;padding:20px 12px;text-align:center;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:6px}.format-option input[type=radio]{display:none}.format-option:hover{border-color:#4a90e2;background:#f8f9fa}.format-option.selected{border-color:#4a90e2;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.format-icon{font-size:28px;margin-bottom:4px}.format-name{font-weight:600;font-size:14px;color:#1a1a1a}.format-desc{font-size:11px;color:#666}.export-info{margin-top:20px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.info-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#666}.info-row strong{color:#1a1a1a;font-weight:600}.scenario-inputs{display:flex;flex-direction:column;gap:24px;margin:24px 0}.scenario-slider label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.slider-container{display:flex;align-items:center;gap:16px}.slider{flex:1;height:8px;border-radius:4px;background:linear-gradient(to right,#e57373,#f0f0f0,#66bb6a);outline:none;-webkit-appearance:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#4a90e2;cursor:pointer;box-shadow:0 2px 8px #4a90e266}.slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#4a90e2;cursor:pointer;border:none;box-shadow:0 2px 8px #4a90e266}.slider-value{font-size:18px;font-weight:700;min-width:60px;text-align:center}.slider-value.positive{color:#66bb6a}.slider-value.negative{color:#e57373}.impact-preview{margin:24px 0;padding:24px;background:linear-gradient(135deg,#f8f9fa,#e3f2fd);border-radius:12px;border:2px solid #4a90e2}.impact-preview h3{margin:0 0 20px;font-size:16px;font-weight:600;color:#1a1a1a}.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.impact-card{background:#fff;padding:20px;border-radius:12px;text-align:center;box-shadow:0 2px 8px #00000014}.impact-label{font-size:12px;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.impact-value{font-size:28px;font-weight:700;color:#1a1a1a;margin-bottom:4px}.impact-change{font-size:14px;font-weight:600;color:#4a90e2}.quick-scenarios{margin-top:24px}.quick-scenarios h4{font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.scenario-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.scenario-buttons button{padding:12px 16px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;color:#333}.scenario-buttons button:hover{border-color:#4a90e2;background:#f8f9fa;color:#4a90e2}.model-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;border-radius:12px;text-align:center;color:#fff}.stat-label{font-size:12px;opacity:.9;margin-bottom:8px;font-weight:500}.stat-value{font-size:24px;font-weight:700}.training-benefits{margin-top:20px;padding:16px;background:#f8f9fa;border-radius:8px}.training-benefits h4{font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.training-benefits ul{list-style:none;padding:0;margin:0}.training-benefits li{padding:6px 0;font-size:14px;color:#666}@media (max-width: 768px){.modal-content{max-width:100%;margin:10px;max-height:95vh}.form-row,.format-options,.impact-grid,.scenario-buttons{grid-template-columns:1fr}.modal-header,.modal-body{padding:20px}.modal-footer{padding:16px 20px}}.wif-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:box-shadow .3s ease}.wif-card:hover{box-shadow:0 6px 16px #0000001f}.wif-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.wif-card-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:#1e293b}.wif-card-actions{display:flex;gap:8px;align-items:center}.wif-analyze-btn{display:flex;align-items:center;gap:6px;padding:7px 16px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 6px #2563eb40}.wif-analyze-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px #2563eb59}.wif-reset-btn{padding:7px 14px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s}.wif-reset-btn:hover{background:#e2e8f0;color:#334155}.wif-rerun-btn{display:flex;align-items:center;gap:5px;padding:7px 14px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s}.wif-rerun-btn:hover{background:#e2e8f0;color:#334155}.wif-presets{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.wif-preset-chip{padding:6px 14px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:12px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.wif-preset-chip:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.wif-preset-chip.active{background:#2563eb;color:#fff;border-color:#2563eb}.wif-sliders-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.wif-slider-control{padding:12px 14px;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.wif-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.wif-slider-label{font-size:12px;font-weight:600;color:#334155}.wif-slider-value{font-size:14px;font-weight:700;font-variant-numeric:tabular-nums}.wif-range-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,var(--slider-color) 0%,var(--slider-color) var(--slider-pct),#e2e8f0 var(--slider-pct),#e2e8f0 100%);outline:none;cursor:pointer}.wif-range-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid var(--slider-color);box-shadow:0 1px 4px #00000026;cursor:pointer;transition:transform .15s}.wif-range-input::-webkit-slider-thumb:hover{transform:scale(1.2)}.wif-slider-range{display:flex;justify-content:space-between;font-size:9px;color:#94a3b8;margin-top:4px}.wif-impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}.wif-impact-card{padding:12px;border-radius:8px;text-align:center;border:1px solid #e2e8f0}.wif-impact-card.positive{background:#f0fdf4;border-color:#bbf7d0}.wif-impact-card.negative{background:#fef2f2;border-color:#fecaca}.wif-impact-label{display:block;font-size:10px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.wif-impact-value{display:block;font-size:18px;font-weight:700;color:#1e293b;line-height:1.2}.wif-impact-change{display:block;font-size:11px;font-weight:600;margin-top:4px}.wif-impact-change.up{color:#059669}.wif-impact-change.down{color:#dc2626}.wif-builder-chart{border-top:1px solid #f1f5f9;padding-top:16px}.wif-sub-title{font-size:13px;font-weight:600;color:#475569;margin:0 0 12px}.wif-sensitivity-layout{display:flex;flex-direction:column;gap:20px}.wif-tornado-section,.wif-detail-section{flex:1}.wif-tornado-rows{display:flex;flex-direction:column;gap:6px}.wif-tornado-row{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .15s}.wif-tornado-row:hover,.wif-tornado-row.selected{background:#f8fafc}.wif-tornado-row.selected{border:1px solid #e2e8f0}.wif-tornado-label{width:100px;font-size:11px;font-weight:500;color:#475569;flex-shrink:0;text-align:right}.wif-tornado-bar-wrap{flex:1;display:flex;align-items:center;height:24px;position:relative}.wif-tornado-center{width:2px;height:100%;background:#475569;position:absolute;left:50%;transform:translate(-50%)}.wif-tornado-bar-neg{height:20px;background:#fecaca;border-radius:3px 0 0 3px;position:absolute;right:50%;display:flex;align-items:center;justify-content:flex-start;padding-left:4px}.wif-tornado-bar-pos{height:20px;background:#bbf7d0;border-radius:0 3px 3px 0;position:absolute;left:50%;display:flex;align-items:center;justify-content:flex-end;padding-right:4px}.wif-tornado-val{font-size:9px;font-weight:600;color:#475569;white-space:nowrap}.wif-mc-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px}.wif-mc-iter-control{display:flex;align-items:center;gap:6px}.wif-mc-iter-label{font-size:12px;font-weight:500;color:#64748b}.wif-mc-iter-btn{padding:4px 12px;border:1px solid #e2e8f0;border-radius:4px;background:#fff;font-size:11px;font-weight:600;color:#64748b;cursor:pointer;transition:all .15s}.wif-mc-iter-btn:hover{border-color:#2563eb;color:#2563eb}.wif-mc-iter-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.wif-mc-stats-row{display:flex;gap:8px;margin-bottom:16px}.wif-mc-stat{flex:1;padding:10px;background:#f8fafc;border-radius:8px;text-align:center;border:1px solid #f1f5f9}.wif-mc-stat-label{display:block;font-size:10px;font-weight:500;color:#94a3b8;text-transform:uppercase;margin-bottom:2px}.wif-mc-stat-value{font-size:16px;font-weight:700;color:#1e293b}.wif-mc-chart{margin-bottom:16px}.wif-mc-prob-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.wif-mc-prob-card{padding:14px;border-radius:8px;text-align:center}.wif-mc-prob-card.positive{background:#f0fdf4;border:1px solid #bbf7d0}.wif-mc-prob-card.neutral{background:#eff6ff;border:1px solid #bfdbfe}.wif-mc-prob-val{display:block;font-size:24px;font-weight:800;color:#1e293b;line-height:1;margin-bottom:4px}.wif-mc-prob-label{font-size:11px;color:#64748b;font-weight:500}.wif-metric-toggle{display:flex;gap:4px;margin-bottom:16px;background:#f1f5f9;padding:3px;border-radius:8px;width:fit-content}.wif-metric-btn{padding:6px 16px;border:none;border-radius:6px;background:transparent;font-size:12px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.wif-metric-btn.active{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001a}.wif-sc-chart{margin-bottom:8px}.wif-sc-hint{text-align:center;font-size:11px;color:#94a3b8;margin-bottom:16px}.wif-probability-row{display:flex;gap:6px;align-items:flex-end;padding:0 4px;margin-bottom:16px}.wif-prob-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:6px 2px;border-radius:6px;transition:background .15s}.wif-prob-item:hover{background:#f8fafc}.wif-prob-item.selected{background:#eff6ff;border:1px solid #bfdbfe}.wif-prob-item.compared{background:#f5f3ff;border:1px solid #ddd6fe}.wif-prob-bar-track{width:28px;height:60px;background:#f1f5f9;border-radius:4px 4px 0 0;position:relative;overflow:hidden}.wif-prob-bar-fill{position:absolute;bottom:0;left:0;right:0;border-radius:4px 4px 0 0;transition:height .3s ease}.wif-prob-pct{font-size:10px;font-weight:700;color:#475569}.wif-prob-name{font-size:8px;color:#94a3b8;text-align:center;white-space:nowrap}.wif-compare-panel{padding:14px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;animation:wifSlideIn .2s ease}@keyframes wifSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.wif-compare-header{display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;margin-bottom:12px}.wif-compare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.wif-compare-item{text-align:center}.wif-compare-metric{display:block;font-size:10px;font-weight:500;color:#94a3b8;text-transform:uppercase;margin-bottom:4px}.wif-compare-vals{display:flex;justify-content:center;gap:8px;font-size:14px;font-weight:700;margin-bottom:2px}.wif-compare-diff{font-size:11px;font-weight:600}.wif-compare-diff.positive{color:#059669}.wif-compare-diff.negative{color:#dc2626}.wif-scenario-detail{padding:14px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;animation:wifSlideIn .2s ease}.wif-scenario-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.wif-scenario-detail-name{font-size:14px;font-weight:600;color:#1e293b}.wif-scenario-risk-badge{padding:3px 10px;border-radius:12px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase}.wif-scenario-desc{font-size:12px;color:#64748b;margin:0 0 12px;line-height:1.5}.wif-scenario-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.wif-scenario-numbers>div{text-align:center}.wif-sn-label{display:block;font-size:10px;color:#94a3b8;font-weight:500;text-transform:uppercase;margin-bottom:2px}.wif-sn-val{font-size:16px;font-weight:700;color:#1e293b}.wif-risk-filters{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.wif-risk-filter-btn{padding:5px 12px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;font-size:11px;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s}.wif-risk-filter-btn:hover{border-color:#94a3b8;color:#334155}.wif-risk-filter-btn.active{background:#1e293b;color:#fff;border-color:#1e293b}.wif-risk-summary-row{display:flex;gap:10px;margin-bottom:16px}.wif-risk-summary{flex:1;text-align:center;padding:10px;border-radius:8px}.wif-risk-summary.critical{background:#fef2f2;border:1px solid #fecaca}.wif-risk-summary.high{background:#fff7ed;border:1px solid #fed7aa}.wif-risk-summary.avg{background:#f8fafc;border:1px solid #e2e8f0}.wif-risk-summary-val{display:block;font-size:22px;font-weight:800;color:#1e293b}.wif-risk-summary-label{font-size:10px;font-weight:500;color:#64748b;text-transform:uppercase}.wif-matrix-container{position:relative;margin-bottom:16px}.wif-matrix-y-label{position:absolute;left:-2px;top:50%;transform:translateY(-50%) rotate(-90deg);font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.wif-matrix-x-label{text-align:center;font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.wif-matrix-grid{margin-left:24px}.wif-matrix-row{display:flex;gap:4px;margin-bottom:4px;align-items:center}.wif-matrix-row-label{width:16px;font-size:10px;font-weight:600;color:#94a3b8;text-align:center;flex-shrink:0}.wif-matrix-cell{flex:1;min-height:44px;border:1px solid;border-radius:6px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:3px;padding:4px}.wif-matrix-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0003}.wif-matrix-dot:hover{transform:scale(1.2);box-shadow:0 2px 8px #0000004d}.wif-matrix-dot.selected{transform:scale(1.3);box-shadow:0 0 0 3px #fff,0 0 0 5px currentColor}.wif-matrix-x-labels{display:flex;gap:4px}.wif-matrix-x-labels span{flex:1;text-align:center;font-size:10px;font-weight:600;color:#94a3b8}.wif-matrix-x-labels span:first-child{width:16px;flex:none}.wif-risk-detail{padding:14px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;border-left:4px solid;animation:wifSlideIn .2s ease}.wif-risk-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.wif-risk-detail-name{font-size:14px;font-weight:600;color:#1e293b}.wif-risk-detail-badge{padding:3px 10px;border-radius:12px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase}.wif-risk-detail-meta{display:flex;gap:12px;font-size:11px;color:#64748b;margin-bottom:8px}.wif-risk-detail-mitigation{font-size:12px;color:#475569;line-height:1.5}.wif-risk-detail-mitigation strong{color:#1e293b}.wif-metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.wif-metric-card{background:#fff;border-radius:10px;padding:16px;border-top:3px solid;box-shadow:0 2px 8px #0000000f;transition:all .2s;cursor:default}.wif-metric-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.wif-metric-icon{font-size:24px;margin-bottom:8px}.wif-metric-label{font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.wif-metric-value{font-size:22px;font-weight:800;color:#1e293b}.wif-view-tabs{display:flex;gap:4px;background:#f1f5f9;padding:4px;border-radius:10px;margin-bottom:24px}.wif-view-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:8px;background:transparent;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.wif-view-tab:hover{color:#334155}.wif-view-tab.active{background:#fff;color:#1e293b;box-shadow:0 2px 4px #00000014}.wif-view-tab svg{flex-shrink:0}.wif-charts-grid{display:grid;grid-template-columns:1fr;gap:24px}.wif-charts-grid.two-col{grid-template-columns:repeat(2,1fr)}@media (max-width: 1200px){.wif-charts-grid.two-col,.wif-sliders-grid{grid-template-columns:1fr}.wif-impact-grid,.wif-metrics-grid{grid-template-columns:repeat(2,1fr)}}.records-page{padding:24px;max-width:1600px}.records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.records-header h1{font-size:24px;font-weight:700;color:#1a1a1a;margin:0}.records-actions,.records-summary{display:flex;gap:12px;align-items:center}.summary-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#f0f4ff;border-radius:20px;font-size:13px;font-weight:600;color:#3a6ea5}.summary-badge.revenue{background:#e8f5e9;color:#2e7d32}.summary-badge.cost{background:#fce4ec;color:#c62828}.records-toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:240px;padding:10px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.search-input:focus{border-color:#4a90e2}.filter-select{padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:13px;background:#fff;cursor:pointer;outline:none;color:#333;min-width:140px}.filter-select:focus{border-color:#4a90e2}.records-count{font-size:13px;color:#888;padding:10px 0;font-weight:500}.records-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;overflow:hidden}.records-table-scroll{overflow-x:auto}.records-table{width:100%;border-collapse:collapse;font-size:13px}.records-table thead{background:#f8f9fb;position:sticky;top:0;z-index:1}.records-table th{padding:12px 14px;text-align:left;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid #eee;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.records-table th:hover{background:#eef1f5}.records-table th .sort-indicator{margin-left:4px;opacity:.4;font-size:11px}.records-table th .sort-indicator.active{opacity:1;color:#4a90e2}.records-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;color:#333;white-space:nowrap}.records-table tbody tr{transition:background .1s}.records-table tbody tr:hover{background:#f8faff}.records-table tbody tr:last-child td{border-bottom:none}.job-number{font-weight:600;color:#4a90e2;font-family:SF Mono,Consolas,monospace;font-size:12px}.status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.status-badge.on-time{background:#e8f5e9;color:#2e7d32}.status-badge.delayed{background:#fce4ec;color:#c62828}.status-badge.billed{background:#e3f2fd;color:#1565c0}.status-badge.unbilled{background:#fff3e0;color:#e65100}.amount-cell{font-weight:500;font-family:SF Mono,Consolas,monospace;font-size:12px}.amount-cell.revenue{color:#2e7d32}.amount-cell.cost{color:#c62828}.amount-cell.profit{color:#1565c0}.pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #f0f0f0}.pagination-info{font-size:13px;color:#888}.pagination-controls{display:flex;gap:4px}.page-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:6px;font-size:13px;cursor:pointer;color:#555;transition:all .15s}.page-btn:hover:not(:disabled){background:#f0f4ff;border-color:#4a90e2;color:#4a90e2}.page-btn.active{background:#4a90e2;color:#fff;border-color:#4a90e2}.page-btn:disabled{opacity:.4;cursor:not-allowed}.loading-records{display:flex;align-items:center;justify-content:center;height:400px;color:#888;font-size:16px}.export-btn{padding:10px 18px;background:#4a90e2;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.export-btn:hover{background:#357abd}.admin-container{padding:24px;max-width:1400px;margin:0 auto}.admin-header-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.admin-header-left{display:flex;align-items:baseline;gap:12px}.admin-header-left h1{font-size:24px;font-weight:700;color:#1a202c;margin:0}.admin-user-count{font-size:14px;color:#718096;background:#edf2f7;padding:4px 10px;border-radius:12px;font-weight:500}.admin-header-right{display:flex;align-items:center;gap:12px}.admin-search{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#a0aec0;min-width:220px}.admin-search input{border:none;outline:none;font-size:14px;color:#2d3748;background:transparent;width:100%}.admin-search input::placeholder{color:#a0aec0}.admin-toggle-inactive{display:flex;align-items:center;gap:6px;font-size:13px;color:#4a5568;cursor:pointer;white-space:nowrap}.admin-toggle-inactive input{accent-color:#3182ce}.admin-btn-create{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.admin-btn-create:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.admin-error-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fed7d7;color:#c53030;border-radius:8px;margin-bottom:16px;font-size:14px}.admin-error-banner button{background:none;border:none;color:#c53030;font-weight:600;cursor:pointer;text-decoration:underline}.admin-loading{text-align:center;padding:60px 0;color:#718096;font-size:16px}.admin-table-wrapper{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow-x:auto;box-shadow:0 1px 3px #0000000f}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.admin-table th{padding:14px 16px;text-align:left;font-weight:600;color:#4a5568;font-size:12px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.admin-table td{padding:14px 16px;border-bottom:1px solid #edf2f7;color:#2d3748;vertical-align:middle}.admin-table tbody tr:hover{background:#f7fafc}.admin-table tbody tr.inactive-row{opacity:.55}.admin-user-cell{display:flex;align-items:center;gap:12px}.admin-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.admin-user-name{font-weight:600;color:#1a202c}.admin-user-username{font-size:12px;color:#a0aec0}.admin-role-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;text-transform:capitalize;white-space:nowrap}.admin-role-badge.role-admin{background:#fed7d7;color:#c53030}.admin-role-badge.role-operations{background:#c6f6d5;color:#276749}.admin-role-badge.role-warehouse_manager{background:#bee3f8;color:#2a4365}.admin-role-badge.role-sales_manager{background:#fefcbf;color:#975a16}.admin-role-badge.role-finance_manager{background:#e9d8fd;color:#553c9a}.admin-role-badge.role-viewer{background:#edf2f7;color:#4a5568}.admin-company-tag{display:inline-block;padding:3px 8px;background:#edf2f7;border-radius:4px;font-size:13px;color:#4a5568;font-weight:500}.admin-access-tags{display:flex;flex-wrap:wrap;gap:4px;max-width:200px}.admin-small-tag{display:inline-block;padding:2px 8px;background:#edf2f7;border-radius:4px;font-size:11px;color:#4a5568;white-space:nowrap}.admin-small-tag.all{background:#c6f6d5;color:#276749}.admin-small-tag.page{background:#bee3f8;color:#2a4365}.admin-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.admin-status.active{background:#c6f6d5;color:#276749}.admin-status.active:before{content:"";width:6px;height:6px;border-radius:50%;background:#38a169}.admin-status.inactive{background:#fed7d7;color:#c53030}.admin-status.inactive:before{content:"";width:6px;height:6px;border-radius:50%;background:#e53e3e}.admin-actions{display:flex;gap:6px}.admin-action-btn{width:32px;height:32px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#718096;transition:all .2s ease}.admin-action-btn:hover{border-color:#cbd5e0;background:#f7fafc}.admin-action-btn.edit:hover{color:#2563eb;border-color:#93c5fd;background:#eff6ff}.admin-action-btn.deactivate:hover{color:#dc2626;border-color:#fca5a5;background:#fef2f2}.admin-action-btn.activate:hover{color:#16a34a;border-color:#86efac;background:#f0fdf4}.admin-empty{text-align:center;color:#a0aec0;padding:40px 16px;font-size:15px}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-modal{background:#fff;border-radius:16px;width:100%;max-width:720px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;border-radius:16px 16px 0 0;z-index:1}.admin-modal-header h2{font-size:20px;font-weight:700;color:#1a202c;margin:0}.admin-modal-close{width:36px;height:36px;border:none;background:#f7fafc;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#718096;transition:all .2s}.admin-modal-close:hover{background:#edf2f7;color:#1a202c}.admin-form{padding:24px}.admin-form-error{background:#fed7d7;color:#c53030;padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:16px}.admin-form-grid{display:flex;flex-direction:column;gap:24px}.admin-form-section{border:1px solid #edf2f7;border-radius:10px;padding:16px}.admin-form-section h3{font-size:14px;font-weight:600;color:#2d3748;margin:0 0 12px;text-transform:uppercase;letter-spacing:.3px}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}.admin-form-row:last-child{margin-bottom:0}.admin-field{display:flex;flex-direction:column;gap:6px}.admin-field label{font-size:13px;font-weight:500;color:#4a5568}.admin-field input,.admin-field select{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#2d3748;transition:border-color .2s;background:#fff}.admin-field input:focus,.admin-field select:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.admin-field-hint{font-size:12px;color:#a0aec0;margin-top:2px}.admin-radio-group{display:flex;gap:20px;margin-bottom:12px}.admin-radio{display:flex;align-items:center;gap:6px;font-size:14px;color:#4a5568;cursor:pointer}.admin-radio input{accent-color:#3182ce}.admin-chips-grid{display:flex;flex-wrap:wrap;gap:8px}.admin-chip{padding:6px 14px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:13px;color:#4a5568;cursor:pointer;transition:all .2s ease}.admin-chip:hover{border-color:#3182ce;color:#3182ce;background:#ebf8ff}.admin-chip.selected{background:#2563eb;color:#fff;border-color:#2563eb}.admin-chip.selected:hover{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.admin-page-preview{display:flex;flex-wrap:wrap;gap:6px}.admin-page-tag{display:inline-block;padding:4px 10px;background:#ebf8ff;color:#2b6cb0;border-radius:6px;font-size:12px;font-weight:500}.admin-page-tag.empty{background:#fed7d7;color:#c53030}.admin-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;margin-top:8px;border-top:1px solid #edf2f7}.admin-btn-cancel{padding:10px 20px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#4a5568;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.admin-btn-cancel:hover{background:#f7fafc;border-color:#cbd5e0}.admin-btn-save{padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.admin-btn-save:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.admin-btn-save:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.admin-header-bar{flex-direction:column;align-items:stretch}.admin-header-right{flex-wrap:wrap}.admin-form-row{grid-template-columns:1fr}}@media (max-width: 768px){.admin-container{padding:16px}.admin-modal{max-width:100%;margin:16px}.admin-table th:nth-child(5),.admin-table td:nth-child(5),.admin-table th:nth-child(6),.admin-table td:nth-child(6){display:none}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px}.login-card{background:#fffffff2;border-radius:16px;box-shadow:0 25px 50px -12px #0006;width:100%;max-width:420px;overflow:hidden}.login-header{background:linear-gradient(135deg,#0f3460,#1a1a2e);padding:40px 32px 32px;text-align:center}.login-logo{width:80px;height:80px;margin:0 auto 16px;background:#ffffff1a;border-radius:16px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-logo img{width:56px;height:56px;object-fit:contain}.login-header h1{color:#fff;font-size:28px;font-weight:700;margin:0 0 8px;letter-spacing:-.5px}.login-header p{color:#ffffffb3;font-size:14px;margin:0}.login-form{padding:32px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-group input{width:100%;padding:14px 16px;font-size:15px;border:2px solid #e5e7eb;border-radius:10px;background:#f9fafb;color:#1f2937;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#0f3460;background:#fff;box-shadow:0 0 0 4px #0f34601a}.form-group input::placeholder{color:#9ca3af}.form-group input:disabled{opacity:.7;cursor:not-allowed}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px;text-align:center}.login-button{width:100%;padding:16px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#0f3460,#1a1a2e);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px -5px #0f346066}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{padding:16px 32px 24px;text-align:center;border-top:1px solid #f3f4f6}.login-footer p{color:#9ca3af;font-size:12px;margin:0}@media (max-width: 480px){.login-card{border-radius:12px}.login-header{padding:32px 24px 24px}.login-logo{width:64px;height:64px}.login-logo img{width:44px;height:44px}.login-header h1{font-size:24px}.login-form{padding:24px}}*{margin:0;padding:0;box-sizing:border-box}html{background:#f5f7fa}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;overflow-x:hidden;color:#1a1a1a}#root{width:100%;min-height:100vh;background:#f5f7fa;position:relative;overflow-x:hidden}
