@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-primary:#0f1512;--bg-secondary:#161d1a;--bg-card:#1a231fb3;--bg-card-hover:#25322bbf;--border-color:#323e3880;--border-glow:#f47ba338;--text-primary:#f1eeef;--text-secondary:#b7c2bd;--text-dim:#83918a;--primary:#f47ba3;--primary-hover:#f797b7;--primary-glow:#f47ba359;--accent:#31c46e;--accent-hover:#43d07e;--accent-glow:#31c46e4d;--success:#31c46e;--success-bg:#31c46e26;--warning:#f6a823;--warning-bg:#f6a82326;--danger:#f04251;--danger-bg:#f0425126;--glass-blur:blur(16px);--shadow-premium:0 10px 40px -10px #00000080, 0 0 1px 1px #ffffff0d inset;--transition-smooth:all .3s cubic-bezier(.25, .8, .25, 1);--transition-fast:all .15s ease;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-heading:"Outfit", sans-serif}[data-theme=light]{--bg-primary:#f2f7f4;--bg-secondary:#f9fbfa;--bg-card:#fffc;--bg-card-hover:#fffffff2;--border-color:#d1dbd58c;--border-glow:#e7558626;--text-primary:#17261f;--text-secondary:#4a6457;--text-dim:#7e958a;--primary:#e75586;--primary-hover:#e23670;--primary-glow:#e7558633;--accent:#209752;--accent-hover:#1b7e44;--accent-glow:#2097522e;--success:#209752;--success-bg:#2097521a;--warning:#d48d11;--warning-bg:#d48d111a;--danger:#c91d2b;--danger-bg:#c91d2b1a;--shadow-premium:0 10px 30px -15px #0000001a, 0 0 1px 1px #fffc inset}*{box-sizing:border-box;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);flex-direction:column;min-height:100vh;font-size:15px;line-height:1.6;transition:background-color .4s,color .4s;display:flex;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%{box-shadow:0 0 0 0 var(--primary-glow)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes ringGrow{0%{opacity:.8;transform:scale(.95)}50%{opacity:.4;transform:scale(1.05)}to{opacity:0;transform:scale(1.15)}}.animate-fade{animation:.4s cubic-bezier(.25,.8,.25,1) forwards fadeIn}#app{flex-direction:column;width:100%;max-width:1400px;min-height:100vh;margin:0 auto;padding:0 20px;display:flex}.demo-control-bar{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);box-shadow:var(--shadow-premium);z-index:100;border-top:none;border-radius:0 0 16px 16px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px 24px;animation:.5s fadeIn;display:flex}.demo-title-area{align-items:center;gap:12px;display:flex}.demo-badge{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;letter-spacing:1px;text-transform:uppercase;box-shadow:0 0 12px var(--primary-glow);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.demo-title{font-family:var(--font-heading);letter-spacing:.5px;font-size:16px;font-weight:700}.demo-actions{align-items:center;gap:16px;display:flex}.btn-theme-toggle{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;width:38px;height:38px;transition:var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-theme-toggle:hover{border-color:var(--primary);color:var(--primary);background:#775ff21a}.role-switch-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:30px;padding:4px;display:flex;position:relative}.role-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);z-index:2;background:0 0;border:none;border-radius:20px;align-items:center;gap:8px;padding:6px 18px;font-size:13px;font-weight:600;display:flex}.role-btn.active{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-hover));box-shadow:0 4px 12px var(--primary-glow)}.btn-reset-demo{color:var(--danger);cursor:pointer;transition:var(--transition-fast);background:#ef39481a;border:1px solid #ef39484d;border-radius:30px;padding:6px 14px;font-size:12px;font-weight:600}.btn-reset-demo:hover{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 0 12px var(--danger-bg)}.portal-container{flex-grow:1;grid-template-columns:240px 1fr;gap:24px;margin-bottom:24px;display:grid;position:relative}@media (width<=900px){.portal-container{grid-template-columns:1fr}}.portal-sidebar{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);box-shadow:var(--shadow-premium);border-radius:16px;flex-direction:column;gap:24px;height:fit-content;padding:24px 16px;display:flex}.user-profile-widget{text-align:center;border-bottom:1px solid var(--border-color);flex-direction:column;align-items:center;padding-bottom:20px;display:flex}.user-avatar-glow{background:linear-gradient(135deg, var(--primary), var(--accent));border-radius:50%;width:68px;height:68px;margin-bottom:12px;padding:3px;position:relative;box-shadow:0 0 20px #aa3bff33}.user-avatar-glow:after{content:"";opacity:.15;border:2px solid #fff;border-radius:50%;position:absolute;inset:0}.user-avatar-inner{background:var(--bg-secondary);width:100%;height:100%;color:var(--text-primary);font-size:22px;font-weight:800;font-family:var(--font-heading);border-radius:50%;justify-content:center;align-items:center;display:flex}.user-name{font-family:var(--font-heading);color:var(--text-primary);font-size:16px;font-weight:700}.user-dept{color:var(--text-secondary);margin-top:2px;font-size:12px}.user-badge{background:var(--border-color);color:var(--text-primary);border-radius:10px;margin-top:8px;padding:1px 8px;font-size:10px;font-weight:700;display:inline-block}.sidebar-tabs{flex-direction:column;gap:6px;display:flex}.tab-nav-btn{color:var(--text-secondary);cursor:pointer;text-align:left;transition:var(--transition-fast);background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.tab-nav-btn:hover{color:var(--primary);background:#775ff214;transform:translate(4px)}.tab-nav-btn.active{color:var(--primary);border-left:3px solid var(--primary);background:linear-gradient(90deg,#775ff226,#0000);border-radius:0 10px 10px 0;font-weight:700;transform:none}.tab-nav-btn svg{stroke-width:2.2px;width:18px;height:18px}.portal-workspace{flex-direction:column;gap:24px;min-width:0;display:flex}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:16px;padding:24px}.glass-card:hover{border-color:var(--border-glow)}.glass-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{font-family:var(--font-heading);letter-spacing:.3px;color:var(--text-primary);align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.card-title svg{color:var(--primary);width:20px;height:20px}.clock-container{text-align:center;flex-direction:column;align-items:center;padding:24px 0;display:flex;position:relative}.clock-display{font-family:var(--font-heading);letter-spacing:2px;color:var(--text-primary);text-shadow:0 0 30px #ffffff1a;margin-bottom:6px;font-size:54px;font-weight:800}.clock-date{color:var(--text-secondary);margin-bottom:32px;font-size:14px;font-weight:600}.clock-actions-grid{grid-template-columns:1fr 1fr;gap:16px;width:100%;max-width:320px;display:grid}.btn-clock{cursor:pointer;transition:var(--transition-smooth);color:#fff;border:none;border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:16px;font-size:15px;font-weight:700;display:flex;position:relative;overflow:hidden}.btn-clock-in{background:linear-gradient(135deg, var(--primary), var(--primary-hover));box-shadow:0 6px 20px var(--primary-glow)}.btn-clock-in:hover:not(:disabled){box-shadow:0 10px 24px var(--primary-glow);transform:translateY(-3px)}.btn-clock-out{background:linear-gradient(135deg, var(--accent), var(--accent-hover));box-shadow:0 6px 20px var(--accent-glow)}.btn-clock-out:hover:not(:disabled){box-shadow:0 10px 24px var(--accent-glow);transform:translateY(-3px)}.btn-clock:disabled{opacity:.4;cursor:not-allowed;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-dim);box-shadow:none!important;transform:none!important}.btn-clock svg{width:22px;height:22px}.clock-status-display{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;gap:24px;margin-top:24px;padding:14px 20px;display:flex}.status-item{text-align:left}.status-label{color:var(--text-dim);text-transform:uppercase;font-size:11px;font-weight:700}.status-value{color:var(--text-primary);font-size:14px;font-weight:700}.status-value.present{color:var(--success)}.form-group{text-align:left;margin-bottom:20px}.form-label{color:var(--text-secondary);letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-input,.form-textarea,.form-select{background:var(--bg-primary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);transition:var(--transition-fast);border-radius:10px;padding:12px 14px;font-size:14px}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.form-textarea{resize:vertical;min-height:100px}.form-help{color:var(--text-dim);margin-top:4px;font-size:11px}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;cursor:pointer;transition:var(--transition-fast);box-shadow:0 4px 14px var(--primary-glow);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:700;display:inline-flex}.btn-primary:hover{box-shadow:0 6px 18px var(--primary-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.request-feed{flex-direction:column;gap:12px;display:flex}.request-card{background:var(--bg-primary);border:1px solid var(--border-color);transition:var(--transition-fast);border-radius:12px;justify-content:space-between;align-items:center;padding:16px;display:flex}.request-card:hover{border-color:var(--border-glow)}.req-left{align-items:flex-start;gap:14px;display:flex}.req-icon-box{border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;display:flex}.req-icon-box.leave{color:var(--primary);background:#775ff21f}.req-icon-box.expense{color:var(--accent);background:#ec51b81f}.req-info{text-align:left}.req-title{color:var(--text-primary);font-size:14px;font-weight:700}.req-details{color:var(--text-secondary);margin-top:2px;font-size:12px}.req-meta{color:var(--text-dim);gap:12px;margin-top:4px;font-size:11px;display:flex}.status-badge{text-transform:uppercase;border-radius:30px;padding:3px 10px;font-size:11px;font-weight:700}.status-badge.pending{background:var(--warning-bg);color:var(--warning);border:1px solid #f6a82333}.status-badge.approved{background:var(--success-bg);color:var(--success);border:1px solid #1dc97333}.status-badge.rejected{background:var(--danger-bg);color:var(--danger);border:1px solid #ef394833}.req-actions{gap:8px;display:flex}.btn-action-circle{cursor:pointer;width:32px;height:32px;transition:var(--transition-fast);color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-action-circle.approve{background:var(--success);box-shadow:0 2px 8px var(--success-bg)}.btn-action-circle.approve:hover{box-shadow:0 4px 12px var(--success-bg);transform:scale(1.1)}.btn-action-circle.reject{background:var(--danger);box-shadow:0 2px 8px var(--danger-bg)}.btn-action-circle.reject:hover{box-shadow:0 4px 12px var(--danger-bg);transform:scale(1.1)}.btn-action-circle svg{width:16px;height:16px}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.metric-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);box-shadow:var(--shadow-premium);border-radius:14px;justify-content:space-between;align-items:center;padding:20px;display:flex}.metric-left{text-align:left}.metric-label{color:var(--text-secondary);font-size:12px;font-weight:600}.metric-number{font-family:var(--font-heading);color:var(--text-primary);margin-top:4px;font-size:28px;font-weight:800}.metric-badge{border-radius:10px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.metric-icon-wrapper{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.metric-icon-wrapper.blue{color:var(--primary);background:#775ff21f}.metric-icon-wrapper.purple{color:var(--accent);background:#ec51b81f}.metric-icon-wrapper.green{color:var(--success);background:#1dc9731f}.charts-split-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.charts-split-grid{grid-template-columns:1fr}}.chart-visual-box{justify-content:center;align-items:center;height:180px;display:flex;position:relative}.donut-svg{width:140px;height:140px;transform:rotate(-90deg)}.donut-bg{fill:none;stroke:var(--border-color);stroke-width:14px}.donut-segment-1{fill:none;stroke:var(--primary);stroke-width:14px;stroke-dasharray:220 360;stroke-dashoffset:0;transition:var(--transition-smooth)}.donut-segment-2{fill:none;stroke:var(--accent);stroke-width:14px;stroke-dasharray:80 360;stroke-dashoffset:-220px;transition:var(--transition-smooth)}.donut-center-text{flex-direction:column;align-items:center;display:flex;position:absolute}.donut-number{font-family:var(--font-heading);color:var(--text-primary);font-size:24px;font-weight:800}.donut-label{color:var(--text-dim);font-size:10px}.css-bars-container{justify-content:space-between;align-items:flex-end;width:100%;height:120px;padding:0 10px;display:flex}.bar-wrapper{flex-direction:column;flex-grow:1;align-items:center;display:flex}.bar-fill{background:linear-gradient(to top, var(--primary), var(--accent));width:20px;box-shadow:0 2px 8px var(--primary-glow);border-radius:6px 6px 0 0;transition:height .6s cubic-bezier(.25,.8,.25,1)}.bar-label{color:var(--text-dim);margin-top:8px;font-size:10px}.directory-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}@media (width<=600px){.directory-toolbar{flex-direction:column;align-items:stretch}}.directory-list{flex-direction:column;gap:10px;display:flex}.directory-row{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.emp-row-left{align-items:center;gap:12px;display:flex}.emp-avatar-dot{background:var(--border-color);width:32px;height:32px;color:var(--text-primary);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.emp-row-info{text-align:left}.emp-row-name{font-size:14px;font-weight:700}.emp-row-meta{color:var(--text-dim);font-size:11px}.terminal-box{border:1px solid var(--border-color);color:#63e9a6;text-align:left;background:#0a0b10;border-radius:12px;max-height:250px;padding:16px;font-family:Courier New,Courier,monospace;font-size:12px;overflow-y:auto}.log-entry{margin-bottom:6px;line-height:1.4;animation:.3s slideInRight}.log-time{color:var(--text-dim)}.log-msg{margin-left:8px}.profile-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=600px){.profile-grid{grid-template-columns:1fr}}.credential-tag-list{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.credential-tag{color:var(--primary);background:#775ff21a;border:1px solid #775ff240;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.credential-tag svg{width:12px;height:12px}.toast-container{z-index:1000;flex-direction:column;gap:10px;width:100%;max-width:360px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);transition:var(--transition-smooth);border-radius:12px;align-items:center;gap:12px;padding:14px 18px;animation:.3s cubic-bezier(.25,.8,.25,1) forwards slideInRight;display:flex;box-shadow:0 20px 40px -10px #0006}.toast.success{border-left:4px solid var(--success)}.toast.info{border-left:4px solid var(--primary)}.toast.warning{border-left:4px solid var(--warning)}.toast.error{border-left:4px solid var(--danger)}.toast-content{text-align:left;flex-grow:1}.toast-title{font-size:13px;font-weight:700}.toast-message{color:var(--text-secondary);margin-top:1px;font-size:12px}.btn-toast-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none}.btn-toast-close:hover{color:var(--text-primary)}.portal-footer{text-align:center;border-top:1px solid var(--border-color);margin-top:auto;padding:24px 0}.loki-attribution{font-family:var(--font-heading);letter-spacing:.8px;color:var(--text-dim);text-transform:uppercase;justify-content:center;align-items:center;gap:8px;font-size:11px;display:flex}.loki-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent);border-radius:50%;animation:2s infinite pulseGlow;display:inline-block}.info-banner{border-left:3px solid var(--primary);text-align:left;color:var(--text-secondary);background:linear-gradient(90deg,#775ff21a,#0000);border-radius:0 8px 8px 0;margin-bottom:20px;padding:12px 16px;font-size:13px}
