@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:300;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:800;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_22964812-module__6xTrPq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_22964812-module__6xTrPq__variable{--font-inter:"Inter", "Inter Fallback"}
:root{--primary-50:#fffbeb;--primary-100:#fef3c7;--primary-200:#fde68a;--primary-300:#fcd34d;--primary-400:#fbbf24;--primary-500:#f59e0b;--primary-600:#d4920b;--primary-700:#b87a08;--primary-800:#92610a;--primary-900:#78510e;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--accent-blue:#3b82f6;--accent-amber:#f59e0b;--accent-red:#ef4444;--accent-purple:#8b5cf6;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--sidebar-width:260px;--header-height:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #00000008;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #00000008;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--font-scale:.85;--font-family:var(--font-inter,"Inter"), -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-body:#f5f3ef;--bg-card:#fff;--bg-sidebar:#1c1c1e;--bg-sidebar-hover:#2d2d30;--bg-sidebar-active:#3a3a3c;--text-primary:var(--gray-900);--text-secondary:var(--gray-500);--text-sidebar:#ffffffd9;--text-sidebar-active:#fff;--border-color:var(--gray-200)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:calc(16px * var(--font-scale))}body{font-size:1rem}html,body{height:100%;font-family:var(--font-family);color:var(--text-primary);background:var(--bg-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg, var(--bg-sidebar) 0%, #111113 100%);color:var(--text-sidebar);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-brand-logo{object-fit:contain;background:#fff;border-radius:50%;flex-shrink:0;width:40px;height:40px;padding:3px}.sidebar-brand h1{color:#fff;letter-spacing:-.3px;font-size:1.125rem;font-weight:700}.sidebar-brand span{color:#ffffff80;margin-top:2px;font-size:.6875rem;display:block}.sidebar-nav{flex:1;padding:16px 12px}.sidebar-section{margin-bottom:24px}.sidebar-section-title{text-transform:uppercase;letter-spacing:1.2px;color:#ffffff59;margin-bottom:8px;padding:0 12px;font-size:.625rem;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--text-sidebar);align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex}.nav-item:hover{background:var(--bg-sidebar-hover);color:#fff}.nav-item.active{background:var(--bg-sidebar-active);color:var(--text-sidebar-active);font-weight:600}.nav-item-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.125rem}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:4px;padding:12px;display:flex}.sidebar-profile-btn{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px;transition:background .15s;display:flex}.sidebar-profile-btn:hover{background:#ffffff14}.sidebar-user-avatar{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.8125rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff80;text-transform:capitalize;font-size:.6875rem}.sidebar-profile-icon{color:#ffffff59;font-size:.875rem;transition:color .15s}.sidebar-profile-btn:hover .sidebar-profile-icon{color:#ffffffb3}.sidebar-chevron{color:#ffffff59;flex-shrink:0;font-size:.625rem;transition:color .15s}.sidebar-profile-btn--active,.sidebar-profile-btn:hover{background:#ffffff14}.sidebar-profile-btn--active .sidebar-chevron{color:#ffffffb3}.sidebar-footer{position:relative}.sidebar-popup-menu{z-index:9999;background:#fff;border-radius:14px;width:220px;animation:.18s slideInRight;position:fixed;overflow:hidden;box-shadow:0 8px 32px #0000002e,0 2px 8px #00000014}@keyframes slideInRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.sidebar-popup-user{background:linear-gradient(135deg, var(--primary-50), #fffbeb);align-items:center;gap:10px;padding:14px 16px;display:flex}.sidebar-popup-avatar{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:700;display:flex}.sidebar-popup-name{font-family:var(--font-family);color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:700;overflow:hidden}.sidebar-popup-role{font-family:var(--font-family);color:var(--gray-500);text-transform:capitalize;font-size:.6875rem}.sidebar-popup-divider{background:var(--gray-100);height:1px}.sidebar-popup-item{width:100%;font-family:var(--font-family);color:var(--gray-700);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:11px 16px;font-size:.8125rem;font-weight:500;transition:background .12s;display:flex}.sidebar-popup-item:hover{background:var(--gray-50);color:var(--gray-900)}.sidebar-popup-item--danger{color:#dc2626}.sidebar-popup-item--danger:hover{color:#b91c1c;background:#fef2f2}.sidebar-popup-item-icon{background:var(--gray-100);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-popup-item:hover .sidebar-popup-item-icon{background:var(--gray-200)}.sidebar-popup-item--danger .sidebar-popup-item-icon{background:#fee2e2}.sidebar-popup-item--danger:hover .sidebar-popup-item-icon{background:#fecaca}.profile-modal{max-width:400px!important}.profile-card{background:linear-gradient(135deg, var(--primary-50), #fffbeb);border:1px solid var(--primary-200);border-radius:12px;align-items:center;gap:16px;margin-bottom:20px;padding:16px;display:flex}.profile-avatar{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 4px 12px #d4920b40}.profile-info{min-width:0}.profile-name{font-family:var(--font-family);color:var(--gray-900);margin-bottom:2px;font-size:.9375rem;font-weight:700}.profile-username{font-family:var(--font-family);color:var(--gray-500);margin-bottom:6px;font-size:.75rem}.profile-divider{color:var(--gray-400);font-family:var(--font-family);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:10px;margin-bottom:18px;font-size:.6875rem;font-weight:600;display:flex}.profile-divider:before,.profile-divider:after{content:"";background:var(--gray-200);flex:1;height:1px}.profile-language-row{gap:8px;display:flex}.profile-language-btn{flex:1;justify-content:center}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:28px 32px}.card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);min-width:0;transition:box-shadow var(--transition-base);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-body{padding:20px 24px}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:all var(--transition-base);align-items:flex-start;gap:16px;padding:20px 24px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.375rem;display:flex}.stat-icon.green{background:var(--primary-50);color:var(--primary-700)}.stat-icon.blue{color:var(--accent-blue);background:#eff6ff}.stat-icon.amber{color:var(--accent-amber);background:#fffbeb}.stat-icon.purple{color:var(--accent-purple);background:#f5f3ff}.stat-icon.red{color:var(--accent-red);background:#fef2f2}.stat-info h3{color:var(--gray-900);letter-spacing:-.5px;font-size:1.75rem;font-weight:700;line-height:1}.stat-info p{color:var(--text-secondary);margin-top:4px;font-size:.8125rem;font-weight:500}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}table th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);background:var(--gray-50);border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:.6875rem;font-weight:600}table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:14px 16px;font-size:.875rem}table tr:last-child td{border-bottom:none}table tr:hover td{background:var(--gray-50)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary-600), var(--primary-700));color:#fff;box-shadow:0 2px 4px #d4920b4d}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-500), var(--primary-600));transform:translateY(-1px);box-shadow:0 4px 8px #d4920b59}.btn-secondary{background:var(--bg-card);color:var(--gray-700);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;color:var(--gray-400);transition:all var(--transition-fast);background:0 0;border:none;padding:8px;font-size:1rem}.btn-icon:hover{color:var(--gray-700);background:var(--gray-100)}.btn-icon-action{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;padding:0;font-size:1rem;line-height:1;display:inline-flex}.form-group{margin-bottom:18px}.form-group label{color:var(--gray-700);margin-bottom:6px;font-size:.8125rem;font-weight:600;display:block}.form-control{border:1.5px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--gray-900);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#fff;padding:10px 14px;font-family:inherit;font-size:.875rem}.form-control:focus{border-color:var(--primary-500);outline:none;box-shadow:0 0 0 3px #f59e0b1f}.form-control::placeholder{color:var(--gray-400)}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.duration-row{align-items:center;gap:10px;display:flex}.duration-col{flex:1;align-items:center;gap:6px;display:flex}.duration-col .form-control{text-align:center;padding:9px 8px;font-size:.9375rem;font-weight:600}.duration-col .form-control::-webkit-inner-spin-button{opacity:.4}.duration-col .form-control::-webkit-outer-spin-button{opacity:.4}.duration-unit{font-family:var(--font-family);color:var(--gray-500);white-space:nowrap;flex-shrink:0;font-size:.75rem;font-weight:600}.duration-preview{font-family:var(--font-family);color:var(--primary-600);background:var(--primary-50);white-space:nowrap;text-align:center;border-radius:20px;flex-shrink:0;min-width:56px;padding:4px 10px;font-size:.75rem;font-weight:600}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--primary-50);color:var(--primary-700)}.badge-warning{color:#92400e;background:#fffbeb}.badge-danger{color:#991b1b;background:#fef2f2}.badge-info{color:#1d4ed8;background:#eff6ff}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#0f172a73;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;flex-direction:column;width:90%;max-width:480px;max-height:90vh;animation:.3s slideUp;display:flex;box-shadow:0 20px 60px #00000026,0 4px 16px #00000014}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:22px 24px 18px;display:flex}.modal-header h3{font-family:var(--font-family);color:var(--gray-900);margin:0;font-size:1.0625rem;font-weight:700}.modal-close-btn{background:var(--gray-100);width:32px;height:32px;color:var(--gray-500);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:.75rem;line-height:1;transition:all .15s;display:flex}.modal-close-btn:hover{background:var(--gray-200);color:var(--gray-700)}.modal-body{flex:1;padding:22px 24px;overflow-y:auto}.modal-footer{justify-content:flex-end;gap:10px;padding:0 24px 22px;display:flex}.code-display{text-align:center;padding:40px 20px}.code-display .code{letter-spacing:12px;color:var(--primary-700);text-shadow:0 2px 4px #05966926;font-family:Inter,monospace;font-size:4.5rem;font-weight:800}.code-display .code-label{color:var(--text-secondary);margin-bottom:16px;font-size:.875rem;font-weight:500}.code-display .code-timer{color:var(--gray-500);margin-top:20px;font-size:1rem;font-weight:600}.code-display .code-timer.urgent{color:var(--danger)}.status-message{text-align:center;border-radius:var(--radius-md);padding:16px 20px;font-size:.875rem;font-weight:600;animation:.3s slideUp}.status-message.success{background:var(--primary-50);color:var(--primary-700);border:1px solid var(--primary-200)}.status-message.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.login-page{background:linear-gradient(135deg, var(--bg-sidebar) 0%, #043927 40%, var(--primary-700) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl), 0 0 60px #00000026;background:#fff;padding:48px 40px;animation:.5s slideUp}.login-card h1{color:var(--gray-900);text-align:center;letter-spacing:-.5px;font-size:1.75rem;font-weight:800}.login-card .login-subtitle{text-align:center;color:var(--text-secondary);margin-top:8px;margin-bottom:32px;font-size:.875rem}.login-card .login-logo{background:linear-gradient(135deg, var(--primary-500), var(--primary-700));border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;font-size:1.625rem;font-weight:800;display:flex}.login-error{color:#991b1b;border-radius:var(--radius-sm);background:#fef2f2;margin-bottom:16px;padding:10px 14px;font-size:.8125rem;font-weight:500}.empty-state{text-align:center;color:var(--text-secondary);padding:60px 20px}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--gray-700);margin-bottom:8px;font-size:1.125rem;font-weight:600}.empty-state p{max-width:360px;margin:0 auto;font-size:.875rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.modal.modal-lg{max-width:720px}.detail-summary{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px;display:grid}.detail-summary-item{text-align:center;border-radius:var(--radius-sm);background:var(--gray-50);border:1px solid var(--border-color);transition:transform var(--transition-fast);padding:14px 8px}.detail-summary-item:hover{transform:translateY(-2px)}.detail-summary-item.present{background:var(--primary-50);border-color:var(--primary-200)}.detail-summary-item.absent{background:#fef2f2;border-color:#fecaca}.detail-summary-item.late{background:#fffbeb;border-color:#fde68a}.detail-summary-item.rate{background:#eff6ff;border-color:#bfdbfe}.detail-summary-value{color:var(--gray-900);font-size:1.375rem;font-weight:700;line-height:1;display:block}.detail-summary-item.present .detail-summary-value{color:var(--primary-700)}.detail-summary-item.absent .detail-summary-value{color:var(--accent-red)}.detail-summary-item.late .detail-summary-value{color:var(--accent-amber)}.detail-summary-item.rate .detail-summary-value{color:var(--accent-blue)}.detail-summary-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:.6875rem;font-weight:600;display:block}.detail-courses{flex-direction:column;gap:10px;display:flex}.detail-course-card{border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:box-shadow var(--transition-fast);overflow:hidden}.detail-course-card:hover{box-shadow:var(--shadow-sm)}.detail-course-header{cursor:pointer;background:var(--gray-50);transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.detail-course-header:hover{background:var(--gray-100)}.detail-course-info{flex-shrink:0;align-items:center;gap:10px;display:flex}.detail-course-expand{color:var(--text-secondary);width:16px;font-size:.625rem}.detail-course-group{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:2px 8px;font-size:.75rem}.detail-course-stats{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.detail-course-stats .badge{padding:2px 8px;font-size:.6875rem}.detail-rate-bar{background:var(--gray-200);border-radius:3px;width:60px;height:6px;overflow:hidden}.detail-rate-fill{background:linear-gradient(90deg, var(--primary-400), var(--primary-600));height:100%;transition:width var(--transition-base);border-radius:3px}.detail-rate-text{color:var(--gray-600);text-align:right;min-width:36px;font-size:.75rem;font-weight:700}.detail-lessons-table{border-top:1px solid var(--border-color);animation:.2s fadeIn}.detail-lessons-table table th{padding:8px 12px;font-size:.625rem}.detail-lessons-table table td{padding:10px 12px;font-size:.8125rem}.btn-sm-action{background:var(--primary-50);color:var(--primary-700);border:1px solid var(--primary-200);cursor:pointer;border-radius:var(--radius-sm);padding:4px 10px;font-family:inherit;font-size:.75rem}.btn-sm-action:hover{background:var(--primary-100)}.dash-loading{height:60vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:.875rem;display:flex}.dash-loading-spinner{border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite dash-spin}@keyframes dash-spin{to{transform:rotate(360deg)}}.dash-stats{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px;display:grid}.dash-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:14px;padding:18px 20px;transition:transform .18s,box-shadow .18s;display:flex}.dash-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dash-stat-icon{border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;display:flex}.dash-stat-body{flex-direction:column;display:flex}.dash-stat-value{font-size:1.5rem;font-weight:800;font-family:var(--font-family);color:var(--gray-900);line-height:1}.dash-stat-label{color:var(--text-secondary);font-size:.75rem;font-weight:500;font-family:var(--font-family);margin-top:3px}.dash-today-row{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.dash-today-pill{background:var(--bg-card);border:1px solid var(--border-color);color:var(--gray-600);font-size:.8125rem;font-family:var(--font-family);border-radius:20px;align-items:center;gap:8px;padding:6px 14px;display:inline-flex}.dash-today-pill strong{color:var(--gray-900);font-weight:700}.dash-today-pill--rate{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.dash-today-pill--rate strong{color:var(--primary-800)}.dash-today-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dash-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:20px 24px;overflow:hidden}.dash-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dash-card-header h3{color:var(--gray-800);font-size:.9375rem;font-weight:700;font-family:var(--font-family);margin:0}.dash-card-badge{background:var(--primary-50);color:var(--primary-700);font-size:.6875rem;font-weight:600;font-family:var(--font-family);border-radius:20px;padding:3px 10px}.dash-charts{grid-template-columns:1fr 2fr;gap:16px;margin-bottom:0;display:grid}.dash-card--wide{min-height:340px}.dash-hbar-list{flex-direction:column;gap:14px;padding-top:4px;display:flex}.dash-hbar-item{flex-direction:column;gap:6px;display:flex}.dash-hbar-info{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.dash-hbar-name{color:var(--gray-800);font-size:.8125rem;font-weight:600;line-height:1.3}.dash-hbar-meta{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-size:.6875rem}.dash-hbar-bar-wrap{flex-direction:column;gap:4px;display:flex}.dash-hbar-bar{background:var(--gray-100);border-radius:6px;height:10px;display:flex;overflow:hidden}.dash-hbar-fill{height:100%;transition:width .6s cubic-bezier(.25,.8,.25,1)}.dash-hbar-fill--present{background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:6px 0 0 6px}.dash-hbar-fill--absent{background:linear-gradient(90deg,#ef4444,#f87171)}.dash-hbar-stats{align-items:center;gap:12px;font-size:.6875rem;display:flex}.dash-hbar-stat{align-items:center;gap:4px;display:flex}.dash-hbar-stat.present{color:#16a34a}.dash-hbar-stat.absent{color:#dc2626}.dash-hbar-stat:before{content:"";border-radius:50%;width:7px;height:7px}.dash-hbar-stat.present:before{background:#22c55e}.dash-hbar-stat.absent:before{background:#ef4444}.dash-hbar-pct{color:var(--gray-700);margin-left:auto;font-size:.75rem;font-weight:700}.dash-donut-area{position:relative}.dash-donut-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-55%)}.dash-donut-pct{color:var(--gray-800);font-size:1.75rem;font-weight:800;font-family:var(--font-family);display:block}.dash-donut-sub{color:var(--text-secondary);font-size:.75rem;font-weight:500;display:block}.dash-donut-legend{justify-content:center;gap:24px;margin-top:6px;display:flex}.dash-legend-item{color:var(--gray-600);font-size:.8125rem;font-family:var(--font-family);align-items:center;gap:6px;display:flex}.dash-legend-item strong{color:var(--gray-800);margin-left:2px}.dash-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dash-table{border-collapse:collapse;width:100%;font-family:var(--font-family)}.dash-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);background:var(--gray-50);border-bottom:1px solid var(--border-color);padding:10px 14px;font-size:.6875rem;font-weight:600}.dash-table tbody td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:12px 14px;font-size:.8125rem}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr:hover td{background:var(--gray-50)}.lesson-code{letter-spacing:2px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:6px;padding:3px 8px;font-family:Inter,monospace;font-size:.8125rem;font-weight:700}.attendance-fraction{font-size:.8125rem;font-family:var(--font-family);color:var(--gray-600)}.attendance-fraction strong{color:var(--primary-700);font-weight:700}.crud-card{flex-direction:column;height:calc(100vh - 48px);display:flex;overflow:hidden}.crud-card>.card-body{flex:1;padding:20px 24px;overflow-y:auto}.crud-card-header{border-bottom:1px solid var(--border-color);background:var(--gray-50);justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.crud-card-title{color:var(--gray-800);font-size:1.1875rem;font-weight:700;font-family:var(--font-family);white-space:nowrap;align-items:center;gap:8px;display:flex}.crud-card-icon{font-size:1.25rem}.btn-add{letter-spacing:.2px;border-radius:10px;padding:8px 18px;font-size:.8125rem;font-weight:600}.crud-card-actions{align-items:center;gap:8px;display:flex}.btn-import{border-radius:10px;padding:8px 16px;font-size:.8125rem;font-weight:600}.crud-search{align-items:center;display:flex;position:relative}.crud-search-input{font-family:var(--font-family);border:1px solid var(--border-color);height:34px;color:var(--gray-800);background:#fff;border-right:none;border-radius:8px 0 0 8px;outline:none;width:240px;min-width:180px;padding:0 30px 0 12px;font-size:.8125rem;transition:border-color .2s}.crud-search-input:focus{border-color:var(--primary-400)}.crud-search-input::placeholder{color:var(--gray-400)}.crud-search-clear{background:var(--gray-200);width:20px;height:20px;color:var(--gray-500);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.625rem;line-height:1;transition:all .15s;display:flex;position:absolute;top:50%;left:194px;transform:translateY(-50%)}.crud-search-clear:hover{background:var(--gray-300);color:var(--gray-700)}.crud-search-btn{background:linear-gradient(135deg, var(--primary-600), var(--primary-700))!important;color:#fff!important;border:none!important;border-radius:0 8px 8px 0!important;height:34px!important;padding:0 12px!important;font-size:.8125rem!important}.crud-search-btn:hover{transform:translateY(-1px);background:linear-gradient(135deg, var(--primary-500), var(--primary-600))!important;box-shadow:0 4px 8px #d4920b59!important}.import-modal-content{flex-direction:column;gap:14px;display:flex}.import-dropzone:hover,.import-dropzone--active{border-color:var(--primary-400);background:#eff6ff}.import-dropzone-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute;inset:0}.import-dropzone-icon{font-size:2rem;line-height:1}.import-dropzone-label{color:var(--gray-700);text-align:center;font-size:.875rem;font-weight:600}.import-dropzone-filename{color:var(--primary-600,#2563eb);text-align:center;word-break:break-all;font-size:.875rem;font-weight:600}.import-dropzone-hint{color:var(--gray-400);font-size:.75rem}.import-columns-hint{flex-wrap:wrap;gap:6px;display:flex}.import-col-tag{background:var(--gray-100);color:var(--gray-500);border:1px solid var(--border-color);border-radius:999px;padding:2px 10px;font-size:.6875rem;font-weight:500;display:inline-block}.import-col-tag--required{color:var(--primary-600,#2563eb);background:#eff6ff;border-color:#bfdbfe}.import-preview-title{color:var(--gray-700);font-size:.8125rem;font-weight:600}.import-preview-table{border:1px solid var(--border-color);border-radius:10px;max-height:300px;overflow:auto}.import-preview-table table{border-collapse:collapse;width:100%}.import-preview-table table th,.import-preview-table table td{white-space:nowrap;padding:7px 10px;font-size:.75rem}.import-preview-table table thead th{background:var(--gray-50,#f9fafb);border-bottom:1px solid var(--border-color);color:var(--gray-600);z-index:1;font-weight:600;position:sticky;top:0}.import-row-error td{color:#b91c1c;background:#fef2f2}.import-row-issue-detail td{background:#fff7f7;border-bottom:1px solid #fecaca;padding:2px 10px 6px!important}.import-issue-tag{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5;border-radius:999px;margin-right:6px;padding:1px 8px;font-size:.6875rem;display:inline-block}.import-result{border:1px solid var(--border-color);border-radius:10px;padding:10px 14px;font-size:.8125rem}.import-result-success{color:#78510e;background:#ecfdf5;border-color:#a7f3d0}.import-result-warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.report-modal-content{flex-direction:column;gap:16px;display:flex}.report-subtitle{color:var(--gray-500);margin:0;font-size:.8125rem;line-height:1.5}.report-type-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.report-type-card--active{border-color:var(--primary-500);background:linear-gradient(135deg,#f0fdf9 0%,#ecfdf5 100%);box-shadow:0 0 0 3px #10b98124}.report-card-accent{border-radius:14px 0 0 14px;flex-shrink:0;width:5px;display:block}.report-card-accent--green{background:linear-gradient(#d4920b,#b87a08)}.report-card-accent--blue{background:linear-gradient(#3b82f6,#2563eb)}.report-card-body{flex-direction:column;flex:1;gap:10px;padding:16px 14px;display:flex}.report-card-top{align-items:flex-start;gap:10px;display:flex}.report-card-icon{flex-shrink:0;margin-top:2px;font-size:1.375rem;line-height:1}.report-card-text{flex:1;min-width:0}.report-card-title{color:var(--gray-800);font-size:.875rem;font-weight:700;font-family:var(--font-family);margin-bottom:2px}.report-card-desc{color:var(--gray-500);font-size:.75rem;line-height:1.4}.report-card-check{background:var(--primary-500);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-size:.6875rem;font-weight:800;display:flex;box-shadow:0 2px 6px #10b98166}.report-card-cols{flex-wrap:wrap;gap:5px;display:flex}.report-col-pill{background:var(--gray-100);color:var(--gray-500);border:1px solid var(--border-color);white-space:nowrap;font-size:.625rem;font-weight:600;font-family:var(--font-family);border-radius:999px;padding:2px 8px;display:inline-block}.report-type-card--active .report-col-pill{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}.report-col-pill--more{padding:1px 6px;font-size:.75rem}.report-file-note{background:var(--gray-50);border:1px solid var(--border-color);color:var(--gray-600);font-size:.8125rem;font-family:var(--font-family);border-radius:10px;align-items:center;gap:8px;padding:10px 14px;display:flex}.report-file-note-icon{flex-shrink:0;font-size:1rem}.report-file-note strong{color:var(--gray-800);font-weight:600}.report-export-btn--loading{opacity:.85;cursor:not-allowed}.report-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.65s linear infinite global-spin;display:inline-block}.pagination-header{align-items:center;gap:2px;margin-right:4px;display:inline-flex}.pagination-header-btn{border:1px solid var(--border-color);width:28px;height:28px;color:var(--gray-500);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.pagination-header-btn:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.pagination-header-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-header-info{color:var(--gray-600);text-align:center;-webkit-user-select:none;user-select:none;min-width:36px;font-size:.75rem;font-weight:600}.student-cards-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:16px;display:grid}.student-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;padding:20px;transition:transform .2s,box-shadow .2s}.student-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.student-card-top{align-items:center;gap:14px;margin-bottom:16px;display:flex}.student-avatar{background:linear-gradient(135deg, var(--primary-500), var(--primary-700));color:#fff;width:44px;height:44px;font-size:1.125rem;font-weight:700;font-family:var(--font-family);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.student-card-info{flex:1;min-width:0}.student-card-name{color:var(--gray-900);font-size:.9375rem;font-weight:700;font-family:var(--font-family);word-break:break-word;line-height:1.35}.student-card-meta{color:var(--gray-500);font-size:.8125rem;font-family:var(--font-family);margin-top:2px}.student-card-badges{flex-shrink:0}.student-card-details{border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);gap:16px;padding:12px 0;display:flex}.student-card-detail{flex-direction:column;flex:1;gap:4px;display:flex}.student-card-detail-label{text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);font-size:.6875rem;font-weight:600;font-family:var(--font-family)}.student-card-detail-value{color:var(--gray-800);font-size:.8125rem;font-weight:600;font-family:var(--font-family)}.student-card-footer{justify-content:space-between;align-items:center;margin-top:14px;display:flex}.student-card-btn{font-family:var(--font-family);border:1px solid var(--primary-200);background:var(--primary-50);color:var(--primary-700);cursor:pointer;border-radius:8px;align-items:center;gap:4px;padding:6px 14px;font-size:.75rem;font-weight:600;transition:all .15s;display:inline-flex}.student-card-btn:hover{background:var(--primary-100);border-color:var(--primary-300)}.student-card-actions{align-items:center;gap:2px;display:flex}.teacher-cards-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:16px;display:grid}.teacher-card{border:1px solid var(--gray-200);background:#fff;border-radius:14px;transition:box-shadow .2s,transform .15s;overflow:hidden}.teacher-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.teacher-card-top{align-items:center;gap:12px;padding:16px 18px 12px;display:flex}.teacher-card-avatar{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;width:42px;height:42px;font-size:1.0625rem;font-weight:700;font-family:var(--font-family);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.teacher-card-info{flex:1;min-width:0}.teacher-card-name{color:var(--gray-900);font-size:.9375rem;font-weight:700;font-family:var(--font-family);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.teacher-card-badges{flex-shrink:0}.teacher-card-details{border-bottom:1px solid var(--gray-100);grid-template-columns:1fr 1fr;gap:0;padding:0 18px 12px;display:grid}.teacher-card-detail{color:var(--gray-500);font-size:.75rem;font-family:var(--font-family);align-items:center;gap:6px;padding:5px 0;display:flex}.teacher-card-detail:last-child:nth-child(odd){grid-column:1/-1}.teacher-card-detail svg{color:var(--gray-400);flex-shrink:0}.teacher-card-footer{justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.teacher-card-actions{align-items:center;gap:2px;display:flex}.teacher-card-courses{border-bottom:1px solid var(--gray-100);flex-wrap:wrap;align-items:center;gap:6px;padding:8px 18px;display:flex}.teacher-card-courses svg{color:var(--gray-400);flex-shrink:0}.teacher-course-chip{font-family:var(--font-family);color:#92400e;background:#fef3c7;border-radius:20px;padding:2px 10px;font-size:.6875rem;font-weight:600}.class-cards-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:16px;display:grid}.class-card{border:1px solid var(--gray-200);background:#fff;border-radius:14px;transition:box-shadow .2s,transform .15s;overflow:hidden}.class-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.class-card-top{align-items:center;gap:10px;padding:16px 18px 10px;display:flex}.class-card-avatar{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.class-card-title{color:var(--gray-900);font-size:.9375rem;font-weight:700;font-family:var(--font-family);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.class-card-meta{flex-wrap:wrap;gap:6px;padding:0 18px 8px;display:flex}.class-card-tag{color:var(--primary);letter-spacing:.02em;background:#d4920b1f;border-radius:12px;padding:2px 10px;font-size:.6875rem;font-weight:600;display:inline-block}.class-card-footer{border-top:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.class-card-stats{gap:16px;display:flex}.class-stat{align-items:baseline;gap:4px;display:flex}.class-stat-number{color:var(--primary-700);font-size:1rem;font-weight:800;font-family:var(--font-family);line-height:1}.class-stat-label{text-transform:uppercase;letter-spacing:.3px;color:var(--gray-400);font-size:.6875rem;font-weight:600;font-family:var(--font-family)}.course-cards-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:16px;display:grid}.course-card{border:1px solid var(--gray-200);background:#fff;border-radius:14px;transition:box-shadow .2s,transform .15s;overflow:hidden}.course-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.course-card-top{align-items:flex-start;gap:12px;padding:16px 18px 10px;display:flex}.course-card-avatar{background:linear-gradient(135deg, var(--primary-600), var(--primary-400));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-top:2px;display:flex}.course-card-info{flex:1;min-width:0}.course-card-title{color:var(--gray-900);font-size:.9375rem;font-weight:700;font-family:var(--font-family);word-break:break-word;line-height:1.35}.course-card-duration{font-family:var(--font-family);color:#92400e;white-space:nowrap;background:#fef3c7;border-radius:20px;flex-shrink:0;align-items:center;gap:3px;padding:3px 10px;font-size:.6875rem;font-weight:600;display:inline-flex}.course-card-details{padding:0 18px 10px}.course-card-detail{color:var(--gray-500);font-size:.75rem;font-family:var(--font-family);align-items:center;gap:6px;display:flex}.course-card-detail svg{color:var(--gray-400);flex-shrink:0}.course-card-footer{border-top:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.lessons-card-body{position:relative}.lesson-cards-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:16px;display:grid}.ms-chips-row{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.ms-chip{font-family:var(--font-family);white-space:nowrap;border-radius:6px;align-items:center;gap:5px;padding:3px 8px;font-size:.6875rem;font-weight:600;display:inline-flex}.ms-chip-purple{color:#6d28d9;background:#ede9fe}.ms-chip-blue{color:#0369a1;background:#e0f2fe}.ms-chip-amber{color:#92400e;background:#fef3c7}.ms-chip-x{cursor:pointer;width:14px;height:14px;color:inherit;background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.4375rem;transition:background .15s;display:flex}.ms-chip-x:hover{background:#0003}.ms-trigger{border:1px solid var(--gray-300);cursor:pointer;width:100%;font-family:var(--font-family);color:var(--gray-500);text-align:left;background:#fff;border-radius:10px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.8125rem;transition:border-color .2s,border-radius .15s;display:flex}.ms-trigger:hover{border-color:var(--gray-400)}.ms-trigger--open{border-color:var(--primary-400);border-bottom-color:#0000;border-bottom-right-radius:0;border-bottom-left-radius:0}.ms-trigger-label{flex:1}.ms-arrow{color:var(--gray-400);flex-shrink:0;font-size:.5625rem}.ms-inline-panel{border:1px solid var(--primary-400);background:#fff;border-top:none;border-bottom-right-radius:10px;border-bottom-left-radius:10px;animation:.15s fadeIn;overflow:hidden}.ms-search-wrap{border-bottom:1px solid var(--gray-100);padding:8px 8px 6px}.ms-search{width:100%;font-family:var(--font-family);border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-800);box-sizing:border-box;border-radius:7px;outline:none;padding:7px 10px;font-size:.8125rem;transition:border-color .15s}.ms-search:focus{border-color:var(--primary-400);background:#fff}.ms-search::placeholder{color:var(--gray-400)}.ms-options{scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent;max-height:200px;padding:4px;overflow-y:auto}.ms-options::-webkit-scrollbar{width:5px}.ms-options::-webkit-scrollbar-track{background:0 0}.ms-options::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.ms-options::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.ms-option{cursor:pointer;font-family:var(--font-family);color:var(--gray-700);-webkit-user-select:none;user-select:none;border-radius:7px;align-items:center;gap:10px;padding:8px 10px;font-size:.8125rem;transition:background .1s;display:flex}.ms-option:hover{background:var(--gray-50)}.ms-option--selected{background:#fafafa;font-weight:600}.ms-option--disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.ms-check{border:1.5px solid var(--gray-300);color:#fff;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6875rem;transition:all .15s;display:flex}.ms-check-purple{background:#7c3aed;border-color:#7c3aed}.ms-check-blue{background:#0284c7;border-color:#0284c7}.ms-check-amber{background:#d97706;border-color:#d97706}.ms-option-label{flex:1}.ms-no-results{font-family:var(--font-family);color:var(--gray-400);text-align:center;padding:20px;font-size:.75rem;font-style:italic}.ms-list-wrap{position:relative}.ms-scroll-fade{pointer-events:none;background:linear-gradient(#0000,#fffffff2);border-radius:0 0 8px 8px;height:40px;position:absolute;bottom:0;left:0;right:0}.ms-scroll-hint{font-family:var(--font-family);color:var(--gray-400);border-top:1px solid var(--gray-100);letter-spacing:.2px;justify-content:center;align-items:center;gap:4px;padding:5px 0;font-size:.6875rem;font-weight:500;display:flex}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.toast{pointer-events:auto;min-width:320px;max-width:420px;font-family:var(--font-family);background:#fff;border-radius:12px;animation:.3s forwards toast-enter;overflow:hidden;box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f}.toast-exit{animation:.3s forwards toast-exit}@keyframes toast-enter{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes toast-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60px)}}.toast-body{align-items:center;gap:12px;padding:14px 16px;display:flex}.toast-icon{flex-shrink:0;font-size:1.125rem}.toast-message{color:var(--gray-800);flex:1;font-size:.875rem;font-weight:500;line-height:1.4}.toast-close{background:var(--gray-100);width:24px;height:24px;color:var(--gray-400);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:.625rem;transition:all .15s;display:flex}.toast-close:hover{background:var(--gray-200);color:var(--gray-600)}.toast-timer{background:var(--gray-100);height:3px}.toast-timer-bar{transform-origin:0;width:100%;height:100%;animation:linear forwards toast-timer}@keyframes toast-timer{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-info{border-left:4px solid #3b82f6}.toast-success{border-left:4px solid #22c55e}.toast-warning{border-left:4px solid #f59e0b}.toast-error{border-left:4px solid #ef4444}.toast-info .toast-timer-bar{background:#3b82f6}.toast-success .toast-timer-bar{background:#22c55e}.toast-warning .toast-timer-bar{background:#f59e0b}.toast-error .toast-timer-bar{background:#ef4444}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.lesson-history-card{border:1px solid var(--gray-200);background:#fff;border-radius:14px;flex-direction:column;transition:box-shadow .2s,transform .15s;display:flex;overflow:hidden}.lesson-history-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.lesson-history-card-header{background:var(--gray-50);border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.lesson-history-code{letter-spacing:3px;color:var(--gray-800);font-family:JetBrains Mono,Fira Code,monospace;font-size:.9375rem;font-weight:800}.lesson-history-card-body{flex:1;padding:14px 16px}.lesson-history-name{color:var(--gray-800);margin-bottom:4px;font-size:.875rem;font-weight:600}.lesson-history-meta{color:var(--text-secondary);gap:14px;font-size:.75rem;display:flex}.lesson-history-card-footer{border-top:1px solid var(--gray-100);background:var(--gray-50);justify-content:flex-end;padding:10px 16px;display:flex}.active-lesson-trigger{color:#16a34a;cursor:pointer;background:#f0fdf4;border:1px solid #22c55e;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;animation:2s ease-in-out infinite trigger-pulse;display:flex;position:relative}.active-lesson-trigger:hover{background:#dcfce7;transform:scale(1.05)}.active-lesson-trigger-dot{background:#22c55e;border-radius:50%;width:7px;height:7px;animation:1.5s ease-in-out infinite dot-blink;position:absolute;top:4px;right:4px}@keyframes trigger-pulse{0%,to{box-shadow:0 0 #22c55e4d}50%{box-shadow:0 0 0 6px #22c55e00}}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:.3}}.active-modal-layout{flex-direction:column;height:75vh;margin:-22px -24px;display:flex}.active-modal-top{flex-shrink:0;padding:8px 24px 16px}.active-modal-header{text-align:center}.active-modal-course{color:var(--gray-900);font-size:1.0625rem;font-weight:700;font-family:var(--font-family);line-height:1.3}.active-modal-group{color:var(--primary-700);font-size:.8125rem;font-weight:600;font-family:var(--font-family);letter-spacing:.3px;margin-top:2px}.active-modal-qr-zone{border:1px solid var(--gray-200);background:linear-gradient(145deg,#fafafa,#f5f5f4);border-radius:16px;flex-direction:column;align-items:center;gap:14px;padding:16px;display:flex}.active-modal-qr-zone .active-modal-status-row{width:100%}.active-modal-qr-img{border-radius:10px;width:140px;height:140px;box-shadow:0 2px 10px #0000000f}.active-modal-qr-zone .active-modal-stats{width:100%}.active-modal-status-row{justify-content:space-between;align-items:center;display:flex}.active-modal-live-badge{color:#15803d;font-size:.75rem;font-weight:700;font-family:var(--font-family);text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:999px;align-items:center;gap:7px;padding:5px 16px;display:inline-flex}.active-modal-live-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite dot-blink;box-shadow:0 0 6px #22c55e99}.active-modal-timer{color:var(--primary-700);font-size:1rem;font-weight:800;font-family:var(--font-family);font-variant-numeric:tabular-nums;align-items:center;gap:4px;display:inline-flex}.active-modal-timer--danger{color:#dc2626;animation:1s ease-in-out infinite pulse-soft}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.6}}.active-modal-code-row{gap:6px;display:flex}.active-modal-code-char{width:36px;height:40px;color:var(--primary-700);border:2px solid var(--primary-200);font-size:1.125rem;font-weight:800;font-family:var(--font-family);background:#fff;border-radius:10px;justify-content:center;align-items:center;display:inline-flex;box-shadow:0 1px 4px #0000000a}.active-modal-stats{gap:8px;display:flex}.active-modal-stat{border-radius:10px;flex:1;align-items:center;gap:6px;padding:8px 10px;display:flex}.active-modal-stat--present{color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0}.active-modal-stat--absent{color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca}.active-modal-stat-number{font-size:1.125rem;font-weight:800;font-family:var(--font-family);line-height:1}.active-modal-stat-label{text-transform:uppercase;letter-spacing:.4px;opacity:.8;font-size:.5625rem;font-weight:700;font-family:var(--font-family)}.active-modal-divider{border-top:1px solid var(--gray-200);flex-shrink:0;align-items:center;padding:0 24px;display:flex}.active-modal-divider span{color:var(--gray-500);font-size:.75rem;font-weight:700;font-family:var(--font-family);text-transform:uppercase;letter-spacing:.5px;padding:10px 0}.active-modal-bottom{flex:1;min-height:0;padding:0 24px;overflow-y:auto}.active-modal-list{border:1px solid var(--gray-200);background:var(--gray-50);border-radius:14px}.active-modal-list-item{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:10px 14px;transition:background .15s;display:flex}.active-modal-list-item:last-child{border-bottom:none}.active-modal-list-item:hover{background:#fff}.active-modal-list-left{align-items:center;gap:10px;min-width:0;display:flex}.active-modal-list-avatar{width:30px;height:30px;font-size:.75rem;font-weight:700;font-family:var(--font-family);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.active-modal-list-avatar--present{color:#16a34a;background:#dcfce7}.active-modal-list-avatar--absent{color:#991b1b;background:#fee2e2}.active-modal-list-name{color:var(--gray-800);font-size:.8125rem;font-weight:600;font-family:var(--font-family);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.active-modal-list-actions{flex-shrink:0;align-items:center;gap:5px;display:flex}.active-modal-list-status{font-size:.6875rem;font-weight:700;font-family:var(--font-family);text-transform:capitalize;border-radius:999px;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.active-modal-list-status--present{color:#16a34a;background:#dcfce7}.active-modal-list-status--absent{color:#991b1b;background:#fee2e2}.active-modal-override{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.active-modal-override:hover{opacity:.85;transform:scale(1.05)}.active-modal-override--present{color:#16a34a;background:#dcfce7}.active-modal-override--absent{color:#991b1b;background:#fee2e2}.active-modal-empty{text-align:center;color:var(--gray-400);padding:30px 20px}.active-modal-empty svg{opacity:.5;margin-bottom:8px}.active-modal-empty p{color:var(--gray-500);font-size:.9375rem;font-weight:600;font-family:var(--font-family);margin:0 0 4px}.active-modal-empty span{color:var(--gray-400);font-size:.75rem;font-family:var(--font-family)}.active-modal-close-btn{color:#fff;cursor:pointer;width:100%;font-size:.875rem;font-weight:700;font-family:var(--font-family);background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px;transition:all .2s;display:flex;box-shadow:0 2px 8px #dc26264d}.active-modal-close-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #dc262666}.active-modal-footer{border-top:1px solid var(--gray-100);flex-shrink:0;padding:16px 24px 20px}.detail-code-block{text-align:center;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:14px;padding:20px}.detail-code-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:8px;font-size:.6875rem;font-weight:600}.detail-code-value{letter-spacing:8px;color:var(--gray-900);font-family:JetBrains Mono,Fira Code,monospace;font-size:2.25rem;font-weight:900}.detail-summary{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.detail-stat{text-align:center;border:1px solid #0000000d;border-radius:12px;padding:14px}.detail-stat-value{margin-bottom:4px;font-size:1.625rem;font-weight:800;line-height:1}.detail-stat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:.6875rem;font-weight:600}.status-pill{cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;line-height:1.4;transition:opacity .15s,filter .15s;display:inline-flex}.status-pill:hover{filter:brightness(.95)}.status-pill__dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.status-pill--active{color:#065f46;background:#d1fae5}.status-pill--active .status-pill__dot{background:#d4920b}.status-pill--inactive{color:#6b7280;background:#f3f4f6}.status-pill--inactive .status-pill__dot{background:#9ca3af}.global-spinner{border:2.5px solid #10b98140;border-top-color:#22c55e;border-radius:50%;width:18px;height:18px;animation:.65s linear infinite global-spin}@keyframes global-spin{to{transform:rotate(360deg)}}.mobile-menu-btn,.sidebar-overlay{display:none}@media (max-width:1024px){:root{--sidebar-width:220px}.main-content{padding:24px 20px}.sidebar-brand{padding:20px 16px}.sidebar-nav{padding:12px 10px}.detail-summary{grid-template-columns:repeat(3,1fr)}.student-cards-grid,.teacher-cards-grid,.class-cards-grid,.lesson-cards-grid,.course-cards-grid,.dash-stats{grid-template-columns:repeat(2,1fr)}.crud-card{height:auto;min-height:calc(100vh - 48px)}.crud-search-input{width:180px}.crud-search-clear{left:auto;right:70px}}@media (max-width:768px){:root{--sidebar-width:280px}.sidebar{width:var(--sidebar-width);z-index:1001;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-100%)}.sidebar.sidebar--open{transform:translate(0)}.sidebar-overlay{z-index:1000;background:#00000080;animation:.2s fadeIn;display:block;position:fixed;inset:0}.mobile-menu-btn{z-index:999;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);width:42px;height:42px;color:var(--gray-700);cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:fixed;top:16px;left:14px}.mobile-menu-btn:hover{background:var(--gray-50)}.main-content{max-width:100vw;margin-left:0;padding:72px 14px 24px;overflow-x:hidden}.stat-card{padding:16px}.stat-icon{width:40px;height:40px;font-size:1.125rem}.stat-info h3{font-size:1.375rem}.student-cards-grid,.teacher-cards-grid,.class-cards-grid,.lesson-cards-grid,.course-cards-grid{grid-template-columns:1fr}.dashboard-page{overflow-x:hidden}.dash-stats{grid-template-columns:1fr;gap:8px}.dash-stat-card{gap:12px;padding:14px 16px}.dash-stat-icon{width:40px;height:40px}.dash-stat-value{font-size:1.35rem}.dash-stat-label{font-size:.75rem}.dash-today-row{flex-direction:column;gap:6px}.dash-today-pill{justify-content:center;width:100%;padding:8px 14px;font-size:.8125rem}.dash-charts{grid-template-columns:1fr}.dash-card{padding:14px}.dash-card--wide{min-height:auto}.dash-card-header h3{font-size:.8125rem}.dash-donut-pct{font-size:1.375rem}.dash-donut-legend{gap:16px}.dash-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.dash-table thead th,.dash-table tbody td{white-space:nowrap;padding:8px 10px;font-size:.75rem}.admin-chart-card .card-body{padding:14px 12px;overflow:hidden}.detail-summary{grid-template-columns:repeat(2,1fr);gap:8px}.admin-charts-row{flex-wrap:wrap}.admin-chart-card{width:100%;min-width:0}.crud-card{height:auto;min-height:0}.crud-card-header{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.crud-card-actions{flex-wrap:wrap;gap:8px}.crud-card-actions>.btn-icon-action{gap:6px;width:auto;height:34px;padding:0 12px;font-size:.75rem}.crud-search{order:10;width:100%}.crud-search-input{flex:1;width:100%;min-width:0}.crud-search-clear{left:auto;right:70px}.crud-card>.card-body{padding:12px}.btn-add{justify-content:center;width:100%}.table-container{margin:0 -12px;padding:0 12px}table th,table td{padding:10px 12px;font-size:.8125rem}.modal-overlay{align-items:flex-end}.modal{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:92vh;animation:.3s slideUpMobile}.modal-header{padding:18px 20px 14px}.modal-body{padding:18px 20px}.modal-footer{padding:0 20px 20px}.modal.large-modal{max-width:100%}.code-display .code{letter-spacing:8px;font-size:3rem}.active-modal-qr-img{width:120px;height:120px}.code-display .code-timer{font-size:.875rem}.login-card{padding:32px 24px}.login-card h1{font-size:1.5rem}.btn{padding:10px 16px;font-size:.8125rem}.btn-sm{padding:6px 12px;font-size:.75rem}.pagination-header-btn{width:24px;height:24px}.pagination-header-info{min-width:28px;font-size:.6875rem}.sidebar-popup-menu{width:calc(100% - 32px);max-width:320px;animation:.2s slideUpMobile;position:fixed;bottom:16px;left:50%;transform:translate(-50%);top:auto!important}.sidebar-inline-menu{background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;margin-bottom:6px;animation:.18s slideUp;overflow:hidden}.sidebar-inline-menu-item{width:100%;font-family:var(--font-family);color:#ffffffe6;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:12px 14px;font-size:.875rem;font-weight:500;transition:background .12s;display:flex}.sidebar-inline-menu-item:hover{background:#ffffff1a}.sidebar-inline-menu-item+.sidebar-inline-menu-item{border-top:1px solid #ffffff14}.sidebar-inline-menu-item--danger{color:#fca5a5}.sidebar-inline-menu-item--danger:hover{background:#ef44441f}.sidebar-inline-menu-icon{background:#ffffff1a;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-inline-menu-item--danger .sidebar-inline-menu-icon{background:#ef444426}.profile-modal{max-width:100%!important}.profile-card{gap:12px;padding:14px}.profile-name{font-size:.875rem}.profile-language-row{flex-direction:column}.profile-language-btn{width:100%}.ms-dropdown{max-height:200px}.toast-container{max-width:none;bottom:12px;left:12px;right:12px}}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.detail-summary{grid-template-columns:1fr}.active-modal-qr-img{width:100px;height:100px}.active-modal-top{padding:14px}.active-modal-course{font-size:.9375rem}.active-modal-stat-number{font-size:1.125rem}.active-modal-close-btn{padding:10px 16px;font-size:.8125rem}.active-modal-list-name{font-size:.8125rem}.dash-stats{gap:8px}.dash-stat-card{gap:8px;padding:10px 12px}.dash-stat-icon{width:32px;height:32px}.dash-stat-value{font-size:1.125rem}.dash-today-pill{padding:5px 8px;font-size:.6875rem}.dash-card{padding:12px}.dash-donut-pct{font-size:1.375rem}.code-display .code{letter-spacing:6px;font-size:2.5rem}.stat-card{gap:12px;padding:14px 12px}.stat-info h3{font-size:1.25rem}.stat-info p{font-size:.75rem}.main-content{padding:68px 10px 20px}.card-body{padding:16px}.crud-card>.card-body{padding:10px}.modal-header h3{font-size:.9375rem}.admin-chart-card .card-body{padding:12px 10px}.login-card{padding:28px 20px}.login-card h1{font-size:1.375rem}.btn{padding:9px 14px}}@media (max-width:768px){.dashboard-page .admin-section-header{flex-direction:column;align-items:flex-start;gap:8px}.dashboard-page .admin-section-badge{align-self:flex-start}.dashboard-page .admin-card-title{font-size:.875rem;line-height:1.35}.dashboard-page .admin-card-title span{margin-top:4px;display:inline-block;margin-left:0!important}.dashboard-responsive-table td .lesson-code,.dashboard-responsive-table td .attendance-fraction,.dashboard-responsive-table td .badge,.dashboard-responsive-table td .status-badge,.dashboard-responsive-table td button.btn-sm-action{white-space:nowrap;padding:6px 10px;font-size:.75rem}.dashboard-page .admin-donut-wrapper{justify-content:center;align-items:center;width:100%;min-height:220px;display:flex}.dashboard-page .recharts-responsive-container{min-width:0;width:100%!important}.dashboard-page .recharts-surface{overflow:visible}}@media (max-width:480px){.profile-card{flex-direction:column;align-items:flex-start}.profile-avatar{width:44px;height:44px;font-size:1rem}.profile-divider{font-size:.625rem}}.inst-page{max-width:1160px;margin:0 auto}.inst-form{flex-direction:column;gap:20px;display:flex}.inst-header{border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-md);background:linear-gradient(135deg,#1c1c1e 0%,#26262a 55%,#2d2a22 100%);align-items:center;gap:20px;padding:26px 30px;display:flex;position:relative;overflow:hidden}.inst-header-glow{pointer-events:none;background:radial-gradient(circle,#f59e0b2e 0%,#0000 70%);border-radius:50%;width:260px;height:260px;position:absolute;top:-60px;right:-40px}.inst-header-logo{border-radius:var(--radius-md);width:64px;height:64px;color:var(--primary-300);background:#ffffff12;border:1px solid #f59e0b40;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.inst-header-logo img{object-fit:cover;width:100%;height:100%}.inst-header-main{flex:1;min-width:0;position:relative}.inst-header-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--primary-400);margin-bottom:3px;font-size:.6875rem;font-weight:700}.inst-header-title{text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:1.375rem;font-weight:700;overflow:hidden}.inst-header-sub{color:#fff9;font-size:.875rem}.inst-header-stats{flex-wrap:wrap;flex-shrink:0;gap:10px;display:flex;position:relative}.inst-stat-chip{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff12;border:1px solid #ffffff1a;flex-direction:column;align-items:center;min-width:96px;padding:10px 16px;display:flex}.inst-stat-value{color:#fff;font-size:1.125rem;font-weight:700}.inst-stat-label{text-transform:uppercase;letter-spacing:.04em;color:#ffffff8c;margin-top:2px;font-size:.6875rem}.inst-layout{grid-template-columns:210px minmax(0,1fr);align-items:start;gap:22px;display:grid}.inst-nav{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:14px 12px;display:flex;position:sticky;top:20px}.inst-nav-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);padding:0 10px 8px;font-size:.6875rem;font-weight:700}.inst-nav-item{border-radius:var(--radius-sm);width:100%;color:var(--gray-600);text-align:left;cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:9px 10px;font-family:inherit;font-size:.8125rem;font-weight:600;display:flex}.inst-nav-item:hover{background:var(--gray-50);color:var(--gray-900)}.inst-nav-item.active{background:var(--primary-50);color:var(--primary-800)}.inst-nav-item-icon{background:var(--gray-100);width:26px;height:26px;color:var(--gray-500);transition:all var(--transition-fast);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.inst-nav-item.active .inst-nav-item-icon{background:var(--primary-600);color:#fff}.inst-nav-unsaved{border-top:1px solid var(--border-color);color:var(--primary-700);align-items:center;gap:8px;margin-top:8px;padding:8px 10px;font-size:.75rem;font-weight:600;display:flex}.inst-content{flex-direction:column;gap:20px;min-width:0;display:flex}.inst-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base);scroll-margin-top:20px;overflow:hidden}.inst-card:hover{box-shadow:var(--shadow-md)}.inst-card-head{border-bottom:1px solid var(--gray-100);background:linear-gradient(180deg, var(--gray-50) 0%, var(--bg-card) 100%);align-items:flex-start;gap:12px;padding:18px 22px;display:flex}.inst-card-title{color:var(--text-primary);font-size:.9375rem;font-weight:700}.inst-card-title-icon{border-radius:var(--radius-sm);background:var(--primary-50);border:1px solid var(--primary-100);width:36px;height:36px;color:var(--primary-700);flex-shrink:0;justify-content:center;align-items:center;display:flex}.inst-card-hint{color:var(--text-secondary);margin-top:3px;font-size:.8125rem}.inst-card-body{padding:20px 22px 22px}.inst-field-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.inst-divider{background:var(--gray-100);height:1px;margin:4px 0 18px}.inst-input-icon{position:relative}.inst-input-icon>svg{color:var(--gray-400);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.inst-input-icon .form-control{padding-left:36px}.inst-input-suffix{flex-shrink:0;width:140px;position:relative}.inst-input-suffix .form-control{padding-right:60px}.inst-input-suffix-label{color:var(--text-secondary);pointer-events:none;font-size:.75rem;font-weight:600;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.inst-radius-row{align-items:center;gap:16px;display:flex}.inst-range{appearance:none;background:var(--gray-200);height:6px;accent-color:var(--primary-600);cursor:pointer;border-radius:999px;flex:1}.inst-range::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary-600);cursor:grab;border:3px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #00000040}.inst-range::-moz-range-thumb{background:var(--primary-600);cursor:grab;border:3px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 4px #00000040}.inst-chips{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.inst-chip{border:1.5px solid var(--border-color);background:var(--bg-card);color:var(--gray-600);cursor:pointer;transition:all var(--transition-fast);border-radius:999px;padding:5px 14px;font-family:inherit;font-size:.75rem;font-weight:600}.inst-chip:hover{border-color:var(--primary-300);color:var(--primary-700)}.inst-chip.active{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.inst-loc-actions{flex-wrap:wrap;gap:10px;margin-bottom:18px;display:flex}.inst-map{border-radius:var(--radius-md);border:1px solid var(--border-color);margin-top:16px;position:relative;overflow:hidden}.inst-map iframe{border:0;width:100%;height:300px;display:block}.inst-map-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#1c1c1ed9;border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:.75rem;font-weight:600;display:inline-flex;position:absolute;top:10px;right:10px}.inst-map-empty{text-align:center;border-radius:var(--radius-md);border:1px dashed var(--border-color);background:var(--gray-50);height:220px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:8px;margin-top:16px;padding:20px;font-size:.8125rem;display:flex}.inst-map-link{color:var(--primary-700);align-items:center;gap:6px;margin-top:10px;font-size:.8125rem;font-weight:600;display:inline-flex}.inst-map-link:hover{color:var(--primary-800);text-decoration:underline}.inst-actionbar{z-index:5;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);background:#ffffffeb;justify-content:flex-end;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;bottom:12px}.inst-actionbar-note{color:var(--primary-700);align-items:center;gap:8px;margin-right:auto;font-size:.8125rem;font-weight:600;display:inline-flex}.inst-actionbar-note-dot{background:var(--warning);border-radius:50%;width:8px;height:8px;animation:1.6s ease-in-out infinite instPulse;box-shadow:0 0 0 3px #f59e0b2e}@keyframes instPulse{0%,to{box-shadow:0 0 0 3px #f59e0b2e}50%{box-shadow:0 0 0 6px #f59e0b14}}.inst-page .btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}@media (max-width:1024px){.inst-layout{grid-template-columns:1fr}.inst-nav{flex-flow:wrap;align-items:center;gap:8px;padding:10px 12px;position:static}.inst-nav-title{display:none}.inst-nav-item{width:auto}.inst-nav-unsaved{border-top:none;margin-top:0;margin-left:auto;padding:0 4px}}@media (max-width:700px){.inst-header{flex-direction:column;align-items:flex-start;padding:22px 20px}.inst-header-stats{width:100%}.inst-stat-chip{flex:1}.inst-field-row{grid-template-columns:1fr;gap:0}.inst-radius-row{flex-direction:column;align-items:stretch;gap:12px}.inst-input-suffix{width:100%}.inst-actionbar{flex-wrap:wrap;bottom:8px}}
