/* ============================================
   🚽 トイレ取りゲーム 3D EXTREME v12
   style.css
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Rampart+One&family=M+PLUS+Rounded+1c:wght@400;700;900&family=DotGothic16&display=swap');
*{box-sizing:border-box;margin:0;padding:0;}
html,body{width:100%;height:100%;background:#020008;overflow:hidden;}
body{font-family:'M PLUS Rounded 1c',sans-serif;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 20% 30%,rgba(140,0,255,.15) 0%,transparent 100%),radial-gradient(ellipse 60% 50% at 80% 70%,rgba(255,20,80,.12) 0%,transparent 100%);}

#wrap{width:960px;height:640px;position:relative;border-radius:18px;overflow:hidden;transform-origin:center center;
  box-shadow:0 0 0 2px #3a0055,0 0 70px rgba(180,0,255,.3),0 28px 90px rgba(0,0,0,.95);background:#000;}
canvas#c{display:block;width:960px;height:640px;}
.scene{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:60;}
.scene.on{display:flex;}
.scanline{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.15) 3px,rgba(0,0,0,.15) 4px);animation:scanroll 15s linear infinite;}
@keyframes scanroll{to{background-position:0 400px;}}

/* TITLE */
#sc-title{background:radial-gradient(ellipse at center,#1a003a 0%,#04000c 80%);}
.t-logo{font-size:52px;letter-spacing:4px;animation:tshk .8s ease-in-out infinite;margin-bottom:4px;filter:drop-shadow(0 0 10px rgba(255,255,255,.5));}
@keyframes tshk{0%,100%{transform:rotate(-3deg) scale(1);}50%{transform:rotate(3deg) scale(1.05);}}
.t-main{font-family:'Rampart One',sans-serif;font-size:58px;color:#fff;letter-spacing:4px;text-shadow:0 0 25px #ff3c6e,0 0 55px #ff3c6e,5px 5px 0 #99001e;animation:nflk 3.5s ease-in-out infinite;}
@keyframes nflk{0%,92%,100%{opacity:1;}93%{opacity:.2;}95%{opacity:1;}97%{opacity:.4;}99%{opacity:1;}}
.t-xtag{font-family:'Rampart One',sans-serif;font-size:22px;color:#00d4ff;letter-spacing:6px;text-shadow:0 0 20px #00d4ff;margin-bottom:6px;}
.t-sub{font-size:12px;color:#ffe600;border:1px solid rgba(255,230,0,.4);background:rgba(255,230,0,.1);padding:5px 22px;border-radius:999px;margin-bottom:14px;box-shadow:0 0 15px rgba(255,230,0,.2);}
.t-feats{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:720px;margin-bottom:14px;}
.feat{font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.02));color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.2);box-shadow:0 2px 5px rgba(0,0,0,.5);}
.hi-disp{font-size:15px;color:rgba(255,230,0,.8);font-family:'DotGothic16',monospace;margin-bottom:10px;text-shadow:0 0 10px #ffe600;}
.hi-disp strong{color:#fff;font-size:22px;}
.t-ctrls{font-size:11px;color:rgba(255,255,255,.8);text-align:center;line-height:2.2;font-family:'DotGothic16',monospace;background:rgba(0,0,0,.6);padding:10px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.1);}
.t-ctrls strong{color:#00ff88;text-shadow:0 0 5px #00ff88;}
.t-btn-row{display:flex;gap:10px;margin-bottom:10px;}

.btn{font-family:inherit;font-weight:900;border:none;cursor:pointer;border-radius:12px;transition:transform .1s,filter .1s;}
.btn:active{transform:scale(.93)!important;}
.btn-primary{font-size:22px;padding:14px 52px;letter-spacing:2px;background:linear-gradient(135deg,#ff3c6e,#bf00ff);color:#fff;box-shadow:0 0 30px rgba(255,60,110,.7),0 6px 0 #77001a,inset 0 2px 5px rgba(255,255,255,.4);animation:bpulse 1.5s ease-in-out infinite;}
.btn-primary:hover{filter:brightness(1.2);}
@keyframes bpulse{0%,100%{box-shadow:0 0 30px rgba(255,60,110,.6),0 6px 0 #77001a;}50%{box-shadow:0 0 55px rgba(255,60,110,1),0 6px 0 #77001a;}}
.btn-cyan{font-size:16px;padding:11px 32px;background:linear-gradient(135deg,#00aacc,#0077aa);color:#fff;font-weight:900;border-radius:12px;border:none;cursor:pointer;box-shadow:0 0 18px rgba(0,170,220,.5),0 4px 0 #003355;transition:filter .1s;}
.btn-cyan:hover{filter:brightness(1.2);}
.btn-green{font-size:19px;padding:12px 46px;background:linear-gradient(135deg,#00cc66,#009944);color:#fff;font-weight:900;border-radius:13px;box-shadow:0 0 20px rgba(0,200,100,.5),0 5px 0 #004422;letter-spacing:1px;transition:filter .1s,transform .1s;}
.btn-green:hover{filter:brightness(1.2);}
.btn-ghost{font-size:13px;padding:7px 22px;background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);border-radius:999px;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:background .1s;margin-top:8px;}
.btn-ghost:hover{background:rgba(255,255,255,.2);}
.btn-purple{font-size:16px;padding:11px 32px;background:linear-gradient(135deg,#6600cc,#aa00ff);color:#fff;font-weight:900;border-radius:12px;border:none;cursor:pointer;box-shadow:0 0 16px rgba(170,0,255,.35),0 4px 0 #330066;transition:filter .1s;}
.btn-purple:hover{filter:brightness(1.1);}

.voice-toggle{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.6);border:1px solid #00d4ff;color:#00d4ff;padding:5px 12px;border-radius:999px;font-family:'DotGothic16',monospace;font-size:11px;cursor:pointer;font-weight:bold;box-shadow:0 0 10px rgba(0,212,255,.3);z-index:100;transition:all 0.2s;}
.voice-toggle.off{border-color:#888;color:#888;box-shadow:none;}
#settings-btn{position:absolute;top:12px;right:160px;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);padding:5px 12px;border-radius:999px;font-family:'DotGothic16',monospace;font-size:11px;cursor:pointer;z-index:100;}

/* STAGE SELECT */
#sc-stage{background:radial-gradient(ellipse at center,#1a003a 0%,#04000c 80%);}
.st-h{font-family:'Rampart One',sans-serif;font-size:30px;color:#fff;margin-bottom:3px;text-shadow:0 0 20px #bf00ff;}
.st-sh{font-size:11px;color:rgba(255,255,255,.5);margin-bottom:16px;font-family:'DotGothic16',monospace;}
.st-cards{display:flex;gap:10px;margin-bottom:16px;}
.st-card{width:160px;cursor:pointer;border-radius:16px;overflow:hidden;border:2px solid rgba(255,255,255,.15);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(0,0,0,.4));transition:transform .2s,border-color .2s,box-shadow .2s;}
.st-card:hover{transform:translateY(-6px);border-color:#ff3c6e;box-shadow:0 10px 25px rgba(255,60,110,.5);}
.st-card.sel{border-color:#ffe600;box-shadow:0 0 30px rgba(255,230,0,.6);background:linear-gradient(180deg,rgba(255,230,0,.15),rgba(0,0,0,.6));}
.stc-top{height:72px;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative;background:rgba(0,0,0,.3);}
.stc-locked{position:absolute;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;font-size:28px;backdrop-filter:blur(2px);}
.stc-name{font-size:13px;font-weight:900;color:#fff;text-align:center;padding:5px 0 2px;}
.stc-desc{font-size:9px;color:rgba(255,255,255,.5);text-align:center;padding:0 6px 5px;line-height:1.4;}
.stc-diff{display:flex;gap:2px;justify-content:center;padding-bottom:6px;font-size:11px;}
.stc-tags{display:flex;gap:3px;justify-content:center;flex-wrap:wrap;padding:0 4px 8px;}
.stc-tag{font-size:8px;padding:2px 5px;border-radius:999px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);}
.npc-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;background:rgba(0,0,0,.5);padding:7px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.1);}
.npc-lbl{font-size:11px;color:rgba(255,255,255,.6);font-family:'DotGothic16',monospace;}
.npc-btn{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:900;}
#npc-val{font-size:28px;font-weight:900;color:#00d4ff;min-width:40px;text-align:center;text-shadow:0 0 15px #00d4ff;}
.npc-dhint{font-size:12px;font-weight:bold;color:#ff3c6e;font-family:'DotGothic16',monospace;min-width:120px;text-shadow:0 0 5px #ff3c6e;}
.unlock-hint{font-size:10px;color:rgba(255,255,255,.4);font-family:'DotGothic16',monospace;margin-top:6px;text-align:center;}

/* ABILITY SELECT */
#sc-ability{background:radial-gradient(ellipse at center,#001a20 0%,#04000c 80%);}
.ab-h{font-family:'Rampart One',sans-serif;font-size:28px;color:#00ff88;margin-bottom:4px;text-shadow:0 0 20px #00ff88;}
.ab-sh{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:18px;font-family:'DotGothic16',monospace;}
.ab-cards{display:flex;gap:12px;margin-bottom:22px;flex-wrap:wrap;justify-content:center;max-width:800px;}
.ab-card{width:140px;cursor:pointer;border-radius:14px;overflow:hidden;border:2px solid rgba(255,255,255,.15);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(0,0,0,.5));transition:transform .2s,border-color .2s,box-shadow .2s;padding:12px 8px;text-align:center;}
.ab-card:hover{transform:translateY(-5px);border-color:#00ff88;box-shadow:0 8px 20px rgba(0,255,136,.4);}
.ab-card.sel{border-color:#00ff88;box-shadow:0 0 25px rgba(0,255,136,.6);background:linear-gradient(180deg,rgba(0,255,136,.12),rgba(0,0,0,.6));}
.ab-icon{font-size:36px;margin-bottom:6px;}
.ab-name{font-size:13px;font-weight:900;color:#fff;margin-bottom:4px;}
.ab-stat{font-size:9px;color:rgba(255,255,255,.55);line-height:1.5;margin-bottom:4px;}
.ab-buff{font-size:9px;color:#00ff88;font-weight:700;}
.ab-nerf{font-size:9px;color:#ff6060;font-weight:700;}

/* ACHIEVEMENT */
#sc-achieve{background:radial-gradient(ellipse at center,#1a1000 0%,#04000c 80%);}
.ach-h{font-family:'Rampart One',sans-serif;font-size:28px;color:#ffe600;margin-bottom:4px;text-shadow:0 0 20px #ffe600;}
.ach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;max-height:360px;overflow-y:auto;padding:4px;width:680px;}
.ach-item{border-radius:12px;padding:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);text-align:center;position:relative;}
.ach-item.unlocked{border-color:rgba(255,230,0,.5);background:linear-gradient(180deg,rgba(255,230,0,.1),rgba(0,0,0,.4));box-shadow:0 0 12px rgba(255,230,0,.2);}
.ach-icon{font-size:28px;margin-bottom:4px;display:block;}
.ach-item:not(.unlocked) .ach-icon{filter:grayscale(100%) opacity(0.3);}
.ach-name{font-size:10px;font-weight:900;color:#fff;margin-bottom:2px;}
.ach-item:not(.unlocked) .ach-name{color:rgba(255,255,255,.3);}
.ach-desc{font-size:8px;color:rgba(255,255,255,.45);line-height:1.3;}
.ach-item:not(.unlocked) .ach-desc{color:rgba(255,255,255,.15);}
.ach-new-badge{position:absolute;top:-4px;right:-4px;background:#ff3c6e;color:#fff;font-size:8px;font-weight:900;padding:2px 5px;border-radius:999px;}

/* SETTINGS */
#sc-settings{background:radial-gradient(ellipse at center,#001020 0%,#04000c 80%);}
.set-h{font-family:'Rampart One',sans-serif;font-size:26px;color:#00d4ff;margin-bottom:20px;text-shadow:0 0 16px #00d4ff;}
.set-row{display:flex;align-items:center;gap:16px;margin-bottom:18px;width:440px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 20px;}
.set-lbl{font-size:13px;color:rgba(255,255,255,.7);font-family:'DotGothic16',monospace;flex:1;}
.set-val{font-size:14px;font-weight:900;color:#00d4ff;min-width:36px;text-align:center;}
input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:6px;border-radius:3px;background:rgba(255,255,255,.15);outline:none;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#00d4ff;cursor:pointer;box-shadow:0 0 8px #00d4ff;}

/* HUD */
#hud{position:absolute;top:0;left:0;right:0;display:none;background:linear-gradient(180deg,rgba(0,0,0,.95) 0%,rgba(0,0,0,.6) 70%,transparent 100%);padding:8px 16px 20px;flex-direction:row;align-items:center;gap:6px;}
#hud.on{display:flex;}
.hb{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:3px 12px;display:flex;flex-direction:column;align-items:center;}
.hl{font-size:9px;color:rgba(255,255,255,.4);font-weight:700;letter-spacing:1.5px;}
.hv{font-size:19px;font-weight:900;color:#fff;line-height:1.2;}
.hv.danger{color:#ff3c6e!important;animation:blink .35s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.3;}}
#h-tbar-bg{flex:1;height:6px;background:rgba(0,0,0,.8);border:1px solid rgba(255,255,255,.1);border-radius:3px;margin:0 8px;}
#h-tbar{height:100%;border-radius:2px;background:linear-gradient(90deg,#ff3c6e,#ffb800,#00ff88);background-size:200% 100%;animation:tgrad 2s linear infinite;transition:width .05s linear;}
@keyframes tgrad{0%{background-position:100% 0;}100%{background-position:-100% 0;}}
#h-efx{display:flex;gap:4px;align-items:center;}
.efxi{font-size:15px;animation:efxpop .7s ease-in-out infinite;}
@keyframes efxpop{0%,100%{transform:scale(1);}50%{transform:scale(1.3);}}

#stam-wrap{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:none;flex-direction:column;align-items:center;gap:4px;}
#stam-wrap.on{display:flex;}
.stam-lbl{font-size:10px;color:rgba(255,255,255,.9);font-family:'DotGothic16',monospace;letter-spacing:1.5px;text-shadow:0 2px 4px #000;}
#stam-bg{width:220px;height:12px;background:rgba(0,0,0,.8);border:2px solid rgba(255,255,255,.25);border-radius:6px;overflow:hidden;box-shadow:0 0 15px rgba(0,0,0,.8);}
#stam-bar{height:100%;border-radius:3px;transition:width .1s linear,background .3s;}
#combo-disp{position:absolute;top:65px;right:16px;display:none;font-family:'Rampart One',sans-serif;font-size:28px;color:#ffe600;text-shadow:0 0 20px #ffe600,2px 2px 0 #880000;animation:cglow 0.8s ease-in-out infinite;}
@keyframes cglow{0%,100%{transform:scale(1) rotate(-3deg);}50%{transform:scale(1.15) rotate(3deg);}}
#combo-disp.on{display:block;}
#rprog-wrap{position:absolute;top:49px;left:14px;right:14px;display:none;gap:4px;}
#rprog-wrap.on{display:flex;}
.rpseg{flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,.1);transition:background .4s;}
.rpseg.done{background:rgba(0,255,136,.7);}
.rpseg.cur{background:rgba(255,230,0,.9);animation:rppulse .8s ease-in-out infinite;}
@keyframes rppulse{0%,100%{opacity:.9;}50%{opacity:.4;}}

/* OVERLAY */
#overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:35;}
#evbanner{position:absolute;top:54px;left:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,0,80,.9),rgba(150,0,255,.9),transparent);color:#fff;font-weight:900;font-size:16px;text-align:center;padding:8px 0;letter-spacing:1.5px;pointer-events:none;z-index:24;transform:translateY(-150%);transition:transform .3s cubic-bezier(.34,1.5,.64,1);text-shadow:0 2px 5px #000;}
#evbanner.on{transform:translateY(0);}
@keyframes bpop{0%{transform:scale(0) rotate(-20deg);opacity:0;}70%{transform:scale(1.1) rotate(5deg);opacity:1;}100%{transform:scale(1) rotate(0);opacity:1;}}
@keyframes bfup{to{transform:translateY(-80px) scale(1.2);opacity:0;}}
.bn{padding:20px 60px;border-radius:20px;text-align:center;font-family:'Rampart One',sans-serif;animation:bpop .4s cubic-bezier(.34,1.56,.64,1);}
.bn-round{background:linear-gradient(135deg,rgba(46,0,101,.9),rgba(114,0,204,.9));border:2px solid #d400ff;box-shadow:0 0 60px rgba(212,0,255,.6);backdrop-filter:blur(5px);}
.bn-go{background:linear-gradient(135deg,#ff003c,#ffaa00);box-shadow:0 0 80px #ff3c6e;border:4px solid #fff;}
.bn-warn{background:linear-gradient(135deg,#cc0000,#880000);box-shadow:0 0 50px #ff0000;border:2px solid #ff5555;}
.bn-ok{background:linear-gradient(135deg,#008833,#00cc55);box-shadow:0 0 50px #00ff66;border:2px solid #aaffaa;}
.bn-evt{background:linear-gradient(135deg,#5500aa,#cc00ff);box-shadow:0 0 50px #bb00ff;border:2px solid #ee88ff;}
.bn-gold{background:linear-gradient(135deg,#886600,#cc9900);box-shadow:0 0 50px #ffe600;border:2px solid #ffe600;}
.bn-title{font-size:64px;color:#fff;line-height:1;text-shadow:0 5px 0 rgba(0,0,0,.4),0 0 20px rgba(255,255,255,.5);}
.bn-sub{font-size:15px;color:rgba(255,255,255,.8);margin-top:8px;font-weight:700;letter-spacing:1px;}
.bn-go .bn-title{font-size:100px;font-style:italic;}
.bn-center{font-size:32px;color:#fff;border-radius:16px;padding:15px 45px;animation:bpop .3s cubic-bezier(.34,1.56,.64,1),bfup .5s ease-in 1.8s forwards;}
#flash{position:absolute;inset:0;pointer-events:none;opacity:0;z-index:44;}
#flash.r{background:rgba(255,0,48,.4);animation:fla .27s ease-out forwards;}
#flash.y{background:rgba(255,225,0,.35);animation:fla .27s ease-out forwards;}
#flash.w{background:rgba(255,255,255,.6);animation:fla .2s ease-out forwards;}
@keyframes fla{0%{opacity:1;}100%{opacity:0;}}

/* INTER-ROUND */
#sc-inter{background:rgba(0,0,20,.95);backdrop-filter:blur(10px);}
.inter-title{font-family:'Rampart One',sans-serif;font-size:34px;color:#00d4ff;margin-bottom:16px;text-shadow:0 0 25px #00d4ff;}
.inter-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px;width:460px;}
.istat{background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(0,0,0,.4));border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:12px;display:flex;flex-direction:column;align-items:center;box-shadow:0 5px 15px rgba(0,0,0,.5);}
.istat .il{font-size:10px;color:rgba(255,255,255,.5);font-weight:700;letter-spacing:2px;margin-bottom:3px;}
.istat .iv{font-size:30px;font-weight:900;color:#fff;line-height:1.1;text-shadow:0 0 15px currentColor;}
.inter-msg{font-size:15px;color:#ffe600;margin-bottom:18px;text-align:center;line-height:1.6;font-weight:900;}
.ach-unlock-toast{font-size:13px;color:#ffe600;background:rgba(255,230,0,.15);border:1px solid rgba(255,230,0,.4);border-radius:10px;padding:8px 20px;margin-bottom:12px;text-align:center;font-weight:700;}

/* RESULT */
#sc-result{background:radial-gradient(ellipse at center,#1a0030 0%,#000 100%);}
.rptcl{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.rp-pt{position:absolute;animation:rpfall linear forwards;}
@keyframes rpfall{0%{opacity:1;transform:translateY(-50px) rotate(0) scale(1);}100%{opacity:0;transform:translateY(700px) rotate(1000deg) scale(0.5);}}
.r-title{font-family:'Rampart One',sans-serif;font-size:64px;animation:bpop .5s cubic-bezier(.34,1.56,.64,1);margin-bottom:10px;}
.r-over{color:#ff003c;text-shadow:0 0 35px #ff003c,5px 5px 0 #660011;}
.r-win{color:#ffe600;text-shadow:0 0 35px #ffe600,5px 5px 0 #886600;}
.r-flavor{font-size:18px;font-weight:900;color:rgba(255,255,255,.8);margin-bottom:20px;letter-spacing:1px;}
.r-cards{display:flex;gap:14px;margin-bottom:20px;}
.rcard{background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(0,0,0,.6));border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:14px 30px;text-align:center;box-shadow:0 10px 20px rgba(0,0,0,.6);}
.rcard .rl{font-size:10px;color:rgba(255,255,255,.4);font-weight:700;letter-spacing:1px;}
.rcard .rv{font-size:42px;font-weight:900;line-height:1.1;text-shadow:0 0 15px currentColor;}
.rcard.rc .rv{color:#00d4ff;}.rcard.sc .rv{color:#ffe600;}.rcard.cc .rv{color:#ff8c00;}
.r-hi{font-size:16px;font-weight:900;color:#00ff88;margin-bottom:14px;text-shadow:0 0 15px #00ff88;font-family:'DotGothic16',monospace;}
.r-achieve-list{font-size:12px;color:#ffe600;margin-bottom:12px;font-family:'DotGothic16',monospace;text-align:center;background:rgba(255,230,0,.08);border:1px solid rgba(255,230,0,.2);padding:6px 16px;border-radius:8px;}
.r-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}

/* TOUCH UI */
#touch-ui{position:absolute;inset:0;pointer-events:none;display:none;z-index:50;}
#touch-ui.on{display:block;}
#t-pad{position:absolute;bottom:30px;left:30px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.1);border:3px solid rgba(255,255,255,.25);pointer-events:auto;touch-action:none;box-shadow:0 0 20px rgba(0,0,0,.5),inset 0 0 20px rgba(0,0,0,.5);}
#t-pad-inner{position:absolute;top:40px;left:40px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(200,200,200,.7));pointer-events:none;box-shadow:0 5px 15px rgba(0,0,0,.6);}
.t-btn{position:absolute;border-radius:50%;border:none;pointer-events:auto;touch-action:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:inherit;transition:transform 0.1s;}
.t-btn:active{transform:scale(0.85);filter:brightness(1.2);}
#t-dash{bottom:130px;right:30px;width:75px;height:75px;font-size:32px;background:linear-gradient(135deg,#ff3c6e,#bf00ff);border:3px solid rgba(255,255,255,.5);box-shadow:0 0 25px rgba(191,0,255,.7);}
#t-enter{bottom:30px;right:30px;width:95px;height:95px;font-size:44px;background:linear-gradient(135deg,#00cc66,#009944);border:3px solid rgba(255,255,255,.5);box-shadow:0 0 25px rgba(0,255,100,.7);}
#ctrl-bar{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);font-size:11px;color:rgba(255,255,255,.7);display:none;white-space:nowrap;pointer-events:none;font-family:'DotGothic16',monospace;background:rgba(0,0,0,.7);padding:5px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.15);}
#ctrl-bar.on{display:block;}
