:root{color:#17202a;background:#f5f7fb;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select{font:inherit}.center{color:#53606f;place-items:center;min-height:100vh;display:grid}.login-page{background:linear-gradient(135deg,#edf7f6 0%,#f8fafc 45%,#fff7e1 100%);place-items:center;min-height:100vh;display:grid}.login-panel{background:#fff;border:1px solid #e5e7eb;border-radius:8px;gap:16px;width:min(420px,100vw - 32px);padding:28px;display:grid;box-shadow:0 22px 70px #1f29371f}.brand,.sidebar-brand,.topbar,.section-title{align-items:center;gap:12px;display:flex}.brand h1,.hero-band h1{margin:0}.brand p,.topbar p,.hero-band p,.level p{color:#667085;margin:4px 0 0}.brand-mark{color:#fff;background:#216869;border-radius:8px;flex:none;place-items:center;width:48px;height:48px;display:grid}label,.panel-form{gap:8px;display:grid}input,select{background:#fff;border:1px solid #d0d5dd;border-radius:6px;width:100%;padding:10px 12px}.primary,.secondary,.icon-button,.nav{cursor:pointer;border:0}.primary{color:#fff;background:#216869;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:10px 14px;text-decoration:none;display:inline-flex}.secondary{color:#334155;background:#edf2f7;border-radius:6px;padding:8px 10px}.icon-button{color:#344054;background:#edf2f7;border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.error{color:#b42318;background:#fffbfa;border:1px solid #fecdca;border-radius:6px;padding:10px 12px}.inline{margin-bottom:16px}.app-shell{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{color:#f9fafb;background:#111827;flex-direction:column;gap:8px;padding:20px 14px;display:flex}.sidebar-brand{padding:0 8px 18px;font-weight:700}.nav{color:#d1d5db;text-align:left;background:0 0;border-radius:6px;align-items:center;gap:10px;width:100%;padding:11px 12px;display:flex}.nav.active,.nav:hover{color:#fff;background:#1f2937}.logout{margin-top:auto}.workspace{padding:24px;overflow-x:auto}.topbar{justify-content:space-between;margin-bottom:22px}.topbar h2{margin:0}.stack{gap:18px;display:grid}.hero-band{color:#fff;background-color:#0000;background-image:linear-gradient(90deg,#111827e0,#216869c7),url(/static/skillmap/backgrounds/beg-comp.png);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border-radius:8px;justify-content:space-between;align-items:center;gap:20px;min-height:220px;padding:28px;display:flex}.hero-band p{color:#e5e7eb;max-width:560px}.eyebrow{color:#f2c14e;font-weight:700}.progress-ring{--progress:0%;aspect-ratio:1;background:conic-gradient(#f2c14e var(--progress), #fff3 0);border-radius:50%;flex:none;place-items:center;width:116px;font-size:24px;font-weight:800;display:grid}.level-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;display:grid}.level{background:#fff;border:1px solid #e5e7eb;border-radius:8px;gap:8px;min-height:146px;padding:16px;display:grid}.level h3{margin:0;font-size:17px}.level-index{color:#216869;font-weight:800}.level span{color:#53606f;font-size:14px}.level.completed{background:#f0fdfa;border-color:#8fd3c7}.level.in_progress{background:#fffdf2;border-color:#f2c14e}.split{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:18px;display:grid}.panel-stack{gap:18px;display:grid}.panel-form,.split>section,.stack>table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.panel-form h3,.section-title h3{margin:0}.section-title{justify-content:space-between;margin-bottom:12px}.section-title.compact{margin-bottom:0}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.hint{color:#667085;margin:0;font-size:14px;line-height:1.5}.pill{color:#216869;background:#edf7f6;border-radius:999px;justify-content:center;align-items:center;min-width:46px;min-height:26px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.result-panel{gap:14px}.generated-meta{color:#216869;font-weight:700}.result-table{overflow-x:auto}code{font-family:Cascadia Code,SFMono-Regular,Consolas,monospace;font-size:13px}table{border-collapse:collapse;background:#fff;width:100%}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid #edf2f7;padding:11px 10px}th{color:#475467;font-weight:700}td small{color:#667085;margin-top:2px;display:block}.class-list{gap:10px;display:grid}.class-row{border:1px solid #edf2f7;border-radius:6px;grid-template-columns:1fr auto auto;align-items:center;gap:16px;padding:12px;display:grid}.wide-select{max-width:360px}.mini-bars{grid-template-columns:repeat(20,minmax(8px,1fr));gap:3px;display:grid}.mini-bars span{background:#e5e7eb;border-radius:3px;height:18px}.mini-bars .doing{background:#f2c14e}.mini-bars .done{background:#216869}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:2;flex-direction:row;position:sticky;top:0;overflow-x:auto}.sidebar-brand{display:none}.nav{white-space:nowrap;width:auto}.logout{margin-top:0;margin-left:auto}.split,.form-grid{grid-template-columns:1fr}.hero-band{flex-direction:column;align-items:flex-start}}
