@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap";:root{--bg-0:#0a0b0c;--bg-1:#111214;--bg-2:#18191c;--line:#ffffff14;--line-strong:#ffffff29;--fg:#ececec;--fg-mid:#ecececa6;--fg-low:#ececec6b;--fg-faint:#ececec38;--accent:#d21e1e;--sans:"Inter", "Noto Sans JP", system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, monospace;--jp:"Noto Sans JP", "Inter", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-0);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5;overflow:hidden}.muted{color:var(--fg-low)}.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}.small{font-size:11px}.xs{font-size:10px}.lg{font-size:24px}.accent-text{color:var(--accent)}.kicker{letter-spacing:.18em;text-transform:uppercase;color:var(--fg-low);margin-bottom:12px;font-size:11px}.btn{appearance:none;border:1px solid var(--line-strong);color:var(--fg);font-family:var(--mono);letter-spacing:.12em;cursor:pointer;background:#ffffff05;border-radius:2px;justify-content:center;align-items:center;gap:16px;padding:14px 22px;font-size:12px;font-weight:500;transition:all .18s;display:inline-flex}.btn:hover{background:#ffffff0d;border-color:#ffffff47}.btn-arrow{font-family:var(--sans);font-size:14px;transition:transform .18s}.btn:hover .btn-arrow{transform:translate(4px)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:color-mix(in srgb, var(--accent) 85%, white);box-shadow:0 0 24px color-mix(in srgb, var(--accent) 40%, transparent)}.btn-ghost{background:0 0}.game-screen{width:100%;height:100vh;position:relative;overflow:hidden}.game-canvas-wrap{position:absolute;inset:0}.hud{z-index:10;pointer-events:none;padding:24px 36px;display:flex;position:absolute;left:0;right:0}.hud>*{pointer-events:auto}.hud-top{justify-content:space-between;align-items:flex-start;top:0}.hud-block{flex-direction:column;gap:4px;min-width:140px;display:flex}.hud-block.right{align-items:flex-end;gap:8px}.hud-block.left{gap:8px}.hud-label{letter-spacing:.18em;color:var(--fg-low);text-transform:uppercase;font-size:10px}.hud-value{font-family:var(--mono);letter-spacing:.08em;font-size:16px}.hud-center{flex-direction:column;align-items:center;gap:2px;display:flex}.hud-time{letter-spacing:-.01em;font-variant-numeric:tabular-nums;font-size:32px;font-weight:500;line-height:1}.hud-unit{color:var(--fg-low);margin-left:2px;font-size:14px}.hud-score{letter-spacing:.04em;color:var(--accent);font-size:22px;font-weight:500;line-height:1}.hud-precision{align-items:center;gap:8px;margin-top:4px;display:flex}.hud-precision .xs{color:var(--fg-low);text-align:right;min-width:30px}.time-bar{background:var(--line);width:240px;height:2px;position:relative;overflow:hidden}.time-bar-fill{background:var(--fg);transform-origin:0;transition:transform .1s linear;position:absolute;inset:0}.meter{gap:2px;height:14px;display:flex}.meter-cell{background:var(--line);width:5px;transition:background 60ms linear,box-shadow 60ms linear}.meter-cell.on{background:var(--accent);box-shadow:0 0 6px color-mix(in srgb, var(--accent) 60%, transparent)}.ctrl-pill{appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line-strong);color:var(--fg);cursor:pointer;letter-spacing:.12em;font-family:var(--mono);background:#141416b3;border-radius:2px;align-items:center;gap:12px;padding:10px 16px;transition:all .15s;display:inline-flex}.ctrl-pill:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.ctrl-pill:disabled{opacity:.4;cursor:not-allowed}.kbd{border:1px solid var(--line);color:var(--fg-low);letter-spacing:.08em;border-radius:2px;padding:2px 6px}.countdown-overlay{pointer-events:none;z-index:20;position:absolute;inset:0}.countdown-num{letter-spacing:-.04em;color:var(--fg);text-shadow:0 0 40px #000000d9, 0 0 80px color-mix(in srgb, var(--accent) 35%, transparent);font-size:140px;font-weight:500;line-height:1;animation:1s cubic-bezier(.2,.7,.2,1) countPulse;position:absolute;top:14%;left:50%;transform:translate(-50%)}.countdown-sub{letter-spacing:.3em;white-space:nowrap;text-shadow:0 0 12px #000000e6;position:absolute;top:calc(14% + 150px);left:50%;transform:translate(-50%)}@keyframes countPulse{0%{opacity:0;transform:translate(-50%)scale(.6)}30%{opacity:1;transform:translate(-50%)scale(1)}to{opacity:.85;transform:translate(-50%)scale(1.05)}}.tip-marker{pointer-events:none;width:0;height:0;transition:left 50ms linear,top 50ms linear;position:absolute;transform:translate(-50%,-50%)}.tip-marker-ring{border:1.5px solid var(--accent);width:36px;height:36px;box-shadow:0 0 20px color-mix(in srgb, var(--accent) 60%, transparent);border-radius:50%;margin:-18px 0 0 -18px;animation:1s ease-out infinite tipPulse;position:absolute;top:0;left:0}.tip-marker-ring:after{content:"";border:1px solid color-mix(in srgb, var(--accent) 40%, transparent);border-radius:50%;animation:1s ease-out .3s infinite tipPulse;position:absolute;inset:-10px}.tip-marker-label{font-family:var(--mono);letter-spacing:.25em;color:var(--accent);white-space:nowrap;text-shadow:0 0 12px #000000e6,0 0 4px #000000e6;font-size:10px;position:absolute;top:26px;left:50%;transform:translate(-50%)}@keyframes tipPulse{0%{opacity:1;transform:scale(.7)}to{opacity:0;transform:scale(1.6)}}.pause-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:20;background:#0a0b0cb3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.pause-card{background:var(--bg-1);border:1px solid var(--line-strong);text-align:center;border-radius:2px;flex-direction:column;align-items:center;gap:20px;min-width:360px;padding:36px 44px;display:flex}.pause-mode{letter-spacing:.16em;color:var(--accent);margin-top:-8px;font-size:18px}.pause-stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);justify-content:center;gap:48px;width:100%;padding:16px 0;display:flex}.pause-stats .lg{font-size:28px;font-weight:500}.pause-actions{flex-direction:column;gap:8px;width:100%;display:flex}.pause-actions .btn{justify-content:center;width:100%}.app{width:100%;height:100%;position:relative;overflow:hidden}.backdrop{background:radial-gradient(ellipse 80% 60% at 50% 50%, #ffffff06, transparent 70%), linear-gradient(180deg, var(--bg-1), var(--bg-0));pointer-events:none;position:absolute;inset:0}.backdrop:before{content:"";background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-position:-1px -1px;background-size:80px 80px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(90% 80%,#000 30%,#0000 90%);mask-image:radial-gradient(90% 80%,#000 30%,#0000 90%)}.screen{z-index:1;flex-direction:column;animation:.45s cubic-bezier(.2,.7,.2,1) screenIn;display:flex;position:absolute;inset:0;overflow-y:auto}.screen.pad{padding:28px 40px}@keyframes screenIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chrome{z-index:5;justify-content:space-between;align-items:center;padding:0 0 24px;display:flex;position:relative}.chrome-l,.chrome-r{font-family:var(--mono);letter-spacing:.04em;align-items:center;gap:8px;font-size:11px;display:flex}.link-back{appearance:none;color:var(--fg-mid);font-family:var(--mono);letter-spacing:.1em;cursor:pointer;background:0 0;border:0;padding:4px 0;font-size:11px}.link-back:hover{color:var(--fg)}.centered-stack{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;max-width:1100px;margin:0 auto;padding:20px;display:flex}.centered-stack.wide{max-width:1280px}.screen-title{font-family:var(--jp);letter-spacing:-.01em;margin:0 0 40px;font-size:clamp(28px,4vw,44px);font-weight:600}.btn.lg{padding:18px 32px;font-size:13px}.btn.small{gap:6px;padding:8px 14px;font-size:10px}.start-glow{box-shadow:0 0 32px color-mix(in srgb, var(--accent) 25%, transparent)}.title-screen{padding:28px 40px}.title-stage{flex:1;grid-template-columns:1fr 1fr;align-items:center;gap:60px;padding:0 20px;display:grid}.title-pendulum{aspect-ratio:1;width:100%;max-width:540px;margin:0 auto;position:relative}.title-text{padding-left:20px}.hero-title{font-family:var(--jp);letter-spacing:-.02em;margin:0 0 28px;font-size:clamp(64px,10vw,140px);font-weight:700;line-height:.92}.hero-title .accent{color:var(--accent);text-shadow:0 0 24px color-mix(in srgb, var(--accent) 50%, transparent)}.hero-sub{color:var(--fg-mid);font-family:var(--jp);letter-spacing:.02em;margin:0 0 40px;font-size:17px}.cta-row{align-items:center;gap:20px;display:flex}.mode-grid{grid-template-columns:1fr 1fr;gap:20px;width:100%;max-width:880px;display:grid}.mode-card{appearance:none;text-align:left;background:var(--bg-1);border:1px solid var(--line);cursor:pointer;color:inherit;border-radius:2px;flex-direction:column;gap:16px;min-height:280px;padding:32px;font-family:inherit;transition:all .2s;display:flex}.mode-card:hover{border-color:var(--line-strong);background:var(--bg-2);transform:translateY(-2px)}.mode-card.primary:hover{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent), 0 0 32px color-mix(in srgb, var(--accent) 12%, transparent)}.mode-card-top{justify-content:space-between;align-items:center;display:flex}.mode-card-arrow{color:var(--fg-low);font-size:18px;transition:all .2s}.mode-card:hover .mode-card-arrow{color:var(--accent);transform:translate(4px)}.mode-card-titles{flex-direction:column;gap:4px;margin-top:8px;display:flex}.mode-card-jp{font-family:var(--jp);letter-spacing:-.01em;font-size:28px;font-weight:600}.mode-card-en{letter-spacing:.2em;color:var(--fg-low);font-size:11px}.mode-card-desc{color:var(--fg-mid);font-family:var(--jp);flex:1;margin:0}.mode-card-meta{color:var(--fg-low);border-top:1px solid var(--line);flex-direction:column;gap:4px;margin:0;padding:16px 0 0;list-style:none;display:flex}.bobs-toggle{align-items:center;gap:18px;margin-bottom:28px;display:flex}.bobs-toggle-lbl{letter-spacing:.2em}.lg-seg .seg-btn{letter-spacing:.15em;padding:10px 28px;font-size:13px}.seg{border:1px solid var(--line-strong);border-radius:2px;align-self:flex-start;display:inline-flex;overflow:hidden}.seg-btn{appearance:none;color:var(--fg-mid);font-family:var(--mono);cursor:pointer;background:0 0;border:0;padding:8px 18px;font-size:12px;transition:all .15s}.seg-btn+.seg-btn{border-left:1px solid var(--line-strong)}.seg-btn.on{background:var(--accent);color:#fff}.seg-btn:hover:not(.on){background:#ffffff0a}.diff-grid{grid-template-columns:1fr 1fr 1fr;gap:16px;width:100%;margin-bottom:32px;display:grid}.diff-card{appearance:none;background:var(--bg-1);border:1px solid var(--line);cursor:pointer;text-align:left;color:inherit;border-radius:2px;flex-direction:column;gap:12px;padding:16px;font-family:inherit;transition:all .18s;display:flex;position:relative}.diff-card:hover{background:var(--bg-2);border-color:var(--line-strong)}.diff-card.selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, var(--bg-1));box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent), inset 0 0 60px color-mix(in srgb, var(--accent) 6%, transparent)}.diff-preview{background:var(--bg-0);border:1px solid var(--line);aspect-ratio:1;border-radius:2px;width:100%}.diff-preview svg{width:100%;height:100%;display:block}.diff-card-foot{border-top:1px solid var(--line);flex-direction:column;gap:4px;padding-top:10px;display:flex}.diff-foot-row{justify-content:space-between;align-items:baseline;display:flex}.diff-selected-bar{background:var(--accent);width:100%;height:2px;box-shadow:0 0 12px var(--accent);position:absolute;bottom:0;left:0}.diff-cta{justify-content:center;align-items:center;gap:24px;display:flex}.diff-cta .muted{letter-spacing:.15em}.result-layout{flex:1;grid-template-columns:1fr 320px;align-items:center;gap:60px;width:100%;max-width:1100px;margin:0 auto;padding-top:20px;display:grid}.result-main{flex-direction:column;gap:16px;display:flex}.new-record{border:1px solid var(--accent);color:var(--accent);letter-spacing:.2em;background:color-mix(in srgb, var(--accent) 8%, transparent);border-radius:2px;align-self:flex-start;align-items:center;gap:10px;padding:8px 14px;font-size:11px;animation:1.4s ease-in-out infinite blink;display:inline-flex}@keyframes blink{0%,to{opacity:1}50%{opacity:.55}}.new-record-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 10px var(--accent);border-radius:50%}.big-score{letter-spacing:-.04em;font-variant-numeric:tabular-nums;color:var(--fg);margin:16px 0;font-size:clamp(80px,14vw,180px);font-weight:500;line-height:.9}.result-meta{border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-direction:column;gap:8px;max-width:480px;margin-top:8px;padding:16px 0;display:flex}.result-meta-row{font-family:var(--jp);justify-content:space-between;align-items:baseline;font-size:14px;display:flex}.result-cta{gap:12px;margin-top:24px;display:flex}.result-actions{gap:8px;margin-top:12px;display:flex}.result-side{border:1px solid var(--line);background:var(--bg-1);border-radius:2px;flex-direction:column;gap:16px;padding:24px;display:flex}.result-stat{flex-direction:column;gap:4px;display:flex}.result-stat .lg{letter-spacing:-.01em;font-size:32px}.result-bar{background:var(--line);height:4px;margin-top:16px;position:relative}.result-bar-fill{background:var(--accent);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 50%, transparent);transition:width 1s cubic-bezier(.2,.7,.2,1);position:absolute;top:0;bottom:0;left:0}.result-pct{font-size:24px;font-weight:500}.result-pct .muted{margin-left:6px;font-size:12px}.custom-layout{flex:1;grid-template-columns:380px 1fr;align-items:stretch;gap:40px;min-height:0;padding-top:8px;display:grid}.custom-controls{scrollbar-width:thin;scrollbar-color:var(--line-strong) var(--bg-0);scrollbar-gutter:stable;padding-right:8px;overflow-y:auto}.custom-controls::-webkit-scrollbar{width:6px}.custom-controls::-webkit-scrollbar-track{background:var(--bg-0)}.custom-controls::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}.custom-controls::-webkit-scrollbar-thumb:hover{background:var(--fg-low)}.custom-controls .screen-title{text-align:left;margin-bottom:28px}.custom-controls .kicker{text-align:left}.ctrl-block{border-top:1px solid var(--line);flex-direction:column;gap:10px;padding:16px 0;display:flex}.ctrl-block:first-of-type{border-top:0;padding-top:0}.ctrl-label{font-family:var(--jp);justify-content:space-between;align-items:baseline;font-size:14px;font-weight:500;display:flex}.ctrl-label.tight{margin-top:12px}.cslider{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;height:32px;display:flex;position:relative}.cslider-track{background:var(--line);width:100%;height:1px;position:relative}.cslider-tick{background:var(--line-strong);width:1px;height:7px;position:absolute;top:-3px;transform:translate(-50%)}.cslider-fill{background:var(--accent);box-shadow:0 0 6px color-mix(in srgb, var(--accent) 50%, transparent);position:absolute;top:0;bottom:0;left:0}.cslider-handle{pointer-events:none;justify-content:center;align-items:center;width:14px;height:22px;display:flex;position:absolute;top:50%;transform:translate(-50%,-50%)}.cslider-handle:before{content:"";background:var(--bg-0);border:1px solid var(--accent);box-shadow:0 0 12px color-mix(in srgb, var(--accent) 40%, transparent);border-radius:1px;position:absolute;inset:0}.cslider-handle-line{background:var(--accent);z-index:1;width:1px;height:10px;position:absolute}.angle-dial{cursor:grab;-webkit-user-select:none;user-select:none;width:110px;height:110px}.angle-dial:active{cursor:grabbing}.angle-dial svg{width:100%;height:100%;display:block}.custom-preview{flex-direction:column;align-items:stretch;gap:20px;min-height:0;display:flex}.preview-frame{border:1px solid var(--line);background:radial-gradient(#ffffff05,#0000 70%);border-radius:2px;flex:1;min-height:0;position:relative}.preview-canvas{position:absolute;inset:0}.preview-meta-bar{letter-spacing:.1em;pointer-events:none;justify-content:flex-end;gap:16px;display:flex;position:absolute;top:14px;left:14px;right:14px}.custom-cta-row{justify-content:flex-end;align-items:stretch;gap:14px;padding-top:18px;display:flex}.preview-toggle-pill{appearance:none;background:var(--bg-1);border:1px solid var(--line-strong);color:var(--fg-mid);cursor:pointer;letter-spacing:.1em;border-radius:2px;align-items:center;gap:10px;height:auto;padding:0 22px;font-family:inherit;transition:all .15s;display:inline-flex}.preview-toggle-pill:hover{border-color:var(--accent);color:var(--accent)}.preview-toggle-pill svg{width:14px;height:14px}.custom-cta-meta{text-align:right;letter-spacing:.15em;padding-top:8px}@media (width<=900px){.hud{padding:16px 20px}.hud-block{min-width:80px}.title-stage{grid-template-columns:1fr;gap:20px}.title-text{text-align:center;padding-left:0}.cta-row{justify-content:center}.mode-grid{grid-template-columns:1fr}.mode-card{min-height:200px;padding:24px}.diff-grid{grid-template-columns:1fr}.result-layout{grid-template-columns:1fr;gap:32px;padding-top:0}.result-side{padding:20px}.custom-layout{grid-template-columns:1fr;gap:24px}.custom-controls{max-height:360px}.preview-frame{min-height:320px}.screen.pad{padding:20px}.time-bar{width:160px}}@media (width<=600px){.result-cta,.result-actions{flex-wrap:wrap}}@media (width<=480px){.hud-time{font-size:24px}.time-bar{width:120px}.meter{gap:1px;height:12px}.meter-cell{width:4px}.hud-score{font-size:18px}.ctrl-pill{gap:6px;padding:8px 12px}.ctrl-pill .kbd{display:none}.hero-title{margin-bottom:20px;font-size:clamp(48px,14vw,80px)}.hero-sub{margin-bottom:28px;font-size:14px}.pause-card{min-width:0;max-width:92vw;padding:24px 20px}.pause-stats{gap:24px}.pause-stats .lg{font-size:22px}.result-stat .lg{font-size:24px}.result-pct{font-size:20px}.diff-card{padding:12px}.diff-card-foot .mono.xs{font-size:9px}.diff-cta{flex-direction:column;gap:12px}.custom-layout{gap:16px}.custom-controls{max-height:320px}.preview-frame{min-height:260px}.ctrl-block{padding:12px 0}.btn.lg{padding:14px 22px;font-size:12px}}
