:root{--font: "Outfit", "Space Grotesk", system-ui, sans-serif;--bg-base: #0a0906;--bg-surface: #1b1a18;--bg-elevated: #1c1810;--bg-header: #1a1508;--bg-inset: #1a1207;--gold: #c9a84c;--gold-light: #e8d4a0;--gold-mid: #d4c8a8;--gold-warm: #cda353;--gold-text: #ddc870;--gold-bright: #e8d098;--gold-pale: #d4c69a;--gold-fab: #d6b16f;--gold-soft: #8a7a55;--gold-faint: #5a4a28;--gold-deep: #d4a830;--text-primary: #d4c8a8;--text-dim: #6a5a30;--text-muted: #4a3a18;--text-faint: #3a2c10;--accent-rgb: 205,163,83;--accent-bright-rgb: 232,208,152;--bg-base-rgb: 10,9,6;--accent-green: #80d090;--accent-green-rgb: 100,200,130;--scrim: #2a2214;--concert-vignette-edge: #0a0703;--overlay-rgb: 255,255,255;--fab-bg: rgba(15,12,8,.78);--fab-bg-strong: rgba(15,12,8,.92);--ctl-bg: rgba(52,42,20,.4);--ctl-bg-strong: rgba(52,42,20,.7);--panel-bg: rgba(20,16,8,.96);--border-subtle: rgba(255,255,255,.07);--border-gold: rgba(205,163,83,.22);--border-gold-hi: rgba(205,163,83,.5);--tint-accent: #e8d098;--tint-accent-strong: #d6b16f;--tint-base: #c9a84c;--tint-dim: #8a7a55;--tint-soft: #9a8a60;--tint-faint: #5a4a28;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--borders-radius: var(--radius-xs)}[data-theme=light-classic]{--bg-base: #f6f2e8;--bg-surface: #fffdf8;--bg-elevated: #f3eedf;--bg-header: #efe8d6;--bg-inset: #e8e0cc;--gold: #b8860b;--gold-light: #b8902f;--gold-mid: #7a6a40;--gold-warm: #a87a20;--gold-text: #8a6a18;--gold-bright: #9a7820;--gold-pale: #9a8550;--gold-fab: #b8902f;--gold-soft: #9a8a60;--gold-faint: #d8cba8;--gold-deep: #9a7820;--text-primary: #3a3326;--text-dim: #7a6a45;--text-muted: #a89878;--text-faint: #c4b794;--accent-rgb: 150,110,20;--accent-bright-rgb: 184,134,11;--bg-base-rgb: 246,242,232;--overlay-rgb: 92,74,40;--fab-bg: rgba(255,255,255,.72);--fab-bg-strong: rgba(255,255,255,.88);--ctl-bg: rgba(146,116,56,.12);--ctl-bg-strong: rgba(146,116,56,.22);--panel-bg: rgba(255,253,248,.98);--accent-green: #2e8b57;--scrim: #a8a298;--border-subtle: rgba(0,0,0,.08);--border-gold: rgba(150,110,20,.28);--border-gold-hi: rgba(150,110,20,.55);--concert-vignette-edge: #fdfbf4}[data-theme=dark-tinted]{--gold: var(--tint-base);--gold-light: var(--tint-accent);--gold-mid: var(--tint-soft);--gold-warm: var(--tint-accent-strong);--gold-text: var(--tint-accent);--gold-bright: var(--tint-accent);--gold-pale: var(--tint-soft);--gold-fab: var(--tint-accent-strong);--gold-soft: var(--tint-dim);--gold-faint: var(--tint-faint);--gold-deep: var(--tint-base);--accent-rgb: var(--tint-accent-rgb);--accent-bright-rgb: var(--tint-accent-rgb);--border-gold: rgba(var(--tint-accent-rgb),.22);--border-gold-hi: rgba(var(--tint-accent-rgb),.5)}[data-theme=light-tinted]{--bg-base: #f6f2e8;--bg-surface: #fffdf8;--bg-elevated: #f3eedf;--bg-header: #efe8d6;--bg-inset: #e8e0cc;--text-primary: #2e2a22;--text-dim: #5a5040;--text-muted: #8a8068;--text-faint: #b4ac94;--gold: var(--tint-dim);--gold-light: var(--tint-base);--gold-mid: var(--tint-dim);--gold-warm: var(--tint-dim);--gold-text: var(--tint-dim);--gold-bright: var(--tint-base);--gold-pale: var(--tint-dim);--gold-fab: var(--tint-base);--gold-soft: var(--tint-dim);--gold-faint: var(--tint-soft);--gold-deep: var(--tint-dim);--accent-rgb: var(--tint-dim-rgb);--accent-bright-rgb: var(--tint-accent-rgb);--bg-base-rgb: 246,242,232;--overlay-rgb: 92,74,40;--fab-bg: rgba(255,255,255,.72);--fab-bg-strong: rgba(255,255,255,.88);--ctl-bg: rgba(146,116,56,.12);--ctl-bg-strong: rgba(146,116,56,.22);--panel-bg: rgba(255,253,248,.98);--accent-green: #2e8b57;--scrim: #a8a298;--border-subtle: rgba(0,0,0,.08);--border-gold: rgba(var(--tint-dim-rgb),.3);--border-gold-hi: rgba(var(--tint-dim-rgb),.55);--concert-vignette-edge: #fbfcfe}*{-webkit-tap-highlight-color:transparent}button,svg,g{outline:none}body{padding:0;margin:0}.hp-app{min-height:100vh;background:var(--bg-base);color:var(--text-primary);font-family:var(--font);-webkit-text-size-adjust:100%}.hp-sticky-header{display:none;position:sticky;top:0;z-index:100;background:linear-gradient(180deg,var(--bg-header) 0%,#0e0c07 100%);border-bottom:1px solid rgba(var(--accent-rgb),.13);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);text-align:center;padding:12px 16px 18px;overflow:hidden}.hp-sticky-header__inner{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:0}.hp-logo{flex-shrink:0;transform-origin:60px center;will-change:transform}.hp-title{font-size:44px;font-weight:700;color:var(--gold-light);margin:0;letter-spacing:-1px;font-family:var(--font);line-height:1;text-shadow:0 0 30px rgba(var(--accent-rgb),.25)}.hp-title-logo{gap:5px;display:flex;justify-content:center;align-items:center}.hp-tagline{font-size:12px;color:var(--text-dim);font-family:var(--font);letter-spacing:.5px;position:relative;margin-top:6px;will-change:margin-top,padding-bottom,opacity;height:0;padding-bottom:10px}.hp-support-link{display:none;border:1px solid #853f00;align-items:center;gap:5px;padding:5px 11px 5px 9px;border-radius:8px;background:#892f084a;color:#ff6335b5;font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:.3px;text-decoration:none;transition:transform .15s,box-shadow .15s,opacity .15s;text-align:center;height:20px}.hp-support-link:hover{opacity:.95}.hp-support-link:active{transform:scale(.97);box-shadow:0 1px 12px #ff6a004c}.hp-content{max-width:880px;margin:0 auto;padding:0 12px}.hp-footer{background:var(--bg-base);border-top:1px solid rgba(var(--accent-rgb),.1);padding:28px 16px;text-align:center;font-family:var(--font)}.hp-footer__inner{max-width:880px;margin:0 auto}.hp-footer__brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px}.hp-footer__brand-name{font-size:14px;color:rgba(var(--accent-rgb),.7);font-weight:600;letter-spacing:.5px}.hp-footer__icons{display:flex;gap:18px;justify-content:center;margin-bottom:14px}.hp-footer__icon-link{color:rgba(var(--accent-rgb),.5);display:flex;align-items:center;transition:color .2s}.hp-footer__icon-link:hover{color:rgba(var(--accent-rgb),.9)}.hp-footer__copy{font-size:10px;color:rgba(var(--accent-rgb),.25);letter-spacing:.5px}.hp-opacity-0{opacity:0}.hp-pan-strip{top:var(--hp-topbar-h);z-index:99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 0 0;user-select:none;-webkit-user-select:none;display:flex;flex-direction:column;align-items:center}.hp-pan-strip__inner{max-width:880px;width:100%;display:flex;flex-direction:column;align-items:center;gap:5px;transform-origin:center center}.hp-pan-strip__top-row{width:100%;display:flex;align-items:stretch;gap:8px;min-height:30px}.hp-pan-controls-group{display:flex;flex-direction:row;gap:0;flex-shrink:0}.hp-pan-name-btn{background:#bf7f0524;border:1px solid rgba(var(--accent-rgb),.25);border-radius:8px 0 0 8px;padding:0;cursor:pointer;color:#e7b626;font-family:var(--font);display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.hp-pan-name-btn__svg{flex-shrink:0}.hp-pan-mode-btn{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.09);border-radius:0;border-left:none;padding:0;cursor:pointer;color:var(--text-dim);font-family:var(--font);transition:all .15s;display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.hp-pan-mode-btn--artistic{color:#c0a0e0;border-color:#a078c847;background:#8526abc7}.hp-pan-mode-btn--learning{color:#80d090;border-color:#64c88247;background:#0b953429}:root{--note-bagde-center-h: 27px}.hp-chord-badge-center{min-height:var(--note-bagde-center-h);height:var(--note-bagde-center-h);min-width:160px;display:flex;justify-content:center;align-items:center;margin:0}.hp-chord-badge{display:flex;align-items:center;gap:6px;height:calc(var(--note-bagde-center-h) - 2px);border-radius:7px;padding:0 12px;font-size:11px;font-family:var(--font);white-space:nowrap;overflow:hidden;background:color-mix(in srgb,var(--accent) 7%,transparent);border:1px solid color-mix(in srgb,var(--accent) 20%,transparent);border:none;background:none}.hp-chord-badge__root{font-weight:700;font-size:13px;flex-shrink:0;color:var(--accent)}.hp-chord-badge__name{overflow:hidden;text-overflow:ellipsis;color:color-mix(in srgb,var(--accent) 80%,transparent)}.hp-chord-badge__count{font-size:8px;flex-shrink:0;color:color-mix(in srgb,var(--accent) 40%,transparent)}.hp-pan-name-spacer{visibility:hidden;padding:0 10px;font-size:13px;font-weight:700;max-width:45%;flex-shrink:0;white-space:nowrap;display:flex;align-items:center}.hp-action-bar{display:flex;width:100%;border-radius:8px;overflow:hidden;background:#00000059;border:1px solid rgba(var(--accent-rgb),.3)}.hp-action-bar__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;background:transparent;border:none;color:#4d4551;font-size:12px;font-family:var(--font);font-weight:600;cursor:pointer;white-space:nowrap;letter-spacing:.3px;transition:background .12s,color .12s}.hp-action-bar__icon{font-size:12px}.hp-action-bar__btn--strum-on{color:var(--gold);background:rgba(var(--accent-rgb),.08)}.hp-action-bar__btn--strum-off{color:#80a0b0}.hp-action-bar__btn--play.hp-action-bar__btn--enabled{color:#80d090;background:#64c88242}.hp-action-bar__btn--play.hp-action-bar__btn--enabled:hover{background:#64c88240}.hp-action-bar__btn--save.hp-action-bar__btn--enabled{color:#c0a0e0;background:#a078c826}.hp-playNote-btn.hp-action-bar__btn--playing{background:#dc785045!important;color:#ff9060}.hp-playNote-btn.hp-action-bar__btn--disabled{background:none!important;color:#3a3a30!important;cursor:default}.hp-action-bar__btn--perform-on{color:#e8c97a;background:#ffef9217;max-width:40px}.hp-action-bar__btn--perform-on span{filter:drop-shadow(0px 0px 6px #e8c97a)}.hp-action-bar__btn--perform-off{max-width:40px;color:#909090}.hp-action-bar__btn--record{max-width:40px;transition:background .15s,border-color .15s,color .15s}.hp-action-bar__btn--record-on{color:#ff6b6b;background:#dc3c3c24;border-color:#dc3c3c8c}.hp-action-bar__btn--record-on span{filter:drop-shadow(0 0 6px rgba(255,80,80,.65));animation:hp-record-pulse 1.4s ease-in-out infinite}@keyframes hp-record-pulse{0%,to{opacity:1}50%{opacity:.55}}.hp-action-bar__btn--record-off{color:#b06060;background:#9632320f;border-color:#9632324d}.hp-diagrams-row{display:flex;gap:4px;justify-content:center;align-items:flex-start;width:100%;max-width:100%;overflow:visible}.hp-diagram-col{z-index:2;min-width:0;max-width:100%}.hp-diagram-side-label{font-size:7px;color:var(--gold-faint);text-align:center;letter-spacing:2px;text-transform:uppercase;margin-bottom:2px}.hp-diagram-svg{pointer-events:all;filter:brightness(2.1);display:block;width:100%;max-width:clamp(270px,calc(100vh - var(--hp-layout-h-diagram)),350px);margin:0 auto;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}:root{--bottom-progression-row: calc(var(--hp-tabbar-h) + var(--hp-topbar-b) + 10px);--progression-row-h: 280px}.hp-progression-row{justify-content:end;height:var(--progression-row-h);position:fixed;left:0;right:0;bottom:calc(var(--hp-tabbar-h) + var(--hp-tabbar-padding));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;z-index:320;margin:0 auto;max-width:760px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:14px;padding:0 0 10px;display:flex;flex-direction:column;gap:0px;transition:transform .26s cubic-bezier(.32,.72,0,1),opacity .2s}.hp-progression-row[data-tab-hidden]{transform:translateY(140%);opacity:0;pointer-events:none}@media(min-width:1024px){.hp-progression-row{bottom:16px}}@media(max-height:520px){.hp-progression-row{bottom:8px}}.hp-progression-row .hp-saved-strip--dock{position:relative;left:auto;right:auto;bottom:auto;z-index:auto;width:auto;max-width:none;background:none;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;border-radius:0;box-shadow:none;padding:0;margin:0}.hp-progression-row .hp-saved-strip--hidden{transform:none;opacity:1;pointer-events:auto}.hp-progression-row .hp-action-bar{display:flex;gap:0;justify-content:center;flex-wrap:wrap;padding:0;height:35px}:root{--height-info-row: 125px }.hp-info-row{width:100%;text-align:center;margin-bottom:0;display:flex;flex-direction:column;justify-content:center}.hp-active-notes-row{transition:.5s ease;height:25px;display:flex;gap:2px;flex-wrap:nowrap;justify-content:safe center;align-items:center;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;width:100%;padding:7px 0 2px;-webkit-overflow-scrolling:touch;pointer-events:all}.hp-active-notes-row::-webkit-scrollbar{display:none;height:0;width:0}.hp-active-notes-row>*{flex-shrink:0}.hp-active-notes-placeholder{font-size:10px;color:var(--gold-faint);font-style:italic;font-family:var(--font);margin-left:10px}.hp-active-notes-label{display:none;font-size:8px;color:var(--gold-faint);letter-spacing:3px;text-transform:uppercase;font-family:var(--font)}.hp-note-chip{height:22px;opacity:var(--lit-opacity);background:var(--note-color);border-bottom:none;border-right:none;color:color-mix(in srgb,var(--note-color) 30%,#000000);border-radius:0;padding:3px 7px;font-size:10px;font-family:monospace;position:relative;cursor:pointer;transition:opacity 0,transform .15s ease;touch-action:pan-x pan-y;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.hp-active-notes-row[data-wrap-cols] .hp-note-chip{touch-action:none}.hp-drop-ghost{display:inline-block;border-radius:0;background:rgba(var(--accent-bright-rgb),.1);border:1px dashed rgba(var(--accent-bright-rgb),.65);box-shadow:inset 0 0 8px rgba(var(--accent-bright-rgb),.18);animation:hp-ghost-pulse .7s ease-in-out infinite alternate;pointer-events:none;box-sizing:border-box}@keyframes hp-ghost-pulse{0%{background:rgba(var(--accent-bright-rgb),.06)}to{background:rgba(var(--accent-bright-rgb),.18)}}.hp-note-chip--floating{cursor:grabbing}.hp-note-chip--dimmed{opacity:calc((var(--lit-opacity) * .25) + .25)!important}.hp-note-chip-played{opacity:calc(var(--lit-opacity) * 2 + .1)!important}.hp-note-chip--armed{background:#c83c3c8c!important;border-color:#dc5050d9!important;color:#fff!important;box-shadow:0 0 10px #dc505099}.hp-note-chip--armed .hp-note-chip__sub{color:#fff!important}.hp-active-notes-wrap{z-index:5;position:relative;width:100%;transition:.5s ease;height:80px}.hp-active-notes-row[data-wrap-cols]{flex-wrap:wrap;overflow:visible;height:auto;row-gap:2px;justify-content:flex-start;max-width:calc(var(--wrap-cols) * 90px);margin-inline:auto}.hp-active-notes-row[data-wrap-cols] .hp-note-chip{flex:0 0 calc((100% - (var(--wrap-cols) - 1) * 2px) / var(--wrap-cols));text-align:center;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;color:#000;font-weight:600;transition:all .9s ease,opacity .4s ease,background .2s}.hp-active-notes-row[data-wrap-cols] .hp-note-chip--token{width:calc((100% - (var(--wrap-cols) - 1) * 2px) / var(--wrap-cols))!important;padding:2px 4px}.hp-active-notes-row[data-wrap-cols="4"]{--wrap-cols: 4}.hp-active-notes-row[data-wrap-cols="5"]{--wrap-cols: 5}.hp-active-notes-row[data-wrap-cols="6"]{--wrap-cols: 6}.hp-active-notes-row[data-wrap-cols="7"]{--wrap-cols: 7}.hp-active-notes-row[data-wrap-cols="8"]{--wrap-cols: 8}.hp-add-clear-pair{position:absolute;display:inline-flex;align-items:center;bottom:0;right:0}.hp-clear-bubble{position:absolute;top:-100px;right:0;z-index:5;width:35px;height:35px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:50%;border:1px solid rgb(220 90 90 / 66%);background:#b4323242;color:#dc5a5ae6;cursor:pointer;box-shadow:inset 0 1px 12px -2px #dc5a5ae6;transition:background .12s,transform .12s}.hp-clear-bubble:hover{background:#dc4646;border-color:#ff8282}.hp-clear-bubble:active{transform:scale(.88)}.hp-clear-bubble svg{pointer-events:none}.hp-btn-clear-sm{background:#8c2d2d26;border:1px solid rgba(140,45,45,.3);color:#a85858;border-radius:5px;padding:4px 8px;cursor:pointer;font-size:9px;font-family:var(--font)}.hp-info-status{display:none;font-size:9.5px;color:var(--gold-faint);font-style:italic;font-family:var(--font)}.hp-info-hint{font-size:9.5px;color:#727450;letter-spacing:.5px;font-family:var(--font)}.hp-note-chip--compound{background:#015060b3;display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1px 2px;padding:2px 3px;min-width:0;overflow:hidden;border-radius:0;cursor:pointer}.hp-note-chip__sub{color:var(--note-color);font-size:10px;line-height:1;font-family:monospace;min-width:0;flex:0 1 auto}.hp-note-chip--compound[data-sub-count="3"] .hp-note-chip__sub{font-size:8px}.hp-note-chip--compound[data-sub-count="4"]{align-content:center}.hp-note-chip--compound[data-sub-count="4"] .hp-note-chip__sub{font-size:7px;flex:0 0 calc(50% - 1px);text-align:center}.hp-button-progressionRow--locked{opacity:.45;cursor:not-allowed!important;pointer-events:none}.hp-bpm-led{width:25px;height:50px;background:transparent;border:none;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}.hp-bpm-led__dot{width:10px;height:10px;border-radius:50%;background:#4a2820;box-shadow:0 0 0 1px #f7876940,0 0 4px #f7876933;transition:background .12s,box-shadow .12s}.hp-bpm-led--on .hp-bpm-led__dot{background:#f58769;box-shadow:0 0 3px 2px #c73913}.hp-bpm-led--disabled{cursor:not-allowed;opacity:.4}.hp-bpm-label-row{display:inline-flex;align-items:center;gap:6px;justify-content:center}.hp-beat-led{width:7px;height:7px;border-radius:50%;background:rgba(var(--overlay-rgb),.1);box-shadow:inset 0 0 1px #0006;transition:background .08s,box-shadow .08s}.hp-beat-led--green{background:#5dd55d;box-shadow:0 0 4px 1px #5dd55da6}.hp-beat-led--red{background:#f04848;box-shadow:0 0 5px 2px #f04848bf}.hp-playNote-btn{width:50px;height:50px;flex:0;border:1px solid;border-radius:50px;min-height:50px;position:absolute;left:0;bottom:0;justify-content:center;align-items:center;display:flex;border:none}.hp-playNote-btn span{text-align:center;display:flex;justify-self:center;align-items:center}.hp-playNote-btn:before{position:absolute;bottom:0;left:0;transform:translate(55px,-3px);opacity:.3;color:#bc8f8f;font-weight:200}.hp-addNotes-btn{filter:brightness(1.6);width:60px;height:60px;flex:0;border:1px solid;border-radius:50px;min-height:50px;position:absolute;background:#000;right:0;bottom:0;justify-content:center;align-items:center;display:flex;border:none;background:none}.hp-addNotes-btn:before{position:absolute;bottom:0;right:0;transform:translate(-55px,-3px);opacity:.3;color:#bc8f8f;font-weight:200}.hp-action-notes{font-size:20px}.hp-filter-bar{padding:10px 0 0;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.hp-btn-filter{display:flex;align-items:center;gap:6px;border-radius:var(--radius-md);padding:7px 14px;cursor:pointer;font-size:12px;font-family:var(--font);transition:all .15s}.hp-btn-filter--inactive{background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.09);color:var(--gold-soft)}.hp-btn-filter--active{background:var(--bg-base);border:none;color:var(--gold-text);box-shadow:none}.hp-btn-filter--icon{width:38px;height:34px;padding:0;justify-content:center;position:relative;flex-shrink:0}.hp-btn-filter--icon .hp-filter-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0;border-radius:8px;background:var(--gold);color:#141108;font-weight:700;font-size:9px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,0,0,.4)}.hp-filter-badge{background:rgba(var(--accent-rgb),.32);border-radius:10px;padding:0 6px;font-size:10px;color:var(--gold-text)}.hp-search-input{background:#000;border:1px solid rgb(44 32 14);flex:1;min-width:110px;max-width:210px;border-radius:var(--radius-md);padding:7px 12px;color:var(--text-primary);font-size:12px;font-family:var(--font);outline:none;height:34px;box-sizing:border-box}.hp-btn-show-all{background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.35);color:var(--gold);border-radius:var(--radius-md);padding:7px 13px;cursor:pointer;font-size:11px;font-family:var(--font)}.hp-btn-clear-filters{background:#8c2d2d24;border:1px solid rgba(140,45,45,.28);color:#a85858;border-radius:var(--radius-md);padding:6px 12px;cursor:pointer;font-size:11px;font-family:var(--font)}.hp-filter-spacer{flex:1}.hp-filter-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.hp-btn-strum{display:flex;align-items:center;gap:5px;border-radius:var(--radius-md);padding:6px 11px;cursor:pointer;font-size:11px;font-family:var(--font);transition:all .15s;white-space:nowrap;height:34px;box-sizing:border-box}.hp-btn-strum--on{background:rgba(var(--accent-rgb),.14);border:1px solid rgba(var(--accent-rgb),.4);color:var(--gold-text)}.hp-btn-strum--off{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.09);color:var(--gold-soft)}.hp-btn-strum__icon{font-size:12px;line-height:1}.hp-btn-play{display:flex;align-items:center;gap:5px;border-radius:var(--radius-md);padding:6px 13px;font-size:12px;font-family:var(--font);transition:all .15s;white-space:nowrap;height:34px;box-sizing:border-box}.hp-btn-play--enabled{background:#64b4782e;border:1px solid rgba(100,200,130,.4);color:#80d090;cursor:pointer}.hp-btn-play--disabled{background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);color:#3a3a30;cursor:default}.hp-btn-play__icon{font-size:14px;line-height:1}.hp-btn-play__label{font-size:11px}.hp-btn-save-chord{display:flex;align-items:center;gap:5px;border-radius:var(--radius-md);padding:6px 13px;font-size:11px;font-family:var(--font);font-weight:600;transition:all .15s;white-space:nowrap;height:34px;box-sizing:border-box}.hp-btn-save-chord--enabled{background:#a078c82e;border:1px solid rgba(160,120,200,.4);color:#c0a0e0;cursor:pointer}.hp-btn-save-chord--disabled{background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);color:#3a3a30;cursor:default}.hp-btn-save{display:flex;align-items:center;gap:5px;border-radius:var(--radius-md);padding:6px 11px;font-size:11px;font-family:var(--font);white-space:nowrap}.hp-btn-save--enabled{background:#a078c82e;border:1px solid rgba(160,120,200,.4);color:#c0a0e0;cursor:pointer}.hp-btn-save--disabled{background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);color:#3a3a30;cursor:default}.hp-chord-list{padding:10px 8px 72px;background:transparent;border:none;box-shadow:none}.hp-chord-grid{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.hp-chord-empty{grid-column:1 / -1;text-align:center;padding:48px 20px;color:var(--text-faint);font-size:13px;font-style:italic;font-family:var(--font)}.hp-chord-empty--full{text-align:center;padding:48px 20px;color:var(--text-faint);font-size:13px;font-style:italic;font-family:var(--font)}.hp-cat-section{margin-bottom:28px}.hp-cat-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid color-mix(in srgb,var(--accent) 13%,transparent)}.hp-cat-dot{width:3px;height:16px;border-radius:2px;flex-shrink:0;background:var(--accent)}.hp-cat-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;font-family:var(--font);font-weight:600;color:var(--accent)}.hp-cat-count{font-size:10px;font-family:var(--font);color:color-mix(in srgb,var(--accent) 33%,transparent)}.hp-cat-section-body{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.hp-chord-type-section{break-inside:avoid;display:block}.hp-chord-type-section .hp-chord-grid{grid-template-columns:1fr;gap:0px}.hp-chord-type-name{display:none;font-size:9.5px;letter-spacing:2px;text-transform:uppercase;font-family:var(--font);font-weight:700;margin-bottom:5px;padding-left:8px;color:color-mix(in srgb,var(--accent) 53%,transparent);padding-top:7px}.hp-chord-card{width:96px;min-height:96px;border-radius:10px;padding:6px 5px 4px;cursor:pointer;transition:transform .15s,opacity .15s,background .15s,border-color .15s;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;gap:4px;background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--overlay-rgb),.06);box-shadow:none}.hp-chord-card:hover{transform:scale(1.04);background:color-mix(in srgb,var(--accent) 5%,rgba(var(--overlay-rgb),.02));border-color:color-mix(in srgb,var(--accent) 25%,rgba(var(--overlay-rgb),.06))}.hp-chord-card--default{opacity:1}.hp-chord-card--selected{background:color-mix(in srgb,var(--accent) 12%,rgba(var(--overlay-rgb),.02));border-color:color-mix(in srgb,var(--accent) 55%,transparent);transform:scale(1.04)}.hp-chord-card--related{background:color-mix(in srgb,var(--accent) 6%,rgba(var(--overlay-rgb),.02));border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.hp-chord-card--dimmed{opacity:.35}.hp-chord-card__top{display:flex;flex-direction:column;align-items:center;gap:1px;text-align:center;line-height:1.1}.hp-chord-card__root{font-size:13px;font-family:var(--font);font-weight:700;letter-spacing:.3px;color:var(--accent)}.hp-chord-card__root--selected{color:var(--gold-bright)}.hp-chord-card__name{font-size:9px;font-family:var(--font);font-weight:500;color:#806850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.hp-chord-card__name--selected{color:#b8a060}.hp-chord-card__notes{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;flex:1;align-content:center}.hp-chord-note-chip{background:color-mix(in srgb,var(--note-color) 10%,transparent);border:1px solid color-mix(in srgb,var(--note-color) 27%,transparent);color:var(--note-color);padding:0 3px;font-size:8px;font-family:monospace;line-height:1.5;letter-spacing:.2px;font-weight:bolder;opacity:var(--lit-opacity);background:var(--note-color);border-bottom:none;border-right:none;color:color-mix(in srgb,var(--note-color) 30%,#000000);border-radius:0}.hp-chord-card__actions{display:flex;align-items:center;justify-content:space-between;gap:2px;margin-top:2px}.hp-chord-card__cycle,.hp-chord-card__save{flex:0 0 auto;width:22px;height:22px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;transition:background .15s,color .15s;color:color-mix(in srgb,var(--accent) 45%,transparent)}.hp-chord-card__cycle:hover{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.hp-chord-card__save{width:28px;height:22px;color:color-mix(in srgb,var(--accent) 65%,transparent)}.hp-chord-card__save:hover{background:color-mix(in srgb,#e05070 14%,transparent);color:#e05070}.hp-chord-card__save--selected{color:var(--gold-bright)}.hp-saved-strip{user-select:none;-webkit-user-select:none;padding-bottom:10px;border-bottom:1px solid #251d0d}.hp-saved-strip--dock{position:fixed;left:8px;right:8px;bottom:calc(var(--hp-tabbar-h, 64px) + env(safe-area-inset-bottom,0px) + 8px);z-index:320;margin:0 auto;max-width:760px;background:var(--panel-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(var(--accent-rgb),.3);border-radius:14px;box-shadow:0 12px 36px #0000008c;padding:0 8px 6px;border-bottom:1px solid rgba(var(--accent-rgb),.3);transition:transform .26s cubic-bezier(.32,.72,0,1),opacity .2s;height:38px}.hp-saved-strip--hidden{transform:translateY(140%);opacity:0;pointer-events:none}@media(min-width:1024px){.hp-saved-strip--dock{bottom:16px}}@media(max-height:520px){.hp-saved-strip--dock{bottom:8px}}.hp-saved-strip__handle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:none;border:none;padding:6px 0 4px;cursor:pointer;color:var(--gold-soft);font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.04em}.hp-saved-strip__handle-bar{width:38px;height:4px;background:rgba(var(--accent-rgb),.3);border-radius:2px;display:block}.hp-saved-strip__handle-count{color:var(--gold-pale)}.hp-saved-strip--collapsed{max-width:max-content;padding:0 14px;left:auto;right:8px}.hp-saved-strip--collapsed .hp-saved-strip__row,.hp-saved-strip--collapsed .hp-action-bar--prog{display:none}.hp-saved-strip--collapsed .hp-saved-strip__handle{padding:8px 4px}:root{--height-savedChordStrip: 30px}.hp-saved-strip__row{justify-content:safe center;display:flex;gap:1px;flex-wrap:nowrap;align-items:center;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;padding:4px 2px;height:var(--height-savedChordStrip);max-height:var(--height-savedChordStrip);border:1px solid transparent;border-left:none;border-right:none;filter:brightness(.8)}.hp-saved-strip__row::-webkit-scrollbar{display:none;height:0;width:0}.hp-saved-strip__row>*{flex-shrink:0}.hp-saved-strip__placeholder{font-size:10px;color:var(--gold-faint);font-style:italic;font-family:var(--font)}.hp-saved-chip--playing{background:#cd53aa50!important;border-color:rgba(var(--accent-rgb),.85)!important;color:rgba(var(--accent-rgb),.85)}.hp-saved-chip--playing .hp-saved-chip__chord-root,.hp-saved-chip--playing .hp-saved-chip__chord-name{color:rgba(var(--accent-rgb),.85)}.hp-saved-delete-hint{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:#8c2d2dd9;color:#ffd0d0;padding:6px 14px;border-radius:8px;font-size:11px;font-family:var(--font);z-index:1200;pointer-events:none}.hp-saved-strip__controls{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding-top:6px}.hp-saved-chip__token{display:inline-flex;align-items:center;justify-content:center;font-size:14px;margin:0 1px;font-family:var(--font)}.hp-saved-chip__token--slap{color:#c0a0e0}.hp-saved-chip__token--pause{color:#80a0b0}.hp-token-btn{background:#a078c81a;border:1px solid rgba(160,120,200,.3);color:#c0a0e0;border-radius:7px;padding:0;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;transition:background .12s,border-color .12s}.hp-token-btn:active{background:#a078c840;transform:scale(.96)}.hp-token-btn--pause{background:#78a0c81a;border-color:#78a0c84d;color:#80a0b0}.hp-token-btn--pause:active{background:#78a0c840}.hp-btn-melodies{display:inline-flex;align-items:center;gap:5px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.3);color:var(--gold-deep);border-radius:7px;padding:5px 10px;font-size:11px;font-family:var(--font);font-weight:600;cursor:pointer;height:30px}.hp-btn-melodies:hover{background:rgba(var(--accent-rgb),.18)}.hp-note-chip--merge-target{cursor:cell}.hp-note-chip--merge-selected{box-shadow:0 0 0 2px rgba(var(--accent-rgb),.85),0 0 14px rgba(var(--accent-rgb),.45);background:rgba(var(--accent-rgb),.18)!important}.hp-note-chip--token{font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:0;cursor:pointer;padding:6px 8px;background:#e5cefc45;color:#c0a0e0;border-radius:0}.hp-note-chip--pause{border-color:#78a0c84d;color:#80a0b0}.hp-saved-strip__label{display:none;font-size:8px;color:var(--gold-faint);letter-spacing:3px;text-transform:uppercase;flex-shrink:0}.hp-saved-chip{display:flex;gap:1px;align-items:center;color:#c8d4ff;border-radius:0;padding:4px 8px 4px 0;cursor:grab;font-size:13px;font-family:monospace;touch-action:pan-x pan-y;transition:transform .1s,opacity .1s,background .15s}.hp-saved-chip--default{background:#d3b38ba6;border:1px solid rgb(188 168 112 / 28%);opacity:1;transform:none;height:30px;padding:0 10px;box-shadow:inset 0 1px rgba(var(--overlay-rgb),.05)}.hp-saved-chip--default:hover{background:#9baff0a9;border-color:#c8dcff52}.hp-saved-chip-ghost{display:inline-block;vertical-align:middle;flex-shrink:0;border-radius:4px;background:rgba(var(--accent-bright-rgb),.08);border:1px dashed rgba(var(--accent-bright-rgb),.6);box-shadow:inset 0 0 10px rgba(var(--accent-bright-rgb),.14);animation:hp-saved-ghost-pulse .7s ease-in-out infinite alternate;pointer-events:none;box-sizing:border-box}@keyframes hp-saved-ghost-pulse{0%{background:rgba(var(--accent-bright-rgb),.05)}to{background:rgba(var(--accent-bright-rgb),.16)}}.hp-saved-chip--floating{cursor:grabbing;box-sizing:border-box}.hp-saved-chip__handle{font-size:14px;opacity:.55;cursor:grab;touch-action:none;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;line-height:1;left:0;position:relative;width:20px;padding-left:5px;height:100%}.hp-saved-chip__handle:active{cursor:grabbing;opacity:1;background:rgba(var(--overlay-rgb),.1)}.hp-saved-delete-zone{padding:4px 10px;border-radius:var(--radius-sm);font-size:9px;font-family:var(--font);transition:all .15s}.hp-saved-delete-zone--idle{background:#8c2d2d1a;border:1px dashed rgba(160,55,55,.4);color:#a85858}.hp-saved-delete-zone--over{background:#c83c3c59;border:1px dashed rgba(240,80,80,.9);color:#ff9090}.hp-drag-delete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:480;background:#dc3c3c38;animation:hp-drag-overlay-in .15s ease-out}@keyframes hp-drag-overlay-in{0%{opacity:0}to{opacity:1}}.hp-drag-ghost{position:fixed;pointer-events:none;z-index:9999;background:#a078c8e6;border-radius:7px;padding:4px 9px;font-size:10px;font-family:monospace;color:#fff;box-shadow:0 4px 16px #00000080}.hp-bpm-wrapper{background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--overlay-rgb),.14);border-radius:var(--radius-sm);padding:3px 9px;display:flex;align-items:center;gap:4px;flex-shrink:0}.hp-bpm-label{color:var(--gold-soft);font-size:13px;font-family:var(--font);text-transform:uppercase;opacity:.7;-webkit-user-select:none;user-select:none;cursor:pointer;transition:opacity .15s}.hp-bpm-label:hover{opacity:1}.hp-bpm-input{background:transparent;border:none;color:var(--gold-soft);font-size:13px;font-family:var(--font);font-variant-numeric:tabular-nums;width:22px;outline:none;padding:0;cursor:text}.hp-bpm-input::-webkit-outer-spin-button,.hp-bpm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hp-metronome-btn{background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--overlay-rgb),.14);color:var(--gold-soft);border-radius:var(--radius-sm);padding:3px 6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;height:24px}.hp-metronome-btn.active{background:#a0907033;border-color:var(--gold-soft);color:var(--gold)}.hp-metronome-btn svg{opacity:.7}.hp-metronome-btn.active svg{opacity:1}.hp-btn-time-sig{background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--overlay-rgb),.14);color:var(--gold-soft);border-radius:var(--radius-sm);padding:3px 9px;cursor:pointer;font-size:13px;font-family:var(--font);flex-shrink:0;touch-action:manipulation;font-variant-numeric:tabular-nums;letter-spacing:.5px}.hp-btn-play-prog{border-radius:var(--radius-sm);padding:7px;cursor:pointer;font-size:13px;font-family:var(--font);flex-shrink:0;touch-action:manipulation}.hp-btn-play-prog--idle{background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.35);color:var(--gold)}.hp-btn-play-prog--playing{background:rgba(var(--accent-rgb),.3);border:1px solid rgba(var(--accent-rgb),.7);color:#f0d078}.hp-btn-clear-saved{background:#8c2d2d1f;border:1px solid rgba(140,45,45,.25);color:#a85858;border-radius:var(--radius-sm);padding:3px 8px;cursor:pointer;font-size:13px;font-family:var(--font);touch-action:manipulation}.hp-action-bar--prog{margin-top:10px;display:flex;justify-content:center;gap:10px;align-items:center}.hp-action-bar__btn--melodies-open{max-width:55px;width:55px;height:35px;border-radius:10px;background:no-repeat;border:none;color:var(--gold-warm);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.hp-action-bar__btn--melodies-open:hover{background:rgba(var(--accent-rgb),.18)}.hp-action-bar__btn--meas{color:var(--gold);max-width:50px}.hp-action-bar__btn--bpm{color:#c0a0e0;gap:5px;max-width:90px}.hp-action-bar__btn--swing{color:#80a0b0;max-width:90px}.hp-action-bar__btn--play-prog{color:#80d090;background:#64c88208}.hp-button-progressionRow{border:1px solid #51401f85;border-radius:10px;font-size:.8em;font-weight:100;color:#e5d39b5e;padding:5px 10px;display:flex;flex-direction:column;cursor:pointer;gap:0;align-items:baseline;background:#3733287d;height:35px}.hp-button-progressionRow button{padding:0}.hp-action-bar__btn--melodies{color:var(--gold-deep);max-width:40px}.hp-action-bar__bpm-input{width:30px;background:transparent;border:none;border-radius:4px;color:inherit;font-size:11px;font-family:var(--font);text-align:center;-moz-appearance:textfield;padding:0}.hp-action-bar__bpm-input::-webkit-outer-spin-button,.hp-action-bar__bpm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hp-action-bar__bpm-input:disabled{color:inherit;-webkit-text-fill-color:currentColor}.hp-action-bar__btn--bpm.hp-action-bar__btn--disabled{opacity:.4;cursor:not-allowed}.hp-action-bar__btn--bpm.hp-action-bar__btn--disabled .hp-bpm-step,.hp-action-bar__btn--bpm.hp-action-bar__btn--disabled .hp-action-bar__bpm-input{cursor:not-allowed;pointer-events:none}.hp-bpm-step{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;margin:0 2px;border-radius:50%;border:none;background:rgba(var(--accent-rgb),.08);color:var(--gold-deep);font-size:12px;line-height:1;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.hp-bpm-step:hover{background:rgba(var(--accent-rgb),.18);color:#f1c45a;border-color:rgba(var(--accent-rgb),.7)}.hp-bpm-step:active{transform:scale(.92)}.hp-saved-chip--pressed{background:#3789c837;border:1px solid #3789c8ba;height:30px;transition:transform .18s ease,background .18s ease;padding:0 9px}.hp-btn-clear-saved-end{left:0;background:#270f0f;border:1px solid #c24b4b46;color:#c24b4b;border-radius:7px;padding:5px 10px;font-size:14px;font-family:var(--font);cursor:pointer;height:40px;align-self:center;font-weight:800;z-index:10;opacity:1}.hp-btn-empty-saved-end{flex-shrink:0;background:#1e43604a;border:1px solid rgba(53,75,128,.3);color:#5997c7f0;border-radius:7px;padding:5px 10px;font-size:10px;font-family:var(--font);cursor:pointer;height:40px;align-self:center;box-shadow:0 0 8px inset;opacity:.4;filter:saturate(.6)}.hp-btn-active-saved-end{position:absolute;right:0;top:0;z-index:2;background:#1e43604a;border:1px solid rgb(20 50 121 / 30%);color:#3789c8f0;border-radius:7px;padding:4px 7px;font-size:10px;font-family:var(--font);cursor:pointer;height:40px;display:inline-flex;align-items:center;justify-content:center}.hp-btn-active-saved-end--arm{color:#d5a149;background:var(--bg-base);box-shadow:none;height:40px;border:none}.hp-btn-active-saved-end--armed{color:#d55949;border-radius:0;display:flex;align-items:center;justify-content:center;border:none}.hp-btn-active-saved-end--mute{color:#9bd07a;background:var(--bg-base);border:navajowhite;box-shadow:10px 0 11px 21px var(--bg-base)}.hp-btn-active-saved-end--muted{color:#d07a7a;border-color:#7e4242fb}.hp-btn-active-saved-end--clear{background:var(--bg-base);border:none;color:#d07a7a;box-shadow:10px 10px 11px 21px var(--bg-base)}.hp-btn-active-saved-end--clear:hover{color:#ff9c9c}.hp-strip-end-shadow{position:absolute;right:0;top:0;height:100%;width:86px;z-index:1;pointer-events:none;background:linear-gradient(to right,transparent 0%,rgba(var(--bg-base-rgb),.65) 35%,var(--bg-base) 70%)}.hp-strip-end{position:absolute;right:6px;top:50%;transform:translateY(-50%);z-index:2;display:inline-flex;align-items:center;gap:3px}.hp-strip-end__btn{position:relative;display:inline-flex;align-items:center;justify-content:center;background:var(--fab-bg);border:1px solid rgba(var(--accent-rgb),.14);color:var(--gold-fab);height:28px;padding:0 8px;border-radius:6px;font-family:var(--font);font-size:10px;font-weight:600;cursor:pointer;overflow:hidden;transition:background .15s ease,border-color .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.hp-strip-end__btn:hover{background:#1c160ceb;border-color:rgba(var(--accent-rgb),.45)}.hp-strip-end__btn--vol{min-width:36px;touch-action:none}.hp-strip-end__btn--vol.hp-strip-end__btn--muted{color:#d07a7a;border-color:#7e42428c}.hp-strip-end__vol-fill{position:absolute;left:0;top:0;bottom:0;background:rgba(var(--accent-rgb),.3);pointer-events:none;transition:width .08s linear}.hp-strip-end__btn--muted .hp-strip-end__vol-fill{background:#7e424240}.hp-strip-end__vol-content{position:relative;display:inline-flex;align-items:center;gap:4px;z-index:1}.hp-strip-end--vol-dragging .hp-strip-end__btn--vol{background:#281c0cf2;color:var(--gold-bright);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.5)}.hp-vol-slider{background:var(--fab-bg-strong);border:1px solid rgba(var(--accent-rgb),.3);border-radius:12px;padding:14px 0;box-shadow:0 6px 20px #0000008c,0 0 0 2px #0a090666;-webkit-user-select:none;user-select:none;touch-action:none}.hp-vol-slider__track{position:absolute;left:50%;top:14px;bottom:14px;width:4px;transform:translate(-50%);background:rgba(var(--accent-rgb),.18);border-radius:2px}.hp-vol-slider__fill{position:absolute;left:50%;bottom:14px;width:4px;transform:translate(-50%);background:linear-gradient(to top,var(--gold-fab),var(--gold-bright));border-radius:2px;pointer-events:none}.hp-vol-slider__thumb{position:absolute;left:50%;transform:translate(-50%);width:22px;height:12px;background:var(--gold-bright);border-radius:4px;box-shadow:0 1px 3px #000000b3;pointer-events:none}.hp-strip-end__btn--clear{color:#d07a7a;border-color:#7e424273}.hp-strip-end__btn--clear:hover{color:#ff9c9c}.hp-strip-end__btn--disabled{opacity:.4;cursor:not-allowed}.hp-strip-end__btn--disabled:hover{background:var(--fab-bg);border-color:rgba(var(--accent-rgb),.14)}.hp-saved-strip{position:relative}.hp-saved-strip--armed{box-shadow:0 12px 36px #0000008c,0 0 0 1.5px rgba(var(--accent-rgb),.55)}.hp-saved-strip--muted .hp-saved-strip__row{opacity:.55;filter:grayscale(1)}.hp-saved-strip__row{padding-right:78px!important}.hp-btn-clear-saved-end:hover{opacity:1}.hp-saved-chip--together{border-style:double;border-width:3px}.hp-saved-chip__compound{display:inline-flex;align-items:center;gap:2px;padding:0 5px;border-radius:5px;background:rgba(var(--overlay-rgb),.06);border:1px solid rgb(218 164 247 / 40%);margin:0 1px}.hp-saved-strip__row--locked{overflow-x:hidden!important;touch-action:none}.hp-saved-strip__row--locked .hp-saved-chip{touch-action:none}.hp-saved-strip-wrapper--inactive{opacity:.5;filter:grayscale(.4);cursor:pointer;transition:opacity .2s,filter .2s}.hp-saved-strip-wrapper--inactive:hover{opacity:.75;filter:grayscale(.2)}.hp-saved-strip-wrapper--inactive .hp-saved-strip{pointer-events:none}.hp-saved-strip-wrapper--inactive .hp-saved-strip__handle{display:none}.hp-saved-strip--alt{display:flex;align-items:center;gap:6px;padding:4px 8px;margin:0 4px 4px;background:rgba(var(--overlay-rgb),.03);border:1px dashed rgba(var(--accent-rgb),.3);border-radius:8px;cursor:pointer;font-size:10px;color:var(--gold-soft);transition:background .15s,border-color .15s}.hp-saved-strip--alt:hover{background:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.45);color:var(--gold-fab)}.hp-saved-strip__alt-label{font-weight:700;letter-spacing:.08em;text-transform:uppercase}.hp-saved-strip__alt-chips{flex:1;display:flex;gap:3px;flex-wrap:nowrap;overflow:hidden}.hp-saved-chip--alt{padding:0 4px;background:none;border:none;color:var(--text-dim);font-size:14px;line-height:1}.hp-saved-strip__alt-hint{color:var(--gold-soft);font-size:12px}.hp-action-bar__btn--level-1{color:var(--gold-fab)}.hp-action-bar__btn--level-2{color:#93a9d8;background:#96aadc1a;border-color:#96aadc59}.hp-saved-chip__chord{display:inline-flex;align-items:baseline;gap:1px;padding:0 3px}.hp-saved-chip__chord-root{font-weight:500;font-size:13px;color:#332504;letter-spacing:.02em}.hp-saved-chip__chord-name{font-size:9px;font-weight:600;color:#500b59;letter-spacing:0}.hp-saved-chip__ellipsis{color:var(--gold-soft);font-size:12px;margin-left:2px}.hp-btn-play-ref{width:60px;height:60px;position:relative;background:radial-gradient(circle at 35% 30%,#d1a948,#d1a948 0%,#b8860b,#6e5926);color:gold;border-radius:50%;padding:20px;display:block;bottom:0;left:0;border:none;flex-grow:0;flex-shrink:0;flex:0;min-width:60px;border-top:1px solid;border-left:1px solid}.hp-btn-play-ref.hp-action-bar__btn--disabled{filter:grayscale(1) brightness(.55);opacity:.5;cursor:not-allowed}.hp-btn-play-ref-stop{width:60px;height:60px;position:relative;color:#f56666!important;background:radial-gradient(circle at 35% 30%,#973b3ae8,#973b3ae8 0%,#652726e8,#3e1212e8);border-radius:50%;padding:20px;display:block;bottom:0;left:0;border:none;flex-grow:0;flex-shrink:0;flex:0;min-width:60px;border-top:1px solid;border-left:1px solid}.hp-btn-play-ref-stop span{color:#f56666}.hp-btn-play-ref--rec{color:#f56666!important}.hp-btn-play-ref--rec svg{animation:hp-rec-pulse 1.4s ease-in-out infinite}@keyframes hp-rec-pulse{0%,to{opacity:1}50%{opacity:.55}}.hp-saved-chip-wrap{display:flex;flex-direction:column;justify-content:center;align-items:center}.hp-saved-chip-num{font-size:9px;opacity:.5;font-weight:800}.hp-selected-strip{filter:brightness(1.5);border:1px solid rgba(103,42,32,.597);border-left:none;border-right:none}.hp-bpm-label-bpm-wrap{display:flex;justify-content:space-between;align-items:center;width:100%}.hp-metronome-btn{background:transparent;border:1px solid rgba(var(--accent-rgb),.3);color:rgba(var(--accent-rgb),.7);border-radius:5px;padding:1px 3px;margin:0 4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:background .15s,border-color .15s,color .15s}.hp-metronome-btn--on{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.85);color:var(--gold-bright)}.hp-metronome-btn--disabled{filter:grayscale(1) brightness(.55);opacity:.45;cursor:not-allowed}.hp-metronome-led-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;background:var(--ctl-bg);color:#968d7ac7;border-radius:7px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;border:none}.hp-metronome-led-btn:hover{background:var(--ctl-bg-strong);color:rgba(var(--accent-rgb),.78)}.hp-metronome-led-btn--on{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.85);color:var(--gold-bright)}.hp-metronome-led-btn--disabled{filter:grayscale(1) brightness(.55);opacity:.5;cursor:not-allowed}.hp-action-bar__btn--bpm-standalone{display:inline-flex;align-items:center}.hp-countin-btn{display:inline-flex;align-items:center;justify-content:center;padding:5px 8px;background:var(--ctl-bg);border:1px solid rgba(var(--accent-rgb),.3);color:#968d7ac7;border-radius:7px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;border:none}.hp-countin-btn:hover{background:var(--ctl-bg-strong);color:rgba(var(--accent-rgb),.78)}.hp-countin-btn--on{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.85);color:var(--gold-bright)}.hp-countin-btn--disabled{filter:grayscale(1) brightness(.55);opacity:.5;cursor:not-allowed}.hp-saved-chip--match{border-color:#6480c8b0!important;background:#799bb8}.hp-filter-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);transition:opacity .3s ease}.hp-filter-modal-panel{position:fixed;bottom:0;left:0;right:0;z-index:600;background:var(--bg-surface);border-top:1px solid rgba(214,214,214,.11);border-radius:18px 18px 0 0;height:min(93vh,calc(100dvh - env(safe-area-inset-top) - 10px));max-height:min(93vh,calc(100dvh - env(safe-area-inset-top) - 10px));overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;font-family:var(--font);transition:transform .32s cubic-bezier(.32,.72,0,1);box-shadow:0 -12px 48px #0009;-webkit-user-select:none;user-select:none}.hp-filter-modal__content{max-width:700px;margin:0 auto;padding:5px 18px 36px}.hp-filter-modal__drag-handle{width:40px;height:4px;background:rgba(var(--accent-rgb),.2);border-radius:2px;margin:0 auto}.hp-filter-modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.hp-filter-modal__title{font-size:16px;color:#d4c090;letter-spacing:.5px;font-family:var(--font);font-weight:700}.hp-filter-modal__close{background:#0505057d;color:#f7f6f6b8;font-size:18px;cursor:pointer;line-height:1;padding:4px 8px;width:50px;height:50px;border-radius:30px;border:none;border-left:1px solid rgba(var(--overlay-rgb),.15);border-right:1px solid rgba(var(--overlay-rgb),.1);box-shadow:inset 4px 5px 13px -2px #ffffff09}.hp-filter-label{font-size:9px;letter-spacing:3px;color:#7a6030;text-transform:uppercase;margin-bottom:7px;font-family:var(--font);font-weight:600}.hp-filter-chips-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.hp-filter-chips-row--sm{gap:5px;margin-bottom:18px}.hp-filter-chips-row--note{gap:5px;margin-bottom:20px}.hp-chip{border-radius:var(--radius-sm);padding:5px 11px;cursor:pointer;font-size:11px;font-family:var(--font);font-weight:400;transition:all .13s;white-space:nowrap}.hp-chip--inactive{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);color:#6a5840}.hp-chip--active{background:color-mix(in srgb,var(--chip-color, var(--gold)) 16%,transparent);border:1px solid var(--chip-color, rgba(var(--accent-rgb),.6));color:var(--chip-color, var(--gold-light))}.hp-filter-toggle-row{display:flex;align-items:center;justify-content:space-between;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);border-radius:10px;padding:10px 14px;margin-bottom:20px;cursor:pointer}.hp-filter-toggle__label{font-size:12px;color:#c8b880;font-family:var(--font);font-weight:500;margin-bottom:2px}.hp-filter-toggle__desc{font-size:10px;color:var(--text-dim);font-family:var(--font)}.hp-toggle-track{width:44px;height:24px;border-radius:12px;flex-shrink:0;margin-left:12px;position:relative;transition:all .2s}.hp-toggle-track--on{background:#c8b8784d;border:1px solid rgba(var(--accent-rgb),.6)}.hp-toggle-track--off{background:rgba(var(--overlay-rgb),.07);border:1px solid rgba(var(--overlay-rgb),.1)}.hp-toggle-thumb{position:absolute;top:3px;width:16px;height:16px;border-radius:50%;transition:left .2s}.hp-toggle-thumb--on{left:21px;background:var(--gold-warm);box-shadow:0 0 6px rgba(var(--accent-rgb),.5)}.hp-toggle-thumb--off{left:3px;background:var(--text-muted);box-shadow:none}.hp-btn-clear-all-filters{background:#96323226;border:1px solid rgba(150,50,50,.3);color:#b06060;border-radius:var(--radius-md);padding:9px 20px;cursor:pointer;font-size:12px;font-family:var(--font);width:100%}.hp-melody-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1100;transition:opacity .25s}.hp-melody-outer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1101;display:flex;align-items:center;justify-content:center;padding:16px;pointer-events:none}.hp-melody-panel{pointer-events:auto;width:100%;max-width:560px;max-height:80vh;background:var(--panel-bg);border:1px solid rgba(var(--accent-rgb),.3);border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:0 16px 60px #000000b3;transition:transform .3s,opacity .3s}.hp-melody-header{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px;border-bottom:1px solid rgba(var(--accent-rgb),.15);flex-shrink:0}.hp-melody-header__title{font-family:var(--font);font-size:16px;font-weight:600;color:var(--gold-bright)}.hp-melody-header__sub{font-family:var(--font);font-size:11px;color:var(--text-dim);margin-top:2px}.hp-melody-header__close{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);color:#c0a080;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:14px}.hp-melody-body{padding:14px 16px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.hp-melody-save-row{display:flex;gap:8px}.hp-melody-name-input{flex:1;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.1);color:var(--gold-bright);border-radius:7px;padding:8px 10px;font-size:12px;font-family:var(--font)}.hp-melody-save-btn{background:rgba(var(--accent-rgb),.18);border:1px solid rgba(var(--accent-rgb),.4);color:var(--gold-bright);border-radius:7px;padding:8px 14px;cursor:pointer;font-size:12px;font-family:var(--font);font-weight:600}.hp-melody-save-btn:disabled{opacity:.4;cursor:not-allowed}.hp-melody-empty{text-align:center;color:var(--text-dim);font-size:12px;padding:24px 0;font-style:italic}.hp-melody-list{display:flex;flex-direction:column;gap:10px}.hp-melody-item{background:rgba(var(--accent-rgb),.05);border:1px solid rgba(var(--accent-rgb),.18);border-radius:9px;padding:10px 12px}.hp-melody-item__head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.hp-melody-item__name{font-family:var(--font);font-size:13px;font-weight:600;color:var(--gold-bright);flex:1}.hp-melody-item__count{font-size:10px;color:var(--text-dim)}.hp-melody-item__actions{display:flex;gap:6px}.hp-melody-item__load{background:#64c8821f;border:1px solid rgba(100,200,130,.3);color:#80d090;border-radius:6px;padding:4px 10px;cursor:pointer;font-size:11px;font-family:var(--font)}.hp-melody-item__delete{background:#9632321f;border:1px solid rgba(150,50,50,.3);color:#b06060;border-radius:6px;width:24px;height:24px;cursor:pointer;font-size:12px}.hp-melody-item__chords{display:flex;flex-direction:column;gap:6px}.hp-melody-chord{display:flex;gap:10px;align-items:center;padding:6px 8px;background:#00000040;border-radius:6px}.hp-melody-chord__name{font-family:var(--font);font-size:11px;font-weight:600;color:var(--gold);min-width:80px}.hp-melody-chord__notes{font-family:monospace;font-size:12px;color:#c0a0e0}.hp-melody-select-row{display:flex;gap:8px;align-items:center}.hp-melody-modal-panel{background:var(--bg-surface);border-top:1px solid rgba(214,214,214,.11);z-index:600}.hp-melody-modal-panel .hp-filter-modal__content{display:flex;flex-direction:column;gap:14px;padding:14px 18px 28px}.hp-melody-subtitle{font-size:9px;color:var(--text-dim);letter-spacing:.18em;text-transform:uppercase;margin-top:4px;font-weight:600}.hp-melody-section{display:flex;flex-direction:column;gap:6px}.hp-melody-section .hp-filter-label{margin-bottom:4px}.hp-melody-modal-panel .hp-melody-name-input{flex:1;height:32px;padding:0 12px;background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.1);border-right:none;border-radius:8px 0 0 8px;color:var(--text-primary);font-size:12px;font-family:var(--font);outline:none}.hp-melody-modal-panel .hp-melody-name-input:focus{border-color:rgba(var(--accent-rgb),.45);background:rgba(var(--overlay-rgb),.07)}.hp-melody-modal-panel .hp-melody-save-btn{height:34px;padding:0 16px;border-radius:0 8px 8px 0;background:rgba(var(--accent-rgb),.18);border:1px solid rgba(var(--accent-rgb),.45);border-left:1px solid rgba(var(--overlay-rgb),.07);color:var(--gold-bright);font-size:12px;font-weight:600;cursor:pointer}.hp-melody-modal-panel .hp-melody-save-btn:disabled{opacity:.5;cursor:not-allowed}.hp-melody-modal-panel .hp-melody-save-btn:not(:disabled):hover{background:rgba(var(--accent-rgb),.26)}.hp-melody-modal-panel .hp-melody-select-row{gap:0;align-items:stretch}.hp-melody-modal-panel .hp-melody-select-row .hp-dropdown{flex:1}.hp-melody-modal-panel .hp-melody-select-row .hp-dropdown__trigger{height:34px;border-radius:8px 0 0 8px;font-size:12px}.hp-melody-modal-panel .hp-melody-item__load,.hp-melody-modal-panel .hp-melody-item__delete{height:34px;border-radius:0;border-left:1px solid rgba(var(--overlay-rgb),.07);font-weight:600;cursor:pointer;font-size:12px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center}.hp-melody-modal-panel .hp-melody-item__load{background:#64c88224;border-top:1px solid rgba(100,200,130,.42);border-bottom:1px solid rgba(100,200,130,.42);border-right:none;color:#80d090}.hp-melody-modal-panel .hp-melody-item__load:not(:disabled):hover{background:#64c88238}.hp-melody-modal-panel .hp-melody-item__delete{background:#c85a551f;border-top:1px solid rgba(200,90,85,.42);border-bottom:1px solid rgba(200,90,85,.42);border-right:1px solid rgba(200,90,85,.42);border-radius:0 8px 8px 0;color:#c98785;width:38px;padding:0}.hp-melody-modal-panel .hp-melody-item__delete:not(:disabled):hover{background:#c85a5533}.hp-melody-modal-panel .hp-melody-item__load:disabled,.hp-melody-modal-panel .hp-melody-item__delete:disabled{opacity:.4;cursor:not-allowed}.hp-melody-meta{display:flex;gap:6px;margin:6px 0 4px;flex-wrap:wrap}.hp-melody-meta__pill{font-size:10px;font-weight:600;letter-spacing:.04em;padding:3px 10px;border-radius:999px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.3);color:var(--gold)}.hp-melody-modal-panel .hp-melody-item__chords{margin-top:6px;background:#0000004d;border:1px solid rgba(var(--overlay-rgb),.06);border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:4px;max-height:32vh;overflow-y:auto}.hp-melody-modal-panel .hp-melody-chord{background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.06)}.hp-melody-modal-panel .hp-melody-chord__name{color:var(--gold-fab);font-size:11px;letter-spacing:.04em}.hp-melody-modal-panel .hp-melody-chord__notes{color:#c4d0e8;font-size:12px;font-family:var(--font)}.hp-melody-modal-panel .hp-melody-empty{background:rgba(var(--overlay-rgb),.03);border:1px dashed rgba(var(--accent-rgb),.2);border-radius:10px;color:var(--text-dim);font-size:12px}.hp-melody-select{flex:1;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.1);color:var(--gold-bright);border-radius:7px;padding:8px 10px;font-size:12px;font-family:var(--font);cursor:pointer}.hp-profile-modal-panel .hp-filter-modal__content{padding:18px 16px 28px}.hp-profile-modal__body{font-family:var(--font);color:var(--gold-pale);font-size:13px;line-height:1.5;padding-top:6px}.hp-profile-modal__placeholder{text-align:center;padding:30px 10px;color:var(--gold-soft);font-style:italic}.hp-filter-modal-panel .hp-filter-modal__header{position:sticky;top:0;z-index:6;margin:0 -18px 14px;padding:6px 18px 10px;background:var(--bg-surface);border-bottom:1px solid rgba(var(--overlay-rgb),.1)}.hp-melody-modal-panel .hp-filter-modal__header{margin-bottom:0}.hp-profile-modal-panel .hp-filter-modal__header{margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}.hp-filter-modal__header-left{display:flex;align-items:center;gap:10px;min-width:0}.hp-filter-modal__back{background:#0505057d;color:#f7f6f6b8;font-size:26px;cursor:pointer;line-height:1;width:50px;height:50px;border-radius:30px;border:none;border-left:1px solid rgba(var(--overlay-rgb),.15);border-right:1px solid rgba(var(--overlay-rgb),.1);box-shadow:inset 4px 5px 13px -2px #ffffff09;display:flex;align-items:center;justify-content:center;padding:0 4px 3px 0;flex:0 0 auto}.hp-guide-intro{font-family:var(--font);color:var(--gold-soft);font-size:12px;line-height:1.5;margin:0 4px 14px}.hp-guide-menu{display:flex;flex-direction:column;gap:8px}.hp-guide-row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);border-radius:12px;padding:13px 14px;cursor:pointer;font-family:var(--font);transition:background .15s ease,border-color .15s ease}.hp-guide-row:hover,.hp-guide-row:active{background:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.22)}.hp-guide-row__text{display:flex;flex-direction:column;gap:3px;flex:1 1 auto;min-width:0}.hp-guide-row__title{font-size:14px;font-weight:600;color:var(--gold-pale)}.hp-guide-row__sum{font-size:11.5px;line-height:1.4;color:var(--gold-soft)}.hp-guide-row__chev{font-size:20px;color:var(--gold-soft);flex:0 0 auto}.hp-doc{font-family:var(--font);color:var(--gold-pale)}.hp-doc-lead{font-size:13.5px;line-height:1.6;color:var(--gold-pale);margin:2px 2px 18px}.hp-doc-h{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin:22px 2px 10px}.hp-doc-p{font-size:13px;line-height:1.6;color:var(--gold-pale);margin:0 2px 12px}.hp-doc-dl{margin:0 0 4px}.hp-doc-dl__row{padding:10px 0;border-bottom:1px solid rgba(var(--overlay-rgb),.07)}.hp-doc-dl__row:last-child{border-bottom:none}.hp-doc-dt{font-size:12.5px;font-weight:700;color:var(--gold-pale);margin-bottom:3px}.hp-doc-dd{margin:0;font-size:12.5px;line-height:1.55;color:var(--gold-soft)}.hp-doc-note{margin:16px 2px 2px;padding:11px 13px;border-radius:10px;background:rgba(var(--accent-rgb),.07);border:1px solid rgba(var(--accent-rgb),.16);font-size:12px;line-height:1.5;color:var(--gold-pale)}.hp-doc-demo-wrap{margin:4px 2px 16px}.hp-doc-demo{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:14px;border-radius:12px;background:#00000038;border:1px solid rgba(var(--overlay-rgb),.08)}.hp-doc-demo__cap{font-size:11px;color:var(--gold-soft);margin:7px 2px 0;line-height:1.4}.hp-doc-demo .hp-pan-fab{position:static;opacity:1;display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:999px;background:var(--fab-bg, rgba(40,32,12,.7));border:none;color:var(--hp-fab, var(--gold-fab, #e8d098));font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:default}.hp-doc-demo .hp-auto-button svg{width:18px;height:18px}.hp-doc-demo .hp-action-bar__btn{flex:0 0 auto}.hp-doc-demo .hp-btn-play-ref{width:46px;height:46px;min-width:46px;padding:0}.hp-doc-demo .hp-action-chip{flex:0 0 auto}.hp-doc-badge-host{width:190px;max-width:60%}.hp-doc-tab{font-family:var(--font);font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;border:1px solid rgba(var(--overlay-rgb),.14);background:transparent;color:var(--gold-soft);cursor:default}.hp-doc-tab--active{color:var(--doc-tab, var(--gold-pale));border-color:var(--doc-tab, rgba(var(--accent-rgb),.5));background:color-mix(in srgb,var(--doc-tab, rgba(var(--accent-rgb),1)) 14%,transparent)}.hp-doc-dropdown{display:inline-flex;align-items:center;justify-content:space-between;gap:10px;min-width:130px;padding:8px 11px;border-radius:8px;background:var(--ctl-bg, rgba(0,0,0,.25));border:1px solid rgba(var(--accent-rgb),.25);color:var(--gold-pale);font-size:12px;font-family:var(--font)}.hp-doc-dropdown svg{color:var(--gold-soft);flex:0 0 auto}.hp-doc-slider{position:relative;width:150px;height:4px;border-radius:2px;background:rgba(var(--overlay-rgb),.18)}.hp-doc-slider__fill{position:absolute;left:0;top:0;bottom:0;border-radius:2px;background:rgba(var(--accent-rgb),.7)}.hp-doc-slider__thumb{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;background:var(--accent, #d4a830);transform:translate(-50%,-50%);box-shadow:0 1px 4px #0006}.hp-doc-stepper{display:inline-flex;align-items:center;gap:4px;font-family:var(--font)}.hp-doc-stepper span{min-width:22px;text-align:center;font-size:13px;color:var(--gold-pale)}.hp-doc-stepper button{width:26px;height:26px;border-radius:7px;border:1px solid rgba(var(--overlay-rgb),.14);background:transparent;color:var(--gold-soft);font-size:15px;cursor:default}.hp-doc-gesture{display:inline-flex;flex-direction:column;align-items:center;gap:3px;padding:5px 10px;border-radius:9px;background:#0f0c08d9;border:1px solid rgba(var(--accent-rgb),.55)}.hp-doc-gesture__label{font-family:var(--font);font-size:9px;font-weight:700;letter-spacing:1px;color:#e8d098}.hp-doc-gesture__bar{display:block;width:54px;height:2px;border-radius:1px;background:#cda3532e}.hp-doc-gesture__bar span{display:block;height:100%;border-radius:1px;background:#e8d098}.hp-doc-card-host{width:132px}.hp-doc-noteeditor{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.hp-doc-add{font-family:var(--font);font-size:12px;font-weight:600;padding:8px 13px;border-radius:8px;border:1px solid rgba(var(--accent-rgb),.4);background:rgba(var(--accent-rgb),.12);color:var(--gold-pale);cursor:default}.hp-about{font-family:var(--font)}.hp-about__brand{text-align:center;padding:6px 0 18px;margin-bottom:8px;border-bottom:1px solid rgba(var(--overlay-rgb),.08)}.hp-about__name{font-size:22px;font-weight:700;letter-spacing:.5px;color:var(--gold-pale)}.hp-about__tag{font-size:12px;color:var(--gold-soft);margin-top:4px}.hp-about__maker{display:flex;align-items:flex-start;gap:14px}.hp-about__maker .hp-doc-p{margin-top:0}.hp-about__photo{flex:0 0 auto;width:84px;height:84px;border-radius:50%;object-fit:cover;border:2px solid rgba(var(--accent-rgb),.45);box-shadow:0 4px 14px #0006}.hp-about__link{color:var(--accent, #d4a830);text-decoration:none}.hp-about__link:hover{text-decoration:underline}.hp-about__credit{text-align:center;font-size:11.5px;color:var(--gold-soft);margin:22px 0 2px}.hp-settings-cat{margin-bottom:22px}.hp-settings-cat:last-child{margin-bottom:0}.hp-settings-cat__title{font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);padding:4px 4px 10px}.hp-settings-cat__body{display:flex;flex-direction:column;gap:10px;background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--accent-rgb),.12);border-radius:10px;padding:6px}.hp-settings-row{display:flex;align-items:center;gap:12px;padding:10px}.hp-settings-row+.hp-settings-row{border-top:1px solid rgba(var(--accent-rgb),.08)}.hp-settings-row__text{flex:1;min-width:0}.hp-settings-row__label{font-family:var(--font);font-size:13px;font-weight:600;color:var(--gold-bright)}.hp-settings-row__hint{font-family:var(--font);font-size:11px;color:var(--gold-soft);margin-top:3px;line-height:1.4}.hp-settings-row__control{flex-shrink:0}.hp-settings-row__soon{font-family:var(--font);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);padding:4px 10px;border:1px solid var(--border-gold);border-radius:999px}.hp-theme-picker{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.hp-theme-opt--default{grid-column:1 / -1}.hp-theme-opt{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:var(--radius-md);border:1px solid var(--border-gold);background:transparent;cursor:pointer;font-family:var(--font);transition:border-color .15s ease,background .15s ease}.hp-theme-opt:hover{border-color:var(--border-gold-hi)}.hp-theme-opt--active{border-color:var(--gold-bright);background:var(--border-gold)}.hp-theme-opt__swatch{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle)}.hp-theme-opt__dot{width:8px;height:8px;border-radius:50%}.hp-theme-opt__label{font-size:11px;font-weight:600;color:var(--gold-bright);white-space:nowrap}.hp-toggle{position:relative;width:44px;height:24px;border-radius:999px;background:rgba(var(--overlay-rgb),.08);border:1px solid rgba(var(--overlay-rgb),.1);cursor:pointer;padding:0;transition:background .18s,border-color .18s}.hp-toggle__thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#b9a872;transition:transform .2s cubic-bezier(.32,.72,0,1),background .18s}.hp-toggle--on{background:rgba(var(--accent-rgb),.32);border-color:rgba(var(--accent-rgb),.55)}.hp-toggle--on .hp-toggle__thumb{transform:translate(20px);background:var(--gold-bright)}.hp-toggle:disabled,.hp-toggle--locked{opacity:.4;cursor:not-allowed}.hp-segmented{display:inline-flex;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--accent-rgb),.2);border-radius:999px;padding:2px;gap:2px}.hp-segmented__btn{background:transparent;border:none;font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--gold-soft);padding:6px 12px;border-radius:999px;cursor:pointer;transition:color .15s,background .15s}.hp-segmented__btn--active{color:var(--gold-bright);background:rgba(var(--accent-rgb),.2)}.hp-melody-pending-tracks{display:flex;flex-direction:column;gap:6px;margin-top:8px}.hp-melody-pending-track{display:flex;align-items:center;gap:8px}.hp-melody-pending-track__label{flex:0 0 auto;font-size:11px;color:#c0a0e0;letter-spacing:.08em;text-transform:uppercase;font-weight:600;min-width:56px}.hp-melody-pending-btn{flex:1;height:30px;padding:0 10px;background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.1);border-radius:8px;color:var(--gold-bright);font-size:11px;font-family:var(--font);cursor:pointer;transition:background .15s,border-color .15s}.hp-melody-pending-btn:hover{background:rgba(var(--accent-rgb),.14);border-color:rgba(var(--accent-rgb),.4)}.hp-melody-pending-btn--arrow{flex:0 0 auto;min-width:30px;padding:0;font-size:14px;line-height:1}.hp-melody-pending-btn--groove{flex:1;text-align:center}.hp-melody-pending-track--slider .hp-slider{flex:1;display:flex;align-items:center;gap:10px}.hp-melody-pending-track--slider .hp-slider__label{font-size:11px;color:var(--gold-pale);min-width:34px;text-align:right;font-variant-numeric:tabular-nums}.hp-melody-pending-track--groove-row{gap:10px}.hp-melody-pending-groove-picker{flex:1 0 auto;display:flex;align-items:center;gap:4px}.hp-melody-pending-btn--groove-compact{min-width:78px;height:26px;padding:0 8px;font-size:10px;letter-spacing:.04em;text-transform:uppercase}.hp-melody-pending-groove-picker .hp-melody-pending-btn--arrow{height:26px;min-width:24px;font-size:13px}.hp-melody-pending-intensity{flex:1;display:flex;align-items:center;min-width:0}.hp-melody-pending-intensity .hp-slider{flex:1;display:flex;align-items:center;gap:10px}.hp-melody-pending-intensity .hp-slider__label{font-size:10px;color:var(--gold-pale);min-width:32px;text-align:right;font-variant-numeric:tabular-nums}.hp-melody-search-input{width:100%;height:34px;padding:0 12px;background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.1);border-radius:8px;color:var(--text-primary);font-size:12px;font-family:var(--font);outline:none;box-sizing:border-box}.hp-melody-search-input:focus{border-color:rgba(var(--accent-rgb),.45);background:rgba(var(--overlay-rgb),.07)}.hp-melody-tabs{display:flex;gap:4px;margin:8px 0 4px;border-bottom:1px solid rgba(var(--overlay-rgb),.08)}.hp-melody-tab{background:transparent;border:none;padding:8px 14px;color:var(--gold-soft);font-size:12px;font-family:var(--font);font-weight:600;letter-spacing:.03em;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.hp-melody-tab--active{color:var(--gold-bright);border-bottom-color:rgba(var(--accent-rgb),.65)}.hp-melody-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.hp-melody-row{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px;transition:background .15s;background:rgba(var(--overlay-rgb),.025)}.hp-melody-row:hover{background:rgba(var(--overlay-rgb),.03)}.hp-melody-row__art{flex:0 0 auto;width:44px;height:44px;border-radius:8px;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);display:flex;align-items:center;justify-content:center;color:#c0a0e0;overflow:hidden}.hp-melody-row__art img{width:100%;height:100%;object-fit:cover}.hp-melody-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.hp-melody-row__name{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-melody-row__meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--gold-soft)}.hp-melody-row__author{color:var(--gold-pale);font-weight:600}.hp-melody-row__dot{opacity:.6}.hp-melody-row__actions{display:flex;gap:4px;flex:0 0 auto;flex-direction:column}.hp-melody-row__actions2{display:flex;gap:4px}.hp-melody-row__load{display:inline-flex;align-items:center;gap:3px;height:30px;padding:0 8px;background:rgba(var(--accent-rgb),.14);border:1px solid rgba(var(--accent-rgb),.35);border-radius:8px;color:var(--gold-bright);font-size:11px;font-weight:600;cursor:pointer}.hp-melody-row__load:hover{background:rgba(var(--accent-rgb),.24)}.hp-melody-row__load-num{font-weight:700;letter-spacing:.02em}.hp-melody-row__del{width:30px;height:30px;background:transparent;border:1px solid rgba(var(--overlay-rgb),.08);border-radius:8px;color:var(--gold-soft);font-size:12px;cursor:pointer}.hp-melody-row__del:hover{color:#ffb0b0;border-color:#ff787859}.hp-concert-loops{display:inline-flex;align-items:center;gap:2px;height:30px;padding:0 4px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.28);border-radius:8px;color:var(--gold-bright)}.hp-concert-loops__btn{width:22px;height:22px;background:transparent;border:none;color:var(--gold-bright);font-size:16px;line-height:1;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center}.hp-concert-loops__btn:disabled{opacity:.35;cursor:default}.hp-concert-loops__val{min-width:26px;text-align:center;font-size:11px;font-weight:700;letter-spacing:.02em}.hp-melody-export-toggle{display:flex;align-items:center;gap:8px;width:100%;margin:8px 0 0;padding:9px 14px;background:rgba(var(--accent-rgb),.08);border:1px solid rgba(var(--accent-rgb),.28);color:var(--gold-bright);border-radius:10px;font-family:var(--font);font-weight:600;font-size:12px;letter-spacing:.03em;cursor:pointer;transition:background .15s,border-color .15s}.hp-melody-export-toggle:hover:not(:disabled){background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.45)}.hp-melody-export-toggle:disabled{opacity:.35;cursor:not-allowed}.hp-melody-export-toggle__chev{margin-left:auto;font-size:11px;opacity:.8}.hp-melody-export-panel{margin:8px 0 4px;padding:12px;border-radius:10px;background:rgba(var(--accent-rgb),.05);border:1px solid rgba(var(--accent-rgb),.2);display:flex;flex-direction:column;gap:10px}.hp-melody-export-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.hp-melody-export-row__label{font-size:12px;font-weight:600;letter-spacing:.03em;color:var(--text-dim, rgba(255,255,255,.7))}.hp-melody-export-format{display:inline-flex;gap:4px}.hp-melody-export-format__btn{min-width:52px;height:30px;padding:0 12px;background:rgba(var(--accent-rgb),.08);border:1px solid rgba(var(--accent-rgb),.28);color:var(--gold-bright);border-radius:8px;font-family:var(--font);font-weight:700;font-size:11px;letter-spacing:.04em;cursor:pointer;transition:background .15s,border-color .15s}.hp-melody-export-format__btn--active{background:rgba(var(--accent-rgb),.3);border-color:rgba(var(--accent-rgb),.6)}.hp-melody-export-format__btn:disabled{opacity:.4;cursor:not-allowed}.hp-melody-export-meta{font-size:11px;letter-spacing:.02em;color:var(--text-dim, rgba(255,255,255,.55));text-align:center}.hp-melody-export-go{width:100%;padding:10px 14px;background:rgba(var(--accent-rgb),.3);border:1px solid rgba(var(--accent-rgb),.6);color:var(--gold-bright);border-radius:9px;font-family:var(--font);font-weight:700;font-size:13px;letter-spacing:.03em;cursor:pointer;transition:background .15s,border-color .15s}.hp-melody-export-go:hover:not(:disabled){background:rgba(var(--accent-rgb),.42)}.hp-melody-export-go:disabled{opacity:.4;cursor:not-allowed}.hp-melody-export-progress{display:flex;flex-direction:column;gap:6px}.hp-melody-export-progress__bar{height:8px;border-radius:6px;background:rgba(var(--accent-rgb),.14);overflow:hidden}.hp-melody-export-progress__fill{height:100%;background:var(--gold-bright);border-radius:6px;transition:width .15s linear}.hp-melody-export-progress__label{font-size:11px;letter-spacing:.03em;color:var(--gold-bright);text-align:center}.hp-melody-export-note{font-size:10px;line-height:1.4;color:var(--text-dim, rgba(255,255,255,.45));text-align:center}.hp-melody-tabs--four{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.hp-melody-tabs--four .hp-melody-tab{padding:8px 6px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-melody-row__concert{background:transparent;border:1px solid rgba(var(--accent-rgb),.25);color:var(--gold-warm);min-width:28px;height:28px;padding:0 6px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:2px;font-size:16px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-row__concert:hover:not(:disabled){background:rgba(var(--accent-rgb),.12);color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.55)}.hp-melody-row__concert--in{color:#7fb87f;border-color:#7fb87f73;background:#7fb87f24;cursor:pointer}.hp-melody-row__concert--in:hover:not(:disabled){color:#ffb0b0;border-color:#ff787873;background:#ff78781a}.hp-melody-row__concert-count{font-size:10px;font-weight:700;margin-left:2px}.hp-melody-row__concert:disabled{opacity:.85}.hp-melody-tab--with-icon{display:inline-flex;align-items:center;justify-content:center;gap:5px}.hp-melody-row__share{background:transparent;border:1px solid rgba(var(--accent-rgb),.22);color:var(--gold-warm);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-row__share:hover{background:rgba(var(--accent-rgb),.12);color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.55)}.hp-melody-row__pan{color:var(--gold-warm);opacity:.85}.hp-melody-row__pan--foreign{color:#e08a8a;opacity:1}.hp-melody-foreign-banner{display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 12px;margin:0 0 12px;border-radius:10px;background:#b43c3c1f;border:1px solid rgba(220,90,90,.55);color:#f3c8c8}.hp-melody-foreign-banner--info{background:#7fb87f1a;border-color:#7fb87f73;color:#cfe3cf}[data-theme^=light] .hp-melody-foreign-banner{background:#b43c3c1f;border-color:#b43c3c80;color:#8a2222}[data-theme^=light] .hp-melody-foreign-banner--info{background:#3c823c1f;border-color:#3c823c73;color:#2c6a2c}.hp-melody-foreign-banner__icon{width:22px;height:22px;border-radius:50%;background:#dc5a5acc;color:#1a0707;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}.hp-melody-foreign-banner__body{flex:1;min-width:0}.hp-melody-foreign-banner__title{font-weight:600;font-size:13px;text-align:center}.hp-melody-foreign-banner__sub{font-size:11px;opacity:.78;margin-top:2px;text-align:center}.hp-melody-foreign-banner__actions{display:flex;align-items:center;gap:6px}.hp-melody-foreign-banner__transpose{background:#dc5a5ad9;color:#1a0707;border:none;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px;cursor:pointer;font-family:var(--font)}.hp-melody-foreign-banner__transpose:hover{filter:brightness(1.08)}.hp-melody-foreign-banner__loadpan{background:rgba(var(--accent-rgb),.85);color:var(--bg-inset);border:none;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px;cursor:pointer;font-family:var(--font)}.hp-melody-foreign-banner__loadpan:hover:not(:disabled){filter:brightness(1.08)}.hp-melody-foreign-banner__loadpan:disabled{opacity:.45;cursor:not-allowed;background:#b4b4b440;color:rgba(var(--overlay-rgb),.55)}.hp-melody-fx-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 6px}.hp-melody-fx-toggle{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--gold-warm);cursor:pointer;-webkit-user-select:none;user-select:none}.hp-melody-fx-toggle input{accent-color:var(--gold-warm);cursor:pointer}.hp-alert-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0805029e;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:hp-alert-fade .14s ease-out}@keyframes hp-alert-fade{0%{opacity:0}to{opacity:1}}.hp-alert{background:var(--panel-bg);border:1px solid rgba(var(--accent-rgb),.32);border-radius:14px;padding:18px 18px 14px;width:420px;max-width:calc(100vw - 68px);box-shadow:0 14px 40px #00000080,0 0 0 1px rgba(var(--accent-rgb),.05) inset;color:var(--gold-light);font-family:var(--font);animation:hp-alert-pop .16s cubic-bezier(.32,.72,0,1)}.hp-alert--danger{border-color:#dc5a5a8c}@keyframes hp-alert-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.hp-alert__title{font-size:14px;font-weight:700;color:var(--gold-warm);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}.hp-alert--danger .hp-alert__title{color:#e8a8a8}.hp-alert__message{font-size:14px;line-height:1.45;color:var(--gold-light);white-space:pre-wrap}.hp-alert__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.hp-alert__btn{background:transparent;border:1px solid rgba(var(--accent-rgb),.35);color:var(--gold-light);padding:8px 16px;border-radius:9px;font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.hp-alert__btn:hover{background:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.6)}.hp-alert__btn--ok{background:linear-gradient(135deg,rgba(var(--accent-rgb),.92),#a5782deb);color:var(--bg-inset);border-color:transparent}.hp-alert__btn--ok:hover{filter:brightness(1.08);background:linear-gradient(135deg,rgba(var(--accent-rgb),.92),#a5782deb)}.hp-alert__btn--danger{background:linear-gradient(135deg,#dc5a5ae6,#a53737e6);color:#1a0707}.hp-alert__btn--danger:hover{filter:brightness(1.08)}.hp-alert__btn--cancel{color:#b8a988}.hp-sample-loading{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 76px);transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--panel-bg);border:1px solid rgba(var(--accent-rgb),.35);border-radius:999px;padding:7px 14px;z-index:10000;pointer-events:none;font-family:var(--font);font-size:12px;color:var(--text-primary);box-shadow:0 4px 18px #00000040}.hp-sample-loading__spinner{width:12px;height:12px;flex:0 0 auto;border:2px solid rgba(var(--accent-rgb),.25);border-top-color:rgba(var(--accent-rgb),.9);border-radius:50%;animation:hp-sample-spin .9s linear infinite}@keyframes hp-sample-spin{to{transform:rotate(360deg)}}.hp-sample-loading__bar{width:72px;height:3px;border-radius:2px;background:rgba(var(--accent-rgb),.18);overflow:hidden}.hp-sample-loading__fill{display:block;height:100%;background:rgba(var(--accent-rgb),.85);border-radius:2px;transition:width .25s ease}.hp-toast-stack{position:fixed;top:16px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:10001;pointer-events:none;width:min(420px,calc(100vw - 32px))}.hp-toast{background:var(--panel-bg);border:1px solid rgba(var(--accent-rgb),.45);border-radius:10px;padding:10px 14px;font-family:var(--font);font-size:13px;font-weight:500;color:var(--gold-light);box-shadow:0 8px 24px #00000073;pointer-events:auto;animation:hp-toast-in .22s cubic-bezier(.32,.72,0,1);text-align:center}.hp-toast--success{border-color:#7fb87f99;color:#d5ebd5}.hp-toast--error{border-color:#dc5a5a99;color:#f3c8c8}@keyframes hp-toast-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hp-melody-foreign-banner__dismiss{background:transparent;border:none;color:inherit;cursor:pointer;font-size:14px;opacity:.7}.hp-melody-foreign-banner__dismiss:hover{opacity:1}.hp-melody-concert-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:6px 0 8px}.hp-melody-concert-start{background:linear-gradient(135deg,rgba(var(--accent-rgb),.85),#a5782dd9);color:var(--bg-inset);border:none;padding:8px 16px;border-radius:10px;font-weight:700;font-size:13px;letter-spacing:.03em;font-family:var(--font);cursor:pointer;transition:filter .15s,opacity .15s}.hp-melody-concert-start:hover:not(:disabled){filter:brightness(1.08)}.hp-melody-concert-start:disabled{opacity:.4;cursor:not-allowed}.hp-melody-list--concert .hp-melody-row{background:rgba(var(--overlay-rgb),.025);border:none;border-radius:10px}.hp-melody-concert-idx{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:rgba(var(--accent-rgb),.15);border:1px solid rgba(var(--accent-rgb),.35);color:var(--gold-bright);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}.hp-concert-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:radial-gradient(ellipse at center,var(--bg-inset) 0%,var(--concert-vignette-edge, #0a0703) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;box-sizing:border-box;animation:hpConcertFadeIn .4s ease-out}@keyframes hpConcertFadeIn{0%{opacity:0}to{opacity:1}}.hp-concert-overlay__top{position:absolute;top:24px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:none}.hp-concert-overlay__title{color:var(--gold-bright);font-family:var(--font);font-weight:600;font-size:18px;letter-spacing:.04em}.hp-concert-overlay__counter{color:var(--gold-soft);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.hp-concert-overlay__stage{display:flex;gap:24px;align-items:center;justify-content:center;flex-wrap:wrap;max-width:100%;max-height:70vh}.hp-concert-overlay__exit{position:absolute;bottom:32px;background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--accent-rgb),.35);color:var(--gold-bright);padding:10px 22px;border-radius:12px;font-family:var(--font);font-weight:600;font-size:13px;letter-spacing:.05em;cursor:pointer;transition:background .15s,border-color .15s}.hp-concert-overlay__exit:hover{background:rgba(var(--overlay-rgb),.1);border-color:rgba(var(--accent-rgb),.6)}.hp-melody-edit-current{margin-bottom:12px;padding:10px 12px;border-radius:10px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.18)}.hp-melody-edit-current__row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px}.hp-melody-edit-current__name{color:var(--gold-bright);font-weight:600;font-size:14px;font-family:var(--font);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-melody-update-btn{background:linear-gradient(135deg,rgba(var(--accent-rgb),.85),#a5782dd9);color:var(--bg-inset);border:none;padding:7px 14px;border-radius:8px;font-weight:700;font-size:12px;letter-spacing:.03em;font-family:var(--font);cursor:pointer;transition:filter .15s,opacity .15s;white-space:nowrap}.hp-melody-update-btn:hover:not(:disabled){filter:brightness(1.08)}.hp-melody-update-btn:disabled{opacity:.4;cursor:not-allowed}.hp-melody-row__open{justify-content:center;display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(var(--accent-rgb),.3);color:var(--gold-warm);padding:5px 10px;border-radius:8px;font-size:12px;font-family:var(--font);font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-row__open:hover{background:rgba(var(--accent-rgb),.12);color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.55)}.hp-melody-grab{flex:0 0 auto;background:transparent;border:none;color:rgba(var(--accent-bright-rgb),.55);width:24px;height:32px;display:flex;align-items:center;justify-content:center;cursor:grab;touch-action:none;padding:0;margin-right:-2px}.hp-melody-grab:hover{color:var(--gold-bright)}.hp-melody-grab:active{cursor:grabbing}.hp-melody-row--concert{-webkit-user-select:none;user-select:none;transition:transform .12s,background .15s}.hp-melody-floating{list-style:none;font-family:var(--font)}.hp-melody-row--dragging{background:#262014fa;box-shadow:0 10px 26px #0000008c,0 0 0 1px rgba(var(--accent-rgb),.55);transform:scale(1.02);cursor:grabbing}.hp-melody-row--ghost{background:rgba(var(--accent-bright-rgb),.06);border:1px dashed rgba(var(--accent-bright-rgb),.55);box-shadow:inset 0 0 12px rgba(var(--accent-bright-rgb),.12);box-sizing:border-box;animation:hp-melody-ghost-pulse .7s ease-in-out infinite alternate}@keyframes hp-melody-ghost-pulse{0%{background:rgba(var(--accent-bright-rgb),.04)}to{background:rgba(var(--accent-bright-rgb),.14)}}.hp-melody-update-btn--clean{background:rgba(var(--overlay-rgb),.04);color:rgba(var(--accent-bright-rgb),.55);border:1px solid rgba(var(--overlay-rgb),.08)}.hp-melody-update-btn--clean:disabled{opacity:1;cursor:default}.hp-melody-update-btn--done{background:linear-gradient(135deg,#7fb87fd9,#508c50d9);color:#0a1207;animation:hpUpdateFlash .35s ease-out}@keyframes hpUpdateFlash{0%{transform:scale(.94)}60%{transform:scale(1.05)}to{transform:scale(1)}}.hp-melody-concert-actions{display:flex;align-items:center;gap:8px}.hp-melody-shuffle-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.1);color:rgba(var(--accent-bright-rgb),.65);padding:7px 12px;border-radius:10px;font-family:var(--font);font-weight:600;font-size:12px;letter-spacing:.03em;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-shuffle-btn:hover{color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.35)}.hp-melody-shuffle-btn--on{background:rgba(var(--accent-rgb),.18);border-color:rgba(var(--accent-rgb),.55);color:var(--gold-bright);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.18) inset}.hp-melody-clear-btn{display:block;margin:10px 0 12px;background:#ff78780f;border:1px solid rgba(255,120,120,.25);color:#ffb0b0;padding:7px 14px;border-radius:8px;font-family:var(--font);font-weight:600;font-size:12px;letter-spacing:.03em;cursor:pointer;transition:background .15s,border-color .15s}.hp-melody-clear-btn:hover:not(:disabled){background:#ff787824;border-color:#ff787873}.hp-melody-clear-btn:disabled{opacity:.35;cursor:not-allowed}.hp-melody-edit-globals,.hp-melody-edit-fx{margin-top:12px;padding:10px 12px;border-radius:10px;background:rgba(var(--overlay-rgb),.025);border:1px solid rgba(var(--overlay-rgb),.06)}.hp-melody-edit-fx{margin-top:12px}.hp-melody-fx-block{margin-top:10px;padding-top:8px;border-top:1px dashed rgba(var(--overlay-rgb),.06)}.hp-melody-fx-block:first-of-type{margin-top:4px;padding-top:0;border-top:none}.hp-melody-fx-block__title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-fab);margin-bottom:4px}.hp-melody-fx-time{display:flex;align-items:center;gap:8px;width:100%}.hp-melody-fx-time .hp-slider{flex:1}.hp-melody-fx-mode{flex-shrink:0;background:var(--fab-bg);border:1px solid rgba(var(--accent-rgb),.3);color:var(--gold-fab);padding:4px 10px;border-radius:5px;font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.05em;cursor:pointer;height:24px;transition:background .15s,color .15s,border-color .15s}.hp-melody-fx-mode:hover{color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.6)}.hp-melody-fx-mode--free{color:#c8d4ff;border-color:#78a0ff4d}.hp-melody-eq-row{display:flex;justify-content:space-around;align-items:stretch;gap:12px;padding:8px 4px 4px;height:160px}.hp-melody-eq-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}.hp-melody-eq-col__label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#d6b16fbf}.hp-melody-eq-col .hp-slider{flex:1;height:100%;min-height:0}.hp-melody-edit-row{display:flex;flex-direction:column;align-items:stretch;gap:6px;margin:8px 0}.hp-melody-edit-row>:last-child{width:100%}.hp-melody-edit-row-pair{display:flex;align-items:flex-end;gap:16px}.hp-melody-edit-row-pair .hp-melody-edit-row{margin:8px 0}.hp-melody-edit-row-pair .hp-melody-edit-row--measure{flex:0 0 auto}.hp-melody-edit-row-pair .hp-melody-edit-row--swing{flex:1 1 auto;min-width:0}.hp-melody-edit-row--measure .hp-melody-pending-groove-picker{flex:0 0 auto}.hp-melody-edit-row__label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;font-family:var(--font)}.hp-melody-edit-tracks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.hp-melody-edit-track-card{min-width:0;padding:10px;border-radius:10px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--accent-rgb),.18)}.hp-melody-edit-track-card__header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.hp-melody-edit-track-card__title{color:var(--gold-bright);font-weight:600;font-size:13px;letter-spacing:.03em}.hp-loop-sel-row .hp-melody-edit-row__label{display:flex;align-items:center;gap:5px}.hp-loop-sel-inf{font-size:15px;line-height:1;color:#7fd1c0;text-transform:none}.hp-melody-edit-track-card--looping{border-color:#7fd1c08c;box-shadow:0 0 0 1px #7fd1c040 inset}.hp-loop-lock-dots{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin:2px 0 6px}.hp-loop-lock-dot{min-width:20px;height:20px;padding:0 5px;border-radius:6px;border:1px solid rgba(var(--overlay-rgb),.14);background:transparent;color:var(--gold-soft);font-size:11px;font-weight:700;font-family:var(--font);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-loop-lock-dot--locked{color:#7fd1c0;border-color:#7fd1c080}.hp-loop-lock-dot--active{background:#7fd1c02e;color:#aef0e3;border-color:#7fd1c0cc}.hp-loop-lock-clear{margin-left:auto;height:20px;padding:0 8px;border-radius:6px;border:1px solid rgba(255,120,120,.3);background:transparent;color:#d98a8a;font-size:10px;font-weight:600;letter-spacing:.04em;font-family:var(--font);cursor:pointer}.hp-loop-lock-clear:hover{background:#ff78781f}.hp-melody-edit-row--locked .hp-melody-edit-row__label{color:#7fd1c0}.hp-melody-edit-row--locked .hp-melody-pending-btn--groove-compact,.hp-melody-edit-row--locked .hp-melody-vol-row{box-shadow:0 0 0 1px #7fd1c099 inset;border-radius:8px}.hp-melody-edit-row--inherited .hp-melody-edit-row__label{color:#5f9b91}.hp-melody-edit-row--inherited .hp-melody-pending-btn--groove-compact,.hp-melody-edit-row--inherited .hp-melody-vol-row{box-shadow:0 0 0 1px #7fd1c047 inset;border-radius:8px}.hp-loop-lock-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:5px;width:16px;height:16px;padding:0;vertical-align:middle;border:none;border-radius:4px;background:#7fd1c02e;color:#7fd1c0;cursor:pointer}.hp-loop-lock-badge:hover{background:#7fd1c052;color:#aef0e3}.hp-melody-edit-mute{background:transparent;border:1px solid rgba(var(--overlay-rgb),.12);color:var(--gold-soft);padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;letter-spacing:.05em;font-family:var(--font);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-edit-mute:hover{color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.35)}.hp-melody-edit-mute--on{background:#ff78781f;border-color:#ff787873;color:#ffb0b0}.hp-melody-vol-row{display:flex;align-items:center;gap:8px;flex:1}.hp-melody-vol-row .hp-slider{flex:1}.hp-melody-vol-mute{background:transparent;border:1px solid rgba(var(--overlay-rgb),.12);color:var(--gold-fab);padding:4px 6px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;height:24px;width:26px;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.hp-melody-vol-mute:hover{color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.35)}.hp-melody-vol-mute--on{background:#ff78781f;border-color:#ff787873;color:#ffb0b0}.hp-melody-edit-row--actions{justify-content:flex-end}.hp-melody-edit-clear{display:inline-flex;align-items:center;gap:6px;background:#7e42421a;border:1px solid rgba(126,66,66,.45);color:#d07a7a;padding:5px 10px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.hp-melody-edit-clear:hover{background:#7e424233;color:#ffb0b0;border-color:#ff78788c}.hp-melody-edit-track-card .hp-melody-pending-groove-picker{display:flex;gap:4px;width:100%}.hp-melody-edit-track-card .hp-melody-pending-btn--groove-compact{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-melody-edit-track-card .hp-melody-pending-btn--arrow{flex:0 0 auto}.hp-builder-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000000b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .35s ease}.hp-builder-outer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:301;display:flex;align-items:center;justify-content:center;pointer-events:none}.hp-builder-panel{position:relative;top:5vh;background:#141108;border:1px solid var(--border-gold);border-radius:var(--border-radius);width:100%;max-width:880px;height:90vh;overflow-y:auto;font-family:var(--font);pointer-events:all;transition:opacity .35s ease,transform .35s cubic-bezier(.32,.72,0,1);box-shadow:0 24px 80px #000000bf}.hp-builder-header{position:sticky;top:0;background:#0d0903;display:flex;justify-content:space-between;align-items:center;padding:6px 21px;border-bottom:1px solid rgba(var(--accent-rgb),.12);z-index:9}.hp-builder-header__title{filter:drop-shadow(0px 0px 21px #e8d098a1);font-size:17px;color:var(--gold-bright);font-weight:500}.hp-builder-header__sub{display:none;font-size:9px;color:var(--gold-faint);letter-spacing:3px;text-transform:uppercase;margin-top:2px}.hp-builder-header__close{background:none;border:none;color:var(--text-dim);font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;margin-left:18px}.hp-builder-body{padding:5px}.hp-builder-tabs{display:flex;gap:6px;flex-wrap:wrap}.hp-builder-tab{border-radius:var(--border-radius);padding:5px 12px;cursor:pointer;font-size:11px;font-family:var(--font);transition:all .14s;white-space:nowrap}.hp-builder-tab--inactive{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);color:var(--gold-soft)}.hp-builder-tab--active{background:rgba(var(--accent-rgb),.18);border:1px solid rgba(var(--accent-rgb),.55);color:var(--gold-text)}.hp-builder-tab--active-green{background:#64c8822e;border:1px solid rgba(100,200,130,.55);color:#80d090}.hp-builder-tab--active-blue{background:#a0a0dc2e;border:1px solid rgba(160,160,220,.55);color:#a0b0e0}.hp-preset-list{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.hp-preset-item{display:inline-flex;align-items:stretch;border-radius:7px;overflow:hidden;transition:all .15s;cursor:pointer}.hp-preset-item--selected{border:1px solid rgba(var(--accent-rgb),.55);background:rgba(var(--accent-rgb),.1)}.hp-preset-item--default{border:1px solid rgba(var(--overlay-rgb),.08);background:rgba(var(--overlay-rgb),.03)}.hp-preset-item__label{display:flex;align-items:center;gap:5px;padding:5px 12px;font-size:11px;font-family:var(--font)}.hp-preset-item__label--selected{color:var(--gold-text)}.hp-preset-item__label--default{color:var(--gold-soft)}.hp-preset-item__edit-btn{background:#a0a0dc1a;border-left:1px solid rgba(var(--overlay-rgb),.07);border-top:none;border-bottom:none;border-right:none;color:#a0b0e0;cursor:pointer;padding:0 10px;font-size:10px;font-family:var(--font)}.hp-preset-hint{font-size:9px;color:var(--text-muted);text-align:center;margin-bottom:14px;font-style:italic}.hp-preview-center{display:flex;justify-content:center;margin-bottom:10px}.hp-btn-use-preset{width:100%;padding:11px;background:rgba(var(--accent-rgb),.2);border:1px solid rgba(var(--accent-rgb),.5);color:var(--gold-bright);border-radius:9px;cursor:pointer;font-size:13px;font-family:var(--font);font-weight:600}.hp-custom-empty{text-align:center;padding:32px 0;color:var(--text-muted);font-style:italic;font-size:13px}.hp-custom-list{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.hp-custom-item{display:inline-flex;align-items:stretch;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all .15s}.hp-custom-item--selected{border:1px solid rgba(100,200,130,.55);background:#64c8821a}.hp-custom-item--default{border:1px solid rgba(var(--overlay-rgb),.08);background:rgba(var(--overlay-rgb),.03)}.hp-custom-item__label{display:flex;align-items:center;gap:4px;padding:7px 10px;font-size:12px;font-family:var(--font);font-weight:500}.hp-custom-item__label--selected{color:#80d090}.hp-custom-item__label--default{color:#9a8a60}.hp-custom-item__edit-btn{background:#a0a0dc1a;border-left:1px solid rgba(var(--overlay-rgb),.07);border-top:none;border-bottom:none;border-right:none;color:#a0b0e0;cursor:pointer;padding:0 10px;font-size:10px;font-family:var(--font)}.hp-custom-item__delete-btn{background:#8c2d2d1f;border-left:1px solid rgba(var(--overlay-rgb),.07);border-top:none;border-bottom:none;border-right:none;color:#a85858;cursor:pointer;padding:0 10px;font-size:12px;font-family:var(--font)}.hp-custom-preview-row{display:flex;gap:4px;justify-content:center;margin-bottom:12px;align-items:flex-start;width:100%;overflow:hidden}.hp-custom-preview-col{min-width:0;text-align:center;max-width:270px}.hp-custom-preview-col--single{flex:0 0 auto}.hp-custom-preview-col--double{flex:1 1 0}.hp-custom-side-label{font-size:8px;color:var(--gold-faint);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}.hp-btn-use-custom{width:100%;padding:11px;background:#64c8822e;border:1px solid rgba(100,200,130,.45);color:#80d090;border-radius:9px;cursor:pointer;font-size:13px;font-family:var(--font);font-weight:600}.hp-select-section{max-width:333px;width:100%;margin-bottom:14px}.hp-select-source-label{font-size:9px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;font-family:var(--font);font-weight:600}.hp-select-row{display:flex;gap:6px;align-items:center}.hp-btn-already-active{width:100%;padding:11px;background:#64c88212;border:1px solid rgba(100,200,130,.28);color:#60b080;border-radius:var(--border-radius);cursor:pointer;font-size:13px;font-family:var(--font);font-weight:600}.hp-build-body{display:flex;flex-direction:column;gap:14px}.hp-build-type-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}.hp-build-type-label{font-size:9px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase}.hp-build-divider{width:1px;height:18px;background:rgba(var(--overlay-rgb),.1);margin:0 4px}.hp-build-reset-btn-wrap{margin-left:auto;display:flex;gap:4px;align-items:center}.hp-btn-transpose{background:#a078c81a;border:1px solid rgba(160,120,200,.3);color:#c0a0e0;border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;font-size:12px;font-family:var(--font);font-weight:600;min-width:26px}.hp-btn-transpose:disabled{opacity:.4;cursor:not-allowed}.hp-btn-reset-build{background:#8c2d2d1f;border:1px solid rgba(140,45,45,.25);color:#a85858;border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;font-size:10px;font-family:var(--font)}.hp-rings-editor{background:rgba(var(--accent-rgb),.05);border:1px solid rgba(var(--accent-rgb),.18);border-radius:10px;padding:10px 14px}.hp-rings-editor__header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.hp-rings-editor__title{font-size:9px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;font-weight:600}.hp-rings-editor__sub{font-size:9px;color:var(--gold-faint)}.hp-rings-editor__slots-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.hp-rings-editor__slots-item{display:flex;gap:6px;align-items:center}.hp-rings-editor__slots-label{font-size:9px;color:var(--text-dim)}.hp-rings-editor__rotate-item{display:flex;gap:6px;align-items:center;flex:1;min-width:150px}.hp-rings-editor__rotate-label{font-size:9px;color:var(--text-dim);white-space:nowrap}.hp-canvas-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.hp-canvas-row--wide{flex-wrap:nowrap}.hp-canvas-col{flex:1 1 300px;max-width:300px}.hp-canvas-side-label{display:none;font-size:9px;color:var(--text-dim);text-align:center;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}.hp-canvas-hint{font-size:9px;color:#2e2610;text-align:center;margin-top:6px;font-style:italic}.hp-note-editor{background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.18);border-radius:10px;padding:12px 14px}.hp-note-editor__row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.hp-note-editor__pitch-col{flex:1 1 170px}.hp-note-editor__size-col{flex:1 1 130px}.hp-note-editor__sub-label{font-size:8px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px}.hp-note-editor__pitch-row{display:flex;gap:5px;align-items:center}.hp-btn-preview-note{background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.3);color:var(--gold);border-radius:var(--radius-sm);padding:6px 10px;cursor:pointer;font-size:12px}.hp-note-editor__btn-row{display:flex;gap:6px;flex-wrap:wrap}.hp-btn-add-note{flex:1;padding:7px 12px;background:#64c88226;border:1px solid rgba(100,200,130,.4);color:#80d090;border-radius:7px;cursor:pointer;font-size:11px;font-family:var(--font);font-weight:600}.hp-btn-update-note{flex:1;padding:7px 12px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.4);color:var(--gold-text);border-radius:7px;cursor:pointer;font-size:11px;font-family:var(--font);font-weight:600}.hp-btn-remove-note{padding:7px 12px;background:#8c2d2d1f;border:1px solid rgba(140,45,45,.28);color:#a85858;border-radius:7px;cursor:pointer;font-size:11px;font-family:var(--font)}.hp-note-list__title{font-size:9px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}.hp-note-list__chips{display:flex;gap:4px;flex-wrap:wrap}.hp-note-list__empty{font-size:10px;color:var(--text-faint);font-style:italic}.hp-note-list-btn{border-radius:var(--radius-sm);padding:3px 9px;cursor:pointer;font-size:10px;font-family:var(--font)}.hp-note-list-btn--default{background:rgba(var(--overlay-rgb),.04);border:1px solid rgba(var(--overlay-rgb),.08);color:#8a7850}.hp-note-list-btn--selected{background:rgba(var(--accent-rgb),.2);border:1px solid rgba(var(--accent-rgb),.55);color:var(--gold-text)}.hp-note-list-btn__size{font-size:8px;color:var(--gold-faint);margin-left:3px}.hp-note-list-btn__side{font-size:7px;color:#4a5a28;margin-left:2px}.hp-save-section{border-top:1px solid rgba(var(--overlay-rgb),.06);padding-top:14px}.hp-save-section__label{font-size:9px;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}.hp-a4-row{display:flex;gap:10px;align-items:center;margin-bottom:10px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);border-radius:var(--radius-md);padding:8px 12px}.hp-a4-row__label{font-size:9px;color:var(--text-dim);letter-spacing:1px;white-space:nowrap}.hp-btn-reset-a4{background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.25);color:var(--gold);border-radius:5px;padding:2px 8px;cursor:pointer;font-size:9px;font-family:var(--font);flex-shrink:0}.hp-save-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.hp-pan-name-input{flex:1;background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.1);border-radius:7px;padding:7px 12px;color:var(--text-primary);font-size:12px;font-family:var(--font);outline:none}.hp-btn-save-apply{border-radius:7px;padding:8px 14px;font-size:12px;font-family:var(--font);font-weight:600;white-space:nowrap}.hp-btn-save-apply--enabled{background:#64c8822e;border:1px solid rgba(100,200,130,.45);color:#80d090;cursor:pointer}.hp-btn-save-apply--disabled{background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--overlay-rgb),.07);color:#3a3a30;cursor:default}.hp-btn-save-as-new{background:#a0a0dc26;border:1px solid rgba(160,160,220,.4);color:#a0b0e0;border-radius:7px;padding:8px 14px;cursor:pointer;font-size:12px;font-family:var(--font);font-weight:600;white-space:nowrap}.hp-builder-canvas-svg{display:block;max-width:300px;margin:0 auto;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.hp-preview-pan-svg{display:block;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.hp-builder-mode-row{display:flex;justify-content:center;margin-bottom:10px}.hp-pan-controls-group--attached{gap:0}.hp-pan-controls-group--attached>.hp-pan-mode-btn--lead{border-radius:8px 0 0 8px;border-left:1px solid rgba(var(--overlay-rgb),.09)}.hp-pan-controls-group--attached>.hp-pan-mode-btn:last-child{border-radius:0 8px 8px 0}.hp-select-row.hp-select-row--attached{gap:0;align-items:stretch}.hp-select-row--attached>.hp-dropdown{flex:1}.hp-select-row--attached>.hp-dropdown .hp-dropdown__trigger{border-radius:8px 0 0 8px;height:32px;padding:6px 10px}.hp-select-row--attached>button{height:32px;border-radius:0;border-left:1px solid rgba(var(--overlay-rgb),.07);display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.hp-select-row--attached>button:last-child{border-radius:0 8px 8px 0}.hp-select-row--attached>button:only-of-type{border-radius:0 8px 8px 0}.hp-select-diagrams-row{display:flex;justify-content:center;gap:14px;margin-bottom:8px}.hp-select-diagrams-row--double{flex-wrap:wrap}.hp-select-diagram-col{display:flex;flex-direction:column;align-items:center;width:280px;max-width:100%}.hp-select-diagram-col .hp-diagram-svg{width:100%;height:auto}.hp-builder-tabs{background:#0000004d;border:1px solid rgba(var(--accent-rgb),.18);border-radius:12px;padding:4px;gap:4px;display:inline-flex}.hp-builder-tab{border:1px solid transparent;padding:7px 16px;font-size:12px;font-weight:600;letter-spacing:.02em;border-radius:8px;background:transparent;transition:background .15s,color .15s,border-color .15s,transform .12s}.hp-builder-tab--inactive{background:transparent;border-color:transparent;color:var(--gold-soft)}.hp-builder-tab--inactive:hover{background:rgba(var(--overlay-rgb),.04);color:#b09870}.hp-builder-tab--active,.hp-builder-tab--active-green,.hp-builder-tab--active-blue{background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.45);color:var(--gold-text);box-shadow:0 1px #ffd2781a inset,0 4px 12px #00000059}.hp-builder-tab--active-blue{background:#a0a0dc29;border-color:#a0a0dc73;color:#b8c4e8}.hp-builder-tab--active-green{background:#64c88229;border-color:#64c88273;color:#9cd9ad}.hp-builder-header__title{letter-spacing:.02em}.hp-builder-header__close{transition:background .15s,color .15s,transform .12s}.hp-builder-header__close:hover{background:rgba(var(--overlay-rgb),.06);color:var(--gold-bright);transform:rotate(90deg)}.hp-pan-mode-btn--slap-mute{border-radius:0 8px 8px 0}.hp-pan-mode-btn--slap-mute.hp-pan-mode-btn--muted{background:#dc50461f;border-color:#dc504673;color:#e89890}.hp-builder-outer--sheet{align-items:flex-end;justify-content:center}.hp-builder-panel--sheet{position:relative;top:auto;bottom:0;margin:0 auto;height:min(90vh,calc(100dvh - env(safe-area-inset-top) - 10px));max-height:min(90vh,calc(100dvh - env(safe-area-inset-top) - 10px));border-radius:18px 18px 0 0;border-bottom:none;box-shadow:0 -16px 60px #000000b3;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;-webkit-user-select:none;user-select:none}body:has(.hp-builder-panel--sheet),body:has(.hp-filter-modal-panel){overscroll-behavior-y:none}html:has(.hp-builder-panel--sheet),html:has(.hp-filter-modal-panel){overscroll-behavior-y:none;overflow:hidden}.hp-builder-panel--sheet .hp-filter-modal__drag-handle{position:sticky;top:0;z-index:10;background:#0d0903;margin:0;padding:8px 0 6px;width:100%;height:auto}.hp-builder-panel--sheet .hp-filter-modal__drag-handle:before{content:"";display:block;margin:0 auto;width:40px;height:4px;background:rgba(var(--accent-rgb),.3);border-radius:2px}.hp-builder-panel--sheet .hp-builder-header{top:17px;cursor:grab}.hp-builder-panel--sheet .hp-builder-header:active{cursor:grabbing}.hp-builder-panel{--hpb-radius: 8px;--hpb-radius-sm: 6px;--hpb-control-h: 32px;--hpb-surface-1: rgba(var(--overlay-rgb),.03);--hpb-surface-2: rgba(var(--overlay-rgb),.05);--hpb-border: rgba(var(--accent-rgb),.18);--hpb-border-soft: rgba(var(--overlay-rgb),.08);--hpb-gold: var(--gold-fab);--hpb-gold-soft: rgba(var(--accent-rgb),.16);--hpb-gold-strong: rgba(var(--accent-rgb),.45);--hpb-green: #7fc794;--hpb-green-soft: rgba(100,200,130,.14);--hpb-green-strong: rgba(100,200,130,.45);--hpb-blue: #93a9d8;--hpb-blue-soft: rgba(150,170,220,.14);--hpb-blue-strong: rgba(150,170,220,.42);--hpb-red: #c98785;--hpb-red-soft: rgba(200,90,85,.12);--hpb-red-strong: rgba(200,90,85,.42);--hpb-label: var(--gold-soft);--hpb-text: var(--gold-pale);--hpb-text-dim: var(--gold-soft)}.hp-builder-panel .hp-builder-header{padding:14px 22px}.hp-builder-panel .hp-builder-header__title{font-size:16px;font-weight:600}.hp-builder-panel .hp-builder-header__sub{display:block;font-size:9px;letter-spacing:.18em}.hp-builder-panel .hp-builder-header__close{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;color:var(--gold-soft)}.hp-builder-panel .hp-builder-tabs{margin:none;-webkit-user-select:none;user-select:none}.hp-builder-panel .hp-select-source-label,.hp-builder-panel .hp-build-type-label,.hp-builder-panel .hp-rings-editor__title,.hp-builder-panel .hp-rings-editor__sub,.hp-builder-panel .hp-rings-editor__slots-label,.hp-builder-panel .hp-rings-editor__rotate-label,.hp-builder-panel .hp-note-editor__sub-label,.hp-builder-panel .hp-note-list__title,.hp-builder-panel .hp-save-section__label,.hp-builder-panel .hp-a4-row__label,.hp-builder-panel .hp-canvas-side-label,.hp-builder-panel .hp-custom-side-label,.hp-builder-panel .hp-diagram-side-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--hpb-label);font-weight:600}.hp-builder-panel .hp-preset-hint,.hp-builder-panel .hp-canvas-hint{font-size:10px;color:var(--text-dim);font-style:normal;letter-spacing:.04em}.hp-builder-panel .hp-dropdown__trigger,.hp-builder-panel .hp-pan-name-input,.hp-builder-panel .hp-btn-use-preset,.hp-builder-panel .hp-btn-use-custom,.hp-builder-panel .hp-btn-already-active,.hp-builder-panel .hp-btn-save-apply,.hp-builder-panel .hp-btn-save-as-new,.hp-builder-panel .hp-btn-add-note,.hp-builder-panel .hp-btn-update-note,.hp-builder-panel .hp-btn-remove-note,.hp-builder-panel .hp-btn-preview-note,.hp-builder-panel .hp-btn-transpose,.hp-builder-panel .hp-btn-reset-build,.hp-builder-panel .hp-btn-reset-a4,.hp-builder-panel .hp-preset-item__edit-btn,.hp-builder-panel .hp-custom-item__edit-btn,.hp-builder-panel .hp-custom-item__delete-btn{font-family:var(--font);font-size:12px;font-weight:500;letter-spacing:.02em;transition:background .15s,border-color .15s,color .15s,transform .12s}.hp-builder-panel .hp-dropdown__trigger{height:var(--hpb-control-h);border-radius:var(--hpb-radius);background:var(--hpb-surface-2);border:1px solid var(--hpb-border-soft);color:var(--hpb-text);padding:0 12px;font-size:12px}.hp-builder-panel .hp-dropdown__trigger:hover{border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--overlay-rgb),.07)}.hp-builder-panel .hp-dropdown__menu{border-radius:var(--hpb-radius);border-color:var(--hpb-border);margin-top:4px}.hp-builder-panel .hp-dropdown__option{font-size:12px;padding:8px 12px}.hp-builder-panel .hp-pan-name-input{height:var(--hpb-control-h);border-radius:var(--hpb-radius);background:var(--hpb-surface-2);border:1px solid var(--hpb-border-soft);padding:0 12px}.hp-builder-panel .hp-pan-name-input:focus{border-color:var(--hpb-gold-strong);background:rgba(var(--overlay-rgb),.07)}.hp-builder-panel .hp-btn-use-preset,.hp-builder-panel .hp-btn-use-custom,.hp-builder-panel .hp-btn-already-active,.hp-builder-panel .hp-btn-save-apply,.hp-builder-panel .hp-btn-save-as-new{height:38px;padding:0 18px;border-radius:var(--hpb-radius);cursor:pointer;font-weight:600;font-size:12px;max-width:333px;width:100%}.hp-builder-panel .hp-btn-use-preset{background:var(--hpb-gold-soft);border:1px solid var(--hpb-gold-strong);color:var(--gold-bright)}.hp-builder-panel .hp-btn-use-preset:hover{background:rgba(var(--accent-rgb),.24)}.hp-builder-panel .hp-btn-use-custom,.hp-builder-panel .hp-btn-save-apply.hp-btn-save-apply--enabled{background:var(--hpb-green-soft);border:1px solid var(--hpb-green-strong);color:var(--hpb-green)}.hp-builder-panel .hp-btn-use-custom:hover,.hp-builder-panel .hp-btn-save-apply.hp-btn-save-apply--enabled:hover{background:#64c88238}.hp-builder-panel .hp-btn-save-apply.hp-btn-save-apply--disabled{background:var(--hpb-surface-1);border:1px solid var(--hpb-border-soft);color:#4a4232}.hp-builder-panel .hp-btn-already-active{background:#64c8820f;border:1px solid rgba(100,200,130,.28);color:var(--hpb-green)}.hp-builder-panel .hp-btn-save-as-new{background:var(--hpb-blue-soft);border:1px solid var(--hpb-blue-strong);color:var(--hpb-blue)}.hp-builder-panel .hp-btn-save-as-new:hover{background:#96aadc38}.hp-builder-panel .hp-btn-add-note,.hp-builder-panel .hp-btn-update-note,.hp-builder-panel .hp-btn-remove-note{height:var(--hpb-control-h);padding:0 14px;border-radius:var(--hpb-radius);cursor:pointer;font-size:11px;font-weight:600}.hp-builder-panel .hp-btn-add-note{background:var(--hpb-green-soft);border:1px solid var(--hpb-green-strong);color:var(--hpb-green)}.hp-builder-panel .hp-btn-add-note:hover{background:#64c88238}.hp-builder-panel .hp-btn-update-note{background:var(--hpb-gold-soft);border:1px solid var(--hpb-gold-strong);color:var(--gold-bright)}.hp-builder-panel .hp-btn-update-note:hover{background:rgba(var(--accent-rgb),.24)}.hp-builder-panel .hp-btn-remove-note{background:var(--hpb-red-soft);border:1px solid var(--hpb-red-strong);color:var(--hpb-red)}.hp-builder-panel .hp-btn-remove-note:hover{background:#c85a5533}.hp-builder-panel .hp-btn-preview-note{height:var(--hpb-control-h);min-width:var(--hpb-control-h);padding:0;border-radius:var(--hpb-radius);background:var(--hpb-gold-soft);border:1px solid var(--hpb-gold-strong);color:var(--hpb-gold);cursor:pointer}.hp-builder-panel .hp-btn-preview-note:hover{background:rgba(var(--accent-rgb),.26)}.hp-builder-panel .hp-btn-transpose{height:28px;min-width:30px;padding:0 10px;border-radius:var(--hpb-radius-sm);background:#a078c81a;border:1px solid rgba(160,120,200,.32);color:#c0a0e0;font-weight:600;cursor:pointer}.hp-builder-panel .hp-btn-transpose:hover:not(:disabled){background:#a078c82e}.hp-builder-panel .hp-btn-reset-build{height:28px;padding:0 12px;border-radius:var(--hpb-radius-sm);background:var(--hpb-red-soft);border:1px solid var(--hpb-red-strong);color:var(--hpb-red);font-size:10px;font-weight:600;cursor:pointer}.hp-builder-panel .hp-btn-reset-build:hover{background:#c85a5533}.hp-builder-panel .hp-btn-reset-a4{height:24px;padding:0 10px;border-radius:var(--hpb-radius-sm);background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.3);color:var(--hpb-gold);font-size:10px;cursor:pointer}.hp-builder-panel .hp-btn-reset-a4:hover{background:rgba(var(--accent-rgb),.2)}.hp-builder-panel .hp-preset-item__edit-btn,.hp-builder-panel .hp-custom-item__edit-btn,.hp-builder-panel .hp-custom-item__delete-btn{padding:0 14px;font-size:11px;font-weight:600;cursor:pointer}.hp-builder-panel .hp-preset-item__edit-btn,.hp-builder-panel .hp-custom-item__edit-btn{background:var(--hpb-blue-soft);color:var(--hpb-blue)}.hp-builder-panel .hp-preset-item__edit-btn:hover,.hp-builder-panel .hp-custom-item__edit-btn:hover{background:#96aadc38}.hp-builder-panel .hp-custom-item__delete-btn{background:var(--hpb-red-soft);color:var(--hpb-red);font-size:13px}.hp-builder-panel .hp-custom-item__delete-btn:hover{background:#c85a5538}.hp-builder-panel .hp-builder-tabs--segment{margin:0;padding:3px;border-radius:9px;background:#0000004d;border:1px solid var(--hpb-border);display:inline-flex;gap:2px}.hp-builder-panel .hp-builder-tabs--segment .hp-builder-tab{padding:5px 12px;font-size:11px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--hpb-text-dim);font-weight:600;letter-spacing:.02em}.hp-builder-panel .hp-builder-tabs--segment .hp-builder-tab--inactive{background:transparent;border-color:transparent}.hp-builder-panel .hp-builder-tabs--segment .hp-builder-tab--inactive:hover{background:rgba(var(--overlay-rgb),.04);color:#b09870}.hp-builder-panel .hp-builder-tabs--segment .hp-builder-tab--active{background:var(--hpb-gold-soft);border-color:var(--hpb-gold-strong);color:var(--hpb-gold);box-shadow:0 1px #ffd2781a inset}.hp-builder-panel .hp-rings-editor,.hp-builder-panel .hp-note-editor{background:var(--hpb-surface-1);border-radius:var(--hpb-radius);padding:14px;margin:8px 0;width:100%}.hp-builder-panel .hp-a4-row{background:var(--hpb-surface-1);border:1px solid var(--hpb-border-soft);border-radius:var(--hpb-radius);padding:8px 12px}.hp-builder-panel .hp-note-list-btn{height:26px;padding:0 10px;border-radius:var(--hpb-radius-sm);font-size:11px;display:inline-flex;align-items:center;gap:4px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.hp-builder-panel .hp-note-list-btn--default{background:var(--hpb-surface-2);border:1px solid var(--hpb-border-soft);color:#a89878}.hp-builder-panel .hp-note-list-btn--default:hover{border-color:var(--hpb-gold-strong);color:var(--hpb-text)}.hp-builder-panel .hp-note-list-btn--selected{background:var(--hpb-gold-soft);border:1px solid var(--hpb-gold-strong);color:var(--gold-bright)}.hp-builder-panel .hp-select-section{margin-bottom:14px}.hp-builder-panel .hp-select-source-label{margin-bottom:6px}.hp-builder-panel .hp-build-body{gap:14px}.hp-builder-panel .hp-dropdown--w72 .hp-dropdown__trigger,.hp-builder-panel .hp-dropdown--w88 .hp-dropdown__trigger,.hp-builder-panel .hp-dropdown--w100 .hp-dropdown__trigger{padding:0 10px;font-size:11px}.hp-builder-tab-right{justify-content:safe center;align-items:center;display:flex;flex-direction:column;width:100%}.hp-build-sectioned{align-items:stretch}.hp-build-nav{display:flex;gap:4px;width:100%;padding:20px 4px 4px;margin-bottom:8px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.14);border-radius:12px;box-sizing:border-box}.hp-build-nav-btn{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:3px 4px;background:transparent;border:1px solid transparent;border-radius:9px;color:var(--gold-soft);font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:color .15s ease,background .15s ease,border-color .15s ease}.hp-build-nav-btn:hover{color:var(--gold-bright);background:rgba(var(--accent-rgb),.08)}.hp-build-nav-btn--active{color:#1c1408;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:rgba(var(--accent-rgb),.55);box-shadow:0 1px 6px #00000059,inset 0 1px rgba(var(--overlay-rgb),.35)}.hp-build-nav-btn__icon{display:block;width:22px;height:22px}.hp-build-nav-btn__icon svg{width:100%;height:100%;display:block}.hp-build-nav-btn__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.hp-build-section-summary{width:100%;padding:0 4px 8px;font-size:11px;letter-spacing:.02em;color:var(--gold-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:1px solid rgba(var(--accent-rgb),.12)}.hp-build-section{display:none;width:100%}.hp-build-section--active{display:block;padding-top:12px}.hp-build-general-row{align-items:center}.hp-build-general-row__field{flex:1 1 120px;min-width:0}.hp-build-general-row__field .hp-dropdown{flex:1 1 auto;min-width:0}.hp-build-general-row__reset{flex:0 0 auto;align-self:center}.hp-midi-panel{display:flex;flex-direction:column;gap:14px;max-width:520px;width:100%;margin:0 auto;color:#dcd9d9}.hp-midi-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--overlay-rgb),.08);border-radius:10px}.hp-midi-row--toggle{align-items:flex-start}.hp-midi-title{font-weight:600;font-size:15px;margin-bottom:4px}.hp-midi-sub{font-size:12px;opacity:.7;max-width:320px;line-height:1.4}.hp-midi-label{font-size:13px;opacity:.7}.hp-midi-value{font-size:13px;opacity:.95;text-align:right;z-index:2}.hp-midi-toggle{border:1px solid rgba(var(--overlay-rgb),.2);background:transparent;color:inherit;padding:8px 18px;border-radius:999px;font-weight:600;letter-spacing:.5px;cursor:pointer;min-width:64px}.hp-midi-toggle:disabled{opacity:.4;cursor:not-allowed}.hp-midi-toggle--on{background:#80d090;color:#0b1a10;border-color:#80d090}.hp-midi-status{color:var(--gold-bright)}.hp-midi-status--ready{color:#80d090}.hp-midi-status--idle{opacity:.6}.hp-midi-status--unsupported,.hp-midi-status--denied{color:#e08080}.hp-midi-hint{font-size:12px;opacity:.55;padding:4px 4px 0}.hp-dropdown{position:relative}.hp-dropdown__trigger{width:100%;background:rgba(var(--overlay-rgb),.06);border:1px solid rgba(var(--overlay-rgb),.14);color:var(--text-primary);border-radius:var(--border-radius);padding:6px 10px;cursor:pointer;font-size:11px;font-family:var(--font);display:flex;justify-content:space-between;align-items:center;gap:6px;text-align:left}.hp-dropdown__arrow{opacity:.5;font-size:9px}.hp-dropdown__menu{position:absolute;top:calc(100% + 3px);left:0;right:0;z-index:500;background:var(--bg-elevated);border:1px solid rgba(var(--accent-rgb),.3);border-radius:var(--border-radius);overflow:auto;max-height:200px;box-shadow:0 8px 32px #000000b3}.hp-dropdown__option{width:100%;border:none;padding:7px 10px;cursor:pointer;font-size:11px;font-family:var(--font);text-align:left;border-bottom:1px solid rgba(var(--overlay-rgb),.04)}.hp-dropdown__option--active{background:rgba(var(--accent-rgb),.1);color:var(--gold-bright)}.hp-dropdown__option--default{background:transparent;color:var(--gold-soft)}.hp-dropdown__option--current{background:rgba(var(--accent-green-rgb),.12);color:var(--accent-green);font-weight:600;border-left:2px solid var(--accent-green)}.hp-dropdown__option--current.hp-dropdown__option--active{background:rgba(var(--accent-green-rgb),.2);color:var(--accent-green)}.hp-dropdown__option--disabled{opacity:.45;cursor:not-allowed;font-style:italic}.hp-dropdown__option--disabled:hover{background:transparent!important}.hp-dropdown__trigger--current{border-color:rgba(var(--accent-green-rgb),.4)!important;background:rgba(var(--accent-green-rgb),.08)!important;color:var(--accent-green)!important}.hp-dropdown__current-mark{display:inline-block;color:var(--accent-green);margin-right:6px;font-size:8px;vertical-align:middle}.hp-dropdown__current-tag{margin-left:8px;font-size:9px;font-weight:500;color:var(--accent-green);background:rgba(var(--accent-green-rgb),.15);padding:1px 6px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px}.hp-dropdown--w100{width:100px}.hp-dropdown--w88{width:88px}.hp-dropdown--w72{width:72px}.hp-dropdown--flex{flex:1}.hp-slider{display:flex;gap:8px;align-items:center;flex:1}.hp-slider__track-wrap{flex:1;position:relative;height:28px;display:flex;align-items:center;cursor:pointer;touch-action:pan-y;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.hp-slider__track-wrap.hp-slider__track-wrap--dragging,.hp-slider__track-wrap--vertical.hp-slider__track-wrap--dragging{touch-action:none}.hp-slider__track-bg{position:absolute;left:0;right:0;height:4px;background:rgba(var(--overlay-rgb),.08);border-radius:2px;pointer-events:none}.hp-slider__track-fill{position:absolute;left:0;height:4px;background:rgba(var(--accent-rgb),.6);border-radius:2px;pointer-events:none}.hp-slider__thumb{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--gold);border:2px solid var(--bg-header);pointer-events:none;box-shadow:0 0 6px rgba(var(--accent-rgb),.4);transition:transform .12s ease}.hp-slider__track-wrap--dragging .hp-slider__thumb{transform:scale(1.15);box-shadow:0 0 10px rgba(var(--accent-bright-rgb),.65)}.hp-slider__label{font-size:9px;color:var(--text-dim);min-width:28px;text-align:right;flex-shrink:0}.hp-slider--vertical{flex-direction:column;align-items:center;gap:6px;height:100%}.hp-slider__track-wrap--vertical{flex:1;width:28px;height:100%;min-height:120px;display:flex;justify-content:center;touch-action:pan-x}.hp-slider__track-bg--vertical{width:4px;height:100%;left:50%;right:auto;top:0;transform:translate(-50%);background:rgba(var(--overlay-rgb),.08);border-radius:2px}.hp-slider__track-fill--vertical{width:4px;height:0;left:50%;right:auto;bottom:0;transform:translate(-50%);background:rgba(var(--accent-rgb),.6);border-radius:2px}.hp-slider__thumb--vertical{width:18px;height:18px;left:50%;transform:translate(-50%)}.hp-slider__track-wrap--vertical.hp-slider__track-wrap--dragging .hp-slider__thumb{transform:translate(-50%) scale(1.15)}.hp-slider__label--vertical{min-width:0;text-align:center;font-variant-numeric:tabular-nums}.hp-action-chips-row{display:flex;grid-template-columns:repeat(4,1fr);gap:6px;margin:0 auto 6px;width:100%;max-width:480px;padding:0 8px;box-sizing:border-box;transition:opacity .2s}.hp-action-chip{min-width:50px;position:relative;display:flex;align-items:center;justify-content:center;height:24px;min-height:24px;border-radius:7px;padding:0 8px;font-family:var(--font);font-size:11px;font-weight:600;cursor:pointer;box-sizing:border-box;top:auto;left:auto;right:auto;bottom:auto;transform:none}.hp-action-chip__placeholder{color:rgba(var(--accent-bright-rgb),.3);font-size:13px;letter-spacing:.1em}.hp-action-chip--badge{flex-grow:1;background:color-mix(in srgb,var(--accent, rgba(var(--accent-rgb),.4)) 8%,rgba(var(--overlay-rgb),.03));border:1px solid color-mix(in srgb,var(--accent, rgba(var(--accent-rgb),.4)) 22%,rgba(var(--overlay-rgb),.06));overflow:hidden}.hp-action-chip--badge .hp-chord-badge{height:auto;padding:0;font-size:11px;background:none;border:none}.hp-action-chip--badge .hp-chord-badge__root{font-size:12px}.hp-action-chip--badge .hp-chord-badge__count{font-size:8px}.hp-action-chip--swipeable{touch-action:pan-y;cursor:grab}.hp-action-chip--dragging{cursor:grabbing}.hp-chord-badge-strip{--step: 50%;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;will-change:transform;transform:translate(calc(50% - 1.5 * var(--step) + var(--dx, 0px)))}.hp-chord-badge-strip--anim{transition:transform .19s cubic-bezier(.22,.61,.36,1)}.hp-chord-badge-cell{flex:0 0 var(--step);min-width:0;display:flex;align-items:center;justify-content:center;white-space:nowrap}.hp-chord-badge-cell .hp-chord-badge{min-width:0;max-width:100%}.hp-chord-badge-cell .hp-chord-badge__name{min-width:0;overflow:hidden;text-overflow:ellipsis}.hp-chord-badge-cell--side{opacity:.5;transition:opacity .15s}.hp-chord-badge-cell--side[aria-hidden=true]{opacity:0}.hp-action-chip--active .hp-chord-badge-cell--side{opacity:.9}.hp-chord-badge-cell--side .hp-chord-badge{font-size:10px}.hp-action-chip--clear{background:#ff78780f;border:1px solid rgba(255,120,120,.25);color:#ffb0b0;transition:background .15s,border-color .15s}.hp-action-chip--clear:hover:not(:disabled){background:#ff787824;border-color:#ff787873}.hp-action-chip--clear:disabled,.hp-action-chip--disabled{opacity:.32;cursor:not-allowed}.hp-note-glow-circle{filter:blur(6px);opacity:0;transition:all 1s ease-out;pointer-events:none;transform:translateZ(0);will-change:transform}.hp-note-glow-circle--lit{transform:translateZ(0);will-change:transform;filter:blur(6px);opacity:1;transition:all 50ms ease-out}.hp-svg-note-group--pressed .hp-note-glow-circle{opacity:var(--press-opacity);transition:opacity 30ms linear}.hp-svg-note-group{scale:1.05;transform:scaleY(var(--scale-note));transform-origin:var(--transformOrigin);rotate:var(--rotate);cursor:pointer;transition:opacity .35s cubic-bezier(.32,.72,0,1)}.hp-svg-note-group--pressed{transition:opacity 30ms linear}.hp-svg-builder-note{cursor:grab}.hp-svg-builder-note--dragging{cursor:grabbing}.hp-svg-text{-webkit-user-select:none;user-select:none;pointer-events:none}.hp-svg-circle--stroke-anim{stroke:var(--color-default);scale:var(--scale-inner-note);transform-origin:var(--transformOrigin)}.hp-svg-circle--stroke-anim-in{scale:var(--scale-inner-note);transform-origin:var(--transformOrigin);stroke:var(--color-lit)}@keyframes flash-sequence-stroke{0%{stroke:var(--color-default)}14%{stroke:var(--color-lit)}43%{stroke:var(--color-lit)}to{stroke:var(--color-default)}}.hp-svg-circle--all-anim{transition:all .7s;fill:var(--color-default);stroke:var(--color-stroke-default);stroke-width:1.5;opacity:var(--press-opacity)}@keyframes flash-sequence-all{0%{stroke:var(--color-stroke-default);fill:var(--color-default)}14%{stroke:var(--color-stroke-lit);fill:var(--color-lit)}43%{stroke:var(--color-stroke-lit);fill:var(--color-lit)}to{stroke:var(--color-stroke-default);fill:var(--color-default)}}.hp-svg-circle--all-anim-in{stroke-width:2.5;transition:all 50ms;fill:var(--color-lit);stroke:var(--color-stroke-lit)}@keyframes flash-sequence-all-in{0%{stroke:var(--color-stroke-default)}14%{stroke:rgba(var(--accent-rgb),.1)}43%{stroke:rgba(var(--accent-rgb),.1)}to{stroke:var(--color-stroke-lit)}}.hp-svg-text--fill-anim{-webkit-user-select:none;user-select:none;pointer-events:none;transition:fill 50ms;fill:var(--color-default)}.hp-svg-text--fill-anim-in{-webkit-user-select:none;user-select:none;pointer-events:none;animation:flash-sequence-text-fill 1s ease-in-out forwards}@keyframes flash-sequence-text-fill{0%{fill:var(--color-default)}14%{fill:var(--color-lit)}43%{fill:var(--color-lit)}to{fill:var(--color-default)}}@keyframes flash-sequence-glow{0%{fill:var(--color-default)}14%{fill:var(--color-lit)}43%{fill:var(--color-lit)}to{fill:var(--color-default)}}@media(max-width:560px){.hp-builder-panel{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:100vh}.hp-builder-header{padding:14px 16px 12px}.hp-canvas-row{flex-wrap:wrap}.hp-content{padding:0 8px}.hp-filter-bar{gap:6px}}.hp-left-panel,.hp-right-panel{display:contents}@media(min-width:750px){.hp-builder-outer{padding:0;align-items:stretch}.hp-builder-panel{height:100dvh;max-height:100dvh;border-radius:0;overflow:hidden;display:flex;flex-direction:column}.hp-builder-header{flex-shrink:0;padding:10px 16px 8px}.hp-builder-header__title{font-size:14px}.hp-builder-header__sub{display:none}.hp-builder-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding:0}.hp-builder-tabs{flex-shrink:0;padding:8px 14px 6px;border-bottom:1px solid rgba(var(--overlay-rgb),.05)}.hp-builder-tab-layout{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;gap:0;padding:0 16px 16px}.hp-builder-tab-left{width:46%;min-width:220px;max-width:340px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden;padding:6px 8px;border-right:1px solid rgba(var(--accent-rgb),.1)}.hp-builder-tab-right{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:20px 14px 16px;display:flex;flex-direction:column;gap:10px}.hp-builder-tab-empty{font-size:11px;color:var(--text-dim);font-style:italic;text-align:center;padding:16px}.hp-build-body{flex:1;min-height:0;overflow:hidden}.hp-canvas-area{width:100%}.hp-canvas-hint{font-size:8px;margin-top:2px}.hp-preview-center{display:flex;justify-content:center}.hp-preset-hint{font-size:9px;margin-top:4px;text-align:center}.hp-custom-preview-row{width:100%}}body[data-perf="1"] *,body[data-perf="1"] *:before,body[data-perf="1"] *:after{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}body[data-no-note-blur="1"] .hp-note-glow-circle,body[data-no-note-blur="1"] .hp-note-glow-circle--lit,body[data-no-note-blur="1"] .mod-blur{filter:none!important;will-change:auto!important}body[data-no-note-blur="1"] .hp-svg-note-group{will-change:auto!important}body[data-perf="1"] .hp-builder-panel,body[data-perf="1"] .hp-filter-modal-panel,body[data-perf="1"] .hp-profile-modal-panel,body[data-perf="1"] .hp-saved-chords-row,body[data-perf="1"] .hp-pan-strip,body[data-perf="1"] .hp-topbar,body[data-perf="1"] .hp-tabbar{box-shadow:none!important}[data-theme^=light] body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab{box-shadow:0 0 18px -5px rgba(var(--accent-rgb),.3)}[data-theme^=light] body.hp-grid-shell .hp-pan-strip .hp-pan-fab:hover{background:rgba(var(--accent-rgb),.16);color:var(--gold-warm)}[data-theme^=light] body.hp-grid-shell .hp-pan-strip .hp-pan-fab--gesturing{background:rgba(var(--accent-rgb),.22);color:var(--gold-warm)}[data-theme^=light] .hp-tabbar__btn{color:var(--gold-soft)}[data-theme^=light] .hp-tabbar__btn[aria-current]{color:var(--gold-bright)}[data-theme^=light] .hp-tabbar__btn[aria-current]:before{background:rgba(var(--accent-rgb),.14)}[data-theme^=light] .hp-doc-demo{background:rgba(var(--accent-rgb),.1)}[data-theme^=light] .hp-filter-modal__close,[data-theme^=light] .hp-filter-modal__back{background:rgba(var(--accent-rgb),.1);color:var(--gold-text);border-left-color:var(--border-gold);border-right-color:var(--border-gold);box-shadow:inset 2px 3px 10px -2px rgba(var(--accent-rgb),.12)}[data-theme^=light] .hp-melody-header__close{color:var(--gold-text)}[data-theme^=light] body.hp-grid-shell .hp-filter-bar.hp-filter-fab{box-shadow:0 6px 18px -6px rgba(var(--accent-rgb),.45)}[data-theme^=light] body.hp-grid-shell .hp-filter-bar.hp-filter-fab:hover{background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.55)}[data-theme^=light] body.hp-grid-shell .hp-filter-bar.hp-filter-fab--active{background:rgba(var(--accent-rgb),.2);color:var(--gold-text);border-color:rgba(var(--accent-rgb),.7)}[data-theme^=light] .hp-btn-filter--active{background:rgba(var(--accent-rgb),.12);color:var(--gold-text)}[data-theme^=light] .hp-builder-panel .hp-builder-tabs--segment{background:#5c4a2814}[data-theme^=light] .hp-builder-panel .hp-builder-tabs--segment .hp-builder-tab--inactive{color:var(--gold-soft)}[data-theme^=light] body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn--active,[data-theme^=light] body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn--active:hover{color:var(--bg-surface)}[data-theme^=light] body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn:not(.hp-build-nav-btn--active):hover{color:var(--gold-bright)}[data-theme^=light] .hp-btn-play-ref{background:radial-gradient(circle at 35% 28%,var(--gold-bright) 0%,var(--gold) 58%,var(--gold-warm) 100%);box-shadow:0 4px 16px rgba(var(--accent-rgb),.4);color:#fffaf0;border-color:rgba(var(--accent-rgb),.3)}[data-theme^=light] .hp-action-bar__btn--perform-off{color:var(--gold-soft);background:rgba(var(--accent-rgb),.06)}[data-theme^=light] .hp-melody-clear-btn,[data-theme^=light] .hp-action-chip--clear,[data-theme^=light] .hp-melody-edit-clear{background:#b8382e1a;border-color:#b8382e61;color:#b0382e}[data-theme^=light] .hp-melody-clear-btn:hover:not(:disabled),[data-theme^=light] .hp-action-chip--clear:hover:not(:disabled),[data-theme^=light] .hp-melody-edit-clear:hover{background:#b8382e2e;border-color:#b8382e94;color:#8f2a22}[data-theme^=light] .hp-melody-row{background:#5c4a280f}[data-theme^=light] .hp-melody-row:hover{background:#5c4a281c}[data-theme^=light] .hp-melody-row__art{background:#5c4a2814;border-color:#5c4a2824}[data-theme^=light] .hp-saved-chip{color:var(--text-muted)}[data-theme^=light] .hp-saved-chip--default{background:var(--bg-surface);border-color:var(--border-gold);box-shadow:0 1px 4px rgba(var(--accent-rgb),.14)}[data-theme^=light] .hp-saved-chip--default:hover{background:rgba(var(--accent-rgb),.1);border-color:var(--border-gold-hi)}[data-theme^=light] .hp-strip-end__btn:hover{background:rgba(var(--accent-rgb),.16);border-color:rgba(var(--accent-rgb),.45);color:var(--gold-warm)}[data-theme^=light] .hp-strip-end__btn--clear{color:#b0382e;border-color:#b8382e66}[data-theme^=light] .hp-strip-end__btn--clear:hover{background:#b8382e24;border-color:#b8382e8c;color:#8f2a22}[data-theme^=light] .hp-action-bar__btn--play.hp-action-bar__btn--enabled{color:#2e8b57;background:#64c88233;border:1px solid rgba(100,200,130,.42)}[data-theme^=light] .hp-action-bar__btn--save.hp-action-bar__btn--enabled{color:#6d45a8;background:#a078c82e;border:1px solid rgba(160,120,200,.45)}[data-theme^=light] .hp-toast--success{color:#1f7a4a}[data-theme^=light] .hp-toast--error{color:#b0382e}[data-theme^=light] .hp-alert__btn--cancel{color:var(--text-dim)}[data-theme^=light] .hp-alert--danger .hp-alert__title{color:#b0382e}html{-webkit-user-select:none;user-select:none}.hp-chord-badge{align-items:center}.hp-chord-badge__root{font-size:14px}.hp-cat-dot{width:3px;height:16px;border-radius:2px}.hp-chord-type-name{padding-left:8px}.hp-chord-note-chip{letter-spacing:.2px;line-height:1.7}.hp-btn-filter,.hp-btn-strum,.hp-btn-play,.hp-btn-save-chord,.hp-search-input{height:34px;box-sizing:border-box}.hp-chord-list{padding-bottom:80px}#guideLine1{width:2px;background-color:#fff;height:100vh;position:fixed;left:50%;transform:translate(-50%);z-index:99999}#tests{position:fixed;z-index:9999;top:100px;right:50px}:root{--hp-tabbar-h: 55px;--hp-topbar-h: 50px;--hp-topbar-b: 30px;--hp-tabbar-padding: 15px}body{padding-bottom:calc(var(--hp-tabbar-h) + env(safe-area-inset-bottom,0px) + 220px)}@media(min-width:1024px){body{padding-bottom:240px}}.hp-splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:radial-gradient(ellipse at center,var(--panel-bg) 0%,rgba(8,6,3,.98) 70%,rgba(0,0,0,1) 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;padding:24px 20px;opacity:1;transition:opacity .6s ease-out;pointer-events:auto;touch-action:none}.hp-splash--fading{opacity:0;pointer-events:none}.hp-splash__header{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.hp-splash__logo{width:72px;height:72px;filter:drop-shadow(0 4px 12px rgba(201,168,76,.25))}.hp-splash__title{font-family:var(--font, inherit);font-size:34px;font-weight:300;letter-spacing:.04em;color:#e7d6a8;margin:0;line-height:1}.hp-splash__handpan-wrap{width:100%;max-width:min(350px,70vw);filter:drop-shadow(0 12px 32px rgba(0,0,0,.45))}.hp-splash__tagline{font-size:16px;color:#e7d6a8a6;letter-spacing:.02em;text-align:center}.hp-splash__verb{display:inline-block;color:var(--gold);font-weight:500;animation:hp-splash-verb-in .36s ease-out}@keyframes hp-splash-verb-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(min-width:768px){.hp-splash{gap:28px}.hp-splash__logo{width:88px;height:88px}.hp-splash__title{font-size:42px}.hp-splash__tagline{font-size:18px}}body.hp-grid-shell{background:var(--bg-header)}body.hp-grid-shell:is(:has(.hp-filter-modal-backdrop),:has(.hp-builder-backdrop),:has(.hp-alert-backdrop),:has(.hp-melody-backdrop)){background:var(--scrim)}body.hp-grid-shell:is(:has(.hp-filter-modal-backdrop),:has(.hp-builder-backdrop),:has(.hp-alert-backdrop),:has(.hp-melody-backdrop)) .hp-safe-top{background:var(--scrim)}.hp-safe-top{position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top,0px);background:var(--bg-header);z-index:3000;pointer-events:none}.hp-topbar{justify-content:center;position:sticky;top:0;z-index:50;min-height:var(--hp-topbar-h);background:var(--bg-header);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(var(--accent-rgb),.12);display:flex;align-items:center;padding:env(safe-area-inset-top,0px) 14px 0;gap:10px}.hp-topbar-wrapper{justify-content:space-between;display:flex;width:100%;max-width:1000px;padding:0 20px}.hp-topbar__brand{min-width:200px;display:flex;flex-direction:row;justify-content:start;gap:0;line-height:1;align-items:baseline;padding-top:2px}.hp-topbar__title{margin:0;font-size:18px;font-weight:700;letter-spacing:-.5px;color:var(--gold-bright);font-family:var(--font);text-shadow:0 0 18px rgba(var(--accent-rgb),.25)}.hp-topbar__tagline{font-family:var(--font);margin-top:1px;font-size:9px;letter-spacing:.1em;color:var(--gold-soft);display:inline-flex;gap:4px;align-items:baseline;margin-left:8px}.hp-topbar__verb{width:fit-content;display:inline-block;color:var(--gold-fab);font-weight:700;animation:hp-verb-fade .42s ease}@keyframes hp-verb-fade{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.hp-topbar__scale{font-family:var(--font);font-size:11px;padding:4px 10px;border-radius:999px;background:rgba(var(--accent-rgb),.1);color:var(--gold-fab);font-weight:600;letter-spacing:.04em;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis;display:flex;justify-content:center;align-items:center;cursor:pointer}.hp-topbar__nav{display:none}.hp-topbar__spacer{flex:1}.hp-topbar__avatar{display:none;width:32px;height:32px;border:1.5px solid rgba(var(--accent-rgb),.45);border-radius:50%;background:linear-gradient(135deg,var(--gold-faint),#3a2e16);color:var(--gold-bright);font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;align-items:center;justify-content:center}.hp-screen{display:none}.hp-screen[data-active]{display:block}.hp-screen--profile{display:block;position:absolute;inset:var(--hp-topbar-h) 0 0 0;background:#0d0903f5;z-index:500;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translate(100vw);opacity:0;pointer-events:none;transition:transform .6s cubic-bezier(.32,.72,0,1),opacity .5s ease}.hp-screen--profile[data-active]{transform:translate(0);opacity:1;pointer-events:auto}.hp-tabbar{max-width:100vw;width:100%;position:fixed;left:0;right:0;bottom:0;z-index:600;isolation:isolate;will-change:transform;height:var(--hp-tabbar-h);background:var(--bg-header);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);border:1px solid rgba(var(--accent-rgb),.18);justify-content:space-around;display:flex;padding:0;padding-bottom:var(--hp-tabbar-padding);border:none;border-top:.6px solid rgba(var(--accent-rgb),.36)}.hp-tabbar__btn span{display:none}.hp-tabbar__btn{background:none;border:none;color:#858484;cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.04em;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;position:relative;transition:color .15s}.hp-tabbar__btn[aria-current]{color:#fff}.hp-tabbar__btn[aria-current]:before{content:"";position:absolute;top:4px;left:50%;transform:translate(-50%);width:calc(var(--hp-tabbar-h) - 9px);height:calc(var(--hp-tabbar-h) - 9px);background:#00000029;border-radius:50px;border:none;border-left:1px solid rgba(var(--accent-rgb),.36);border-right:1px solid rgba(var(--accent-rgb),.36)}.hp-tabbar__btn svg{width:22px;height:22px}.hp-profile{max-width:480px;margin:0 auto;padding:0 18px 80px;font-family:var(--font)}.hp-profile__header{display:flex;flex-direction:column;gap:12px;padding:14px 0 26px;justify-content:center;align-items:center}.hp-profile__avatar{width:88px;height:88px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--text-dim),#2c2410 70%);border:2px solid rgba(var(--accent-rgb),.55);color:var(--gold-bright);font-family:var(--font);font-size:30px;font-weight:700;letter-spacing:.5px;display:grid;place-items:center;box-shadow:0 6px 22px #00000073,inset 0 1px rgba(var(--overlay-rgb),.08);-webkit-user-select:none;user-select:none;pointer-events:none}.hp-profile__name{color:var(--gold-bright);font-family:var(--font);font-weight:600;font-size:18px;letter-spacing:.3px;text-shadow:0 0 18px rgba(var(--accent-rgb),.25)}.hp-profile__list{display:flex;flex-direction:column;gap:8px;justify-content:center;align-items:center}.hp-profile__item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--accent-rgb),.14);border-radius:10px;font-family:var(--font);font-size:13px;font-weight:500;color:var(--gold-pale);cursor:pointer;text-align:left;transition:background .15s,border-color .15s;width:280px;max-width:280px}.hp-profile__item:hover{background:rgba(var(--accent-rgb),.07);border-color:rgba(var(--accent-rgb),.3)}.hp-profile__item-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0}.hp-profile__item-icon svg{width:20px;height:20px}.hp-profile__item-label{flex:1}.hp-profile__item-chevron{color:var(--gold-soft);font-size:16px;font-weight:400;flex-shrink:0}.hp-auth-panel{display:flex;flex-direction:column;align-items:center;gap:18px;padding:8px 4px;font-family:var(--font);color:var(--gold-pale)}.hp-auth-panel__hint{text-align:center;font-size:13px;line-height:1.5;color:var(--gold-soft);margin:0;max-width:280px}.hp-auth-panel__google{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:#fff;color:#3c4043;border:1px solid rgba(0,0,0,.12);border-radius:8px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s}.hp-auth-panel__google:hover{background:#f7f8f9;box-shadow:0 2px 8px #0000002e}.hp-auth-panel__user{display:flex;align-items:center;gap:12px}.hp-auth-panel__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:1px solid rgba(var(--accent-rgb),.4)}.hp-auth-panel__meta{display:flex;flex-direction:column;gap:2px}.hp-auth-panel__name{color:var(--gold-bright);font-weight:600;font-size:14px}.hp-auth-panel__email{color:var(--gold-soft);font-size:12px}.hp-auth-panel__signout{padding:8px 18px;background:transparent;color:var(--gold);border:1px solid rgba(var(--accent-rgb),.4);border-radius:8px;font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.hp-auth-panel__signout:hover{background:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.6)}.hp-admin-users{display:flex;flex-direction:column;gap:6px}.hp-admin-user{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:rgba(var(--overlay-rgb),.03);border:1px solid rgba(var(--accent-rgb),.14);border-radius:10px;font-family:var(--font);color:var(--gold-pale);cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.hp-admin-user:hover{background:rgba(var(--accent-rgb),.07);border-color:rgba(var(--accent-rgb),.3)}.hp-admin-user__avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;border:1px solid rgba(var(--accent-rgb),.4);flex-shrink:0}.hp-admin-user__meta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.hp-admin-user__name{color:var(--gold-bright);font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-admin-user__sub{color:var(--gold-soft);font-size:11px}.hp-screen-placeholder{text-align:center;padding:60px 30px}.hp-screen-placeholder h2{font-size:18px;color:var(--gold-bright);margin:0 0 8px}.hp-screen-placeholder p{font-size:12px;line-height:1.6;max-width:320px;margin:0 auto;color:var(--gold-soft)}@media(min-width:600px){body{padding-bottom:20px}.hp-tabbar{display:none}.hp-topbar__nav{display:flex;align-items:center;gap:4px;margin-left:14px;padding:0 10px;height:calc(var(--hp-topbar-h) - 10px);border-radius:999px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.hp-topbar__nav-btn{background:none;border:none;color:#b4b3b3;cursor:pointer;font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.04em;display:flex;align-items:center;gap:6px;padding:12px;border-radius:999px;transition:color .15s,background .15s}.hp-topbar__nav-btn:hover{color:var(--gold-bright)}.hp-topbar__nav-btn[aria-current]{color:#fff;background:#000000c7;border-left:1px solid rgba(var(--accent-rgb),.36);border-right:1px solid rgba(var(--accent-rgb),.36)}.hp-topbar__nav-btn svg{width:16px;height:16px}}@media(max-height:520px){.hp-tabbar{display:none}body{padding-bottom:0}}.hp-topbar__logoMark{flex-shrink:0;filter:drop-shadow(0 0 6px rgba(201,168,76,.35))}.hp-pan-strip__top-row{position:absolute;top:6px;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:12}.hp-pan-strip__top-row .hp-chord-badge-center{pointer-events:auto}body[data-tab=chords] .hp-pan-strip__top-row,body[data-tab=melodies] .hp-pan-strip__top-row,body[data-tab=studio] .hp-pan-strip__top-row,body[data-tab=profile] .hp-pan-strip__top-row{display:none}:root{--hp-anim-time: .35s}.hp-progression-row,.hp-chord-list,.hp-filter-bar{transition:transform .32s cubic-bezier(.32,.72,0,1),opacity .25s ease;border-radius:0}body[data-tab=chords] .hp-progression-row{transform:translate(calc(-100vw - 20px));opacity:0;pointer-events:none}body[data-tab=play] .hp-chord-list,body[data-tab=play] .hp-filter-bar{display:block;transform:translate(calc(100vw + 20px));opacity:0;pointer-events:none}body[data-tab=melodies] .hp-chord-list,body[data-tab=studio] .hp-chord-list,body[data-tab=profile] .hp-chord-list{display:block;transform:translate(calc(-100vw - 20px));opacity:0;pointer-events:none}body[data-tab=melodies] .hp-filter-bar,body[data-tab=studio] .hp-filter-bar,body[data-tab=profile] .hp-filter-bar{display:none}body[data-tab=studio] .hp-progression-row{transform:translate(calc(-100vw - 20px));opacity:0;pointer-events:none}.hp-studio-dock{transition:transform .32s cubic-bezier(.32,.72,0,1),opacity .25s ease;border-radius:14px;padding:8px 10px 12px}body[data-tab=play] .hp-studio-dock,body[data-tab=chords] .hp-studio-dock,body[data-tab=melodies] .hp-studio-dock{transform:translate(calc(100vw + 20px));opacity:0;pointer-events:none}body[data-tab=profile] .hp-studio-dock{transform:translate(calc(-100vw - 20px));opacity:0;pointer-events:none}.hp-studio-dock .hp-builder-panel--inline{position:static;top:auto;background:transparent;border:none;box-shadow:none;padding:0;width:100%;max-width:none;height:100%;overflow:hidden;display:flex;flex-direction:column}.hp-studio-dock .hp-builder-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.hp-studio-tabs{z-index:9;background:var(--bg-base);display:flex;gap:0px;justify-content:center;padding:4px 0 8px;flex-shrink:0}.hp-studio-tab{background:transparent;border:none;border-left:1px solid rgba(var(--accent-rgb),.18);color:var(--gold-soft);font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 16px;border-radius:0;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.hp-studio-tab:hover{color:var(--gold-fab);border-color:rgba(var(--accent-rgb),.35)}.hp-studio-tab--active{border-left:1px solid;border-right:1px solid;color:var(--gold-bright);background:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.45)}.hp-studio-settings-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:28px;padding:0;background:transparent;border:none;border-radius:999px;color:var(--gold-soft);cursor:pointer;transition:color .15s,border-color .15s,background .15s;align-self:center}.hp-studio-settings-btn:hover{color:var(--gold-fab);border-color:rgba(var(--accent-rgb),.35)}.hp-studio-settings-btn svg{width:16px;height:16px}.hp-studio-dock .hp-select-diagrams-row,.hp-studio-dock .hp-preset-hint{display:none}.hp-builder-canvas-slot .hp-canvas-area{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.hp-builder-canvas-slot .hp-canvas-row{display:flex;gap:12px;justify-content:center}.hp-builder-canvas-slot .hp-canvas-hint{font-size:9.5px;color:var(--gold-faint);letter-spacing:.5px;text-align:center}.hp-chord-list{overflow-y:auto;-webkit-overflow-scrolling:touch;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:14px;padding:8px 10px 12px}body{padding-bottom:0;overflow:hidden}body[data-tab=play] .hp-footer,body[data-tab=chords] .hp-footer,body[data-tab=studio] .hp-footer{display:none}.hp-screen{flex:1;max-width:1000px}.hp-screen-wrapper{display:flex;justify-content:center;background:var(--bg-base)}.hp-plan__cards{display:flex;flex-direction:column;gap:12px}.hp-plan-card{padding:16px;border:1px solid rgba(var(--accent-rgb),.16);border-radius:14px;background:rgba(var(--overlay-rgb),.03)}.hp-plan-card--current{border-color:rgba(var(--accent-rgb),.55);background:rgba(var(--accent-rgb),.06)}.hp-plan-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.hp-plan-card__name{color:var(--gold-bright);font-weight:700;font-size:16px}.hp-plan-card__badge{font-size:11px;font-weight:600;color:var(--bg-base);background:var(--gold);border-radius:999px;padding:2px 9px}.hp-plan-card__price{display:flex;align-items:baseline;gap:5px;margin-top:6px}.hp-plan-card__amount{color:var(--gold-bright);font-weight:700;font-size:22px}.hp-plan-card__period{color:var(--gold-soft);font-size:12px}.hp-plan-card__tagline{color:var(--gold-soft);font-size:12px;margin-top:2px}.hp-plan-card__features{list-style:none;margin:12px 0;padding:0;display:flex;flex-direction:column;gap:7px}.hp-plan-card__features li{display:flex;align-items:center;gap:8px;color:var(--gold);font-size:13px}.hp-plan-card__check{color:var(--gold);flex:0 0 auto;display:inline-flex}.hp-plan-card__btn{width:100%;padding:10px 16px;border-radius:9px;font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}.hp-plan-card__btn--upgrade{background:var(--gold);color:var(--bg-base);border:1px solid var(--gold)}.hp-plan-card__btn--upgrade:hover{background:var(--gold-bright);border-color:var(--gold-bright)}.hp-plan-card__btn--ghost{background:transparent;color:var(--gold);border:1px solid rgba(var(--accent-rgb),.4)}.hp-plan-card__btn--ghost:hover:not(:disabled){background:rgba(var(--accent-rgb),.08)}.hp-plan-card__btn:disabled{opacity:.5;cursor:default}.hp-plan__toggle{display:flex;justify-content:center;margin:0 0 14px}.hp-plan-card__save{color:var(--gold);font-size:11px;font-weight:600;margin-top:3px}.hp-legal{color:var(--gold);font-size:13.5px;line-height:1.62}.hp-legal__updated{color:var(--gold-soft);font-size:12px;margin:0 0 14px}.hp-legal h4{color:var(--gold-bright);font-size:14px;font-weight:700;margin:18px 0 6px}.hp-legal p{margin:0 0 10px}.hp-legal ul{margin:0 0 10px;padding-left:18px}.hp-legal li{margin:0 0 6px}.hp-legal a{color:var(--gold-bright);text-decoration:underline}.hp-session-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid rgba(var(--accent-rgb),.16);border-radius:12px;background:rgba(var(--overlay-rgb),.03)}.hp-session-card--current{border-color:rgba(var(--accent-rgb),.4)}.hp-session-card__title{color:var(--gold-bright);font-weight:600;font-size:14px}.hp-session-card__sub{color:var(--gold-soft);font-size:12px;margin-top:2px}.hp-session-card__badge{font-size:11px;font-weight:600;color:var(--gold);border:1px solid rgba(var(--accent-rgb),.4);border-radius:999px;padding:2px 9px}.hp-admin-input{width:100%;padding:8px 10px;background:rgba(var(--overlay-rgb),.04);color:var(--gold-bright);border:1px solid rgba(var(--accent-rgb),.22);border-radius:8px;font-family:var(--font);font-size:13px}.hp-admin-input:focus{outline:none;border-color:rgba(var(--accent-rgb),.55)}.hp-field{display:flex;flex-direction:column;gap:4px}.hp-field__label{color:var(--gold-soft);font-size:11px;font-weight:600}.hp-coupon-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.hp-coupon-form__err{color:#e0816b;font-size:12px;margin-bottom:8px}.hp-coupons__list{display:flex;flex-direction:column;gap:6px;margin-top:16px}.hp-coupon-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid rgba(var(--accent-rgb),.14);border-radius:10px;background:rgba(var(--overlay-rgb),.03)}.hp-coupon-row__code{color:var(--gold-bright);font-weight:700;font-size:14px;letter-spacing:.5px}.hp-coupon-row__meta{display:block;color:var(--gold-soft);font-size:11.5px;margin-top:2px}.hp-coupon-row__del{flex:0 0 auto;width:28px;height:28px;border-radius:7px;background:transparent;color:var(--gold-soft);border:1px solid rgba(var(--accent-rgb),.25);cursor:pointer}.hp-coupon-row__del:hover{color:#e0816b;border-color:#e0816b80}.hp-lock{position:relative}.hp-lock__behind{border-radius:14px;overflow:hidden;filter:blur(1.1px) saturate(.9);opacity:.72;pointer-events:none;-webkit-user-select:none;user-select:none}.hp-lock__scrim{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;background:rgba(var(--bg-base-rgb, 20,16,8),.16);pointer-events:none}.hp-lock__stickywrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:flex-start;pointer-events:none}.hp-lock__panel{position:sticky;top:14px;margin:14px;pointer-events:auto;display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;padding:16px 22px 18px;border-radius:14px;background:rgba(var(--bg-base-rgb),.9);border:1px solid rgba(var(--accent-rgb),.22);box-shadow:0 8px 24px #00000047}.hp-lock__icon{display:inline-flex;color:var(--gold-bright);margin-bottom:2px}.hp-lock__title{color:var(--gold-bright);font-weight:700;font-size:16px}.hp-lock__sub{color:var(--gold-soft);font-size:12.5px}.hp-lock__btn{margin-top:8px;padding:10px 20px;border-radius:9px;background:var(--gold);color:var(--bg-base);border:1px solid var(--gold);font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}.hp-lock__btn:hover{background:var(--gold-bright);border-color:var(--gold-bright)}.hp-plan-card__amount--gift{font-size:15px;color:var(--gold-bright)}body.hp-grid-shell{height:100dvh;min-height:100dvh;margin:0 auto;display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:100%;overflow:hidden;padding-bottom:0}body.hp-grid-shell>#root{display:contents}body.hp-grid-shell .hp-topbar{position:relative;top:auto;grid-row:1;grid-column:1}body.hp-grid-shell .hp-tabbar{position:relative;left:auto;right:auto;bottom:auto;grid-row:3;grid-column:1;padding-bottom:env(safe-area-inset-bottom,0px);height:calc(var(--hp-tabbar-h))}body.hp-grid-shell .hp-screen{display:none}body.hp-grid-shell .hp-screen[data-active]{display:flex;flex-direction:column;grid-row:2;grid-column:1;min-height:0;min-width:0;position:relative;overflow:hidden}body.hp-grid-shell[data-tab=play]{--dock-h: clamp(180px, 32vh, 280px);--pan-max: 350px}body.hp-grid-shell[data-tab=chords],body.hp-grid-shell[data-tab=studio]{--dock-h: clamp(280px, 50vh, 520px);--pan-max: 350px}body.hp-grid-shell[data-tab=melodies],body.hp-grid-shell[data-tab=profile]{--dock-h: calc(100dvh - var(--hp-topbar-h, 50px) - var(--hp-tabbar-h, 55px) - 100px);--pan-max: 100px}body.hp-grid-shell .hp-screen--profile{display:block;grid-row:2;grid-column:1;position:absolute;top:0;right:0;bottom:0;left:0;z-index:500}body.hp-grid-shell .hp-pan-strip{flex:1 1 0;min-height:0;min-width:0;position:relative!important;top:auto!important;bottom:auto!important;left:auto!important;right:auto!important;display:flex;align-items:center;justify-content:center;padding:6px;margin:0!important;overflow:visible;will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-transition:-webkit-transform .45s cubic-bezier(.32,.72,0,1),transform .45s cubic-bezier(.32,.72,0,1),filter .45s ease;transition:transform .45s cubic-bezier(.32,.72,0,1),filter .45s ease}body.hp-grid-shell[data-tab=studio][data-studio-sub-tab=build] .hp-pan-strip{filter:none}body.hp-grid-shell[data-studio-sub-tab=build] .hp-studio-dock .hp-builder-tab-left{display:none!important}body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-circle--all-anim,body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-circle--all-anim-in{transition:none!important}body.hp-grid-shell .hp-studio-settings-panel{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:12px}body.hp-grid-shell .hp-studio-settings-panel .hp-settings-row{display:grid;grid-template-columns:1fr auto;grid-template-areas:"label control" "hint  hint";align-items:center;column-gap:12px;row-gap:4px;padding:12px 4px}body.hp-grid-shell .hp-studio-settings-panel .hp-settings-row__text{display:contents}body.hp-grid-shell .hp-studio-settings-panel .hp-settings-row__label{grid-area:label;min-width:0}body.hp-grid-shell .hp-studio-settings-panel .hp-settings-row__hint{grid-area:hint;margin-top:4px}body.hp-grid-shell .hp-studio-settings-panel .hp-settings-row__control{grid-area:control;justify-self:end}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-sectioned{display:flex;flex-direction:column;gap:0;padding:0;flex:1 1 auto;height:100%;width:100%;min-height:0;min-width:0;overflow:hidden;box-sizing:border-box;justify-content:flex-start}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav{flex:0 0 auto;display:flex;gap:4px;width:100%;padding:4px;background:rgba(var(--accent-rgb),.06);border:1px solid rgba(var(--accent-rgb),.14);border-radius:12px;box-sizing:border-box}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:3px 4px;background:transparent;border:1px solid transparent;border-radius:9px;color:var(--gold-soft);font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:color .15s ease,background .15s ease,border-color .15s ease}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn:hover{color:#86744d}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn--active{color:#1c1408;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:rgba(var(--accent-rgb),.55);box-shadow:0 1px 6px #00000059,inset 0 1px rgba(var(--overlay-rgb),.35)}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn__icon{display:block;width:22px;height:22px}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn__icon svg{width:100%;height:100%;display:block}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-nav-btn__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section-summary{flex:0 0 auto;padding:8px 4px 6px;font-size:11px;font-weight:400;letter-spacing:.02em;color:var(--gold-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:1px solid rgba(var(--accent-rgb),.12)}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section{display:none}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section--active{flex:1 1 auto;display:block;min-height:0;max-height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;width:100%}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-general-row{align-items:center}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-general-row__field{flex:1 1 110px;min-width:0}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-general-row__reset{flex:0 0 auto;align-self:center}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-tuning-transpose{display:flex;align-items:center;gap:8px;margin-top:10px}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-tuning-transpose .hp-btn-transpose{flex:0 0 auto}body.hp-grid-shell[data-studio-sub-tab=build] .hp-note-tweaks{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid rgba(var(--accent-rgb),.1)}body.hp-grid-shell[data-studio-sub-tab=build] .hp-note-tweaks__row{display:flex;align-items:center;gap:8px;width:100%}body.hp-grid-shell[data-studio-sub-tab=build] .hp-note-tweaks__label{flex:0 0 74px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-soft)}body.hp-grid-shell[data-studio-sub-tab=build] .hp-note-tweaks__row>:nth-child(2){flex:1 1 auto;min-width:0}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section *{max-width:100%;box-sizing:border-box}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section .hp-build-type-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section .hp-rings-editor__slots-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section .hp-note-editor__row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section .hp-save-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-section .hp-a4-row{flex-wrap:wrap}body.hp-grid-shell[data-tab=melodies] .hp-pan-strip .hp-svg-text,body.hp-grid-shell[data-tab=profile] .hp-pan-strip .hp-svg-text{display:none}body.hp-grid-shell[data-studio-sub-tab=build] .hp-builder-body{display:flex;flex-direction:column;min-height:0;overflow:hidden}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body{display:flex;flex-direction:column;flex:1 1 auto;gap:12px;min-width:0;min-height:0;align-items:stretch;padding:0}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body>*{width:100%;min-width:0}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-build-type-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-select-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-build-reset-btn-wrap,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-a4-row,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-save-section{display:flex;align-items:center;gap:8px;width:100%}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-dropdown,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-dropdown__trigger,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-pan-name-input{flex:1 1 auto;width:100%;min-width:0}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-btn-save-apply,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-btn-save-as-new,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-btn-use-preset{flex:1 1 auto;max-width:none;width:100%}body.hp-grid-shell .hp-profile__item{width:100%;display:flex;align-items:center}body.hp-grid-shell .hp-profile__item-label{flex:1 1 auto;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.hp-grid-shell .hp-profile__item-icon{flex:0 0 auto}body.hp-grid-shell .hp-profile__item-chevron{flex:0 0 auto;margin-left:auto}body.hp-grid-shell .hp-profile{max-width:460px;margin:0 auto;padding:32px 18px 80px}body.hp-grid-shell .hp-profile__header{gap:10px;padding:8px 0 24px}body.hp-grid-shell .hp-profile__avatar{width:56px;height:56px;background:transparent;border:1px solid rgba(var(--accent-rgb),.45);box-shadow:none;color:var(--gold-bright);font-size:22px;font-weight:500;letter-spacing:0}body.hp-grid-shell .hp-profile__name{font-size:15px;font-weight:500;text-shadow:none;color:var(--gold-pale)}body.hp-grid-shell .hp-profile__list{gap:4px}body.hp-grid-shell .hp-profile__item{background:rgba(var(--overlay-rgb),.02);border:1px solid rgba(var(--accent-rgb),.1);border-radius:8px;padding:12px 14px;gap:12px;color:var(--gold-pale);font-weight:500;font-size:13px;transition:background .15s ease,border-color .15s ease,color .15s ease}body.hp-grid-shell .hp-profile__item:hover{background:rgba(var(--accent-rgb),.06);border-color:rgba(var(--accent-rgb),.28);color:var(--gold-bright)}body.hp-grid-shell .hp-profile__item-icon{width:18px;height:18px;color:#b89c5b}body.hp-grid-shell .hp-profile__item-icon svg{width:18px;height:18px}body.hp-grid-shell .hp-profile__item-chevron{color:var(--gold-faint);font-size:18px;font-weight:300}body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-select-source-label,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-build-type-label,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-rings-editor__title,body.hp-grid-shell[data-studio-sub-tab=build] .hp-build-body .hp-note-editor__sub-label{color:var(--gold-soft)!important;font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-builder-note,body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-builder-note--dragging{pointer-events:auto;cursor:grab}body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-builder-note--dragging{cursor:grabbing}body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-note-group,body.hp-grid-shell[data-studio-sub-tab=build] .hp-pan-strip .hp-svg-note-group *{pointer-events:none}body.hp-grid-shell .hp-pan-strip .hp-diagrams-row{display:flex;gap:12px;flex:0 1 auto;align-items:center;justify-content:center;min-height:0;min-width:0}body.hp-grid-shell .hp-pan-strip .hp-diagram-col{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1 / 1;max-width:min(100%,var(--pan-max, 350px));max-height:min(100%,var(--pan-max, 350px));min-height:0;min-width:0;flex:1 1 auto;position:relative;overflow:visible;transition:max-width .48s cubic-bezier(.32,.72,0,1) .38s,max-height .48s cubic-bezier(.32,.72,0,1) .38s}body.hp-grid-shell .hp-pan-strip .hp-diagram-svg{width:100%;height:auto;max-width:var(--pan-max, 350px)!important;display:block;transition:max-width .48s cubic-bezier(.32,.72,0,1) .38s}body.hp-grid-shell .hp-dock{font-family:var(--font);flex:0 0 auto;height:var(--dock-h, 280px);position:relative;min-height:270px;min-width:0;overflow:hidden;transition:height .75s cubic-bezier(.32,.72,0,1) .15s;will-change:height;contain:layout size}body.hp-grid-shell .hp-progression-row,body.hp-grid-shell .hp-chord-list,body.hp-grid-shell .hp-studio-dock,body.hp-grid-shell .hp-filter-bar{transition:transform .45s cubic-bezier(.32,.72,0,1),opacity .35s ease}body.hp-grid-shell .hp-progression-row,body.hp-grid-shell .hp-chord-list,body.hp-grid-shell .hp-studio-dock,body.hp-grid-shell .hp-melodies-dock,body.hp-grid-shell .hp-profile-dock{position:absolute;left:8px;right:8px;bottom:0;top:0;max-width:1000px;margin:0;z-index:10}body.hp-grid-shell .hp-progression-row{top:auto;height:auto}body.hp-grid-shell .hp-melodies-dock,body.hp-grid-shell .hp-profile-dock{overflow-y:auto;-webkit-overflow-scrolling:touch;transition:transform .45s cubic-bezier(.32,.72,0,1),opacity .35s ease}body.hp-grid-shell .hp-melodies-dock[data-tab-hidden],body.hp-grid-shell .hp-profile-dock[data-tab-hidden]{transform:translate(calc(100vw + 20px));opacity:0;pointer-events:none}body.hp-grid-shell[data-tab=chords] .hp-melodies-dock,body.hp-grid-shell[data-tab=play] .hp-melodies-dock,body.hp-grid-shell[data-tab=studio] .hp-melodies-dock,body.hp-grid-shell[data-tab=profile] .hp-melodies-dock{transform:translate(calc(-100vw - 20px))}body.hp-grid-shell[data-tab=melodies] .hp-profile-dock,body.hp-grid-shell[data-tab=chords] .hp-profile-dock,body.hp-grid-shell[data-tab=play] .hp-profile-dock,body.hp-grid-shell[data-tab=studio] .hp-profile-dock{transform:translate(calc(100vw + 20px))}body.hp-grid-shell .hp-melody-inline{width:100%;height:100%;display:flex;flex-direction:column;min-height:0}body.hp-grid-shell .hp-profile--inline{padding:18px 14px 32px;font-family:var(--font)}body.hp-grid-shell .hp-profile--inline .hp-profile__header{padding:0 4px 18px;align-items:flex-start}body.hp-grid-shell .hp-profile--inline .hp-profile__name{font-size:16px}body.hp-grid-shell .hp-profile--inline .hp-profile__list{gap:0;border-top:1px solid rgba(var(--accent-rgb),.1)}body.hp-grid-shell .hp-profile--inline .hp-profile__item{background:transparent!important;border:none!important;border-bottom:1px solid rgba(var(--accent-rgb),.1)!important;border-radius:0!important;padding:14px 4px!important}body.hp-grid-shell .hp-profile--inline .hp-profile__item:hover{background:transparent!important;border-bottom-color:rgba(var(--accent-rgb),.28)!important;color:var(--gold-bright)!important}body.hp-grid-shell:not([data-tab=chords]) .hp-filter-bar.hp-filter-fab{display:none}body.hp-grid-shell .hp-filter-bar.hp-filter-fab{position:absolute;top:8px;right:16px;left:auto;bottom:auto;z-index:12;width:44px;height:44px;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--fab-bg-strong);border:1px solid rgba(var(--accent-rgb),.32);color:var(--gold-fab);cursor:pointer;box-shadow:0 6px 18px #00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform .15s ease,background .15s,border-color .15s,opacity .22s}body.hp-grid-shell .hp-filter-bar.hp-filter-fab:hover{background:#1c160cf5;border-color:rgba(var(--accent-rgb),.55)}body.hp-grid-shell .hp-filter-bar.hp-filter-fab:active{transform:scale(.94)}body.hp-grid-shell .hp-filter-bar.hp-filter-fab--active{color:var(--gold-bright);border-color:rgba(var(--accent-rgb),.7);background:#2d200ef0}.hp-search-input--modal{display:block;width:100%;height:36px;margin:0 0 14px;padding:0 12px;background:rgba(var(--overlay-rgb),.05);border:1px solid rgba(var(--overlay-rgb),.1);border-radius:8px;color:var(--gold-pale);font-family:var(--font);font-size:13px;outline:none}.hp-search-input--modal::placeholder{color:var(--gold-faint)}.hp-search-input--modal:focus{border-color:rgba(var(--accent-rgb),.45)}body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab{position:absolute;bottom:-6px;z-index:11;display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:999px;background:var(--fab-bg);border:none;color:var(--hp-fab, var(--gold-fab));font-family:var(--font);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 0 14px -5px #00000059;transition:background .15s ease,border-color .15s ease,color .15s ease,opacity .25s ease,transform .12s ease;-webkit-user-select:none;user-select:none}body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab--left{left:-6px}body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab--right{right:-6px}body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab--above{bottom:32px;padding:0 10px}body.hp-grid-shell .hp-pan-strip .hp-auto-button svg{width:18px;height:18px}body.hp-grid-shell .hp-pan-strip .hp-pan-fab--gesturing{background:#281c0cf2;color:var(--hp-fab-strong, var(--gold-bright))}body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab--lit,body.hp-grid-shell .hp-pan-strip .hp-diagram-col .hp-pan-fab--lit:hover{background:var(--hp-fab, var(--gold-fab));color:var(--fab-bg-strong);border-color:transparent;transition:none}body.hp-grid-shell .hp-pan-strip .hp-pan-fab__bar{position:absolute;left:4px;right:4px;bottom:3px;height:2px;border-radius:1px;background:var(--hp-fab-bar, rgba(var(--accent-rgb), .18));overflow:hidden}body.hp-grid-shell .hp-pan-strip .hp-pan-fab__bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:calc(var(--intensity, 0) * 100%);background:var(--hp-fab-strong, var(--gold-bright));border-radius:1px}body.hp-grid-shell .hp-pan-strip .hp-pan-fab:hover{background:#1c160ceb;border-color:var(--hp-fab-bar, rgba(var(--accent-rgb), .55));color:var(--hp-fab-strong, var(--gold-bright))}body.hp-grid-shell .hp-pan-strip .hp-pan-fab:active{transform:scale(.94)}body.hp-grid-shell .hp-pan-strip .hp-pan-fab svg{width:12px;height:12px}body.hp-grid-shell .hp-pan-strip .hp-pan-fab__label{line-height:1}body.hp-grid-shell .hp-pan-strip .hp-pan-fab--disabled,.hp-pan-fab--disabled{filter:grayscale(1) brightness(.55);opacity:.45;cursor:not-allowed}body.hp-grid-shell .hp-pan-strip .hp-pan-fab--disabled:hover{background:inherit;border-color:inherit;color:inherit}body.hp-grid-shell .hp-filter-bar.hp-filter-fab .hp-filter-badge{position:absolute;top:-5px;right:-5px;width:10px;height:10px;padding:5px;border-radius:999px;background:var(--gold);color:var(--bg-inset);font-family:var(--font);font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}@media(orientation:landscape)and (min-width:750px),(min-width:1024px){body.hp-grid-shell[data-tab=melodies],body.hp-grid-shell[data-tab=profile]{--pan-max: 350px}body.hp-grid-shell .hp-screen[data-active]{flex-direction:row}body.hp-grid-shell .hp-pan-strip{flex:1 1 50%;min-width:0;align-items:center!important;justify-content:center!important}body.hp-grid-shell .hp-pan-strip .hp-diagrams-row{align-items:center!important;justify-content:center!important}body.hp-grid-shell .hp-dock{flex:1 1 50%;min-width:0;height:auto}body.hp-grid-shell .hp-progression-row,body.hp-grid-shell .hp-chord-list,body.hp-grid-shell .hp-studio-dock{top:50%!important;left:50%!important;right:auto!important;bottom:auto!important;transform:translate(-50%,-50%)!important;width:calc(100% - 24px);max-width:460px;max-height:calc(100% - 32px);margin:0!important;transition:opacity .22s ease}body.hp-grid-shell .hp-chord-list,body.hp-grid-shell .hp-studio-dock{height:calc(100% - 32px)}body.hp-grid-shell .hp-filter-bar.hp-filter-fab{top:8px!important;right:10px!important;left:auto!important;bottom:auto!important;transform:none!important;width:34px;height:34px;max-width:none}}
