:root{--bg-color: #1a1a1a;--text-color: #f0f0f0;--primary-color: #ff69b4;--secondary-color: #333;--panel-bg: #252525;--card-bg: #2d2d2d;--hina-color: #ff85c0;--kai-color: #5cdbd3;--others-color: #ffd700;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark}body{margin:0;padding:0;background-color:var(--bg-color);color:var(--text-color);width:100vw;height:100vh;height:100dvh;overflow:hidden;display:flex;justify-content:center}#root{width:100%;height:100%;display:flex;flex-direction:column;max-width:1200px}header{padding:.5rem;display:flex;flex-direction:column;gap:.5rem;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.header-logo-container{display:flex;justify-content:center;align-items:center;padding:0 .5rem;width:100%}.header-logo{max-width:100%;height:auto;max-height:80px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.controls{display:flex;flex-direction:row;justify-content:space-between;align-items:stretch;gap:.5rem;background:var(--panel-bg);padding:.5rem;border-radius:8px}.bgm-control-group{display:flex;flex-direction:column;gap:2px;flex:1;justify-content:center;min-width:0}.label-row{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:700;color:#aaa;overflow:hidden}.marquee-container{flex:1;overflow:hidden;white-space:nowrap;position:relative;mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent)}.marquee-content{display:inline-block;padding-left:100%;animation:marquee 15s linear infinite;color:#666;font-size:.65rem}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.bgm-credit{margin-left:8px;font-size:.55rem;font-weight:400;color:#888;white-space:normal;word-break:break-all;line-height:1.1}.bgm-buttons{display:flex;gap:.3rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.bgm-btn{background:var(--secondary-color);color:#ccc;border:1px solid #444;padding:.2rem .6rem;border-radius:15px;font-size:.75rem;cursor:pointer;white-space:nowrap}.bgm-btn:hover{background:#444}.bgm-btn.active{background:var(--primary-color);color:#000;border-color:var(--primary-color);font-weight:700}.control-right-group{display:flex;align-items:stretch;gap:8px}.vol-control{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:2px;font-size:.7rem;color:#aaa;min-width:60px}.vol-control input[type=range]{width:100%;accent-color:var(--primary-color)}.pro-toggle-btn{background:#444;color:#fff;border:2px solid #555;font-size:1.1rem;font-weight:900;padding:0 1rem;border-radius:8px;cursor:pointer;transition:all .2s;text-shadow:0 2px 0 #000;white-space:nowrap;user-select:none;-webkit-user-select:none}.pro-toggle-btn:hover{background:#555}.pro-toggle-btn.active{background:var(--primary-color);color:#000;border-color:#fff;box-shadow:0 0 15px var(--primary-color);text-shadow:none}.seq-toggle-btn{background:#2b2b2b;color:#ddd;border:2px solid #3a3a3a;font-size:1.1rem;font-weight:900;padding:0 .9rem;border-radius:8px;cursor:pointer;transition:all .2s;text-shadow:0 2px 0 #000;white-space:nowrap;user-select:none;-webkit-user-select:none}.seq-toggle-btn:hover{background:#3a3a3a}.seq-toggle-btn.active{background:#ffd54f;color:#000;border-color:#fff;box-shadow:0 0 15px #ffd54fcc;text-shadow:none}.pro-panel-inline{background:#222;border-bottom:2px solid var(--primary-color);padding:.8rem .8rem 1.2rem;animation:slideDown .3s cubic-bezier(.2,.8,.2,1);display:grid;grid-template-columns:1.2fr 1fr;gap:.5rem;flex-shrink:0;user-select:none;-webkit-user-select:none}.seq-panel{background:#1f1f1f;border-bottom:2px solid #ffd54f;padding:.6rem .8rem;animation:slideDown .3s cubic-bezier(.2,.8,.2,1);flex-shrink:0}.seq-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.seq-title{font-size:.75rem;font-weight:700;color:#ffd54f;letter-spacing:.06em}.seq-play-btn{border:1px solid #444;background:#333;color:#bbb;font-size:.7rem;font-weight:800;padding:.2rem .6rem;border-radius:6px;cursor:pointer}.seq-play-btn.active{background:#66bb6a;color:#000;border-color:#fff;box-shadow:0 0 10px #66bb6acc}.seq-controls{display:flex;align-items:center;gap:.4rem}.seq-sync-btn{border:1px solid #444;background:#2a2a2a;color:#bbb;font-size:.7rem;font-weight:800;padding:.2rem .5rem;border-radius:6px;cursor:pointer}.seq-sync-btn.active{background:#29b6f6;color:#000;border-color:#fff;box-shadow:0 0 10px #29b6f6cc}.seq-reset-btn{border:1px solid #444;background:#2a2a2a;color:#bbb;font-size:.7rem;font-weight:800;padding:.2rem .5rem;border-radius:6px;cursor:pointer}.seq-reset-btn:hover{background:#3a3a3a}.seq-bpm{display:flex;align-items:center;gap:.3rem;color:#bbb;font-size:.7rem;font-weight:700}.seq-bpm input{width:56px;background:#2a2a2a;color:#eee;border:1px solid #444;border-radius:4px;padding:2px 6px;font-size:.7rem;text-align:right}.seq-bpm input:disabled{opacity:.5}.seq-grid,.seq-row{display:flex;flex-direction:column;gap:.35rem}.seq-row-main{display:flex;align-items:center;gap:.5rem}.seq-track{display:flex;align-items:center;gap:.4rem;min-width:160px}.seq-track-label{font-size:.65rem;font-weight:700;color:#888;width:24px;text-align:right}.seq-track-select{background:#2a2a2a;color:#ddd;border:1px solid #444;border-radius:4px;padding:2px 6px;font-size:.7rem;min-width:120px}.seq-fx-toggle,.seq-mute-toggle{border:1px solid #444;background:#2a2a2a;color:#bbb;font-size:.65rem;font-weight:800;padding:.2rem .4rem;border-radius:6px;cursor:pointer}.seq-mute-toggle.active{background:#ef5350;color:#000;border-color:#fff;box-shadow:0 0 8px #ef5350cc}.seq-retrig-toggle{border:1px solid #444;background:#2a2a2a;color:#bbb;font-size:.65rem;font-weight:800;padding:.2rem .4rem;border-radius:6px;cursor:pointer}.seq-retrig-toggle.active{background:#ffd54f;color:#000;border-color:#fff;box-shadow:0 0 8px #ffd54fcc}.seq-fx-toggle.active{background:#ff8f00;color:#000;border-color:#fff;box-shadow:0 0 8px #ff8f00cc}.seq-steps{display:grid;grid-template-columns:repeat(16,16px);gap:4px}.seq-step{width:16px;height:16px;border-radius:3px;border:1px solid #333;background:#222;cursor:pointer;padding:0}.seq-step.group-a{background:#242424}.seq-step.group-b{background:#1c1c1c}.seq-step.active{background:var(--primary-color);border-color:#fff;box-shadow:0 0 6px #ff69b4cc}.seq-step.current{outline:2px solid #66bb6a;outline-offset:-2px}.seq-fx-panel{background:#1a1a1a;border:1px solid #333;border-radius:6px;padding:6px;display:grid;grid-template-columns:1.2fr 1fr;gap:.6rem}.seq-fx-section{display:flex;flex-direction:column;gap:.4rem}.seq-fx-filter select{background:#2a2a2a;color:#ddd;border:1px solid #444;border-radius:4px;padding:2px 6px;font-size:.65rem}.seq-fx-row input[type=range]{accent-color:var(--primary-color);height:6px}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0;height:0;padding-top:0;padding-bottom:0}}.fx-section{display:flex;flex-direction:column;gap:.5rem}.fx-title{font-size:.7rem;font-weight:700;color:var(--primary-color);border-bottom:1px solid #444;margin-bottom:4px}.fx-types{display:grid;grid-template-columns:1fr 1fr;gap:4px}.fx-types button{background:#333;color:#999;border:1px solid #444;padding:4px;border-radius:4px;font-size:.65rem}.fx-types button.active{background:var(--primary-color);color:#000;font-weight:700;border-color:#fff}.fx-row{display:flex;flex-direction:column}.fx-row label{font-size:.65rem;color:#aaa}.fx-row input{width:100%;accent-color:var(--primary-color);height:4px;background:#111;border-radius:2px}.eq-row{display:flex;justify-content:space-around;height:50px;align-items:flex-end;padding-bottom:2px}.v-slider{display:flex;flex-direction:column;align-items:center;height:100%}.v-slider input{writing-mode:vertical-lr;direction:rtl;appearance:slider-vertical;width:24px;flex:1;background:#111;border-radius:4px;margin-bottom:4px}.v-slider label{font-size:.6rem;color:#777;font-weight:700;white-space:nowrap;line-height:1}.char-tabs{display:flex;width:100%;border-bottom:2px solid #333;flex-shrink:0;height:40px}.tab{flex:1;display:flex;justify-content:center;align-items:center;background:var(--panel-bg);cursor:pointer;font-weight:700;font-size:.9rem;transition:all .3s ease;opacity:.6}.char-icon-frame{width:28px;height:28px;border-radius:50%;margin-right:8px;overflow:hidden;border:2px solid rgba(255,255,255,.2);flex-shrink:0}.char-icon-frame img{width:100%;height:100%;object-fit:cover;display:block}.hina-img{transform:scale(1.8) translateY(5%);transform-origin:center center}.kai-img{transform:scale(1.4) translateY(5%);transform-origin:center center}.tab.active{opacity:1;color:#000;border-bottom:none!important}.tab.hina.active{background:var(--hina-color);box-shadow:0 0 15px var(--hina-color)}.tab.kai.active{background:var(--kai-color);box-shadow:0 0 15px var(--kai-color)}.tab.others.active{background:var(--others-color);box-shadow:0 0 15px var(--others-color)}.content-area{flex:1;overflow:hidden;display:flex;flex-direction:column}.board{flex:1;padding:.5rem;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(65px,1fr);gap:.5rem;height:100%;overflow-y:auto;transition:all .3s cubic-bezier(.2,.8,.2,1)}@media(max-width:600px){.board.compact{gap:2px;padding:2px;grid-auto-rows:1fr;align-content:stretch}.board.compact .sound-btn{font-size:.6rem;padding:0;border-radius:4px;overflow:hidden;text-overflow:ellipsis}}@media(min-width:400px){.board{grid-template-columns:repeat(4,1fr)}}@media(min-width:600px){.board{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(80px,1fr);gap:1rem;padding:1rem}.sound-btn{font-size:1.2rem;border-radius:12px}}@media(min-width:1000px){.board{grid-template-columns:repeat(5,1fr)}.sound-btn{font-size:1.5rem}}.sound-btn{background:var(--card-bg);background-image:linear-gradient(to bottom right,var(--theme-bg),transparent);border:1px solid transparent;border-radius:8px;padding:.2rem;font-size:.8rem;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000004d;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;line-height:1.1}.sound-label{display:block;width:100%;text-align:center;padding:2px 4px 0;margin-top:0}.sound-btn{flex-direction:column;gap:4px;justify-content:center;padding:.4rem}.sound-wave{height:80px;border-radius:6px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);padding:2px 4px;display:flex;align-items:center;width:calc(100% - 8px);position:relative;overflow:hidden;margin-top:0;margin-bottom:2px}.sound-wave canvas{width:100%;height:100%;display:block}.sound-wave.compact{height:18px;padding:1px 3px;width:calc(100% - 6px)}.sound-wave:after{content:"";display:none}.sound-wave .playhead{position:absolute;top:0;bottom:0;width:2px;background:#ff2d2d;box-shadow:0 0 6px #ff2d2db3;opacity:0;pointer-events:none}.sound-btn:active,.sound-btn.playing{transform:scale(.95);background:var(--primary-color);color:#000;box-shadow:0 0 20px var(--primary-color);border-color:#fff;z-index:10}.construction{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#888}.construction h2{font-size:2rem;margin-bottom:1rem;color:var(--kai-color)}.loading-overlay{position:fixed;inset:0;background:#000;z-index:9999;display:flex;justify-content:center;align-items:center;color:var(--primary-color)}.loading-content{text-align:center;width:80%;max-width:400px}.loading-image{width:100%;max-width:300px;border-radius:16px;margin-bottom:2rem;box-shadow:0 0 20px #00000080;border:2px solid #333}.loading-content h2{font-size:1.5rem;margin-bottom:2rem;letter-spacing:2px;animation:pulse 1.5s infinite}.progress-bar-bg{width:100%;height:10px;background:#333;border-radius:5px;overflow:hidden;margin-bottom:10px}.progress-bar-fill{height:100%;background:var(--primary-color);box-shadow:0 0 15px var(--primary-color);transition:width .2s ease-out}.loading-text{font-size:.8rem;color:#888;margin-top:5px;letter-spacing:1px}@keyframes pulse{0%{opacity:.6}50%{opacity:1;text-shadow:0 0 10px var(--primary-color)}to{opacity:.6}}@media(max-width:480px){.controls{padding:4px;gap:4px}.header-logo{max-height:45px}.vol-label{display:none}.vol-control{width:86px;min-width:86px}.control-right-group{gap:4px}.pro-toggle-btn,.seq-toggle-btn{font-size:.9rem;padding:0 .6rem}.fx-types button{font-size:.6rem;padding:4px 2px}.eq-row{height:40px}.v-slider label{font-size:.5rem}.loading-content h2{font-size:1rem;margin-bottom:1rem}}@media(max-width:700px){.seq-track{min-width:120px}.seq-steps{grid-template-columns:repeat(16,14px);gap:3px}.seq-step{width:14px;height:14px}.seq-fx-panel{grid-template-columns:1fr}.seq-row-main{flex-direction:column;align-items:stretch;gap:.3rem}.seq-track{width:100%;justify-content:flex-start;gap:.35rem}.seq-steps{width:100%;justify-content:flex-start}.seq-track-label{text-align:left}}@media(max-width:600px){.pro-panel-inline{padding:.2rem .4rem;gap:.2rem}.fx-section{gap:2px;margin-bottom:4px}.fx-title{margin-bottom:2px;font-size:.65rem;padding-bottom:1px;line-height:1.1;border-bottom:1px solid #333}.fx-row{gap:1px}.fx-row label{font-size:.6rem;line-height:1.1;margin-bottom:1px}.fx-row input{height:8px;margin-top:1px;margin-bottom:1px}.eq-row{height:auto;padding-bottom:2px;align-items:flex-end;gap:4px;display:flex}.v-slider{gap:0;flex:1;width:auto;flex-direction:column-reverse}.v-slider input{writing-mode:horizontal-tb;direction:ltr;appearance:auto;width:100%;height:6px;margin:0}.v-slider label{font-size:.55rem;text-align:center;margin-bottom:1px;width:100%;line-height:1}.fx-types{gap:2px;margin-bottom:2px;display:flex;flex-direction:row;width:100%}.fx-types button{padding:2px 0;font-size:.55rem;line-height:1.1;flex:1;white-space:nowrap;min-height:20px;display:flex;align-items:center;justify-content:center}}.app-container{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.footer-controls{flex-shrink:0;display:flex;justify-content:center;align-items:center;gap:.5rem;padding:.4rem;background:#222;border-top:1px solid #444;z-index:100}.footer-btn{flex:0 0 40%;max-width:150px;border:none;border-radius:4px;padding:.4rem;font-size:.8rem;font-weight:700;cursor:pointer;text-align:center;transition:transform .1s}.footer-btn:active{transform:scale(.98)}.share-btn{background:#1da1f2;color:#fff;box-shadow:0 0 10px #1da1f266}.reset-btn{background:#444;color:#ccc}@media(max-width:600px){.footer-controls{padding:2px;gap:4px}.footer-btn{padding:4px 0;font-size:.7rem;border-radius:4px;height:28px;display:flex;align-items:center;justify-content:center}}
