@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:wght@300;400;500;600&display=swap";.app-wrap{max-width:900px;margin:0 auto;padding:0 1rem 5rem}.app-header{border-bottom:.5px solid var(--border2);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 0;display:flex}.app-title{letter-spacing:-.01em;color:var(--text);white-space:nowrap;font-size:18px;font-weight:300}.app-title span{font-weight:600}.app-title-dot{background:var(--accent);vertical-align:middle;border-radius:50%;width:5px;height:5px;margin-left:3px;display:inline-block;position:relative;top:-2px}.app-nav{background:var(--surface3);border:.5px solid var(--border2);border-radius:99px;gap:2px;padding:3px;display:flex}.nav-btn{color:var(--muted);white-space:nowrap;background:0 0;border:none;border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500}.nav-btn:hover{color:var(--text)}.nav-active{box-shadow:var(--shadow-sm);background:var(--surface)!important;color:var(--text)!important}.user-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.user-license{font-family:var(--mono);color:var(--accent);background:var(--accent-light);border-radius:99px;padding:3px 10px;font-size:11px;font-weight:500}.user-email{font-family:var(--mono);color:var(--muted);background:var(--surface3);border-radius:99px;padding:4px 10px;font-size:12px}.btn-signout{border:.5px solid var(--border2);color:var(--muted);background:0 0;border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500}.btn-signout:hover{background:var(--surface3);color:var(--text)}.card{background:var(--surface);border:.5px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1.25rem}.page-title{letter-spacing:-.01em;margin-bottom:.2rem;font-size:18px;font-weight:600}.page-sub{color:var(--muted);margin-bottom:1.5rem;font-size:13px}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin:1.5rem 0 .75rem;display:flex}.section-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--hint);font-size:11px;font-weight:400}.btn-primary{background:var(--accent);color:#fff;white-space:nowrap;border:none;border-radius:99px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:500;display:inline-flex;box-shadow:0 1px 3px #1a5fa84d}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-sm{background:var(--surface);border:.5px solid var(--border2);color:var(--muted);box-shadow:var(--shadow-sm);white-space:nowrap;border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500}.btn-sm:hover{background:var(--surface3);color:var(--text)}.btn-cancel{background:var(--surface2);border:.5px solid var(--border2);color:var(--muted);border-radius:99px;padding:8px 16px;font-size:13px;font-weight:500}.btn-cancel:hover{background:var(--surface3);color:var(--text)}.btn-delete{color:var(--red);white-space:nowrap;background:0 0;border:.5px solid #a12c2c40;border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500}.btn-delete:hover{background:var(--red-light);border-color:var(--red)}.req-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (width>=560px){.req-grid{grid-template-columns:repeat(4,1fr)}}.req-item{background:var(--bg);border:.5px solid var(--border2);border-radius:var(--radius-sm);padding:.875rem 1rem}.req-label{color:var(--hint);font-size:10px;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.09em;margin-bottom:6px}.req-nums{align-items:baseline;gap:4px;margin-bottom:6px;display:flex}.req-earned{font-size:22px;font-weight:300;font-family:var(--mono);letter-spacing:-.02em;line-height:1}.req-total{color:var(--hint);font-size:11px;font-family:var(--mono)}.bar-track{background:var(--border2);border-radius:99px;height:3px;margin-bottom:6px;overflow:hidden}.bar-fill{border-radius:99px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.badge{font-size:10px;font-weight:500;font-family:var(--mono);letter-spacing:.02em;border-radius:99px;align-items:center;padding:3px 8px;display:inline-flex}.badge-ok{background:var(--green-light);color:var(--green)}.badge-warn{background:var(--amber-light);color:var(--amber)}.badge-danger{background:var(--red-light);color:var(--red)}.credit-chip{font-family:var(--mono);background:var(--accent-light);color:var(--accent);white-space:nowrap;letter-spacing:.02em;border-radius:99px;padding:3px 9px;font-size:11px;font-weight:500}.ethics-chip{background:var(--amber-light);color:var(--amber)}.subject-pill{border:.5px solid var(--border2);color:var(--muted);background:var(--surface2);white-space:nowrap;border-radius:99px;padding:3px 9px;font-size:11px;font-weight:500}.period-pill{background:var(--surface3);color:var(--muted);font-size:11px;font-weight:500;font-family:var(--mono);white-space:nowrap;border-radius:99px;padding:3px 9px}.alert-banner{border-radius:var(--radius-sm);border:.5px solid;align-items:flex-start;gap:10px;margin-bottom:10px;padding:12px 16px;font-size:13px;display:flex}.alert-warn{background:var(--amber-light);color:var(--amber);border-color:var(--amber)}.alert-danger{background:var(--red-light);color:var(--red);border-color:var(--red)}.log-table-wrap{background:var(--surface);border:.5px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.log-table{border-collapse:collapse;width:100%;font-size:13px}.log-table th{text-align:left;font-family:var(--mono);text-transform:uppercase;letter-spacing:.09em;color:var(--hint);border-bottom:.5px solid var(--border2);background:var(--bg);padding:10px 14px;font-size:10px;font-weight:400}.log-table td{border-bottom:.5px solid var(--border);vertical-align:middle;padding:11px 14px}.log-table tr:last-child td{border-bottom:none}.log-table tbody tr{transition:background .1s}.log-table tbody tr:hover td{background:var(--surface2)}.empty-state{text-align:center;color:var(--hint);font-size:13px;font-family:var(--mono);padding:3rem 1rem}.course-cards{display:none}@media (width<=680px){.log-table-wrap table{display:none}.course-cards{flex-direction:column;display:flex}.course-card{border-bottom:.5px solid var(--border);padding:1rem}.course-card:last-child{border-bottom:none}.course-card-title{margin-bottom:2px;font-size:14px;font-weight:500}.course-card-meta{color:var(--muted);margin-bottom:8px;font-size:12px}.course-card-chips{flex-wrap:wrap;gap:5px;margin-bottom:10px;display:flex}.course-card-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0006;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=560px){.modal-backdrop{align-items:center;padding:1rem}}.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;border:.5px solid var(--border2);width:100%;max-width:100%;max-height:92vh;box-shadow:var(--shadow);padding:1.5rem 1.25rem;animation:.22s modal-in-mobile;overflow-y:auto}@media (width>=560px){.modal{border-radius:var(--radius);max-width:520px;animation:.18s modal-in}}@keyframes modal-in-mobile{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{letter-spacing:-.01em;margin-bottom:.25rem;font-size:17px;font-weight:600}.form-row{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}@media (width<=400px){.form-row{grid-template-columns:1fr}}.form-group{flex-direction:column;gap:5px;margin-bottom:12px;display:flex}.form-group label{font-size:11px;font-weight:600;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group select,.form-group textarea{border:.5px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;width:100%;padding:8px 11px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-mid);box-shadow:0 0 0 3px #3a8ade1f}.form-hint{color:var(--hint);font-size:11px;font-family:var(--mono);margin-top:2px}.modal-actions{border-top:.5px solid var(--border);justify-content:flex-end;gap:8px;margin-top:1.25rem;padding-top:1rem;display:flex}.credit-cat-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.settings-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (width<=480px){.settings-grid{grid-template-columns:1fr}}.settings-section-title{font-size:12px;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.09em;color:var(--hint);border-bottom:.5px solid var(--border2);margin-bottom:1rem;padding-bottom:8px}.history-filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.history-filters input,.history-filters select{border:.5px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;padding:7px 11px;font-size:13px}.history-filters input{flex:1;min-width:160px}.login-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--surface);border:.5px solid var(--border2);border-radius:var(--radius);text-align:center;width:100%;max-width:340px;box-shadow:var(--shadow);padding:2.5rem 2rem}.login-title{letter-spacing:-.02em;margin-bottom:.25rem;font-size:22px;font-weight:300}.login-title span{font-weight:600}.login-sub{color:var(--muted);font-size:12px;font-family:var(--mono);letter-spacing:.04em;margin-bottom:2rem}.btn-google{border:.5px solid var(--border2);background:var(--surface);width:100%;color:var(--text);box-shadow:var(--shadow-sm);border-radius:99px;justify-content:center;align-items:center;gap:10px;padding:11px 16px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.btn-google:hover{background:var(--surface2);transform:translateY(-1px)}.mobile-nav{background:var(--surface);border-top:.5px solid var(--border2);padding:.5rem 1rem calc(.5rem + env(safe-area-inset-bottom));z-index:50;justify-content:space-around;display:none;position:fixed;bottom:0;left:0;right:0}@media (width<=600px){.app-nav{display:none}.mobile-nav{display:flex}.user-row .user-email,.user-row .user-license{display:none}.app-wrap{padding-bottom:6rem}}.mobile-nav-btn{font-size:10px;font-weight:500;font-family:var(--mono);color:var(--muted);border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:6px 16px;display:flex}.mobile-nav-btn.active{color:var(--accent)}.mobile-nav-icon{font-size:20px;line-height:1}@media print{.app-header,.app-nav,.mobile-nav,.btn-sm,.btn-delete,.btn-primary,.btn-cancel,.no-print{display:none!important}body{color:#000;background:#fff}.app-wrap{max-width:100%;padding:0}.card,.log-table-wrap{box-shadow:none;border:1px solid #ddd}.print-header{margin-bottom:1.5rem;display:block!important}}.print-header{display:none}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0ede8;--surface:#faf9f7;--surface2:#f0ede8;--surface3:#e8e4de;--border:#00000012;--border2:#00000021;--text:#1c1b18;--muted:#6b6660;--hint:#a09b95;--accent:#1a5fa8;--accent-hover:#154d8a;--accent-light:#e8f0fb;--accent-mid:#3a8ade;--green:#3a6b10;--green-light:#e8f3dc;--amber:#84500c;--amber-light:#faeedd;--red:#a12c2c;--red-light:#fbeaea;--radius:12px;--radius-sm:7px;--radius-xs:4px;--mono:"DM Mono", monospace;--sans:"DM Sans", sans-serif;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow:0 2px 8px #00000014, 0 1px 3px #0000000d}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:15px;line-height:1.6}button{cursor:pointer;font-family:var(--sans);transition:all .15s}input,select,textarea{font-family:var(--sans)}@media (width<=768px){input,select,textarea{font-size:16px!important}}
