@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#111827b3;--bg-card-hover:#1e293bcc;--bg-glass:#ffffff08;--border:#ffffff14;--border-focus:#6366f180;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#818cf8;--accent-glow:#6366f14d;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--risk-sangat-tinggi:#dc2626;--risk-tinggi:#f97316;--risk-sedang:#eab308;--risk-rendah:#22c55e;--risk-sangat-rendah:#3b82f6;--radius:12px;--radius-sm:8px;--radius-xs:6px;--shadow:0 4px 24px #0000004d;--shadow-lg:0 8px 40px #0006;--transition:all .2s cubic-bezier(.4, 0, .2, 1);--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif}[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f1f5f9;--bg-glass:#00000005;--border:#e2e8f0;--border-focus:#6366f1;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}#root{min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-layout{width:100%;min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:260px;padding:1.5rem 0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border);margin-bottom:1rem;padding:0 1.5rem 1.5rem}.sidebar-brand h1{background:linear-gradient(135deg, var(--accent), #a78bfa);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.4rem;font-weight:800}.sidebar-brand p{color:var(--text-muted);margin-top:.25rem;font-size:.75rem}.sidebar-nav{flex:1;padding:0 .75rem}.sidebar-nav a{color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.7rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.sidebar-nav a:hover{background:var(--bg-glass);color:var(--text-primary)}.sidebar-nav a.active{color:var(--text-primary);box-shadow:inset 4px 0 0 var(--accent);background:#6366f133}.sidebar-nav a .icon{text-align:center;width:1.5rem;font-size:1.15rem}.main-content{background:var(--bg-primary);flex:1;min-height:100vh;margin-left:260px;padding:4rem 2rem 2rem;position:relative}.top-actions{z-index:1000;align-items:center;gap:1rem;display:flex;position:fixed;top:1rem;right:2rem}@media (width<=1024px){.sidebar{width:220px}.main-content{margin-left:220px;padding:3.5rem 1.5rem 1.5rem}}@media (width<=768px){.sidebar{display:none}.main-content{margin-left:0;padding:3.5rem 1rem 1rem}}.page-container{flex-direction:column;gap:1.5rem;animation:.4s ease-out fadeIn;display:flex}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;display:flex}.page-header h1{color:var(--text-primary);letter-spacing:-.5px;font-size:1.8rem;font-weight:800}.page-header p{color:var(--text-secondary);margin-top:.25rem;font-size:.95rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:.85rem;font-weight:600;font-family:var(--font);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.6rem 1.25rem;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent), #7c3aed);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.btn-ai{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 2px 12px #7c3aed4d}.btn-ai:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #7c3aed66}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-outline{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-outline:hover:not(:disabled){background:var(--bg-glass);border-color:var(--text-secondary);color:var(--text-primary)}.btn-success{background:linear-gradient(135deg, var(--success), #059669);color:#fff}.btn-sm{padding:.4rem .75rem;font-size:.78rem}.btn-lg{padding:.8rem 1.75rem;font-size:.95rem}.btn-group{flex-wrap:wrap;gap:.5rem;display:flex}.tab-btn{background:var(--bg-glass);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);padding:.5rem 1rem;font-size:.85rem;font-weight:600}.tab-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem;font-size:.82rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-xs);width:100%;color:var(--text-primary);font-family:var(--font);transition:var(--transition);padding:.65rem .9rem;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #6366f11a}.form-textarea{resize:vertical;min-height:100px}.form-select{cursor:pointer}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}@media (width<=768px){.form-row{grid-template-columns:1fr}}.sakip-picker{border-radius:var(--radius-sm);background:#10b9810d;border:1px solid #10b98133;padding:1rem}.sakip-items{flex-direction:column;gap:.5rem;max-height:200px;display:flex;overflow-y:auto}.sakip-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);transition:var(--transition);padding:.75rem}.sakip-item:hover{background:#10b9811a;border-color:#10b98166;transform:translate(4px)}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);padding:1.5rem}.card:hover{border-color:#ffffff1f}.card-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.card-header h2{font-size:1.1rem;font-weight:700}.card-header h3{font-size:.95rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent);height:3px;position:absolute;top:0;left:0;right:0}.stat-card.danger:before{background:var(--risk-sangat-tinggi)}.stat-card.warning:before{background:var(--risk-tinggi)}.stat-card.caution:before{background:var(--risk-sedang)}.stat-card.success:before{background:var(--risk-rendah)}.stat-card .stat-value{margin-bottom:.25rem;font-size:2rem;font-weight:800;line-height:1}.stat-card .stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.table-wrapper,.table-responsive{border-radius:var(--radius-sm);width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#0003;padding:.7rem .75rem;font-size:.75rem;font-weight:700}td{vertical-align:top;border-bottom:1px solid #ffffff0a;padding:.65rem .75rem;font-size:.85rem}tr:hover td{background:#ffffff05}td .form-input,td .form-select,td .form-textarea{background:#0000004d;border-color:#ffffff0d;padding:.5rem .75rem;font-size:.85rem}td .form-input:focus,td .form-select:focus,td .form-textarea:focus{border-color:var(--accent);background:#00000080}td .form-textarea{resize:vertical;width:100%;height:100%;min-height:80px;line-height:1.5}tbody tr:nth-child(2n) td{background:#ffffff04}tbody.risk-item-body tr:nth-child(2n) td{background:0 0}tbody.risk-item-body:nth-child(2n) tr td{background:#ffffff04}tbody tr{transition:var(--transition)}tbody:not(.risk-item-body) tr:hover td,tbody.risk-item-body:hover tr td{background:#ffffff0a}.badge{text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-radius:9999px;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:700;display:inline-flex}.badge-sangat-tinggi{color:var(--risk-sangat-tinggi);background:#dc262633;border:1px solid #dc26264d}.badge-tinggi{color:var(--risk-tinggi);background:#f9731633;border:1px solid #f973164d}.badge-sedang{color:var(--risk-sedang);background:#eab30833;border:1px solid #eab3084d}.badge-rendah{color:var(--risk-rendah);background:#22c55e33;border:1px solid #22c55e4d}.badge-sangat-rendah{color:var(--risk-sangat-rendah);background:#3b82f633;border:1px solid #3b82f64d}.badge-ai{color:#a78bfa;background:#7c3aed33;border:1px solid #7c3aed4d}.badge-manual{color:var(--text-secondary);background:#64748b33;border:1px solid #64748b4d}.badge-kategori{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:flex-start;padding-top:10vh;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal,.modal-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:520px;max-height:85vh;box-shadow:var(--shadow-lg);padding:1.75rem;animation:.3s ease-out modalSlideUp;position:relative;overflow-y:auto}.modal-body{padding:1rem 0}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:1rem;padding-top:1.5rem;display:flex}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.modal-header h3{font-size:1.1rem;font-weight:700}.sidebar-user{border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff08;align-items:center;gap:.6rem;margin:0 .75rem .75rem;padding:.75rem 1rem;display:flex}.sidebar-user-avatar{color:#fff;border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:800;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;display:block;overflow:hidden}.sidebar-user-role{text-transform:uppercase;letter-spacing:.3px;font-size:.68rem;font-weight:600;display:block}.sidebar-logout-btn,.sidebar-icon-btn{cursor:pointer;opacity:.5;transition:var(--transition);background:0 0;border:none;flex-shrink:0;padding:.25rem;font-size:1rem}.sidebar-logout-btn:hover,.sidebar-icon-btn:hover{opacity:1;transform:scale(1.15)}.sidebar-section-label{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;align-items:center;gap:.6rem;padding:1rem 1rem .5rem;font-size:.65rem;font-weight:700;display:flex}.sidebar-section-line{background:linear-gradient(90deg, var(--border), transparent);flex:1;height:1px}.sidebar-section-line:first-child{background:linear-gradient(90deg, transparent, var(--border))}.sidebar-step-link,.sidebar-step-item{color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:1rem;margin-bottom:.25rem;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.sidebar-step-item.locked{opacity:.4;cursor:not-allowed}.sidebar-step-link:hover{background:var(--bg-glass);color:var(--text-primary)}.sidebar-step-link.active{color:var(--text-primary);box-shadow:inset 4px 0 0 var(--accent);background:#6366f126}.sidebar-step-num{width:24px;height:24px;color:var(--text-muted);transition:var(--transition);background:#ffffff14;border:1px solid #ffffff1f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-left:-.25rem;font-size:.75rem;font-weight:800;display:inline-flex}.sidebar-step-text{white-space:nowrap;font-size:.85rem;font-weight:500}.sidebar-step-link.active .sidebar-step-num{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 10px var(--accent-glow)}.sidebar-step-link.active .sidebar-step-text{color:var(--text-primary);font-weight:700}.stepper{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:0;margin-bottom:2.5rem;padding:1.5rem 2rem;display:flex;overflow-x:auto}.step-container{flex:1;align-items:center;display:flex}.step-container:last-child{flex:0}.step-item{cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);flex-shrink:0;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.step-number{border:2px solid var(--border);width:32px;height:32px;color:var(--text-muted);transition:var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.step-item.active .step-number{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 16px var(--accent-glow)}.step-item.completed .step-number{background:var(--success);border-color:var(--success);color:#fff}.step-label{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;display:flex}.step-icon{font-size:1rem}.step-item.active .step-label{color:var(--text-primary)}.step-item.completed .step-label{color:var(--success)}.step-connector{background:var(--border);flex:1;min-width:20px;height:2px;margin:0 1rem}.step-connector.completed{background:var(--success)}.risk-matrix{aspect-ratio:1.15;grid-template-rows:repeat(5,1fr) 50px;grid-template-columns:50px repeat(5,1fr);gap:3px;max-width:650px;margin:0 auto;display:grid}.matrix-cell{border-radius:var(--radius-xs);cursor:pointer;min-height:70px;transition:var(--transition);flex-direction:column;justify-content:center;align-items:center;padding:.35rem;display:flex;position:relative;overflow-y:auto}.matrix-cell::-webkit-scrollbar{background:0 0;width:0}.matrix-cell:hover{z-index:2;transform:scale(1.03)}.matrix-cell.level-st{background:#dc262659;border:1px solid #dc262680}.matrix-cell.level-t{background:#f973164d;border:1px solid #f9731666}.matrix-cell.level-s{background:#eab30840;border:1px solid #eab30859}.matrix-cell.level-r{background:#22c55e33;border:1px solid #22c55e4d}.matrix-cell.level-sr{background:#3b82f633;border:1px solid #3b82f64d}.matrix-label{color:var(--text-muted);writing-mode:vertical-lr;text-orientation:mixed;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex;transform:rotate(180deg)}.matrix-label-x{writing-mode:horizontal-tb;transform:none}.matrix-dot{color:#fff;cursor:pointer;width:20px;height:20px;transition:var(--transition);text-shadow:0 1px 2px #00000080;border-radius:50%;justify-content:center;align-items:center;margin:1px;font-size:.55rem;font-weight:800;display:inline-flex}.matrix-dot.st{background:var(--risk-sangat-tinggi)}.matrix-dot.t{background:var(--risk-tinggi)}.matrix-dot.s{background:var(--risk-sedang)}.matrix-dot.r{background:var(--risk-rendah)}.matrix-dot.sr{background:var(--risk-sangat-rendah)}.loading-overlay{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:10000;pointer-events:auto;word-break:break-word;align-items:flex-start;gap:.75rem;width:fit-content;min-width:280px;max-width:400px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;line-height:1.4;animation:.4s cubic-bezier(.175,.885,.32,1.275) slideInRight;display:flex;position:fixed;top:5rem;right:1.5rem}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--danger);background:#dc26260d}.notification-wrapper{position:relative}.top-icon-btn{background:var(--bg-glass);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;width:40px;height:40px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.top-icon-btn:hover{background:var(--bg-glass-hover);border-color:var(--accent);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-2px)}.notification-dropdown{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);width:320px;max-height:450px;box-shadow:var(--shadow-lg);z-index:1000;flex-direction:column;animation:.3s ease-out slideInDown;display:flex;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.notification-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.notification-header h3{margin:0;font-size:1rem;font-weight:700}.notification-list{flex:1;max-height:380px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);gap:1rem;padding:1rem 1.25rem;display:flex;position:relative}.notification-item:hover{background:var(--bg-glass)}.notification-item.unread{background:#6366f10d}.notification-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.notification-icon.info{color:var(--info);background:#3b82f61a}.notification-icon.warning{color:var(--warning);background:#f59e0b1a}.notification-icon.error{color:var(--danger);background:#ef44441a}.notification-icon.success{color:var(--success);background:#10b9811a}.notification-content{flex:1;min-width:0}.notification-message{color:var(--text-primary);margin-bottom:.25rem;font-size:.85rem;line-height:1.4}.notification-time{color:var(--text-muted);font-size:.7rem}.unread-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;position:absolute;top:1.25rem;right:1.25rem}.notification-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.9rem}.notification-badge{background:var(--danger);color:#fff;border:2px solid var(--bg-secondary);border-radius:10px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.65rem;font-weight:800;display:flex;position:absolute;top:-2px;right:-2px}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.process-steps-bar{border:1px solid var(--border);border-radius:var(--radius);background:#0003;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.75rem 1.25rem;display:flex;overflow-x:auto}.process-step-pill{cursor:pointer;transition:var(--transition);white-space:nowrap;border:1px solid #0000;border-radius:50px;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.process-step-pill:hover{background:var(--bg-glass)}.process-step-pill.active{background:#6366f126;border-color:#6366f14d;box-shadow:0 0 20px #6366f11a}.process-step-num{background:var(--bg-secondary);border:1px solid var(--border);width:24px;height:24px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.process-step-pill.active .process-step-num{background:var(--accent);border-color:var(--accent);color:#fff}.process-step-pill.completed .process-step-num{background:var(--success);border-color:var(--success);color:#fff}.process-step-text{color:var(--text-muted);font-size:.85rem;font-weight:600}.process-step-pill.active .process-step-text{color:var(--text-primary)}.process-step-pill.completed .process-step-text{color:var(--success)}.process-step-pill.locked{opacity:.5;cursor:not-allowed}.process-step-connector{color:var(--text-muted);opacity:.3;margin:0 .25rem;font-size:.8rem}.active-project-badge{border:1px solid var(--border);border-radius:var(--radius-sm);background:#1e293b66;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem 1.25rem;display:flex}.active-project-badge span{align-items:center;gap:.75rem;display:flex}.active-project-badge strong{color:var(--text-primary)}.lifecycle-bar{border-bottom:1px solid var(--border);background:#00000026;justify-content:space-between;align-items:center;margin:-1.5rem -1.5rem 1.5rem;padding:1.25rem;display:flex}.lifecycle-steps{align-items:center;gap:0;display:flex}.lifecycle-step-wrapper{align-items:center;display:flex}.lifecycle-step{opacity:.5;transition:var(--transition);align-items:center;gap:.5rem;display:flex}.lifecycle-step.active,.lifecycle-step.completed{opacity:1}.lifecycle-step-icon{border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;display:flex}.lifecycle-step.completed .lifecycle-step-icon{background:var(--success);border-color:var(--success);color:#fff}.lifecycle-step.active .lifecycle-step-icon{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.lifecycle-step-label{text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.lifecycle-connector{background:var(--border);width:40px;height:1px;margin:0 .75rem}.lifecycle-connector.completed{background:var(--success)}.lifecycle-actions{gap:.5rem;display:flex}.wizard-actions{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:2.5rem;padding-top:1.5rem;display:flex}.wizard-actions.right-only{justify-content:flex-end}.upload-dropzone{border-radius:var(--radius);text-align:center;cursor:pointer;transition:var(--transition);background:#11182799;border:2px dashed #6366f14d;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2.5rem 1.5rem;display:flex}.upload-dropzone:hover,.upload-dropzone.active{border-color:var(--accent);background:#6366f10d}.upload-dropzone-icon{opacity:.8;margin-bottom:.5rem;font-size:2.5rem}.upload-dropzone-text{color:var(--text-primary);font-size:1rem;font-weight:500}.upload-dropzone-subtext{color:var(--text-muted);font-family:monospace;font-size:.8rem}.btn-warning{color:#000;background:#facc15}.btn-warning:hover{background:#eab308}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.login-split-container{background:#0f172a;width:100%;min-height:100vh;display:flex}.login-illustration{background:url(/images/login-bg.png) 50%/cover no-repeat;flex:1;display:none;position:relative;overflow:hidden}@media (width>=900px){.login-illustration{flex-direction:column;justify-content:center;padding:4rem;display:flex}}.illustration-overlay{z-index:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#0f172ab3 0%,#1e3a8a66 100%);position:absolute;inset:0}.illustration-content{z-index:2;color:#fff;max-width:500px;animation:1s ease-out fadeUp;position:relative}.login-logo-large{filter:drop-shadow(0 0 20px #3b82f680);margin-bottom:1rem;font-size:4.5rem}.illustration-content h2{background:linear-gradient(90deg,#60a5fa,#c084fc);-webkit-text-fill-color:transparent;letter-spacing:-1px;-webkit-background-clip:text;margin-bottom:1.5rem;font-size:2.5rem;font-weight:800}.illustration-tagline{color:#e2e8f0;border-left:4px solid #3b82f6;padding-left:1.5rem;font-size:1.5rem;font-weight:300;line-height:1.4}.illustration-tagline strong{color:#60a5fa;font-weight:600}.login-form-side{background:var(--bg-primary);flex:1;justify-content:center;align-items:center;max-width:100%;padding:2rem;display:flex;position:relative}@media (width>=900px){.login-form-side{z-index:10;max-width:500px;box-shadow:-10px 0 30px #0003}}.login-form-container{width:100%;max-width:400px;animation:.6s ease-out cardFadeIn}.login-header{margin-bottom:2.5rem}.login-header h1{color:var(--text-primary);margin-bottom:.5rem;font-size:2rem;font-weight:700}.login-header p{color:var(--text-muted);font-size:.95rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.login-error{color:#fca5a5;background:#ef44441a;border-left:4px solid #ef4444;border-radius:4px;align-items:center;gap:.5rem;padding:.8rem 1rem;font-size:.9rem;animation:.4s shake;display:flex}.login-field{flex-direction:column;gap:.5rem;display:flex}.login-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.form-input{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);width:100%;color:var(--text-primary);padding:.9rem 1rem;font-size:1rem;transition:all .2s}.form-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f633}.login-password-wrapper{align-items:center;display:flex;position:relative}.login-password-wrapper .form-input{padding-right:3rem}.login-toggle-pass{cursor:pointer;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:1.2rem;transition:color .2s;display:flex;position:absolute;right:1rem}.login-toggle-pass:hover{color:var(--text-primary)}.login-submit{color:#fff;border-radius:var(--radius-md);cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;justify-content:center;align-items:center;margin-top:1rem;padding:1rem;font-size:1.1rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 14px #3b82f64d}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;border-top:1px solid var(--border);margin-top:3rem;padding-top:1.5rem}.login-footer p{color:var(--text-muted);font-size:.8rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes cardFadeIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.org-breadcrumb{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem;display:flex}.org-legend{background:var(--bg-glass);border-radius:var(--radius-sm);border:1px solid var(--border);flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding:.75rem 1.25rem;display:flex}.legend-item{align-items:center;gap:.5rem;display:flex}.legend-item .dot{border-radius:50%;width:10px;height:10px}.legend-item .dot.st{background:#dc2626;box-shadow:0 0 8px #dc262666}.legend-item .dot.t{background:#f97316;box-shadow:0 0 8px #f9731666}.legend-item .dot.s{background:#eab308;box-shadow:0 0 8px #eab30866}.legend-item .dot.r{background:#22c55e;box-shadow:0 0 8px #22c55e66}.legend-item .dot.sr{background:#3b82f6;box-shadow:0 0 8px #3b82f666}.legend-item .label{color:var(--text-secondary);font-size:.85rem}.org-breadcrumb-item{align-items:center;gap:.5rem;display:flex}.org-breadcrumb-item button{color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:var(--radius-xs);background:0 0;border:none;padding:.25rem .5rem;font-size:.9rem;font-weight:600}.org-breadcrumb-item button:hover{background:var(--bg-glass);color:var(--text-primary)}.org-breadcrumb-item .separator{color:var(--text-muted);opacity:.5;font-size:1.2rem}.org-summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2.5rem;display:grid}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);flex-direction:column;gap:.25rem;padding:1.5rem;display:flex}.summary-card.blue{border-left:4px solid var(--accent)}.summary-card.red{border-left:4px solid var(--danger)}.summary-card.green{border-left:4px solid var(--success)}.summary-value{color:var(--text-primary);font-size:2.5rem;font-weight:800;line-height:1}.summary-card.blue .summary-value{color:var(--accent)}.summary-card.red .summary-value{color:var(--danger)}.summary-card.green .summary-value{color:var(--success)}.summary-label{color:var(--text-muted);font-size:.85rem;font-weight:600}.org-level-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;display:grid}.org-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex;position:relative}.org-card.clickable:hover{background:var(--bg-card-hover);border-color:#6366f166;transform:translateY(-4px);box-shadow:0 12px 40px #0006}.org-card-top{align-items:flex-start;gap:1rem;display:flex}.org-card-icon-small{border-radius:var(--radius-sm);background:#6366f126;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.org-card-title-area{flex:1}.org-card-title-area h4{color:var(--text-primary);margin-bottom:.4rem;font-size:.95rem;font-weight:700;line-height:1.4}.level-pill{letter-spacing:.5px;border-radius:4px;padding:.2rem .6rem;font-size:.65rem;font-weight:800;display:inline-block}.org-card-arrow{color:var(--text-muted);opacity:.5;font-size:.85rem;font-weight:600}.org-card-metrics{border-radius:var(--radius-sm);text-align:center;background:#0003;grid-template-columns:repeat(4,1fr);padding:.75rem 0;display:grid}.metric{border-right:1px solid #ffffff0d;flex-direction:column;gap:.25rem;display:flex}.metric:last-child{border-right:none}.metric .val{color:var(--text-primary);font-size:1.1rem;font-weight:800}.metric .lab{color:var(--text-muted);font-size:.65rem;font-weight:700}.org-risk-distribution{flex-direction:column;gap:.75rem;display:flex}.risk-bar{background:#ffffff0d;border-radius:4px;height:8px;display:flex;overflow:hidden}.segment.st{background:#dc2626}.segment.t{background:#f97316}.segment.s{background:#eab308}.segment.r{background:#22c55e}.segment.sr{background:#3b82f6}.risk-status-pills{flex-wrap:wrap;gap:.5rem;display:flex}.pill{border-radius:50px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.pill.st{color:#f87171;background:#dc262626;border:1px solid #dc26264d}.pill.t{color:#fb923c;background:#f9731626;border:1px solid #f973164d}.pill.s{color:#facc15;background:#eab30826;border:1px solid #eab3084d}.pill.r{color:#4ade80;background:#22c55e26;border:1px solid #22c55e4d}.pill.sr{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f64d}.org-treatment-progress{flex-direction:column;gap:.5rem;display:flex}.progress-label{justify-content:space-between;font-size:.8rem;font-weight:600;display:flex}.progress-label span:first-child{color:var(--text-muted)}.progress-label span:last-child{color:var(--success)}.progress-bar-container{background:#ffffff0d;border-radius:3px;height:6px;overflow:hidden}.progress-bar-fill{background:var(--success);height:100%;transition:width 1s ease-out;box-shadow:0 0 10px #10b9814d}.monitoring-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.monitoring-header h2{align-items:center;gap:.75rem;font-size:1.8rem;font-weight:800;display:flex}.monitoring-filters{border-radius:var(--radius);border:1px solid var(--border);background:#0003;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:grid}.monitoring-filter-item label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.75rem;font-weight:600;display:block}.monitoring-table th{background:#0000004d;padding:.75rem 1rem;font-size:.7rem}.monitoring-table td{padding:1.25rem 1rem}.risk-plan-cell{max-width:350px}.risk-plan-title{color:var(--text-primary);margin-bottom:.25rem;font-weight:700;display:block}.risk-plan-content{color:var(--text-secondary);font-size:.8rem;line-height:1.5;display:block}.progress-input-group{flex-direction:column;gap:.5rem;min-width:120px;display:flex}.progress-slider-container{align-items:center;gap:.75rem;display:flex}.progress-slider{-webkit-appearance:none;background:#ffffff1a;border-radius:3px;outline:none;flex:1;height:6px}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;width:14px;height:14px;box-shadow:0 0 10px var(--accent-glow);border:2px solid #fff;border-radius:50%}.progress-percentage{color:var(--text-primary);min-width:35px;font-size:.85rem;font-weight:700}.monitoring-notes-area{border:1px solid var(--border)!important;background:#0003!important;min-height:80px!important;padding:.5rem!important;font-size:.8rem!important}.btn-segarkan{border:1px solid var(--border);color:var(--text-secondary);background:#ffffff0d;padding:.5rem 1rem;font-size:.8rem;font-weight:600}.btn-segarkan:hover{background:var(--bg-glass);color:var(--text-primary)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mb-6{margin-bottom:3.5rem}.gap-1{gap:.5rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-sm{font-size:.8rem}.text-xs{font-size:.72rem}.font-bold{font-weight:700}.w-full{width:100%}.block{display:block}.inline-block{display:inline-block}.hidden{display:none}.p-0{padding:0}.m-0{margin:0}.custom-scrollbar::-webkit-scrollbar{width:6px;height:6px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#fff3}
