:root{--bg:#1a1a1a;--panel:#1b1b1c;--panel-2:#1b1b1c;--border:#2a2f39;--fg:#dadada;--muted:#a5adba;--accent:#7aa2ff;--hitA:#519751;--hitB:#407bae;--hitC:#7d3636;--hit-alpha:.2;--hit-border-alpha:.45;--radius:12px;--shadow:0 2px 10px #32323240;background:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body{scrollbar-gutter:stable;background:var(--bg);color:var(--fg);font:var(--font);margin:0}.wrap{max-width:1100px;margin:24px auto;padding:0 20px}.graph3d-section{margin-top:18px}.graph3d-canvas{background:#0000002e;border-radius:12px;width:100%;height:clamp(320px,100vh - 260px,650px);overflow:hidden}h1{margin:0 0 14px;font-size:1.6rem;font-weight:800}#stat-lists .stackbar{border:1px solid var(--border);background:#141820;border-radius:7px;height:14px;display:flex;overflow:hidden}#stat-lists .stackbar .seg{height:100%}#stat-lists .seg--full{background:#ababab}#stat-lists .seg--two{background:#909090}#stat-lists .seg--one{background:#464646}#stat-lists .seg--zero{background:#212121}.card-controls .row-groups{flex-wrap:wrap;align-items:center;gap:8px 14px;display:flex}.card-controls .group-label{color:var(--fg);opacity:.9;margin-right:4px;font-weight:700}.card-controls .groups-sep{width:18px;height:1px;display:inline-block}#tabla-acordes tbody tr.row-muted{opacity:.2;filter:grayscale(99%);color:#000;transition:opacity .15s,filter .15s,background-color .15s}#tabla-acordes tbody tr.row-muted:hover{opacity:.45;filter:grayscale(12%)}#btn-export-pdf{z-index:99999;background:var(--accent,#3b82f6);color:#fff;letter-spacing:.01em;cursor:pointer;border:1px solid #ffffff26;border-radius:10px;padding:8px 12px;font-weight:800;position:fixed;inset:10px auto auto 10px;box-shadow:0 6px 20px #00000059}#btn-export-pdf:hover{filter:brightness(1.08)}@media print{#btn-export-pdf{display:none!important}}:root{--legend-item-d:22px;--legend-gap:10px;--legend-pad-x:12px;--legend-pad-y:6px;--legend-radius:12px;--legend-on-bg:#7aa2ff2e;--legend-on-ring:#7aa2ffa8}.legend-pill{display:inline-flex;position:relative}.legend-pill>input{opacity:0;pointer-events:none;appearance:none;position:absolute;inset:0}.legend-pill .deg-pill,.legend-pill .dot-pill{align-items:center;gap:var(--legend-gap);padding:var(--legend-pad-y)var(--legend-pad-x);height:calc(var(--legend-item-d) + var(--legend-pad-y)*2);border-radius:var(--legend-radius);background:var(--panel-2);border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;min-width:calc(4*var(--legend-item-d) + 3*var(--legend-gap) + 2*var(--legend-pad-x));justify-content:center;transition:background .18s,border-color .18s,box-shadow .18s,transform 50ms;display:inline-flex}.legend-pill:hover .deg-pill,.legend-pill:hover .dot-pill{background:#1e222b}.legend-pill>input:focus-visible+.deg-pill,.legend-pill>input:focus-visible+.dot-pill{outline:2px solid var(--accent);outline-offset:2px}.legend-pill>input:checked+.deg-pill,.legend-pill>input:checked+.dot-pill{background:var(--legend-on-bg);box-shadow:inset 0 0 0 1px var(--legend-on-ring);border-color:var(--legend-on-ring)}.legend-pill:active .deg-pill,.legend-pill:active .dot-pill{transform:translateY(1px)}.deg-pill .d{width:var(--legend-item-d);height:var(--legend-item-d);color:#e6e8ee;background:#30374a;border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:inline-flex}.deg-pill .d.dim{opacity:.45}.dot-pill .dot{border-radius:50%;width:10px;height:10px;display:inline-block;box-shadow:inset 0 0 0 1px #00000059}.dot-pill .dot.a{background:#2e7d32}.dot-pill .dot.b{background:#1565c0}.dot-pill .dot.c{background:#9c1c28}.tabla-simple{border-collapse:collapse;width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.tabla-simple th,.tabla-simple td{text-align:center;border:1px solid #444;padding:6px 10px}.tabla-simple tr:hover{background:#242424}.tabla-simple td:first-child{color:#fff!important}:root{--hit-alpha:.2;--hit-border-alpha:.45}.hit-a{background:rgb(from var(--hitA)r g b/var(--hit-alpha));box-shadow:inset 0 0 0 1px rgb(from var(--hitA)r g b/var(--hit-border-alpha))}.hit-b{background:rgb(from var(--hitB)r g b/var(--hit-alpha));box-shadow:inset 0 0 0 1px rgb(from var(--hitB)r g b/var(--hit-border-alpha))}.hit-c{background:rgb(from var(--hitC)r g b/var(--hit-alpha));box-shadow:inset 0 0 0 1px rgb(from var(--hitC)r g b/var(--hit-border-alpha))}.hit-d{background:rgb(from var(--hitD)r g b/var(--hit-alpha));box-shadow:inset 0 0 0 1px rgb(from var(--hitD)r g b/var(--hit-border-alpha))}.hit-a.hit-b{background:#a0822838;box-shadow:inset 0 0 0 1px #a0822873}.hit-a.hit-c{background:#48649638;box-shadow:inset 0 0 0 1px #48649673}.hit-b.hit-c{background:#96505038;box-shadow:inset 0 0 0 1px #96505073}.hit-a.hit-b.hit-c{background:#78782840;box-shadow:inset 0 0 0 1px #7878288c}.kind-major{background:linear-gradient(90deg,#e57f9f 25%,#0000 25%)!important}.kind-minor{background:linear-gradient(90deg,#6fb9d6 25%,#0000 25%)!important}.kind-aug{background:linear-gradient(90deg,#7cba50 25%,#0000 25%)!important}.kind-dim{background:linear-gradient(90deg,#8b5ab8 25%,#0000 25%)!important}.kind-sus2,.kind-sus4{background:linear-gradient(90deg,#151515 25%,#0000 25%)!important}.kind-7{background:linear-gradient(90deg,#efc373 25%,#0000 25%)!important}.kind-major,.kind-minor,.kind-aug,.kind-dim,.kind-sus2,.kind-sus4,.kind-7{background:0 0!important}.kind-major{--kind-color:var(--col-major,#ff7bb3)}.kind-minor{--kind-color:var(--col-minor,#69b8ff)}.kind-aug{--kind-color:var(--col-aug,#8bd15a)}.kind-dim{--kind-color:var(--col-dim,#b18cff)}.kind-7{--kind-color:var(--col-7,#ffd08a)}.table-legend{align-items:center;gap:10px;margin:6px 0 8px;display:flex}.table-legend .deg-pill{background:#1a2334;border:1px solid #2c3a55;border-radius:14px;align-items:center;gap:8px;padding:6px 10px;display:inline-flex;box-shadow:inset 0 0 0 1px #ffffff0a}.table-legend .deg-pill .d{color:#e7ecff;letter-spacing:.1em;font-size:.95rem;font-weight:800}.table-legend .deg-pill .d.dim{opacity:.45}.table-legend .dot-pill{background:#171a21;border:1px solid #2a2f39;border-radius:12px;align-items:center;gap:8px;padding:6px 10px;display:inline-flex;box-shadow:inset 0 0 0 1px #ffffff08}.table-legend .dot-pill .dot{border-radius:50%;width:10px;height:10px;display:inline-block;box-shadow:inset 0 0 0 2px #00000059}.table-legend .dot-pill .dot.a{background:var(--hitA,#ccb534)}.table-legend .dot-pill .dot.b{background:var(--hitB,#27699c)}.table-legend .dot-pill .dot.c{background:var(--hitC,#ad4333)}.table-legend .dot-pill .dot.d{background:var(--hitD,#80cf47)}.apps-back-button{cursor:pointer;position:absolute;top:2rem;left:2rem}.vi-logo{background:#1a1a1a;width:400px;height:auto;display:block}.vi-logo-wrap{display:inline-block;position:relative}.header{background:#1a1a1a;flex-direction:row;place-content:space-between;display:flex}@media (max-width:768px){.header{justify-content:center;margin-bottom:30px}.header h1{display:none}.vi-logo{width:220px;margin-top:10px}.piano{transform-origin:top;transform:scale(.75)}}
.progress{border:1px solid var(--border);background:#20242c;border-radius:12px;height:18px;margin:12px 0 14px;overflow:hidden}.progress .seg{height:100%;display:inline-block}.stat-tags{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.chip{color:#111;border-radius:6px;padding:2px 8px;font-weight:700}.chip-dark{color:#d9dde6;background:#2a2f39}.lists{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-top:12px;display:grid}.lists.mobile{grid-template-columns:1fr}.mobile-stat-list{flex-direction:column;gap:18px;display:flex}.mobile-stat-row{flex-direction:column;gap:10px;display:flex}.mobile-stat-kind{color:#cfd6e4;font-size:18px;font-weight:500}.mobile-acordes{flex-wrap:wrap;gap:10px;display:flex}.kind-major{background:var(--col-major);color:#111;font-weight:700}.kind-minor{background:var(--col-minor);color:#111;font-weight:700}.kind-dim{background:var(--col-dim);color:#111;font-weight:700}.kind-aug,.kind-aug7{background:var(--col-aug);color:#111;font-weight:700}.kind-7{background:var(--col-7);color:#111;font-weight:700}.kind-sus2{background:var(--col-sus2);color:#111;font-weight:700}.kind-sus4{background:var(--col-sus4);color:#111;font-weight:700}#stat-lists table{table-layout:fixed;border-collapse:collapse;width:100%}#stat-lists td.acordes{white-space:normal;word-break:break-word;flex-wrap:wrap;gap:6px;display:flex}#stat-lists td.acordes>span:not(.chord-pill){color:#fff;background:#222;border:1px solid #444;border-radius:6px;padding:2px 6px;font-size:.9rem}#stat-lists .barlist{gap:10px;display:grid}#stat-lists .bar{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:8px}#stat-lists .bar__row{font-variant-numeric:tabular-nums;justify-content:space-between;gap:12px;margin-bottom:6px;display:flex}#stat-lists .bar__track{background:#16181a;border-radius:6px;height:10px;overflow:hidden}#stat-lists .bar__fill{background:var(--accent);width:0;height:100%;transition:width .25s}#stat-lists .bar--full .bar__fill,#stat-lists .bar--two .bar__fill,#stat-lists .bar--one .bar__fill,#stat-lists .bar--zero .bar__fill{background:#465064}#stat-lists .acordes .mini-hits{gap:3px;height:4px;display:flex}#stat-lists .acordes .mini-hits i{border-radius:2px;width:10px;height:100%}#stat-lists .barlist{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:12px;display:grid}#stat-lists .bar{height:100%}#stat-lists .bar__row{justify-content:space-between;gap:8px;margin-bottom:6px;display:flex}#stat-lists .bar__track{height:12px}@media (max-width:1000px){#stat-lists .barlist{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:600px){#stat-lists .barlist{grid-template-columns:1fr}}:root{--hitA:#2e7d32;--hitB:#1565c0;--hitC:#9c1c28;--hit0:#5a5a5a;--pill-h:44px;--label-h:18px;--dot-h:8px;--dot-h-hover:20px;--dot-w:22px}.acordes .chord-pill{height:var(--pill-h);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:flex-end;margin:2px 6px;padding:0 4px;display:inline-flex;position:relative;overflow:visible}.chord-pill__label{height:var(--label-h);line-height:var(--label-h);text-align:center;letter-spacing:.02em;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 1px 1px #00000059;font-size:12px;font-weight:800;position:absolute;top:2px;left:0;right:0}.chord-pill__dots{gap:4px;padding-bottom:3px;line-height:0;display:flex}.chord-pill__dot{width:var(--dot-w);height:var(--dot-h);color:var(--hit0);position:relative}.chord-pill__dot[data-hit=a]{color:var(--hitA)}.chord-pill__dot[data-hit=b]{color:var(--hitB)}.chord-pill__dot[data-hit=c]{color:var(--hitC)}.chord-pill__dot:before{content:"";height:var(--dot-h);background:currentColor;border-radius:6px;transition:height .15s;position:absolute;bottom:0;left:0;right:0}.chord-pill__dot>b{height:var(--dot-h-hover);line-height:var(--dot-h-hover);text-align:center;white-space:nowrap;color:#fff;letter-spacing:.02em;opacity:0;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px #00000059;font-size:10px;font-weight:800;transition:opacity .15s;position:absolute;bottom:0;left:0;right:0}.acordes .chord-pill:hover .chord-pill__dot:before{height:var(--dot-h-hover)}.acordes .chord-pill:hover .chord-pill__dot>b{opacity:1}.lists{margin-top:10px;display:block}.lists .block{background:var(--panel);border:0px solid var(--border);border-radius:12px;margin:12px 0;padding:10px}#stat-lists table{border-collapse:collapse;table-layout:auto;width:100%}#stat-lists th,#stat-lists td{text-align:center;vertical-align:top;border:1px solid #333;padding:6px 8px}#stat-lists td.acordes{flex-wrap:wrap;gap:6px;display:flex}#stat-lists td.acordes span{color:#fff;background:#222;border-radius:6px;padding:2px;font-size:.9rem}#stat-lists .block:first-child th:first-child,#stat-lists .block:first-child td:first-child{text-align:center;vertical-align:middle;width:9rem}#stat-lists .block:first-child th:nth-child(2),#stat-lists .block:first-child td:nth-child(2){text-align:center;vertical-align:middle;width:5rem}#stat-lists .block:first-child th:nth-child(3),#stat-lists .block:first-child td:nth-child(3){text-align:center;vertical-align:middle;width:auto}#stat-lists .block:first-child th:nth-child(4),#stat-lists .block:first-child td:nth-child(4){text-align:center;vertical-align:middle;width:7rem}
:root{--pill-on-bg:#7aa2ff38;--pill-on-ring:#7aa2ffa8;--hitA:#ccb534;--hitB:#27699c;--hitC:#ad4333;--hitD:#80cf47}.controls.two-cols{grid-template-columns:repeat(2,minmax(280px,1fr));gap:16px;margin:12px 0 18px;display:grid}.control-group{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:0 2px 10px #00000040}.control-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.control-header strong{color:var(--fg);font-weight:800}.control-options{grid-template-columns:1fr 1fr;gap:8px 16px;display:grid}.control-options label{color:var(--fg);align-items:center;gap:8px;display:flex}.control-options input[type=checkbox]{border:1px solid var(--border);appearance:none;background:var(--panel-2);cursor:pointer;border-radius:4px;width:16px;height:16px;position:relative}.control-options input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.control-options input[type=checkbox]:checked:after{content:"";background:#fff;border-radius:2px;position:absolute;inset:3px}.card-controls{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);border-radius:18px;flex-wrap:wrap;gap:8px 14px;margin:12px 0;padding:18px 14px 14px;display:flex;position:relative}.card-controls>legend{background:var(--panel);color:var(--fg);border-radius:8px;margin-left:10px;padding:0 8px;font-size:.95rem;font-weight:800;line-height:1;position:relative}.card-title{width:100%;color:var(--fg);opacity:.9;margin-bottom:4px;font-weight:800}.pill{background:var(--panel-2);cursor:pointer;white-space:nowrap;color:var(--fg);border:1px solid #2a2f39;border-radius:12px;align-items:center;gap:10px;padding:8px 12px;transition:background .18s,border-color .18s,box-shadow .18s;display:inline-flex;position:relative}.pill>span:last-child{z-index:1;letter-spacing:.01em;font-synthesis-weight:none;font-size:1rem;font-weight:600;line-height:1;position:relative}.pill>input{opacity:0;pointer-events:none;appearance:none;position:absolute;inset:0}.pill .dot{border-radius:inherit;z-index:0;pointer-events:none;background:0 0;border:none;position:absolute;inset:0}.pill:hover .dot{background:#7aa2ff14}.pill>input:focus-visible+.dot{outline:2px solid var(--accent);outline-offset:2px}.pill>input:checked+.dot{background:var(--pill-on-bg);box-shadow:inset 0 0 0 1px var(--pill-on-ring)}.pill.pill-neutral,.chk-major,.chk-minor,.chk-dim,.chk-aug,.chk-sus2,.chk-sus4,.chk-7,.chk-aug7,.chk-maj7,.chk-min7,.chk-halfDim7,.chk-dim7,.chk-augMaj7{color:var(--fg)}.card-controls.two-cols{display:block}.card-controls.two-cols .cols{grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px 18px;display:grid}.card-controls .subgroup{border:0;margin:0;padding:0}.card-controls .subgroup>legend{color:var(--fg);background:0 0;margin-bottom:8px;padding:0;font-weight:700;position:static}.note-grid{-webkit-user-select:none;user-select:none;grid-template-columns:repeat(12,minmax(56px,1fr));gap:8px;margin:6px 0 14px;display:grid}.note{background:var(--panel-2);border:1px solid var(--border);color:var(--fg);cursor:pointer;border-radius:10px;padding:10px 8px;font-weight:700;transition:transform 60ms,border-color .15s,background .15s}.note:hover{background:#1e222b;border-color:#3a4250}.note:active{transform:translateY(1px)}.note.active-a{color:#fff;background:#4a90e2;border-color:#4a90e2}.note.active-b{color:#fff;background:#e67e22;border-color:#e67e22}.note.active-c{background:var(--hitC);color:#fff;border-color:var(--hitC)}.note.active-d{background:var(--hitD);color:#fff;border-color:var(--hitD)}#note-grid.piano{--w:60px;--gap:2px;width:calc(7*var(--w) + 7*var(--gap));-webkit-user-select:none;user-select:none;flex-wrap:nowrap;height:110px;margin:10px 0 14px;font-size:0;display:flex;position:relative}#note-grid.piano .note{box-sizing:border-box;color:#fff;background:0 0;border:none;border-radius:6px;padding:0;font-weight:700;position:relative}#note-grid.piano .white,#note-grid.piano .black{background:var(--panel-2);color:#fff;border:1px solid var(--border);box-shadow:none}#note-grid.piano .white{flex:0 0 var(--w);vertical-align:top;height:110px;margin-right:var(--gap);z-index:1;justify-content:center;align-items:flex-end;padding-bottom:8px;font-size:.92rem;display:inline-flex}#note-grid.piano .white:last-of-type{margin-right:0}#note-grid.piano .black{cursor:pointer;z-index:2;justify-content:center;align-items:flex-end;width:36px;height:66px;padding-bottom:6px;font-size:.8rem;display:flex;position:absolute;top:0}#note-grid.piano .black[data-note=C\#]{left:calc(1*var(--w) - 18px + 0*var(--gap))}#note-grid.piano .black[data-note=D\#]{left:calc(2*var(--w) - 18px + 1*var(--gap))}#note-grid.piano .black[data-note=F\#]{left:calc(4*var(--w) - 18px + 3*var(--gap))}#note-grid.piano .black[data-note=G\#]{left:calc(5*var(--w) - 18px + 4*var(--gap))}#note-grid.piano .black[data-note=A\#]{left:calc(6*var(--w) - 18px + 5*var(--gap))}#note-grid.piano .note.active-a{background:var(--hitA)!important;border-color:#383843!important}#note-grid.piano .note.active-b{background:var(--hitB)!important;border-color:#383843!important}#note-grid.piano .note.active-c{background:var(--hitC)!important;border-color:#383843!important}#note-grid.piano .note.active-d{background:var(--hitD)!important;border-color:#383843!important}#note-grid.piano .key-predict{color:#e3e6ee;text-align:center;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.95;z-index:3;background:#0f1320;border:1px solid #ffffff14;border-radius:9px;min-width:20px;height:18px;padding:0 6px;font-size:11px;font-weight:800;line-height:18px;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}#note-grid.piano .key-predict.muted{opacity:.55}@media (max-width:960px){.controls.two-cols{grid-template-columns:1fr}.note-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width:560px){.note-grid{grid-template-columns:repeat(4,1fr)}}
/*# sourceMappingURL=98fd44c6b8f24433.css.map*/