*{box-sizing:border-box}:root{--bg-dark:#fff;--bg-card:#f5f5f7;--bg-contrast:#fef9e7;--bg-special:#e0d7ff;--primary:#b8860b;--secondary:#801e1d;--accent-purple:#e0d7ff;--text-label:#475569;--text-input:#1e293b;--text-placeholder:#94a3b8;--text-muted:#801e1db3;--text-accent:#801e1d;--danger:#d32f2f;--form-error:#ff8a75;--glass-bg:#fffc;--glass-border:#b8860b1a;--shadow-premium:0 10px 30px #801e1d0d;--shadow-glow:0 0 15px #b8860b1a;--gap:24px}.dark-theme{--bg-dark:#0f1117;--bg-card:#1a1d27;--bg-contrast:#1e2130;--bg-special:#25252b;--text-label:#94a3b8;--text-input:#f8fafc;--text-placeholder:#475569;--text-muted:#ffffff80;--text-accent:#d4af37;--secondary:#e2e8f0;--primary:#d4af37;--glass-bg:#1a1d27cc;--glass-border:#d4af3726;--shadow-premium:0 15px 35px #00000080;--shadow-glow:0 0 20px #d4af370d}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--shadow-premium);border-radius:16px}body{background-color:var(--bg-dark);color:var(--secondary);width:100%;max-width:100%;height:100vh;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;overflow:hidden}html{width:100%;height:100%;overflow:hidden}h1,h2,h3{color:var(--text-accent);letter-spacing:-.02em;font-family:Outfit,sans-serif;font-weight:700}input[type=date]{cursor:pointer;position:relative}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;color:#0000;cursor:pointer;opacity:0;background:0 0;width:auto;height:auto;position:absolute;inset:0}.login-container{background:var(--bg-dark);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";z-index:0;background:radial-gradient(circle,#b8860b14 0%,#0000 70%);width:150vw;height:150vw;position:absolute;top:-75vw;left:-25vw}.login-card{width:100%;max-width:420px;box-shadow:var(--shadow-premium);z-index:1;flex-direction:column;gap:25px;padding:40px;display:flex;position:relative}.login-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.login-logo{width:auto;height:90px;margin-bottom:15px}.login-header h1{color:var(--primary);letter-spacing:1px;margin:0;font-family:Outfit,sans-serif;font-size:24px}.login-header p{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin:0;font-size:13px}.login-form{flex-direction:column;gap:20px;display:flex}.login-input-group{background:#801e1d05;border:1px solid #801e1d14;border-radius:12px;flex-direction:row;align-items:center;gap:15px;padding:14px 18px;transition:all .3s;display:flex}.login-input-group:focus-within{border-color:var(--primary);background:#801e1d0a}.input-icon{color:var(--primary);opacity:.8;flex-shrink:0}.login-input-group input{color:var(--text-input);background:0 0;border:none;outline:none;width:100%;font-size:15px}.login-input-group input::placeholder{color:var(--text-placeholder)}.login-btn{background:var(--secondary);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;margin-top:10px;padding:16px;font-size:16px;font-weight:600;transition:all .3s;display:flex;color:#fff!important}.login-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.login-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--glass-border);margin-top:10px;padding-top:20px;font-size:12px}@media (width<=480px){.login-card{width:92%;padding:30px 20px}}.dark-theme .login-container{background:#0f1117}.dark-theme .login-card{background:var(--bg-card)}.dark-theme .login-input-group{background:#ffffff08;border-color:#ffffff1a}.dark-theme .login-input-group:focus-within{border-color:var(--primary);background:#ffffff0d}.dark-theme .login-btn{background:linear-gradient(135deg,#801e1d,#b83230);box-shadow:0 4px 15px #0000004d;color:#fff!important}.dark-theme .login-btn:hover:not(:disabled){background:linear-gradient(135deg,#992523,#cc4240);transform:translateY(-2px);box-shadow:0 6px 20px #0006}.dark-theme .login-btn:disabled{opacity:.7;cursor:not-allowed;background:#3a3f52}.dark-theme .login-footer{color:var(--text-muted)}.dark-theme .login-header h1{color:var(--text-accent)}.admin-container{background:radial-gradient(circle at top right, var(--shadow-glow), var(--bg-dark));width:100%;max-width:100%;height:100vh;display:block;position:relative;overflow:hidden}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px}.sidebar{z-index:1000;scrollbar-width:none;background:var(--glass-bg);border:1px solid var(--glass-border);backface-visibility:hidden;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;flex-direction:column;width:280px;min-width:280px;max-width:280px;padding:0;display:flex;position:fixed;top:10px;bottom:10px;left:10px;overflow-y:auto;transform:translateZ(0);box-shadow:10px 0 30px #00000005;transition:none!important}.sidebar::-webkit-scrollbar{display:none}.logo-section{border-bottom:1px solid var(--glass-border);flex-direction:column;justify-content:center;align-items:center;width:100%;margin-bottom:20px;padding:30px 15px;display:flex}.dash-logo{filter:drop-shadow(0 4px 8px #801e1d1a);width:60%;max-width:140px;height:auto;display:block}.nav-menu{flex-direction:column;flex:1;gap:2px;padding:10px 16px;display:flex}.menu-btn,.menu-header{width:100%;color:var(--secondary);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:6px 12px;font-size:13.5px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.menu-btn:hover,.menu-header:hover{background:var(--glass-border)}.menu-btn.active,.menu-header.active{background:var(--glass-border);border:1px solid var(--primary);color:var(--secondary);box-shadow:0 4px 15px #0000000d}.menu-btn svg,.menu-header svg{color:var(--primary);background:#b8860b1a;border-radius:5px;width:20px;height:20px;padding:3px;transition:all .3s}.menu-btn.active svg,.menu-header.active svg{background:var(--primary);color:#fff;box-shadow:0 4px 10px #b8860b4d}.menu-group{flex-direction:column;gap:4px;display:flex}.menu-header{justify-content:space-between}.menu-header .title{align-items:center;gap:12px;display:flex}.menu-header .arrow{opacity:.5;transition:transform .3s;background:0 0!important;width:14px!important;height:14px!important;padding:0!important}.menu-group.expanded .arrow{opacity:1;color:var(--secondary);transform:rotate(180deg)}.sub-menu{flex-direction:column;gap:2px;padding-left:42px;display:flex;position:relative;overflow:hidden}.sub-menu:before{content:"";background:linear-gradient(#801e1d1a,#801e1d05);border-radius:1px;width:2px;position:absolute;top:0;bottom:10px;left:31px}.sub-menu button{color:var(--text-muted);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 16px;font-size:13px;transition:all .2s;display:flex;position:relative}.sub-menu button:after{content:"";background:#801e1d1a;border-radius:50%;width:6px;height:6px;transition:transform .2s;position:absolute;top:50%;left:-11px;transform:translateY(-50%)scale(0)}.sub-menu button:hover{color:var(--secondary);background:#801e1d08;padding-left:20px}.sub-menu button:hover:after{transform:translateY(-50%)scale(1)}.sub-menu button.active{color:var(--secondary);background:#801e1d0f;padding-left:20px;font-weight:700}.sub-menu button.active:after{background:var(--primary);transform:translateY(-50%)scale(1)}.sub-menu button svg{color:currentColor;background:0 0;width:14px;height:14px;padding:0}.sidebar-footer{border-top:1px solid var(--glass-border);margin-top:10px;padding:15px}.logout-btn{color:#ff4d4d;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 16px;transition:background .3s;display:flex}.logout-btn:hover{background:#ff4d4d1a}.main-content{width:calc(100% - 300px);height:100vh;margin-left:300px;padding:20px;position:relative;overflow:hidden auto}.dark-theme .main-content,.dark-theme .dashboard-content{background:var(--bg-dark)}.top-header{justify-content:space-between;align-items:center;display:flex}.search-bar{align-items:center;gap:10px;width:400px;padding:10px 20px;display:flex}.search-bar input{color:var(--secondary);background:0 0;border:none;outline:none;width:100%;font-size:14px}.header-spacer{flex:1}.icon-btn{cursor:pointer;width:42px;height:42px;color:var(--text-muted);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex}.icon-btn:hover{color:var(--primary);border-color:var(--primary);background:#801e1d08;transform:translateY(-2px)}.admin-profile{align-items:center;gap:12px;margin-left:10px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary), var(--bg-special));width:42px;height:42px;color:var(--bg-dark);border-radius:12px;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:10px;display:grid}.stat-card{padding:24px;position:relative;overflow:hidden}.stat-card:before{content:"";background:radial-gradient(circle at 100% 0,#d4af371a,#0000);width:120px;height:120px;position:absolute;top:0;right:0}.stat-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.stat-icon{color:var(--accent-purple);background:#e0d7ff1a;border-radius:10px;padding:10px}.stat-trend{color:#4ade80;background:#4ade801a;border-radius:12px;padding:2px 8px;font-size:12px}.stat-trend.highlight{color:var(--primary);background:#b8860b1a}.stat-card h3{margin:0;font-size:32px}.stat-card p{color:var(--text-muted);margin:4px 0 0;font-size:14px}.split-stats{justify-content:space-between;gap:20px;margin-top:10px;display:flex;position:relative}.split-stats .stat-item{flex:1}.split-stats .stat-item:not(:last-child){border-right:1px solid var(--glass-border);padding-right:15px}.split-stats h3{margin:0;font-size:24px}.split-stats p{margin-top:2px;font-size:12px}.wide-card{padding:24px}.card-header-with-action{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-header-with-action h3{margin:0}.text-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-weight:600}.text-btn:hover{background:#b8860b1a}.event-mini-list{flex-direction:column;gap:12px;display:flex}.event-mini-item{border:1px solid var(--glass-border);background:#ffffff05;border-radius:12px;align-items:center;gap:16px;padding:12px;transition:all .3s;display:flex}.event-mini-item:hover{background:#b8860b0d;transform:translate(5px)}.event-time{color:var(--primary);text-align:center;background:#b8860b26;border-radius:8px;min-width:75px;padding:6px 10px;font-size:12px;font-weight:700}.event-info{flex-direction:column;display:flex}.event-info strong{font-size:14px}.event-info span{color:var(--text-muted);font-size:12px}.empty-mini-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:30px;display:flex}.empty-mini-state p{margin:0;font-size:13px}.recent-list{flex-direction:column;gap:12px;margin-top:20px;display:flex}.recent-item{border:1px solid var(--glass-border);background:#801e1d05;border-radius:14px;align-items:center;gap:16px;padding:16px;display:flex}.student-avatar{width:40px;height:40px;color:var(--accent-purple);background:#e0d7ff26;border-radius:10px;justify-content:center;align-items:center;font-weight:700;display:flex}.item-meta{flex-direction:column;flex:1;display:flex}.status-pill{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.status-pill.pending{color:orange;background:#ffa5001a}.primary-btn{background:var(--secondary);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 24px;font-weight:600;transition:transform .2s;display:flex;color:#fff!important}.primary-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.dark-theme .primary-btn{background:var(--primary);box-shadow:0 4px 15px #d4af3733;color:var(--bg-dark)!important}.dark-theme .primary-btn:hover{background:var(--primary);filter:brightness(1.2);box-shadow:0 6px 20px #d4af374d}.section-header{justify-content:space-between;align-items:center;margin-bottom:25px;display:flex}.title-area{align-items:center;gap:15px;display:flex}.count-badge{color:var(--primary);text-transform:uppercase;letter-spacing:1px;background:#b8860b1a;border:1px solid #b8860b33;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:700}.section-header h2{letter-spacing:.5px;font-size:24px}.tab-content{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:400px;padding:40px;display:flex}.placeholder-content{color:var(--text-muted);flex-direction:column;align-items:center;gap:20px;display:flex}.dash-overview{flex-direction:column;gap:20px;display:flex}.dash-kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.dash-kpi-card{align-items:flex-start;gap:14px;padding:20px;transition:transform .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden}.dash-kpi-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #00000026}.dash-kpi-card:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#d4af370f,#0000);width:100px;height:100px;position:absolute;top:0;right:0}.dash-kpi-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.dash-kpi-body{flex-direction:column;flex:1;min-width:0;padding-right:75px;display:flex}.dash-kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;text-overflow:ellipsis;padding-right:4px;font-size:11px;font-weight:700;overflow:hidden}.dash-kpi-value{margin-top:2px;font-size:26px;font-weight:800;line-height:1.2}.dash-kpi-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.dash-kpi-trend{text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:10px;font-weight:800;display:flex;position:absolute;top:14px;right:14px;box-shadow:0 2px 8px #0000000d}.dash-kpi-trend.up{color:#10b981;background:#10b9811a}.dash-kpi-trend.warn{color:#f59e0b;background:#f59e0b1a}.dash-charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-chart-card{flex-direction:column;padding:22px;display:flex}.dash-chart-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.dash-chart-header h3{margin:0;font-size:16px;font-weight:700}.dash-chart-header p{color:var(--text-muted);margin:2px 0 0;font-size:12px}.dash-chart-legend{color:var(--text-muted);gap:14px;font-size:11px;font-weight:600;display:flex}.dash-chart-legend span{align-items:center;gap:5px;display:flex}.dash-chart-legend .dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dash-chart-body{flex:1;min-height:260px}.dash-bottom-row{grid-template-columns:1fr 1fr 1.4fr;gap:16px;display:grid}.dash-today-card{flex-direction:column;padding:22px;display:flex}.dash-today-body{flex-direction:column;flex:1;align-items:center;gap:20px;padding-top:10px;display:flex}.dash-ring-container{width:130px;height:130px;position:relative}.dash-ring{width:100%;height:100%;transform:rotate(-90deg)}.dash-ring-text{text-align:center;flex-direction:column;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dash-ring-pct{font-size:28px;font-weight:800;line-height:1}.dash-ring-label{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:600}.dash-today-stats{gap:16px;width:100%;display:flex}.dash-today-stat{border:1px solid var(--glass-border);background:#ffffff05;border-radius:10px;flex:1;align-items:center;gap:8px;padding:10px;display:flex}.dash-today-stat div{flex-direction:column;display:flex}.dash-today-stat strong{font-size:16px;font-weight:800}.dash-today-stat span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.dash-recent-card{flex-direction:column;padding:22px;display:flex}.dash-view-all{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:700;transition:background .2s;display:flex}.dash-view-all:hover{background:#d4af371a}.dash-recent-list{flex-direction:column;flex:1;gap:8px;display:flex;overflow-y:auto}.dash-recent-item{border:1px solid var(--glass-border);background:#ffffff05;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;transition:all .2s;display:flex}.dash-recent-item:hover{background:#d4af370a;transform:translate(3px)}.dash-recent-avatar{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:flex}.dash-recent-info{flex-direction:column;flex:1;min-width:0;display:flex}.dash-recent-info strong{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.dash-recent-info span{color:var(--text-muted);font-size:11px}.dash-recent-right{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.dash-recent-amt{font-size:14px;font-weight:800}.dash-status-dot{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:2px 8px;font-size:9px;font-weight:700}.dash-status-dot.approved{color:#10b981;background:#10b9811a}.dash-status-dot.pending{color:#f59e0b;background:#f59e0b1a}.dash-status-dot.rejected{color:#ef4444;background:#ef44441a}.recharts-default-tooltip{display:none!important}@media (width<=1024px){.sidebar{width:240px}.main-content{width:calc(100% - 260px);margin-left:260px}.dash-charts-row,.dash-bottom-row{grid-template-columns:1fr}}@media (width<=768px){.admin-container{flex-direction:column;display:flex}.sidebar{border-radius:0;width:100%;height:auto;margin:0;position:static}.main-content{width:100%;margin-left:0}.logo-section{padding:5px 0}.nav-menu{flex-direction:row;padding:10px;overflow-x:auto}.menu-group{flex-shrink:0}.sub-menu{display:none}.dash-kpi-row{grid-template-columns:1fr 1fr}}.student-list-container{flex-direction:column;gap:20px;padding-bottom:120px;animation:.4s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.filter-actions{gap:12px;display:flex}.page-size-selector{color:var(--text-muted);align-items:center;gap:10px;margin-right:15px;font-size:13px;display:flex}.page-size-selector select{border:1px solid var(--glass-border);color:var(--secondary);cursor:pointer;background:#ffffff0d;border-radius:8px;outline:none;padding:4px 8px}.filter-btn,.refresh-btn{cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:600;display:flex}.filter-btn{border:1px solid var(--glass-border);color:var(--text-muted);background:0 0}.refresh-btn{background:var(--primary);color:#fff;border:none}.table-wrapper{padding:0;position:relative;overflow:visible!important}.student-table{border-collapse:collapse;text-align:left;width:100%}.student-table th{color:var(--secondary);text-transform:uppercase;letter-spacing:1px;background:#ffffff0d;padding:18px 20px;font-size:13px;font-weight:700}.student-table td{border-bottom:1px solid var(--glass-border);color:var(--secondary);padding:16px 20px;font-size:14px}.student-table tr:hover{background:#ffffff05}.student-thumb{width:36px;height:36px;color:var(--secondary);background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;display:flex;overflow:hidden}.std-id{color:var(--secondary);font-family:Courier New,Courier,monospace;font-weight:700}.std-name{font-weight:600}.contact-cell{color:var(--text-muted);align-items:center;gap:8px;display:flex}.batch-badge{color:var(--primary);background:#8b233a1a;border:1px solid #8b233a33;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;display:inline-flex}.action-btn{background:var(--bg-dark);border:1px solid var(--glass-border);cursor:pointer;z-index:5;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:all .2s;box-shadow:0 2px 5px #0000000d;color:#801e1d!important;outline:none!important;display:flex!important}.action-btn svg{stroke-width:2.5px;pointer-events:none;stroke:#801e1d!important;display:block!important}.action-btn:hover{border-color:var(--primary);background:#b8860b1a}.action-btn.active{border-color:var(--primary);box-shadow:0 4px 10px #b8860b4d;background:var(--primary)!important;color:#fff!important}.action-btn.active svg{stroke:#fff!important}.action-dropdown{z-index:1000;background:var(--bg-card);border:1px solid #8b233a33;border-radius:12px;flex-direction:column;width:170px;padding:10px;display:flex;position:absolute;top:45px;right:0;box-shadow:0 15px 50px #0006}.dropdown-item{color:var(--text-muted);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.dropdown-item svg{opacity:.8}.loading-cell,.empty-cell{text-align:center;color:var(--text-muted);font-style:italic;padding:60px!important}.pag-btn,.page-num{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.pag-btn:disabled{opacity:.3;cursor:not-allowed}.pag-btn:not(:disabled):hover,.page-num:hover{color:var(--secondary);background:#801e1d0d}.page-num.active{background:var(--secondary);border-color:var(--secondary);color:#fff}.approval-modal{border-radius:20px;flex-direction:column;width:550px;padding:0;display:flex;overflow:hidden;box-shadow:0 20px 40px #0003;background:var(--bg-card)!important}.modal-top{background:#801e1d05;border-bottom:1px solid #801e1d0d;padding:30px}.modal-top h3{color:var(--secondary);justify-content:center;align-items:center;gap:12px;font-size:20px;display:flex}.modal-top p{color:var(--text-muted);margin-top:5px;font-size:13px}.student-summary-box{background:var(--bg-contrast);border-bottom:1px solid #b8860b1a;flex-direction:column;gap:15px;padding:20px 30px;display:flex}.summary-row{justify-content:space-between;gap:20px;display:flex}.summary-item{text-align:left;flex:1}.summary-item label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:10px;display:block}.summary-item strong{color:var(--secondary);font-size:15px}.summary-item p{margin:0;font-size:14px;font-weight:500}.approval-form-grid{grid-template-columns:1fr 1fr;gap:20px;padding:30px;display:grid}.batch-selector-group{text-align:left;flex-direction:column;gap:8px;display:flex}.batch-selector-group label{color:var(--secondary);font-size:12px;font-weight:700}.batch-selector-group select,.fee-input-wrapper input{background:var(--bg-dark);color:var(--secondary);border:1px solid #801e1d33;border-radius:8px;outline:none;width:100%;padding:12px;font-size:14px}.fee-input-wrapper{align-items:center;display:flex;position:relative}.fee-input-wrapper span{color:var(--secondary);font-weight:700;position:absolute;left:12px}.fee-input-wrapper input{padding-left:30px}.modal-actions{gap:15px;padding:20px 30px 30px;display:flex}.btn-cancel{background:var(--bg-dark);color:var(--secondary);cursor:pointer;border:1px solid #801e1d33;border-radius:10px;flex:1;padding:14px;font-weight:600}.btn-approve{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:2;padding:14px;font-weight:700;box-shadow:0 4px 12px #801e1d33}.btn-approve:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.details-modal{background:var(--bg-dark);border:1px solid var(--glass-border);border-radius:24px;flex-direction:column;width:100%;max-width:900px;max-height:90vh;display:flex;position:relative;overflow:hidden}.dark-theme .details-modal{background:#1a1d27}.modal-header{background:var(--bg-dark);border-bottom:1px solid var(--glass-border)}.dark-theme .modal-header{background:#1a1d27}.close-btn{background:var(--bg-contrast);color:var(--secondary);cursor:pointer;z-index:10;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .3s;display:flex;position:absolute;top:20px;right:20px}.dark-theme .close-btn{background:#252836}.close-btn:hover{background:var(--secondary);color:#fff}.profile-hero{background:var(--bg-dark);border-bottom:none;align-items:center;gap:25px;padding:40px;display:flex}.dark-theme .profile-hero{background:#1a1d27}.large-avatar{background:var(--bg-contrast);border:1px solid var(--glass-border);width:100px;height:100px;color:var(--secondary);border-radius:24px;justify-content:center;align-items:center;display:flex;overflow:hidden}.dark-theme .large-avatar{background:#252836}.large-avatar img{object-fit:cover;width:100%;height:100%}.hero-meta h2{color:var(--secondary);margin:0;font-size:28px}.id-badge{background:var(--secondary);border-radius:6px;margin-right:10px;padding:2px 10px;font-family:monospace;font-size:14px;font-weight:800;display:inline-block;color:#fff!important}.dark-theme .id-badge{border:1px solid var(--glass-border);background:#252836;color:var(--primary)!important}.status-tag{text-transform:uppercase;letter-spacing:1px;color:#4ade80;font-size:11px;font-weight:700}.modal-content{flex:1;padding:40px;overflow-y:auto}.details-grid{grid-template-columns:repeat(2,1fr);gap:40px;display:grid}.detail-section{flex-direction:column;gap:15px;display:flex}.detail-section.full-width{grid-column:1/-1}.detail-section h3{color:var(--secondary);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:10px;margin-bottom:5px;font-size:15px;display:flex}.dark-theme .detail-section h3{color:var(--primary)}.info-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;display:grid}.info-item{flex-direction:column;gap:4px;display:flex}.info-item label{color:var(--text-muted);text-transform:uppercase;font-size:11px}.info-item span{color:var(--secondary);font-size:14px;font-weight:500}.contact-links{gap:20px;margin-top:10px;display:flex}.link-item{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.experience-box,.emergency-contact,.admin-notes,.address-display{background:var(--bg-contrast);border:1px solid var(--glass-border);border-radius:12px;padding:15px}.dark-theme .experience-box,.dark-theme .emergency-contact,.dark-theme .admin-notes,.dark-theme .address-display{background:#252836}.experience-box label,.emergency-contact label,.admin-notes label{color:var(--text-muted);margin-bottom:6px;font-size:11px;display:block}.experience-box p,.emergency-contact p,.admin-notes p,.address-display p{color:var(--secondary);margin:0;font-size:14px}.address-display p{margin:0 0 4px;font-size:15px}.address-display span{color:var(--text-muted);font-size:13px}.permission-chips{flex-wrap:wrap;gap:10px;display:flex}.chip{background:var(--bg-contrast);color:var(--text-muted);border:1px solid var(--glass-border);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;display:flex}.dark-theme .chip{background:#252836}.chip.active{color:#4ade80;background:#4ade801a;border-color:#4ade8033}.admin-notes{margin-top:40px}.admin-notes small{opacity:.6;margin-top:10px;font-style:italic;display:block}@media (width<=768px){.details-grid{grid-template-columns:1fr}}.edit-modal{background:var(--bg-dark);border-radius:16px;flex-direction:column;width:100%;max-width:700px;max-height:85vh;padding:0;display:flex;overflow:hidden;box-shadow:0 20px 50px #0003}.dark-theme .edit-modal{background:#1a1d27}.edit-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:25px 30px;display:flex;position:relative}.edit-header h2{color:var(--secondary);margin:0;font-size:20px}.close-btn{cursor:pointer;width:32px;height:32px;color:var(--text-muted);z-index:10;background:#0000000d;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:20px;right:20px}.close-btn:hover{color:#ff4d4d;background:#ff4d4d1a;transform:scale(1.05)}.edit-form{background:var(--bg-dark);flex:1;padding:30px;overflow-y:auto}.dark-theme .edit-form{background:#1a1d27}.locked-section{background:var(--bg-contrast);border:1px dashed var(--glass-border);border-radius:12px;margin-bottom:20px;padding:12px 18px}.dark-theme .locked-section{background:#1e2130}.modal-section-title{text-transform:uppercase;color:var(--secondary);letter-spacing:.5px;align-items:center;gap:8px;margin-bottom:15px;font-size:10px;font-weight:700;display:flex}.locked-grid{justify-content:space-between;gap:20px;display:flex}.locked-item{flex-direction:column;gap:4px;display:flex}.locked-item label{color:var(--text-label);font-size:10px}.locked-item span{color:var(--secondary);opacity:.7;font-size:13px;font-weight:700}.edit-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.field-group{flex-direction:column;gap:8px;display:flex}.field-group.full-width{grid-column:1/-1}.field-group label{color:var(--text-label);font-size:12px;font-weight:600}.field-group input,.field-group select,.field-group textarea{background:var(--bg-contrast);border:1px solid var(--glass-border);color:var(--text-input);border-radius:10px;outline:none;padding:12px 16px;font-size:14px}.dark-theme .field-group input,.dark-theme .field-group select,.dark-theme .field-group textarea{background:#252836}.field-group textarea{resize:vertical;min-height:80px}.field-group input:focus{border-color:var(--secondary)}.section-divider{color:var(--secondary);border-bottom:1px solid var(--glass-border);grid-column:1/-1;margin:30px 0 10px;padding-bottom:10px;font-size:13px;font-weight:700}.checkbox-group{grid-column:1/-1;align-items:center;gap:12px;margin-top:10px;display:flex}.checkbox-group input{cursor:pointer;width:18px;height:18px;accent-color:var(--secondary)}.edit-footer{border-top:1px solid var(--glass-border);justify-content:flex-end;gap:15px;padding:25px 30px;display:flex}.btn-cancel{border:1px solid var(--glass-border);color:var(--secondary);cursor:pointer;background:0 0;border-radius:10px;padding:12px 24px}.btn-save{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:10px;padding:12px 28px;font-weight:600;display:flex}.enroll-wrapper{max-width:1000px;min-height:600px;margin:10px auto;padding:60px 40px 40px;position:relative;overflow:visible!important}.step-indicator{justify-content:space-between;align-items:center;height:40px;margin-bottom:50px;padding:0 40px;display:flex}.step-dot{border:2px solid var(--glass-border);width:40px;min-width:40px;height:40px;color:var(--text-muted);z-index:2;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-weight:700;transition:all .3s;display:flex;position:relative}.step-label{white-space:nowrap;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);font-size:11px;font-weight:700;position:absolute;top:45px;left:50%;transform:translate(-50%)}.step-line{background:var(--glass-border);z-index:1;flex:1;height:2px;margin:0}.enroll-form{margin-top:20px}.form-page h3{border-bottom:1px solid var(--glass-border);color:var(--primary);align-items:center;gap:12px;margin-bottom:35px;padding-bottom:15px;font-size:20px;display:flex}.enroll-wrapper .form-grid{text-align:left;grid-template-columns:repeat(2,1fr);gap:40px 30px;display:grid}.enroll-wrapper .input-group{text-align:left;flex-direction:column;gap:10px;display:flex;position:relative}.input-group.full-width{grid-column:1/-1}.enroll-wrapper .input-group label{color:var(--text-label);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;padding-left:2px;font-size:13px;font-weight:700;display:block}.input-group input,.input-group select,.input-group textarea{border:1px solid var(--glass-border);color:var(--text-input);background:#ffffff05;border-radius:12px;outline:none;width:100%;padding:14px 18px;font-size:14px;transition:all .3s}.input-group input::placeholder,.input-group textarea::placeholder{color:var(--text-placeholder)}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:var(--primary);background:#ffffff0f}.input-group.has-error input,.input-group.has-error select,.input-group.has-error textarea{border-color:var(--form-error)!important}.input-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23a0a0a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 15px center;background-repeat:no-repeat;background-size:16px}.section-divider{border-left:4px solid var(--primary);color:var(--primary);text-transform:uppercase;letter-spacing:2px;background:linear-gradient(90deg,#b8860b1a,#0000);grid-column:1/-1;margin:40px 0 15px;padding:12px 24px;font-size:14px;font-weight:700}.photo-upload{align-items:flex-start}.photo-placeholder{cursor:pointer;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:120px;height:120px;transition:all .3s;display:flex;border:2px dashed var(--glass-border)!important}.photo-placeholder:hover{background:#ffffff0d;border-color:var(--primary)!important}.photo-placeholder.has-photo{padding:0;overflow:hidden;border:1px solid var(--primary)!important}.photo-preview-img{object-fit:cover;width:100%;height:100%}.form-footer{border-top:1px solid var(--glass-border);justify-content:space-between;margin-top:60px;padding-top:40px;display:flex}.btn-next,.btn-submit{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .3s;display:flex;background:var(--secondary)!important;color:#fff!important}.btn-back{background:var(--bg-contrast);color:var(--secondary);border:1px solid var(--glass-border);cursor:pointer;border-radius:12px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .3s}.btn-next:hover,.btn-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #801e1d33}.btn-back:hover{background:#fdf2d0}@media (width<=768px){.form-grid{grid-template-columns:1fr}.progress-container{padding:0 20px}}.add-teacher-container{max-width:1000px;margin:0 auto;padding:40px}.step-dot{color:var(--text-placeholder);border:2px solid var(--glass-border);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;transition:all .3s;display:flex;position:relative}.step-dot.active{border-color:var(--secondary);color:var(--secondary);background:#d4af370d}.step-dot.active .step-label{opacity:1;color:var(--secondary)}.teacher-form{flex-direction:column;flex:1;display:flex}.page-title{color:var(--secondary);border-bottom:1px solid var(--glass-border);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:10px;font-size:18px;font-weight:700;display:flex}.add-teacher-container .form-grid{grid-template-columns:repeat(2,1fr);gap:15px 25px;display:grid}.input-field{margin-bottom:5px}.add-teacher-container .input-field label{color:var(--text-label);text-align:left;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px;font-size:11px;font-weight:800}.input-field input::placeholder,.input-field textarea::placeholder{color:var(--text-placeholder);font-size:13px}.input-field input:focus,.input-field select:focus,.input-field textarea:focus{border-color:var(--secondary);background:#fff}.dark-theme .input-field input:focus,.dark-theme .input-field select:focus,.dark-theme .input-field textarea:focus{border-color:var(--primary);background:#252836}.input-field.has-error input,.input-field.has-error select,.input-field.has-error textarea{background:#ff8a7505;border-color:var(--form-error)!important}.checkbox-wrap{flex-wrap:wrap;gap:8px;display:flex}.chip-checkbox{cursor:pointer}.chip-checkbox input{display:none}.chip-checkbox span{border:1px solid var(--glass-border);color:var(--text-label);background:#ffffff0d;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s}.chip-checkbox input:checked+span{background:var(--secondary);color:#fff;border-color:var(--secondary)}.section-divider{color:var(--text-label);text-transform:uppercase;letter-spacing:1px;opacity:.6;border-bottom:1px dashed var(--glass-border);grid-column:1/-1;margin:15px 0 5px;padding-bottom:5px;font-size:11px;font-weight:900}.form-navigation{border-top:1px solid var(--glass-border);gap:15px;margin-top:30px;padding-top:20px;display:flex}.btn-prev{border:1px solid var(--glass-border);color:var(--text-label);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:flex}.btn-next,.btn-submit{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 30px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.btn-submit{background:var(--primary)}.btn-next:hover,.btn-submit:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-next:disabled,.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.dark-theme .modal-header,.dark-theme .modal-footer,.dark-theme .details-modal{background:#1a1d27!important}.teacher-list-container{flex-direction:column;gap:20px;animation:.4s fadeIn;display:flex}.tr-name-cell{align-items:center;gap:15px;display:flex}.tr-name{font-size:14px;font-weight:600}.teacher-thumb{width:38px;height:38px;color:var(--secondary);border:1px solid var(--glass-border);background:#ffffff0d;border-radius:10px;justify-content:center;align-items:center;display:flex;overflow:hidden}.teacher-thumb img{object-fit:cover;width:100%;height:100%}.contact-info,.time-info{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.style-badge{color:var(--secondary);background:#d4af370d;border:1px solid #d4af371a;border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:12px;display:inline-flex}.type-tag{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:700}.status-pill{text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:800}.status-pill.active{color:#4ade80;background:#4ade801a}.status-pill.inactive{color:#ef4444;background:#ef44441a}.status-pill.on{color:#fbbf24;background:#fbbf241a}.list-controls{justify-content:space-between;align-items:center;padding:15px 25px;display:flex}.search-box{border:1px solid var(--glass-border);background:#ffffff08;border-radius:12px;align-items:center;gap:12px;width:350px;padding:10px 18px;display:flex}.search-box input{color:#fff;background:0 0;border:none;outline:none;width:100%}.filter-actions{align-items:center;gap:20px;display:flex}.page-size-selector{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:flex}.page-size-selector select{border:1px solid var(--glass-border);color:var(--secondary);background:#ffffff0d;border-radius:8px;outline:none;padding:4px 8px}.refresh-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600}.table-wrapper{overflow:hidden}.teacher-table{border-collapse:collapse;width:100%}.teacher-table th{color:var(--secondary);text-transform:uppercase;letter-spacing:1px;text-align:left;background:#ffffff0d;padding:18px 20px;font-size:12px}.teacher-table td{border-bottom:1px solid var(--glass-border);color:#fff;padding:16px 20px;font-size:14px}.teacher-table tr:hover{background:#ffffff05}.action-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:8px;transition:all .2s}.action-btn:hover,.action-btn.active{color:#fff;background:#ffffff0d}.relative{position:relative}.action-dropdown{z-index:100;width:160px;box-shadow:var(--shadow-lg);border:1px solid var(--glass-border);flex-direction:column;padding:8px;display:flex;position:absolute;top:40px;right:20px}.dropdown-item{color:var(--text-muted);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:13px;display:flex}.dropdown-item:hover{color:var(--secondary);background:#ffffff0d}.pagination-footer{justify-content:space-between;align-items:center;margin-top:10px;padding:12px 20px;display:flex}.page-numbers{gap:8px;display:flex}.pag-btn,.page-num{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-size:13px}.pag-btn:disabled{opacity:.3}.page-num.active{background:var(--primary);color:#fff}.loading-cell,.empty-cell{text-align:center;color:var(--text-muted);padding:60px}.create-batch-container{flex-direction:column;max-width:900px;min-height:700px;margin:0 auto;padding:40px;display:flex}.step-indicator{justify-content:space-between;align-items:center;margin-bottom:60px;padding:0 40px;display:flex}.step-dot{border:2px solid var(--glass-border);width:34px;height:34px;color:var(--text-muted);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;font-weight:700;transition:all .3s;display:flex;position:relative}.step-dot.active{border-color:var(--secondary);color:var(--secondary);box-shadow:0 0 15px #d4af3733}.step-dot.completed{background:var(--secondary);border-color:var(--secondary);color:#fff}.step-label{white-space:nowrap;text-transform:uppercase;letter-spacing:1px;opacity:.6;font-size:11px;font-weight:700;position:absolute;top:45px;left:50%;transform:translate(-50%)}.step-dot.active .step-label{opacity:1}.step-line{background:var(--glass-border);flex:1;height:2px;margin:0 10px;transform:translateY(-8px)}.step-line.completed{background:var(--secondary)}.batch-form{flex-direction:column;flex:1;display:flex}.page-title{color:var(--secondary);border-bottom:1px solid var(--glass-border);align-items:center;gap:12px;margin-bottom:30px;padding-bottom:15px;font-size:22px;display:flex}.form-grid{grid-template-columns:repeat(2,1fr);gap:25px;display:grid}.full-width{grid-column:1/-1}.input-field{flex-direction:column;gap:8px;display:flex}.input-field label{color:var(--text-label);text-align:left;font-size:13px;font-weight:600}.input-field input,.input-field select,.input-field textarea{border:1px solid var(--glass-border);color:var(--text-input);background:#801e1d08;border-radius:12px;outline:none;padding:14px 18px;font-size:14px;transition:all .3s}.dark-theme .input-field input,.dark-theme .input-field select,.dark-theme .input-field textarea{background:#ffffff0d}.dark-theme .input-field select option{background-color:var(--bg-card);color:var(--text-input)}.input-field input::placeholder,.input-field textarea::placeholder{color:var(--text-placeholder)}.input-field input:focus,.input-field select:focus,.input-field textarea:focus{border-color:var(--secondary);box-shadow:0 0 10px #d4af371a}.input-field.has-error input,.input-field.has-error select,.input-field.has-error textarea{border-color:var(--form-error)!important}.error-message{color:var(--form-error);text-transform:lowercase;margin-top:4px;font-size:11px;font-weight:600;display:block}.checkbox-field{align-items:center;gap:12px;padding-top:25px;display:flex}.checkbox-field input{cursor:pointer;width:18px;height:18px}.form-navigation{border-top:1px solid var(--glass-border);margin-top:50px;padding-top:30px;display:flex}.btn-prev{border:1px solid var(--glass-border);color:var(--secondary);cursor:pointer;background:0 0;border-radius:12px;align-items:center;gap:10px;padding:12px 25px;display:flex}.btn-next,.btn-submit{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:10px;padding:14px 35px;font-weight:700;display:flex;box-shadow:0 4px 15px #d4af374d}.dark-theme .btn-next{background:var(--primary)!important;color:#000!important;box-shadow:0 4px 15px #0006!important}.btn-submit{background:var(--primary);color:#fff;box-shadow:0 4px 15px #8b233a4d}.dark-theme .btn-submit{background:var(--primary)!important;color:#000!important;box-shadow:0 4px 15px #0006!important}.flex-spacer{flex:1}.batch-list-container{flex-direction:column;gap:30px;display:flex}.list-header-row{justify-content:space-between;align-items:center;display:flex}.batch-list-container .search-bar{border:1px solid var(--glass-border);background:#ffffff08;border-radius:12px;align-items:center;gap:12px;width:400px;padding:12px 20px;display:flex}.batch-list-container .search-bar input{color:var(--secondary);background:0 0;border:none;outline:none;width:100%}.batch-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px;display:grid}.batch-card{flex-direction:column;gap:15px;padding:25px;transition:all .3s;display:flex;position:relative;overflow:hidden}.batch-card:hover{border-color:var(--secondary);transform:translateY(-5px);box-shadow:0 10px 30px #0003}.card-header{justify-content:space-between;align-items:center;display:flex}.batch-level-tag{text-transform:uppercase;letter-spacing:1px;color:var(--secondary);background:#d4af371a;border-radius:4px;padding:4px 10px;font-size:10px;font-weight:800}.status-dot{background:#ccc;border-radius:50%;width:8px;height:8px}.status-dot.active{background:#4ade80;box-shadow:0 0 10px #4ade8055}.status-dot.upcoming{background:#fbbf24}.status-dot.full{background:#ef4444}.batch-name{color:var(--secondary);margin:5px 0 0;font-size:18px}.dance-type{color:var(--text-muted);margin:0;font-size:13px}.batch-info-grid{grid-template-columns:1fr 1fr;gap:20px;margin:10px 0;display:grid}.info-item{align-items:flex-start;gap:10px;display:flex}.icon-gold{color:var(--secondary);margin-top:2px}.info-text label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:2px;font-size:10px;display:block}.info-text p{color:var(--secondary);margin:0;font-size:13px;font-weight:600}.dark-theme .primary-btn{font-weight:700;background:var(--primary)!important;color:var(--bg-dark)!important;box-shadow:0 4px 15px #d4af3733!important}.dark-theme .primary-btn:hover{filter:brightness(1.2);transform:translateY(-2px)}.batch-progress-stats{margin:10px 0}.progress-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.progress-track{background:#801e1d0d;border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#d4af37,#b8860b);border-radius:3px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.card-footer{border-top:1px solid var(--glass-border);flex-direction:column;gap:15px;margin-top:auto;padding-top:20px;display:flex}.capacity-bar{background:#ffffff0d;border-radius:3px;width:100%;height:6px;overflow:hidden}.capacity-fill{background:linear-gradient(90deg, var(--primary), var(--secondary));height:100%;transition:width .5s}.view-btn{background:var(--bg-contrast);border:1px solid var(--glass-border);width:100%;color:var(--secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:10px;padding:10px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.loading-state,.empty-state{text-align:center;color:var(--text-muted);padding:100px}.empty-state{flex-direction:column;align-items:center;gap:15px;display:flex}.view-btn:hover{background:var(--secondary);color:#fff;border-color:var(--secondary)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#801e1d66;justify-content:center;align-items:flex-start;padding:40px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.batch-detail-modal,.add-member-modal{border:1px solid var(--secondary);border-radius:24px;flex-direction:column;width:100%;max-width:800px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 25px 50px #801e1d33;background:var(--bg-card)!important}.dark-theme .batch-detail-modal,.dark-theme .add-member-modal{border-color:var(--glass-border);box-shadow:0 25px 50px #00000080}.add-member-modal{max-width:500px}.modal-header{border-bottom:1px solid #801e1d1a;justify-content:space-between;align-items:center;padding:20px 30px;display:flex}.header-actions{gap:15px;display:flex}.action-btn{cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.action-btn.edit{border:1px solid var(--secondary);color:var(--secondary);background:0 0}.action-btn.add{background:var(--secondary)!important;border:1px solid var(--secondary)!important;color:#fff!important}.action-btn.add svg{color:#fff!important}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:5px}.modal-body{flex:1;padding:40px;overflow-y:auto}.detail-hero{text-align:center;margin-bottom:40px}.level-badge{color:var(--primary);text-transform:uppercase;letter-spacing:1px;background:#b8860b1a;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:800}.detail-hero h2{color:var(--secondary);margin:15px 0 5px;font-size:32px}.dance-info{color:var(--text-muted);font-size:14px}.detail-grid{grid-template-columns:repeat(3,1fr);gap:30px;display:grid}.detail-item{text-align:center;flex-direction:column;align-items:center;display:flex}.detail-item label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:10px;display:block}.detail-item p{color:var(--secondary);margin:0;font-size:18px;font-weight:700}.detail-item p.syllabus-text{color:var(--text-muted);max-width:250px;margin:0 auto;font-size:13px;font-weight:600;line-height:1.5}.available-tag{color:var(--primary);margin-top:4px;font-size:11px;font-weight:600;display:block}.progress-mini{background:#801e1d0d;border-radius:2px;height:4px;margin-top:10px}.progress-mini .fill{background:var(--primary);border-radius:2px;height:100%}.student-selector-list{max-height:400px;padding:20px;overflow-y:auto}.student-select-card{background:#801e1d05;border:1px solid #0000;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:15px 20px;transition:all .2s;display:flex}.student-select-card:hover{border-color:var(--secondary);background:var(--bg-dark)}.student-meta{flex-direction:column;display:flex}.student-meta strong{color:var(--secondary);font-size:15px}.student-meta span{color:var(--text-muted);font-size:12px}.select-btn{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700}.no-students{text-align:center;color:var(--text-muted);padding:40px;font-size:14px}.edit-batch-form h3{color:var(--secondary);border-bottom:1px solid #801e1d1a;margin-bottom:25px;padding-bottom:15px;font-size:20px}.edit-batch-form .form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.edit-batch-form .form-group{flex-direction:column;gap:8px;display:flex}.edit-batch-form .form-group label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:11px;font-weight:700}.edit-batch-form .form-group input{color:var(--secondary);background:#801e1d05;border:1px solid #801e1d1a;border-radius:10px;outline:none;padding:12px 16px;font-size:14px;transition:all .2s}.edit-batch-form .form-group input:focus{border-color:var(--secondary);background:var(--bg-dark);box-shadow:0 0 0 4px #801e1d0d}.edit-actions{border-top:1px solid #801e1d1a;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:20px;display:flex}.edit-actions .cancel-btn{border:1px solid var(--text-muted);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:600}.edit-actions .save-btn{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 25px;font-size:13px;font-weight:700;transition:all .2s}.edit-actions .save-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.assigned-students-section{border-top:1px solid #801e1d1a;margin-top:40px;padding-top:30px}.section-header-mini{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-header-mini h4{color:var(--secondary);margin:0;font-size:18px}.section-header-mini .count{color:var(--secondary);background:#801e1d0d;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.students-table-mini{background:#801e1d03;border:1px solid #801e1d0d;border-radius:16px;overflow:hidden}.mini-table-header{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;background:#801e1d08;grid-template-columns:2fr 1fr 1fr 1fr;padding:12px 20px;font-size:11px;font-weight:700;display:grid}.mini-table-body{max-height:250px;overflow-y:auto}.mini-table-row{border-bottom:1px solid #801e1d0d;grid-template-columns:2fr 1fr 1fr 1fr;align-items:center;padding:15px 20px;transition:background .2s;display:grid}.mini-table-row:hover{background:#801e1d05}.mini-table-row:last-child{border-bottom:none}.name-col{flex-direction:column;display:flex}.name-col strong{color:var(--secondary);font-size:14px}.name-col small{color:var(--text-muted);font-size:11px}.id-col{color:var(--text-muted);font-family:monospace;font-size:13px}.phone-col{color:var(--text-muted);font-size:13px}.status-chip{text-transform:uppercase;border-radius:6px;padding:4px 10px;font-size:10px;font-weight:800}.status-chip.active{color:#166534;background:#4ade801a}.status-chip.pending{color:#92400e;background:#fbbf241a}.empty-mini{text-align:center;color:var(--text-muted);padding:40px;font-size:14px;font-style:italic}.transfer-interface{flex-direction:column;gap:20px;display:flex}.transfer-instructions{border-left:4px solid var(--secondary);background:#801e1d0d;border-radius:12px;padding:15px 20px}.transfer-instructions p{color:var(--secondary);margin:0;font-size:13px;font-weight:500}.student-selection-list{background:#801e1d05;border:1px solid #801e1d14;border-radius:16px;overflow:hidden}.student-selection-list .list-header{text-transform:uppercase;color:var(--text-muted);letter-spacing:1px;background:#801e1d0d;grid-template-columns:80px 1fr 120px;padding:12px 20px;font-size:11px;font-weight:800;display:grid}.student-selection-list .list-body{max-height:350px;overflow-y:auto}.selection-row{cursor:pointer;border-bottom:1px solid #801e1d0d;grid-template-columns:80px 1fr 120px;align-items:center;padding:15px 20px;transition:all .2s;display:grid}.selection-row:hover{background:#801e1d0d}.selection-row.selected{background:#b8860b14}.checkbox-col{justify-content:center;display:flex}.custom-checkbox{color:#fff;border:2px solid #801e1d33;border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex}.custom-checkbox.checked{background:var(--secondary);border-color:var(--secondary)}.details-col strong{color:var(--secondary);font-size:14px;display:block}.details-col small{color:var(--text-muted);font-size:12px}.glass-footer{background:#801e1d08;border:1px solid #801e1d1a;border-radius:16px;flex-direction:column;gap:20px;margin-top:20px;padding:25px;display:flex}.target-selection{align-items:center;gap:15px;display:flex}.target-selection label{color:var(--secondary);font-size:14px;font-weight:700}.target-select{background:var(--bg-dark);color:var(--secondary);border:1px solid #801e1d33;border-radius:10px;outline:none;flex:1;padding:12px 16px;font-size:14px}.footer-actions{justify-content:flex-end;gap:15px;display:flex}.transfer-btn{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:10px;padding:12px 25px;font-size:14px;font-weight:700;transition:all .2s;display:flex}.transfer-btn:disabled{opacity:.4;cursor:not-allowed}.transfer-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px)}.icon-btn-sm{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:all .2s;display:flex}.icon-btn-sm:hover{filter:brightness(1.2);transform:scale(1.1)}.batch-card-actions{gap:6px;margin-right:8px;display:flex}:root{--mds-gold:#b8860b;--mds-gold-light:#b8860b1a;--mds-maroon:maroon;--mds-bg-light:#fdfdfd;--success:#22c55e;--error:#ef4444;--warning:#f59e0b;--text-main:#2d3436;--text-muted:#636e72;--glass-bg:#ffffffb3;--glass-border:#fff6}.mds-premium{padding:10px;animation:.5s ease-out fadeIn}.page-header{margin-bottom:30px}.header-top{justify-content:space-between;align-items:center;margin-bottom:25px;display:flex}.title-mds{color:var(--text-main);letter-spacing:-.02em;font-size:2rem;font-weight:800}.subtitle-mds{color:var(--text-muted);margin-top:4px;font-size:.95rem}.header-actions{align-items:center;gap:15px;display:flex}.view-switcher{border-radius:12px;gap:4px;padding:4px;display:flex}.view-switcher button{color:var(--text-muted);border-radius:8px;padding:8px 12px;transition:all .2s}.view-switcher button.active{background:var(--bg-dark);color:var(--mds-gold);box-shadow:0 2px 8px #0000000d}.export-btn-premium{background:var(--mds-gold);color:#fff;border-radius:14px;align-items:center;gap:10px;padding:12px 24px;font-size:.9rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 15px #b8860b40}.export-btn-premium:hover{transform:translateY(-2px);box-shadow:0 6px 20px #b8860b59}.filter-bar-premium{border:1px solid var(--glass-border);border-radius:20px;justify-content:space-between;align-items:flex-end;padding:24px;display:flex}.filter-inputs{gap:35px;display:flex}.input-group input,.input-group select{color:var(--text-input);background:0 0;border:none;border-bottom:2px solid #0000000d;outline:none;min-width:150px;padding:6px 0;font-size:.95rem;font-weight:700}.filter-options{align-items:center;gap:30px;display:flex}.checkbox-premium{cursor:pointer;color:var(--text-main);align-items:center;gap:10px;font-size:.85rem;font-weight:600;display:flex}.apply-btn-premium{color:var(--text-main);background:#f1f2f6;border-radius:12px;align-items:center;gap:10px;padding:12px 25px;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.apply-btn-premium:hover{background:#e1e2e6}.kpi-container{grid-template-columns:repeat(3,1fr);gap:25px;margin-bottom:35px;display:grid}.kpi-card{border-radius:24px;align-items:center;gap:20px;padding:24px;display:flex}.kpi-icon{border-radius:18px;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.p-accent .kpi-icon{color:var(--success);background:#22c55e1a}.p-warning .kpi-icon{color:var(--error);background:#ef44441a}.p-total .kpi-icon{background:var(--mds-gold-light);color:var(--mds-gold)}.kpi-info{flex-direction:column;display:flex}.kpi-label{color:var(--text-muted);font-size:.85rem;font-weight:600}.kpi-value{color:var(--text-main);margin:4px 0;font-size:2.2rem;font-weight:800;line-height:1.1}.kpi-trend{font-size:.75rem;font-weight:700}.kpi-trend.positive{color:var(--success)}.kpi-trend.negative{color:var(--error)}.data-container{border-radius:28px;padding:30px}.data-header{justify-content:space-between;align-items:center;margin-bottom:25px;display:flex}.data-header h3{color:var(--text-main);font-size:1.2rem;font-weight:800}.data-search{border-radius:14px;align-items:center;gap:12px;width:300px;padding:10px 20px;display:flex}.data-search input{color:var(--text-main);background:0 0;border:none;outline:none;width:100%;font-size:.85rem}.mds-table{border-collapse:collapse;width:100%}.mds-table th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid #0000000d;padding:15px 20px;font-size:.7rem;font-weight:800}.mds-table td{vertical-align:middle;border-bottom:1px solid #00000008;padding:20px}.student-cell{align-items:center;gap:15px;display:flex}.avatar-mds{background:var(--mds-gold);color:#fff;border-radius:14px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1rem;font-weight:800;display:flex}.student-cell .info{flex-direction:column;display:flex}.student-cell .name{color:var(--text-main);font-weight:700}.student-cell .id{color:var(--text-muted);font-size:.75rem}.batch-pill{color:var(--text-muted);background:#f8f9fa;border-radius:10px;padding:6px 14px;font-size:.8rem;font-weight:700}.stats-cell{font-size:.9rem;font-weight:700}.p-val{color:var(--success)}.a-val{color:var(--error)}.divider{color:#ddd;margin:0 8px}.progress-cell{flex-direction:column;gap:8px;min-width:120px;display:flex}.progress-text{color:var(--text-main);font-size:1rem;font-weight:800}.progress-track{background:#f1f2f6;border-radius:10px;height:6px;overflow:hidden}.progress-fill{border-radius:10px;height:100%}.action-cell{gap:10px;display:flex}.icon-btn-mds{width:36px;height:36px;color:var(--text-muted);background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn-mds:hover{background:var(--mds-gold-light);color:var(--mds-gold)}.alert-row{background:#ef444405}.alert-row td:first-child{border-left:4px solid var(--error)}.empty-state-cell{text-align:center;color:var(--text-muted);font-style:italic;padding:60px!important}.events-container{padding:10px;animation:.5s ease-out fadeIn}.events-header{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.header-text h1{color:var(--text-main);align-items:center;gap:12px;margin-bottom:8px;font-size:2rem;font-weight:800;display:flex}.header-text p{color:var(--text-muted);font-size:1rem}.create-event-btn{background:var(--secondary);color:#121212;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:10px;padding:12px 24px;font-weight:700;transition:all .3s;display:flex;box-shadow:0 4px 15px #b8860b33}.create-event-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #b8860b4d}.events-controls{border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:30px;padding:16px 24px;display:flex}.filter-chips{gap:10px;display:flex}.filter-chip{color:var(--text-muted);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;padding:8px 20px;font-size:.9rem;font-weight:600;transition:all .3s}.filter-chip.active{background:var(--secondary);color:#121212;border-color:var(--secondary)}.search-box{color:var(--text-muted);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:12px;width:300px;padding:8px 16px;display:flex}.search-box input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-size:.9rem}.events-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px;display:grid}.event-card{border-radius:24px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.event-card:hover{border-color:#b8860b4d;transform:translateY(-8px);box-shadow:0 12px 30px #0000004d}.event-banner{height:180px;position:relative;overflow:hidden}.event-banner img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.event-card:hover .event-banner img{transform:scale(1.05)}.event-content{padding:24px}.event-main-info{gap:16px;margin-bottom:20px;display:flex}.poster-small{border:2px solid #ffffff1a;border-radius:8px;flex-shrink:0;width:60px;height:80px;overflow:hidden}.poster-small img{object-fit:cover;width:100%;height:100%}.title-section h3{color:var(--text-main);margin-bottom:6px;font-size:1.25rem;font-weight:700}.event-style{color:var(--secondary);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.event-details-grid{background:#ffffff05;border-radius:12px;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;padding:15px;display:grid}.detail-item{color:var(--text-muted);align-items:center;gap:10px;font-size:.85rem;display:flex}.detail-item svg{color:var(--secondary);opacity:.8}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.event-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:24px;font-size:.9rem;line-height:1.6;display:-webkit-box;overflow:hidden}.event-footer{border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:20px;display:flex}.price-tag{color:#4ade80;align-items:center;gap:8px;font-size:1.05rem;font-weight:700;display:flex}.seats-info{color:var(--text-muted);align-items:center;gap:8px;font-size:.8rem;font-weight:600;display:flex}.seats-info span.critical{color:#f87171}.view-details-btn{color:#fff;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .3s;display:flex}.view-details-btn:hover{border-color:var(--secondary);background:#ffffff1a}.icon-gold{color:var(--secondary)}@media (width<=1200px){.events-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}}@media (width<=768px){.events-controls{flex-direction:column;gap:20px}.search-box{width:100%}.filter-chips{width:100%;padding-bottom:5px;overflow-x:auto}}.loading-state,.empty-state{text-align:center;width:100%;color:var(--text-muted);flex-direction:column;grid-column:1/-1;justify-content:center;align-items:center;padding:100px 20px;display:flex}.loading-state svg{color:var(--secondary);margin-bottom:20px}.empty-state p{font-size:1.2rem;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;animation:.3s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.create-event-modal{background:#fff;border:1px solid #e0e0e0;border-radius:24px;flex-direction:column;width:100%;max-width:1000px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 25px 50px #0000001a}.modal-header{background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.header-title{align-items:center;gap:12px;display:flex}.header-title h2{color:#1a1a1a;margin:0;font-size:1.5rem;font-weight:700}.close-btn{color:#666;cursor:pointer;background:#f5f5f5;border:none;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex}.close-btn:hover{color:#fff;background:#f87171}.event-form{flex:1;padding:32px;overflow-y:auto}.form-grid{grid-template-columns:1fr 1.1fr;align-items:start;gap:40px;display:grid}.form-section{flex-direction:column;gap:20px;display:flex}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:#555;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.input-group label svg{color:var(--secondary)}.input-group input,.input-group select,.input-group textarea{color:#222;background:#fafafa;border:1px solid #ddd;border-radius:12px;outline:none;padding:12px 16px;font-size:.95rem;transition:all .3s}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:var(--secondary);background:#fff;box-shadow:0 0 0 4px #b8860b1a}.datepicker-input{color:#222;background:#fafafa;border:1px solid #ddd;border-radius:12px;outline:none;padding:12px 16px;font-size:.95rem;transition:all .3s;width:100%!important}.datepicker-input:focus{border-color:var(--secondary);background:#fff;box-shadow:0 0 0 4px #b8860b1a}.react-datepicker-wrapper{width:100%}.input-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.image-upload-sections{grid-template-columns:1.5fr 1fr;align-items:end;gap:16px;margin-bottom:5px;display:grid}.preview-container{cursor:pointer;background:#f9f9f9;border:2px dashed #ccc;border-radius:12px;height:140px;margin-top:8px;transition:all .3s;position:relative;overflow:hidden}.preview-container:hover{border-color:var(--secondary);background:#f0f0f0}.preview-container input{opacity:0;cursor:pointer;z-index:2;width:100%;height:100%;position:absolute;top:0;left:0}.upload-placeholder{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.upload-placeholder span{font-size:.8rem;font-weight:600}.preview-container img{object-fit:cover;width:100%;height:100%}.modal-actions{background:#fff;border-top:1px solid #f0f0f0;justify-content:flex-end;gap:16px;padding:24px 32px;display:flex}.cancel-btn{color:#666;cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:12px;padding:12px 28px;font-weight:600;transition:all .3s}.cancel-btn:hover{color:#333;background:#f5f5f5}.save-btn{background:var(--secondary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 32px;font-weight:700;transition:all .3s;box-shadow:0 4px 15px #b8860b26}.save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #b8860b40}@media (width<=768px){.form-grid{grid-template-columns:1fr;gap:30px}}.chat-container{background:var(--glass-bg);border:1px solid var(--glass-border);height:calc(100vh - 120px);box-shadow:var(--shadow-premium);border-radius:16px;gap:0;display:flex;overflow:hidden}.chat-batch-list{border-right:1px solid var(--glass-border);background:#f5f5f799;flex-direction:column;width:320px;min-width:320px;display:flex}.chat-batch-list .chat-list-header{border-bottom:1px solid var(--glass-border);padding:20px}.chat-batch-list .chat-list-header h2{align-items:center;gap:8px;margin:0 0 12px;font-size:18px;display:flex}.chat-search{position:relative}.chat-search input{border:1px solid var(--glass-border);box-sizing:border-box;background:#fff;border-radius:10px;outline:none;width:100%;padding:10px 12px 10px 36px;font-size:13px;transition:border-color .2s}.chat-search input:focus{border-color:var(--primary)}.chat-search .search-icon{color:#aaa;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.chat-batch-items{flex:1;padding:8px;overflow-y:auto}.batch-chat-item{cursor:pointer;border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:14px 12px;transition:all .2s;display:flex}.batch-chat-item:hover{background:#b8860b0f}.batch-chat-item.active{border-color:var(--primary);background:#b8860b1a}.batch-chat-avatar{background:linear-gradient(135deg, var(--secondary), var(--primary));color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:700;display:flex}.batch-chat-info{flex:1;min-width:0}.batch-chat-info .batch-name{color:var(--secondary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.batch-chat-info .last-msg{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.batch-chat-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.batch-chat-meta .time{color:var(--text-muted);font-size:11px}.batch-chat-meta .member-count{background:var(--bg-card);color:var(--secondary);border-radius:8px;padding:2px 6px;font-size:10px}.chat-window{background:#fff;flex-direction:column;flex:1;display:flex}.chat-window-empty{color:var(--text-muted);background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.chat-window-empty svg{opacity:.3}.chat-window-empty p{font-size:15px;font-weight:500}.chat-header{border-bottom:1px solid var(--glass-border);background:#f5f5f780;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chat-header-info{align-items:center;gap:12px;display:flex}.chat-header-info .avatar{background:linear-gradient(135deg, var(--secondary), var(--primary));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:700;display:flex}.chat-header-info .details h3{margin:0;font-size:15px}.chat-header-info .details span{color:var(--text-muted);font-size:12px}.chat-header-actions{gap:8px;display:flex}.chat-header-actions button{background:var(--bg-card);border:1px solid var(--glass-border);cursor:pointer;color:var(--secondary);border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.chat-header-actions button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.chat-messages{flex-direction:column;flex:1;gap:4px;padding:20px;display:flex;overflow-y:auto}.chat-messages .load-more-btn{background:var(--bg-card);border:1px solid var(--glass-border);cursor:pointer;color:var(--secondary);border-radius:20px;align-self:center;margin-bottom:12px;padding:6px 16px;font-size:12px;transition:all .2s}.chat-messages .load-more-btn:hover{background:var(--primary);color:#fff}.chat-date-separator{text-align:center;margin:16px 0 8px}.chat-date-separator span{background:var(--bg-card);color:var(--text-muted);border-radius:20px;padding:4px 14px;font-size:11px;font-weight:500}.chat-msg{gap:8px;max-width:75%;margin-bottom:2px;animation:.25s msgFadeIn;display:flex}@keyframes msgFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-msg.sent{flex-direction:row-reverse;align-self:flex-end}.chat-msg.received{align-self:flex-start}.msg-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:4px;font-size:11px;font-weight:700;display:flex}.msg-avatar.admin{background:var(--secondary)}.msg-avatar.teacher{background:var(--primary)}.msg-avatar.parent{background:#5b8c5a}.msg-content{flex-direction:column;display:flex}.msg-sender{margin-bottom:2px;padding:0 4px;font-size:11px;font-weight:600}.msg-sender.admin{color:var(--secondary)}.msg-sender.teacher{color:var(--primary)}.msg-sender.parent{color:#5b8c5a}.msg-bubble{word-break:break-word;border-radius:16px;padding:10px 14px;font-size:14px;line-height:1.5;position:relative}.chat-msg.sent .msg-bubble{background:linear-gradient(135deg, var(--secondary), #a62a28);color:#fff;border-bottom-right-radius:4px}.chat-msg.received .msg-bubble{background:var(--bg-card);color:var(--secondary);border-bottom-left-radius:4px}.msg-bubble.announcement{color:var(--secondary)!important;background:linear-gradient(135deg,#fff3cd,#fff8e1)!important;border:1px solid #b8860b4d!important}.msg-bubble .announcement-badge{color:var(--primary);text-transform:uppercase;align-items:center;gap:4px;margin-bottom:4px;font-size:10px;font-weight:700;display:inline-flex}.msg-reply-preview{border-left:3px solid var(--primary);color:var(--text-muted);background:#0000000d;border-radius:4px;margin-bottom:6px;padding:4px 8px;font-size:12px}.msg-attachment{margin-top:6px}.msg-attachment img{cursor:pointer;border-radius:8px;max-width:240px}.msg-attachment .file-link{color:var(--primary);background:#0000000d;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;text-decoration:none;display:inline-flex}.msg-time{color:var(--text-muted);margin-top:2px;padding:0 4px;font-size:10px}.chat-msg.sent .msg-time{text-align:right;color:#801e1d80}.msg-actions{display:none;position:absolute;top:-8px;right:-8px}.msg-bubble:hover .msg-actions{gap:2px;display:flex}.msg-actions button{border:1px solid var(--glass-border);cursor:pointer;width:24px;height:24px;color:var(--text-muted);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:flex;box-shadow:0 2px 6px #00000014}.msg-actions button:hover{color:var(--danger);border-color:var(--danger)}.chat-input-area{border-top:1px solid var(--glass-border);background:#f5f5f780;padding:16px 20px}.chat-reply-bar{background:var(--bg-card);border-left:3px solid var(--primary);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 12px;font-size:13px;display:flex}.chat-reply-bar .close-reply{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:16px}.chat-input-row{align-items:flex-end;gap:8px;display:flex}.chat-input-row .attach-btn,.chat-input-row .announce-btn{background:var(--bg-card);border:1px solid var(--glass-border);cursor:pointer;color:var(--secondary);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:10px;transition:all .2s;display:flex}.chat-input-row .announce-btn.active,.chat-input-row .attach-btn:hover,.chat-input-row .announce-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.chat-text-input{border:1px solid var(--glass-border);resize:none;background:#fff;border-radius:10px;outline:none;flex:1;min-height:42px;max-height:120px;padding:10px 14px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s}.chat-text-input:focus{border-color:var(--primary)}.chat-send-btn{background:linear-gradient(135deg, var(--secondary), var(--primary));cursor:pointer;color:#fff;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.chat-send-btn:hover{opacity:.9;transform:scale(1.02)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-members-panel{border-left:1px solid var(--glass-border);background:#f5f5f799;flex-direction:column;width:260px;min-width:260px;display:flex}.chat-members-panel .panel-header{border-bottom:1px solid var(--glass-border);padding:16px 20px}.chat-members-panel .panel-header h3{margin:0;font-size:14px}.chat-members-list{flex:1;padding:8px 12px;overflow-y:auto}.chat-member-item{border-radius:8px;align-items:center;gap:10px;padding:10px 8px;display:flex}.chat-member-item .member-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.chat-member-item .member-info{flex:1}.chat-member-item .member-info .member-name{color:var(--secondary);font-size:13px;font-weight:600}.chat-member-item .member-info .member-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}@media (width<=768px){.chat-container{flex-direction:column;height:calc(100vh - 80px)}.chat-batch-list{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--glass-border);max-height:200px}.chat-members-panel{display:none}}.dark-theme .chat-container{background:var(--bg-card)}.dark-theme .chat-batch-list{background:var(--bg-contrast)}.dark-theme .chat-search input{background:var(--bg-special);color:var(--secondary)}.dark-theme .chat-window,.dark-theme .chat-window-empty{background:var(--bg-card)}.dark-theme .chat-header,.dark-theme .chat-input-area{background:#ffffff08}.dark-theme .chat-msg.received .msg-bubble,.dark-theme .chat-text-input{background:var(--bg-special);color:var(--secondary)}.dark-theme .msg-bubble.announcement{color:var(--secondary)!important;background:linear-gradient(135deg,#2d2a1b,#1a1d27)!important;border-color:#d4af374d!important}.dark-theme .msg-reply-preview,.dark-theme .msg-attachment .file-link{background:#ffffff0d}.dark-theme .msg-actions button{background:var(--bg-special);color:var(--secondary)}.dark-theme .chat-members-panel{background:var(--bg-contrast)}.dark-theme .chat-date-separator span{background:var(--bg-special)}.dark-theme .batch-chat-item:hover{background:#d4af370f}.dark-theme .batch-chat-item.active{background:#d4af371a}.dark-theme .batch-chat-meta .member-count,.dark-theme .chat-reply-bar{background:var(--bg-special)}.dark-theme .msg-sender{opacity:.9}
