.lnd-root{flex-direction:column;display:flex}.lnd-hero{background-position:50% 40%;background-size:cover;align-items:center;min-height:440px;margin:-2.5rem -2rem 0;padding:3rem 2rem;display:flex;position:relative}.lnd-hero-overlay{background:linear-gradient(110deg,#14100ad1 0%,#14100aa6 50%,#14100a66 100%);position:absolute;inset:0}.lnd-hero-content{z-index:2;max-width:560px;position:relative}.lnd-eyebrow{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--gold-lt);margin:0 0 .85rem;font-size:.75rem}.lnd-headline{font-family:var(--serif);color:#fff;margin:0 0 .85rem;font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:700;line-height:1.1}.lnd-headline em{color:var(--gold-lt);font-style:italic}.lnd-sub{color:#fff;max-width:480px;margin:0 0 1.75rem;font-size:1.05rem;line-height:1.6}.lnd-ctas{flex-wrap:wrap;gap:.75rem;margin-bottom:1.1rem;display:flex}.lnd-btn-student{color:#fff!important;background:#ffffff14!important;border-color:#ffffffb3!important}.lnd-btn-student:hover{background:#ffffff2e!important;border-color:#fff!important}.lnd-browse-nudge{font-family:var(--mono);letter-spacing:.04em;color:#ffffffbf;margin:0;font-size:.75rem}.lnd-browse-link{cursor:pointer;font-family:var(--mono);letter-spacing:.04em;color:var(--gold-lt);text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:.75rem;text-decoration:underline}.lnd-browse-link:hover{color:#fff}.lnd-cred-bar{background:var(--ink);font-family:var(--mono);letter-spacing:.06em;color:#fffc;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem 2rem;margin:0 -2rem;padding:.9rem 2rem;font-size:.78rem;display:flex}.lnd-cred-bar strong{color:#fff;font-weight:600}.lnd-cred-item+.lnd-cred-item:before{content:"·";color:#ffffff59;margin-right:2rem}.lnd-tabs-wrap{max-width:740px;padding-top:2.5rem}.lnd-tab-bar{border-bottom:2px solid var(--line);margin-bottom:2.25rem;display:flex}.lnd-tab-btn{cursor:pointer;font-family:var(--serif);color:var(--muted);transition:color var(--trans-speed), border-color var(--trans-speed);background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;margin-right:.75rem;padding:.65rem 1.5rem .65rem 0;font-size:1.1rem;font-weight:600}.lnd-tab-btn:hover{color:var(--ink)}.lnd-tab-btn--active{color:var(--ink);border-bottom-color:var(--gold)}.lnd-tab-body{animation:.18s lnd-in}@keyframes lnd-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.lnd-tab-intro{margin-bottom:2rem}.lnd-tab-heading{font-family:var(--serif);color:var(--ink);margin:0 0 .6rem;font-size:1.6rem;font-weight:700}.lnd-tab-desc{color:var(--ink);max-width:560px;margin:0;font-size:1rem;line-height:1.65}.lnd-bullets{flex-direction:column;gap:1.5rem;margin:0 0 2rem;padding:0;list-style:none;display:flex}.lnd-bullet{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;display:flex}.lnd-bullet-icon{color:var(--gold);text-align:center;flex-shrink:0;width:1.2rem;margin-top:.15rem;font-size:1rem}.lnd-bullet-text{flex-direction:column;gap:.25rem;display:flex}.lnd-bullet-head{color:var(--ink);font-size:.97rem;font-weight:600;line-height:1.4}.lnd-bullet-body{color:var(--ink);font-size:.9rem;line-height:1.6}.lnd-free-note{color:var(--ink);background:var(--cream);border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0;align-items:center;gap:.75rem;margin-bottom:1.75rem;padding:.8rem 1rem;font-size:.92rem;display:flex}.lnd-free-badge{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;background:var(--gold);color:#fff;white-space:nowrap;border-radius:2px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.lnd-tab-ctas{flex-direction:column;align-items:flex-start;gap:.6rem;display:flex}.lnd-ghost-btn{cursor:pointer;font-size:.85rem;font-family:var(--mono);letter-spacing:.04em;color:var(--muted);text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}.lnd-ghost-btn:hover{color:var(--ink)}.lnd-library{border-bottom:1px solid var(--line);margin-bottom:0;padding:2.5rem 0 0}.lnd-library-grid{grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:2.5rem;display:grid}.lnd-library-block{flex-direction:column;gap:.4rem;display:flex}.lnd-library-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--gold-text);margin:0;font-size:.72rem}.lnd-library-value{font-family:var(--serif);color:var(--ink);margin:0;font-size:1.05rem;font-weight:700;line-height:1.3}.lnd-library-desc{color:var(--muted);margin:0;font-size:.875rem;line-height:1.6}.style-index-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.65rem;display:grid}.style-index-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:border-color var(--trans-speed), box-shadow var(--trans-speed);padding:1.4rem 1.1rem}.style-index-card:hover{border-color:var(--gold);box-shadow:0 2px 8px #0000000f}.style-index-card:focus-visible{outline:2px solid var(--gold-text);outline-offset:-2px;border-radius:var(--r)}.sic-icon{margin-bottom:.5rem;font-size:1.4rem}.sic-label{font-family:var(--serif);color:var(--ink);margin-bottom:.15rem;font-size:1.25rem;font-weight:600}.sic-period{font-family:var(--mono);letter-spacing:.07em;color:var(--muted);margin-bottom:.5rem;font-size:.75rem}.sic-tagline{color:var(--ink);font-size:.88rem;font-style:italic;line-height:1.5}.sic-hero-icon{text-align:center;flex-shrink:0;width:3rem;margin-top:.2rem;font-size:2.8rem;line-height:1}.style-keyword-row{flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem;display:flex}.style-keyword{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;background:var(--cream);color:var(--muted);border:1px solid var(--line);border-radius:2px;padding:.2rem .55rem;font-size:.75rem}@media (width<=640px){.lnd-hero{min-height:380px;margin:-1.5rem -1rem 0;padding:2rem 1rem}.lnd-cred-bar{margin:0 -1rem;font-size:.75rem}.lnd-headline{font-size:1.9rem}.lnd-ctas{flex-direction:column}.lnd-ctas .btn{text-align:center;width:100%}.lnd-bullet{padding:.85rem .9rem}.lnd-library-grid{grid-template-columns:1fr;gap:1.25rem}.style-index-grid{grid-template-columns:1fr 1fr}}:root{--serif:"Cormorant Garamond", Georgia, serif;--mono:"DM Mono", "Courier New", monospace;--ink:#1a1a1a;--paper:#faf8f5;--cream:#f0ece4;--white:#fff;--gold:#c9a84c;--gold-text:#7a5a00;--gold-lt:#e8c97a;--rust:#8b3a2a;--sage:#3d5c3d;--muted:#5c544c;--line:#e0dbd4;--studying-text:#6b4f00;--studying-bg:#fdf8ec;--studying-border:#c8a840;--completed-text:#3d5c3d;--completed-bg:#edf7ed;--completed-border:#7aaa7a;--wishlist-text:#3d4a7a;--wishlist-bg:#eff1f8;--wishlist-border:#8090b8;--abandoned-text:#5c544c;--abandoned-bg:#f0ece4;--abandoned-border:#e0dbd4;--error-bg:#fdf0ee;--error-border:#e8b4aa;--signout-color:#d4a8b8;--r:3px;--trans-speed:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--serif);background-color:var(--paper);color:var(--ink);flex-direction:column;min-height:100vh;line-height:1.6;display:flex}a{color:var(--gold-text)}code{font-family:var(--mono);font-size:.88em}ul{padding-left:1.4em}li{margin-bottom:.3em}p{margin-bottom:.75em}p:last-child{margin-bottom:0}h2{margin:1.5em 0 .5em;font-size:1.25rem;font-weight:400}:focus-visible{outline:2px solid var(--gold-text);outline-offset:2px}:focus:not(:focus-visible){outline:none}input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--gold-text);outline:2px solid var(--gold-text);outline-offset:0;box-shadow:0 0 0 3px #7a5a0026}.skip-link{z-index:9999;background:var(--ink);width:1px;height:1px;color:var(--paper);font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;padding:.5rem 1rem;font-size:.75rem;text-decoration:none;position:absolute;top:auto;left:-9999px;overflow:hidden}.skip-link:focus{width:auto;height:auto;left:1rem}#app-root{flex-direction:column;min-height:100vh;display:flex}header{background:var(--ink);color:var(--paper);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;height:52px;padding:0 2rem;display:flex;position:sticky;top:0}main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:2.5rem 2rem}.logo{cursor:pointer;flex-shrink:0;align-items:center;gap:.55rem;display:flex}.logo-mark{border:1.5px solid var(--gold-lt);background:0 0;border-radius:2px;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.logo-m{font-family:var(--serif);color:var(--gold-lt);font-size:1.1rem;font-weight:500;line-height:1}.logo-text{font-family:var(--serif);letter-spacing:.04em;color:var(--paper);font-size:1.05rem;font-weight:300}#main-nav{flex-wrap:nowrap;align-items:center;gap:.15rem;display:flex;overflow-x:auto}.nav-btn{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;border-radius:var(--r);cursor:pointer;color:var(--paper);transition:color var(--trans-speed), background var(--trans-speed);white-space:nowrap;background:0 0;border:none;padding:.35rem .6rem;font-size:.8rem}.nav-btn:hover{background:#ffffff14}.nav-btn.active,.nav-btn.nav-upgrade,.nav-btn.nav-subscription{color:var(--gold-lt)}.nav-btn-signout{color:var(--signout-color)!important}.nav-sep{background:#ffffff26;flex-shrink:0;width:1px;height:18px;margin:0 .4rem}.user-chip{font-family:var(--mono);color:var(--gold-lt);letter-spacing:.05em;padding:0 .25rem;font-size:.8rem}.nav-pro-chip{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--gold-lt);opacity:.8;border:1px solid #e8c97a73;border-radius:3px;padding:.1rem .3rem;font-size:.6rem}.site-footer{font-family:var(--mono);letter-spacing:.06em;color:var(--muted);border-top:1px solid var(--line);flex-wrap:wrap;gap:1.5rem;padding:1rem 2rem;font-size:.75rem;display:flex}.site-footer a{color:var(--muted);cursor:pointer;text-decoration:underline}.site-footer a:hover{color:var(--gold-text)}.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem}.card-gold-accent{border-left:3px solid var(--gold)}.btn{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border-radius:var(--r);cursor:pointer;transition:all var(--trans-speed);white-space:nowrap;border:1px solid #0000;align-items:center;gap:.3rem;min-height:2.25rem;padding:.5rem 1.2rem;font-size:.75rem;display:inline-flex}.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn-primary:hover{background:#2d2010}.btn-outline{color:var(--ink);border-color:var(--line);background:0 0}.btn-outline:hover{border-color:var(--ink);background:var(--cream)}.btn-cancel{color:var(--rust);border-color:var(--error-border)}.btn-cancel:hover{background:var(--error-bg);border-color:var(--rust)}.btn-gold{background:var(--gold-text);color:var(--paper);border-color:var(--gold-text)}.btn-gold:hover{background:#5e4500}.btn-sm{min-height:1.75rem;padding:.28rem .65rem;font-size:.7rem}.btn:disabled{opacity:.4;cursor:not-allowed}.form-group{margin-bottom:1.25rem}label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin-bottom:.4rem;font-size:.75rem;display:block}input,select,textarea{background:var(--white);border:1px solid var(--line);border-radius:var(--r);width:100%;font-family:var(--serif);color:var(--ink);transition:border-color var(--trans-speed);outline:none;padding:.6rem .75rem;font-size:1rem}input:focus,select:focus,textarea:focus{border-color:var(--gold-text)}textarea{resize:vertical;min-height:80px}select{cursor:pointer}::placeholder{color:var(--muted);opacity:1}.error-msg{background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--r);font-family:var(--mono);color:var(--rust);margin-bottom:1rem;padding:.6rem .75rem;font-size:.75rem}.field-label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-bottom:.3rem;font-size:.75rem}.date-fieldset{border:none;margin:0;padding:0}.date-fieldset legend{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);float:left;width:100%;margin-bottom:.3rem;padding:0;font-size:.75rem}.date-fieldset legend+*{clear:both}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.date-display{font-family:var(--mono);color:var(--ink);align-items:center;gap:.4rem;font-size:.8rem;display:flex}.date-display .field-label{margin-bottom:0}.date-display-label{color:var(--muted)}.date-display-value{color:var(--ink)}.date-display-value.not-set{color:var(--muted);font-style:italic}.date-value-btn{cursor:pointer;font-family:var(--mono);color:var(--ink);text-align:left;background:0 0;border:none;padding:0;font-size:.8rem}.date-value-btn:hover{color:var(--gold-text);text-decoration:underline}.date-placeholder{color:var(--muted);font-style:italic}.date-edit-btn{cursor:pointer;color:var(--muted);border-radius:var(--r);min-width:1.5rem;min-height:1.5rem;transition:color var(--trans-speed);background:0 0;border:none;justify-content:center;align-items:center;padding:.15rem;font-size:.85rem;line-height:1;display:flex}.date-edit-btn:hover{color:var(--gold-text)}.date-clear-btn{cursor:pointer;color:var(--muted);border-radius:var(--r);min-width:1.5rem;min-height:1.5rem;transition:color var(--trans-speed);background:0 0;border:none;justify-content:center;align-items:center;padding:.15rem;font-size:.8rem;line-height:1;display:flex}.date-clear-btn:hover{color:var(--rust)}.date-editor{flex-direction:column;gap:.3rem;display:flex}.date-inputs-row{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.date-input-group{flex-direction:column;gap:.2rem;display:flex}.date-input-group label{letter-spacing:.05em;color:var(--muted);margin-bottom:0;font-size:.65rem}.date-sub-input{font-family:var(--mono);border:1px solid var(--line);border-radius:var(--r);background:var(--white);width:auto;padding:.25rem .4rem;font-size:.85rem}.date-sub-input.year{width:5rem}.date-sub-input.month,.date-sub-input.day{width:3.5rem}.date-hint{font-family:var(--mono);color:var(--muted);font-size:.7rem}.date-error{font-family:var(--mono);color:var(--rust);font-size:.75rem}.date-teacher-set{font-family:var(--mono);color:var(--muted);font-size:.8rem}.date-teacher-set .teacher-label{color:var(--muted);font-size:.7rem;font-style:italic}.section-title{letter-spacing:.02em;margin-bottom:.2rem;font-size:2rem;font-weight:300;line-height:1.2}.section-title em{color:var(--gold-text);font-style:italic}.section-sub{font-family:var(--mono);color:var(--ink);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2rem;font-size:.75rem}.toast{background:var(--ink);color:var(--paper);border-radius:var(--r);font-family:var(--mono);letter-spacing:.04em;opacity:0;pointer-events:none;z-index:9000;white-space:nowrap;padding:.6rem 1.2rem;font-size:.8rem;transition:opacity .2s,transform .2s;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)translateY(1rem)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast.show.error{background:var(--rust)}.toast.show.success{background:var(--sage)}.loader{font-family:var(--mono);color:var(--ink);letter-spacing:.06em;padding:2rem 0;font-size:.85rem}.empty-state{color:var(--muted);padding:3rem 0;font-style:italic}.auth-container{max-width:400px;margin:3.5rem auto}.auth-title{margin-bottom:.2rem;font-size:2.2rem;font-weight:300}.auth-sub{color:var(--ink);margin-bottom:2rem;font-size:.95rem;font-style:italic}.auth-switch{text-align:center;color:var(--ink);margin-top:1.25rem;font-size:.88rem}.auth-switch a{color:var(--gold-text);cursor:pointer;text-decoration:underline}.landing-wrap{max-width:680px;margin:3rem auto}.landing-logo-block{align-items:center;gap:.7rem;margin-bottom:2rem;display:flex}.landing-mark{background:var(--ink);border-radius:3px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.landing-mark-m{font-family:var(--serif);color:var(--gold-lt);font-size:1.6rem;font-weight:500;line-height:1}.landing-wordmark{font-family:var(--serif);letter-spacing:.04em;color:var(--ink);font-size:1.5rem;font-weight:300}.landing-headline{letter-spacing:-.01em;margin-bottom:1.1rem;font-size:2.8rem;font-weight:300;line-height:1.15}.landing-headline em{color:var(--gold-text);font-style:italic}.landing-sub{color:var(--ink);max-width:500px;margin-bottom:2rem;font-size:1.1rem;font-weight:300;line-height:1.65}.landing-cta{flex-wrap:wrap;gap:.75rem;margin-bottom:3rem;display:flex}.landing-rule{border:none;border-top:1px solid var(--line);margin-bottom:3rem}.landing-stats{border:1px solid var(--line);border-radius:var(--r);background:var(--white);grid-template-columns:repeat(4,1fr);margin-bottom:3rem;display:grid;overflow:hidden}.lstat{text-align:center;border-right:1px solid var(--line);padding:1.25rem 1rem}.lstat:last-child{border-right:none}.lstat-num{color:var(--gold-text);font-size:2rem;font-weight:300;line-height:1;display:block}.lstat-lbl{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-top:.35rem;font-size:.75rem;display:block}.feature-table{border-collapse:collapse;width:100%}.feature-table td,.feature-table th{text-align:left;border-bottom:1px solid var(--line);padding:.7rem .9rem;font-size:.92rem}.feature-table th{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding-bottom:.5rem;font-size:.7rem;font-weight:400}.feature-table tr:last-child td{border-bottom:none}.feature-table td:not(:first-child){font-family:var(--mono);letter-spacing:.05em;color:var(--muted);text-align:center;white-space:nowrap;font-size:.75rem}.ft-yes{color:var(--sage)!important}.ft-pro{color:var(--gold-text)!important}.ft-no{color:var(--muted)!important}.search-bar{margin-bottom:.75rem}.search-bar .form-group{max-width:480px;margin-bottom:0}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1.25rem;display:flex}.filter-row .form-group{flex:1;min-width:140px;max-width:200px;margin-bottom:0}.filter-clear{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:0 0;border:none;align-self:flex-end;padding:0 .25rem .65rem;font-size:.75rem}.filter-clear:hover{color:var(--ink)}.results-meta{font-family:var(--mono);letter-spacing:.05em;color:var(--ink);text-transform:uppercase;margin-bottom:.75rem;font-size:.75rem}.piece-list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.piece-row{border-bottom:1px solid var(--line);cursor:pointer;transition:background var(--trans-speed);grid-template-columns:3rem 1fr auto;align-items:center;gap:.75rem;padding:.65rem .9rem;display:grid}.piece-row:last-child{border-bottom:none}.piece-row:hover{background:var(--cream)}.piece-row.in-library{background:#fafaf8}.piece-row.s-completed{border-left:2px solid var(--sage)}.piece-row.s-studying{border-left:2px solid var(--gold)}.piece-row.s-wishlist{border-left:2px solid #8090b8}.piece-row.s-abandoned{border-left:2px solid var(--line)}.piece-grade{font-family:var(--mono);letter-spacing:.04em;text-align:center;color:var(--muted);background:var(--cream);white-space:nowrap;border-radius:2px;padding:.18rem .35rem;font-size:.75rem}.piece-grade.clickable{cursor:pointer}.piece-grade.clickable:hover{background:var(--line)}.piece-grade.g-high{background:var(--cream);color:var(--gold-text)}.piece-grade.g-dip{color:var(--rust);background:#f9f0ee}.piece-title{font-size:1rem;font-weight:400;line-height:1.3}.piece-composer{color:var(--ink);margin-top:.05rem;font-size:.88rem}.piece-tags{flex-wrap:wrap;gap:.35rem;margin-top:.3rem;display:flex}.piece-main{min-width:0}.piece-status{font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:2px;padding:.18rem .4rem;font-size:.7rem}.s-completed{background:var(--completed-bg);color:var(--completed-text)}.s-studying{background:var(--studying-bg);color:var(--studying-text)}.s-wishlist{background:var(--wishlist-bg);color:var(--wishlist-text)}.s-abandoned{background:var(--abandoned-bg);color:var(--abandoned-text)}.ptag{font-family:var(--mono);letter-spacing:.04em;white-space:nowrap;border-radius:2px;padding:.15rem .45rem;font-size:.7rem}.ptag-style{background:var(--cream);color:var(--muted)}.pagination{font-family:var(--mono);align-items:center;gap:1rem;margin-top:1.5rem;font-size:.75rem;display:flex}.page-btn{font-family:var(--mono);letter-spacing:.05em;border:1px solid var(--line);border-radius:var(--r);cursor:pointer;color:var(--ink);transition:all var(--trans-speed);background:0 0;min-height:2rem;padding:.35rem .75rem;font-size:.75rem}.page-btn:hover:not(:disabled){border-color:var(--ink);background:var(--cream)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{color:var(--ink)}.modal-overlay{z-index:500;background:#14120f8c;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem 1.5rem .75rem;display:flex}.modal-grade-line{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.35rem;font-size:.75rem}.modal-title-line{font-size:1.4rem;font-weight:400;line-height:1.2}.modal-composer-line{color:var(--muted);margin-top:.2rem;font-size:.95rem;font-style:italic}.modal-close{cursor:pointer;color:var(--ink);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:2rem;min-height:2rem;padding:.2rem;font-size:1.2rem;line-height:1;display:flex}.modal-close:hover{color:var(--gold-text)}.modal-tags-row{flex-wrap:wrap;gap:.4rem;padding:0 1.5rem .75rem;display:flex}.modal-body{flex-direction:column;gap:1.25rem;padding:0 1.5rem 1rem;display:flex}.modal-actions{border-top:1px solid var(--line);gap:.5rem;padding:1rem 1.5rem;display:flex}.sec-title{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin-bottom:.6rem;font-size:.75rem}.detail-item{border-bottom:1px solid var(--line);justify-content:space-between;gap:1rem;padding:.4rem 0;font-size:.9rem;display:flex}.detail-item:last-child{border-bottom:none}.detail-item-key{color:var(--ink);font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.status-form{flex-direction:column;gap:1rem;display:flex}.status-row{flex-wrap:wrap;gap:.4rem;display:flex}.status-btn{font-family:var(--mono);letter-spacing:.05em;text-transform:capitalize;border:1px solid var(--line);border-radius:var(--r);color:var(--ink);cursor:pointer;transition:all var(--trans-speed);background:0 0;min-height:2rem;padding:.3rem .65rem;font-size:.75rem}.status-btn:hover{border-color:var(--ink)}.sb-studying{background:var(--studying-bg);color:var(--studying-text);border-color:var(--studying-border)}.sb-completed{background:var(--completed-bg);color:var(--completed-text);border-color:var(--completed-border)}.sb-wishlist{background:var(--wishlist-bg);color:var(--wishlist-text);border-color:var(--wishlist-border)}.sb-abandoned{background:var(--abandoned-bg);color:var(--abandoned-text);border-color:var(--abandoned-border)}.notes-area{width:100%;font-family:var(--serif);font-size:.9rem}.rating-row{gap:.2rem;display:flex}.star-btn{cursor:pointer;color:var(--line);transition:color var(--trans-speed);background:0 0;border:none;justify-content:center;align-items:center;min-width:2.25rem;min-height:2.25rem;padding:0;font-size:1.3rem;display:flex}.star-btn.lit{color:var(--gold)}.star-btn:hover{color:var(--gold-text)}.gate-banner{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.gate-text p{color:var(--ink);margin:.2rem 0 0;font-size:.88rem}.gate-text strong{font-size:.95rem}.perf-form{background:var(--cream);border-radius:var(--r);border:1px solid var(--line);flex-direction:column;gap:.6rem;padding:.75rem;display:flex}.perf-form-actions{gap:.4rem;display:flex}.perf-readonly{font-family:var(--mono);color:var(--muted);font-size:.8rem}.perf-readonly-badge{color:var(--muted);font-size:.7rem;font-style:italic}.assigned-row{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:var(--r);cursor:pointer;transition:background var(--trans-speed);padding:.7rem 1rem}.assigned-row:hover{background:var(--cream)}.assigned-row-top{align-items:flex-start;gap:.5rem;display:flex}.assigned-row-info{flex:1;min-width:0}.assigned-title{white-space:nowrap;text-overflow:ellipsis;font-size:.93rem;overflow:hidden}.assigned-composer{font-family:var(--mono);color:var(--muted);font-size:.75rem}.assigned-meta{font-size:.8rem;font-family:var(--mono);color:var(--muted);flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.4rem;display:flex}.assigned-due-overdue,.assigned-due-soon{color:var(--rust);font-weight:500}.assigned-due-normal{color:var(--muted)}.assigned-note{font-family:var(--serif);color:var(--ink);margin-top:.4rem;font-size:.82rem;font-style:italic}.teacher-group{margin-bottom:1.75rem}.teacher-group-heading{font-family:var(--mono);letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem;font-size:.75rem}.teacher-group-list{flex-direction:column;gap:.4rem;display:flex}.nudge-body{font-family:var(--serif);color:var(--muted);margin-bottom:1.25rem;font-size:.9rem}.nudge-actions{flex-wrap:wrap;gap:.6rem;margin-bottom:1.25rem;display:flex}.nudge-share-section{border-top:1px solid var(--line);padding-top:1rem}.nudge-share-label{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;font-size:.75rem;display:block}.nudge-share-row{align-items:center;gap:.5rem;display:flex}.nudge-share-input{font-family:var(--mono);border:1px solid var(--line);border-radius:var(--r);background:var(--cream);color:var(--ink);cursor:text;flex:1;padding:.4rem .6rem;font-size:.85rem}.nudge-share-hint{font-family:var(--serif);color:var(--muted);margin-top:.45rem;font-size:.82rem}.tab-bar{border-bottom:1px solid var(--line);margin-bottom:1.5rem;display:flex}.lib-tab{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all var(--trans-speed);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.5rem .9rem;font-size:.75rem}.lib-tab.active{color:var(--ink);border-bottom-color:var(--gold)}.lib-tab:hover{color:var(--ink)}.tab-count-pill{background:var(--gold-text);color:var(--paper);vertical-align:middle;border-radius:9px;margin-left:.35rem;padding:0 .45em;font-size:.7em;display:inline-block}.recs-section{margin-bottom:2.25rem}.recs-section-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin-bottom:.75rem;font-size:.75rem}.recs-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;display:grid}.rec-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:border-color var(--trans-speed), box-shadow var(--trans-speed);padding:1rem 1.1rem}.rec-card:hover{border-color:var(--gold);box-shadow:0 2px 8px #0000000f}.rec-card-top{justify-content:space-between;align-items:flex-start;display:flex}.rec-title{font-size:.97rem;font-weight:400;line-height:1.3}.rec-composer{color:var(--ink);margin-top:.05rem;font-size:.82rem}.rec-reasons{flex-direction:column;gap:.2rem;margin-top:.6rem;display:flex}.rec-reason{font-family:var(--mono);color:var(--sage);letter-spacing:.03em;font-size:.75rem}.pop-list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.pop-item{border-bottom:1px solid var(--line);cursor:pointer;transition:background var(--trans-speed);align-items:center;gap:.75rem;padding:.65rem .9rem;display:flex}.pop-item:last-child{border-bottom:none}.pop-item:hover{background:var(--cream)}.pop-rank{font-family:var(--mono);color:var(--muted);text-align:right;flex-shrink:0;width:1.5rem;font-size:.8rem}.pop-saves{font-family:var(--mono);color:var(--muted);letter-spacing:.03em;flex-shrink:0;font-size:.75rem}.progress-hero{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:2rem;display:grid}.hero-stat{background:var(--white);border:1px solid var(--line);border-radius:var(--r);text-align:center;padding:1.1rem 1rem}.hero-stat-num{font-size:2rem;font-weight:300;line-height:1;display:block}.hero-stat-lbl{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-top:.35rem;font-size:.75rem;display:block}.hs-completed .hero-stat-num{color:var(--completed-text)}.hs-studying .hero-stat-num{color:var(--studying-text)}.hs-wishlist .hero-stat-num{color:var(--wishlist-text)}.hs-total .hero-stat-num{color:var(--gold-text)}.progress-section-hdr{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:1.75rem 0 .75rem;font-size:.8rem}.style-badges{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.6rem;margin-bottom:.5rem;display:grid}.style-badge{background:var(--white);border:1px solid var(--line);border-radius:var(--r);text-align:center;padding:.75rem}.style-badge.sb-earned{border-color:var(--completed-border);background:#f7fbf7}.style-badge-name{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.35rem;font-size:.75rem}.style-badge-grade{color:var(--gold-text);font-size:1.2rem;font-weight:300;line-height:1}.sb-locked .style-badge-grade{color:var(--line)}.style-badge-sub{font-family:var(--mono);color:var(--muted);margin-top:.2rem;font-size:.7rem}.style-badge-pips{justify-content:center;gap:3px;margin-top:.5rem;display:flex}.style-pip{background:var(--line);border-radius:1px;width:8px;height:4px}.style-pip.filled{background:var(--sage)}.progress-tabs{border-bottom:1px solid var(--line);margin-bottom:1rem;display:flex}.progress-tab{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all var(--trans-speed);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.4rem;margin-bottom:-1px;padding:.5rem .9rem;font-size:.75rem;display:flex}.progress-tab.active{color:var(--ink);border-bottom-color:var(--gold)}.progress-tab:hover{color:var(--ink)}.progress-tab-count{background:var(--cream);border-radius:2px;padding:.05rem .35rem;font-size:.7rem}.progress-tab.active .progress-tab-count{background:#7a5a001f}.progress-search-row{flex-wrap:wrap;gap:.6rem;margin-bottom:1rem;display:flex}.progress-search-row input{flex:1;min-width:200px}.progress-search-row select{max-width:160px}.progress-piece-row{border-bottom:1px solid var(--line);cursor:pointer;transition:background var(--trans-speed);align-items:center;gap:.75rem;padding:.55rem 0;display:flex}.progress-piece-row:hover{background:var(--cream);border-radius:var(--r);padding-left:.35rem}.progress-piece-title{font-size:.93rem;line-height:1.3}.progress-piece-meta{color:var(--ink);flex-wrap:wrap;align-items:center;gap:.3rem;margin-top:.1rem;font-size:.82rem;display:flex}.progress-piece-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.2rem;margin-left:auto;display:flex}.progress-date{font-family:var(--mono);color:var(--ink);font-size:.75rem}.progress-stars{color:var(--gold);letter-spacing:-.05em;font-size:.8rem}.progress-empty{color:var(--ink);padding:1.5rem 0;font-size:.92rem;font-style:italic}.monthly-chart{padding:1.25rem 1.5rem}.chart-row{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.chart-row:last-child{margin-bottom:0}.chart-row-label{font-family:var(--mono);color:var(--ink);flex-shrink:0;width:4rem;font-size:.75rem}.chart-row-track{background:var(--cream);border-radius:3px;flex:1;height:6px;overflow:hidden}.chart-row-fill{background:var(--gold);border-radius:3px;height:100%}.chart-row-val{font-family:var(--mono);color:var(--ink);text-align:right;flex-shrink:0;width:1.5rem;font-size:.75rem}.acct-section-hdr{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--line);margin-bottom:1rem;padding-bottom:.75rem;font-size:.75rem}.billing-renew-note{font-family:var(--mono);color:var(--muted);margin-bottom:.5rem;font-size:.8rem}.billing-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);max-width:520px;padding:1.5rem}.billing-plan-row{justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;display:flex}.billing-label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-bottom:.2rem;font-size:.75rem}.billing-plan-name{font-size:1.2rem;font-weight:300}.billing-plan-interval{color:var(--muted);font-size:.85rem;font-weight:400}.billing-value{margin-bottom:1rem;font-size:.95rem}.billing-actions{flex-wrap:wrap;gap:.6rem;margin-top:1.25rem;display:flex}.cancel-note{font-family:var(--mono);color:var(--rust);background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--r);margin:.75rem 0;padding:.5rem .75rem;font-size:.75rem}.pro-perks{margin:1rem 0}.pro-perks-hdr{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;font-size:.7rem}.pro-perks ul{padding:0;list-style:none}.pro-perks li{color:var(--ink);border-bottom:1px solid var(--line);padding:.3rem 0;font-size:.9rem}.pro-perks li:last-child{border-bottom:none}.pro-perks li:before{content:"✓ ";color:var(--sage)}.tier-badge{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;background:var(--cream);color:var(--muted);border-radius:2px;padding:.2rem .55rem;font-size:.7rem}.tier-badge.tier-paid{color:var(--studying-text);background:#7a5a001a}.tier-badge.tier-admin{background:var(--error-bg);color:var(--rust)}.legal-wrap{max-width:660px;margin:0 auto}.legal-back{font-family:var(--mono);letter-spacing:.05em;color:var(--muted);cursor:pointer;background:0 0;border:none;margin-bottom:1.5rem;padding:0;font-size:.75rem;display:block}.legal-back:hover{color:var(--ink)}.legal-wrap h1{margin-bottom:.5rem;font-size:2rem;font-weight:300}.legal-wrap h2{margin:1.5em 0 .5em;font-size:1.1rem;font-weight:400}.legal-meta{font-family:var(--mono);letter-spacing:.05em;color:var(--muted);margin-bottom:1.5rem;font-size:.75rem}.index-header{margin-bottom:2rem}.grade-band-row{flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;display:flex}.grade-band-pill{background:var(--white);border:1px solid var(--line);border-radius:var(--r);min-width:120px;padding:.7rem 1rem}.grade-band-name{font-size:.95rem;font-weight:400;line-height:1.2}.grade-band-grades{font-family:var(--mono);color:var(--muted);margin-top:.15rem;font-size:.75rem}.grade-index-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem;display:grid}.grade-index-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);text-align:center;cursor:pointer;transition:border-color var(--trans-speed), box-shadow var(--trans-speed);padding:1.25rem .75rem}.grade-index-card:hover{border-color:var(--gold);box-shadow:0 2px 8px #0000000f}.gic-num{color:var(--gold-text);font-size:2rem;font-weight:300;line-height:1}.gic-num.init{margin-top:.4rem;font-size:1.2rem}.gic-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.15rem;font-size:.75rem}.gic-band{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;margin-top:.3rem;font-size:.7rem}.grade-back-btn{font-family:var(--mono);letter-spacing:.05em;color:var(--muted);cursor:pointer;background:0 0;border:none;margin-bottom:1.5rem;padding:0;font-size:.75rem;display:block}.grade-back-btn:hover{color:var(--ink)}.grade-hero{border-bottom:1px solid var(--line);align-items:flex-start;gap:1.5rem;margin-bottom:2.5rem;padding-bottom:2rem;display:flex}.grade-hero-num{color:var(--gold-text);text-align:center;flex-shrink:0;width:3rem;font-size:4rem;font-weight:300;line-height:1}.grade-hero-band{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem;font-size:.75rem}.grade-hero-content h1{margin-bottom:.5rem;font-size:1.6rem;font-weight:300}.grade-hero-desc{color:var(--ink);font-size:1rem;font-style:italic}.grade-section{margin-bottom:2rem}.grade-card-header{align-items:center;gap:.6rem;margin-bottom:1rem;display:flex}.grade-card-icon{color:var(--gold);text-align:center;width:1.2rem;font-size:.9rem}.grade-card-title{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink);font-size:.75rem}.grade-overview p{color:var(--ink);margin-bottom:.85rem;font-size:.97rem;line-height:1.7}.grade-skill-block{background:var(--white);border:1px solid var(--line);border-radius:var(--r);margin-bottom:.6rem;padding:1.1rem 1.25rem}.grade-skill-header{align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.grade-skill-tag{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border-radius:2px;padding:.15rem .45rem;font-size:.7rem}.grade-skill-tag.technical{background:var(--cream);color:var(--muted)}.grade-skill-tag.musical{color:var(--studying-text);background:#f5ecda}.grade-skill-name{font-size:.97rem;font-weight:400}.grade-skill-desc{color:var(--ink);margin-bottom:.85rem;font-size:.9rem;line-height:1.6}.grade-skill-meta{border-top:1px solid var(--line);grid-template-columns:1fr 1fr;gap:1rem;padding-top:.75rem;display:grid}.grade-skill-meta-label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-bottom:.4rem;font-size:.75rem}.grade-skill-meta-items{color:var(--ink);font-size:.82rem;line-height:1.7}.grade-skill-meta-items div{border-bottom:1px solid var(--line);margin-bottom:.2rem;padding-bottom:.2rem}.grade-skill-meta-items div:last-child{border-bottom:none}.grade-two-col{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}.grade-scales-table{border-collapse:collapse;width:100%}.grade-scales-table td{border-bottom:1px solid var(--line);vertical-align:top;padding:.45rem 0;font-size:.88rem}.grade-scales-table td:first-child{font-family:var(--mono);color:var(--ink);text-transform:uppercase;letter-spacing:.04em;width:40%;font-size:.78rem}.grade-scales-table tr:last-child td{border-bottom:none}.grade-cog-list{flex-direction:column;gap:.5rem;display:flex}.grade-cog-item{align-items:flex-start;gap:.5rem;display:flex}.grade-cog-dot{background:var(--gold);border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-top:.55rem}.grade-cog-text{color:var(--ink);font-size:.88rem;line-height:1.55}.grade-piece-tiers{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;display:grid}.grade-tier-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.1rem}.grade-tier-label{font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;border-radius:2px;margin-bottom:.5rem;padding:.18rem .45rem;font-size:.7rem;display:inline-block}.grade-tier-label.stepping{background:var(--cream);color:var(--muted)}.grade-tier-label.benchmark{color:var(--studying-text);background:#f2e8cc}.grade-tier-label.perform{background:var(--completed-bg);color:var(--sage)}.grade-tier-desc{color:var(--ink);margin-bottom:.75rem;font-size:.85rem;line-height:1.5}.grade-piece-item{border-bottom:1px solid var(--line);padding:.45rem 0}.grade-piece-item:last-child{border-bottom:none}.grade-piece-title{font-size:.88rem;font-weight:400}.grade-piece-composer{color:var(--ink);font-size:.82rem;font-style:italic}.grade-next-bar{background:var(--white);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:border-color var(--trans-speed), box-shadow var(--trans-speed);justify-content:space-between;align-items:center;margin-top:1rem;padding:1.1rem 1.25rem;display:flex}.grade-next-bar:hover{border-color:var(--gold);box-shadow:0 2px 8px #0000000f}.grade-next-bar-label{font-family:var(--mono);color:var(--ink);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;font-size:.75rem}.grade-next-bar-name{font-size:1rem;font-weight:400}.grade-next-bar-arrow{color:var(--gold);font-size:1.4rem}@media (width<=640px){header{padding:0 1rem}.logo-text{display:none}main{padding:1.5rem 1rem}.piece-row{grid-template-columns:1fr auto}.piece-row .piece-grade{display:none}.landing-stats,.progress-hero{grid-template-columns:repeat(2,1fr)}.grade-two-col,.grade-piece-tiers{grid-template-columns:1fr}}.perf-toggle-hdr{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;margin-top:1.25rem;padding:0;display:flex}.perf-toggle-hdr:hover .sec-title{color:var(--gold-text)}.perf-count{color:var(--muted);font-weight:400}.perf-toggle-arrow{color:var(--muted);flex-shrink:0;font-size:.75rem}.perf-divider{border-bottom:1px solid var(--line);margin:.4rem 0 .85rem}.perf-list{flex-direction:column;gap:.65rem;display:flex}.perf-item{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:.5rem;padding:.5rem 0;display:flex}.perf-item-main{flex-direction:column;gap:.15rem;min-width:0;display:flex}.perf-item-datevenue{font-family:var(--mono);color:var(--ink);font-size:.8rem}.perf-no-date,.perf-venue{color:var(--muted)}.perf-event-name{font-family:var(--serif);color:var(--gold-text);font-size:.85rem;font-style:italic}.perf-notes{color:var(--muted);white-space:pre-wrap;font-size:.85rem}.perf-item-actions{flex-shrink:0;gap:.25rem;display:flex}.perf-delete-btn{cursor:pointer;color:var(--rust);border-radius:var(--r);min-width:1.5rem;min-height:1.5rem;transition:opacity var(--trans-speed);background:0 0;border:none;justify-content:center;align-items:center;padding:.15rem .25rem;font-size:.8rem;display:flex}.perf-delete-btn:hover{opacity:.7}.perf-add-btn{align-self:flex-start;margin-top:.25rem}.sh-root{max-width:900px;margin:0 auto}.sh-greeting{border-bottom:1px solid var(--line);margin-bottom:2rem;padding-bottom:1.5rem}.sh-headline{font-family:var(--serif);letter-spacing:.01em;margin:0 0 .2rem;font-size:2rem;font-weight:300}.sh-sub{font-family:var(--serif);color:var(--muted);margin:0;font-size:1rem;font-style:italic}.sh-invite-banner{border:1px solid #e0c870;border-left:3px solid var(--gold);border-radius:var(--r);background:#fdf6e3;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:.85rem 1.1rem;display:flex}.sh-invite-title{font-family:var(--mono);letter-spacing:.05em;color:var(--ink);font-size:.8rem;font-weight:500;display:block}.sh-invite-sub{font-family:var(--serif);color:var(--muted);margin:.2rem 0 0;font-size:.85rem}.sh-invite-btn{flex-shrink:0}.sh-panel{background:var(--white);border:1px solid var(--line);border-radius:var(--r);border-left:3px solid #0000;margin-bottom:1rem;box-shadow:0 1px 4px #1a12080f}.sh-panel-flex{flex-direction:column;display:flex}.sh-panel-header{border-bottom:1px solid var(--line);padding:.75rem 1.1rem}.sh-panel-body{padding:.85rem 1.1rem}.sh-panel-body-flex{flex:1}.sh-section-hdr{justify-content:space-between;align-items:center;gap:1rem;display:flex}.sh-section-label{font-family:var(--mono);letter-spacing:.09em;text-transform:uppercase;color:var(--muted);align-items:center;gap:.5rem;margin:0;font-size:.75rem;font-weight:400;display:flex}.sh-section-count{background:var(--cream);border:1px solid var(--line);color:var(--muted);font-variant-numeric:tabular-nums;border-radius:2px;padding:0 .35em;font-size:.7rem}.sh-section-action{font-family:var(--mono);letter-spacing:.04em;color:var(--muted);cursor:pointer;transition:color var(--trans-speed);background:0 0;border:none;flex-shrink:0;padding:0;font-size:.75rem}.sh-section-action:hover{color:var(--ink)}.sh-empty-stand{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;padding:.25rem 0;display:flex}.sh-empty-primary{font-family:var(--serif);color:var(--ink);margin:0 0 .25rem;font-size:1rem}.sh-empty-secondary{font-family:var(--serif);color:var(--muted);margin:0;font-size:.88rem;font-style:italic}.sh-empty-btn{flex-shrink:0}.sh-empty-col{font-family:var(--serif);color:var(--muted);margin:0;font-size:.88rem;font-style:italic;line-height:1.5}.sh-two-col{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}@media (width<=640px){.sh-two-col{grid-template-columns:1fr}}.sh-piece-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.5rem;display:grid}.sh-piece-card{cursor:pointer;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);transition:box-shadow var(--trans-speed);border-left:3px solid #0000;flex-direction:column;gap:.25rem;padding:.65rem .8rem;display:flex}.sh-piece-card:hover{box-shadow:0 2px 8px #1a12081a}.sh-card-title{font-family:var(--mono);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;line-height:1.35;display:-webkit-box;overflow:hidden}.sh-card-composer{font-family:var(--serif);color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.sh-compact-list{flex-direction:column;gap:0;display:flex}.sh-compact-row{border-radius:var(--r);cursor:pointer;transition:background var(--trans-speed);border-bottom:1px solid var(--line);align-items:center;gap:.5rem;padding:.5rem .4rem;display:flex}.sh-compact-row:hover{background:var(--cream)}.sh-compact-row:last-child{border-bottom:none}.sh-compact-grade{flex-shrink:0;font-size:.7rem}.sh-compact-info{flex:1;min-width:0}.sh-compact-title{font-family:var(--mono);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.sh-compact-composer{font-family:var(--serif);color:var(--muted);font-size:.8rem}.sh-rank{font-family:var(--mono);color:var(--muted);text-align:right;flex-shrink:0;width:1.2rem;font-size:.75rem}.sh-saves{font-family:var(--mono);color:var(--muted);flex-shrink:0;font-size:.75rem}.timeline-wrap{position:relative;overflow-x:auto}.timeline-empty{font-family:var(--serif);color:var(--muted);margin:0;padding:.5rem 0;font-size:.88rem}.timeline-tooltip{background:var(--white);border:1px solid var(--line);border-radius:var(--r);font-size:.8rem;font-family:var(--mono);pointer-events:none;white-space:nowrap;z-index:10;padding:.4rem .65rem;position:absolute;top:0;box-shadow:0 2px 8px #0000001a}.timeline-tooltip-title{color:var(--ink);white-space:normal;max-width:220px;font-weight:500;line-height:1.3}.timeline-tooltip-composer{color:var(--muted)}.timeline-tooltip-grade{color:var(--rust);margin-top:.2rem}.timeline-tooltip-style{color:var(--muted);font-size:.75rem}.progress-timeline-card{padding:.9rem 1rem .5rem}.progress-section-note{letter-spacing:0;color:var(--muted);text-transform:none;margin-left:.6rem;font-size:.75rem;font-weight:300}.progress-section-hdr--spaced{margin-top:2.25rem}.progress-piece-row--readonly{cursor:default}.progress-piece-grade-col{flex-direction:column;flex-shrink:0;align-items:flex-start;gap:.2rem;display:flex}.progress-piece-main{flex:1;min-width:0}.verify-banner{border-radius:var(--r);font-family:var(--mono);letter-spacing:.04em;color:#7a6200;background:#fdf8e8;border:1px solid #e8d890;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.6rem 1rem;font-size:.75rem;display:flex}.billing-success-banner{font-family:var(--mono);letter-spacing:.04em;border-radius:var(--r);color:#2a6a2a;background:#f0f7f0;border:1px solid #aacbaa;margin-bottom:1rem;padding:.65rem .9rem;font-size:.75rem}.billing-portal-unavailable{color:var(--muted);font-size:.88rem;font-style:italic}.btn-full{justify-content:center;width:100%}.interval-toggle{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);gap:3px;width:fit-content;margin:1.25rem 0 1rem;padding:3px;display:flex}.interval-btn{border-radius:calc(var(--r) - 1px);color:var(--muted);font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:background var(--trans-speed), color var(--trans-speed), box-shadow var(--trans-speed);white-space:nowrap;background:0 0;border:none;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.75rem;display:flex}.interval-btn:hover{color:var(--ink)}.interval-btn--active{background:var(--white);color:var(--ink);box-shadow:0 1px 3px #0000001a}.savings-chip{color:var(--gold-text);letter-spacing:.04em;background:#7a5a001f;border-radius:2px;padding:.1rem .4rem;font-size:.65rem;font-weight:500;display:inline-block}.price-display{align-items:baseline;gap:.35rem;margin:.75rem 0 1rem;display:flex}.price-amount{color:var(--ink);font-size:2rem;font-weight:300;line-height:1}.price-interval{font-family:var(--mono);letter-spacing:.05em;color:var(--muted);text-transform:uppercase;font-size:.75rem}.price-monthly-equiv{font-family:var(--mono);color:var(--muted);margin-left:.25rem;font-size:.75rem}.price-display--contact .price-amount{color:var(--muted);font-size:1.5rem}.teacher-tiers{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.teacher-tier-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex;position:relative}.teacher-tier-card--highlight{border-color:var(--gold);box-shadow:0 2px 10px #c9a84c26}.tier-popular-badge{background:var(--gold-text);color:var(--paper);font-family:var(--mono);letter-spacing:.07em;text-transform:uppercase;border-radius:0 0 var(--r) var(--r);padding:.2rem .5rem;font-size:.62rem;position:absolute;top:-1px;right:1rem}.tier-card-header{margin-bottom:.1rem}.tier-card-name{font-size:1rem;font-weight:400}.tier-card-tagline{color:var(--muted);margin-top:.15rem;font-size:.82rem}.tier-student-limit{font-family:var(--mono);letter-spacing:.04em;color:var(--muted);text-transform:uppercase;font-size:.72rem}.teacher-tier-card .pro-perks{flex:1;margin:0}.usage-meter{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:1rem 0;padding:.75rem 0}.usage-header{justify-content:space-between;align-items:baseline;margin-bottom:.4rem;display:flex}.usage-of{color:var(--muted);font-size:.85em}.usage-warn{color:var(--rust)!important}.usage-bar-track{background:var(--line);border-radius:99px;height:5px;overflow:hidden}.usage-bar-fill{background:var(--gold);border-radius:99px;height:100%;transition:width .3s}.usage-bar-fill--warn{background:var(--rust)}.usage-near-limit,.usage-at-limit{color:var(--rust);margin-top:.5rem;font-size:.78rem;font-style:italic}.rec-card-grade{flex-shrink:0;align-self:flex-start;margin-left:.5rem}.rec-card-tags{margin-top:.45rem}.gate-banner-spaced{margin-top:1.5rem}.pop-piece-main{flex:1;min-width:0}.pop-style-tag{flex-shrink:0}.assigned-grade-badge{flex-shrink:0;margin-top:.2rem}.assigned-tap-hint{color:var(--muted)}.assigned-note{background:var(--cream);border-radius:var(--r);font-family:var(--serif);color:var(--ink);margin-top:.5rem;padding:.4rem .6rem;font-size:.85rem;font-style:italic}.inv-root{max-width:640px}.inv-section{margin-bottom:2rem}.inv-section-heading{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem;font-size:.75rem}.inv-list{flex-direction:column;gap:.5rem;display:flex}.inv-list--gap-lg{gap:.75rem}.inv-empty{color:var(--muted);font-family:var(--serif);font-size:.9rem}.invite-card{border:1px solid var(--gold);border-radius:var(--r);background:var(--white);padding:1.1rem 1.25rem}.invite-card-title{font-family:var(--mono);color:var(--ink);margin:0 0 .4rem;font-size:.9rem}.invite-card-email{font-family:var(--serif);color:var(--muted);margin:0 0 1rem;font-size:.85rem}.invite-card-info{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);font-family:var(--serif);color:var(--muted);margin-bottom:1rem;padding:.7rem .9rem;font-size:.85rem}.invite-card-info-label{color:var(--ink);font-weight:500}.invite-card-actions{flex-wrap:wrap;gap:.6rem;display:flex}.invite-card-accept{min-width:160px}.btn-muted{color:var(--muted)}.teacher-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1rem;display:flex}.teacher-row-info{flex-wrap:wrap;align-items:baseline;gap:.6rem;display:flex}.teacher-row-name{font-family:var(--mono);color:var(--ink);font-size:.85rem}.teacher-row-email{color:var(--muted);font-size:.78rem;font-family:var(--serif)}.btn-danger{background:var(--rust);color:var(--paper);border-color:var(--rust)}.btn-danger:hover{background:#6e2c1e;border-color:#6e2c1e}.disc-modal-overlay{background:#00000073}.disc-modal-card{width:100%;max-width:400px}.disc-modal-title{margin-bottom:.75rem;font-size:1rem;font-weight:500}.disc-modal-body{font-family:var(--serif);color:var(--muted);margin-bottom:1.25rem;font-size:.9rem}.disc-modal-actions{justify-content:flex-end;gap:.6rem;display:flex}.date-inputs-actions{gap:.3rem;margin-top:auto}.field-label-optional{text-transform:none;letter-spacing:0;color:var(--muted);font-size:.75rem;font-weight:300}.modal-grade-link{cursor:pointer;text-underline-offset:2px;text-decoration:underline}.lib-content{margin-top:1.25rem}.date-fields-col{flex-direction:column;gap:.45rem;display:flex}.date-fields-col .field-label{min-width:5rem;margin-bottom:0}.piece-row[role=button]:focus-visible{background:var(--cream);outline-offset:-2px}.piece-grade.clickable[role=button]:focus-visible{outline:2px solid var(--gold-text);outline-offset:2px;border-radius:2px}.rec-card[role=button]:focus-visible{border-color:var(--gold);box-shadow:0 2px 8px #0000000f}.pop-item[role=button]:focus-visible{background:var(--cream)}.progress-piece-row[role=button]:focus-visible{background:var(--cream);border-radius:var(--r);padding-left:.35rem}.assigned-row[role=button]:focus-visible,.sh-compact-row[role=button]:focus-visible{background:var(--cream)}.sh-piece-card[role=button]:focus-visible{box-shadow:0 2px 8px #1a12081a}button.logo{cursor:pointer;background:0 0;border:none;padding:0}button.logo:focus-visible{outline:2px solid var(--gold-lt);outline-offset:3px;border-radius:var(--r)}.perf-toggle-hdr:focus-visible{outline:2px solid var(--gold-text);outline-offset:2px;border-radius:var(--r)}.combobox-wrap,.combobox-container{position:relative}.combobox-searching{font-family:var(--mono);color:var(--muted);margin-top:.25rem;font-size:.75rem;display:block}.combobox-listbox{background:var(--white);border:1px solid var(--line);border-radius:var(--r);z-index:50;max-height:260px;margin:0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.combobox-option{cursor:pointer;border-bottom:1px solid var(--line);align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.combobox-option:last-child{border-bottom:none}.combobox-option--active{background:var(--cream)}.combobox-option--disabled{opacity:.5;cursor:default}.combobox-option-text{flex:1;min-width:0}.combobox-option-title{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.combobox-option-composer{font-family:var(--mono);color:var(--muted);font-size:.7rem}.combobox-option-badge{font-size:.68rem;font-family:var(--mono);color:var(--muted);flex-shrink:0}.th-root{max-width:960px;margin:0 auto;padding-bottom:3rem}.th-header{margin-bottom:2.5rem}.th-header-sub{color:var(--ink);margin:.25rem 0 0;font-size:1rem}.th-new-students{color:var(--sage)}.th-pulse-row{border:1px solid var(--line);border-radius:var(--r);background:var(--white);grid-template-columns:repeat(4,1fr);margin-bottom:2.5rem;display:grid;overflow:hidden}.th-pulse-card{background:var(--white);border-right:1px solid var(--line);cursor:default;transition:background var(--trans-speed);text-align:left;border-top:3px solid #0000;padding:1.5rem 1.4rem 1.25rem;font-family:inherit;position:relative}.th-pulse-card--last{border-right:none}.th-pulse-card--clickable{cursor:pointer;border:none;width:100%}.th-pulse-card--clickable:hover,.th-pulse-card--clickable:focus-visible{background:var(--cream)}.th-pulse-val{font-family:var(--serif);margin-bottom:.5rem;font-size:2.75rem;font-weight:300;line-height:1}.th-pulse-label{color:var(--ink);margin-bottom:.15rem;font-size:.9rem;font-weight:600;line-height:1.3}.th-pulse-sub{color:var(--muted);font-size:.82rem;line-height:1.4}.th-pulse-arrow{color:var(--muted);transition:color var(--trans-speed);font-size:.75rem;position:absolute;top:1.25rem;right:1.1rem}.th-pulse-card--clickable:hover .th-pulse-arrow,.th-pulse-card--clickable:focus-visible .th-pulse-arrow{color:var(--gold-text)}.th-all-good{border-radius:var(--r);background:#f0f8f0;border:1px solid #a8d5a8;align-items:center;gap:.85rem;margin-bottom:2rem;padding:1rem 1.25rem;display:flex}.th-all-good-icon{color:var(--sage);flex-shrink:0;font-size:1rem}.th-all-good-text{color:#1e4020;font-size:.95rem;font-weight:500}.th-attention{margin-bottom:2.5rem}.th-attention-hdr{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.th-section-heading{font-family:var(--serif);color:var(--ink);margin:0;font-size:1.4rem;font-weight:400}.th-section-heading--serif{margin-bottom:.85rem}.th-attention-badge{color:var(--rust);background:#fde8e3;border-radius:2px;padding:.1rem .6rem;font-size:.82rem;font-weight:700}.th-att-list{border-radius:var(--r);border:2px solid #d4a090;overflow:hidden}.th-att-row{background:var(--white);flex-wrap:wrap;align-items:center;gap:.75rem;padding:.9rem 1.25rem;display:flex}.th-att-row--divider{border-bottom:1px solid var(--line)}.att-tag{letter-spacing:.05em;text-transform:uppercase;text-align:center;border-radius:2px;flex-shrink:0;min-width:5.5rem;padding:.2rem .5rem;font-size:.75rem;font-weight:700}.att-tag--overdue{color:var(--rust);background:#fde8e3}.att-tag--inactive{color:var(--studying-text);background:#fff0d0}.att-tag--pending{background:var(--cream);color:var(--muted)}.th-att-name{color:var(--ink);font-size:1rem;font-weight:500}.th-att-detail{color:var(--muted);font-size:.95rem}.th-att-spacer{flex:1}.th-att-meta{color:var(--muted);white-space:nowrap;font-size:.875rem}.th-att-overdue-days{color:var(--rust);white-space:nowrap;font-size:.875rem;font-weight:600}.dash-btn{border-radius:var(--r);border:1px solid var(--line);color:var(--ink);cursor:pointer;background:0 0;flex-shrink:0;padding:.3rem .85rem;font-size:.85rem;font-weight:500;transition:all .12s}.dash-btn:hover,.dash-btn:focus-visible{border-color:var(--ink);background:var(--ink);color:var(--paper)}.th-activity-list{border:1px solid var(--line);border-radius:var(--r);background:var(--white);overflow:hidden}.th-activity-empty{text-align:center;padding:2.5rem 1.5rem}.th-activity-empty-primary{font-family:var(--serif);color:var(--muted);margin:0 0 .35rem;font-size:1.05rem;font-style:italic}.th-activity-empty-sub{color:var(--muted);margin:0;font-size:.9rem}.th-act-row{cursor:pointer;transition:background var(--trans-speed);align-items:flex-start;gap:.9rem;padding:.95rem 1.25rem;display:flex}.th-act-row--divider{border-bottom:1px solid var(--line)}.th-act-row:hover,.th-act-row:focus-visible{background:var(--cream);outline-offset:-2px}.act-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:.45rem}.act-dot--completed{background:var(--sage)}.act-dot--started{background:var(--gold)}.act-dot--default{background:var(--line)}.th-act-body{flex:1;min-width:0}.th-act-top{flex-wrap:wrap;align-items:baseline;gap:.4rem;margin-bottom:.2rem;display:flex}.th-act-student{font-family:var(--serif);color:var(--ink);font-size:1.05rem;font-weight:400}.th-act-verb{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-size:.8rem;font-weight:600}.th-act-piece{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.th-act-grade{font-size:.62rem}.th-act-title{font-family:var(--serif);color:var(--ink);text-overflow:ellipsis;white-space:nowrap;max-width:260px;font-size:.95rem;font-style:italic;overflow:hidden}.th-act-composer{color:var(--muted);white-space:nowrap;font-size:.85rem}.th-act-time{color:var(--muted);white-space:nowrap;padding-top:.2rem;font-size:.82rem}.th-events-hdr{justify-content:space-between;align-items:baseline;margin-bottom:.85rem;display:flex}.th-events-all-btn{color:var(--gold-text);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:.85rem;font-weight:500;text-decoration:underline}.th-events-all-btn:hover,.th-events-all-btn:focus-visible{color:var(--ink)}.th-events-empty{border:1px solid var(--line);border-radius:var(--r);text-align:center;background:var(--white);padding:2rem 1.25rem}.th-events-empty-text{font-family:var(--serif);color:var(--muted);margin:0 0 1rem;font-size:1rem;font-style:italic}.th-events-list{flex-direction:column;gap:.6rem;display:flex}.th-event-card{border:1px solid var(--line);border-radius:var(--r);cursor:pointer;background:var(--white);transition:border-color var(--trans-speed), box-shadow var(--trans-speed);align-items:stretch;display:flex;overflow:hidden}.th-event-card:hover,.th-event-card:focus-visible{border-color:var(--gold);outline-offset:-2px;box-shadow:0 2px 10px #00000012}.th-event-date{background:var(--cream);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:62px;padding:.85rem 0;display:flex}.th-event-date--soon{background:var(--gold)}.th-event-month{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem;font-size:.65rem;line-height:1}.th-event-date--soon .th-event-month{color:#ffffffe6}.th-event-day{font-family:var(--serif);color:var(--ink);font-size:2rem;font-weight:300;line-height:1}.th-event-date--soon .th-event-day{color:var(--white)}.th-event-body{min-width:0;transition:background var(--trans-speed);flex:1;padding:.85rem 1rem}.th-event-card:hover .th-event-body{background:var(--cream)}.th-event-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.15rem;font-size:.95rem;font-weight:600;overflow:hidden}.th-event-venue{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.2rem;font-size:.85rem;overflow:hidden}.th-event-meta{color:var(--muted);font-size:.82rem}.th-lower{grid-template-columns:1fr 310px;align-items:start;gap:2rem;display:grid}@media (width<=720px){.th-lower{grid-template-columns:1fr}}@media (width<=640px){.th-pulse-row{grid-template-columns:1fr 1fr}}.sd-root{max-width:700px}.sd-sub{color:var(--muted);font-family:var(--serif);margin-bottom:2rem;font-size:.9rem}.sd-invite-card{margin-bottom:2rem}.sd-card-heading{letter-spacing:.04em;margin-bottom:1rem;font-size:1rem;font-weight:500}.sd-limit-banner{border-radius:var(--r);font-family:var(--serif);color:#7a4200;background:#fdf8e8;border:1px solid #e8d890;margin-bottom:1rem;padding:.8rem 1rem;font-size:.88rem}.sd-upgrade-link{cursor:pointer;color:inherit;font:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.sd-invite-form{flex-wrap:wrap;align-items:flex-start;gap:.6rem;display:flex}.sd-invite-input-wrap{flex:1;min-width:200px}.sd-invite-err{color:var(--rust);font-family:var(--serif);margin:.35rem 0 0;font-size:.82rem}.sd-loading{color:var(--muted);font-family:var(--serif)}.sd-section{margin-bottom:2rem}.sd-section-heading{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem;font-size:.75rem}.sd-list{flex-direction:column;gap:.5rem;display:flex}.sd-invalid{color:var(--muted)}.sd-student-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1rem;display:flex}.sd-student-info{flex:1;min-width:0}.sd-student-name{font-family:var(--mono);color:var(--ink);font-size:.85rem}.sd-student-email{color:var(--muted);font-size:.75rem;font-family:var(--serif);margin-left:.6rem}.sd-student-actions{flex-shrink:0;gap:.4rem;display:flex}.sd-pending-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);opacity:.8;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1rem;display:flex}.sd-pending-label{font-size:.72rem;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.sdet-root{max-width:800px}.sdet-header{align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.sdet-name{margin:0;font-size:1.5rem;font-weight:300}.sdet-email{color:var(--muted);font-family:var(--serif);margin:.1rem 0 0;font-size:.83rem}.sdet-status-section{margin-bottom:1.75rem}.sdet-status-heading{letter-spacing:.09em;text-transform:uppercase;margin-bottom:.6rem;font-size:.72rem}.sdet-piece-list{flex-direction:column;gap:.35rem;display:flex}.sdet-piece-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:background var(--trans-speed);grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;padding:.6rem .9rem;display:grid}.sdet-piece-row:hover,.sdet-piece-row:focus-visible{background:var(--cream);outline-offset:-2px}.sdet-piece-info{min-width:0}.sdet-piece-title{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.sdet-piece-composer{font-family:var(--mono);color:var(--muted);font-size:.72rem}.sdet-piece-date{font-family:var(--mono);color:var(--muted);text-align:right;white-space:nowrap;font-size:.7rem}.sdet-assign-list{flex-direction:column;gap:.6rem;margin-bottom:1.25rem;display:flex}.sdet-assignment-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:.75rem 1rem}.sdet-assignment-main{flex:1;min-width:0}.sdet-assignment-top{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.15rem;display:flex}.sdet-assignment-title{font-size:.92rem;font-weight:400}.sdet-assignment-composer{font-family:var(--mono);color:var(--muted);font-size:.72rem}.sdet-assignment-meta{font-size:.75rem;font-family:var(--mono);color:var(--muted);flex-wrap:wrap;gap:1rem;margin-top:.5rem;display:flex}.sdet-assignment-note{font-family:var(--serif);color:var(--muted);margin-top:.45rem;font-size:.83rem;font-style:italic}.sdet-confirm-inline{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.sdet-confirm-label{color:var(--muted);font-size:.78rem;font-family:var(--serif)}.sdet-assign-form-card{margin-top:.5rem}.sdet-assign-form-heading{letter-spacing:.04em;margin-bottom:1rem;font-size:.9rem;font-weight:500}.sdet-selected-piece{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);font-family:var(--serif);margin-bottom:1rem;padding:.5rem .75rem;font-size:.85rem}.sdet-selected-composer{color:var(--muted)}.sdet-already-assigned{color:var(--rust);margin-top:.2rem;font-size:.8rem;display:block}.sdet-form-actions{justify-content:flex-end;gap:.6rem;display:flex}.pe-root{max-width:720px}.pe-list-header{justify-content:space-between;align-items:baseline;margin-bottom:1.5rem;display:flex}.pe-sub{color:var(--muted);font-family:var(--serif);margin:.2rem 0 0;font-size:.88rem}.pe-section{margin-bottom:2rem}.pe-section-heading{letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem;font-size:.72rem}.pe-event-list{flex-direction:column;gap:.4rem;display:flex}.pe-event-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:background var(--trans-speed);justify-content:space-between;align-items:center;padding:.7rem 1rem;display:flex}.pe-event-row--dim{opacity:.7}.pe-event-row:hover,.pe-event-row:focus-visible{background:var(--cream);outline-offset:-2px}.pe-event-name{font-size:.95rem;font-weight:400}.pe-event-meta{font-family:var(--mono);color:var(--muted);margin-top:.15rem;font-size:.72rem}.pe-event-right{align-items:center;gap:.75rem;display:flex}.pe-event-count{font-family:var(--mono);color:var(--muted);font-size:.72rem}.pe-event-arrow{color:var(--muted);font-size:.8rem}.pe-form-card{margin-bottom:1.5rem}.pe-form-heading{margin-bottom:1rem;font-size:.9rem;font-weight:500}.pe-date-venue-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.pe-form-actions{justify-content:flex-end;gap:.6rem;display:flex}.pe-detail-root{max-width:760px}.pe-detail-header{flex-wrap:wrap;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.pe-detail-title-wrap{flex:1;min-width:0}.pe-detail-title{margin:0;font-size:1.5rem;font-weight:300}.pe-detail-meta{font-family:var(--mono);color:var(--muted);margin:.2rem 0 0;font-size:.75rem}.pe-detail-notes{font-family:var(--serif);color:var(--muted);margin:.4rem 0 0;font-size:.85rem}.pe-detail-actions{flex-shrink:0;gap:.4rem;display:flex}.pe-participants-hdr{justify-content:space-between;align-items:baseline;margin-bottom:.75rem;display:flex}.pe-participant-list{flex-direction:column;gap:.4rem;margin-bottom:1rem;display:flex}.pe-participant-row{background:var(--white);border:1px solid var(--line);border-radius:var(--r);grid-template-columns:1fr 1fr auto;align-items:center;gap:.75rem;padding:.65rem 1rem;display:grid}.pe-participant-name{font-family:var(--mono);color:var(--ink);font-size:.82rem}.pe-participant-piece{min-width:0}.pe-participant-piece-top{align-items:center;gap:.4rem;display:flex}.pe-participant-title{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;overflow:hidden}.pe-participant-composer{font-family:var(--mono);color:var(--muted);font-size:.7rem}.pe-participant-note{font-family:var(--serif);color:var(--muted);margin-top:.15rem;font-size:.78rem;font-style:italic}.pe-add-form-card{margin-top:.75rem}:root{--baroque-bg:#eef0f8;--baroque-text:#2d3a6b;--classical-bg:#edf7ed;--classical-text:#2d5c2d;--romantic-bg:#fdf0ee;--romantic-text:#7a2a1a;--c20-bg:#f5f0fa;--c20-text:#4a2d6b}.ptag-baroque{background:var(--baroque-bg);color:var(--baroque-text)}.ptag-classical{background:var(--classical-bg);color:var(--classical-text)}.ptag-romantic{background:var(--romantic-bg);color:var(--romantic-text)}.ptag-c20{background:var(--c20-bg);color:var(--c20-text)}
