@import "https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;0,8..60,700;1,8..60,400&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--paper:#f6f8f3;--paper-alt:#f0f3ec;--ledger-line:#c3d9c8;--ink:#16263a;--ink-muted:#5b6b66;--stamp-red:#a8342f;--stamp-amber:#b8762a;--stamp-gray:#8a8f87;--ink-10:#16263a1a;--ink-05:#16263a0d;--stamp-red-15:#a8342f26;--font-display:"Source Serif 4", "Georgia", serif;--font-body:"IBM Plex Sans", "Segoe UI", sans-serif;--font-mono:"IBM Plex Mono", "Consolas", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.375rem;--text-2xl:1.75rem;--text-3xl:2.25rem;--text-4xl:3rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius:4px;--transition-fast:.15s ease;--transition-normal:.2s ease;--sidebar-width:240px;--header-height:56px;--max-content:1200px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--ink);background-color:var(--paper);line-height:1.5}h1,h2,h3{font-family:var(--font-display);color:var(--ink);font-weight:600;line-height:1.25}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}a{color:var(--ink);text-decoration:underline;-webkit-text-decoration-color:var(--ledger-line);text-decoration-color:var(--ledger-line);text-underline-offset:2px;transition:color var(--transition-fast)}a:hover{color:var(--stamp-red);-webkit-text-decoration-color:var(--stamp-red);text-decoration-color:var(--stamp-red)}:focus-visible{outline:2px solid var(--ink);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.text-muted{color:var(--ink-muted)}.text-red{color:var(--stamp-red)}.text-amber{color:var(--stamp-amber)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.login-page{min-height:100vh;padding:var(--space-4);background-color:var(--paper);background-image:repeating-linear-gradient(#0000,#0000 31px,#c3d9c84d 31px 32px);justify-content:center;align-items:center;display:flex}.login-card{border:1px solid var(--ledger-line);border-radius:var(--radius);width:100%;max-width:380px;padding:var(--space-8) var(--space-6);background:#fff}.login-logo{text-align:center;margin-bottom:var(--space-6);color:var(--ink)}.login-title{font-family:var(--font-display);font-size:var(--text-xl);text-align:center;letter-spacing:.08em;margin-bottom:var(--space-1)}.login-subtitle{text-align:center;color:var(--ink-muted);font-size:var(--text-sm);margin-bottom:var(--space-8)}.login-error{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);color:var(--stamp-red);background-color:var(--stamp-red-15);border:1px solid var(--stamp-red);border-radius:var(--radius)}.login-form{gap:var(--space-5);flex-direction:column;display:flex}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--ink-muted);font-weight:500}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-md);color:var(--ink);border:1px solid var(--ledger-line);border-radius:var(--radius);transition:border-color var(--transition-fast);background-color:#fff}.form-input::placeholder{color:var(--ink-muted);opacity:.6}.form-input:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 2px #16263a1f}.form-input:hover:not(:focus){border-color:#9bbaa2}.form-input:disabled{opacity:.6;cursor:not-allowed}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-body);font-size:var(--text-base);border-radius:var(--radius);cursor:pointer;transition:background-color var(--transition-fast);border:1px solid #0000;font-weight:500;line-height:1.5;text-decoration:none;display:inline-flex}.btn-primary{background-color:var(--ink);color:var(--paper);border-color:var(--ink)}.btn-primary:hover{background-color:#1e3450}.btn:disabled{opacity:.45;cursor:not-allowed}.login-submit{width:100%;margin-top:var(--space-2)}.login-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm)}@media (width<=480px){.login-card{padding:var(--space-6) var(--space-4)}}.loading-screen{background:var(--paper);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-success{padding:var(--space-4);margin-bottom:var(--space-4);border:1px solid var(--ledger-line);border-radius:var(--radius);background:var(--paper)}.admin-layout{background:var(--paper);min-height:100vh;display:flex}.admin-sidebar{background:var(--ink);width:260px;color:var(--paper);border-right:1px solid var(--ink-05);flex-direction:column;flex-shrink:0;display:flex}.admin-sidebar__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid #ffffff1a}.admin-sidebar__logo{align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:.05em;font-weight:600;display:flex}.admin-sidebar__nav{padding:var(--space-6) 0;gap:var(--space-1);flex-direction:column;display:flex}.nav-group{padding:var(--space-4) var(--space-6) var(--space-2);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--stamp-gray);font-weight:600}.nav-item{padding:var(--space-2) var(--space-6);color:#ccc;font-size:var(--text-sm);border-left:3px solid #0000;text-decoration:none;transition:all .15s}.nav-item:hover{color:#fff;background:#ffffff0d}.nav-item.active{color:#fff;border-left-color:var(--stamp-red);background:#ffffff1a;font-weight:500}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-topbar{padding:var(--space-3) var(--space-6);border-bottom:1px solid var(--ledger-line);background:#fff;justify-content:space-between;align-items:center;height:64px;display:flex}.admin-topbar__title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--ink);font-weight:600}.admin-topbar__right{align-items:center;gap:var(--space-4);display:flex}.admin-profile-info{flex-direction:column;align-items:flex-end;line-height:1.2;display:flex}.admin-name{font-size:var(--text-sm);color:var(--ink);font-weight:600}.admin-role{font-size:var(--text-xs);color:var(--ink-muted)}.admin-content-area{padding:var(--space-6);flex:1;overflow-y:auto}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--ink);margin-bottom:var(--space-6);font-weight:600}.section-label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:var(--space-3);font-weight:600}.divider--double{border-top:3px double var(--ledger-line);margin-bottom:var(--space-5)}.placeholder-box{padding:var(--space-8);border:1px dashed var(--ledger-line);border-radius:var(--radius);text-align:center}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.page-header .page-title{margin-bottom:0}.table-container{border:1px solid var(--ledger-line);border-radius:var(--radius);background:#fff;max-height:calc(100vh - 200px);overflow:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:var(--text-sm)}.data-table th,.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--ledger-line)}.data-table th{background:var(--paper);color:var(--ink-muted);text-transform:uppercase;font-weight:600;font-size:var(--text-xs);letter-spacing:.05em;z-index:10;border-bottom:2px solid var(--ledger-line);position:sticky;top:0}.data-table tbody tr:nth-child(2n){background:#00000005}.data-table tbody tr:hover{background:#0000000a}.data-table td.numeric{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}.data-table th.numeric{text-align:right}.font-medium{color:var(--ink);font-weight:500}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.text-center{text-align:center}.btn-link{color:var(--ink-muted);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.btn-link:hover{color:var(--ink)}.badge{text-transform:uppercase;letter-spacing:.05em;border:1px solid #0000;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-active{color:var(--stamp-red);border-color:var(--stamp-red);background:#a8342f0d}.badge-inactive{color:var(--stamp-gray);border-color:var(--stamp-gray);background:#8a8f870d}.alert-error{padding:var(--space-3) var(--space-4);color:#856404;border-radius:var(--radius);margin-bottom:var(--space-4);background:#fff3cd;border:1px solid #ffeeba}.student-page{background:var(--paper);min-height:100vh}.student-topbar{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--ledger-line);z-index:50;background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.student-topbar__title{font-family:var(--font-display);font-size:var(--text-md);font-weight:600}.student-content{max-width:600px;padding:var(--space-4);margin:0 auto}.student-profile{padding:var(--space-4) 0;border-bottom:1px solid var(--ledger-line);margin-bottom:var(--space-5)}.student-profile__name{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600}.student-profile__meta{font-size:var(--text-sm);color:var(--ink-muted)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}
