@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{color:#1a202c;-webkit-font-smoothing:antialiased;background:#f2f4f7;min-height:100vh;font-family:Inter,sans-serif}.app-root{flex-direction:column;min-height:100vh;display:flex}.main-wrap{flex-direction:column;flex:1;gap:1.25rem;width:100%;max-width:780px;margin:0 auto;padding:1.75rem 1rem 3rem;display:flex}.site-header{color:#fff;background:#1a56db;padding:.85rem 1rem;box-shadow:0 2px 8px #1a56db40}.header-inner{align-items:center;gap:.65rem;max-width:780px;margin:0 auto;display:flex}.brand-icon{background:#ffffff2e;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.brand-title{letter-spacing:-.01em;font-size:.95rem;font-weight:700}.brand-sep{opacity:.5;margin:0 .4rem}.brand-sub{opacity:.8;font-size:.8rem}.card{background:#fff;border:1px solid #e4e8ef;border-radius:10px;padding:1.5rem;box-shadow:0 1px 3px #0000000f,0 2px 8px #0000000a}.card-title{color:#1a202c;border-bottom:1px solid #edf0f5;align-items:center;gap:.5rem;margin-bottom:1.1rem;padding-bottom:1rem;font-size:1rem;font-weight:700;display:flex}.field{margin-bottom:.875rem}.field-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem;font-size:.78rem;font-weight:600;display:block}.select-wrap{position:relative}.field-select{color:#1a202c;appearance:none;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:7px;width:100%;padding:.65rem 2.25rem .65rem .875rem;font-family:inherit;font-size:.9rem;transition:border-color .18s,box-shadow .18s}.field-select:focus{border-color:#1a56db;outline:none;box-shadow:0 0 0 3px #1a56db1f}.select-chevron{color:#9ca3af;pointer-events:none;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.input-wrap{position:relative}.input-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.field-input{color:#1a202c;background:#fff;border:1.5px solid #d1d5db;border-radius:7px;width:100%;padding:.65rem .875rem .65rem 2.25rem;font-family:inherit;font-size:.9rem;transition:border-color .18s,box-shadow .18s}.field-input::placeholder{color:#b0bec5}.field-input:focus{border-color:#1a56db;outline:none;box-shadow:0 0 0 3px #1a56db1f}.btn-search{color:#fff;cursor:pointer;background:#1a56db;border:none;border-radius:7px;justify-content:center;align-items:center;gap:.45rem;width:100%;margin-top:.25rem;padding:.75rem;font-family:inherit;font-size:.92rem;font-weight:600;transition:background .18s,opacity .18s,transform .12s;display:flex}.btn-search:hover:not(:disabled){background:#1648c0}.btn-search:active:not(:disabled){transform:scale(.99)}.btn-search:disabled{opacity:.5;cursor:not-allowed}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:17px;height:17px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.not-found{text-align:center;flex-direction:column;align-items:center;gap:.6rem;padding:2.5rem 1.5rem;display:flex}.nf-icon{color:#f59e0b}.nf-title{color:#1a202c;font-size:1rem;font-weight:700}.nf-sub{color:#6b7280;font-size:.855rem;line-height:1.55}.result-top{border-bottom:1px solid #edf0f5;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:1rem;display:flex}.result-section-title{color:#1a202c;align-items:center;gap:.45rem;font-size:1rem;font-weight:700;display:flex}.btn-print{color:#4b5563;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:6px;align-items:center;gap:.35rem;padding:.38rem .75rem;font-family:inherit;font-size:.78rem;font-weight:600;transition:all .18s;display:flex}.btn-print:hover{color:#1a56db;background:#eff6ff;border-color:#1a56db}.student-name{color:#1a56db;margin-bottom:.75rem;font-size:1.2rem;font-weight:700}.info-list{flex-direction:column;gap:.4rem;margin-bottom:1.5rem;list-style:none;display:flex}.info-item{color:#374151;align-items:center;gap:.5rem;font-size:.855rem;display:flex}.info-icon{color:#6366f1;flex-shrink:0}.sgpa-inline{color:#1a56db;font-weight:700}.tbl-wrap{border:1px solid #e4e8ef;border-radius:7px;margin-bottom:1rem;overflow-x:auto}.result-tbl{border-collapse:collapse;width:100%;font-size:.865rem}.result-tbl thead tr{background:#f9fafb;border-bottom:2px solid #e4e8ef}.result-tbl thead th{text-transform:uppercase;letter-spacing:.05em;color:#6b7280;text-align:left;white-space:nowrap;padding:.7rem .875rem;font-size:.72rem;font-weight:700}.result-tbl tbody tr{border-bottom:1px solid #f1f4f8;transition:background .12s}.result-tbl tbody tr:nth-child(odd){background:#fff}.result-tbl tbody tr:nth-child(2n){background:#f3f4f6}.result-tbl tbody tr:last-child{border-bottom:none}.result-tbl tbody tr:hover{background:#e5e7eb}.result-tbl td{color:#374151;vertical-align:middle;padding:.7rem .875rem}.result-tbl td.tc{text-align:center}.result-tbl td.code{color:#374151;font-family:Inter,sans-serif;font-size:.82rem;font-weight:700}.tbl-total{background:#f9fafb;border-top:2px solid #e4e8ef}.tbl-total td{padding:.7rem .875rem}.total-lbl{color:#374151;text-align:right;font-weight:700}.total-num{color:#1a56db;text-align:center;font-size:.95rem;font-weight:800}.grade-chip{border-radius:5px;justify-content:center;align-items:center;padding:.15rem .55rem;font-size:.8rem;font-weight:700;display:inline-flex}.grade-a{color:#15803d;background:#dcfce7}.grade-b{color:#1d4ed8;background:#dbeafe}.grade-c{color:#a16207;background:#fef9c3}.grade-d{color:#b91c1c;background:#fee2e2}.notice{color:#b91c1c;border-top:1px solid #edf0f5;padding-top:.875rem;font-size:.8rem;line-height:1.55}.notice-link{color:#1a56db;cursor:pointer;font-weight:600}.notice-link:hover{text-decoration:underline}.site-footer{text-align:center;color:#9ca3af;background:#fff;border-top:1px solid #e4e8ef;padding:1rem;font-size:.76rem}.print-header{display:none}@media print{.no-print{display:none!important}.print-header{text-align:center;border-bottom:2px solid #1a56db;margin-bottom:1rem;padding-bottom:.75rem;display:block}.print-header h2{color:#1a56db;font-size:1.1rem;font-weight:800}.print-header p{color:#6b7280;margin-top:3px;font-size:.82rem}body{background:#fff;font-size:12px}.main-wrap{padding:0}.card{box-shadow:none;border:none;padding:0}.result-tbl thead th,.result-tbl td{padding:.5rem .625rem}}@media (width<=540px){.brand-sub,.brand-sep{display:none}.card{padding:1.125rem}.student-name{font-size:1.05rem}}
