.datalist-container{width:100%;background:var(--bg-card);border-radius:16px;overflow:visible}.datalist-table-wrapper{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.datalist-table{width:100%;border-collapse:collapse;font-size:14px}.datalist-table th{text-align:left;padding:14px 20px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.datalist-table-header-sticky th{position:sticky;top:0;z-index:10}.datalist-table td{padding:0 20px;height:56px;border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle}.datalist-table-row{cursor:pointer;transition:background-color .15s ease}.datalist-table-row:nth-child(2n){background:#fafbfd}[data-theme=dark] .datalist-table-row:nth-child(2n){background:#ffffff04}.datalist-table-row:hover{background:#f4f5fa}[data-theme=dark] .datalist-table-row:hover{background:#6c63ff0a}.datalist-table-row:active{background:#eef1f6}[data-theme=dark] .datalist-table-row:active{background:#6c63ff14}.datalist-table-actions{padding:8px 12px!important;width:70px}.datalist-cards{display:none;flex-direction:column;gap:10px;padding:12px}.datalist-cards-desktop{display:flex}.datalist-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:16px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000a;-webkit-tap-highlight-color:transparent}.datalist-card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--primary-light)}.datalist-card:active{transform:scale(.99);background:var(--bg-secondary)}.datalist-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}.datalist-card-primary{flex:1;min-width:0}.datalist-card-actions-trigger{flex-shrink:0}.datalist-card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.datalist-card-field{display:flex;flex-direction:column;gap:4px}.datalist-card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.datalist-card-value{font-size:14px;font-weight:500;color:var(--text-primary)}.datalist-card-quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border-light)}.datalist-card-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;min-height:42px}.datalist-card-action-btn:active{transform:scale(.97)}.datalist-card-action-btn-default:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-card-action-btn-danger{background:#ef444414;border-color:#ef444433;color:#ef4444}.datalist-card-action-btn-danger:hover{background:#ef444426}.datalist-card-action-btn-success{background:#22c55e14;border-color:#22c55e33;color:#22c55e}.datalist-card-action-btn-success:hover{background:#22c55e26}.datalist-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap}.datalist-badge-success{background:#34c7591f;color:#22c55e}.datalist-badge-warning{background:#ff95001f;color:#f59e0b}.datalist-badge-danger{background:#ff3b301f;color:#ef4444}.datalist-badge-info{background:#007aff1f;color:#3b82f6}.datalist-badge-primary{background:#6366f11f;color:#6366f1}.datalist-badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.datalist-badge-muted{background:#8e8e931f;color:#8e8e93}.datalist-entity-cell{display:flex;align-items:center;gap:12px}.datalist-entity-avatar{border-radius:50%;object-fit:cover;border:2px solid var(--border-light);flex-shrink:0;background:var(--bg-tertiary)}.datalist-entity-info{display:flex;flex-direction:column;gap:2px;min-width:0}.datalist-entity-name{font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.datalist-entity-subtitle{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.datalist-rating{display:flex;align-items:center;gap:6px}.datalist-rating-stars{display:flex;color:gold}.datalist-rating-value{font-size:13px;font-weight:700;color:var(--text-primary)}.datalist-rating-count,.datalist-rating-empty{font-size:12px;color:var(--text-muted)}.datalist-action-dropdown{position:relative;display:inline-block}.datalist-action-trigger{width:36px;height:36px;padding:0;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.datalist-action-trigger:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-action-trigger:active{transform:scale(.95)}.datalist-action-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:6px;z-index:1000;animation:datalist-dropdown-fade-in .15s ease}.datalist-action-menu-up{top:auto;bottom:calc(100% + 6px);animation:datalist-dropdown-fade-in-up .15s ease}@keyframes datalist-dropdown-fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes datalist-dropdown-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.datalist-action-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;border-radius:8px;text-align:left}.datalist-action-item:hover{background:var(--hover-bg)}.datalist-action-item-default:hover{background:var(--primary-bg);color:var(--primary)}.datalist-action-item-danger{color:#ef4444}.datalist-action-item-danger:hover{background:#ef44441a}.datalist-action-item-success{color:#22c55e}.datalist-action-item-success:hover{background:#22c55e1a}.datalist-action-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.datalist-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-card);flex-wrap:wrap;gap:12px}.datalist-pagination-info{font-size:13px;color:var(--text-muted);font-weight:500}.datalist-pagination-controls{display:flex;gap:4px;align-items:center;flex-wrap:wrap;justify-content:center}.datalist-pagination-btn{min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .15s ease}.datalist-pagination-btn:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.datalist-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.datalist-pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}.datalist-skeleton{padding:20px}.datalist-skeleton-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:20px;margin-bottom:16px}.datalist-skeleton-cell{height:20px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary)}.datalist-skeleton-pulse{width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:datalist-skeleton-shimmer 1.5s infinite}@keyframes datalist-skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.datalist-empty-wrapper{padding:60px 20px}.datalist-empty{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.datalist-empty-icon{width:48px;height:48px;color:var(--text-muted);opacity:.5}.datalist-empty-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.datalist-empty-description{font-size:14px;color:var(--text-muted);margin:0;max-width:300px}@media(max-width:1024px){.datalist-table td:nth-child(n+5){font-size:13px;padding:0 14px}}@media(max-width:768px){.datalist-table-wrapper{display:none}.datalist-cards{display:flex}.datalist-pagination{flex-direction:column;padding:12px 16px}.datalist-pagination-info{text-align:center;font-size:12px;order:2}.datalist-pagination-controls{width:100%;order:1}.datalist-pagination-btn{min-width:32px;height:32px;padding:0 8px;font-size:12px}.datalist-card-body{grid-template-columns:1fr;gap:10px}.datalist-card-field{flex-direction:row;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.datalist-card-field:last-child{border-bottom:none}}@media(max-width:480px){.datalist-cards{padding:10px;gap:8px}.datalist-card{padding:14px;border-radius:14px}.datalist-card-quick-actions{grid-template-columns:1fr}.datalist-card-action-btn{width:100%}.datalist-action-trigger{width:32px;height:32px}.datalist-action-menu{min-width:160px;right:-6px}.datalist-action-item{padding:8px 10px;font-size:13px}}[data-theme=dark] .datalist-card{background:var(--bg-card);border-color:#ffffff14}[data-theme=dark] .datalist-card:hover{border-color:#6366f14d;box-shadow:0 4px 16px #0000004d}[data-theme=dark] .datalist-table th{background:#ffffff08}[data-theme=dark] .datalist-action-menu{box-shadow:0 8px 32px #0006;border-color:#ffffff1a}[data-theme=dark] .datalist-skeleton-cell{background:#ffffff0d}@supports (padding-bottom: env(safe-area-inset-bottom)){.datalist-pagination{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}.table-dropdown-trigger{display:inline-flex;align-items:center;justify-content:space-between;gap:10px;min-width:148px;max-width:100%;border:1px solid color-mix(in srgb,var(--primary) 12%,var(--border));border-radius:12px;padding:6px 10px;background:linear-gradient(180deg,#fffffff5,#f8fafcfa);color:var(--text-primary);cursor:pointer;transition:border-color .18s ease,background-color .18s ease}.table-dropdown-trigger:hover{border-color:color-mix(in srgb,var(--primary) 30%,var(--border));background:var(--bg-card)}.table-dropdown-trigger.is-disabled{opacity:.7;cursor:wait}.table-dropdown-trigger-main{display:inline-flex;align-items:center;gap:8px;min-width:0}.table-dropdown-trigger-label{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-chevron{color:var(--text-muted);flex-shrink:0}.table-dropdown-menu{display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:14px;border:1px solid color-mix(in srgb,var(--primary) 16%,var(--border));background:color-mix(in srgb,var(--bg-card) 92%,white 8%);box-shadow:0 24px 48px #0f172a2e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow:hidden}.table-dropdown-search-wrap{position:relative;flex-shrink:0}.table-dropdown-search-icon{position:absolute;top:50%;left:10px;transform:translateY(-50%);color:var(--text-muted)}.table-dropdown-search-input{width:100%;height:34px;padding:0 10px 0 32px;border:1px solid var(--border);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:12px;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.table-dropdown-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.table-dropdown-options{overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding-right:2px}.table-dropdown-option{display:inline-flex;width:100%;align-items:center;justify-content:space-between;gap:10px;border:none;border-radius:10px;background:transparent;padding:8px;text-align:left;cursor:pointer;transition:background .18s ease,transform .18s ease}.table-dropdown-option:hover,.table-dropdown-option.is-active{background:color-mix(in srgb,var(--primary-bg) 46%,var(--bg-secondary))}.table-dropdown-option:hover{transform:translate(2px)}.table-dropdown-option-main{display:inline-flex;align-items:center;gap:10px;min-width:0}.table-dropdown-icon-box{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.table-dropdown-option-text{display:flex;flex-direction:column;min-width:0}.table-dropdown-option-label{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-option-description{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-dropdown-check{color:var(--primary);flex-shrink:0}.table-dropdown-empty{font-size:12px;color:var(--text-muted);padding:8px}[data-theme=dark] .table-dropdown-trigger{background:linear-gradient(180deg,#18181bfa,#121215fa)}[data-theme=dark] .table-dropdown-menu{background:color-mix(in srgb,var(--bg-card) 92%,black 8%)}.cropper-container{position:relative;width:100%;height:400px;background:#333;border-radius:var(--radius);overflow:hidden}.cropper-controls{padding:16px 0;display:flex;flex-direction:column;gap:12px}.cropper-zoom{display:flex;align-items:center;gap:12px}.cropper-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-light);border-radius:3px;outline:none}.cropper-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a;border:2px solid #fff}.cropper-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}:root{--primary: #6C63FF;--primary-light: #8B84FF;--primary-dark: #5A52E0;--primary-bg: rgba(108, 99, 255, .08);--bg: #f4f6fb;--bg-card: #ffffff;--bg-sidebar: #ffffff;--bg-header: rgba(255, 255, 255, .98);--text-primary: #111111;--text-secondary: #222222;--text-muted: #888888;--border: #e6e8ee;--border-light: #f0f1f4;--hover-bg: #f9fafc;--success: #10B981;--success-bg: rgba(16, 185, 129, .08);--warning: #F59E0B;--warning-bg: rgba(245, 158, 11, .08);--danger: #EF4444;--danger-bg: rgba(239, 68, 68, .08);--info: #3B82F6;--info-bg: rgba(59, 130, 246, .08);--stat-blue: #EFF6FF;--stat-blue-accent: #3B82F6;--stat-green: #ECFDF5;--stat-green-accent: #10B981;--stat-orange: #FFF7ED;--stat-orange-accent: #F59E0B;--stat-indigo: #EEF2FF;--stat-indigo-accent: #6366f1;--stat-purple: #F5F3FF;--stat-purple-accent: #A855F7;--stat-pink: #FDF2F8;--stat-pink-accent: #EC4899;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--s-16: 64px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .03);--shadow: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 2px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .08);--shadow-xl: 0 8px 28px rgba(0, 0, 0, .1);--shadow-glass: 0 4px 24px rgba(108, 99, 255, .06);--table-header-bg: #fafbfd;--radius-sm: 10px;--radius: 14px;--radius-lg: 18px;--radius-xl: 24px;--transition: .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 280px;--sidebar-collapsed-width: 90px;--header-height: 72px;--font-body: "Inter", -apple-system, sans-serif;--font-heading: "Plus Jakarta Sans", sans-serif;--text-xs: .8125rem;--text-sm: .9375rem;--text-base: 1.0625rem;--text-lg: 1.1875rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--z-base: 1;--z-header: 50;--z-sidebar: 100;--z-dropdown: 200;--z-modal: 500;--z-toast: 1000;--premium-zinc-50: #f8fafc;--premium-zinc-100: #f1f5f9;--premium-zinc-200: #e2e8f0;--premium-zinc-300: #cbd5e1;--premium-zinc-400: #94a3b8;--premium-zinc-500: #64748b;--premium-zinc-600: #475569;--premium-zinc-700: #334155;--premium-zinc-800: #1e293b;--premium-zinc-900: #0f172a;--premium-purple-500: #8b5cf6;--premium-purple-600: #7c3aed;--premium-indigo-500: #6366f1;--premium-indigo-600: #4f46e5;--shadow-premium: 0 0 0 1px rgba(0, 0, 0, .05), 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-glow: 0 0 20px rgba(139, 92, 246, .15);--border-premium: 1px solid rgba(0, 0, 0, .08);--bg-tertiary: #f0f4f8;--glass-border: rgba(255, 255, 255, .1);--text-soft: #666666;--border-color: #e2e8f0;--star-color: #FFD700;--star-bg: rgba(255, 215, 0, .05)}[data-theme=dark]{--bg: #09090b;--bg-card: #121215;--bg-sidebar: #09090b;--bg-header: rgba(9, 9, 11, .8);--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-muted: #52525b;--border: #27272a;--border-light: #18181b;--table-header-bg: #18181b;--hover-bg: #18181b;--shadow-premium: 0 0 0 1px rgba(255, 255, 255, .05), 0 4px 6px -1px rgba(0, 0, 0, .2), 0 2px 4px -1px rgba(255, 255, 255, .08);--bg-tertiary: #18181b;--glass-border: rgba(255, 255, 255, .05);--text-soft: #a1a1aa;--border-color: #27272a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.25;letter-spacing:-.02em}h1{font-size:var(--text-3xl);margin-bottom:var(--s-6)}h2{font-size:var(--text-2xl);margin-bottom:var(--s-4)}h3{font-size:var(--text-xl);margin-bottom:var(--s-3)}img{max-width:100%;display:block}button{font-family:inherit}.glass-effect{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .glass-effect{background:#121215b3;border:1px solid rgba(255,255,255,.05)}.glass-card{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .glass-card{background:#101622b3;border:1px solid rgba(255,255,255,.05)}.noise-bg{position:relative}.noise-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}.card-hover-lift{transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.card-hover-lift:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl),var(--shadow-glow)}.button-press-scale{transition:transform .1s ease}.button-press-scale:active{transform:scale(.95)}.p-1{padding:var(--s-1)}.p-2{padding:var(--s-2)}.p-3{padding:var(--s-3)}.p-4{padding:var(--s-4)}.p-5{padding:var(--s-5)}.m-1{margin:var(--s-1)}.m-2{margin:var(--s-2)}.m-3{margin:var(--s-3)}.m-4{margin:var(--s-4)}.m-5{margin:var(--s-5)}.gap-1{gap:var(--s-1)}.gap-2{gap:var(--s-2)}.gap-3{gap:var(--s-3)}.gap-4{gap:var(--s-4)}.h-full{height:100%}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-primary{color:var(--text-primary)}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:var(--z-sidebar);transition:width var(--transition);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-sidebar) - 1);animation:fadeIn .2s ease}.sidebar-overlay.open{display:block}.sidebar-fixed-top{padding:var(--s-6) var(--s-6) var(--s-4);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar.collapsed .sidebar-fixed-top{padding:var(--s-6) 0 var(--s-4);flex-direction:column;gap:var(--s-2);justify-content:center;min-height:100px}.sidebar-brand{display:flex;align-items:center;gap:var(--s-3);transition:all var(--transition);text-decoration:none;color:inherit}.sidebar-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;display:flex;align-items:center;justify-content:center;border-radius:12px;font-weight:800;font-size:20px;box-shadow:0 4px 12px var(--primary-bg)}.sidebar-brand-text{font-family:var(--font-heading);font-size:20px;font-weight:800;letter-spacing:-.5px;white-space:nowrap;opacity:1;transition:opacity .2s ease}.sidebar.collapsed .sidebar-brand-text{opacity:0;width:0;pointer-events:none}.sidebar-scrollable-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 var(--s-4) var(--s-6);display:flex;flex-direction:column}.sidebar.collapsed .sidebar-scrollable-content{padding:0 var(--s-2) var(--s-6);align-items:center}.sidebar-nav{display:flex;flex-direction:column;gap:var(--s-6)}.sidebar-section{display:flex;flex-direction:column;gap:var(--s-1)}.sidebar-section-title{padding:0 var(--s-4) var(--s-2);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);transition:opacity .2s ease}.sidebar.collapsed .sidebar-section-title{opacity:0;height:0;margin:0;padding:0}.sidebar-link{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-2) var(--s-3);border-radius:14px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid transparent}.sidebar-icon-wrapper{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:color-mix(in srgb,var(--icon-color, var(--text-muted)),transparent 92%);color:var(--icon-color, var(--text-muted));transition:all .2s ease;flex-shrink:0}.sidebar-link:hover{background:var(--bg-card);border-color:var(--border-light);color:var(--text-primary)}.sidebar-link:hover .sidebar-icon-wrapper{background:color-mix(in srgb,var(--icon-color),transparent 85%);transform:scale(1.05)}.sidebar-link.active{background:color-mix(in srgb,var(--icon-color),transparent 90%);border-color:color-mix(in srgb,var(--icon-color),transparent 85%);color:var(--icon-color)}.sidebar-link.active .sidebar-icon-wrapper{background:var(--icon-color);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--icon-color),transparent 60%)}.sidebar-link.active .sidebar-label{font-weight:600;color:var(--text-primary)}.sidebar-label{white-space:nowrap;opacity:1;transition:opacity .2s ease;flex:1}.sidebar.collapsed .sidebar-label{opacity:0;width:0;pointer-events:none;position:absolute}.sidebar-collapse-btn-simple{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.sidebar-collapse-btn-simple:hover{background:var(--hover-bg);color:var(--primary);border-color:var(--primary-light)}.rotate-180{transform:rotate(180deg)}.sidebar-theme-toggle{margin-top:auto;display:flex;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:4px;gap:4px}.sidebar.collapsed .sidebar-theme-toggle{flex-direction:column;width:44px;padding:4px}.theme-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;border-radius:8px;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.theme-option.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm)}.sidebar.collapsed .theme-text{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px!important}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:280px!important}.sidebar.collapsed .sidebar-brand-text,.sidebar.collapsed .sidebar-label,.sidebar.collapsed .sidebar-section-title{opacity:1;width:auto;position:relative;pointer-events:auto}.sidebar.collapsed .sidebar-fixed-top{flex-direction:row;padding:var(--s-6)}.sidebar.collapsed .theme-text{display:block}.sidebar.collapsed .sidebar-theme-toggle{flex-direction:row;width:auto}}.header{height:var(--header-height);padding:0 var(--s-8);background:var(--bg-header);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;transition:all var(--transition)}.header-left,.header-right{display:flex;align-items:center;gap:var(--s-4)}.hamburger{display:none;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;padding:var(--s-2);border-radius:10px;transition:all var(--transition);align-items:center;justify-content:center}.hamburger:hover{background:var(--hover-bg);border-color:var(--primary-light);color:var(--primary)}.header-user{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-1) var(--s-3);background:var(--bg-card);border-radius:14px;border:1px solid var(--border-light);transition:all var(--transition);cursor:pointer}.header-user:hover{border-color:var(--primary-light);background:color-mix(in srgb,var(--primary),transparent 95%);transform:translateY(-1px)}.header-avatar{width:32px;height:32px;border-radius:10px;object-fit:cover;border:1.5px solid var(--primary-light);box-shadow:0 2px 8px var(--primary-bg)}.header-user-info{display:flex;flex-direction:column;line-height:1.2}.header-username{font-size:13px;font-weight:700;color:var(--text-primary)}.header-role{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:capitalize}.logout-btn{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.logout-btn:hover{background:color-mix(in srgb,var(--danger),transparent 92%);color:var(--danger);border-color:var(--danger-light);transform:scale(1.05)}@media(max-width:768px){.hamburger{display:flex}.header{padding:0 var(--s-4);height:64px}.header-user-info{display:none}.header-user{padding:var(--s-1);border-radius:12px}}[data-theme=dark] .header{background:#10121fcc}[data-theme=dark] .header-user,[data-theme=dark] .logout-btn{background:#ffffff08;border-color:#ffffff14}.user-badge{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-2) var(--s-3);border-radius:var(--radius-sm);background:var(--hover-bg);font-size:15px;font-weight:500}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px}.notification-bell{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.notification-bell:hover{background:color-mix(in srgb,var(--primary),transparent 92%);color:var(--primary);border-color:color-mix(in srgb,var(--primary),transparent 80%);transform:scale(1.05)}.notification-bell.active{background:color-mix(in srgb,var(--primary),transparent 90%);color:var(--primary);border-color:color-mix(in srgb,var(--primary),transparent 70%)}.notification-bell.intense{box-shadow:0 0 #ef444480;animation:intense-bell-glow 1.6s ease infinite}@keyframes intense-bell-glow{0%{box-shadow:0 0 #ef44448c}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.notification-bell-icon{transition:transform .2s ease}.notification-bell:hover .notification-bell-icon{transform:rotate(12deg)}.notification-bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;border-radius:20px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-header);box-shadow:0 2px 4px #ef44444d;animation:badge-pop .3s ease}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.notification-drawer .drawer-body{padding:0;display:flex;flex-direction:column;height:100%}.notification-filter-tabs{display:flex;gap:4px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.notification-filter-tab{flex:1;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}.notification-filter-tab:hover{background:var(--hover-bg);color:var(--text-primary)}.notification-filter-tab.active{background:var(--bg-card);color:var(--primary);box-shadow:0 1px 3px #0000001a}.notification-filter-badge{background:var(--primary);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px}.notification-mark-all{padding:8px 16px;border-bottom:1px solid var(--border-light)}.notification-mark-all-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition)}.notification-mark-all-btn:hover{background:color-mix(in srgb,var(--primary),transparent 90%)}.notification-list{flex:1;overflow-y:auto;padding:16px}.notification-group{margin-bottom:24px}.notification-group:last-child{margin-bottom:0}.notification-group-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.notification-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap}.notification-group-divider{flex:1;height:1px;background:var(--border-light)}.notification-group-items{display:flex;flex-direction:column;gap:12px}.notification-card{position:relative;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-light);padding:16px;transition:all .2s ease;cursor:pointer}.notification-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px);border-color:color-mix(in srgb,var(--primary),transparent 70%)}.notification-card.unread{background:color-mix(in srgb,var(--primary),transparent 96%);border-left:3px solid var(--primary)}.notification-card.unread:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:16px;pointer-events:none;background:linear-gradient(120deg,color-mix(in srgb,var(--primary),transparent 86%),transparent 35%,color-mix(in srgb,#25D366,transparent 90%));opacity:.5}.notification-card.unread:hover:before{opacity:.75}.notification-unread-dot{position:absolute;top:16px;right:48px;width:8px;height:8px;background:var(--primary);border-radius:50%;animation:pulse-dot 2s ease infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.notification-card-content{display:flex;gap:14px}.notification-avatar-section{position:relative;flex-shrink:0}.notification-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid var(--bg-card);box-shadow:0 2px 8px #0000001a}.notification-type-icon{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card);box-shadow:0 2px 4px #0000001a}.notification-content{flex:1;min-width:0}.notification-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.notification-header-right{display:inline-flex;align-items:center;gap:8px}.notification-whatsapp-btn{width:24px;height:24px;border:none;border-radius:999px;background:#25d366;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #25d36659;transition:transform .15s ease,box-shadow .15s ease}.notification-whatsapp-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #25d36673}.notification-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3}.notification-time{font-size:10px;font-weight:500;color:var(--text-muted);white-space:nowrap}.notification-message{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.4;margin-bottom:4px}.notification-subtitle{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.notification-view-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--primary);text-decoration:none;transition:gap .2s ease}.notification-view-link:hover{gap:8px}.notification-delete-btn{position:absolute;top:16px;right:16px;width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.notification-card:hover .notification-delete-btn.visible,.notification-delete-btn:focus{opacity:1}.notification-delete-btn:hover{background:var(--danger-bg);color:var(--danger)}.notification-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.notification-action-btn{padding:6px 14px;border:none;border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;transition:all var(--transition)}.notification-action-btn.primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #ec5b134d}.notification-action-btn.primary:hover{background:color-mix(in srgb,var(--primary),black 15%);transform:translateY(-1px);box-shadow:0 4px 12px #ec5b1366}.notification-action-btn.secondary{background:var(--bg-secondary);color:var(--text-secondary)}.notification-action-btn.secondary:hover{background:var(--hover-bg);color:var(--text-primary)}.notification-action-btn.danger{background:var(--danger-bg);color:var(--danger)}.notification-action-btn.danger:hover{background:var(--danger);color:#fff}.notification-actions-more{font-size:11px;color:var(--text-muted);align-self:center}.notification-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.notification-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-muted)}.notification-empty-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.notification-empty-description{font-size:13px;color:var(--text-muted)}.notification-drawer-footer{display:flex;align-items:center;justify-content:space-between;padding:16px;border-top:1px solid var(--border-light);background:var(--bg-secondary)}.notification-view-all{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:all var(--transition)}.notification-view-all:hover{color:var(--primary);gap:10px}.notification-settings-link{padding:8px;border-radius:8px;color:var(--text-muted);transition:all var(--transition)}.notification-settings-link:hover{background:var(--hover-bg);color:var(--primary)}.notification-skeleton-list{padding:16px;display:flex;flex-direction:column;gap:16px}.notification-skeleton-card{display:flex;gap:14px;padding:16px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-light)}.notification-skeleton-avatar{position:relative;flex-shrink:0}.notification-skeleton-icon{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;overflow:hidden}.notification-skeleton-content{flex:1}.notification-skeleton-header{display:flex;justify-content:space-between;margin-bottom:8px}.notification-skeleton-message{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.notification-skeleton-actions{display:flex;gap:8px}.skeleton-pulse{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--hover-bg) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease infinite}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-icon{width:22px;height:22px}.skeleton-title{width:60%;height:14px;border-radius:4px}.skeleton-time{width:60px;height:10px;border-radius:4px}.skeleton-text{height:12px;border-radius:4px}.skeleton-text-full{width:100%}.skeleton-text-70{width:70%}.skeleton-btn{width:80px;height:28px;border-radius:8px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .notification-card{background:var(--bg-sidebar)}[data-theme=dark] .notification-card.unread{background:color-mix(in srgb,var(--primary),transparent 92%)}[data-theme=dark] .notification-card.unread:before{opacity:.42}[data-theme=dark] .notification-filter-tab.active,[data-theme=dark] .notification-skeleton-card{background:var(--bg-sidebar)}@media(max-width:480px){.notification-drawer{width:100%!important;max-width:100%!important}.notification-card{padding:12px}.notification-avatar{width:40px;height:40px}.notification-type-icon{width:18px;height:18px}.notification-action-btn{padding:5px 10px;font-size:10px}}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-base);background:#fff}.data-table th{text-align:left;padding:16px 22px;font-weight:700;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--table-header-bg);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:0 22px;height:56px;border-bottom:1px solid var(--border-light);color:var(--text-primary);line-height:1.4;vertical-align:middle}.data-table tbody tr{transition:all .15s ease;cursor:pointer}.data-table tbody tr:nth-child(2n){background:#fafbfd}[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#ffffff04}.data-table tbody tr:hover{background:#f4f5fa}.badge{display:inline-flex;align-items:center;padding:3px 11px;border-radius:99px;font-size:var(--text-sm);font-weight:600;letter-spacing:.01em}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-primary{background:var(--primary-bg);color:var(--primary)}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .15s ease}.card:hover{box-shadow:var(--shadow-md)}.attendance-card-apple{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000005,0 1px 2px #0000000a;border:.5px solid rgba(0,0,0,.05);transition:all .2s cubic-bezier(.4,0,.2,1);padding:16px;display:flex;align-items:center;gap:16px;cursor:pointer}.attendance-card-apple:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000000a}.attendance-card-avatar{width:56px;height:56px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid white;box-shadow:inset 0 0 0 1px #0000000d}.attendance-card-avatar img{width:100%;height:100%;object-fit:cover}.attendance-card-avatar.initials{background:#f0f0f5;color:#1d1d1f;font-weight:700;font-size:18px}.attendance-card-info{flex:1;min-width:0}.attendance-card-title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.attendance-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.attendance-status-dot.pending{background:#ff9500}.attendance-status-dot.completed{background:#34c759}.attendance-status-dot.ongoing{background:#af52de}.attendance-status-dot.scheduled{background:#007aff}.attendance-status-dot.low{background:#ff3b30}.attendance-card-title{font-size:14px;font-weight:700;color:#1d1d1f;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.25}.attendance-card-meta{font-size:11px;color:#86868b;display:flex;align-items:center;flex-wrap:wrap;gap:6px}.attendance-card-meta .separator{color:#d1d1d6}.attendance-card-status-section{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.attendance-status-badge{font-size:9px;font-weight:700;text-transform:uppercase;padding:4px 10px;border-radius:8px;letter-spacing:.02em;transform:translateY(-2px)}.attendance-progress-count{font-size:10px;font-weight:700;color:#6e6e73;line-height:1}.attendance-status-badge.pending{background:#fff4e5;color:#ff9500;border:1px solid #FFE4C4}.attendance-status-badge.completed{background:#e8f7ee;color:#34c759;border:1px solid #D4EDE0}.attendance-status-badge.ongoing{background:#f5eefc;color:#af52de;border:1px solid #E8DBF5}.attendance-status-badge.scheduled{background:#e5f2ff;color:#007aff;border:1px solid #CCE4FF}.attendance-status-badge.low{background:#ffe5e5;color:#ff3b30;border:1px solid #FFD4D4}.attendance-progress-mini{width:64px;height:4px;background:#f0f0f5;border-radius:10px;overflow:hidden}.attendance-progress-mini-fill{height:100%;border-radius:10px;transition:width .3s ease}.attendance-progress-mini-fill.pending{background:#ff9500}.attendance-progress-mini-fill.completed{background:#34c759}.attendance-progress-mini-fill.ongoing{background:#af52de}.attendance-progress-mini-fill.scheduled{background:#007aff}.attendance-progress-mini-fill.low{background:#ff3b30}.attendance-add-card{border-radius:16px;border:2px dashed #d1d1d6;display:flex;align-items:center;justify-content:center;padding:20px;opacity:.5;transition:all .2s ease;cursor:pointer;background:transparent}.attendance-add-card:hover{opacity:1;border-color:var(--primary, #007AFF);background:#007aff0d}.attendance-add-card span{font-size:12px;font-weight:700;color:#86868b;letter-spacing:.05em;text-transform:uppercase}.attendance-add-card:hover span{color:var(--primary, #007AFF)}.teacher-payouts-filter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end}.teacher-payouts-quick-filters{display:flex;gap:8px;flex-wrap:wrap}.teacher-payout-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}.teacher-payout-apple-card{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;box-shadow:0 1px 2px #0f172a0a,0 12px 28px #0f172a14;border:1px solid rgba(148,163,184,.24);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:14px;display:flex;flex-direction:column;gap:12px;transition:all .2s cubic-bezier(.4,0,.2,1)}.teacher-payout-apple-card:hover{transform:translateY(-2px);box-shadow:0 1px 2px #0f172a0a,0 16px 32px #0f172a1f}.teacher-payout-card-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.teacher-payout-card-user{display:flex;align-items:center;gap:10px;min-width:0}.teacher-payout-avatar{width:44px;height:44px;border-radius:14px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#0f172a;font-size:14px;font-weight:700;background:linear-gradient(160deg,#dbeafe,#c7d2fe);border:1px solid rgba(148,163,184,.3);box-shadow:inset 0 1px #fffc}.teacher-payout-avatar img{width:100%;height:100%;object-fit:cover}.teacher-payout-card-name{font-size:15px;line-height:1.25;font-weight:700;color:#1d1d1f}.teacher-payout-card-meta{margin-top:4px;font-size:11px;color:#6e6e73;display:flex;align-items:center;flex-wrap:wrap;gap:5px}.teacher-payout-card-meta .sep{color:#d1d1d6}.teacher-payout-badge{font-size:10px;font-weight:700;padding:4px 8px;border-radius:9px;border:1px solid transparent;line-height:1}.teacher-payout-badge.pending{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.teacher-payout-badge.partial{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.teacher-payout-badge.paid{background:#ecfdf3;color:#166534;border-color:#bbf7d0}.teacher-payout-card-body{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.teacher-payout-card-metric{background:#ffffffad;border:1px solid rgba(148,163,184,.24);border-radius:10px;padding:8px 9px}.teacher-payout-card-metric .metric-label{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.02em;font-weight:700}.teacher-payout-card-metric .metric-value{margin-top:4px;font-size:13px;font-weight:700;color:#0f172a;line-height:1.15}.teacher-payout-card-metric .metric-value.muted{color:#334155}.teacher-payout-card-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}.teacher-payout-card-actions-main{display:flex;align-items:center;gap:8px}.teacher-payout-more-trigger{width:auto!important;height:34px!important;padding:0 12px!important;border-radius:11px!important;border:1px solid rgba(148,163,184,.36)!important;background:#ffffffbd!important}.teacher-payout-more-label{font-size:12px;font-weight:700;color:#334155}.teacher-payout-card-actions .action-dropdown-menu{min-width:190px;border-radius:12px;border-color:#94a3b84d;box-shadow:0 10px 24px #0f172a24}.teacher-payout-card-actions .btn{border-radius:11px;font-weight:600}@media(max-width:768px){.teacher-payouts-filter-row{grid-template-columns:1fr}.teacher-payouts-quick-filters{width:100%}.teacher-payouts-quick-filters .btn{flex:1;justify-content:center}.teacher-payout-apple-card{padding:12px}.teacher-payout-card-body{grid-template-columns:1fr}.teacher-payout-card-actions{justify-content:stretch;flex-direction:column;align-items:stretch}.teacher-payout-card-actions-main{width:100%}.teacher-payout-card-actions .btn{flex:1;justify-content:center}.teacher-payout-more-trigger{width:100%!important;justify-content:center!important}}.card-header{padding:20px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary)}.card-body{padding:24px 28px}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(160px,auto);gap:var(--s-5);margin-bottom:var(--s-8)}@media(max-width:1200px){.bento-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.bento-grid{grid-template-columns:1fr;gap:var(--s-4)}}.stats-container-mobile{display:flex;gap:var(--s-4);overflow-x:auto;padding:4px 4px 16px;margin:0 -4px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;scroll-snap-type:x mandatory}.stats-container-mobile::-webkit-scrollbar{display:none}.premium-stat-card{min-width:180px;flex:1;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--s-5);display:flex;flex-direction:column;justify-content:space-between;gap:var(--s-4);transition:all var(--transition);position:relative;overflow:hidden;scroll-snap-align:start;-webkit-user-select:none;user-select:none}.premium-stat-card:active{transform:scale(.97);background:var(--hover-bg)}.premium-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.premium-stat-card .stat-icon-wrapper{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:auto;transition:transform var(--transition)}.premium-stat-card:hover .stat-icon-wrapper{transform:rotate(-10deg) scale(1.1)}.premium-stat-content{display:flex;flex-direction:column}.premium-stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.premium-stat-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1}.premium-stat-trend{display:flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;margin-top:4px}.premium-stat-trend.up{color:var(--success)}.premium-stat-trend.down{color:var(--danger)}.premium-stat-card.blue .stat-icon-wrapper{background:var(--stat-blue-accent);color:#fff}.premium-stat-card.green .stat-icon-wrapper{background:var(--stat-green-accent);color:#fff}.premium-stat-card.orange .stat-icon-wrapper{background:var(--stat-orange-accent);color:#fff}.premium-stat-card.purple .stat-icon-wrapper{background:var(--stat-purple-accent);color:#fff}.premium-stat-card.red .stat-icon-wrapper{background:var(--stat-red-accent);color:#fff}.premium-stat-card.pink .stat-icon-wrapper{background:var(--stat-pink-accent);color:#fff}.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 2;grid-row:span 2}@media(max-width:1200px){.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 2}}@media(max-width:768px){.bento-chart-main,.bento-chart-side,.bento-list{grid-column:span 1}.premium-stat-card{min-width:160px;padding:var(--s-4)}}.bento-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--s-6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}[data-theme=dark] .bento-card{background:#18181b99;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-color:#ffffff0d}.hero-card-premium{background:linear-gradient(135deg,#8b84ff,#6c63ff);color:#fff;border-radius:var(--radius-xl);padding:var(--s-8);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;grid-column:span 2;grid-row:span 2;box-shadow:0 20px 40px -10px #6c63ff4d}.hero-card-premium h2{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--s-4);line-height:1.1;max-width:70%}.hero-card-premium p{font-size:var(--text-sm);opacity:.9;max-width:60%}.hero-illustration{position:absolute;right:-20px;top:50%;transform:translateY(-50%);width:240px;height:240px;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.1))}.bento-card.progress-card{background:#ffad7c;border:none;color:#331a0d;padding:var(--s-8);grid-column:span 2;grid-row:span 4}.progress-pills-container{display:flex;align-items:flex-end;justify-content:space-between;height:200px;margin-top:var(--s-8);gap:var(--s-4)}.progress-pill-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--s-3);flex:1}.progress-pill-bar{width:60px;height:100%;background:#0000000d;border-radius:30px;position:relative;overflow:hidden}.progress-pill-fill{position:absolute;bottom:0;left:0;width:100%;background:#4d2612;border-radius:30px;transition:height 1s cubic-bezier(.34,1.56,.64,1)}.progress-pill-fill.striped{background:repeating-linear-gradient(45deg,#4d2612,#4d2612 10px,#5d3622 10px,#5d3622 20px)}.progress-pill-label{font-size:13px;font-weight:600;opacity:.7}.dark-highlight-card{background:#25282c;color:#fff;border-radius:var(--radius-xl);padding:var(--s-8);grid-column:span 2;grid-row:span 1;display:flex;align-items:center;justify-content:space-between}.visual-tile{background:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);transition:transform var(--transition);cursor:pointer}.visual-tile:hover{transform:translateY(-8px)}.visual-tile-img{width:100%;height:160px;object-fit:cover}.visual-tile-content{padding:var(--s-5)}.visual-tile-title{font-size:var(--text-base);font-weight:700;margin-bottom:4px}.subject-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 4px 12px #0000000a}.ph-main{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--bg-card);border-radius:14px;box-shadow:var(--shadow-md);flex-wrap:wrap;transition:margin-bottom .2s ease}.ph-title-wrap{display:flex;align-items:center;gap:10px;min-width:0}.ph-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em;line-height:1.2}.ph-count{padding:4px 12px;border-radius:100px;font-size:.9rem;font-weight:600;white-space:nowrap}.ph-divider{width:1px;height:28px;background:var(--border)}.ph-stats{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.ph-stat-pill{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--text-primary)}.ph-stat-pill.is-clickable{padding:6px 12px;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid transparent}.ph-stat-pill.is-clickable:hover{background:var(--bg);border-color:var(--border)}.ph-stat-pill.is-active{background:var(--ph-stat-bg)}.ph-stat-pill.is-active .ph-stat-icon,.ph-stat-pill.is-active .ph-stat-label,.ph-stat-pill.is-active .ph-stat-value{color:var(--ph-stat-color)}.ph-stat-icon,.ph-stat-label{color:var(--text-muted)}.ph-spacer{flex:1}.ph-search{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:10px;border:1px solid var(--border);padding:0 12px;height:38px;min-width:200px;max-width:320px;flex:1 1 240px}.ph-search-input{border:none;background:transparent;width:100%;font-size:.9rem;outline:none;color:var(--text-primary)}.ph-filter-btn,.ph-add-btn,.ph-reset-btn{height:38px;padding:0 16px;border-radius:10px;border:1px solid var(--border);font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.ph-add-btn{padding:0 20px;border-radius:100px;background:var(--primary);color:#fff;border:none;box-shadow:0 2px 8px #6c63ff4d}.ph-filters-panel{display:flex;gap:10px;padding:12px;background:var(--bg-card);border-radius:0 0 14px 14px;margin-bottom:16px;box-shadow:var(--shadow-sm);flex-wrap:wrap;animation:slideDown .2s ease}.ph-filter-select{height:36px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);font-size:.85rem;min-width:120px;color:var(--text-primary);cursor:pointer}.ph-reset-btn{height:36px;background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}@media(max-width:900px){.ph-main{gap:10px;padding:12px}.ph-divider,.ph-spacer{display:none}.ph-title{font-size:1.2rem}.ph-title-wrap,.ph-stats,.ph-search,.ph-custom-actions,.ph-filter-btn,.ph-add-btn{width:100%}.ph-stats{justify-content:flex-start}.ph-search{max-width:none;min-width:0}.ph-filter-btn,.ph-add-btn{justify-content:center}.ph-filters-panel{padding:10px}.ph-filter-select,.ph-reset-btn{width:100%}}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:var(--text-base);font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);text-decoration:none;line-height:1.4}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-md)}.form-group{margin-bottom:var(--s-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--s-1)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-card);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:42px;cursor:pointer;background-image:linear-gradient(180deg,#ffffffd9,#f8fafceb),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:center,right 14px center;background-size:auto,14px;box-shadow:0 1px 2px #0f172a0a}[data-theme=dark] .form-select{background-image:linear-gradient(180deg,#18181bfa,#121215fa),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.form-select:hover{border-color:color-mix(in srgb,var(--primary) 20%,var(--border));box-shadow:0 6px 16px #0f172a0f}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.form-select:disabled{cursor:not-allowed;opacity:.68;box-shadow:none}.form-select option{color:var(--text-primary);background:var(--bg-card)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;animation:scaleIn .2s ease}.modal-lg{max-width:900px}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:var(--s-3)}.confirm-dialog{display:flex;flex-direction:column;gap:16px}.confirm-dialog-icon-wrap{display:flex;align-items:flex-start;gap:16px}.confirm-dialog-icon{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 10px 25px #0f172a14}.confirm-dialog-danger .confirm-dialog-icon{color:#dc2626;background:linear-gradient(135deg,#fee2e2f2,#fef2f2f2);border:1px solid rgba(239,68,68,.18)}.confirm-dialog-info .confirm-dialog-icon{color:#2563eb;background:linear-gradient(135deg,#dbeafef2,#eff6fff2);border:1px solid rgba(59,130,246,.18)}.confirm-dialog-text{min-width:0;display:flex;flex-direction:column;gap:8px}.confirm-dialog-message{font-size:1rem;font-weight:700;line-height:1.5;color:var(--text-primary)}.confirm-dialog-details{font-size:.92rem;line-height:1.6;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:14px;padding:12px 14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.modal-backdrop{align-items:center;padding:10px;background:#00000080}.modal,.modal-lg{width:calc(100% - 4px);max-width:100%;max-height:92vh;border-radius:16px;box-shadow:0 14px 30px #00000038;animation:slideUpIn .22s ease;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:14px 16px;position:sticky;top:0;z-index:2;background:var(--bg-card);flex-shrink:0}.modal-header h2{font-size:1rem;line-height:1.3}.modal-body{padding:14px 16px;overflow-y:auto;flex:1 1 auto;min-height:0}.confirm-dialog-icon-wrap{gap:12px}.confirm-dialog-icon{width:46px;height:46px;border-radius:14px}.confirm-dialog-message{font-size:.95rem}.confirm-dialog-details{font-size:.88rem;padding:10px 12px}.modal-footer{padding:12px 16px calc(12px + env(safe-area-inset-bottom));position:sticky;bottom:0;background:var(--bg-card);z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:10px;flex-shrink:0}.modal-footer .btn{width:100%;min-height:42px;justify-content:center}}@media(max-width:420px){.modal-footer{grid-template-columns:1fr}}@keyframes slideUpIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.page-content{flex:1;padding:var(--s-8) var(--s-10);max-width:1600px}.search-box{position:relative;max-width:320px}.search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:18px;height:18px}.search-box .form-input{padding-left:38px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-6);flex-wrap:wrap;gap:var(--s-4)}.page-header h1{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.tabs{display:flex;gap:4px;padding:4px;background:var(--hover-bg);border-radius:var(--radius);margin-bottom:var(--s-5);overflow-x:auto}.tab{padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition);white-space:nowrap}.tab.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:600}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-5)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;padding:20px}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:float 20s ease-in-out infinite;pointer-events:none}.login-bg-orb:nth-child(1){width:400px;height:400px;background:linear-gradient(135deg,var(--primary),var(--primary-light));top:-150px;left:-100px;animation-delay:0s}.login-bg-orb:nth-child(2){width:300px;height:300px;background:linear-gradient(135deg,var(--premium-purple-500),var(--premium-indigo-500));bottom:-100px;right:-50px;animation-delay:-7s}.login-bg-orb:nth-child(3){width:250px;height:250px;background:linear-gradient(135deg,var(--success),var(--info));top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s;opacity:.3}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(108,99,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(108,99,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.login-card{width:100%;max-width:440px;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);padding:48px 40px;box-shadow:0 0 0 1px #00000005,0 4px 6px -1px #00000005,0 10px 40px -10px #6c63ff26;position:relative;z-index:10;animation:cardAppear .6s cubic-bezier(.16,1,.3,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .login-card{background:#121215d9;border:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 1px #ffffff08,0 4px 6px -1px #0003,0 10px 40px -10px #6c63ff33}.login-card-header{text-align:center;margin-bottom:36px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:20px;margin-bottom:20px;box-shadow:0 4px 12px #6c63ff4d,inset 0 1px #ffffff4d;animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.login-logo svg{width:36px;height:36px;color:#fff}.login-card h1{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.02em}.login-card p{font-size:var(--text-sm);color:var(--text-muted);margin:0;line-height:1.5}.login-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:var(--danger);padding:14px 18px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;margin-bottom:24px;display:flex;align-items:center;gap:10px;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-error svg{flex-shrink:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form .form-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.login-form .form-input{width:100%;height:52px;padding:0 18px;font-size:var(--text-base);font-family:var(--font-body);color:var(--text-primary);background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);transition:all var(--transition);box-shadow:inset 0 1px 2px #00000005}.login-form .form-input:hover{border-color:var(--primary-light);background:var(--hover-bg)}.login-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:inset 0 1px 2px #00000005,0 0 0 4px #6c63ff1a}.login-form .form-input::placeholder{color:var(--text-muted);opacity:.7}.login-submit-btn{width:100%;height:54px;padding:0 24px;font-size:var(--text-base);font-weight:600;font-family:var(--font-body);color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;position:relative;overflow:hidden;letter-spacing:-.01em}.login-submit-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s ease}.login-submit-btn:hover:not(:disabled):before{transform:translate(100%)}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6c63ff59}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed;background:var(--premium-zinc-400)}.login-submit-btn .spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin:0}.login-footer{margin-top:28px;text-align:center;display:flex;flex-direction:column;gap:12px}.login-forgot{font-size:var(--text-sm);color:var(--text-muted)}.login-forgot a{color:var(--primary);text-decoration:none;font-weight:600;transition:color var(--transition)}.login-forgot a:hover{color:var(--primary-dark);text-decoration:underline}.login-back{font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:6px}.login-back a{color:var(--primary);text-decoration:none;font-weight:600;transition:color var(--transition)}.login-back a:hover{color:var(--primary-dark)}.login-input-wrapper{position:relative}.login-input-wrapper .form-input{padding-left:48px}.login-input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition)}.login-input-wrapper:focus-within .login-input-icon{color:var(--primary)}.login-password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition)}.login-password-toggle:hover{color:var(--primary)}.login-remember{display:flex;align-items:center;gap:10px;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer}.login-remember input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}@media(max-width:520px){.login-page{padding:40px 16px 16px;align-items:flex-start}.login-card{padding:36px 24px;border-radius:var(--radius-lg);max-width:100%}.login-logo{width:64px;height:64px;border-radius:18px}.login-logo svg{width:30px;height:30px}.login-card h1{font-size:var(--text-xl)}.login-form .form-input,.login-submit-btn{height:50px;font-size:var(--text-sm)}}.login-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:20}[data-theme=dark] .login-loading-overlay{background:#121215cc}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:var(--text-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}:root{--drawer-width: 640px;--drawer-overlay: rgba(15, 23, 42, .2);--drawer-surface: var(--bg-card, #ffffff);--drawer-surface-muted: var(--bg-secondary, #f6f7f8);--drawer-border: var(--border, #e2e8f0);--drawer-title: var(--text-primary, #0f172a);--drawer-subtitle: var(--text-muted, #64748b);--drawer-shadow: none;--drawer-radius: 0;--drawer-transition: .32s cubic-bezier(.22, 1, .36, 1)}[data-theme=dark]{--drawer-overlay: rgba(2, 6, 23, .55);--drawer-shadow: none}.side-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:var(--drawer-overlay);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease}.side-drawer-overlay.open{opacity:1;visibility:visible}.side-drawer{position:fixed;inset:0 0 0 auto;width:100%;max-width:var(--drawer-width);background:var(--drawer-surface);border-left:1px solid var(--drawer-border);box-shadow:var(--drawer-shadow);z-index:9999;transform:translate(100%);transition:transform var(--drawer-transition);display:flex;flex-direction:column;overflow:hidden;border-radius:var(--drawer-radius)}.side-drawer.open{transform:translate(0)}.drawer-content{height:100%;display:flex;flex-direction:column}.drawer-header{position:sticky;top:0;z-index:5;padding:20px 22px;border-bottom:1px solid var(--drawer-border);background:color-mix(in srgb,var(--drawer-surface) 86%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:space-between;gap:14px}.drawer-title-group{min-width:0}.drawer-title{margin:0;font-size:1.25rem;font-weight:700;line-height:1.25;color:var(--drawer-title);letter-spacing:-.01em}.drawer-subtitle{margin-top:4px;color:var(--drawer-subtitle);font-size:.85rem;display:flex;align-items:center;gap:6px}.drawer-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.drawer-header-actions{display:flex;align-items:center;gap:8px}.drawer-close-btn{width:38px;height:38px;border:0;border-radius:999px;background:var(--drawer-surface-muted);color:var(--drawer-subtitle);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s ease}.drawer-close-btn:hover{background:var(--hover-bg, #eef2f7);color:var(--drawer-title)}.drawer-body{flex:1;overflow:auto;padding:22px;display:flex;flex-direction:column;gap:22px}.drawer-body::-webkit-scrollbar{width:6px}.drawer-body::-webkit-scrollbar-thumb{background:var(--drawer-border);border-radius:999px}.drawer-footer{position:sticky;bottom:0;z-index:5;display:flex;gap:10px;justify-content:flex-end;padding:16px 22px 20px;border-top:1px solid var(--drawer-border);background:color-mix(in srgb,var(--drawer-surface) 90%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.drawer-section{display:flex;flex-direction:column;gap:14px}.section-title{margin:4px 2px 0;font-size:.7rem;line-height:1;text-transform:uppercase;letter-spacing:.15em;color:var(--drawer-subtitle);font-weight:700;display:inline-flex;align-items:center;gap:8px}.side-drawer .form-group,.side-drawer .form-row,.side-drawer .drawer-section>.credentials-box,.side-drawer .drawer-section>.rating-summary-box,.side-drawer .drawer-section>.feedback-card,.side-drawer .drawer-section>.student-info-popup,.side-drawer .drawer-section>.tab-content{margin:0}.side-drawer .form-label{font-size:.84rem;font-weight:600}.side-drawer .form-input,.side-drawer .form-select,.side-drawer .form-textarea{border-radius:12px;border:1px solid transparent;background:var(--drawer-surface-muted);box-shadow:none}.side-drawer .form-input:focus,.side-drawer .form-select:focus,.side-drawer .form-textarea:focus{border-color:color-mix(in srgb,var(--primary, #137fec) 35%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary, #137fec) 15%,transparent)}.drawer-empty-state{border:1px dashed var(--drawer-border);border-radius:16px;padding:42px 24px;text-align:center}.drawer-empty-state-icon{width:60px;height:60px;border-radius:16px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;background:var(--drawer-surface-muted)}.credentials-box{background:var(--drawer-surface-muted);border:1px solid var(--drawer-border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px}.credentials-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.credentials-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--drawer-subtitle);font-weight:700}.credentials-value{font-size:1rem;font-weight:700;color:var(--drawer-title)}.credentials-hint{margin:2px 0 0;padding-top:10px;border-top:1px dashed var(--drawer-border);color:var(--drawer-subtitle);font-size:.8rem}@media(max-width:768px){.side-drawer{inset:auto 0 0 0;max-width:100%!important;height:min(92vh,820px);border-left:0;border-top:1px solid var(--drawer-border);border-radius:16px 16px 0 0;transform:translateY(100%)}.side-drawer.open{transform:translateY(0)}.drawer-header,.drawer-body,.drawer-footer{padding-left:16px;padding-right:16px}.drawer-footer{flex-direction:column-reverse;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.drawer-footer .btn{width:100%;justify-content:center}}.dashboard-page{padding:var(--s-6);background:var(--bg);min-height:calc(100vh - var(--header-height))}.elite-dashboard-container{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;gap:var(--s-8)}.elite-header-minimal{margin-bottom:var(--s-2);display:flex;justify-content:space-between;align-items:center}.elite-welcome-title{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin-bottom:4px;font-family:var(--font-heading)}.elite-welcome-sub{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.header-actions{display:flex;gap:var(--s-3)}.glass-btn{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-4);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.glass-btn:hover{background:var(--hover-bg);border-color:var(--primary-light);transform:translateY(-1px)}.elite-grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--s-6)}.elite-stat-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:var(--s-4)}.elite-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.elite-stat-header{display:flex;justify-content:space-between;align-items:center}.elite-stat-icon-wrapper{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;background:var(--bg)}.elite-stat-avatars{display:flex;align-items:center}.elite-stat-avatars img{width:32px;height:32px;border-radius:50%;border:2px solid var(--bg-card);margin-left:-10px}.elite-stat-avatars img:first-child{margin-left:0}.avatar-more{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid var(--bg-card);margin-left:-10px}.elite-stat-badge{padding:4px 10px;border-radius:99px;font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;gap:2px}.elite-stat-badge.positive{background:var(--success-bg);color:var(--success)}.elite-stat-badge.negative{background:var(--danger-bg);color:var(--danger)}.elite-stat-title{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.elite-stat-value-row{display:flex;align-items:baseline;gap:var(--s-3);margin-top:4px}.elite-stat-value{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin:0}.elite-stat-trend-mini{font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;gap:2px}.elite-stat-trend-mini.positive{color:var(--success)}.elite-stat-trend-mini.negative{color:var(--danger)}.charts-stack{display:flex;flex-direction:column;gap:var(--s-8)}.elite-grid-charts{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6)}.elite-chart-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm)}.elite-chart-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--s-4);font-family:var(--font-heading)}.risk-center{display:flex;flex-direction:column;gap:var(--s-6)}.risk-widget{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--s-4);position:relative;overflow:hidden}.risk-widget.warning{border-top:4px solid var(--warning)}.risk-header{display:flex;justify-content:space-between;align-items:center}.risk-title{display:flex;align-items:center;gap:var(--s-2);font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin:0}.risk-list{display:flex;flex-direction:column;gap:var(--s-3)}.risk-item{display:flex;justify-content:space-between;align-items:center;padding:var(--s-3) var(--s-4);background:var(--bg);border-radius:var(--radius);transition:all var(--transition)}.risk-item:hover{background:var(--hover-bg)}.risk-info{display:flex;flex-direction:column}.risk-name{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.risk-sub{font-size:var(--text-xs);color:var(--text-muted)}.risk-value{font-weight:700;font-size:var(--text-sm)}.risk-value.danger{color:var(--danger)}.follow-up-btn{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary);border:none;cursor:pointer;transition:all var(--transition)}.follow-up-btn:hover{background:var(--primary);color:#fff}.transaction-card{background:var(--bg-card);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);padding:0!important;overflow:hidden}.elite-card-header{padding:var(--s-6);display:flex;justify-content:space-between;align-items:center}.elite-btn-view-all{background:transparent;border:1px solid var(--border);padding:var(--s-2) var(--s-4);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:var(--s-2);cursor:pointer;transition:all var(--transition)}.elite-btn-view-all:hover{background:var(--hover-bg);border-color:var(--primary-light)}.elite-table-wrapper{overflow-x:auto}.elite-table{width:100%;border-collapse:collapse}.elite-table th{text-align:left;padding:16px 24px;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);background:var(--table-header-bg);border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.05em}.elite-table td{padding:16px 24px;border-bottom:1px solid var(--border-light);vertical-align:middle}.td-customer{display:flex;align-items:center;gap:12px}.td-avatar{width:40px;height:40px;border-radius:12px}.td-info{display:flex;flex-direction:column}.td-name{font-weight:700;color:var(--text-primary);font-size:var(--text-sm)}.td-sub{font-size:var(--text-xs);color:var(--text-muted)}.td-price{font-weight:700;color:var(--text-primary)}.td-payment{display:flex;align-items:center;gap:8px;font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.td-payment img{height:18px}.elite-badge{padding:4px 12px;border-radius:8px;font-size:var(--text-xs);font-weight:700;display:inline-block}.tx-status-success{background:#dcfce7;color:#166534}.tx-status-cancel{background:#fee2e2;color:#991b1b}.tx-status-pending{background:#fef9c3;color:#854d0e}.td-actions{display:flex;gap:8px}.action-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s}.action-btn.view{background:#e0e7ff;color:#4338ca}.action-btn.edit{background:#dcfce7;color:#166534}.action-btn.delete{background:#fee2e2;color:#991b1b}.action-btn:hover{transform:scale(1.1)}.elite-grid-main{display:grid;grid-template-columns:2fr 1fr;gap:var(--s-8);align-items:start}@media(max-width:1280px){.elite-grid-main{grid-template-columns:1fr}}.elite-activity-card{background:var(--bg-card);padding:var(--s-6);border-radius:var(--radius-xl);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--s-6);height:100%}.activity-header{display:flex;justify-content:space-between;align-items:center}.activity-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0;font-family:var(--font-heading)}.activity-list{display:flex;flex-direction:column;gap:var(--s-6)}.activity-item{display:flex;gap:var(--s-4);position:relative}.activity-item:not(:last-child):after{content:"";position:absolute;left:20px;top:48px;bottom:-24px;width:2px;background:var(--border-light)}.activity-user{position:relative;z-index:1}.activity-avatar{width:40px;height:40px;border-radius:12px;border:2px solid var(--bg-card);object-fit:cover}.activity-icon-badge{position:absolute;bottom:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:var(--bg-card);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.activity-content{display:flex;flex-direction:column;gap:4px}.activity-text{font-size:var(--text-sm);line-height:1.5;color:var(--text-secondary)}.activity-username{font-weight:700;color:var(--text-primary)}.activity-action{font-weight:600}.activity-entity{color:var(--primary);font-weight:600}.activity-meta{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.meta-dot{opacity:.5}.clickable{cursor:pointer;transition:color var(--transition)}.clickable:hover{color:var(--primary)}.activity-empty{text-align:center;padding:var(--s-8) 0;color:var(--text-muted);font-size:var(--text-sm)}@media(max-width:1024px){.elite-grid-charts{grid-template-columns:1fr}}.teacher-dashboard{display:flex;flex-direction:column;gap:var(--s-8)}.teacher-grid-top{display:grid;grid-template-columns:3fr 1fr;gap:var(--s-6);align-items:start}.class-card{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;gap:var(--s-2)}.class-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.class-card.active{border-color:var(--primary);background:var(--primary-bg)}.class-card h3{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0}.class-subject{font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;gap:var(--s-1)}.class-meta{display:flex;gap:var(--s-4);margin-top:var(--s-2);font-size:var(--text-sm);color:var(--text-secondary)}.class-meta span{display:flex;align-items:center;gap:var(--s-1)}.homework-widget{background:var(--bg-card);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);overflow:hidden}.homework-header{padding:var(--s-4) var(--s-4);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-light)}.homework-header h3{font-size:var(--text-base);font-weight:700;margin:0}.homework-list{padding:0 var(--s-4)}.homework-item{padding:var(--s-3) 0;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:4px}.homework-item:last-child{border-bottom:none}.homework-title{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.homework-meta{font-size:var(--text-xs);color:var(--text-muted)}.attendance-section{margin-top:var(--s-6)}@media(max-width:1024px){.teacher-grid-top{grid-template-columns:1fr}}.student-dashboard{display:flex;flex-direction:column;gap:var(--s-8)}.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-xl);padding:var(--s-10);color:#fff;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-xl);position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.banner-content h1{font-size:var(--text-3xl);font-weight:800;margin:0;font-family:var(--font-heading)}.banner-content p{font-size:var(--text-lg);opacity:.9;margin-top:var(--s-2)}.banner-stats{display:flex;gap:var(--s-6);z-index:var(--z-base)}.stat-card-glass{background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--s-4) var(--s-6);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--s-4);border:1px solid rgba(255,255,255,.2);box-shadow:var(--shadow-glass)}.stat-icon.xp{color:#fbbf24}.stat-icon.badge-icon{color:#818cf8}.stat-value{display:block;font-size:var(--text-2xl);font-weight:800}.stat-label{font-size:var(--text-xs);text-transform:uppercase;font-weight:700;opacity:.8}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--s-8)}.dashboard-section{display:flex;flex-direction:column;gap:var(--s-4)}.section-header{display:flex;align-items:center;gap:var(--s-3)}.section-header h2{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0;font-family:var(--font-heading)}.exams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s-4)}.exam-card-mini{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;text-decoration:none;transition:all var(--transition)}.exam-card-mini:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-light)}.subject-tag{font-size:var(--text-xs);font-weight:800;color:var(--primary);text-transform:uppercase;margin-bottom:var(--s-1);display:block}.exam-info h3{margin:0;font-size:var(--text-base);color:var(--text-primary)}.exam-meta{display:flex;gap:var(--s-4);margin-top:var(--s-2);font-size:var(--text-xs);color:var(--text-muted)}.exam-meta span{display:flex;align-items:center;gap:var(--s-1)}.progress-card{background:var(--bg-card);padding:var(--s-5);border-radius:var(--radius-lg);border:var(--border-premium)}.progress-info{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--s-3)}.subject-meta h3{margin:0;font-size:var(--text-lg);font-weight:700}.level-badge{padding:2px 8px;background:var(--primary-bg);color:var(--primary);border-radius:99px;font-size:var(--text-xs);font-weight:700}.xp-details{font-size:var(--text-sm);font-weight:700;color:var(--text-muted)}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s-4)}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--s-4)}.badge-item{display:flex;flex-direction:column;align-items:center;gap:var(--s-2);text-align:center}.badge-circle{width:64px;height:64px;background:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.badge-item:hover .badge-circle{transform:scale(1.1) rotate(5deg);border-color:var(--primary)}.badge-circle img{width:40px;height:40px;object-fit:contain}.badge-name{font-size:var(--text-xs);font-weight:700;color:var(--text-muted)}.action-btn-premium{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4);border-radius:var(--radius-lg);text-decoration:none;color:var(--text-primary);background:var(--bg-card);border:var(--border-premium);transition:all var(--transition)}.action-btn-premium:hover{background:var(--hover-bg);transform:translate(4px);border-color:var(--primary-light)}.action-icon-wrapper{width:40px;height:40px;background:var(--primary-bg);color:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center}.action-icon-wrapper.trophy{background:var(--warning-bg);color:var(--warning)}.action-label-stack{flex:1;display:flex;flex-direction:column}.action-label-stack span{font-weight:700;font-size:var(--text-base)}.action-label-stack small{font-size:var(--text-xs);color:var(--text-muted)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column;text-align:center;gap:var(--s-6)}}.uc-page{display:flex;flex-direction:column;gap:20px}.uc-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.uc-title-row{display:flex;align-items:center;gap:14px}.uc-title-icon{color:#ef4444;flex-shrink:0}.uc-title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.uc-subtitle{font-size:14px;color:var(--text-muted);margin:2px 0 0}.uc-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-primary:hover:not(:disabled){background:var(--primary-dark, #4F46E5);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.uc-btn-primary:disabled{opacity:.6;cursor:not-allowed}.uc-btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-ghost:hover{background:var(--hover-bg);color:var(--text-primary)}.uc-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:#ef4444;color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all var(--transition)}.uc-btn-danger:hover{background:#dc2626;transform:translateY(-1px)}.uc-stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.uc-stat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:500;transition:all var(--transition)}.uc-stat-total{background:var(--bg-tertiary, var(--hover-bg));color:var(--text-secondary);border:1px solid var(--border)}.uc-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.uc-search-wrap{position:relative;flex:1;min-width:200px;max-width:380px}.uc-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.uc-search{width:100%;padding:9px 36px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;box-sizing:border-box;transition:border-color var(--transition)}.uc-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.uc-search::placeholder{color:var(--text-muted)}.uc-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:4px;display:flex;align-items:center}.uc-search-clear:hover{color:var(--text-primary)}.uc-select-wrap{position:relative;display:inline-flex;align-items:center}.uc-select-icon{position:absolute;right:10px;pointer-events:none;color:var(--text-muted)}.uc-select{padding:9px 32px 9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:border-color var(--transition)}.uc-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.uc-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.uc-table{width:100%;border-collapse:collapse}.uc-table thead th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg-secondary, var(--hover-bg));border-bottom:1px solid var(--border)}.uc-table tbody td{padding:13px 16px;border-bottom:1px solid var(--border-light, var(--border));font-size:14px;color:var(--text-primary);vertical-align:middle}.uc-table tbody tr:last-child td{border-bottom:none}.uc-table tbody tr{transition:background var(--transition)}.uc-table tbody tr:hover{background:var(--hover-bg)}.uc-row-disabled td{opacity:.45}.uc-user-cell{display:flex;align-items:center;gap:10px}.uc-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border-light, var(--border))}.uc-fullname{font-weight:600}.uc-username{font-size:13px;color:var(--text-muted);background:var(--hover-bg);padding:2px 7px;border-radius:6px}.uc-contact{display:flex;flex-direction:column;gap:3px;font-size:13px;color:var(--text-muted)}.uc-contact span{display:flex;align-items:center;gap:5px}.uc-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.uc-status-active{background:#10b9811f;color:#10b981}.uc-status-inactive{background:#ef44441a;color:#ef4444}.uc-actions{display:flex;gap:6px;align-items:center}.uc-action-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);cursor:pointer;transition:all var(--transition);color:var(--text-muted)}.uc-action-btn:disabled{opacity:.3;cursor:not-allowed}.uc-action-edit:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-bg, rgba(99,102,241,.08))}.uc-action-disable:hover{color:#ef4444;border-color:#ef4444;background:#ef444414}.uc-action-enable:hover{color:#10b981;border-color:#10b981;background:#10b98114}.uc-loading{display:flex;align-items:center;justify-content:center;min-height:200px}.uc-error{padding:12px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#ef4444;font-size:14px}.uc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.uc-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease;max-height:90vh;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.uc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.uc-modal-title{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;color:var(--text-primary)}.uc-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;transition:all var(--transition)}.uc-modal-close:hover{color:var(--text-primary);background:var(--hover-bg)}.uc-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.uc-modal-footer{padding:16px 24px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.uc-field{display:flex;flex-direction:column;gap:5px}.uc-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.uc-label{font-size:13px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center}.uc-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary, var(--hover-bg));color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;width:100%;box-sizing:border-box;transition:border-color var(--transition)}.uc-input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px #6366f11a}.uc-input::placeholder{color:var(--text-muted)}.uc-form-error{padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#ef4444;font-size:13px}.uc-confirm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:28px;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease}.uc-confirm-modal h3{margin:0 0 12px;font-size:18px;font-weight:700;color:var(--text-primary)}.uc-confirm-modal p{margin:0 0 24px;font-size:14px;color:var(--text-secondary);line-height:1.6}.uc-confirm-actions{display:flex;gap:10px;justify-content:flex-end}@media(max-width:768px){.uc-header{flex-direction:column;align-items:flex-start}.uc-filters{flex-direction:column;align-items:stretch}.uc-search-wrap{max-width:100%}.uc-field-row{grid-template-columns:1fr}.uc-table thead{display:none}.uc-table tbody td{display:block;padding:6px 16px}.uc-table tbody td:before{content:attr(data-label);font-weight:600;font-size:11px;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:2px}.uc-table tbody tr{display:block;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:8px 0}}.profile-role{font-size:13px;color:var(--text-muted);text-transform:capitalize}.attendance-grid{display:grid;gap:10px}.attendance-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius)}.attendance-student{font-weight:500;font-size:15px}.attendance-actions{display:flex;gap:6px}.attendance-btn{padding:6px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;border:2px solid transparent;cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.attendance-btn.join{background:var(--success-bg);color:var(--success);border-color:var(--success)}.attendance-btn.join.active,.attendance-btn.join:hover{background:var(--success);color:#fff}.attendance-btn.absence{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.attendance-btn.absence.active,.attendance-btn.absence:hover{background:var(--danger);color:#fff}.attendance-btn.excuse{background:var(--warning-bg);color:var(--warning);border-color:var(--warning)}.attendance-btn.excuse.active,.attendance-btn.excuse:hover{background:var(--warning);color:#fff}.chart-container{width:100%;height:300px}.warning-list{display:flex;flex-direction:column;gap:8px}.warning-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px}.warning-item.debt{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2)}.warning-item.lesson{background:var(--warning-bg);border:1px solid rgba(245,158,11,.2)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:24px auto}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:16px}.weekday-picker{display:flex;gap:6px}.weekday-btn{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.weekday-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pipeline-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.pipeline-btn{padding:6px 14px;border-radius:99px;font-size:14px;font-weight:500;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}.pipeline-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pipeline-btn:hover:not(.active){background:var(--hover-bg)}@media(max-width:768px){.sidebar{transform:translate(-100%);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90}.sidebar-overlay.open{display:block;animation:fadeIn .2s ease}.main-content{margin-left:0}.hamburger{display:flex;align-items:center;justify-content:center}.header{padding:0 20px;height:64px}.header-title{font-size:18px}.page-content{padding:20px}.stats-grid{grid-template-columns:1fr;gap:16px}.grid-2,.grid-3,.grid-4,.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.toolbar{flex-direction:column;align-items:stretch;width:100%}.modal{max-height:95vh;margin:16px;width:calc(100% - 32px)}.login-card{padding:28px 20px;margin:16px}}@media(max-width:480px){.attendance-row{flex-direction:column;gap:8px;align-items:stretch}.attendance-actions{justify-content:stretch}.attendance-btn{flex:1;text-align:center}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.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}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.w-full{width:100%}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-icon{width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition)}.btn-icon:hover{background:var(--hover-bg);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:var(--text-sm)}.form-checkbox{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition)}.form-checkbox:has(input:checked){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.form-checkbox input[type=checkbox]{margin:0}.actions-row{display:flex;align-items:center;gap:6px}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;border-radius:99px;background:var(--primary-bg);color:var(--primary);font-size:14px;font-weight:600;margin-left:8px;vertical-align:middle}.btn[title]{position:relative}.btn[title]:hover:after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);padding:4px 10px;border-radius:6px;background:var(--text-primary);color:var(--bg-card);font-size:13px;font-weight:500;white-space:nowrap;pointer-events:none;z-index:200;opacity:0;animation:tooltipIn .15s ease forwards}@keyframes tooltipIn{to{opacity:1}}.modern-list{display:flex;flex-direction:column;gap:16px}.modern-list-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:20px 28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer}.modern-list-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-light)}.modern-list-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--bg-tertiary, #f0f4f8);border:2px solid var(--border-light);box-shadow:var(--shadow-sm)}.modern-list-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;align-items:center}.modern-list-info{display:flex;flex-direction:column;gap:4px}.modern-list-name{font-family:var(--font-heading);font-size:19px;font-weight:700;color:var(--text-primary)}.modern-list-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.modern-list-actions{display:flex;gap:10px}@media(max-width:768px){.modern-list-item{grid-template-columns:1fr;padding:24px;gap:16px;text-align:center}.modern-list-avatar{margin:0 auto;width:80px;height:80px}.modern-list-content{grid-template-columns:1fr;gap:16px}.modern-list-badge-row{justify-content:center}.modern-list-actions{justify-content:center;border-top:1px solid var(--border-light);padding-top:16px;width:100%}}.card-2025{background:var(--bg-card);border-radius:20px;box-shadow:0 4px 20px -5px #0000000d,inset 0 1px #ffffffb3;border:1px solid var(--border);transition:all .3s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}[data-theme=dark] .card-2025{box-shadow:0 10px 40px -10px #0000004d,inset 0 1px #ffffff0d}.card-2025:hover{transform:translateY(-4px);box-shadow:0 12px 30px -8px #0000001a,inset 0 1px #ffffffb3;border-color:#6366f180}[data-theme=dark] .card-2025:hover{box-shadow:0 20px 50px -10px #0006,inset 0 1px #ffffff1a;border-color:#6366f166}.glass-icon-wrapper{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f11a,#6366f105);border:1px solid rgba(99,102,241,.2);box-shadow:inset 0 1px #ffffff80,0 4px 10px -2px #6366f126;color:var(--primary);flex-shrink:0}[data-theme=dark] .glass-icon-wrapper{background:linear-gradient(135deg,#6366f133,#6366f10d);box-shadow:inset 0 1px #ffffff1a,0 4px 10px -2px #6366f14d}.floating-filters{position:sticky;top:60px;z-index:40;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffb3;border-radius:16px;border:1px solid var(--border);box-shadow:0 8px 30px -10px #0000000f;padding:16px;margin-bottom:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}[data-theme=dark] .floating-filters{background:#141622bf}.floating-filters .form-input,.floating-filters .form-select{border-radius:12px;background:var(--bg-card);box-shadow:inset 0 1px 2px #00000005}.capacity-progress-bg{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:6px;position:relative;box-shadow:inset 0 1px 2px #0000000d}.capacity-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--primary));border-radius:3px;transition:width .5s ease-out}.capacity-progress-fill.full{background:linear-gradient(90deg,var(--warning),var(--danger))}.floating-actions-group{opacity:0;transform:translate(10px);transition:all .2s ease;display:flex;gap:4px}.card-2025:hover .floating-actions-group{opacity:1;transform:translate(0)}@media(max-width:768px){.floating-actions-group{opacity:1;transform:none}}.subjects-alert{margin:0 16px 12px;padding:10px 12px;border-radius:12px;border:1px solid rgba(239,68,68,.25);background:#ef444414;color:#b91c1c;font-weight:500;font-size:14px}.subjects-mobile-list{display:none}.subjects-mobile-card{border:1px solid var(--border);border-radius:16px;background:var(--bg-card);padding:14px;box-shadow:var(--shadow-sm)}.subjects-mobile-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.subjects-mobile-desc{font-size:14px;line-height:1.5;margin-bottom:12px}.subjects-mobile-actions{display:flex;gap:8px}.subjects-mobile-actions .btn{flex:1;justify-content:center}@media(max-width:768px){.subjects-table-desktop{display:none}.subjects-mobile-list{display:grid;gap:10px;padding:12px}}.teachers-list-item{border-radius:18px}.teachers-actions{flex-wrap:wrap}@media(max-width:768px){.teachers-list-item{padding:14px;gap:12px;border-radius:16px}.teachers-list-item .modern-list-content{gap:10px;text-align:left}.teachers-list-item .modern-list-name{font-size:17px}.teachers-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.teachers-actions .btn{width:100%;justify-content:center;min-height:40px}}@media(max-width:420px){.teachers-actions{grid-template-columns:1fr}}@media(max-width:768px){.classes-grid{grid-template-columns:1fr!important;gap:10px!important}.classes-card{border-radius:14px!important;padding:10px!important}.classes-card-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:6px!important}.classes-card-actions .btn{min-height:36px;font-size:.8rem!important;padding:6px!important}.classes-schedule-row{flex-wrap:wrap;gap:8px!important}.classes-schedule-row>div:first-child{width:100%!important}.classes-schedule-row .form-input{flex:1;min-width:120px}}@media(max-width:420px){.classes-card-actions{grid-template-columns:1fr}}.packages-mobile-list{display:none}@media(max-width:768px){.packages-table-desktop{display:none}.packages-mobile-list{display:grid;gap:10px;padding:12px}}.students-list-item{border-radius:18px}.students-actions{flex-wrap:wrap}@media(max-width:768px){.students-list-item{padding:14px;gap:12px;border-radius:16px}.students-list-item .modern-list-content{grid-template-columns:1fr;gap:10px;text-align:left}.students-list-item .modern-list-name{font-size:17px}.students-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.students-actions .btn{width:100%;justify-content:center;min-height:40px;font-size:.85rem}.students-credentials-modal,.students-info-modal{width:calc(100% - 20px)!important;max-width:none!important;max-height:92vh!important;border-radius:14px!important;margin:10px!important}}@media(max-width:420px){.students-actions{grid-template-columns:1fr}}.students-list-item{cursor:pointer}.student-info-popup{display:flex;flex-direction:column;gap:12px;margin:0 24px;width:calc(100% - 48px);max-width:100%;box-sizing:border-box}.student-info-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%}.student-info-summary-card{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--bg-card);box-sizing:border-box;min-width:0}.student-info-section-title{margin:4px 24px;font-size:1rem}.student-info-enrollment-list,.student-info-payment-list{display:flex;flex-direction:column;gap:8px;width:100%;min-width:0}.student-info-enrollment-card,.student-info-payment-row{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--bg-card);box-sizing:border-box;width:100%;min-width:0;overflow:hidden}.student-info-enrollment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;min-width:0}.student-info-enrollment-head .font-semibold{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.student-info-metrics-row{margin-top:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;font-size:.85rem;width:100%}.student-info-metrics-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.student-info-payment-row{display:flex;justify-content:space-between;align-items:center;gap:10px;min-width:0}.student-info-payment-row>div{min-width:0;overflow:hidden}.student-info-enrollment-head-btn{width:100%;background:transparent;border:0;padding:0;text-align:left;cursor:pointer;min-width:0}.student-info-attendance-list{margin-top:8px;display:flex;flex-direction:column;gap:6px;width:100%;min-width:0}.student-info-attendance-row{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:8px;background:var(--bg-secondary);font-size:.85rem;min-width:0}@media(max-width:768px){.student-info-popup{margin:0 20px;width:calc(100% - 40px)}.student-info-section-title{margin:4px 20px}.student-info-summary-grid{grid-template-columns:1fr}.student-info-metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:480px){.student-info-popup{margin:0 16px;width:calc(100% - 32px)}.student-info-section-title{margin:4px 16px}.student-info-metrics-row{grid-template-columns:1fr 1fr;gap:4px;font-size:.8rem}.student-info-enrollment-card,.student-info-payment-row{padding:8px}}.enrollments-list-item{border-radius:18px}.enrollments-actions{flex-wrap:wrap}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 24px;width:calc(100% - 48px);max-width:100%;box-sizing:border-box}.side-drawer .table-wrapper-sm{width:100%;overflow-x:auto;min-width:0}.side-drawer .data-table{width:100%;min-width:0;border-collapse:collapse}.side-drawer .data-table th,.side-drawer .data-table td{padding:10px 12px;text-align:left;white-space:nowrap}.side-drawer .data-table th:first-child,.side-drawer .data-table td:first-child{padding-left:0}.side-drawer .data-table th:last-child,.side-drawer .data-table td:last-child{padding-right:0}.side-drawer .mb-6{margin-bottom:24px}.side-drawer .mb-3{margin-bottom:12px}.side-drawer h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.side-drawer .flex{display:flex}.side-drawer .items-center{align-items:center}.side-drawer .gap-2{gap:8px}@media(max-width:768px){.enrollments-list-item{padding:14px;gap:12px;border-radius:16px}.enrollments-list-item .modern-list-content{grid-template-columns:1fr;gap:10px}.enrollments-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px;border-top:1px solid var(--border-light);padding-top:10px}.enrollments-actions .btn{width:100%;min-height:40px;justify-content:center;font-size:.84rem}.enrollments-actions .btn svg{width:14px;height:14px}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 20px;width:calc(100% - 40px)}.side-drawer .data-table th,.side-drawer .data-table td{padding:8px 10px;font-size:.875rem}}@media(max-width:420px){.enrollments-actions{grid-template-columns:1fr}.enrollments-drawer-content,.side-drawer .tab-content{margin:0 16px;width:calc(100% - 32px)}.side-drawer .data-table th,.side-drawer .data-table td{padding:6px 8px;font-size:.8rem}}.enrollments-table-wrapper{display:block}.enrollments-mobile-list{display:none}.enrollments-table .enrollments-table-student{display:flex;align-items:center;gap:12px}.enrollments-table .enrollments-table-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border-light);flex-shrink:0}.enrollments-table .enrollments-table-badges{display:flex;flex-wrap:wrap;gap:6px}.enrollments-table .enrollments-table-actions{display:flex;gap:6px;flex-wrap:wrap}.enrollments-table .enrollments-table-actions .btn{padding:6px 10px}@media(max-width:768px){.enrollments-table-wrapper{display:none}.enrollments-mobile-list{display:flex}}@media(min-width:769px)and (max-width:1024px){.enrollments-table .enrollments-table-student{gap:8px}.enrollments-table .enrollments-table-avatar{width:32px;height:32px}.enrollments-table th,.enrollments-table td{padding:12px 14px;font-size:.9rem}.enrollments-table .enrollments-table-actions .btn{padding:5px 8px;font-size:.85rem}.enrollments-table .badge{padding:2px 8px;font-size:.75rem}}@media(max-width:768px){.hierarchy-page-v2 .page-header-premium{flex-direction:column;align-items:flex-start;gap:10px}.hierarchy-page-v2 .header-actions{width:100%;display:grid!important;grid-template-columns:1fr;gap:8px}.hierarchy-page-v2 .main-layout{display:block!important}.hierarchy-page-v2 .subject-sidebar{width:100%!important;margin-bottom:10px;max-height:220px;overflow:auto}.hierarchy-page-v2 .levels-grid{grid-template-columns:1fr!important;gap:10px!important}.hierarchy-page-v2 .level-card,.hierarchy-page-v2 .unit-card,.hierarchy-page-v2 .topic-item{border-radius:14px!important}.ai-modal-container{width:calc(100% - 16px)!important;margin:8px!important;max-height:94vh!important;border-radius:14px!important}}@media(max-width:768px){.questions-page{padding:12px!important}.questions-page .q-card-header{flex-wrap:wrap;align-items:flex-start!important}.questions-page .q-actions{width:100%;justify-content:flex-end}.questions-page .q-content-body{font-size:1rem!important}.questions-page .floating-filters{padding:12px!important}.questions-page .floating-filters .form-select,.questions-page .floating-filters .btn{width:100%!important;min-width:0!important}.questions-page .ai-grid{grid-template-columns:1fr!important}.questions-page .ai-modal-container{border-radius:14px!important;max-height:94vh!important}}@media(max-width:768px){.exams-page .page-header{flex-direction:column;align-items:flex-start!important;gap:10px}.exams-page [style*="repeat(auto-fill, minmax(300px, 1fr))"]{grid-template-columns:1fr!important}.exams-page [style*="width: 'fit-content'"]{width:100%!important;overflow-x:auto}}@media(max-width:768px){.ai-modal-overlay{align-items:center!important;padding:10px!important}.ai-modal-container{width:100%!important;max-width:100%!important;max-height:92vh!important;border-radius:16px!important;margin:0!important}.side-drawer{width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0}.side-drawer .drawer-header{padding:12px 14px!important}.side-drawer .drawer-body{padding:14px 0!important}.side-drawer .drawer-info-bar,.side-drawer .drawer-section>.description-content,.side-drawer .drawer-section>.resources-grid,.side-drawer .drawer-section>h3:not(.discussion-section-wrapper h3){margin:0 14px!important}}@media(max-width:768px){.attendance-page{padding-bottom:90px!important}.attendance-page>div:first-child{gap:12px!important}.attendance-page [style*="justify-content: space-between"][style*="margin-bottom: '32px'"]{flex-direction:column!important;align-items:stretch!important}.attendance-page [style*="background: 'var(--bg-card)'"][style*="padding: '12px 20px'"]{padding:12px!important}.attendance-desktop-table{display:none!important}.attendance-mobile-list{display:grid!important;gap:10px}.attendance-mobile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:12px;box-shadow:var(--shadow-sm)}.attendance-mobile-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.attendance-mobile-actions .btn{min-height:42px;justify-content:center}}@media(max-width:420px){.attendance-mobile-actions{grid-template-columns:1fr}}.attendance-pill{border:1.5px solid var(--border);background:#fff;color:var(--text-secondary);border-radius:12px;min-height:42px;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}.attendance-pill.join.active{background:#e8f7ee;border-color:#22c55e;color:#15803d}.attendance-pill.absence.active{background:#feecec;border-color:#ef4444;color:#b91c1c}.attendance-pill.excuse.active{background:#fff7e6;border-color:#f59e0b;color:#b45309}.attendance-fab-save{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;border:none;background:var(--primary);color:#fff;display:none;align-items:center;justify-content:center;box-shadow:0 10px 24px #2563eb59;z-index:70}.attendance-fab-save:disabled{background:#94a3b8;box-shadow:none}.attendance-fab-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;animation:spin .8s linear infinite}.attendance-save-toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(86px + env(safe-area-inset-bottom));background:#16a34a;color:#fff;font-weight:700;border-radius:12px;padding:10px 14px;z-index:71;box-shadow:0 8px 20px #0003}@media(max-width:768px){.attendance-save-top{display:none!important}.attendance-fab-save{display:inline-flex}}.attendance-page,.attendance-page *{box-sizing:border-box}.attendance-fab-save{right:16px;bottom:calc(84px + env(safe-area-inset-bottom));background:linear-gradient(135deg,#2563eb,#7c3aed)}.attendance-fab-icon{animation:attendanceFabPulse 1.8s ease-in-out infinite}@keyframes attendanceFabPulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}@media(max-width:768px){.attendance-page{padding-left:10px;padding-right:10px}.attendance-page [style*="display: 'flex'"][style*="alignItems: 'center'"][style*="padding: '6px'"]{width:100%;overflow:hidden;flex-wrap:wrap;gap:6px;justify-content:center}.attendance-page input[type=date]{min-width:0;width:100%}.attendance-mobile-list{width:100%;max-width:100%;overflow:hidden}.attendance-mobile-card{width:100%;max-width:100%;margin:0}.attendance-mobile-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-mobile-actions .attendance-pill{width:100%;padding:8px 4px;font-size:12px}}.attendance-class-grid,.attendance-class-card{min-width:0}.attendance-save-top-icon{animation:attendanceTopIconFloat 1.6s ease-in-out infinite}@keyframes attendanceTopIconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}@media(max-width:768px){.attendance-class-grid{grid-template-columns:1fr!important;gap:12px!important}.attendance-class-card{width:100%!important;max-width:100%!important;padding:14px!important;overflow:hidden}.attendance-class-card *{min-width:0}}.teacher-payouts-mobile-list{display:none}@media(max-width:768px){.teacher-payouts-table-desktop{display:none}.teacher-payouts-mobile-list{display:grid;gap:10px}}.teachers-table th{position:sticky;top:0;background:var(--table-header-bg);z-index:10;box-shadow:0 2px 4px #0000000a}.teachers-table td{vertical-align:middle}.teachers-table tbody tr{cursor:pointer;transition:all .15s ease}.teachers-table tbody tr:nth-child(2n){background:#fafbfd}[data-theme=dark] .teachers-table tbody tr:nth-child(2n){background:#ffffff04}.teachers-table tbody tr:hover{background:#f4f5fa}[data-theme=dark] .teachers-table tbody tr:hover{background:#6c63ff0a}.action-dropdown-container{position:relative;display:inline-block}.action-dropdown-trigger{width:36px;height:36px;padding:0;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.action-dropdown-trigger:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.action-dropdown-trigger:focus{outline:none;box-shadow:0 0 0 3px var(--primary-bg)}.action-dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;padding:6px;z-index:1000;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.action-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .15s ease;border-radius:var(--radius-sm);text-align:left}.action-dropdown-item:hover{background:var(--hover-bg)}.action-dropdown-item-default:hover{background:var(--primary-bg);color:var(--primary)}.action-dropdown-item-danger{color:var(--danger)}.action-dropdown-item-danger:hover{background:var(--danger-bg)}.action-dropdown-item-success{color:var(--success)}.action-dropdown-item-success:hover{background:var(--success-bg)}.action-dropdown-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-dropdown-label{flex:1;white-space:nowrap}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid var(--border);background:var(--bg-card);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.pagination-info{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.pagination{display:flex;gap:6px;align-items:center}.pagination-btn{min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background:var(--primary-bg);border-color:var(--primary);color:var(--primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}@media(max-width:1024px){.teachers-table th:nth-child(3),.teachers-table td:nth-child(3){display:none}}@media(max-width:768px){.pagination-container{flex-direction:column;gap:12px;padding:12px 16px}.pagination-info{text-align:center;font-size:12px}.pagination{width:100%;justify-content:center}.pagination-btn{min-width:32px;height:32px;padding:0 8px;font-size:12px}.teachers-table th,.teachers-table td{padding:10px 12px}.teachers-table th:nth-child(5),.teachers-table td:nth-child(5),.teachers-table th:nth-child(4),.teachers-table td:nth-child(4){display:none}.teachers-table td:first-child img{width:32px;height:32px}.action-dropdown-menu{right:-10px}}@media(max-width:480px){.teachers-table th:nth-child(2),.teachers-table td:nth-child(2){display:none}.action-dropdown-trigger{width:32px;height:32px}.action-dropdown-menu{min-width:160px}.action-dropdown-item{padding:8px 10px;font-size:13px}.pagination-btn:first-child,.pagination-btn:last-child{padding:0 16px}}
