@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.profile-page-container{display:flex;gap:24px;margin-top:16px}.profile-breadcrumb{font-size:13px;color:var(--text-muted);margin-bottom:24px}.profile-breadcrumb span{color:var(--accent-primary);font-weight:500}.profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.profile-header-title{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:var(--text-primary)}.profile-header-title:before{content:"";display:block;width:4px;height:24px;background:var(--accent-primary);border-radius:4px}.profile-main-card{background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border-color);padding:32px;display:flex;gap:40px;flex:1}.profile-left-col{width:280px;display:flex;flex-direction:column;align-items:center;border-right:1px dashed var(--border-color);padding-right:40px}.profile-avatar-wrapper{position:relative;width:180px;height:180px;border-radius:var(--radius-lg);padding:4px;background:linear-gradient(135deg,#2563eb66,#2563eb00);margin-bottom:24px}.profile-avatar{width:100%;height:100%;border-radius:calc(var(--radius-lg) - 4px);object-fit:cover;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:64px;color:var(--text-muted)}.profile-avatar-edit{position:absolute;bottom:-10px;right:-10px;width:40px;height:40px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb66;cursor:pointer;border:3px solid var(--bg-card);transition:transform .2s}.profile-avatar-edit:hover{transform:scale(1.1)}.profile-name{font-size:24px;font-weight:800;margin-bottom:8px;text-align:center}.profile-role{font-size:13px;color:var(--accent-primary);font-weight:700;text-transform:uppercase;margin-bottom:32px;text-align:center}.profile-stats-row{display:flex;gap:16px;width:100%}.profile-stat-box{flex:1;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:16px 12px;text-align:center}.profile-stat-box-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;margin-bottom:8px}.profile-stat-box-value{font-size:15px;font-weight:700;color:var(--text-primary)}.profile-right-col{flex:1;display:flex;flex-direction:column}.profile-info-grid{display:flex;flex-direction:column;gap:24px;margin-bottom:40px}.profile-info-row{display:flex;align-items:center}.profile-info-label{width:180px;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted);font-weight:600;text-transform:uppercase}.profile-info-label svg{font-size:16px}.profile-info-value{flex:1;font-size:16px;font-weight:600;color:var(--text-primary)}.profile-cards-bottom{display:flex;gap:24px;margin-top:auto}.profile-bottom-card{flex:1;padding:24px;border-radius:var(--radius-lg);display:flex;align-items:center;gap:16px}.profile-bottom-card.orange{background:#ffa7261a;border:1px solid rgba(255,167,38,.2)}.profile-bottom-card.blue{background:#2563eb0d;border:1px solid rgba(37,99,235,.1)}.profile-bc-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:var(--shadow-sm)}.profile-bottom-card.orange .profile-bc-icon{color:#f57c00}.profile-bottom-card.blue .profile-bc-icon{color:#1e3a8a}.profile-bc-content{display:flex;flex-direction:column;gap:4px}.profile-bc-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase}.profile-bc-value{font-size:20px;font-weight:800;color:var(--text-primary)}.profile-actions{display:flex;justify-content:flex-end;gap:16px;margin-top:32px}.profile-btn{padding:12px 24px;border-radius:var(--radius-md);font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s;border:none}.profile-btn-outline{background:var(--bg-secondary);border:1px dashed var(--accent-primary);color:var(--text-primary)}.profile-btn-outline:hover{background:var(--bg-tertiary)}.profile-btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 4px 12px #2563eb4d}.profile-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.profile-support-widget{width:260px;background:#2563eb0d;border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:12px}.ps-title{font-size:14px;font-weight:700;color:#1e3a8a}.ps-desc{font-size:12px;color:var(--text-muted);line-height:1.5}.ps-btn{background:#fff;border:1px solid rgba(37,99,235,.2);color:var(--accent-primary);padding:10px;border-radius:var(--radius-sm);text-align:center;font-weight:600;font-size:13px;cursor:pointer;margin-top:8px}@media (max-width: 1024px){.profile-main-card{flex-direction:column;padding:24px}.profile-left-col{width:100%;border-right:none;border-bottom:1px dashed var(--border-color);padding-right:0;padding-bottom:32px;margin-bottom:32px}.profile-cards-bottom{flex-direction:column}}.leave-mgmt-container{padding:0;width:100%}.leave-mgmt-header{margin-bottom:32px}.leave-mgmt-header h2{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.leave-mgmt-header p{color:var(--text-muted);font-size:15px}.leave-stats-row{display:flex;gap:24px;margin-bottom:32px}.leave-stat-card{flex:1;background:var(--bg-card);border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;position:relative;overflow:hidden;border:1px solid var(--border-color)}.leave-stat-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.leave-stat-value{font-size:32px;font-weight:700;margin-bottom:12px}.leave-stat-val-primary{color:#2563eb}.leave-stat-val-warning{color:#d97706}.leave-stat-val-neutral{color:var(--text-secondary)}.leave-stat-line{height:4px;width:100%;background:var(--bg-secondary);border-radius:2px;position:relative}.leave-stat-line-inner{position:absolute;left:0;top:0;height:100%;width:40%;border-radius:2px}.line-bg-primary{background:#2563eb}.line-bg-warning{background:#d97706}.line-bg-neutral{background:var(--text-secondary)}.leave-main-layout{display:flex;flex-direction:column;gap:24px}.leave-form-col{width:100%;background:var(--bg-card);border-radius:12px;padding:32px 24px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid var(--border-color)}.leave-form-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:8px}.leave-form-title svg{color:#2563eb}.leave-form-group{margin-bottom:20px}.leave-form-row{display:flex;gap:16px;margin-bottom:20px}.leave-form-row .leave-form-group{flex:1;margin-bottom:0}.leave-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.leave-input,.leave-select,.leave-textarea{width:100%;background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;padding:12px 14px;font-size:14px;color:var(--text-primary);font-family:inherit;transition:all .2s}.leave-input:focus,.leave-select:focus,.leave-textarea:focus{outline:none;border-color:#3b82f6;background:var(--bg-card);box-shadow:0 0 0 3px #3b82f61a}.leave-textarea{resize:vertical;min-height:100px}.leave-btn-submit{width:100%;background:#1d4ed8;color:#fff;border:none;border-radius:8px;padding:14px;font-size:15px;font-weight:600;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:8px;transition:background .2s;margin-top:12px}.leave-btn-submit:hover{background:#1e40af}.leave-btn-submit:disabled{background:var(--text-muted);cursor:not-allowed}.leave-form-note{font-size:12px;color:var(--text-muted);text-align:center;margin-top:16px}.leave-table-col{width:100%;background:var(--bg-card);border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden;border:1px solid var(--border-color)}.leave-table-header{padding:24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.leave-table-title{font-size:18px;font-weight:600;color:var(--text-primary)}.leave-table-actions{display:flex;gap:16px;color:var(--text-muted)}.leave-table-wrapper{width:100%;overflow-x:auto}.leave-table{width:100%;border-collapse:collapse}.leave-table th{background:var(--bg-secondary);color:var(--text-muted);font-size:12px;font-weight:600;text-transform:uppercase;text-align:left;padding:16px 24px}.leave-table td{padding:16px 24px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-color);vertical-align:middle}.leave-type-badge{display:inline-block;background:#2563eb26;color:#3b82f6;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.leave-status{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;text-transform:uppercase}.leave-status-dot{width:8px;height:8px;border-radius:50%}.status-pending .leave-status-dot{background:var(--text-muted)}.status-pending{color:var(--text-secondary)}.status-approved .leave-status-dot{background:#3b82f6}.status-approved{color:#3b82f6}.status-rejected .leave-status-dot{background:#ef4444}.status-rejected{color:#ef4444}.leave-charts-row{display:flex;gap:24px;margin-bottom:32px}.leave-chart-card{flex:1;background:var(--bg-card);border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000000d;border:1px solid var(--border-color)}.leave-chart-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.leave-chart-container{height:300px;width:100%}.leave-stat-val-danger{color:#ef4444}.leave-stat-val-success{color:#22c55e}.line-bg-danger{background:#ef4444}.line-bg-success{background:#22c55e}.line-bg-pending{background:var(--text-muted)}@media (max-width: 900px){.leave-stats-row{flex-wrap:wrap}.leave-stat-card{min-width:calc(50% - 12px)}.leave-main-layout,.leave-charts-row{flex-direction:column}}@media (max-width: 600px){.leave-stat-card{min-width:100%}.leave-form-row{flex-direction:column;gap:0}}.calendar-container{padding:24px;background:var(--bg-card);border-radius:12px;box-shadow:0 4px 6px -1px #0000000d}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.calendar-title-group h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.calendar-title-group p{color:var(--text-muted);font-size:14px}.calendar-nav{display:flex;align-items:center;gap:16px}.calendar-nav-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}.calendar-nav-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.calendar-month-label{font-size:18px;font-weight:600;color:var(--text-primary);min-width:140px;text-align:center}.calendar-grid{border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.calendar-weekday{padding:12px;text-align:center;font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;border-right:1px solid var(--border-color)}.calendar-weekday:last-child{border-right:none}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:120px;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:12px;position:relative;background:var(--bg-card);transition:background .2s}.calendar-day:nth-child(7n){border-right:none}.calendar-day:nth-last-child(-n+7){border-bottom:none}.calendar-day.empty{background:var(--bg-tertiary)}.calendar-day.not-empty:hover{background:var(--bg-glass-hover);cursor:pointer}.calendar-date-number{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.calendar-date-number.today{background:var(--accent-primary);color:#fff;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.calendar-events-list{display:flex;flex-direction:column;gap:4px}.calendar-event-badge{font-size:11px;font-weight:500;padding:4px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.event-target-all{background:#2563eb26;color:#3b82f6;border:1px solid rgba(37,99,235,.3)}.event-target-dept{background:#a21caf26;color:#c026d3;border:1px solid rgba(162,28,175,.3)}.event-modal-content{margin-bottom:16px}.event-detail-row{display:flex;margin-bottom:12px}.event-detail-label{font-weight:600;color:var(--text-muted);width:100px}.event-detail-value{color:var(--text-primary);flex:1}.event-detail-desc{background:var(--bg-tertiary);padding:16px;border-radius:8px;color:var(--text-secondary);font-size:14px;line-height:1.5;margin-top:16px}.homepage-container{font-family:Inter,sans-serif;color:#1f2937;background-color:#f9fafb;min-height:100vh;display:flex;flex-direction:column}.hp-header{display:flex;justify-content:space-between;align-items:center;padding:16px 48px;background:#fff;box-shadow:0 4px 6px -1px #0000000d;position:sticky;top:0;z-index:50}.hp-logo{font-size:24px;font-weight:800;color:#2563eb;display:flex;align-items:center;gap:8px}.hp-nav{display:flex;gap:32px}.hp-nav a{color:#4b5563;font-weight:500;text-decoration:none;font-size:16px;transition:color .3s ease}.hp-nav a:hover{color:#2563eb}.hp-auth-buttons{display:flex;gap:16px}.hp-btn{padding:10px 24px;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.hp-btn-primary{background:#2563eb;color:#fff;border:none;box-shadow:0 4px 12px #2563eb4d}.hp-btn-primary:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.hp-btn-outline{background:transparent;color:#2563eb;border:2px solid #2563EB}.hp-btn-outline:hover{background:#eff6ff}.hp-hero{padding:80px 48px;display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;gap:48px}.hp-hero-content{flex:1;max-width:600px}.hp-hero-title{font-size:48px;font-weight:800;line-height:1.2;color:#111827;margin-bottom:24px}.hp-hero-title span{color:#2563eb}.hp-hero-desc{font-size:18px;line-height:1.6;color:#4b5563;margin-bottom:40px}.hp-hero-buttons{display:flex;gap:16px}.hp-btn-lg{padding:14px 32px;font-size:16px}.hp-btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db;box-shadow:0 2px 4px #0000000d}.hp-btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.hp-hero-image-wrapper{flex:1;position:relative;display:flex;justify-content:center}.hp-hero-image{width:100%;max-width:550px;border-radius:16px;box-shadow:0 20px 40px #0000001a;animation:float 6s ease-in-out infinite}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-15px)}to{transform:translateY(0)}}.hp-features{padding:80px 48px;background:#fff}.hp-section-header{text-align:center;margin-bottom:56px}.hp-section-title{font-size:36px;font-weight:700;color:#111827;margin-bottom:16px}.hp-section-desc{font-size:18px;color:#6b7280;max-width:600px;margin:0 auto}.hp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;max-width:1280px;margin:0 auto}.hp-feature-card{padding:32px 24px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;transition:all .3s ease;text-align:center}.hp-feature-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000001a;border-color:#bfdbfe}.hp-feature-icon{width:64px;height:64px;background:#eff6ff;color:#2563eb;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:24px;transition:all .3s ease}.hp-feature-card:hover .hp-feature-icon{background:#2563eb;color:#fff}.hp-feature-title{font-size:20px;font-weight:700;color:#111827;margin-bottom:12px}.hp-feature-desc{font-size:15px;color:#6b7280;line-height:1.5}.hp-about{padding:80px 48px;max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:64px}.hp-about-content{flex:1}.hp-about-list{list-style:none;padding:0;margin:32px 0 0}.hp-about-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.hp-about-item-icon{color:#10b981;font-size:24px;flex-shrink:0;margin-top:2px}.hp-about-item-text{font-size:17px;color:#374151;font-weight:500}.hp-about-image-wrapper{flex:1;background:linear-gradient(135deg,#eff6ff,#e0e7ff);border-radius:20px;padding:40px;display:flex;justify-content:center;align-items:center}.hp-about-img{width:100%;border-radius:12px;box-shadow:0 10px 25px #0000001a}.hp-demo{padding:80px 48px;background:#fff;text-align:center}.hp-demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1280px;margin:40px auto 0}.hp-demo-card{border-radius:16px;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a;border:1px solid #e5e7eb;transition:transform .3s ease}.hp-demo-card:hover{transform:scale(1.03)}.hp-demo-card img{width:100%;height:auto;display:block}.hp-demo-caption{padding:16px;font-weight:600;font-size:16px;background:#f9fafb;color:#374151;border-top:1px solid #e5e7eb}.hp-cta{padding:80px 48px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;text-align:center}.hp-cta-inner{max-width:800px;margin:0 auto}.hp-cta h2{font-size:40px;font-weight:800;margin-bottom:24px}.hp-cta p{font-size:18px;opacity:.9;margin-bottom:40px}.hp-btn-white{background:#fff;color:#2563eb;border:none}.hp-btn-white:hover{background:#f3f4f6;transform:translateY(-2px);box-shadow:0 6px 16px #0003}.hp-footer{background:#111827;color:#9ca3af;padding:64px 48px 24px}.hp-footer-content{max-width:1280px;margin:0 auto 24px;display:flex;justify-content:space-between;border-bottom:1px solid #374151;padding-bottom:40px}.hp-footer-brand{max-width:300px}.hp-footer-logo{font-size:24px;font-weight:800;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:8px}.hp-footer-brand p{font-size:14px;line-height:1.6}.hp-footer-links h4{color:#fff;font-size:16px;font-weight:600;margin-bottom:16px}.hp-footer-links ul{list-style:none;padding:0;margin:0}.hp-footer-links li{margin-bottom:12px}.hp-footer-links a{color:#9ca3af;text-decoration:none;font-size:14px;transition:color .3s ease}.hp-footer-links a:hover{color:#fff}.hp-footer-bottom{text-align:center;font-size:14px}@media (max-width: 1024px){.hp-grid,.hp-demo-grid{grid-template-columns:repeat(2,1fr)}.hp-hero{flex-direction:column;text-align:center;padding:60px 24px}.hp-hero-buttons{justify-content:center}.hp-about{flex-direction:column;padding:60px 24px}}@media (max-width: 768px){.hp-header{padding:16px 24px}.hp-nav{display:none}.hp-hero-title{font-size:36px}.hp-grid,.hp-demo-grid{grid-template-columns:1fr}.hp-footer-content{flex-direction:column;gap:32px}.hp-cta h2{font-size:28px}.hp-about-item{text-align:left}}:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--bg-card: rgba(26, 26, 46, .8);--bg-glass: rgba(255, 255, 255, .05);--bg-glass-hover: rgba(255, 255, 255, .1);--bg-input: rgba(255, 255, 255, .07);--text-primary: #e8e8f0;--text-secondary: #a0a0b8;--text-muted: #6b6b80;--text-inverse: #0f0f1a;--accent-primary: #6c63ff;--accent-primary-hover: #5a52e0;--accent-primary-glow: rgba(108, 99, 255, .3);--accent-secondary: #00d4aa;--accent-secondary-glow: rgba(0, 212, 170, .3);--accent-warning: #ffa726;--accent-danger: #ef5350;--accent-danger-hover: #d32f2f;--accent-info: #42a5f5;--gradient-primary: linear-gradient(135deg, #6c63ff 0%, #00d4aa 100%);--gradient-accent: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-warm: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-dark: linear-gradient(135deg, #0f0f1a 0%, #1a1a2e 100%);--border-color: rgba(255, 255, 255, .08);--border-color-hover: rgba(255, 255, 255, .15);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(108, 99, 255, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--sidebar-width: 260px;--header-height: 64px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}[data-theme=light]{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #eef2f7;--bg-card: rgba(255, 255, 255, .9);--bg-glass: rgba(255, 255, 255, .7);--bg-glass-hover: rgba(255, 255, 255, .9);--bg-input: rgba(0, 0, 0, .04);--text-primary: #1a1a2e;--text-secondary: #5a5a72;--text-muted: #9a9ab0;--text-inverse: #ffffff;--border-color: rgba(0, 0, 0, .08);--border-color-hover: rgba(0, 0, 0, .15);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(108, 99, 255, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-hover)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:24px;padding-top:calc(var(--header-height) + 24px);min-height:100vh;transition:margin-left var(--transition-normal)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;animation:fadeIn .2s ease}.mobile-menu-btn{display:none}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-normal)}.sidebar-logo{padding:20px 24px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-color)}.sidebar-logo-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;flex-shrink:0}.sidebar-logo h2{font-size:16px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo span{display:block;font-size:11px;font-weight:400;color:var(--text-muted);-webkit-text-fill-color:var(--text-muted)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:12px 12px 8px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-primary-glow);color:var(--accent-primary)}.sidebar-link .icon{font-size:18px;width:20px;display:flex;align-items:center;justify-content:center}.sidebar-user{padding:16px;border-top:1px solid var(--border-color);display:flex;align-items:center;gap:12px}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.sidebar-user-info{flex:1}.sidebar-user-name{font-size:13px;font-weight:600}.sidebar-user-role{font-size:11px;color:var(--text-muted)}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:50;transition:left var(--transition-normal)}.header-title{font-size:18px;font-weight:700}.header-actions{display:flex;align-items:center;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 12px var(--accent-primary-glow)}.btn-primary:hover{background:var(--accent-primary-hover);box-shadow:0 4px 20px var(--accent-primary-glow)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-color-hover)}.btn-danger{background:var(--accent-danger);color:#fff}.btn-danger:hover{background:var(--accent-danger-hover)}.btn-success{background:var(--accent-secondary);color:var(--text-inverse)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12px}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-normal)}.card:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:16px;font-weight:700}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:center;gap:16px;transition:all var(--transition-normal);cursor:default}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.stat-card-icon.blue{background:#42a5f526;color:#42a5f5}.stat-card-icon.green{background:#00d4aa26;color:#00d4aa}.stat-card-icon.orange{background:#ffa72626;color:#ffa726}.stat-card-icon.red{background:#ef535026;color:#ef5350}.stat-card-icon.purple{background:#6c63ff26;color:#6c63ff}.stat-card-value{font-size:28px;font-weight:800;line-height:1}.stat-card-label{font-size:12px;color:var(--text-muted);margin-top:4px}.table-container{overflow-x:auto;border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap}.table td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.table tr:hover td{background:var(--bg-glass)}.table tr:last-child td{border-bottom:none}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input,.form-select{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-family);font-size:14px;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.form-input::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px;width:90%;max-width:520px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:18px;font-weight:700}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-success{background:#00d4aa26;color:#00d4aa}.badge-warning{background:#ffa72626;color:#ffa726}.badge-danger{background:#ef535026;color:#ef5350}.badge-info{background:#42a5f526;color:#42a5f5}.badge-purple{background:#6c63ff26;color:#6c63ff}.search-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-input-wrapper{position:relative;flex:1;min-width:200px}.search-input-wrapper .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:16px}.search-input-wrapper .form-input{padding-left:38px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,var(--accent-primary-glow) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,var(--accent-secondary-glow) 0%,transparent 70%);bottom:-100px;left:-100px;pointer-events:none}.login-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:32px}.login-logo-icon{width:64px;height:64px;border-radius:var(--radius-lg);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;margin:0 auto 16px}.login-logo h1{font-size:24px;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo p{color:var(--text-muted);font-size:13px;margin-top:4px}.login-error{background:#ef53501a;border:1px solid rgba(239,83,80,.3);color:#ef5350;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.login-btn{width:100%;padding:12px;font-size:15px;font-weight:600;margin-top:8px}.attendance-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-glass);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-color)}.attendance-tab{flex:1;padding:10px 16px;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-family);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:8px}.attendance-tab.active{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.attendance-tab:hover:not(.active){background:var(--bg-glass-hover)}.camera-container{position:relative;width:100%;max-width:640px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--border-color);background:#000;aspect-ratio:4/3}.camera-container video{width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.camera-overlay .face-guide{width:200px;height:260px;border:2px dashed var(--accent-primary);border-radius:50%;opacity:.6;animation:pulse 2s ease-in-out infinite}.camera-status{text-align:center;margin-top:16px;font-size:14px;color:var(--text-secondary)}.camera-status.success{color:var(--accent-secondary)}.camera-status.error{color:var(--accent-danger)}.realtime-feed{max-height:400px;overflow-y:auto}.feed-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color);animation:slideIn .3s ease}.feed-item:last-child{border-bottom:none}.feed-item-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}.feed-item-info{flex:1}.feed-item-name{font-size:13px;font-weight:600}.feed-item-detail{font-size:11px;color:var(--text-muted)}.feed-item-time{font-size:11px;color:var(--text-muted);white-space:nowrap}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}.pagination button{padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;font-family:var(--font-family);font-size:13px;transition:all var(--transition-fast)}.pagination button:hover:not(:disabled){background:var(--bg-glass-hover);color:var(--text-primary)}.pagination button.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:40px}.spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.empty-state p{font-size:13px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.page-enter{animation:slideUp .3s ease}.flex-between{display:flex;align-items:center;justify-content:space-between}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.gap-1{gap:8px}.gap-2{gap:16px}.qr-display{text-align:center;padding:20px}.qr-display img{width:200px;height:200px;border-radius:var(--radius-md);border:2px solid var(--border-color)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dashboard-grid .full-width{grid-column:1 / -1}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.mobile-menu-btn{display:flex}.main-content{margin-left:0}.header{left:0}.stat-cards{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}}@media (max-width: 480px){.stat-cards{grid-template-columns:1fr}}option{background-color:var(--bg-card);color:var(--text-primary)}
