@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.hidden{display:none!important}#waterfall-watermark{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);z-index:10;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;padding:20px;opacity:.15;mix-blend-mode:screen;transition:opacity 2.5s ease-in-out,transform 2.5s ease-in-out;-webkit-user-select:none;user-select:none;pointer-events:none}#waterfall-watermark.dimmed{opacity:0;transform:translate(-50%,-40%)}#watermark-title{font-family:Outfit,sans-serif;font-size:84px;font-weight:800;line-height:1;color:#fff;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:8px;text-shadow:0 0 20px rgba(255,255,255,.1)}#watermark-composer{font-family:Outfit,sans-serif;font-size:24px;font-weight:400;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;opacity:.8}@media (max-width: 768px){#watermark-title{font-size:36px}#watermark-composer{font-size:12px;letter-spacing:.15em}#waterfall-watermark{opacity:.15}}.render-safe-hide{visibility:hidden!important;position:absolute!important;pointer-events:none!important;height:0!important;overflow:hidden!important}:root{--bg: #0d0f14;--surface: #161a24;--surface2: #1e2433;--border: rgba(255, 255, 255, .08);--accent: #a78bfa;--accent2: #7c3aed;--gold: #fbbf24;--text: #e2e8f0;--muted: #64748b;--success: #34d399;--danger: #f87171;--radius: 12px;--radius-sm: 8px;--shadow: 0 8px 32px rgba(0, 0, 0, .5);--glow: 0 0 24px rgba(167, 139, 250, .25);--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.5;overflow:hidden}#app{display:grid;grid-template-rows:auto 1fr auto;height:100vh;gap:0}#header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;gap:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10}#header .logo{display:flex;align-items:center;gap:10px;flex-shrink:0}#header .logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent2),var(--accent));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--glow)}#header .logo-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.3px}#header .logo-sub{font-size:11px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}.header-divider{width:1px;height:28px;background:var(--border);flex-shrink:0}#piece-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;outline:none;transition:border-color .2s;min-width:200px}#piece-select:focus{border-color:var(--accent)}.format-badge{background:#a78bfa1f;border:1px solid rgba(167,139,250,.3);color:var(--accent);padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0}.view-switcher{display:flex;background:var(--surface2);padding:4px;border-radius:var(--radius-sm);border:1px solid var(--border);gap:4px}.view-btn{background:transparent;border:none;color:var(--muted);padding:6px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.view-btn:hover{color:var(--text);background:#ffffff0d}.view-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #a78bfa4d}.search-wrap{position:relative;width:300px;height:40px;display:flex;align-items:center;gap:8px;flex:1;max-width:300px}#github-limit-indicator{display:inline-flex;align-items:center;font-size:.65rem;color:var(--muted);background:var(--surface2);border:1px solid var(--border);padding:2px 8px;border-radius:12px;margin-left:12px;opacity:1;pointer-events:none;transition:opacity .5s ease;white-space:nowrap}#github-limit-indicator.dimmed{opacity:.2}#github-limit-indicator.hidden{display:none!important}#input-search{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:6px 12px;font-size:13px;width:100%}#input-search:focus{outline:none;border-color:var(--accent)}.search-btn{background:transparent;border:none;font-size:14px;cursor:pointer;opacity:.6;transition:opacity .2s}.search-btn:hover{opacity:1}#search-results{position:absolute;top:48px;left:0;width:100%;max-height:400px;overflow-y:auto;background:var(--surface2);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px #0009;z-index:100}#search-results.hidden{display:none}.search-category-title{padding:10px 12px 4px;font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);margin-bottom:4px}.search-result-item{padding:10px 16px;cursor:pointer;transition:background .2s;font-size:13px;border-bottom:1px solid var(--border-light)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--surface2);color:var(--accent)}.search-result-item .composer{font-size:11px;color:var(--muted);display:block;margin-top:2px}.vfx-btn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:6px 12px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.5px}.vfx-btn:hover{color:var(--text);border-color:var(--accent)}.vfx-btn.active{background:#a78bfa26;border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px #a78bfa33}#waterfall-container{flex:1;background:#020617;position:relative;overflow:hidden;transition:opacity .3s ease}#waterfall-canvas{width:100%;height:100%;display:block}#status-bar{margin-left:auto;font-size:12px;color:var(--muted);font-style:italic}#main{flex:1;display:grid;grid-template-columns:1fr 340px;grid-template-rows:1fr auto;grid-template-areas:"notation info" "ad-mobile ad-mobile";overflow:hidden;position:relative}#notation-column{grid-area:notation}#info-panel{grid-area:info}#ad-mobile-footer-container{grid-area:ad-mobile;display:flex}#ad-desktop-sidebar-container{display:none}@media (min-width: 769px){#main{grid-template-rows:auto 1fr;grid-template-areas:"notation info" "notation ad"}#info-panel{grid-area:info;border-bottom:1px solid var(--border);overflow-y:visible}#ad-desktop-sidebar-container{grid-area:ad;display:flex;align-self:stretch;min-height:600px;z-index:5;border-left:1px solid var(--border)}#ad-mobile-footer-container{display:none!important}}#main.full-width-layout{grid-template-columns:1fr 0px}#notation-column{display:flex;flex-direction:column;height:100%;overflow:hidden;background:#faf9f7}.visualizer-layers{flex:1;display:grid;grid-template-areas:"layer";overflow:hidden;position:relative}#notation-panel-wrap,#waterfall-container{grid-area:layer;height:100%;width:100%}#notation-panel-wrap{background:#faf9f7;z-index:1;overflow-y:auto;overflow-x:hidden}#waterfall-container{background:#020617;z-index:2}.visualizer-layers[data-active=sheet] #waterfall-container,.visualizer-layers[data-active=waterfall] #notation-panel-wrap{visibility:hidden;pointer-events:none;z-index:0}#notation-panel{min-height:100%;padding:32px 48px}#keyboard-container{height:160px;background:#0f172a;padding:8px 8px 0;display:flex;justify-content:center;border-top:2px solid #000;box-shadow:0 -8px 24px #0006;z-index:5;overflow-x:auto;overflow-y:hidden}#piano-keyboard{height:100%;display:flex;position:relative;min-width:max-content}.key{cursor:pointer;transition:all .1s;-webkit-user-select:none;user-select:none}.white-key{width:36px;height:100%;background:linear-gradient(to bottom,#eee,#fff 5%,#fff 95%,#ccc);z-index:1;border-radius:0 0 4px 4px;border:1px solid #aaa;box-shadow:inset 0 -3px 4px #0000001a}.black-key{width:22px;height:60%;background:linear-gradient(to bottom,#334155,#000 15%,#000 90%,#1e293b);z-index:2;margin-left:-11px;margin-right:-11px;border-radius:0 0 3px 3px;box-shadow:0 4px 8px #0009}.key.active{background:var(--accent)!important;transform:translateY(3px);box-shadow:0 2px 4px #0006}#loader{position:absolute;top:0;right:0;bottom:0;left:0;background:#faf9f7d9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:5}.spinner{width:44px;height:44px;border:3px solid rgba(124,58,237,.2);border-top-color:var(--accent2);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loader-text{font-size:14px;color:#64748b;font-weight:500}#info-panel{background:var(--surface);border-left:1px solid var(--border);overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;gap:24px}.info-section{display:flex;flex-direction:column;gap:8px}.info-section-title{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding-bottom:6px;border-bottom:1px solid var(--border)}#info-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.3}#info-composer{font-size:13px;color:var(--muted);font-style:italic}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.info-chip{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;display:flex;flex-direction:column;gap:2px}.info-chip-label{font-size:10px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-chip-value{font-size:14px;font-weight:600;color:var(--accent)}.format-card{background:#a78bfa12;border:1px solid rgba(167,139,250,.2);border-radius:var(--radius);padding:14px}.format-card-title{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.format-card p{font-size:12px;color:var(--muted);line-height:1.6}.tech-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tech-tag{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:11px;font-weight:500;color:var(--text);font-family:var(--font-mono)}#transport{background:var(--surface);border-top:1px solid var(--border);padding:14px 28px;display:flex;align-items:center;gap:20px;z-index:10}.transport-buttons{display:flex;align-items:center;gap:10px}.btn-transport{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface2);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .18s ease;outline:none}.btn-transport:hover:not(:disabled){background:var(--surface);border-color:var(--accent);color:var(--accent);box-shadow:0 0 12px #a78bfa4d;transform:translateY(-1px)}.btn-transport:disabled{opacity:.35;cursor:not-allowed}#btn-play{width:52px;height:52px;background:linear-gradient(135deg,var(--accent2),var(--accent));border:none;color:#fff;font-size:20px;box-shadow:0 4px 16px #7c3aed66}#btn-play:hover:not(:disabled){transform:translateY(-2px) scale(1.04);box-shadow:0 6px 24px #7c3aed99;background:linear-gradient(135deg,var(--accent2),var(--accent));border:none;color:#fff}.transport-divider{width:1px;height:32px;background:var(--border);flex-shrink:0}.tempo-control{display:flex;align-items:center;gap:12px}.tempo-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}#tempo-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:160px;height:4px;background:var(--surface2);border-radius:2px;outline:none;cursor:pointer}#tempo-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 8px #a78bfa80;transition:transform .15s}#tempo-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.tempo-value{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--accent);min-width:32px;text-align:right}.tempo-unit{font-size:11px;color:var(--muted)}.transport-hints{margin-left:auto;display:flex;gap:16px;align-items:center}.ad-container{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;transition:opacity .5s ease;margin:0 auto}.ad-container:empty{display:none}.ad-leaderboard{width:100%;max-width:728px;height:90px;margin-top:8px}.ad-sidebar-slot{width:300px;height:250px;margin-top:24px}.ad-ghost{font-size:10px;font-family:var(--font-mono);color:#ffffff1a;letter-spacing:2px;text-transform:uppercase;text-align:center}.ad-smart-float{width:100%;display:flex;align-items:center;justify-content:center;padding:12px}@media (max-width: 768px){#main{overflow-y:auto;grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"notation" "sidebar" "ad"}#rotate-overlay{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0a0cfa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999;align-items:center;justify-content:center;text-align:center;padding:30px;color:var(--text)}.rotate-content h2{color:var(--accent);margin:20px 0 10px;font-size:1.5rem}.rotate-icon{font-size:4rem;display:block;animation:rotateHint 2s infinite ease-in-out}@keyframes rotateHint{0%,to{transform:rotate(0)}50%{transform:rotate(90deg)}}@media (max-width: 768px) and (orientation: landscape){#rotate-overlay{display:flex}}#ad-mobile-footer-container{position:fixed;bottom:0;left:0;width:100%;z-index:10000;background:#0a0a0c;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:center;min-height:100px}.ad-container:empty{background:#ffffff0d;border:2px dashed rgba(255,255,255,.15);position:relative;border-radius:8px;margin:10px}#ad-mobile-footer-container:empty{min-height:90px}#ad-desktop-sidebar-container:empty{min-height:300px}.ad-container:empty:after{content:"AD SLOT READY";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#ffffff4d;letter-spacing:.1em;text-transform:uppercase;background:#0000004d;padding:8px 16px;border-radius:4px}.hint{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}.kbd{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:var(--font-mono);font-size:10px;color:var(--text)}#header{padding:10px 16px;gap:12px;flex-wrap:wrap}#header .logo-text,#header .logo-sub,#header .header-divider,#status-bar,.header-divider{display:none!important}#header .logo{margin-right:auto}.search-wrap{display:flex!important;order:10;flex:1 1 100%;max-width:100%;margin-top:4px}#input-search{font-size:16px}#piece-select{min-width:140px;font-size:16px;padding:6px 10px}#transport{padding:10px 16px 110px;gap:12px}.transport-buttons{gap:8px}.btn-transport{width:44px;height:44px}#btn-play{width:50px;height:50px}.tempo-label,.transport-divider,.transport-hints{display:none!important}.tempo-control{gap:8px;flex:1;justify-content:flex-end}#tempo-slider{width:80px}#main{display:flex;flex-direction:column}#info-panel,#notation-panel-wrap,#keyboard-container{display:none!important}#notation-column{flex:1;display:flex;flex-direction:column}#waterfall-container{display:block!important;flex:1}@media (max-width: 900px){#main{grid-template-columns:1fr}#info-panel,#header .logo-sub,.transport-hints{display:none}#notation-panel{padding:16px}}#notation-panel svg{max-width:100%;height:auto!important}.btn-secondary:hover{color:var(--text);border-color:var(--text)}.btn-primary{padding:9px 20px;border-radius:var(--radius-sm);border:none;background:linear-gradient(135deg,var(--accent2),var(--accent));color:#fff;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;box-shadow:0 4px 14px #7c3aed59}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed80}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-accept{background:linear-gradient(135deg,#059669,#34d399);box-shadow:0 4px 14px #34d3994d}.btn-accept:hover:not(:disabled){box-shadow:0 6px 20px #34d39980}}
