body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:#f5f7fa;color:#2c3e50;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.focus-dashboard{margin:0 auto;max-width:1400px;padding:24px}.focus-dashboard-login{margin:0 auto;max-width:100%;padding:24px}.dashboard-header{align-items:center;border-bottom:1px solid #e1e8ed;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.header-left h1{color:#1a202c;font-size:24px;font-weight:700;margin-bottom:4px}.subtitle{color:#718096;font-size:14px}.btn-analyze{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:transform .2s,box-shadow .2s}.btn-analyze:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-analyze:disabled{cursor:not-allowed;opacity:.6}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px}.stat-label{color:#718096;font-size:13px;margin-bottom:8px}.stat-value{color:#1a202c;font-size:32px;font-weight:700;margin-bottom:4px}.stat-subtitle{color:#a0aec0;font-size:12px}.main-content-area{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 320px}.left-content,.right-sidebar{display:flex;flex-direction:column;gap:20px}.insight-box{background:#fff;border-left:4px solid #667eea;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.insight-header{align-items:center;display:flex;gap:8px;margin-bottom:16px}.insight-icon{font-size:20px}.insight-header h3{color:#667eea;font-size:16px;font-weight:600}.insight-content p{color:#4a5568;font-size:14px;line-height:1.6;margin-bottom:16px}.insight-highlights{display:flex;flex-direction:column;gap:12px}.highlight-item{align-items:flex-start;display:flex;font-size:13px;gap:8px;line-height:1.5}.check-icon{align-items:center;background:#e6f7ff;border-radius:4px;display:flex;flex-shrink:0;font-size:12px;height:20px;justify-content:center;width:20px}.highlight-item strong{color:#2d3748}.source-ref{color:#667eea;font-size:10px;font-weight:600;margin-left:2px}.fokus-summary-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h3{color:#1a202c;font-size:18px;font-weight:600}.fokus-count{background:#f7fafc;border-radius:12px;color:#718096;font-size:13px;padding:4px 12px}.fokus-summary-table{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;width:100%}.table-header{background:#f7fafc;border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:13px;font-weight:600;padding:12px 16px}.table-header,.table-row{display:grid;grid-template-columns:2fr 1fr 1.5fr .8fr 1fr}.table-row{align-items:center;border-bottom:1px solid #e2e8f0;padding:16px;transition:background .2s}.table-row:hover{background:#f7fafc}.table-row:last-child{border-bottom:none}.table-cell{color:#4a5568;font-size:13px}.text-center{text-align:center}.fokus-name-cell{display:flex;flex-direction:column;gap:4px}.fokus-name{color:#2d3748;font-size:14px;font-weight:600}.fokus-meta{color:#718096;font-size:11px}.progress-inline{background:#e2e8f0;border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden;width:100%}.progress-inline-bar{height:100%;transition:width .3s ease}.progress-text{color:#2d3748;font-size:13px;font-weight:600}.gap-value{font-size:14px;font-weight:700}.status-badge-mini{border-radius:12px;color:#fff;display:inline-block;font-size:11px;font-weight:600;padding:4px 12px}@media (max-width:968px){.table-header,.table-row{grid-template-columns:1.5fr .8fr 1.2fr .8fr .8fr}.fokus-name{font-size:12px}.fokus-meta{font-size:10px}}@media (max-width:768px){.table-header{display:none}.table-row{gap:8px;grid-template-columns:1fr;padding:12px}.table-cell{align-items:center;display:flex;justify-content:space-between}.table-cell:before{color:#718096;content:attr(data-label);font-size:11px;font-weight:600}.text-center{text-align:left}}.source-explanation-box{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.source-explanation-box h4{color:#2d3748;font-size:14px;font-weight:600;margin-bottom:12px}.source-list{display:flex;flex-direction:column;gap:8px}.source-item{display:flex;font-size:12px;gap:8px;line-height:1.5}.source-ref-label{color:#667eea;flex-shrink:0;font-weight:600}.source-desc{color:#4a5568}.widget-box{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px}.widget-title{align-items:center;color:#1a202c;display:flex;font-size:16px;font-weight:600;gap:8px;margin-bottom:16px}.info-icon{font-size:18px}.risk-items{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.risk-item{align-items:center;background:#f7fafc;border-radius:8px;display:flex;gap:12px;padding:12px}.risk-item.risk-kritis{border-left:3px solid #dc3545}.risk-item.risk-tinggi{border-left:3px solid #fd7e14}.risk-item.risk-sedang{border-left:3px solid #ffc107}.risk-item.risk-rendah{border-left:3px solid #28a745}.risk-icon{flex-shrink:0;font-size:18px}.risk-info{flex:1 1}.risk-label{color:#2d3748;font-size:13px;font-weight:600}.risk-count{color:#718096;font-size:11px}.risk-badge{background:#e2e8f0;border-radius:12px;color:#2d3748;font-size:12px;font-weight:700;padding:4px 10px}.widget-footer{border-top:1px solid #e2e8f0;color:#718096;font-size:12px;padding-top:12px}.rekomendasi-box{max-height:600px;overflow-y:auto}.rekomendasi-content{display:flex;flex-direction:column;gap:16px}.rekomendasi-section h4{color:#2d3748;font-size:13px;font-weight:600;margin-bottom:12px}.action-item{background:#f7fafc;border-radius:6px;color:#4a5568;display:flex;font-size:12px;gap:12px;line-height:1.5;margin-bottom:8px;padding:12px}.action-item.action-priority{background:#fff5f5;border-left:3px solid #fc8181}.action-number{background:#667eea;border-radius:50%;color:#fff;flex-shrink:0;font-size:11px;font-weight:700;height:20px;justify-content:center;width:20px}.action-number,.attention-item{align-items:center;display:flex}.attention-item{background:#fff5f5;border-radius:6px;gap:8px;margin-bottom:6px;padding:8px 12px}.attention-number{align-items:center;background:#fc8181;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:18px;justify-content:center;width:18px}.attention-name{color:#2d3748;font-size:12px}.prediction-item{background:#fffaf0;border-left:3px solid #ed8936;border-radius:6px;margin-bottom:8px;padding:12px}.prediction-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.prediction-header strong{color:#2d3748;font-size:12px}.prediction-badge{border-radius:8px;color:#fff;font-size:10px;font-weight:600;padding:2px 8px}.prediction-badge.critical{background:#dc3545}.prediction-item p{color:#718096;font-size:11px;line-height:1.4}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.loading-spinner{text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 16px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.error-container button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:12px 24px}@media (max-width:1200px){.main-content-area{grid-template-columns:1fr}.right-sidebar{display:grid;grid-template-columns:1fr 1fr}}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.right-sidebar{grid-template-columns:1fr}.dashboard-header{align-items:flex-start;flex-direction:column;gap:12px}.btn-analyze{width:100%}}.filter-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.filter-tab{background:#f7fafc;border:1px solid #e2e8f0;border-radius:20px;color:#4a5568;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;transition:all .2s ease}.filter-tab:hover{background:#edf2f7}.filter-tab.active{background:#edf2f7;color:#1a202c}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.8880fdbf.css.map*/