*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--orange:#e8620a;--orange-lt:#fdf0e8;--orange-dk:#c4530a;--dark:#1c1c2e;--mid:#6b6b7e;--muted:#9393a3;--surface:#f7f7f9;--white:#fff;--border:#e5e5ea;--radius:14px;--radius-sm:9px;--font:"Outfit",system-ui,sans-serif;--mono:"Space Mono",monospace}body{font-family:var(--font);background:var(--surface);color:var(--dark);min-height:100vh;-webkit-font-smoothing:antialiased}.hdr{background:var(--white);border-bottom:1px solid var(--border);padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.hdr-in{max-width:960px;margin:0 auto;height:58px;gap:13px}.hdr-in,.logo{display:flex;align-items:center}.logo{flex-shrink:0;border-radius:50%;justify-content:center;overflow:hidden}.logo,.logo img{width:40px;height:40px}.logo img{object-fit:contain;display:block}.hdr-title{font-size:15px;font-weight:600;flex:1 1;line-height:1.3}.hdr-sub{font-size:11px;color:var(--muted);font-weight:400}.mode-pill{font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px;cursor:pointer;border:none;font-family:var(--font);letter-spacing:.3px;text-transform:uppercase}.mode-pill.teacher{background:var(--orange-lt);color:var(--orange)}.mode-pill.parent{background:#eaf3de;color:#27500a;cursor:default}.main{max-width:960px;margin:0 auto;padding:24px 16px 48px}.layout{display:flex;gap:16px;align-items:flex-start}.content{flex:1 1;min-width:0}.sidebar{width:210px;flex-shrink:0;background:var(--white);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;align-self:flex-start;position:-webkit-sticky;position:sticky;top:74px;max-height:calc(100vh - 90px);overflow-y:auto}.sb-head{padding:10px 12px;border-bottom:1px solid var(--border)}.sb-search{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:var(--font);outline:none;color:var(--dark);background:var(--surface)}.sb-search:focus{border-color:var(--orange)}.sb-group-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;padding:8px 12px 4px;display:block}.sb-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;transition:background .1s;border:none;background:none;width:100%;text-align:left;font-family:var(--font)}.sb-item:hover{background:var(--surface)}.sb-item.active{background:var(--orange-lt)}.sb-iname{font-size:13px;font-weight:500;color:var(--dark)}.sb-item.active .sb-iname{color:var(--orange)}.sb-pts{font-family:var(--mono);font-size:11px;color:var(--muted)}.sb-item.active .sb-pts{color:var(--orange);opacity:.7}.sb-row{display:flex;align-items:center}.sb-row .sb-item{flex:1 1;border-radius:0}.sb-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:0 10px 0 4px;opacity:0;transition:opacity .15s;flex-shrink:0;line-height:1}.sb-row:hover .sb-del{opacity:.5}.sb-del:hover{opacity:1!important;color:#e24b4a}.sb-add{display:block;width:100%;padding:10px 12px;text-align:center;font-size:12px;color:var(--muted);cursor:pointer;border:none;background:none;font-family:var(--font);border-top:1px solid var(--border);transition:background .1s}.sb-add:hover{background:var(--surface);color:var(--orange)}.sb-data-tools{border-top:1px solid var(--border);padding:8px;display:flex;gap:6px}.sb-data-btn{flex:1 1;padding:6px 4px;font-size:11px;color:var(--muted);cursor:pointer;border:1px solid var(--border);border-radius:6px;background:none;font-family:var(--font);transition:all .15s;text-align:center}.sb-data-btn:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-lt)}.stu-card{gap:14px;margin-bottom:16px;padding:16px 18px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border)}.avatar,.stu-card{display:flex;align-items:center}.avatar{width:46px;height:46px;border-radius:50%;background:var(--orange-lt);color:var(--orange);justify-content:center;font-size:18px;font-weight:600;flex-shrink:0}.stu-info{flex:1 1;min-width:0}.stu-name{font-size:18px;font-weight:600;color:var(--dark)}.stu-name,.stu-sub{border:none;outline:none;background:transparent;font-family:var(--font);width:100%}.stu-sub{font-size:12px;color:var(--mid);margin-top:2px}.sel-grp{margin-top:3px;font-size:12px;border:none;outline:none;background:transparent;font-family:var(--font);color:var(--muted);cursor:pointer}.score-hdr{text-align:right;flex-shrink:0}.score-num{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--dark);line-height:1}.score-lbl{font-size:10px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.5px}.sbtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;align-items:center}.sbtab{padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:var(--white);color:var(--mid);font-family:var(--font);transition:all .15s}.sbtab:hover{border-color:var(--orange);color:var(--orange)}.sbtab.active{background:var(--orange);border-color:var(--orange);color:#fff}.sbtab.done{border-style:dashed;opacity:.6}.sbtab.done.active{opacity:1}.sbtab-add{padding:6px 12px;border-radius:20px;font-size:12px;cursor:pointer;border:1.5px dashed var(--border);background:transparent;color:var(--muted);font-family:var(--font);transition:all .15s}.sbtab-add:hover{border-color:var(--orange);color:var(--orange)}.sb-meta{display:flex;gap:16px;align-items:center;padding:12px 16px;background:var(--surface);border-radius:var(--radius-sm);margin-bottom:16px;flex-wrap:wrap}.sbm-item{display:flex;flex-direction:column;gap:3px}.sbm-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.sbm-val{font-weight:500}.date-in,.sbm-val{font-size:13px;color:var(--dark)}.date-in{border:1px solid var(--border);border-radius:6px;padding:3px 7px;outline:none;font-family:var(--font);background:var(--white);cursor:pointer}.date-in:focus{border-color:var(--orange)}.sb-name-in{font-size:14px;font-weight:600;border:none;border-bottom:1px solid var(--border);outline:none;background:transparent;font-family:var(--font);color:var(--dark);width:130px;padding:1px 0}.weeks-pill{font-size:12px;font-weight:600;padding:4px 12px;border-radius:20px;background:var(--orange-lt);color:var(--orange);white-space:nowrap}.sbm-del{margin-left:auto;background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;font-family:var(--font)}.sbm-del:hover{color:#e24b4a}.song{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:10px;overflow:hidden}.song-hdr{display:flex;align-items:center;gap:10px;padding:13px 15px;cursor:pointer;transition:background .1s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.song-hdr:hover{background:var(--surface)}.song-num{font-family:var(--mono);font-size:11px;color:var(--muted);width:20px;flex-shrink:0}.song-title{flex:1 1;font-size:15px;font-weight:600;border:none;outline:none;background:transparent;font-family:var(--font);color:var(--dark)}.song-pts{font-family:var(--mono);font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px}.song-del{background:none;border:none;color:var(--mid);cursor:pointer;font-size:16px;padding:0 4px;opacity:0;transition:opacity .15s}.song:hover .song-del{opacity:.4}.song-del:hover{opacity:1!important}.song-chev{font-size:10px;color:var(--muted)}.sec{padding:13px 15px}.sec-top{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.sec-name{font-size:13px;font-weight:600;border:none;outline:none;background:transparent;font-family:var(--font);color:var(--dark);min-width:70px}.trow{display:flex;gap:3px;flex-wrap:wrap;align-items:center}.tbtn{padding:2px 7px;border-radius:6px;font-family:var(--mono);font-weight:700;cursor:pointer;border:1px solid var(--border);background:transparent;transition:all .1s}.tbtn,.tlabel{font-size:11px;color:var(--mid)}.tlabel{margin-left:3px}.sec-score{margin-left:auto;font-family:var(--mono);font-size:21px;font-weight:700;flex-shrink:0;line-height:1}.sec-pts{font-size:11px;opacity:.6}.sec-del{background:none;border:none;color:var(--mid);cursor:pointer;font-size:14px;opacity:0;transition:opacity .15s;flex-shrink:0}.sec:hover .sec-del{opacity:.4}.sec-del:hover{opacity:1!important}.stages{display:flex;gap:3px;flex-wrap:wrap}.stbtn{padding:4px 9px;border-radius:6px;font-family:var(--mono);font-size:11px;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--mid);transition:all .1s;min-width:38px;text-align:center}.skills-in{color:var(--mid);border:none;outline:none;background:transparent;border-bottom:1px solid var(--border);padding:5px 0;margin-top:8px}.add-sec-btn,.skills-in{width:100%;font-size:12px;font-family:var(--font)}.add-sec-btn{display:block;padding:10px;text-align:center;color:var(--muted);cursor:pointer;border:none;background:none;border-top:1px solid var(--border);transition:background .1s}.add-sec-btn:hover{background:var(--surface)}.add-song{width:100%;padding:14px;border:1.5px dashed var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);font-size:14px;cursor:pointer;font-family:var(--font);transition:all .15s;margin-top:4px}.add-song:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-lt)}.share-row{display:flex;align-items:center;gap:10px;margin-top:18px;padding:11px 15px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface)}.share-url{flex:1 1;font-family:var(--mono);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--dark)}.copy-btn{padding:6px 13px;border-radius:6px;font-size:12px;font-family:var(--font);cursor:pointer;border:1px solid var(--border);background:var(--white);color:var(--dark);flex-shrink:0;transition:all .15s;font-weight:500}.copy-btn:hover{background:var(--orange);border-color:var(--orange);color:#fff}.copy-btn.ok{background:#1d9e75;border-color:#1d9e75;color:#fff}.overlay{position:fixed;inset:0;background:rgba(28,28,46,.65);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--white);border-radius:var(--radius);padding:36px 32px;max-width:360px}.modal,.pin-in{width:100%;text-align:center}.pin-in{padding:13px 16px;font-size:26px;font-family:var(--mono);border:1.5px solid var(--border);border-radius:var(--radius-sm);letter-spacing:8px;outline:none;margin-bottom:13px;color:var(--dark);transition:border-color .15s}.pin-in:focus{border-color:var(--orange)}.pin-in.err{border-color:#e24b4a;animation:shake .3s ease}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}.pin-go{width:100%;padding:13px;background:var(--orange);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer}.pin-go:hover{background:var(--orange-dk)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:65vh;gap:16px;color:var(--mid);font-size:14px}.spin{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.guide{margin-top:24px;padding:20px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border)}.guide-h{font-size:14px;font-weight:600;margin-bottom:10px}.guide-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:16px}.guide-band{padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:600}.t-guide{display:flex;align-items:baseline;gap:10px;margin-bottom:7px;font-size:13px}@media (max-width:680px){.layout{flex-direction:column}.sidebar{width:100%;position:static;max-height:none}.main{padding:16px 10px 40px}.stages{gap:2px}.stbtn{font-size:10px;padding:3px 6px;min-width:32px}}