*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;margin:0}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f0f2f5;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;background:#1e3a5f;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;box-shadow:0 2px 8px #0003}.app-header h1{letter-spacing:-.3px;font-size:24px;font-weight:700}.app-header p{color:#a0b4c8;margin-top:2px;font-size:13px}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:28px 32px}.toolbar{margin-bottom:20px}.search-input{background:#fff;border:1px solid #d0d7e2;border-radius:8px;outline:none;width:100%;max-width:400px;padding:10px 16px;font-size:14px;transition:border-color .2s}.search-input:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a}.table-wrapper{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #00000014}.students-table{border-collapse:collapse;width:100%;font-size:14px}.students-table thead{background:#f8fafc;border-bottom:2px solid #e8edf2}.students-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:#64748b;padding:12px 16px;font-size:12px;font-weight:600}.students-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:14px 16px}.students-table tbody tr:last-child td{border-bottom:none}.students-table tbody tr:hover{background:#fafbfc}.name-cell{color:#1e3a5f;font-weight:500}.empty-row{text-align:center;color:#94a3b8;font-style:italic;padding:40px!important}.grade-badge{border-radius:20px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.grade-a{color:#16a34a;background:#dcfce7}.grade-b{color:#1d4ed8;background:#dbeafe}.grade-c{color:#a16207;background:#fef9c3}.grade-d{color:#dc2626;background:#fee2e2}.actions-cell{gap:8px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:500;transition:background .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-secondary{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-sm{padding:5px 12px;font-size:13px}.btn-edit{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.btn-edit:hover{background:#dbeafe}.btn-delete{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.btn-delete:hover{background:#fee2e2}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:14px;width:100%;max-width:460px;overflow:hidden;box-shadow:0 20px 60px #00000040}.modal-header{border-bottom:1px solid #e8edf2;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:#1e3a5f;font-size:18px;font-weight:600}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;line-height:1}.close-btn:hover{color:#475569;background:#f1f5f9}.student-form{flex-direction:column;gap:16px;padding:24px;display:flex}.student-form label{color:#475569;flex-direction:column;gap:6px;font-size:13px;font-weight:500;display:flex}.student-form input{border:1px solid #d0d7e2;border-radius:8px;outline:none;padding:9px 12px;font-size:14px;transition:border-color .2s}.student-form input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.required{color:#ef4444}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.confirm-delete{padding:24px}.confirm-delete p{color:#475569;margin-bottom:24px;font-size:14px;line-height:1.6}.state-message{text-align:center;color:#64748b;padding:60px 32px;font-size:15px}.state-message.error{color:#dc2626;background:#fff;border-radius:12px;box-shadow:0 1px 4px #00000014}.state-message .hint{color:#94a3b8;margin:12px 0 20px;font-size:13px}.state-message code{color:#1e3a5f;background:#f1f5f9;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:12px}
