.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.announcement-form[data-v-9deec032]{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #eee}.announcement-form .input[data-v-9deec032],.announcement-form .textarea[data-v-9deec032]{width:100%}.announcement-item[data-v-9deec032]{border:1px solid #eee;border-radius:8px;padding:16px;margin-bottom:16px;background:#fafafa}.announcement-header[data-v-9deec032]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.announcement-title[data-v-9deec032]{margin:0;font-size:1.1em;font-weight:600;color:#333}.announcement-date[data-v-9deec032]{font-size:.85em;color:#999}.announcement-content[data-v-9deec032]{color:#555;white-space:pre-wrap;line-height:1.5}.announcement-actions[data-v-9deec032]{margin-top:12px;text-align:right}.empty-state[data-v-9deec032]{text-align:center;color:#999;padding:32px}.btn-sm[data-v-9deec032]{padding:4px 12px;font-size:.85em}:root{--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #e0e7ff;--bg: #f3f4f6;--card-bg: #ffffff;--text-main: #111827;--text-secondary: #4b5563;--border: #e5e7eb;--input-bg: #ffffff;--danger: #ef4444;--danger-hover: #dc2626;--success: #10b981;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--radius: .5rem}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}#app{display:flex;flex-direction:column;min-height:100vh}.container{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.page{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem;border:1px solid rgba(0,0,0,.02);transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.card-flat{background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-main);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.section-title:before{content:"";display:block;width:4px;height:1.25rem;background:var(--primary);border-radius:2px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:1px solid var(--border);background-color:#fff;color:var(--text-secondary);cursor:pointer;transition:all .2s;line-height:1.25rem;gap:.5rem}.btn:hover{background-color:#f9fafb;border-color:#d1d5db}.btn:active{transform:translateY(1px)}.btn-primary{background-color:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.btn-danger{background-color:#fff;border-color:var(--border);color:var(--danger)}.btn-danger:hover{background-color:#fef2f2;border-color:var(--danger)}.input,.select,.textarea{display:block;width:100%;padding:.5rem .75rem;font-size:.875rem;line-height:1.5;color:var(--text-main);background-color:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.textarea{resize:vertical;min-height:80px}.input:focus,.select:focus,.textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.table{width:100%;border-collapse:separate;border-spacing:0}.table th{background-color:#f8fafc;color:var(--text-secondary);font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);text-align:left}.table td{padding:1rem 1.5rem;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:.875rem}.table tr:last-child td{border-bottom:none}.table tr:hover td{background-color:#f9fafb}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;line-height:1;border-radius:9999px;background-color:#e5e7eb;color:var(--text-secondary);border:1px solid transparent;transition:all .2s;-webkit-user-select:none;user-select:none}.chip input[type=checkbox]{margin-right:.5rem}.chip.clickable{cursor:pointer}.chip.clickable:hover{background-color:#d1d5db}.chip.active{background-color:var(--primary);color:#fff;border-color:var(--primary)}.main-header{background-color:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50}.header-content{max-width:1200px;margin:0 auto;padding:0 1rem;height:4rem;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}.brand-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),#818cf8);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem}.brand-title{font-size:1.25rem;font-weight:700;color:var(--text-main);letter-spacing:-.025em}.nav-links{display:flex;gap:1.5rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.95rem;padding:.5rem .75rem;border-radius:var(--radius);transition:all .2s}.nav-link:hover{color:var(--primary);background-color:var(--primary-light)}.nav-link.router-link-active{color:var(--primary);font-weight:600}.toolbar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.switch-label{display:flex;align-items:center;cursor:pointer;font-size:.875rem;color:var(--text-secondary)}.switch-label input{margin-right:.5rem}.bulk-toolbar{align-items:flex-start}.bulk-toolbar .textarea{flex:1}.bulk-toolbar .select{width:auto;min-width:100px}.grid-2-columns{display:grid;grid-template-columns:350px 1fr;gap:1.5rem;align-items:start}@media (max-width: 768px){.grid-2-columns{grid-template-columns:1fr}}.score-input-group{display:grid;grid-template-columns:100px 1fr;gap:.75rem}.student-selector{max-height:400px;overflow-y:auto;padding-right:.5rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.student-selector::-webkit-scrollbar{width:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);width:420px;max-width:90vw;padding:1rem 1.25rem}.modal-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.modal-body{color:var(--text-secondary);margin-bottom:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem}.toast{position:fixed;top:16px;right:16px;padding:.5rem .75rem;border-radius:var(--radius);box-shadow:var(--shadow);color:#fff;z-index:1000;animation:fadeIn .2s ease}.toast.success{background:var(--success)}.toast.danger{background:var(--danger)}.student-selector::-webkit-scrollbar-thumb{background-color:var(--border);border-radius:4px}.grade-group{margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.grade-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem;color:var(--text-secondary)}.student-chips{display:flex;flex-wrap:wrap;gap:.5rem}.table-container{max-height:calc(100vh - 200px);overflow-y:auto}.text-success{color:#10b981;font-weight:600}.text-danger{color:#ef4444;font-weight:600}.grade-tag{font-size:.75rem;color:var(--text-secondary);background:#f3f4f6;padding:2px 6px;border-radius:4px;margin-left:.5rem;border:1px solid #e5e7eb}.btn-icon{padding:4px 8px;border:none;background:transparent;font-size:1.2rem;line-height:1;cursor:pointer}.btn-danger-text{color:var(--text-secondary)}.btn-danger-text:hover{color:var(--danger);background:transparent}.form-group{margin-bottom:1.5rem}.label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.btn-block{width:100%;display:flex;justify-content:center;padding:.75rem;font-size:1rem}.btn-xs{font-size:.75rem;padding:.2rem .5rem}
