@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800&family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800&family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&display=swap";:root{--cream-50:#fffdf7;--cream-100:#fff9e8;--cream-200:#fff3d0;--cream-300:#ffebb3;--cream-400:#ffe08a;--cream-500:#ffd460;--cream-600:#ffc933;--cream-700:#f5b800;--cream-800:#cc9a00;--cream-900:#8a6800;--amber-400:#fbbf24;--amber-500:#f59e0b;--amber-600:#d97706;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;--success:#22c55e;--danger:#ef4444;--info:#3b82f6;--warning:#f59e0b;--bg-primary:var(--cream-50);--bg-card:#fff;--bg-glass:#ffffffe0;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 8px 32px #00000014;--shadow-xl:0 16px 48px #0000001a;--shadow-glow:0 0 40px #ffd46040;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--duration-fast:.12s;--duration-normal:.24s;--duration-slow:.4s}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0;outline:none!important}:focus{outline:none!important}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-primary);color:var(--slate-800);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:700;line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;font-family:Inter,sans-serif;font-weight:500}input{outline:none;font-family:Inter,sans-serif}.page-wrapper{min-height:100vh;position:relative}.bg-pattern{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bg-pattern .circle{opacity:.12;will-change:transform;border-radius:50%;animation:16s ease-in-out infinite floatCircle;position:absolute}.bg-pattern .circle:first-child{background:var(--cream-400);width:400px;height:400px;animation-delay:0s;top:-100px;right:-80px}.bg-pattern .circle:nth-child(2){background:var(--amber-400);width:300px;height:300px;animation-delay:-5s;bottom:-50px;left:-60px}.bg-pattern .circle:nth-child(3){background:var(--cream-500);width:200px;height:200px;animation-delay:-11s;top:40%;left:50%}.bg-pattern .circle:nth-child(4){background:var(--amber-500);width:150px;height:150px;animation-delay:-2s;top:20%;left:20%}.bg-pattern .circle:nth-child(5){background:var(--cream-600);width:250px;height:250px;animation-delay:-8s;bottom:20%;right:15%}@keyframes floatCircle{0%,to{transform:translate(0)scale(1)}25%{transform:translate(30px,-40px)scale(1.05)}50%{transform:translate(-20px,20px)scale(.95)}75%{transform:translate(15px,35px)scale(1.03)}}.glass-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid #fff9}.btn-primary{background:linear-gradient(135deg, var(--cream-400), var(--cream-600));color:var(--slate-900);border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-smooth);border:none;justify-content:center;align-items:center;gap:8px;padding:14px 32px;font-size:1rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 10px 15px -3px #ffc93366,0 4px 6px -2px #ffc9331a}.btn-primary:before{content:"";background:linear-gradient(135deg, var(--cream-500), var(--cream-700));opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);border-radius:inherit;position:absolute;inset:0}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #ffc93380,0 10px 10px -5px #ffc93333}.btn-primary:hover:before{opacity:1}.btn-primary span,.btn-primary svg{z-index:1;position:relative}.btn-primary:active{transform:translateY(0)}.btn-outline{color:var(--slate-700);border-radius:var(--radius-full);border:2px solid var(--cream-400);transition:all var(--duration-normal) var(--ease-smooth);background:0 0;justify-content:center;align-items:center;gap:8px;padding:14px 32px;font-size:1rem;font-weight:600;display:inline-flex}.btn-outline:hover{background:var(--cream-100);border-color:var(--cream-500);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-outline:active{transform:translateY(0)}.btn-danger{color:var(--danger);border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-smooth);background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #ef444433;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-danger:hover{background:linear-gradient(135deg,#fecaca,#fca5a5);transform:translateY(-1px);box-shadow:0 4px 12px #ef444433}.btn-success{color:#15803d;border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-smooth);background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #22c55e33;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-success:hover{background:linear-gradient(135deg,#bbf7d0,#86efac);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e33}.input-field{background:var(--cream-50);border:2px solid var(--cream-200);border-radius:var(--radius-md);width:100%;color:var(--slate-800);transition:all var(--duration-normal) var(--ease-smooth);padding:14px 18px;font-size:.95rem}.input-field::placeholder{color:var(--slate-400)}.input-field:focus{border-color:var(--cream-500);background:#fff;box-shadow:0 0 0 4px #ffd46026}.input-group{width:100%;position:relative}.input-group .input-icon{color:var(--slate-400);transition:color var(--duration-normal) var(--ease-smooth);pointer-events:none;font-size:1.1rem;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.input-group .input-field{padding-left:46px}.input-group:focus-within .input-icon{color:var(--cream-600)}.form-container{flex-direction:column;gap:20px;width:100%;display:flex}.form-label{color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.toast{border-radius:var(--radius-md);z-index:9999;box-shadow:var(--shadow-lg);animation:slideInRight .4s var(--ease-spring);padding:14px 24px;font-size:.9rem;font-weight:500;position:fixed;bottom:24px;right:24px}.toast-success{color:#15803d;background:#dcfce7;border:1px solid #22c55e33}.toast-error{color:#dc2626;background:#fee2e2;border:1px solid #ef444433}@keyframes slideInRight{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:translate(0)}}.spinner{border:3px solid #ffffff4d;border-top-color:currentColor;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.shimmer{background:linear-gradient(90deg,#fff0 0%,#fff6 50%,#fff0 100%) 0 0/200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.smooth-image-container{background:var(--slate-100)}.auth-icon .smooth-image-container{background:0 0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--cream-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--cream-500)}@media (width<=768px){.btn-primary,.btn-outline{padding:12px 24px;font-size:.9rem}}.grecaptcha-badge{visibility:hidden!important}.landing-nav{z-index:100;-webkit-backdrop-filter:none;background:#fffdf7f2;border-bottom:1px solid #ffe48a4d;padding:16px 0;position:fixed;top:0;left:0;right:0}@media (width>=901px){.landing-nav{-webkit-backdrop-filter:blur(16px);background:#fffdf7d9}}.nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;display:flex}.nav-logo{cursor:pointer;align-items:center;gap:10px;display:flex}.nav-actions{align-items:center;gap:12px;display:flex}.btn-nav{padding:10px 20px!important;font-size:.875rem!important}.hero-section{z-index:1;justify-content:center;align-items:center;gap:80px;max-width:1200px;min-height:100vh;margin:0 auto;padding:120px 24px 80px;display:flex;position:relative}.hero-content{text-align:left;flex:1;max-width:600px}.hero-badge{background:var(--cream-100);border:1px solid var(--cream-300);border-radius:var(--radius-full);color:var(--amber-600);align-items:center;gap:8px;margin-bottom:24px;padding:8px 18px;font-size:.85rem;font-weight:600;display:inline-flex}.badge-dot{background:var(--success);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.hero-title{color:var(--slate-900);margin-bottom:20px;font-size:3.5rem;font-weight:900;line-height:1.1}.text-gradient{background:linear-gradient(135deg, var(--cream-600), var(--amber-500), var(--cream-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--slate-500);max-width:520px;margin-bottom:36px;font-size:1.15rem;line-height:1.7}.hero-buttons{flex-wrap:wrap;justify-content:flex-start;gap:16px;display:flex}.btn-hero{padding:16px 36px!important;font-size:1rem!important}.hero-visual{flex:1;justify-content:center;align-items:center;max-width:480px;display:flex}.hero-card-stack{width:100%;height:380px;position:relative}.floating-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#ffffffeb;border:1px solid #ffffffb3;align-items:center;gap:14px;min-width:260px;padding:18px 24px;display:flex;position:absolute}.card-1{top:20px;left:10px}.card-2{top:150px;right:0}.card-3{top:280px;left:30px}.fc-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--cream-200), var(--cream-300));width:46px;height:46px;color:var(--amber-600);flex-shrink:0;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.fc-icon.icon-green{color:#16a34a;background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.fc-icon.icon-purple{color:#7c3aed;background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.fc-title{color:var(--slate-800);font-size:.95rem;font-weight:700}.fc-sub{color:var(--slate-400);margin-top:2px;font-size:.8rem}.features-section{z-index:1;max-width:1200px;margin:0 auto;padding:80px 24px 90px;position:relative}.section-alt{border-radius:var(--radius-xl);background:linear-gradient(#fff9e880 0%,#0000 100%);max-width:1220px;margin-left:auto;margin-right:auto;padding:80px 40px 90px}.section-header{text-align:center;margin-bottom:52px}.section-tag{background:var(--cream-100);border:1px solid var(--cream-300);border-radius:var(--radius-full);color:var(--amber-600);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding:6px 16px;font-size:.8rem;font-weight:700;display:inline-block}.tag-amber{color:#c2410c;text-transform:none;background:#fff7ed;border-color:#fed7aa;font-size:.85rem}.tag-green{color:#15803d;text-transform:none;background:#f0fdf4;border-color:#bbf7d0;font-size:.85rem}.tag-blue{color:#1d4ed8;text-transform:none;background:#eff6ff;border-color:#bfdbfe;font-size:.85rem}.section-title{color:var(--slate-900);margin-bottom:12px;font-size:2.4rem}.section-desc{color:var(--slate-500);max-width:540px;margin:0 auto;font-size:1.05rem}.features-grid{grid-template-columns:repeat(3,1fr);justify-content:center;justify-items:center;gap:22px;display:grid}.features-grid.grid-4{grid-template-columns:repeat(4,1fr);justify-content:center;justify-items:center}.feature-card{text-align:center;width:100%;max-width:320px;padding:30px 24px;transition:all .3s}.feature-card:hover{box-shadow:var(--shadow-xl), var(--shadow-glow);transform:translateY(-6px)}.feature-icon{background:linear-gradient(135deg, var(--cream-200), var(--cream-300));border-radius:var(--radius-lg);width:56px;height:56px;color:var(--amber-600);justify-content:center;align-items:center;margin:0 auto 18px;font-size:1.5rem;display:flex}.feature-icon.icon-teacher{color:#16a34a;background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.feature-icon.icon-parent{color:#2563eb;background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.feature-title{color:var(--slate-800);margin-bottom:8px;font-size:1.05rem}.feature-desc{color:var(--slate-500);font-size:.85rem;line-height:1.55}.modules-ribbon{-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fffffff2;border:1px solid #fff9;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:40px;padding:20px 28px;display:flex}@media (width>=901px){.modules-ribbon{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}}.ribbon-label{color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:.85rem;font-weight:700}.ribbon-chips{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.ribbon-chip{background:linear-gradient(135deg, var(--cream-100), var(--cream-200));border:1px solid var(--cream-300);border-radius:var(--radius-full);color:var(--amber-600);padding:6px 18px;font-size:.8rem;font-weight:600;transition:all .25s}.ribbon-chip:hover{background:linear-gradient(135deg, var(--cream-300), var(--cream-400));box-shadow:var(--shadow-sm);transform:translateY(-2px)}.extras-grid{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.extra-chip{color:var(--slate-700);align-items:center;gap:10px;padding:14px 22px;font-size:.9rem;font-weight:600;transition:all .3s;display:inline-flex}.extra-chip:hover{box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-4px)}.extra-chip-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--cream-200), var(--cream-300));width:36px;height:36px;color:var(--amber-600);flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.cta-section{z-index:1;max-width:1200px;margin:0 auto;padding:0 24px 100px;position:relative}.cta-card{text-align:center;background:linear-gradient(135deg,#fff4cdb3,#fffdf7e6);padding:64px 40px}.cta-title{color:var(--slate-900);margin-bottom:12px;font-size:2.2rem}.cta-desc{color:var(--slate-500);margin-bottom:32px;font-size:1.05rem}.landing-footer{border-top:1px solid var(--cream-200);z-index:1;padding:40px 0;position:relative}.footer-inner{text-align:center;flex-direction:column;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;display:flex}.footer-brand{flex-direction:column;align-items:center;gap:8px;display:flex}.footer-tagline{color:var(--slate-400);font-size:.9rem}.footer-bottom{border-top:1px solid var(--cream-200);width:100%;color:var(--slate-400);margin-top:32px;padding-top:24px;font-size:.85rem}@media (width<=1024px){.features-grid.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.hero-section{text-align:center;flex-direction:column;padding-top:100px}.hero-content{flex-direction:column;align-items:center;max-width:100%;display:flex}.hero-subtitle{max-width:100%}.hero-visual{max-width:360px}.hero-card-stack{height:320px}.features-grid{grid-template-columns:repeat(2,1fr)}.hero-title{font-size:2.5rem}.section-title{font-size:2rem}.section-alt{margin-left:12px;margin-right:12px;padding-left:20px;padding-right:20px}}@media (width<=600px){.nav-actions span{display:none}.btn-nav{padding:10px 14px!important}.hero-card-stack{flex-direction:column;align-items:center;gap:12px;height:auto;display:flex}.floating-card{min-width:100%;max-width:320px;padding:14px 18px;animation:none!important;position:static!important;transform:none!important}.features-grid,.features-grid.grid-4{grid-template-columns:repeat(2,1fr);gap:12px}.feature-card{padding:20px 12px}.feature-icon{width:44px;height:44px;margin-bottom:12px;font-size:1.2rem}.feature-title{font-size:.9rem}.feature-desc{font-size:.75rem}.hero-buttons{justify-content:center}.extras-grid{gap:8px}.extra-chip{border-radius:var(--radius-full);gap:8px;padding:8px 14px;font-size:.8rem}.extra-chip-icon{width:28px;height:28px;font-size:.9rem}.hero-title{font-size:2rem}.section-alt{margin-left:8px;margin-right:8px;padding-left:16px;padding-right:16px}.modules-ribbon{gap:10px;padding:16px}}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-container{z-index:1;border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);background:#fffffffa;border:1px solid #ffffffb3;padding:40px 36px;position:relative}.back-btn{color:var(--slate-500);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:24px;font-size:.875rem;font-weight:500;transition:color .2s;display:inline-flex}.back-btn:hover{color:var(--amber-600)}.auth-header{text-align:center;margin-bottom:32px}.auth-icon{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:68px;height:68px;margin:0 auto 18px;font-size:1.8rem;display:flex;box-shadow:0 6px 20px #00000014}.school-icon{background:linear-gradient(135deg, var(--cream-400), var(--amber-500));color:#fff}.student-icon{color:#fff;background:linear-gradient(135deg,#93c5fd,#3b82f6)}.company-icon{background:linear-gradient(135deg, var(--slate-700), var(--slate-900));color:var(--cream-400)}.auth-title{color:var(--slate-900);margin-bottom:6px;font-size:1.6rem}.auth-subtitle{color:var(--slate-400);font-size:.9rem}.auth-error{border-radius:var(--radius-sm);color:#dc2626;background:#fee2e2;border:1px solid #ef444433;padding:12px 16px;font-size:.85rem;font-weight:500}.auth-submit{width:100%;margin-top:4px;border-radius:var(--radius-md)!important;padding:16px!important;font-size:1rem!important}.auth-footer-text{text-align:center;color:var(--slate-400);margin-top:24px;font-size:.85rem}@media (width<=480px){.auth-container{padding:32px 24px}}.school-login-container{max-width:500px}.role-tabs{background:#f1f5f9;border-radius:14px;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:28px;padding:6px;display:grid}.role-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;font-size:.78rem;font-weight:500;transition:all .2s;display:flex}.role-tab-icon{font-size:1.2rem;line-height:1}.role-tab-label{font-size:.75rem}.role-tab:hover{color:#1e293b;background:#ffffffb3}.role-tab.active.role-admin{color:#d97706;background:#fff;box-shadow:0 2px 10px #00000014}.role-admin-icon{background:linear-gradient(135deg, var(--cream-400,#fcd34d), var(--amber-500,#f59e0b));color:#fff}.coming-soon-panel{text-align:center;border:2px dashed #e2e8f0;border-radius:14px;margin-bottom:8px;padding:36px 24px}.coming-soon-icon{color:#7c3aed;margin-bottom:14px;font-size:2.4rem}.coming-soon-panel h3{color:#1e293b;margin-bottom:8px;font-size:1.1rem}.coming-soon-panel p{color:#64748b;margin-bottom:20px;font-size:.87rem;line-height:1.5}.coming-soon-badge{color:#7c3aed;letter-spacing:.5px;text-transform:uppercase;background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-radius:999px;padding:6px 16px;font-size:.78rem;font-weight:700;display:inline-block}.dashboard-page{min-height:100vh}.dash-header{z-index:100;-webkit-backdrop-filter:blur(16px);background:#fffdf7e6;border-bottom:1px solid #ffe48a4d;padding:14px 0;position:sticky;top:0}.dash-header-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;display:flex}.dash-badge{background:linear-gradient(135deg, var(--slate-800), var(--slate-900));color:var(--cream-400);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;margin-left:8px;padding:4px 12px;font-size:.7rem;font-weight:700}.logo-icon{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.3rem;display:flex;box-shadow:0 4px 12px #ffd46059}.logo-text{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800}.nav-logo{align-items:center;gap:10px;display:flex}.btn-logout{padding:10px 20px!important;font-size:.875rem!important}.dash-main{z-index:1;max-width:1200px;margin:0 auto;padding:32px 24px 64px;position:relative}.dash-stats{gap:20px;margin-bottom:28px;display:flex}.dash-stat-card{align-items:center;gap:16px;min-width:220px;padding:24px 32px;display:flex}.dsc-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--cream-200), var(--cream-300));width:52px;height:52px;color:var(--amber-600);justify-content:center;align-items:center;font-size:1.4rem;display:flex}.dsc-num{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:800}.dsc-label{color:var(--slate-400);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.dash-toolbar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:24px;display:flex}.search-bar{flex:1;min-width:220px}.dash-table-wrap{padding:0;overflow:hidden}.table-scroll{overflow-x:auto}.dash-table{border-collapse:collapse;width:100%}.dash-table thead{background:var(--cream-100)}.dash-table th{text-align:left;color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--cream-200);padding:14px 20px;font-size:.75rem;font-weight:700}.dash-table td{color:var(--slate-700);border-bottom:1px solid var(--cream-100);vertical-align:middle;padding:16px 20px;font-size:.9rem}.dash-table tbody tr{transition:background .2s}.dash-table tbody tr:hover{background:var(--cream-50)}.td-num{color:var(--slate-400);width:50px;font-weight:700}.id-badge{background:var(--cream-100);border:1px solid var(--cream-300);border-radius:var(--radius-full);color:var(--amber-600);padding:4px 12px;font-family:Outfit,monospace;font-size:.8rem;font-weight:700;display:inline-block}.td-name{color:var(--slate-800);font-weight:600}.pass-code{background:var(--slate-100);border-radius:var(--radius-sm);color:var(--slate-600);padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:.8rem}.td-date{color:var(--slate-400);font-size:.85rem}.action-btns{gap:8px;display:flex}.dash-empty{color:var(--slate-400);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-icon{opacity:.3;margin-bottom:12px;font-size:3rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#0f172a66;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-card{width:100%;max-width:460px;padding:32px}.modal-sm{text-align:center;max-width:380px;padding:40px 32px}.modal-top{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-top h2{color:var(--slate-900);font-size:1.3rem}.modal-close{background:var(--cream-100);width:36px;height:36px;color:var(--slate-500);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:all .2s;display:flex}.modal-close:hover{background:var(--cream-200);color:var(--slate-700)}.del-title{color:var(--slate-900);margin-bottom:8px;font-size:1.3rem}.del-desc{color:var(--slate-400);margin-bottom:28px;font-size:.9rem}.del-actions{justify-content:center;gap:12px;display:flex}@media (width<=768px){.dash-stats,.dash-toolbar{flex-direction:column}.search-bar{width:100%}.dash-table th,.dash-table td{padding:12px 14px;font-size:.8rem}}@media (width<=480px){.dash-stat-card{padding:18px 20px}.modal-card{padding:24px 20px}}.sdash-layout{background:var(--cream-50);max-width:100vw;min-height:100vh;display:flex;position:relative;overflow-x:hidden}.sdash-sidebar{z-index:100;will-change:transform;background:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);border-right:1px solid #ffe48a66;flex-direction:column;width:260px;min-height:100vh;transition:transform .18s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 28px #f59e0b1a,2px 0 8px #0000000f}.sdash-sidebar-logo{border-bottom:1px solid #ffe48a59;align-items:center;gap:10px;padding:24px 22px 20px;display:flex}.sdash-sidebar-logo-img{object-fit:cover;border-radius:10px;width:38px;height:38px;box-shadow:0 4px 12px #ffd4604d}.sdash-sidebar-brand{flex-direction:column;display:flex}.sdash-sidebar-brand-name{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;line-height:1.1}.sdash-sidebar-brand-sub{color:var(--amber-600);letter-spacing:.5px;text-transform:uppercase;font-size:.7rem;font-weight:500}.sdash-school-info{border-bottom:1px solid #ffe48a59;padding:16px 22px}.sdash-school-chip{background:#ffd4601f;border:1px solid #ffd46040;border-radius:12px;align-items:flex-start;gap:10px;padding:10px 14px;display:flex}.sdash-school-avatar{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:34px;height:34px;color:var(--slate-900);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex;overflow:hidden}.sdash-school-text{flex:1;min-width:0}.sdash-school-name{color:var(--slate-800);word-break:break-word;font-size:.82rem;font-weight:700;line-height:1.3}.sdash-school-id{color:var(--slate-400);letter-spacing:.3px;font-size:.68rem;font-weight:500}.sdash-nav-item{cursor:pointer;text-align:left;width:100%;color:var(--slate-500);background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:11px 14px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:500;transition:all .2s;display:flex;position:relative}.sdash-nav-item.active{color:var(--amber-600);background:linear-gradient(135deg,#ffd4602e,#f59e0b1a);border-color:#ffd4604d;box-shadow:0 2px 8px #f59e0b1a}.sdash-nav-item.active .snav-icon{color:var(--amber-500)}.snav-icon{flex-shrink:0;font-size:1.15rem;transition:color .2s}.sdash-nav-item:hover .snav-icon{color:var(--slate-700)}.snav-label{flex:1}.sdash-nav-badge{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));color:var(--slate-900);letter-spacing:.3px;border-radius:20px;padding:2px 7px;font-size:.65rem;font-weight:700}.sdash-logout-btn{color:#dc2626;cursor:pointer;background:#ef444412;border:1px solid #ef444426;border-radius:12px;align-items:center;gap:10px;width:100%;padding:11px 14px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;transition:all .2s;display:flex}.sdash-logout-btn:hover{color:#b91c1c;background:#ef444421}.sdash-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;background:#00000080;display:none;position:fixed;inset:0}.sdash-main{will-change:margin-left;flex-direction:column;flex:1;max-width:100%;min-height:100vh;margin-left:260px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex;overflow-x:hidden}@media (width<=900px){.sdash-main{margin-left:0!important;transition:none!important}}.sdash-topbar{z-index:50;-webkit-backdrop-filter:blur(16px);background:#fffdf7eb;border-bottom:1px solid #ffe48a4d;justify-content:space-between;align-items:center;gap:16px;padding:14px 28px;display:flex;position:sticky;top:0}.sdash-topbar-left{align-items:center;gap:14px;display:flex}.sdash-desktop-toggle-btn,.sdash-mobile-toggle-btn{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:34px;height:34px;color:var(--slate-900);cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:0 4px 14px #f59e0b59}.sdash-desktop-toggle-btn:hover,.sdash-mobile-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #f59e0b80}.sdash-desktop-toggle-btn.mini,.sdash-mobile-toggle-btn.mini{border-radius:8px;width:28px;height:28px;font-size:.9rem;box-shadow:0 2px 8px #f59e0b40}.sdash-desktop-toggle-btn.mini:hover,.sdash-mobile-toggle-btn.mini:hover{transform:scale(1.05)}.sdash-desktop-toggle-btn.floating,.sdash-mobile-toggle-btn.floating{z-index:1000;background:linear-gradient(135deg, var(--cream-500), var(--amber-500));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:40px;height:40px;color:var(--slate-900);border:1px solid #ffffff4d;font-size:1.2rem;position:absolute;top:24px;left:24px;box-shadow:0 8px 32px #00000040,0 0 0 2px #ffd46066,0 0 20px #f59e0b66}.sdash-desktop-toggle-btn.floating.collapsed,.sdash-mobile-toggle-btn.floating.collapsed{box-shadow:0 8px 32px #00000040,0 0 0 2px #ffd46066,0 0 20px #f59e0b99}.sdash-desktop-toggle-btn.floating:hover,.sdash-mobile-toggle-btn.floating:hover{transform:scale(1.08)}.sdash-page-title{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:700}.sdash-page-crumb{color:var(--slate-400);margin-top:1px;font-size:.8rem}.sdash-avatar{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:38px;height:38px;color:var(--slate-900);border-radius:10px;justify-content:center;align-items:center;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;display:flex;box-shadow:0 4px 12px #ffd46059}.sdash-header-logout-btn{color:#ef4444;cursor:pointer;background:#ef444414;border:1px solid #ef444433;border-radius:10px;align-items:center;gap:8px;padding:8px 16px;font-family:Outfit,Inter,sans-serif;font-size:.88rem;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 8px #ef44440d}.sdash-header-logout-btn:hover{color:#fff;background:#ef4444;border-color:#ef4444;transform:translateY(-1px);box-shadow:0 4px 12px #ef444440}.sdash-header-logout-btn:active{transform:translateY(0)}.sdash-header-logout-btn svg{font-size:1.1rem}.sdash-tch-search-input:focus{border-color:var(--amber-400)!important}.sdash-content{z-index:1;box-sizing:border-box;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:28px;position:relative}.sdash-section-title{align-items:center;gap:14px;display:flex}.sdash-section-icon{color:var(--cream-700);background:var(--cream-100);border:1.5px solid #f5b80033;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.8rem;display:flex;box-shadow:0 4px 12px #f59e0b1a}.sdash-overview-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:28px;display:grid}.sdash-ov-card{cursor:default;background:#fffffff2;border:1px solid #ffffffb3;border-radius:18px;align-items:center;gap:16px;padding:22px 20px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 20px #0000000d}.sdash-ov-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #00000017}.sdash-ov-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.4rem;display:flex}.ov-amber{color:#d97706;background:linear-gradient(135deg,#fef3c7,#fde68a)}.ov-blue{color:#2563eb;background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.ov-green{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.ov-purple{color:#7c3aed;background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.ov-rose{color:#e11d48;background:linear-gradient(135deg,#ffe4e6,#fecdd3)}.ov-teal{color:#0d9488;background:linear-gradient(135deg,#ccfbf1,#99f6e4)}.ov-indigo{color:#4338ca;background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}.ov-slate{color:#475569;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.sdash-ov-num{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800;line-height:1.1}:root{--rose-50:#fff1f2;--rose-500:#f43f5e;--rose-600:#e11d48;--yellow-50:#ffeb3;--yellow-500:#ffd460;--yellow-600:#f5b800;--violet-50:#f5f3ff;--violet-500:#8b5cf6;--violet-600:#7c3aed}.sdash-classes-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;padding:12px 0;display:grid}.sdash-class-card{border:1px solid var(--slate-200);background:#fff;border-radius:24px;flex-direction:column;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 10px 30px -5px #00000014,0 4px 6px -2px #00000005}.sdash-class-card:hover{border-color:var(--amber-300);transform:translateY(-8px);box-shadow:0 20px 40px #0f172a1a}.sdash-class-card-header{justify-content:space-between;align-items:center;padding:24px 24px 12px;display:flex}.sdash-class-icon-wrap{border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.6rem;transition:all .3s;display:flex}.sdash-class-card.preschool .sdash-class-icon-wrap{background:linear-gradient(135deg, var(--rose-50), #fff1f2);color:var(--rose-600)}.sdash-class-card.primary .sdash-class-icon-wrap{background:linear-gradient(135deg, var(--yellow-50), #fff9e8);color:var(--yellow-600);border:1.5px solid #ffc93333}.sdash-class-card.secondary .sdash-class-icon-wrap{background:linear-gradient(135deg, var(--violet-50), #f5f3ff);color:var(--violet-600)}.sdash-class-del-btn{background:var(--slate-50);color:var(--slate-400);cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.2rem;transition:all .2s;display:flex}.sdash-class-del-btn:hover{background:var(--danger);color:#fff;transform:scale(1.1)}.sdash-class-card-content{flex:1;padding:8px 24px 24px}.sdash-class-name-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.sdash-class-name-row h3{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:2rem;font-weight:800;line-height:1.1}.sdash-class-badge{text-transform:uppercase;letter-spacing:1px;border-radius:12px;padding:6px 14px;font-size:.75rem;font-weight:800;display:inline-block}.preschool .sdash-class-badge{background:var(--rose-50);color:var(--rose-600);border:1px solid #e11d481a}.primary .sdash-class-badge{background:var(--yellow-50);color:var(--yellow-600);border:1.5px solid #ffc9334d}.secondary .sdash-class-badge{background:var(--violet-50);color:var(--violet-600);border:1px solid #7c3aed1a}.sdash-class-stats{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.sdash-class-stat{background:var(--slate-50);border:1px solid var(--slate-100);border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:80px;padding:16px 12px;transition:all .2s;display:flex}.sdash-class-card:hover .sdash-class-stat{border-color:var(--slate-200);background:#fff}.stat-value{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.stat-label{color:var(--slate-400);text-transform:uppercase;letter-spacing:.5px;font-size:.72rem;font-weight:700}.sdash-class-sections-list{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.sdash-section-chip{border:1.5px solid var(--slate-100);color:var(--slate-700);background:#fff;border-radius:12px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:0 12px;font-size:.85rem;font-weight:800;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000a}.sdash-class-card:hover .sdash-section-chip{border-color:var(--amber-200);color:var(--amber-700)}.sdash-class-card-footer{background:var(--slate-50);border-top:1px solid var(--slate-100);padding:20px 24px}.sdash-class-action-btn{border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);cursor:pointer;background:#fff;border-radius:16px;justify-content:center;align-items:center;gap:10px;padding:12px;font-size:.9rem;font-weight:800;transition:all .3s;display:flex}.sdash-class-card:hover .sdash-class-action-btn{background:var(--yellow-600);border-color:var(--yellow-600);color:var(--slate-900);box-shadow:0 4px 12px #ffc9334d}.sdash-class-action-btn svg{font-size:1.2rem;transition:transform .3s}.sdash-class-card:hover .sdash-class-action-btn svg{transform:translate(4px)}.sdash-ov-label{color:var(--slate-400);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;font-size:.78rem;font-weight:500}.sdash-coming-soon{min-height:55vh;color:var(--slate-400);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:18px;display:flex}.sdash-cs-icon{border-radius:24px;justify-content:center;align-items:center;width:90px;height:90px;margin:0 auto;font-size:2.5rem;display:flex}.sdash-cs-title{color:var(--slate-600);font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:700}.sdash-cs-desc{color:var(--slate-400);max-width:360px;font-size:.9rem;line-height:1.7}.sdash-content.p-0{padding:0}.sdash-main.cctv-mode{height:100vh;overflow:hidden}.sdash-menu-btn.floating{z-index:60;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6;display:flex;position:absolute;top:16px;left:16px;box-shadow:0 4px 12px #0000001a}.sdash-cctv-full-wrap{background:var(--slate-900);width:100%;height:100vh}.sdash-cctv-full{border:none;width:100%;height:100vh;display:block}.sdash-cctv-no-url{background:var(--slate-900);color:#fff6;text-align:center;border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:65vh;padding:32px;display:flex}.sdash-cctv-no-url.full-screen{border-radius:0;height:100vh}.sdash-cctv-no-url svg{opacity:.3;font-size:3rem}.sdash-cctv-no-url p{font-size:.9rem;line-height:1.6}.sdash-quick-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:28px;display:grid}.sdash-quick-card{background:#fffffff2;border:1px solid #ffffffb3;border-radius:18px;padding:24px;box-shadow:0 4px 20px #0000000d}.sdash-quick-card-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.sdash-quick-card-title{color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px;font-size:.9rem;font-weight:700}.sdash-list-row{border-bottom:1px solid var(--cream-100);justify-content:space-between;align-items:center;padding:10px 0;font-size:.875rem;display:flex}.sdash-list-row:last-child{border-bottom:none}.sdash-list-name{color:var(--slate-700);font-weight:600}.sdash-list-meta{color:var(--slate-400);font-size:.8rem}.status-badge{letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.status-present{color:#15803d;background:#dcfce7}.status-absent{color:#dc2626;background:#fee2e2}.status-pending{color:#d97706;background:#fef3c7}@media (width>=901px){.sdash-sidebar.collapsed{transform:translate(-260px)}.sdash-main.collapsed{margin-left:0}}@media (width<=900px){.sdash-sidebar{transform:translate(-260px)}.sdash-sidebar.open{transform:translate(0)}.sdash-overlay.open{display:block}.sdash-main{margin-left:0}.sdash-desktop-toggle-btn{display:none!important}}@media (width>=901px){.sdash-mobile-toggle-btn{display:none!important}}@media (width<=600px){.sdash-content{padding:18px 16px}.sdash-topbar{padding:12px 16px}.sdash-overview-grid{grid-template-columns:repeat(2,1fr);gap:12px}.sdash-ov-card{padding:16px 14px}.sdash-ov-num{font-size:1.3rem}}.sdash-teachers-module{animation:.4s forwards fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes sdash-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sdash-module-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.sdash-modal-title-wrap{align-items:center;gap:12px;display:flex}.sdash-modal-icon-sm{color:#92400e;background:#fef3c7;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;display:flex}.sdash-modal-header h2{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:700}.sdash-module-desc{color:var(--slate-500);margin-top:4px;font-size:.85rem}.sdash-btn-primary{background:linear-gradient(135deg, var(--cream-400), var(--cream-600));color:var(--slate-900);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 10px 15px -3px #ffc93366,0 4px 6px -2px #ffc9331a}.sdash-btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #ffc93380,0 10px 10px -5px #ffc93333}.sdash-btn-secondary{color:var(--slate-700);cursor:pointer;background:#fffc;border:1px solid #0000001a;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.sdash-btn-secondary:hover{background:#fff;box-shadow:0 2px 8px #0000000d}.sdash-btn-cancel{color:var(--slate-500);cursor:pointer;background:0 0;border:none;border-radius:14px;padding:14px 24px;font-size:.9rem;font-weight:700;transition:all .2s}.sdash-btn-cancel:hover{color:var(--slate-700);background:#0000000d}.sdash-btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:14px;padding:14px 32px;font-size:.9rem;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #ef444440}.sdash-btn-danger:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 6px 16px #ef444459}.sdash-btn-icon-text{color:var(--amber-600);cursor:pointer;background:#f59e0b1a;border:1px solid #f59e0b33;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .2s;display:inline-flex}.sdash-btn-icon-text:hover{background:#f59e0b33}.sdash-csv-menu{border:1px solid var(--slate-200);z-index:10;background:#fff;border-radius:12px;min-width:220px;position:absolute;top:110%;right:0;overflow:hidden;box-shadow:0 10px 25px #0000001a}.sdash-csv-item{border:none;border-bottom:1px solid var(--slate-100);text-align:left;width:100%;color:var(--slate-700);cursor:pointer;background:0 0;padding:12px 16px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:600;transition:all .2s}.sdash-csv-item:last-child{border-bottom:none}.sdash-csv-item:hover{background:var(--slate-50);color:var(--amber-600)}.sdash-csv-item-sub{color:var(--slate-400);margin-top:2px;font-size:.75rem;font-weight:500;transition:color .2s;display:block}.sdash-csv-item:hover .sdash-csv-item-sub{color:var(--amber-500)}.sdash-btn-csv{color:var(--slate-700);border:1.5px solid var(--slate-200);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;gap:8px;min-width:170px;padding:9px 24px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 6px #00000005}.sdash-btn-csv:hover{border-color:var(--slate-300);background:var(--slate-50);color:var(--slate-900);box-shadow:0 4px 12px #0000000d}.sdash-btn-csv svg{color:var(--slate-500);font-size:1.1rem;transition:color .2s}.sdash-btn-csv:hover svg{color:var(--amber-600)}.sdash-table-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffd9;border:1px solid #fff9;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000008}.sdash-table-wrap{-webkit-overflow-scrolling:touch;width:100%;max-width:100%;overflow-x:auto}.sdash-table{border-collapse:collapse;width:100%}.sdash-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--slate-400);background:#00000005;border-bottom:1px solid #0000000d;padding:16px 20px;font-size:.75rem;font-weight:600}.sdash-table td{color:var(--slate-600);vertical-align:middle;border-bottom:1px solid #0000000d;padding:16px 20px;font-size:.88rem}.sdash-t-name{color:var(--slate-800);font-weight:600}.sdash-t-address{white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.sdash-table-empty{text-align:center!important;color:var(--slate-400)!important;padding:40px!important}.sdash-table-actions{align-items:center;gap:8px;display:flex}.sdash-action-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;transition:all .2s;display:flex}.sdash-action-btn.edit{color:#3b82f6;background:#3b82f61a}.sdash-action-btn.edit:hover{background:#3b82f633}.sdash-action-btn.delete{color:#ef4444;background:#ef44441a}.sdash-action-btn.delete:hover{background:#ef444433}.sdash-modal-overlay{-webkit-backdrop-filter:none;z-index:200;will-change:opacity;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}@media (width>=901px){.sdash-modal-overlay{-webkit-backdrop-filter:blur(4px)}}.sdash-modal{border:1px solid var(--slate-100);will-change:transform, opacity;background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:500px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 20px 40px -10px #00000026}@media (width<=600px){.sdash-modal{height:100%;max-height:100vh;box-shadow:none;border-radius:0}}.sdash-modal.wide{max-width:800px}.sdash-modal-footer{background:var(--slate-50);border-top:1px solid var(--slate-100);justify-content:flex-end;align-items:center;gap:12px;padding:20px 28px;display:flex}.sdash-form-group{margin-bottom:24px}.sdash-form-group:last-child{margin-bottom:0}.sdash-form-group label{color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.85rem;font-weight:700;display:block}.sdash-input{border:2px solid var(--slate-200);width:100%;color:var(--slate-800);background:#fff;border-radius:14px;padding:14px 18px;font-family:Inter,sans-serif;font-size:1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.sdash-input:focus{border-color:var(--yellow-500);background:#fff;outline:none;box-shadow:0 0 0 4px #ffd46026}.sdash-input::placeholder{color:var(--slate-300)}select.sdash-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7' /%3E%3C/svg%3E");background-position:right 20px center;background-repeat:no-repeat;background-size:18px;padding-right:52px}.sdash-input-hint{color:var(--slate-400);margin-top:8px;font-size:.75rem;font-weight:500;display:block}.sdash-modal-footer .sdash-btn-primary{border-radius:14px;padding:14px 40px;font-size:.95rem}.sdash-modal-footer .sdash-btn-outline{border:2px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#fff;border-radius:14px;padding:14px 24px;font-weight:700;transition:all .2s}.sdash-modal-footer .sdash-btn-outline:hover{background:var(--slate-50);border-color:var(--slate-300);color:var(--slate-800)}.sdash-modal.delete-confirm{text-align:center;max-width:400px;padding:30px}.sdash-confirm-icon{color:#ef4444;background:#ef44441a;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 20px;font-size:2rem;display:flex}.sdash-modal.delete-confirm h3{color:var(--slate-800);margin-bottom:10px;font-family:Outfit,sans-serif;font-size:1.3rem}.sdash-modal.delete-confirm p{color:var(--slate-500);margin-bottom:24px;font-size:.9rem;line-height:1.5}.sdash-modal-header{border-bottom:1px solid #0000000d;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.sdash-modal-header h3{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:1.2rem}.sdash-modal-close{color:var(--slate-400);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.2rem;transition:color .2s}.sdash-modal-close:hover{color:var(--slate-700)}.sdash-modal-body{flex:1;padding:24px;overflow-y:auto}.sdash-form-group{text-align:left;margin-bottom:16px}.sdash-form-group label{color:var(--slate-600);margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}.sdash-form-group input,.sdash-form-group textarea{width:100%;color:var(--slate-800);box-sizing:border-box;background:#f8fafc;border:1px solid #0000001a;border-radius:10px;padding:12px 14px;font-family:Inter,sans-serif;font-size:.9rem;transition:all .2s}.sdash-form-group input:focus,.sdash-form-group textarea:focus{border-color:var(--amber-400);background:#fff;outline:none;box-shadow:0 0 0 4px #f59e0b1a}.sdash-form-group textarea{resize:vertical}.sdash-file-upload{align-items:center;gap:12px;display:flex}.sdash-file-text{color:var(--slate-400);font-size:.8rem}.sdash-modal-footer{justify-content:flex-end;gap:12px;padding-top:16px;display:flex}.sdash-modal-footer.center{justify-content:center}@media (width<=700px){.sdash-module-header{flex-direction:column;align-items:flex-start;gap:12px}.sdash-header-actions{flex-wrap:wrap;width:100%;flex-direction:row!important}.sdash-header-actions>*{flex:1;min-width:0}.sdash-btn-primary,.sdash-btn-csv{justify-content:center;width:100%;padding-left:0;padding-right:0}.sdash-csv-menu{min-width:240px;left:0;right:auto}.sdash-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.sdash-modal-overlay,.sdash-overlay{-webkit-backdrop-filter:none!important;background:#000000b3!important}.sdash-topbar{-webkit-backdrop-filter:none!important;background:#fffdf7!important}.sdash-table{min-width:560px}.sdash-table th,.sdash-table td{padding:12px;font-size:.82rem}.sdash-t-address{max-width:80px}.sdash-action-btn{width:36px;height:36px;font-size:1.1rem}.sdash-modal-overlay{align-items:flex-end;padding:0}.sdash-modal{border-radius:20px 20px 0 0;max-width:100%;max-height:92vh;overflow-y:auto}.sdash-modal.delete-confirm{border-radius:20px 20px 0 0;max-width:100%;padding:28px 20px 32px}.sdash-modal-header{z-index:10;background:#fff;border-radius:20px 20px 0 0;padding:16px 18px;position:sticky;top:0}.sdash-modal-body{padding:16px 18px}.sdash-modal-footer{flex-direction:column-reverse;gap:8px;padding-top:12px}.sdash-modal-footer .sdash-btn-primary,.sdash-modal-footer .sdash-btn-cancel,.sdash-modal-footer .sdash-btn-danger{text-align:center;justify-content:center;width:100%;padding:14px}.sdash-form-group input,.sdash-form-group textarea{font-size:1rem}.sdash-file-upload{flex-direction:column;align-items:flex-start;gap:8px}.sdash-btn-secondary{justify-content:center;width:100%}}@media (width<=400px){.sdash-table-actions{gap:6px}.sdash-btn-icon-text{padding:5px 9px;font-size:.75rem}.sdash-module-title{font-size:1.2rem}}.sdash-class-detail-view{animation:.4s forwards slideIn}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sdash-detail-header{margin-bottom:32px}.sdash-back-btn{color:var(--slate-500);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:16px;padding:8px 0;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.sdash-back-btn:hover{color:var(--yellow-600);transform:translate(-4px)}.sdash-detail-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;display:flex}.sdash-detail-main-info h1{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:2.2rem;font-weight:800}.sdash-detail-main-info p{color:var(--slate-400);margin-top:4px;font-size:1rem;font-weight:600}.sdash-divisions-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.sdash-division-card{border:1px solid var(--slate-200);background:#fff;border-radius:20px;transition:all .3s;overflow:hidden;box-shadow:0 4px 20px #00000008}.sdash-division-card:hover{border-color:var(--yellow-400);transform:translateY(-5px);box-shadow:0 15px 35px #00000012}.sdash-div-card-head{border-bottom:1px solid var(--slate-50);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.sdash-div-badge{background:var(--yellow-50);color:var(--yellow-600);text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:6px 14px;font-size:.8rem;font-weight:800}.sdash-div-opt-btn{color:var(--slate-400);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;font-size:1.2rem;transition:all .2s}.sdash-div-opt-btn:hover{background:var(--slate-50);color:var(--slate-700)}.sdash-div-card-body{flex-direction:column;gap:16px;padding:24px 20px;display:flex}.sdash-div-stat{align-items:center;gap:14px;display:flex}.sdash-div-icon{background:var(--slate-50);width:40px;height:40px;color:var(--slate-400);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.sdash-division-card:hover .sdash-div-icon{background:var(--yellow-50);color:var(--yellow-600)}.div-stat-num{color:var(--slate-800);font-size:1.1rem;font-weight:800}.div-stat-label{color:var(--slate-400);font-size:.75rem;font-weight:600}.sdash-div-card-footer{background:var(--slate-50);grid-template-columns:1fr 1fr;gap:12px;padding:16px 20px;display:grid}.sdash-div-action-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.sdash-div-action-btn.primary{color:var(--yellow-600);border:1.5px solid var(--yellow-500);background:#fff}.sdash-div-action-btn.primary:hover{background:var(--yellow-600);color:var(--slate-900)}.sdash-div-action-btn.secondary{color:var(--slate-500);border:1.5px solid var(--slate-200);background:0 0}.class-mgmt-modal{background:#fff;border-radius:24px;width:100%;max-width:500px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.sdash-modal-header.premium{color:var(--slate-900);background:#fffbeb;border-bottom:1px solid #fef3c7;padding:30px 24px;position:relative}.sdash-modal-icon-lg{color:#f59e0b;background:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.8rem;display:flex;box-shadow:0 4px 10px #f59e0b26}.sdash-modal-close-btn{background:var(--slate-100);color:var(--slate-500);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:20px;right:20px}.sdash-modal-close-btn:hover{background:var(--slate-200);color:var(--slate-900)}.sdash-modal-close-btn.red{color:#ef4444;background:#fee2e2}.sdash-modal-close-btn.red:hover{color:#fff;background:#ef4444}.sdash-label-bold{color:var(--slate-500);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:.75rem;font-weight:800;display:block}.sdash-input-group{background:var(--slate-50);border:2px solid var(--slate-100);border-radius:14px;align-items:center;transition:all .2s;display:flex}.sdash-input-group:focus-within{border-color:var(--yellow-400);background:#fff;box-shadow:0 0 0 4px #ffd4601a}.sdash-input-prefix{color:var(--slate-400);border-right:1px solid var(--slate-100);padding:0 16px;font-size:1.2rem}.sdash-input-prefix-small{color:var(--slate-400);border-right:1px solid var(--slate-100);padding:0 12px;font-size:.8rem;font-weight:700}.sdash-input-premium{color:var(--slate-800);background:0 0;border:none;outline:none;flex:1;padding:14px 16px;font-family:Inter,sans-serif;font-size:1rem;font-weight:600}.sdash-input-premium.small{padding:10px 14px;font-size:.9rem}.sdash-btn-tiny{background:var(--yellow-50);color:var(--yellow-700);border:1px solid var(--yellow-100);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.sdash-btn-tiny:hover{background:var(--yellow-400);color:var(--slate-900)}.sdash-divisions-list{flex-direction:column;gap:10px;max-height:240px;padding-right:4px;display:flex;overflow-y:auto}.sdash-division-input-row{align-items:center;gap:10px;display:flex}.sdash-btn-icon-danger{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.sdash-btn-icon-danger:hover{color:#fff;background:#ef4444}.sdash-btn-icon-danger:disabled{opacity:.3;cursor:not-allowed}.sdash-input-hint-premium{color:var(--slate-400);margin-top:12px;font-size:.75rem;font-weight:500}.sdash-modal-footer.premium{background:var(--slate-50);border-top:1px solid var(--slate-100);justify-content:flex-end;gap:12px;padding:20px 24px;display:flex}.sdash-btn-ghost{color:var(--slate-500);cursor:pointer;background:0 0;border:none;border-radius:12px;padding:12px 20px;font-weight:700;transition:all .2s}.sdash-btn-ghost:hover{background:var(--slate-200);color:var(--slate-700)}.sdash-btn-primary-premium{background:var(--yellow-400);color:var(--slate-900);cursor:pointer;border:none;border-radius:14px;padding:12px 32px;font-weight:800;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 14px #ffd46066}.sdash-btn-primary-premium:hover{background:var(--yellow-500);transform:translateY(-2px);box-shadow:0 6px 20px #ffd46080}.flex-1{flex:1}.delete-confirm-premium{text-align:center;background:#fff;border-radius:28px;width:100%;max-width:400px;overflow:hidden;box-shadow:0 25px 50px -12px #0003}.sdash-confirm-header{justify-content:center;padding:32px 24px 20px;display:flex}.sdash-confirm-icon-wrap{color:#f59e0b;background:#fffbeb;border-radius:24px;justify-content:center;align-items:center;width:72px;height:72px;font-size:2.2rem;display:flex;transform:rotate(-5deg);box-shadow:0 10px 15px -3px #f59e0b26}.sdash-confirm-body{padding:0 32px 32px}.sdash-confirm-body h3{color:var(--slate-900);margin-bottom:12px;font-size:1.4rem;font-weight:800}.sdash-confirm-body p{color:var(--slate-500);font-size:.95rem;line-height:1.6}.sdash-confirm-body strong{color:var(--slate-800);font-weight:700}.sdash-confirm-footer{background:#fffdf5;border-top:1px solid #fef3c7;flex-direction:column;gap:10px;padding:24px;display:flex}.sdash-btn-danger-premium{background:var(--yellow-400);width:100%;color:var(--slate-900);cursor:pointer;border:none;border-radius:14px;padding:14px;font-size:1rem;font-weight:800;transition:all .2s;box-shadow:0 4px 10px #f59e0b33}.sdash-btn-danger-premium:hover{color:#fff;background:#ef4444;transform:translateY(-1px);box-shadow:0 6px 15px #ef44444d}.sdash-btn-ghost-dark{width:100%;color:var(--slate-500);cursor:pointer;background:0 0;border:none;border-radius:14px;padding:12px;font-size:.9rem;font-weight:700;transition:all .2s}.sdash-btn-ghost-dark:hover{background:var(--slate-100);color:var(--slate-800)}.sdash-div-subjects-preview{border-top:1px dashed var(--slate-200);margin-top:20px;padding-top:16px}.preview-label{color:var(--slate-400);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-size:.7rem;font-weight:800}.preview-list{flex-direction:column;gap:8px;display:flex}.preview-item{color:var(--slate-700);align-items:center;gap:6px;font-size:.85rem;font-weight:600;display:flex}.preview-dot{color:var(--yellow-400);font-size:1.2rem;line-height:0}.preview-teach{color:var(--slate-500);font-weight:500}.preview-empty{color:var(--slate-400);font-size:.8rem;font-style:italic}.sdash-class-card-actions{gap:8px;display:flex}.sdash-class-icon-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:all .2s;display:flex}.sdash-class-icon-btn.edit{background:var(--yellow-50);color:var(--yellow-600);border:1px solid #f59e0b33}.sdash-class-icon-btn.edit:hover{background:var(--yellow-600);color:var(--slate-900)}.sdash-class-icon-btn.lc{color:#0369a1;background:#e0f2fe;border:1px solid #0369a133}.sdash-class-icon-btn.lc:hover{color:#fff;background:#0369a1;border-color:#0369a1}.sdash-class-icon-btn.delete{color:#ef4444;background:#fee2e2;border:1px solid #ef44441a}.sdash-class-icon-btn.delete:hover{color:#fff;background:#ef4444}@media (width<=600px){.sdash-classes-grid{grid-template-columns:1fr;gap:16px}.sdash-class-card-header,.sdash-class-card-content{padding:16px}.sdash-class-name{font-size:1.1rem}}.sdash-btn-promote{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 14px #6366f14d}.sdash-btn-promote:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.promo-overlay{z-index:3000;background:#fff;flex-direction:column;display:flex;position:fixed;inset:0}.promo-container{background:#fff;flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}.promo-header{border-bottom:1px solid var(--slate-100);background:linear-gradient(135deg,#f5f3ff,#ede9fe);flex-shrink:0;align-items:center;gap:16px;padding:24px 28px;display:flex}.promo-header-icon{color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex;box-shadow:0 4px 14px #6366f166}.promo-header h2{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800}.promo-header p{color:var(--slate-500);margin:4px 0 0;font-size:.82rem}.promo-close-btn{color:#6366f1;cursor:pointer;background:#6366f11a;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-left:auto;font-size:1.2rem;transition:all .2s;display:flex}.promo-close-btn:hover{color:#fff;background:#6366f1}.promo-body{flex:1;grid-template-columns:1fr 80px 1fr;gap:0;display:grid;overflow:hidden}.promo-panel{flex-direction:column;gap:16px;padding:24px;display:flex;overflow-y:auto}.promo-panel.source{border-right:1px solid var(--slate-100);background:#fafaff}.promo-panel.dest{border-left:1px solid var(--slate-100);background:#f0fdf4}.promo-panel-label{letter-spacing:1.5px;text-transform:uppercase;font-size:.7rem;font-weight:800}.promo-panel.source .promo-panel-label{color:#6366f1}.promo-panel.dest .promo-panel-label{color:#15803d}.promo-panel-title{color:var(--slate-800);margin-top:-8px;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800}.promo-field{flex-direction:column;gap:6px;display:flex}.promo-field label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:700}.promo-field select,.promo-field input{border:1.5px solid var(--slate-200);color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;width:100%;padding:10px 12px;font-family:Inter,sans-serif;font-size:.9rem;transition:border .2s}.promo-field select:focus{border-color:#6366f1}.promo-panel.dest .promo-field select:focus{border-color:#15803d}.promo-disabled-input{opacity:.6;cursor:not-allowed!important;background:var(--slate-50)!important}.promo-chip{letter-spacing:.3px;border-radius:20px;justify-content:center;align-items:center;padding:8px 18px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:800;display:inline-flex}.source-chip{color:#4338ca;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border:1.5px solid #c7d2fe}.dest-chip{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1.5px solid #bbf7d0}.promo-remaining-list{flex-direction:column;gap:6px;margin-top:4px;display:flex}.promo-remaining-title{color:var(--slate-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:.72rem;font-weight:700}.promo-remaining-empty{color:#15803d;text-align:center;background:#f0fdf4;border-radius:10px;padding:12px;font-size:.85rem;font-weight:600}.promo-pair-btn{border:1.5px solid var(--slate-100);color:var(--slate-600);cursor:pointer;text-align:left;background:#fff;border-radius:10px;align-items:center;padding:8px 14px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;transition:all .15s;display:flex}.promo-pair-btn:hover{color:#4338ca;background:#eef2ff;border-color:#a5b4fc}.promo-pair-btn.active{color:#4338ca;background:#eef2ff;border-color:#6366f1;font-weight:800}.promo-student-list-container{border:1.5px solid var(--slate-200);background:#fff;border-radius:14px;flex-direction:column;flex:1;min-height:300px;margin-top:10px;display:flex;overflow:hidden}.list-header{background:var(--slate-50);border-bottom:1.5px solid var(--slate-200);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.list-header h4{color:var(--slate-700);margin:0;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:700}.list-header button{border:1.5px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#fff;border-radius:8px;padding:6px 12px;font-family:Inter,sans-serif;font-size:.75rem;font-weight:700;transition:all .2s}.list-header button:hover{color:#6366f1;border-color:#6366f1}.student-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.student-row{background:var(--slate-50);border:1px solid var(--slate-100);border-radius:10px;align-items:center;gap:12px;padding:10px 14px;transition:all .2s;display:flex}.student-row:hover{background:#fff;border-color:#c7d2fe;box-shadow:0 2px 8px #6366f114}.student-row span{color:var(--slate-700);flex:1;font-size:.9rem;font-weight:600}.student-row .stu-id-badge{color:#4338ca;background:#e0e7ff;border-radius:6px;padding:3px 8px;font-family:Outfit,monospace;font-size:.7rem;font-weight:700}.shuttle-btn{cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;height:32px;padding:0 14px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.shuttle-btn.right{color:#4338ca;background:#fff;border:1.5px solid #c7d2fe}.shuttle-btn.right:hover{color:#fff;background:#4f46e5;border-color:#4f46e5;transform:translate(2px);box-shadow:0 4px 10px #4f46e533}.shuttle-btn.left{color:#b91c1c;background:#fff;border:1.5px solid #fecaca}.shuttle-btn.left:hover{color:#fff;background:#ef4444;border-color:#ef4444;transform:translate(-2px);box-shadow:0 4px 10px #ef444433}.empty-state-msg{text-align:center;color:var(--slate-400);padding:24px;font-size:.85rem;font-weight:500}.promo-arrow-col{background:#fff;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:24px 0;display:flex}.promo-arrow-circle{color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;font-size:1.6rem;display:flex;box-shadow:0 6px 20px #6366f166}.promo-arrow-label{color:#6366f1;text-transform:uppercase;letter-spacing:.5px;text-align:center;font-size:.7rem;font-weight:700}.promo-info-box{background:#fff;border:1.5px solid #bbf7d0;border-radius:14px;margin-top:4px;padding:16px}.promo-info-title{color:#15803d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.75rem;font-weight:800}.promo-info-box p{color:var(--slate-600);margin:0;font-size:.85rem;line-height:1.6}.promo-message{border-top:1px solid var(--slate-100);padding:12px 28px;font-size:.9rem;font-weight:600}.promo-message.success{color:#15803d;background:#f0fdf4}.promo-message.error{color:#dc2626;background:#fef2f2}.promo-footer{border-top:1px solid var(--slate-100);background:var(--slate-50);flex-shrink:0;justify-content:flex-end;gap:12px;padding:18px 28px;display:flex}.promo-promote-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:12px;align-items:center;gap:8px;padding:11px 24px;font-family:Inter,sans-serif;font-size:.92rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 14px #6366f14d}.promo-promote-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.promo-promote-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (width<=720px){.promo-body{grid-template-columns:1fr;overflow:hidden auto}.promo-header{flex-wrap:nowrap;gap:10px;padding:12px 16px}.promo-header-icon{border-radius:10px;width:32px;height:32px;font-size:1rem}.promo-header h2{font-size:1.05rem}.promo-header p{display:none}.promo-close-btn{width:32px;height:32px}.promo-panel{gap:12px;padding:16px;overflow-y:visible}.promo-panel.source{border-right:none;border-bottom:2px solid var(--slate-100)}.promo-panel.dest{border-left:none}.promo-panel>div[style*=flex]{flex-direction:column!important;gap:10px!important}.promo-arrow-col{border-top:1px solid var(--slate-100);border-bottom:1px solid var(--slate-100);background:#f5f5ff;flex-direction:row;justify-content:center;gap:10px;padding:10px 16px}.promo-arrow-circle{width:40px;height:40px;font-size:1.2rem}.promo-arrow-label{font-size:.65rem}.student-row{flex-wrap:wrap;gap:8px;padding:10px}.student-row span{word-break:break-word;min-width:0;font-size:.82rem}.student-row .stu-id-badge{font-size:.65rem}.shuttle-btn{height:30px;padding:0 10px;font-size:.75rem}.promo-student-list-container{min-height:160px}.promo-footer{flex-direction:column-reverse;gap:8px;padding:14px 16px;align-items:stretch!important}.promo-footer>div{flex-direction:column;gap:8px;width:100%}.promo-promote-btn,.sdash-btn-ghost{justify-content:center;width:100%;padding:13px 16px;font-size:.9rem}}@media (width<=600px){.pg-bar{gap:8px;padding:10px 14px}.pg-btn{min-width:30px;height:30px;font-size:.8rem}.pg-goto input{width:44px;height:30px}}.sdash-header-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.sdash-header-btns{align-items:center;gap:10px;display:flex}.sdash-search-wrap{border:1px solid var(--slate-200);background:#fff;border-radius:10px;flex:1;align-items:center;min-width:260px;height:48px;padding:0 14px;transition:all .2s;display:flex}.sdash-search-wrap:focus-within{border-color:var(--amber-400);box-shadow:0 0 0 3px #f59e0b1a}.sdash-search-wrap-large{height:52px}@media (width<=768px){.sdash-search-wrap{order:2;width:100%;min-width:0;height:54px}.sdash-header-btns{order:1;justify-content:space-between;width:100%}.sdash-header-btns>div,.sdash-header-btns>button{flex:1}.sdash-btn-csv,.sdash-btn-primary{justify-content:center;width:100%}.sdash-tch-search{order:2;width:100%;flex:unset!important;min-width:0!important}}@media (width<=480px){.sdash-header-btns{justify-content:stretch}.sdash-header-btns>div,.sdash-header-btns>button{flex:1}.sdash-btn-csv,.sdash-btn-primary{justify-content:center;width:100%}}.sdash-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-family:Outfit,Inter,sans-serif;font-size:.85rem;font-weight:700;transition:all .18s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.sdash-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.sdash-btn.sdash-btn-primary{color:#1c1917;background:linear-gradient(135deg,#fcd34d 0%,#f59e0b 100%);box-shadow:0 4px 14px #f59e0b59}.sdash-btn.sdash-btn-primary:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 8px 24px #f59e0b73}.sdash-btn.sdash-btn-primary:active:not(:disabled){transform:translateY(0)}.sdash-btn.sdash-btn-ghost{color:#475569;background:#fff;border:1.5px solid #e2e8f0;box-shadow:0 1px 4px #0000000f}.sdash-btn.sdash-btn-ghost:hover:not(:disabled){color:#1e293b;background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 3px 10px #00000014}.sdash-btn.sdash-btn-danger{color:#fff;background:linear-gradient(135deg,#f87171 0%,#dc2626 100%);box-shadow:0 4px 14px #dc26264d}.sdash-btn.sdash-btn-danger:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 8px 20px #dc262666}.sdash-form-input{background:var(--cream-100);border:1.5px solid var(--cream-300);color:#1e293b;box-sizing:border-box;appearance:none;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:Inter,sans-serif;font-size:.875rem;transition:all .18s}.sdash-form-input:focus{border-color:var(--amber-500);background:#fff;box-shadow:0 0 0 3px #f59e0b26}.sdash-form-input::placeholder{color:#94a3b8}select.sdash-form-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.class-mgmt-modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:9999;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.18s finance-overlay-in;display:flex;position:fixed;inset:0}@keyframes finance-overlay-in{0%{opacity:0}to{opacity:1}}.class-mgmt-modal{background:#fff;border-radius:20px;width:100%;max-width:500px;animation:.22s cubic-bezier(.34,1.56,.64,1) finance-modal-in;overflow:hidden;box-shadow:0 25px 60px -12px #0000004d,inset 0 0 0 1px #fffc}@keyframes finance-modal-in{0%{opacity:0;transform:scale(.94)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.class-mgmt-modal-header{background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border-bottom:1px solid #fde68a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.class-mgmt-modal-title{color:#1e293b;align-items:center;gap:8px;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800;display:flex}.class-mgmt-modal-close{cursor:pointer;color:#64748b;background:#fffc;border:1px solid #00000014;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:.9rem;font-weight:700;line-height:1;transition:all .15s;display:flex}.class-mgmt-modal-close:hover{color:#1e293b;background:#fff;box-shadow:0 2px 8px #0000001a}.finance-tabs{background:#f1f5f9;border-radius:14px;gap:4px;width:fit-content;margin-bottom:28px;padding:4px;display:flex}.finance-tab-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:10px;padding:9px 22px;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700;transition:all .18s}.finance-tab-btn.active{color:#1e293b;background:#fff;box-shadow:0 1px 6px #0000001f}.finance-tab-btn:hover:not(.active){color:#334155}.fin-accountant-card{background:#fff;border:1.5px solid #f1f5f9;border-radius:18px;flex-direction:column;gap:12px;padding:20px 22px;transition:box-shadow .2s,transform .2s;display:flex;box-shadow:0 2px 16px #0000000d}.fin-accountant-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0000001a}.fee-badge{letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:3px 11px;font-size:.76rem;font-weight:700;display:inline-flex}.fee-badge.paid{color:#15803d;background:#dcfce7}.fee-badge.partial{color:#b45309;background:#fef3c7}.fee-badge.pending{color:#dc2626;background:#fee2e2}.fin-summary-card{border-radius:16px;flex-direction:column;gap:6px;padding:18px 20px;display:flex}.fin-summary-icon{margin-bottom:2px;font-size:1.6rem;line-height:1}.fin-summary-value{font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:800;line-height:1.1}.fin-summary-label{opacity:.7;text-transform:uppercase;letter-spacing:.5px;font-size:.77rem;font-weight:600}.fin-table-wrap{background:#fff;border:1.5px solid #f1f5f9;border-radius:18px;overflow:hidden;box-shadow:0 2px 16px #0000000d}.fin-table-wrap table{border-collapse:collapse;width:100%;font-size:.86rem}.fin-table-wrap thead tr{background:#f8fafc;border-bottom:2px solid #f1f5f9}.fin-table-wrap th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;padding:13px 15px;font-size:.78rem;font-weight:700}.fin-table-wrap tbody tr{border-bottom:1px solid #f1f5f9;transition:background .12s}.fin-table-wrap tbody tr:last-child{border-bottom:none}.fin-table-wrap tbody tr:hover{background:#fafbff!important}.fin-table-wrap td{vertical-align:middle;padding:13px 15px}.fin-empty{text-align:center;background:#fff;border:1.5px dashed #e2e8f0;border-radius:18px;padding:64px 24px}.fin-empty-icon{background:#f8fafc;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 16px;font-size:1.8rem;display:flex}.fin-empty h3{color:#1e293b;margin:0 0 6px;font-size:1rem;font-weight:800}.fin-empty p{color:#94a3b8;margin:0;font-size:.85rem}.fin-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:22px;display:flex}.fin-section-header h2{color:#1e293b;margin:0;font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800}.fin-section-header p{color:#64748b;margin:3px 0 0;font-size:.83rem}.fin-acc-avatar{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800;display:flex;box-shadow:0 4px 12px #6366f14d}.fin-pass-chip{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:8px;padding:8px 12px;display:flex}.fin-pass-label{color:#94a3b8;white-space:nowrap;font-size:.76rem;font-weight:700}.fin-pass-value{color:#334155;text-overflow:ellipsis;flex:1;min-width:0;font-family:Courier New,monospace;font-size:.83rem;overflow:hidden}.fin-pass-toggle{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px 4px;font-size:1rem;line-height:1;transition:color .15s;display:flex}.fin-pass-toggle:hover{color:#475569}.fin-filter-row{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.fin-filter-row .fin-search{flex:220px;position:relative}.fin-filter-row .fin-search .fin-search-icon{color:#94a3b8;pointer-events:none;font-size:1rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.fin-filter-row .fin-search input{box-sizing:border-box;color:#1e293b;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:10px 14px 10px 36px;font-size:.86rem;transition:border-color .18s,box-shadow .18s}.fin-filter-row .fin-search input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1f}.fin-filter-row select{color:#334155;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 12px center no-repeat;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:10px 36px 10px 14px;font-size:.86rem;transition:border-color .18s}.fin-filter-row select:focus{border-color:#f59e0b}.fin-pay-entry{background:#fff;border:1px solid #f1f5f9;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;transition:background .12s;display:flex}.fin-pay-entry:nth-child(2n){background:#fafbff}.fin-pay-entry:hover{background:#f0f9ff}.fin-pay-amount{color:#15803d;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.fin-pay-meta{color:#64748b;margin-top:3px;font-size:.78rem}.fin-reports-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:28px;display:grid}@media (width<=640px){.finance-tabs{width:100%}.finance-tab-btn{text-align:center;flex:1;padding:9px 10px;font-size:.78rem}.fin-section-header{flex-direction:column;align-items:flex-start}.sdash-btn{padding:9px 14px;font-size:.82rem}.fin-reports-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=400px){.fin-reports-grid{grid-template-columns:1fr}}@media (width<=1200px){.acc-reports-grid,.acc-reports-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}}@media (width<=768px){.acc-reports-grid,.acc-reports-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}}@media (width<=480px){.acc-reports-grid,.acc-reports-summary-grid{grid-template-columns:repeat(1,minmax(0,1fr))!important;gap:8px!important}}.teacher-leaves-filters::-webkit-scrollbar{display:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.sdash-modal-close+div{white-space:normal!important;text-align:center!important;max-width:250px!important;left:50%!important;right:auto!important;transform:translate(-50%)!important}}.stu-module{flex-direction:column;gap:20px;display:flex}.stu-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.stu-title{color:var(--slate-800);align-items:center;gap:10px;margin:0;font-family:Outfit,sans-serif;font-size:1.7rem;font-weight:800;display:flex}.stu-sub{color:var(--slate-400);margin:4px 0 0;font-size:.88rem}.stu-header-actions{flex-wrap:wrap;gap:10px;display:flex}.stu-btn-primary{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));color:var(--slate-900);cursor:pointer;border:none;border-radius:12px;align-items:center;gap:7px;padding:10px 20px;font-size:.9rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 14px #f59e0b4d}.stu-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b73}.stu-btn-primary:disabled{background:var(--slate-150,#e2e8f0)!important;color:var(--slate-400,#94a3b8)!important;cursor:not-allowed!important;box-shadow:none!important;transform:none!important}.stu-btn-cancel{border:1.5px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#fff;border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s}.stu-btn-cancel:hover{background:var(--slate-50)}.stu-btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:700;transition:all .2s}.stu-btn-danger:hover{background:#dc2626}.stu-filters{flex-wrap:wrap;gap:12px;width:100%;display:flex}.stu-search-wrap{flex:1;min-width:280px;position:relative}.stu-search-icon{color:var(--slate-400);font-size:1rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.stu-search{border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;padding:10px 12px 10px 38px;font-family:Inter,sans-serif;font-size:.9rem;transition:border .2s}.stu-search:focus{border-color:var(--amber-400)}.stu-filter-select{border:1.5px solid var(--slate-200);color:var(--slate-700);cursor:pointer;background:#fff;border-radius:12px;outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:.9rem;transition:border .2s}.stu-filter-select:focus{border-color:var(--amber-400)}.stu-stats-bar{border:1px solid var(--slate-100);background:#fff;border-radius:14px;flex-wrap:wrap;gap:14px;padding:14px 20px;display:flex;box-shadow:0 2px 10px #0000000a}.stu-stat{border-right:1px solid var(--slate-100);flex-direction:column;align-items:center;gap:2px;padding:0 12px;display:flex}.stu-stat:last-child{border-right:none}.stu-stat-num{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800}.stu-stat span:last-child{color:var(--slate-400);text-transform:uppercase;letter-spacing:.4px;font-size:.72rem;font-weight:600}.stu-table-card{border:1px solid var(--slate-100);background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 20px #0000000d}.stu-table-wrap{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto!important}.stu-table{border-collapse:collapse;width:100%}.stu-table thead tr{background:var(--slate-50)}.stu-table th{text-align:left;color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:1.5px solid var(--slate-100);white-space:nowrap;padding:13px 16px;font-size:.75rem;font-weight:700}.stu-table td{border-bottom:1px solid var(--slate-50);color:var(--slate-700);vertical-align:middle;padding:14px 16px;font-size:.88rem}.stu-table tr:last-child td{border-bottom:none}.stu-table tr:hover td{background:#fffdf7}.stu-table-empty{text-align:center;color:var(--slate-400);padding:40px 16px!important}.stu-id-badge{color:#92400e;letter-spacing:.5px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;padding:4px 10px;font-family:Outfit,monospace;font-size:.82rem;font-weight:800}.stu-name-cell{align-items:center;gap:10px;display:flex}.stu-avatar-sm{background:linear-gradient(135deg, var(--cream-400), var(--amber-400));width:34px;height:34px;color:var(--slate-900);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:800;display:flex}.stu-name{color:var(--slate-800);font-size:.88rem;font-weight:700}.stu-meta{color:var(--slate-400);font-size:.75rem}.stu-class-chip{background:var(--slate-50);border:1px solid var(--slate-200);color:var(--slate-600);white-space:nowrap;border-radius:8px;padding:4px 10px;font-size:.8rem;font-weight:700}.stu-pass{background:var(--slate-50);border:1px solid var(--slate-200);color:var(--slate-600);border-radius:6px;padding:3px 8px;font-size:.8rem}.stu-actions{gap:6px;display:flex}.stu-act-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:.9rem;transition:all .2s;display:flex}.stu-act-btn.view{color:#3b82f6;background:#eff6ff}.stu-act-btn.view:hover{color:#fff;background:#3b82f6}.stu-act-btn.lc{color:#16a34a;background:#f0fdf4}.stu-act-btn.lc:hover{color:#fff;background:#16a34a}.stu-act-btn.edit{color:#d97706;background:#fef3c7}.stu-act-btn.edit:hover{color:#fff;background:#d97706}.stu-act-btn.del{color:#ef4444;background:#fef2f2}.stu-act-btn.del:hover{color:#fff;background:#ef4444}.stu-act-btn.leave{color:#9333ea;background:#faf5ff}.stu-act-btn.leave:hover{color:#fff;background:#9333ea}.stu-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.stu-modal-overlay.fullscreen{padding:0}.stu-modal-lg{background:#fff;border-radius:22px;flex-direction:column;width:100%;max-width:860px;max-height:92vh;display:flex;box-shadow:0 30px 80px #0003}.stu-modal-fullscreen{width:100%;max-width:none;height:100%;max-height:100vh;box-shadow:none;background:#fff;border-radius:0;flex-direction:column;display:flex}.stu-modal-fullscreen .stu-form-scroll{max-height:none}.stu-modal-sm{text-align:center;background:#fff;border-radius:22px;width:100%;max-width:440px;padding:32px;box-shadow:0 30px 80px #0003}.stu-modal-sm h3{color:var(--slate-800);margin:12px 0 8px;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.stu-modal-sm p{color:var(--slate-500);margin:0 0 8px;font-size:.9rem;line-height:1.6}.stu-warn-note{color:#d97706!important;font-size:.85rem!important;font-weight:600!important}.stu-modal-head h3{margin:0;font-size:1.2rem;font-weight:800}.stu-confirm-icon{border-radius:18px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 14px;font-size:1.6rem;display:flex}.stu-confirm-icon.del{color:#ef4444;background:#fef2f2}.stu-confirm-icon.warn{color:#d97706;background:#fffbeb}.stu-form-scroll{background:var(--slate-50);flex:1;padding:24px 28px;overflow-y:auto}.stu-form-section{border:1px solid var(--slate-200);background:#fff;border-radius:18px;margin-bottom:24px;padding:24px;box-shadow:0 4px 14px #00000008}.stu-form-section-title{color:var(--slate-800);text-transform:capitalize;letter-spacing:0;border-bottom:1.5px solid var(--slate-100);align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;display:flex}.stu-sec-icon{background:linear-gradient(135deg, var(--cream-400), var(--amber-400));width:36px;height:36px;color:var(--slate-900);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex;box-shadow:0 4px 10px #f59e0b40}.stu-fg{flex-direction:column;gap:5px;display:flex}.stu-fg.full{margin-top:14px}.stu-fg label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.4px;font-size:.78rem;font-weight:700}.stu-fg .req{color:#ef4444;margin-left:3px}.stu-fg input,.stu-fg textarea,.stu-datepicker{border:1.5px solid var(--slate-200);color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:10px;outline:none;width:100%;padding:9px 12px;font-family:Inter,sans-serif;font-size:.88rem;transition:border .2s}.stu-fg input:focus,.stu-fg textarea:focus,.stu-datepicker:focus{border-color:var(--amber-400)}.react-datepicker-wrapper{width:100%}.stu-fg textarea{resize:vertical;min-height:60px}.stu-input-error{background:#fef2f2!important;border-color:#ef4444!important}.stu-field-err{color:#ef4444;margin-top:2px;font-size:.74rem;font-weight:600}.stu-field-ok{color:#16a34a;margin-top:2px;font-size:.74rem;font-weight:700}.stu-sel-wrap{position:relative}.stu-sel-wrap select{appearance:none;border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);cursor:pointer;background:#fff;border-radius:10px;outline:none;padding:9px 36px 9px 12px;font-family:Inter,sans-serif;font-size:.88rem;transition:border .2s}.stu-sel-wrap select:focus{border-color:var(--amber-400)}.stu-sel-icon{color:var(--slate-400);pointer-events:none;font-size:.9rem;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.id-card-modal{text-align:left!important}.id-card{border:2px solid var(--amber-300);border-radius:16px;margin:20px 0;overflow:hidden;box-shadow:0 8px 24px #f59e0b26}.id-card-header{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.id-card-school{color:var(--slate-900);font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800}.id-card-year{color:var(--slate-700);font-size:.75rem;font-weight:600}.id-card-body{background:#fff;padding:20px}.id-card-avatar{background:linear-gradient(135deg, var(--cream-400), var(--amber-400));width:56px;height:56px;color:var(--slate-900);border-radius:14px;justify-content:center;align-items:center;margin-bottom:12px;font-size:1.4rem;font-weight:800;display:flex}.id-card-name{color:var(--slate-800);margin-bottom:2px;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800}.id-card-class{color:var(--slate-400);margin-bottom:12px;font-size:.82rem;font-weight:600}.id-card-footer{background:var(--slate-50);color:var(--slate-500);border-top:1px solid var(--slate-100);padding:12px 20px;font-size:.82rem}.id-card-footer code{background:var(--slate-200);color:var(--slate-700);border-radius:6px;padding:2px 8px;font-size:.85rem}.react-datepicker{overflow:hidden;border:1px solid var(--slate-200)!important;border-radius:14px!important;font-family:Inter,sans-serif!important;box-shadow:0 10px 30px #0000001a!important}.react-datepicker__header{background:var(--slate-50)!important;border-bottom:1px solid var(--slate-100)!important;padding-top:14px!important}.react-datepicker-popper{z-index:3000!important}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background:linear-gradient(135deg, var(--amber-400), var(--amber-500))!important;color:#fff!important;border-radius:8px!important;font-weight:700!important}.react-datepicker__day:hover{background:var(--slate-100)!important;border-radius:8px!important}.react-datepicker__day{color:var(--slate-700)!important;margin:.2rem!important}.react-datepicker__day-name{font-size:.8rem;color:var(--slate-400)!important;font-weight:700!important}.react-datepicker__month-select,.react-datepicker__year-select{border:1px solid var(--slate-200);color:var(--slate-700);cursor:pointer;background:#fff;border-radius:6px;outline:none;padding:4px 8px;font-family:Inter,sans-serif;font-size:.9rem}.react-datepicker__month-select:focus,.react-datepicker__year-select:focus{border-color:var(--amber-400)}.react-datepicker__navigation{top:14px!important}@media print{.stu-modal-overlay{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;position:static}.stu-modal-sm{box-shadow:none;padding:0}.stu-modal-head,.stu-modal-footer{display:none}.id-card{border:2px solid #000}}@media (width<=700px){.stu-form-grid{grid-template-columns:1fr}.stu-stats-bar{justify-content:space-between;padding:12px}.stu-stat{border:none;flex:1;padding:0 4px}.stu-csv-menu{min-width:240px;left:0;right:auto}.stu-filters{flex-direction:column;width:100%}.stu-search-wrap{width:100%}.stu-filters-row2{gap:10px;width:100%;display:flex;flex-direction:row!important}.stu-filters-row2 select{flex:1;min-width:0}.stu-header-actions{grid-template-columns:1fr 1fr!important;gap:8px!important;width:100%!important;display:grid!important}.stu-header-actions>:first-child{grid-area:1/1!important;width:100%!important}.stu-header-actions>.stu-btn-bonafide-manage{grid-area:1/2!important;width:100%!important}.stu-header-actions>.stu-btn-primary{grid-area:2/1/auto/span 2!important;width:100%!important}.stu-btn-csv,.stu-btn-primary,.stu-btn-bonafide-manage{justify-content:center;padding-left:0;padding-right:0;width:100%!important}.stu-modal-overlay{-webkit-backdrop-filter:none!important;background:#000000b3!important}}.stu-btn-csv{color:var(--slate-700);border:1.5px solid var(--slate-200);cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:8px;padding:10px 18px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 8px #0000000a}.stu-btn-csv:hover{border-color:var(--amber-400);background:var(--slate-50);color:var(--slate-900);transform:translateY(-1px);box-shadow:0 4px 15px #f59e0b1a}.stu-btn-csv svg:first-child{color:var(--slate-400);font-size:1.1rem;transition:color .25s}.stu-btn-csv:hover svg:first-child{color:var(--amber-600)}.stu-csv-menu{border:1px solid var(--slate-100);z-index:1000;background:#fff;border-radius:16px;min-width:260px;margin-top:10px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 15px 45px #00000026}.stu-csv-menu.left{left:0;right:auto}.stu-csv-filter-sec{border-bottom:1px solid var(--slate-100);background:var(--slate-50);padding:16px}.stu-csv-filter-label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-size:.7rem;font-weight:800;display:block}.stu-csv-select{border:1.5px solid var(--slate-200);cursor:pointer;border-radius:10px;outline:none;width:100%;padding:10px;font-family:Inter,sans-serif;font-size:.85rem;transition:all .2s}.stu-csv-select:focus{border-color:var(--amber-400);background:#fff}.stu-csv-item{text-align:left;cursor:pointer;background:#fff;border:none;flex-direction:column;width:100%;padding:16px 20px;transition:all .2s;display:flex}.stu-csv-item:hover{background:var(--slate-50)}.stu-csv-item-title{color:var(--slate-800);font-size:.92rem;font-weight:700;transition:color .2s}.stu-csv-item-desc{color:var(--slate-400);margin-top:4px;font-size:.75rem}.stu-csv-item:hover .stu-csv-item-title{color:var(--amber-700)}@keyframes stu-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.stu-skeleton-item{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;border-radius:6px;animation:1.5s linear infinite stu-shimmer}.stu-skeleton-title{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;border-radius:8px;align-items:center;width:180px;height:24px;margin-bottom:18px;animation:1.5s linear infinite stu-shimmer;display:flex}.stu-skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px;display:grid}.stu-skeleton-card-row{border:1px solid var(--slate-100);background:#fff;border-radius:12px;flex-direction:column;gap:8px;padding:14px 18px;display:flex}.stu-skeleton-card-row .label{width:80px;height:12px}.stu-skeleton-card-row .value{width:140px;height:16px}@media (width<=768px){.stu-modal-close+div{white-space:normal!important;text-align:center!important;max-width:250px!important;left:50%!important;right:auto!important;transform:translate(-50%)!important}}[contenteditable]:empty:before{content:attr(data-placeholder);color:#94a3b8;pointer-events:none;font-size:.88rem;font-style:italic}[contenteditable]:focus{outline:none}.stu-act-btn.lc{color:#0369a1;background:#e0f2fe;border:1px solid #bae6fd}.stu-act-btn.lc:hover{color:#fff;background:#0ea5e9;border-color:#0ea5e9}.stu-btn-bonafide-manage{color:#0369a1;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border:1.5px solid #7dd3fc;border-radius:12px;align-items:center;gap:7px;padding:10px 18px;font-size:.88rem;font-weight:700;transition:all .2s;display:flex}.stu-btn-bonafide-manage:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0369a126}.stu-bulk-preview-wrap{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;border:1px solid var(--slate-200);border-radius:12px;max-width:100%;min-height:250px;max-height:calc(100vh - 290px);overflow:auto!important}.stu-bulk-preview-wrap::-webkit-scrollbar{width:10px;height:10px}.stu-bulk-preview-wrap::-webkit-scrollbar-track{background:var(--slate-50);border-radius:8px}.stu-bulk-preview-wrap::-webkit-scrollbar-thumb{background:var(--slate-300);border:2px solid var(--slate-50);border-radius:8px}.stu-bulk-preview-wrap::-webkit-scrollbar-thumb:hover{background:var(--amber-400)}.stu-bulk-file-banner{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 18px;display:flex}.stu-bulk-file-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.stu-bulk-file-name{color:#14532d;overflow-wrap:break-word;word-break:break-all;font-size:.88rem;font-weight:700}.stu-bulk-file-sub{color:#15803d;font-size:.75rem}@media (width<=600px){.stu-bulk-file-banner{flex-direction:column;align-items:stretch;gap:10px;padding:12px}.stu-bulk-file-banner button{justify-content:center;width:100%}}.nc-module{flex-direction:column;gap:20px;display:flex}.nc-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;display:flex}.nc-header-left{align-items:center;gap:14px;display:flex}.nc-header-icon{color:#fff;background:linear-gradient(135deg,#f43f5e,#e11d48);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex;box-shadow:0 4px 14px #f43f5e59}.nc-module-title{color:var(--slate-800);margin:0;font-family:Outfit,sans-serif;font-size:1.7rem;font-weight:800}.nc-module-sub{color:var(--slate-400);margin:4px 0 0;font-size:.87rem}.nc-btn-compose{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f43f5e,#e11d48);border:none;border-radius:12px;align-items:center;gap:7px;padding:11px 22px;font-family:Inter,sans-serif;font-size:.92rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 14px #f43f5e59}.nc-btn-compose:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f43f5e73}.nc-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.nc-search-wrap{flex:1;min-width:200px;position:relative}.nc-search-icon{color:var(--slate-400);pointer-events:none;font-size:1rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.nc-search{border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;padding:10px 12px 10px 36px;font-family:Inter,sans-serif;font-size:.9rem;transition:border .2s}.nc-search:focus{border-color:#f43f5e}.nc-filter-sel{border:1.5px solid var(--slate-200);color:var(--slate-700);cursor:pointer;background:#fff;border-radius:12px;outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:.88rem;transition:border .2s}.nc-filter-sel:focus{border-color:#f43f5e}.nc-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;display:grid}.nc-card{border:1px solid var(--slate-100);background:#fff;border-radius:18px;flex-direction:column;gap:10px;padding:20px;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden;box-shadow:0 4px 18px #0000000d}.nc-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #00000017}.nc-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.nc-card-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.nc-tag{text-transform:uppercase;letter-spacing:.4px;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.74rem;font-weight:700;display:inline-flex}.nc-aud-chip{align-items:center;gap:5px;font-size:.78rem;font-weight:700;display:inline-flex}.nc-edit-btn,.nc-del-btn{cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.95rem;transition:all .2s;display:flex}.nc-edit-btn{color:#16a34a;background:#f0fdf4}.nc-edit-btn:hover{color:#fff;background:#16a34a}.nc-del-btn{color:#ef4444;background:#fef2f2}.nc-del-btn:hover{color:#fff;background:#ef4444}.nc-title{color:var(--slate-800);word-wrap:break-word;word-break:break-word;overflow-wrap:anywhere;margin:0;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800;line-height:1.35}.nc-desc-wrap{flex-direction:column;align-items:flex-start;gap:4px;display:flex}.nc-desc{color:var(--slate-600);white-space:pre-wrap;-webkit-line-clamp:4;-webkit-box-orient:vertical;max-height:6.6rem;margin:0;font-size:.88rem;line-height:1.65;display:-webkit-box;overflow:hidden}.nc-show-more{color:#3b82f6;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:0;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;display:inline-flex}.nc-show-more:hover{color:#2563eb;text-decoration:underline}.nc-attachments{flex-direction:column;gap:12px;margin-top:4px;display:flex}.nc-images-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;display:grid}.nc-img-preview{cursor:pointer;aspect-ratio:4/3;background:var(--slate-50);border-radius:12px;position:relative;overflow:hidden}.nc-img-preview img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.nc-img-preview:hover img{transform:scale(1.04)}.nc-img-shimmer{z-index:1;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;border-radius:12px;animation:1.4s infinite nc-shimmer;position:absolute;inset:0}@keyframes nc-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.nc-img-loading{opacity:0;transition:opacity .4s}.nc-img-loaded{opacity:1;transition:opacity .4s}.nc-img-overlay{color:#fff;opacity:0;background:#00000059;justify-content:center;align-items:center;gap:6px;font-size:.9rem;font-weight:700;transition:opacity .2s;display:flex;position:absolute;inset:0}.nc-img-preview:hover .nc-img-overlay{opacity:1}.nc-img-overlay.always-show{opacity:1;background:#0009;font-size:1.1rem}.nc-pdf-list{flex-direction:column;gap:8px;display:flex}.nc-pdf-chip{color:#4f46e5;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;background:#f0f2ff;border:1.5px solid #c7d2fe;border-radius:10px;align-items:center;gap:7px;max-width:100%;padding:8px 14px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex;overflow:hidden}.nc-pdf-chip svg{flex-shrink:0}.nc-pdf-chip:hover{color:#fff;background:#4f46e5;border-color:#4f46e5}.nc-pdf-chip.extra{color:#64748b;cursor:pointer;background:#f8fafc;border-style:dashed;border-color:#cbd5e1}.nc-pdf-chip.extra:hover{color:#475569;background:#f1f5f9}.nc-card-footer{color:var(--slate-400);border-top:1px solid var(--slate-50);justify-content:space-between;align-items:center;gap:6px;margin-top:4px;padding-top:8px;font-size:.76rem;font-weight:600;display:flex}.nc-author{background:var(--slate-100);color:var(--slate-600);border-radius:99px;padding:3px 10px;font-size:.72rem}.iv-overlay{z-index:999999;-webkit-user-select:none;user-select:none;touch-action:none;background:#000000eb;flex-direction:column;display:flex;position:fixed;inset:0}.iv-topbar{z-index:10;background:linear-gradient(#0009,#0000);justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:absolute;top:0;left:0;right:0}.iv-counter{color:#fffc;font-family:Inter,sans-serif;font-size:.88rem;font-weight:700}.iv-toolbar{align-items:center;gap:6px;display:flex}.iv-toolbar button{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:none;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.2rem;transition:all .2s;display:flex}.iv-toolbar button:hover{background:#ffffff40}.iv-zoom-level{color:#ffffffb3;text-align:center;min-width:44px;font-family:Inter,sans-serif;font-size:.78rem;font-weight:700}.iv-image-wrap{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.iv-image{object-fit:contain;border-radius:4px;max-width:92vw;max-height:82vh;transition:transform .1s ease-out}.iv-arrow{z-index:10;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:none;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.6rem;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.iv-arrow:hover{background:#ffffff4d}.iv-prev{left:16px}.iv-next{right:16px}.iv-disabled{opacity:.25;cursor:not-allowed}.iv-disabled:hover{background:#ffffff1f}.iv-thumbs{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#00000080;border-radius:14px;gap:8px;max-width:90vw;padding:8px 12px;display:flex;position:absolute;bottom:16px;left:50%;overflow-x:auto;transform:translate(-50%)}.iv-thumb{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:8px;flex-shrink:0;width:52px;height:40px;padding:0;transition:all .2s;overflow:hidden}.iv-thumb img{object-fit:cover;width:100%;height:100%;display:block}.iv-thumb.active{border-color:#fff;box-shadow:0 0 10px #fff6}.iv-thumb:hover:not(.active){border-color:#fff6}@media (width<=640px){.iv-arrow{border-radius:10px;width:38px;height:38px;font-size:1.3rem}.iv-prev{left:8px}.iv-next{right:8px}.iv-toolbar button{width:34px;height:34px;font-size:1rem}.iv-thumb{width:40px;height:32px}}.pv-overlay{z-index:999999;background:#000000eb;flex-direction:column;display:flex;position:fixed;inset:0}.pv-topbar{background:linear-gradient(#000000b3,#0006);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.pv-title{color:#fff;align-items:center;gap:8px;font-family:Inter,sans-serif;font-size:.95rem;font-weight:700;display:flex}.pv-toolbar{gap:6px;display:flex}.pv-toolbar button{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .2s;display:flex}.pv-toolbar button:hover{background:#ffffff40}.pv-toolbar .pv-close-btn{color:#ef4444!important}.pv-toolbar .pv-close-btn:hover{background:#ef44444d!important}.pv-body{flex:1;padding:0;position:relative;overflow:hidden}.pv-loading{z-index:2;color:#ffffffb3;background:#000c;flex-direction:column;justify-content:center;align-items:center;gap:14px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;display:flex;position:absolute;inset:0}.pv-iframe{background:#fff;border:none;width:100%;height:100%;transition:opacity .3s}@media (width<=640px){.pv-toolbar button{width:36px;height:36px;font-size:1rem}}.nc-empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;display:flex}.nc-empty-icon{color:#f43f5e;background:linear-gradient(135deg,#ffe4e6,#fecdd3);border-radius:22px;justify-content:center;align-items:center;width:68px;height:68px;font-size:2rem;display:flex}.nc-empty p{color:var(--slate-400);margin:0;font-size:.95rem;font-weight:500}.nc-loading{color:var(--slate-400);justify-content:center;align-items:center;gap:12px;padding:60px 20px;font-weight:600;display:flex}.nc-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:3000;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.nc-compose{will-change:transform, opacity;background:#fff;border-radius:22px;flex-direction:column;width:100%;max-width:640px;max-height:92vh;display:flex;overflow:hidden;transform:translateZ(0);box-shadow:0 30px 80px #0003}.nc-compose-header{border-bottom:1px solid var(--slate-100);background:linear-gradient(135deg,#fff1f2,#ffe4e6);flex-shrink:0;align-items:center;gap:14px;padding:22px 28px;display:flex}.nc-compose-icon{color:#fff;background:linear-gradient(135deg,#f43f5e,#e11d48);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.4rem;display:flex;box-shadow:0 4px 12px #f43f5e59}.nc-compose-header>div:not(.nc-compose-icon){flex:1;min-width:0}.nc-compose-header h2{color:var(--slate-800);word-wrap:break-word;word-break:break-word;overflow-wrap:anywhere;margin:0;font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:800}.nc-compose-header p{color:var(--slate-500);margin:3px 0 0;font-size:.8rem}.nc-compose-close{color:#f43f5e;cursor:pointer;background:#f43f5e1a;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-left:auto;font-size:1.15rem;transition:all .2s;display:flex}.nc-compose-close:hover{color:#fff;background:#f43f5e}.nc-compose-body{flex-direction:column;flex:1;gap:18px;padding:24px 28px;display:flex;overflow-y:auto}.nc-form-group{flex-direction:column;gap:8px;display:flex}.nc-form-group label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px;font-size:.78rem;font-weight:700}.nc-req{color:#ef4444;margin-left:3px}.nc-optional{color:var(--slate-400);text-transform:none;letter-spacing:0;font-size:.76rem;font-weight:400}.nc-form-group input{border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;height:40px;padding:10px 14px;font-family:inherit;font-size:.95rem;transition:all .2s}.nc-form-group textarea{border:1.5px solid var(--slate-200);resize:vertical;width:100%;min-height:100px;color:var(--slate-700);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:all .2s}.nc-form-group input:focus,.nc-form-group textarea:focus,.nc-date-input:focus{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.nc-date-input{border:1.5px solid var(--slate-200);width:100%;color:var(--slate-700);background:#fff;border-radius:12px;outline:none;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:all .2s}.nc-char-count{color:var(--slate-400);text-align:right;margin-top:-4px;font-size:.72rem}.nc-tag-chips{flex-wrap:wrap;gap:8px;display:flex}.nc-tag-chip{border:1.5px solid var(--slate-200);color:var(--slate-500);cursor:pointer;background:#fff;border-radius:20px;padding:6px 14px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;transition:all .2s}.nc-tag-chip:hover{border-color:var(--slate-400);color:var(--slate-700)}.nc-tag-chip.active{font-weight:700}.nc-aud-options{flex-wrap:wrap;gap:8px;display:flex}.nc-aud-btn{border:1.5px solid var(--slate-200);color:var(--slate-500);cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:6px;padding:8px 16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.nc-aud-btn:hover{border-color:var(--slate-400);color:var(--slate-700)}.nc-aud-btn.active{font-weight:700}.nc-class-select{margin-top:10px}.nc-multi-select{flex-wrap:wrap;gap:8px;display:flex}.nc-multi-chip{border:1.5px solid var(--slate-200);color:var(--slate-500);cursor:pointer;background:#fff;border-radius:10px;padding:6px 12px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.nc-multi-chip:hover{border-color:var(--slate-400);color:var(--slate-700)}.nc-multi-chip.active{color:#3b82f6;background:#eff6ff;border-color:#3b82f6;font-weight:700}.nc-attach-area{border:2px dashed var(--slate-200);background:var(--slate-50);cursor:pointer;border-radius:14px;justify-content:center;align-items:center;min-height:100px;transition:border .2s;display:flex;overflow:hidden}.nc-attach-area:hover{border-color:#f43f5e}.nc-attach-placeholder{color:var(--slate-400);flex-direction:column;align-items:center;gap:8px;padding:20px;font-size:.88rem;font-weight:500;display:flex}.nc-attach-icons{color:var(--slate-300);gap:10px;font-size:1.8rem;display:flex}.nc-file-list{flex-direction:column;gap:6px;margin-top:10px;display:flex}.nc-file-item{border:1.5px solid var(--slate-200);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;padding:10px 14px;display:flex}.nc-file-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.nc-file-info>div:not(.nc-file-preview){flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.nc-file-preview{background:var(--slate-50);width:44px;height:44px;color:var(--slate-400);border:1px solid var(--slate-100);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.3rem;display:flex;overflow:hidden}.nc-file-thumb{object-fit:cover;width:100%;height:100%}.nc-file-name{color:var(--slate-700);white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:.88rem;font-weight:600;display:block;overflow:hidden}.nc-file-tag{color:#3b82f6;text-transform:uppercase;margin-top:-2px;font-size:.7rem;font-weight:700}.nc-file-size{color:var(--slate-400);margin-top:-2px;font-size:.7rem;font-weight:500}.nc-file-remove{color:#ef4444;cursor:pointer;background:#fef2f2;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.1rem;transition:all .2s;display:flex}.nc-file-remove:hover{background:#fee2e2;transform:scale(1.05)}.nc-upload-bar{background:var(--slate-100);border-radius:4px;align-items:center;height:4px;margin-top:6px;display:flex;position:relative;overflow:hidden}.nc-upload-fill{background:linear-gradient(90deg,#f43f5e,#e11d48);border-radius:4px;height:100%;transition:width .3s}.nc-upload-bar span{color:#f43f5e;font-size:.7rem;font-weight:700;position:absolute;top:-18px;right:0}.nc-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:10px 14px;font-size:.85rem;font-weight:600}.nc-compose-footer{border-top:1px solid var(--slate-100);background:var(--slate-50);flex-shrink:0;justify-content:flex-end;gap:10px;padding:18px 28px;display:flex}.nc-btn-cancel{border:1.5px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#fff;border-radius:10px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s}.nc-btn-cancel:hover{background:var(--slate-50)}.nc-btn-cancel:disabled{opacity:.5;cursor:not-allowed}.nc-btn-post{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f43f5e,#e11d48);border:none;border-radius:12px;align-items:center;gap:8px;padding:11px 24px;font-family:Inter,sans-serif;font-size:.92rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 14px #f43f5e4d}.nc-btn-post:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f43f5e73}.nc-btn-post:disabled{opacity:.55;cursor:not-allowed;transform:none}.nc-btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:10px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;transition:all .2s}.nc-btn-danger:hover{background:#dc2626}.nc-spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite nc-spin}@keyframes nc-spin{to{transform:rotate(360deg)}}.nc-confirm{text-align:center;background:#fff;border-radius:22px;width:100%;max-width:420px;padding:36px 32px;box-shadow:0 30px 80px #0003}.nc-confirm-icon{color:#ef4444;background:#fef2f2;border-radius:18px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 16px;font-size:1.7rem;display:flex}.nc-confirm h3{color:var(--slate-800);margin:0 0 8px;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.nc-confirm p{color:var(--slate-500);margin:0 0 24px;font-size:.9rem;line-height:1.55}.nc-confirm-btns{justify-content:center;gap:12px;width:100%;display:flex}.nc-confirm-btns button{text-align:center;white-space:nowrap;flex:1;justify-content:center}@media (width<=640px){.nc-overlay{padding:0;-webkit-backdrop-filter:none!important;background:#000000b3!important}.nc-compose{width:100%;max-width:none;height:100%;max-height:100vh;box-shadow:none;border-radius:0}.nc-grid{grid-template-columns:1fr}.nc-compose-header{border-radius:0;padding:16px}.nc-compose-body{padding:18px}.nc-compose-footer{flex-direction:column;padding:14px 18px}.nc-btn-post,.nc-btn-cancel{justify-content:center;width:100%}.nc-aud-options{flex-direction:column}.nc-aud-btn{width:100%}.nc-filters{flex-direction:column}.nc-search-wrap,.nc-filter-sel{width:100%}}.pg-bar{border-top:1px solid var(--slate-100);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:30px;padding-top:20px;display:flex}.pg-info{color:var(--slate-500);font-size:.88rem;font-weight:500}.pg-btn{border:1.5px solid var(--slate-200);min-width:36px;height:36px;color:var(--slate-600);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;padding:0 10px;font-size:.88rem;font-weight:600;transition:all .2s;display:flex}.pg-goto{align-items:center;gap:8px;margin-left:10px;display:flex}.pg-goto span{color:var(--slate-400);font-size:.85rem}.pg-goto input{border:1.5px solid var(--slate-200);text-align:center;border-radius:8px;outline:none;width:50px;height:34px;font-size:.88rem;transition:border .2s}.pg-goto input:focus{border-color:#3b82f6}.apply-leave-backdrop{z-index:2000;background:#0009;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.apply-leave-modal{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:480px;max-height:90vh;display:flex;overflow:auto;box-shadow:0 24px 60px #00000040}@media (width<=640px){.apply-leave-backdrop{padding:0!important}.apply-leave-modal{width:100%!important;max-width:none!important;height:100%!important;max-height:100vh!important;box-shadow:none!important;border-radius:0!important}}.nc-desc-full{color:var(--slate-700);word-break:break-word;margin:0;font-size:.95rem;line-height:1.8;white-space:pre-wrap!important}.nc-leave-actions{gap:6px;display:flex}.nc-details-btn-wrap{align-items:center;gap:8px;display:flex}@media (width<=640px){.nc-leave-actions{z-index:10;position:absolute;top:14px;right:14px}.nc-card-top{flex-wrap:wrap!important}.nc-details-btn-wrap{justify-content:flex-end!important;width:100%!important;margin-top:10px!important}}.att-module{flex-direction:column;gap:24px;width:100%;min-width:0;max-width:100%;font-family:Inter,sans-serif;display:flex}.att-tabs{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;gap:4px;width:fit-content;padding:6px;display:flex}.att-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:7px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.88rem;font-weight:700;transition:all .2s;display:flex}.att-tab.active{color:#f59e0b;background:#fff;box-shadow:0 2px 8px #00000014}.att-tab:hover:not(.active){color:#334155;background:#ffffff80}.att-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.att-header-left{flex-direction:column;gap:4px;display:flex}.att-title{color:#0f172a;margin:0;font-family:Outfit,sans-serif;font-size:1.55rem;font-weight:800}.att-sub{color:#64748b;margin:0;font-size:.87rem}.att-header-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.att-date-row{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-wrap:wrap;align-items:center;gap:12px;padding:14px 20px;display:flex;box-shadow:0 2px 8px #0000000a}.att-date-label{color:#475569;white-space:nowrap;font-size:.85rem;font-weight:700}.att-date-input{color:#1e293b;cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:8px 14px;font-family:Inter,sans-serif;font-size:.9rem;transition:border .2s}.att-date-input:focus{background:#fff;border-color:#f59e0b}.att-today-badge{color:#92400e;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:8px;padding:5px 12px;font-size:.78rem;font-weight:700}.att-taken-badge{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #86efac;border-radius:8px;align-items:center;gap:5px;padding:5px 12px;font-size:.78rem;font-weight:700;display:flex}.att-quick-actions{flex-wrap:wrap;gap:8px;display:flex}.att-qa-btn{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;align-items:center;gap:6px;padding:7px 14px;font-family:Inter,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.att-qa-btn:hover{color:#f59e0b;background:#fffbeb;border-color:#f59e0b}.att-qa-btn.present{color:#16a34a;border-color:#86efac}.att-qa-btn.present:hover{background:#f0fdf4}.att-qa-btn.absent{color:#dc2626;border-color:#fca5a5}.att-qa-btn.absent:hover{background:#fef2f2}.att-roll-list{flex-direction:column;gap:8px;display:flex}.att-student-row{background:#fff;border:1.5px solid #f1f5f9;border-radius:14px;align-items:center;gap:14px;padding:12px 16px;transition:border .15s;display:flex;box-shadow:0 1px 4px #00000008}.att-student-row:hover{border-color:#e2e8f0}.att-student-row.present{background:#f0fdf4;border-color:#86efac}.att-student-row.absent{background:#fef2f2;border-color:#fca5a5}.att-roll-no{color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.82rem;font-weight:700;display:flex}.att-student-avatar{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.88rem;font-weight:700;display:flex}.att-student-info{flex:1;min-width:0}.att-student-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.att-student-id{color:#94a3b8;margin-top:1px;font-size:.77rem;font-weight:500}.att-action-btns{flex-shrink:0;gap:8px;display:flex}.att-action-btn{cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-family:Inter,sans-serif;font-size:.95rem;font-weight:800;transition:all .18s;display:flex}.att-action-btn.present-active{color:#fff;background:#16a34a;border-color:#15803d;box-shadow:0 2px 8px #16a34a40}.att-action-btn.present-idle{color:#16a34a;background:#f0fdf4;border-color:#86efac}.att-action-btn.present-idle:hover{background:#dcfce7}.att-action-btn.absent-active{color:#fff;background:#dc2626;border-color:#b91c1c;box-shadow:0 2px 8px #dc262640}.att-action-btn.absent-idle{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.att-action-btn.absent-idle:hover{background:#fee2e2}.att-submit-bar{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex;box-shadow:0 2px 8px #0000000a}.att-submit-counts{gap:16px;display:flex}.att-count-chip{align-items:center;gap:6px;font-size:.88rem;font-weight:700;display:flex}.att-count-chip.present{color:#16a34a}.att-count-chip.absent{color:#dc2626}.att-count-chip.pending{color:#94a3b8}.att-count-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.att-count-dot.present{background:#16a34a}.att-count-dot.absent{background:#dc2626}.att-count-dot.pending{background:#cbd5e1}.att-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 28px;font-family:Inter,sans-serif;font-size:.95rem;font-weight:800;transition:all .2s;display:flex;box-shadow:0 4px 14px #f59e0b59}.att-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b73}.att-submit-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.att-success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1.5px solid #86efac;border-radius:14px;align-items:center;gap:12px;padding:16px 20px;display:flex}.att-success-icon{font-size:1.6rem}.att-success h4{color:#15803d;margin:0 0 2px;font-size:1rem;font-weight:800}.att-success p{color:#166534;margin:0;font-size:.85rem}.att-stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}.att-stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;align-items:center;gap:14px;padding:18px 20px;display:flex;box-shadow:0 2px 8px #0000000a}.att-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.att-stat-icon.amber{color:#d97706;background:#fef3c7}.att-stat-icon.green{color:#16a34a;background:#dcfce7}.att-stat-icon.red{color:#dc2626;background:#fee2e2}.att-stat-icon.blue{color:#2563eb;background:#dbeafe}.att-stat-icon.slate{color:#475569;background:#f1f5f9}.att-stat-num{color:#0f172a;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800;line-height:1}.att-stat-label{color:#64748b;margin-top:2px;font-size:.75rem;font-weight:500}.att-calendar-card{background:#fff;border:1px solid #f1f5f9;border-radius:18px;padding:12px 14px;box-shadow:0 2px 8px #0000000a}.att-calendar-head{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.att-calendar-title{color:#0f172a;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800}.att-cal-nav{align-items:center;gap:8px;display:flex}.att-cal-nav button{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:all .2s;display:flex}.att-cal-nav button:hover{color:#f59e0b;border-color:#f59e0b}.att-cal-nav span{color:#334155;text-align:center;min-width:100px;font-size:.9rem;font-weight:700}.att-cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.att-cal-day-header{text-align:center;color:#94a3b8;text-transform:uppercase;padding:4px 0;font-size:.7rem;font-weight:700}.att-cal-day{aspect-ratio:1;cursor:default;border-radius:6px;justify-content:center;align-items:center;font-size:.78rem;font-weight:600;display:flex;position:relative}.att-cal-day.empty{background:0 0}.att-cal-day.no-data{color:#cbd5e1;background:#f8fafc}.att-cal-day.high{color:#fff;background:#16a34a}.att-cal-day.med{color:#fff;background:#f59e0b}.att-cal-day.low{color:#fff;background:#dc2626}.att-cal-day.today{outline-offset:2px;outline:2.5px solid #f59e0b}.att-cal-day.future{color:#e2e8f0;cursor:not-allowed;background:#f8fafc}.att-cal-legend{flex-wrap:wrap;align-items:center;gap:14px;margin-top:14px;display:flex}.att-leg-item{color:#64748b;align-items:center;gap:5px;font-size:.75rem;font-weight:500;display:flex}.att-leg-dot{border-radius:3px;width:12px;height:12px}.att-table-card{background:#fff;border:1px solid #f1f5f9;border-radius:18px;width:100%;min-width:0;max-width:100%;overflow:hidden;box-shadow:0 2px 8px #0000000a}.att-table-head{border-bottom:1px solid #f1f5f9;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;display:flex}.att-table-title{color:#0f172a;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.att-table-filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.att-table-search{color:#334155;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:7px 12px;font-family:Inter,sans-serif;font-size:.85rem;transition:border .2s}.att-table-search:focus{border-color:#f59e0b}.att-table-wrap{-webkit-overflow-scrolling:touch;background:#fff;width:100%;max-width:100%;padding-bottom:8px;display:block;position:relative;overflow-x:auto!important}.att-table-wrap::-webkit-scrollbar{height:6px}.att-table-wrap::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px;margin:0 12px}.att-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}table.att-table{border-collapse:collapse;table-layout:auto;width:100%;min-width:650px}table.att-table th:last-child,table.att-table td:last-child{padding-right:24px}table.att-table thead tr{background:#f8fafc}table.att-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:12px 14px;font-size:.78rem;font-weight:700}table.att-table td{border-bottom:1px solid #f8fafc;padding:12px 14px;font-size:.88rem}table.att-table tbody tr:last-child td{border-bottom:none}table.att-table tbody tr:hover td{background:#fafafa}.att-table-name{color:#1e293b;font-weight:700}.att-table-id{color:#94a3b8;font-size:.75rem}.att-pct-badge{border-radius:20px;justify-content:center;align-items:center;min-width:54px;padding:4px 10px;font-size:.82rem;font-weight:800;display:inline-flex}.att-pct-badge.high{color:#15803d;background:#dcfce7}.att-pct-badge.med{color:#854d0e;background:#fef9c3}.att-pct-badge.low{color:#991b1b;background:#fee2e2}.att-pct-badge.none{color:#94a3b8;background:#f1f5f9}.att-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.att-filter-sel{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:8px 12px;font-family:Inter,sans-serif;font-size:.85rem;transition:border .2s}.att-filter-sel:focus{border-color:#f59e0b}.att-chart-card{background:#fff;border:1px solid #f1f5f9;border-radius:18px;padding:12px 14px;box-shadow:0 2px 8px #0000000a}.att-chart-title{color:#0f172a;margin-bottom:12px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:800}.att-chart-bars{align-items:flex-end;gap:4px;height:90px;display:flex}.att-chart-col{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.att-bar-wrap{align-items:flex-end;gap:2px;width:100%;height:70px;display:flex}.att-bar{border-radius:4px 4px 0 0;flex:1;min-height:3px;transition:height .4s}.att-bar.present{background:linear-gradient(#4ade80,#16a34a)}.att-bar.absent{background:linear-gradient(#f87171,#dc2626)}.att-bar-label{color:#94a3b8;text-align:center;font-size:.7rem;font-weight:600}.att-chart-legend{gap:14px;margin-top:10px;display:flex}.att-cl-item{color:#64748b;align-items:center;gap:5px;font-size:.78rem;font-weight:500;display:flex}.att-cl-dot{border-radius:3px;width:10px;height:10px}.att-empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;display:flex}.att-empty-icon{color:#d97706;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:22px;justify-content:center;align-items:center;width:68px;height:68px;font-size:2rem;display:flex}.att-empty p{color:#94a3b8;margin:0;font-size:.95rem;font-weight:500}.att-loading{color:#94a3b8;justify-content:center;align-items:center;gap:12px;padding:60px 20px;font-weight:600;display:flex}.att-spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite att-spin}@keyframes att-spin{to{transform:rotate(360deg)}}.att-class-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.att-class-card{cursor:default;background:#fff;border:1.5px solid #f1f5f9;border-radius:16px;padding:18px 20px;transition:all .2s;box-shadow:0 2px 8px #0000000a}.att-class-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.att-class-card-header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.att-class-icon{color:#d97706;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.3rem;display:flex}.att-class-name{color:#0f172a;font-family:Outfit,sans-serif;font-size:1rem;font-weight:800}.att-class-div{color:#64748b;font-size:.78rem;font-weight:500}.att-class-stats{flex-wrap:wrap;gap:8px;display:flex}.att-class-stat{flex-direction:column;flex:1;align-items:center;min-width:60px;display:flex}.att-class-stat-num{color:#0f172a;font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:800}.att-class-stat-lbl{color:#94a3b8;text-align:center;font-size:.7rem;font-weight:600}.att-class-pct-bar{background:#f1f5f9;border-radius:3px;height:6px;margin-top:12px;overflow:hidden}.att-class-pct-fill{background:linear-gradient(90deg,#16a34a,#4ade80);border-radius:3px;height:100%;transition:width .4s}.att-class-badge{border-radius:20px;margin-left:auto;padding:3px 10px;font-size:.72rem;font-weight:700}.att-class-badge.taken{color:#15803d;background:#dcfce7}.att-class-badge.not-taken{color:#92400e;background:#fef3c7}.att-risk-section{flex-direction:column;gap:10px;display:flex}.att-risk-header{align-items:center;gap:10px;display:flex}.att-risk-icon{color:#dc2626;background:#fee2e2;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.att-risk-title{color:#0f172a;font-family:Outfit,sans-serif;font-size:1rem;font-weight:800}.att-risk-desc{color:#64748b;font-size:.82rem}.att-school-trend-chart{align-items:flex-end;gap:4px;height:180px;padding:0 4px;display:flex;overflow-x:auto}.att-trend-col{flex-direction:column;flex:1;align-items:center;gap:4px;min-width:32px;display:flex}.att-trend-bar-wrap{flex-direction:column;justify-content:flex-end;align-items:center;width:100%;height:145px;display:flex;position:relative}.att-trend-pct-label{color:#64748b;font-size:.6rem;font-weight:700;position:absolute;top:-16px}.att-trend-bars{align-items:flex-end;gap:1px;width:100%;height:100%;display:flex}.att-trend-label{color:#94a3b8;text-align:center;font-size:.62rem;font-weight:600}.att-class-mini-bars{align-items:flex-end;gap:3px;height:36px;margin:10px 0 6px;padding:0 2px;display:flex}.att-class-mini-bar{border-radius:2px 2px 0 0;flex:1;min-height:4%;transition:height .3s}.att-daylog-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-wrap:wrap;align-items:center;gap:14px;padding:12px 16px;display:flex}.att-daylog-card{background:#fff;border:1.5px solid #f1f5f9;border-radius:16px;transition:border-color .15s;overflow:hidden;box-shadow:0 2px 8px #0000000a}.att-daylog-card:hover{border-color:#e2e8f0}.att-daylog-card-header{cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:14px 16px;transition:background .15s;display:flex}.att-daylog-card-header:hover{background:#fafafa}.att-daylog-chips{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.att-daylog-chevron{align-items:center;display:flex}.att-daylog-modal-overlay{z-index:1000;background:#0f172a99;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.att-daylog-modal{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 10px 40px #00000026}.att-daylog-modal-header{background:#f8fafc;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.att-daylog-modal-close{color:#dc2626;cursor:pointer;background:#fee2e2;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.4rem;transition:all .2s;display:flex}.att-daylog-modal-close:hover{color:#991b1b;background:#fecaca}.att-daylog-modal-body{flex-direction:column;flex:1;display:flex;overflow-y:auto}.att-daylog-detail-summary{background:#f8fafc;border-bottom:1px solid #f1f5f9;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:14px;padding:12px 20px;display:flex}.att-daylog-students{flex-direction:column;flex:1;gap:0;display:flex;overflow-y:auto}.att-daylog-stu-row{border-bottom:1px solid #f8fafc;align-items:center;gap:10px;padding:9px 16px;transition:background .12s;display:flex}.att-daylog-stu-row:last-child{border-bottom:none}.att-daylog-stu-row:hover{background:#fafafa}.att-daylog-stu-row.present{background:#f0fdf480}.att-daylog-stu-row.absent{background:#fef2f280}.att-daylog-status-badge{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:.75rem;font-weight:700}.att-daylog-status-badge.present{color:#15803d;background:#dcfce7}.att-daylog-status-badge.absent{color:#991b1b;background:#fee2e2}.att-risk-cards{flex-direction:column;gap:10px;display:flex}.att-risk-card{background:#fff;border:1.5px solid #f1f5f9;border-radius:14px;align-items:center;gap:14px;padding:14px 16px;display:flex;box-shadow:0 2px 8px #0000000a}@media (width<=900px){.att-class-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.att-module{gap:12px}.att-tabs{scrollbar-width:none;width:100%;overflow-x:auto}.att-tabs::-webkit-scrollbar{display:none}.att-tab{white-space:nowrap;flex-shrink:0;padding:8px 12px;font-size:.82rem}.att-stat-grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px}.att-stat-card{border-radius:12px;gap:8px;padding:8px 10px}.att-stat-num{font-size:1.15rem}.att-stat-label{font-size:.62rem}.att-filters{flex-direction:column;align-items:stretch;gap:8px}.att-filter-sel{width:100%;font-size:.85rem}.att-submit-bar{flex-direction:column;align-items:stretch;gap:10px;padding:12px}.att-submit-btn{justify-content:center;width:100%}.att-header{flex-direction:column;align-items:flex-start;gap:8px}.att-quick-actions{flex-wrap:wrap}.att-date-row{flex-wrap:wrap;gap:8px;padding:10px 12px}.att-student-row{gap:8px;padding:8px 10px}.att-action-btn{width:32px;height:32px;font-size:.85rem}.att-chart-card{padding:8px}.att-chart-title{margin-bottom:8px;font-size:.82rem}.att-chart-bars{gap:2px;height:75px}.att-bar-wrap{height:55px}.att-bar-label{font-size:.55rem}.att-calendar-card{padding:8px}.att-calendar-head{margin-bottom:8px}.att-calendar-title{font-size:.82rem}.att-cal-grid{gap:2px}.att-cal-day{border-radius:2px;font-size:.58rem}.att-cal-day-header{font-size:.52rem}.att-cal-legend{gap:4px;margin-top:8px}.att-table-card{border-radius:12px;width:100%;min-width:0;overflow:hidden}.att-table-head{flex-direction:column;align-items:stretch;gap:10px;padding:14px 16px}.att-table-search{box-sizing:border-box;width:100%;padding:10px 14px;font-size:.88rem}table.att-table th,table.att-table td{white-space:nowrap;padding:12px 14px;font-size:.82rem}.att-module{width:100%}.att-class-grid{grid-template-columns:1fr}.att-school-trend-chart{gap:2px;height:160px}.att-trend-bar-wrap{height:130px}.att-trend-pct-label{font-size:.55rem;top:-14px}.att-trend-label{font-size:.52rem}.att-daylog-card-header{gap:8px;padding:10px}.att-daylog-chips{gap:4px}.att-daylog-status-badge{padding:2px 6px;font-size:.68rem}.att-risk-card{gap:8px;padding:10px}.att-daylog-modal-overlay{align-items:flex-start;padding:0}.att-daylog-modal{width:100%;max-width:100%;height:100%;max-height:100%;padding-bottom:env(safe-area-inset-bottom);border-radius:0}.att-daylog-modal-header{padding:12px 14px}.att-daylog-modal-close{width:40px;height:40px;font-size:1.6rem}.att-daylog-detail-summary{padding:8px 14px}}@media (width<=400px){.att-stat-grid{grid-template-columns:1fr}.att-trend-pct-label{display:none}.att-chart-bars{height:65px}.att-calendar-card{padding:6px}}.hl-root{flex-direction:column;gap:20px;min-height:calc(100vh - 130px);font-family:Inter,sans-serif;display:flex}.hl-header{background:linear-gradient(135deg, var(--slate-800) 0%, #1a2540 60%, #243050 100%);border-radius:18px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:22px 28px;display:flex;position:relative;overflow:hidden}.hl-header:before{content:"";pointer-events:none;background:#ffd4601a;border-radius:50%;width:180px;height:180px;position:absolute;top:-40px;right:-40px}.hl-header-left{z-index:1;align-items:center;gap:14px;display:flex;position:relative}.hl-header-icon{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:46px;height:46px;color:var(--slate-900);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;display:flex;box-shadow:0 4px 14px #f59e0b66}.hl-header-title{color:#fff;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800}.hl-header-sub{color:#ffffff80;margin-top:2px;font-size:.78rem}.hl-legend{z-index:1;flex-wrap:wrap;gap:10px;display:flex;position:relative}.hl-legend-item{color:#fff9;background:#ffffff14;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.73rem;display:flex}.hl-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hl-body{flex:1;grid-template-columns:1fr 290px;align-items:start;gap:18px;display:grid}@media (width<=960px){.hl-body{grid-template-columns:1fr}}.hl-calendar-panel{border:1px solid var(--slate-200);background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 20px #0000000d}.hl-month-nav{border-bottom:1px solid var(--slate-100);background:var(--cream-50);justify-content:space-between;align-items:center;padding:16px 22px;display:flex}.hl-nav-btn{border:1.5px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#fff;border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.1rem;transition:all .18s;display:flex;box-shadow:0 1px 4px #0000000f}.hl-nav-btn:hover{background:linear-gradient(135deg, var(--cream-400), var(--amber-500));border-color:var(--amber-500);color:var(--slate-900);box-shadow:0 4px 12px #f59e0b4d}.hl-month-label{align-items:center;gap:8px;display:flex}.hl-month-name{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800}.hl-year-trigger{color:var(--amber-700);background:linear-gradient(135deg, var(--cream-100), var(--cream-200));cursor:pointer;border:1.5px solid #f59e0b40;border-radius:8px;align-items:center;gap:3px;padding:3px 8px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;transition:all .18s;display:inline-flex}.hl-year-trigger:hover{background:linear-gradient(135deg, var(--cream-200), var(--cream-300));border-color:var(--amber-400);box-shadow:0 3px 8px #f59e0b33}.hl-year-chevron{font-size:.75rem;transition:transform .18s}.hl-year-trigger:hover .hl-year-chevron{transform:rotate(180deg)}.hl-year-backdrop{z-index:1300;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a59;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.hl-year-picker{border:1px solid var(--slate-200);background:#fff;border-radius:18px;width:340px;max-width:95vw;overflow:hidden;box-shadow:0 20px 60px #00000026}.hl-year-title{color:var(--slate-700);border-bottom:1px solid var(--slate-100);background:var(--cream-50);text-align:center;letter-spacing:.3px;padding:14px 18px 10px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:800}.hl-year-grid{grid-template-columns:repeat(4,1fr);gap:4px;max-height:260px;padding:12px;display:grid;overflow-y:auto}.hl-year-btn{background:var(--slate-50);color:var(--slate-700);cursor:pointer;text-align:center;border:1.5px solid #0000;border-radius:10px;padding:9px 4px;font-size:.88rem;font-weight:600;transition:all .15s}.hl-year-btn:hover{background:var(--cream-100);border-color:var(--amber-300);color:var(--amber-700)}.hl-year-btn.current{color:var(--amber-600);font-weight:700}.hl-year-btn.active{background:linear-gradient(135deg, var(--cream-400), var(--amber-500));border-color:var(--amber-500);color:var(--slate-900);font-weight:800;box-shadow:0 3px 10px #f59e0b59}.hl-year-grid::-webkit-scrollbar{width:4px}.hl-year-grid::-webkit-scrollbar-thumb{background:var(--cream-400);border-radius:4px}.hl-cal-grid-wrapper{width:100%;overflow-x:auto}.hl-cal-grid-wrapper::-webkit-scrollbar{height:6px}.hl-cal-grid-wrapper::-webkit-scrollbar-thumb{background:var(--cream-300);border-radius:6px}.hl-cal-grid{grid-template-columns:repeat(7,minmax(0,1fr));width:100%;display:grid}.hl-day-header{text-align:center;letter-spacing:.5px;text-transform:uppercase;color:var(--slate-400);border-bottom:1.5px solid var(--slate-100);background:var(--slate-50);padding:10px 4px;font-size:.72rem;font-weight:700}.hl-day-header.sunday{color:#dc2626}.hl-cal-cell{border-right:1px solid var(--slate-100);border-bottom:1px solid var(--slate-100);cursor:pointer;flex-direction:column;gap:3px;min-width:0;min-height:90px;padding:7px 4px 4px;transition:background .14s;display:flex;position:relative;overflow:hidden}.hl-cal-cell:nth-child(7n){border-right:none}.hl-cal-cell.empty{cursor:default;background:var(--slate-50)}.hl-cal-cell:not(.empty):hover{background:var(--cream-50)}.hl-cal-cell.sunday{background:#fff5f5}.hl-cal-cell.sunday:hover{background:#fee2e2}.hl-cal-cell.today{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.hl-cal-cell.today:hover{background:linear-gradient(135deg,#fef3c7,#fde68a)}.hl-cal-cell.selected{box-shadow:inset 0 0 0 2px var(--amber-400);background:linear-gradient(135deg,#fffbeb,#fef3c7)!important}.hl-cell-num{color:var(--slate-700);padding:1px 3px;font-size:.82rem;font-weight:700;line-height:1}.hl-cal-cell.sunday .hl-cell-num{color:#dc2626}.hl-cal-cell.today .hl-cell-num{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));color:var(--slate-900);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.78rem;font-weight:800;display:flex;box-shadow:0 2px 8px #f59e0b59}.hl-cell-sun-label{color:#ef4444;opacity:.7;letter-spacing:.3px;padding:0 3px;font-size:.6rem;font-weight:700}.hl-cell-events{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex;overflow:hidden}.hl-event-chip{white-space:nowrap;text-overflow:ellipsis;border-radius:4px;min-width:0;max-width:100%;padding:2px 5px;font-size:.64rem;font-weight:600;display:block;overflow:hidden}.hl-event-more{color:var(--slate-400);padding:0 3px;font-size:.6rem}.hl-cell-add-btn{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:20px;height:20px;color:var(--slate-900);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;transition:transform .15s;display:none;position:absolute;bottom:4px;right:4px;box-shadow:0 2px 6px #f59e0b66}.hl-cal-cell:not(.empty):hover .hl-cell-add-btn{display:flex}.hl-cell-add-btn:hover{transform:scale(1.12)}.hl-right-panel{flex-direction:column;gap:14px;min-width:0;display:flex;position:sticky;top:80px}.hl-day-panel,.hl-month-panel{border:1px solid var(--slate-200);background:#fff;border-radius:16px;min-width:0;overflow:hidden;box-shadow:0 4px 16px #0000000d}.hl-day-panel-head{border-bottom:1px solid var(--slate-100);background:var(--cream-50);justify-content:space-between;align-items:flex-start;gap:10px;padding:15px 16px 12px;display:flex}.hl-day-panel-date{color:var(--slate-800);font-size:.82rem;font-weight:700}.hl-day-panel-count{color:var(--slate-400);margin-top:2px;font-size:.72rem}.hl-add-event-btn{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));color:var(--slate-900);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:700;transition:all .18s;display:flex;box-shadow:0 3px 10px #f59e0b4d}.hl-add-event-btn:hover{transform:translateY(-1px);box-shadow:0 5px 16px #f59e0b73}.hl-day-empty{color:var(--slate-400);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:32px 16px;font-size:.82rem;display:flex}.hl-add-first-btn{border:1.5px dashed var(--amber-400);background:var(--cream-50);color:var(--amber-600);cursor:pointer;border-radius:9px;align-items:center;gap:5px;margin-top:12px;padding:8px 16px;font-size:.78rem;font-weight:700;transition:all .15s;display:flex}.hl-add-first-btn:hover{background:var(--cream-100)}.hl-day-event-list{flex-direction:column;gap:10px;padding:10px 12px;display:flex}.hl-day-event-card{background:var(--slate-50);border:1px solid var(--slate-100);border-radius:10px;padding:10px 12px;transition:box-shadow .15s}.hl-day-event-card:hover{box-shadow:0 4px 12px #00000012}.hl-dce-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.hl-dce-type-badge{text-transform:uppercase;letter-spacing:.4px;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:.67rem;font-weight:700;display:flex}.hl-dce-actions{gap:4px;display:flex}.hl-dce-actions button{border:1px solid var(--slate-200);width:26px;height:26px;color:var(--slate-500);cursor:pointer;background:#fff;border-radius:7px;justify-content:center;align-items:center;font-size:.82rem;transition:all .15s;display:flex}.hl-dce-actions button:hover{background:var(--slate-100);color:var(--slate-800)}.hl-dce-actions button.danger:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.hl-dce-title{color:var(--slate-800);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;font-size:.88rem;font-weight:700}.hl-dce-desc{color:var(--slate-500);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;margin-top:4px;font-size:.75rem;line-height:1.5}.hl-month-panel-head{border-bottom:1px solid var(--slate-100);background:var(--cream-50);justify-content:space-between;align-items:center;padding:15px 16px 12px;display:flex}.hl-month-panel-title{color:var(--slate-800);font-size:.88rem;font-weight:700}.hl-month-panel-count{background:linear-gradient(135deg, var(--cream-200), var(--cream-300));color:var(--amber-700);border:1px solid #f59e0b33;border-radius:20px;padding:2px 10px;font-size:.72rem;font-weight:800}.hl-month-empty{color:var(--slate-400);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:36px 16px;font-size:.82rem;display:flex}.hl-month-event-list{flex-direction:column;gap:6px;max-height:420px;padding:8px 10px;display:flex;overflow-y:auto}.hl-month-event-row{background:var(--slate-50);border:1px solid var(--slate-100);cursor:pointer;border-radius:10px;align-items:center;gap:10px;min-width:0;padding:9px 10px;transition:all .15s;display:flex}.hl-month-event-row:hover{background:var(--cream-50);border-color:var(--cream-300);box-shadow:0 3px 10px #0000000d}.hl-mer-date{text-align:center;min-width:30px}.hl-mer-day{color:var(--slate-800);font-size:1rem;font-weight:800;line-height:1}.hl-mer-wday{color:var(--slate-400);text-transform:uppercase;font-size:.6rem}.hl-mer-info{flex:1;min-width:0;overflow:hidden}.hl-mer-title{color:var(--slate-700);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:.82rem;font-weight:600;overflow:hidden}.hl-mer-type{text-transform:uppercase;letter-spacing:.3px;margin-top:2px;font-size:.67rem;font-weight:700}.hl-mer-actions{gap:3px;display:flex}.hl-mer-actions button{border:1px solid var(--slate-200);width:24px;height:24px;color:var(--slate-400);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:.78rem;transition:all .15s;display:flex}.hl-mer-actions button:hover{background:var(--slate-100);color:var(--slate-700)}.hl-mer-actions button.danger:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.hl-fab{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:50px;height:50px;color:var(--slate-900);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-self:flex-end;align-items:center;font-size:1.4rem;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 4px 18px #f59e0b73}.hl-fab:hover{transform:scale(1.1);box-shadow:0 6px 26px #f59e0b99}@media (width<=960px){.hl-fab{display:none}}.hl-fab-fixed{z-index:900;background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:54px;height:54px;color:var(--slate-900);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;transition:transform .18s,box-shadow .18s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 6px 24px #f59e0b8c}.hl-fab-fixed:hover{transform:scale(1.1);box-shadow:0 8px 30px #f59e0bb3}@media (width>=961px){.hl-fab-fixed{display:none}}.hl-loading{color:var(--slate-400);flex-direction:column;align-items:center;gap:10px;padding:32px;font-size:.82rem;display:flex}.hl-spinner{border:3px solid var(--slate-200);border-top-color:var(--amber-500);border-radius:50%;width:26px;height:26px;animation:.7s linear infinite hl-spin}@keyframes hl-spin{to{transform:rotate(360deg)}}.hl-modal-backdrop{z-index:9999;background:#0f172a99;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.hl-modal{border:1px solid var(--slate-200);background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0000002e}.hl-modal-head{border-bottom:1px solid var(--slate-100);background:var(--cream-50);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.hl-modal-title{color:var(--slate-800);align-items:center;gap:10px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:800;display:flex}.hl-modal-date-badge{background:linear-gradient(135deg, var(--cream-200), var(--cream-300));color:var(--amber-700);border:1px solid #f59e0b33;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600}.hl-modal-close{background:var(--slate-100);border:1px solid var(--slate-200);color:#ef4444;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:1.1rem;transition:all .15s;display:flex}.hl-modal-close:hover{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.hl-modal-form{flex-direction:column;gap:8px;padding:16px 20px;display:flex}.hl-label{color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:.73rem;font-weight:700}.hl-input{background:var(--slate-50);border:1.5px solid var(--slate-200);width:100%;color:var(--slate-800);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border .15s,box-shadow .15s}.hl-input:focus{border-color:var(--amber-400);background:#fff;box-shadow:0 0 0 3px #ffd46033}.hl-textarea{resize:vertical;min-height:60px}.hl-type-grid{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.hl-type-btn{border:1.5px solid var(--slate-200);background:var(--slate-50);color:var(--slate-600);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:600;transition:all .15s;display:flex}.hl-type-btn:hover{background:var(--cream-50);border-color:var(--amber-300)}.hl-type-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.hl-color-grid{flex-wrap:wrap;gap:7px;margin-top:4px;display:flex}.hl-color-btn{cursor:pointer;border:2.5px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .15s,border-color .15s;display:flex}.hl-color-btn:hover{transform:scale(1.15)}.hl-color-btn.active{border-color:var(--slate-800);transform:scale(1.15)}.hl-color-custom-wrap{border:2px dashed var(--slate-300);cursor:pointer;border-radius:50%;width:28px;height:28px;position:relative;overflow:hidden}.hl-color-custom{cursor:pointer;border:none;width:200%;height:200%;margin:-50%;padding:0}.hl-preview-strip{border:1px solid #0000;border-radius:9px;justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:10px 14px;font-size:.88rem;font-weight:600;display:flex}.hl-preview-strip span:first-child{word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;min-width:0}.hl-preview-type{text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:3px 8px;font-size:.68rem;font-weight:700}.hl-modal-footer{border-top:1px solid var(--slate-100);justify-content:flex-end;gap:10px;margin-top:8px;padding-top:12px;display:flex}.hl-modal-footer.center{justify-content:center}.hl-btn-cancel{border:1.5px solid var(--slate-200);background:var(--slate-50);color:var(--slate-600);cursor:pointer;border-radius:10px;padding:9px 18px;font-size:.85rem;font-weight:600;transition:all .15s}.hl-btn-cancel:hover{background:var(--slate-100);color:var(--slate-800)}.hl-btn-save{color:#fff;cursor:pointer;border:none;border-radius:10px;padding:9px 22px;font-size:.85rem;font-weight:700;transition:filter .15s,opacity .15s,transform .15s;box-shadow:0 3px 10px #00000026}.hl-btn-save:hover{filter:brightness(1.06);transform:translateY(-1px)}.hl-btn-save:disabled{opacity:.55;cursor:not-allowed;transform:none}.hl-confirm{text-align:center;flex-direction:column;align-items:center;gap:8px;max-width:340px;padding:28px 24px;display:flex}.hl-confirm-icon{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.5rem;display:flex}.hl-confirm-title{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.hl-confirm-desc{color:var(--slate-400);font-size:.82rem}.hl-btn-delete{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:10px;padding:9px 22px;font-size:.85rem;font-weight:700;transition:background .15s,transform .15s}.hl-btn-delete:hover{background:#dc2626;transform:translateY(-1px)}.hl-month-event-list::-webkit-scrollbar{width:5px}.hl-month-event-list::-webkit-scrollbar-track{background:0 0}.hl-month-event-list::-webkit-scrollbar-thumb{background:var(--cream-400);border-radius:20px}.hl-month-event-list::-webkit-scrollbar-thumb:hover{background:var(--cream-500)}.hl-export-btn{color:#0f172a;cursor:pointer;background:linear-gradient(135deg,#facc15 0%,#f59e0b 100%);border:none;border-radius:100px;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.hl-export-btn:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 10px 15px -3px #f59e0b4d,0 4px 6px -2px #0000000d}.hl-export-btn:active{transform:translateY(0)}.hl-export-btn svg{font-size:1rem}.tt-overlay{z-index:3000;overscroll-behavior:contain;will-change:opacity;background:#0f172aa6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.tt-overlay.is-selecting{touch-action:none}.tt-modal{will-change:transform, opacity;background:#fffdf7;border-radius:20px;flex-direction:column;width:100%;max-width:1200px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 24px 60px #0000002e}.tt-header{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #f59e0b33;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.tt-header-left{flex-direction:column;display:flex}.tt-title{color:#1e293b;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:700}.tt-subtitle{color:#64748b;margin-top:2px;font-size:.85rem}.tt-close-btn{color:#475569;cursor:pointer;background:#0000000f;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;transition:all .2s;display:flex}.tt-close-btn:hover{color:#ef4444;background:#0000001f}.tt-toolbar{background:#ffffffd9;border-bottom:1px solid #0000000f;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:12px 20px;display:flex}.tt-toolbar-group{border-right:1px solid #00000012;align-items:center;gap:8px;padding-right:16px;display:flex}.tt-toolbar-group:last-of-type{border-right:none}.tt-tool-btn{color:#334155;cursor:pointer;background:#ffffffe6;border:1px solid #0000001a;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;font-size:.82rem;font-weight:600;transition:all .18s;display:inline-flex}.tt-tool-btn:hover:not(:disabled){background:#f1f5f9;border-color:#00000026}.tt-tool-btn:disabled{opacity:.38;cursor:not-allowed}.tt-tool-btn.primary{color:#1e293b;background:linear-gradient(135deg,#fde68a,#f59e0b);border-color:#0000;box-shadow:0 2px 8px #f59e0b40}.tt-tool-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b59}.tt-tool-label{color:#94a3b8;white-space:nowrap;font-size:.78rem;font-weight:600}.tt-color-group{align-items:center;gap:6px;display:flex}.tt-color-swatch{cursor:pointer;border:1.5px solid #0000001f;border-radius:6px;flex-shrink:0;width:22px;height:22px;transition:transform .15s}.tt-color-swatch:hover{border-color:#f59e0b;transform:scale(1.2)}.tt-color-swatch.clear{color:#94a3b8;background:#f1f5f9;justify-content:center;align-items:center;font-size:.75rem;display:flex}.tt-main-container{background:#fff;flex-direction:column;flex:1;display:flex;overflow:hidden}.tt-left-panel{border-right:none;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.tt-loading{text-align:center;color:#94a3b8;flex:1;justify-content:center;align-items:center;padding:60px;font-size:.9rem;font-weight:500;display:flex}.tt-desktop-grid-view{flex-direction:column;flex:1;width:100%;display:flex}.tt-table{border-collapse:collapse;table-layout:fixed;-webkit-user-select:none;user-select:none;width:100%;min-width:100%;height:100%}.tt-th{z-index:10;color:#475569;text-transform:uppercase;letter-spacing:.4px;text-align:center;-webkit-user-select:none;user-select:none;background:#fef9ec;border-bottom:2px solid #f59e0b4d;border-right:1px solid #0000000f;padding:12px 10px;font-size:.78rem;font-weight:700;position:sticky;top:0}.tt-th-time{text-align:center;background:#fdf6e3;width:140px;padding-left:0}.tt-th-del{background:#fef9ec;border-right:none}.tt-row:hover .tt-del-row-btn{opacity:1}.tt-time-cell{vertical-align:middle;text-align:center;-webkit-user-select:none;user-select:none;background:#fffbf0;border-bottom:1px solid #0000000d;border-right:2px solid #f59e0b40;width:140px;padding:8px 12px}.tt-slot-label{color:#92400e;cursor:default;justify-content:center;align-items:center;gap:8px;font-size:.8rem;font-weight:600;line-height:1.4;display:flex}.tt-slot-edit-icon{color:#d97706;opacity:0;flex-shrink:0;font-size:.7rem;transition:opacity .2s}.tt-time-cell:hover .tt-slot-edit-icon{opacity:1}.tt-slot-input{color:#92400e;resize:none;text-align:center;background:#fff;border:1.5px solid #f59e0b;border-radius:6px;outline:none;width:100%;padding:6px 8px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;line-height:1.4}.tt-cell{cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000000f;height:56px;padding:0;transition:all .12s;position:relative}.tt-cell:hover{background:#f59e0b0a}.tt-cell.selected{outline-offset:-2px;outline:2px solid #f59e0b8c;background:#f59e0b1f!important}.tt-cell.active-detail{outline-offset:-2.5px;outline:2.5px solid #f59e0b;background:#f59e0b14!important}.tt-cell.merged{border:2px solid #f59e0b59}.tt-cell-content{color:#334155;white-space:pre-wrap;word-break:break-word;padding:8px 10px;font-size:.82rem;font-weight:500;line-height:1.5}.tt-cell-placeholder{color:#cbd5e1;font-size:.72rem;font-style:italic;line-height:1.4}.tt-cell-input{resize:none;color:#1e293b;outline-offset:-2px;background:#fffbebf2;border:none;border-radius:0;outline:2px solid #f59e0b;width:100%;height:100%;min-height:72px;padding:8px 10px;font-family:Inter,sans-serif;font-size:.82rem;line-height:1.5}.tt-del-cell{text-align:center;vertical-align:middle;border-bottom:1px solid #0000000d;width:36px;padding:0}.tt-del-row-btn{color:#ef4444;cursor:pointer;opacity:1;background:#ef444414;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;margin:auto;font-size:.85rem;transition:all .2s;display:flex}.tt-del-row-btn:hover{background:#ef44442e}.tt-mobile-day-selector{scrollbar-width:none;background:#fafafa;border-bottom:1px solid #f0f0f0;flex-shrink:0;gap:8px;padding:12px 16px;display:none;overflow-x:auto}.tt-mobile-day-selector::-webkit-scrollbar{display:none}.tt-day-pill{color:#475569;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:6px 16px;font-size:.8rem;font-weight:600;transition:all .15s}.tt-day-pill:hover{border-color:#cbd5e1}.tt-day-pill.active{color:#fff;background:#f59e0b;border-color:#f59e0b;box-shadow:0 2px 6px #f59e0b40}.tt-mobile-timeline-view{flex-direction:column;gap:12px;padding:16px;display:none;overflow-y:auto}.tt-mobile-slot-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;transition:all .2s;display:flex;box-shadow:0 2px 4px #00000005}.tt-mobile-slot-card:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000000d}.tt-mobile-slot-card.active-detail{outline-offset:-1.5px;background:#fffbeb;outline:2.5px solid #f59e0b}.tt-mobile-slot-time{color:#d97706;text-transform:uppercase;align-items:center;gap:6px;font-size:.72rem;font-weight:700;display:flex}.tt-mobile-slot-body{color:#1e293b;font-size:.88rem;font-weight:600}.tt-mobile-slot-placeholder{color:#94a3b8;font-style:italic;font-weight:400}.tt-right-panel{background:#fffdf9;flex-direction:column;flex-shrink:0;display:flex;border-top:1px solid #f59e0b26!important;border-left:none!important;width:100%!important;height:120px!important;padding:10px 24px!important;overflow:hidden!important}.tt-details-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;gap:20px;display:flex;box-shadow:0 4px 15px #00000005;height:100%!important;min-height:unset!important;flex-direction:row!important;padding:8px 16px!important}.tt-details-header{flex-direction:column;flex-shrink:0;justify-content:center;align-items:flex-start;gap:4px;display:flex;border-bottom:none!important;margin-bottom:0!important;padding-bottom:0!important}.tt-details-header h3{color:#1e293b;margin:0;font-family:Outfit,sans-serif;font-size:.92rem;font-weight:700}.tt-details-badge{color:#b45309;background:#fef3c7;border-radius:10px;padding:2px 6px;font-size:.65rem;font-weight:600}.tt-details-empty{color:#94a3b8;flex:1;justify-content:center;align-items:center;gap:12px;margin:0;display:flex;flex-direction:row!important;padding:0!important}.tt-details-empty-icon{color:#cbd5e1;opacity:.8;margin-bottom:0!important;font-size:1.6rem!important}.tt-details-empty p{color:#64748b;font-weight:600;margin:0!important;font-size:.8rem!important}.tt-details-empty-sub{color:#94a3b8;font-size:.72rem}.tt-details-content{flex:1;align-items:center;gap:20px;display:flex;flex-direction:row!important}.tt-details-meta-row{flex-shrink:0;flex-direction:row!important;gap:10px!important;display:flex!important}.tt-meta-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:6px;align-items:center;gap:6px;display:flex;flex-direction:row!important;padding:6px 10px!important}.tt-meta-label{color:#94a3b8;text-transform:uppercase;font-size:.62rem;font-weight:700}.tt-meta-val{color:#334155;font-size:.78rem;font-weight:700}.tt-details-body-card{border-radius:8px;flex:1;justify-content:space-between;align-items:center;gap:12px;display:flex;flex-direction:row!important;margin:0!important;padding:8px 16px!important}.tt-details-body-title{color:#d97706;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;font-size:.62rem;font-weight:700}.tt-details-body-text{color:#1e293b;text-align:right;white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-size:.82rem;font-weight:600;overflow:hidden}.tt-details-status-bar{color:#94a3b8;border-top:1px solid #f1f5f9;align-items:center;gap:8px;margin-top:auto;padding-top:12px;font-size:.72rem;font-weight:600;display:flex}.tt-status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.tt-footer{background:#ffffffe6;border-top:1px solid #0000000f;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:14px 24px;display:flex}.tt-hint{color:#94a3b8;font-size:.78rem;line-height:1.5}.tt-footer-actions{flex-shrink:0;gap:10px;display:flex}.tt-download-btn{color:#334155;cursor:pointer;background:#f1f5f9;border:1px solid #0000001a;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.tt-download-btn:hover{background:#e2e8f0;border-color:#00000026;transform:translateY(-1px)}.tt-save-btn{color:#1e293b;cursor:pointer;background:linear-gradient(135deg,#fde68a,#f59e0b);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 24px;font-size:.9rem;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #f59e0b4d}.tt-save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f59e0b66}@media (width<=768px){.tt-overlay{align-items:flex-end;padding:0}.tt-modal{border-radius:0;height:100%;max-height:100vh}.tt-header{padding:16px 18px}.tt-title{font-size:1.1rem}.tt-toolbar{flex-wrap:wrap;gap:10px 8px;padding:10px 12px}.tt-tool-label{display:none}.tt-color-group{flex-wrap:wrap}.tt-toolbar-group{flex-shrink:0;padding-right:10px}.tt-main-container{flex-direction:column;overflow-y:auto}.tt-left-panel{flex:unset;border-right:none;overflow:visible}.tt-desktop-grid-view{display:none}.tt-mobile-day-selector,.tt-mobile-timeline-view{display:flex}.tt-right-panel{flex:unset!important;background:#fff!important;border-top:1px solid #0000000f!important;border-left:none!important;width:100%!important;height:auto!important;padding:16px!important;overflow:visible!important}.tt-details-card{flex-direction:column!important;gap:12px!important;height:auto!important;min-height:auto!important;padding:16px!important}.tt-details-content{flex-direction:column!important;gap:12px!important}.tt-details-meta-row{grid-template-columns:1fr 1fr!important;gap:10px!important;width:100%!important;display:grid!important}.tt-meta-item{flex-direction:column!important;align-items:flex-start!important;padding:10px 12px!important}.tt-details-body-card{flex-direction:column!important;align-items:flex-start!important;width:100%!important;padding:16px!important}.tt-details-body-text{text-align:left!important;white-space:pre-wrap!important;overflow:visible!important}.tt-footer{flex-direction:column;align-items:flex-start;gap:10px;padding:12px 16px}.tt-hint{color:#94a3b8;font-size:.72rem}.tt-download-btn,.tt-save-btn{justify-content:center;width:100%}}.tt-cell.is-copied{position:relative}.tt-cell.is-copied:after{content:"";pointer-events:none;z-index:10;border:2px dashed #10b981;animation:1.2s ease-in-out infinite tt-copied-pulse;position:absolute;inset:0}@keyframes tt-copied-pulse{0%,to{opacity:.5}50%{opacity:1}}.tt-cell-input,.tt-slot-input,textarea,input{-webkit-user-select:text!important;user-select:text!important}@media (width<=991px){.is-school-dashboard .tt-desktop-grid-view{display:block!important}.is-school-dashboard .tt-mobile-day-selector,.is-school-dashboard .tt-mobile-timeline-view{display:none!important}.is-school-dashboard .tt-main-container{flex-direction:column!important;flex:1!important;overflow:hidden!important}.is-school-dashboard .tt-left-panel{-webkit-overflow-scrolling:touch;flex:1!important;width:100%!important;height:60vh!important;min-height:450px!important;display:block!important;overflow:auto!important}.is-school-dashboard .tt-table{min-width:800px!important}.is-school-dashboard .tt-modal{height:100%!important;max-height:100vh!important}}:root{--td-yellow:#f59e0b;--td-yellow-light:#fef3c7;--td-cream:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);--td-border:#ffe48a66;--td-slate:#1e293b;--td-gray:#64748b}.tdash-layout{background:#f8fafc;min-height:100vh;font-family:Inter,sans-serif;display:flex}.tdash-overlay{z-index:40;background:#00000073;display:none;position:fixed;inset:0}.tdash-overlay.open{display:block}.tdash-sidebar{z-index:50;background:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);border-right:1px solid #ffe48a66;flex-direction:column;width:250px;min-height:100vh;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #f59e0b14}.tdash-sidebar.collapsed{transform:translate(-100%)}.tdash-sidebar-logo{border-bottom:1px solid #ffe48a59;align-items:center;gap:10px;min-height:64px;padding:20px 16px 16px;display:flex}.tdash-sidebar-logo-img{border-radius:8px;flex-shrink:0;width:32px;height:32px;box-shadow:0 2px 8px #f59e0b33}.tdash-brand-name{color:#1e293b;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.tdash-brand-sub{color:#d97706;text-transform:uppercase;letter-spacing:.6px;font-size:.68rem}.tdash-teacher-chip{background:#ffd4601f;border:1px solid #ffd46040;border-radius:12px;align-items:center;gap:10px;margin:12px 12px 4px;padding:10px 12px;display:flex}.tdash-teacher-avatar{color:#1e293b;background:linear-gradient(135deg,#fcd34d,#f59e0b);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9rem;font-weight:800;display:flex}.tdash-teacher-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;font-weight:700;overflow:hidden}.tdash-teacher-role-badge{border-radius:999px;margin-top:2px;padding:2px 8px;font-size:.66rem;font-weight:600;display:inline-block}.tdash-teacher-role-badge.class-teacher{color:#d97706;background:#fef3c7}.tdash-teacher-role-badge.subject-teacher{color:#7c3aed;background:#ede9fe}.tdash-nav{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex;overflow-y:auto}.tdash-nav-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:.84rem;font-weight:500;transition:all .18s;display:flex}.tdash-nav-item:hover{color:#334155;background:#f59e0b14;border-color:#ffd46033}.tdash-nav-item.active{color:#d97706;background:linear-gradient(135deg,#ffd46033,#f59e0b1f);border-color:#ffd4604d;font-weight:700;box-shadow:0 2px 8px #f59e0b14}.tdash-nav-icon{flex-shrink:0;font-size:1.15rem}.tdash-nav-label{white-space:nowrap;overflow:hidden}.tdash-sidebar-footer{border-top:1px solid #ffe48a59;padding:12px 8px}.tdash-logout-btn{color:#dc2626;cursor:pointer;background:#ef444412;border:1px solid #ef444426;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:.84rem;font-weight:600;transition:all .18s;display:flex}.tdash-logout-btn:hover{color:#b91c1c;background:#ef444421}.tdash-toggle-btn{cursor:pointer;color:#1e293b;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:none;border-radius:8px;align-items:center;padding:6px 8px;font-size:.9rem;transition:all .18s;display:flex;box-shadow:0 2px 8px #f59e0b40}.tdash-toggle-btn:hover{transform:scale(1.07)}.tdash-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:250px;transition:margin-left .28s;display:flex}.tdash-main.collapsed{margin-left:0}.tdash-topbar{z-index:20;background:#fffdf7fa;border-bottom:1px solid #ffe48a4d;justify-content:space-between;align-items:center;gap:12px;height:62px;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #f59e0b0f}.tdash-topbar-left{flex:1;align-items:center;gap:14px;min-width:0;display:flex}.tdash-topbar-logo-wrap{background:#fff;border:1px solid #ffd4604d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000000f}.tdash-topbar-logo{object-fit:cover;width:100%;height:100%}.tdash-topbar-titles{min-width:0;overflow:hidden}.tdash-page-title{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:700;overflow:hidden}.tdash-page-crumb{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.tdash-hamburger{cursor:pointer;color:#64748b;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:1.4rem;display:none}.tdash-topbar-right{align-items:center;gap:12px;display:flex}.tdash-top-logout{color:#ef4444;cursor:pointer;background:#fff5f5;border:1px solid #fee2e2;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.2rem;transition:all .2s;display:none}@media (width<=900px){.tdash-top-logout{display:flex}}.tdash-top-logout:hover{background:#fee2e2;transform:translateY(-1px)}.tdash-content{box-sizing:border-box;flex:1;width:100%;min-width:0;max-width:1300px;margin:0 auto;padding:24px 28px;overflow-x:hidden}.tdash-section-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.tdash-section-title h2{color:#1e293b;margin:0 0 3px;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.tdash-section-title p{color:#94a3b8;margin:0;font-size:.82rem}.tdash-welcome-banner{background:linear-gradient(135deg,#1e293b 0%,#243050 100%);border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;padding:26px 28px;display:flex;position:relative;overflow:hidden}.tdash-welcome-banner:before{content:"";background:#fbbf2414;border-radius:50%;width:200px;height:200px;position:absolute;top:-40px;right:-40px}.tdash-welcome-text{z-index:1;position:relative}.tdash-welcome-label{color:#fbbf24;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:.72rem;font-weight:600}.tdash-welcome-name{color:#fff;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800}.tdash-welcome-meta{color:#ffffff80;font-size:.8rem}.tdash-welcome-right{z-index:1;text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;padding-top:40px;display:flex;position:relative}.tdash-role-pill{border-radius:999px;align-items:center;gap:6px;margin-bottom:6px;padding:8px 16px;font-size:.82rem;font-weight:700;display:inline-flex}.tdash-role-pill.class-teacher{color:#fbbf24;background:#fbbf242e;border:1px solid #fbbf244d}.tdash-role-pill.subject-teacher{color:#a5b4fc;background:#6366f12e;border:1px solid #6366f14d}.tdash-welcome-date{color:#ffffff59;font-size:.75rem}.tdash-stats-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:22px;display:grid}.tdash-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:14px;padding:18px;transition:box-shadow .2s;display:flex}.tdash-stat-card:hover{box-shadow:0 4px 20px #00000012}.tdash-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.tdash-stat-icon.amber{color:#d97706;background:#fef3c7}.tdash-stat-icon.green{color:#059669;background:#dcfce7}.tdash-stat-icon.blue{color:#2563eb;background:#dbeafe}.tdash-stat-icon.rose{color:#e11d48;background:#ffe4e6}.tdash-stat-num{color:#1e293b;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800;line-height:1}.tdash-stat-label{color:#94a3b8;margin-top:3px;font-size:.73rem}.tdash-my-classes{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:22px;display:grid}.tdash-class-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:18px 20px;transition:all .2s}.tdash-class-card:hover{border-color:#fcd34d;box-shadow:0 4px 16px #f59e0b1a}.tdash-class-card-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.tdash-class-icon{color:#1e293b;background:linear-gradient(135deg,#fcd34d,#f59e0b);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;display:flex}.tdash-class-name{color:#1e293b;font-size:.95rem;font-weight:700}.tdash-class-sub{color:#94a3b8;font-size:.75rem}.tdash-class-badge-ct{color:#d97706;background:#fef3c7;border-radius:999px;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-block}.tdash-subject-chip{color:#475569;background:#f1f5f9;border-radius:999px;align-items:center;gap:5px;margin:2px;padding:4px 10px;font-size:.73rem;font-weight:500;display:inline-flex}.tdash-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden}.tdash-table-wrap{overflow-x:auto}.tdash-table{border-collapse:collapse;width:100%;font-size:.85rem}.tdash-table thead tr{background:#f8fafc}.tdash-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:12px 16px;font-size:.73rem;font-weight:700}.tdash-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:12px 16px}.tdash-table tbody tr:hover{background:#fffbeb}.tdash-table-empty{text-align:center;color:#94a3b8;padding:40px 16px!important}.tdash-student-card-list{flex-direction:column;gap:10px;display:none}.tdash-student-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;display:flex;box-shadow:0 2px 4px #00000005}.tdash-student-card-roll{color:#f59e0b;background:#fffbeb;border:1px solid #fef3c7;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:800;display:flex}.tdash-student-card-info{flex:1;min-width:0}.tdash-student-card-name{color:#1e293b;margin-bottom:2px;font-size:.95rem;font-weight:700}.tdash-student-card-meta{color:#64748b;align-items:center;gap:12px;font-size:.78rem;display:flex}.tdash-student-card-contact{color:#d97706;align-items:center;gap:4px;font-weight:600;display:flex}.tdash-attendance-day-selector{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.tdash-date-input{color:#334155;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:9px 14px;font-family:inherit;font-size:.88rem;transition:border .18s}.tdash-date-input:focus{border-color:#f59e0b}.tdash-att-grid{flex-direction:column;gap:8px;display:flex}.tdash-att-row{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 16px;transition:border-color .15s;display:flex}.tdash-att-row:hover{border-color:#f59e0b}.tdash-att-roll{color:#94a3b8;text-align:center;min-width:36px;font-size:.75rem;font-weight:700}.tdash-att-name{color:#1e293b;flex:1;min-width:120px;font-size:.88rem;font-weight:500}.tdash-att-btns{flex-wrap:wrap;gap:6px;display:flex}.tdash-att-btn{cursor:pointer;color:#64748b;background:#f1f5f9;border:1.5px solid #0000;border-radius:8px;padding:5px 12px;font-size:.75rem;font-weight:700;transition:all .15s}.tdash-att-btn.present.active{color:#059669;background:#dcfce7;border-color:#86efac}.tdash-att-btn.absent.active{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.tdash-att-btn.late.active{color:#d97706;background:#fef3c7;border-color:#fcd34d}.tdash-compose-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:20px;padding:24px}.tdash-compose-card label{color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.78rem;font-weight:700;display:block}.tdash-compose-card input,.tdash-compose-card textarea,.tdash-compose-card select{color:#334155;box-sizing:border-box;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:.88rem;transition:border .18s}.tdash-compose-card input:focus,.tdash-compose-card textarea:focus,.tdash-compose-card select:focus{border-color:#f59e0b}.tdash-compose-card textarea{resize:vertical;min-height:100px}.tdash-form-row{margin-bottom:16px}.tdash-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.tdash-sent-list{flex-direction:column;gap:10px;display:flex}.tdash-sent-item{background:#fff;border:1px solid #e2e8f0;border-left:4px solid #f59e0b;border-radius:12px;padding:16px 18px}.tdash-sent-item-title{color:#1e293b;word-wrap:break-word;word-break:break-word;overflow-wrap:anywhere;margin-bottom:4px;font-size:.9rem;font-weight:700}.tdash-sent-item-meta{color:#94a3b8;margin-bottom:6px;font-size:.75rem}.tdash-sent-item-body{color:#475569;font-size:.83rem;line-height:1.5}.tdash-tt-tabs{background:#f1f5f9;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:inline-flex}.tdash-tt-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:7px;padding:8px 18px;font-size:.83rem;font-weight:600;transition:all .18s}.tdash-tt-tab.active{color:#d97706;background:#fff;box-shadow:0 1px 4px #00000014}.tdash-coming-soon{text-align:center;background:#fff;border:2px dashed #e2e8f0;border-radius:16px;padding:48px 24px}.tdash-coming-soon-icon{margin-bottom:12px;font-size:2.8rem}.tdash-coming-soon h3{color:#1e293b;margin-bottom:6px;font-size:1.1rem}.tdash-coming-soon p{color:#94a3b8;max-width:320px;margin:0 auto;font-size:.85rem}.tdash-coming-soon-badge{color:#d97706;text-transform:uppercase;background:#fef3c7;border-radius:999px;margin-top:16px;padding:6px 18px;font-size:.75rem;font-weight:700;display:inline-block}.tdash-btn-primary{color:#1e293b;cursor:pointer;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:none;border-radius:10px;align-items:center;gap:7px;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .18s;display:inline-flex;box-shadow:0 2px 8px #f59e0b40}.tdash-btn-primary:hover{filter:brightness(1.07);transform:translateY(-1px)}.tdash-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.tdash-btn-secondary{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;align-items:center;gap:7px;padding:9px 18px;font-size:.85rem;font-weight:600;transition:all .18s;display:inline-flex}.tdash-btn-secondary:hover{color:#1e293b;border-color:#f59e0b}.tdash-status-pill{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.tdash-status-pill.present{color:#059669;background:#dcfce7}.tdash-status-pill.absent{color:#dc2626;background:#fee2e2}.tdash-status-pill.late{color:#d97706;background:#fef3c7}.tdash-status-pill.none{color:#94a3b8;background:#f1f5f9}.tdash-loading{color:#94a3b8;justify-content:center;align-items:center;gap:10px;padding:60px;display:flex}.tdash-error{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5;border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:.84rem}.tdash-success{color:#059669;background:#dcfce7;border:1px solid #86efac;border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:.84rem}.tdash-mobile-bottom-nav{z-index:100;padding:6px 0 max(10px, env(safe-area-inset-bottom));background:linear-gradient(160deg,#fffdf7,#fff9e8);border-top:1px solid #ffe48a80;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #f59e0b1f}.tdash-mobile-nav-inner{justify-content:space-around;align-items:center;padding:0 8px;display:flex;position:relative}.tdash-mobile-nav-item{color:#94a3b8;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;outline:none;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:6px 4px;font-size:.6rem;font-weight:600;transition:all .18s;display:flex}.tdash-mobile-nav-item .tdash-mob-icon{font-size:1.25rem}.tdash-mobile-nav-item.active{color:#d97706}.tdash-fab-container{z-index:102;flex:0 0 56px;justify-content:center;align-items:center;display:flex;position:relative}.tdash-fab-btn{color:#1e293b;cursor:pointer;z-index:103;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:3px solid #fffdf7;border-radius:50%;outline:none;justify-content:center;align-items:center;width:52px;height:52px;margin-top:-20px;font-size:1.5rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;display:flex;position:relative;box-shadow:0 4px 20px #f59e0b66}.tdash-fab-btn:hover{transform:scale(1.08)translateY(-2px)}.tdash-fab-btn.open{transform:rotate(45deg)translateY(-2px);box-shadow:0 6px 28px #f59e0b80}.tdash-fab-btn:active{transform:scale(.93)}.tdash-fab-items{pointer-events:none;width:0;height:0;position:absolute;bottom:50%;left:50%}.tdash-fab-items.open{pointer-events:auto}.tdash-fab-item{opacity:0;flex-direction:column;align-items:center;gap:5px;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .25s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}.tdash-fab-items.open .tdash-fab-item{opacity:1;pointer-events:auto}.tdash-fab-item-btn{color:#d97706;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:2px solid #ffe48a99;border-radius:50%;outline:none;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.25rem;transition:background .18s,transform .18s;display:flex;box-shadow:0 6px 20px #f59e0b2e,0 2px 8px #00000014}.tdash-fab-item-btn:active{background:#fef3c7;transform:scale(.9)}.tdash-fab-item-label{color:#1e293b;white-space:nowrap;background:#fffdf7f7;border:1px solid #ffe48a66;border-radius:8px;padding:3px 8px;font-size:.6rem;font-weight:700;box-shadow:0 2px 8px #0000001f}.tdash-fab-backdrop{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000026;display:none;position:fixed;inset:0}.tdash-fab-backdrop.open{display:block}@media (width<=900px){.tdash-layout{height:100vh;overflow:hidden}.tdash-sidebar{display:none!important}.tdash-main{-webkit-overflow-scrolling:touch;height:100vh;padding-bottom:80px;overflow-y:auto;margin-left:0!important}.tdash-hamburger{display:none}.tdash-welcome-banner{flex-direction:column;align-items:flex-start;gap:12px}.tdash-welcome-right{text-align:left;align-items:flex-start!important;padding-top:0!important}.tdash-form-grid{grid-template-columns:1fr}.tdash-mobile-bottom-nav{display:block}.tdash-toggle-btn,.tdash-table-card{display:none}.tdash-student-card-list{display:flex}.tdash-topbar-logo-wrap{border-radius:8px;width:36px;height:36px}.tdash-topbar{gap:8px;padding:0 12px}.tdash-topbar-left{gap:10px}.tdash-content{padding:12px 14px}}@media (width<=480px){.tdash-welcome-name{font-size:1.2rem}.tdash-stats-grid{grid-template-columns:1fr 1fr}.tdash-att-btns{gap:4px}.tdash-att-btn{padding:5px 8px;font-size:.7rem}}.tdash-table-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000008}.tdash-table-wrap{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto!important}.tdash-table{border-collapse:collapse;width:100%;min-width:800px}.tdash-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #f1f5f9;padding:14px 16px;font-size:.75rem;font-weight:700}.tdash-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:14px 16px;font-size:.88rem}.tdash-table tr:last-child td{border-bottom:none}.tdash-table tr:hover td{background:#fdfaf2}@keyframes tdash-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stu-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;will-change:opacity;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.stu-modal-lg{will-change:transform, opacity;background:#fff;border-radius:22px;flex-direction:column;width:100%;max-width:860px;max-height:92vh;display:flex;overflow:hidden;box-shadow:0 30px 80px #0003}.stu-modal-head{border-bottom:1px solid #f1f5f9;flex-shrink:0;justify-content:space-between;align-items:center;padding:22px 28px 18px;display:flex}.stu-modal-head h2{color:#1e293b;margin:0;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800}.stu-modal-head p{color:#94a3b8;margin:4px 0 0;font-size:.82rem}.stu-modal-close{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;transition:all .2s;display:flex}.stu-modal-close:hover{color:#dc2626;background:#fecaca;transform:scale(1.05)}.stu-modal-body{flex:1;overflow-y:auto}.stu-modal-footer{border-top:1px solid #f1f5f9;flex-shrink:0;justify-content:flex-end;gap:10px;padding:18px 28px;display:flex}.stu-modal-footer.center{justify-content:center}.stu-form-section{background:#fff;border:1.5px solid #f1f5f9;border-radius:18px;margin-bottom:24px;padding:24px;box-shadow:0 4px 14px #00000005}.stu-form-section-title{color:#1e293b;border-bottom:1.5px solid #f8fafc;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:800;display:flex}.stu-sec-icon{color:#1e293b;background:linear-gradient(135deg,#fde68a,#f59e0b);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.stu-form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.id-card-row{align-items:baseline;gap:10px;margin-bottom:5px;font-size:.85rem;display:flex}.id-card-row span{color:#94a3b8;text-transform:uppercase;letter-spacing:.3px;min-width:85px;font-size:.75rem;font-weight:600}.id-card-row strong{color:#1e293b;word-break:break-all;overflow-wrap:break-word;flex:1;min-width:0;font-weight:700}.id-card-row.full{grid-column:1/-1}.tdash-btn-icon{color:#f59e0b;cursor:pointer;background:#fffbeb;border:1px solid #fef3c7;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:flex}.tdash-btn-icon:hover{background:#fef3c7;transform:translateY(-1px)}@media (width<=700px){.stu-modal-overlay{-webkit-backdrop-filter:none!important;background:#000000b3!important}.stu-form-grid{grid-template-columns:1fr}}.assign-roll-overlay{z-index:3000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172abf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.assign-roll-container{box-sizing:border-box;background:#fff;border-radius:24px;flex-direction:column;width:100%;max-width:440px;padding:32px;display:flex;box-shadow:0 25px 50px -12px #0000004d,0 0 0 1px #0000000d}@media (width<=768px){.assign-roll-overlay{background:#0f172a66!important;align-items:flex-end!important;padding:0!important}.assign-roll-container{width:100vw!important;max-width:none!important;height:auto!important;max-height:90vh!important;padding:24px 20px max(32px, env(safe-area-inset-bottom)) 20px!important;border-radius:28px 28px 0 0!important;justify-content:flex-start!important;box-shadow:0 -10px 30px #00000026!important}}@keyframes tdash-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tdash-spin-animate{animation:.8s linear infinite tdash-spin}@media (width>=1024px){.tdash-pull-indicator{display:none!important}}.tdash-nav-badge{color:#fff;text-align:center;background:#ef4444;border-radius:999px;min-width:18px;margin-left:auto;padding:2px 6px;font-size:.6rem;font-weight:800;line-height:1.4}.tdash-mob-badge{color:#fff;text-align:center;background:#ef4444;border-radius:999px;min-width:14px;padding:1px 5px;font-size:.5rem;font-weight:800;position:absolute;top:2px;right:calc(50% - 18px)}.tdash-fees-mobile-cards{flex-direction:column;gap:10px;display:none}@media (width<=900px){.tdash-fees-mobile-cards{display:flex}}.mobile-only-footer{display:none}@media (width<=768px){.stu-modal-overlay.tdash-preview-modal-overlay{-webkit-backdrop-filter:none!important;background:#000000b3!important;justify-content:stretch!important;align-items:stretch!important;padding:0!important}.stu-modal-lg.tdash-preview-modal-lg{border-radius:0!important;flex-direction:column!important;width:100%!important;max-width:none!important;height:100%!important;max-height:100vh!important;display:flex!important}.tdash-preview-modal-lg .stu-modal-body{flex:1!important;overflow-y:auto!important}.pc-only-close{display:none!important}.mobile-only-footer{background:#f8fafc!important;border-top:1px solid #e2e8f0!important;flex-shrink:0!important;justify-content:center!important;padding:14px 20px!important;display:flex!important}.stu-modal-mobile-close-btn{color:#475569;cursor:pointer;background:#f8fafc;border:1.5px solid #cbd5e1;border-radius:10px;width:auto;min-width:140px;padding:10px 24px;font-size:.9rem;font-weight:700;transition:all .2s;box-shadow:0 2px 6px #0000000d}.stu-modal-mobile-close-btn:hover{color:#1e293b;background:#f1f5f9;border-color:#94a3b8}}.tdash-notification-dot{z-index:10;background-color:#ef4444;border:1.5px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-1px;right:-1px;box-shadow:0 1px 4px #ef444466}@media (width<=900px){.profile-close-desktop{display:none!important}.profile-close-mobile{justify-content:center;width:100%;margin-top:18px;display:flex!important}}@media (width<=900px){.profile-btn-banner-position{align-self:flex-end!important;margin-top:10px!important;position:static!important}}@keyframes skeleton-loading-pulse{0%{background-color:#f1f5f9}50%{background-color:#e2e8f0}to{background-color:#f1f5f9}}:root{--sd-amber:#d97706;--sd-amber-light:#fef3c7;--sd-cream:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);--sd-border:#f59e0b33;--sd-slate:#1e293b;--sd-gray:#64748b}.sdash-layout{background:#f8fafc;min-height:100vh;font-family:Inter,sans-serif;display:flex}.sdash-overlay{z-index:40;background:#00000073;display:none;position:fixed;inset:0}.sdash-overlay.open{display:block}.sdash-sidebar{z-index:50;background:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);border-right:1px solid #f59e0b33;flex-direction:column;width:250px;min-height:100vh;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #f59e0b14}.sdash-sidebar.collapsed{transform:translate(-100%)}.sdash-sidebar-logo{border-bottom:1px solid #f59e0b26;align-items:center;gap:10px;min-height:64px;padding:20px 16px 16px;display:flex}.sdash-sidebar-logo-img{border-radius:8px;flex-shrink:0;width:32px;height:32px;box-shadow:0 2px 8px #f59e0b33}.sdash-brand-name{color:#1e293b;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700}.sdash-brand-sub{color:#d97706;text-transform:uppercase;letter-spacing:.6px;font-size:.68rem}.sdash-student-chip{background:#ffd4601f;border:1px solid #ffd46040;border-radius:12px;align-items:center;gap:10px;margin:12px 12px 4px;padding:10px 12px;display:flex}.sdash-student-avatar{color:#1e293b;background:linear-gradient(135deg,#fcd34d,#f59e0b);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9rem;font-weight:800;display:flex}.sdash-student-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:.84rem;font-weight:700;overflow:hidden}.sdash-student-badge{color:#d97706;background:#fef3c7;border-radius:999px;margin-top:2px;padding:2px 8px;font-size:.66rem;font-weight:600;display:inline-block}.sdash-nav{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex;overflow-y:auto}.sdash-nav-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:.84rem;font-weight:500;transition:all .18s;display:flex;position:relative}.sdash-nav-item:hover{color:#334155;background:#f59e0b14;border-color:#ffd46033}.sdash-nav-item.active{color:#d97706;background:linear-gradient(135deg,#ffd46033,#f59e0b1f);border-color:#ffd4604d;font-weight:700;box-shadow:0 2px 8px #f59e0b14}.sdash-nav-icon{flex-shrink:0;font-size:1.15rem}.sdash-nav-label{white-space:nowrap;flex:1;overflow:hidden}.sdash-nav-badge{color:#fff;text-align:center;background:#ef4444;border-radius:999px;min-width:18px;padding:2px 6px;font-size:.6rem;font-weight:800;line-height:1.4}.sdash-sidebar-footer{border-top:1px solid #f59e0b26;padding:12px 8px}.sdash-logout-btn{color:#dc2626;cursor:pointer;background:#ef444412;border:1px solid #ef444426;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:.84rem;font-weight:600;transition:all .18s;display:flex}.sdash-logout-btn:hover{background:#ef444421}.sdash-toggle-btn{cursor:pointer;color:#1e293b;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:none;border-radius:8px;align-items:center;padding:6px 8px;font-size:.9rem;transition:all .18s;display:flex;box-shadow:0 2px 8px #f59e0b40}.sdash-toggle-btn:hover{transform:scale(1.07)}.sdash-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:250px;transition:margin-left .28s;display:flex}.sdash-main.collapsed{margin-left:0}.sdash-topbar{z-index:20;background:#fffdf7fa;border-bottom:1px solid #f59e0b26;justify-content:space-between;align-items:center;gap:12px;height:62px;padding:0 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #f59e0b0f}.sdash-topbar-left{flex:1;align-items:center;gap:14px;min-width:0;display:flex}.sdash-topbar-logo-wrap{background:#fff;border:1px solid #f59e0b33;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000000f}.sdash-topbar-logo{object-fit:cover;width:100%;height:100%}.sdash-topbar-titles{min-width:0;overflow:hidden}.sdash-page-title{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:700;overflow:hidden}.sdash-page-crumb{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.sdash-hamburger{cursor:pointer;color:#64748b;background:0 0;border:none;flex-shrink:0;padding:4px;font-size:1.4rem;display:none}.sdash-topbar-right{align-items:center;gap:12px;display:flex}.sdash-top-logout{color:#ef4444;cursor:pointer;background:#fff5f5;border:1px solid #fee2e2;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.2rem;transition:all .2s;display:none}.sdash-content{box-sizing:border-box;flex:1;width:100%;min-width:0;max-width:1300px;margin:0 auto;padding:24px 28px;overflow-x:hidden}.sdash-welcome-banner{background:linear-gradient(135deg,#1e293b 0%,#243050 100%);border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;padding:26px 28px;display:flex;position:relative;overflow:hidden}.sdash-welcome-banner:before{content:"";background:#fbbf2414;border-radius:50%;width:200px;height:200px;position:absolute;top:-40px;right:-40px}.sdash-welcome-text{z-index:1;position:relative}.sdash-welcome-label{color:#fcd34d;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:.72rem;font-weight:600}.sdash-welcome-name{color:#fff;margin-bottom:4px;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800}.sdash-welcome-meta{color:#ffffff80;font-size:.8rem}.sdash-welcome-right{z-index:1;text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;padding-top:40px;display:flex;position:relative}.sdash-class-pill{color:#fbbf24;background:#fbbf242e;border:1px solid #fbbf244d;border-radius:999px;align-items:center;gap:6px;margin-bottom:6px;padding:8px 16px;font-size:.82rem;font-weight:700;display:inline-flex}.sdash-welcome-date{color:#ffffff59;font-size:.75rem}.sdash-stats-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:22px;display:grid}.sdash-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:14px;padding:18px;transition:box-shadow .2s;display:flex}.sdash-stat-card:hover{box-shadow:0 4px 20px #00000012}.sdash-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.sdash-stat-icon.indigo{color:#d97706;background:#fef3c7}.sdash-stat-icon.green{color:#059669;background:#dcfce7}.sdash-stat-icon.red{color:#dc2626;background:#fee2e2}.sdash-stat-icon.amber{color:#d97706;background:#fef3c7}.sdash-stat-icon.blue{color:#2563eb;background:#dbeafe}.sdash-stat-num{color:#1e293b;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:800;line-height:1}.sdash-stat-label{color:#94a3b8;margin-top:3px;font-size:.73rem}.sdash-section-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.sdash-section-title h2{color:#1e293b;margin:0 0 3px;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.sdash-section-title p{color:#94a3b8;margin:0;font-size:.82rem}.sdash-today-att{background:#fff;border:2px solid #e2e8f0;border-radius:16px;flex-wrap:wrap;align-items:center;gap:20px;margin-bottom:22px;padding:20px 24px;display:flex}.sdash-today-att.present{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.sdash-today-att.absent{background:linear-gradient(135deg,#fff5f5,#fee2e2);border-color:#fca5a5}.sdash-today-att.late{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fcd34d}.sdash-att-status-icon{flex-shrink:0;font-size:2.2rem}.sdash-att-status-text{flex:1}.sdash-att-status-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.75rem;font-weight:600}.sdash-att-status-val{font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800}.sdash-att-status-val.present{color:#059669}.sdash-att-status-val.absent{color:#dc2626}.sdash-att-status-val.late{color:#d97706}.sdash-att-status-val.unmarked{color:#94a3b8}.sdash-item-list{flex-direction:column;gap:10px;display:flex}.sdash-item-card{cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:16px 18px;transition:all .18s;position:relative}.sdash-item-card:hover{border-color:#fcd34d;box-shadow:0 4px 16px #f59e0b1a}.sdash-item-card.new-item{border-color:#d97706;box-shadow:0 0 0 3px #f59e0b1a}.sdash-item-card.overdue{border-color:#ef4444;box-shadow:0 0 0 3px #ef444414}.sdash-new-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#fcd34d,#f59e0b);border-radius:999px;padding:2px 8px;font-size:.58rem;font-weight:800;animation:2s infinite sdash-pulse;position:absolute;top:10px;right:12px}.sdash-overdue-badge{color:#fff;text-transform:uppercase;background:#ef4444;border-radius:999px;padding:2px 8px;font-size:.58rem;font-weight:800;position:absolute;top:10px;right:12px}@keyframes sdash-pulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 6px #f59e0b00}}.sdash-item-title{color:#1e293b;word-wrap:break-word;word-break:break-word;overflow-wrap:anywhere;margin-bottom:4px;padding-right:70px;font-size:.92rem;font-weight:700}.sdash-item-meta{color:#94a3b8;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;font-size:.75rem;display:flex}.sdash-item-body{color:#475569;font-size:.83rem;line-height:1.55}.sdash-item-expand{border-top:1px solid #f1f5f9;margin-top:12px;padding-top:12px}.sdash-tag-chip{border-radius:999px;align-items:center;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.sdash-tt-day-tabs{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}.sdash-tt-day-btn{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;padding:7px 14px;font-size:.8rem;font-weight:600;transition:all .18s}.sdash-tt-day-btn:hover{color:#d97706;border-color:#fcd34d}.sdash-tt-day-btn.active{color:#fff;background:linear-gradient(135deg,#fcd34d,#d97706);border-color:#d97706;box-shadow:0 2px 8px #f59e0b40}.sdash-tt-day-btn.today{border-color:#d97706}.sdash-tt-period-list{flex-direction:column;gap:8px;display:flex}.sdash-tt-period{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:16px;padding:14px 18px;display:flex}.sdash-tt-period.current-period{background:#fef3c7;border-color:#d97706}.sdash-tt-period-num{color:#d97706;background:#fef3c7;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:800;display:flex}.sdash-tt-period-info{flex:1}.sdash-tt-subject{color:#1e293b;font-size:.92rem;font-weight:700}.sdash-tt-teacher{color:#64748b;margin-top:2px;font-size:.75rem}.sdash-tt-time{color:#94a3b8;flex-shrink:0;font-size:.75rem;font-weight:600}.sdash-att-analytics{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:22px;display:grid}.sdash-att-analytic-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px}.sdash-att-rate{margin:8px 0 4px;font-family:Outfit,sans-serif;font-size:2rem;font-weight:800}.sdash-att-rate.green{color:#059669}.sdash-att-rate.red{color:#dc2626}.sdash-att-rate.amber{color:#d97706}.sdash-att-rate-label{color:#94a3b8;font-size:.75rem}.sdash-progress-bar{background:#f1f5f9;border-radius:999px;height:8px;margin:10px 0;overflow:hidden}.sdash-progress-fill{border-radius:999px;height:100%;transition:width .6s}.sdash-progress-fill.green{background:linear-gradient(90deg,#4ade80,#059669)}.sdash-progress-fill.red{background:linear-gradient(90deg,#f87171,#dc2626)}.sdash-att-calendar{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.sdash-att-cal-header{color:#94a3b8;text-align:center;text-transform:uppercase;padding:4px 0;font-size:.65rem;font-weight:700}.sdash-att-cal-day{aspect-ratio:1;cursor:default;border-radius:8px;justify-content:center;align-items:center;font-size:.72rem;font-weight:600;transition:transform .15s;display:flex}.sdash-att-cal-day:hover{transform:scale(1.15)}.sdash-att-cal-day.present{color:#059669;background:#dcfce7}.sdash-att-cal-day.absent{color:#dc2626;background:#fee2e2}.sdash-att-cal-day.late{color:#d97706;background:#fef3c7}.sdash-att-cal-day.empty{color:#cbd5e1;background:0 0}.sdash-att-cal-day.today{ring:2px solid #d97706;outline:2px solid #d97706}.sdash-filter-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.sdash-filter-btn{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:6px 14px;font-size:.78rem;font-weight:600;transition:all .15s}.sdash-filter-btn:hover{color:#d97706;border-color:#fcd34d}.sdash-filter-btn.active{color:#d97706;background:#fef3c7;border-color:#d97706}.sdash-loading{color:#94a3b8;justify-content:center;align-items:center;gap:10px;padding:60px;display:flex}.sdash-empty{text-align:center;color:#94a3b8;padding:40px 24px}.sdash-empty-icon{margin-bottom:12px;font-size:2.5rem}.sdash-empty h3{color:#64748b;margin-bottom:6px;font-size:1rem}.sdash-empty p{font-size:.83rem}.sdash-attachments{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.sdash-attachment-btn{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.sdash-attachment-btn:hover{color:#d97706;border-color:#fcd34d}.sdash-mobile-bottom-nav{z-index:100;padding:6px 0 max(10px,env(safe-area-inset-bottom));background:linear-gradient(160deg,#fffdf7,#fff9e8);border-top:1px solid #f59e0b33;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #f59e0b1a}.sdash-mobile-nav-inner{justify-content:space-around;align-items:center;padding:0 8px;display:flex}.sdash-mobile-nav-item{color:#94a3b8;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:10px;outline:none;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:6px 4px;font-size:.6rem;font-weight:600;transition:all .18s;display:flex;position:relative}.sdash-mob-icon{font-size:1.25rem}.sdash-mobile-nav-item.active{color:#d97706}.sdash-mob-badge{color:#fff;text-align:center;background:#ef4444;border-radius:999px;min-width:14px;padding:1px 5px;font-size:.5rem;font-weight:800;position:absolute;top:2px;right:calc(50% - 18px)}@media (width<=900px){.student-portal.sdash-layout{height:100vh;overflow:hidden}.student-portal .sdash-sidebar{display:none!important}.student-portal .sdash-main{-webkit-overflow-scrolling:touch;height:100vh;padding-bottom:80px;overflow-y:auto;margin-left:0!important}.student-portal .sdash-hamburger{display:none}.student-portal .sdash-content{padding:12px 14px}.student-portal .sdash-mobile-bottom-nav{display:block}.student-portal .sdash-toggle-btn{display:none}.student-portal .sdash-top-logout{display:flex}.sdash-welcome-banner{flex-direction:column;align-items:flex-start;gap:12px}.sdash-welcome-right{text-align:left;align-items:flex-start!important;padding-top:0!important}.sdash-att-analytics{grid-template-columns:1fr 1fr}}@media (width<=480px){.sdash-welcome-name{font-size:1.2rem}.sdash-stats-grid,.sdash-att-analytics{grid-template-columns:1fr 1fr}}.sdash-btn-primary{color:#1e293b;cursor:pointer;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:none;border-radius:10px;align-items:center;gap:7px;padding:10px 20px;font-size:.85rem;font-weight:700;transition:all .18s;display:inline-flex;box-shadow:0 2px 8px #f59e0b40}.sdash-btn-primary:hover{filter:brightness(1.07);transform:translateY(-1px)}.sdash-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.sdash-fab-backdrop{z-index:98;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);-webkit-tap-highlight-color:transparent;background:#00000026;display:none;position:fixed;inset:0}.sdash-fab-backdrop.open{pointer-events:auto}.sdash-fab-container{z-index:102;flex:0 0 56px;justify-content:center;align-items:center;display:flex;position:relative}.sdash-fab-btn{color:#1e293b;cursor:pointer;z-index:103;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#fcd34d,#f59e0b);border:3px solid #fffdf7;border-radius:50%;outline:none;justify-content:center;align-items:center;width:52px;height:52px;margin-top:-20px;font-size:1.5rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;display:flex;position:relative;box-shadow:0 4px 20px #f59e0b66}.sdash-fab-btn:hover{transform:scale(1.08)translateY(-2px)}.sdash-fab-btn.open{transform:rotate(45deg)translateY(-2px);box-shadow:0 6px 28px #f59e0b80}.sdash-fab-btn:active{transform:scale(.93)}.sdash-fab-items{pointer-events:none;width:0;height:0;position:absolute;bottom:50%;left:50%}.sdash-fab-items.open{pointer-events:auto}.sdash-fab-item{opacity:0;flex-direction:column;align-items:center;gap:5px;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .25s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(0)}.sdash-fab-items.open .sdash-fab-item{opacity:1;pointer-events:auto}.sdash-fab-item-btn{color:#d97706;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:2px solid #ffe48a99;border-radius:50%;outline:none;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.25rem;transition:background .18s,transform .18s;display:flex;box-shadow:0 6px 20px #f59e0b2e,0 2px 8px #00000014}.sdash-fab-item-btn:active{background:#fef3c7;transform:scale(.9)}.sdash-fab-item-label{color:#1e293b;white-space:nowrap;background:#fffdf7f7;border:1px solid #ffe48a66;border-radius:8px;padding:3px 8px;font-size:.6rem;font-weight:700;box-shadow:0 2px 8px #0000001f}@media (width<=900px){.student-portal .sdash-fab-backdrop.open{display:block}}@keyframes sdash-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sdash-spin-animate{animation:.8s linear infinite sdash-spin}@media (width>=1024px){.sdash-pull-indicator{display:none!important}}.sdash-notification-dot{z-index:10;background-color:#ef4444;border:1.5px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:-1px;right:-1px;box-shadow:0 1px 4px #ef444466}.sdash-mob-icon{position:relative}.profile-close-desktop{display:flex}.profile-close-mobile{display:none}@media (width<=900px){.profile-close-desktop{display:none!important}.profile-close-mobile{justify-content:center;width:100%;margin-top:18px;display:flex!important}}.sdash-profile-btn{box-shadow:0 4px 30px #00000026,inset 0 1px 1px #fff3;-webkit-backdrop-filter:blur(16px)saturate(180%)!important;color:#fffffff2!important;cursor:pointer!important;background:#ffffff0d!important;border:1px solid #ffffff1f!important;border-radius:12px!important;align-items:center!important;gap:6px!important;padding:8px 16px!important;font-size:.8rem!important;font-weight:700!important;transition:all .25s cubic-bezier(.4,0,.2,1)!important;display:inline-flex!important}.sdash-profile-btn:hover{color:#fff!important;background:#ffffff1f!important;border-color:#ffffff40!important;transform:translateY(-1.5px)!important;box-shadow:0 8px 32px #1f268740,inset 0 1px 1px #ffffff4d!important}.sdash-profile-btn:active{transform:translateY(0)!important}.profile-btn-banner-position{z-index:2!important;position:absolute!important;top:26px!important;right:28px!important}@media (width<=900px){.profile-btn-banner-position{align-self:flex-end!important;margin-top:10px!important;position:static!important}}.skeleton-pulse{animation:1.5s ease-in-out infinite skeleton-loading-pulse}.skeleton-layout{width:100%;overflow:hidden}.skeleton-sidebar{box-shadow:none!important;background:#f8fafc!important;border-right:1px solid #e2e8f0!important}.skeleton-line{background-color:#f1f5f9;border-radius:4px;height:16px;animation:1.5s ease-in-out infinite skeleton-loading-pulse}.logo-skeleton{width:120px;height:24px}.skeleton-circle{background-color:#f1f5f9;border-radius:50%;animation:1.5s ease-in-out infinite skeleton-loading-pulse}.avatar-skeleton{width:38px;height:38px}.text-skeleton-short{width:80px;height:14px}.nav-skeleton{border-radius:8px;width:80%;height:36px;margin:8px 12px}.title-skeleton{width:160px;height:20px}.skeleton-banner{background-color:#f1f5f9;border-radius:18px;height:140px;margin-bottom:22px;animation:1.5s ease-in-out infinite skeleton-loading-pulse}.skeleton-stat-card{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:14px;height:80px;animation:1.5s ease-in-out infinite skeleton-loading-pulse}.skeleton-list-item{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:14px;height:100px;margin-bottom:10px;animation:1.5s ease-in-out infinite skeleton-loading-pulse}.nav-skeleton-mob{background-color:#f1f5f9;border-radius:8px;width:50px;height:36px;animation:1.5s ease-in-out infinite skeleton-loading-pulse}:root{--acc-sidebar-w:260px;--acc-indigo:var(--amber-600);--acc-indigo-dark:var(--cream-700);--acc-violet:var(--amber-500);--acc-surface:var(--cream-50);--acc-border:var(--cream-200);--acc-text:var(--slate-800);--acc-muted:var(--slate-500);--acc-subtle:var(--slate-400)}.acc-layout{background:#f1f5f9;max-width:100vw;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow-x:hidden}.acc-sidebar{width:var(--acc-sidebar-w);z-index:200;will-change:transform;background:linear-gradient(160deg,#fffdf7 0%,#fff9e8 60%,#fff3d0 100%);border-right:1px solid #ffe48a66;flex-direction:column;min-height:100vh;transition:transform .22s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 28px #f59e0b1a,2px 0 8px #0000000f}.acc-sidebar-overlay{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;display:none;position:fixed;inset:0}.acc-sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:24px 20px 20px;display:flex;position:relative}.acc-brand-icon{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:40px;height:40px;color:var(--slate-900);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;display:flex;box-shadow:0 4px 12px #ffd4604d}.acc-brand-name{color:var(--slate-800);font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800;line-height:1.1}.acc-brand-sub{color:var(--amber-600);letter-spacing:.6px;text-transform:uppercase;margin-top:1px;font-size:.68rem;font-weight:600}.acc-sidebar-close{color:var(--amber-600);cursor:pointer;background:#ffd4601f;border:1px solid #ffd46040;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;transition:background .15s;position:absolute;top:50%;right:14px;transform:translateY(-50%);display:none!important}.acc-sidebar-close:hover{background:#ffffff2e}.acc-school-chip{background:#ffd4601f;border:1px solid #ffd46040;border-radius:12px;align-items:center;gap:10px;margin:16px 16px 8px;padding:10px 14px;display:flex}.acc-school-chip-icon{color:var(--amber-500);flex-shrink:0;font-size:1.1rem}.acc-school-name{color:var(--slate-800);font-size:.85rem;font-weight:700;line-height:1.2}.acc-school-id{color:var(--slate-400);margin-top:1px;font-family:Courier New,monospace;font-size:.72rem}.acc-nav{flex-direction:column;flex:1;gap:4px;padding:12px;display:flex;overflow-y:auto}.acc-nav-item{color:var(--slate-500);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:11px 14px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:600;transition:all .16s;display:flex}.acc-nav-item:hover{color:var(--slate-700);background:#f59e0b14;border-color:#ffd46033}.acc-nav-item.active{color:var(--amber-600);background:linear-gradient(135deg,#ffd4602e,#f59e0b1a);box-shadow:inset 0 0 0 1px #ffd4604d}.acc-nav-icon{flex-shrink:0;align-items:center;font-size:1.15rem;display:flex}.acc-sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:12px;padding:16px;display:flex}.acc-user-row{align-items:center;gap:10px;display:flex}.acc-user-avatar{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:36px;height:36px;color:var(--slate-900);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:800;display:flex;box-shadow:0 3px 10px #f59e0b33}.acc-user-name{color:var(--slate-800);font-size:.85rem;font-weight:700;line-height:1.2}.acc-user-id{color:var(--slate-400);font-family:Courier New,monospace;font-size:.71rem}.acc-user-info{min-width:0}.acc-logout-btn{color:#dc2626;cursor:pointer;background:#ef444412;border:1px solid #ef444426;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 16px;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:600;transition:all .16s;display:flex}.acc-logout-btn:hover{color:#b91c1c;background:#ef444421;border-color:#ef444440}.acc-main{margin-left:var(--acc-sidebar-w);will-change:margin-left;flex-direction:column;flex:1;max-width:100%;min-height:100vh;transition:margin-left .22s cubic-bezier(.4,0,.2,1);display:flex;overflow-x:hidden}@media (width>=901px){.acc-sidebar.collapsed{transform:translate(-260px)}.acc-main.collapsed{margin-left:0}}.acc-desktop-toggle-btn{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:34px;height:34px;color:var(--slate-900);cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:none;box-shadow:0 4px 14px #f59e0b59}@media (width>=901px){.acc-desktop-toggle-btn{display:flex}}.acc-desktop-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #f59e0b80}.acc-desktop-toggle-btn.mini{border-radius:8px;width:28px;height:28px;font-size:.9rem;box-shadow:0 2px 8px #f59e0b40}.acc-desktop-toggle-btn.mini:hover{transform:scale(1.05)}.acc-topbar{border-bottom:1px solid var(--acc-border);z-index:100;background:#fff;align-items:center;gap:16px;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 1px 6px #0000000f}.acc-menu-btn{background:linear-gradient(135deg, var(--cream-500), var(--amber-500));width:34px;height:34px;color:var(--slate-900);cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:0 4px 14px #f59e0b59}.acc-menu-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #f59e0b80}@media (width>=901px){.acc-menu-btn{display:none!important}}.acc-topbar-title{color:var(--acc-text);flex:1;font-family:Outfit,sans-serif;font-size:1.05rem;font-weight:800}.acc-topbar-right{align-items:center;gap:12px;display:flex}.acc-topbar-user{color:var(--acc-muted);align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.acc-topbar-user svg{color:var(--acc-indigo);font-size:1.3rem}.acc-content{box-sizing:border-box;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:28px 32px;overflow:hidden}.acc-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:22px;display:flex}.acc-section-header h2{color:var(--acc-text);margin:0;font-family:Outfit,sans-serif;font-size:1.15rem;font-weight:800}.acc-section-header p{color:var(--acc-muted);margin:3px 0 0;font-size:.83rem}.acc-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700;transition:all .18s cubic-bezier(.4,0,.2,1);display:inline-flex}.acc-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.acc-btn-primary{background:linear-gradient(135deg, var(--cream-400), var(--cream-600));color:var(--slate-900);box-shadow:0 10px 15px -3px #ffc93366,0 4px 6px -2px #ffc9331a}.acc-btn-primary:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 20px 25px -5px #ffc93380,0 10px 10px -5px #ffc93333}.acc-btn-ghost{color:var(--acc-muted);border:1.5px solid var(--acc-border);background:#fff;box-shadow:0 1px 4px #0000000d}.acc-btn-ghost:hover:not(:disabled){background:var(--acc-surface);color:var(--acc-text);border-color:#cbd5e1;transform:translateY(-1px)}.acc-btn-sm{border-radius:8px;padding:5px 12px;font-size:.79rem}.acc-filters{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.acc-search-wrap{flex:220px;position:relative}.acc-search-icon{color:var(--acc-subtle);pointer-events:none;font-size:1rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.acc-search-input{border:1.5px solid var(--acc-border);box-sizing:border-box;width:100%;color:var(--acc-text);background:#fff;border-radius:10px;outline:none;padding:10px 14px 10px 36px;font-size:.86rem;transition:border-color .18s,box-shadow .18s}.acc-search-input:focus{border-color:var(--acc-indigo);box-shadow:0 0 0 3px #6366f11f}.acc-filter-select{border:1.5px solid var(--acc-border);color:var(--acc-text);cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 12px center no-repeat;border-radius:10px;outline:none;padding:10px 36px 10px 14px;font-size:.86rem;transition:border-color .18s}.acc-filter-select:focus{border-color:var(--acc-indigo)}.acc-table-card{border:1.5px solid var(--acc-border);box-sizing:border-box;background:#fff;border-radius:16px;max-width:100%;overflow:hidden;box-shadow:0 2px 16px #0000000d}.acc-table-wrap{-webkit-overflow-scrolling:touch;box-sizing:border-box;width:100%;max-width:100%;overflow:auto hidden}.acc-table{border-collapse:collapse;width:100%;font-size:.86rem}.acc-table thead tr{background:var(--acc-surface);border-bottom:2px solid var(--acc-border)}.acc-table th{text-align:left;color:var(--acc-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;padding:13px 15px;font-size:.78rem;font-weight:700}.acc-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .12s}.acc-table tbody tr:last-child{border-bottom:none}.acc-table tbody tr:hover{background:#fafbff}.acc-table td{vertical-align:middle;padding:13px 15px}.acc-student-name{color:var(--acc-text);font-weight:700}.acc-student-id{color:var(--acc-subtle);font-family:Courier New,monospace;font-size:.74rem}.acc-td-muted{color:var(--acc-muted)}.acc-td-bold{color:var(--acc-text);font-weight:600}.acc-td-green{color:#15803d;font-weight:600}.acc-td-red{color:#dc2626;font-weight:600}.acc-badge{letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:3px 11px;font-size:.75rem;font-weight:700;display:inline-flex}.badge-paid{color:#15803d;background:#dcfce7}.badge-pending{color:#dc2626;background:#fee2e2}.acc-empty{border:1.5px dashed var(--acc-border);text-align:center;background:#fff;border-radius:16px;padding:60px 24px}.acc-empty-icon{background:var(--acc-surface);width:56px;height:56px;color:var(--acc-subtle);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 16px;font-size:1.6rem;display:flex}.acc-empty h3{color:var(--acc-text);margin:0 0 6px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:800}.acc-empty p{color:var(--acc-subtle);margin:0;font-size:.85rem}.acc-loading{text-align:center;color:var(--acc-subtle);padding:52px;font-size:.9rem}.acc-modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:9999;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.18s acc-overlay-in;display:flex;position:fixed;inset:0}@keyframes acc-overlay-in{0%{opacity:0}to{opacity:1}}.acc-modal{background:#fff;border-radius:20px;width:100%;max-width:480px;animation:.22s cubic-bezier(.34,1.56,.64,1) acc-modal-in;overflow:hidden;box-shadow:0 25px 60px -12px #0000004d,inset 0 0 0 1px #fffc}@keyframes acc-modal-in{0%{opacity:0;transform:scale(.94)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.acc-modal-header{background:linear-gradient(135deg, var(--cream-100), var(--cream-200));border-bottom:1px solid var(--cream-300);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.acc-modal-title{color:var(--slate-900);align-items:center;gap:8px;font-family:Outfit,sans-serif;font-size:1.02rem;font-weight:800;display:flex}.acc-modal-close{cursor:pointer;width:30px;height:30px;color:var(--acc-muted);background:#fffc;border:1px solid #00000014;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:1rem;font-weight:700;transition:all .15s;display:flex}.acc-modal-close:hover{color:var(--acc-text);background:#fff;box-shadow:0 2px 8px #0000001a}.acc-modal-body{flex-direction:column;gap:14px;padding:22px 24px 24px;display:flex}.acc-modal-footer{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.acc-label{color:var(--acc-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-size:.8rem;font-weight:700;display:block}.acc-input{background:var(--cream-100);border:1.5px solid var(--cream-300);width:100%;color:var(--acc-text);box-sizing:border-box;appearance:none;border-radius:10px;outline:none;padding:11px 14px;font-family:Inter,sans-serif;font-size:.875rem;transition:all .18s}.acc-input:focus{border-color:var(--amber-500);background:#fff;box-shadow:0 0 0 3px #f59e0b26}.acc-input::placeholder{color:var(--acc-subtle)}select.acc-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.acc-hint{color:var(--acc-subtle);margin:0;font-size:.76rem}@media (width<=900px){.acc-sidebar{transform:translateX(calc(-1 * var(--acc-sidebar-w)))}.acc-sidebar.open{transform:translate(0)}.acc-sidebar-overlay{display:block}.acc-sidebar-close{display:flex!important}.acc-main{margin-left:0}.acc-desktop-toggle-btn{display:none!important}.acc-content{padding:20px 18px}.acc-topbar{gap:10px;padding:0 16px}}@media (width<=768px){.acc-content{padding:16px 14px}.acc-topbar{gap:8px;padding:0 12px}.acc-topbar-user span{display:none}.acc-topbar-title{font-size:.92rem}.acc-summary-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}.acc-summary-card{padding:14px}.acc-summary-value{font-size:1rem}.acc-filters{gap:8px}.acc-filter-select{flex:calc(50% - 8px);min-width:0;padding:9px 28px 9px 10px;font-size:.82rem}.acc-search-wrap{flex:100%}.acc-search-input{font-size:.84rem}.acc-table-card{border-radius:12px}.acc-table th{padding:10px;font-size:.72rem}.acc-table td{padding:10px;font-size:.82rem}.acc-student-name{font-size:.84rem}.acc-student-id{font-size:.7rem}.acc-btn{padding:9px 14px;font-size:.82rem}.acc-btn-sm{padding:6px 10px;font-size:.76rem}.acc-modal-overlay{align-items:flex-end;padding:0}.acc-modal{border-radius:20px 20px 0 0;width:100%;max-height:94vh;margin:0;overflow:hidden;max-width:100%!important}.acc-modal-header{padding:16px 18px}.acc-modal-body{gap:12px;padding:16px 18px}.acc-edit-modal-overlay{align-items:flex-end;padding:0}.acc-edit-modal-content{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:96vh}.acc-input{padding:10px 12px;font-size:.875rem}}@media (width<=480px){.acc-content{padding:12px 10px}.acc-topbar{height:56px}.acc-summary-grid{grid-template-columns:repeat(2,1fr);gap:8px}.acc-summary-card{padding:12px}.acc-summary-value{font-size:.95rem}.acc-summary-label{font-size:.68rem}.acc-summary-icon{margin-bottom:5px;font-size:1.2rem}.acc-filters{flex-direction:column;gap:8px}.acc-filter-select{flex:100%;width:100%}.acc-search-wrap{flex:100%}.acc-table th{padding:9px 8px;font-size:.68rem}.acc-table td{padding:9px 8px;font-size:.78rem}.acc-modal{border-radius:18px 18px 0 0;max-height:96vh}.acc-modal-header{padding:14px 16px}.acc-edit-modal-content{border-radius:18px 18px 0 0;max-height:98vh}.pg-bar{flex-direction:column;align-items:stretch;gap:8px;padding:10px 12px}.pg-controls{justify-content:center}.pg-info{text-align:center;font-size:.75rem}.pg-goto{justify-content:center}}.nc-img-shimmer{z-index:1;pointer-events:none;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;transition:opacity .3s;animation:1.6s linear infinite shimmer;position:absolute;inset:0}.nc-img-loaded+.nc-img-shimmer{opacity:0}.acc-edit-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999999;background:#0f172a99;justify-content:center;align-items:center;padding:16px;animation:.25s cubic-bezier(.4,0,.2,1) fadeIn;display:flex;position:fixed;inset:0}.acc-edit-modal-content{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:550px;max-height:90vh;animation:.3s cubic-bezier(.34,1.56,.64,1) slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pg-bar{border-top:1px solid var(--acc-border);background:#ffffffe6;border-radius:0 0 16px 16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.pg-info{color:var(--slate-400);white-space:nowrap;font-size:.8rem;font-weight:600}.pg-controls{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pg-btn{border:1.5px solid var(--slate-200);min-width:34px;height:34px;color:var(--slate-600);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;padding:0 10px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;transition:all .18s;display:flex}.pg-btn:hover:not(:disabled){background:var(--amber-50,#fffbeb);border-color:var(--amber-300,#fcd34d);color:var(--amber-700,#b45309)}.pg-btn:disabled{opacity:.38;cursor:not-allowed}.pg-btn.active{background:linear-gradient(135deg, var(--cream-400,#fcd34d), var(--amber-500,#f59e0b));border-color:var(--amber-400,#fbbf24);color:var(--slate-900);box-shadow:0 2px 8px #f59e0b40}.pg-goto{color:var(--slate-500);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.pg-goto input{border:1.5px solid var(--slate-200);text-align:center;width:52px;height:34px;color:var(--slate-700);border-radius:10px;outline:none;font-family:Inter,sans-serif;font-size:.85rem;font-weight:700;transition:border-color .18s}.pg-goto input:focus{border-color:var(--amber-400,#fbbf24);box-shadow:0 0 0 3px #f59e0b1f}@media (width<=600px){.pg-bar{gap:8px;padding:10px 14px}.pg-btn{min-width:30px;height:30px;font-size:.8rem}.pg-goto input{width:44px;height:30px}}.acc-reports-summary-grid{grid-template-columns:repeat(6,minmax(0,1fr))!important;gap:14px!important;margin-bottom:28px!important;display:grid!important}@media (width<=1200px){.acc-reports-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}}@media (width<=768px){.acc-reports-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}}@media (width<=480px){.acc-reports-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important}}.acc-reports-table-card{border:1.5px solid var(--slate-100);box-sizing:border-box;background:#fff;border-radius:16px;max-width:100%;overflow:hidden;box-shadow:0 2px 12px #0000000d}.acc-reports-table-wrap{-webkit-overflow-scrolling:touch;box-sizing:border-box;width:100%;max-width:100%;overflow:auto hidden}.acc-reports-table-wrap table{border-collapse:collapse;width:100%;min-width:700px;font-size:.85rem}
