html{font-size:17px}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;min-height:100vh;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#374151}:root{--bg:#f0f2f5;--bg-panel:#fff;--bg-hover:#f5f6fa;--text-primary:#1a1d2e;--text-sec:#6b7280;--text-muted:#9ca3af;--border:#e5e7eb;--input-bg:#f9fafb;--sidebar-bg:#fff;--sidebar-w:240px;--header-h:80px;--radius:16px;--shadow-sm:0 1px 3px #00000012;--shadow-md:0 4px 16px #0000001a}[data-theme=dark]{--bg:#0f1117;--bg-panel:#1a1d2e;--bg-hover:#232638;--text-primary:#f0f2f8;--text-sec:#9ca3af;--text-muted:#6b7280;--border:#2d3148;--input-bg:#232638;--sidebar-bg:#141624;--calendar-icon-filter:invert(.7)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif}.app-shell{min-height:100vh;display:flex}.app-main{min-width:0;margin-left:var(--sidebar-w);flex-direction:column;flex:1;transition:margin-left .25s;display:flex}.app-main.sidebar-collapsed{margin-left:0}.app-content{flex:1;padding:1.75rem 2rem;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar--collapsed{border-right-width:0;width:0}.sidebar-logo{height:var(--header-h);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;padding:.5rem 1rem;display:flex;overflow:hidden}.sidebar-logo-img{object-fit:contain;width:auto;max-width:220px;height:64px;transition:width .25s,height .25s}.logo-text{color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap;font-size:1.15rem;font-weight:800;transition:opacity .2s}.logo-text span{color:#00c9a7}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:3px;padding:.85rem 1.25rem;display:flex}.sidebar-copyright{color:#000;opacity:.7;text-align:center;white-space:nowrap;margin:0;font-size:.65rem}.sidebar-version{color:#000;letter-spacing:.06em;opacity:.65;white-space:nowrap;font-size:.65rem;font-weight:600}.nav-section-label{letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;white-space:nowrap;padding:.9rem .6rem .4rem;font-size:.63rem;font-weight:700;transition:opacity .2s;overflow:hidden}.nav-section-label.sidebar-section-toggle:hover{color:var(--text-sec)}.nav-list{flex-direction:column;gap:2px;list-style:none;display:flex}.nav-item{border-radius:10px;overflow:hidden}.nav-link{color:var(--text-sec);cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:10px;padding:.65rem .85rem;font-size:.87rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active .nav-link{color:#00c9a7;background:#00c9a71a;font-weight:700}.nav-item.active .nav-link .nav-icon svg{color:#00c9a7}.nav-icon{color:inherit;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s;display:flex}.nav-icon svg{font-size:20px!important}.nav-label{flex:1;transition:opacity .2s}.nav-badge{color:#fff;background:#e84d4d;border-radius:20px;padding:1px 6px;font-size:.62rem;font-weight:700;transition:opacity .2s}.nav-arrow{color:var(--text-muted);transition:opacity .2s;font-size:16px!important}.header{height:var(--header-h);background:var(--bg-panel);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:0 2rem;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:1rem;display:flex}.header-toggle{border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-sec);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.header-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.header-breadcrumb{color:var(--text-primary);font-size:.85rem;font-weight:600}.header-right{align-items:center;gap:.75rem;display:flex}.header-icon-btn{border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-sec);background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex;position:relative}.header-icon-btn:hover{background:var(--bg-hover)}.header-icon-btn .badge{border:1.5px solid var(--bg-panel);background:#e84d4d;border-radius:50%;width:7px;height:7px;position:absolute;top:4px;right:4px}.header-avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00c9a7 0%,#3b82f6 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.82rem;font-weight:800;display:flex}.header-avatar-wrap{position:relative}.avatar-menu{background:var(--bg-panel);border:1px solid var(--border);min-width:220px;box-shadow:var(--shadow-md);z-index:200;border-radius:14px;padding:.5rem;position:absolute;top:calc(100% + 8px);right:0}.avatar-menu-brand{background:linear-gradient(135deg,#00c9a7 0%,#3b82f6 100%);border-radius:10px;justify-content:center;align-items:center;margin-bottom:.25rem;padding:.6rem;display:flex}.avatar-menu-brand-icon{object-fit:contain;width:36px;height:36px}.avatar-menu-user{align-items:center;gap:10px;padding:.6rem .75rem;display:flex}.avatar-menu-avatar{color:#fff;background:linear-gradient(135deg,#00c9a7 0%,#3b82f6 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.82rem;font-weight:800;display:flex}.avatar-menu-name{color:var(--text-primary);font-size:.87rem;font-weight:700}.avatar-menu-email{color:var(--text-muted);margin-top:1px;font-size:.74rem}.avatar-menu-divider{border:none;border-top:1px solid var(--border);margin:.4rem 0}.avatar-menu-item{width:100%;color:var(--text-sec);cursor:pointer;background:0 0;border:none;border-radius:9px;align-items:center;gap:8px;padding:.6rem .75rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .15s,color .15s;display:flex}.avatar-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.avatar-menu-item--danger{color:#e84d4d}.avatar-menu-item--danger:hover{color:#e84d4d;background:#e84d4d14}.page-title{color:var(--text-primary);margin-bottom:.25rem;font-size:1.45rem;font-weight:800}.page-sub{color:var(--text-sec);margin-bottom:1.5rem;font-size:.83rem}.tbl-wrap{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;overflow:hidden}.tbl{border-collapse:collapse;width:100%}.tbl th,.tbl td{text-align:left;padding:.85rem 1.25rem;font-size:.84rem}.tbl th{background:var(--bg-hover);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);font-size:.7rem;font-weight:700}.tbl td{color:var(--text-primary);border-bottom:1px solid var(--border)}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg-hover)}.status-badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.status-badge--active,.status-badge--approved{color:#00c9a7;background:#00c9a71f}.status-badge--inactive{color:#6b7280;background:#6b72801f}.status-badge--maintenance{color:#f07a1a;background:#f07a1a1f}.status-badge--blocked,.status-badge--rejected{color:#e84d4d;background:#e84d4d1f}.status-badge--pending{color:#3b82f6;background:#3b82f61f}.status-badge--high{color:#f07a1a;background:#f07a1a1f}.status-badge--critical{color:#e84d4d;background:#e84d4d1f}.status-badge--medium{color:#3b82f6;background:#3b82f61f}.status-badge--low{color:#00c9a7;background:#00c9a71f}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:.55rem 1.2rem;font-family:inherit;font-size:.84rem;font-weight:600;transition:opacity .15s,transform .15s;display:inline-flex}.btn:hover{opacity:.88;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn--primary{color:#fff;background:#00c9a7}.btn--danger{color:#fff;background:#e84d4d}.btn--ghost{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn--sm{padding:.35rem .85rem;font-size:.78rem}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.search-box{background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:200px;padding:0 12px;display:flex}.search-box svg{color:var(--text-muted);font-size:18px!important}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:.6rem 0;font-family:inherit;font-size:.85rem}.search-box input::placeholder{color:var(--text-muted)}.filter-select{background:var(--bg-panel);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:10px;outline:none;padding:.6rem 1rem;font-family:inherit;font-size:.83rem}.filter-select:focus{border-color:#00c9a7}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.9rem}.empty-state svg{opacity:.4;margin-bottom:.75rem;font-size:48px!important}.spinner{justify-content:center;align-items:center;padding:3rem;display:flex}.spinner:after{content:"";border:3px solid var(--border);border-top-color:#00c9a7;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:20px;width:100%;max-width:520px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 24px 60px #0000002e}.modal-title{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.15rem;font-weight:800}.form-group{flex-direction:column;gap:4px;margin-bottom:1rem;display:flex}.form-group label{color:var(--text-sec);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:var(--input-bg);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;outline:none;width:100%;padding:.65rem 1rem;font-family:inherit;font-size:.87rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#00c9a7}.form-group textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=520px){.form-row{grid-template-columns:1fr}}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.login-page{background:var(--bg);background-image:radial-gradient(at 20%,#00c9a714 0%,#0000 60%),radial-gradient(at 80% 20%,#3b82f612 0%,#0000 55%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--bg-panel);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-md), 0 0 0 1px #00c9a70f;border-radius:24px;padding:2.75rem 2.5rem 2.5rem}.login-brand{text-align:center;margin-bottom:2rem}.login-brand-logo{object-fit:contain;width:auto;max-width:260px;height:72px;margin:0 auto 1rem;display:block}.login-brand-name{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-size:1rem;font-weight:700}.login-brand-icon{background:linear-gradient(135deg,#00c9a7 0%,#0fa6a7 100%);border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1rem;display:flex;box-shadow:0 8px 24px #00c9a747}.login-logo{color:var(--text-primary);letter-spacing:-.03em;margin-bottom:.3rem;font-size:1.75rem;font-weight:800}.login-logo span{color:#00c9a7}.login-sub{color:var(--text-sec);font-size:.83rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--text-sec);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;font-weight:700}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-wrap input{background:var(--input-bg);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:12px;outline:none;padding:.75rem 2.75rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.login-input-wrap input::placeholder{color:var(--text-muted)}.login-input-wrap input:focus{border-color:#00c9a7;box-shadow:0 0 0 3px #00c9a726}.login-input-wrap input:disabled{opacity:.6;cursor:not-allowed}.login-input-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:.8rem}.login-eye{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;padding:0;transition:color .15s;display:flex;position:absolute;right:.75rem}.login-eye:hover{color:var(--text-primary)}.login-error{color:#e84d4d;background:#e84d4d17;border:1px solid #e84d4d47;border-radius:10px;padding:.65rem 1rem;font-size:.82rem;font-weight:500}.login-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#00c9a7 0%,#00b896 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:.25rem;padding:.85rem;font-family:inherit;font-size:.92rem;font-weight:700;transition:opacity .15s,transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #00c9a74d}.login-submit:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #00c9a761}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.login-spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.65s linear infinite spin;display:inline-block}.pc-page{flex-direction:column;gap:1.5rem;display:flex}.pc-header{justify-content:space-between;align-items:flex-start;display:flex}.pc-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}@media (width<=1100px){.pc-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=780px){.pc-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.pc-grid{grid-template-columns:1fr}}.pc-card{background:var(--bg-panel);border:1px solid var(--border);cursor:pointer;border-radius:16px;outline:none;flex-direction:column;align-items:flex-start;gap:1rem;padding:1.5rem 1.25rem 1.35rem;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;position:relative}.pc-card:hover{border-color:#00c9a759;transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.pc-card:focus-visible{box-shadow:0 0 0 3px #00c9a74d}.pc-card:active{transform:translateY(-1px)}.pc-icon-box{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.pc-card-body{flex-direction:column;gap:4px;display:flex}.pc-card-title{color:var(--text-primary);margin:0;font-size:.97rem;font-weight:700}.pc-card-desc{color:var(--text-sec);margin:0;font-size:.78rem;line-height:1.45}.pc-title-tooltip{cursor:default;position:relative}.pc-title-tooltip:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;text-overflow:ellipsis;opacity:0;pointer-events:none;z-index:100;background:#1e1e2e;border-radius:6px;max-width:260px;padding:5px 9px;font-size:.72rem;font-weight:400;transition:opacity .18s,transform .18s;position:absolute;bottom:calc(100% + 7px);left:0;overflow:hidden;transform:translateY(4px);box-shadow:0 4px 12px #0003}.pc-title-tooltip:hover:after{opacity:1;transform:translateY(0)}.pc-title-link{color:inherit;text-decoration:none}.pc-badge{border-radius:50%;width:8px;height:8px;position:absolute;top:14px;right:14px}.pc-skeleton{background:var(--border);border-radius:16px;height:140px;animation:1.4s ease-in-out infinite alternate pc-pulse}@keyframes pc-pulse{0%{opacity:.45}to{opacity:.9}}.pc-error{color:#e84d4d;background:#e84d4d14;border:1px solid #e84d4d40;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:.75rem 1rem;font-size:.85rem;display:flex}.pc-retry{cursor:pointer;color:#e84d4d;white-space:nowrap;background:0 0;border:none;align-items:center;gap:4px;font-family:inherit;font-size:.82rem;font-weight:600;display:flex}.pc-retry:hover{text-decoration:underline}
