:root{--bg: #1e1e2e;--bg2: #313244;--bg3: #45475a;--fg: #cdd6f4;--fg2: #a6adc8;--green: #a6e3a1;--red: #f38ba8;--yellow: #fab387;--purple: #cba6f7;--blue: #89b4fa;--gray: #6c7086}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif}body{font-size:14px}.app{display:flex;flex-direction:column;height:100vh}.bar{display:flex;gap:6px;align-items:center;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--bg3);flex-wrap:wrap}.btn{padding:6px 14px;border:0;border-radius:4px;background:var(--bg2);color:var(--fg);cursor:pointer;font-weight:600;font-size:11px}.btn:hover{filter:brightness(1.2)}.btn.primary{background:var(--green);color:var(--bg)}.btn.warn{background:var(--yellow);color:var(--bg)}.btn.danger{background:var(--bg2);color:var(--red)}.btn.active{background:var(--blue);color:var(--bg)}.btn:disabled{opacity:.4;cursor:not-allowed}.spacer{flex:1}.counter{color:var(--fg2);font-size:13px}.header{padding:10px 14px;background:var(--bg);font-weight:700;font-size:13px;border-bottom:1px solid var(--bg3)}.result{padding:10px 14px;background:#181825;font-size:12px;border-bottom:1px solid var(--bg3);min-height:24px}.views{flex:1;display:flex;overflow:hidden;padding:6px 10px}.panel{background:var(--bg2);border-radius:6px;display:flex;flex-direction:column;margin:0 4px;flex:1;overflow:hidden}.panel-title{background:var(--bg3);color:var(--purple);padding:6px 10px;font-size:11px;font-weight:700}.panel-title.student{color:var(--blue)}.panel-img{flex:1;min-height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg2);overflow:hidden;padding:4px}.panel-img img{max-width:100%;max-height:100%;object-fit:contain}.panel-img .placeholder{color:var(--fg2);font-size:13px}.panel-name{color:var(--fg2);padding:4px 8px;font-size:11px;text-align:center;border-top:1px solid var(--bg3)}.panel-desc{background:#181825;color:var(--fg2);padding:8px 10px;font-size:11px;line-height:1.4;max-height:40%;overflow:auto;white-space:pre-wrap;font-family:-apple-system,Helvetica,sans-serif;border-top:1px solid var(--bg3)}.tab{display:flex;gap:4px;padding:8px 14px;border-bottom:1px solid var(--bg3)}.tab button{padding:4px 12px;background:transparent;color:var(--fg2);border:0;cursor:pointer;font-size:12px}.tab button.active{color:var(--fg);border-bottom:2px solid var(--blue)}.table-wrap{padding:14px;overflow:auto}table{width:100%;border-collapse:collapse;font-size:12px}th,td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--bg3)}th{color:var(--fg2);font-weight:600}td.grade{color:var(--green);font-weight:700;text-align:right}td.grade.fail{color:var(--red)}.label{color:var(--fg2);font-size:11px}.input{background:var(--bg2);color:var(--fg);border:1px solid var(--bg3);border-radius:4px;padding:4px 8px;font-size:12px}.checkbox{accent-color:var(--blue)}.course-badge{font-size:11px;color:var(--green);background:var(--bg2);padding:3px 8px;border-radius:4px}.course-badge.warn{color:var(--red)}.course-active-row td{color:var(--green)}.add-course-form{display:flex;gap:8px;align-items:center;padding:12px;background:var(--bg2);border-radius:6px;margin-top:12px;flex-wrap:wrap}
