*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f11;--surface:#1a1a1f;--border:#2a2a35;--accent:#a78bfa;--beat:#f59e0b;--text:#e4e4f0;--muted:#6b6b80;--radius:10px;--font:"Montserrat", -apple-system, BlinkMacSystemFont, sans-serif}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);justify-content:center;align-items:flex-start;min-height:100vh;display:flex}#intro-bg-layer{z-index:0;opacity:0;background:linear-gradient(135deg,#1db954 0%,#7c3aed 100%);transition:opacity .8s;position:fixed;inset:0;overflow:hidden}body.intro-step1 #intro-bg-layer{opacity:1}body.intro-step2 #intro-bg-layer{opacity:0}@keyframes intro-bubble-float{0%{opacity:0;transform:translateY(0)}12%{opacity:.22}70%{opacity:.18}to{opacity:0;transform:translateY(-110vh)}}.intro-bubbles{pointer-events:none;position:absolute;inset:0;overflow:hidden}.intro-bubble{bottom:calc(-1 * var(--size));left:var(--left);width:var(--size);height:var(--size);opacity:0;animation:intro-bubble-float var(--duration) linear infinite;animation-delay:var(--delay);background:#fff;border-radius:999px;position:absolute}#app{z-index:1;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:860px;padding:24px 16px 28px;transition:opacity .9s,transform .9s;display:flex;position:relative}.app-footer{width:100%;max-width:860px;padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));letter-spacing:.2px;color:#ffffffbf;z-index:2;pointer-events:auto;justify-content:flex-start;align-items:center;gap:10px;font-size:12px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.app-footer-left{white-space:nowrap}.app-footer-link{white-space:nowrap;color:#ffffffd9;text-underline-offset:3px;text-decoration:underline;position:absolute;left:50%;transform:translate(-50%)}.app-footer-link-right{left:auto;right:16px;transform:none}#app.intro-hidden{opacity:0;pointer-events:none}#app.intro-visible{opacity:1;pointer-events:auto}.header{text-align:center}.logo{letter-spacing:-.02em;background:linear-gradient(135deg, var(--accent), #34d399);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.4rem;font-weight:900;transition:text-shadow .6s,background .6s}body.intro-step1 .logo{-webkit-text-fill-color:#ffffffeb;color:#ffffffeb;text-shadow:0 2px 10px #00000059,0 0 18px #ffffff1a;background:0 0;-webkit-background-clip:border-box;background-clip:border-box}body.intro-step2 .logo{text-shadow:none}.subtitle{color:var(--muted);letter-spacing:.02em;margin-top:3px;font-size:.82rem;font-weight:600}.main{flex-direction:row;align-items:center;gap:40px;width:100%;display:flex}body.intro-step1 .main{justify-content:center;gap:0}.turntable-wrap{will-change:transform;flex-shrink:0;width:420px;height:420px;position:relative}#turntable{filter:drop-shadow(0 6px 28px #a78bfa2e);shape-rendering:geometricprecision;width:420px;height:420px;display:block}body.intro-step2 #turntable{filter:drop-shadow(0 10px 40px #a78bfa47)}#turntable #needle-group{will-change:transform}#turntable #markers{transition:opacity .8s}body.intro-step1 #turntable #markers{opacity:0}body.intro-step2 #turntable #markers{opacity:1}@keyframes needle-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.beat-flash{pointer-events:none;opacity:0;border-radius:50%;transition:opacity 80ms ease-out;position:absolute;inset:0}.beat-flash.active{opacity:1;background:radial-gradient(circle,#f59e0b61 0%,#0000 68%);transition:none}.cell-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;flex:1;gap:16px;min-width:0;padding:20px 18px;display:flex}.cell-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.cell-title{font-family:var(--font);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.72rem;font-weight:700}.controls{opacity:0;pointer-events:none;flex-direction:column;flex:1;align-items:center;gap:14px;display:flex}body.intro-step1 .controls{opacity:0;pointer-events:none;flex:0;width:0;max-width:0;margin:0;padding:0;transition:opacity .8s,transform .8s;overflow:hidden;transform:translateY(10px)}body.intro-step2 .controls{opacity:1;pointer-events:auto;flex:1;width:auto;max-width:none;transition:opacity .8s,transform .8s;overflow:visible;transform:none}@media (orientation:portrait){html,body{height:100%;overflow:hidden}#app{transform-origin:50%;width:100vh;max-width:none;height:100vw;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-90deg)}body.intro-step1 #app,body.intro-step2 #app{transition:opacity .9s}}.bpm-row{justify-content:center;align-items:center;gap:12px;width:100%;margin-bottom:6px;display:flex}.bpm-display{flex-direction:column;justify-content:center;align-items:center;min-width:80px;height:54px;display:flex;position:relative}#bpm-value{font-size:3.2rem;font-weight:700;font-family:var(--font);font-variant-numeric:tabular-nums;color:var(--accent);cursor:text;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;text-align:center;border-bottom:1.5px solid #0000;outline:none;order:2;min-width:3ch;line-height:1;transition:border-color .15s}#bpm-value:focus{border-bottom-color:var(--accent);-webkit-user-select:text;user-select:text}.bpm-label{color:var(--muted);letter-spacing:.12em;text-transform:uppercase;order:1;margin-bottom:4px;font-size:.62rem;font-weight:700;position:static;transform:none}.transport-row{justify-content:center;align-items:center;gap:14px;margin-top:6px;display:flex}.subdivision-row{flex-direction:column;align-items:center;gap:8px;width:100%;max-width:620px;display:flex}.sub-btns{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;justify-content:center;gap:6px;max-width:100%;display:flex;overflow-x:auto}.sub-btns::-webkit-scrollbar{height:0}.btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius);cursor:pointer;font-size:.76rem;font-weight:600;font-family:var(--font);-webkit-user-select:none;user-select:none;white-space:nowrap;justify-content:center;align-items:center;padding:6px 12px;line-height:1;transition:background .12s,border-color .12s,transform 70ms;display:inline-flex}.btn:hover{border-color:var(--accent);background:#22222c}.btn:active{transform:scale(.94)}.btn-icon{text-align:center;border-radius:50%;width:54px;height:54px;padding:0;font-size:.9rem;font-weight:700}.btn-play{color:#fff;text-align:center;background:#22c55e;border-color:#22c55e;border-radius:50%;width:72px;height:72px;padding:0;font-size:1.6rem;font-weight:700;box-shadow:0 4px 24px #22c55e73}.btn-play:hover{background:#4ade80;border-color:#4ade80}.btn-play.playing{color:#c0392b;background:#1e1b2e;border-color:#c0392b;box-shadow:0 0 18px #c0392b4d}#btn-silent.active{color:#4ade80;background:#22c55e2e;border-color:#22c55ed9;box-shadow:0 0 18px #22c55e40}#btn-silent.active.muted{color:#f59e0b66;box-shadow:none;background:#f59e0b1a;border-color:#f59e0b38}.tempo-panel-scrim{z-index:40;background:#00000059;justify-content:center;align-items:center;padding:14px;display:flex;position:fixed;inset:0}.tempo-panel{z-index:41;-webkit-backdrop-filter:blur(10px);background:#12121af5;border:1px solid #ffffff1a;border-radius:16px;width:min(320px,100vw - 28px);padding:14px;position:relative;transform:none;box-shadow:0 18px 60px #0000008c}.tempo-panel-title{letter-spacing:.12em;text-transform:uppercase;color:#ffffff8c;margin-bottom:6px;font-size:12px}.tempo-panel-value{color:#ffffffeb;margin-bottom:10px;font-size:38px;font-weight:900;line-height:1}.tempo-panel-track{touch-action:none;background:linear-gradient(90deg,#7c3aed47 0%,#22c55e47 50%,#7c3aed47 100%);border:1px solid #ffffff1a;border-radius:14px;width:100%;height:44px;position:relative;overflow:hidden}.tempo-panel-track:after{content:"";background:#ffffff1a;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.tempo-panel-knob{background:#ffffffeb;border-radius:999px;width:18px;height:42px;position:absolute;top:50%;left:0%;transform:translate(-50%,-50%);box-shadow:0 8px 20px #00000073}.tempo-panel-presets{-webkit-overflow-scrolling:touch;gap:8px;margin-top:12px;display:flex;overflow-x:auto}.tempo-panel-presets::-webkit-scrollbar{height:0}.tempo-preset-btn{padding:8px 12px}.downbeat-panel-scrim{z-index:40;background:#00000059;justify-content:center;align-items:center;padding:14px;display:flex;position:fixed;inset:0}.downbeat-panel{z-index:41;-webkit-backdrop-filter:blur(10px);background:#12121af5;border:1px solid #ffffff1a;border-radius:16px;width:min(320px,100vw - 28px);padding:14px;position:relative;transform:none;box-shadow:0 18px 60px #0000008c}.downbeat-panel-title{letter-spacing:.12em;text-transform:uppercase;color:#ffffff8c;margin-bottom:10px;font-size:12px}.downbeat-panel-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.downbeat-pattern-btn.active{border-color:var(--accent);color:var(--accent);background:#20203a}.cgu-scrim{z-index:60;background:#0000008c;justify-content:center;align-items:stretch;padding:14px;display:flex;position:fixed;inset:0}.cgu-panel{background:#faf8f3;border-radius:18px;flex-direction:column;width:min(860px,100vw - 28px);height:calc(100vh - 28px);display:flex;overflow:hidden;box-shadow:0 24px 80px #0000008c}.cgu-doc{-webkit-overflow-scrolling:touch;flex:1;overflow:auto}.cgu-hero{color:#fff;background:#1a1a2e;padding:44px 26px 36px;position:relative;overflow:hidden}.cgu-hero:before{content:"🥁";opacity:.07;pointer-events:none;font-size:148px;position:absolute;top:-18px;right:-14px;transform:rotate(-15deg)}.cgu-hero-inner{max-width:720px;margin:0 auto;position:relative}.cgu-badge{letter-spacing:.08em;text-transform:uppercase;color:#f4a24df2;background:#ffffff1a;border:1px solid #fff3;border-radius:999px;align-items:center;gap:8px;margin-bottom:16px;padding:6px 14px;font-size:12px;display:inline-flex}.cgu-hero h1{margin-bottom:10px;font-size:clamp(28px,4.8vw,44px);font-weight:900;line-height:1.1}.cgu-hero h1 span{color:#e8533a}.cgu-hero-sub{color:#ffffff8c;font-size:14px}.cgu-main{color:#1a1a2e;max-width:720px;margin:0 auto;padding:38px 26px 46px;line-height:1.7}.cgu-intro{color:#6b6b7b;background:#fff;border-left:4px solid #e8533a;border-radius:0 12px 12px 0;margin-bottom:34px;padding:18px;font-size:15px}.cgu-intro strong{color:#1a1a2e}.cgu-main section{margin-bottom:34px}.cgu-num{letter-spacing:.12em;text-transform:uppercase;color:#e8533a;margin-bottom:6px;font-size:12px;font-weight:800}.cgu-main h2{color:#1a1a2e;border-bottom:1px solid #e2ddd6;margin-bottom:14px;padding-bottom:10px;font-size:20px;font-weight:800}.cgu-main p{color:#3a3a4a;margin-bottom:12px;font-size:15px}.cgu-pills{flex-wrap:wrap;gap:8px;margin:12px 0;padding:0;list-style:none;display:flex}.cgu-pills li{color:#2d5a8e;background:#eef2ff;border-radius:999px;padding:6px 12px;font-size:13px}.cgu-pills li:before{content:"✓ ";opacity:.6}.cgu-highlight{background:linear-gradient(135deg,#fff9f0,#fff4e6);border:1px solid #fde9c4;border-radius:12px;margin:14px 0;padding:14px 16px}.cgu-highlight p{margin:0;font-size:14px}.cgu-contact{color:#fff;background:#1a1a2e;border-radius:16px;margin-top:12px;padding:18px}.cgu-contact h3{margin-bottom:10px;font-size:18px}.cgu-contact a{color:#f4a24d;word-break:break-all;text-decoration:none}.cgu-contact a:hover{text-decoration:underline}.cgu-contact-note{color:#ffffffb3;margin-top:14px;font-size:14px}.cgu-footer{text-align:center;color:#1a1a2e73;margin-top:22px;font-size:13px}.cgu-bottombar{background:#111827;padding:10px 14px 12px}.cgu-back-btn{color:#fff;letter-spacing:1px;background:#7c3aed;border-color:#7c3aed;border-radius:16px;width:100%;padding:14px 16px;font-size:16px;font-weight:900}.oss-scrim{z-index:60;background:#0000008c;justify-content:center;align-items:stretch;padding:14px;display:flex;position:fixed;inset:0}.oss-panel{background:#0b0b0d;border:1px solid #ffffff1a;border-radius:18px;flex-direction:column;width:min(860px,100vw - 28px);height:calc(100vh - 28px);display:flex;overflow:hidden;box-shadow:0 24px 80px #0000008c}.oss-doc{-webkit-overflow-scrolling:touch;flex:1;padding:18px;overflow:auto}.oss-title{letter-spacing:.08em;text-transform:uppercase;color:#ffffffb8;margin-bottom:12px;font-size:14px;font-weight:800}.oss-pre{white-space:pre-wrap;word-break:break-word;color:#ffffffdb;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;line-height:1.5}.oss-bottombar{background:#111118;padding:10px 14px 12px}.oss-back-btn{color:#ffffffeb;letter-spacing:1px;background:#1a1a1f;border-color:#ffffff1f;border-radius:16px;width:100%;padding:14px 16px;font-size:16px;font-weight:900}@media (width<=520px){.cgu-panel{border-radius:16px;height:calc(100vh - 20px)}.cgu-scrim{padding:10px}.cgu-hero,.cgu-main{padding-left:18px;padding-right:18px}}.btn-sub.active{border-color:var(--accent);color:var(--accent);background:#20203a}.swing-grid-row{gap:6px;display:flex}.swing-row{justify-content:center;width:100%;margin-top:2px;display:flex}.btn-swing{letter-spacing:.02em;min-width:140px;font-weight:800}.btn-swing.active{color:#ffd38a;background:linear-gradient(135deg,#f59e0b33 0%,#a78bfa38 100%);border-color:#f59e0bcc;box-shadow:0 6px 22px #f59e0b29}.btn-grid.active{border-color:var(--accent);color:var(--accent);background:#20203a}.btn-silent{letter-spacing:.04em;padding:12px 22px;font-size:1.05rem;font-weight:700}.btn-silent.active{color:#f59e0b;border-color:#f59e0b}.btn-silent.active.muted{border-color:var(--muted);color:var(--muted);background:#111118}#flash-overlay{pointer-events:none;background:var(--beat);opacity:0;z-index:999;transition:opacity 70ms ease-out;position:fixed;inset:0}#flash-overlay.flash{opacity:.12;transition:none}@media (width<=700px){.main{flex-direction:column;align-items:center}.turntable-wrap,#turntable{width:300px;height:300px}.controls{width:100%}.bpm-row{gap:6px}}@media (orientation:landscape) and (height<=600px){html,body{height:100%;overflow:hidden}#app{justify-content:flex-start;gap:0;height:100%;padding:4px 12px}.header{flex-shrink:0;padding:2px 0}.logo{font-size:1.3rem}.subtitle{display:none}.main{flex:1;align-items:stretch;gap:16px;min-height:0}.turntable-wrap{aspect-ratio:1;flex-shrink:0;width:auto;height:100%}#turntable{width:100%;height:100%}.controls{justify-content:center;gap:8px}.bpm-row{gap:8px}.bpm-display{height:42px}#bpm-value{font-size:2rem}.btn-icon{width:42px;height:42px;font-size:.78rem;line-height:42px}.btn-play{width:54px;height:54px;font-size:1.3rem;line-height:54px}.btn-silent{padding:9px 16px;font-size:.94rem}.btn{padding:5px 9px;font-size:.7rem}.subdivision-row{gap:5px}.sub-btns{gap:4px}}
