:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app{background:#f0f4f8;min-height:100vh;font-family:Segoe UI,Apple SD Gothic Neo,sans-serif}.app-header{color:#fff;background:linear-gradient(135deg,#1e40af 0%,#3b82f6 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:24px 32px;display:flex;box-shadow:0 4px 12px #1e40af4d}.header-left h1{letter-spacing:-.5px;margin:0;font-size:1.8rem;font-weight:700}.header-sub{opacity:.8;margin:4px 0 0;font-size:.85rem}.header-stats{flex-wrap:wrap;gap:12px;display:flex}.stat-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1px solid #ffffff40;border-radius:12px;align-items:center;gap:10px;padding:10px 18px;display:flex}.stat-icon{font-size:1.4rem}.stat-label{opacity:.85;font-size:.72rem;font-weight:500}.stat-value{font-size:1.1rem;font-weight:700}.app-main{max-width:1100px;margin:0 auto;padding:24px 32px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.subject-legend{flex-wrap:wrap;gap:8px;display:flex}.legend-item{border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:600}.btn-primary{color:#fff;cursor:pointer;background:#1e40af;border:none;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background .2s,transform .1s}.btn-primary:hover{background:#1d3faa;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:background .2s}.btn-secondary:hover{background:#f9fafb}.btn-edit{color:#1e40af;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:4px 10px;font-size:.78rem;font-weight:600;transition:background .15s}.btn-edit:hover{background:#dbeafe}.btn-delete{color:#be123c;cursor:pointer;background:#fff1f2;border:1px solid #fecdd3;border-radius:6px;padding:4px 10px;font-size:.78rem;font-weight:600;transition:background .15s}.btn-delete:hover{background:#ffe4e6}.grade-excellent{color:#15803d;background:#dcfce7;font-weight:700}.grade-good{color:#1d4ed8;background:#dbeafe;font-weight:600}.grade-average{color:#a16207;background:#fef9c3;font-weight:600}.grade-poor{color:#be123c;background:#ffe4e6;font-weight:600}.grade-empty{color:#9ca3af;background:0 0}.table-wrapper{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #00000014}.grade-table{border-collapse:collapse;width:100%;font-size:.9rem}.grade-table thead{color:#fff;background:#1e40af}.grade-table thead th{letter-spacing:.3px;padding:14px 12px;font-size:.85rem;font-weight:600}.col-number{text-align:center;width:60px}.col-name{text-align:left;width:90px}.col-subject{text-align:center}.col-avg{text-align:center;width:70px}.col-actions{text-align:center;width:110px}.grade-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.grade-table tbody tr:hover{background:#f8fafc}.grade-table tbody tr:last-child{border-bottom:none}.cell-number{text-align:center;color:#6b7280;padding:12px 6px;font-size:.82rem}.cell-name{color:#111827;padding:12px;font-weight:600}.cell-grade{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 6px;transition:filter .15s}.cell-grade:hover{filter:brightness(.93)}.cell-avg{text-align:center;padding:10px 6px;font-weight:700}.cell-actions{text-align:center;white-space:nowrap;justify-content:center;align-items:center;gap:4px;padding:8px;display:flex}.grade-table tfoot{color:#fff;background:#1e3a8a}.grade-table tfoot td{text-align:center;padding:12px 6px;font-size:.85rem;font-weight:600}.avg-footer-label{color:#bfdbfe;text-align:center!important}.grade-table tfoot .grade-excellent,.grade-table tfoot .grade-good,.grade-table tfoot .grade-average,.grade-table tfoot .grade-poor{color:#fff;background:0 0}.grade-input{text-align:center;color:#111827;background:#fff;border:2px solid #3b82f6;border-radius:6px;outline:none;width:56px;padding:4px;font-size:.9rem;font-weight:700}.dash{color:#d1d5db}.table-hint{text-align:center;color:#9ca3af;background:#fafafa;border-top:1px solid #f1f5f9;margin:0;padding:10px;font-size:.75rem}.empty-state{text-align:center;background:#fff;border-radius:16px;padding:80px 20px;box-shadow:0 2px 12px #00000014}.empty-icon{margin-bottom:16px;font-size:3.5rem}.empty-title{color:#374151;margin:0 0 8px;font-size:1.2rem;font-weight:700}.empty-sub{color:#9ca3af;margin:0 0 24px}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:420px;animation:.2s modal-in;box-shadow:0 20px 60px #0003}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h2{color:#111827;margin:0;font-size:1.1rem;font-weight:700}.modal-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;transition:color .15s,background .15s}.modal-close:hover{color:#374151;background:#f3f4f6}.modal-body{flex-direction:column;gap:16px;padding:20px 24px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:.82rem;font-weight:600}.form-group input{color:#111827;border:1.5px solid #d1d5db;border-radius:8px;outline:none;padding:10px 12px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.form-error{color:#be123c;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;margin:0;padding:8px 12px;font-size:.82rem}.modal-footer{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start;padding:16px 20px}.app-main{padding:16px 12px}.grade-table{font-size:.8rem}.grade-table thead th,.grade-table tbody td,.grade-table tfoot td{padding:8px 4px}.btn-edit,.btn-delete{padding:3px 6px;font-size:.72rem}}
