:root{--bg: #140c09;--wood: #2a1712;--wood-red: #3a1b14;--panel: #100c09;--panel-soft: #19100c;--border: rgba(184, 128, 72, .42);--border-soft: rgba(184, 128, 72, .22);--text: #f0d6aa;--muted: #a87d55;--orange: #e8752c;--orange-soft: #b95623;--brass: #b8874d;--red: #7a2d24;--red-hi: #9d3d30;--black: #080604;color:var(--text);background:var(--bg);font-family:Times New Roman,SimSun,Songti SC,"Noto Serif CJK SC","Source Han Serif SC",serif;font-synthesis:none;line-height:1.35;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{overflow-x:hidden;background:radial-gradient(circle at 50% 0%,rgba(184,128,72,.12),transparent 24rem),linear-gradient(135deg,#0b0605 0%,var(--bg) 42%,#070403 100%)}button,input{font:inherit}button{border:1px solid rgba(214,176,115,.45);border-radius:9px;color:var(--text);cursor:pointer;font-weight:600;letter-spacing:.02em;box-shadow:inset 0 1px #ffe6b41f,inset 0 -4px 8px #00000059,0 3px 8px #00000059;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease,filter .12s ease}button:active{transform:translateY(1px);box-shadow:inset 0 1px 4px #00000073,0 1px 4px #00000040}button:disabled,input:disabled{cursor:not-allowed;opacity:.45;filter:saturate(.75)}.app-shell{width:100%;max-width:430px;min-height:100svh;margin:0 auto;padding:8px}.device{position:relative;overflow:hidden;width:100%;padding:8px;border:2px solid #090504;border-radius:18px;background:linear-gradient(90deg,rgba(255,220,160,.02) 0 1px,transparent 1px 8px),linear-gradient(145deg,var(--wood-red),var(--wood) 48%,#160c09 100%);box-shadow:inset 0 0 0 1px #d6b07324,inset 0 0 22px #0000009e,0 16px 36px #00000080}.device:before{position:absolute;top:6px;right:6px;bottom:6px;left:6px;z-index:0;pointer-events:none;content:"";border:1px solid rgba(184,128,72,.16);border-radius:13px}.device>*{position:relative;z-index:1}.top-bar,.player-window,.panel,.transport-row,.beat-footer{margin:0 0 8px;border:1px solid var(--border-soft);border-radius:12px;background:linear-gradient(#0c0806b8,#0c0806c7),url(/assets/ui/panel-bg.webp) center / cover,linear-gradient(180deg,var(--panel-soft),var(--panel));box-shadow:inset 0 1px #ffdca00f,0 4px 12px #00000059}.top-bar{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;min-height:36px;padding:6px 10px}.vent-slats{display:grid;grid-template-columns:repeat(12,1fr);gap:4px;max-width:190px}.vent-slats span{height:18px;border-radius:8px;background:#050403;box-shadow:inset 0 1px #ffdca00d}.ready-state{display:flex;gap:7px;align-items:center;color:var(--text);font-size:16px;white-space:nowrap}.pilot-light{width:15px;height:15px;border:1px solid rgba(240,215,170,.28);border-radius:50%;background:radial-gradient(circle at 36% 32%,#ffc7a0 0,#ffc7a0 12%,#8d251d 42%,#210706 74%);box-shadow:0 0 6px #e8752c6b}.pilot-light.is-playing{background:radial-gradient(circle at 36% 32%,#e5f2b6 0,#e5f2b6 12%,#82b86b 42%,#1a3517 76%);box-shadow:0 0 6px #82b86b6b}.player-window{display:grid;grid-template-columns:96px minmax(0,1fr);grid-template-rows:32px 25px 32px auto auto;gap:4px 10px;min-height:150px;padding:7px}.record-area{position:relative;grid-row:1 / 4;align-self:start;width:96px;aspect-ratio:1;overflow:hidden;border:1px solid rgba(111,74,47,.58);border-radius:10px;background:#0c0908;box-shadow:inset 0 0 0 1px #000000b8,inset 0 0 12px #000000ad}.vinyl{position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:8px;background:url(/assets/ui/player-vinyl.png) center / contain no-repeat}.vinyl span,.tone-arm{display:none}.track-area{display:contents;min-width:0}.loader-row{grid-column:2;display:grid;grid-template-columns:auto minmax(0,1fr);gap:6px;align-items:center}.file-button,.url-form button,.calibration-controls button,.loop-buttons button,.stepper-buttons button{min-height:34px;padding:0 10px;text-align:center}.file-button,.url-form button,.calibration-controls button,.loop-buttons button,.stepper-buttons button{background:linear-gradient(180deg,#c49a62,#7a5635);color:#130c08}.file-button{display:grid;place-items:center;white-space:nowrap}.file-button input{position:absolute;width:1px;height:1px;opacity:0}.url-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;min-width:0}.url-form input,.number-row input{min-width:0;border:1px solid var(--border-soft);border-radius:8px;background:#070504;color:var(--text);box-shadow:inset 0 2px 8px #000000b3}.url-form input{height:34px;padding:0 9px;color:var(--muted);font-size:13px}.track-area h1{grid-column:2;min-width:0;margin:0;overflow:hidden;color:var(--text);font-size:clamp(18px,5vw,21px);font-weight:600;line-height:1.24;text-overflow:ellipsis;white-space:nowrap}.wave-line{grid-column:2;display:flex;height:34px;align-items:center;justify-content:center;gap:2px;overflow:hidden;padding:0 6px}.wave-line span{width:2px;max-width:3px;flex:1 1 2px;border-radius:999px;background:var(--orange);opacity:.48;box-shadow:0 0 3px #e8752c2e}.wave-line.has-waveform span{opacity:.82}.time-row,.slider-header{display:flex;justify-content:space-between;gap:10px;color:var(--text);font-size:15px}.player-window .time-row{grid-column:1 / -1;margin-top:0;font-size:14px}.progress{grid-column:1 / -1;margin-top:0}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:16px;margin:0;background:transparent}input[type=range]::-webkit-slider-runnable-track{height:5px;border:1px solid rgba(184,128,72,.32);border-radius:999px;background:linear-gradient(180deg,#080605,#1a120e);box-shadow:inset 0 1px 3px #000000d1}input[type=range]::-webkit-slider-thumb{width:18px;height:18px;margin-top:-7px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(240,215,170,.55);border-radius:6px;background:linear-gradient(90deg,#6e472b,#d0a66a,#6e472b);box-shadow:inset 0 1px #fff3,0 2px 5px #00000061}input[type=range]::-moz-range-track,input[type=range]::-moz-range-progress{height:5px;border-radius:999px}input[type=range]::-moz-range-track{border:1px solid rgba(184,128,72,.32);background:#100b09}input[type=range]::-moz-range-progress{background:var(--orange-soft)}input[type=range]::-moz-range-thumb{width:18px;height:18px;border:1px solid rgba(240,215,170,.55);border-radius:6px;background:linear-gradient(90deg,#6e472b,#d0a66a,#6e472b);box-shadow:0 2px 5px #00000061}.transport-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;min-height:58px;padding:7px}.transport-button{display:grid;gap:2px;place-items:center;min-height:46px;background:linear-gradient(180deg,#211713,#0e0a08);color:var(--text)}.transport-button.play{background:linear-gradient(180deg,var(--red-hi),var(--red));color:#f5dfb7}.transport-button span{font-size:15px}.transport-button b{color:#f0d7aadb;font-size:18px;line-height:1}.panel{padding:9px 11px}.calibration-panel{min-height:78px;padding-block:7px;text-align:center}.calibration-readout{margin-bottom:6px;color:var(--text);font-size:14px}.calibration-controls{display:grid;grid-template-columns:1fr 1.38fr 1fr .82fr;gap:7px}.calibration-controls button{min-width:0;min-height:38px;padding:0 7px;white-space:normal}.calibration-controls .set-downbeat{font-size:16px}.calibration-controls button:last-child,.transport-button:not(.play){background:linear-gradient(180deg,#211713,#0e0a08);color:var(--text)}.beat-settings{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr) minmax(0,1fr);gap:7px;min-height:100px}.number-control{min-width:0;text-align:center}.number-control label{display:block;min-height:1.5em;margin-bottom:5px;color:var(--text);font-size:14px;line-height:1.15}.number-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:5px}.number-row input{height:60px;padding:0 3px;text-align:center;color:var(--orange);font-size:clamp(34px,8.8vw,41px);font-weight:650;letter-spacing:0;text-shadow:0 0 5px rgba(232,117,44,.22)}.number-row input:focus,.url-form input:focus{outline:2px solid rgba(184,128,72,.38);outline-offset:2px}.stepper-buttons{display:grid;grid-template-rows:1fr 1fr;gap:4px}.stepper-buttons button{min-height:29px;padding:0;font-size:12px;line-height:1}.slider-panel{min-height:60px;padding-block:6px}.slider-panel p{margin:1px 0 0;color:var(--text);font-size:13px;line-height:1.15}.slider-header strong{color:var(--text);font-size:16px}.panel-title{margin-bottom:5px;color:var(--text);text-align:center;font-size:15px;font-weight:500}.loop-panel{min-height:84px;padding-block:6px}.loop-buttons{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.loop-buttons button{min-height:32px;padding:0 5px;font-size:13px}.loop-buttons .active,.loop-buttons button:nth-child(3){background:linear-gradient(180deg,var(--red-hi),var(--red));color:#f5dfb7}.loop-readout{display:flex;justify-content:center;gap:10px;height:27px;margin-top:3px;padding:3px 8px;border:1px solid var(--border-soft);border-radius:8px;background:#050403;color:var(--orange);font-size:13px}.mixer-panel{display:grid;min-height:68px;gap:4px;padding-block:8px}.volume-row{display:grid;grid-template-columns:76px minmax(0,1fr) 40px;gap:8px;align-items:center;min-height:26px;color:var(--text);font-size:15px}.volume-row strong{color:var(--text);text-align:right;font-size:15px}.status-message{margin:0 0 8px;padding:6px 8px;border:1px solid rgba(123,47,37,.72);border-radius:9px;background:#7b2f252e;color:var(--text);font-size:13px}.beat-footer{display:grid;grid-template-columns:minmax(0,1fr) minmax(120px,158px) minmax(0,1fr);gap:7px;align-items:center;min-height:68px;margin-bottom:0;padding:5px}.speaker-grille{height:34px;border-radius:8px;background:linear-gradient(#0a070661,#0a07067a),url(/assets/ui/speaker-grille.webp) center / cover;opacity:.62;box-shadow:inset 0 0 10px #000000b8}.beat-status{display:grid;gap:6px;place-items:center;padding:5px;border:1px solid rgba(184,128,72,.28);border-radius:9px;background:#080605}.beat-status>span{color:var(--text);font-size:15px}.beat-status>span.playing{color:var(--text);text-shadow:none}.beat-lights{display:grid;width:100%;gap:clamp(3px,1vw,6px);align-items:center}.beat-lights i{aspect-ratio:1;min-width:0;border:0;border-radius:50%;background:url(/assets/ui/beat-light-off.png) center / contain no-repeat;box-shadow:none}.beat-lights i.active,.beat-lights i.downbeat.active{background:url(/assets/ui/beat-light-on.png) center / contain no-repeat;box-shadow:0 0 6px #e8752c61}@media (max-width: 390px){.app-shell{padding:6px}.device{padding:7px;border-radius:16px}.top-bar,.player-window,.panel,.transport-row,.beat-footer{margin-bottom:6px}.player-window{grid-template-columns:88px minmax(0,1fr);grid-template-rows:30px 23px 30px auto auto;min-height:142px;gap:4px 8px;padding:6px}.record-area{width:88px}.file-button,.url-form button,.calibration-controls button,.loop-buttons button,.stepper-buttons button{font-size:13px}.track-area h1{font-size:18px;line-height:1.24}.wave-line{height:32px;padding:0 4px}.transport-row{min-height:56px;padding:7px}.transport-button{min-height:44px}.transport-button span{font-size:13px}.transport-button b{font-size:16px}.panel{padding:7px 9px}.calibration-panel{min-height:76px}.calibration-readout{margin-bottom:6px;font-size:13px}.calibration-controls{gap:5px}.calibration-controls button{min-height:38px;font-size:12px}.calibration-controls .set-downbeat{font-size:13px}.beat-settings{min-height:96px;gap:5px}.number-control label{min-height:1.4em;margin-bottom:3px;font-size:11px}.number-row{grid-template-columns:minmax(0,1fr) 30px;gap:4px}.number-row input{height:56px;font-size:clamp(28px,7.6vw,36px)}.stepper-buttons button{min-height:26px;font-size:11px}.slider-panel{min-height:58px;padding-block:6px}.slider-header strong{font-size:14px}.slider-panel p{margin-top:1px;font-size:12px}.loop-panel{min-height:82px;padding-block:6px}.panel-title{margin-bottom:4px;font-size:14px}.loop-buttons{gap:5px}.loop-buttons button{min-height:31px;font-size:12px}.loop-readout{height:27px;margin-top:4px;padding:3px 6px;font-size:12px}.mixer-panel{min-height:58px;gap:3px;padding-block:6px}.volume-row{grid-template-columns:68px minmax(0,1fr) 36px;gap:6px;min-height:24px;font-size:12px}.volume-row strong{font-size:12px}.beat-footer{grid-template-columns:minmax(0,1fr) minmax(108px,142px) minmax(0,1fr);min-height:64px;padding:5px}.speaker-grille{height:32px}.beat-status{gap:4px;padding:5px}.beat-status>span{font-size:13px}}@media (max-height: 760px){.app-shell{padding:5px}.device{padding:6px}.top-bar,.player-window,.panel,.transport-row,.beat-footer{margin-bottom:5px}.top-bar{min-height:32px;padding:4px 8px}.vent-slats span{height:14px}.ready-state{font-size:13px}.pilot-light{width:12px;height:12px}.player-window{grid-template-columns:74px minmax(0,1fr);grid-template-rows:28px 19px 26px auto auto;min-height:132px;gap:4px 7px;padding:6px}.record-area{width:74px}.file-button,.url-form button,.calibration-controls button,.loop-buttons button,.stepper-buttons button{min-height:28px}.url-form input{height:28px}.track-area h1{margin:1px 0;font-size:14px;line-height:1.25}.wave-line{height:26px;gap:1px}.time-row,.slider-header{font-size:11px}input[type=range]{height:14px}.transport-row{min-height:50px;padding:6px}.transport-button{min-height:38px}.panel{padding:7px 9px}.calibration-panel{min-height:70px}.calibration-controls button{min-height:34px}.beat-settings{min-height:88px}.number-row input{height:48px;font-size:clamp(24px,6.8vw,30px)}.stepper-buttons button{min-height:22px}.slider-panel{min-height:56px}.slider-panel p{margin-top:0;font-size:12px}.loop-panel{min-height:78px}.loop-buttons button{min-height:32px}.loop-readout{height:28px;margin-top:4px;padding:4px 6px}.mixer-panel{min-height:58px;gap:3px}.volume-row{min-height:24px}.beat-footer{min-height:62px}.speaker-grille{height:30px}}
