@import url(https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700&display=swap);body{margin:0;padding:0;font-family:Open Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50;background-color:#f8f9fa}#app{min-height:100vh;display:flex;flex-direction:column}.nav-bar{background-color:#343a40;justify-content:space-between;padding:.5rem 2rem;color:#fff}.nav-bar,.nav-bar .logo,.nav-bar .logo a{display:flex;align-items:center}.nav-bar .logo a{color:#fff;text-decoration:none}.nav-bar .logo a img{height:40px;margin-right:.5rem}.nav-bar .logo a span{font-weight:600;align-items:center}.nav-bar .nav-links{display:flex;list-style:none}.nav-bar .nav-links li{margin-left:1.5rem}.nav-bar .nav-links a{color:#fff;text-decoration:none;font-weight:500;padding:.5rem 0;border-bottom:2px solid transparent;transition:border-color .2s}.nav-bar .nav-links a.router-link-exact-active,.nav-bar .nav-links a:hover{border-color:#fff}main{flex:1;width:100%}h1,h2,h3,h4,h5,h6{font-weight:600;color:#34495e}.list-header h1{padding-right:10px}@media(max-width:768px){.nav-bar{flex-direction:column;padding:0}.nav-bar .logo{display:none}.nav-bar .nav-links{margin-top:1rem;display:flex;flex-wrap:wrap;justify-content:center}.nav-bar .nav-links li{margin:.5rem}main{overflow-x:auto;white-space:nowrap}}.login-container[data-v-ff3ebb40]{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:#f5f5f5}.login-card[data-v-ff3ebb40]{width:100%;max-width:400px;margin:0 auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px rgba(0,0,0,.1)}.logo-container[data-v-ff3ebb40]{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem}.logo[data-v-ff3ebb40]{height:80px;margin-bottom:1rem}.app-title[data-v-ff3ebb40]{font-size:1.5rem;color:#2c3e50;margin:0}.login-subtitle[data-v-ff3ebb40]{text-align:center;color:#7f8c8d;margin-bottom:1.5rem}.login-form[data-v-ff3ebb40]{display:flex;flex-direction:column}.form-group[data-v-ff3ebb40]{margin-bottom:1.25rem}label[data-v-ff3ebb40]{display:block;margin-bottom:.5rem;font-weight:500}input[data-v-ff3ebb40]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.login-button[data-v-ff3ebb40]{background-color:#2c3e50;color:#fff;border:none;border-radius:4px;padding:.75rem;font-size:1rem;cursor:pointer;margin-top:1rem}.login-button[data-v-ff3ebb40]:hover{background-color:#1e2b38}.login-button[data-v-ff3ebb40]:disabled{background-color:#95a5a6;cursor:not-allowed}.error-message[data-v-ff3ebb40]{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem}@media (max-width:768px){.login-container[data-v-ff3ebb40]{align-items:flex-start;padding-top:2rem}}.dashboard-container[data-v-d2b5c496]{margin:0 auto;padding:1rem}.dashboard-grid[data-v-d2b5c496]{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.dashboard-card[data-v-d2b5c496]{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.1);overflow:hidden}.full-width[data-v-d2b5c496]{grid-column:1/-1}.card-header[data-v-d2b5c496]{padding:1.25rem;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.card-header h2[data-v-d2b5c496]{margin:0;font-size:1.25rem;color:#2c3e50}.view-all-link[data-v-d2b5c496]{color:#3498db;text-decoration:none;font-size:.875rem}.card-body[data-v-d2b5c496]{padding:1.25rem}.empty-state[data-v-d2b5c496],.loading[data-v-d2b5c496]{padding:2rem;text-align:center;color:#7f8c8d}.error-message[data-v-d2b5c496]{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem}.stats-grid[data-v-d2b5c496]{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stat-item[data-v-d2b5c496]{background-color:#f5f5f5;padding:1.5rem;border-radius:8px;text-align:center}.stat-value[data-v-d2b5c496]{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:.5rem}.stat-label[data-v-d2b5c496]{color:#7f8c8d;font-size:.875rem}.upcoming-list[data-v-d2b5c496]{display:flex;flex-direction:column}.upcoming-item[data-v-d2b5c496]{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #eee}.upcoming-item[data-v-d2b5c496]:last-child{border-bottom:none}.student-info[data-v-d2b5c496]{display:flex;align-items:center}.student-name[data-v-d2b5c496]{margin-right:.75rem;font-weight:500}.grade-badge[data-v-d2b5c496]{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.875rem;font-weight:700}.grade-badge.small[data-v-d2b5c496]{padding:.15rem .35rem;font-size:.75rem}.grading-date[data-v-d2b5c496]{color:#7f8c8d;font-size:.875rem}.recent-table[data-v-d2b5c496]{width:100%;border-collapse:collapse}.recent-table td[data-v-d2b5c496],.recent-table th[data-v-d2b5c496]{padding:.75rem;text-align:left;border-bottom:1px solid #eee}.recent-table th[data-v-d2b5c496]{font-weight:500;color:#7f8c8d}.actions[data-v-d2b5c496]{display:flex;gap:.5rem}.view-button[data-v-d2b5c496]{background-color:#3498db;color:#fff;border:none;border-radius:4px;padding:.25rem .5rem;cursor:pointer;font-size:.875rem;text-decoration:none}@media (max-width:768px){.dashboard-grid[data-v-d2b5c496]{grid-template-columns:1fr}.card-body[data-v-d2b5c496]{overflow-x:auto}.recent-table[data-v-d2b5c496]{width:100%;white-space:nowrap}}.student-list-container[data-v-6b7a0704]{width:100%}.list-header[data-v-6b7a0704]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.actions[data-v-6b7a0704]{display:flex;gap:1rem}.search-input[data-v-6b7a0704]{padding:.5rem;border:1px solid #ddd;border-radius:4px;width:250px}.add-button[data-v-6b7a0704]{background-color:#2c3e50;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.student-table[data-v-6b7a0704]{width:100%;border-collapse:collapse}td[data-v-6b7a0704],th[data-v-6b7a0704]{border:1px solid #ddd;padding:.75rem;text-align:left}th[data-v-6b7a0704]{background-color:#f5f5f5;cursor:pointer}th[data-v-6b7a0704]:hover{background-color:#e5e5e5}.edit-button[data-v-6b7a0704]{background-color:#3498db}.delete-button[data-v-6b7a0704],.edit-button[data-v-6b7a0704]{color:#fff;border:none;border-radius:4px;padding:.25rem .5rem;cursor:pointer}.delete-button[data-v-6b7a0704]{background-color:#e74c3c}.status-badge[data-v-6b7a0704]{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.875rem}.status-eligible[data-v-6b7a0704]{background-color:#27ae60;color:#fff}.status-not-eligible[data-v-6b7a0704]{background-color:#95a5a6;color:#fff}.age-badge[data-v-6b7a0704]{display:inline-block;padding:.2rem .4rem;border-radius:4px;font-size:.75rem;margin-left:.5rem;font-weight:500}.age-junior[data-v-6b7a0704]{background-color:#3498db;color:#fff}.age-senior[data-v-6b7a0704]{background-color:#9b59b6;color:#fff}.belt-badge[data-v-6b7a0704]{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:500;width:90%;text-align:center}.belt-white[data-v-6b7a0704]{background-color:#f5f5f5;color:#333;border:1px solid #ddd}.belt-yellow[data-v-6b7a0704]{background-color:#f1c40f;color:#333}.belt-orange[data-v-6b7a0704]{background-color:#e67e22;color:#fff}.belt-green[data-v-6b7a0704]{background-color:#27ae60;color:#fff}.belt-blue[data-v-6b7a0704]{background-color:#3498db;color:#fff}.belt-red[data-v-6b7a0704]{background-color:#c0392b;color:#fff}.belt-brown[data-v-6b7a0704]{background-color:#8b4513;color:#fff}.belt-black[data-v-6b7a0704]{background-color:#2c3e50;color:#fff}.empty-state[data-v-6b7a0704],.loading[data-v-6b7a0704]{padding:2rem;text-align:center;color:#7f8c8d}.error-message[data-v-6b7a0704]{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem}.pad[data-v-6b7a0704]{padding-left:5px;padding-right:5px}.modal-backdrop[data-v-6b7a0704]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center}.modal-content[data-v-6b7a0704]{background-color:#fff;padding:2rem;border-radius:8px;width:100%;max-width:400px}.modal-actions[data-v-6b7a0704]{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.cancel-button[data-v-6b7a0704]{background-color:#95a5a6}.cancel-button[data-v-6b7a0704],.confirm-delete-button[data-v-6b7a0704]{color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.confirm-delete-button[data-v-6b7a0704]{background-color:#e74c3c}.students-container[data-v-0b1840b6]{margin:0 auto;padding:1rem}.success-message[data-v-0b1840b6]{width:100%;box-sizing:border-box;background-color:#e8f5e9;color:#2e7d32;padding:1rem;border-radius:4px;margin-bottom:1rem;display:flex;align-items:center}.success-message.error-message[data-v-0b1840b6]{background-color:#ffebee;color:#c62828}.success-message.clickable[data-v-0b1840b6]{cursor:pointer;transition:background-color .2s ease}.success-message.clickable[data-v-0b1840b6]:active,.success-message.clickable[data-v-0b1840b6]:hover{background-color:#c8e6c9}.success-message a[data-v-0b1840b6]{color:#1976d2;text-decoration:underline;margin-left:.5rem;cursor:pointer}.success-message a[data-v-0b1840b6]:hover{color:#0d47a1}.student-form[data-v-0c1be3d9]{max-width:800px;margin:0 auto}.form-group[data-v-0c1be3d9]{margin-bottom:1.5rem}.form-col>.form-group[data-v-0c1be3d9]{margin-bottom:0}.form-section[data-v-0c1be3d9]{border-top:1px solid #eee;padding-top:1.5rem;margin-top:1.5rem}.form-section h3[data-v-0c1be3d9]{margin-bottom:1rem;color:#2c3e50}.form-section .history-header[data-v-0c1be3d9]{margin-bottom:0}label[data-v-0c1be3d9]{display:block;margin-bottom:.5rem;font-weight:500}input[data-v-0c1be3d9],select[data-v-0c1be3d9],textarea[data-v-0c1be3d9]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}input.error[data-v-0c1be3d9],select.error[data-v-0c1be3d9],textarea.error[data-v-0c1be3d9]{border-color:#e74c3c}.error-text[data-v-0c1be3d9]{color:#e74c3c;font-size:.875rem;margin-top:.25rem;display:block}textarea[data-v-0c1be3d9]{resize:vertical}.history-header[data-v-0c1be3d9]{cursor:pointer;padding:.5rem;background-color:#f5f5f5;border-radius:4px;display:flex;align-items:center;justify-content:space-between;&[data-v-0c1be3d9]:hover{background-color:#e8e8e8}.chevron[data-v-0c1be3d9]{display:inline-block;width:10px;height:10px;border-right:2px solid #555;border-bottom:2px solid #555;margin-right:8px;transition:transform .3s ease;&.down[data-v-0c1be3d9]{transform:rotate(45deg)}&.up[data-v-0c1be3d9]{transform:rotate(-135deg)}}}.history-content[data-v-0c1be3d9]{margin-top:1rem;border:1px solid #eee;border-radius:4px;padding:1rem;max-height:300px;overflow-y:auto}.history-item[data-v-0c1be3d9]{padding:.5rem 0;border-bottom:1px solid #f0f0f0;&[data-v-0c1be3d9]:last-child{border-bottom:none}}.history-date[data-v-0c1be3d9]{font-size:.8rem;color:#666}.history-type[data-v-0c1be3d9]{font-weight:700;margin:.25rem 0;text-transform:capitalize}.history-details[data-v-0c1be3d9]{white-space:pre-wrap}.history-user[data-v-0c1be3d9]{font-size:.8rem;color:#888;text-align:right}.loading-history[data-v-0c1be3d9],.no-history[data-v-0c1be3d9]{padding:1rem;text-align:center;color:#777;font-style:italic}.slide-enter-active[data-v-0c1be3d9],.slide-leave-active[data-v-0c1be3d9]{transition:max-height .5s ease,opacity .5s ease;max-height:500px;overflow:hidden;opacity:1}.slide-enter-from[data-v-0c1be3d9],.slide-leave-to[data-v-0c1be3d9]{max-height:0;opacity:0;transform:translateY(-10px)}.form-actions[data-v-0c1be3d9]{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.cancel-button[data-v-0c1be3d9]{background-color:#95a5a6}.cancel-button[data-v-0c1be3d9],.save-button[data-v-0c1be3d9]{color:#fff;border:none;border-radius:4px;padding:.75rem 1.5rem;cursor:pointer}.save-button[data-v-0c1be3d9]{background-color:#2c3e50}.cancel-button[data-v-0c1be3d9]:hover{background-color:#7f8c8d}.save-button[data-v-0c1be3d9]:hover{background-color:#1e2b38}.save-button[data-v-0c1be3d9]:disabled{background-color:#95a5a6;cursor:not-allowed}.image-upload-container[data-v-0c1be3d9]{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1rem;@media (min-width:768px){flex-direction:row;align-items:flex-start}}.image-preview[data-v-0c1be3d9]{width:200px;height:200px;border:1px solid #ddd;border-radius:8px;overflow:hidden;background-color:#f9f9f9;box-shadow:0 2px 4px rgba(0,0,0,.1);margin-bottom:10px;&.placeholder[data-v-0c1be3d9]{display:flex;flex-direction:column;justify-content:center;align-items:center;border:2px dashed #ddd;background:#f5f5f5;.placeholder-icon[data-v-0c1be3d9]{font-size:3rem;margin-bottom:1rem;color:#aaa}.placeholder-text[data-v-0c1be3d9]{color:#777;font-size:.9rem}}}.image-preview img[data-v-0c1be3d9]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.image-path[data-v-0c1be3d9]{font-size:.8rem;color:#777;margin-top:.5rem;word-break:break-all;text-align:left;max-width:100%;padding:.5rem;background-color:rgba(0,0,0,.03);border-radius:4px;overflow:hidden}.image-upload-controls[data-v-0c1be3d9]{display:flex;flex-direction:column;gap:.75rem;align-items:center;width:100%;@media (min-width:768px){width:auto;min-width:180px}}.file-input[data-v-0c1be3d9]{display:none}.upload-button[data-v-0c1be3d9]{background-color:#3498db;color:#fff;padding:.7rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;width:100%;transition:background-color .2s;&[data-v-0c1be3d9]:hover{background-color:#2980b9}&[data-v-0c1be3d9]:active{transform:translateY(1px)}}.remove-button[data-v-0c1be3d9]{background-color:#e74c3c;color:#fff;padding:.7rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;width:100%;transition:background-color .2s;&[data-v-0c1be3d9]:hover{background-color:#c0392b}&[data-v-0c1be3d9]:active{transform:translateY(1px)}}.field-help-text[data-v-0c1be3d9],.image-help-text[data-v-0c1be3d9]{color:#7f8c8d;font-size:.875rem;margin-top:.5rem}.belt-preview[data-v-0c1be3d9]{display:block;margin-top:.5rem;padding:.5rem;border-radius:4px;text-align:center;font-weight:500;border:1px solid transparent}.promotion-info[data-v-0c1be3d9]{background-color:#f8f9fa;border:1px solid #ddd;border-radius:4px;padding:1rem;margin-top:1rem}.info-title[data-v-0c1be3d9]{font-weight:600;margin-bottom:.75rem;color:#2c3e50;font-size:1.1rem}.info-row[data-v-0c1be3d9]{display:flex;margin-bottom:.5rem}.info-label[data-v-0c1be3d9]{width:120px;font-weight:500;color:#7f8c8d}.info-value[data-v-0c1be3d9]{flex:1}.form-row[data-v-0c1be3d9]{display:flex;gap:1.5rem;margin-bottom:1.5rem}.form-col[data-v-0c1be3d9]{flex:1}@media (max-width:768px){.form-row[data-v-0c1be3d9]{flex-direction:column;gap:0;margin-bottom:0}.form-col[data-v-0c1be3d9]{margin-bottom:1.5rem}.form-col[data-v-0c1be3d9]:last-child{margin-bottom:0}}.student-edit-container[data-v-0a68d781]{margin:0 auto;padding:1rem}.page-header[data-v-0a68d781]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.back-button[data-v-0a68d781]{background-color:#95a5a6;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.error-message[data-v-0a68d781]{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem}.loading[data-v-0a68d781]{padding:2rem;text-align:center;color:#7f8c8d}.grading-list-container[data-v-628a87e7]{width:100%}.list-header[data-v-628a87e7]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.list-header h2[data-v-628a87e7]{margin:0}.refresh-button[data-v-628a87e7]{background-color:#2c3e50;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.refresh-button[data-v-628a87e7]:disabled{background-color:#95a5a6;cursor:not-allowed}.pad[data-v-628a87e7]{padding-left:5px;padding-right:5px}.grading-table[data-v-628a87e7]{width:100%;border-collapse:collapse}td[data-v-628a87e7],th[data-v-628a87e7]{border:1px solid #ddd;padding:.75rem;text-align:left}th[data-v-628a87e7]{background-color:#f5f5f5}.actions-cell[data-v-628a87e7]{display:flex;gap:.5rem}.promote-button[data-v-628a87e7]{background-color:#27ae60;color:#fff;border:none;border-radius:4px;padding:.25rem .5rem;cursor:pointer}.promote-button[data-v-628a87e7]:disabled{background-color:#95a5a6;cursor:not-allowed}.view-button[data-v-628a87e7]{background-color:#3498db;color:#fff;border:none;border-radius:4px;padding:.25rem .5rem;cursor:pointer}.grade-badge[data-v-628a87e7]{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.875rem;font-weight:700}.empty-state[data-v-628a87e7],.loading[data-v-628a87e7]{padding:2rem;text-align:center;color:#7f8c8d}.error-message[data-v-628a87e7]{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem}.modal-backdrop[data-v-628a87e7]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center}.modal-content[data-v-628a87e7]{background-color:#fff;padding:2rem;border-radius:8px;width:100%;max-width:400px}.modal-actions[data-v-628a87e7]{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.cancel-button[data-v-628a87e7]{background-color:#95a5a6}.cancel-button[data-v-628a87e7],.confirm-button[data-v-628a87e7]{color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer}.confirm-button[data-v-628a87e7]{background-color:#27ae60}.gradings-container[data-v-27d7b22c]{margin:0 auto;padding:1rem}.success-message[data-v-27d7b22c]{background-color:#e8f5e9;color:#2e7d32;padding:1rem;border-radius:4px;margin-bottom:1rem}