:root{--portal-bg:#0f1117;--portal-surface:#1a1d27;--portal-surface-2:#22263a;--portal-border:#ffffff14;--portal-text:#f0f2f8;--portal-text-2:#8b92a9;--portal-blue:#378add;--portal-blue-light:#378add1f;--portal-green:#639922;--portal-green-light:#63992224;--portal-amber:#ba7517;--portal-amber-light:#ba751724;--portal-red:#e24b4a;--portal-red-light:#e24b4a24;--portal-purple:#7c6fd0;--portal-purple-light:#7c6fd024;--sidebar-width:240px}.portal-shell *{box-sizing:border-box}.portal-shell{background:var(--portal-bg);height:100dvh;color:var(--portal-text);font-family:var(--font-inter,system-ui, sans-serif);display:flex;overflow:hidden}.portal-sidebar{width:var(--sidebar-width);background:var(--portal-surface);border-right:1px solid var(--portal-border);flex-direction:column;flex-shrink:0;gap:4px;padding:24px 0;display:flex;overflow-y:auto}.portal-sidebar-logo{color:var(--portal-text);border-bottom:1px solid var(--portal-border);align-items:center;gap:10px;margin-bottom:12px;padding:0 20px 20px;font-size:15px;font-weight:600;display:flex}.portal-sidebar-logo svg{color:var(--portal-blue)}.sidebar-nav-item{color:var(--portal-text-2);cursor:pointer;border-radius:10px;align-items:center;gap:10px;margin:0 10px;padding:10px 20px;font-size:13.5px;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-nav-item:hover{background:var(--portal-surface-2);color:var(--portal-text)}.sidebar-nav-item.active{background:var(--portal-blue-light);color:var(--portal-blue)}.sidebar-nav-item.active svg{color:var(--portal-blue)}.sidebar-spacer{flex:1}.sidebar-user{background:var(--portal-surface-2);border-radius:12px;align-items:center;gap:10px;margin:12px 10px 0;padding:12px;display:flex}.sidebar-avatar{background:var(--portal-blue-light);width:36px;height:36px;color:var(--portal-blue);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.sidebar-user-name{color:var(--portal-text);font-size:13px;font-weight:500}.sidebar-user-role{color:var(--portal-text-2);font-size:11px}.portal-main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.portal-topbar{background:var(--portal-surface);border-bottom:1px solid var(--portal-border);z-index:20;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.portal-topbar-title{font-size:16px;font-weight:600}.portal-greeting{color:var(--portal-text-2);font-size:11px}.portal-bottom-nav{background:var(--portal-surface);border-top:1px solid var(--portal-border);z-index:30;height:68px;padding-top:8px;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-grid{grid-template-columns:repeat(5,1fr);height:100%;display:grid}.bottom-nav-item{cursor:pointer;color:var(--portal-text-2);flex-direction:column;align-items:center;gap:3px;padding:4px 0;font-size:10px;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item.active{color:var(--portal-blue)}.bottom-nav-item svg{width:22px;height:22px}.portal-page{flex:1;padding:24px}.portal-hero{background:linear-gradient(135deg, #1e2d45 0%, var(--portal-surface) 100%);border:1px solid var(--portal-border);border-radius:18px;margin-bottom:20px;padding:20px}.hero-label{color:var(--portal-text-2);margin-bottom:6px;font-size:11px}.hero-status{align-items:center;gap:10px;display:flex}.hero-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.hero-text{font-size:16px;font-weight:600}.hero-sub{color:var(--portal-text-2);margin-top:4px;font-size:12px}.hero-stats{border-top:1px solid var(--portal-border);grid-template-columns:repeat(4,1fr);gap:0;margin-top:16px;padding-top:16px;display:grid}.hero-stat{text-align:center}.hs-val{color:var(--portal-text);font-size:14px;font-weight:600}.hs-lab{color:var(--portal-text-2);margin-top:2px;font-size:10px}.portal-kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.portal-kpi{background:var(--portal-surface);border:1px solid var(--portal-border);cursor:default;border-radius:14px;padding:16px}.kpi-icon{margin-bottom:8px;font-size:18px}.kpi-label{color:var(--portal-text-2);margin-bottom:6px;font-size:11px}.kpi-value{color:var(--portal-text);font-size:24px;font-weight:700}.kpi-sub{color:var(--portal-text-2);margin-top:2px;font-size:11px}.portal-quick-actions{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.qa-btn{background:var(--portal-surface);border:1px solid var(--portal-border);color:var(--portal-text);cursor:pointer;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;min-width:130px;padding:10px 16px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.qa-btn:hover{background:var(--portal-surface-2);border-color:var(--portal-blue)}.portal-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.portal-section-title{color:var(--portal-text);font-size:14px;font-weight:600}.portal-section-link{color:var(--portal-blue);cursor:pointer;font-size:12px}.portal-table-wrap{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:14px;overflow:hidden}.portal-table{border-collapse:collapse;width:100%;font-size:13px}.portal-table th{text-align:left;color:var(--portal-text-2);border-bottom:1px solid var(--portal-border);background:var(--portal-surface-2);padding:12px 16px;font-size:11px;font-weight:500}.portal-table td{border-bottom:1px solid var(--portal-border);color:var(--portal-text);padding:12px 16px}.portal-table tr:last-child td{border-bottom:none}.portal-table tbody tr:hover{background:var(--portal-surface-2)}.status-pill{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-block}.sp-present{background:var(--portal-green-light);color:#7ec736}.sp-late{background:var(--portal-amber-light);color:#f5a623}.sp-absent{background:var(--portal-red-light);color:#ff6b6b}.sp-leave{background:var(--portal-blue-light);color:var(--portal-blue)}.sp-mp{background:var(--portal-purple-light);color:var(--portal-purple)}.sp-holiday{background:var(--portal-blue-light);color:var(--portal-blue)}.filter-tabs{gap:6px;margin-bottom:16px;display:flex;position:relative}.filter-tab{border:1px solid var(--portal-border);color:var(--portal-text-2);cursor:pointer;background:0 0;border-radius:20px;padding:6px 16px;font-size:12px;font-weight:500;transition:all .15s}.filter-tab.active{background:var(--portal-blue);color:#fff;border-color:var(--portal-blue)}.profile-card{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:14px;margin-bottom:16px;overflow:hidden}.prow{border-bottom:1px solid var(--portal-border);align-items:center;padding:12px 16px;font-size:13px;display:flex}.prow:last-child{border-bottom:none}.prow-key{color:var(--portal-text-2);flex-shrink:0;width:130px}.prow-val{color:var(--portal-text);flex:1}.prow-eye{color:var(--portal-text-2);cursor:pointer;margin-left:8px;transition:color .15s}.prow-eye:hover{color:var(--portal-blue)}.portal-avatar{background:var(--portal-blue-light);width:64px;height:64px;color:var(--portal-blue);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex}.notif-badge{background:var(--portal-red);color:#fff;border:2px solid var(--portal-surface);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.notif-panel{background:var(--portal-surface);border:1px solid var(--portal-border);z-index:50;border-radius:16px;width:300px;position:absolute;top:56px;right:16px;overflow:hidden;box-shadow:0 20px 60px #0006}.notif-header{border-bottom:1px solid var(--portal-border);justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;font-weight:600;display:flex}.notif-item{border-bottom:1px solid var(--portal-border);cursor:pointer;gap:10px;padding:12px 16px;transition:background .1s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--portal-surface-2)}.notif-item.unread{background:#378add0a}.notif-dot{background:var(--portal-blue);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:5px}.notif-dot.read{background:var(--portal-border)}.notif-text{color:var(--portal-text-2);font-size:12px;line-height:1.5}.notif-text strong{color:var(--portal-text);font-weight:500}.notif-time{color:var(--portal-text-2);margin-top:3px;font-size:10px}.modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (min-width:768px){.modal-backdrop{align-items:center}}.bottom-sheet{background:var(--portal-surface);border-radius:20px 20px 0 0;width:100%;max-width:560px;max-height:85dvh;padding:20px;overflow-y:auto}@media (min-width:768px){.bottom-sheet{border-radius:20px}}.sheet-handle{background:var(--portal-border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.sheet-title{margin-bottom:20px;font-size:16px;font-weight:600}.portal-form-group{margin-bottom:16px}.portal-label{color:var(--portal-text-2);margin-bottom:6px;font-size:12px;display:block}.portal-input,.portal-select,.portal-textarea{background:var(--portal-surface-2);border:1px solid var(--portal-border);width:100%;color:var(--portal-text);border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:13px;transition:border-color .15s}.portal-input:focus,.portal-select:focus,.portal-textarea:focus{border-color:var(--portal-blue)}.portal-textarea{resize:vertical;min-height:80px}.portal-select option{background:var(--portal-surface)}.btn-primary{background:var(--portal-blue);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:12px;font-size:14px;font-weight:600;transition:opacity .15s}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{border:1px solid var(--portal-border);color:var(--portal-text-2);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;transition:all .15s;display:flex}.btn-ghost:hover{background:var(--portal-surface-2);color:var(--portal-text)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg, var(--portal-surface) 25%, var(--portal-surface-2) 50%, var(--portal-surface) 75%);background-size:800px 100%;border-radius:8px;animation:1.4s linear infinite shimmer}.portal-calendar{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:14px;overflow:hidden}.cal-header{border-bottom:1px solid var(--portal-border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.cal-grid{grid-template-columns:repeat(7,1fr);gap:0;display:grid}.cal-day-name{text-align:center;color:var(--portal-text-2);padding:8px 0;font-size:10px;font-weight:500}.cal-cell{aspect-ratio:1;cursor:pointer;color:var(--portal-text-2);border-radius:8px;justify-content:center;align-items:center;margin:2px;font-size:12px;transition:background .1s;display:flex;position:relative}.cal-cell:hover{background:var(--portal-surface-2)}.cal-cell.today{background:var(--portal-blue-light);color:var(--portal-blue);font-weight:700}.cal-cell.approved{background:var(--portal-green-light);color:#7ec736}.cal-cell.holiday{background:var(--portal-red-light);color:#ff6b6b}.cal-cell.pending{border:1.5px dashed var(--portal-amber);color:var(--portal-amber)}.cal-cell.weekend{color:var(--portal-text-2);opacity:.4}.drop-zone{border:2px dashed var(--portal-border);text-align:center;cursor:pointer;color:var(--portal-text-2);border-radius:12px;padding:24px;font-size:13px;transition:border-color .15s,background .15s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--portal-blue);background:var(--portal-blue-light)}@media (max-width:768px){.portal-sidebar{display:none}.portal-bottom-nav{display:block}.portal-topbar{display:flex}.portal-page{padding:16px 16px 84px}.portal-kpi-grid{grid-template-columns:repeat(2,1fr)}.hero-stats{grid-template-columns:repeat(2,1fr);gap:12px}}@media (min-width:769px){.portal-topbar,.portal-bottom-nav{display:none}}
