:root{--bg: #e8dfc9;--panel: #f8f1df;--paper: #fdf8ea;--ink: #3a2d1c;--muted: #7a6a50;--accent: #8b5a2b;--accent-ink: #ffffff;--ok: #5d6b3e;--err: #9a3b2e;--border: #d8c9a8}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Georgia,Palatino Linotype,Book Antiqua,serif;background:var(--bg);background-image:radial-gradient(ellipse at 18% 0%,rgba(255,250,235,.5),transparent 60%),radial-gradient(ellipse at 82% 100%,rgba(120,90,50,.06),transparent 55%);color:var(--ink)}button,input,select,textarea{font-family:Segoe UI,system-ui,sans-serif}.app{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:baseline;gap:8px;text-decoration:none;color:inherit}.brand-mark{font-size:22px;color:var(--accent)}.brand-name{font-size:20px;font-weight:700;letter-spacing:.3px}.brand-tag{font-size:12px;color:var(--muted)}.actions{display:flex;gap:8px;flex-wrap:wrap}.mainnav{display:flex;gap:4px;margin-left:12px;margin-right:auto}.mainnav a{padding:6px 12px;border-radius:8px;text-decoration:none;color:var(--muted);font-size:13px}.mainnav a:hover{color:var(--accent);background:#eef3ff}.mainnav a.active{color:var(--accent);background:#e8f0ff;font-weight:600}.authbox{display:flex;align-items:center;gap:10px}.username{font-size:13px;font-weight:600}.btn.small{text-decoration:none;display:inline-block}.btn.accent{background:var(--ok);border-color:var(--ok);color:#fff}.btn.accent:hover:not(:disabled){color:#fff;filter:brightness(1.08)}.btn.danger{color:var(--err);border-color:#e4b6b3}.btn.danger:hover:not(:disabled){background:var(--err);border-color:var(--err);color:#fff}.workbench{display:flex;flex-direction:column;flex:1;min-height:0}.actionsbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:5px 18px;background:var(--panel);border-bottom:1px solid var(--border)}.actionsbar .spacer{flex:1}.owner-panel{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}.owner-label{font-weight:600}.owner-panel select,.controls select{padding:5px 8px;border:1px solid var(--border);border-radius:7px;background:var(--panel);font-size:12px}.btn.active-edit{background:#fff3e0;border-color:#e8a33d;color:#9a6200;font-weight:600}.palette{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:6px 18px;background:#fffaf0;border-bottom:1px solid #f0dcb8;font-size:12px}.pal-group{display:flex;align-items:center;gap:4px}.pal-group+.pal-group{border-left:1px solid #eadfc8;padding-left:16px}.pal-group select{padding:3px 6px;border:1px solid var(--border);border-radius:6px;background:var(--panel);font-size:11px}.pal-help{margin-left:auto;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;cursor:help}.sheet.editing{outline:2px solid #e8a33d;outline-offset:-2px;cursor:text}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f192873;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--panel);border-radius:14px;padding:24px;width:min(560px,92vw);max-height:88vh;overflow:auto;box-shadow:0 18px 60px #0a142859}.modal h2{margin:0 0 16px;font-size:18px}.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.modal-grid input,.modal-grid select{padding:7px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px}.timesig-inputs{display:flex;align-items:center;gap:6px}.timesig-inputs input{width:60px}.instrument-list{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px 14px}.list-title{width:100%;font-size:12px;color:var(--muted);font-weight:600}.instrument-item{display:flex;align-items:center;gap:5px;font-size:13px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.presence{background:#eafaf0;color:var(--ok);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.sync{font-size:12px;padding:2px 8px;border-radius:12px;white-space:nowrap}.sync-saving{color:var(--accent);background:#e8f0ff}.sync-saved{color:var(--ok);background:#eafaf0}.sync-dirty{color:#8a6100;background:#fff3d6}.sync-idle{color:var(--muted)}.lockbanner{font-size:12px;padding:2px 8px;border-radius:12px;background:#fde7e5;color:var(--err);font-weight:600}.btn.small.on{background:var(--accent);border-color:var(--accent);color:#fff}.score-area.with-comments{gap:18px;align-items:flex-start}.sheet.commenting{cursor:crosshair}.comments-panel{width:320px;flex-shrink:0;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px;max-height:80vh;overflow:auto;position:sticky;top:110px}.comments-panel h3{margin:0 0 10px;font-size:15px}.comment-list{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:8px}.comment{border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px}.comment.resolved{opacity:.55}.comment.resolved .comment-text{text-decoration:line-through}.comment-head{display:flex;gap:8px;align-items:baseline;font-size:12px;margin-bottom:3px}.comment-measure{background:#e8f0ff;color:var(--accent);border-radius:5px;padding:1px 6px;font-weight:700;font-size:11px}.comment-date{color:var(--muted);margin-left:auto;font-size:11px}.comment-actions{display:flex;gap:6px;margin-top:6px}.comment-form{display:flex;flex-direction:column;gap:8px}.comment-form label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.comment-form input{width:80px;padding:5px 8px;border:1px solid var(--border);border-radius:6px}.comment-form textarea{padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;resize:vertical}.diff-controls{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:13px}.diff-controls label{display:flex;align-items:center;gap:6px;color:var(--muted)}.diff-controls select{padding:5px 8px;border:1px solid var(--border);border-radius:6px}.diff-table{margin-bottom:12px}.diff-chips{display:flex;flex-wrap:wrap;gap:6px;max-height:260px;overflow:auto}.diff-chip{border-radius:6px;padding:3px 8px;font-size:11px}.diff-chip.changed{background:#fff3d6;color:#8a6100}.diff-chip.added{background:#e2f7e9;color:var(--ok)}.diff-chip.removed{background:#fde7e5;color:var(--err)}.record-row{display:flex;align-items:center;gap:12px;margin-top:14px}.page{flex:1;padding:26px 32px;max-width:1100px;width:100%;margin:0 auto}.page.narrow{max-width:460px}.pagehead{display:flex;align-items:center;gap:18px;margin-bottom:18px;flex-wrap:wrap}.pagehead h1{margin:0;font-size:22px}.search{flex:1;min-width:240px;padding:9px 14px;border:1px solid var(--border);border-radius:9px;font-size:14px}.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:22px;box-shadow:0 4px 18px #14233c0f}.tabbar{display:flex;gap:6px;margin-bottom:18px}.tab{flex:1;padding:8px;border:1px solid var(--border);background:var(--panel);border-radius:8px;cursor:pointer;font-size:14px}.tab.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.authform{display:flex;flex-direction:column;gap:12px}.authform label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}.authform input{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px}.formerror{color:var(--err);font-size:13px;margin:8px 0}.hint{color:var(--muted);font-size:14px}.scoretable{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:hidden}.scoretable th,.scoretable td{padding:10px 12px;text-align:left;font-size:13px;border-bottom:1px solid var(--border)}.scoretable th{background:#f7f9fc;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}.scoretable tr:last-child td{border-bottom:none}.scoretable a{color:var(--ink);text-decoration:none}.scoretable a:hover{color:var(--accent)}.muted{color:var(--muted)}.rowactions{display:flex;gap:6px}.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.scorecard{display:block;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;text-decoration:none;color:var(--ink);transition:box-shadow .15s,border-color .15s}.scorecard:hover{border-color:var(--accent);box-shadow:0 6px 18px #2f6fed1f}.scorecard-title{font-weight:700;font-size:15px}.scorecard-composer{color:var(--muted);font-size:13px;margin-top:2px}.scorecard-meta{color:var(--muted);font-size:12px;margin-top:8px}.scorecard-footer{color:var(--muted);font-size:11px;margin-top:10px;border-top:1px solid var(--border);padding-top:8px}.btn{border:1px solid var(--border);background:var(--panel);color:var(--ink);padding:7px 14px;border-radius:8px;font-size:13px;cursor:pointer}.btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.45;cursor:default}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn.primary:hover{color:var(--accent-ink);filter:brightness(1.08)}.btn.play{min-width:110px;font-weight:600}.btn.play.active{background:var(--err);border-color:var(--err);color:#fff}.btn.small{padding:3px 9px;font-size:12px}.controls{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:8px 18px;background:var(--panel);border-bottom:1px solid var(--border)}.ctl{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);white-space:nowrap}.ctl input[type=range]{width:130px}.transpose .semi{min-width:44px;text-align:center;color:var(--ink)}.ctl.check{gap:5px;cursor:pointer;-webkit-user-select:none;user-select:none}.mixerbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:6px 18px;background:#f7f9fc;border-bottom:1px solid var(--border);font-size:12px}.mixer-title{font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-size:12px}.chan{display:flex;align-items:center;gap:6px}.chan-name{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink)}.chan input[type=range]{width:90px}.btn.tiny{padding:2px 7px;font-size:11px;border-radius:5px}.btn.tiny.on{background:var(--accent);border-color:var(--accent);color:#fff}.score-meta{font-size:13px;color:var(--muted);margin-left:auto}.score-meta strong{color:var(--ink)}.badge{margin-left:8px;background:#e8f0ff;color:var(--accent);border-radius:20px;padding:2px 9px;font-size:11px}.score-area{flex:1;padding:24px;display:flex;justify-content:center;position:relative}.sheet{background:var(--paper);border:1px solid #e4d6b4;border-radius:4px;box-shadow:0 8px 26px #46321429;padding:24px;width:min(1100px,100%);min-height:400px;overflow:hidden}.sheet svg{max-width:100%;height:auto;display:block}.drop-hint{position:absolute;top:12px;right:12px;bottom:12px;left:12px;border:3px dashed var(--accent);border-radius:12px;background:#2f6fed0f;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--accent);pointer-events:none}.app.drag-over .sheet{opacity:.5}.statusbar{padding:7px 18px;font-size:12px;color:var(--muted);background:var(--panel);border-top:1px solid var(--border);position:sticky;bottom:0}.statusbar.ok{color:var(--ok)}.statusbar.err{color:var(--err)}.statusbar.busy{color:var(--accent)}@media print{.no-print{display:none!important}body{background:#fff}.app{height:auto!important;overflow:visible!important}.workbench,.wb-body{display:block!important;overflow:visible!important}.score-area{padding:0;overflow:visible!important}.sheet{border:none;box-shadow:none;padding:0;width:100%}}:root{--accent: #8b5a2b;--accent-bright: #d9a860;--accent-ink: #ffffff;--bar-dark: #2b2118;--bar-dark-ink: #eadfc8;--bar-dark-muted: #b9a884}.app{height:100vh;overflow:hidden}.page{overflow-y:auto}.topbar{background:var(--bar-dark);border-bottom:1px solid #1e293b}.topbar .brand-name{color:#fff;font-style:italic;letter-spacing:.01em}.topbar .brand-mark{color:var(--accent-bright)}.topbar .brand-tag{color:var(--bar-dark-muted);font-style:italic}.mainnav a{color:var(--bar-dark-muted)}.mainnav a:hover{color:#fff;background:#ffffff14}.mainnav a.active{color:var(--accent-bright);background:#d9a86024;font-weight:600}.topbar .username{color:var(--bar-dark-ink)}.topbar .btn{background:transparent;color:var(--bar-dark-ink);border-color:#334155}.topbar .btn:hover:not(:disabled){border-color:var(--accent-bright);color:var(--accent-bright)}.topbar .btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.langsel{background:transparent;color:var(--bar-dark-ink);border:1px solid #4a3a28;border-radius:7px;padding:4px 8px;font-size:12px;cursor:pointer}.langsel option{color:#222}.workbench{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.transport{display:flex;align-items:center;gap:12px;padding:5px 16px;background:var(--panel);border-bottom:1px solid var(--border)}.t-skip{border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:13px}.t-skip:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.t-play{width:42px;height:42px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:16px;cursor:pointer;box-shadow:0 3px 10px #0d948859}.t-play:hover:not(:disabled){filter:brightness(1.08)}.t-play.playing{background:var(--err);box-shadow:0 3px 10px #b3261e4d}.t-play:disabled,.t-skip:disabled{opacity:.4;cursor:default}.t-loop{border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:8px;width:34px;height:34px;cursor:pointer;font-size:15px}.t-loop:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.t-loop.on{background:var(--accent);color:#fff;border-color:var(--accent)}.t-loop:disabled{opacity:.4;cursor:default}.t-time{font-variant-numeric:tabular-nums;font-size:14px;font-weight:600;white-space:nowrap}.t-total{color:var(--muted);font-weight:400}.t-seek{flex:1;min-width:120px;accent-color:var(--accent)}.t-bpm{font-size:13px;color:var(--ink);white-space:nowrap}.t-tempo{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);white-space:nowrap}.t-tempo input{width:90px;accent-color:var(--accent)}.t-undo{display:flex;gap:4px}.t-title{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.t-title strong{color:var(--ink)}.wb-body{display:flex;flex:1;min-height:0}.score-area{flex:1;overflow:auto;position:relative}.palette-side{width:220px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.palette-head{display:flex;align-items:center}.palette-title{font-size:13px;font-weight:700}.palette-search{padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;width:100%}.palette-activate{width:100%}.palette-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:6px}.palette-grid{display:flex;flex-wrap:wrap;gap:4px}.pal-btn{min-width:30px;padding:5px 8px;border:1px solid var(--border);background:var(--panel);border-radius:6px;font-size:13px;cursor:pointer}.pal-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.pal-btn.on{background:var(--accent);border-color:var(--accent);color:#fff}.pal-btn:disabled{opacity:.35;cursor:default}.palette-footnote{margin-top:auto;font-size:11px;color:var(--muted);cursor:help;border-top:1px solid var(--border);padding-top:10px}.wb-right{width:300px;flex-shrink:0;background:var(--panel);border-left:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}.inspector{padding:12px}.insp-tabs{display:flex;gap:4px;margin-bottom:12px}.insp-tab{flex:1;padding:6px 4px;font-size:12px;border:1px solid var(--border);background:var(--panel);border-radius:7px;cursor:pointer}.insp-tab.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.insp-body{display:flex;flex-direction:column;gap:14px}.insp-section{display:flex;flex-direction:column;gap:6px}.insp-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}.insp-selection{font-size:14px;font-weight:600}.insp-pos{color:var(--muted);font-weight:400;font-size:12px}.insp-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.insp-row.btns{gap:4px}.insp-row select,.insp-section select{padding:6px 8px;border:1px solid var(--border);border-radius:7px;font-size:12px;background:var(--panel)}.insp-check{display:flex;align-items:center;gap:7px;font-size:13px;cursor:pointer}.insp-value{font-size:13px;min-width:44px;text-align:center}.insp-input{width:100%;padding:6px 9px;border:1px solid var(--border);border-radius:7px;font-size:13px;background:var(--panel)}.insp-input:focus{outline:none;border-color:var(--accent)}.insp-row.btns.wrap{flex-wrap:wrap}.insp-mini{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--muted)}.insp-mini select{padding:4px 6px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--panel)}.insp-body input[type=range]{width:100%;accent-color:var(--accent)}.wb-right .comments-panel{width:auto;position:static;max-height:none;border:none;border-top:1px solid var(--border);border-radius:0}.mixerdock{background:var(--panel);border-top:1px solid var(--border)}.mixer-toggle{width:100%;text-align:left;padding:6px 16px;border:none;background:#f7f9fc;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);cursor:pointer}.mixer-channels{padding:6px 16px 10px;display:flex;flex-direction:column;gap:6px;max-height:170px;overflow-y:auto}.mchan{display:flex;align-items:center;gap:10px;font-size:13px;flex-wrap:wrap}.mchan-num{width:16px;flex:0 0 16px;color:var(--muted);font-size:11px}.mchan-name{width:128px;flex:0 0 128px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.mchan-vol{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);flex:0 0 auto}.mchan-vol input{width:88px;flex:0 0 88px;accent-color:var(--accent)}.dropdown{position:relative}.dropdown summary{list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none}.dropdown summary::-webkit-details-marker{display:none}.dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #0f19282e;padding:6px;display:flex;flex-direction:column;min-width:190px;z-index:60}.dropdown-menu button{text-align:left;padding:8px 10px;border:none;background:transparent;border-radius:7px;font-size:13px;cursor:pointer}.dropdown-menu button:hover:not(:disabled){background:#eef7f6;color:var(--accent)}.dropdown-menu button:disabled{opacity:.4;cursor:default}.t-title .badge{margin-left:6px;background:#e6f6f4;color:var(--accent)}.landing{flex:1;overflow-y:auto}.landing .hero{max-width:860px;margin:0 auto;padding:64px 28px 32px;text-align:center}.hero-eyebrow{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 14px}.landing h1{font-family:Georgia,Palatino Linotype,serif;font-size:52px;line-height:1.08;margin:0 0 18px;font-weight:600;text-wrap:balance}.landing h1 em{color:var(--accent)}.hero-sub{max-width:60ch;margin:0 auto 28px;font-size:18px;color:var(--muted);line-height:1.6}.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn.lg{padding:11px 22px;font-size:15px;border-radius:10px;text-decoration:none}.btn.ghost{background:transparent}.hero-staff{margin:44px auto 0;max-width:760px;opacity:.9}.hero-staff svg{width:100%;height:auto}.feats{max-width:980px;margin:24px auto;padding:0 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.feat{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:22px;box-shadow:0 6px 16px #46321414}.feat h3{margin:0 0 8px;font-size:18px;font-style:italic}.feat p{margin:0;font-size:14.5px;color:var(--muted);line-height:1.55}.try{max-width:760px;margin:40px auto;padding:34px 28px;text-align:center;background:var(--panel);border:1px solid var(--border);border-top:3px double var(--accent);border-radius:12px}.try h2{margin:0 0 8px;font-style:italic;font-size:26px}.try p{margin:0 0 18px;color:var(--muted)}.landing-foot{text-align:center;padding:30px;color:var(--muted);font-size:13px;border-top:1px solid var(--border);margin-top:20px}.landing-foot .brand-mark{color:var(--accent)}@media (max-width: 640px){.landing h1{font-size:36px}.hero-sub{font-size:16px}}.hero-logo{display:flex;justify-content:center;margin-bottom:22px}.topbar .brand{display:flex;align-items:center}.logo-img{border-radius:7px;box-shadow:0 1px 4px #140c0040}.topbar .brand .logo-img{border-radius:6px}.hero-logo .logo-img{border-radius:16px;box-shadow:0 10px 34px #785a1e47}.ai-panel{border-top:1px solid var(--border);margin-top:12px;padding-top:12px;display:flex;flex-direction:column;gap:8px}.ai-warn{font-size:12px;color:var(--err);background:#fbeae7;border:1px solid #e4b6b3;border-radius:8px;padding:8px 10px;margin:0}.ai-log{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto}.ai-msg{font-size:13px;border-radius:10px;padding:7px 10px}.ai-user{background:#efe6d0;align-self:flex-end;max-width:90%}.ai-ai{background:var(--paper);border:1px solid var(--border)}.ai-text{white-space:pre-wrap}.ai-dim{color:var(--muted);font-style:italic}.ai-applied{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:2px}.ai-applied li{font-size:12px;color:var(--ok)}.ai-input{display:flex;flex-direction:column;gap:6px}.ai-input textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-family:Segoe UI,system-ui,sans-serif;font-size:13px;resize:vertical}.ai-input .btn{align-self:flex-end}.admin-create{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.admin-create input,.admin-create select{padding:7px 10px;border:1px solid var(--border);border-radius:7px;font-size:13px}.row-disabled{opacity:.5}.badge-on{color:var(--ok);font-weight:600;font-size:12px}.badge-off{color:var(--err);font-weight:600;font-size:12px}.tag{font-size:11px;color:var(--muted)}.piano-dock{display:flex;align-items:center;gap:14px;padding:8px 18px;background:var(--panel);border-top:1px solid var(--border);overflow-x:auto}.piano-hint{font-size:12px;color:var(--muted);white-space:nowrap}.piano-keys{position:relative;height:96px;flex:0 0 auto}.pk-white{position:relative;display:inline-block;width:26px;height:96px;margin:0;padding:0;background:#fffdf6;border:1px solid #c9b78c;border-radius:0 0 4px 4px;cursor:pointer;vertical-align:top}.pk-white:active{background:#efe3c8}.pk-label{position:absolute;bottom:4px;left:0;right:0;font-size:9px;color:var(--muted);text-align:center}.pk-black{position:absolute;top:0;width:16px;height:60px;background:#2b2118;border:1px solid #14100a;border-radius:0 0 3px 3px;cursor:pointer;z-index:2;padding:0}.pk-black:active{background:#4a3418}.linkbtn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:6px 0;text-decoration:underline}.linkbtn:hover{filter:brightness(1.1)}.card-title{margin:0 0 14px;font-size:18px}.topbar .brand .logo-img{background:#f6edd7;padding:4px 11px;border-radius:9px;box-shadow:0 1px 4px #00000059}html,body,#root{height:auto;min-height:100%}.app{height:auto;min-height:100vh;overflow:visible}.workbench{flex:0 0 auto;min-height:0;overflow:visible}.wb-body{flex:0 0 auto;min-height:0;align-items:flex-start}.score-area{overflow:visible;min-height:320px}.wb-right{overflow:visible}.topbar{position:sticky;top:0;z-index:20}.palette-side,.wb-right{position:sticky;top:51px;align-self:flex-start;max-height:calc(100vh - 51px);overflow-y:auto}.piano-dock{position:sticky;bottom:0;z-index:15;box-shadow:0 -2px 10px #140c002e}
