.shooter-wrapper{position:relative;width:100%;height:100vh;overflow:hidden}.shooter-nav-header{display:flex;align-items:center;justify-content:center;margin-bottom:14px;padding:2px 0}.shooter-nav-header .nav-spacer{flex:1}.shooter-home-logo{display:block;text-decoration:none}.shooter-logo-img{height:28px;width:auto;opacity:.9;transition:opacity .2s}.shooter-home-logo:hover .shooter-logo-img{opacity:1}.shooter-wrapper .piece-list-title{font-size:14px;font-weight:700;color:#d2e6ffe6;letter-spacing:.02em;margin-bottom:10px;text-align:center}.shooter-wrapper .piece-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;width:100%;border:1px solid rgba(166,216,255,.2);border-radius:12px;padding:12px 14px;margin-bottom:8px;color:#eaf8ff;cursor:pointer;font-size:13px;font-weight:600;background:linear-gradient(180deg,#28486e4d,#122a484d);transition:background .15s,border-color .15s}.shooter-wrapper .piece-card:hover{background:linear-gradient(180deg,#37649666,#1c3c6466);border-color:#64b4ff66}.shooter-wrapper .piece-card-title{font-size:14px;font-weight:700;margin-bottom:4px}.shooter-wrapper .piece-card-meta{font-size:11px;font-weight:400;color:#a5bdd9cc}.shooter-wrapper .back-btn{width:100%;border:1px solid rgba(166,216,255,.25);border-radius:10px;padding:8px 12px;margin-bottom:10px;color:#b4d2f0e6;cursor:pointer;font-size:12px;font-weight:600;text-align:left;background:#1932504d;transition:background .15s,color .15s}.shooter-wrapper .back-btn:hover{background:#284b7366;color:#fff}@media(max-width:960px){.shooter-wrapper .mobile-menu-btn{left:auto;right:10px}}.shooter-wrapper .sound-toggles{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}.shooter-wrapper .sound-toggle-btn{margin:0;padding:7px 6px;border-radius:8px;font-size:12px;opacity:.5}.shooter-wrapper .sound-toggle-btn.active{opacity:1;border-color:#82f5b4b3;background:linear-gradient(180deg,#44a07880,#1e60488c);color:#effff5}.shooter-wrapper{--ink: #e9f2ff;--muted: #9ab0c8;--glass: rgba(12, 20, 34, .8);--line: rgba(170, 210, 255, .22);--danger: #ff99a1;--good: #a4ffc5;--warn: #ffd59d;color:var(--ink);font-family:Space Grotesk,Avenir Next,Trebuchet MS,sans-serif;background:radial-gradient(1200px 600px at 14% -10%,#0d1520 0%,transparent 60%),radial-gradient(900px 500px at 100% 0%,#080e18 0%,transparent 58%),#030508}.shooter-wrapper #shooter-app{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr);height:100%;min-height:100%}.shooter-wrapper #panel{border-right:1px solid var(--line);background:linear-gradient(180deg,#1c2d4773,#080e1be0);padding:14px;overflow:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.shooter-wrapper h1{margin:0 0 12px;font-size:19px;line-height:1.2;letter-spacing:.02em}.shooter-wrapper .card{margin-bottom:10px;border:1px solid var(--line);border-radius:14px;padding:10px;background:var(--glass)}.shooter-wrapper .row{display:flex;justify-content:space-between;gap:12px;margin:6px 0;font-size:13px;line-height:1.25}.shooter-wrapper .label{color:var(--muted)}.shooter-wrapper .mono{font-family:IBM Plex Mono,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.shooter-wrapper .ok{color:var(--good)}.shooter-wrapper .warn{color:var(--warn)}.shooter-wrapper .bad{color:var(--danger)}.shooter-wrapper button{width:100%;border:1px solid rgba(166,216,255,.36);border-radius:12px;padding:10px 12px;color:#eaf8ff;cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.02em;background:linear-gradient(180deg,#4578a259,#193b6259);margin-bottom:8px}.shooter-wrapper button:hover{background:linear-gradient(180deg,#538bb873,#224b7980)}.shooter-wrapper select{width:100%;border:1px solid rgba(166,216,255,.32);border-radius:10px;padding:8px 10px;margin-top:6px;color:#dcecff;font-size:12px;background:linear-gradient(180deg,#29426459,#0f233a73)}.shooter-wrapper select:disabled{opacity:.6;cursor:not-allowed}.shooter-wrapper input[type=range]{width:100%;margin:4px 0 2px;accent-color:#85d2ff}.shooter-wrapper .section-nav{display:flex;flex-direction:column;gap:4px;margin-top:6px}.shooter-wrapper .section-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:6px;align-items:stretch}.shooter-wrapper .section-btn{width:100%;border:1px solid rgba(166,216,255,.2);border-radius:8px;padding:6px 10px;color:var(--muted);cursor:pointer;font-size:11px;font-weight:500;text-align:left;background:#19325040;transition:background .15s,color .15s,border-color .15s}.shooter-wrapper .section-row .section-btn{margin-bottom:0}.shooter-wrapper .section-subhead{margin-top:8px;margin-bottom:2px;padding:2px 2px 4px;color:#c6dcf5c7;font-size:11px;font-weight:700;letter-spacing:.02em}.shooter-wrapper .section-submeta{margin-top:-2px;margin-bottom:4px;padding:0 2px 2px;color:#a5bdd9cc;font-size:10px;font-weight:500}.shooter-wrapper .section-btn:hover{background:#325a8259;color:var(--ink)}.shooter-wrapper .section-btn.active{background:linear-gradient(180deg,#458cc866,#1e508c66);border-color:#64b4ff80;color:#fff;font-weight:600}.shooter-wrapper .section-btn .section-desc{display:block;font-size:10px;color:var(--muted);margin-top:2px;font-weight:400}.shooter-wrapper .section-btn.active .section-desc{color:#c8e1ffb3}.shooter-wrapper .section-play-btn{width:34px;min-width:34px;margin-bottom:0;padding:0;border-radius:8px;text-align:center;font-size:12px;font-weight:700;background:linear-gradient(180deg,#38668e66,#18385d66)}.shooter-wrapper .section-play-btn.playing{border-color:#82f5b4b3;background:linear-gradient(180deg,#44a07880,#1e60488c);color:#effff5}.shooter-wrapper .practice-timer-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.shooter-wrapper .practice-timer-controls .timer-btn{margin:0;padding:7px 6px;border-radius:8px;font-size:12px}.shooter-wrapper .break-reminder{position:fixed;inset:0;z-index:2200;display:none;align-items:center;justify-content:center;padding:24px;background:#02070eb8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.shooter-wrapper .break-reminder.show{display:flex}.shooter-wrapper .break-reminder-card{position:relative;width:min(520px,100%);border:1px solid rgba(150,220,255,.5);border-radius:16px;padding:20px 18px 16px;background:linear-gradient(180deg,#162d4eeb,#0a172cf0);box-shadow:0 18px 40px #00000073;text-align:center}.shooter-wrapper .break-title{margin:0 0 8px;font-size:26px;letter-spacing:.02em;color:#ecf7fffa}.shooter-wrapper .break-text{margin:0 0 14px;font-size:15px;line-height:1.45;color:#d2e4f5f2}.shooter-wrapper .break-reminder-close{width:auto;min-width:150px;margin:0 auto;padding:8px 14px}.shooter-wrapper .break-fireworks{position:absolute;inset:0;pointer-events:none;overflow:hidden}.shooter-wrapper .firework{position:absolute;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);opacity:0;animation:shooter-burst 1.7s ease-out infinite}.shooter-wrapper .firework:before,.shooter-wrapper .firework:after{content:"";position:absolute;inset:0;border-radius:50%}.shooter-wrapper .firework:before{background:radial-gradient(circle,rgba(255,255,255,.95) 0 14%,transparent 15%),radial-gradient(circle at 15% 45%,rgba(255,110,80,.95) 0 18%,transparent 19%),radial-gradient(circle at 85% 45%,rgba(120,225,255,.95) 0 18%,transparent 19%),radial-gradient(circle at 50% 85%,rgba(130,255,170,.95) 0 18%,transparent 19%);transform:scale(1)}.shooter-wrapper .firework:after{border:1px solid rgba(220,245,255,.85);transform:scale(.4)}.shooter-wrapper .fw-1{left:16%;top:26%;animation-delay:0s}.shooter-wrapper .fw-2{left:34%;top:18%;animation-delay:.28s}.shooter-wrapper .fw-3{left:52%;top:25%;animation-delay:.62s}.shooter-wrapper .fw-4{left:70%;top:17%;animation-delay:.88s}.shooter-wrapper .fw-5{left:84%;top:28%;animation-delay:1.15s}.shooter-wrapper .fw-6{left:50%;top:10%;animation-delay:1.38s}@keyframes shooter-burst{0%{opacity:0;transform:translate(-50%,-50%) scale(.2)}12%{opacity:1;transform:translate(-50%,-50%) scale(1)}65%{opacity:.92;transform:translate(-50%,-50%) scale(2.8)}to{opacity:0;transform:translate(-50%,-50%) scale(3.35)}}.shooter-wrapper .help{margin:8px 0 0;font-size:12px;line-height:1.4;color:var(--muted)}.shooter-wrapper #scene{width:100%;height:100%;display:block}.shooter-wrapper .layout-nav{position:fixed;right:16px;bottom:16px;z-index:1000;width:164px;border:1px solid rgba(140,190,245,.35);border-radius:12px;padding:8px;background:linear-gradient(180deg,#122034d1,#0a121fdb);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 8px 22px #00000047}.shooter-wrapper .cue-dock{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;margin-bottom:6px}.shooter-wrapper .cue-dock .cue-btn{margin:0;height:28px;font-size:10px;padding:4px 2px;border-radius:8px}.shooter-wrapper .cue-dock .cue-btn.active{border-color:#82f5b4b3;background:linear-gradient(180deg,#44a07880,#1e60488c);color:#effff5}.shooter-wrapper .layout-nav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.shooter-wrapper .layout-nav-title{font-size:11px;color:#d2e6ffe6;letter-spacing:.02em}.shooter-wrapper .layout-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:6px}.shooter-wrapper .layout-pad .layout-btn:nth-child(1){grid-column:2}.shooter-wrapper .layout-pad .layout-btn:nth-child(2){grid-column:1}.shooter-wrapper .layout-pad .layout-btn:nth-child(3){grid-column:2}.shooter-wrapper .layout-pad .layout-btn:nth-child(4){grid-column:3}.shooter-wrapper .layout-pad .layout-btn:nth-child(5){grid-column:2}.shooter-wrapper .layout-ops{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.shooter-wrapper .layout-btn{width:100%;min-width:0;margin:0;padding:0;height:30px;border-radius:8px;font-size:13px;font-weight:700;line-height:1;letter-spacing:0}.shooter-wrapper .layout-btn.center{color:#b9ebfff2}.shooter-wrapper .layout-btn.reset{width:auto;padding:0 8px;height:24px;font-size:11px;font-weight:600}.shooter-wrapper .mobile-menu-btn{display:none;align-items:center;justify-content:center;position:fixed;top:10px;left:10px;width:40px;height:40px;margin:0;padding:0;border-radius:10px;z-index:1450;font-size:20px;line-height:1;background:linear-gradient(180deg,#305882c7,#10243ed6)}.shooter-wrapper .mobile-menu-backdrop{display:none}@media(max-width:960px){.shooter-wrapper{overflow:hidden}.shooter-wrapper #shooter-app{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr);height:100vh;height:100dvh;position:relative}.shooter-wrapper .mobile-menu-btn{display:flex}.shooter-wrapper #panel{display:block;position:fixed;top:0;left:0;bottom:0;width:min(88vw,340px);border-right:1px solid var(--line);border-bottom:0;z-index:1400;transform:translate(-104%);transition:transform .2s ease;overscroll-behavior:contain}.shooter-wrapper #shooter-app.mobile-menu-open #panel{transform:translate(0)}.shooter-wrapper .mobile-menu-backdrop{position:fixed;inset:0;z-index:1300;background:#00000085;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.shooter-wrapper #shooter-app.mobile-menu-open .mobile-menu-backdrop{display:block}.shooter-wrapper #scene{width:100vw;height:100vh;height:100dvh}.shooter-wrapper .layout-nav{display:block;right:10px;bottom:10px;width:122px;padding:6px;z-index:1200}.shooter-wrapper .layout-nav-top,.shooter-wrapper .layout-pad{display:none}.shooter-wrapper .layout-ops{grid-template-columns:repeat(2,1fr);gap:5px}.shooter-wrapper .layout-btn{height:32px;font-size:14px}.shooter-wrapper .cue-dock{display:none}}
