:root{--ink: #1a1814;--ink-soft: #534f48;--ink-mute: #7a7568;--paper: #f4ede0;--paper-light: #faf5ea;--paper-lighter: #fdf9ef;--rule: #c9bfa8;--rule-soft: #e4dcc6;--accent: #2e5339;--accent-soft: #a8b5a0;--warm: #8b3a1f;--warm-soft: #c28161;--gold: #a07a2c;--font-display: "Fraunces", "Iowan Old Style", "Palatino", serif;--font-body: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);background-image:radial-gradient(ellipse at top left,rgba(160,122,44,.05),transparent 50%),radial-gradient(ellipse at bottom right,rgba(46,83,57,.04),transparent 50%);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.ttb-header{display:flex;justify-content:space-between;align-items:flex-end;padding-bottom:1.25rem;border-bottom:2px solid var(--ink);position:relative;flex-wrap:wrap;gap:1rem}.ttb-header:after{content:"";position:absolute;bottom:-6px;left:0;right:0;border-bottom:1px solid var(--ink)}.ttb-brand{display:flex;align-items:center;gap:.9rem}.ttb-mark{font-family:var(--font-display);font-size:2.5rem;color:var(--warm);line-height:1}.ttb-title{font-family:var(--font-display);font-weight:700;font-size:2rem;letter-spacing:-.01em;margin:0 0 .15rem;font-variation-settings:"opsz" 144}.ttb-sub{font-family:var(--font-display);font-style:italic;color:var(--ink-soft);margin:0;font-size:.95rem;font-weight:400}.ttb-status{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.ttb-user-switch{display:flex;align-items:center;gap:.5rem;padding:.25rem .7rem .25rem .3rem;border:1px solid var(--rule);background:var(--paper-light);border-radius:2px}.ttb-user-switch select{border:none;background:transparent;font-family:var(--font-body);font-size:.85rem;padding:0;cursor:pointer;color:var(--ink)}.ttb-user-switch select:focus{outline:none}.ttb-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.3rem .7rem;border:1px solid var(--rule);background:var(--paper-light);font-family:var(--font-body);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;color:var(--ink-soft);border-radius:2px}.ttb-chip.on{border-color:var(--accent);color:var(--accent)}.ttb-chip.off{border-color:var(--warm);color:var(--warm)}.ttb-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.ttb-pending-label{font-size:.75rem;color:var(--ink-soft);font-style:italic;font-family:var(--font-display)}.ttb-nav{display:flex;gap:0;margin:1.75rem 0 1.5rem;align-items:center;flex-wrap:wrap}.ttb-nav>button{background:transparent;border:none;padding:.5rem 1.1rem;font-family:var(--font-display);font-size:1.05rem;color:var(--ink-soft);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s}.ttb-nav>button:hover{color:var(--ink)}.ttb-nav>button.active{color:var(--ink);border-bottom-color:var(--warm);font-weight:600}.ttb-nav .ttb-add{margin-left:auto;background:var(--ink);color:var(--paper-light);border-radius:2px;font-family:var(--font-body);font-size:.85rem;font-weight:500;padding:.5rem .9rem;border-bottom:none;margin-bottom:0}.ttb-nav .ttb-add:hover{background:var(--warm);color:var(--paper-light)}.ttb-controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.ttb-controls-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.ttb-search{flex:1;min-width:14rem;padding:.6rem .85rem;border:1px solid var(--rule);background:var(--paper-light);font-family:var(--font-display);font-size:.98rem;border-radius:2px;color:var(--ink)}.ttb-search:focus{outline:none;border-color:var(--ink)}.ttb-scope-toggle,.ttb-filter-group{display:inline-flex;border:1px solid var(--rule);background:var(--paper-light);border-radius:2px}.ttb-scope-toggle button,.ttb-filter-group button{background:transparent;border:none;padding:.45rem .9rem;font-family:var(--font-body);font-size:.82rem;color:var(--ink-soft);cursor:pointer;border-right:1px solid var(--rule)}.ttb-scope-toggle button:last-child,.ttb-filter-group button:last-child{border-right:none}.ttb-scope-toggle button.active,.ttb-filter-group button.active{background:var(--ink);color:var(--paper-light)}.ttb-select{padding:.4rem .6rem;border:1px solid var(--rule);background:var(--paper-light);font-family:var(--font-body);font-size:.85rem;color:var(--ink);border-radius:2px}.ttb-select:focus{outline:none;border-color:var(--ink)}.ttb-count{font-size:.82rem;color:var(--ink-soft);font-style:italic;font-family:var(--font-display)}.avatar{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:500;color:#fff;flex-shrink:0;font-family:var(--font-body)}.avatar-sm{width:18px;height:18px;font-size:10px}.avatar-lg{width:30px;height:30px;font-size:13px}.avatars-row{display:inline-flex;align-items:center}.avatars-row .avatar{margin-right:-6px;border:1.5px solid var(--paper)}.avatars-row .avatar:last-child{margin-right:0}.avatars-row .avatar-more{margin-left:8px;font-size:11px;color:var(--ink-mute);font-family:var(--font-display);font-style:italic}.ttb-table{list-style:none;padding:0;margin:0}.ttb-row{display:grid;grid-template-columns:2.4fr .9fr .6fr .8fr 1.1fr 1fr;align-items:center;padding:.75rem .25rem;border-bottom:1px solid var(--rule-soft);gap:.75rem;cursor:pointer;transition:background .15s}.ttb-row:hover{background:var(--paper-light)}.ttb-row-head{cursor:default;font-family:var(--font-body);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--ink);padding-bottom:.5rem}.ttb-row-head:hover{background:transparent}.c-name{display:flex;align-items:center;gap:.5rem}.tune-name{font-family:var(--font-display);font-size:1.05rem;font-weight:500}.tune-note-mark{color:var(--warm);margin-left:.3rem;font-weight:700}.c-type em{font-family:var(--font-display);font-style:italic;color:var(--ink-soft)}.c-key{font-family:var(--font-display);font-feature-settings:"tnum";color:var(--ink-soft)}.c-also-in{display:flex;align-items:center;font-size:.8rem;color:var(--ink-mute)}.c-also-in .avatars-row+span{margin-left:.6rem;font-style:italic;font-family:var(--font-display)}.c-also-in .none{color:var(--rule);font-family:var(--font-display);font-style:italic}.pill{display:inline-block;padding:.15rem .55rem;font-family:var(--font-body);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;border:1px solid;border-radius:2px}.pill-know{color:var(--accent);border-color:var(--accent-soft);background:#a8b5a026}.pill-learning{color:var(--warm);border-color:var(--warm);background:#8b3a1f14}.c-links{display:flex;gap:.6rem;align-items:center;font-size:.82rem}.link-session{color:var(--accent);text-decoration:none;font-family:var(--font-body);border-bottom:1px dotted var(--accent);padding-bottom:1px;font-size:.82rem}.link-session:hover{border-bottom-style:solid}.link-pending{color:var(--ink-mute);font-style:italic;font-family:var(--font-display);font-size:.8rem}.link-nomatch{color:var(--rule);font-family:var(--font-display);font-style:italic;font-size:.78rem}.link-rec{color:var(--gold);font-size:1.1rem;text-decoration:none}.link-ambiguous{color:var(--warm);font-family:var(--font-display);font-style:italic;font-size:.8rem;cursor:pointer;text-decoration:underline}.ttb-empty{padding:3rem 1rem;text-align:center;color:var(--ink-soft);font-family:var(--font-display);font-style:italic;font-size:1.05rem}.ttb-practice-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:.6rem 1rem;background:var(--paper-light);border:1px solid var(--rule);border-radius:2px;margin-bottom:1.25rem;flex-wrap:wrap}.ttb-practice-bar-group{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.ttb-practice-bar label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-family:var(--font-body)}.ttb-skip-badge{font-size:.82rem;font-family:var(--font-display);font-style:italic;color:var(--ink-soft)}.ttb-practice-start{text-align:center;padding:2.5rem 1rem;max-width:32rem;margin:0 auto}.ttb-practice-start h2{font-family:var(--font-display);font-size:2.4rem;font-weight:600;margin:0 0 .5rem;font-variation-settings:"opsz" 144}.ttb-practice-intro{color:var(--ink-soft);font-family:var(--font-display);font-size:1.05rem;line-height:1.5;margin-bottom:2rem}.ttb-practice-card{max-width:36rem;margin:0 auto;padding:2.5rem 2rem;background:var(--paper-light);border:1px solid var(--rule);position:relative;text-align:center}.ttb-practice-card:before,.ttb-practice-card:after{content:"";position:absolute;height:1px;background:var(--ink);left:1rem;right:1rem}.ttb-practice-card:before{top:6px}.ttb-practice-card:after{bottom:6px}.ttb-practice-meta{font-family:var(--font-display);font-style:italic;color:var(--ink-soft);font-size:.95rem;margin-bottom:.75rem}.ttb-practice-meta .sep{margin:0 .5rem;color:var(--rule)}.ttb-practice-name{font-family:var(--font-display);font-weight:700;font-size:3rem;line-height:1.1;margin:0 0 1.25rem;font-variation-settings:"opsz" 144;letter-spacing:-.015em}.ttb-practice-notes{font-family:var(--font-display);font-size:1.05rem;color:var(--ink-soft);line-height:1.55;margin:0 auto 1.5rem;max-width:28rem;font-style:italic}.ttb-practice-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:2rem}.ttb-practice-links a{color:var(--accent);text-decoration:none;font-family:var(--font-body);font-size:.88rem;border-bottom:1px dotted var(--accent);padding-bottom:1px}.ttb-practice-links a:hover{border-bottom-style:solid}.ttb-practice-actions{display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap}.ttb-practice-hint{margin-top:.75rem;font-size:.78rem;color:var(--ink-mute);font-style:italic;font-family:var(--font-display)}.ttb-big-btn{background:var(--ink);color:var(--paper-light);border:none;padding:.75rem 1.5rem;font-family:var(--font-body);font-size:.92rem;font-weight:500;letter-spacing:.02em;cursor:pointer;border-radius:2px;transition:background .2s}.ttb-big-btn:hover:not(:disabled){background:var(--warm)}.ttb-big-btn:disabled{opacity:.4;cursor:not-allowed}.ttb-secondary{background:transparent;border:1px solid var(--ink);color:var(--ink);padding:.7rem 1.3rem;font-family:var(--font-body);font-size:.88rem;cursor:pointer;border-radius:2px}.ttb-secondary:hover{background:var(--ink);color:var(--paper-light)}.ttb-danger{background:transparent;border:1px solid var(--warm);color:var(--warm);padding:.7rem 1.3rem;font-family:var(--font-body);font-size:.88rem;cursor:pointer;border-radius:2px}.ttb-danger:hover{background:var(--warm);color:var(--paper-light)}.ttb-edit{max-width:36rem;margin:0 auto}.ttb-edit h2{font-family:var(--font-display);font-size:1.75rem;font-weight:600;margin:0 0 1.5rem}.ttb-edit label{display:block;margin-bottom:1rem}.ttb-edit label span.field-label{display:block;font-family:var(--font-body);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:.35rem}.ttb-edit input,.ttb-edit select,.ttb-edit textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--rule);background:var(--paper-light);font-family:var(--font-display);font-size:1rem;color:var(--ink);border-radius:2px}.ttb-edit input:focus,.ttb-edit select:focus,.ttb-edit textarea:focus{outline:none;border-color:var(--ink)}.ttb-edit textarea{line-height:1.55;resize:vertical}.ttb-edit-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-bottom:.5rem}.ttb-edit-row label{margin-bottom:0}.ttb-edit-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--rule-soft)}.ttb-edit-actions .ttb-danger{margin-right:auto}.ttb-also-in{display:flex;align-items:center;gap:.5rem;padding:.7rem .9rem;background:var(--paper-light);border:1px solid var(--rule-soft);border-radius:2px;margin-bottom:1rem;font-family:var(--font-display);font-style:italic;color:var(--ink-soft);font-size:.92rem;flex-wrap:wrap}.ttb-also-in-tag{display:inline-flex;align-items:center;gap:.3rem;font-style:normal}.ttb-also-in-tag span.name{color:var(--ink)}.ttb-peer-banner{display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem;background:#a07a2c14;border:1px solid var(--gold);border-radius:2px;margin-bottom:1rem;font-size:.9rem;flex-wrap:wrap}.ttb-peer-banner a{color:var(--accent);text-decoration:underline;text-decoration-style:dotted;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;font-size:inherit}.ttb-suggestion{display:flex;align-items:center;gap:.6rem;padding:.65rem .9rem;background:#2e533912;border:1px solid var(--accent-soft);border-radius:2px;margin-bottom:1rem;font-size:.88rem;color:var(--ink);flex-wrap:wrap}.ttb-suggestion button{margin-left:auto;font-size:.8rem;padding:.3rem .7rem;background:var(--accent);color:var(--paper-light);border:none;cursor:pointer;border-radius:2px;font-family:var(--font-body)}.ttb-foot{padding-top:2rem;border-top:1px solid var(--rule-soft);font-family:var(--font-display);font-style:italic;font-size:.82rem;color:var(--ink-soft);text-align:center}.ttb-loading{padding:3rem;text-align:center;color:var(--ink-soft);font-family:var(--font-display);font-style:italic}@media (max-width: 720px){body{padding:.75rem .75rem 2rem}.ttb-header{flex-wrap:wrap;gap:.5rem;padding-bottom:.5rem}.ttb-title{font-size:1.5rem}.ttb-sub{font-size:.8rem}.ttb-mark{font-size:1.75rem}.ttb-header-right{flex-wrap:wrap;gap:.4rem}.ttb-header-right>*{font-size:.72rem!important;padding:.35rem .55rem!important}.ttb-nav{gap:.4rem;flex-wrap:wrap}.ttb-nav>button{padding:.45rem .7rem;font-size:.9rem}.ttb-nav .ttb-add{margin-left:auto;font-size:.85rem;padding:.5rem .75rem}.ttb-filter-bar{flex-wrap:wrap;gap:.4rem}.ttb-filter-bar>*{font-size:.85rem}.ttb-row-head{display:none}.ttb-row{display:grid;grid-template-columns:1fr auto;grid-template-areas:"name    status" "meta    links";gap:.25rem .6rem;padding:.65rem .4rem;align-items:center}.ttb-row .c-name{grid-area:name;min-width:0}.ttb-row .tune-name{font-size:1rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%}.ttb-row .c-status{grid-area:status;justify-self:end}.ttb-row .c-status .pill{font-size:.65rem;padding:.15rem .45rem}.ttb-row .c-type,.ttb-row .c-key,.ttb-row .c-also-in{grid-area:meta;display:inline;font-size:.78rem;color:var(--ink-soft)}.ttb-row .c-type{grid-area:meta}.ttb-row .c-type em{font-size:.78rem;font-style:italic}.ttb-row .c-key{display:none}.ttb-row .c-also-in{grid-area:meta;justify-self:start;margin-left:.5rem}.ttb-row .c-also-in .none{display:none}.ttb-row .c-links{grid-area:links;justify-self:end;font-size:.75rem;gap:.4rem}.ttb-row .c-links a{font-size:.72rem}.ttb-row>.c-type+.c-key,.ttb-row>.c-type+.c-also-in{margin-left:.4rem}.ttb-practice-name{font-size:1.75rem}.ttb-practice-card{padding:1.5rem 1rem}.ttb-edit{padding:1rem}.ttb-edit-row{grid-template-columns:1fr;gap:.6rem}.ttb-edit h2{font-size:1.3rem}.ttb-edit-actions{flex-wrap:wrap;gap:.5rem}.ttb-edit-actions>*{flex:1 1 auto;min-width:6rem}}.ttb-invite-banner{margin:1rem 0;background:#a07a2c1a;border:1px solid var(--gold);border-radius:2px;padding:.75rem 1rem}.ttb-invite-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-family:var(--font-display);color:var(--ink)}.ttb-invite-row+.ttb-invite-row{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--rule-soft)}.ttb-invite-actions{display:flex;gap:.5rem}.ttb-modal-backdrop{position:fixed;inset:0;background:#1a181480;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.ttb-modal{background:var(--paper-light);border:1px solid var(--ink);padding:1.75rem;max-width:28rem;width:100%;border-radius:2px;position:relative}.ttb-modal:before,.ttb-modal:after{content:"";position:absolute;height:1px;background:var(--ink);left:.6rem;right:.6rem}.ttb-modal:before{top:4px}.ttb-modal:after{bottom:4px}.ttb-modal h2{font-family:var(--font-display);font-weight:600;font-size:1.5rem;margin:0 0 .5rem}.ttb-modal-intro{font-family:var(--font-display);font-style:italic;color:var(--ink-soft);font-size:.95rem;line-height:1.5;margin:0 0 1.25rem}.ttb-modal label{display:block;margin-bottom:1rem}.ttb-modal label .field-label{display:block;font-family:var(--font-body);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:.35rem}.ttb-modal input{width:100%;padding:.6rem .75rem;border:1px solid var(--rule);background:var(--paper);font-family:var(--font-display);font-size:1rem;color:var(--ink);border-radius:2px;box-sizing:border-box}.ttb-modal-error{color:var(--warm);font-size:.85rem;font-family:var(--font-display);font-style:italic;margin:0 0 1rem}.ttb-modal-sent{color:var(--accent);font-size:.85rem;font-family:var(--font-display);font-style:italic;margin:0 0 1rem}.ttb-modal-actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--rule-soft)}
