:root{color-scheme:light dark;font-family:Inter,system-ui,sans-serif;background:#0f172a;color:#e2e8f0}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 20%,#1e293b,#0f172a 45%)}[data-theme=light]{color:#0f172a;background:#f8fafc}[data-theme=light] body{background:radial-gradient(circle at 20% 20%,#e2e8f0,#f8fafc 45%);color:#0f172a}.app{max-width:960px;margin:0 auto;padding:2.5rem 1.5rem 3rem}.song-detail__meta-row{display:flex;align-items:center;gap:.5rem;margin:.35rem 0 .5rem}.song-detail__meta{margin:0;font-size:.85rem;color:#94a3b8}[data-theme=light] .song-detail__meta{color:#475569}.song-detail__info-button{font-style:normal;font-weight:600}.song-detail__info-button:focus-visible{outline:2px solid currentColor;outline-offset:2px}.search{display:block}.search__layout{display:grid;grid-template-columns:92px minmax(0,1fr);gap:.5rem;align-items:start}.search__group{display:flex;align-self:start}.search__controls{min-width:0;display:grid;grid-template-rows:auto 1fr;gap:.5rem}.search__controls-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.5rem;align-items:center}.search input{width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid #1f2937;background:#ffffff14;color:inherit;min-width:0;box-sizing:border-box}.search__field{display:grid;min-width:0}.search__period-select{width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid #1f2937;background:#ffffff14;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;box-sizing:border-box}.icon-dropdown{width:100%}.icon-dropdown__native{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;border:0;clip:rect(0,0,0,0)}.icon-dropdown__details{position:relative;width:92px;height:92px}.icon-dropdown__summary{list-style:none;display:flex;align-items:center;justify-content:center;width:92px;height:92px;padding:0;border-radius:14px;border:1px solid #1f2937;background:#ffffff14;color:inherit;min-width:0;box-sizing:border-box;cursor:pointer;overflow:hidden}.icon-dropdown__summary::-webkit-details-marker{display:none}.icon-dropdown__icon{flex:0 0 auto;object-fit:cover}.icon-dropdown__icon--trigger{width:100%;height:100%;border-radius:14px;transform:none;transform-origin:center}.icon-dropdown__icon--option{width:42px;height:42px;border-radius:6px}.icon-dropdown__menu{position:absolute;top:calc(100% + .4rem);left:0;width:max-content;min-width:220px;max-width:min(280px,calc(100vw - 3rem));z-index:15;display:grid;gap:.25rem;padding:.4rem;border-radius:12px;border:1px solid #1f2937;background:#0f172a;box-shadow:0 16px 34px #00000059}.icon-dropdown__option{display:flex;align-items:center;gap:.55rem;font-size:1.5rem;border:0;background:transparent;color:inherit;text-align:left;width:100%;border-radius:8px;padding:.45rem .5rem;cursor:pointer}.icon-dropdown__option:hover,.icon-dropdown__option:focus-visible,.icon-dropdown__option[aria-selected=true]{background:#94a3b833}[data-theme=light] .search input,[data-theme=light] .search__period-select,[data-theme=light] .icon-dropdown__summary{border-color:#cbd5e1;background:#0f172a08}[data-theme=light] .icon-dropdown__menu{border-color:#cbd5e1;background:#fff;box-shadow:0 16px 34px #0f172a2e}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.5rem;margin-top:1rem}.card{padding:.5rem 1rem;border-radius:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:1rem}[data-theme=light] .card,[data-theme=light] .card--clickable{background:#fff;border:1px solid #e2e8f0;box-shadow:0 6px 18px #0f172a14}.card--clickable{width:100%;text-align:left;color:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;justify-content:flex-start;border:1px solid rgba(255,255,255,.08);background:#ffffff0d}.card--clickable:focus-visible{outline:2px solid #60a5fa;outline-offset:2px}h1,h2{margin:0}.muted{color:#94a3b8}[data-theme=light] .muted{color:#64748b}button.ghost{border:1px solid #334155;background:transparent;color:inherit;border-radius:12px;padding:.65rem .9rem;cursor:pointer}[data-theme=light] button.ghost{border-color:#cbd5e1}.theme-toggle{border:1px solid #334155;background:#ffffff0f;color:inherit;border-radius:12px;padding:.55rem .75rem;cursor:pointer;min-width:44px;min-height:44px;display:grid;place-items:center;font-size:1rem}[data-theme=light] .theme-toggle{border-color:#cbd5e1;background:#fff}.panel{margin-top:1.5rem;padding:1.25rem;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a}.panel--solid{background:#0f172a;border-color:#1f2937;box-shadow:0 14px 40px #0006}[data-theme=light] .panel{background:#fff;border-color:#e2e8f0}[data-theme=light] .panel--solid{background:#f8fafc;border-color:#e2e8f0;box-shadow:0 14px 40px #0f172a1f}.editor__list-shell{border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#ffffff08;padding:.75rem}[data-theme=light] .editor__list-shell{border-color:#e2e8f0;background:#fff}.editor__sidebar-header{margin-bottom:.5rem}.editor__list{display:flex;flex-direction:column;gap:.5rem;max-height:70vh;overflow:auto;padding-right:.35rem}.song-row{width:100%;text-align:left;border:1px solid #1f2937;background:#ffffff08;color:inherit;border-radius:12px;padding:.65rem .75rem;display:flex;justify-content:space-between;gap:.75rem;align-items:center;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease}[data-theme=light] .song-row{border-color:#e2e8f0;background:#fff}.song-row--active{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa59;background:#60a5fa14}.song-row--dragging{opacity:.6;cursor:grabbing}.song-row--drag-over{border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf859}[data-theme=light] .song-row--drag-over{border-color:#0ea5e9}.song-row__text{display:flex;flex-direction:column;gap:.15rem}.song-row__title{font-weight:600}.song-row__authors{color:#cbd5e1;font-size:.9rem}[data-theme=light] .song-row__authors{color:#475569}.song-row__meta{color:#e2e8f0;font-size:.85rem;white-space:nowrap}.editor__workspace-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:1.5rem;z-index:10}.modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172aa6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal__content{position:relative;width:min(720px,100%);height:calc(100vh - 3rem);max-height:calc(100vh - 3rem);display:flex;overflow:hidden;border-radius:14px;box-shadow:0 24px 60px #00000059}.modal .panel{margin-top:0;width:100%}.panel__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.panel__body{display:flex;flex-direction:column;gap:1rem}.song-detail{display:flex;flex-direction:column;height:100%;min-height:0;box-sizing:border-box;overflow:hidden;border-radius:inherit;padding:1.05rem 1.1rem}.song-detail .panel__header{flex:0 0 auto;align-items:flex-start;margin-bottom:.75rem}.song-detail__body{flex:1 1 auto;min-height:0;overflow:hidden}.song-detail__tab-content{min-height:0}.song-detail__tab-content--lyrics,.song-detail__tab-content--notation{height:100%;overflow:auto}.song-detail__tab-content--djembe,.song-detail__tab-content--guitar{display:flex;flex:1 1 auto;height:100%;min-height:0;overflow:hidden}.song-detail__tab-content--djembe>.performance-guide,.song-detail__tab-content--guitar>.performance-guide{flex:1 1 auto;min-height:0;height:100%}.song-detail__actions{display:flex;gap:.35rem;margin-top:.5rem;flex-wrap:wrap}.song-detail__version{margin-top:.5rem;display:grid;gap:.35rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;max-width:220px}.song-detail__version select{width:100%;padding:.75rem .85rem;border-radius:12px;border:1px solid #1f2937;background:#ffffff14;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box}[data-theme=light] .song-detail__version{color:#475569}[data-theme=light] .song-detail__version select{border-color:#cbd5e1;background:#0f172a08}.transpose-controls{display:inline-flex;align-items:center;gap:.25rem}.song-detail__actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.song-detail__actions-group{display:inline-flex;align-items:center}.transpose-controls button{padding:.55rem .65rem;font-size:.95rem}.transpose-controls__indicator{min-width:3rem;font-variant-numeric:tabular-nums}.tempo-indicator{display:inline-flex;align-items:baseline;gap:.25rem;font-variant-numeric:tabular-nums;letter-spacing:.01em;transition:color .16s ease,box-shadow .16s ease}.tempo-indicator__unit{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.tempo-indicator--pulse{color:#bfdbfe;box-shadow:0 0 0 2px #bfdbfe;transition-duration:80ms}[data-theme=light] .tempo-indicator--pulse{color:#0b3b7a;box-shadow:0 0 0 2px #0b3b7a}@media (prefers-reduced-motion: reduce){.tempo-indicator{transition:none}}.chord-toggle{padding:.55rem .65rem;font-size:.95rem;border-color:#1f2937;background:#ffffff0a}.chord-toggle__icon{display:grid;gap:.28rem;min-width:32px}.chord-toggle__icon--stacked .chord-toggle__row--top{justify-content:center}.chord-toggle__icon--stacked .chord-toggle__row--bottom{justify-content:flex-start}.chord-toggle__icon--inline .chord-toggle__row--top{flex-direction:row;justify-content:space-between;align-items:center}.chord-toggle__icon--inline .chord-toggle__row--bottom{justify-content:flex-end}.chord-toggle__row{display:flex;align-items:center;gap:.25rem}.chord-toggle__badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:5px;font-size:.65rem;font-weight:700;background:#60a5fa;color:#0b1222;box-shadow:0 0 0 1px #ffffff26}[data-theme=light] .chord-toggle__badge{color:#0f172a;box-shadow:0 0 0 1px #0f172a26}.chord-toggle__line{display:block;height:6px;border-radius:999px;background:#e2e8f0}[data-theme=light] .chord-toggle__line{background:#0f172a}.chord-toggle__line--short{width:55%}.chord-toggle__line--wide{width:100%}.chord-toggle__line--none{display:none}.song-detail .panel__body{font-size:1.08rem;line-height:1.55;gap:.85rem}.song-detail__body--djembe,.song-detail__body--guitar{gap:0}.song-detail .lyric-line{margin:.25rem 0}.performance-guide{display:grid;grid-template-rows:auto minmax(0,1fr) minmax(0,25%);gap:.9rem;min-height:0;height:100%;box-sizing:border-box;padding:.95rem;border-radius:18px;background:linear-gradient(180deg,#0e749029,#0f172a4d),#0f172a80;border:1px solid rgba(103,232,249,.16)}[data-theme=light] .performance-guide{background:linear-gradient(180deg,#bae6fda6,#ffffffeb),#fff;border-color:#0e749033}.performance-guide__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.35rem 1rem}.performance-guide__transport{display:inline-flex;flex-wrap:wrap;gap:.3rem;align-items:center;position:relative}.performance-section__header h4{margin:0}.performance-guide__meta,.performance-section__header p{margin:0;color:#cbd5e1;font-size:.95rem}[data-theme=light] .performance-guide__meta,[data-theme=light] .performance-section__header p{color:#334155}.performance-guide__sections{display:flex;flex-direction:column;gap:.45rem}.performance-guide__focus-meta{display:flex;flex-wrap:wrap;gap:.35rem .8rem;align-items:baseline;color:#cbd5e1}.performance-guide__focus-meta span{font-size:.88rem;color:#94a3b8}[data-theme=light] .performance-guide__focus-meta{color:#0f172a}[data-theme=light] .performance-guide__focus-meta span{color:#475569}.performance-section{display:flex;flex-direction:column;gap:.8rem;padding:.85rem;border-radius:14px;background:#0f172a57;border:1px solid rgba(148,163,184,.18)}.performance-section--selected{box-shadow:none}.performance-section--flat{gap:.2rem;padding:0 0 .35rem;border:0;border-radius:0;background:transparent;box-shadow:none;cursor:pointer}.performance-section--flat:not(:last-child){border-bottom:0;margin-bottom:.15rem}[data-theme=light] .performance-section--selected{box-shadow:none}[data-theme=light] .performance-section{background:#f8fafcf2;border-color:#94a3b84d}.performance-section__header{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;justify-content:space-between}.performance-section__controls{display:inline-flex;flex-wrap:wrap;gap:.35rem}button.performance-section__button.ghost{padding:.18rem .34rem;font-size:1.02rem;line-height:1;min-width:0;min-height:0;border-radius:10px}button.performance-section__button--tempo.ghost{min-width:3.1rem;padding-inline:.3rem;font-size:.98rem;font-variant-numeric:tabular-nums}button.performance-section__button--icon.ghost{padding:.18rem;width:1.98rem;height:1.98rem;display:inline-flex;align-items:center;justify-content:center}.performance-section__icon{width:1rem;height:1rem;display:block}.performance-tempo-picker{position:absolute;top:calc(100% + .45rem);right:0;z-index:20;width:5.2rem;padding:.3rem;border-radius:14px;border:1px solid rgba(148,163,184,.24);background:#0f172af0;box-shadow:0 14px 28px #0f172a52}.performance-tempo-picker__list{max-height:12.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:.18rem;padding:2.8rem 0;scroll-snap-type:y proximity}.performance-tempo-picker__option{border:0;background:transparent;color:#cbd5e1;padding:.28rem .2rem;border-radius:10px;font:inherit;text-align:center;cursor:pointer;scroll-snap-align:center}.performance-tempo-picker__option--selected{background:#3b82f63d;color:#eff6ff;font-weight:700}.performance-tempo-picker__option--default:after{content:"•";margin-left:.22rem;color:#67e8f9}[data-theme=light] .performance-tempo-picker{background:#fffffffa;border-color:#94a3b83d;box-shadow:0 14px 28px #94a3b82e}[data-theme=light] .performance-tempo-picker__option{color:#334155}[data-theme=light] .performance-tempo-picker__option--selected{background:#bfdbfef2;color:#0f172a}.performance-section__button--active{box-shadow:0 0 0 1px #facc1573;color:#fde68a}[data-theme=light] .performance-section__button--active{color:#92400e}.performance-section__timeline{display:flex;flex-direction:column;gap:.24rem;min-width:0;padding:0 0 .15rem}.performance-section__grid-region,.performance-section__focus-region{display:flex;flex-direction:column;gap:.55rem;min-height:0;padding:.8rem;border-radius:12px;border:1px solid rgba(148,163,184,.16);background:#0f172a33}.performance-section__grid-region{overflow-y:auto;overflow-x:hidden}.performance-section__focus-region{overflow:hidden;align-items:stretch;justify-content:stretch}.performance-section__focus-region--djembe{padding:.2rem;overflow:hidden}.performance-section__focus-region--djembe>.performance-focus--djembe{flex:1 1 auto;min-height:0}[data-theme=light] .performance-section__grid-region,[data-theme=light] .performance-section__focus-region{background:#ffffffdb;border-color:#94a3b838}.performance-section__region-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:#67e8f9}[data-theme=light] .performance-section__region-label{color:#0f766e}.performance-section__bars{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.24rem}.performance-section__bar{color:#67e8f9;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}[data-theme=light] .performance-section__bar{color:#155e75}.performance-lane{display:block;align-items:start;min-width:0}.performance-lane__label{padding-top:.25rem;font-size:.72rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.performance-lane__cells{display:grid;grid-template-columns:repeat(var(--performance-columns),minmax(0,1fr));gap:.22rem;min-width:0;width:100%}.performance-cell{display:flex;align-items:center;justify-content:center;min-height:1.95rem;min-width:0;padding:.15rem .1rem;border-radius:7px;border:1px dashed rgba(148,163,184,.28);background:#0f172a1f;color:#94a3b8;font-family:Fira Code,SFMono-Regular,Consolas,monospace;font-size:.76rem;text-align:center;overflow:hidden;text-overflow:ellipsis}.performance-cell--filled{border-style:solid;color:#f8fafc}.performance-cell--active{box-shadow:inset 0 0 0 2px #facc15d9;transform:translateY(-1px)}.performance-cell--chord{background:#2563eb47;border-color:#60a5fa73}.performance-cell--djembe{background:#d9770647;border-color:#fbbf2480}[data-theme=light] .performance-cell{background:#f1f5f9f5;color:#64748b}[data-theme=light] .performance-cell--filled{color:#0f172a}[data-theme=light] .performance-cell--active{box-shadow:inset 0 0 0 2px #d97706b3}[data-theme=light] .performance-cell--chord{background:#bfdbfef2;border-color:#2563eb59}[data-theme=light] .performance-cell--djembe{background:#fed7aaf2;border-color:#d9770659}.performance-guide__legend{display:flex;flex-wrap:wrap;gap:.35rem .8rem;color:#cbd5e1;font-size:.74rem;padding-top:.15rem}[data-theme=light] .performance-guide__legend{color:#475569}.performance-section__lyrics{display:flex;flex-direction:column;gap:.4rem}.performance-section__lyric{display:flex;flex-direction:column;gap:.12rem;padding:.55rem .7rem;border-radius:10px;border:1px solid rgba(148,163,184,.18);background:#0f172a33}.performance-section__lyric--active{border-color:#facc15a6;background:#facc1524}.performance-section__lyric-range{font-size:.78rem;color:#94a3b8;font-family:Fira Code,SFMono-Regular,Consolas,monospace}[data-theme=light] .performance-section__lyric{background:#f8fafcfa}[data-theme=light] .performance-section__lyric-range{color:#64748b}.performance-focus{display:grid;gap:1rem;align-items:center;width:100%;height:100%}.performance-focus--djembe{display:flex;align-items:stretch;justify-content:stretch;align-self:stretch;padding:0}.performance-focus--guitar{display:flex;align-items:stretch;justify-content:center;min-width:0;min-height:0}.performance-focus__text{display:flex;flex-direction:column;gap:.35rem}.performance-focus__text h5,.performance-focus__text p{margin:0}.performance-focus__eyebrow{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:#fbbf24}[data-theme=light] .performance-focus__eyebrow{color:#92400e}.performance-focus__chords{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;width:100%;max-width:28rem;margin:0 auto;min-width:0;min-height:0;align-items:stretch}.performance-chord-card{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.25rem;min-height:100%;min-width:0;padding:.45rem .4rem;border-radius:12px;border:1px solid rgba(148,163,184,.2);background:#0f172a3d}[data-theme=light] .performance-chord-card{background:#f8fafcfa}.performance-chord-card__title{display:flex;align-items:baseline;justify-content:center;gap:.22rem;width:100%;min-width:0;line-height:1.1}.performance-chord-card__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;white-space:nowrap}.performance-chord-card__name{font-size:.95rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.performance-chord-card__diagram{display:flex;align-items:center;justify-content:center;width:100%;min-height:0}.performance-chord-card__placeholder{display:flex;align-items:center;justify-content:center;width:100%;min-height:4.6rem;border-radius:10px;border:1px dashed rgba(148,163,184,.28);color:#94a3b8;font-size:.8rem;text-align:center}.djembe-visual{flex:1 1 auto;width:100%;height:100%;align-self:stretch;min-width:0;min-height:0;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;padding:1.5%}.djembe-visual__stage{position:relative;width:100%;height:100%;min-width:0;min-height:0}.djembe-visual__image{display:block;width:100%;height:100%;object-fit:contain;object-position:center top;min-width:0;min-height:0;filter:drop-shadow(0 16px 18px rgba(15,23,42,.18))}.djembe-visual__overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;filter:none;opacity:1;transition:opacity .18s ease-out}.djembe-visual__overlay--fading{opacity:0;transition-duration:.28s}@media (max-width: 760px){.performance-guide{grid-template-rows:auto minmax(0,1fr) minmax(0,25%);min-height:0;height:100%;gap:.7rem;padding:.8rem}.performance-guide__header{gap:.3rem}.performance-guide__transport{width:100%;flex-wrap:nowrap;gap:.22rem;justify-content:space-between}button.performance-section__button.ghost{padding:.16rem .24rem;font-size:.92rem;border-radius:9px;flex:0 1 auto}button.performance-section__button--tempo.ghost{min-width:0;padding-inline:.22rem;font-size:.88rem}button.performance-section__button--icon.ghost{width:1.8rem;height:1.8rem;padding:.14rem;flex:0 0 auto}.performance-section__icon{width:.92rem;height:.92rem}.performance-section__grid-region{padding:.65rem}.performance-section__focus-region,.performance-section__focus-region--djembe{min-height:0;padding:.1rem}.performance-focus--djembe{grid-template-columns:1fr}.performance-focus--guitar .performance-focus__chords{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.djembe-visual{padding:.75%}.djembe-visual__stage{width:100%;height:100%}}.song-detail .lyric-line pre{font-size:calc(1em * var(--line-scale, 1))}.lyrics--inline{color:#e2e8f0;display:flex;gap:.75rem;align-items:flex-start}[data-theme=light] .lyrics--inline{color:#0f172a}.lyrics--stacked{display:flex;flex-direction:column;gap:0}.lyrics__text{flex:1;margin:0;white-space:pre-wrap}.lyrics__chords{margin:0;white-space:pre;text-align:right;min-width:4ch;color:#bfdbfe;font-family:Inter,system-ui,sans-serif;line-height:1.2}[data-theme=light] .lyrics__chords{color:#0b3b7a}.chord-layer{position:relative;min-height:var(--chord-line-height, 1em);margin:0;color:#bfdbfe;font-family:Inter,system-ui,sans-serif;font-size:calc(.95em * var(--line-scale, 1));line-height:1}[data-theme=light] .chord-layer{color:#0b3b7a}.chord-layer__item{position:absolute;left:calc(var(--chord-left) * var(--chord-char-width, 1ch));top:0;white-space:nowrap}.chord-text{display:inline-flex;align-items:flex-end;gap:.08em;font-weight:600;font-family:Inter,system-ui,sans-serif}.chord-text sub{font-size:.68em;line-height:1;vertical-align:baseline;transform:translateY(.1em);padding-left:.05em}.chord-text__bass{padding-left:.12em}.chord-token{display:inline-flex;align-items:center;justify-content:center;font:inherit;color:inherit;background:transparent;border:0;padding:0}.chord-token--clickable{cursor:pointer}.chord-token--clickable:hover,.chord-token--clickable:focus-visible{text-decoration:underline}.lyric-line__row{display:flex;flex-direction:column;gap:.05rem}.chord-layer__placeholder{visibility:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.section__title{margin:0 0 .5rem;font-weight:600;color:#cbd5e1}[data-theme=light] .section__title{color:#0f172a}.lyric-line{margin:.35rem 0}.lyric-line pre{margin:0;font-family:Fira Code,SFMono-Regular,Consolas,monospace;font-size:calc(1em * var(--line-scale, 1));white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;tab-size:4;-moz-tab-size:4}.chords{color:#bfdbfe}.chord-popover{position:fixed;z-index:120;width:min(156px,calc(100vw - 16px));max-width:156px;padding:.1rem .14rem .14rem;background:#0f172a;border:1px solid rgba(148,163,184,.35);border-radius:8px;box-shadow:0 18px 40px #0f172a66}[data-theme=light] .chord-popover{background:#f8fafc;border-color:#94a3b899;box-shadow:0 16px 32px #0f172a2e}.chord-diagram{display:block;max-width:100%;height:auto;color:#bfdbfe}.chord-diagram--compact{max-width:min(100%,5.45rem)}[data-theme=light] .chord-diagram{color:#0b3b7a}.chord-popover__header{position:relative;display:flex;align-items:center;justify-content:center;gap:.12rem;margin-bottom:.08rem}.chord-popover__title{width:100%;text-align:center;font-size:1.3rem;font-weight:600;color:#e2e8f0}[data-theme=light] .chord-popover__title{color:#0f172a}.chord-popover__close{position:absolute;right:0;top:0;border:0;background:transparent;color:inherit;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1;cursor:pointer}.chord-popover__grid{display:grid;grid-template-columns:1fr;gap:.08rem}.chord-popover__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.04rem;padding:.03rem;border-radius:4px;min-height:120px;background:#94a3b814}.chord-popover__item--default{outline:2px solid rgba(148,163,184,.75);background:transparent}[data-theme=light] .chord-popover__item{background:#94a3b833}.chord-popover__item--default{outline:2px solid rgba(71,85,105,.5)}[data-theme=light] .chord-popover__item--default{background:transparent;outline:2px solid rgba(71,85,105,.5)}.chord-popover__label{font-size:.5rem;color:#94a3b8}[data-theme=light] .chord-popover__label{color:#475569}.chord-diagram__title{font-size:10.5px;fill:#e2e8f0}[data-theme=light] .chord-diagram__title{fill:#0f172a}.chord-diagram__string,.chord-diagram__fret-line{stroke:#94a3b8b3;stroke-width:1}[data-theme=light] .chord-diagram__string,[data-theme=light] .chord-diagram__fret-line{stroke:#47556980}.chord-diagram__nut{stroke-width:2}.chord-diagram__dot{fill:currentColor}.chord-diagram__open{fill:transparent;stroke:currentColor;stroke-width:1.5}.chord-diagram__mute{color:currentColor}.chord-diagram__mute-line{stroke:currentColor;stroke-width:1.3;stroke-linecap:round}.chord-diagram__fret{font-size:7px;fill:#94a3b8}[data-theme=light] .chord-diagram__fret{fill:#475569}[data-theme=light] .chords{color:#0b3b7a}.lyric-line--spacer{min-height:.9rem}.lyrics{color:#e2e8f0}[data-theme=light] .lyrics{color:#0f172a}.song-notation__canvas{background:transparent;border-radius:0;padding:0;color:#0f172a;overflow-x:auto}.song-notation__canvas>[id^=osmdCanvasPage]{background:transparent;border:none;border-radius:0;box-shadow:none;margin:0;max-width:none;overflow:hidden}.song-notation__canvas svg{display:block;height:auto;max-width:none}.print-notation .song-notation__canvas{background:transparent}.print-notation .song-notation__canvas>[id^=osmdCanvasPage]{background:transparent;border:none;border-radius:0;box-shadow:none;margin:0;max-width:none}.print-notation .song-notation__canvas>[id^=osmdCanvasPage]>svg{background:transparent;box-shadow:none}@media screen{.song-notation__canvas>[id^=osmdCanvasPage]{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 12px 30px #0f172a1f;margin:1.5rem auto;max-width:100%}.song-notation__canvas svg{max-width:100%}}@media print{@page{size:A4 portrait;margin:0}html,body{margin:0;padding:0}body{background:#fff}.app__hero{display:none!important}.app>main>:not(.modal){display:none!important}.song-notation{width:auto;height:auto}.song-notation__canvas{background:transparent;border-radius:0;margin:0;padding:0;overflow:visible;width:100%}.song-notation__canvas>[id^=osmdCanvasPage]{display:block;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0;background:transparent!important;position:static!important;transform:none!important;max-width:none;width:100%;filter:none!important;page-break-after:always;break-after:page}.song-notation__canvas>[id^=osmdCanvasPage]:last-child{page-break-after:auto;break-after:auto}.song-notation__canvas>[id^=osmdCanvasPage]>svg{display:block;position:static!important;transform:none!important;box-shadow:none!important;background:transparent!important;width:100%;height:auto;filter:none!important}.song-notation,.song-notation *{box-shadow:none!important;text-shadow:none!important}.modal{position:static;inset:auto;display:block;padding:0}.modal__backdrop{display:none}.modal__content{position:static;width:auto;max-height:none;overflow:visible;box-shadow:none}.song-detail{padding:0}.song-detail .panel__header{display:none}.song-detail .panel__body{padding-top:0}}.tabs{display:flex;gap:.5rem;align-items:center}.tab{border:1px solid #334155;background:#ffffff0a;color:inherit;border-radius:12px;padding:.5rem .9rem;cursor:pointer}.tab--active{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa59}[data-theme=light] .tab{border-color:#cbd5e1;background:#fff}.editor{display:flex;flex-direction:column;gap:1.25rem}.editor-tabs{align-self:flex-start}.performance-editor{display:flex;flex-direction:column;gap:1rem}.performance-editor__toggle{align-self:flex-start}.performance-editor__card,.performance-editor__preview{display:flex;flex-direction:column;gap:.9rem;padding:1rem;border-radius:16px;border:1px solid rgba(148,163,184,.2);background:#0f172a2e}[data-theme=light] .performance-editor__card,[data-theme=light] .performance-editor__preview{background:#f8fafcf2;border-color:#94a3b859}.performance-editor__heading{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.performance-editor__events{display:flex;flex-direction:column;gap:.65rem}.performance-editor__event-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:.5rem;align-items:center}.performance-editor__checkbox{display:inline-flex;align-items:center;gap:.4rem}.performance-editor__checkbox input{margin:0}.performance-editor__warnings{display:flex;flex-direction:column;gap:.45rem;padding:.9rem 1rem;border-radius:14px;border:1px solid rgba(248,113,113,.35);background:#7f1d1d2e}.performance-editor__warnings ul{margin:0;padding-left:1.1rem}.performance-editor__warnings li{margin:.2rem 0}[data-theme=light] .performance-editor__warnings{background:#fef2f2f2;border-color:#ef444447}.editor__grid{display:grid;grid-template-columns:minmax(260px,1fr) 2fr;gap:1rem}.editor__form .field{display:flex;flex-direction:column;gap:.35rem}.notation-width-controls{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center}.notation-width-controls input{width:100%}.notation-preview{padding:0;background:transparent}.notation-preview .song-notation__canvas>[id^=osmdCanvasPage]{margin:1rem auto}.field span{font-size:.85rem;color:#cbd5e1}[data-theme=light] .field span{color:#475569}.field--compact{display:flex;flex-direction:column;gap:.35rem;min-width:140px}.field--compact select{width:100%;padding:.5rem .65rem;border-radius:10px;border:1px solid #1f2937;background:#ffffff0f;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}[data-theme=light] .field--compact select{border-color:#e2e8f0;background:#fff}.field input,.field textarea,.field select{width:100%;padding:.65rem .75rem;border-radius:10px;border:1px solid #1f2937;background:#ffffff0f;color:inherit}[data-theme=light] .field input,[data-theme=light] .field textarea,[data-theme=light] .field select{border-color:#e2e8f0;background:#fff}.field textarea{font-family:inherit;resize:vertical}.duo{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.match-list{display:flex;flex-direction:column;gap:.5rem}.match-row{display:flex;justify-content:space-between;gap:.75rem;align-items:center;padding:.6rem .75rem;border-radius:12px;border:1px solid #1f2937;background:#ffffff08}.match-row strong{display:block}.match-row .muted{display:block;font-size:.85rem}.match-row--button{width:100%;text-align:left;cursor:pointer;color:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.match-row--active{border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fa59;background:#60a5fa14}.match-row__actions{display:flex;gap:.35rem}.editor__actions{display:flex;justify-content:flex-end;gap:.5rem}[data-theme=light] .match-row{border-color:#e2e8f0;background:#fff}.editor__lines{border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08;padding:.5rem;display:flex;flex-direction:column;gap:.35rem}[data-theme=light] .editor__lines{border-color:#e2e8f0;background:#fff}.editor__line{display:flex;flex-direction:column;gap:.35rem}.editor__meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin-bottom:.5rem}.tag-grid{display:flex;flex-wrap:wrap;gap:.45rem}.tag-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;font-size:.78rem;cursor:pointer}.tag-toggle input{accent-color:#60a5fa}[data-theme=light] .tag-toggle{border-color:#e2e8f0;background:#fff;box-shadow:0 8px 18px #0f172a14}.section-tabs{display:flex;flex-wrap:wrap;gap:.4rem}.picker{position:fixed;z-index:20;background:#0b1222;border:1px solid #334155;border-radius:12px;padding:.5rem;box-shadow:0 16px 38px #0006}[data-theme=light] .picker{background:#fff;border-color:#e2e8f0;box-shadow:0 16px 38px #0f172a1f}.picker__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem}.picker button{border:1px solid #1f2937;background:#ffffff0d;color:inherit;padding:.4rem .6rem;border-radius:8px;cursor:pointer}[data-theme=light] .picker button{border-color:#cbd5e1;background:#f8fafc}@media (max-width: 800px){.editor__grid{grid-template-columns:1fr}.editor__list{max-height:60vh}}@media (max-width: 640px){.performance-editor__event-row{grid-template-columns:1fr}.search__layout{grid-template-columns:84px minmax(0,1fr)}.icon-dropdown__details,.icon-dropdown__summary{width:84px;height:84px}.lyric-line pre{font-size:calc(.9rem * var(--line-scale, 1));line-height:1.35}.song-detail .lyric-line pre{font-size:calc(.96em * var(--line-scale, 1))}}.line-block{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:stretch;border-radius:10px;overflow:hidden;border:1px solid #1f2937}[data-theme=light] .line-block{border-color:#e2e8f0}.line-block--selected{border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf859}[data-theme=light] .line-block--selected{border-color:#0ea5e9}.line-block__handle{border:0;background:#0f172a99;color:#94a3b8;cursor:grab;font-size:.9rem;display:flex;align-items:center;justify-content:center;padding:0}.line-block__handle:active{cursor:grabbing}[data-theme=light] .line-block__handle{background:#f1f5f9;color:#64748b}.line-block__fields{display:flex;flex-direction:column;min-width:0}.line-input{width:100%;padding:.45rem .65rem;border:0;outline:none;color:inherit;font-family:Fira Code,SFMono-Regular,Consolas,monospace;background:#ffffff08}.line-input--chords{background:#60a5fa14;border-bottom:1px solid #1f2937}.line-input--lyrics{background:#ffffff05}[data-theme=light] .line-input{background:#fff}[data-theme=light] .line-input--chords{background:#2563eb14;border-bottom-color:#e2e8f0}[data-theme=light] .line-input--lyrics{background:#fff}
