@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=DM+Sans:wght@400;500&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-primary: #003B7A;--color-primary-dark: #002A5C;--color-primary-light: #E8F0FB;--color-accent: #F5A623;--color-accent-dark: #D4891A;--color-accent-light: #FEF3D8;--color-bg: #F7F8FC;--color-surface: #FFFFFF;--color-surface-raised: #FFFFFF;--color-border: #E2E8F0;--color-border-strong: #CBD5E0;--color-text: #1A202C;--color-text-secondary: #4A5568;--color-text-disabled: #A0AEC0;--color-fatality: #C53030;--color-fatality-bg: #FFF5F5;--color-berat: #C05621;--color-berat-bg: #FFFAF0;--color-ringan: #B7791F;--color-ringan-bg: #FFFFF0;--color-nearmiss: #276749;--color-nearmiss-bg: #F0FFF4;--color-sla-ok: #276749;--color-sla-warning: #B7791F;--color-sla-breach: #C53030;--color-success: #276749;--color-success-bg: #F0FFF4;--color-info: #2B6CB0;--color-info-bg: #EBF8FF;--color-warning: #B7791F;--color-warning-bg: #FFFFF0;--color-danger: #C53030;--color-danger-bg: #FFF5F5;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 4px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,59,122,.1);--shadow-lg: 0 8px 24px rgba(0,59,122,.12);--shadow-xl: 0 16px 48px rgba(0,59,122,.16);--sidebar-width: 260px;--sidebar-collapsed-width: 68px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;max-width:100%;overflow-x:hidden}body{font-family:DM Sans,sans-serif;font-size:.9375rem;font-weight:400;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100%;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Plus Jakarta Sans,sans-serif;line-height:1.3;color:var(--color-text)}h1{font-size:2rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.5rem;font-weight:700;letter-spacing:-.01em}h3{font-size:1.25rem;font-weight:600}h4{font-size:1.1rem;font-weight:600}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}img{max-width:100%;display:block}code,pre,.mono{font-family:JetBrains Mono,monospace}.label,.caption{font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary)}.text-secondary{color:var(--color-text-secondary)}.text-disabled{color:var(--color-text-disabled)}.text-primary{color:var(--color-primary)}.text-accent{color:var(--color-accent)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.font-heading{font-family:Plus Jakarta Sans,sans-serif}.font-body{font-family:DM Sans,sans-serif}.font-mono{font-family:JetBrains Mono,monospace}.fw-400{font-weight:400}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.fw-800{font-weight:800}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.w-full{width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-disabled)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width var(--transition-base);overflow-x:hidden}.sidebar-header{padding:var(--space-6) var(--space-5);display:flex;align-items:center;gap:var(--space-3);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:40px;height:40px;background:var(--color-accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:1.1rem;color:var(--color-primary-dark);flex-shrink:0}.sidebar-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1rem;line-height:1.2;white-space:nowrap}.sidebar-subtitle{font-size:.7rem;opacity:.7;white-space:nowrap}.sidebar-nav{flex:1;padding:var(--space-4) 0;overflow-y:auto}.sidebar-section-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff6;padding:var(--space-4) var(--space-5) var(--space-2)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent;color:#ffffffbf;font-size:.875rem;font-weight:500;white-space:nowrap;text-decoration:none}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff1f;border-left-color:var(--color-accent);color:#fff;font-weight:600}.nav-item svg{width:20px;height:20px;flex-shrink:0;opacity:.8}.nav-item.active svg{opacity:1}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3)}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-accent);display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;color:var(--color-primary-dark);flex-shrink:0}.sidebar-user-info{overflow:hidden}.sidebar-user-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.65rem;opacity:.6;white-space:nowrap}.top-header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-xs);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);z-index:90;transition:left var(--transition-base)}.header-left,.header-right{display:flex;align-items:center;gap:var(--space-4)}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;color:var(--color-text);padding:var(--space-2)}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--color-text-secondary)}.breadcrumb-item{cursor:pointer}.breadcrumb-item:hover{color:var(--color-primary)}.breadcrumb-separator{opacity:.4}.breadcrumb-current{color:var(--color-primary);font-weight:600}.search-box{display:flex;align-items:center;gap:var(--space-2);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);min-width:220px;transition:border-color var(--transition-fast)}.search-box:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #003b7a1a}.search-box input{border:none;background:transparent;outline:none;font-family:DM Sans,sans-serif;font-size:.8125rem;color:var(--color-text);width:100%}.search-box svg{width:16px;height:16px;color:var(--color-text-disabled);flex-shrink:0}.header-icon-btn{position:relative;background:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);color:var(--color-text-secondary)}.header-icon-btn:hover{background:var(--color-bg)}.header-icon-btn svg{width:20px;height:20px}.notification-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;background:var(--color-danger);color:#fff;font-size:.6rem;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-surface)}.header-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;cursor:pointer;border:2px solid var(--color-border);transition:border-color var(--transition-fast)}.header-avatar:hover{border-color:var(--color-primary)}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:var(--space-6) var(--space-8);min-height:calc(100vh - var(--header-height));max-width:calc(1280px + var(--space-16));transition:margin-left var(--transition-base)}.page-header{margin-bottom:var(--space-6)}.page-header-flex{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.page-title{font-size:1.5rem;font-weight:700;color:var(--color-text);font-family:Plus Jakarta Sans,sans-serif}.page-subtitle{color:var(--color-text-secondary);font-size:.875rem;margin-top:var(--space-1)}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-bordered{border:1px solid var(--color-border);box-shadow:none}.card-elevated{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;color:var(--color-text)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-6)}.kpi-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border-left:4px solid var(--color-primary);transition:all var(--transition-fast)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card.danger{border-left-color:var(--color-fatality)}.kpi-card.warning{border-left-color:var(--color-berat)}.kpi-card.caution{border-left-color:var(--color-ringan)}.kpi-card.success{border-left-color:var(--color-nearmiss)}.kpi-card.info{border-left-color:var(--color-info)}.kpi-label{font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.kpi-value{font-family:Plus Jakarta Sans,sans-serif;font-size:2rem;font-weight:800;color:var(--color-text);line-height:1}.kpi-card.danger .kpi-value{color:var(--color-fatality)}.kpi-card.warning .kpi-value{color:var(--color-berat)}.kpi-trend{font-size:.75rem;margin-top:var(--space-2);display:flex;align-items:center;gap:var(--space-1)}.kpi-trend.up{color:var(--color-danger)}.kpi-trend.down{color:var(--color-success)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:DM Sans,sans-serif;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-sm{height:32px;padding:0 var(--space-3);font-size:.8125rem}.btn-md{height:40px;padding:0 var(--space-5);font-size:.875rem}.btn-lg{height:48px;padding:0 var(--space-6);font-size:.9375rem}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary-light)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#9b2c2c}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn-accent{background:var(--color-accent);color:var(--color-primary-dark);font-weight:600}.btn-accent:hover{background:var(--color-accent-dark);color:#fff}.btn:disabled,.btn.loading{opacity:.6;cursor:not-allowed;pointer-events:none}.btn .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-3);border-radius:var(--radius-full);font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.badge-fatality{background:var(--color-fatality-bg);color:var(--color-fatality);border:1px solid rgba(197,48,48,.2)}.badge-berat{background:var(--color-berat-bg);color:var(--color-berat);border:1px solid rgba(192,86,33,.2)}.badge-ringan{background:var(--color-ringan-bg);color:var(--color-ringan);border:1px solid rgba(183,121,31,.2)}.badge-nearmiss{background:var(--color-nearmiss-bg);color:var(--color-nearmiss);border:1px solid rgba(39,103,73,.2)}.badge-open{background:#ebf8ff;color:#2b6cb0;border:1px solid rgba(43,108,176,.2)}.badge-investigating{background:var(--color-accent-light);color:var(--color-accent-dark);border:1px solid rgba(212,137,26,.2)}.badge-closed{background:var(--color-nearmiss-bg);color:var(--color-nearmiss);border:1px solid rgba(39,103,73,.2)}.badge-pending{background:#fefcbf;color:#975a16;border:1px solid rgba(151,90,22,.2)}.badge-auto{background:var(--color-primary-light);color:var(--color-primary)}.badge-manual{background:var(--color-accent-light);color:var(--color-accent-dark)}.badge-lg{padding:var(--space-2) var(--space-4);font-size:.8125rem}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table thead{background:var(--color-bg)}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:#ebf4ff}.table tbody tr:last-child td{border-bottom:none}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-input,.form-textarea,.form-select{width:100%;height:40px;padding:0 var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-family:DM Sans,sans-serif;font-size:.875rem;color:var(--color-text);background:var(--color-surface);transition:all var(--transition-fast);outline:none}.form-textarea{height:auto;min-height:100px;padding:var(--space-3);resize:vertical}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #003b7a26}.form-input.error,.form-textarea.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #c530301a}.form-error{font-size:.75rem;color:var(--color-danger);margin-top:var(--space-1)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{background:var(--color-bg);opacity:.6;cursor:not-allowed}.toggle-wrapper{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.toggle{width:44px;height:24px;border-radius:var(--radius-full);background:var(--color-border-strong);position:relative;transition:background var(--transition-fast);cursor:pointer;border:none;padding:0}.toggle.active{background:var(--color-primary)}.toggle:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform var(--transition-fast);box-shadow:var(--shadow-xs)}.toggle.active:after{transform:translate(20px)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);font-size:.875rem;border:1px solid transparent}.alert-info{background:var(--color-info-bg);color:var(--color-info);border-color:#2b6cb033}.alert-success{background:var(--color-success-bg);color:var(--color-success);border-color:#27674933}.alert-warning{background:var(--color-warning-bg);color:var(--color-warning);border-color:#b7791f33}.alert-danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:#c5303033}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:560px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:1.1rem}.modal-close{background:none;border:none;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stepper{display:flex;align-items:center;gap:0;margin-bottom:var(--space-8)}.stepper-step{display:flex;align-items:center;gap:var(--space-2);flex:1;position:relative}.stepper-step:not(:last-child):after{content:"";flex:1;height:2px;background:var(--color-border);margin:0 var(--space-3)}.stepper-step.completed:not(:last-child):after{background:var(--color-primary)}.stepper-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.8rem;flex-shrink:0;transition:all var(--transition-fast);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-disabled)}.stepper-step.active .stepper-number{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-primary-dark)}.stepper-step.completed .stepper-number{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stepper-label{font-size:.8125rem;font-weight:500;color:var(--color-text-disabled);white-space:nowrap}.stepper-step.active .stepper-label{color:var(--color-text);font-weight:600}.stepper-step.completed .stepper-label{color:var(--color-primary)}.timeline{position:relative;padding-left:var(--space-8)}.timeline:before{content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;background:var(--color-border)}.timeline-item{position:relative;padding-bottom:var(--space-6)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:calc(-1 * var(--space-8) + 6px);top:2px;width:18px;height:18px;border-radius:50%;background:var(--color-surface);border:2px solid var(--color-border-strong);z-index:1}.timeline-item.completed .timeline-dot{background:var(--color-primary);border-color:var(--color-primary)}.timeline-item.active .timeline-dot{background:var(--color-accent);border-color:var(--color-accent);animation:pulse 2s infinite}.timeline-item.pending .timeline-dot{border-style:dashed}.timeline-title{font-weight:600;font-size:.875rem;margin-bottom:var(--space-1)}.timeline-meta{font-size:.75rem;color:var(--color-text-secondary)}@keyframes pulse{0%{box-shadow:0 0 #f5a62366}70%{box-shadow:0 0 0 10px #f5a62300}to{box-shadow:0 0 #f5a62300}}.sla-timer{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-family:JetBrains Mono,monospace;font-size:.875rem;font-weight:500}.sla-timer.on-track{background:var(--color-nearmiss-bg);color:var(--color-sla-ok)}.sla-timer.warning-state{background:var(--color-ringan-bg);color:var(--color-sla-warning)}.sla-timer.breached{background:var(--color-fatality-bg);color:var(--color-sla-breach);animation:blink 1s infinite}.sla-progress{height:4px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;flex:1;min-width:60px}.sla-progress-bar{height:100%;border-radius:var(--radius-full);transition:width 1s linear,background var(--transition-fast)}.sla-progress-bar.ok{background:var(--color-sla-ok)}.sla-progress-bar.warning{background:var(--color-sla-warning)}.sla-progress-bar.breach{background:var(--color-sla-breach)}@keyframes blink{0%,to{opacity:1}50%{opacity:.6}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center}.empty-state-icon{width:80px;height:80px;border-radius:var(--radius-full);background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-5)}.empty-state-icon svg{width:36px;height:36px;color:var(--color-primary)}.empty-state h3{margin-bottom:var(--space-2)}.empty-state p{color:var(--color-text-secondary);font-size:.875rem;max-width:320px;margin-bottom:var(--space-5)}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:480px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--color-border);overflow:hidden;animation:slideDown .2s ease;z-index:300}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--color-border)}.notif-list{overflow-y:auto;max-height:360px}.notif-item{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border)}.notif-item:hover{background:var(--color-bg)}.notif-item.unread{background:#f7f9ff}.notif-icon{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.notif-content{flex:1;min-width:0}.notif-title{font-size:.8125rem;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notif-time{font-size:.7rem;color:var(--color-text-disabled);margin-top:2px}.notif-footer{padding:var(--space-3) var(--space-4);text-align:center;border-top:1px solid var(--color-border)}.notif-footer a{font-size:.8125rem;font-weight:600}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;top:var(--space-5);right:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);z-index:1000}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);min-width:320px;max-width:420px;animation:slideInRight .3s ease;font-size:.8125rem}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-1);margin-top:var(--space-5)}.pagination-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-size:.8125rem;transition:all var(--transition-fast);color:var(--color-text-secondary)}.pagination-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.skeleton{background:linear-gradient(90deg,var(--color-border) 25%,#f0f0f0 50%,var(--color-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:14px;margin-bottom:var(--space-3)}.skeleton-title{height:24px;width:60%;margin-bottom:var(--space-4)}.skeleton-card{height:120px}.skeleton-avatar{width:40px;height:40px;border-radius:50%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.login-page{display:flex;min-height:100vh}.login-branding{width:40%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);position:relative;overflow:hidden;color:#fff}.login-branding:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:#f5a6230f;top:-200px;right:-200px}.login-branding:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:#f5a6230a;bottom:-100px;left:-100px}.login-branding-logo{width:80px;height:80px;background:var(--color-accent);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:2rem;color:var(--color-primary-dark);margin-bottom:var(--space-6);z-index:1}.login-branding h1{color:#fff;text-align:center;margin-bottom:var(--space-2);z-index:1}.login-branding p{opacity:.8;text-align:center;z-index:1}.login-features{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-10);z-index:1}.login-feature{display:flex;align-items:center;gap:var(--space-3);font-size:.875rem;opacity:.85}.login-feature-icon{width:40px;height:40px;border-radius:var(--radius-md);background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-form-side{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-8);position:relative}.login-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-10);width:100%;max-width:440px}.login-card h2{margin-bottom:var(--space-2)}.login-card .login-subtitle{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--space-8)}.login-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--color-text-disabled);font-size:.8125rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-footer{position:absolute;bottom:var(--space-5);right:var(--space-8);font-size:.75rem;color:var(--color-text-disabled)}.password-wrapper{position:relative}.password-toggle{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-disabled);display:flex;padding:var(--space-1)}.password-toggle:hover{color:var(--color-text-secondary)}.checkbox-wrapper{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;color:var(--color-text-secondary);cursor:pointer}.checkbox-wrapper input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.cta-banner{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-8);color:#fff;display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);position:relative;overflow:hidden}.cta-banner:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#f5a62314;right:-80px;top:-80px}.cta-banner h2{color:#fff;z-index:1}.cta-banner p{opacity:.8;margin-top:var(--space-1);font-size:.875rem;z-index:1}.fab{display:none;position:fixed;bottom:88px;right:var(--space-5);width:56px;height:56px;border-radius:50%;background:var(--color-danger);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 16px #c5303066;z-index:80;align-items:center;justify-content:center;animation:fabPulse 2s infinite}@keyframes fabPulse{0%{box-shadow:0 4px 16px #c5303066}50%{box-shadow:0 4px 24px #c5303099}to{box-shadow:0 4px 16px #c5303066}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--color-surface);border-top:1px solid var(--color-border);z-index:90}.bottom-nav-items{display:flex;height:100%}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;color:var(--color-text-disabled);transition:color var(--transition-fast);font-size:.625rem;font-weight:500;position:relative;text-decoration:none;background:none;border:none}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.active:after{content:"";position:absolute;bottom:8px;width:4px;height:4px;border-radius:50%;background:var(--color-accent)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}.sidebar-overlay.show{display:block}.page-split-layout{display:grid;grid-template-columns:1fr 380px;gap:24px}.page-split-layout.w-360{grid-template-columns:1fr 360px}.page-split-layout.w-340{grid-template-columns:1fr 340px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.stat-grid.cols-3,.kpi-grid.cols-3{grid-template-columns:repeat(3,1fr)}.kpi-grid.cols-4{grid-template-columns:repeat(4,1fr)}.kpi-grid.cols-5{grid-template-columns:repeat(5,1fr)}@media(max-width:1200px){.kpi-grid.cols-5{grid-template-columns:repeat(3,1fr)}}@media(max-width:1023px){.page-split-layout,.page-split-layout.w-360,.page-split-layout.w-340{grid-template-columns:1fr}.kpi-grid.cols-5{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr!important;gap:var(--space-4)!important}.kpi-grid,.kpi-grid.cols-3,.kpi-grid.cols-4,.kpi-grid.cols-5,.stat-grid,.stat-grid.cols-3{grid-template-columns:repeat(2,1fr)!important;gap:var(--space-3)!important}}@media(max-width:479px){.kpi-grid,.kpi-grid.cols-3,.kpi-grid.cols-4,.kpi-grid.cols-5,.stat-grid,.stat-grid.cols-3{grid-template-columns:1fr!important}}@media(max-width:1279px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar .sidebar-title,.sidebar .sidebar-subtitle,.sidebar .sidebar-section-label,.sidebar .nav-item span,.sidebar .sidebar-user-info{display:none}.sidebar .nav-item{justify-content:center;padding:var(--space-3) 0;border-left:none}.sidebar .nav-item.active{border-left:none;border-right:3px solid var(--color-accent)}.sidebar-header{justify-content:center}.sidebar-footer{display:flex;justify-content:center}.top-header{left:var(--sidebar-collapsed-width)}.main-content{margin-left:var(--sidebar-collapsed-width)}}@media(max-width:1023px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.main-content{padding:var(--space-4) var(--space-5)}}@media(max-width:767px){.sidebar{width:var(--sidebar-width);transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.sidebar .sidebar-title,.sidebar .sidebar-subtitle,.sidebar .sidebar-section-label,.sidebar .nav-item span,.sidebar .sidebar-user-info{display:block}.sidebar .nav-item{justify-content:flex-start;padding:var(--space-3) var(--space-5);border-left:3px solid transparent;border-right:none}.sidebar .nav-item.active{border-left-color:var(--color-accent);border-right:none}.sidebar-header,.sidebar-footer{justify-content:flex-start}.top-header{left:0}.hamburger-btn{display:flex}.main-content{margin-left:0;width:100%;max-width:100%;padding:var(--space-4);margin-bottom:64px}.search-box{display:none}.bottom-nav{display:block}.fab{display:flex}.login-branding{display:none}.login-card{padding:var(--space-6)}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.kpi-value{font-size:1.5rem}.cta-banner{flex-direction:column;text-align:center;padding:var(--space-6)}.stepper-label{display:none}.page-header-flex{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.page-header-flex .btn{width:100%}.card-header,.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.card-header .btn,.section-header .btn{width:100%}.modal{max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:85vh;position:fixed;bottom:0;animation:slideUpMobile .3s ease}.notif-panel{position:fixed;top:var(--header-height);left:var(--space-4);right:var(--space-4);width:auto;max-width:calc(100vw - var(--space-8));z-index:999}}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:479px){.main-content{padding:var(--space-3)}.card{padding:var(--space-4);border-radius:var(--radius-md)}.btn-lg{height:48px;min-height:48px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}#root{width:100%;min-height:100vh}
