:root{--bg: #F9FAFB;--bg-secondary: #F3F4F6;--bg-hover: #E5E7EB;--surface: #FFFFFF;--muted: #6B7280;--text: #1F2937;--text-muted: #6B7280;--primary: #3B82F6;--primary-contrast: #FFFFFF;--primary-hover: #2563EB;--secondary: #6366F1;--success: #10B981;--danger: #EF4444;--warning: #F59E0B;--border: #E5E7EB;--border-light: #F3F4F6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .08);--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 20px;--spacing-6: 24px;--spacing-8: 32px;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-full: 9999px;--font-sans: "Inter", "Public Sans", "Manrope", "Roboto", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", SFMono-Regular, ui-monospace, Menlo, Consolas, monospace;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px}[data-theme=dark]{--bg: #1E1E2F;--bg-secondary: #2A2A3C;--bg-hover: #3F3F4F;--surface: #2A2A3C;--muted: #9CA3AF;--text: #F3F4F6;--text-muted: #9CA3AF;--primary: #60A5FA;--primary-hover: #3B82F6;--secondary: #818CF8;--success: #34D399;--danger: #F87171;--warning: #FBBF24;--border: #3F3F4F;--border-light: #2A2A3C;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 1px 3px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5)}[data-theme=sakura]{--bg: #FFF0F5;--bg-hover: #FFD6E0;--surface: #FFE4E8;--muted: #8F5D85;--text: #4B0082;--primary: #FF69B4;--primary-hover: #ff85c3;--secondary: #DB7093;--success: #34D399;--danger: #F87171;--warning: #FBBF24;--border: #FFC1D6;--border-light: #FFE4E8;--shadow-sm: 0 1px 2px rgba(255, 105, 180, .25);--shadow: 0 1px 3px rgba(255, 105, 180, .35);--shadow-lg: 0 4px 12px rgba(255, 105, 180, .45)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;height:100%}body{font-family:var(--font-sans);font-size:var(--font-size-base);background:var(--bg);color:var(--text);line-height:1.6;min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;transition:background-color .3s ease-in-out,color .3s ease-in-out}.container{max-width:1200px;margin:0 auto;padding:var(--spacing-4)}#main-content{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-5);min-height:calc(100vh - 140px)}@media (max-width: 768px){#main-content{padding:var(--spacing-4) var(--spacing-3)}}h1{font-size:var(--font-size-2xl);font-weight:600;line-height:1.2;margin-bottom:var(--spacing-4);color:var(--text)}h2{font-size:var(--font-size-xl);font-weight:600;line-height:1.3;margin-bottom:var(--spacing-3);color:var(--text)}h3{font-size:var(--font-size-lg);font-weight:600;line-height:1.4;margin-bottom:var(--spacing-3);color:var(--text)}h4,h5,h6{font-size:var(--font-size-base);font-weight:600;line-height:1.4;margin-bottom:var(--spacing-2);color:var(--text)}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.m-1{margin:var(--spacing-1)}.m-2{margin:var(--spacing-2)}.m-3{margin:var(--spacing-3)}.m-4{margin:var(--spacing-4)}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-bold{font-weight:600}.text-muted{color:var(--muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:var(--radius-full)}@media (max-width: 1024px){.container{padding:var(--spacing-3)}}@media (max-width: 768px){html{font-size:15px}.container{padding:var(--spacing-2)}h1{font-size:var(--font-size-xl)}h2{font-size:var(--font-size-lg)}::-webkit-scrollbar{width:0;height:0}}@media (max-width: 640px){html{font-size:14px}.container{padding:var(--spacing-2)}button,a,input[type=checkbox],input[type=radio]{min-height:44px;min-width:44px}}@media print{.sidebar,.top-nav,.btn,.modal-backdrop,.toast-container{display:none!important}.container{max-width:100%;padding:0}body{background:#fff;color:#000}}.btn.btn-icon{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;gap:0}.sidebar-user-section{padding-top:var(--spacing-4);border-top:1px solid var(--border);margin-top:var(--spacing-4)}.user-account-card{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all .2s ease}.user-account-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.user-account-btn{display:flex;align-items:center;gap:var(--spacing-3);flex:1;padding:0;background:none;border:none;text-align:left;cursor:default;transition:opacity .2s ease}.user-account-btn.clickable{cursor:pointer}.user-account-btn.clickable:hover{opacity:.8}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:var(--shadow-sm)}.user-info-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-1)}.user-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--font-size-xs);color:var(--muted);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all .2s ease;flex-shrink:0}.logout-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.logout-btn:active{transform:translateY(0)}.top-nav-actions{display:flex;align-items:center;gap:var(--spacing-3)}.top-nav-user-card{display:flex;align-items:center;gap:var(--spacing-2)}.top-nav-user-card .user-account-card{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-xl);box-shadow:none;min-width:220px}.top-nav-user-card .user-avatar{width:34px;height:34px}.top-nav-user-card .user-info-content{gap:2px}.top-nav-user-card .user-name{font-size:.85rem}.top-nav-guest-actions{display:flex;gap:var(--spacing-2)}.top-nav-guest-actions .btn{border-radius:var(--radius-full)}@media (max-width: 768px){.top-nav-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-2)}.top-nav-user-card{width:100%;justify-content:space-between}.top-nav-user-card .user-account-card{flex:1}.top-nav-guest-actions{width:100%;justify-content:space-between}}.btn-icon-only{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius)}.admin-login-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.admin-login-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.admin-login-form label{font-size:var(--font-size-sm);font-weight:600;color:var(--text);display:flex;align-items:center;gap:var(--spacing-1)}.admin-login-form .input-wrapper{position:relative;display:flex;align-items:center}.admin-login-form .password-wrapper{position:relative}.admin-login-form .form-control{width:100%;padding:var(--spacing-3);font-size:var(--font-size-base);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);transition:all .2s ease}.admin-login-form .password-wrapper .form-control{padding-right:44px}.admin-login-form .form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.admin-login-form .form-control::-moz-placeholder{color:var(--muted);opacity:.6}.admin-login-form .form-control::placeholder{color:var(--muted);opacity:.6}.password-toggle{position:absolute;right:var(--spacing-2);top:50%;transform:translateY(-50%);background:none;border:none;padding:var(--spacing-2);cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease;z-index:1;width:32px;height:32px}.password-toggle:hover{background:var(--surface-hover);color:var(--text)}.password-toggle:active{transform:translateY(-50%) scale(.95)}.password-toggle .eye-icon{width:20px;height:20px;stroke-width:2;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.password-toggle .eye-closed{display:none}.password-toggle .eye-open{display:block}.form-hint{display:flex;align-items:flex-start;gap:var(--spacing-1);font-size:var(--font-size-xs);color:var(--muted);line-height:1.5;margin-top:var(--spacing-1)}.form-hint svg{flex-shrink:0;margin-top:2px;width:14px;height:14px}.admin-login-form .form-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end;padding-top:var(--spacing-2);border-top:1px solid var(--border);margin-top:var(--spacing-2)}.admin-login-form .form-actions .btn{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius);transition:all .2s ease}.admin-login-form .form-actions .btn-outline{background:var(--surface);border:1px solid var(--border);color:var(--text)}.admin-login-form .form-actions .btn-outline:hover{background:var(--surface-hover);border-color:var(--border-hover)}.admin-login-form .form-actions .btn-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.admin-login-form .form-actions .btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.admin-login-form .form-actions .btn-primary:active{transform:translateY(0)}.admin-login-form .form-actions .btn svg{width:16px;height:16px}.staff-tabs{display:flex;gap:var(--spacing-2);border-bottom:1px solid var(--border);padding:0;margin:0}.staff-tab{padding:var(--spacing-3) var(--spacing-4);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;margin-bottom:-1px}.staff-tab:hover{color:var(--text);background:var(--surface-hover)}.staff-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.role-badge{display:inline-block;padding:2px 8px;background:var(--primary);color:#fff;border-radius:12px;font-size:.75rem;margin-right:4px;white-space:nowrap}.account-btn{padding:var(--spacing-2) var(--spacing-3);width:auto;height:auto;justify-content:flex-start;gap:var(--spacing-2)}.account-btn:hover{background:var(--surface-hover)}.sidebar{background:#ffffffd1;background-image:linear-gradient(180deg,#3b82f60d,#6366f108 35%,#ffffff1a);box-shadow:0 20px 60px #0f172a14;display:flex;flex-direction:column;padding:var(--spacing-5) var(--spacing-4);min-height:100vh;border-right:1px solid rgba(15,23,42,.06);position:sticky;top:0;height:100vh;overflow-y:auto;transition:box-shadow .3s ease,transform .3s ease;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}body[data-theme=dark] .sidebar{background:#0f172ab3;border-right-color:#ffffff14}.sidebar .brand{margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--spacing-3)}.sidebar .brand svg{color:var(--primary);flex-shrink:0}.sidebar .brand>div{display:flex;flex-direction:column;gap:var(--spacing-1)}.sidebar .brand>div>div:first-child{font-weight:600;font-size:var(--font-size-lg);color:var(--text)}.sidebar .brand>div>div:last-child{font-size:var(--font-size-xs);color:var(--muted)}.sidebar .tabs{flex:1;display:flex;flex-direction:column;gap:var(--spacing-1);padding-right:2px}.sidebar .tab{width:100%;text-align:left;padding:var(--spacing-2) var(--spacing-3);border:none;background:transparent;color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:all .2s ease-in-out;display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);font-weight:500;position:relative;min-height:42px}.sidebar .tab svg{width:18px;height:18px;flex-shrink:0;opacity:.7;transition:opacity .2s ease-in-out}.sidebar .tab:hover{background:#3b82f614;color:var(--primary);box-shadow:inset 0 0 0 1px #3b82f626}.sidebar .tab:hover svg{opacity:1;color:inherit}.sidebar .tab[aria-current=page]{background:linear-gradient(90deg,#3b82f62e,#3b82f614);color:var(--primary);font-weight:600;box-shadow:inset 0 0 0 1px #3b82f640}.sidebar .tab[aria-current=page]:before{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:6px;height:60%;background:var(--primary);border-radius:0 var(--radius) var(--radius) 0;box-shadow:0 8px 20px #3b82f64d}.sidebar .tab[aria-current=page] svg{opacity:1;color:var(--primary)}.navbar{position:fixed;top:0;left:0;right:0;height:64px;background:var(--surface);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-4);z-index:50}.brand{display:flex;align-items:center;gap:var(--spacing-3);font-weight:600}.tabs{display:flex;gap:var(--spacing-2)}.tab{padding:var(--spacing-2) var(--spacing-3);border:none;background:transparent;color:var(--muted);border-radius:var(--radius);cursor:pointer;transition:all .2s}.tab[aria-current=page]{background:var(--primary);color:var(--primary-contrast)}.top-nav{display:flex;justify-content:center;padding:var(--spacing-2) var(--spacing-4);border-bottom:1px solid var(--border-subtle);background:#ffffffe6;position:sticky;top:0;z-index:40;box-shadow:var(--shadow-sm);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:box-shadow .3s ease,background .3s ease,border-color .3s ease}[data-theme=dark] .top-nav{background:#1e293bd9}.top-nav.top-nav-scrolled{box-shadow:0 8px 24px #0f172a14;border-bottom-color:#94a3b833}.top-nav-inner{width:100%;max-width:1200px;margin:0 auto;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-4)}.top-nav-left{flex:1;display:flex;flex-direction:column;gap:var(--spacing-2)}.top-nav-brand{display:flex;align-items:center;gap:var(--spacing-2)}.top-nav-tabs{display:flex;gap:var(--spacing-2);justify-content:flex-start;align-items:center;overflow-x:auto;padding:0 var(--spacing-1);scrollbar-width:none;position:relative}.top-nav-tabs::-webkit-scrollbar{display:none}.top-nav-tabs:before,.top-nav-tabs:after{content:"";position:sticky;top:0;width:18px;height:100%;pointer-events:none;z-index:1;opacity:0;transition:opacity .2s ease}.top-nav-tabs:before{left:0;background:linear-gradient(90deg,#ffffffe6,#fff0)}.top-nav-tabs:after{right:0;background:linear-gradient(270deg,#ffffffe6,#fff0)}[data-theme=dark] .top-nav-tabs:before{background:linear-gradient(90deg,#1e293bd9,#1e293b00)}[data-theme=dark] .top-nav-tabs:after{background:linear-gradient(270deg,#1e293bd9,#1e293b00)}.top-nav-tabs.has-left-shadow:before{opacity:1}.top-nav-tabs.has-right-shadow:after{opacity:1}.top-nav-tabs .tab{display:flex;align-items:center;gap:var(--spacing-1);white-space:nowrap;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-full);transition:all .2s ease;border:1px solid transparent;background:#94a3b824;color:var(--muted);min-height:38px}.top-nav-tabs .tab:hover{background:#3b82f61f;color:var(--text);border-color:#3b82f626}.top-nav-tabs .tab[aria-current=page]{background:var(--primary);color:var(--primary-contrast);box-shadow:0 8px 20px #3b82f640}.top-nav-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-shrink:0}@media (max-width: 1024px){.top-nav-inner{flex-direction:column;align-items:stretch;gap:var(--spacing-3)}.top-nav-actions{width:100%;justify-content:space-between}}.theme-switcher{width:100%;display:flex;flex-direction:row;gap:var(--spacing-2)}.theme-switcher .btn{flex:1;justify-content:center;padding:var(--spacing-2);border-radius:var(--radius);transition:transform .2s ease,border-color .2s ease,background .2s ease}.theme-icon-only{font-size:1.3rem;line-height:1}.theme-btn.theme-active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary);box-shadow:var(--shadow)}.actions{display:flex;align-items:center;gap:var(--spacing-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease-in-out;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn:hover:not(:disabled){background:var(--bg);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover);color:var(--primary-contrast);box-shadow:var(--shadow)}[data-theme=dark] .btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626;color:#fff}.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){background:#3b82f614;border-color:var(--primary);color:var(--primary)}.btn-icon{padding:var(--spacing-2);border-radius:var(--radius);min-width:32px;min-height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);cursor:pointer;transition:all .2s ease-in-out}.btn-icon:hover{color:var(--text);background:var(--bg)}.btn-icon svg{width:16px;height:16px}.crud-actions{display:flex;align-items:center;gap:var(--spacing-1);opacity:0;transition:opacity .2s ease-in-out}tr:hover .crud-actions{opacity:1}.btn-edit-icon,.btn-delete-icon,.btn-transfer-icon,.btn-add-icon{padding:var(--spacing-1);border-radius:var(--radius);min-width:28px;min-height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;transition:all .2s ease-in-out}.btn-edit-icon{color:var(--primary)}.btn-edit-icon:hover{background:var(--primary);color:var(--primary-contrast)}.btn-transfer-icon{color:var(--warning, #F59E0B)}.btn-transfer-icon:hover{background:var(--warning, #F59E0B);color:#fff;transform:scale(1.05)}.btn-delete-icon{color:var(--danger)}.btn-delete-icon:hover{background:var(--danger);color:var(--danger-contrast)}.btn-add-icon{background:var(--primary);color:var(--primary-contrast)}.btn-add-icon:hover{opacity:.9;transform:scale(1.05)}.btn-add-icon svg,.btn-edit-icon svg,.btn-delete-icon svg,.btn-transfer-icon svg{width:16px;height:16px}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-4);border:1px solid var(--border);transition:all .2s ease-in-out}.card:hover{box-shadow:var(--shadow);border-color:var(--border)}.table-container{overflow-x:auto;border-radius:var(--radius)}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{padding:var(--spacing-3);text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;color:var(--muted);background:var(--bg)}.table-striped tbody tr{transition:all .2s ease-in-out;cursor:pointer;position:relative;overflow:visible}.table-striped tbody tr:hover{background:var(--bg);transform:translate(2px)}.session-row-clickable{cursor:pointer;transition:background-color .2s ease-in-out,transform .1s ease-in-out;position:relative}.session-row-clickable:hover{background:var(--bg)!important;transform:translate(2px)}.session-row-clickable:active{transform:translate(0);background:var(--surface)!important}.session-row-clickable.row-selected{background:#3b82f61a!important;border-left:3px solid var(--primary)}.session-row-clickable.row-selected:hover{background:#3b82f626!important}.status-dropdown{position:relative;display:inline-block;z-index:1}.status-cell,.table-striped tbody,.table-striped tbody td{position:relative;overflow:visible}.status-badge{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius);border:none;cursor:default;font-size:var(--font-size-sm);font-weight:500;display:inline-flex;align-items:center;gap:var(--spacing-1);position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.status-badge.badge-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.25);color:#047857}.status-badge.badge-danger{background:#f43f5e1f;border:1px solid rgba(244,63,94,.25);color:#b91c1c}.status-badge.badge-purple{background:#a855f71f;border:1px solid rgba(168,85,247,.25);color:#7c3aed}[data-theme=dark] .status-badge.badge-success{background:#22c55e2e;border-color:#22c55e59;color:#34d399}[data-theme=dark] .status-badge.badge-danger{background:#f43f5e2e;border-color:#f43f5e59;color:#f87171}[data-theme=dark] .status-badge.badge-purple{background:#a855f733;border-color:#a855f766;color:#c4b5fd}.status-dropdown-menu,.status-menu-header,.status-option,.status-option:hover,.status-option:active,.status-option .badge,.status-option span:not(.badge),.status-option-active,.status-check{display:none}.sessions-table input[type=checkbox]{cursor:pointer;width:18px;height:18px}.sessions-table th:first-child,.sessions-table td:first-child{text-align:center;width:40px}.status-cell{position:relative}.session-actions-header{width:48px}.session-actions{text-align:right}.session-actions .btn-delete-icon{min-width:32px;min-height:32px}.table-striped tbody tr .row-edit-icon{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:10}.table-striped tbody tr:hover .row-edit-icon{opacity:1;pointer-events:auto}.table-striped tbody tr .row-edit-icon button{padding:var(--spacing-1) var(--spacing-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--muted)}.table-striped tbody tr .row-edit-icon button:hover{background:var(--primary);border-color:var(--primary);color:var(--primary-contrast);transform:scale(1.05)}.table-striped tbody tr .row-delete-icon{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:10}.table-striped tbody tr:hover .row-delete-icon{opacity:1;pointer-events:auto}.table-striped tbody tr .row-delete-icon button{padding:var(--spacing-1) var(--spacing-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--danger);width:32px;height:32px}.table-striped tbody tr .row-delete-icon button:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:scale(1.05)}.table-striped tbody tr .row-delete-icon button svg{width:16px;height:16px}.link-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--primary);transition:all .2s ease;padding:var(--spacing-1);border-radius:var(--radius)}.link-icon:hover{background:var(--bg);color:var(--primary);transform:scale(1.1)}.link-icon svg{width:16px;height:16px}.link-actions{display:flex;align-items:center;gap:var(--spacing-2)}.link-actions .btn-icon{width:32px;height:32px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);transition:all .2s ease}.link-actions .btn-icon:hover{background:var(--bg-muted);color:var(--primary)}.table-striped tbody tr.selected{background:#2563eb1a;border-left:3px solid var(--primary)}.table-striped tbody tr:nth-child(2n){background:var(--bg)}.table-striped tbody tr:nth-child(2n).selected{background:#2563eb1a}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-success{background:var(--success);color:#fff;font-weight:500}.badge-warning{background:var(--warning);color:#fff}.badge-danger{background:var(--danger);color:#fff}.badge-purple{background:#9333ea;color:#fff}[data-theme=dark] .badge-purple{background:#a855f7;color:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}body.home-landing-mode .modal-backdrop{background:#0009;z-index:10000}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);border-bottom:1px solid var(--border)}.modal-body{padding:var(--spacing-4)}.form-group,.form-group-enhanced{margin-bottom:var(--spacing-4)}label{display:block;margin-bottom:var(--spacing-2);font-size:.875rem;font-weight:500;color:var(--muted)}input,select,textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.875rem;transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{box-shadow:0 0 0 3px #3b82f633}@media (max-width: 768px){.layout{flex-direction:column}.sidebar{width:100%;min-height:auto;flex-direction:row;overflow-x:auto;padding:var(--spacing-2)}.sidebar .brand{margin-bottom:0;margin-right:var(--spacing-4);padding-bottom:0;border-bottom:none;border-right:1px solid rgba(0,0,0,.1);padding-right:var(--spacing-4)}.sidebar .tabs{flex-direction:row;gap:var(--spacing-2)}.sidebar .tab{white-space:nowrap;margin-bottom:0}.sidebar .actions{margin-top:0;margin-left:auto}}.breadcrumb{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);font-size:.875rem}.breadcrumb-item a{color:var(--muted);text-decoration:none}.breadcrumb-item a:hover{color:var(--primary)}.breadcrumb-current{color:var(--text);font-weight:500}.breadcrumb-separator{color:var(--muted)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);min-height:200px;gap:var(--spacing-3)}.spinner{width:40px;height:40px;border:4px solid var(--bg);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;position:relative}.spinner:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:4px solid transparent;border-top-color:var(--primary);border-radius:50%;opacity:.3;animation:spin 1.2s linear infinite reverse}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;color:var(--primary-contrast)}.btn-outline.btn-loading:after{color:var(--primary)}.skeleton{background:linear-gradient(90deg,var(--bg) 0%,rgba(255,255,255,.4) 50%,var(--bg) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius)}[data-theme=dark] .skeleton{background:linear-gradient(90deg,var(--surface) 0%,rgba(255,255,255,.05) 50%,var(--surface) 100%);background-size:200% 100%}.skeleton-text{height:1em;margin-bottom:var(--spacing-2)}.skeleton-text:last-child{margin-bottom:0}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.skeleton-card{padding:var(--spacing-4);border-radius:var(--radius-lg);border:1px solid var(--border)}.skeleton-table-row{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);align-items:center}.skeleton-table-row .skeleton-text{flex:1;margin:0}.skeleton-table-row .skeleton-avatar{flex-shrink:0}.data-loading-indicator{margin-bottom:var(--spacing-4)}.loading-badge{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background:var(--primary);color:var(--primary-contrast);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow)}.loading-spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.data-sync-badge{position:fixed;top:80px;right:20px;background:var(--primary);color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;z-index:1000;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--spacing-2);transition:opacity .3s ease}.data-sync-badge .sync-icon{animation:spin 1s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}[data-theme=dark] .data-sync-badge{background:var(--primary);box-shadow:0 4px 12px #0000004d}@media (max-width: 768px){.data-sync-badge{top:60px;right:10px;font-size:11px;padding:6px 12px}}.form-control.error{border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a}.form-control.success{border-color:var(--success);box-shadow:0 0 0 3px #10b9811a}.form-error{display:flex;align-items:center;gap:var(--spacing-1);color:var(--danger);font-size:var(--font-size-xs);margin-top:var(--spacing-1);font-weight:500}.form-error:before{content:"⚠";font-size:14px}.form-success{display:flex;align-items:center;gap:var(--spacing-1);color:var(--success);font-size:var(--font-size-xs);margin-top:var(--spacing-1);font-weight:500}.form-success:before{content:"✓";font-size:14px}.form-hint{display:flex;align-items:flex-start;gap:var(--spacing-1);font-size:var(--font-size-xs);color:var(--muted);margin-top:var(--spacing-1);line-height:1.5}.toast-container{position:fixed;top:var(--spacing-4);right:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-2);z-index:10001;max-width:400px;width:calc(100% - var(--spacing-8));pointer-events:none}@media (max-width: 640px){.toast-container{top:var(--spacing-2);right:var(--spacing-2);left:var(--spacing-2);width:auto;max-width:none}}.toast{background:var(--surface);color:var(--text);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;font-size:var(--font-size-sm);animation:toastSlideIn .4s cubic-bezier(.16,1,.3,1);border-left:4px solid var(--primary);display:flex;align-items:flex-start;gap:var(--spacing-2);position:relative;overflow:hidden;pointer-events:auto}.toast:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);transform:scaleX(0);transform-origin:left;animation:toastProgress 3s linear forwards}.toast.success{border-left-color:var(--success)}.toast.success:before{background:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.error:before{background:var(--danger)}.toast.warning{border-left-color:var(--warning)}.toast.warning:before{background:var(--warning)}.toast.info{border-left-color:var(--primary)}.toast-icon{flex-shrink:0;width:20px;height:20px;margin-top:2px}.toast-content{flex:1;min-width:0}.toast-close{flex-shrink:0;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-sm);transition:all .2s ease;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toast-close:hover{background:var(--bg);color:var(--text)}@keyframes toastSlideIn{0%{transform:translate(calc(100% + var(--spacing-4))) translateY(-20px);opacity:0}to{transform:translate(0) translateY(0);opacity:1}}@keyframes toastProgress{to{transform:scaleX(1)}}.toast.exiting{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideOut{0%{transform:translate(0) translateY(0);opacity:1}to{transform:translate(calc(100% + var(--spacing-4))) translateY(-20px);opacity:0}}mark{background:#fef08a;padding:2px 4px;border-radius:2px}.teachers-page{--teacher-primary: var(--secondary, #9333ea)}.class-detail-inline{border:1px solid var(--border);border-left:3px solid var(--primary)}.class-edit-icon{opacity:.6;transition:opacity .2s ease,transform .2s ease;padding:var(--spacing-1);background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.class-edit-icon:hover{opacity:1;transform:scale(1.1);color:var(--primary)}.teachers-page .btn-primary{background:var(--secondary);color:var(--primary-contrast)}.teachers-page .btn-primary:hover{background:var(--secondary);opacity:.9}.teachers-page .btn{border-color:#9333ea1a}.teachers-page .btn-sm{padding:6px 8px;font-size:.8125rem}.teachers-page .badge-teacher{background:var(--secondary);color:#fff}.collapsible-section{border-radius:var(--radius-lg)}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color .2s ease-in-out;border-radius:var(--radius-lg)}.section-header:hover{background:var(--bg)}.section-header h3{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--text)}.section-header-main{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer}.section-actions{display:flex;align-items:center;gap:var(--spacing-2)}.toggle-icon{font-size:var(--font-size-sm);color:var(--muted);transition:transform .3s ease-in-out,color .2s ease-in-out;-webkit-user-select:none;-moz-user-select:none;user-select:none}.section-header:hover .toggle-icon{color:var(--primary)}.section-content{padding:var(--spacing-4);overflow:visible;transition:max-height .3s ease-in-out,opacity .3s ease-in-out,padding .3s ease-in-out;max-height:5000px;opacity:1}.section-content[style*="max-height: 0"]{padding-top:0;padding-bottom:0;opacity:0;overflow:hidden}.space-y-3>*+*{margin-top:var(--spacing-3)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4)}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-2);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--border)}.add-to-topic-form .topic-selection-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.add-to-topic-form .topic-selection-list::-webkit-scrollbar{width:6px}.add-to-topic-form .topic-selection-list::-webkit-scrollbar-track{background:transparent}.add-to-topic-form .topic-selection-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.add-to-topic-form .topic-selection-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}.topic-option-item{-webkit-user-select:none;-moz-user-select:none;user-select:none}.topic-option-item:hover{background:var(--bg)!important;border-color:var(--primary)!important;transform:translate(2px);box-shadow:0 2px 8px #3b82f61a}.topic-option-item .topic-checkbox:checked+.custom-checkbox{background:var(--primary);border-color:var(--primary)}.topic-option-item .topic-checkbox:checked+.custom-checkbox svg{display:block}.topic-option-item .topic-checkbox:checked~div{color:var(--primary)}.topic-option-item .topic-checkbox:checked~div svg{color:var(--primary)}.topic-option-item .custom-checkbox{position:relative}.topic-option-item .custom-checkbox:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-sm);background:#3b82f61a;opacity:0;transition:opacity .2s ease}.topic-option-item:hover .custom-checkbox:after{opacity:1}.topic-option-item .topic-checkbox:focus+.custom-checkbox{outline:2px solid var(--primary);outline-offset:2px}.exercise-detail-modal{max-width:100%}.exercise-detail-modal .detail-info-item{padding:var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);transition:all .2s ease}.exercise-detail-modal .detail-info-item:hover{border-color:var(--border-hover);box-shadow:0 2px 8px #0000000d}.exercise-detail-modal .detail-section{padding:var(--spacing-4);background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border)}[data-theme=dark] .exercise-detail-modal .detail-info-item,[data-theme=dark] .exercise-detail-modal .detail-section{background:var(--surface-dark);border-color:var(--border-dark)}@media (max-width: 768px){.exercise-detail-modal .detail-info-item{padding:var(--spacing-2)}.exercise-detail-modal .detail-section{padding:var(--spacing-3)}}.tag-select-container{position:relative}.tag-input-wrapper{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:42px;cursor:text;transition:all .2s ease}.tag-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .tag-input-wrapper{background:var(--surface-dark);border-color:var(--border-dark)}.tag-search-input{flex:1;min-width:120px;border:none;outline:none;background:transparent;padding:0;font-size:var(--font-size-sm);color:var(--text)}.tag-search-input::-moz-placeholder{color:var(--muted);opacity:.6}.tag-search-input::placeholder{color:var(--muted);opacity:.6}.tag-dropdown{scrollbar-width:thin;scrollbar-color:var(--border) transparent;animation:slideDown .2s ease;max-height:400px;overflow-y:auto}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tag-level-group{border-bottom:2px solid var(--border)}.tag-level-group:last-child{border-bottom:none}.tag-level-header{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tag-dropdown-empty{animation:fadeIn .3s ease}.tag-suggestion-chip{animation:fadeIn .2s ease}.tag-suggestion-chip:hover{box-shadow:0 2px 8px #3b82f633}.tag-dropdown::-webkit-scrollbar{width:6px}.tag-dropdown::-webkit-scrollbar-track{background:transparent}.tag-dropdown::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.tag-dropdown::-webkit-scrollbar-thumb:hover{background:var(--muted)}.tag-dropdown-item{transition:all .2s ease}.tag-dropdown-item:hover{background:var(--bg)!important}.tag-dropdown-item:last-child{border-bottom:none!important}.selected-tags-container{display:flex;flex-wrap:wrap;gap:var(--spacing-1);flex:1}.tag-badge-selected{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;font-size:var(--font-size-xs);background:linear-gradient(135deg,var(--primary) 0%,rgba(59,130,246,.9) 100%);color:#fff;border-radius:var(--radius);cursor:pointer;transition:all .2s ease;font-weight:500;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden}.tag-badge-selected:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.tag-badge-selected:hover:before{left:100%}.tag-badge-selected:hover{background:linear-gradient(135deg,var(--danger) 0%,rgba(244,63,94,.9) 100%);transform:scale(1.05);box-shadow:0 2px 8px #f43f5e4d}.tag-badge-selected svg{flex-shrink:0;transition:transform .2s ease}.tag-badge-selected:hover svg{transform:rotate(90deg)}.tag-count-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;font-size:var(--font-size-xs);background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:500;animation:fadeIn .2s ease}[data-theme=dark] .tag-badge-selected{box-shadow:0 1px 3px #0000004d}@media (max-width: 768px){.tag-badge-selected{font-size:11px;padding:5px 8px}.tag-dropdown{max-height:300px}.tag-level-group{font-size:var(--font-size-xs)}}.table-checkbox{cursor:pointer;width:18px;height:18px;accent-color:var(--primary);transition:all .2s ease}.table-checkbox:hover{transform:scale(1.1)}.table-checkbox:checked{box-shadow:0 0 0 3px #3b82f61a}.bulk-actions{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.bulk-actions .selected-count{font-size:var(--font-size-sm);color:var(--muted);font-weight:500;padding-right:var(--spacing-2);border-right:1px solid var(--border)}.bulk-actions button{transition:all .2s ease}.bulk-actions button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.table-striped tbody tr:hover{background:var(--bg)}.table-striped tbody tr:has(.table-checkbox:checked){background:#3b82f60d;border-left:3px solid var(--primary)}.table-striped tbody tr:has(.table-checkbox:checked):hover{background:#3b82f61a}#outputsTable{table-layout:fixed;width:100%}#outputsTable th,#outputsTable td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#outputsTable td:has(strong){white-space:normal;word-break:break-word}#outputsTable td:has(.badge){white-space:normal}.btn-delete-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--danger);cursor:pointer;transition:all .2s ease;border-radius:var(--radius);opacity:.7}.btn-delete-icon:hover{background:#ef44441a;opacity:1;transform:scale(1.1)}.btn-delete-icon:active{transform:scale(.95)}[data-status]{transition:all .2s ease}[data-status]:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.badge-muted{background:var(--bg);color:var(--muted);border:1px solid var(--border)}.modal-backdrop{animation:fadeIn .2s ease-in-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal{animation:modalSlideUp .3s cubic-bezier(.16,1,.3,1);transform-origin:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-backdrop.exiting{animation:fadeOut .2s ease-in-out forwards}.modal.exiting{animation:modalSlideDown .2s ease-in-out forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(20px) scale(.95)}}.form-control{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);transition:all .2s ease-in-out}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .form-control:focus{box-shadow:0 0 0 3px #60a5fa33}.staff-form-enhanced{max-width:100%}.form-section{margin-bottom:var(--spacing-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s ease}.form-section:hover{box-shadow:var(--shadow-sm);border-color:var(--primary)}.form-section-header{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-5);background:linear-gradient(180deg,#3b82f60d,#3b82f605);border-bottom:1px solid var(--border)}.form-section-header h3{margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--text)}.form-section-content{padding:var(--spacing-5)}.form-group-enhanced:last-child{margin-bottom:0}.form-label-with-icon{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);font-weight:600;color:var(--text)}.form-control-enhanced{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);transition:all .2s ease-in-out;box-sizing:border-box}.form-control-enhanced:disabled{background:var(--bg);color:var(--muted);cursor:not-allowed;opacity:.7}.form-row-enhanced{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.form-hint{display:block;margin-top:var(--spacing-1);font-size:var(--font-size-xs);color:var(--muted);line-height:1.4}.password-toggle-btn-enhanced{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:var(--spacing-1);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s ease;border-radius:var(--radius-sm);z-index:10}.password-eye-icon,.password-eye-off-icon{width:18px;height:18px;flex-shrink:0}.role-checkbox-label input[type=checkbox]{display:none}.role-checkbox-custom{width:20px;height:20px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);position:relative;flex-shrink:0;transition:all .2s ease}.role-checkbox-label:hover .role-checkbox-custom{border-color:var(--primary)}.role-checkbox-label input[type=checkbox]:checked+.role-checkbox-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);width:5px;height:10px;border:solid white;border-width:0 2px 2px 0}.role-checkbox-text{font-size:var(--font-size-sm);font-weight:500;color:var(--text);flex:1}.role-checkbox-label input[type=checkbox]:checked~.role-checkbox-text{color:var(--primary);font-weight:600}.form-actions-enhanced{display:flex;justify-content:flex-end;gap:var(--spacing-3);padding-top:var(--spacing-5);margin-top:var(--spacing-5);border-top:1px solid var(--border)}.form-actions-enhanced .btn{min-width:120px;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2)}@media (max-width: 768px){.form-row-enhanced{grid-template-columns:1fr;gap:var(--spacing-3)}.form-section-content{padding:var(--spacing-4)}.form-section-header{padding:var(--spacing-3) var(--spacing-4)}.form-actions-enhanced{flex-direction:column-reverse}.form-actions-enhanced .btn{width:100%}}.currency-input{font-variant-numeric:tabular-nums;letter-spacing:.02em}.currency-input-invalid{border-color:var(--danger);box-shadow:0 0 0 2px #ef444426}.currency-hint{color:var(--muted);font-size:var(--font-size-xs);margin-top:var(--spacing-1)}.currency-hint-line{line-height:1.4}.currency-hint-line+.currency-hint-line{margin-top:2px}.currency-hint-error{color:var(--danger);margin-top:4px;font-weight:500}.session-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.session-month-nav{display:inline-flex;align-items:center;gap:8px;justify-content:center;flex:1;position:relative}.session-month-btn{padding:4px 8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:var(--font-size-sm);color:var(--text);min-width:32px;display:inline-flex;align-items:center;justify-content:center}.session-month-btn:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.session-month-label-btn{border:none;background:transparent;cursor:pointer;padding:4px 8px;border-radius:var(--radius);display:inline-flex;align-items:center;justify-content:center}.session-month-label-btn:hover{background:var(--bg)}.session-month-label{font-weight:500;font-size:var(--font-size-sm);white-space:nowrap}.session-month-popup{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:6px 8px 8px;z-index:30;min-width:200px}.session-month-popup-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;font-size:var(--font-size-xs)}.session-month-year-btn{border:none;background:transparent;cursor:pointer;padding:2px 4px;border-radius:var(--radius)}.session-month-year-btn:hover{background:var(--bg)}.session-month-year-label{font-weight:500}.session-month-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}.session-month-cell{border-radius:var(--radius);border:1px solid transparent;background:transparent;cursor:pointer;padding:3px 0;font-size:var(--font-size-xs)}.session-month-cell:hover{background:var(--bg)}.session-month-cell.active{border-color:var(--primary);background:#3b82f61a;color:var(--primary)}.session-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .2s ease-in-out}.session-icon-btn:hover{color:var(--primary);border-color:var(--primary);background:#3b82f614}.session-icon-btn.session-icon-btn-primary{background:var(--primary);border-color:var(--primary);color:var(--primary-contrast)}.session-icon-btn.session-icon-btn-primary:hover{filter:brightness(.95);color:var(--primary-contrast)}.session-time-row{display:flex;align-items:center;gap:12px}.session-time-field{flex:1;display:flex;align-items:center;gap:8px;cursor:pointer}.session-time-label{font-size:13px;color:var(--muted);white-space:nowrap;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.session-time-field .form-control{flex:1;min-width:0;cursor:pointer}.date-picker-container{cursor:pointer}.date-picker-container label{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.date-picker-clickable,input[type=date].date-picker-clickable{cursor:pointer!important}.date-picker-clickable:focus,input[type=date].date-picker-clickable:focus{outline:2px solid var(--primary);outline-offset:2px;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb, 59, 130, 246),.1)}.time-picker-container{cursor:pointer}.time-picker-clickable,input[type=time].time-picker-clickable{cursor:pointer!important}.time-picker-clickable:focus,input[type=time].time-picker-clickable:focus{outline:2px solid var(--primary);outline-offset:2px;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb, 59, 130, 246),.1)}@media (max-width: 768px){.date-picker-clickable,.time-picker-clickable{min-height:44px;padding:var(--spacing-2) var(--spacing-3)}.date-picker-container label,.session-time-label{font-size:var(--font-size-sm);margin-bottom:var(--spacing-1)}}.session-time-separator{font-size:18px;color:var(--muted)}.stacked-list{display:grid;gap:8px}.stacked-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--divider);border-radius:10px;background:var(--surface);transition:border-color .2s ease,box-shadow .2s ease}.stacked-list-item:hover{border-color:var(--primary);box-shadow:0 4px 12px #3b82f61f}.stacked-list-item .btn-delete-icon{opacity:.8}.stacked-list-item .btn-delete-icon:hover{opacity:1}.search-dropdown{position:relative;margin-top:6px;display:none}.search-dropdown.visible{display:block}.search-dropdown:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;background:var(--surface);border:1px solid var(--divider);box-shadow:0 10px 30px #0f172a1f}.search-dropdown .search-item,.search-dropdown .search-empty{position:relative;z-index:1;display:block;width:100%;text-align:left;padding:10px 12px;border:none;background:transparent;cursor:pointer;font-size:14px;color:var(--text)}.search-dropdown .search-item+.search-item{border-top:1px solid rgba(148,163,184,.15)}.search-dropdown .search-item:hover{background:#3b82f614;color:var(--primary)}.search-dropdown .search-empty{cursor:default;color:var(--muted)}.search-item-title{font-weight:600}.search-item-sub{display:block;margin-top:2px}.session-time-header{min-width:160px;width:160px}.session-notes-header{min-width:300px;width:auto}.session-info-header{min-width:200px;width:200px}.session-time-cell{vertical-align:middle!important;padding:var(--spacing-3) var(--spacing-4)!important;min-width:160px;width:160px;text-align:center}.session-time-cell>div{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.session-notes-cell{vertical-align:middle!important;padding:var(--spacing-3) var(--spacing-4)!important;min-width:300px;max-width:none;width:auto;text-align:left}.session-notes-cell span,.session-notes-cell div{display:block;white-space:pre-wrap;word-wrap:break-word;line-height:1.6;font-size:var(--font-size-sm);text-align:left}.session-info-cell{vertical-align:middle!important;padding:var(--spacing-3) var(--spacing-4)!important;min-width:200px;width:200px;text-align:center}.session-info-cell>div{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-1)}.sessions-table{border-collapse:collapse;width:100%;table-layout:auto}.sessions-table tbody tr{height:auto}.sessions-table tbody td{vertical-align:middle;padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--border);box-sizing:border-box;position:relative;height:auto;min-height:48px}.sessions-table tbody tr:last-child td{border-bottom:none}.sessions-table thead th{vertical-align:middle;padding:var(--spacing-3) var(--spacing-4);border-bottom:2px solid var(--border);box-sizing:border-box;position:relative}.session-meta-cell{display:flex;align-items:center;gap:var(--spacing-2);vertical-align:top;padding:var(--spacing-3) var(--spacing-4)!important;box-sizing:border-box;border-bottom:1px solid var(--border)!important;position:relative;height:auto;min-height:48px}.sessions-table tbody tr td.session-meta-cell{border-bottom:1px solid var(--border)!important;padding:var(--spacing-3) var(--spacing-4)!important;vertical-align:top!important}.sessions-table tbody tr:last-child td.session-meta-cell{border-bottom:none!important}.sessions-table tbody tr{display:table-row}.sessions-table tbody tr td{display:table-cell}.sessions-table tbody tr td,.sessions-table tbody tr td.session-meta-cell,.sessions-table tbody tr td.session-notes-cell,.sessions-table tbody tr td.status-cell{border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:var(--border)}.sessions-table tbody tr:last-child td,.sessions-table tbody tr:last-child td.session-meta-cell,.sessions-table tbody tr:last-child td.session-notes-cell,.sessions-table tbody tr:last-child td.status-cell{border-bottom:none}.session-meta-icon{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--bg);color:var(--muted);font-size:var(--font-size-xs);font-weight:500}.session-meta-icon svg{width:14px;height:14px}.session-allowance-preview{font-weight:600}.teacher-actions-menu{position:relative;display:inline-block}.menu-trigger{background:transparent;border:none;padding:var(--spacing-1);cursor:pointer;color:var(--muted);transition:color .2s ease-in-out;display:flex;align-items:center;justify-content:center}.menu-trigger:hover{color:var(--text)}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);min-width:140px;z-index:1000;overflow:hidden}.menu-item{width:100%;padding:var(--spacing-2) var(--spacing-3);background:transparent;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-2);color:var(--text);font-size:var(--font-size-sm);transition:background-color .2s ease-in-out}.menu-item:hover{background:var(--bg)}.menu-item-danger{color:var(--danger)}.menu-item-danger:hover{background:var(--danger);color:var(--danger-contrast)}.menu-item svg{flex-shrink:0}.teacher-row-clickable{cursor:pointer;transition:background-color .2s ease-in-out,transform .1s ease-in-out,box-shadow .2s ease-in-out;position:relative}.teacher-row-clickable:hover{background:var(--bg)!important;transform:translate(2px);box-shadow:0 1px 3px #0000000d}.teacher-row-clickable:active{transform:translate(0);background:var(--surface)!important;box-shadow:none}.teacher-row-clickable td{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.teacher-row-clickable .teacher-actions-menu,.teacher-row-clickable .teacher-actions-menu *{pointer-events:all;cursor:default}@media (hover: none){.teacher-row-clickable:active{background:var(--bg)!important}}.teacher-class-row{transition:background-color .2s ease-in-out,transform .1s ease-in-out}.teacher-class-row:hover{background:var(--bg)!important;transform:translate(2px)}.teacher-class-row:active{transform:translate(0);background:var(--surface)!important}.btn-allowance-edit:hover{background:var(--primary)!important;color:var(--primary-contrast)!important}.class-status-badge{font-size:var(--font-size-xs);font-weight:600;margin-left:var(--spacing-2);padding:2px 6px;border-radius:var(--radius-sm)}.class-status-active{color:#059669;background:#0596691a}.class-status-inactive{color:#dc2626;background:#dc26261a}[data-theme=dark] .class-status-active{color:#34d399;background:#34d39926}[data-theme=dark] .class-status-inactive{color:#f87171;background:#f8717126}.teacher-class-row.class-inactive{opacity:.7}.teacher-class-row.class-inactive:hover{background:var(--bg)!important;transform:none}.qr-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;transition:all .2s ease-in-out;flex-shrink:0}.qr-icon-btn-large{width:40px;height:40px;border-radius:var(--radius);box-shadow:0 1px 2px #0000000d}.qr-icon-btn:hover{background:var(--surface);border-color:var(--primary);color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.qr-icon-btn:active{transform:translateY(0)}.qr-icon-btn-active{color:var(--primary);border-color:var(--primary);background:rgba(var(--primary-rgb, 0, 122, 255),.1)}.qr-icon-btn-active:hover{background:var(--primary);color:var(--primary-contrast);box-shadow:0 2px 8px rgba(var(--primary-rgb, 0, 122, 255),.3)}.qr-icon-btn-inactive{opacity:.5;cursor:not-allowed!important}.qr-icon-btn-inactive:hover{background:var(--bg);border-color:var(--border);color:var(--text);transform:none;box-shadow:none}.qr-icon-btn-upload{color:var(--muted)}.qr-icon-btn-upload:hover{background:var(--surface);border-color:var(--primary);color:var(--primary)}.qr-link-form{max-width:500px}.account-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;transition:all .2s ease-in-out;flex-shrink:0}.account-icon-btn:hover{background:var(--surface);border-color:var(--primary);color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.account-icon-btn:active{transform:translateY(0)}.account-icon-btn-left{width:36px;height:36px;margin-right:var(--spacing-1)}.account-icon-btn-left svg{width:18px;height:18px}.teacher-info-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2000;opacity:0;transition:opacity .3s ease-in-out;pointer-events:none}.teacher-info-backdrop.active{opacity:1;pointer-events:all}[data-theme=dark] .teacher-info-backdrop{background:#000000b3}.teacher-info-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:500px;background:var(--bg);box-shadow:-2px 0 8px #0000001a;z-index:2001;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease-in-out;overflow-y:auto}.teacher-info-panel.active{transform:translate(0)}.teacher-info-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:10}.teacher-info-header h3{margin:0;font-size:var(--font-size-lg);font-weight:600}.btn-icon-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--text);cursor:pointer;transition:all .2s ease-in-out}.btn-icon-close:hover{background:var(--surface);color:var(--primary)}.teacher-info-content{padding:var(--spacing-4);flex:1}.teacher-info-view .info-item{margin-bottom:var(--spacing-4);padding:var(--spacing-3);background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);transition:all .2s ease}.teacher-info-view .info-item:hover{border-color:var(--primary);box-shadow:0 2px 4px #3b82f61a}.teacher-info-view .info-item label{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);font-weight:600;color:var(--muted);margin-bottom:var(--spacing-2);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.teacher-info-view .info-item .info-value{font-size:var(--font-size-base);color:var(--text);word-break:break-word;font-weight:500;line-height:1.6}.teacher-info-view .info-item .qr-link{color:var(--primary);text-decoration:none;word-break:break-all}.teacher-info-view .info-item .qr-link:hover{text-decoration:underline}.info-actions{margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:2px solid var(--border);position:sticky;bottom:0;background:var(--bg);padding-bottom:var(--spacing-4)}.info-actions .btn{width:100%;min-height:44px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);transition:all .2s ease}.info-actions .btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.teacher-info-edit .form-group{margin-bottom:var(--spacing-4)}.teacher-info-edit .form-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--border)}@media (max-width: 768px){.teacher-info-panel{max-width:100%}.account-icon-btn,.account-icon-btn-left{width:32px;height:32px}.account-icon-btn svg,.account-icon-btn-left svg{width:16px;height:16px}.qr-icon-btn{width:28px;height:28px}.qr-icon-btn-large{width:36px;height:36px}.qr-icon-btn svg{width:16px;height:16px}.qr-icon-btn-large svg{width:18px;height:18px}}.pagination-container{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-2);padding:var(--spacing-2) 0}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;transition:all .2s ease-in-out;flex-shrink:0}.pagination-btn:hover:not(:disabled){background:var(--surface);border-color:var(--primary);color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.pagination-btn:active:not(:disabled){transform:translateY(0)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--bg);border-color:var(--border);color:var(--muted)}.pagination-page-number{font-size:var(--font-size-base);font-weight:600;color:var(--text);min-width:24px;text-align:center;padding:0 var(--spacing-2)}.pagination-page-info{display:flex;align-items:center;gap:4px;font-size:var(--font-size-base);font-weight:500;color:var(--text);padding:0 var(--spacing-2)}.pagination-current{font-weight:600;color:var(--primary)}.pagination-separator{color:var(--muted);margin:0 2px}.pagination-total{color:var(--muted)}@media (max-width: 768px){.pagination-btn{width:28px;height:28px}.pagination-btn svg{width:14px;height:14px}.pagination-page-number{font-size:var(--font-size-sm)}}input[type=date].date-input,input.date-input[type=date]{cursor:pointer;position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}input[type=date].date-input::-webkit-calendar-picker-indicator,input.date-input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:1;position:absolute;right:var(--spacing-2);width:20px;height:20px;padding:0;margin:0}input[type=date].date-input:hover,input.date-input[type=date]:hover{border-color:var(--primary)}input[type=date].date-input:focus,input.date-input[type=date]:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] input[type=date].date-input:focus,[data-theme=dark] input.date-input[type=date]:focus{box-shadow:0 0 0 3px #60a5fa33}select[multiple]{min-height:120px;padding:var(--spacing-2)}select[multiple] option{padding:var(--spacing-2);border-radius:var(--radius-sm);margin:var(--spacing-1) 0}select[multiple] option:checked{background:var(--primary);color:var(--primary-contrast)}.attendance-checkbox{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.attendance-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.attendance-status{font-size:var(--font-size-sm);font-weight:500;transition:color .2s ease-in-out}.attendance-icon-btn{background:none;border:none;cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius);transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.attendance-icon-btn:hover{background:var(--surface-hover);transform:scale(1.1)}.attendance-icon-btn:active{transform:scale(.95)}.attendance-icon-btn.present{color:var(--success)}.attendance-icon-btn.absent{color:var(--danger)}@media (max-width: 768px){.attendance-icon-btn{width:40px;height:40px;padding:var(--spacing-2)}.attendance-icon-btn svg{width:24px;height:24px}}.text-success{color:var(--success);font-weight:500}.text-danger{color:var(--danger);font-weight:500}#attendanceTableBody tr{transition:background-color .15s ease-in-out}#attendanceTableBody tr:hover{background:var(--bg)}#attendanceTableBody td{padding:var(--spacing-2);border-bottom:1px solid var(--border)}#attendanceTableBody th{padding:var(--spacing-2);font-size:var(--font-size-xs);font-weight:600;color:var(--muted);background:var(--bg)}.teacher-card{position:relative}.teacher-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.teacher-list-basic .teacher-row{grid-template-columns:1fr;gap:var(--spacing-1)}.teacher-list-basic .teacher-col-info{color:var(--muted);font-size:var(--font-size-sm)}.teacher-row{display:grid;grid-template-columns:1fr 140px 160px;gap:var(--spacing-3);align-items:center;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius);transition:background-color .2s ease-in-out;cursor:pointer}.teacher-row:hover{background:var(--bg)}.teacher-row-header{cursor:default;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding-top:0;padding-bottom:var(--spacing-1);background:transparent}.teacher-row-header:hover{background:transparent}.teacher-name-link{color:var(--primary);text-decoration:none;transition:color .2s ease-in-out,-webkit-text-decoration .2s ease-in-out;transition:color .2s ease-in-out,text-decoration .2s ease-in-out;transition:color .2s ease-in-out,text-decoration .2s ease-in-out,-webkit-text-decoration .2s ease-in-out}.teacher-name-link:hover{color:var(--primary-hover);text-decoration:underline}.teacher-allowance{background:transparent;border:1px solid var(--border);border-radius:var(--radius);padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-sm);color:var(--primary);cursor:pointer;transition:all .2s ease-in-out;justify-self:start;text-align:left;width:100%;max-width:120px}.teacher-allowance:hover{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.teacher-col-allowance,.teacher-row-header .teacher-col-allowance{text-align:left}.teacher-col-total{justify-self:end;font-weight:500;text-align:right}.teacher-row-header .teacher-col-total{text-align:right}.teacher-col-name{font-weight:500}.teacher-row-header .teacher-col-name,.teacher-row-header .teacher-col-allowance,.teacher-row-header .teacher-col-total{font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-3)}.stat-item{border:1px solid var(--border);border-radius:var(--radius);padding:var(--spacing-3);background:var(--surface);display:flex;flex-direction:column;gap:var(--spacing-1)}.stat-label{font-size:var(--font-size-sm);color:var(--muted)}.stat-value{font-size:var(--font-size-lg);font-weight:600;color:var(--text)}.teacher-row-header .teacher-col-allowance,.teacher-row-header .teacher-col-total{font-weight:600}.schedule-card{position:relative}.schedule-card:hover .schedule-edit-btn{opacity:1!important}@media (max-width: 768px){.modal-backdrop{padding:0}.modal.modal-mobile-fullscreen{max-width:100%;max-height:100vh;border-radius:0;height:100vh;display:flex;flex-direction:column}.modal-header{padding:var(--spacing-3);flex-shrink:0}.modal-body{padding:var(--spacing-3);flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal.modal-mobile-fullscreen .modal-body{min-height:0}.form-row{grid-template-columns:1fr}.section-header{padding:var(--spacing-2) var(--spacing-3);flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.section-content{padding:var(--spacing-3)}.section-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:var(--spacing-1)}#attendanceTableBody{font-size:var(--font-size-xs)}.teacher-row{grid-template-columns:1fr;gap:var(--spacing-1);padding:var(--spacing-2)}.teacher-allowance,.teacher-col-total{justify-self:start}.menu-dropdown{right:auto;left:0}}.student-class-row{cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease}.student-class-row-hover,.student-class-row:hover{background:#3b82f614!important;box-shadow:inset 0 0 0 1px #3b82f640}.student-class-link{padding:0;background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer}.student-class-link:hover{text-decoration:underline}.student-class-fee{display:flex;align-items:center;gap:var(--spacing-2)}.student-class-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-1)}.student-class-actions .btn.btn-xs{padding:2px var(--spacing-2);font-size:var(--font-size-xs)}.student-account-icon-btn:hover{background:var(--primary-dark)!important;transform:scale(1.05);box-shadow:0 4px 12px #00000026}.student-info-card:hover{box-shadow:0 4px 16px #00000014!important;transform:translateY(-2px)}.student-account-card .btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.student-class-row:hover{background:var(--bg-hover)!important}.student-class-link:hover{color:var(--primary-dark)!important;text-decoration:underline}.student-classes-table .btn-delete-icon:hover{background:var(--danger)!important;color:#fff!important;transform:scale(1.1)}.student-classes-table .btn.btn-xs:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.student-classes-table .btn.btn-link:hover{color:var(--primary-dark)!important;text-decoration:underline}.student-login-icon-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #f093fb66;opacity:.9}@media (max-width: 768px){.student-detail-header{flex-direction:column!important;gap:var(--spacing-3)!important;align-items:flex-start!important}.student-info-card{min-width:100%!important}.student-classes-table{font-size:.875rem}.student-classes-table th,.student-classes-table td{padding:var(--spacing-2) var(--spacing-2)!important}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);text-align:center;min-height:300px;gap:var(--spacing-4)}.empty-state-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#3b82f61a,#3b82f60d);display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:var(--spacing-2)}.empty-state-icon svg{width:40px;height:40px;opacity:.6}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0}.empty-state-description{font-size:var(--font-size-sm);color:var(--muted);max-width:400px;line-height:1.6;margin:0}.empty-state-action{margin-top:var(--spacing-2)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);text-align:center;min-height:300px;gap:var(--spacing-4)}.error-state-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#ef44441a,#ef44440d);display:flex;align-items:center;justify-content:center;color:var(--danger)}.error-state-icon svg{width:40px;height:40px}.error-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0}.error-state-description{font-size:var(--font-size-sm);color:var(--muted);max-width:400px;line-height:1.6;margin:0}.error-state-action{margin-top:var(--spacing-2)}.success-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);text-align:center;min-height:200px;gap:var(--spacing-4)}.success-state-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#10b9811a,#10b9810d);display:flex;align-items:center;justify-content:center;color:var(--success);animation:successPulse .6s ease-out}.success-state-icon svg{width:32px;height:32px}@keyframes successPulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.success-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0}.success-state-description{font-size:var(--font-size-sm);color:var(--muted);max-width:400px;line-height:1.6;margin:0}.page-transition-enter{opacity:0;transform:translateY(10px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.page-transition-exit{opacity:1;transform:translateY(0)}.page-transition-exit-active{opacity:0;transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--radius-sm)}.btn:focus-visible{outline-offset:3px}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:none;filter:grayscale(.3)}@media (max-width: 768px){.btn{min-height:44px;min-width:44px;padding:var(--spacing-3) var(--spacing-4)}input,select,textarea{min-height:44px;font-size:16px}.tab{min-height:44px;padding:var(--spacing-3) var(--spacing-4)}}@media (hover: none) and (pointer: coarse){.btn:hover:not(:active){transform:none}.table-striped tbody tr:hover{background:transparent;transform:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--primary);color:var(--primary-contrast);padding:var(--spacing-2) var(--spacing-4);text-decoration:none;z-index:1000;border-radius:0 0 var(--radius) 0}.skip-to-main:focus{top:0}.staff-form-enhanced{max-width:100%;animation:formFadeIn .3s ease-out}@keyframes formFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-section{margin-bottom:var(--spacing-6);padding:var(--spacing-5);background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all .3s ease}.form-section:hover{border-color:var(--primary);box-shadow:0 2px 8px #3b82f614}.form-section-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:2px solid var(--border)}.form-section-header svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}.form-section-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.form-section-content{display:flex;flex-direction:column;gap:var(--spacing-4)}.form-group-enhanced{margin-bottom:var(--spacing-4)}.form-label-with-icon{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);font-weight:600;color:var(--text);margin-bottom:var(--spacing-2)}.form-label-with-icon svg{width:16px;height:16px;color:var(--primary);flex-shrink:0}.form-control-enhanced{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:var(--font-size-base);color:var(--text);transition:all .2s ease;min-height:44px;box-sizing:border-box}.form-control-enhanced:hover{border-color:var(--primary)}.form-control-enhanced:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a;background:var(--surface)}.form-control-enhanced::-moz-placeholder{color:var(--muted);opacity:.6}.form-control-enhanced::placeholder{color:var(--muted);opacity:.6}.form-control-enhanced:disabled{background:var(--bg);color:var(--muted);cursor:not-allowed;opacity:.6}.form-row-enhanced{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}@media (max-width: 768px){.form-row-enhanced{grid-template-columns:1fr}.form-section{padding:var(--spacing-4)}}.form-hint{display:block;font-size:var(--font-size-xs);color:var(--muted);margin-top:var(--spacing-1);line-height:1.5}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-control-enhanced{padding-right:48px}.password-toggle-btn-enhanced{position:absolute;right:var(--spacing-2);top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;padding:var(--spacing-2);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .2s ease;border-radius:var(--radius);min-width:36px;min-height:36px;z-index:1}.password-toggle-btn-enhanced:hover{background:var(--bg);color:var(--text)}.password-toggle-btn-enhanced:active{transform:translateY(-50%) scale(.95)}.password-toggle-btn-enhanced svg{width:18px;height:18px;flex-shrink:0}.password-eye-icon,.password-eye-off-icon{transition:opacity .2s ease}.staff-roles-checkboxes-enhanced{display:flex;flex-direction:column;gap:var(--spacing-3);margin-top:var(--spacing-2)}.role-checkbox-label{display:flex;align-items:center;gap:var(--spacing-3);cursor:pointer;padding:var(--spacing-3);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.role-checkbox-label:hover{background:var(--bg);border-color:var(--primary);transform:translate(4px)}.role-checkbox-label input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.role-checkbox-custom{width:20px;height:20px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;position:relative}.role-checkbox-label input[type=checkbox]:checked+.role-checkbox-custom{background:var(--primary);border-color:var(--primary)}.role-checkbox-label input[type=checkbox]:checked+.role-checkbox-custom:after{content:"";position:absolute;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);top:2px}.role-checkbox-label input[type=checkbox]:focus+.role-checkbox-custom{box-shadow:0 0 0 3px #3b82f61a}.role-checkbox-text{font-size:var(--font-size-base);font-weight:500;color:var(--text);flex:1}.role-checkbox-label:hover .role-checkbox-text{color:var(--primary)}.form-actions-enhanced{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:2px solid var(--border)}.form-actions-enhanced .btn{min-height:44px;padding:var(--spacing-3) var(--spacing-5);font-weight:600;display:flex;align-items:center;gap:var(--spacing-2);transition:all .2s ease}.form-actions-enhanced .btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.form-actions-enhanced .btn:active{transform:translateY(0)}.form-actions-enhanced .btn svg{width:18px;height:18px;flex-shrink:0}@media (max-width: 768px){.form-section{padding:var(--spacing-4)}.form-section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.form-actions-enhanced{flex-direction:column-reverse;gap:var(--spacing-2)}.form-actions-enhanced .btn{width:100%;justify-content:center}}.dashboard-page{display:flex;flex-direction:column;gap:var(--spacing-4)}.dashboard-filter-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-3);align-items:flex-end}.dashboard-filter-bar .filter-group{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:220px;flex:1}.dashboard-filter-bar .filter-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4)}.stat-card{background:var(--surface);padding:var(--spacing-4);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--primary)}.stat-card:nth-child(2){border-left-color:var(--secondary)}.stat-card:nth-child(3){border-left-color:var(--success)}.stat-card h3{color:var(--muted);font-size:.875rem;margin-bottom:var(--spacing-2)}.stat-card .value{font-size:1.5rem;font-weight:600}.dashboard-chart-toggle{display:flex;justify-content:flex-end;margin-top:var(--spacing-2)}.chart-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:90}.chart-panel-overlay.visible{opacity:1;pointer-events:auto}.chart-panel{position:fixed;top:50%;left:50%;width:min(520px,92vw);max-height:90vh;background:var(--surface);box-shadow:var(--shadow-lg);border-radius:var(--radius-lg, 16px);transform:translate(-50%,-50%) scale(.96);opacity:0;transition:transform .25s ease,opacity .2s ease;z-index:100;display:flex;flex-direction:column;overflow:hidden}.chart-panel.open{transform:translate(-50%,-50%) scale(1);opacity:1}.chart-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--border)}.chart-panel-body{padding:var(--spacing-3) var(--spacing-4);flex:1;overflow-y:auto}.chart-panel-body .dual-line-chart{min-height:240px}.chart-panel .btn-panel-close{font-size:1.1rem}.chart-shell{min-height:220px;display:flex;align-items:center;justify-content:center;position:relative;padding:var(--spacing-2)}.chart{width:100%;height:auto}.chart text{font-size:.65rem;fill:var(--muted)}.dual-line-chart{width:100%;position:relative}.chart-scroll-wrapper{width:100%;overflow-x:auto}.chart-scroll-wrapper svg{width:100%;min-width:440px}.chart-line-revenue{stroke:var(--primary)}.chart-line-profit{stroke:var(--warning)}.chart-dot{stroke:var(--surface);stroke-width:1.5;fill:var(--primary);cursor:pointer}.chart-dot-profit{fill:var(--warning)}.chart-y-label{font-size:.65rem;fill:var(--muted);text-anchor:start}.chart-x-label{font-size:.6rem;fill:var(--muted)}.chart-inline-legend{display:flex;justify-content:center;gap:var(--spacing-4);margin-top:var(--spacing-2);font-size:.8rem;color:var(--muted)}.chart-inline-legend .legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.legend-revenue{background:var(--primary)}.legend-profit{background:var(--warning)}.chart-tooltip{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--spacing-2);box-shadow:var(--shadow);pointer-events:none;transform:translate(-50%,-120%);opacity:0;transition:opacity .15s ease;font-size:.78rem;min-width:120px}.chart-tooltip.visible{opacity:1}.chart-tooltip .tooltip-title{font-weight:600;margin-bottom:2px}.chart-tooltip .tooltip-value{color:var(--primary);font-weight:600}.chart-tooltip .tooltip-label{font-size:.75rem;color:var(--muted);margin-top:2px}.chart-empty{padding:var(--spacing-4);color:var(--muted);text-align:center}.pie-wrapper{display:flex;gap:var(--spacing-4);align-items:center;justify-content:center;flex-wrap:wrap}.chart-legend{display:flex;flex-direction:column;gap:var(--spacing-2);min-width:180px}.legend-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:.875rem;color:var(--text)}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.dashboard-section-title{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-2)}.dashboard-finance{display:flex;flex-direction:column}.finance-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-3)}.finance-table th,.finance-table td{text-align:left;padding:var(--spacing-2);border-bottom:1px solid var(--border-light, var(--border))}.finance-table tbody tr:last-child td{border-bottom:none}.finance-trend{font-size:.85rem;color:var(--muted)}.dashboard-alerts{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-4)}.alert-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:var(--spacing-4);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-3)}.alert-card h4{margin:0;display:flex;align-items:center;justify-content:space-between;font-size:1rem}.alert-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--spacing-3);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-2)}.alert-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.95rem}.alert-toggle{border:none;background:transparent;font-size:.9rem;cursor:pointer}.alert-link{background:none;border:none;padding:0;font-size:.85rem;color:var(--primary);cursor:pointer}.alert-link:hover{text-decoration:underline}.alert-note{font-size:.75rem;color:var(--warning);margin:var(--spacing-2) 0}.alert-body.collapsed{display:none}.alert-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.alert-list li{border-bottom:1px dashed var(--border-light, var(--border));padding-bottom:var(--spacing-2);font-size:.9rem}.alert-list li:last-child{border-bottom:none;padding-bottom:0}.alert-meta{font-size:.75rem;color:var(--muted);margin-top:var(--spacing-1)}.dashboard-advanced{display:grid;gap:var(--spacing-4)}.widget-toggle-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.widget-toggle-list label{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border:1px dashed var(--border);border-radius:var(--radius);background:var(--bg);font-size:.85rem;cursor:pointer}.widget-toggle-list input{accent-color:var(--primary)}.quickview-tabs{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.quickview-tabs button{border-radius:var(--radius-full);border:1px solid var(--border);padding:var(--spacing-2) var(--spacing-3);background:transparent;color:var(--muted);cursor:pointer;transition:all .2s ease-in-out}.quickview-tabs button.active{background:var(--primary);border-color:var(--primary);color:var(--primary-contrast);box-shadow:var(--shadow-sm)}.quickview-grid{margin-top:var(--spacing-3);display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-3)}.quickview-card{background:var(--surface);border-radius:var(--radius);padding:var(--spacing-3);box-shadow:var(--shadow-sm);border:1px solid var(--border-light, var(--border))}.quickview-card .label{font-size:.8rem;color:var(--muted)}.quickview-card .value{font-size:1.4rem;font-weight:600;margin-top:var(--spacing-1)}.quickview-card .hint{font-size:.75rem;color:var(--muted);margin-top:var(--spacing-1)}.dashboard-quickview{display:flex;flex-direction:column;gap:var(--spacing-3)}.quickview-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.quickview-year-selector{display:flex;align-items:center;gap:var(--spacing-2);font-size:.85rem;color:var(--muted)}.quickview-year-selector select{min-width:110px}.home-page{display:flex;flex-direction:column;gap:var(--spacing-4)}.home-header{display:flex;flex-wrap:wrap;gap:var(--spacing-3);align-items:center;justify-content:space-between}.home-brand{display:flex;gap:var(--spacing-2);align-items:center}.home-brand .logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.home-nav{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.home-nav-link{border:none;background:none;color:var(--muted);font-size:.9rem;cursor:pointer}.home-nav-link.active{color:var(--primary);font-weight:600}.home-account{display:flex;gap:var(--spacing-2);align-items:center;flex-wrap:wrap}.home-auth-buttons{display:flex;gap:var(--spacing-2)}.home-auth-buttons .btn{display:inline-flex;align-items:center;gap:var(--spacing-1)}.home-icon-svg{width:24px;height:24px;color:inherit}.home-brand-icon{color:var(--primary)}.home-tab-icon{display:flex;align-items:center;justify-content:center}.home-hero{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-3)}.home-hero-actions{display:flex;gap:var(--spacing-2)}.home-tabs{display:flex;flex-wrap:wrap;gap:var(--spacing-2);align-items:center}.home-tab{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-full);padding:.4rem .9rem;display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.85rem;color:var(--muted)}.home-tab.active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.home-search{margin-left:auto;flex:1;min-width:180px}.home-search input{width:100%}.home-feed,.home-feed-content{display:flex;flex-direction:column;gap:var(--spacing-3)}.home-post-card{border:1px solid var(--border);border-radius:var(--radius);padding:var(--spacing-3);background:var(--surface);box-shadow:var(--shadow-sm)}.home-post-header{display:flex;justify-content:space-between;gap:var(--spacing-2)}.home-post-meta{font-size:.8rem;color:var(--muted);display:flex;gap:.5rem;flex-wrap:wrap}.home-post-controls{display:flex;align-items:center;gap:var(--spacing-1)}.home-post-indicator{font-size:.8rem;color:var(--muted);cursor:pointer;transition:transform .2s ease}.home-post-card[data-expanded=true] .home-post-indicator{transform:rotate(180deg)}.home-post-body{max-height:0;overflow:hidden;transition:max-height .3s ease}.home-post-card[data-expanded=true] .home-post-body{max-height:1000px;margin-top:var(--spacing-2)}.home-post-badge{background:var(--primary);color:var(--primary-contrast);padding:.1rem .6rem;border-radius:var(--radius-full);font-size:.7rem}.home-post-content{margin:var(--spacing-2) 0;line-height:1.6}.home-post-tags{display:flex;gap:.5rem;font-size:.8rem;color:var(--primary)}.home-post-attachments{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.home-post-actions{display:flex;gap:.25rem}.home-auth-form .form-group{margin-bottom:var(--spacing-3)}.home-post-form textarea,.home-post-form input,.home-post-form select{width:100%}.class-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.class-students{background:var(--bg);padding:var(--spacing-3);margin:var(--spacing-3) 0;border-radius:var(--radius)}.class-detail-page{animation:pageFadeIn .3s ease-out}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.class-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:2px solid var(--border)}.class-detail-header-content{flex:1;min-width:0}.class-detail-title-row{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);flex-wrap:wrap}.class-detail-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--text);margin:0;line-height:1.2;display:flex;align-items:center;gap:var(--spacing-2)}.class-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--muted);line-height:1.6}.class-detail-meta-item{display:flex;align-items:center;gap:var(--spacing-1)}.class-detail-status-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.class-detail-status-badge.running{background:linear-gradient(135deg,#10b98126,#10b98114);color:#059669;border:1px solid rgba(16,185,129,.25)}.class-detail-status-badge.inactive{background:linear-gradient(135deg,#6b728026,#6b728014);color:var(--muted);border:1px solid rgba(107,114,128,.25)}.class-detail-status-badge:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}.class-detail-status-badge.running:before{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.class-detail-header-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-shrink:0}.class-detail-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.class-detail-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-5);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.class-detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,rgba(59,130,246,.5) 100%);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.class-detail-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);transform:translateY(-2px)}.class-detail-card:hover:before{transform:scaleX(1)}.class-detail-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--border)}.class-detail-card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.class-detail-card-title svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}.class-detail-card-actions{display:flex;align-items:center;gap:var(--spacing-2)}.class-detail-empty-state{text-align:center;padding:var(--spacing-6) var(--spacing-4);color:var(--muted)}.class-detail-empty-state-icon{width:64px;height:64px;margin:0 auto var(--spacing-3);opacity:.5}.class-detail-empty-state-icon svg{width:100%;height:100%;color:var(--muted)}.class-detail-loading-state{text-align:center;padding:var(--spacing-6) var(--spacing-4);color:var(--muted)}.class-detail-loading-spinner{width:32px;height:32px;margin:0 auto var(--spacing-3);animation:spin 1s linear infinite}.class-detail-skeleton{padding:var(--spacing-2)}.skeleton-item{background:linear-gradient(90deg,var(--border) 0%,rgba(255,255,255,.1) 50%,var(--border) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius)}.skeleton-line{height:16px;margin-bottom:var(--spacing-2);background:linear-gradient(90deg,var(--bg) 0%,rgba(255,255,255,.4) 50%,var(--bg) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius)}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,var(--surface) 0%,rgba(255,255,255,.05) 50%,var(--surface) 100%);background-size:200% 100%}.skeleton-table{margin-top:var(--spacing-4)}.skeleton-table-header{padding:var(--spacing-3);background:var(--border);border-radius:var(--radius);margin-bottom:var(--spacing-2)}.skeleton-table-row{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);margin-bottom:var(--spacing-2);border-bottom:1px solid var(--border)}.skeleton-table-row:last-child{border-bottom:none}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.class-detail-loading-spinner svg{width:100%;height:100%;color:var(--primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-loading-spinner{display:inline-block;vertical-align:middle}.dashboard-loading-spinner svg{animation:spin 1s linear infinite}.class-detail-schedule-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.class-detail-schedule-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);transition:all .2s ease}.class-detail-schedule-item:hover{background:#3b82f60d;border-color:var(--primary);transform:translate(4px)}.class-detail-schedule-item svg{width:16px;height:16px;color:var(--primary);flex-shrink:0}.class-detail-section{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-4);overflow:hidden;transition:all .3s ease}.class-detail-section:hover{box-shadow:var(--shadow)}.class-detail-section-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(59,130,246,.03) 0%,transparent 100%)}.class-detail-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.class-detail-section-content{padding:var(--spacing-5)}.class-detail-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-3);margin-top:var(--spacing-4)}.class-detail-stat-item{padding:var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);transition:all .2s ease}.class-detail-stat-item:hover{border-color:var(--primary);background:#3b82f608}.class-detail-stat-label{font-size:var(--font-size-xs);color:var(--muted);font-weight:500;margin-bottom:var(--spacing-1);text-transform:uppercase;letter-spacing:.5px}.class-detail-stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text)}.sessions-table tbody tr{transition:all .2s ease}.sessions-table tbody tr:hover{background:#3b82f60d!important;transform:translate(2px)}.sessions-table tbody tr.session-row-clickable:active{transform:translate(0);background:#3b82f614!important}.sessions-table tbody tr:has(.table-checkbox:checked){background:#3b82f61a!important;border-left:3px solid var(--primary)}.sessions-table tbody tr:has(.table-checkbox:checked):hover{background:#3b82f626!important}.session-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);flex-wrap:wrap;gap:var(--spacing-3)}.session-toolbar-actions{display:flex;align-items:center;gap:var(--spacing-2)}.staff-detail-page{animation:pageFadeIn .3s ease-out}.staff-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:2px solid var(--border)}.staff-detail-header-content{flex:1;min-width:0}.staff-detail-title-row{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3);flex-wrap:wrap}.staff-detail-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--text);margin:0;line-height:1.2;display:flex;align-items:center;gap:var(--spacing-2)}.staff-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--muted);line-height:1.6}.staff-detail-meta-item{display:flex;align-items:center;gap:var(--spacing-1)}.staff-detail-header-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-shrink:0}.staff-detail-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.staff-detail-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-5);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.staff-detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,rgba(59,130,246,.5) 100%);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.staff-detail-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);transform:translateY(-2px)}.staff-detail-card:hover:before{transform:scaleX(1)}.staff-detail-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--border)}.staff-detail-card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.staff-detail-card-title svg{width:20px;height:20px;color:var(--primary);flex-shrink:0}.staff-detail-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4);margin-bottom:0}.staff-detail-info-grid--summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-2);align-items:center}.staff-qr-card{position:relative;border:1px dashed var(--border-strong);border-radius:var(--radius-lg);padding:var(--spacing-1);background:linear-gradient(135deg,#3b82f60d,#3b82f605);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--spacing-1);min-height:0;aspect-ratio:1 / 1;max-width:140px;max-height:140px;width:100%;height:auto;margin:0 auto;transition:all .2s ease-in-out;cursor:pointer}.staff-detail-info-grid--summary>*{height:100%}.staff-detail-info-grid--summary .staff-detail-info-item{display:flex;flex-direction:column;justify-content:center;height:100%;padding:var(--spacing-2)}.staff-detail-info-grid--summary .staff-qr-card{align-self:center}.staff-qr-card:hover{border-style:solid;border-color:var(--primary);box-shadow:var(--shadow-md)}.staff-qr-card.has-qr{border-style:solid;border-color:var(--primary);background:linear-gradient(135deg,#3b82f614,#3b82f608)}.staff-qr-card.no-qr{opacity:.75;color:var(--muted)}.staff-qr-icon svg{width:48px;height:48px;color:var(--text)}.staff-qr-card.no-qr .staff-qr-icon svg{color:var(--muted)}.staff-qr-status{font-weight:600;color:var(--text);text-align:center}.staff-qr-card.no-qr .staff-qr-status{color:var(--muted)}.staff-qr-link-hint{font-size:var(--font-size-xs);color:var(--muted);text-align:center}.staff-qr-edit-btn{position:absolute;top:8px;right:8px;border:none;background:#fff;border-radius:var(--radius);padding:var(--spacing-1);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.staff-qr-edit-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.staff-qr-edit-btn svg{width:14px;height:14px;color:var(--text)}.staff-detail-info-item{padding:var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}.staff-detail-specialization-section{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--border)}.staff-detail-specialization-section .staff-detail-info-label{margin-bottom:var(--spacing-2);font-weight:500;color:var(--text);display:flex;align-items:center;gap:var(--spacing-2)}.staff-detail-specialization-section .staff-detail-info-value{padding:var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);min-height:60px;transition:all .2s ease}.staff-detail-info-item:hover{border-color:var(--primary);background:#3b82f608;transform:translateY(-2px)}.staff-detail-info-label{font-size:var(--font-size-xs);color:var(--muted);font-weight:500;margin-bottom:var(--spacing-1);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:var(--spacing-1)}.staff-detail-info-value{font-size:var(--font-size-base);font-weight:600;color:var(--text)}.staff-detail-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-3);margin-top:var(--spacing-4)}.staff-detail-stat-item{padding:var(--spacing-3);background:var(--bg);border-radius:var(--radius);border:1px solid var(--border);transition:all .2s ease}.staff-detail-stat-item:hover{border-color:var(--primary);background:#3b82f608}.staff-detail-stat-label{font-size:var(--font-size-xs);color:var(--muted);font-weight:500;margin-bottom:var(--spacing-1);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:var(--spacing-1)}.staff-detail-stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text)}.staff-detail-section{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-4);overflow:hidden;transition:all .3s ease}.staff-detail-section:hover{box-shadow:var(--shadow)}.staff-detail-section-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(59,130,246,.03) 0%,transparent 100%);display:flex;justify-content:space-between;align-items:center}.staff-detail-section-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.staff-detail-section-content{padding:var(--spacing-5)}.staff-detail-empty-state{text-align:center;padding:var(--spacing-6) var(--spacing-4);color:var(--muted)}.staff-detail-empty-state-icon{width:64px;height:64px;margin:0 auto var(--spacing-3);opacity:.5}.staff-detail-empty-state-icon svg{width:100%;height:100%;color:var(--muted)}.staff-detail-two-column-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.staff-detail-left-column,.staff-detail-right-column{display:flex;flex-direction:column;gap:var(--spacing-4)}.staff-month-selector{position:relative}.btn-icon-month-nav:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-month-display:hover{background:var(--surface);border-color:var(--primary);color:var(--primary)}.month-picker-dropdown{box-shadow:0 4px 12px #00000026}.btn-month-option:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px)}.btn-month-option.selected{background:var(--primary);color:#fff;border-color:var(--primary)}@media (max-width: 768px){.staff-detail-info-grid--summary{grid-template-columns:1fr 1fr;gap:var(--spacing-2);align-items:center}.staff-detail-info-grid--summary .staff-qr-card{max-width:120px;max-height:120px}.staff-detail-two-column-layout{grid-template-columns:1fr}.staff-detail-section-content{max-height:none!important}}.role-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);background:linear-gradient(135deg,var(--primary) 0%,rgba(59,130,246,.8) 100%);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;margin-right:var(--spacing-1);box-shadow:0 2px 8px #3b82f64d;transition:all .2s ease}.role-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}@media (max-width: 1024px){.class-detail-cards-grid,.staff-detail-cards-grid{grid-template-columns:1fr}}@media (max-width: 768px){.class-detail-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3);padding-bottom:var(--spacing-3)}.class-detail-header-actions{width:100%;justify-content:flex-end}.class-detail-title-row{flex-wrap:wrap}.class-detail-cards-grid{grid-template-columns:1fr;gap:var(--spacing-3)}.class-detail-card{padding:var(--spacing-4)}.class-detail-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.class-detail-title{font-size:var(--font-size-xl)}.class-detail-meta{font-size:var(--font-size-xs);gap:var(--spacing-2);flex-direction:column;align-items:flex-start}.class-detail-section-content{padding:var(--spacing-3)}.class-detail-stats-grid{grid-template-columns:1fr}.session-toolbar{flex-direction:column;align-items:stretch}.session-toolbar-actions{width:100%;justify-content:flex-end}.sessions-table{font-size:var(--font-size-xs)}.sessions-table th,.sessions-table td{padding:var(--spacing-2) var(--spacing-3)}.sessions-table .session-meta-cell{padding:var(--spacing-2) var(--spacing-3)!important}.sessions-table thead{display:none}.sessions-table,.sessions-table tbody,.sessions-table tr,.sessions-table td{display:block;width:100%!important}.sessions-table tbody tr{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-3);padding:var(--spacing-3);background:var(--surface)}.sessions-table tbody td{border:none!important;padding:var(--spacing-2) 0!important;display:block;width:100%!important}.sessions-table tbody td:first-child{order:1;text-align:left}.sessions-table tbody td.session-time-cell{order:2;border-bottom:1px solid var(--border)!important;padding-bottom:var(--spacing-2)!important;margin-bottom:var(--spacing-2)}.sessions-table tbody td.session-info-cell{order:3;border-bottom:1px solid var(--border)!important;padding-bottom:var(--spacing-2)!important;margin-bottom:var(--spacing-2)}.sessions-table tbody td.session-notes-cell{order:4}.sessions-table tbody td.session-actions{order:5;text-align:right;padding-top:var(--spacing-2)!important;border-top:1px solid var(--border)!important;margin-top:var(--spacing-2)}.session-notes-cell{max-width:100%!important;min-width:100%!important}.session-time-cell,.session-info-cell{min-width:100%!important;width:100%!important}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.staff-detail-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3);padding-bottom:var(--spacing-3)}.staff-detail-header-actions{width:100%;justify-content:flex-end}.staff-detail-title-row{flex-wrap:wrap}.staff-detail-cards-grid{grid-template-columns:1fr;gap:var(--spacing-3)}.staff-detail-card{padding:var(--spacing-4)}.staff-detail-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.staff-detail-title{font-size:var(--font-size-xl)}.staff-detail-meta{font-size:var(--font-size-xs);gap:var(--spacing-2);flex-direction:column;align-items:flex-start}.staff-detail-section-content{padding:var(--spacing-3)}.staff-detail-stats-grid,.staff-detail-info-grid{grid-template-columns:1fr}}.student-card{display:grid;grid-template-columns:auto 1fr;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--surface);border-radius:var(--radius);margin-bottom:var(--spacing-3)}.teacher-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.payment-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.payment-summary{background:var(--surface);padding:var(--spacing-4);border-radius:var(--radius);margin-bottom:var(--spacing-4)}.schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.schedule-day{background:var(--surface);padding:var(--spacing-3);border-radius:var(--radius);min-height:120px}.schedule-item{padding:var(--spacing-2);margin-bottom:var(--spacing-2);border-radius:var(--radius-sm);background:var(--bg)}.report-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.chart-container{background:var(--surface);padding:var(--spacing-4);border-radius:var(--radius);margin-bottom:var(--spacing-4)}@media (max-width: 640px){.dashboard-stats,.teacher-stats{grid-template-columns:1fr}.schedule-grid{grid-template-columns:repeat(1,1fr)}.student-card{grid-template-columns:1fr}.transaction-history .transaction-table{max-height:320px;overflow-y:auto}.transaction-history table{width:100%;border-collapse:collapse;font-size:.8rem}.transaction-history th,.transaction-history td{text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--border)}.transaction-history tbody tr:last-child td{border-bottom:none}}.lesson-plans-tabs{position:relative;display:flex;gap:var(--spacing-1, .25rem);padding:var(--spacing-2, .5rem);margin-bottom:var(--spacing-5, 1.25rem);background:var(--bg, #f8fafc);border-radius:var(--radius-lg, .75rem);border:1px solid var(--border, #e2e8f0);box-shadow:0 1px 3px #0000000d}.lesson-plan-tab{position:relative;flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--spacing-2, .5rem);padding:var(--spacing-3, .75rem) var(--spacing-4, 1rem);border:none;background:transparent;color:var(--muted, #64748b);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:var(--font-size-sm, .875rem);font-weight:500;z-index:1;border-radius:var(--radius, .5rem);overflow:hidden}.lesson-plan-tab:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#3b82f614,#3b82f60a);opacity:0;transition:opacity .3s ease;z-index:-1}.lesson-plan-tab:hover{color:var(--primary, #3b82f6);background:#3b82f60f;transform:translateY(-1px)}.lesson-plan-tab:hover:before{opacity:1}.lesson-plan-tab.active{color:var(--primary, #3b82f6);font-weight:600;background:linear-gradient(135deg,#3b82f61f,#3b82f614);box-shadow:0 2px 8px #3b82f626,inset 0 1px #ffffff1a;transform:translateY(-1px)}.lesson-plan-tab.active:before{opacity:1}.lesson-plan-tab-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.lesson-plan-tab-icon svg{width:100%;height:100%;stroke-width:2.5;transition:all .3s ease}.lesson-plan-tab:hover .lesson-plan-tab-icon{transform:scale(1.1) rotate(2deg);color:var(--primary, #3b82f6)}.lesson-plan-tab.active .lesson-plan-tab-icon{color:var(--primary, #3b82f6);transform:scale(1.15);filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.lesson-plan-tab.active .lesson-plan-tab-icon svg{stroke-width:2.8}.lesson-plan-tab-text{font-size:var(--font-size-sm, .875rem);white-space:nowrap;letter-spacing:.01em;transition:all .3s ease}.lesson-plan-tab.active .lesson-plan-tab-text{letter-spacing:.02em}.lesson-plan-tab-indicator{position:absolute;bottom:0;left:0;width:33.33%;height:3px;background:linear-gradient(90deg,var(--primary, #3b82f6) 0%,rgba(59,130,246,.8) 100%);transition:left .4s cubic-bezier(.4,0,.2,1),width .4s cubic-bezier(.4,0,.2,1);z-index:2;border-radius:3px 3px 0 0;box-shadow:0 -2px 8px #3b82f666}[data-theme=dark] .lesson-plans-tabs{background:#1e293b80;border-color:#94a3b81a}[data-theme=dark] .lesson-plan-tab:hover{background:#3b82f61a}[data-theme=dark] .lesson-plan-tab.active{background:linear-gradient(135deg,#3b82f633,#3b82f626);box-shadow:0 2px 8px #3b82f640,inset 0 1px #ffffff0d}@media (max-width: 768px){.lesson-plans-tabs{padding:var(--spacing-1, .25rem);gap:var(--spacing-1, .25rem)}.lesson-plan-tab{padding:var(--spacing-2, .5rem) var(--spacing-2, .5rem);font-size:var(--font-size-xs, .75rem);gap:var(--spacing-1, .25rem)}.lesson-plan-tab-icon{width:18px;height:18px}.lesson-plan-tab-icon svg{width:18px;height:18px}.lesson-plan-tab-text{font-size:var(--font-size-xs, .75rem)}}@media (max-width: 480px){.lesson-plan-tab{flex-direction:column;padding:var(--spacing-2, .5rem) var(--spacing-1, .25rem)}.lesson-plan-tab-text{font-size:.7rem}}.exercises-container{display:flex;gap:var(--spacing-4)}.exercises-sidebar{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--spacing-4);overflow-y:auto}.topic-item{padding:var(--spacing-3);margin-bottom:var(--spacing-1);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;font-size:var(--font-size-sm);border:1px solid transparent}.topic-item:hover{background:var(--bg);border-color:var(--border);transform:translate(2px)}.topic-item.active{background:linear-gradient(135deg,#3b82f61f,#3b82f614);color:var(--primary);font-weight:600;border-color:#3b82f633}.custom-topic:hover .topic-actions{opacity:1!important}.exercises-table{width:100%}.exercise-row{transition:all .2s ease}.exercise-row:hover{background:var(--bg)!important;transform:translate(2px)}.exercise-row.dragging{opacity:.6;transform:scale(1.02);box-shadow:0 4px 12px #00000026;z-index:1000;cursor:grabbing!important}.exercise-row.draggable-row{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.exercise-row.draggable-row:active{cursor:grabbing}.overview-tab-content{padding:var(--spacing-2)}.overview-section-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--spacing-5);box-shadow:var(--shadow-sm);transition:all .3s ease}.overview-section-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}[data-theme=dark] .overview-section-card{background:var(--surface-dark);border-color:var(--border-dark)}.overview-section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--border)}.overview-section-title{display:flex;align-items:center;gap:var(--spacing-3);flex:1}.overview-section-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}.overview-section-card:hover .overview-section-icon{transform:scale(1.05)}.overview-table{width:100%;border-collapse:collapse}.overview-table thead th{text-align:left;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);background:var(--bg)}.overview-table tbody td{padding:var(--spacing-4);border-bottom:1px solid var(--border);vertical-align:middle}.overview-table-row{transition:all .2s ease;cursor:pointer}.overview-table-row:hover{background:var(--bg)!important;transform:translate(2px);box-shadow:0 2px 8px #0000000d}.overview-table-row:nth-child(2n){background:var(--bg)}.overview-table-row:nth-child(2n):hover{background:var(--bg)!important}.overview-empty-state{padding:0!important}.overview-empty-state div{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}@media (max-width: 768px){.overview-section-card{padding:var(--spacing-3)}.overview-section-header{flex-direction:column;gap:var(--spacing-3);align-items:flex-start}.overview-section-icon{width:40px;height:40px}.overview-section-icon svg{width:18px;height:18px}.overview-table thead th,.overview-table tbody td{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}.exercises-container{flex-direction:column;height:auto}.exercises-sidebar{width:100%!important;max-height:300px}}body.home-landing-mode{background:var(--surface)}body[data-theme=dark].home-landing-mode{background:#0f172a}body.home-landing-mode .layout{display:block;background:transparent}body.home-landing-mode .layout>main{max-width:1200px;margin:0 auto;padding:var(--spacing-5) var(--spacing-4) var(--spacing-8);background:transparent}body.home-landing-mode .modal-backdrop{background:#0009!important;z-index:10000!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}body.home-landing-mode .modal-backdrop~* .sidebar,body.home-landing-mode .modal-backdrop~* aside,body.home-landing-mode .modal-backdrop~* .layout:not(.layout-landing){display:none!important;visibility:hidden!important;opacity:0!important}body.home-landing-mode .layout>aside,body.home-landing-mode .sidebar,body.home-landing-mode .top-nav,body.home-landing-mode #sidebar{display:none!important}.home-landing{min-height:100vh;display:flex;flex-direction:column;gap:var(--spacing-6);color:var(--text)}.home-landing-header{position:sticky;top:16px;z-index:100;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-5);background:linear-gradient(180deg,#fffffffa,#f7f8fff2);border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-3xl);box-shadow:0 8px 32px #0f172a14,0 2px 8px #0f172a0a;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);transition:all .3s cubic-bezier(.4,0,.2,1);margin-bottom:var(--spacing-2)}.home-landing-header.scrolled{top:8px;padding:var(--spacing-2) var(--spacing-4);box-shadow:0 12px 40px #0f172a1f,0 4px 12px #0f172a0f;background:linear-gradient(180deg,#fffffffc,#f7f8fff7)}.home-brand{display:flex;align-items:center;gap:var(--spacing-2)}.home-logo{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;transition:transform .2s ease;padding:var(--spacing-1);border-radius:var(--radius-lg)}.home-logo:hover{transform:scale(1.05)}.home-logo svg{transition:transform .3s ease,filter .3s ease;filter:drop-shadow(0 2px 4px rgba(59,130,246,.2))}.home-logo:hover svg{transform:rotate(15deg) scale(1.1);filter:drop-shadow(0 4px 8px rgba(59,130,246,.4))}.home-brand-name{font-weight:700;font-size:1rem}.home-brand-tagline{font-size:.75rem;color:var(--muted)}.home-primary-nav{display:flex;justify-content:center;gap:var(--spacing-3);flex-wrap:wrap}.home-nav-link{border:none;background:transparent;font-weight:600;font-size:.95rem;color:var(--muted);cursor:pointer;padding:var(--spacing-2) var(--spacing-3);transition:all .25s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-lg);letter-spacing:.02em;position:relative;overflow:hidden}.home-nav-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#3b82f614;border-radius:var(--radius-lg);transform:scale(0);transform-origin:center;transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:0}.home-nav-link:after{content:"";position:absolute;left:50%;right:50%;bottom:4px;height:2.5px;border-radius:999px;background:linear-gradient(90deg,#3b82f6cc,#6366f1cc);transform:translate(-50%) scaleX(0);transform-origin:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1;width:60%}.home-nav-link:hover,.home-nav-link:focus{color:var(--primary);transform:translateY(-1px)}.home-nav-link:hover:before{transform:scale(1)}.home-nav-link:hover:after,.home-nav-link:focus:after{transform:translate(-50%) scaleX(1);width:80%}.home-nav-link.active{color:var(--primary);background:#3b82f61a}.home-nav-link.active:before{transform:scale(1);background:#3b82f61f}.home-nav-link.active:after{transform:translate(-50%) scaleX(1);width:70%;height:3px;background:linear-gradient(90deg,#3b82f6,#6366f1);box-shadow:0 2px 8px #3b82f666}.home-auth-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.home-auth-actions .btn-ghost{border:1.5px solid rgba(15,23,42,.1);background:transparent;color:var(--text);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-lg);font-weight:600;font-size:.9rem;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.home-auth-actions .btn-ghost:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#3b82f614;transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:0}.home-auth-actions .btn-ghost:hover{color:var(--primary);border-color:#3b82f64d;transform:translateY(-1px)}.home-auth-actions .btn-ghost:hover:before{transform:scaleX(1)}.home-auth-actions .btn-primary,.top-nav-guest-actions .btn-primary{border:none;padding:var(--spacing-2) var(--spacing-5);border-radius:var(--radius-lg);background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 8px 24px #3b82f659,0 2px 8px #3b82f633;font-weight:600;font-size:.9rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.home-auth-actions .btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#2563eb,#4f46e5);opacity:0;transition:opacity .3s ease;z-index:0}.home-auth-actions .btn-primary:hover,.top-nav-guest-actions .btn-primary:hover{box-shadow:0 12px 32px #3b82f673,0 4px 12px #3b82f64d;transform:translateY(-2px) scale(1.02)}.home-auth-actions .btn-primary:hover:before{opacity:1}.home-auth-actions .btn-primary span,.top-nav-guest-actions .btn-primary span{position:relative;z-index:1}.home-user-chip{display:flex;flex-direction:column;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);background:#3b82f614}.home-user-chip .chip-name{font-weight:600}.chip-role{font-size:.75rem;color:var(--muted)}.home-hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-6);padding:var(--spacing-6) 0 var(--spacing-4)}.home-hero-content h1{font-size:clamp(2.2rem,4vw,3rem);margin:var(--spacing-3) 0 var(--spacing-2)}.home-hero-subtext{font-size:1.1rem;color:var(--muted);margin-bottom:var(--spacing-4)}.home-hero-actions{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.home-hero-kpis{margin-top:var(--spacing-5);display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-3)}.hero-kpi-card{background:#3b82f612;border:1px solid rgba(59,130,246,.15);border-radius:var(--radius-xl);padding:var(--spacing-3);box-shadow:inset 0 0 0 1px #ffffff26}.hero-kpi-card p{font-size:.85rem;color:var(--muted);margin-bottom:.35rem}.hero-kpi-card strong{font-size:1.7rem;font-weight:700;color:var(--text)}.home-pill{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:6px 12px;border-radius:var(--radius-full);background:#3b82f61f;color:var(--primary);font-weight:600;font-size:.85rem}.home-hero-illustration{position:relative;background:linear-gradient(135deg,#3b82f629,#6366f11f);border-radius:32px;padding:var(--spacing-6);overflow:hidden;min-height:320px}.hero-badge,.hero-card{position:absolute;background:var(--surface);border-radius:var(--radius-xl);padding:var(--spacing-3);box-shadow:0 12px 30px #0f172a1f}.hero-badge{top:24px;right:24px}.hero-card--primary{bottom:40px;left:30px}.hero-card--secondary{bottom:100px;right:40px}.home-insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.home-insight-card{padding:var(--spacing-4);border-radius:var(--radius-2xl);border:1px solid rgba(15,23,42,.08);background:linear-gradient(180deg,#f8fafff2,#ffffffe6);box-shadow:0 18px 45px #0f172a14}.insight-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.insight-value{font-size:2.4rem;font-weight:700;margin:var(--spacing-2) 0}.insight-meta{font-size:.85rem;color:var(--muted)}.insight-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin:var(--spacing-3) 0 var(--spacing-2)}.insight-chips span{padding:.35rem .8rem;border-radius:var(--radius-full);background:#3b82f61f;color:var(--primary);font-size:.8rem}.home-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-4);margin:var(--spacing-2) 0 var(--spacing-6)}.home-feature-card{padding:var(--spacing-4);border:1px solid var(--border);border-radius:var(--radius-2xl);background:var(--surface);box-shadow:0 8px 20px #0f172a0f;display:flex;flex-direction:column;gap:var(--spacing-2);transition:transform .2s ease,box-shadow .2s ease}.home-feature-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px #0f172a1f}.home-workflow{margin-top:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-4)}.workflow-header h2{margin:var(--spacing-2) 0}.workflow-tagline{color:var(--muted);max-width:640px}.workflow-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-4)}.workflow-card{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-2xl);padding:var(--spacing-4);background:var(--surface);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--spacing-2)}.workflow-icon{width:48px;height:48px;border-radius:16px;background:#3b82f61f;display:flex;align-items:center;justify-content:center;color:var(--primary)}.workflow-card h3{margin:var(--spacing-1) 0}.home-preview{margin-top:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-4)}.preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-4)}.preview-card{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-2xl);padding:var(--spacing-4);background:linear-gradient(180deg,#f8faff,#fffffff2);box-shadow:0 18px 40px #0f172a14;display:flex;flex-direction:column;gap:var(--spacing-2)}.preview-card-top{display:flex;justify-content:space-between;align-items:flex-start}.preview-card h3{font-size:1.8rem;margin:0}.preview-card h3 span{font-size:.9rem;color:var(--muted);font-weight:400;margin-left:.3rem}.preview-meta{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--muted);flex-wrap:wrap;gap:var(--spacing-2)}.status-pill{padding:.2rem .75rem;border-radius:999px;background:#22c55e26;color:#22c55e;font-weight:600;font-size:.75rem}.home-teams-section{margin:var(--spacing-2) 0 var(--spacing-6);padding:var(--spacing-5);border-radius:var(--radius-3xl);background:linear-gradient(135deg,#ffffffe6,#f1f5fff2);border:1px solid rgba(15,23,42,.08);box-shadow:0 24px 60px #0f172a14}.teams-header{text-align:center;margin-bottom:var(--spacing-5)}.teams-header h2{margin:var(--spacing-2) 0;font-size:2rem}.teams-tagline{color:var(--muted);font-size:1rem}.home-teams-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-4)}.home-team-card{background:var(--surface);border-radius:var(--radius-2xl);padding:var(--spacing-4);border:1px solid var(--border);box-shadow:0 14px 30px #0f172a14;display:flex;flex-direction:column;gap:var(--spacing-2);transition:transform .2s ease,box-shadow .2s ease}.home-team-card:hover{transform:translateY(-6px);box-shadow:0 24px 45px #0f172a1f;border-color:#3b82f666}.team-icon{font-size:2rem}.home-team-card p{color:var(--muted);flex:1}.home-team-card .btn{align-self:flex-start;border-radius:var(--radius-full)}.home-teams-contact{margin-top:var(--spacing-5);padding:var(--spacing-4);border-radius:var(--radius-xl);border:1px dashed rgba(59,130,246,.4);background:#3b82f614}.contact-inline{display:flex;gap:var(--spacing-4);flex-wrap:wrap;font-weight:600;color:var(--text)}.feature-icon{width:48px;height:48px;border-radius:14px;background:#3b82f61f;color:var(--primary);display:inline-flex;align-items:center;justify-content:center}.feature-link{margin-top:auto;border:none;background:none;color:var(--primary);font-weight:600;text-align:left;padding:0;cursor:pointer}.home-section{padding:var(--spacing-6) 0;border-bottom:1px solid var(--border-subtle)}.section-eyebrow{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:var(--spacing-2)}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);flex-wrap:wrap}.home-section-description p{margin-bottom:var(--spacing-2);color:var(--muted);line-height:1.7}.home-edit-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:transparent;padding:6px 12px;border-radius:var(--radius-lg);cursor:pointer;font-size:.85rem;color:var(--muted)}.home-edit-btn:hover{border-color:var(--primary);color:var(--primary)}.home-footer{padding:var(--spacing-8) 0}.home-footer-card{border-radius:var(--radius-3xl);background:linear-gradient(135deg,#eef2ffe6,#ede9fee6);border:1px solid rgba(59,130,246,.2);box-shadow:0 24px 60px #0f172a14;padding:var(--spacing-6);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-6)}.home-footer-lede{color:var(--muted);margin:var(--spacing-2) 0 var(--spacing-4)}.home-contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--spacing-3)}.contact-item{display:flex;gap:var(--spacing-3);align-items:center;padding:var(--spacing-3);border-radius:var(--radius-xl);background:#ffffffeb;border:1px solid rgba(15,23,42,.05)}.contact-icon{width:44px;height:44px;border-radius:14px;background:#3b82f61f;display:inline-flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.home-footer-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-top:var(--spacing-4)}.home-footer-actions .btn-ghost{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-full)}.home-footer-right{background:#0f172a0a;border-radius:var(--radius-2xl);padding:var(--spacing-5);border:1px dashed rgba(59,130,246,.25);display:flex;flex-direction:column;gap:var(--spacing-4)}.home-footer-right h3{margin:0}.home-footer-socials{display:flex;flex-direction:column;gap:var(--spacing-2)}.home-social-link{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2);border-radius:var(--radius-lg);transition:background .2s ease;color:var(--text);font-weight:600}.home-social-link:hover{background:#fffc}.home-social-icon{width:36px;height:36px;border-radius:12px;background:#ffffffe6;display:inline-flex;align-items:center;justify-content:center;color:var(--text)}.home-footer-note{font-size:.85rem;color:var(--muted)}@media (max-width: 1024px){.home-landing-header{grid-template-columns:1fr;text-align:center;top:8px;padding:var(--spacing-3) var(--spacing-4);gap:var(--spacing-3)}.home-landing-header.scrolled{top:4px;padding:var(--spacing-2) var(--spacing-3)}.home-brand{justify-content:center}.home-primary-nav{justify-content:center;flex-wrap:wrap;gap:var(--spacing-2)}.home-nav-link{padding:var(--spacing-1.5) var(--spacing-2.5);font-size:.875rem}.home-auth-actions{justify-content:center;width:100%;flex-wrap:wrap}.home-auth-actions .btn-ghost,.home-auth-actions .btn-primary{flex:1;min-width:120px}}@media (max-width: 640px){.home-hero{grid-template-columns:1fr}.home-hero-illustration{min-height:260px}.home-landing-header{position:static;border-bottom:none}.home-teams-section{padding:var(--spacing-4)}.contact-inline{flex-direction:column;gap:var(--spacing-2)}}.students-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4);gap:var(--spacing-4)}.students-page-title-row{display:flex;align-items:center;gap:var(--spacing-3);flex:1}.students-count-badge{display:flex;align-items:baseline;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border)}.students-count-number{font-size:1.25rem;font-weight:700;color:var(--primary)}.students-count-label{font-size:.875rem;color:var(--muted);font-weight:500}.students-filters-card,.students-search-bar{margin-bottom:var(--spacing-4)}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--spacing-3);color:var(--muted);pointer-events:none;z-index:1}.search-input{width:100%;padding:var(--spacing-2) var(--spacing-3) var(--spacing-2) calc(var(--spacing-3) * 2 + 18px);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--font-size-base);background:var(--bg);color:var(--text);transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.search-input::-moz-placeholder{color:var(--muted)}.search-input::placeholder{color:var(--muted)}.search-clear-btn{position:absolute;right:var(--spacing-2);display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease;z-index:1}.search-clear-btn:hover{background:var(--bg-secondary);color:var(--text)}.students-filters-row{display:flex;flex-wrap:wrap;gap:var(--spacing-3);align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:180px;flex:1}.filter-label{font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:var(--spacing-1)}.filter-select{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--font-size-base);background:var(--bg);color:var(--text);cursor:pointer;transition:all .2s ease}.filter-select:hover{border-color:var(--primary)}.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.filter-actions{display:flex;gap:var(--spacing-2);align-items:flex-end}.status-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius);font-size:.875rem;font-weight:500}.status-badge.status-active{background:#22c55e1a;color:#16a34a}.status-badge.status-inactive{background:#ef44441a;color:#dc2626}.status-badge svg{flex-shrink:0}@media (max-width: 768px){.students-page-header{flex-direction:column;align-items:stretch}.students-page-title-row{justify-content:space-between}.students-filters-row{flex-direction:column}.filter-group{min-width:100%}.filter-actions{width:100%}.filter-actions .btn{flex:1}}.action-history-page{max-width:1200px;margin:0 auto;padding:var(--spacing-4)}.page-header h1{font-size:var(--font-size-2xl);font-weight:600;color:var(--text);margin:0}.page-header p{margin:var(--spacing-2) 0 0 0;color:var(--muted)}.filter-card{box-shadow:var(--shadow-sm)}.filter-card .form-group-enhanced{margin-bottom:0}.timeline-container{position:relative;padding:var(--spacing-4) 0}.timeline-item{position:relative;padding-left:var(--spacing-6);margin-bottom:var(--spacing-4)}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:0;top:0;width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid var(--surface);z-index:2;box-shadow:0 0 0 2px var(--bg)}.timeline-line{position:absolute;left:5px;top:12px;width:2px;background:var(--border);z-index:1}.timeline-content{transition:all .2s ease;box-shadow:var(--shadow-sm)}.timeline-content:hover{box-shadow:var(--shadow);border-color:var(--primary)}.badge-success{background:var(--success);color:#fff;padding:2px 8px;border-radius:var(--radius);font-size:var(--font-size-xs);font-weight:600}.badge-primary{background:var(--primary);color:#fff;padding:2px 8px;border-radius:var(--radius);font-size:var(--font-size-xs);font-weight:600}.badge-danger{background:var(--danger);color:#fff;padding:2px 8px;border-radius:var(--radius);font-size:var(--font-size-xs);font-weight:600}.badge-warning{background:var(--warning);color:#fff;padding:2px 8px;border-radius:var(--radius);font-size:var(--font-size-xs);font-weight:600}.badge-default{background:var(--muted);color:#fff;padding:2px 8px;border-radius:var(--radius);font-size:var(--font-size-xs);font-weight:600}.undo-action-btn{transition:all .2s ease}.undo-action-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.undo-action-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.action-history-page{padding:var(--spacing-3)}.filter-card>div{grid-template-columns:1fr!important}.timeline-item{padding-left:var(--spacing-4)}.timeline-marker{width:10px;height:10px;left:-2px}.timeline-content{padding:var(--spacing-3)!important}.timeline-content>div{flex-direction:column!important;align-items:flex-start!important}.undo-action-btn{width:100%;margin-top:var(--spacing-2)}}details summary{list-style:none;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}details summary::-webkit-details-marker{display:none}details summary:before{content:"▶";display:inline-block;margin-right:6px;transition:transform .2s ease;font-size:10px}details[open] summary:before{transform:rotate(90deg)}body{background:var(--bg);color:var(--text)}.coding-hero{background:linear-gradient(135deg,#2563eb1f,#0ea5e91f);padding:2.5rem;border-radius:1.25rem;margin:2rem auto;max-width:1100px;display:flex;justify-content:space-between;gap:1.5rem;align-items:center}.coding-hero .hero-content{max-width:720px}.coding-main{max-width:1100px;margin:0 auto 4rem}.tab-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.tab-switch{border:none;background:var(--surface);color:var(--muted);padding:.65rem 1.25rem;border-radius:var(--radius);cursor:pointer;font-weight:600;box-shadow:0 1px 2px #0f172a14;transition:background .2s,color .2s}.tab-switch.active{background:var(--primary);color:var(--primary-contrast)}.tab-panel{display:none;gap:1rem}.tab-panel.active{display:block}.info-card{background:var(--surface);padding:1.75rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.info-card ol{padding-left:1.25rem;line-height:1.7}.info-card li{margin-bottom:.75rem}.note{margin-top:1rem;background:var(--surface-strong);border-left:4px solid var(--primary);padding:1rem;border-radius:var(--radius);font-weight:500}.doc-list{display:flex;flex-direction:column;gap:1rem}.doc-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.doc-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.doc-header h3{margin:0}.doc-date{margin:.25rem 0 0;color:var(--muted);font-size:.9rem}.doc-content{margin-top:1rem;line-height:1.6}.doc-attachments{margin-top:1.2rem;display:flex;gap:.75rem;flex-wrap:wrap}.coding-footer{text-align:center;padding:2rem 1rem;color:var(--muted)}@media (max-width: 768px){.coding-hero{flex-direction:column;padding:1.75rem}}.layout:has(.sidebar[data-collapsed=true]) .main-content{margin-left:56px;transition:margin-left .3s ease-in-out}@media (max-width: 768px){.layout{position:relative}.sidebar{position:fixed;left:0;top:0;height:100vh;z-index:999;box-shadow:2px 0 8px #0000001a}.main-content{margin-left:56px!important;transition:margin-left .3s ease-in-out}.sidebar:not([data-collapsed=true]){box-shadow:4px 0 16px #0003}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-toggle-btn{position:absolute;top:72px;right:-12px;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;box-shadow:var(--shadow-sm);transition:right .3s ease-in-out,transform .3s ease-in-out}.sidebar-toggle-btn:hover{background:var(--bg-secondary);transform:scale(1.05)}.sidebar-toggle-btn:active{transform:scale(.95)}.sidebar[data-collapsed=true] .tab{justify-content:center;padding:var(--spacing-2)}.sidebar[data-collapsed=true] .tab span{display:none}.sidebar[data-collapsed=true] .brand>div:not(:first-child){display:none}.sidebar[data-collapsed=true] .user-info-content{display:none}.sidebar[data-collapsed=true] .version-text{font-size:.65rem}}@media (max-width: 1024px) and (min-width: 769px){.sidebar{width:200px;flex:0 0 200px}}@media (min-width: 769px){.sidebar{position:relative}.main-content{transition:margin-left .3s ease-in-out}.sidebar-toggle-btn-desktop{display:none}}.sidebar *{transition-timing-function:ease-in-out}.sidebar{will-change:width}.sidebar .tab:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media (max-width: 768px){.sidebar .tab{min-height:48px;min-width:48px}.sidebar .btn{min-height:44px;min-width:44px}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,Public Sans,Manrope,Roboto,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:SF Mono,SFMono-Regular,ui-monospace,Menlo,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.mb-1{margin-bottom:.25rem}.mb-3{margin-bottom:.75rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.max-w-2xl{max-width:42rem}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.gap-2{gap:.5rem}.gap-4{gap:1rem}.border{border-width:1px}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.text-center{text-align:center}.text-right{text-align:right}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{margin:0;min-width:320px;min-height:100vh;font-family:var(--font-sans);font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{content-visibility:auto}.scroll-container{will-change:scroll-position;transform:translateZ(0)}#root{width:100%;min-height:100vh;font-family:var(--font-sans)}*{font-family:inherit}
