@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Rajdhani:wght@400;600;700&display=swap');
*{margin:0;padding:0;box-sizing:border-box;}
body{background:#000;overflow:hidden;font-family:'Rajdhani',sans-serif;color:#fff;user-select:none;}
#gc{position:fixed;top:0;left:0;width:100%;height:100%;}
#dc{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;display:none;}
#hud{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;display:none;}
#raceTop{position:absolute;top:16px;left:50%;transform:translateX(-50%);text-align:center;font-family:'Orbitron',monospace;}
#lapNum{font-size:13px;color:#666;letter-spacing:3px;text-transform:uppercase;}
#lapVal{font-size:26px;font-weight:700;color:#ffd700;text-shadow:0 0 20px #ffd700aa;}
#timer{font-size:18px;color:#ccc;letter-spacing:2px;margin-top:2px;}
#cpRow{font-size:13px;color:#888;letter-spacing:2px;margin-top:1px;}
#cpLabel{color:#555;}
#cpVal{color:#aaa;}
#lapTimes{margin-top:5px;font-size:12px;color:#666;letter-spacing:1px;line-height:1.6;}
#pos{position:absolute;top:16px;left:20px;font-family:'Orbitron',monospace;}
#posNum{font-size:46px;font-weight:900;color:#00ffaa;text-shadow:0 0 25px #00ffaa88;line-height:1;}
#posLabel{font-size:11px;color:#666;letter-spacing:3px;}
#speedBox{position:absolute;bottom:200px;right:20px;text-align:right;font-family:'Orbitron',monospace;}
#speedNum{font-size:52px;font-weight:900;color:#fff;text-shadow:0 0 15px #0088ffaa;line-height:1;}
#speedUnit{font-size:12px;color:#668;letter-spacing:3px;}
#gearBox{position:absolute;bottom:200px;left:20px;font-family:'Orbitron',monospace;}
#gearNum{font-size:52px;font-weight:900;color:#ffd700;text-shadow:0 0 20px #ffd700aa;line-height:1;}
#gearLabel{font-size:11px;color:#666;letter-spacing:3px;}
#camLabel{position:absolute;bottom:180px;left:50%;transform:translateX(-50%);font-size:11px;color:#445;letter-spacing:3px;}
#mm{position:absolute;top:14px;right:14px;width:150px;height:150px;border-radius:50%;overflow:hidden;border:1px solid #223;}
#mmc{width:100%;height:100%;}
#notif{position:fixed;top:38%;left:50%;transform:translate(-50%,-50%);font-family:'Orbitron',monospace;font-size:32px;font-weight:900;color:#00ffaa;text-shadow:0 0 30px #00ffaa;pointer-events:none;display:none;opacity:0;text-align:center;}
#cd{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Orbitron',monospace;font-size:110px;font-weight:900;color:#ffd700;text-shadow:0 0 50px #ffd700;pointer-events:none;display:none;}
.ghostNameTag{position:fixed;display:none;z-index:205;pointer-events:none;transform:translate(-50%,-100%);padding:5px 8px;border-radius:999px;background:rgba(5,10,20,.7);border:1px solid rgba(133,216,255,.55);font-family:'Orbitron',monospace;font-size:11px;letter-spacing:1px;color:#d3f0ff;white-space:nowrap;text-shadow:0 0 8px rgba(130,205,255,.45);}
#hint{position:fixed;bottom:12px;left:50%;transform:translateX(-50%);font-size:11px;color:#333;letter-spacing:2px;display:none;pointer-events:none;}
/* Screens */
.screen{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 60%,#0e0e1e,#050508);z-index:100;padding:28px 22px;overflow:auto;}
.introScreen{z-index:230;background:radial-gradient(ellipse at 50% 60%,#1a1b35,#050508);}
.screen h1{font-family:'Orbitron',monospace;font-size:78px;font-weight:900;letter-spacing:10px;text-transform:uppercase;background:linear-gradient(135deg,#ff5500,#ffcc00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:6px;line-height:1;}
.screen .sub{font-size:13px;color:#333;letter-spacing:5px;text-transform:uppercase;margin-bottom:44px;}
.screen h2{font-family:'Orbitron',monospace;font-size:24px;letter-spacing:6px;color:#556;text-transform:uppercase;margin-bottom:32px;}
.menuVersion{position:absolute;right:20px;bottom:16px;font-family:'Orbitron',monospace;font-size:12px;letter-spacing:2px;color:#4f5978;text-transform:uppercase;}
.menuActions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;max-width:100%;}
.menuActions-inline{margin-top:2px;}
.btn{padding:13px 36px;font-family:'Orbitron',monospace;font-size:13px;font-weight:700;border:none;border-radius:4px;cursor:pointer;text-transform:uppercase;letter-spacing:3px;transition:all .15s;margin:6px;}
.btn-p{background:linear-gradient(135deg,#ff5500,#ff2200);color:#fff;box-shadow:0 0 20px #ff550066;}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 0 35px #ff5500aa;}
.btn-p:disabled{opacity:.3;cursor:not-allowed;transform:none;}
.btn-s{background:rgba(255,255,255,.05);color:#778;border:1px solid #223;}
.btn-s:hover{background:rgba(255,255,255,.1);color:#aab;}
.trackCards{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;margin-bottom:24px;max-width:100%;}
.cards{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;margin:0 0 24px;}
.card{width:250px;padding:22px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:all .15s;text-align:center;}
.carCardCanvas{display:block;width:100%;height:140px;border-radius:10px;margin:0 0 14px;background:radial-gradient(circle at 50% 65%,rgba(255,255,255,.08),rgba(255,255,255,.01) 60%,rgba(0,0,0,.05));}
.card:hover,.card.sel{border-color:#ff5500;background:rgba(255,85,0,.07);transform:translateY(-4px);box-shadow:0 8px 30px rgba(255,85,0,.2);}
.card h3{font-family:'Orbitron',monospace;font-size:18px;margin-bottom:8px;color:#ffcc00;}
.card p{font-size:14px;color:#7c8aac;margin-bottom:14px;line-height:1.5;}
.card .carMeta{font-size:12px;color:#9fb0d9;line-height:1.45;margin-top:10px;margin-bottom:0;}
.stat{display:flex;align-items:center;gap:8px;margin:6px 0;font-size:13px;}
.sl{width:64px;text-align:right;color:#7182ab;letter-spacing:1px;}
.st{flex:1;height:6px;background:rgba(255,255,255,.07);border-radius:4px;}
.sv{min-width:52px;text-align:right;color:#c3cee9;font-family:'Orbitron',monospace;font-size:12px;}
.sf{height:100%;border-radius:2px;background:linear-gradient(90deg,#ff5500,#ffcc00);}
#results{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.94);display:none;flex-direction:column;align-items:center;justify-content:center;z-index:200;padding:24px 20px;overflow:auto;}
#results h1{font-family:'Orbitron',monospace;font-size:50px;font-weight:900;margin-bottom:28px;}
#podium{display:flex;gap:16px;margin-bottom:24px;}
.pi{text-align:center;padding:18px 22px;background:rgba(255,255,255,.04);border-radius:8px;border:1px solid #223;min-width:130px;}
.pm{font-size:40px;margin-bottom:4px;}
.pn{font-size:14px;font-weight:700;margin-bottom:4px;}
.pt{font-size:12px;color:#556;}
#ptime{font-size:16px;color:#556;margin-bottom:8px;font-family:'Orbitron',monospace;letter-spacing:2px;}
#runCar{font-size:13px;color:#7e8fb5;margin-bottom:20px;font-family:'Orbitron',monospace;letter-spacing:1px;}

#resultsLbWrap{width:min(460px,95vw);margin:0 0 22px;padding:14px 14px 10px;border:1px solid #223;border-radius:10px;background:rgba(255,255,255,.03);}
#resultsLbWrap h3{font-family:'Orbitron',monospace;font-size:13px;letter-spacing:2px;color:#aeb9d8;text-transform:uppercase;margin-bottom:10px;text-align:center;}
#resultsLeaderboard{display:flex;flex-direction:column;gap:6px;}
.lb-row{display:grid;grid-template-columns:40px 1fr auto;gap:8px;align-items:center;padding:7px 9px;border-radius:7px;background:rgba(0,0,0,.2);font-size:13px;}
.lb-row-you{outline:1px solid #ffd70066;background:rgba(255,215,0,.08);}
.lb-pos{color:#9fb0de;font-family:'Orbitron',monospace;}
.lb-name{color:#e9eeff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;flex-direction:column;gap:3px;}
.lb-ghost-marker{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;font-size:12px;filter:drop-shadow(0 0 6px rgba(112,214,255,.55));}
.lb-car{display:flex;align-items:center;gap:6px;color:#95a6d0;font-size:11px;font-family:'Rajdhani',sans-serif;}
.lb-car-dot{width:10px;height:10px;border-radius:3px;display:inline-block;box-shadow:0 0 8px currentColor;}
.lb-time{color:#ffd28f;font-family:'Orbitron',monospace;font-size:12px;}
.lb-empty{font-size:12px;color:#667aab;text-align:center;padding:6px 0;}
.trackBest{font-size:11px;color:#8f9fc8;letter-spacing:1px;}
/* Pause Menu */
#pauseMenu{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.82);display:none;flex-direction:column;align-items:center;justify-content:center;z-index:300;padding:24px 20px;overflow:auto;}
#pauseMenu h2{font-family:'Orbitron',monospace;font-size:42px;font-weight:900;letter-spacing:8px;color:#ffd700;text-shadow:0 0 30px #ffd700aa;margin-bottom:36px;}
/* Settings Modal */
#settingsModal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(480px,calc(100vw - 24px));max-height:calc(100vh - 24px);overflow:auto;background:#0a0a14;border:1px solid #223;border-radius:12px;padding:40px;z-index:400;display:none;}
#settingsModal h2{font-family:'Orbitron',monospace;font-size:20px;letter-spacing:5px;color:#556;text-transform:uppercase;margin-bottom:32px;text-align:center;}
.vol-row{display:flex;align-items:center;gap:16px;margin-bottom:22px;}
.vol-lbl{font-family:'Orbitron',monospace;font-size:11px;letter-spacing:2px;color:#445;width:110px;text-align:right;}
.vol-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:2px;background:rgba(255,255,255,.12);outline:none;}
.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#ff5500;cursor:pointer;box-shadow:0 0 8px #ff5500aa;}
.vol-val{width:38px;text-align:center;font-family:'Orbitron',monospace;font-size:12px;color:#667;}
.ctrl-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 22px;margin:22px 0;padding:18px;background:rgba(255,255,255,.025);border-radius:8px;font-size:12px;color:#556;}
.ctrl-grid span:nth-child(odd){color:#445;letter-spacing:1px;}
.ctrl-grid span:nth-child(even){color:#778;}
.s-sep{height:1px;background:rgba(255,255,255,.06);margin:22px 0;}
.tcard{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px;border-radius:10px;background:rgba(255,255,255,.03);border:2px solid rgba(255,255,255,.06);cursor:pointer;transition:all .15s;}
.tcard:hover,.tcard.sel{border-color:#ff5500;background:rgba(255,85,0,.07);transform:translateY(-4px);box-shadow:0 8px 30px rgba(255,85,0,.25);}
.tcard h3{font-family:'Orbitron',monospace;font-size:13px;color:#ffcc00;letter-spacing:2px;text-transform:uppercase;}
.tcard p{font-size:11px;color:#445;letter-spacing:1px;}
.trackLbBtn{margin-top:4px;padding:8px 12px;font-size:10px;letter-spacing:2px;}
/* Race Setup Screen */
.setupSection{width:min(700px,100%);margin-bottom:28px;}
.setupLabel{font-family:'Orbitron',monospace;font-size:11px;letter-spacing:4px;color:#445;text-transform:uppercase;margin-bottom:14px;text-align:center;}
.diffCards{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}
.diffCard{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 28px;border-radius:10px;background:rgba(255,255,255,.03);border:2px solid rgba(255,255,255,.06);cursor:pointer;transition:all .15s;min-width:150px;text-align:center;}
.diffCard:hover,.diffCard.sel{border-color:#ff5500;background:rgba(255,85,0,.07);transform:translateY(-3px);box-shadow:0 6px 24px rgba(255,85,0,.22);}
.diffIcon{font-size:28px;line-height:1;}
.diffName{font-family:'Orbitron',monospace;font-size:13px;font-weight:700;color:#ffcc00;letter-spacing:2px;text-transform:uppercase;}
.diffDesc{font-size:12px;color:#556;letter-spacing:.5px;line-height:1.4;}
#leaderboardModal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.78);z-index:450;padding:16px;}
.leaderboardPanel{width:min(560px,100%);max-height:min(80vh,640px);display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:12px;border:1px solid #2a3550;background:#0b101d;}
.leaderboardPanel h3{font-family:'Orbitron',monospace;font-size:16px;letter-spacing:3px;color:#d4ddff;text-transform:uppercase;text-align:center;}
#leaderboardModalList{display:flex;flex-direction:column;gap:6px;overflow:auto;padding-right:4px;}

/* Track Editor */
.editorScreen{background:rgba(5,7,12,.92);backdrop-filter:blur(4px);justify-content:flex-start;padding:28px;overflow:auto;}
.editorWrap{width:min(1500px,100%);height:calc(100vh - 56px);display:grid;grid-template-columns:360px 1fr;gap:18px;align-items:stretch;}
.editorSidebar,.editorCanvasPanel{background:rgba(10,12,20,.92);border:1px solid #223041;border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.28);}
.editorSidebar{padding:18px 16px;overflow:auto;}
.editorCanvasPanel{position:relative;padding:14px;display:flex;flex-direction:column;}
.editorTop{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;}
.editorTop h2{margin:0 0 4px;font-size:22px;letter-spacing:4px;color:#cfd7ff;}
.editorSub{font-size:12px;color:#7f8aa5;letter-spacing:1px;line-height:1.4;}
.btn-tight{padding:10px 14px;font-size:11px;letter-spacing:2px;}
.editorSection{padding:12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.05);border-radius:10px;background:rgba(255,255,255,.02);}
.editorLabel{font-family:'Orbitron',monospace;font-size:11px;letter-spacing:3px;color:#94a0bc;margin-bottom:10px;text-transform:uppercase;}
.editorField{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;font-size:12px;color:#9eabc8;}
.editorField input,.editorField select{background:#0d1320;color:#eef3ff;border:1px solid #243246;border-radius:8px;padding:9px 10px;font:inherit;}
.editorField input[type="color"]{padding:3px;height:38px;}
.editorField input[type="range"]{padding:0;}
.editorGrid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.editorCheckbox{flex-direction:row;align-items:center;justify-content:space-between;padding-top:18px;}
.editorHint{font-size:11px;color:#7e8aa5;line-height:1.4;margin-bottom:10px;}
.editorRow{display:flex;gap:8px;flex-wrap:wrap;}
.editorRowWrap{flex-wrap:wrap;}
.editorList{display:flex;flex-direction:column;gap:7px;max-height:180px;overflow:auto;margin-bottom:10px;}
.editorListItem{padding:9px 10px;border-radius:8px;background:#0d1320;border:1px solid #202b3d;color:#a9b6d0;cursor:pointer;font-size:12px;}
.editorListItem:hover,.editorListItem.sel{border-color:#ff5500;background:rgba(255,85,0,.12);color:#fff;}
#trackEditorCanvas{width:100%;height:100%;min-height:660px;border-radius:12px;border:1px solid #1b2635;background:#0a0c14;}
.editorCanvasHint,.editorPreviewBanner{position:absolute;left:26px;padding:8px 12px;border-radius:999px;font-size:11px;letter-spacing:1px;backdrop-filter:blur(3px);}
.editorCanvasHint{bottom:20px;background:rgba(4,8,14,.76);border:1px solid rgba(120,150,200,.2);color:#afbdd7;}
.editorPreviewBanner{top:20px;background:rgba(255,85,0,.14);border:1px solid rgba(255,85,0,.3);color:#ffd3be;}
.editorAssetPalette{display:flex;flex-wrap:wrap;gap:8px;}
.assetChip{padding:8px 12px;border-radius:999px;border:1px solid #263243;background:#0d1320;color:#eaf0ff;font-size:12px;cursor:grab;}
.assetChip:active{cursor:grabbing;}
.assetChip.active{border-color:#ff5500;background:rgba(255,85,0,.18);color:#fff;box-shadow:0 0 0 1px rgba(255,85,0,.25) inset;}
/* Car Editor */
#carEditorInteract{width:100%;flex:1;border-radius:12px;border:1px solid #1b2635;cursor:crosshair;min-height:400px;}
#carEditorInteract.place-active{cursor:cell;}
.btn-active{border-color:#ff5500!important;background:rgba(255,85,0,.22)!important;color:#fff!important;}

@media (max-width: 1200px){.editorWrap{grid-template-columns:1fr; height:auto;} #trackEditorCanvas{min-height:520px;}}

.editorScreen{background:rgba(2,4,8,.32);backdrop-filter:blur(1px);}
.editorCanvasPanel{background:rgba(6,10,18,.38);overflow:hidden;}
#trackEditorCanvas{background:transparent;cursor:crosshair;}
.editorPreviewBanner{display:block;background:rgba(70,180,255,.12);border:1px solid rgba(70,180,255,.25);color:#d8efff;}

.toggleRow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);}
.toggleLbl{font-family:'Orbitron',monospace;font-size:11px;letter-spacing:2px;color:#667;}
.touchCfgHint{margin:10px 4px 0;font-size:11px;color:#556;letter-spacing:1px;}
#touchToggleInput{width:20px;height:20px;accent-color:#ff5500;cursor:pointer;}
#gyroToggleInput{width:20px;height:20px;accent-color:#ff5500;cursor:pointer;}
#onlineGhostToggleInput{width:20px;height:20px;accent-color:#66d9ff;cursor:pointer;}
#onlineGhostCountSelect{min-width:170px;background:#0d1320;color:#eef3ff;border:1px solid #243246;border-radius:8px;padding:8px 10px;font:inherit;cursor:pointer;}
#touchControls{position:fixed;inset:0;display:none;justify-content:space-between;align-items:flex-end;padding:12px;pointer-events:none;z-index:250;}
.touchCluster{display:flex;gap:10px;pointer-events:none;}
.touchCluster-left{align-items:flex-end;}
.touchCluster-right{align-items:flex-end;}
.touchCluster-utility{position:absolute;top:12px;right:12px;align-items:flex-start;}
.touchBtn{pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none;min-width:80px;min-height:54px;padding:0 14px;border-radius:14px;border:1px solid rgba(255,255,255,.22);background:rgba(7,10,20,.72);color:#eef2ff;font-family:'Orbitron',monospace;font-size:12px;letter-spacing:1px;}
.touchBtn-small{min-width:58px;min-height:58px;padding:0 8px;font-size:13px;}
.touchBtn-primary{background:rgba(255,90,20,.78);border-color:rgba(255,140,100,.8);}
.touchBtn.active{transform:translateY(1px) scale(.98);background:rgba(80,140,255,.78);border-color:rgba(140,180,255,.9);}
/* Gyro settings bar */
#gyroSettingsBar{position:relative;margin:6px 4px 2px;height:28px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);overflow:hidden;}
.gyroSettingsDz{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:9.2%;background:rgba(255,255,255,.09);border-left:1px solid rgba(255,255,255,.12);border-right:1px solid rgba(255,255,255,.12);}
.gyroSettingsDot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:11px;height:11px;border-radius:50%;background:#ff5500;box-shadow:0 0 8px #ff5500bb;transition:left .05s linear;}

/* In-game gyro steering bar (replaces slider when gyro active) */
.gyroSteerBar{position:relative;width:158px;min-height:58px;border-radius:14px;border:1px solid rgba(255,255,255,.22);background:rgba(7,10,20,.72);overflow:hidden;flex-shrink:0;}
.gyroSteerDz{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:9.2%;background:rgba(255,255,255,.1);border-left:1px solid rgba(255,255,255,.14);border-right:1px solid rgba(255,255,255,.14);}
.gyroSteerDot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:#ff5500;box-shadow:0 0 12px #ff5500cc;transition:left .04s linear;}

/* Touch steer slider */
.touchSteerSlider{pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none;position:relative;width:300px;min-height:58px;border-radius:14px;border:1px solid rgba(255,255,255,.22);background:rgba(7,10,20,.72);display:flex;align-items:center;overflow:hidden;flex-shrink:0;}
.touchSteerCenter{position:absolute;top:25%;bottom:25%;left:50%;transform:translateX(-50%);width:2px;background:rgba(255,255,255,.2);border-radius:1px;}
.touchSteerThumb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:42px;border-radius:10px;background:rgba(80,140,255,.78);border:1px solid rgba(140,180,255,.9);transition:transform .12s ease-out;}
.touchSteerThumb.dragging{transition:none;background:rgba(80,140,255,.95);}

@media (max-width: 700px){
  #touchControls{padding:10px;}
  .touchBtn{min-width:74px;min-height:52px;font-size:11px;}
  .touchBtn-small{min-width:54px;min-height:54px;}
  .gyroSteerBar{width:134px;min-height:54px;}
  .touchSteerSlider{width:134px;min-height:54px;}
  .touchSteerThumb{width:40px;height:38px;}
}

@media (max-width: 900px){
  .screen{justify-content:flex-start;padding-top:40px;padding-bottom:32px;}
  .screen h1{font-size:clamp(42px,12vw,62px);letter-spacing:6px;}
  .screen .sub{font-size:11px;letter-spacing:3px;margin-bottom:28px;text-align:center;}
  .screen h2{font-size:20px;letter-spacing:4px;margin-bottom:20px;text-align:center;}
  .menuVersion{right:14px;bottom:12px;font-size:11px;}
  .card,.tcard{width:min(100%,360px);}
  #podium{flex-wrap:wrap;justify-content:center;}
}

@media (max-height: 760px){
  .screen{justify-content:flex-start;padding-top:28px;padding-bottom:28px;}
  #settingsModal{top:12px;transform:translateX(-50%);}
}

@media (max-width: 560px){
  .btn{padding:11px 22px;font-size:12px;letter-spacing:2px;}
  #settingsModal{padding:22px 16px 18px;}
  .vol-row{gap:8px;}
  .vol-lbl{width:84px;text-align:left;font-size:10px;letter-spacing:1px;}
  .ctrl-grid{grid-template-columns:1fr;font-size:11px;gap:4px;padding:14px;}
  .ctrl-grid span:nth-child(odd){margin-top:6px;}
}
