@import "https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;700;900&display=swap";
.material-symbols-outlined{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"liga";vertical-align:middle;direction:ltr;max-width:1em;max-height:1em;font-family:Material Symbols Outlined;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-block;overflow:hidden}:root,[data-theme=light]{--brand:#34a853;--brand-light:#4ade80;--brand-dark:#22863a;--brand-surface:#34a85314;--accent:#34a853;--accent-light:#4ade80;--accent-dark:#22863a;--accent-surface:#34a85314;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--bg-input:#f8fafc;--border:#e2e8f0;--border-light:#cbd5e1;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--success:#16a34a;--success-surface:#16a34a14;--warning:#d97706;--warning-surface:#d9770614;--danger:#dc2626;--danger-surface:#dc262614;--info:#2563eb;--info-surface:#2563eb14;--font-sans:"Google Sans",system-ui,-apple-system,sans-serif;--sidebar-width:256px;--header-height:64px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a}[data-theme=dark]{--bg-primary:#0f1117;--bg-secondary:#161b22;--bg-card:#1c2333;--bg-card-hover:#222d3f;--bg-input:#131720;--border:#2a3142;--border-light:#333d52;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#5a6370;--accent:#f97316;--accent-light:#fb923c;--accent-dark:#ea580c;--accent-surface:#f973161a;--success:#22c55e;--success-surface:#22c55e1f;--warning:#eab308;--warning-surface:#eab3081f;--danger:#ef4444;--danger-surface:#ef44441f;--info:#3b82f6;--info-surface:#3b82f61f;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 20px 40px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;transition:background .3s,color .3s}a{color:var(--brand);text-decoration:none;transition:color .15s}a:hover{color:var(--brand-dark)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.portal-layout{min-height:100vh;display:flex}.portal-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.portal-content{padding:32px;padding-top:calc(var(--header-height) + 32px);flex:1;width:100%;max-width:1400px;margin:0 auto}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);z-index:100;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-brand{height:var(--header-height);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:0 20px;display:flex}.sidebar-brand-logo{flex-shrink:0;width:auto;height:32px}.sidebar-brand-text{color:var(--text-primary);white-space:nowrap;font-size:15px;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.sidebar-nav-item{color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.sidebar-nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--brand-surface);color:var(--brand);font-weight:700}.sidebar-nav-icon{text-align:center;flex-shrink:0;width:24px;font-size:20px}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.sidebar-user{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.sidebar-user:hover{background:var(--bg-card-hover)}.sidebar-avatar{background:linear-gradient(135deg,var(--brand-dark),var(--brand-light));color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.header{top:0;right:0;left:var(--sidebar-width);height:var(--header-height);background:var(--bg-card);border-bottom:1px solid var(--border);z-index:90;box-shadow:var(--shadow-xs);justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:fixed}.header-title{color:var(--text-primary);font-size:18px;font-weight:700}.header-actions{align-items:center;gap:12px;display:flex}.header-notification-btn{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text-secondary);border-radius:10px;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:flex;position:relative}.header-notification-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-light)}.header-notification-badge{background:var(--danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-2px;right:-2px}.header-logout-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);border-radius:10px;padding:8px 16px;transition:all .15s}.header-logout-btn:hover{background:var(--danger-surface);color:var(--danger);border-color:#dc26264d}.page-header{margin-bottom:32px}.page-header h1{color:var(--text-primary);margin-bottom:4px;font-size:28px;font-weight:800}.page-header p{color:var(--text-secondary);font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:12px;padding:20px;transition:all .25s}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-light)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:16px;font-weight:700}.card-subtitle{color:var(--text-muted);font-size:13px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;padding:20px;transition:all .25s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:12px;font-size:1.4rem;display:flex}.stat-card-icon.purple{background:#6366f11a}.stat-card-icon.green{background:var(--success-surface)}.stat-card-icon.blue{background:var(--info-surface)}.stat-card-icon.amber{background:var(--warning-surface)}.stat-card-icon.red{background:var(--danger-surface)}.stat-card-icon.pink{background:#ec48991a}.stat-card-value{color:var(--text-primary);margin-bottom:4px;font-size:24px;font-weight:800;line-height:1}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.notification-list{flex-direction:column;gap:8px;display:flex}.notification-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:flex}.notification-item:hover{background:var(--bg-card-hover)}.notification-item-content{flex:1;min-width:0}.notification-item-title{color:var(--text-primary);font-size:14px;font-weight:600}.notification-item-message{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.notification-dismiss{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:16px;transition:color .15s}.notification-dismiss:hover{color:var(--danger)}.progress-track{background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--brand-dark),var(--brand-light));border-radius:999px;height:100%;transition:width .6s}.countdown{align-items:center;gap:8px;display:flex}.countdown-unit{background:var(--bg-card);border:1px solid var(--border);min-width:56px;box-shadow:var(--shadow-sm);border-radius:10px;flex-direction:column;align-items:center;padding:8px 12px;display:flex}.countdown-value{color:var(--brand);font-size:22px;font-weight:800;line-height:1}.countdown-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:10px}.countdown-separator{color:var(--text-muted);font-size:22px;font-weight:700;animation:1s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.live-class-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:12px;padding:20px;transition:all .25s;position:relative;overflow:hidden}.live-class-card.upcoming{border-color:#16a34a4d}.live-class-card.upcoming:before{content:"";background:linear-gradient(90deg,var(--brand-dark),var(--brand-light));height:3px;position:absolute;top:0;left:0;right:0}.live-class-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.live-class-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.live-class-platform{color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:flex}.live-class-status{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700}.live-class-status.live{background:var(--danger-surface);color:var(--danger);animation:2s infinite pulse-live}.live-class-status.upcoming{background:var(--success-surface);color:var(--success)}.live-class-status.ended{background:var(--bg-secondary);color:var(--text-muted)}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.7}}.live-class-title{color:var(--text-primary);margin-bottom:6px;font-size:16px;font-weight:700}.live-class-meta{flex-wrap:wrap;gap:16px;margin-bottom:12px;display:flex}.live-class-meta-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.live-class-join-btn{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-sans);border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;text-decoration:none;transition:all .2s;display:inline-flex;box-shadow:0 2px 8px #34a8534d}.live-class-join-btn:hover{color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #34a85366}.video-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.video-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:12px;transition:all .25s;overflow:hidden}.video-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.video-card-thumbnail{aspect-ratio:16/9;background:var(--bg-secondary);cursor:pointer;justify-content:center;align-items:center;width:100%;font-size:3rem;display:flex;position:relative;overflow:hidden}.video-card-thumbnail img{object-fit:cover;width:100%;height:100%}.video-card-play{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:999px;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.4rem;transition:all .15s;display:flex;position:absolute}.video-card-thumbnail:hover .video-card-play{background:var(--brand);transform:scale(1.1)}.video-card-body{padding:16px}.video-card-title{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.video-card-desc{color:var(--text-muted);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:13px;display:-webkit-box;overflow:hidden}.video-card-footer{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:11px;display:flex}.video-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.video-modal{background:var(--bg-card);width:100%;max-width:960px;box-shadow:var(--shadow-xl);border-radius:16px;animation:.3s slideUp;overflow:hidden}.video-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.video-modal-title{font-size:16px;font-weight:700}.video-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px;transition:color .15s}.video-modal-close:hover{color:var(--text-primary)}.video-modal-body{aspect-ratio:16/9}.video-modal-body iframe{border:none;width:100%;height:100%}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);border-radius:10px;outline:none;padding:10px 14px;transition:border .2s,box-shadow .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #34a85326}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2394a3b8' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}.form-select option{background:var(--bg-card);color:var(--text-primary)}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.btn{font-size:13px;font-weight:700;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;transition:all .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;box-shadow:0 2px 8px #34a85340}.btn-primary:hover{box-shadow:0 4px 16px #34a85359}.btn-secondary{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-hover)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-info{background:var(--info-surface);color:var(--info)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-sm{border-radius:8px;padding:6px 12px;font-size:11px}.btn-lg{padding:14px 28px;font-size:14px}.table-container{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:12px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg-secondary);padding:10px 16px;font-size:11px;font-weight:700}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:12px 16px}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--bg-card-hover)}.data-table tbody tr:last-child td{border-bottom:none}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-success{background:var(--success-surface);color:var(--success)}.badge-warning{background:var(--warning-surface);color:var(--warning)}.badge-danger{background:var(--danger-surface);color:var(--danger)}.badge-info{background:var(--info-surface);color:var(--info)}.badge-neutral{background:var(--bg-secondary);color:var(--text-muted)}.badge-accent{background:var(--accent-surface);color:var(--accent)}.badge-brand{background:var(--brand-surface);color:var(--brand)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000004d;justify-content:center;align-items:center;padding:16px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);border-radius:16px;animation:.3s slideUp;overflow-y:auto}.modal-lg{max-width:800px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-title{color:var(--text-primary);font-size:18px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px;line-height:1;transition:color .15s}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.login-page{background:#0a0e14;justify-content:center;align-items:center;min-height:100vh;font-family:Inter,system-ui,sans-serif;display:flex;position:relative;overflow:hidden}.login-aurora{filter:blur(100px);opacity:.25;pointer-events:none;border-radius:50%;position:absolute}.login-aurora-1{background:radial-gradient(circle,#22c55e 0%,#0000 70%);width:500px;height:500px;animation:8s ease-in-out infinite aurora-1;top:-200px;left:-100px}.login-aurora-2{background:radial-gradient(circle,#16a34a 0%,#0000 70%);width:400px;height:400px;animation:10s ease-in-out 1s infinite aurora-2;top:-150px;right:-80px}.login-aurora-3{background:radial-gradient(circle,#15803d 0%,#0000 70%);width:300px;height:300px;animation:12s ease-in-out 2s infinite aurora-3;top:-100px;left:40%}@keyframes aurora-1{0%,to{opacity:.25;transform:translate(0)scale(1)}25%{opacity:.35;transform:translate(30px,20px)scale(1.1)}50%{opacity:.2;transform:translate(-20px,10px)scale(.95)}75%{opacity:.3;transform:translate(15px,-15px)scale(1.05)}}@keyframes aurora-2{0%,to{opacity:.25;transform:translate(0)scale(1)}30%{opacity:.35;transform:translate(-40px,15px)scale(1.15)}60%{opacity:.15;transform:translate(20px,-10px)scale(.9)}}@keyframes aurora-3{0%,to{opacity:.2;transform:translate(0)scale(1)}40%{opacity:.35;transform:translate(30px,-20px)scale(1.2)}70%{opacity:.15;transform:translate(-15px,10px)scale(.85)}}.login-particles{pointer-events:none;z-index:1;position:absolute;inset:0}.login-particle{background:#4ade80;border-radius:50%;width:3px;height:3px;animation:3s ease-in-out infinite twinkle;position:absolute;box-shadow:0 0 6px #4ade80,0 0 12px #4ade8080}@keyframes twinkle{0%,to{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1.2)}}.login-content{z-index:2;flex-direction:column;align-items:center;width:100%;max-width:460px;padding:0 24px;animation:.8s cubic-bezier(.16,1,.3,1) both login-content-enter;display:flex;position:relative}@keyframes login-content-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo-box{background:#1a1f2b;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:20px;animation:1s cubic-bezier(.16,1,.3,1) .2s both logo-enter;display:flex;box-shadow:0 4px 20px #0000004d}@keyframes logo-enter{0%{opacity:0;transform:translateY(-10px)scale(.85)}to{opacity:1;transform:translateY(0)scale(1)}}.login-brand{color:#e6edf3;text-align:center;margin-bottom:4px;font-size:28px;font-weight:800;animation:.8s .3s both text-enter}.login-brand-accent{color:#4ade80}.login-brand-sub{color:#5a6370;text-align:center;margin-bottom:36px;font-size:14px;animation:.8s .4s both text-enter}@keyframes text-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-card{background:#12161e;border:1px solid #1e2530;border-radius:16px;width:100%;padding:32px;animation:.8s cubic-bezier(.16,1,.3,1) .5s both card-enter;box-shadow:0 20px 60px #0006}@keyframes card-enter{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-card-title{color:#e6edf3;align-items:center;gap:12px;margin-bottom:28px;font-size:18px;font-weight:700;display:flex}.login-card-title-bar{background:#22c55e;border-radius:2px;flex-shrink:0;width:4px;height:20px}.login-form{flex-direction:column;gap:20px;animation:.8s .6s both form-enter;display:flex}@keyframes form-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-field-group{flex-direction:column;gap:8px;display:flex}.login-field-label{color:#5a6370;text-transform:uppercase;letter-spacing:1.5px;font-size:11px;font-weight:700}.login-field{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;padding:0 14px;transition:all .25s;display:flex}.login-field:focus-within{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e1f}.login-field-icon{color:#94a3b8;flex-shrink:0;margin-right:10px;font-size:20px}.login-field-input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;padding:13px 0;font-family:Inter,system-ui,sans-serif;font-size:14px}.login-field-input::placeholder{color:#94a3b8}.login-field-toggle{cursor:pointer;color:#94a3b8;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex}.login-field-toggle:hover{color:#64748b}.login-field-toggle .material-symbols-outlined{font-size:20px}.login-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:14px 24px;font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 16px #22c55e59}.login-submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #22c55e80}.login-submit-btn:active{transform:translateY(0)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{color:#ef4444;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;padding:10px 14px;font-size:13px;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-footer{text-align:center;margin-top:32px;animation:.8s .8s both text-enter}.login-footer p{color:#3a414d;font-size:11px;line-height:1.8}.calendar{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:12px;padding:20px}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.calendar-nav-btn{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);border-radius:8px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.calendar-nav-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.calendar-month{color:var(--text-primary);font-size:15px;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-day-header{text-align:center;color:var(--text-muted);text-transform:uppercase;padding:8px;font-size:11px;font-weight:700}.calendar-day{aspect-ratio:1;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex;position:relative}.calendar-day:hover{background:var(--bg-card-hover);color:var(--text-primary)}.calendar-day.today{border:2px solid var(--brand);color:var(--brand);font-weight:700}.calendar-day.selected{background:var(--brand);color:#fff;font-weight:700}.calendar-day.other-month{color:var(--text-muted);opacity:.3}.calendar-day.has-leave:after{content:"";background:var(--warning);border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px}.empty-state{text-align:center;padding:48px 20px}.empty-state-icon{opacity:.4;margin-bottom:16px;font-size:4rem}.empty-state-title{color:var(--text-primary);margin-bottom:6px;font-size:16px;font-weight:700}.empty-state-message{color:var(--text-muted);max-width:400px;margin:0 auto;font-size:14px}.loading-spinner{justify-content:center;align-items:center;padding:48px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tabs{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;gap:4px;margin-bottom:24px;padding:4px;display:flex}.tab{color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);text-align:center;background:0 0;border:none;border-radius:10px;flex:1;padding:10px 16px;transition:all .2s}.tab:hover{color:var(--text-secondary)}.tab.active{background:var(--brand);color:#fff;box-shadow:0 2px 6px #34a8534d}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.toast{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);z-index:2000;max-width:400px;box-shadow:var(--shadow-lg);border-radius:12px;padding:14px 20px;font-size:13px;animation:.3s slideIn;position:fixed;top:16px;right:16px}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-warning{border-left:3px solid var(--warning)}.toast-info{border-left:3px solid var(--info)}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.filter-chips{flex-wrap:wrap;gap:6px;display:flex}.filter-chip{color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-sans);border-radius:20px;padding:6px 14px;transition:all .15s}.filter-chip:hover{color:var(--text-secondary);border-color:var(--border-light)}.filter-chip.active{color:var(--brand);background:var(--brand-surface);border-color:#34a8534d}.section-title{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.section-title:after{content:"";background:var(--border);flex:1;height:1px}@media (max-width:1024px){.grid-3{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}}.offline-banner{z-index:9999;background:var(--danger);color:#fff;text-align:center;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;animation:.3s slideDown;display:flex;position:fixed;top:0;left:0;right:0}.header-icon-btn{border:1px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.header-icon-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.header-icon-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.mobile-menu-btn{z-index:100;border:1px solid var(--border);background:var(--bg-card);width:40px;height:40px;color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:10px;justify-content:center;align-items:center;display:none;position:fixed;top:14px;left:12px}.sidebar-close-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;margin-left:auto;display:none}.sidebar-close-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-overlay{z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (max-width:768px){.mobile-menu-btn,.sidebar-close-btn{display:flex}.sidebar-overlay{display:block}.sidebar{z-index:300;box-shadow:none;transition:transform .3s;transform:translate(-100%)}.sidebar.sidebar-open{box-shadow:var(--shadow-xl);transform:translate(0)}.portal-main{margin-left:0}.header{padding-left:56px;left:0}.portal-content{padding:16px;padding-top:calc(var(--header-height) + 16px)}.stats-grid{grid-template-columns:1fr 1fr}.grid-2,.grid-3,.video-grid{grid-template-columns:1fr}.countdown-unit{min-width:48px;padding:6px 8px}.header-title{white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:16px;overflow:hidden}.header-logout-btn span:last-child{display:none}.header-logout-btn .material-symbols-outlined{margin-right:0!important}.header-actions>div>div[style]{width:300px!important}.form-row{flex-direction:column}.modal{width:95vw;max-height:90vh;margin:16px}.modal-lg{width:95vw}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.login-card{margin:16px;padding:32px 24px}.header-title{max-width:120px;font-size:14px}.portal-content{padding:12px;padding-top:calc(var(--header-height) + 12px)}.page-header h1{font-size:20px}}
