:root{--bg: #0d1a12;--surface: #111e17;--surface2: #162210;--surface3: #1c2b1e;--panel: #1a2b1d;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.04);--g900: #0b4d26;--g800: #0f6232;--g700: #147a3e;--g600: #1b9450;--g500: #22b160;--g400: #38cc78;--g300: #5fdb96;--g200: #96eab8;--g100: #d0f5e2;--gold: #c9a227;--gold-lt: #e8c547;--gold-pale: rgba(201,162,39,.12);--gold-glow: rgba(201,162,39,.25);--red: #e05050;--red-pale: rgba(224,80,80,.12);--amber: #e8973a;--amber-pale:rgba(232,151,58,.12);--blue: #4285e8;--blue-pale: rgba(66,133,232,.12);--purple: #9b72e0;--t1: #ffffff;--t2: #e0e9e4;--t3: #9fb2ab;--t4: #6d847a;--r: 14px;--r-sm: 8px;--r-xs: 6px;--sidebar-w: 240px;--topbar-h: 62px;--sh: 0 4px 24px rgba(0,0,0,.4);--sh-gold: 0 0 24px rgba(201,162,39,.15);--glass: blur(12px)}[data-theme=light]{--bg: #E0F7ED;--surface: #FFFFFF;--surface2: #F9FDFB;--surface3: #F0FDF9;--panel: #FFFFFF;--border: rgba(0,168,120,.12);--border2: rgba(0,168,120,.06);--g900: #004D38;--g800: #00664B;--g700: #00805E;--g600: #009970;--g500: #00A878;--g400: #10B981;--g300: #34D399;--g200: #A7F3D0;--g100: #D1FAE5;--gold: #FF9500;--gold-lt: #FFC107;--gold-pale: rgba(255,149,0,.1);--gold-glow: rgba(255,149,0,.2);--red: #EF4444;--red-pale: rgba(239,68,68,.1);--amber: #FF9500;--amber-pale:rgba(255,149,0,.1);--blue: #3B82F6;--blue-pale: rgba(59,130,246,.1);--purple: #8B5CF6;--t1: #1F2937;--t2: #4B5563;--t3: #6B7280;--t4: #9CA3AF;--sh: 0 4px 24px rgba(0,168,120,.08);--sh-gold: 0 0 24px rgba(255,149,0,.15);--glass: blur(12px) saturate(180%)}*{box-sizing:border-box;margin:0;padding:0}select option{background-color:var(--surface);color:var(--t1)}.hide-on-desktop{display:none}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:2999;cursor:pointer;will-change:opacity}.sidebar-overlay.active{display:block}html,body{height:100%;overflow-x:hidden}body{font-family:Be Vietnam Pro,sans-serif;background:var(--bg);color:var(--t1);display:flex;min-height:100vh;font-size:13.5px;font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sidebar{width:var(--sidebar-w);height:100dvh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:200;overflow:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden}.sidebar:before{content:"";position:absolute;top:-120px;left:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(27,148,80,.18) 0%,transparent 70%);pointer-events:none}.s-logo{display:flex;align-items:center;gap:10px;padding:18px 16px 16px;border-bottom:1px solid var(--border);position:relative;z-index:1}.s-logo-img{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:visible}.s-logo-img img{width:100%;height:100%;object-fit:contain}.s-logo-text b{display:block;color:var(--t1);font-size:12px;font-weight:800;letter-spacing:.4px}.s-logo-text small{color:var(--gold);font-size:8.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase}.s-nav{flex:1;padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:1px;position:relative;z-index:1}.s-nav::-webkit-scrollbar{display:none}.s-section{font-size:8.5px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--t4);padding:12px 8px 5px}.s-item{display:flex;align-items:center;gap:9px;padding:8.5px 10px;border-radius:var(--r-sm);color:var(--t3);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .18s;position:relative;text-decoration:none;-webkit-user-select:none;user-select:none}.s-item:hover{background:var(--surface3);color:var(--t2)}.s-item.active{background:var(--g800);color:#fff;box-shadow:0 4px 12px #0003}.s-item.active svg{color:var(--g300)}.s-item.active:before{display:none}.s-item svg{flex-shrink:0;width:16px;height:16px}.s-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:800;min-width:17px;height:17px;border-radius:9px;padding:0 4px;display:flex;align-items:center;justify-content:center}.s-badge.gold{background:var(--gold)}.s-footer{margin-top:auto;padding:10px;border-top:1px solid var(--border);position:relative;z-index:1;background:var(--surface)}.s-user{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-sm);background:var(--surface3);margin-bottom:6px;border:1px solid var(--border)}.s-av{width:32px;height:32px;border-radius:50%;flex-shrink:0;overflow:hidden;border:2px solid var(--g800);display:flex;align-items:center;justify-content:center;background:var(--g700);font-weight:900;font-size:13px;color:var(--g200)}.s-av img{width:100%;height:100%;object-fit:cover}.s-user-info b{display:block;color:var(--t1);font-size:11.5px}.s-user-info small{color:var(--gold);font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.s-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--r-sm);background:#3a1515;color:#ff8e8e;font-size:12px;font-weight:700;cursor:pointer;border:1px solid rgba(224,80,80,.2);transition:all .2s}.s-logout:hover{background:#501b1b;color:#fff}.page{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px;position:sticky;top:0;z-index:100}.topbar-brand{flex:1}.topbar-brand h1{font-size:19px;font-weight:800;color:var(--gold-lt);letter-spacing:.2px}.topbar-brand p{font-size:11px;color:var(--t2);margin-top:2px;font-weight:500;opacity:.7}.tb-sep{width:1px;height:28px;background:var(--border)}.tb-pill{display:flex;align-items:center;gap:6px;background:var(--surface3);border:1px solid var(--border);color:var(--t2);font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px}.tb-btn{width:36px;height:36px;border-radius:10px;border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;background:var(--surface3);border:1px solid var(--border);position:relative;transition:all .2s;color:var(--t2)}.tb-btn+.tb-btn{margin-left:6px}.tb-btn:hover{background:var(--surface2);border-color:var(--g600);color:#fff;transform:translateY(-1px)}.tb-btn:hover{background:var(--surface3);border-color:var(--g700)}.tb-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--surface)}.tb-av{width:34px;height:34px;border-radius:50%;background:var(--g700);overflow:hidden;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;color:var(--g200);cursor:pointer;border:2px solid var(--g600);transition:border-color .15s;flex-shrink:0}.tb-av:hover{border-color:var(--g400)}.tb-av img{width:100%;height:100%;object-fit:cover}.tb-user-info{text-align:right}.tb-user-info b{display:block;font-size:12px;color:var(--t1);font-weight:700}.tb-user-info small{color:var(--gold);font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.content{flex:1;padding:20px 24px 36px;display:flex;flex-direction:column;gap:18px}.view-section.hidden{display:none}.hero{background:radial-gradient(circle at 10% 20%,rgba(11,77,38,.4) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(201,162,39,.15) 0%,transparent 40%),linear-gradient(115deg,#052c1a,#084d2e);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:24px 36px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;overflow:hidden;animation:fadeUp .5s cubic-bezier(.16,1,.3,1) both;box-shadow:0 20px 50px #0006}.hero h2,.hero-left h2{color:#fff!important;text-shadow:0 2px 10px rgba(0,0,0,.4)}.hero-left p{color:#ffffffd9!important}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='1000' height='400' viewBox='0 0 1000 400' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M-100 400C100 300 400 400 600 200C800 0 1100 100 1100 100' stroke='%2322b160' stroke-opacity='0.15' stroke-width='2'/%3E%3Cpath d='M-100 350C150 250 450 350 650 150C850 -50 1150 50 1150 50' stroke='%2338cc78' stroke-opacity='0.1' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat center,radial-gradient(circle at 80% 20%,rgba(201,162,39,.08) 0%,transparent 50%);background-size:cover;pointer-events:none;filter:blur(.5px)}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;opacity:.4}.hero-kpis{display:flex;gap:14px;z-index:1;flex-shrink:0}.h-kpi{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:14px;padding:14px 22px;text-align:center;min-width:100px;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.h-kpi:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.h-kpi-val{font-size:24px;font-weight:900;color:#fff;line-height:1.1;font-variant-numeric:tabular-nums;letter-spacing:-.5px}.h-kpi-val.gold{color:var(--gold-lt);text-shadow:0 0 15px rgba(232,197,71,.3)}.h-kpi-lbl{font-size:10px;color:#ffffff80;margin-top:5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi{background:linear-gradient(135deg,var(--surface) 0%,rgba(30,41,59,.4) 100%);border:1px solid var(--border);box-shadow:inset 0 1px 1px #ffffff0d,0 4px 12px #00000026;border-radius:16px;padding:20px 22px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;animation:fadeUp .4s ease both;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s ease,border-color .3s ease;cursor:pointer}.kpi:hover{transform:translateY(-5px) scale(1.02);border-color:var(--g700);box-shadow:0 12px 32px #0006}.kpi:before{content:"";position:absolute;top:-50px;right:-50px;width:150px;height:150px;border-radius:50%;opacity:.7;pointer-events:none;filter:blur(15px)}.kpi.green:before{background:radial-gradient(circle,rgba(16,185,129,.3),transparent 70%)}.kpi.gold:before{background:radial-gradient(circle,rgba(251,191,36,.25),transparent 70%)}.kpi.red:before{background:radial-gradient(circle,rgba(239,68,68,.25),transparent 70%)}.kpi.blue:before{background:radial-gradient(circle,rgba(59,130,246,.25),transparent 70%)}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;z-index:2;position:relative}.kpi-ico{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:inset 0 1px #fff3,0 6px 12px #0003}.kpi.green .kpi-ico{background:#10b98133;border:1.5px solid rgba(16,185,129,.4);color:#10b981}.kpi.gold .kpi-ico{background:#fbbf2433;border:1.5px solid rgba(251,191,36,.4);color:#fbbf24}.kpi.red .kpi-ico{background:#ef444433;border:1.5px solid rgba(239,68,68,.4);color:#ef4444}.kpi.blue .kpi-ico{background:#3b82f633;border:1.5px solid rgba(59,130,246,.4);color:#3b82f6}.kpi-tag{font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;box-shadow:0 2px 5px #0000001a}.tag-up{color:#10b981;background:#10b98126;border:1px solid rgba(16,185,129,.3)}.tag-dn{color:#ef4444;background:#ef444426;border:1px solid rgba(239,68,68,.3)}.tag-neu{color:#3b82f6;background:#3b82f626;border:1px solid rgba(59,130,246,.3)}.tag-warn{color:#fbbf24;background:#fbbf2426;border:1px solid rgba(251,191,36,.3)}.kpi-val{font-size:34px;font-weight:900;color:var(--t1);line-height:1;font-variant-numeric:tabular-nums;z-index:2;position:relative;text-shadow:0 2px 10px rgba(0,0,0,.3)}.kpi.gold .kpi-val{color:var(--gold-lt)}.kpi.red .kpi-val{color:var(--red)}.kpi.green .kpi-val{color:#10b981}.kpi-lbl{font-size:13px;color:var(--t3);font-weight:600;margin-top:-2px;z-index:2;position:relative;letter-spacing:.5px}.main-grid{display:grid;grid-template-columns:1fr 1fr 360px;gap:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;animation:fadeUp .4s ease both}.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{font-size:13px;font-weight:800;color:var(--t1);display:flex;align-items:center;gap:7px}.card-title .pip{width:7px;height:7px;border-radius:50%;background:var(--g400);flex-shrink:0;box-shadow:0 0 8px var(--g400);animation:pulsePip 2s infinite}@keyframes pulsePip{0%{transform:scale(1);opacity:1;box-shadow:0 0 8px var(--g400)}50%{transform:scale(1.2);opacity:.7;box-shadow:0 0 14px var(--g400)}to{transform:scale(1);opacity:1;box-shadow:0 0 8px var(--g400)}}.card-sub{font-size:10px;color:var(--t4);font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-top:1px}.card-link{font-size:11px;color:var(--g400);font-weight:700;cursor:pointer;text-decoration:none}.card-link:hover{color:var(--g300)}.chart-wrap{display:flex;align-items:flex-end;gap:7px;height:120px;border-bottom:1px solid var(--border2);padding-bottom:0;margin-bottom:8px}.ch-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;height:100%}.ch-bars{display:flex;align-items:flex-end;gap:2px;height:calc(100% - 18px)}.ch-bar{width:8px;border-radius:3px 3px 0 0;transition:height .6s cubic-bezier(.16,1,.3,1)}.ch-bar.a{background:linear-gradient(180deg,var(--g400),var(--g700))}.ch-bar.b{background:#c9a22759;border:1px solid rgba(201,162,39,.2)}.ch-lbl{font-size:9px;color:var(--t4);font-weight:600}.ch-legend{display:flex;gap:12px}.ch-leg{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--t3);font-weight:600}.ch-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.task-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.task-label span{font-size:10px;color:var(--t4);font-weight:700}.task-count{background:var(--g800);color:var(--g200);font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;border:1px solid var(--g700)}.task-list{display:flex;flex-direction:column;gap:8px}.task-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-sm);background:var(--surface3);border:1px solid var(--border2);transition:border-color .15s,background .15s;cursor:pointer}.task-item:hover{background:var(--panel);border-color:var(--border)}.task-av{width:36px;height:36px;border-radius:50%;background:var(--g800);overflow:hidden;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:var(--g200);flex-shrink:0;border:1.5px solid var(--g700)}.task-av img{width:100%;height:100%;object-fit:cover}.task-body{flex:1;min-width:0}.task-name{font-size:12.5px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-meta{display:flex;align-items:center;gap:6px;margin-top:2px}.task-meta span{font-size:10px;color:var(--t3);font-weight:500}.task-meta .hi{color:var(--g400);font-weight:700}.task-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.urgent-tag{font-size:9px;font-weight:900;letter-spacing:.8px;padding:2px 7px;border-radius:4px;background:#e0505026;color:var(--red);border:1px solid rgba(224,80,80,.25);text-transform:uppercase}.task-actions{display:flex;gap:5px}.btn-sm{font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:5px;border:none;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-pri{background:var(--g700);color:var(--g100)}.btn-pri:hover{background:var(--g600)}.btn-sec{background:var(--surface);color:var(--t2);border:1px solid var(--border)}.btn-sec:hover{background:var(--surface3);color:var(--t1)}.btn-warn{background:var(--amber-pale);color:var(--amber);border:1px solid rgba(232,151,58,.25)}.btn-warn:hover{background:#e8973a38}.btn-info{background:var(--blue-pale);color:var(--blue);border:1px solid rgba(66,133,232,.25)}.btn-info:hover{background:#4285e838}.log-list{display:flex;flex-direction:column;gap:0}.log-item{display:flex;align-items:flex-start;gap:14px;padding:12px 10px;border-radius:var(--r-xs);cursor:pointer;transition:background .15s;position:relative}.log-item:after{content:"";position:absolute;left:16px;top:32px;bottom:-8px;width:1px;background:#ffffff0d}.log-item:last-child:after{display:none}.log-dot{width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;border:2px solid var(--g600);background:var(--surface)}.log-dot:after{content:"";width:5px;height:5px;border-radius:50%;background:var(--g500)}.log-dot.special{border-color:var(--gold);background:var(--gold-pale)}.log-dot.special:after{background:var(--gold)}.log-body{flex:1;min-width:0}.log-text{font-size:11.5px;color:var(--t2);font-weight:500;line-height:1.4}.log-text b{color:var(--t1);font-weight:700}.log-code{font-size:9.5px;color:var(--t4);margin-top:2px;font-weight:600;font-variant-numeric:tabular-nums}.bot-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.donut-wrap{display:flex;align-items:center;gap:16px}.d-legend{display:flex;flex-direction:column;gap:7px;flex:1}.d-row{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--t2);font-weight:600}.d-sq{width:8px;height:8px;border-radius:2px;flex-shrink:0}.d-pct{margin-left:auto;font-weight:800;color:var(--t1);font-variant-numeric:tabular-nums}.sch-list{display:flex;flex-direction:column;gap:7px}.sch-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--r-xs);background:var(--surface3);border:1px solid var(--border2);border-left:3px solid var(--g600);transition:all .2s}.sch-item:hover{transform:translate(4px);background:var(--panel)}.sch-item.amber{border-left-color:var(--amber)}.sch-item.blue{border-left-color:var(--blue)}.sch-item.purple{border-left-color:var(--purple)}.sch-item.red{border-left-color:var(--red)}.sch-time{font-size:10px;font-weight:800;color:var(--t3);min-width:48px}.sch-body{flex:1}.sch-name{font-size:12px;font-weight:700;color:var(--t1)}.sch-teacher{font-size:10px;color:var(--t4);margin-top:1px}.sch-room{font-size:9.5px;font-weight:700;color:var(--g400);background:#22b1601a;padding:2px 6px;border-radius:4px;border:1px solid rgba(34,177,96,.15);flex-shrink:0}.prog-list{display:flex;flex-direction:column;gap:11px}.prog-top{display:flex;justify-content:space-between;margin-bottom:4px}.prog-name{font-size:11.5px;font-weight:700;color:var(--t2)}.prog-pct{font-size:11px;font-weight:800;color:var(--g400);font-variant-numeric:tabular-nums}.prog-track{height:5px;border-radius:20px;background:#ffffff0f;overflow:hidden}.prog-fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--g700),var(--g400));transition:width .9s cubic-bezier(.16,1,.3,1)}.prog-fill.amber{background:linear-gradient(90deg,#b36a10,var(--amber))}.prog-fill.blue{background:linear-gradient(90deg,#2355a8,var(--blue))}.prog-fill.purple{background:linear-gradient(90deg,#5c3ea8,var(--purple))}.prog-fill.red{background:linear-gradient(90deg,#8f1c1c,var(--red))}.divider{height:1px;background:var(--border2);margin:14px 0}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--g800);border-radius:10px}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1340px){.main-grid{grid-template-columns:1fr 1fr}.main-grid .card:nth-child(3){grid-column:1/-1}.log-list{display:grid;grid-template-columns:1fr 1fr;gap:0}.log-item:after{display:none}}@media (max-width:1100px){.kpi-row{grid-template-columns:repeat(2,1fr)}.bot-grid{grid-template-columns:1fr 1fr}.bot-grid .card:last-child{grid-column:1/-1}}@media (max-width:860px){:root{--sidebar-w: 0px}.page{margin-left:0}.main-grid{grid-template-columns:1fr}.hero{flex-direction:column;align-items:flex-start;padding:20px 16px;gap:20px}.hero-left{flex-direction:column!important;align-items:flex-start!important;gap:12px!important}.hero-left h2{font-size:18px!important;line-height:1.4}.hero-kpis{width:100%;justify-content:space-between}.hero-kpis .h-kpi:last-child{display:none}.h-kpi{padding:12px 10px;min-width:0;flex:1}.h-kpi-val{font-size:18px}}.view-section{animation:fadeUp .4s ease both}.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.view-title{font-size:24px;font-weight:900;color:var(--t1);letter-spacing:-.5px}.view-subtitle{font-size:13px;color:var(--t3);margin-top:2px}.filter-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;animation:fadeUp .5s ease both}.search-box{flex:1;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:14px;color:var(--t4)}.search-box input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px 12px 40px;color:var(--t1);font-size:13px;font-family:inherit;transition:all .2s}.search-box input:focus{border-color:var(--g500);outline:none;background:var(--surface3)}.filter-group{display:flex;gap:10px}.filter-group select{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;color:var(--t2);font-size:12px;font-weight:600;cursor:pointer}.data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;animation:fadeUp .6s ease both}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;border:none;font-family:inherit}.btn-pri{background:var(--g600);color:#fff;box-shadow:0 4px 14px #1b94504d}.btn-pri:hover{background:var(--g500);transform:translateY(-1px)}.btn-sec{background:var(--surface3);color:var(--t1);border:1px solid var(--border)}.btn-sec:hover{background:var(--panel)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);width:100%;max-width:500px;position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:0 20px 60px #0009;max-height:90vh;display:flex;flex-direction:column}.modal-hd{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-title{font-size:18px;font-weight:800;color:var(--t1)}.modal-bd{padding:24px;overflow-y:auto;flex:1}.modal-ft{padding:16px 24px;background:var(--surface2);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:11px;font-weight:800;text-transform:uppercase;color:var(--t4);margin-bottom:8px;letter-spacing:1px}.form-control{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;color:var(--t1);font-size:14px;font-family:inherit}.form-control:focus{border-color:var(--g500);outline:none;background:var(--surface3)}.student-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;transition:all .2s;cursor:pointer;position:relative}.student-card:hover{transform:translateY(-4px);border-color:var(--g700);box-shadow:0 8px 30px #0006}.sc-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}.sc-av{width:48px;height:48px;border-radius:14px;background:var(--surface3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--g400);font-weight:800}.sc-info h4{font-size:15px;font-weight:800;color:var(--t1);margin-bottom:2px}.sc-info p{font-size:11px;color:var(--t4);font-weight:600}.sc-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.sc-stat{background:var(--surface2);padding:8px 12px;border-radius:8px;border:1px solid var(--border2)}.sc-stat-val{font-size:14px;font-weight:800;color:var(--t1);display:block}.sc-stat-lbl{font-size:9px;color:var(--t4);font-weight:700;text-transform:uppercase}.loading-state{padding:60px 0;text-align:center;color:var(--t3)}.spinner{width:30px;height:30px;border:3px solid var(--border);border-top-color:var(--g500);border-radius:50%;margin:0 auto 12px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.table-container,.table-responsive{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow-x:auto;animation:fadeUp .6s ease both;box-shadow:0 10px 30px #0003;width:100%;-webkit-overflow-scrolling:touch}.table-responsive table{min-width:600px}.premium-table{width:100%;border-collapse:collapse;font-size:13px;min-width:800px}.premium-table th{background:var(--surface2);padding:16px;text-align:left;font-size:11px;font-weight:800;text-transform:uppercase;color:var(--t4);letter-spacing:1px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.premium-table td{padding:14px 16px;border-bottom:1px solid var(--border2);color:var(--t2);vertical-align:middle;transition:background .2s}.premium-table tr:hover td{background:#ffffff08;color:var(--t1)}.premium-table tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}.badge:before{content:"";width:6px;height:6px;border-radius:50%}.badge-active{background:#1b94501a;color:var(--g400);border:1px solid rgba(27,148,80,.2)}.badge-active:before{background:var(--g500);box-shadow:0 0 8px var(--g500)}.badge-reserved{background:#e8973a1a;color:var(--amber);border:1px solid rgba(232,151,58,.2)}.badge-reserved:before{background:var(--amber)}.badge-dropped{background:#e050501a;color:var(--red);border:1px solid rgba(224,80,80,.2)}.badge-dropped:before{background:var(--red)}.cell-name{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--t1)}.cell-av{width:32px;height:32px;border-radius:8px;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:14px}.cell-id{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--t4)}.cell-balance{font-weight:800;color:var(--g400)}.student-detail-panel{width:380px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;animation:slideInRight .3s ease both;box-shadow:0 10px 30px #0003;max-height:calc(100vh - 260px)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sdp-header{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sdp-avatar{width:48px;height:48px;border-radius:50%;background:#1b94501f;border:2px solid rgba(27,148,80,.3);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:var(--g400);flex-shrink:0;font-family:monospace}.sdp-avatar.inactive{background:#ffffff0d;border-color:#ffffff1a;color:var(--t3)}.sdp-info{flex:1;min-width:0}.sdp-name{font-size:15px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sdp-meta{font-size:11px;color:var(--t3);margin-top:2px}.sdp-close{width:28px;height:28px;border-radius:6px;background:none;border:1px solid var(--border);color:var(--t3);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}.sdp-close:hover{background:var(--surface3);color:var(--t1)}.sdp-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 18px;background:var(--surface2);overflow-x:auto;-webkit-overflow-scrolling:touch}.sdp-tabs::-webkit-scrollbar{display:none}.sdp-tabs{-ms-overflow-style:none;scrollbar-width:none}.sdp-tab{padding:10px 12px;font-size:12px;font-weight:600;color:var(--t3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.sdp-tab:hover{color:var(--t2)}.sdp-tab.active{color:var(--g400);border-bottom-color:var(--g400);font-weight:700}.sdp-body{flex:1;overflow-y:auto;padding:16px 18px}.sdp-section-label{font-size:9.5px;font-weight:800;color:var(--t4);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;margin-top:4px}.sdp-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:9px 0;border-bottom:1px solid var(--border2)}.sdp-row-label{color:var(--t3)}.sdp-row-value{color:var(--t1);font-weight:600;text-align:right;max-width:60%;word-break:break-word}.sdp-class-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;background:var(--surface3);border:1px solid var(--border2);margin-bottom:6px;transition:all .15s}.sdp-class-item:hover{border-color:var(--border);background:var(--panel)}.sdp-class-dot{width:8px;height:8px;border-radius:50%;background:var(--g500);flex-shrink:0}.sdp-class-name{font-size:12px;font-weight:600;color:var(--t1);margin-left:10px}.sdp-class-badge{font-size:10px;font-weight:700;color:var(--g400);background:#1b94501a;padding:2px 8px;border-radius:20px;border:1px solid rgba(27,148,80,.15)}.sdp-status-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;border-radius:8px;cursor:pointer;margin-bottom:6px;text-align:left;border:1px solid;transition:all .15s;background:none}.sdp-status-btn:hover{transform:translate(4px)}.sdp-status-title{font-size:12px;font-weight:700}.sdp-status-desc{font-size:10px;margin-top:2px;opacity:.8}.sdp-status-btn.green{border-color:#1b945040;background:#1b945014;color:var(--g400)}.sdp-status-btn.amber{border-color:#e8973a40;background:#e8973a14;color:var(--amber)}.sdp-status-btn.red{border-color:#e0505040;background:#e0505014;color:var(--red)}.sdp-danger-zone{margin-top:16px;padding:12px 14px;border-radius:8px;background:#e050500f;border:1px solid rgba(224,80,80,.15)}.sdp-danger-title{font-size:11px;font-weight:700;color:var(--red);margin-bottom:6px}.sdp-danger-btn{font-size:11px;font-weight:600;color:var(--red);background:none;border:none;cursor:pointer;padding:0}.sdp-danger-btn:hover{text-decoration:underline}.sdp-actions{display:flex;gap:6px;margin-top:12px}.sdp-action-btn{flex:1;padding:9px;border-radius:8px;border:1px solid var(--border);background:var(--surface3);color:var(--t2);font-size:11px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s}.sdp-action-btn:hover{background:var(--panel);color:var(--t1);border-color:var(--g700)}.lms-toast{position:fixed;top:20px;right:20px;z-index:9999;padding:12px 20px;border-radius:10px;font-size:13px;font-weight:600;animation:slideInRight .3s ease both;box-shadow:0 8px 24px #0006}.lms-toast.success{background:#1b945026;color:var(--g300);border:1px solid rgba(27,148,80,.3)}.lms-toast.warning{background:#e8973a26;color:var(--amber);border:1px solid rgba(232,151,58,.3)}.lms-toast.error{background:#e0505026;color:var(--red);border:1px solid rgba(224,80,80,.3)}.lms-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.lms-confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px 28px;max-width:380px;width:90%;animation:slideUp .3s ease}.lms-confirm-title{font-size:16px;font-weight:700;color:var(--t1);margin-bottom:8px}.lms-confirm-msg{font-size:13px;color:var(--t2);margin-bottom:20px;line-height:1.5}.lms-confirm-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width:1100px){.student-detail-panel{width:340px}}@media (max-width:860px){.student-detail-panel{position:fixed;right:0;top:0;bottom:0;width:100%;max-width:380px;z-index:500;max-height:100vh;border-radius:0}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:65px;background:#0d1117e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border);z-index:2000;justify-content:space-around;align-items:center;padding:0 10px}.m-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--t4);font-size:10px;font-weight:600;transition:all .2s ease;height:100%;border-radius:0;cursor:pointer}.m-nav-item svg{transition:transform .3s cubic-bezier(.4,0,.2,1)}.m-nav-item.active{color:var(--g400);background:#1b94501a}.m-nav-item.active svg{transform:translateY(-2px);stroke:var(--g400)}@media (max-width: 860px){:root{--sidebar-w: 0px}.sidebar{display:flex!important;position:fixed!important;top:0!important;left:0!important;bottom:0!important;width:280px!important;height:100dvh!important;z-index:9999!important;background:var(--surface)!important;transform:translate(-100%)!important;transition:transform .28s cubic-bezier(.4,0,.2,1)!important;box-shadow:4px 0 20px #0000004d!important;will-change:transform!important;-webkit-backface-visibility:hidden!important;backface-visibility:hidden!important}.sidebar.active{transform:translate(0)!important}.page{margin-left:0;padding-bottom:75px}.mobile-nav{display:flex}.topbar{padding:0 16px;height:60px}.m-menu-btn,.hide-on-desktop{display:block!important}.hide-on-mobile{display:none!important}.topbar-brand h1{font-size:14px}.topbar-brand p{display:none}.topbar-brand img{height:32px!important;width:32px!important}.tb-user-info,.tb-sep,.tb-pill{display:none}.main-grid{grid-template-columns:1fr!important;gap:16px;padding:16px}.hero-banner{padding:24px 20px;border-radius:0;margin:-16px -16px 16px}.hero-banner h1{font-size:20px}.hero-kpis{grid-template-columns:repeat(2,1fr);gap:10px}.h-kpi{padding:12px}.h-kpi-val{font-size:18px}.section-hd,.view-header{flex-direction:column;align-items:flex-start;gap:16px;padding:20px 16px}.filter-bar{flex-direction:column;align-items:stretch;padding:16px;gap:16px}.filter-bar .form-control,.filter-bar select,.filter-bar input{width:100%!important;max-width:none!important}.table-container,.table-responsive{margin:0;border-radius:8px;border:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}.premium-table{min-width:700px}.modal-content{width:95%;margin:10px auto;padding:20px}.grid-2,.grid-3{grid-template-columns:1fr}}@media (max-width: 860px){#classSplitLayout,#financeSplitLayout,#attendanceSplitLayout{flex-direction:column}#classDetailPanel,#invoiceDetailPanel,#sessionDetailPanel{width:100%!important;margin-top:16px}}@media (max-width: 480px){.hero-kpis{grid-template-columns:1fr}.hero-banner{text-align:center}.hero-banner-btns{justify-content:center}}.reports-container{padding:24px}.report-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:24px}.rep-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.rep-card:hover{transform:translateY(-5px);background:#ffffff0d;border-color:var(--g500);box-shadow:0 12px 40px #0000004d}.rep-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--g500);opacity:.5}.rep-card.gold:before{background:var(--gold)}.rep-card.blue:before{background:var(--blue)}.rep-card.purple:before{background:var(--purple)}.rep-label{font-size:11px;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.rep-value{font-size:28px;font-weight:900;color:var(--t1);font-family:Outfit,sans-serif}.rep-trend{font-size:11px;margin-top:8px;display:flex;align-items:center;gap:4px}.rep-trend.up{color:var(--g400)}.rep-trend.down{color:var(--red)}.report-nav{display:flex;gap:8px;margin-top:32px;padding:6px;background:#ffffff08;border-radius:12px;width:fit-content;border:1px solid var(--border)}.report-nav-item{padding:10px 24px;font-size:13px;font-weight:700;color:var(--t3);background:none;border:none;border-radius:8px;cursor:pointer;transition:all .2s;white-space:nowrap}.report-nav-item:hover{color:var(--t1);background:#ffffff0d}.report-nav-item.active{background:var(--g500);color:#fff;box-shadow:0 4px 12px #22b1604d}.grid{display:grid!important}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))!important}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))!important}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))!important}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))!important}.col-span-2{grid-column:span 2 / span 2!important}.col-span-3{grid-column:span 3 / span 3!important}.col-span-4{grid-column:span 4 / span 4!important}.gap-6{gap:24px!important}.mt-4{margin-top:16px!important}.mt-8{margin-top:32px!important}.kpi-row-mini{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.kpi-box{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.kpi-box-label{font-size:10px;color:var(--t4);font-weight:700;text-transform:uppercase;margin-bottom:4px}.kpi-box-value{font-size:18px;font-weight:800;color:var(--t1)}#systemView .split-layout{display:flex;height:calc(100vh - 120px);background:var(--surface);border-radius:16px;overflow:hidden;border:1px solid var(--border)}.split-sidebar{background:#ffffff05;border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-header{padding:24px;border-bottom:1px solid var(--border)}.sidebar-nav{padding:12px;display:flex;flex-direction:column;gap:4px}.sidebar-nav .nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:var(--t3);background:none;border:none;cursor:pointer;text-align:left;font-size:13px;font-weight:600;transition:all .2s}.sidebar-nav .nav-item:hover{background:#ffffff0a;color:var(--t1)}.sidebar-nav .nav-item.active{background:var(--g500);color:#fff;box-shadow:0 4px 12px #22b16033}.split-main{flex:1;overflow-y:auto;background:#0000001a}.system-pane{max-width:900px;margin:0 auto}.field-group{display:flex;flex-direction:column;gap:6px}.field-value{font-size:14px;font-weight:600;color:var(--t1);padding:8px 0;border-bottom:1px solid var(--border)}.flex{display:flex!important}.justify-between{justify-content:space-between!important}.items-center{align-items:center!important}.gap-4{gap:16px!important}.mb-6{margin-bottom:24px!important}.p-6{padding:24px!important}.text-xs{font-size:11px!important}.text-red-500{color:var(--red)!important}.font-medium{font-weight:500!important}.font-bold{font-weight:700!important}.lms-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.lms-confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:400px;padding:32px;text-align:center;box-shadow:0 25px 50px -12px #00000080;animation:slideUp .4s cubic-bezier(.175,.885,.32,1.275)}.lms-confirm-title{font-size:18px;font-weight:900;color:var(--t1);margin-bottom:12px}.lms-confirm-msg{font-size:14px;color:var(--t3);margin-bottom:32px;line-height:1.6}.lms-confirm-actions{display:flex;gap:12px;justify-content:center}.lms-confirm-actions .btn{min-width:120px;justify-content:center}#toastContainer{pointer-events:none}.toast-success{border-left:4px solid var(--g500)!important}.toast-error{border-left:4px solid var(--red)!important}.toast-warning{border-left:4px solid var(--amber)!important}.toast-info{border-left:4px solid var(--blue)!important}.hidden,.view-section.hidden{display:none!important}.excel-grid-container{max-height:500px;overflow-y:auto;background:var(--surface);border-radius:0 0 var(--r) var(--r)}.excel-grid-container table th{font-size:10px;text-transform:uppercase;letter-spacing:1px;background:var(--surface3);border-bottom:1px solid var(--border);white-space:nowrap}.excel-grid-container table tr:hover{background:#ffffff05}.status-chip{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:all .2s;background:var(--chip-bg);color:var(--chip-color);border:1.5px solid transparent;display:inline-flex;align-items:center;gap:4px}.status-chip:hover{transform:translateY(-1px);filter:brightness(1.1)}.status-chip.active{border-color:var(--chip-color);box-shadow:0 2px 8px var(--chip-color) 44}.sdp-body{scrollbar-width:thin;scrollbar-color:var(--g800) transparent}.sdp-body::-webkit-scrollbar{width:5px}.sdp-status-btn{width:100%;padding:12px 16px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.sdp-status-btn:hover{transform:translateY(-2px);border-color:var(--g500)}.sdp-action-btn{padding:10px;border-radius:8px;background:var(--surface3);color:var(--t2);font-size:12px;font-weight:700;border:1px solid var(--border);cursor:pointer;transition:all .2s}.sdp-action-btn:hover{background:var(--g800);color:#fff;border-color:var(--g600)}.sdp-danger-zone{margin-top:30px;padding-top:20px;border-top:1px dashed var(--red)}.sdp-danger-title{font-size:11px;font-weight:800;color:var(--red);text-transform:uppercase;margin-bottom:12px}.sdp-danger-btn{width:100%;padding:10px;border-radius:8px;background:#e050501a;color:var(--red);border:1px solid rgba(224,80,80,.3);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}.sdp-danger-btn:hover{background:var(--red);color:#fff}.float-toggle{position:fixed;bottom:96px;right:24px;width:46px;height:46px;border-radius:50%;background:var(--surface);border:1px solid var(--border);box-shadow:var(--sh);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000;font-size:1.3rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);color:var(--t1)}.float-toggle:hover{transform:scale(1.15) rotate(15deg);box-shadow:0 8px 32px #00a87833;border-color:var(--g400)}.quick-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1rem}.action-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.2rem .6rem;border-radius:12px;background:var(--surface2);border:1px solid var(--border);cursor:pointer;transition:all .25s ease;text-align:center;gap:.5rem}.action-tile:hover{transform:translateY(-4px);border-color:var(--g400);background:var(--surface3);box-shadow:var(--sh)}.action-icon{font-size:1.4rem;width:40px;height:40px;border-radius:10px;background:var(--surface3);display:flex;align-items:center;justify-content:center;color:var(--g400);transition:all .25s ease}.action-tile:hover .action-icon{background:var(--g400);color:#fff}.action-label{font-size:11.5px;font-weight:700;color:var(--t2)}.action-tile:hover .action-label{color:var(--t1)}.avatar-wrapper{display:flex;align-items:center;gap:.75rem}.avatar-circle{width:32px;height:32px;border-radius:50%;background:var(--g800);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;border:1.5px solid var(--border)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day-cell{aspect-ratio:1.1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;font-size:12px;font-weight:600;color:var(--t1);cursor:pointer;position:relative;background:var(--surface2);border:1.5px solid transparent;transition:all .2s ease}.calendar-day-cell:hover{background:var(--surface3);border-color:var(--border)}.calendar-day-cell.today{background:var(--g800);color:#fff;font-weight:700;box-shadow:0 2px 8px #00a8784d}.calendar-day-cell.other-month{color:var(--t4);opacity:.4}.calendar-day-cell.selected{border-color:var(--g400);background:var(--surface3)}.calendar-event-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);position:absolute;bottom:5px}.calendar-event-dot.green{background:var(--g400)}.calendar-event-dot.blue{background:var(--blue)}.timetable-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.25rem 1.5rem;background:var(--surface2);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sh);flex-wrap:wrap;gap:1rem}.week-navigation,.week-navigation button{display:flex;align-items:center;gap:.5rem}.timetable-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.timetable-actions .form-control{min-width:150px}.timetable-grid{display:grid;grid-template-columns:100px repeat(7,minmax(140px,1fr));gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);margin-top:10px;min-width:max-content}.timetable-cell-header{background:var(--surface3);padding:12px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-bottom:1.5px solid var(--border);min-height:55px}.timetable-cell-header .day-name{font-size:11.5px;font-weight:850;color:var(--t1);text-transform:uppercase;letter-spacing:.5px}.timetable-cell-header .day-date{font-size:10px;color:var(--t4);font-weight:700}.timetable-time-cell{background:var(--surface3);padding:12px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;min-height:100px}.timetable-time-cell .time-label{font-size:11.5px;font-weight:850;color:var(--t1)}.timetable-time-cell .time-range{font-size:9.5px;color:var(--t4);font-weight:700}.timetable-cell{background:var(--surface);min-height:100px;padding:6px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:6px;position:relative;transition:all .2s ease}.timetable-cell.empty{display:flex;align-items:center;justify-content:center;cursor:pointer}.timetable-cell.empty .cell-empty-text{font-size:16px;color:var(--t4);opacity:0;transition:all .2s ease;font-weight:600}.timetable-cell.empty:hover{background:#00a87808}.timetable-cell.empty:hover .cell-empty-text{opacity:.7;color:var(--g400)}.timetable-cell.filled{cursor:pointer;background:var(--surface2);border-radius:8px;margin:3px;padding:8px;border:1px solid var(--border);border-left:4px solid var(--g500);box-shadow:0 2px 4px #0000000f;display:flex;flex-direction:column;justify-content:space-between;transition:all .2s ease;min-height:88px}.timetable-cell.filled:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026;background:var(--surface3);border-color:var(--g400)}.timetable-cell.filled.chua_diem_danh{border-left-color:var(--amber)}.timetable-cell.filled.huy_buoi{border-left-color:var(--red);opacity:.65}.timetable-cell.filled .cell-subject{font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.timetable-cell.filled.chua_diem_danh .cell-subject{color:var(--amber)}.timetable-cell.filled.huy_buoi .cell-subject{color:var(--red)}.timetable-cell.filled .cell-class{font-size:11.5px;font-weight:800;color:var(--t1);margin-bottom:3px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.timetable-cell.filled .cell-teacher{font-size:10px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:3px}.timetable-cell.filled .cell-room{font-size:9px;color:var(--t4);font-weight:700;margin-top:3px;display:inline-block;padding:1px 4px;background:var(--surface3);border-radius:4px;width:fit-content}.conflict-badge{position:absolute;top:4px;right:4px;background:var(--red);color:#fff;font-size:8px;font-weight:900;padding:2px 4px;border-radius:4px;box-shadow:0 0 6px var(--red);animation:conflictPulse 1.5s infinite;z-index:5}@keyframes conflictPulse{0%{transform:scale(1);opacity:.9}50%{transform:scale(1.1);opacity:1;box-shadow:0 0 10px var(--red)}to{transform:scale(1);opacity:.9}}.timetable-legend{display:flex;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:flex-start;padding:1rem;background:var(--surface2);border-radius:var(--r);border:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:12px;font-weight:700;color:var(--t2)}.legend-color{width:12px;height:12px;border-radius:3px}.schedule-detail-grid{display:flex;flex-direction:column;gap:8px;margin-top:10px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:11px;color:var(--t4);font-weight:750;text-transform:uppercase}.detail-value{font-size:13px;color:var(--t1);font-weight:800}@media print{body>*:not(.page){display:none!important}.sidebar,.topbar,.mobile-nav,.float-toggle,.timetable-header,.timetable-legend,.s-footer{display:none!important}.page{margin-left:0!important;padding:0!important}.content{padding:0!important}.view-section:not(.active){display:none!important}.timetable-grid{grid-template-columns:80px repeat(7,1fr)!important;width:100%!important;box-shadow:none!important;border:1px solid #000!important;background:#fff!important;color:#000!important}.timetable-cell-header,.timetable-time-cell{background:#f0f0f0!important;border-color:#000!important;color:#000!important}.timetable-cell{background:#fff!important;border-color:#000!important;color:#000!important}.timetable-cell.filled{background:#fafafa!important;border:1px solid #000!important;box-shadow:none!important;color:#000!important;margin:1px!important}}.timetable-compact-strip{display:flex;gap:8px;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);overflow-x:auto}.timetable-compact-day{flex:1;min-width:50px;padding:8px 4px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;text-align:center;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:2px}.timetable-compact-day:hover{background:var(--surface3);border-color:var(--g400)}.timetable-compact-day.active{background:var(--g500);border-color:var(--g400);box-shadow:0 4px 10px #00a87833}.timetable-compact-day.active .day-lbl,.timetable-compact-day.active .day-num{color:#fff!important}.timetable-compact-day .day-lbl{font-size:9px;font-weight:800;color:var(--t4);text-transform:uppercase}.timetable-compact-day .day-num{font-size:14px;font-weight:900;color:var(--t1)}.timetable-compact-day .day-dot{width:4px;height:4px;border-radius:50%;background:var(--g400);margin-top:2px}.timetable-compact-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;max-height:250px;overflow-y:auto;padding:2px}.timetable-compact-item{background:var(--surface2);border:1px solid var(--border);border-left:4px solid var(--g500);border-radius:8px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease;cursor:pointer}.timetable-compact-item:hover{transform:translateY(-1px);background:var(--surface3);border-color:var(--g400);box-shadow:var(--sh)}.timetable-compact-item.chua_diem_danh{border-left-color:var(--amber)}.timetable-compact-item.huy_buoi{border-left-color:var(--red);opacity:.65}.timetable-compact-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.timetable-compact-title{font-size:12.5px;font-weight:850;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timetable-compact-meta{font-size:10px;color:var(--t3);display:flex;gap:8px;align-items:center}.timetable-compact-time{background:var(--surface3);padding:3px 6px;border-radius:4px;font-size:10px;font-weight:800;color:var(--g400);white-space:nowrap}.timetable-compact-item.chua_diem_danh .timetable-compact-time{color:var(--amber)}.timetable-compact-item.huy_buoi .timetable-compact-time{color:var(--red)}.mobile-nav{display:none}@media (max-width: 768px){.page{margin-left:0;padding-bottom:80px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:65px;background:#0d1a12d9;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border);z-index:990;justify-content:space-around;align-items:center;padding:0 10px}[data-theme=light] .mobile-nav{background:#ffffffe6}.m-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--t4);text-decoration:none;font-size:10px;gap:4px;padding:8px;border-radius:12px;transition:all .2s;cursor:pointer;flex:1}.m-nav-item svg{width:20px;height:20px;opacity:.8}.m-nav-item.active{color:var(--g500)}.m-nav-item.active svg{opacity:1}.m-menu-btn{display:block!important}.topbar{left:0;padding:0 12px;gap:8px}.topbar-brand h1{font-size:14px!important}.topbar-brand p{display:none}.tb-user-info,.tb-sep,#dateStr{display:none!important}.tb-btn{width:32px;height:32px}.grid{grid-template-columns:1fr!important;gap:16px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px;width:calc(100% + 32px)}.premium-table{min-width:700px}.kpi-row,.kpi-row-mini{flex-direction:column}.kpi-box{width:100%}.module-header{flex-direction:column;align-items:flex-start;gap:12px}.header-actions{width:100%;display:flex;overflow-x:auto;padding-bottom:4px}.header-actions .btn{white-space:nowrap}.card{padding:20px!important}.modal-content{padding:20px!important;width:95vw!important}}.ai-widget-container{position:fixed;bottom:24px;right:24px;z-index:10005;font-family:Be Vietnam Pro,sans-serif}.ai-widget-btn{width:56px;height:56px;border-radius:28px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 25px #3b82f666;position:relative;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.ai-widget-btn:hover{transform:scale(1.08) translateY(-4px);box-shadow:0 15px 30px #8b5cf680}.ai-glow{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:conic-gradient(from 0deg,#3b82f6,#8b5cf6,#ec4899,#3b82f6);opacity:0;transition:opacity .3s;z-index:-1;filter:blur(8px);animation:spinGlow 4s linear infinite}.ai-widget-btn:hover .ai-glow{opacity:.6}@keyframes spinGlow{to{transform:rotate(360deg)}}.ai-chat-panel{position:absolute;bottom:80px;right:0;width:380px;height:600px;max-height:calc(100vh - 120px);background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 40px #0003,0 0 0 1px #ffffff0d;display:flex;flex-direction:column;overflow:hidden;opacity:0;pointer-events:none;transform:translateY(20px) scale(.95);transform-origin:bottom right;transition:all .3s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.ai-chat-panel.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}.ai-chat-header{padding:16px 20px;background:linear-gradient(135deg,#1e293b,#0f172a);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.ai-chat-header-info{display:flex;align-items:center;gap:12px}.ai-avatar{width:36px;height:36px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 10px #0003}.ai-close-btn{background:none;border:none;color:#fff9;cursor:pointer;font-size:18px;padding:4px;transition:color .2s}.ai-close-btn:hover{color:#fff}.ai-chat-history{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:var(--bg)}.ai-msg{display:flex;gap:12px;max-width:85%}.ai-msg.user{align-self:flex-end;flex-direction:row-reverse}.ai-msg.bot{align-self:flex-start}.ai-msg-av{width:28px;height:28px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.ai-msg.user .ai-msg-av{background:#e2e8f0;color:#0f172a}.ai-msg-bubble{background:var(--surface);padding:12px 16px;border-radius:2px 16px 16px;font-size:13px;line-height:1.5;color:var(--t1);box-shadow:0 2px 8px #0000000d;border:1px solid var(--border)}.ai-msg.user .ai-msg-bubble{background:var(--blue);color:#fff;border-radius:16px 2px 16px 16px;border-color:transparent;box-shadow:0 4px 12px #3b82f633}.ai-chat-input-area{padding:16px;background:var(--surface);border-top:1px solid var(--border)}.ai-input-wrapper{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:10px 14px;transition:border-color .3s,box-shadow .3s}.ai-input-wrapper:focus-within{border-color:var(--blue);box-shadow:0 0 0 2px #3b82f61a}#aiChatInput{width:100%;border:none;background:transparent;outline:none;font-family:inherit;font-size:13px;color:var(--t1);resize:none;max-height:100px;display:block}.ai-send-btn{width:40px;height:40px;border-radius:12px;background:var(--blue);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.ai-send-btn:disabled{background:var(--surface3);color:var(--t4);cursor:not-allowed}.ai-send-btn:not(:disabled):hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.ai-sugg-btn{background:#3b82f61a;color:var(--blue);border:1px solid rgba(59,130,246,.2);padding:6px 12px;border-radius:8px;font-size:11.5px;font-weight:600;cursor:pointer;transition:all .2s;text-align:left}.ai-sugg-btn:hover{background:#3b82f633}.ai-typing-indicator{display:flex;gap:4px;padding:8px 4px}.ai-typing-dot{width:6px;height:6px;border-radius:50%;background:var(--t4);animation:typingBounce 1.4s infinite ease-in-out both}.ai-typing-dot:nth-child(1){animation-delay:-.32s}.ai-typing-dot:nth-child(2){animation-delay:-.16s}@keyframes typingBounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.ai-widget-container{bottom:calc(70px + env(safe-area-inset-bottom));right:16px}.ai-widget-btn{width:50px;height:50px}.ai-chat-panel{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;max-height:100%;border-radius:0;border:none;z-index:10000;transform:translateY(100%)}.ai-chat-panel.open{transform:translateY(0)}.float-toggle{bottom:calc(135px + env(safe-area-inset-bottom));right:16px}}.topbar-actions::-webkit-scrollbar{display:none}@media (max-width: 860px){.bot-grid{grid-template-columns:1fr!important}.bot-grid .card:last-child{grid-column:auto!important}.calendar-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-days{min-width:280px}.calendar-day-cell{min-width:36px;min-height:36px;font-size:12px}.calendar-weekdays{min-width:280px;font-size:11px!important}.donut-wrap{flex-direction:row;align-items:center;gap:12px}.log-list,.main-grid{grid-template-columns:1fr!important}}@media (max-width: 860px){#classDetailPanel,#invoiceDetailPanel,#sessionDetailPanel,#studentDetailPanel,#teacherDetailPanel{position:static!important;max-width:100%!important;width:100%!important;max-height:none!important;border-radius:var(--r)!important;margin-top:16px!important;box-shadow:0 4px 12px #0000001a!important;z-index:auto!important}}.el-subject-item{padding:12px 18px;margin:6px 12px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:12px;color:var(--t2);font-weight:600;transition:all .3s cubic-bezier(.25,.8,.25,1);border:1px solid transparent}.el-subject-item:hover{background:var(--surface2);color:var(--gold);transform:translate(4px);border-color:var(--border);box-shadow:0 4px 12px #0000000d}.el-subject-item.active{background:linear-gradient(135deg,#c9a22726,#c9a2270d);color:var(--gold);border:1px solid var(--gold-lt);box-shadow:0 4px 15px #c9a2271a}.el-icon{font-size:20px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.el-chapter{border-bottom:1px solid var(--border)}.el-chapter:last-child{border-bottom:none}.el-chapter-header{padding:14px 20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:#00000003;transition:all .3s;font-size:14px;font-weight:700}.el-chapter-header:hover{background:var(--surface2);padding-left:24px}.el-toggle-icon{font-size:11px;color:var(--t4);transition:transform .3s}.el-chapter.open .el-toggle-icon{transform:rotate(90deg);color:var(--gold)}.el-lesson-item{padding:12px 20px 12px 36px;cursor:pointer;color:var(--t3);font-size:13.5px;display:flex;align-items:center;transition:all .3s;border-left:3px solid transparent}.el-lesson-item:hover{background:#00000005;color:var(--g500);border-left:3px solid var(--g500);padding-left:40px}.vietjack-content-wrapper img{max-width:100%;height:auto;border-radius:12px;margin:12px 0;box-shadow:0 8px 24px #0000001f;transition:transform .3s}.vietjack-content-wrapper img:hover{transform:scale(1.02)}.el-view-root{padding:0!important;overflow:hidden;height:calc(100vh - 60px);display:flex;flex-direction:column}.el-topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;overflow-x:auto;scrollbar-width:none;flex-shrink:0}.el-topbar::-webkit-scrollbar{display:none}.el-subject-tabs{display:flex;gap:0;min-width:max-content}.el-tab-group{display:flex;align-items:center;border-right:1px solid var(--border);padding:0 8px}.el-tab-group:last-child{border-right:none}.el-tab-group-label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;padding-right:8px;white-space:nowrap}.el-tab-group-items{display:flex;gap:2px}.el-tab-btn{padding:12px 16px;font-size:13px;font-weight:600;color:var(--t3);background:none;border:none;cursor:pointer;border-bottom:3px solid transparent;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:0;position:relative;overflow:hidden}.el-tab-btn:hover{color:var(--tab-color, var(--gold));background:var(--surface2)}.el-tab-btn.active{color:var(--tab-color, var(--gold))!important;font-weight:800;text-shadow:0 0 10px rgba(201,162,39,.3)}.el-tab-btn.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background:var(--tab-color, var(--gold));box-shadow:0 -2px 8px var(--tab-color, var(--gold));border-radius:3px 3px 0 0}.el-mobile-toggle{display:none;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--surface2);border-bottom:1px solid var(--border);flex-shrink:0}.el-mobile-toggle button{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);color:var(--t1);font-size:13px;font-weight:600;padding:7px 14px;border-radius:8px;cursor:pointer}.el-breadcrumb{font-size:11px;color:var(--t4);max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.el-bc-sep{margin:0 4px;color:var(--t4)}.el-bc-current{color:var(--t2);font-weight:600}.el-main{display:flex;flex:1;overflow:hidden;position:relative}.el-sidebar{width:300px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease}.el-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-weight:800;font-size:13px;color:var(--t1);border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0}.el-sidebar-close{display:none;background:none;border:none;color:var(--t3);font-size:16px;cursor:pointer;padding:4px 8px}#elChapters{overflow-y:auto;flex:1}.el-chapter-block{border-bottom:1px solid var(--border)}.el-chapter-title{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;cursor:pointer;font-size:13px;font-weight:700;color:var(--t1);transition:background .15s;line-height:1.4}.el-chapter-title:hover{background:#ffffff08}.el-ch-icon{font-size:10px;color:var(--t4);flex-shrink:0;margin-top:3px;transition:transform .2s}.el-chapter-block.open .el-ch-icon{transform:rotate(90deg)}.el-ch-name{flex:1}.el-ch-count{background:var(--surface3);color:var(--t4);font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;flex-shrink:0}.el-lesson-list{border-top:1px solid var(--border)}.el-lesson-item{display:flex;align-items:flex-start;gap:8px;padding:9px 14px 9px 28px;cursor:pointer;font-size:12.5px;color:var(--t3);transition:all .15s;border-left:3px solid transparent;line-height:1.4}.el-lesson-item svg{flex-shrink:0;margin-top:2px;opacity:.4}.el-lesson-item:hover{background:#ffffff08;color:var(--t1);border-left-color:var(--gold-lt)}.el-lesson-item.active{background:var(--gold-pale);color:var(--gold);border-left-color:var(--gold);font-weight:600}.el-lesson-item.active svg{opacity:1}.el-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.el-overlay.visible{display:block}.el-content{flex:1;overflow-y:auto;padding:0;background:var(--bg)}.el-main-content{padding:32px;overflow-x:hidden}.el-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;text-align:center;color:var(--t4)}.el-welcome-icon{font-size:56px;margin-bottom:16px}.el-welcome h3{font-size:20px;font-weight:700;color:var(--t2);margin:0 0 8px}.el-welcome p{font-size:14px}.el-content-breadcrumb{font-size:12px;color:var(--t4);padding:12px 24px;border-bottom:1px solid var(--border);background:var(--surface)}.el-lesson-title{font-size:26px;font-weight:800;color:var(--t1);padding:24px 32px 16px;margin:0;border-bottom:1px solid var(--border);background:var(--surface);letter-spacing:-.5px}.el-nav-row{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;gap:16px;background:var(--surface);border-bottom:1px solid var(--border)}.el-nav-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;background:linear-gradient(145deg,var(--surface2) 0%,var(--surface) 100%);border:1px solid var(--border);color:var(--t2);font-size:13px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);white-space:nowrap;box-shadow:0 4px 10px #00000008}.el-nav-btn:hover{background:linear-gradient(145deg,var(--gold-pale) 0%,var(--surface) 100%);color:var(--gold);border-color:var(--gold-lt);transform:translateY(-2px);box-shadow:0 6px 15px #c9a22726}.el-source-link{font-size:13px;color:var(--gold);text-decoration:none;font-weight:700;padding:8px 16px;border-radius:12px;background:#c9a2271a;border:1px solid rgba(201,162,39,.3);white-space:nowrap;transition:all .3s}.el-source-link:hover{background:#c9a22733;box-shadow:0 0 15px #c9a2274d;transform:scale(1.05)}.el-lesson-body.vietjack-content{padding:40px;font-size:15px;line-height:1.7;color:var(--t1);width:100%;box-sizing:border-box;word-wrap:break-word;overflow-wrap:break-word}.vietjack-content table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-collapse:collapse}.MathJax_Display{max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.vietjack-content h1{font-size:28px;font-weight:800;color:#ff8c00;margin:0 0 24px;line-height:1.4}.vietjack-content h2{font-size:18px;font-weight:700;color:#00a884;margin:32px 0 12px;padding-top:24px;border-top:1px solid var(--border)}.vietjack-content h3{font-size:16px;font-weight:700;color:#2980b9;margin:24px 0 10px}.vietjack-content h4{font-size:15px;font-weight:700;color:var(--t1);margin:16px 0 8px}.vietjack-content p{margin:10px 0;color:var(--t1)}.vietjack-content img{max-width:100%;height:auto;border-radius:8px;margin:16px auto;display:block;box-shadow:0 4px 16px #0000001a}.vietjack-content iframe{width:100%;border-radius:8px;border:none;margin:16px 0}.vietjack-content ul,.vietjack-content ol{padding-left:22px;margin:10px 0;color:var(--t1)}.vietjack-content li{margin:6px 0}.vietjack-content a{color:#3088e3;text-decoration:none;font-style:italic;font-weight:600}.vietjack-content a:hover{text-decoration:none;color:#216bb5}.vietjack-content .box-new-title,.vietjack-content .paging{display:none}.vietjack-content .box-chia-se,.vietjack-content .box-rating,.vietjack-content .box-vote,.vietjack-content .rating-box,.vietjack-content .vote-box,.vietjack-content .share-box,.vietjack-content .social-share,.vietjack-content [class*=chia-se],.vietjack-content [class*=binh-chon],.vietjack-content .box-ads,.vietjack-content .ads,.vietjack-content .advertisement,.vietjack-content .banner-ads,.vietjack-content .clearfix.chia-se,.vietjack-content .table-chia-se,.vietjack-content .share-bottom,.vietjack-content .fb-share-button,.vietjack-content #fb_like_fb_new,.vietjack-content #fb-share-button,.vietjack-content .facebook-btn,.vietjack-content .zalo,.vietjack-content .zalo-share,.vietjack-content .zalo-share-button,.vietjack-content .kk-star-ratings,.vietjack-content .vote_title,.vietjack-content [class*=kk-star],.vietjack-content [id*=fb_like],.vietjack-content [id*=fb-share]{display:none!important}.vietjack-content .topic,.vietjack-content .n-exercise,.vietjack-content .box-content,.vietjack-content ul.list-bai-viet,.vietjack-content .list-bai-viet li,.vietjack-content div,.vietjack-content p,.vietjack-content table{overflow:visible;width:100%!important;max-width:100%!important;box-sizing:border-box!important}.vietjack-content .topic,.vietjack-content .n-exercise,.vietjack-content .box-content{padding:0!important;margin:0!important}.vietjack-content .topic>div,.vietjack-content .topic>p,.vietjack-content .topic>table,.vietjack-content .n-exercise>div{float:none!important;width:100%!important;max-width:100%!important;box-sizing:border-box}.el-quick-nav-title{font-size:14px;font-weight:700;color:var(--t2);margin:24px 0 12px}.el-quick-nav-container{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;background:var(--surface2);padding:16px;border-radius:12px;border:1px solid var(--border)}.el-quick-nav-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;background:var(--surface);color:var(--gold)!important;border:1px solid var(--gold-lt);border-radius:20px;font-size:13px;font-weight:600;text-decoration:none!important;transition:all .2s ease;box-shadow:0 2px 5px #00000005}.el-quick-nav-btn:hover{background:var(--gold-pale);transform:translateY(-2px);box-shadow:0 4px 10px #c9a22726}body.dark .el-quick-nav-btn{background:#0f172a99;border-color:#38bdf866;color:#38bdf8!important}body.dark .el-quick-nav-btn:hover{background:#0f172ae6;border-color:#38bdf8;box-shadow:0 4px 12px #38bdf84d}.el-sol-content{background:var(--surface2);border:1px solid var(--border);border-radius:16px;padding:24px 32px;margin:16px 0 32px;animation:slideDownFade .4s cubic-bezier(.16,1,.3,1);clear:both;width:100%;box-sizing:border-box;box-shadow:0 10px 30px #0000000d}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.vietjack-content .vj-toc{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 20px;margin:16px 0}.vietjack-content .vj-toc ul{margin:6px 0}.vietjack-content .vj-toc li{margin:4px 0}.el-empty-msg{padding:32px 16px;text-align:center;color:var(--t4);font-size:13px;line-height:1.6}.el-loading{padding:40px;text-align:center}.el-loading .spinner{margin:0 auto 12px}.el-loading p{color:var(--t4);font-size:13px}.el-no-content{padding:48px 24px;text-align:center;color:var(--t4)}.el-no-content h3{font-size:18px;color:var(--t2);margin:0 0 8px}.el-no-content code{background:var(--surface2);padding:6px 12px;border-radius:6px;font-family:monospace;font-size:13px;color:var(--gold);display:inline-block;margin:8px 0}@media (max-width: 900px){.el-view-root{height:calc(100vh - 60px)}.el-mobile-toggle{display:flex}.el-sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;width:300px;max-width:90vw;transform:translate(-100%);box-shadow:4px 0 24px #0000004d}.el-sidebar.open{transform:translate(0)}.el-sidebar-close{display:block}.el-tab-group-label{display:none}.el-tab-btn{padding:8px 10px;font-size:11.5px}.el-content{width:100%}.el-main-content{padding:8px}.el-lesson-title{font-size:18px;padding:14px 16px 10px}.el-content-breadcrumb{padding:10px 16px;margin-bottom:12px}.el-nav-row{padding:10px 16px;flex-wrap:wrap;margin-bottom:16px}.el-lesson-body.vietjack-content{padding:16px;font-size:14.5px;border-radius:12px}.vietjack-content iframe{min-height:200px}.el-sol-content{padding:12px 8px!important;margin:12px 0 24px!important;border-radius:12px}}@media (max-width: 480px){.el-tab-btn{padding:7px 8px;font-size:11px}.el-nav-btn span{display:none}.el-source-link{font-size:11px;padding:5px 10px}}.el-solution-box details summary::-webkit-details-marker{display:none}.el-solution-box summary{list-style:none}.el-solution-box[open] summary{border-bottom:1px solid var(--border)}:root{--el-title-color: #1e293b;--el-question-color: #0284c7;--el-solution-color: #059669}body.dark{--el-title-color: #fbbf24;--el-question-color: #38bdf8;--el-solution-color: #34d399;--bg-gradient: linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%)}body.dark .el-view-root{background:var(--bg-gradient)}.vietjack-content{color:var(--t1);line-height:1.8;font-size:16.5px;letter-spacing:.2px}.vietjack-content b,.vietjack-content strong{color:var(--t1);font-weight:700}.vietjack-content [style*="color:green"],.vietjack-content [style*="color: green"],.vietjack-content [style*="color:#008000"]{color:var(--g500)!important}.vietjack-content [style*="color:red"],.vietjack-content [style*="color: red"]{color:var(--red)!important}.vietjack-content [style*="color:blue"],.vietjack-content [style*="color: blue"]{color:#3b82f6!important}.vietjack-content img{max-width:100%;height:auto;border-radius:12px;margin:16px 0;box-shadow:0 10px 25px #00000026;background:#fff;padding:4px;transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}.vietjack-content img:hover{transform:scale(1.03);box-shadow:0 15px 35px #00000040}body.dark .vietjack-content{color:#f1f5f9!important}body.dark .vietjack-content p,body.dark .vietjack-content span,body.dark .vietjack-content div,body.dark .vietjack-content b,body.dark .vietjack-content strong,body.dark .vietjack-content li,body.dark .vietjack-content td,body.dark .vietjack-content th{color:#f1f5f9!important;background-color:transparent!important}body.dark .vietjack-content h1,body.dark .el-lesson-body>h1{color:transparent!important;background:linear-gradient(90deg,#fbbf24,#f59e0b)!important;-webkit-background-clip:text!important;background-clip:text!important;font-weight:800!important;letter-spacing:-.02em;text-shadow:0 2px 10px rgba(251,191,36,.2)}body.dark .vietjack-content h2,body.dark .vietjack-content h3{color:#34d399!important;font-weight:800!important;text-shadow:0 0 8px rgba(52,211,153,.3)}body.dark .vietjack-content h4{color:#6ee7b7!important;font-weight:700!important}body.dark .el-section-label{color:transparent!important;background:linear-gradient(90deg,#f97316,#f59e0b)!important;-webkit-background-clip:text!important;background-clip:text!important;font-weight:800!important;font-size:1.1em;display:inline-block;padding-bottom:4px;border-bottom:3px solid rgba(249,115,22,.5);margin-top:16px}body.dark .el-solution-box>summary{color:#fbbf24!important;font-weight:800!important}body.dark .vietjack-content a{color:#38bdf8!important;text-decoration-color:#38bdf866!important;transition:all .3s}body.dark .vietjack-content a:hover{color:#bae6fd!important;text-shadow:0 0 10px rgba(56,189,248,.5)}body.dark .vietjack-content img{background-color:#ffffffe6!important;border-radius:8px;padding:4px}body.dark .vietjack-content .box-loigiaihay,body.dark .vietjack-content .box-loigiaihay *{background-color:transparent!important}body.dark a.el-sol-btn{color:#38bdf8!important;border-color:#38bdf866!important;background:#0f172a99!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}body.dark a.el-sol-btn:hover{border-color:#38bdf8!important;box-shadow:0 4px 20px #38bdf84d!important;background:#0f172ae6!important}body.dark a.el-sol-btn.el-sol-open{color:#f97316!important;border-color:#f9731680!important;background:#f973161a!important}a.el-sol-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:16px;padding:10px 24px;background:linear-gradient(135deg,var(--surface) 0%,var(--surface2) 100%);color:var(--g500)!important;border:1px solid var(--border);border-radius:24px;font-size:14.5px;font-weight:700;text-decoration:none!important;transition:all .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 4px 10px #0000000d;cursor:pointer}a.el-sol-btn:hover{background:var(--surface2);border-color:var(--g400);transform:translateY(-3px);box-shadow:0 8px 20px #10b98140}a.el-sol-btn.el-sol-open{background:#ef44441a;border-color:#ef444466;color:var(--red)!important}a.el-sol-btn.el-sol-open:hover{background:#ef444426;box-shadow:0 8px 20px #ef444440}.el-solution-box>summary{transition:all .3s ease;border-radius:12px;font-weight:800!important;padding:12px 16px}.el-solution-box>summary:hover{background:var(--surface3)!important;padding-left:20px}.el-solution-box{background:transparent!important;border-color:var(--border)!important;margin:12px 0}.el-lesson-body>h1{color:var(--el-title-color)!important;font-weight:900!important;margin-bottom:24px;font-size:32px;letter-spacing:-.5px}.el-question-block{color:var(--el-question-color)!important;border-left:5px solid var(--el-question-color)!important;padding:16px 24px;background:#0284c708;border-radius:0 12px 12px 0;margin:24px 0}.el-question-block *{color:inherit!important}.el-solution-title{color:var(--el-solution-color)!important;font-size:1.2em;font-weight:800;display:inline-block;margin-top:16px;border-bottom:3px solid currentColor;padding-bottom:4px;opacity:1}@media (max-width: 950px){body.reading-mode .topbar,body.reading-mode .mobile-nav,body.reading-mode #elHeader{display:none!important}body.reading-mode .page{padding-bottom:0!important;padding-top:0!important;margin-top:0!important;height:100vh!important}body.reading-mode .el-view-root{height:100vh!important;margin-top:0!important}}.el-scraped-bg{background-color:var(--surface2)!important;border-radius:8px}table.el-scraped-bg,td.el-scraped-bg,th.el-scraped-bg{border-radius:0}
