@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";html,body{height:100vh;overflow:hidden}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#ededeb;--surface:#f6f6f4;--border:#dddbd7;--text:#1a1a19;--muted:#78756f;--accent:#1a1a19;--accent-bg:#e4e3e0;--danger:#c4392d;--success:#2d8a4e;--radius:6px;--font:"Inter", system-ui, -apple-system, sans-serif}[data-theme=dark]{--bg:#141413;--surface:#1e1e1c;--border:#2c2c29;--text:#e8e6e1;--muted:#8a8780;--accent:#e8e6e1;--accent-bg:#242422;--danger:#e8564a;--success:#5cb87a}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert()brightness(.9)}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;font-size:14px;line-height:1.55;display:flex}main{flex:1;overflow:hidden auto}.container{max-width:1100px;margin:0 auto;padding:1.5rem}.split{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.stack{flex-direction:column;gap:.75rem;display:flex}.row{align-items:center;gap:.75rem;display:flex}.spinner{color:var(--muted);flex:none;display:inline-block;position:relative}.spinner span{transform-origin:center var(--r);opacity:.14;background:currentColor;border-radius:999px;position:absolute;top:50%;left:50%}.spinner.sm{width:16px;height:16px}.spinner.sm span{width:2.5px;height:5px;margin-left:-1.25px;margin-top:calc(-1 * var(--r));--r:8px}.spinner.md{width:24px;height:24px}.spinner.md span{width:3.5px;height:7px;margin-left:-1.75px;margin-top:calc(-1 * var(--r));--r:12px}.spinner.lg{width:36px;height:36px}.spinner.lg span{width:5px;height:11px;margin-left:-2.5px;margin-top:calc(-1 * var(--r));--r:18px}.spinner span:first-child{animation:.8s linear infinite spinner-fade;transform:rotate(0)}.spinner span:nth-child(2){animation:.8s linear .1s infinite spinner-fade;transform:rotate(45deg)}.spinner span:nth-child(3){animation:.8s linear .2s infinite spinner-fade;transform:rotate(90deg)}.spinner span:nth-child(4){animation:.8s linear .3s infinite spinner-fade;transform:rotate(135deg)}.spinner span:nth-child(5){animation:.8s linear .4s infinite spinner-fade;transform:rotate(180deg)}.spinner span:nth-child(6){animation:.8s linear .5s infinite spinner-fade;transform:rotate(225deg)}.spinner span:nth-child(7){animation:.8s linear .6s infinite spinner-fade;transform:rotate(270deg)}.spinner span:nth-child(8){animation:.8s linear .7s infinite spinner-fade;transform:rotate(315deg)}.loading-inline{color:var(--muted);align-items:center;gap:.45rem;display:inline-flex}.loading-block{min-height:72px;color:var(--muted);justify-content:center;align-items:center;gap:.65rem;font-size:.86rem;display:flex}.btn .spinner{color:currentColor}@keyframes spinner-fade{0%{opacity:1}to{opacity:.14}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}h1{letter-spacing:-.01em;font-size:1.35rem;font-weight:600}h2{letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.05rem;font-weight:600}h3{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;font-weight:600}p{color:var(--muted);font-size:.875rem}label{color:var(--muted);letter-spacing:.01em;margin-bottom:.2rem;font-size:.75rem;font-weight:500;display:block}input,select,textarea{width:100%;font-size:.85rem;font-family:var(--font);color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:.45rem .6rem;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--text)}input[type=number]{text-align:center}.grade-input,#sf10-avg,#sf9-avg{appearance:textfield}.grade-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grade-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}#sf10-avg::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}#sf10-avg::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}#sf9-avg::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}#sf9-avg::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input:disabled{opacity:.45;cursor:not-allowed}.grade-input{text-align:center;width:48px;padding:.3rem .25rem;font-size:.82rem}.grade-remark{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:68px;color:var(--muted);outline:none;padding:.3rem .25rem;font-size:.82rem;font-weight:600}button,.btn{font-size:.85rem;font-family:var(--font);cursor:pointer;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.45rem .85rem;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s;display:inline-flex}button:hover{background:var(--accent-bg);border-color:var(--muted)}button:active{transform:scale(.98)}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}.btn-primary:hover{opacity:.85;background:var(--accent)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{opacity:.85;background:var(--danger)}.btn-sm{box-sizing:border-box;justify-content:center;height:30px;padding:0 .6rem;font-size:.78rem;line-height:1.2}.btn-full{justify-content:center;width:100%}table{border-collapse:collapse;width:100%;font-size:.85rem}th{color:var(--muted);text-align:left;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;padding:.4rem .5rem;font-size:.72rem;font-weight:600}td{border-bottom:1px solid var(--border);padding:.45rem .5rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--accent-bg)}.grades-grid{grid-template-columns:2fr repeat(5,52px);align-items:center;gap:4px;display:grid}.grades-grid .col-header{color:var(--muted);text-align:center;font-size:.72rem;font-weight:600}.grades-grid .subject-label{color:var(--text);padding:.15rem 0;font-size:.85rem}.scan-viewer{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius);min-height:400px;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.scan-viewer img,.scan-viewer iframe{border-radius:var(--radius);object-fit:contain;width:100%;height:100%}nav{background:var(--surface);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;gap:0;height:48px;padding:0 1.5rem;font-size:.85rem;display:flex}nav .logo{letter-spacing:.08em;color:var(--text);font-size:.95rem;font-weight:700;text-decoration:none}nav .nav-sep{background:var(--border);flex-shrink:0;width:1px;height:18px;margin:0 1.25rem}nav .nav-links{align-items:center;gap:1.25rem;display:flex}nav a{color:var(--muted);padding:.15rem 0;font-weight:450;text-decoration:none;transition:color .12s}nav a:hover{color:var(--text)}nav a.active{color:var(--text);font-weight:600}nav .nav-right{align-items:center;gap:1.25rem;margin-left:auto;display:flex}.theme-toggle{--toggle-speed:.2s;flex-shrink:0;width:36px;height:20px;position:relative}.theme-toggle input{opacity:0;width:0;height:0;position:absolute}.theme-toggle .slider{background:var(--border);cursor:pointer;transition:background var(--toggle-speed);border-radius:99px;position:absolute;inset:0}.theme-toggle .slider:before{content:"";background:var(--surface);width:14px;height:14px;transition:transform var(--toggle-speed);border-radius:50%;position:absolute;top:3px;left:3px}.theme-toggle input:checked+.slider{background:var(--muted)}.theme-toggle input:checked+.slider:before{transform:translate(16px)}.badge{background:var(--accent-bg);color:var(--muted);border-radius:99px;padding:.15rem .5rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-success{color:var(--success);background:#ecfdf5}.badge-danger{color:var(--danger);background:#fef2f2}[data-theme=dark] .badge-success{background:#1a2e22}[data-theme=dark] .badge-danger{background:#2e1a1a}hr{border:none;border-top:1px solid var(--border);margin:1rem 0}.search-bar{align-items:center;gap:.5rem;display:flex}.search-bar input{flex:1}.empty{text-align:center;color:var(--muted);padding:3rem 1rem;font-size:.85rem}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--muted);border:2px solid var(--bg);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text)}::selection{background:var(--accent);color:var(--bg)}
