@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--primary:#0f172a;--primary-light:#1e293b;--primary-dark:#020617;--primary-50:#f0f9ff;--primary-100:#e0f2fe;--primary-200:#bae6fd;--accent:#06b6d4;--accent-light:#22d3ee;--accent-dark:#0891b2;--accent-glow:#06b6d426;--secondary:#f97316;--secondary-light:#fb923c;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--danger-hover:#dc2626;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--bg:#f8fafc;--card-bg:#fff;--text:var(--gray-800);--text-light:var(--gray-500);--border:var(--gray-200);--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 25px -3px #0000001a, 0 4px 10px -2px #0000000a;--shadow-xl:0 20px 40px -5px #00000026, 0 10px 15px -5px #0000000f;--shadow-glow:0 0 30px #06b6d426;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .25s cubic-bezier(.4, 0, .2, 1);color:var(--text);background:var(--bg);font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.navbar{color:#fff;z-index:100;background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);border-bottom:1px solid #06b6d426;padding:0 1.5rem;position:sticky;top:0;box-shadow:0 4px 30px #0003}.navbar-inner{align-items:center;max-width:1280px;height:64px;margin:0 auto;display:flex}.navbar-brand{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.navbar-title{letter-spacing:-.3px;align-items:center;gap:.5rem;font-size:1.2rem;font-weight:700;display:flex}.navbar-title:before{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 10px var(--accent), 0 0 20px #06b6d44d;border-radius:50%}.navbar-toggle{color:#fff;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:#ffffff26;border:1px solid #fff3;padding:.4rem .6rem;font-size:1.25rem;display:none}.navbar-toggle:hover{background:#ffffff40}.navbar-menu{flex:1;align-items:center;margin-left:1.5rem;display:flex}.navbar-links{align-items:center;gap:.25rem;display:flex}.navbar-link{color:#fffc;border-radius:var(--radius-sm);transition:var(--transition);padding:.5rem .875rem;font-size:.875rem;font-weight:500;text-decoration:none;position:relative}.navbar-link:hover{color:#fff;background:#ffffff26;transform:translateY(-1px)}.navbar-link.active{color:var(--accent-light);background:#06b6d426;border:1px solid #06b6d440}.navbar-user{border-left:1px solid #fff3;align-items:center;gap:1rem;margin-left:auto;padding-left:1rem;display:flex}.navbar-username{opacity:.9;font-size:.85rem;font-weight:500}@media (width<=768px){.navbar{padding:0 1rem}.navbar-inner{flex-wrap:wrap}.navbar-brand{justify-content:space-between;width:100%}.navbar-toggle{justify-content:center;align-items:center;display:flex}.navbar-menu{z-index:101;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);border-top:1px solid #06b6d41a;flex-direction:column;align-items:stretch;width:100%;margin-left:0;padding:.75rem 1rem 1rem;display:none;position:absolute;top:64px;left:0;right:0;box-shadow:0 12px 40px #00000059}.navbar-menu.open{animation:.25s ease-out slideDown;display:flex}.navbar-links{flex-direction:column;gap:.25rem}.navbar-link{padding:.625rem .75rem}.navbar-user{border-top:1px solid #ffffff26;border-left:none;justify-content:space-between;margin-top:.5rem;margin-left:0;padding:.75rem 0 0}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:2rem}@media (width<=768px){.main-content{padding:1.25rem}}.login-container{background:#0f172a;justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:radial-gradient(circle,#06b6d426 0%,#0000 70%);width:600px;height:600px;animation:12s ease-in-out infinite loginOrb1;position:absolute;top:-40%;right:-20%}.login-container:after{content:"";background:radial-gradient(circle,#f973161a 0%,#0000 70%);width:500px;height:500px;animation:10s ease-in-out infinite loginOrb2;position:absolute;bottom:-30%;left:-10%}@keyframes loginOrb1{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-40px,30px)scale(1.1)}}@keyframes loginOrb2{0%,to{transform:translate(0)scale(1)}50%{transform:translate(30px,-20px)scale(1.05)}}.login-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:var(--radius-xl);z-index:1;background:#1e293bcc;border:1px solid #ffffff14;width:100%;max-width:420px;padding:2.75rem;animation:.6s ease-out cardAppear;position:relative;box-shadow:0 25px 60px #0006,inset 0 1px #ffffff0d}@keyframes cardAppear{0%{opacity:0;transform:translateY(30px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.login-logo{background:#fffffff2;border-radius:20px;justify-content:center;align-items:center;width:120px;height:120px;margin:0 auto 1.25rem;padding:14px;display:flex;box-shadow:0 10px 30px #00000040,0 0 0 1px #ffffff1a}.login-logo img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:100%;display:block}.login-card h1{text-align:center;color:#f1f5f9;letter-spacing:-.3px;margin-bottom:.35rem;font-size:1.35rem;font-weight:700;line-height:1.3}.login-subtitle{text-align:center;color:var(--gray-400);margin-bottom:2rem;font-size:.9rem}.login-footer{text-align:center;color:var(--gray-400);letter-spacing:.2px;border-top:1px solid #ffffff14;margin-top:1.75rem;padding-top:1.25rem;font-size:.78rem;line-height:1.6}.login-footer-line{display:block}.login-footer-line:first-child{color:#cbd5e1;margin-bottom:2px;font-weight:500}.login-footer strong{color:#e2e8f0;font-weight:600}.login-card .form-group label{color:var(--gray-300)}.login-card .form-group input{color:#f1f5f9;background:#0f172a99;border:1.5px solid #ffffff1a}.login-card .form-group input::placeholder{color:var(--gray-500)}.login-card .form-group input:focus{border-color:var(--accent);background:#0f172acc;box-shadow:0 0 0 4px #06b6d426}.login-card .error-message{background:#ef44441f;border-color:#ef444440}@media (width<=480px){.login-card{margin:0 .5rem;padding:2rem 1.5rem}}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--gray-700);letter-spacing:.2px;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:2px solid var(--gray-200);border-radius:var(--radius);width:100%;transition:var(--transition);background:var(--gray-50);color:var(--text);padding:.7rem .875rem;font-family:inherit;font-size:.925rem}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray-400)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:#fff;outline:none}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=480px){.form-row{grid-template-columns:1fr}}.btn{border-radius:var(--radius);cursor:pointer;transition:var(--transition);letter-spacing:.2px;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;width:100%;padding:.8rem;font-size:.95rem;box-shadow:0 4px 15px #06b6d459}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px #06b6d480}.btn-success{background:linear-gradient(135deg, var(--success) 0%, #059669 100%);color:#fff;box-shadow:0 4px 12px #10b9814d}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #10b98166}.btn-danger{background:linear-gradient(135deg, var(--danger) 0%, var(--danger-hover) 100%);color:#fff;box-shadow:0 4px 12px #ef44444d}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #ef444466}.btn-secondary{color:var(--gray-700);border:2px solid var(--gray-200);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-ghost{color:var(--accent-dark);background:0 0;padding:.5rem .75rem}.btn-ghost:hover{background:var(--accent-glow)}.btn-logout{color:#fca5a5;border-radius:var(--radius-sm);background:#ef44441f;border:1px solid #ef444433;padding:.4rem .85rem;font-size:.82rem}.btn-logout:hover{color:#fecaca;background:#ef444440}.btn-sm{padding:.4rem .85rem;font-size:.82rem}.btn-icon{border-radius:var(--radius-sm);width:36px;height:36px;padding:0;font-size:1rem}.error-message{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);border:1px solid #fecaca;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;animation:.4s ease-in-out shakeX;display:flex}.error-message:before{content:"!";background:var(--danger);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;font-weight:700;display:flex}@keyframes shakeX{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.success-message{background:var(--success-light);color:#065f46;border-radius:var(--radius);border:1px solid #a7f3d0;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.info-box{color:var(--accent-dark);border-radius:var(--radius-lg);background:linear-gradient(135deg,#06b6d40f 0%,#06b6d405 100%);border:1px solid #06b6d426;padding:1.25rem 1.5rem;font-size:.9rem;line-height:1.6}.dashboard-welcome{margin-bottom:2rem}.dashboard-welcome h1{color:var(--gray-900);letter-spacing:-.5px;margin-bottom:.25rem;font-size:1.75rem;font-weight:800}.dashboard-welcome p{color:var(--text-light);font-size:.95rem}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;display:grid}.dashboard-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);transition:var(--transition);padding:1.75rem;text-decoration:none;position:relative;overflow:hidden}.dashboard-card:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, var(--secondary) 100%);opacity:0;height:3px;transition:var(--transition);position:absolute;top:0;left:0;right:0}.dashboard-card:hover{box-shadow:var(--shadow-lg), 0 0 0 1px #06b6d41a;border-color:#06b6d433;transform:translateY(-6px)}.dashboard-card:hover:before{opacity:1}.dashboard-card-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:1rem;font-size:1.4rem;display:flex}.dashboard-card-icon.blue{background:linear-gradient(135deg,#e0f2fe,#bae6fd)}.dashboard-card-icon.green{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.dashboard-card-icon.purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.dashboard-card-icon.orange{background:linear-gradient(135deg,#ffedd5,#fed7aa)}.dashboard-card-icon.red{background:linear-gradient(135deg,#fee2e2,#fecaca)}.dashboard-card h3{color:var(--gray-900);margin-bottom:.35rem;font-size:1.05rem;font-weight:700}.dashboard-card p{color:var(--text-light);font-size:.85rem;line-height:1.5}@media (width<=640px){.dashboard-grid{grid-template-columns:1fr}.dashboard-welcome h1{font-size:1.4rem}}.table-container{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}th,td{text-align:left;border-bottom:1px solid var(--gray-100);padding:.875rem 1rem}th{background:var(--gray-50);color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;font-size:.8rem;font-weight:600}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.page-header h1{color:var(--gray-900);letter-spacing:-.3px;font-size:1.5rem;font-weight:800}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.25rem;padding:1.75rem}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.card-header h2{color:var(--gray-900);font-size:1.1rem;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a99;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card-bg);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-xl);padding:2rem;animation:.25s ease-out modalAppear;overflow-y:auto}@keyframes modalAppear{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal h2{color:var(--gray-900);margin-bottom:1.25rem;font-size:1.2rem;font-weight:700}.modal-actions{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:.75rem;margin-top:1.75rem;padding-top:1.25rem;display:flex}@media (width<=480px){.modal{margin:.5rem;padding:1.5rem}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.progress-bar{background:var(--gray-100);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent) 0%, var(--accent-light) 100%);border-radius:4px;height:100%;transition:width .3s}.filter-bar{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:1rem;display:flex}.filter-bar-search input{border:2px solid var(--border);border-radius:var(--radius);width:100%;transition:var(--transition);background:var(--gray-50);padding:.6rem 1rem;font-family:inherit;font-size:.9rem}.filter-bar-search input:focus{border-color:var(--accent);background:#fff;outline:none}.filter-bar-buttons{flex-wrap:wrap;gap:.4rem;display:flex}.filter-chip{border:1.5px solid var(--border);color:var(--text-light);cursor:pointer;transition:var(--transition);background:#fff;border-radius:20px;align-items:center;gap:.35rem;padding:.35rem .85rem;font-family:inherit;font-size:.8rem;font-weight:600;display:inline-flex}.filter-chip:hover{border-color:var(--accent);color:var(--accent-dark)}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.filter-chip-count{background:#00000014;border-radius:10px;padding:.1rem .4rem;font-size:.7rem;font-weight:700}.filter-chip.active .filter-chip-count{background:#ffffff40}.table-info{color:var(--text-light);padding:.4rem 0;font-size:.8rem}@media (width<=600px){.filter-bar-buttons{gap:.3rem}.filter-chip{padding:.3rem .6rem;font-size:.75rem}}.confirm-modal{text-align:center;max-width:400px}.confirm-modal-icon{background:var(--primary-50);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;font-size:1.5rem;display:flex}.confirm-modal-icon.danger{background:#fef2f2}.confirm-modal-title{margin-bottom:.5rem;font-size:1.15rem}.confirm-modal-message{color:var(--text-light);margin-bottom:0;font-size:.9rem;line-height:1.5}.confirm-modal .modal-actions{justify-content:center}.badge{letter-spacing:.2px;border-radius:50px;align-items:center;padding:.2rem .65rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-light);color:#065f46}.badge-warning{background:var(--warning-light);color:#92400e}.badge-danger{background:var(--danger-light);color:#991b1b}.empty-state{text-align:center;color:var(--text-light);padding:3rem 1.5rem}.empty-state-icon{opacity:.5;margin-bottom:1rem;font-size:3rem}.empty-state h3{color:var(--gray-700);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.empty-state p{max-width:400px;margin:0 auto;font-size:.9rem}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.spinner-dark{border-color:var(--gray-200);border-top-color:var(--primary)}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.section-title{color:var(--gray-700);border-left:3px solid var(--accent);margin-bottom:.75rem;padding-left:.5rem;font-size:1rem;font-weight:700}.class-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;display:grid}.class-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.class-card:hover{box-shadow:var(--shadow-md);border-color:#06b6d433}.class-card-info{align-items:center;gap:.75rem;display:flex}.class-card-name{color:var(--gray-900);font-size:1rem;font-weight:700}@media (width<=480px){.class-grid{grid-template-columns:1fr}}.class-selector-group{margin-bottom:1rem}.class-selector-group-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin-bottom:.4rem;padding-left:2px;font-size:.8rem;font-weight:700}.class-selector{flex-wrap:wrap;gap:.5rem;display:flex}.class-selector-btn{background:var(--card-bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--gray-700);transition:var(--transition);align-items:center;gap:.5rem;padding:.6rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;display:flex}.class-selector-btn:hover{border-color:var(--accent);color:var(--accent-dark)}.class-selector-btn.active{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);color:#fff;border-color:#0000;box-shadow:0 4px 12px #06b6d44d}.class-selector-btn.active .class-selector-level{color:#fff;background:#fff3}.class-selector-level{background:var(--gray-100);color:var(--gray-500);border-radius:4px;padding:.15rem .4rem;font-size:.7rem;font-weight:500}.tabs{background:var(--gray-100);border-radius:var(--radius);gap:.25rem;width:fit-content;padding:.25rem;display:flex}.tab{border-radius:var(--radius-sm);cursor:pointer;color:var(--gray-500);transition:var(--transition);background:0 0;border:none;padding:.55rem 1.25rem;font-family:inherit;font-size:.85rem;font-weight:600}.tab:hover{color:var(--gray-700)}.tab.active{background:var(--card-bg);color:var(--gray-900);box-shadow:var(--shadow-sm)}.schedule-toolbar{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.875rem;padding:1rem 1.25rem;display:flex}.schedule-toolbar-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.schedule-view-toggle{background:var(--gray-100);border-radius:var(--radius-sm);gap:.25rem;padding:.2rem;display:flex}.toggle-btn{border-radius:var(--radius-sm);cursor:pointer;color:var(--gray-500);transition:var(--transition);background:0 0;border:none;padding:.45rem 1rem;font-family:inherit;font-size:.82rem;font-weight:600}.toggle-btn.active{background:var(--card-bg);color:var(--gray-900);box-shadow:var(--shadow-sm)}.schedule-toolbar-select{align-items:center;gap:.75rem;display:flex}.schedule-select-label{color:var(--gray-600);white-space:nowrap;font-size:.85rem;font-weight:600}.schedule-select{border:2px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-800);background:var(--card-bg);min-width:200px;transition:var(--transition);flex:1;padding:.5rem .875rem;font-family:inherit;font-size:.875rem;font-weight:600}.schedule-select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);outline:none}.schedule-table{min-width:700px}.schedule-table th,.schedule-table td{text-align:center;vertical-align:top;padding:.5rem}.schedule-th-hour{width:100px;min-width:100px}.schedule-td-hour{background:var(--gray-50)!important;text-align:left!important;padding-left:.75rem!important}.schedule-hour-label{color:var(--gray-800);font-size:.8rem;font-weight:700}.schedule-hour-time{color:var(--gray-400);font-size:.7rem}.schedule-cell{min-width:110px;height:70px;position:relative}.schedule-entry{border-radius:var(--radius-sm);height:100%;transition:var(--transition);background:linear-gradient(135deg,#06b6d414,#06b6d408);border:1px solid #06b6d426;flex-direction:column;justify-content:center;gap:.15rem;padding:.4rem .5rem;display:flex;position:relative}.schedule-entry:hover{background:linear-gradient(135deg,#06b6d424,#06b6d40f);border-color:#06b6d44d}.schedule-entry-subject{color:var(--accent-dark);font-size:.8rem;font-weight:700}.schedule-entry-detail{color:var(--gray-500);font-size:.7rem}.schedule-entry-copy,.schedule-entry-delete{cursor:pointer;opacity:0;transition:var(--transition);background:0 0;border:none;padding:0 2px;font-size:.75rem;line-height:1;position:absolute;top:2px}.schedule-entry-copy{color:var(--gray-400);right:20px}.schedule-entry-delete{color:var(--gray-400);font-size:1rem;right:4px}.schedule-entry:hover .schedule-entry-copy,.schedule-entry:hover .schedule-entry-delete{opacity:1}.schedule-entry-copy:hover{color:var(--accent)}.schedule-entry-delete:hover{color:var(--danger)}.hour-chips{flex-wrap:wrap;gap:.4rem;display:flex}.hour-chip{border:2px solid var(--border);border-radius:var(--radius);color:var(--text-light);cursor:pointer;transition:var(--transition);background:#fff;flex-direction:column;align-items:center;min-width:70px;padding:.4rem .7rem;font-family:inherit;font-size:.8rem;font-weight:600;display:flex}.hour-chip:hover{border-color:var(--accent);color:var(--accent-dark)}.hour-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.hour-chip-time{opacity:.8;margin-top:1px;font-size:.65rem;font-weight:400}.schedule-add-btn{border:2px dashed var(--gray-200);border-radius:var(--radius-sm);width:100%;height:100%;min-height:50px;color:var(--gray-300);cursor:pointer;transition:var(--transition);background:0 0;font-size:1.2rem}.schedule-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.hours-grid{flex-direction:column;gap:.5rem;display:flex}.hour-row{background:var(--gray-50);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.hour-number{color:var(--gray-700);min-width:70px;font-size:.85rem;font-weight:700}.hour-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);color:var(--gray-800);width:110px;transition:var(--transition);background:#fff;padding:.4rem .6rem;font-family:inherit;font-size:.85rem}.hour-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.hour-sep{color:var(--gray-400);font-size:.85rem}@media (width<=640px){.tabs{width:100%}.tab{text-align:center;flex:1;padding:.55rem .5rem;font-size:.8rem}.schedule-toolbar-row{flex-direction:column;align-items:stretch}.schedule-view-toggle{width:100%}.toggle-btn{text-align:center;flex:1}.schedule-toolbar-select{flex-direction:column;align-items:stretch}.schedule-select{width:100%;min-width:unset}.level-chips{justify-content:center}.hour-row{flex-wrap:wrap}.hour-number{min-width:100%;margin-bottom:-.25rem}}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.report-filters{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;display:flex}.report-filters .form-group{flex:1;min-width:150px}.report-filters .btn{flex-shrink:0;width:auto;height:42px;padding:0 1.5rem}.report-summary{gap:1rem;margin-bottom:1.5rem;display:flex}.report-summary-item{text-align:center;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:10px;flex:1;padding:1rem}.report-summary-item.danger{background:#fef2f2;border-color:#fecaca}.report-summary-num{color:var(--primary);font-size:1.75rem;font-weight:800;display:block}.report-summary-item.danger .report-summary-num{color:var(--danger)}.report-summary-label{color:var(--text-light);margin-top:2px;font-size:.8rem;display:block}.report-export-bar{gap:.5rem;margin-bottom:1rem;display:flex}.report-export-bar .btn{width:auto;padding:.4rem 1rem}.report-student-header{background:var(--primary-50);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem;display:flex}.row-danger{background:#fef2f2!important}.unique-absent-section{background:linear-gradient(135deg,#fef3f2 0%,#fff7ed 100%);border:1px solid #fecaca;border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.unique-absent-header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.unique-absent-header h3{color:#991b1b;margin:0;font-size:1.1rem}.unique-absent-hint{color:var(--text-light);margin:0 0 1rem;font-size:.85rem}.unique-absent-section .table-container{background:#fff;border:1px solid #fecaca;border-radius:8px;overflow:hidden}.section-title{color:var(--text);border-bottom:2px solid var(--border);margin:0 0 .75rem;padding-bottom:.5rem;font-size:1.05rem}.edit-mode-banner{color:#78350f;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #f59e0b;border-radius:10px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.85rem 1.15rem;font-size:.9rem;line-height:1.4;display:flex}.edit-mode-banner strong{color:#78350f}.hourly-breakdown-section{background:linear-gradient(135deg,#eff6ff 0%,#f0f9ff 100%);border:1px solid #bfdbfe;border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.hourly-breakdown-header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.hourly-breakdown-header h3{color:#1e3a8a;margin:0;font-size:1.1rem}.hourly-breakdown-hint{color:var(--text-light);margin:0 0 1rem;font-size:.85rem}.hourly-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem;display:grid}.hour-card{border:1px solid var(--border);background:#fff;border-radius:10px;min-height:120px;transition:box-shadow .15s;display:flex;overflow:hidden}.hour-card:hover{box-shadow:0 4px 12px #00000014}.hour-card-time{background:var(--primary-700,#1e3a8a);color:#fff;text-align:center;justify-content:center;align-items:center;min-width:72px;padding:.85rem .5rem;font-size:.9rem;font-weight:700;display:flex}.hour-card-body{flex-direction:column;flex:1;gap:.5rem;min-width:0;padding:.85rem 1rem;display:flex}.hour-card-header{flex-direction:column;gap:.2rem;display:flex}.hour-card-title{color:var(--text);flex-wrap:wrap;align-items:center;font-size:.95rem;font-weight:600;display:flex}.hour-card-teacher{color:var(--text-light);font-size:.8rem}.hour-card-empty{align-items:center;display:flex}.hour-card-absent-label{margin-bottom:.4rem}.hour-card-absent-list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.hour-card-absent-list li{background:#fef2f2;border-left:3px solid #ef4444;border-radius:4px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.35rem .55rem;font-size:.85rem;display:flex}.hour-card-absent-list .absent-name{color:#991b1b;font-weight:500}.hour-card-absent-list .absent-phone{color:#6b7280;white-space:nowrap;font-size:.75rem}.hour-card.lunch-break{opacity:.85;background:#f3f4f6;border-style:dashed}.hour-card.lunch-break .hour-card-time{background:#9ca3af}.hour-card.lunch-break .hour-card-title{color:var(--text-light);font-style:italic}.hour-card.empty{background:#fafafa}.hour-card.empty .hour-card-time{background:#cbd5e1}.hour-card.pending{background:#fffbeb;border-color:#fde68a}.hour-card.pending .hour-card-time{background:#f59e0b}.hour-card.pending .hour-card-title{color:#78350f}.hour-card.all-present .hour-card-time{background:#059669}.hour-card.has-absent .hour-card-time{background:#dc2626}.hour-card.substitute{border-width:2px;border-color:#f59e0b}@media (width<=600px){.hourly-cards{grid-template-columns:1fr}}.badge-danger{color:#dc2626;background:#fecaca}@media (width<=600px){.report-filters{flex-direction:column;align-items:stretch}.report-filters .btn{width:100%}.report-summary{flex-direction:column;gap:.5rem}.report-student-header{text-align:center;flex-direction:column;gap:.75rem}}.lesson-list{flex-direction:column;gap:.75rem;display:flex}.lesson-card{border-left:4px solid var(--accent);background:#fff;border-radius:12px;align-items:center;gap:1rem;padding:1rem 1.25rem;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #0000000f}.lesson-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.lesson-card.taken{border-left-color:var(--success);opacity:.75}.lesson-card-time{text-align:center;border-right:1px solid var(--border);min-width:80px;padding-right:1rem}.lesson-card-hour{color:var(--primary);font-size:1.1rem;font-weight:700}.lesson-card-clock{color:var(--text-light);margin-top:2px;font-size:.75rem}.lesson-card-info{flex:1}.lesson-card-subject{color:var(--text);font-size:1rem;font-weight:600}.lesson-card-class{color:var(--text-light);align-items:center;margin-top:2px;font-size:.85rem;display:flex}.lesson-card-action{flex-shrink:0}.attendance-summary{gap:1rem;margin-bottom:1rem;display:flex}.attendance-stat{text-align:center;background:#fff;border-radius:12px;flex:1;padding:1rem;box-shadow:0 1px 4px #0000000f}.attendance-stat.present{border-bottom:3px solid var(--success)}.attendance-stat.absent{border-bottom:3px solid var(--danger)}.attendance-stat.total{border-bottom:3px solid var(--accent)}.attendance-stat-num{color:var(--primary);font-size:1.75rem;font-weight:800;display:block}.attendance-stat-label{color:var(--text-light);margin-top:2px;font-size:.8rem;display:block}.attendance-list{flex-direction:column;gap:.5rem;display:flex}.attendance-item{cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #0000;border-radius:10px;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:all .15s;display:flex;box-shadow:0 1px 3px #0000000a}.attendance-item:hover{border-color:var(--accent-light)}.attendance-item.absent{border-color:var(--danger);background:#fef2f2}.attendance-item-num{background:var(--primary-100);width:32px;height:32px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.attendance-item.absent .attendance-item-num{background:var(--danger);color:#fff}.attendance-item-info{flex:1}.attendance-item-name{color:var(--text);font-size:.95rem;font-weight:600}.attendance-item-no{color:var(--text-light);font-size:.75rem}.attendance-item-status{flex-shrink:0}.attendance-badge{border-radius:20px;padding:.3rem .75rem;font-size:.75rem;font-weight:600}.attendance-badge.present{color:#059669;background:#ecfdf5}.attendance-badge.absent{color:#dc2626;background:#fef2f2}.attendance-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;display:flex}@media (width<=600px){.lesson-card{flex-direction:column;align-items:flex-start;gap:.5rem}.lesson-card-time{border-right:none;border-bottom:1px solid var(--border);text-align:left;align-items:center;gap:.5rem;width:100%;min-width:auto;padding-bottom:.5rem;padding-right:0;display:flex}.lesson-card-action{width:100%}.lesson-card-action .btn{width:100%!important}.attendance-summary{gap:.5rem}.attendance-stat{padding:.75rem .5rem}.attendance-stat-num{font-size:1.35rem}.attendance-actions{flex-direction:column}.attendance-actions .btn{width:100%}}.substitute-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;display:flex}.substitute-banner-text{flex-direction:column;gap:.2rem;display:flex}.substitute-banner-text strong{color:#92400e;font-size:.95rem}.substitute-banner-text span{color:#78350f;font-size:.82rem}.btn-warning{color:#fff;background:#f59e0b;border:none;font-weight:600}.btn-warning:hover{background:#d97706}.substitute-form{flex-direction:column;gap:1rem;display:flex}.substitute-form .form-group{margin-bottom:0}@media (width<=600px){.substitute-banner{text-align:center;flex-direction:column}}.level-chips{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.level-chips-label{color:var(--gray-500);margin-right:.25rem;font-size:.8rem;font-weight:600}.level-chip{border:1px solid var(--border);background:var(--bg);color:var(--text-light);cursor:pointer;border-radius:20px;padding:.3rem .75rem;font-size:.8rem;transition:all .15s}.level-chip:hover{border-color:var(--primary);color:var(--primary)}.level-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.badge-primary{color:#1d4ed8;background:#dbeafe}.badge-warning{color:#92400e;background:#fef3c7}.substitute-history{margin-top:1.5rem}.substitute-history-title{color:var(--text);border-bottom:2px solid #fde68a;margin-bottom:.75rem;padding-bottom:.5rem;font-size:1rem;font-weight:600}.lesson-card.substitute{border-left:4px solid #f59e0b}.lesson-card.substitute .lesson-card-action{flex-direction:column;align-items:flex-end;gap:.25rem;display:flex}
