:root{--font: "Outfit", "Space Grotesk", system-ui, sans-serif;--bg-base: #0a0906;--bg-surface: #181208;--bg-elevated: #1c1810;--bg-header: #1a1508;--gold: #c9a84c;--gold-light: #e8d4a0;--gold-mid: #d4c8a8;--gold-warm: #cda353;--gold-text: #ddc870;--text-primary: #d4c8a8;--text-dim: #6a5a30;--text-muted: #4a3a18;--text-faint: #3a2c10;--border-subtle: rgba(255,255,255,.07);--border-gold: rgba(205,163,83,.22);--border-gold-hi: rgba(205,163,83,.5);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--borders-radius: var(--radius-xs)}*{-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{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,#1a1508,#0e0c07);border-bottom:1px solid rgba(205,163,83,.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(205,163,83,.25)}.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{border:1px solid #853f00;display:flex;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(205,163,83,.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:#cda353b3;font-weight:600;letter-spacing:.5px}.hp-footer__icons{display:flex;gap:18px;justify-content:center;margin-bottom:14px}.hp-footer__icon-link{color:#cda35380;display:flex;align-items:center;transition:color .2s}.hp-footer__icon-link:hover{color:#cda353e6}.hp-footer__copy{font-size:10px;color:#cda35340;letter-spacing:.5px}.hp-pan-strip{position:sticky;top:0;z-index:99;background:#080704f7;border-bottom:1px solid rgba(205,163,83,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:10px 12px;user-select:none;-webkit-user-select:none}.hp-pan-strip__inner{max-width:880px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:5px}.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(205,163,83,.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:#ffffff0a;border:1px solid rgba(255,255,255,.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}.hp-chord-badge-center{flex:1;display:flex;justify-content:center;align-items:center}.hp-chord-badge{display:flex;align-items:center;gap:6px;height:100%;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)}.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(205,163,83,.3)}.hp-action-bar__btn{filter:drop-shadow(0px 0px 8px #e8c97a50);flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 6px;background:transparent;border:none;border-right:1px solid rgba(205,163,83,.22);color:var(--text-dim);font-size:10px;font-family:var(--font);font-weight:600;cursor:pointer;white-space:nowrap;letter-spacing:.3px;transition:background .12s,color .12s}.hp-action-bar__btn:last-child{border-right:none}.hp-action-bar__btn:hover:not(.hp-action-bar__btn--disabled){filter:drop-shadow(0px 0px 10px gold)}.hp-action-bar__icon{font-size:12px}.hp-action-bar__btn--strum-on{color:#c9a84c;background:#cda35314}.hp-action-bar__btn--strum-off{color:#80a0b0}.hp-action-bar__btn--play.hp-action-bar__btn--enabled{color:#80d090;background:#64c88208}.hp-action-bar__btn--save.hp-action-bar__btn--enabled{color:#c0a0e0;background:#a078c808}.hp-action-bar__btn--disabled{color:#3a3a30;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-diagrams-row{display:flex;gap:4px;justify-content:center;align-items:flex-start;width:100%;max-width:100%;overflow:hidden}.hp-diagram-col{flex:1 1 0;min-width:0;max-width:100%}.hp-diagram-side-label{font-size:7px;color:#5a4a28;text-align:center;letter-spacing:2px;text-transform:uppercase;margin-bottom:2px}.hp-diagram-svg{filter:brightness(2.1);display:block;max-width:300px;margin:0 auto;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.hp-progression-row{box-shadow:inset 0 0 10px #0a0a06,inset 0 0 40px #080605,inset 0 0 20px #080605,inset 0 0 120px #0d0011}.hp-info-row{width:100%;text-align:center;margin-bottom:0;display:flex;flex-direction:column;justify-content:center}.hp-active-notes-row{height:25px;display:flex;gap:4px;flex-wrap:nowrap;justify-content:flex-start;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}.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:#5a4a28;font-style:italic;font-family:var(--font)}.hp-active-notes-label{display:none;font-size:8px;color:#5a4a28;letter-spacing:3px;text-transform:uppercase;font-family:var(--font)}.hp-note-chip{background:var(--note-color);border:1px solid color-mix(in srgb,var(--note-color) 40%,transparent);color:color-mix(in srgb,var(--note-color) 30%,#000000);border-radius:var(--radius-xs);padding:3px 7px;font-size:10px;font-family:monospace;cursor:pointer}.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:#5a4a28;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;gap:2px;padding:8px 6px;border-radius:5px;cursor:pointer}.hp-note-chip__sub{color:var(--note-color);font-size:10px;font-family:monospace}.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:#ffffff0d;border:1px solid rgba(255,255,255,.09);color:#7a6a50}.hp-btn-filter--active{background:#0a0a06;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:#c9a84c;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:#cda35352;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:#cda3531f;border:1px solid rgba(205,163,83,.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:#cda35324;border:1px solid rgba(205,163,83,.4);color:var(--gold-text)}.hp-btn-strum--off{background:#ffffff0a;border:1px solid rgba(255,255,255,.09);color:#7a6a50}.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:#ffffff08;border:1px solid rgba(255,255,255,.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:#ffffff08;border:1px solid rgba(255,255,255,.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:#ffffff08;border:1px solid rgba(255,255,255,.07);color:#3a3a30;cursor:default}.hp-chord-list{padding:10px 0 72px}.hp-chord-grid{display:flex;flex-wrap:wrap}.hp-chord-empty{grid-column:1 / -1;text-align:center;padding:48px 20px;color:#3a2c0e;font-size:13px;font-style:italic;font-family:var(--font)}.hp-chord-empty--full{text-align:center;padding:48px 20px;color:#3a2c0e;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}.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{flex:auto;border-radius:var(--radius-md);padding:0;cursor:pointer;transition:all .15s;display:flex;align-items:stretch;overflow:hidden;margin:5px;width:280px;border:1px solid rgba(255,255,255,.07)}.hp-chord-card:hover{transform:scale(1.02);border:1px solid rgb(229 216 148 / 22%)}.hp-chord-card--default{background:#ffffff08;border:1px solid rgba(255,255,255,.07);opacity:1;transform:scale(1);box-shadow:none;width:280px}.hp-chord-card--selected{background:#cda3532b;border:1px solid rgba(205,163,83,.72);transform:scale(1.015);box-shadow:0 0 18px #cda35321;opacity:1}.hp-chord-card--selected:hover{border:1px solid rgba(205,163,83,.72)}.hp-chord-card--related{background:color-mix(in srgb,var(--accent) 9%,transparent);border:1px solid color-mix(in srgb,var(--accent) 53%,transparent);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 16%,transparent);transform:scale(1);opacity:1}.hp-chord-card--related:hover{border:1px solid color-mix(in srgb,var(--accent) 53%,transparent)}.hp-chord-card--dimmed{opacity:.35}.hp-chord-card__save{box-sizing:content-box;border:none;flex-shrink:0;width:30px;display:flex;align-items:center;justify-content:center;background:none;cursor:pointer;transition:background .15s,color .15s;border-right:1px solid;border-radius:var(--radius-md) 0 0 var(--radius-md)}.hp-chord-card__save--default{border-color:#ffffff0f;color:color-mix(in srgb,var(--accent) 30%,transparent)}.hp-chord-card__save--default:hover{background:color-mix(in srgb,#e05070 12%,transparent);color:#e05070;border-color:#e050704d}.hp-chord-card__save--selected{border-color:#cda3534d;color:color-mix(in srgb,var(--accent) 55%,transparent)}.hp-chord-card__save--selected:hover{background:color-mix(in srgb,#e05070 18%,transparent);color:#e05070}.hp-chord-card__content{flex:1;min-width:0;padding:8px;text-align:center}.hp-chord-card__top{display:flex;align-items:baseline;justify-content:center;gap:5px;margin-bottom:5px}.hp-chord-card__root{font-size:13px;font-family:var(--font);font-weight:700;letter-spacing:.3px}.hp-chord-card__root--selected{color:#ecd898}.hp-chord-card__root--default{color:var(--accent)}.hp-chord-card__name{font-size:10px;font-family:var(--font);font-weight:500}.hp-chord-card__name--selected{color:#b8a060}.hp-chord-card__name--default{color:#806850}.hp-chord-card__cycle{box-sizing:content-box;border:none;flex-shrink:0;width:36px;display:flex;align-items:center;justify-content:center;background:none;cursor:pointer;transition:background .15s,color .15s;border-left:1px solid;border-radius:0 var(--radius-md) var(--radius-md) 0}.hp-chord-card__cycle--default{border-color:#ffffff0f;color:color-mix(in srgb,var(--accent) 35%,transparent)}.hp-chord-card__cycle--default:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.hp-chord-card__cycle--selected{border-color:#cda3534d;color:color-mix(in srgb,var(--accent) 65%,transparent)}.hp-chord-card__cycle--selected:hover{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.hp-chord-card__notes{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.hp-chord-note-chip{background:color-mix(in srgb,var(--note-color) 8%,transparent);border:1px solid color-mix(in srgb,var(--note-color) 27%,transparent);color:var(--note-color);border-radius:3px;padding:0 4px;font-size:8.5px;font-family:monospace;line-height:1.6;letter-spacing:.2px}.hp-saved-strip{user-select:none;-webkit-user-select:none;padding-bottom:10px;border-bottom:1px solid #251d0d}.hp-saved-strip__row{justify-content:safe center;display:flex;gap:6px;flex-wrap:nowrap;align-items:center;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;padding:6px 0 10px}.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:#5a4a28;font-style:italic;font-family:var(--font)}.hp-saved-chip--match{box-shadow:0 0 0 2px #64c8828c,0 0 12px #64c88259;border-color:#64c8828c!important}.hp-saved-chip--playing{box-shadow:0 0 0 2px #cda353d9,0 0 16px #cda353a6;background:#cda35333!important;border-color:#cda353d9!important}.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:#cda3531a;border:1px solid rgba(205,163,83,.3);color:#d4a830;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:#cda3532e}.hp-note-chip--token{font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:0;cursor:pointer;padding:6px 8px;background:#a078c81f;color:#c0a0e0;border-radius:6px}.hp-note-chip--pause{background:#0305081f;border-color:#78a0c84d;color:#80a0b0}.hp-note-chip--slap{background:none;border-color:#3f39204d;color:#ffd236}.hp-saved-strip__label{display:none;font-size:8px;color:#5a4a28;letter-spacing:3px;text-transform:uppercase;flex-shrink:0}.hp-saved-chip{display:flex;gap:3px;align-items:center;color:#c0a0e0;border-radius:7px;padding:4px 9px;cursor:grab;font-size:13px;font-family:monospace;touch-action:pan-x pan-y;transition:transform .1s,opacity .1s}.hp-saved-chip--default{background:#a078c81f;border:1px solid rgba(160,120,200,.3);opacity:1;transform:none}.hp-saved-chip--dragging{background:#a078c859;border:1px solid rgba(160,120,200,.8);opacity:.45;transform:none}.hp-saved-chip--dragover{background:#a078c847;border:1px solid rgba(160,120,200,.6);opacity:1;transform:scale(1.06)}.hp-saved-chip__handle{font-size:14px;opacity:.55;margin-right:4px;margin-left:-4px;padding:4px 6px;cursor:grab;touch-action:none;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;line-height:1}.hp-saved-chip__handle:active{cursor:grabbing;opacity:1;background:#ffffff1a}.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-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:#ffffff0f;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-sm);padding:3px 9px;display:flex;align-items:center;gap:4px;flex-shrink:0}.hp-bpm-label{color:#a09070;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:#a09070;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:#ffffff0f;border:1px solid rgba(255,255,255,.14);color:#a09070;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:#a09070;color:#c9a84c}.hp-metronome-btn svg{opacity:.7}.hp-metronome-btn.active svg{opacity:1}.hp-btn-time-sig{background:#ffffff0f;border:1px solid rgba(255,255,255,.14);color:#a09070;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:#cda3531f;border:1px solid rgba(205,163,83,.35);color:var(--gold)}.hp-btn-play-prog--playing{background:#cda3534d;border:1px solid rgba(205,163,83,.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:0}.hp-action-bar__btn--meas{color:#c9a84c;max-width:50px}.hp-action-bar__btn--bpm{color:#c0a0e0;gap:10px;max-width:90px}.hp-action-bar__btn--swing{color:#80a0b0;max-width:90px}.hp-action-bar__btn--play-prog{color:#80d090;background:#64c88208}.hp-action-bar__btn--play-prog.hp-action-bar__btn--playing{background:#dc78502e;color:#ff9060}.hp-action-bar__btn--melodies{color:#d4a830;max-width:40px}.hp-action-bar__bpm-input{width:18px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:inherit;font-size:11px;font-family:var(--font);text-align:center;-moz-appearance:textfield}.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__btn--slap{color:#ff9060;background:#c8a77814;max-width:40px}.hp-action-bar__btn--pause-token{color:#80a0b0;background:#78a0c814;max-width:40px}.hp-saved-chip--pressed{background:#a078c847;border:1px solid rgba(160,120,200,.7);transform:scale(1.05);transition:transform .18s ease,background .18s ease;box-shadow:0 0 0 2px #a078c859}.hp-btn-clear-saved-end{flex-shrink:0;background:#8c2d2d24;border:1px solid rgba(140,45,45,.3);color:#a85858;border-radius:7px;padding:5px 10px;font-size:10px;font-family:var(--font);cursor:pointer;height:30px;align-self:center}.hp-btn-clear-saved-end:hover{background:#8c2d2d38}.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:#ffffff0f;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-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:201;background:var(--bg-surface);border-top:1px solid var(--border-gold);border-radius:18px 18px 0 0;height:90vh;max-height:90vh;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:20px 18px 36px}.hp-filter-modal__drag-handle{width:40px;height:4px;background:#cda35333;border-radius:2px;margin:0 auto 18px}.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:none;border:none;color:#6a5830;font-size:18px;cursor:pointer;line-height:1;padding:4px 8px}.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:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:#6a5840}.hp-chip--active{background:color-mix(in srgb,var(--chip-color, #c9a84c) 16%,transparent);border:1px solid var(--chip-color, rgba(205,163,83,.6));color:var(--chip-color, #e8d4a0)}.hp-filter-toggle-row{display:flex;align-items:center;justify-content:space-between;background:#ffffff08;border:1px solid rgba(255,255,255,.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:#6a5830;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(205,163,83,.6)}.hp-toggle-track--off{background:#ffffff12;border:1px solid rgba(255,255,255,.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:#cda353;box-shadow:0 0 6px #cda35380}.hp-toggle-thumb--off{left:3px;background:#4a3a18;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:#141008fa;border:1px solid rgba(205,163,83,.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(205,163,83,.15);flex-shrink:0}.hp-melody-header__title{font-family:var(--font);font-size:16px;font-weight:600;color:#e8d098}.hp-melody-header__sub{font-family:var(--font);font-size:11px;color:var(--text-dim);margin-top:2px}.hp-melody-header__close{background:#ffffff0a;border:1px solid rgba(255,255,255,.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:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#e8d098;border-radius:7px;padding:8px 10px;font-size:12px;font-family:var(--font)}.hp-melody-save-btn{background:#cda3532e;border:1px solid rgba(205,163,83,.4);color:#e8d098;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:#cda3530d;border:1px solid rgba(205,163,83,.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:#e8d098;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:#c9a84c;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 var(--border-gold)}.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:#6a5830;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:34px;padding:0 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.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:#cda35373;background:#ffffff12}.hp-melody-modal-panel .hp-melody-save-btn{height:34px;padding:0 16px;border-radius:0 8px 8px 0;background:#cda3532e;border:1px solid rgba(205,163,83,.45);border-left:1px solid rgba(255,255,255,.07);color:#e8d098;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:#cda35342}.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(255,255,255,.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:#cda3531a;border:1px solid rgba(205,163,83,.3);color:#c8a860}.hp-melody-modal-panel .hp-melody-item__chords{margin-top:6px;background:#0000004d;border:1px solid rgba(255,255,255,.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:#ffffff08;border:1px solid rgba(255,255,255,.06)}.hp-melody-modal-panel .hp-melody-chord__name{color:#d6b16f;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:#ffffff08;border:1px dashed rgba(205,163,83,.2);border-radius:10px;color:#6a5830;font-size:12px}.hp-melody-select{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#e8d098;border-radius:7px;padding:8px 10px;font-size:12px;font-family:var(--font);cursor:pointer}.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(205,163,83,.12);z-index:9}.hp-builder-header__title{filter:drop-shadow(0px 0px 21px #e8d098a1);font-size:17px;color:#e8d098;font-weight:500}.hp-builder-header__sub{display:none;font-size:9px;color:#5a4a28;letter-spacing:3px;text-transform:uppercase;margin-top:2px}.hp-builder-header__close{background:none;border:none;color:#6a5830;font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;margin-left:18px}.hp-builder-body{padding:7px 22px 70px}.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:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:#7a6a50}.hp-builder-tab--active{background:#cda3532e;border:1px solid rgba(205,163,83,.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(205,163,83,.55);background:#cda3531a}.hp-preset-item--default{border:1px solid rgba(255,255,255,.08);background:#ffffff08}.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:#7a6a50}.hp-preset-item__edit-btn{background:#a0a0dc1a;border-left:1px solid rgba(255,255,255,.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:#4a3a18;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:#cda35333;border:1px solid rgba(205,163,83,.5);color:#e8d098;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:#4a3a18;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(255,255,255,.08);background:#ffffff08}.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(255,255,255,.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(255,255,255,.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:#5a4a28;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{margin-bottom:14px}.hp-select-source-label{font-size:9px;color:#6a5a30;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}.hp-build-type-label{font-size:9px;color:#6a5a30;letter-spacing:2px;text-transform:uppercase}.hp-build-divider{width:1px;height:18px;background:#ffffff1a;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:#cda3530d;border:1px solid rgba(205,163,83,.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:#c8a860;letter-spacing:2px;text-transform:uppercase;font-weight:600}.hp-rings-editor__sub{font-size:9px;color:#5a4a28}.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:#6a5a30}.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:#6a5a30;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:#6a5a30;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:#cda3530f;border:1px solid rgba(205,163,83,.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:#6a5a30;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:#cda3531f;border:1px solid rgba(205,163,83,.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:#cda3531a;border:1px solid rgba(205,163,83,.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:#6a5a30;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:#3a2c10;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:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:#8a7850}.hp-note-list-btn--selected{background:#cda35333;border:1px solid rgba(205,163,83,.55);color:var(--gold-text)}.hp-note-list-btn__size{font-size:8px;color:#5a4a28;margin-left:3px}.hp-note-list-btn__side{font-size:7px;color:#4a5a28;margin-left:2px}.hp-save-section{border-top:1px solid rgba(255,255,255,.06);padding-top:14px}.hp-save-section__label{font-size:9px;color:#6a5a30;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}.hp-a4-row{display:flex;gap:10px;align-items:center;margin-bottom:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-md);padding:8px 12px}.hp-a4-row__label{font-size:9px;color:#6a5a30;letter-spacing:1px;white-space:nowrap}.hp-btn-reset-a4{background:#cda3531a;border:1px solid rgba(205,163,83,.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:#ffffff0d;border:1px solid rgba(255,255,255,.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:#ffffff08;border:1px solid rgba(255,255,255,.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(255,255,255,.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(255,255,255,.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(205,163,83,.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:#8a7a5a}.hp-builder-tab--inactive:hover{background:#ffffff0a;color:#b09870}.hp-builder-tab--active,.hp-builder-tab--active-green,.hp-builder-tab--active-blue{background:#cda35329;border-color:#cda35373;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:#ffffff0f;color:#e8d098;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:90vh;max-height:90vh;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:#cda3534d;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(255,255,255,.03);--hpb-surface-2: rgba(255,255,255,.05);--hpb-border: rgba(205,163,83,.18);--hpb-border-soft: rgba(255,255,255,.08);--hpb-gold: #d6b16f;--hpb-gold-soft: rgba(205,163,83,.16);--hpb-gold-strong: rgba(205,163,83,.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: #8a7a55;--hpb-text: #d4c69a;--hpb-text-dim: #8a7a55}.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:#8a7a55}.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:#6a5a30;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:#cda3534d;background:#ffffff12}.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:#ffffff12}.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}.hp-builder-panel .hp-btn-use-preset{background:var(--hpb-gold-soft);border:1px solid var(--hpb-gold-strong);color:#e8d098}.hp-builder-panel .hp-btn-use-preset:hover{background:#cda3533d}.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:#e8d098}.hp-builder-panel .hp-btn-update-note:hover{background:#cda3533d}.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);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:#cda35342}.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:#cda3531a;border:1px solid rgba(205,163,83,.3);color:var(--hpb-gold);font-size:10px;cursor:pointer}.hp-builder-panel .hp-btn-reset-a4:hover{background:#cda35333}.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:#ffffff0a;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:1px solid var(--hpb-border);border-radius:var(--hpb-radius);padding:14px;margin:8px 0}.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:#e8d098}.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-dropdown{position:relative}.hp-dropdown__trigger{width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.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(205,163,83,.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(255,255,255,.04)}.hp-dropdown__option--active{background:#cda3531a;color:#e8d098}.hp-dropdown__option--default{background:transparent;color:#b0a080}.hp-dropdown__option--current{background:#64c8821f;color:#80d090;font-weight:600;border-left:2px solid #80d090}.hp-dropdown__option--current.hp-dropdown__option--active{background:#64c88233;color:#a8e8b8}.hp-dropdown__trigger--current{border-color:#64c88266!important;background:#64c88214!important;color:#a8e8b8!important}.hp-dropdown__current-mark{display:inline-block;color:#80d090;margin-right:6px;font-size:8px;vertical-align:middle}.hp-dropdown__current-tag{margin-left:8px;font-size:9px;font-weight:500;color:#80d090;background:#64c88226;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:20px;display:flex;align-items:center}.hp-slider__track-bg{position:absolute;left:0;right:0;height:3px;background:#ffffff14;border-radius:2px}.hp-slider__track-fill{position:absolute;left:0;height:3px;background:#cda35399;border-radius:2px}.hp-slider__input{position:absolute;left:0;right:0;width:100%;opacity:0;height:20px;cursor:pointer;margin:0;padding:0}.hp-slider__thumb{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--gold);border:2px solid #1a1408;pointer-events:none;box-shadow:0 0 6px #cda35366}.hp-slider__label{font-size:9px;color:var(--text-dim);min-width:28px;text-align:right;flex-shrink:0}.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{scale:1.05;transform:scaleY(var(--scale-note));transform-origin:var(--transformOrigin);rotate:var(--rotate);cursor:pointer}.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}@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)}@keyframes flash-sequence-all-in{0%{stroke:var(--color-stroke-default)}14%{stroke:#cda3531a}43%{stroke:#cda3531a}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-body{padding:12px 14px 50px}.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(max-height:600px)and (orientation:landscape){.hp-app{display:flex;flex-direction:row;height:100dvh;overflow:hidden}.hp-left-panel{width:70%;min-width:280px;max-width:540px;height:100dvh;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;border-right:1px solid rgba(205,163,83,.12)}.hp-sticky-header{position:relative;flex-shrink:0;padding:6px 12px 4px;border-bottom:1px solid rgba(205,163,83,.1)}.hp-pan-strip{position:relative;top:auto;flex:1;overflow:hidden;display:flex;flex-direction:column;justify-content:center;border-bottom:none;padding:4px 8px}.hp-pan-strip__inner{max-width:none;gap:2px}.hp-diagrams-row{flex:1;min-height:0}.hp-diagram-col svg{max-height:calc(100dvh - 120px)}.hp-info-row{height:auto;min-height:24px}.hp-support-link{top:6px;right:8px;font-size:9px;padding:4px 9px 4px 7px}.hp-right-panel{display:block;flex:1;min-width:0;height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.hp-content{max-width:none;padding:6px 10px}.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(255,255,255,.05)}.hp-builder-tab-layout{display:flex;flex-direction:row;flex:1;min-height:0;overflow:hidden;gap:0}.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(205,163,83,.1)}.hp-builder-tab-right{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:8px 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%}}.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-active-notes-row{justify-content:center}.hp-chord-list{padding-bottom:80px}
