*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;overscroll-behavior:none;touch-action:none;background:#02030a;font-family:Inter,Arial,Helvetica,sans-serif;color:#fff}
body{display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);background:radial-gradient(circle at 50% 0%,rgba(0,247,255,.14),transparent 34%),radial-gradient(circle at 85% 22%,rgba(255,31,220,.10),transparent 32%),linear-gradient(180deg,#050716,#02030a 62%,#000)}
button,input,textarea,select{font-size:16px;font-family:inherit}.hidden{display:none!important}
#game-shell{position:relative;width:min(100vw,calc(100vh * 9 / 16));height:min(100vh,calc(100vw * 16 / 9));overflow:hidden;background:#050714;border:1px solid rgba(191,255,255,.14);box-shadow:0 24px 80px rgba(0,0,0,.68),0 0 44px rgba(0,247,255,.16),inset 0 0 44px rgba(0,247,255,.04)}
#gameCanvas{display:block;width:100%;height:100%;image-rendering:auto}
.screen{position:absolute;inset:0;z-index:6;display:none;align-items:center;justify-content:center;flex-direction:column;padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));pointer-events:none;background:radial-gradient(circle at 50% 17%,rgba(0,247,255,.10),transparent 34%),linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.78))}
.screen.active{display:flex;pointer-events:auto}.screen:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.11;background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:100% 6px}.compact-screen{z-index:7}
.logo-wrap{position:relative;z-index:2;width:100%;max-width:360px;text-align:center;margin-bottom:18px;filter:drop-shadow(0 0 12px rgba(0,247,255,.32))}.logo-title span,.logo-title strong{display:block;font-weight:1000;font-style:italic;line-height:.82;letter-spacing:-.035em;text-shadow:0 0 14px rgba(0,247,255,.58)}.logo-title span{font-size:clamp(58px,12vw,76px)}.logo-title strong{font-size:clamp(58px,12vw,76px);color:#fff}.logo-sub{display:inline-block;margin-top:14px;padding:8px 17px;border:1px solid rgba(0,247,255,.42);border-radius:999px;background:rgba(3,8,22,.62);box-shadow:0 0 14px rgba(0,247,255,.12);color:#bfffff;font-size:11px;font-weight:1000;letter-spacing:.16em;white-space:nowrap}
.menu-card{position:relative;z-index:2;width:100%;max-width:354px;padding:18px;border-radius:24px;text-align:center;color:#fff;background:linear-gradient(160deg,rgba(5,9,24,.94),rgba(12,8,32,.90) 56%,rgba(4,8,22,.94));border:1px solid rgba(191,255,255,.28);box-shadow:0 18px 58px rgba(0,0,0,.50),0 0 26px rgba(0,247,255,.14),inset 0 0 24px rgba(255,31,220,.06);overflow:hidden}.menu-card:after{content:"";position:absolute;left:18px;right:18px;top:0;height:1px;background:linear-gradient(90deg,transparent,#8fffff,transparent);opacity:.68}.hero-card{max-width:366px}.protocol-row{display:flex;align-items:center;gap:14px;text-align:left;margin-bottom:15px}.menu-mascot-preview{flex:0 0 78px;height:78px;border-radius:22px;border:1px solid rgba(191,255,255,.34);background:radial-gradient(circle,rgba(191,255,255,.13),rgba(0,0,0,.22));background-size:contain;background-position:center;background-repeat:no-repeat;box-shadow:0 0 18px rgba(0,247,255,.16)}.protocol-copy{min-width:0}.eyebrow{font-size:clamp(17px,4.2vw,23px);line-height:1.02;letter-spacing:.09em;color:#fff;font-weight:1000;text-shadow:0 0 10px rgba(0,247,255,.55)}.tagline,.menu-card p{margin-top:7px;color:#dfffff;font-size:13.5px;font-weight:800;line-height:1.28}.menu-card h2{font-size:34px;margin:8px 0 12px;text-shadow:0 0 14px rgba(255,31,78,.72)}
.primary-btn,.secondary-btn,.ghost-btn{position:relative;z-index:2;width:100%;min-height:52px;margin-top:10px;padding:15px 16px;border-radius:18px;cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none;border:1px solid rgba(255,255,255,.34);font-weight:1000;letter-spacing:.09em;transition:transform .12s ease,filter .12s ease}.primary-btn{color:#fff;background:linear-gradient(94deg,#ff25df 0%,#724bff 45%,#00f7ff 100%);box-shadow:0 0 20px rgba(0,247,255,.28),inset 0 0 14px rgba(255,255,255,.18);text-shadow:0 0 8px rgba(255,255,255,.58)}.primary-btn span{margin-right:10px}.secondary-btn{color:#fff;background:linear-gradient(94deg,rgba(117,62,255,.72),rgba(0,247,255,.38));border-color:rgba(191,255,255,.32)}.ghost-btn{color:#dfffff;background:rgba(5,12,28,.66);border-color:rgba(191,255,255,.26)}.primary-btn:active,.secondary-btn:active,.ghost-btn:active,.pause-btn:active,.footer-link:active{transform:scale(.985)}
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:13px}.stat-strip div{border:1px solid rgba(191,255,255,.18);border-radius:15px;padding:9px 5px;background:rgba(1,5,18,.42)}.stat-strip span{display:block;font-size:8px;opacity:.78;font-weight:1000;letter-spacing:.12em}.stat-strip strong{display:block;margin-top:4px;font-size:16px;text-shadow:0 0 8px rgba(0,247,255,.70)}#menuSignalLabel{color:#fff45c;text-shadow:0 0 10px rgba(255,244,92,.58)}.footer-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:13px;color:#bfffff;font-size:10px;font-weight:1000;letter-spacing:.10em}.footer-link{min-height:40px;border:1px solid rgba(0,247,255,.38);border-radius:999px;padding:8px 13px;color:#fff;background:linear-gradient(90deg,rgba(0,247,255,.13),rgba(255,31,220,.13));font-weight:1000;letter-spacing:.10em;cursor:pointer;box-shadow:0 0 12px rgba(0,247,255,.10)}
.hud{position:absolute;top:calc(10px + env(safe-area-inset-top));left:10px;right:10px;z-index:4;display:grid;grid-template-columns:.82fr 1.12fr .78fr 42px;gap:7px;align-items:start;pointer-events:none}.hud-panel,.evo-bar,.pause-btn{border:1px solid rgba(191,255,255,.28);background:rgba(3,8,22,.72);box-shadow:0 0 10px rgba(0,247,255,.11),inset 0 0 12px rgba(255,31,220,.05)}.hud-panel{min-height:50px;border-radius:16px;padding:8px 9px;color:#eaffff;text-transform:uppercase}.hud-kicker{display:block;font-size:7px;letter-spacing:.20em;color:#bfffff;opacity:.84}.hud-panel strong{display:block;margin-top:3px;font-size:21px;line-height:1;text-shadow:0 0 9px rgba(0,247,255,.68)}.variant-panel{text-align:right}.variant-panel strong{font-size:15px;padding-top:4px}.hud-center{display:flex;flex-direction:column;gap:5px;align-items:center;padding-top:25px}.evo-bar{width:100%;height:9px;border-radius:999px;overflow:hidden;background:rgba(1,4,15,.74)}.evo-bar i{display:block;width:0%;height:100%;border-radius:999px;background:linear-gradient(90deg,#00f7ff,#ff1fdc,#fff45c);box-shadow:0 0 10px rgba(0,247,255,.62)}#comboLabel{color:#dfffff;font-size:8px;font-weight:1000;letter-spacing:.12em;text-shadow:0 0 6px rgba(0,247,255,.48);white-space:nowrap}.pause-btn{pointer-events:auto;height:42px;border-radius:15px;color:#fff;font-weight:1000;font-size:18px;cursor:pointer}
.danger{background:linear-gradient(160deg,rgba(22,4,12,.95),rgba(38,6,32,.88));border-color:rgba(255,90,130,.42)}.big-score{font-size:24px!important;color:#fff!important;text-shadow:0 0 12px rgba(0,247,255,.45)}.best-score{font-size:15px!important;color:#bfffff!important}.share-card-wrap{max-width:min(420px,94vw);padding:18px 16px}#shareCardCanvas{width:100%;max-width:min(285px,58vw,36vh);aspect-ratio:9/16;display:block;margin:14px auto 8px;border-radius:22px;border:1px solid rgba(0,247,255,.44);background:#050716;box-shadow:0 0 26px rgba(0,247,255,.20),0 0 42px rgba(255,31,220,.09)}
.evolution-overlay{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none}.evolution-flash{position:absolute;inset:0;opacity:0;background:radial-gradient(circle at center,rgba(255,255,255,.85),rgba(0,247,255,.16) 34%,transparent 72%)}.evolution-overlay.active .evolution-flash{animation:evoFlash .55s ease-out both}.evolution-core{position:relative;text-align:center}.evolution-mascot{width:160px;height:160px;margin:auto;background-size:contain;background-position:center;background-repeat:no-repeat;filter:drop-shadow(0 0 18px #00f7ff)}.evolution-overlay.active .evolution-mascot{animation:evoMascotPop .7s cubic-bezier(.18,.98,.22,1.12) both}.evolution-copy{margin-top:16px;text-transform:uppercase}.evolution-copy span{display:block;color:#bfffff;font-size:11px;font-weight:1000;letter-spacing:.20em;text-shadow:0 0 8px #00f7ff}.evolution-copy strong{display:block;margin-top:6px;color:#fff;font-size:26px;letter-spacing:.05em;font-weight:1000;text-shadow:0 0 14px #fff,0 0 20px #ff1fdc}.evolution-copy em{display:inline-block;margin-top:8px;padding:7px 16px;border:1px solid rgba(0,247,255,.58);border-radius:999px;background:rgba(0,247,255,.10);color:#fff45c;font-style:normal;font-size:11px;font-weight:1000;letter-spacing:.14em}.toast{position:absolute;left:50%;bottom:calc(26px + env(safe-area-inset-bottom));z-index:12;transform:translateX(-50%);padding:11px 16px;border:1px solid rgba(191,255,255,.36);border-radius:999px;background:rgba(4,8,22,.92);color:#fff;font-size:13px;font-weight:900;box-shadow:0 0 16px rgba(0,247,255,.14);white-space:nowrap}
@keyframes evoFlash{0%{opacity:0}14%{opacity:1}100%{opacity:0}}@keyframes evoMascotPop{0%{opacity:0;transform:scale(.35) rotate(-10deg)}50%{opacity:1;transform:scale(1.12) rotate(4deg)}100%{opacity:1;transform:scale(1) rotate(0)}}
@media (min-width:900px){#game-shell{height:min(94vh,860px);width:min(52.875vh,484px);border-radius:24px}.logo-title span,.logo-title strong{font-size:72px}.menu-card{max-width:372px}.logo-wrap{margin-bottom:20px}#shareCardCanvas{max-width:310px}}
@media (max-width:430px){.screen{padding-left:16px;padding-right:16px}.logo-wrap{margin-bottom:16px}.logo-title span,.logo-title strong{font-size:clamp(52px,17vw,68px)}.logo-sub{font-size:10px;padding:7px 14px}.menu-card{max-width:100%;padding:17px 15px;border-radius:24px}.protocol-row{gap:12px;margin-bottom:14px}.menu-mascot-preview{flex-basis:72px;height:72px;border-radius:20px}.eyebrow{font-size:19px}.tagline,.menu-card p{font-size:13px}.primary-btn,.secondary-btn,.ghost-btn{min-height:50px;font-size:16px;padding:14px 13px}.stat-strip strong{font-size:15px}.hud{grid-template-columns:.78fr 1fr .70fr 40px;left:8px;right:8px;gap:6px}.hud-panel{padding:7px 7px;min-height:48px}.hud-panel strong{font-size:20px}.variant-panel strong{font-size:13px}.hud-center{padding-top:24px}.pause-btn{height:40px}#shareCardCanvas{max-width:min(250px,64vw,38vh)}}
@media (max-height:720px){.logo-title span,.logo-title strong{font-size:clamp(46px,11.2vh,62px)}.logo-sub{margin-top:8px}.menu-card{padding:15px}.menu-mascot-preview{flex-basis:68px;height:68px}.primary-btn,.secondary-btn,.ghost-btn{min-height:48px}.stat-strip{margin-top:10px}.footer-row{margin-top:10px}.protocol-row{margin-bottom:12px}}

/* OMO ARCHIVE - frontend-only mascot unlock UI */
.archive-menu-btn{position:relative;z-index:2;width:100%;min-height:50px;margin-top:10px;padding:14px 16px;border-radius:18px;border:1px solid rgba(0,247,255,.42);color:#eaffff;background:linear-gradient(105deg,rgba(2,10,25,.92),rgba(28,10,52,.86));font-weight:1000;letter-spacing:.11em;cursor:pointer;box-shadow:0 0 18px rgba(0,247,255,.16),inset 0 0 18px rgba(255,31,220,.08);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.archive-menu-btn:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(90deg,transparent,rgba(255,255,255,.20),transparent);transform:translateX(-120%);transition:transform .55s ease}.archive-menu-btn:hover:before{transform:translateX(120%)}.archive-menu-btn:hover{transform:translateY(-1px);border-color:rgba(255,31,220,.55);box-shadow:0 0 24px rgba(0,247,255,.22),0 0 20px rgba(255,31,220,.12)}.archive-menu-btn span{margin-right:9px}
.archive-screen{z-index:9;align-items:stretch;justify-content:flex-start;padding:calc(14px + env(safe-area-inset-top)) 12px calc(14px + env(safe-area-inset-bottom));background:radial-gradient(circle at 50% 0%,rgba(0,247,255,.16),transparent 34%),radial-gradient(circle at 70% 25%,rgba(255,31,220,.13),transparent 38%),linear-gradient(180deg,rgba(0,0,0,.58),rgba(0,0,0,.88))}.archive-screen:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(0,247,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,31,220,.035) 1px,transparent 1px);background-size:42px 42px;opacity:.25;mask-image:linear-gradient(to bottom,transparent,#000 12%,#000 88%,transparent)}.archive-shell{position:relative;z-index:2;width:100%;max-width:560px;height:100%;margin:0 auto;padding:16px;border-radius:26px;border:1px solid rgba(191,255,255,.25);background:linear-gradient(160deg,rgba(4,8,22,.92),rgba(12,8,32,.88));box-shadow:0 22px 70px rgba(0,0,0,.58),0 0 28px rgba(0,247,255,.13),inset 0 0 28px rgba(255,31,220,.06);overflow:hidden;display:flex;flex-direction:column}.archive-shell:before{content:"";position:absolute;inset:-30%;background:radial-gradient(circle,rgba(0,247,255,.12),transparent 34%);animation:archivePulse 8s ease-in-out infinite;pointer-events:none}.archive-topbar{position:relative;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(191,255,255,.14)}.archive-eyebrow{font-size:10px;font-weight:1000;letter-spacing:.18em;color:#8fffff;text-shadow:0 0 10px rgba(0,247,255,.42)}.archive-topbar h2{margin-top:5px;font-size:clamp(30px,7vw,44px);line-height:.9;font-weight:1000;font-style:italic;letter-spacing:-.04em;text-shadow:0 0 18px rgba(0,247,255,.58)}.archive-topbar p{margin-top:8px;color:#dfffff;font-size:13px;font-weight:800;line-height:1.25}.archive-close-btn{flex:0 0 46px;width:46px;height:46px;border-radius:16px;border:1px solid rgba(191,255,255,.28);color:#fff;background:rgba(2,6,18,.70);font-size:28px;line-height:1;cursor:pointer;box-shadow:0 0 14px rgba(0,247,255,.12)}.skin-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;overflow:auto;padding:2px 2px 16px;scrollbar-width:none}.skin-grid::-webkit-scrollbar{display:none}.skin-card{position:relative;min-height:224px;padding:13px 10px 12px;border-radius:22px;border:1px solid rgba(191,255,255,.20);background:linear-gradient(160deg,rgba(7,13,34,.88),rgba(13,8,30,.86));color:#fff;text-align:center;cursor:pointer;overflow:hidden;box-shadow:inset 0 0 22px rgba(0,247,255,.05),0 12px 34px rgba(0,0,0,.28);animation:skinFloat 4.8s ease-in-out infinite;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.skin-card:nth-child(2n){animation-delay:.5s}.skin-card:hover,.skin-card:active{transform:translateY(-2px) scale(1.015);border-color:rgba(0,247,255,.48);box-shadow:0 0 24px rgba(0,247,255,.18),0 14px 40px rgba(0,0,0,.36),inset 0 0 22px rgba(255,31,220,.08)}.skin-shine{position:absolute;inset:-40% auto -40% -55%;width:45%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.20),transparent);transform:rotate(18deg);animation:shineSweep 5.8s ease-in-out infinite}.skin-image{display:block;width:96px;height:96px;margin:0 auto 9px;border-radius:22px;background-position:center;background-size:contain;background-repeat:no-repeat;filter:drop-shadow(0 0 12px rgba(0,247,255,.30));position:relative}.skin-name{display:block;min-height:34px;font-size:13px;line-height:1.1;letter-spacing:.02em;text-transform:uppercase;text-shadow:0 0 8px rgba(255,255,255,.20)}.rarity-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;margin-top:7px;padding:5px 9px;border-radius:999px;font-size:9px;font-weight:1000;letter-spacing:.12em;border:1px solid rgba(255,255,255,.20);color:#fff;text-shadow:0 0 8px rgba(255,255,255,.28)}.rarity-common{background:rgba(160,170,185,.20);border-color:rgba(180,190,205,.38)}.rarity-rare{background:rgba(0,122,255,.25);border-color:rgba(66,164,255,.55);box-shadow:0 0 12px rgba(0,122,255,.18)}.rarity-epic{background:rgba(150,60,255,.26);border-color:rgba(190,112,255,.62);box-shadow:0 0 13px rgba(150,60,255,.20)}.rarity-legendary{background:rgba(255,190,40,.25);border-color:rgba(255,222,93,.72);color:#fff8bf;box-shadow:0 0 16px rgba(255,190,40,.25)}.rarity-mythic{background:rgba(255,31,78,.26);border-color:rgba(255,93,116,.72);box-shadow:0 0 18px rgba(255,31,78,.28)}.rarity-secret{background:linear-gradient(90deg,#ff1fdc,#00f7ff,#fff45c,#ff1fdc);background-size:220% 100%;animation:secretGlow 2.4s linear infinite;border-color:rgba(255,255,255,.80);color:#02030a}.skin-price{display:block;margin-top:8px;color:#bfffff;font-size:12px;font-weight:1000}.skin-action{display:block;margin:10px auto 0;min-height:34px;width:100%;border-radius:13px;padding:9px 8px;color:#fff;background:linear-gradient(90deg,rgba(255,31,220,.72),rgba(0,247,255,.55));font-size:11px;font-weight:1000;letter-spacing:.08em;box-shadow:0 0 14px rgba(0,247,255,.14)}.skin-lock{display:none;position:absolute;top:11px;right:11px;z-index:3;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.55);border:1px solid rgba(191,255,255,.25);align-items:center;justify-content:center;font-size:13px}.skin-card.locked .skin-lock{display:flex}.skin-card.locked .skin-image{filter:grayscale(.25) brightness(.78) drop-shadow(0 0 10px rgba(255,31,220,.20))}.skin-card.locked:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.22));pointer-events:none}.skin-card.owned .skin-action{background:linear-gradient(90deg,rgba(0,247,255,.48),rgba(116,75,255,.48))}
.purchase-screen{z-index:12;background:rgba(0,0,0,.66);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.purchase-card{position:relative;z-index:3;width:min(92vw,390px);padding:22px;border-radius:28px;text-align:center;background:linear-gradient(160deg,rgba(5,9,24,.96),rgba(18,8,42,.94));border:1px solid rgba(191,255,255,.32);box-shadow:0 22px 70px rgba(0,0,0,.62),0 0 28px rgba(0,247,255,.18),inset 0 0 28px rgba(255,31,220,.08);overflow:hidden}.purchase-card:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transform:translateX(-100%);animation:shineSweep 5s ease-in-out infinite}.purchase-mascot{position:relative;width:162px;height:162px;margin:0 auto 12px;border-radius:34px;background-position:center;background-repeat:no-repeat;background-size:contain;filter:drop-shadow(0 0 22px rgba(0,247,255,.38))}.purchase-card h2{font-size:27px;margin-top:10px;font-weight:1000;letter-spacing:-.02em;text-transform:uppercase}.purchase-card p{margin:10px auto 0;max-width:300px;color:#dfffff;font-size:14px;font-weight:800;line-height:1.35}.purchase-price{margin:15px auto 4px;width:max-content;max-width:100%;padding:9px 14px;border-radius:999px;border:1px solid rgba(255,244,92,.52);background:rgba(255,244,92,.12);color:#fff8bf;font-weight:1000;letter-spacing:.06em;box-shadow:0 0 16px rgba(255,244,92,.14)}
@keyframes shineSweep{0%,58%{transform:translateX(-130%) rotate(18deg)}75%,100%{transform:translateX(330%) rotate(18deg)}}@keyframes skinFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes archivePulse{0%,100%{transform:translate3d(-4%,0,0);opacity:.55}50%{transform:translate3d(6%,4%,0);opacity:.82}}@keyframes secretGlow{0%{background-position:0 0}100%{background-position:220% 0}}
@media (min-width:760px){.archive-shell{max-width:720px}.skin-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.skin-card{min-height:238px}.skin-image{width:112px;height:112px}.archive-topbar h2{font-size:52px}}
@media (max-height:720px){.skin-card{min-height:205px}.skin-image{width:78px;height:78px}.archive-topbar{margin-bottom:10px;padding-bottom:10px}.archive-shell{padding:13px}.purchase-mascot{width:130px;height:130px}}


/* Premium mascot ability HUD */
.ability-name{display:block;margin-bottom:4px;color:#eaffff;font-size:9px;font-weight:1000;letter-spacing:.13em;text-shadow:0 0 10px rgba(0,247,255,.42);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}
.power-bar{position:relative;overflow:hidden;border-color:rgba(191,255,255,.36);box-shadow:inset 0 0 12px rgba(0,0,0,.55),0 0 18px rgba(0,247,255,.16)}
.power-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transform:translateX(-120%);animation:powerSweep 2.3s linear infinite;pointer-events:none}
.ability-btn{height:48px;min-width:58px;padding:6px 8px;border:1px solid rgba(191,255,255,.36);border-radius:16px;background:linear-gradient(160deg,rgba(7,12,28,.92),rgba(28,8,42,.88));color:#fff;font-weight:1000;letter-spacing:.06em;box-shadow:0 0 16px rgba(0,247,255,.16),inset 0 0 14px rgba(255,31,220,.08);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}
.ability-btn span{font-size:18px;line-height:1;text-shadow:0 0 12px rgba(0,247,255,.8)}
.ability-btn b{font-size:10px;line-height:1}
.ability-btn.ready{border-color:rgba(255,244,92,.72);background:linear-gradient(135deg,rgba(255,31,220,.75),rgba(0,247,255,.72),rgba(255,244,92,.55));box-shadow:0 0 24px rgba(0,247,255,.28),0 0 18px rgba(255,31,220,.18),inset 0 0 18px rgba(255,255,255,.13);animation:abilityReady 1.4s ease-in-out infinite}
.ability-btn.active{border-color:rgba(255,244,92,.92);box-shadow:0 0 28px rgba(255,244,92,.30),0 0 20px rgba(255,31,220,.24);animation:abilityActive .55s ease-in-out infinite alternate}
.ability-btn:disabled{opacity:.72;cursor:default}.ability-btn:not(:disabled):active{transform:scale(.94)}
@keyframes powerSweep{0%{transform:translateX(-120%)}100%{transform:translateX(120%)}}
@keyframes abilityReady{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-1px) scale(1.04)}}
@keyframes abilityActive{0%{transform:scale(.98)}100%{transform:scale(1.04)}}
@media (max-width:520px){.hud{grid-template-columns:.70fr 1fr 54px 40px}.ability-btn{height:42px;min-width:50px;border-radius:14px}.ability-btn span{font-size:16px}.ability-btn b{font-size:9px}.ability-name{font-size:8px}.hud-center{padding-top:10px}}

/* Final HUD grid override after adding the ability trigger */
.hud{grid-template-columns:.72fr 1.10fr .90fr 58px 42px;align-items:start}
.hud-panel,.evo-bar,.pause-btn,.ability-btn{pointer-events:auto}
@media (max-width:520px){.hud{grid-template-columns:.58fr .92fr .85fr 50px 38px;left:6px;right:6px;gap:5px}.hud-panel{padding:6px 5px}.hud-panel strong{font-size:17px}.variant-panel strong{font-size:11px}.pause-btn{height:40px;width:38px;border-radius:13px}.ability-btn{height:40px;min-width:48px;padding:5px 6px}.ability-name{max-width:100%;font-size:7px}#comboLabel{font-size:7px}}
@media (max-width:380px){.hud{grid-template-columns:.58fr 1fr 44px 46px 36px}.variant-panel .hud-kicker{font-size:6px}.variant-panel strong{font-size:9px}.ability-btn b{font-size:8px}}

/* Recheck patch: clear power previews inside archive and purchase modal */
.skin-power-chip{display:block;width:max-content;max-width:100%;margin:7px auto 0;padding:6px 9px;border-radius:999px;border:1px solid rgba(191,255,255,.22);background:linear-gradient(90deg,rgba(0,247,255,.10),rgba(255,31,220,.10));color:#eaffff;font-size:9px;font-weight:1000;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 0 10px rgba(0,247,255,.08)}
.purchase-card{max-height:calc(100dvh - 34px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:auto;touch-action:pan-y;scrollbar-width:none}.purchase-card::-webkit-scrollbar{display:none}
.archive-shell,.skin-grid{touch-action:pan-y}
.purchase-ability-panel{position:relative;margin:14px auto 8px;padding:14px 13px;border-radius:20px;border:1px solid rgba(191,255,255,.28);background:radial-gradient(circle at 50% 0%,rgba(0,247,255,.14),transparent 52%),linear-gradient(160deg,rgba(0,247,255,.08),rgba(255,31,220,.08));box-shadow:inset 0 0 20px rgba(0,247,255,.06),0 0 18px rgba(0,247,255,.10);overflow:hidden}.purchase-ability-panel:before{content:"";position:absolute;inset:-40% auto -40% -70%;width:48%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent);transform:rotate(18deg);animation:shineSweep 4.4s ease-in-out infinite;pointer-events:none}.purchase-ability-panel .power-eyebrow{display:block;color:#8fffff;font-size:9px;font-weight:1000;letter-spacing:.18em;text-shadow:0 0 10px rgba(0,247,255,.48)}.purchase-ability-panel strong{display:block;margin-top:6px;color:#fff;font-size:18px;font-weight:1000;letter-spacing:.06em;text-transform:uppercase;text-shadow:0 0 13px rgba(0,247,255,.38)}.purchase-ability-panel em{display:block;margin:7px auto 0;max-width:310px;color:#fff8bf;font-size:13px;line-height:1.25;font-weight:900;font-style:normal;text-shadow:0 0 8px rgba(255,244,92,.20)}.purchase-ability-panel small{display:block;margin-top:7px;color:#dfffff;font-size:11px;line-height:1.25;font-weight:800}.purchase-ability-panel.base{opacity:.86;background:linear-gradient(160deg,rgba(120,130,150,.10),rgba(0,247,255,.06))}
@media (max-height:740px){.purchase-card{padding:16px}.purchase-ability-panel{padding:11px 10px}.purchase-ability-panel strong{font-size:16px}.purchase-ability-panel em{font-size:12px}.purchase-ability-panel small{font-size:10px}.purchase-price{margin-top:10px}.purchase-card .primary-btn,.purchase-card .ghost-btn{min-height:48px;padding:12px 14px}}

/* === FINAL PREMIUM UI OVERHAUL — PRE DEPLOYMENT === */
:root{--omo-cyan:#00f7ff;--omo-mag:#ff1fdc;--omo-gold:#fff45c;--omo-ink:#02030a;--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom)}
#game-shell:before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 50% 15%,rgba(0,247,255,.14),transparent 26%),radial-gradient(circle at 15% 62%,rgba(255,31,220,.10),transparent 30%),linear-gradient(115deg,transparent 0 42%,rgba(255,255,255,.035) 50%,transparent 58%);mix-blend-mode:screen;opacity:.85}
#game-shell:after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(0,247,255,.035) 1px,transparent 1px);background-size:100% 7px,46px 46px;mask-image:linear-gradient(to bottom,transparent,#000 10%,#000 86%,transparent);opacity:.32}
.screen{z-index:6}.screen.active{animation:screenRise .32s cubic-bezier(.2,.8,.2,1) both}
#mainMenu{justify-content:flex-start;padding-top:calc(22px + env(safe-area-inset-top));gap:10px;background:radial-gradient(circle at 50% 18%,rgba(0,247,255,.16),transparent 31%),radial-gradient(circle at 50% 62%,rgba(255,31,220,.11),transparent 38%),linear-gradient(180deg,rgba(2,3,10,.10),rgba(2,3,10,.74))}
.logo-wrap{margin-bottom:2px}.logo-title{transform:skew(-6deg)}.logo-title span,.logo-title strong{font-size:clamp(54px,13vh,78px);letter-spacing:-.055em}.logo-sub{margin-top:10px;background:linear-gradient(90deg,rgba(0,247,255,.14),rgba(255,31,220,.12));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.hero-card{max-width:min(390px,calc(100vw - 30px));padding:18px 17px 16px;border-radius:30px;background:linear-gradient(155deg,rgba(7,12,31,.76),rgba(17,8,40,.68) 55%,rgba(3,8,22,.74));backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-color:rgba(191,255,255,.36);box-shadow:0 22px 70px rgba(0,0,0,.58),0 0 42px rgba(0,247,255,.18),0 0 34px rgba(255,31,220,.10),inset 0 0 34px rgba(255,255,255,.035)}
.hero-card:before{content:"";position:absolute;inset:-50% -10%;background:conic-gradient(from 120deg,transparent,rgba(0,247,255,.12),transparent,rgba(255,31,220,.10),transparent);animation:coreRotate 12s linear infinite;pointer-events:none}.hero-card>*{position:relative;z-index:2}
.protocol-row{display:flex;flex-direction:column;text-align:center;gap:8px;margin:0 0 13px}.menu-mascot-preview{flex:0 0 auto;width:clamp(142px,31vh,188px);height:clamp(142px,31vh,188px);margin:-4px auto 2px;border-radius:50%;border:1px solid rgba(191,255,255,.44);background-size:78% auto;background-position:center;background-repeat:no-repeat;box-shadow:0 0 0 10px rgba(0,247,255,.035),0 0 32px rgba(0,247,255,.32),0 0 52px rgba(255,31,220,.14),inset 0 0 42px rgba(0,247,255,.10);animation:mascotFloat 3.8s ease-in-out infinite;position:relative;overflow:visible}.menu-mascot-preview:before{content:"";position:absolute;inset:-14px;border-radius:50%;border:2px solid rgba(0,247,255,.28);box-shadow:0 0 24px rgba(0,247,255,.28);animation:coreRotate 7s linear infinite}.menu-mascot-preview:after{content:"";position:absolute;inset:-26px;border-radius:50%;border:1px dashed rgba(255,31,220,.34);filter:drop-shadow(0 0 10px rgba(255,31,220,.32));animation:coreRotate 11s linear infinite reverse}.protocol-copy{max-width:315px;margin:0 auto}.eyebrow{font-size:clamp(18px,4.5vw,25px)}.tagline,.menu-card p{font-size:13px;line-height:1.32;color:#eaffff}
.primary-btn,.secondary-btn,.ghost-btn,.archive-menu-btn,.footer-link{min-height:52px;border-radius:18px;overflow:hidden;box-shadow:0 0 20px rgba(0,247,255,.20),0 12px 28px rgba(0,0,0,.28),inset 0 0 18px rgba(255,255,255,.10);transition:transform .16s cubic-bezier(.2,.8,.2,1),box-shadow .16s ease,filter .16s ease,border-color .16s ease}.primary-btn:before,.secondary-btn:before,.ghost-btn:before{content:"";position:absolute;inset:-30% auto -30% -60%;width:42%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);transform:rotate(18deg);animation:buttonShine 4.8s ease-in-out infinite;pointer-events:none}.primary-btn:hover,.secondary-btn:hover,.ghost-btn:hover,.archive-menu-btn:hover,.footer-link:hover{transform:translateY(-1px) scale(1.01);filter:saturate(1.18);box-shadow:0 0 30px rgba(0,247,255,.28),0 18px 38px rgba(0,0,0,.36),inset 0 0 20px rgba(255,255,255,.14)}.primary-btn:active,.secondary-btn:active,.ghost-btn:active,.archive-menu-btn:active,.footer-link:active,.pause-btn:active,.ability-btn:not(:disabled):active{transform:translateY(1px) scale(.97)}
.stat-strip div{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(180deg,rgba(0,247,255,.08),rgba(1,5,18,.46));border-color:rgba(191,255,255,.24)}
.hud{top:calc(10px + env(safe-area-inset-top));left:8px;right:8px;gap:6px;z-index:5;filter:drop-shadow(0 12px 22px rgba(0,0,0,.42))}.hud-panel,.evo-bar,.pause-btn,.ability-btn{backdrop-filter:blur(13px);-webkit-backdrop-filter:blur(13px);background:linear-gradient(160deg,rgba(3,9,24,.72),rgba(13,8,32,.54));border-color:rgba(191,255,255,.34);box-shadow:0 0 20px rgba(0,247,255,.12),inset 0 0 18px rgba(255,255,255,.045)}.hud-panel{border-radius:18px}.power-bar.ready,.ability-btn.ready{box-shadow:0 0 30px rgba(255,244,92,.30),0 0 22px rgba(0,247,255,.24),inset 0 0 18px rgba(255,255,255,.13)}.pause-btn{min-width:42px;min-height:42px}.ability-name,.skin-name,.skin-power-chip{overflow:visible;text-overflow:clip}.skin-power-chip{white-space:normal;line-height:1.12;border-radius:14px;min-height:29px;width:100%;max-width:126px;display:flex;align-items:center;justify-content:center;padding:6px 7px;word-break:keep-all}.skin-name{min-height:31px;display:flex;align-items:center;justify-content:center;line-height:1.08}
.archive-screen{padding:calc(12px + env(safe-area-inset-top)) 10px calc(12px + env(safe-area-inset-bottom));background:radial-gradient(circle at 50% -5%,rgba(0,247,255,.20),transparent 33%),radial-gradient(circle at 80% 35%,rgba(255,31,220,.15),transparent 36%),linear-gradient(180deg,rgba(0,0,0,.50),rgba(0,0,0,.90))}.archive-screen:before{opacity:.18;background:repeating-linear-gradient(0deg,rgba(255,255,255,.06) 0 1px,transparent 1px 7px)}.archive-screen:after{animation:gridDrift 8s linear infinite}.archive-shell{max-width:740px;padding:calc(14px + env(safe-area-inset-top)*.25) 14px 14px;border-radius:30px;background:linear-gradient(155deg,rgba(4,9,25,.80),rgba(17,7,39,.72));backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-color:rgba(191,255,255,.34)}.archive-topbar{align-items:center;padding-right:2px}.archive-close-btn{flex:0 0 52px;width:52px;height:52px;min-width:52px;min-height:52px;margin-top:0;border-radius:18px;border-color:rgba(0,247,255,.52);background:linear-gradient(145deg,rgba(1,7,20,.88),rgba(29,8,43,.76));box-shadow:0 0 22px rgba(0,247,255,.20),inset 0 0 16px rgba(255,31,220,.08);transition:transform .16s ease,box-shadow .16s ease}.archive-close-btn:hover{transform:rotate(8deg) scale(1.04);box-shadow:0 0 30px rgba(255,31,220,.26),0 0 24px rgba(0,247,255,.24)}.skin-grid{gap:14px;padding:4px 3px 20px}.skin-card{min-height:248px;border-radius:26px;background:radial-gradient(circle at 50% 8%,rgba(0,247,255,.14),transparent 32%),linear-gradient(160deg,rgba(7,13,34,.82),rgba(18,8,38,.78));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-color:rgba(191,255,255,.26)}.skin-card:before{content:"";position:absolute;inset:12px;border-radius:20px;border:1px solid rgba(255,255,255,.07);pointer-events:none}.skin-image{width:104px;height:104px;margin-bottom:10px;filter:drop-shadow(0 0 18px rgba(0,247,255,.38))}.skin-action{min-height:38px;display:flex;align-items:center;justify-content:center}.purchase-card{border-radius:32px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.share-card-wrap{max-width:min(430px,94vw);border-radius:30px}#shareCardCanvas{max-width:min(300px,62vw,45vh);border-radius:24px;box-shadow:0 0 34px rgba(0,247,255,.28),0 0 54px rgba(255,31,220,.14)}.toast{z-index:30;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
@keyframes mascotFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes coreRotate{to{transform:rotate(360deg)}}@keyframes buttonShine{0%,58%{transform:translateX(-140%) rotate(18deg)}76%,100%{transform:translateX(360%) rotate(18deg)}}@keyframes screenRise{from{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes gridDrift{from{background-position:0 0}to{background-position:42px 42px}}
@media (max-height:780px){#mainMenu{padding-top:calc(12px + env(safe-area-inset-top));gap:6px}.logo-title span,.logo-title strong{font-size:clamp(44px,10.5vh,64px)}.logo-sub{margin-top:6px;padding:6px 13px}.hero-card{padding:14px 14px 13px}.menu-mascot-preview{width:clamp(116px,24vh,150px);height:clamp(116px,24vh,150px)}.protocol-row{gap:5px;margin-bottom:9px}.primary-btn,.secondary-btn,.ghost-btn,.archive-menu-btn{min-height:48px;padding:12px 12px;margin-top:8px}.stat-strip{margin-top:9px}.footer-row{margin-top:9px}.skin-card{min-height:220px}.skin-image{width:86px;height:86px}}
@media (max-width:430px){.screen{padding-left:14px;padding-right:14px}.hero-card{max-width:calc(100vw - 28px)}.menu-mascot-preview{width:clamp(128px,32vw,164px);height:clamp(128px,32vw,164px)}.logo-title span,.logo-title strong{font-size:clamp(48px,16vw,68px)}.tagline,.menu-card p{font-size:12.5px}.skin-grid{gap:11px}.skin-card{min-height:232px;padding:12px 8px}.skin-image{width:92px;height:92px}.archive-close-btn{width:50px;height:50px;min-width:50px;min-height:50px}.archive-topbar p{font-size:12px}.hud{grid-template-columns:.58fr 1fr .50fr 48px 38px}.hud-panel strong{font-size:16px}.ability-name{font-size:7px}}
@media (max-height:670px){.logo-title span,.logo-title strong{font-size:clamp(38px,9.2vh,54px)}.menu-mascot-preview{width:clamp(100px,21vh,128px);height:clamp(100px,21vh,128px)}.logo-sub{font-size:9px}.eyebrow{font-size:17px}.tagline{display:none}.stat-strip{display:none}.footer-row{font-size:9px}.skin-card{min-height:202px}.skin-image{width:76px;height:76px}.skin-power-chip{font-size:8px;min-height:27px}.archive-topbar{margin-bottom:8px;padding-bottom:8px}.archive-topbar h2{font-size:30px}.archive-topbar p{display:none}}


/* FINAL PRE-DEPLOYMENT FORCED UI PATCH: settings, archive alignment, share card, premium breach screen */
.footer-actions{display:flex;align-items:center;gap:8px}.footer-actions .footer-link{white-space:nowrap}.settings-screen{z-index:11}.settings-card{max-width:360px}.settings-card h2{font-size:34px;margin:8px 0 6px}.settings-toggle{width:100%;min-height:62px;margin:16px 0 8px;border-radius:20px;border:1px solid rgba(0,247,255,.46);background:linear-gradient(110deg,rgba(0,247,255,.18),rgba(255,31,220,.20));color:#fff;font-weight:1000;letter-spacing:.08em;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 0 28px rgba(0,247,255,.18),inset 0 0 22px rgba(255,255,255,.08);cursor:pointer}.settings-toggle span{font-size:22px}.settings-toggle.off{border-color:rgba(255,255,255,.20);background:rgba(4,8,22,.70);color:#b8c7d8;box-shadow:inset 0 0 18px rgba(255,255,255,.035)}

#mainMenu .menu-mascot-preview{z-index:3}.screen:not(.active) .menu-mascot-preview{display:none!important}
.archive-screen{padding:calc(18px + env(safe-area-inset-top)) 12px calc(18px + env(safe-area-inset-bottom))!important}.archive-shell{overflow:hidden!important;max-width:760px!important}.archive-topbar{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,rgba(4,8,22,.96),rgba(4,8,22,.72));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:22px;padding:6px 0 14px!important}.archive-close-btn{position:relative;z-index:20;flex:0 0 56px!important;width:56px!important;height:56px!important;min-width:56px!important;min-height:56px!important;margin-right:2px!important;font-size:30px!important;display:flex;align-items:center;justify-content:center;line-height:1!important}.skin-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important;align-items:start!important;justify-items:center!important;gap:16px!important;padding:8px 4px 28px!important}.skin-card{width:100%!important;min-height:282px!important;padding:14px 10px 12px!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;overflow:hidden!important}.skin-image{flex:0 0 auto!important;width:104px!important;height:104px!important;margin:0 auto 4px!important}.skin-name{width:100%!important;min-height:44px!important;font-size:clamp(12px,2.2vw,15px)!important;line-height:1.08!important;display:flex!important;align-items:center!important;justify-content:center!important;white-space:normal!important;text-align:center!important;overflow:visible!important}.skin-power-chip{width:100%!important;max-width:132px!important;min-height:42px!important;padding:7px 8px!important;font-size:10px!important;line-height:1.12!important;white-space:normal!important;text-align:center!important;overflow:visible!important}.skin-card .rarity-badge{margin-top:auto!important;margin-bottom:0!important;min-height:32px!important;padding:7px 10px!important;font-size:9px!important;line-height:1!important;white-space:nowrap!important;max-width:100%!important}.skin-price{display:none!important}.skin-action{min-height:36px!important;margin-top:6px!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:10px!important;line-height:1.05!important;white-space:normal!important}

.share-card-wrap{max-height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:auto;touch-action:pan-y}.share-card-wrap .eyebrow{font-size:22px!important;margin-bottom:8px}#shareCardCanvas{width:auto!important;height:auto!important;max-width:min(320px,78vw)!important;max-height:58dvh!important;object-fit:contain!important;margin:10px auto 12px!important}

.gameover-card{position:relative;max-width:min(390px,calc(100vw - 30px))!important;padding:24px 20px 18px!important;border-radius:32px!important;background:radial-gradient(circle at 50% 0%,rgba(255,31,78,.24),transparent 38%),linear-gradient(155deg,rgba(22,4,14,.92),rgba(6,9,28,.86) 55%,rgba(4,7,18,.94))!important;border:1px solid rgba(255,90,130,.48)!important;box-shadow:0 24px 80px rgba(0,0,0,.68),0 0 44px rgba(255,31,78,.18),0 0 34px rgba(0,247,255,.12),inset 0 0 36px rgba(255,255,255,.04)!important;overflow:hidden!important}.breach-grid{position:absolute;inset:0;background:linear-gradient(rgba(255,31,78,.09) 1px,transparent 1px),linear-gradient(90deg,rgba(0,247,255,.06) 1px,transparent 1px);background-size:100% 9px,36px 36px;opacity:.38;animation:gridDrift 7s linear infinite;pointer-events:none}.breach-core{width:72px;height:72px;margin:0 auto 8px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,90,130,.58);background:radial-gradient(circle,rgba(255,31,78,.26),rgba(0,0,0,.36));font-size:40px;font-weight:1000;color:#fff;box-shadow:0 0 30px rgba(255,31,78,.30),inset 0 0 22px rgba(255,255,255,.08);animation:breachPulse 1.45s ease-in-out infinite}.breach-eyebrow{position:relative;font-size:clamp(16px,4vw,22px)!important;color:#ff9eb4!important;text-shadow:0 0 16px rgba(255,31,78,.64)!important}.breach-title{position:relative;font-size:clamp(40px,10vw,58px)!important;line-height:.9!important;margin:8px 0 14px!important;color:#fff!important;letter-spacing:-.03em!important;text-shadow:2px 0 0 rgba(0,247,255,.42),-2px 0 0 rgba(255,31,220,.42),0 0 22px rgba(255,31,78,.58)!important;animation:glitchFlicker 2.8s steps(2,end) infinite}.breach-score-module{position:relative;margin:0 auto 12px;padding:14px 12px;border-radius:22px;border:1px solid rgba(191,255,255,.30);background:linear-gradient(160deg,rgba(0,247,255,.12),rgba(255,31,220,.13));box-shadow:inset 0 0 22px rgba(0,247,255,.08),0 0 22px rgba(0,247,255,.10)}.breach-score-module span{display:block;font-size:10px;font-weight:1000;letter-spacing:.22em;color:#8fffff}.gameover-card .big-score{font-size:clamp(24px,6vw,34px)!important;margin:6px 0 2px!important;line-height:1.1!important}.gameover-card .best-score{font-size:14px!important;margin:0!important;color:#fff8bf!important}.gameover-card .primary-btn,.gameover-card .secondary-btn,.gameover-card .ghost-btn{min-height:52px!important;margin-top:9px!important}.revive-locked{opacity:.82;border-color:rgba(255,255,255,.22)!important;background:rgba(7,12,28,.55)!important}.breach-footer{position:relative;display:block;margin-top:12px;color:#bfffff;font-size:9px;font-weight:1000;letter-spacing:.16em;text-shadow:0 0 10px rgba(0,247,255,.36)}@keyframes breachPulse{0%,100%{transform:scale(1);filter:saturate(1)}50%{transform:scale(1.06);filter:saturate(1.4)}}@keyframes glitchFlicker{0%,94%,100%{transform:translateX(0)}95%{transform:translateX(-2px)}96%{transform:translateX(2px)}}

@media (max-width:430px){.footer-actions{gap:6px}.footer-actions .footer-link{padding-left:10px!important;padding-right:10px!important;font-size:11px!important}.skin-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}.skin-card{min-height:270px!important}.skin-image{width:98px!important;height:98px!important}.archive-topbar h2{font-size:clamp(38px,12vw,54px)!important}.archive-topbar p{display:block!important;font-size:12px!important}.gameover-card{padding:20px 16px 16px!important}.breach-core{width:62px;height:62px;font-size:34px}.share-card-wrap{max-width:94vw!important}}
@media (max-height:700px){.skin-card{min-height:244px!important}.skin-image{width:82px!important;height:82px!important}.skin-name{min-height:38px!important;font-size:12px!important}.skin-power-chip{min-height:36px!important;font-size:9px!important}.skin-card .rarity-badge{min-height:28px!important}.gameover-card .primary-btn,.gameover-card .secondary-btn,.gameover-card .ghost-btn{min-height:48px!important}.breach-core{display:none}.breach-title{font-size:38px!important}.breach-score-module{padding:10px 10px}}

/* TARGETED REPAIR PATCH: restore buttons, prevent truncation, keep menu/archive premium */
#mainMenu.active{display:flex!important;overflow:hidden!important;}
#mainMenu .logo-wrap{flex:0 0 auto;margin-bottom:10px!important;}
#mainMenu .hero-card{display:flex;flex-direction:column;justify-content:flex-start;max-height:calc(100dvh - 156px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:hidden!important;}
#mainMenu .protocol-row{flex:0 0 auto;}
#mainMenu .menu-mascot-preview{display:block!important;visibility:visible!important;opacity:1!important;background-color:rgba(2,8,24,.78)!important;background-size:72% auto!important;background-position:center!important;background-repeat:no-repeat!important;}
#mainMenu .menu-mascot-preview::before,#mainMenu .menu-mascot-preview::after{pointer-events:none!important;}
#mainMenu .primary-btn,#mainMenu .archive-menu-btn,#mainMenu .footer-link{pointer-events:auto!important;}
.footer-row{display:grid!important;grid-template-columns:1fr!important;gap:9px!important;align-items:stretch!important;justify-content:stretch!important;text-align:center!important;margin-top:11px!important;}
.footer-row>span{display:block!important;width:100%!important;line-height:1.15!important;white-space:normal!important;overflow:visible!important;}
.footer-actions{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;width:100%!important;min-width:0!important;}
.footer-actions .footer-link{width:100%!important;min-width:0!important;min-height:46px!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:10px 8px!important;font-size:12px!important;line-height:1!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:clip!important;}

.archive-screen.active{display:flex!important;}
.archive-screen{overflow:hidden!important;}
.archive-shell{height:100%!important;min-height:0!important;display:flex!important;flex-direction:column!important;}
.archive-topbar{flex:0 0 auto!important;align-items:flex-start!important;gap:10px!important;}
.archive-close-btn{pointer-events:auto!important;display:flex!important;align-items:center!important;justify-content:center!important;position:relative!important;right:auto!important;top:auto!important;transform:none!important;}
.skin-grid{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;overflow-x:hidden!important;align-content:start!important;}
.skin-card{box-sizing:border-box!important;min-width:0!important;}
.skin-image{display:block!important;background-color:rgba(2,8,24,.70)!important;background-size:contain!important;background-position:center!important;background-repeat:no-repeat!important;}
.skin-name,.skin-power-chip,.skin-card .rarity-badge,.skin-action{max-width:100%!important;overflow:visible!important;text-overflow:clip!important;word-break:normal!important;hyphens:none!important;}
.skin-power-chip{display:flex!important;align-items:center!important;justify-content:center!important;}
.skin-card .rarity-badge{display:flex!important;align-items:center!important;justify-content:center!important;}

@media (max-width:430px){
  #mainMenu .logo-title span,#mainMenu .logo-title strong{font-size:clamp(42px,14vw,60px)!important;}
  #mainMenu .logo-sub{margin-top:7px!important;font-size:9px!important;padding:6px 12px!important;}
  #mainMenu .hero-card{max-height:calc(100dvh - 138px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding:13px 13px 12px!important;border-radius:24px!important;}
  #mainMenu .menu-mascot-preview{width:clamp(118px,31vw,150px)!important;height:clamp(118px,31vw,150px)!important;margin:-2px auto 0!important;}
  #mainMenu .protocol-row{gap:6px!important;margin-bottom:9px!important;}
  #mainMenu .eyebrow{font-size:clamp(18px,5vw,22px)!important;}
  #mainMenu .tagline{font-size:12px!important;line-height:1.22!important;}
  #mainMenu .primary-btn,#mainMenu .archive-menu-btn{min-height:48px!important;margin-top:8px!important;font-size:15px!important;}
  #mainMenu .stat-strip{gap:7px!important;margin-top:9px!important;}
  #mainMenu .stat-strip div{padding:7px 4px!important;}
  #mainMenu .stat-strip strong{font-size:14px!important;}
  .footer-actions .footer-link{font-size:11px!important;min-height:44px!important;letter-spacing:.07em!important;}
  .archive-shell{border-radius:24px!important;padding:12px!important;}
  .archive-topbar{padding:4px 0 12px!important;margin-bottom:10px!important;}
  .archive-close-btn{flex-basis:52px!important;width:52px!important;height:52px!important;min-width:52px!important;min-height:52px!important;}
  .skin-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;padding-bottom:34px!important;}
  .skin-card{min-height:286px!important;padding:12px 8px 11px!important;gap:7px!important;}
  .skin-image{width:96px!important;height:96px!important;}
  .skin-name{min-height:42px!important;font-size:12px!important;line-height:1.08!important;}
  .skin-power-chip{min-height:40px!important;font-size:9px!important;line-height:1.08!important;}
  .skin-card .rarity-badge{min-height:30px!important;font-size:8px!important;padding:6px 8px!important;letter-spacing:.09em!important;}
}

@media (max-height:700px){
  #mainMenu .hero-card{max-height:calc(100dvh - 120px - env(safe-area-inset-top) - env(safe-area-inset-bottom));}
  #mainMenu .menu-mascot-preview{width:clamp(106px,21vh,132px)!important;height:clamp(106px,21vh,132px)!important;}
  #mainMenu .tagline{display:block!important;font-size:11px!important;}
  #mainMenu .stat-strip{display:grid!important;}
  .footer-row{gap:7px!important;margin-top:8px!important;}
  .footer-actions .footer-link{min-height:40px!important;font-size:10px!important;}
  .skin-card{min-height:260px!important;}
  .skin-image{width:82px!important;height:82px!important;}
}


/* === TARGETED GAME OVER PREMIUM REPAIR + REVIVE AD BUTTON === */
.gameover-card{
  isolation:isolate!important;
  position:relative!important;
  background:
    radial-gradient(circle at 50% 0%,rgba(255,31,78,.30),transparent 36%),
    radial-gradient(circle at 12% 74%,rgba(0,247,255,.18),transparent 34%),
    linear-gradient(155deg,rgba(18,3,14,.98),rgba(5,8,24,.96) 58%,rgba(3,6,18,.98))!important;
  border:1px solid rgba(255,105,150,.58)!important;
  box-shadow:
    0 26px 90px rgba(0,0,0,.78),
    0 0 52px rgba(255,31,78,.22),
    0 0 42px rgba(0,247,255,.16),
    inset 0 0 46px rgba(255,255,255,.045)!important;
}
.gameover-card:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  border-radius:inherit;
  background:
    linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,247,255,.045) 1px,transparent 1px),
    radial-gradient(circle at 50% 8%,rgba(255,31,78,.18),transparent 28%);
  background-size:100% 8px,38px 38px,100% 100%;
  opacity:.42;
  animation:gridDrift 8s linear infinite;
}
.gameover-card > *{position:relative;z-index:2}
.breach-grid{z-index:0!important;opacity:.20!important;mix-blend-mode:screen!important}
.breach-core{
  width:82px!important;
  height:82px!important;
  margin:0 auto 10px!important;
  border-radius:50%!important;
  color:#fff!important;
  background:
    radial-gradient(circle,rgba(255,255,255,.22) 0 12%,rgba(255,31,78,.38) 20%,rgba(255,31,78,.14) 44%,rgba(0,0,0,.48) 72%)!important;
  border:1px solid rgba(255,145,170,.72)!important;
  box-shadow:
    0 0 32px rgba(255,31,78,.42),
    0 0 24px rgba(0,247,255,.14),
    inset 0 0 28px rgba(255,255,255,.10)!important;
}
.breach-core:before{
  content:"";
  position:absolute;
  inset:-9px;
  border-radius:50%;
  border:1px dashed rgba(0,247,255,.45);
  animation:coreRotate 5s linear infinite;
}
.breach-core:after{
  content:"";
  position:absolute;
  inset:-18px;
  border-radius:50%;
  border:1px solid rgba(255,31,220,.25);
  box-shadow:0 0 24px rgba(255,31,220,.15);
  animation:coreRotate 8s linear infinite reverse;
}
.breach-title{
  margin-bottom:16px!important;
  text-shadow:
    2px 0 0 rgba(0,247,255,.48),
    -2px 0 0 rgba(255,31,220,.44),
    0 0 26px rgba(255,31,78,.65)!important;
}
.breach-score-module{
  position:relative!important;
  z-index:5!important;
  margin:16px auto 14px!important;
  padding:18px 16px!important;
  border-radius:24px!important;
  background:
    radial-gradient(circle at 50% 0%,rgba(0,247,255,.12),transparent 48%),
    linear-gradient(160deg,rgba(7,12,31,.98),rgba(16,10,38,.96))!important;
  border:1px solid rgba(0,247,255,.42)!important;
  overflow:hidden!important;
  box-shadow:
    0 0 26px rgba(0,247,255,.14),
    0 14px 36px rgba(0,0,0,.28),
    inset 0 0 28px rgba(0,247,255,.06)!important;
}
.breach-score-module:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:rgba(5,10,25,.96)!important;
}
.breach-score-module:after{
  content:"SIGNAL STATUS: LOST    •    BREACH: CONFIRMED    •    THREAT: CRITICAL";
  display:block;
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(191,255,255,.13);
  color:#bfffff;
  font-size:8px;
  font-weight:1000;
  letter-spacing:.11em;
  line-height:1.25;
  text-shadow:0 0 8px rgba(0,247,255,.28);
}
.breach-score-module span{
  color:#8fffff!important;
  text-shadow:0 0 10px rgba(0,247,255,.45)!important;
}
.gameover-card .big-score{
  display:block!important;
  color:#fff!important;
  font-size:clamp(38px,11vw,58px)!important;
  line-height:.95!important;
  margin:8px 0 0!important;
  text-shadow:0 0 18px rgba(255,255,255,.42),0 0 22px rgba(0,247,255,.24)!important;
}
.gameover-card .big-score::first-letter{text-transform:uppercase}
.gameover-card .best-score{
  color:#fff8bf!important;
  font-size:14px!important;
  margin-top:8px!important;
  text-shadow:0 0 10px rgba(255,244,92,.25)!important;
}
#reviveButton{
  position:relative!important;
  border-color:rgba(255,244,92,.68)!important;
  color:#fff8bf!important;
  background:
    linear-gradient(94deg,rgba(255,186,40,.20),rgba(0,247,255,.18),rgba(255,31,220,.16))!important;
  box-shadow:
    0 0 22px rgba(255,244,92,.18),
    0 0 18px rgba(0,247,255,.12),
    inset 0 0 18px rgba(255,244,92,.06)!important;
  animation:reviveAdPulse 2.8s ease-in-out infinite!important;
}
#reviveButton:before{
  content:"SECOND CHANCE AVAILABLE";
  position:absolute;
  left:50%;
  top:-18px;
  transform:translateX(-50%);
  color:#fff45c;
  font-size:8px;
  font-weight:1000;
  letter-spacing:.14em;
  white-space:nowrap;
  text-shadow:0 0 10px rgba(255,244,92,.45);
  opacity:.92;
}
#reviveButton:after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  border:1px solid rgba(255,244,92,.22);
  pointer-events:none;
  animation:reviveRing 2.8s ease-in-out infinite;
}
#reviveButton.used,
#reviveButton:disabled{
  opacity:.55!important;
  color:#b7bbc8!important;
  border-color:rgba(255,255,255,.16)!important;
  background:rgba(7,12,28,.48)!important;
  box-shadow:inset 0 0 16px rgba(255,255,255,.035)!important;
  animation:none!important;
}
#reviveButton.used:before,
#reviveButton:disabled:before{content:"REVIVE USED";color:#b7bbc8;text-shadow:none}
@keyframes reviveAdPulse{0%,100%{transform:translateY(0);filter:saturate(1)}50%{transform:translateY(-1px);filter:saturate(1.25);box-shadow:0 0 30px rgba(255,244,92,.26),0 0 24px rgba(0,247,255,.18),inset 0 0 20px rgba(255,244,92,.10)}}
@keyframes reviveRing{0%,100%{opacity:.22;transform:scale(1)}50%{opacity:.75;transform:scale(1.018)}}
@media (max-width:430px){
  .breach-score-module{padding:16px 12px!important;margin:14px auto 16px!important}
  .breach-score-module:after{font-size:7px;letter-spacing:.08em}
  .gameover-card .big-score{font-size:clamp(34px,11vw,50px)!important}
  #reviveButton{margin-top:24px!important}
}
@media (max-height:700px){
  .breach-core{display:flex!important;width:56px!important;height:56px!important;font-size:30px!important;margin-bottom:6px!important}
  .breach-core:before,.breach-core:after{display:none!important}
  .breach-title{font-size:34px!important;margin-bottom:10px!important}
  .breach-score-module{padding:12px 10px!important;margin:10px auto 12px!important}
  .gameover-card .big-score{font-size:32px!important}
  #reviveButton{margin-top:20px!important}
}

/* === FINAL GAME OVER 9.5 REVIVE + SCORE STRUCTURE PATCH === */
.gameover-card{
  isolation:isolate!important;
  max-width:min(392px,calc(100vw - 28px))!important;
  background:
    radial-gradient(circle at 50% -4%,rgba(255,31,78,.34),transparent 34%),
    radial-gradient(circle at 10% 68%,rgba(0,247,255,.16),transparent 34%),
    linear-gradient(155deg,rgba(18,3,14,.98),rgba(5,8,24,.97) 58%,rgba(3,6,18,.99))!important;
}
.breach-score-module{
  position:relative!important;
  z-index:5!important;
  width:100%!important;
  margin:14px auto 13px!important;
  padding:16px 14px 15px!important;
  border-radius:25px!important;
  background:
    radial-gradient(circle at 50% 0%,rgba(0,247,255,.12),transparent 46%),
    linear-gradient(160deg,rgba(7,12,31,.985),rgba(15,10,38,.972))!important;
  border:1px solid rgba(0,247,255,.44)!important;
  overflow:hidden!important;
  box-shadow:
    0 0 26px rgba(0,247,255,.16),
    0 16px 38px rgba(0,0,0,.36),
    inset 0 0 30px rgba(0,247,255,.065)!important;
}
.breach-score-module::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:-1!important;
  background:rgba(5,10,25,.98)!important;
}
.breach-score-module::after{
  content:"SIGNAL STATUS: LOST  •  BREACH: CONFIRMED  •  THREAT: CRITICAL"!important;
  display:block!important;
  margin-top:11px!important;
  padding-top:10px!important;
  border-top:1px solid rgba(191,255,255,.14)!important;
  color:#bfffff!important;
  font-size:8px!important;
  font-weight:1000!important;
  letter-spacing:.105em!important;
  line-height:1.25!important;
  text-shadow:0 0 9px rgba(0,247,255,.32)!important;
}
.score-label{
  display:block!important;
  color:#8fffff!important;
  font-size:10px!important;
  font-weight:1000!important;
  letter-spacing:.24em!important;
  line-height:1!important;
  text-shadow:0 0 10px rgba(0,247,255,.48)!important;
}
.score-number{
  display:block!important;
  margin:7px 0 1px!important;
  color:#fff!important;
  font-size:clamp(54px,16vw,82px)!important;
  line-height:.88!important;
  font-weight:1000!important;
  letter-spacing:-.055em!important;
  text-shadow:
    0 0 16px rgba(255,255,255,.48),
    0 0 24px rgba(0,247,255,.28),
    2px 0 0 rgba(255,31,220,.34)!important;
}
.score-cycles{
  display:block!important;
  color:#fff45c!important;
  font-size:13px!important;
  font-weight:1000!important;
  letter-spacing:.24em!important;
  line-height:1!important;
  text-shadow:0 0 12px rgba(255,244,92,.36)!important;
}
.gameover-card .best-score{
  display:block!important;
  margin-top:9px!important;
  color:#fff8bf!important;
  font-size:13px!important;
  font-weight:1000!important;
  letter-spacing:.09em!important;
  line-height:1.15!important;
  text-shadow:0 0 10px rgba(255,244,92,.28)!important;
}
.revive-section{
  position:relative!important;
  z-index:4!important;
  width:100%!important;
  margin:16px 0 0!important;
  padding:13px 10px 10px!important;
  border-radius:22px!important;
  background:
    radial-gradient(circle at 50% 0%,rgba(255,244,92,.15),transparent 56%),
    linear-gradient(135deg,rgba(255,186,40,.075),rgba(0,247,255,.065),rgba(255,31,220,.06))!important;
  border:1px solid rgba(255,244,92,.28)!important;
  box-shadow:0 0 22px rgba(255,244,92,.10),inset 0 0 22px rgba(255,244,92,.045)!important;
  overflow:hidden!important;
}
.revive-section::before{
  content:"";
  position:absolute;
  inset:-40% auto -40% -55%;
  width:42%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:rotate(18deg);
  animation:buttonShine 4.3s ease-in-out infinite;
  pointer-events:none;
}
.revive-eyebrow{
  position:relative!important;
  z-index:2!important;
  margin:0 0 8px!important;
  color:#fff45c!important;
  font-size:9px!important;
  font-weight:1000!important;
  letter-spacing:.18em!important;
  line-height:1.1!important;
  text-shadow:0 0 11px rgba(255,244,92,.46)!important;
  white-space:nowrap!important;
}
.revive-btn{
  position:relative!important;
  z-index:2!important;
  width:100%!important;
  min-height:56px!important;
  border-radius:18px!important;
  border:1px solid rgba(255,244,92,.74)!important;
  color:#fff8bf!important;
  background:
    linear-gradient(94deg,rgba(255,186,40,.25),rgba(0,247,255,.20),rgba(255,31,220,.18))!important;
  font-weight:1000!important;
  letter-spacing:.09em!important;
  cursor:pointer!important;
  box-shadow:
    0 0 26px rgba(255,244,92,.22),
    0 0 20px rgba(0,247,255,.14),
    inset 0 0 20px rgba(255,244,92,.075)!important;
  text-shadow:0 0 10px rgba(255,244,92,.46)!important;
  animation:reviveAdPulse 2.6s ease-in-out infinite!important;
  transition:transform .14s ease,box-shadow .14s ease,filter .14s ease!important;
}
.revive-btn:hover,.revive-btn:active{
  transform:scale(1.018)!important;
  filter:saturate(1.22)!important;
  box-shadow:0 0 34px rgba(255,244,92,.30),0 0 24px rgba(0,247,255,.20),inset 0 0 22px rgba(255,244,92,.10)!important;
}
.revive-btn::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  border:1px solid rgba(255,244,92,.22);
  pointer-events:none;
  animation:reviveRing 2.6s ease-in-out infinite;
}
.revive-btn.used,.revive-btn:disabled{
  opacity:.58!important;
  color:#b7bbc8!important;
  border-color:rgba(255,255,255,.16)!important;
  background:rgba(7,12,28,.50)!important;
  box-shadow:inset 0 0 16px rgba(255,255,255,.035)!important;
  animation:none!important;
  cursor:default!important;
}
.revive-btn.used::after,.revive-btn:disabled::after{display:none!important;}
/* Neutralize legacy label that was clipped above the old button. */
#reviveButton::before{content:none!important;}
#reviveButton::after{content:none!important;}
@media (max-width:430px){
  .gameover-card{padding:18px 15px 15px!important;}
  .breach-score-module{padding:15px 12px 14px!important;margin:12px auto 12px!important;}
  .score-number{font-size:clamp(48px,16vw,70px)!important;}
  .revive-section{margin-top:14px!important;padding:12px 9px 9px!important;}
  .revive-eyebrow{font-size:8px!important;letter-spacing:.13em!important;}
  .revive-btn{min-height:52px!important;font-size:14px!important;}
}
@media (max-height:700px){
  .breach-score-module{padding:11px 10px 10px!important;margin:9px auto 10px!important;}
  .breach-score-module::after{font-size:7px!important;letter-spacing:.075em!important;margin-top:8px!important;padding-top:8px!important;}
  .score-number{font-size:42px!important;}
  .score-cycles{font-size:10px!important;}
  .gameover-card .best-score{font-size:11px!important;margin-top:6px!important;}
  .revive-section{margin-top:10px!important;padding:9px 8px 8px!important;}
  .revive-eyebrow{font-size:7px!important;margin-bottom:6px!important;}
  .revive-btn{min-height:46px!important;font-size:13px!important;}
}

/* === OMO GLOBAL LEADERBOARD — SUPABASE READY UI === */
.leaderboard-menu-btn{position:relative;z-index:2;width:100%;min-height:50px;margin-top:10px;padding:14px 16px;border-radius:18px;border:1px solid rgba(255,244,92,.50);color:#fff;background:linear-gradient(105deg,rgba(255,244,92,.20),rgba(0,247,255,.18) 45%,rgba(255,31,220,.18));font-weight:1000;letter-spacing:.11em;cursor:pointer;box-shadow:0 0 22px rgba(255,244,92,.16),0 0 18px rgba(0,247,255,.16),inset 0 0 18px rgba(255,255,255,.08);overflow:hidden;transition:transform .16s cubic-bezier(.2,.8,.2,1),box-shadow .16s ease,border-color .16s ease,filter .16s ease}.leaderboard-menu-btn:before{content:"";position:absolute;inset:-40% auto -40% -58%;width:44%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);transform:rotate(18deg);animation:buttonShine 4.6s ease-in-out infinite;pointer-events:none}.leaderboard-menu-btn:hover{transform:translateY(-1px) scale(1.01);filter:saturate(1.2);border-color:rgba(255,244,92,.82);box-shadow:0 0 30px rgba(255,244,92,.20),0 0 28px rgba(0,247,255,.22),0 18px 38px rgba(0,0,0,.36),inset 0 0 20px rgba(255,255,255,.12)}.leaderboard-menu-btn:active{transform:translateY(1px) scale(.97)}.leaderboard-menu-btn span{margin-right:9px;filter:drop-shadow(0 0 8px rgba(255,244,92,.72))}
.leaderboard-screen{z-index:13;align-items:stretch;justify-content:flex-start;padding:calc(14px + env(safe-area-inset-top)) 10px calc(14px + env(safe-area-inset-bottom));background:radial-gradient(circle at 50% -5%,rgba(255,244,92,.14),transparent 26%),radial-gradient(circle at 24% 20%,rgba(0,247,255,.18),transparent 34%),radial-gradient(circle at 82% 48%,rgba(255,31,220,.14),transparent 38%),linear-gradient(180deg,rgba(0,0,0,.52),rgba(0,0,0,.92))}.leaderboard-screen:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(255,244,92,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(0,247,255,.04) 1px,transparent 1px);background-size:100% 8px,40px 40px;opacity:.28;mask-image:linear-gradient(to bottom,transparent,#000 12%,#000 88%,transparent);animation:gridDrift 8s linear infinite}.leaderboard-shell{position:relative;z-index:2;width:100%;max-width:760px;height:100%;margin:0 auto;padding:14px;border-radius:30px;border:1px solid rgba(191,255,255,.34);background:linear-gradient(155deg,rgba(4,9,25,.84),rgba(17,7,39,.76));backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 24px 80px rgba(0,0,0,.64),0 0 36px rgba(0,247,255,.16),0 0 28px rgba(255,244,92,.08),inset 0 0 32px rgba(255,255,255,.04);overflow:hidden;display:flex;flex-direction:column}.leaderboard-shell:before{content:"";position:absolute;inset:-45%;background:conic-gradient(from 70deg,transparent,rgba(0,247,255,.10),transparent,rgba(255,244,92,.08),transparent,rgba(255,31,220,.08),transparent);animation:coreRotate 15s linear infinite;pointer-events:none}.leaderboard-shell>*{position:relative;z-index:2}.leaderboard-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 0 13px;border-bottom:1px solid rgba(191,255,255,.16)}.leaderboard-eyebrow{font-size:10px;font-weight:1000;letter-spacing:.18em;color:#fff8bf;text-shadow:0 0 12px rgba(255,244,92,.46)}.leaderboard-topbar h2{margin-top:6px;font-size:clamp(30px,7.4vw,48px);line-height:.9;font-weight:1000;font-style:italic;letter-spacing:-.045em;text-shadow:0 0 18px rgba(0,247,255,.56),0 0 16px rgba(255,244,92,.22)}.leaderboard-topbar p{margin-top:8px;color:#dfffff;font-size:13px;font-weight:800;line-height:1.25}.leaderboard-close-btn{flex:0 0 54px;width:54px;height:54px;min-width:54px;min-height:54px;border-radius:18px;border:1px solid rgba(0,247,255,.52);color:#fff;background:linear-gradient(145deg,rgba(1,7,20,.88),rgba(29,8,43,.76));font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 0 22px rgba(0,247,255,.20),inset 0 0 16px rgba(255,31,220,.08);transition:transform .16s ease,box-shadow .16s ease}.leaderboard-close-btn:active{transform:scale(.96)}
.leaderboard-user-signal{display:flex;align-items:center;gap:12px;margin:13px 0 11px;padding:12px;border-radius:22px;border:1px solid rgba(255,244,92,.26);background:radial-gradient(circle at 8% 20%,rgba(255,244,92,.16),transparent 32%),linear-gradient(120deg,rgba(0,247,255,.10),rgba(255,31,220,.08));box-shadow:inset 0 0 18px rgba(255,255,255,.04),0 0 18px rgba(0,247,255,.08)}.signal-orb{flex:0 0 46px;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,244,92,.52);background:radial-gradient(circle,rgba(255,244,92,.26),rgba(0,0,0,.32));box-shadow:0 0 20px rgba(255,244,92,.20),inset 0 0 15px rgba(255,255,255,.08);font-size:20px}.leaderboard-user-signal span{display:block;color:#fff8bf;font-size:9px;font-weight:1000;letter-spacing:.18em}.leaderboard-user-signal strong{display:block;margin-top:4px;color:#fff;font-size:16px;font-weight:1000;text-shadow:0 0 10px rgba(0,247,255,.38)}.leaderboard-user-signal small{display:block;margin-top:4px;color:#dfffff;font-size:11px;font-weight:800;line-height:1.25}.leaderboard-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;position:sticky;top:0;z-index:5;padding:4px 0 12px;background:linear-gradient(180deg,rgba(5,8,22,.96),rgba(5,8,22,.70),transparent)}.leaderboard-tab{min-height:44px;border-radius:16px;border:1px solid rgba(191,255,255,.24);color:#dfffff;background:linear-gradient(160deg,rgba(5,12,28,.70),rgba(18,8,38,.55));font-size:11px;font-weight:1000;letter-spacing:.11em;cursor:pointer;box-shadow:inset 0 0 14px rgba(255,255,255,.035);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease}.leaderboard-tab.active{color:#02030a;border-color:rgba(255,244,92,.72);background:linear-gradient(95deg,#fff45c,#00f7ff);box-shadow:0 0 22px rgba(255,244,92,.22),0 0 18px rgba(0,247,255,.18),inset 0 0 16px rgba(255,255,255,.28)}.leaderboard-tab:active{transform:scale(.97)}.leaderboard-status{min-height:78px;display:flex;align-items:center;justify-content:center;text-align:center;margin-top:6px;padding:18px;border-radius:22px;border:1px solid rgba(191,255,255,.20);background:linear-gradient(160deg,rgba(0,247,255,.08),rgba(255,31,220,.07));color:#eaffff;font-size:13px;font-weight:1000;letter-spacing:.12em;text-shadow:0 0 10px rgba(0,247,255,.38)}.leaderboard-status[data-state="error"]{border-color:rgba(255,90,130,.42);color:#ffb9c7;background:linear-gradient(160deg,rgba(255,31,78,.13),rgba(255,31,220,.08))}.leaderboard-status[data-state="empty"]{border-color:rgba(255,244,92,.36);color:#fff8bf}.leaderboard-list{overflow:auto;touch-action:pan-y;scrollbar-width:none;padding:1px 2px 18px;margin-top:2px}.leaderboard-list::-webkit-scrollbar{display:none}.leaderboard-row{position:relative;display:grid;grid-template-columns:58px 1fr auto;align-items:center;gap:10px;min-height:76px;margin:0 0 10px;padding:11px 12px;border-radius:22px;border:1px solid rgba(191,255,255,.22);background:radial-gradient(circle at 8% 18%,rgba(0,247,255,.14),transparent 33%),linear-gradient(150deg,rgba(7,13,34,.82),rgba(18,8,38,.76));box-shadow:0 12px 30px rgba(0,0,0,.28),inset 0 0 20px rgba(255,255,255,.035);overflow:hidden;animation:leaderboardRowIn .42s cubic-bezier(.2,.8,.2,1) both;animation-delay:var(--row-delay,0ms)}.leaderboard-row:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:999px;background:linear-gradient(180deg,#00f7ff,#ff1fdc);box-shadow:0 0 14px rgba(0,247,255,.48)}.leaderboard-row.rank-1{border-color:rgba(255,244,92,.64);background:radial-gradient(circle at 8% 18%,rgba(255,244,92,.22),transparent 35%),linear-gradient(150deg,rgba(52,38,7,.70),rgba(18,8,38,.78));box-shadow:0 0 26px rgba(255,244,92,.14),0 12px 34px rgba(0,0,0,.34)}.leaderboard-row.rank-2{border-color:rgba(225,238,255,.46)}.leaderboard-row.rank-3{border-color:rgba(255,152,72,.48)}.leaderboard-row.current-user{border-color:rgba(0,247,255,.72);box-shadow:0 0 24px rgba(0,247,255,.20),0 12px 34px rgba(0,0,0,.34),inset 0 0 22px rgba(0,247,255,.08)}.rank-badge{display:flex;align-items:center;justify-content:center;flex-direction:column;width:48px;height:48px;border-radius:16px;border:1px solid rgba(191,255,255,.28);background:rgba(1,5,18,.48);box-shadow:inset 0 0 15px rgba(255,255,255,.04)}.rank-badge span{font-size:12px;font-weight:1000;color:#dfffff;line-height:1}.rank-badge b{font-size:17px;line-height:1;margin-top:4px}.runner-meta{min-width:0;text-align:left}.runner-meta strong{display:block;font-size:15px;font-weight:1000;line-height:1.1;color:#fff;text-shadow:0 0 10px rgba(0,247,255,.26);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.runner-meta small{display:block;margin-top:6px;color:#bfffff;font-size:10.5px;font-weight:900;line-height:1.22;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.runner-score{font-size:18px;font-weight:1000;color:#fff;text-shadow:0 0 14px rgba(0,247,255,.40);letter-spacing:-.02em;text-align:right}.rank-1 .runner-score{color:#fff8bf;text-shadow:0 0 15px rgba(255,244,92,.48)}@keyframes leaderboardRowIn{from{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (max-width:430px){.leaderboard-screen{padding:calc(12px + env(safe-area-inset-top)) 10px calc(12px + env(safe-area-inset-bottom))}.leaderboard-shell{padding:12px;border-radius:28px}.leaderboard-topbar h2{font-size:clamp(31px,10.6vw,45px)}.leaderboard-topbar p{font-size:12px}.leaderboard-close-btn{width:50px;height:50px;min-width:50px;min-height:50px}.leaderboard-user-signal{padding:11px;gap:10px}.signal-orb{width:42px;height:42px;flex-basis:42px}.leaderboard-tabs{gap:6px}.leaderboard-tab{min-height:42px;font-size:10px}.leaderboard-row{grid-template-columns:50px 1fr auto;gap:8px;min-height:72px;padding:10px;border-radius:20px}.rank-badge{width:44px;height:44px;border-radius:15px}.runner-meta strong{font-size:14px}.runner-meta small{font-size:9.5px;max-width:42vw}.runner-score{font-size:16px}.leaderboard-menu-btn{min-height:48px;padding:12px 13px}}
@media (max-height:700px){.leaderboard-topbar p{display:none}.leaderboard-user-signal{margin:10px 0 8px;padding:10px}.leaderboard-tabs{padding-bottom:8px}.leaderboard-tab{min-height:38px}.leaderboard-row{min-height:66px;margin-bottom:8px}.leaderboard-status{min-height:64px;padding:14px}.runner-score{font-size:15px}}

/* === LEADERBOARD PREMIUM HEADER + CLOSE REPAIR ===
   Fixes clipped "OMO LEADERBOARD" title and guarantees the close button is visible.
   CSS-only patch: no Engine.js changes required. */
.leaderboard-shell{
  min-height:0!important;
}
.leaderboard-topbar{
  position:relative!important;
  display:block!important;
  padding:8px 66px 14px 0!important;
  min-height:88px!important;
  overflow:visible!important;
}
.leaderboard-topbar > div{
  min-width:0!important;
  max-width:100%!important;
}
.leaderboard-eyebrow{
  max-width:100%!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
.leaderboard-topbar h2{
  display:block!important;
  max-width:100%!important;
  margin-top:7px!important;
  font-size:clamp(30px, 8.7vw, 42px)!important;
  line-height:.88!important;
  letter-spacing:-.055em!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  text-wrap:balance;
  text-shadow:
    0 0 18px rgba(0,247,255,.62),
    0 0 22px rgba(255,244,92,.24),
    2px 0 0 rgba(255,31,220,.20)!important;
}
.leaderboard-topbar p{
  max-width:100%!important;
  white-space:normal!important;
  overflow:visible!important;
}
.leaderboard-close-btn{
  position:absolute!important;
  top:8px!important;
  right:0!important;
  z-index:50!important;
  flex:0 0 auto!important;
  width:54px!important;
  height:54px!important;
  min-width:54px!important;
  min-height:54px!important;
  margin:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:18px!important;
  border:1px solid rgba(0,247,255,.62)!important;
  background:
    radial-gradient(circle at 35% 18%,rgba(255,255,255,.18),transparent 38%),
    linear-gradient(145deg,rgba(2,10,26,.96),rgba(34,10,50,.88))!important;
  color:#fff!important;
  font-size:31px!important;
  font-weight:900!important;
  line-height:1!important;
  cursor:pointer!important;
  pointer-events:auto!important;
  box-shadow:
    0 0 24px rgba(0,247,255,.24),
    0 0 18px rgba(255,31,220,.12),
    inset 0 0 18px rgba(255,255,255,.08)!important;
}
.leaderboard-close-btn:hover{
  transform:translateY(-1px) scale(1.035)!important;
  border-color:rgba(255,244,92,.72)!important;
  box-shadow:
    0 0 30px rgba(255,244,92,.18),
    0 0 26px rgba(0,247,255,.26),
    inset 0 0 20px rgba(255,255,255,.10)!important;
}
.leaderboard-close-btn:active{
  transform:translateY(1px) scale(.96)!important;
}
.leaderboard-list{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-bottom:calc(18px + env(safe-area-inset-bottom))!important;
}
.leaderboard-status.hidden + .leaderboard-list,
.leaderboard-list:not(:empty){
  min-height:0!important;
}
.leaderboard-row{
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
}

@media (max-width:430px){
  .leaderboard-screen{
    padding:calc(10px + env(safe-area-inset-top)) 9px calc(10px + env(safe-area-inset-bottom))!important;
  }
  .leaderboard-shell{
    padding:11px!important;
    border-radius:26px!important;
  }
  .leaderboard-topbar{
    padding:6px 58px 11px 0!important;
    min-height:78px!important;
  }
  .leaderboard-eyebrow{
    font-size:9px!important;
    letter-spacing:.14em!important;
  }
  .leaderboard-topbar h2{
    font-size:clamp(28px, 9.1vw, 36px)!important;
    line-height:.89!important;
  }
  .leaderboard-topbar p{
    display:none!important;
  }
  .leaderboard-close-btn{
    top:4px!important;
    width:50px!important;
    height:50px!important;
    min-width:50px!important;
    min-height:50px!important;
    border-radius:16px!important;
    font-size:29px!important;
  }
  .leaderboard-user-signal{
    margin:10px 0 9px!important;
  }
}

@media (max-height:720px){
  .leaderboard-topbar{
    padding-bottom:10px!important;
    min-height:72px!important;
  }
  .leaderboard-topbar h2{
    font-size:clamp(27px, 7.8vh, 37px)!important;
  }
  .leaderboard-close-btn{
    width:48px!important;
    height:48px!important;
    min-width:48px!important;
    min-height:48px!important;
    border-radius:15px!important;
    font-size:28px!important;
  }
  .leaderboard-user-signal{
    margin-top:8px!important;
    margin-bottom:8px!important;
  }
}

@media (max-height:650px){
  .leaderboard-topbar{
    min-height:64px!important;
    padding-right:54px!important;
  }
  .leaderboard-eyebrow{
    font-size:8px!important;
  }
  .leaderboard-topbar h2{
    font-size:clamp(24px, 7.1vh, 32px)!important;
  }
  .leaderboard-close-btn{
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    min-height:44px!important;
    font-size:26px!important;
  }
}

/* === OMO ARCHIVE FINAL PLACEMENT FIX — full visible, premium, no clipping === */
#archiveScreen.archive-screen,
.archive-screen{
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  padding:calc(10px + env(safe-area-inset-top)) 10px calc(10px + env(safe-area-inset-bottom))!important;
}

#archiveScreen .archive-shell,
.archive-screen .archive-shell{
  width:min(100%, 430px)!important;
  height:calc(100dvh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  max-height:calc(100% - 2px)!important;
  min-height:0!important;
  margin:0 auto!important;
  padding:12px!important;
  border-radius:28px!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  background:
    radial-gradient(circle at 50% 0%, rgba(0,247,255,.15), transparent 32%),
    linear-gradient(155deg, rgba(4,9,25,.88), rgba(17,7,39,.78) 58%, rgba(3,7,20,.90))!important;
  border:1px solid rgba(191,255,255,.34)!important;
  box-shadow:
    0 24px 72px rgba(0,0,0,.62),
    0 0 34px rgba(0,247,255,.16),
    inset 0 0 28px rgba(255,255,255,.035)!important;
}

#archiveScreen .archive-topbar,
.archive-screen .archive-topbar{
  position:relative!important;
  top:auto!important;
  flex:0 0 auto!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 48px!important;
  align-items:start!important;
  gap:10px!important;
  margin:0 0 10px!important;
  padding:4px 0 10px!important;
  border-radius:0!important;
  border-bottom:1px solid rgba(191,255,255,.16)!important;
  background:transparent!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  overflow:visible!important;
}

#archiveScreen .archive-eyebrow,
.archive-screen .archive-eyebrow{
  font-size:9px!important;
  letter-spacing:.16em!important;
  line-height:1.1!important;
  margin:0 0 5px!important;
  white-space:normal!important;
}

#archiveScreen .archive-topbar h2,
.archive-screen .archive-topbar h2{
  font-size:clamp(32px, 9.5vw, 46px)!important;
  line-height:.86!important;
  margin:0!important;
  max-width:100%!important;
  white-space:normal!important;
  overflow:visible!important;
  word-break:normal!important;
  letter-spacing:-.055em!important;
}

#archiveScreen .archive-topbar p,
.archive-screen .archive-topbar p{
  display:block!important;
  margin-top:7px!important;
  font-size:12px!important;
  line-height:1.18!important;
  max-width:280px!important;
  color:#eaffff!important;
}

#archiveScreen .archive-close-btn,
.archive-screen .archive-close-btn{
  position:relative!important;
  z-index:50!important;
  width:48px!important;
  height:48px!important;
  min-width:48px!important;
  min-height:48px!important;
  flex:0 0 48px!important;
  margin:0!important;
  padding:0!important;
  border-radius:16px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:28px!important;
  line-height:1!important;
  color:#fff!important;
  background:linear-gradient(145deg, rgba(1,7,20,.92), rgba(29,8,43,.82))!important;
  border:1px solid rgba(0,247,255,.50)!important;
  box-shadow:0 0 22px rgba(0,247,255,.22), inset 0 0 16px rgba(255,31,220,.10)!important;
  pointer-events:auto!important;
}

#archiveScreen .skin-grid,
.archive-screen .skin-grid{
  flex:1 1 auto!important;
  min-height:0!important;
  display:grid!important;
  grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  gap:11px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:2px 2px 26px!important;
  align-content:start!important;
  justify-items:stretch!important;
  scrollbar-width:none!important;
  touch-action:pan-y!important;
}
#archiveScreen .skin-grid::-webkit-scrollbar,
.archive-screen .skin-grid::-webkit-scrollbar{display:none!important;}

#archiveScreen .skin-card,
.archive-screen .skin-card{
  width:100%!important;
  min-width:0!important;
  min-height:220px!important;
  max-height:none!important;
  padding:10px 8px 9px!important;
  border-radius:22px!important;
  gap:6px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:flex-start!important;
  overflow:hidden!important;
}

#archiveScreen .skin-image,
.archive-screen .skin-image{
  width:78px!important;
  height:78px!important;
  flex:0 0 78px!important;
  margin:0 auto 3px!important;
  border-radius:18px!important;
}

#archiveScreen .skin-name,
.archive-screen .skin-name{
  min-height:32px!important;
  font-size:11px!important;
  line-height:1.06!important;
  letter-spacing:.02em!important;
  white-space:normal!important;
  text-align:center!important;
  overflow:visible!important;
}

#archiveScreen .skin-power-chip,
.archive-screen .skin-power-chip{
  width:100%!important;
  max-width:118px!important;
  min-height:32px!important;
  padding:5px 6px!important;
  font-size:8px!important;
  line-height:1.08!important;
  white-space:normal!important;
  text-align:center!important;
  margin-top:2px!important;
}

#archiveScreen .skin-card .rarity-badge,
.archive-screen .skin-card .rarity-badge{
  min-height:25px!important;
  padding:5px 8px!important;
  font-size:8px!important;
  margin-top:auto!important;
}

#archiveScreen .skin-action,
.archive-screen .skin-action{
  min-height:31px!important;
  margin-top:4px!important;
  padding:7px 6px!important;
  font-size:9px!important;
  line-height:1.05!important;
}

@media (max-height:720px){
  #archiveScreen.archive-screen,
  .archive-screen{padding:8px!important;}
  #archiveScreen .archive-shell,
  .archive-screen .archive-shell{padding:10px!important;border-radius:24px!important;}
  #archiveScreen .archive-topbar,
  .archive-screen .archive-topbar{margin-bottom:8px!important;padding-bottom:8px!important;}
  #archiveScreen .archive-topbar h2,
  .archive-screen .archive-topbar h2{font-size:clamp(28px, 8.4vh, 38px)!important;}
  #archiveScreen .archive-topbar p,
  .archive-screen .archive-topbar p{font-size:11px!important;line-height:1.12!important;margin-top:5px!important;}
  #archiveScreen .archive-close-btn,
  .archive-screen .archive-close-btn{width:44px!important;height:44px!important;min-width:44px!important;min-height:44px!important;flex-basis:44px!important;}
  #archiveScreen .skin-grid,
  .archive-screen .skin-grid{gap:9px!important;padding-bottom:22px!important;}
  #archiveScreen .skin-card,
  .archive-screen .skin-card{min-height:198px!important;padding:8px 7px!important;gap:5px!important;}
  #archiveScreen .skin-image,
  .archive-screen .skin-image{width:66px!important;height:66px!important;flex-basis:66px!important;}
  #archiveScreen .skin-name,
  .archive-screen .skin-name{font-size:10px!important;min-height:28px!important;}
  #archiveScreen .skin-power-chip,
  .archive-screen .skin-power-chip{min-height:28px!important;font-size:7.5px!important;}
  #archiveScreen .skin-action,
  .archive-screen .skin-action{min-height:28px!important;font-size:8px!important;}
}

/* === EMERGENCY FINAL LAYOUT STABILIZER: MAIN MENU + ARCHIVE === */
/* Main menu must never clip after adding leaderboard. Keep game shell fixed, allow the menu panel to fit/scroll cleanly. */
#mainMenu,
#mainMenu.active{
  justify-content:flex-start!important;
  align-items:center!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  touch-action:pan-y!important;
  -webkit-overflow-scrolling:touch!important;
  padding-top:calc(8px + env(safe-area-inset-top))!important;
  padding-bottom:calc(26px + env(safe-area-inset-bottom))!important;
  gap:6px!important;
}
#mainMenu::-webkit-scrollbar{display:none!important;}
#mainMenu{scrollbar-width:none!important;}
#mainMenu .logo-wrap{
  flex:0 0 auto!important;
  margin:0 auto 4px!important;
  max-width:360px!important;
}
#mainMenu .logo-title span,
#mainMenu .logo-title strong{
  font-size:clamp(42px,10.2vh,68px)!important;
  line-height:.80!important;
}
#mainMenu .logo-sub{
  margin-top:6px!important;
  padding:6px 12px!important;
  font-size:9px!important;
}
#mainMenu .hero-card{
  flex:0 0 auto!important;
  width:min(390px,calc(100vw - 30px))!important;
  max-width:min(390px,calc(100vw - 30px))!important;
  max-height:none!important;
  overflow:hidden!important;
  margin:0 auto 18px!important;
  padding:13px 14px 12px!important;
  border-radius:26px!important;
}
#mainMenu .protocol-row{
  gap:5px!important;
  margin:0 0 8px!important;
}
#mainMenu .menu-mascot-preview{
  width:clamp(104px,20vh,138px)!important;
  height:clamp(104px,20vh,138px)!important;
  min-width:0!important;
  flex:0 0 auto!important;
  margin:0 auto 0!important;
  background-size:72% auto!important;
}
#mainMenu .menu-mascot-preview:before{inset:-10px!important;}
#mainMenu .menu-mascot-preview:after{inset:-18px!important;}
#mainMenu .eyebrow{
  font-size:clamp(18px,4.2vw,24px)!important;
  line-height:1!important;
}
#mainMenu .tagline{
  display:block!important;
  margin-top:5px!important;
  font-size:11.5px!important;
  line-height:1.16!important;
}
#mainMenu .primary-btn,
#mainMenu .archive-menu-btn,
#mainMenu .leaderboard-menu-btn{
  min-height:45px!important;
  margin-top:7px!important;
  padding:11px 12px!important;
  font-size:15px!important;
  line-height:1!important;
}
#mainMenu .stat-strip{
  display:grid!important;
  gap:7px!important;
  margin-top:8px!important;
}
#mainMenu .stat-strip div{
  padding:7px 4px!important;
  min-height:54px!important;
}
#mainMenu .stat-strip strong{
  font-size:14px!important;
}
#mainMenu .footer-row{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:7px!important;
  margin-top:8px!important;
  padding-bottom:2px!important;
}
#mainMenu .footer-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:7px!important;
}
#mainMenu .footer-actions .footer-link{
  min-height:39px!important;
  padding:9px 7px!important;
  font-size:10px!important;
  letter-spacing:.07em!important;
}
@media (max-height:720px){
  #mainMenu .logo-title span,
  #mainMenu .logo-title strong{font-size:clamp(36px,9vh,56px)!important;}
  #mainMenu .menu-mascot-preview{width:clamp(88px,17vh,116px)!important;height:clamp(88px,17vh,116px)!important;}
  #mainMenu .tagline{font-size:10.5px!important;line-height:1.12!important;}
  #mainMenu .primary-btn,#mainMenu .archive-menu-btn,#mainMenu .leaderboard-menu-btn{min-height:42px!important;padding:10px 11px!important;}
  #mainMenu .stat-strip div{min-height:48px!important;padding:6px 4px!important;}
  #mainMenu .footer-actions .footer-link{min-height:36px!important;font-size:9px!important;}
}
@media (max-height:640px){
  #mainMenu .logo-sub{display:none!important;}
  #mainMenu .tagline{display:none!important;}
  #mainMenu .menu-mascot-preview{width:82px!important;height:82px!important;}
  #mainMenu .hero-card{padding:11px 12px!important;}
  #mainMenu .primary-btn,#mainMenu .archive-menu-btn,#mainMenu .leaderboard-menu-btn{min-height:39px!important;margin-top:6px!important;}
}

/* Archive: phone-shell safe layout. No 3-column squeeze, no overlapping rows, no clipped cards. */
.archive-screen,
.archive-screen.active{
  align-items:stretch!important;
  justify-content:flex-start!important;
  overflow:hidden!important;
  padding:calc(10px + env(safe-area-inset-top)) 10px calc(10px + env(safe-area-inset-bottom))!important;
}
.archive-shell{
  width:100%!important;
  max-width:760px!important;
  height:100%!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:12px!important;
  border-radius:26px!important;
}
.archive-topbar{
  flex:0 0 auto!important;
  position:relative!important;
  top:auto!important;
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding:4px 0 10px!important;
  margin:0 0 10px!important;
  border-radius:0!important;
  background:transparent!important;
}
.archive-topbar h2{
  font-size:clamp(34px,9.5vw,58px)!important;
  line-height:.82!important;
  margin:3px 0 0!important;
  max-width:calc(100% - 62px)!important;
  word-break:normal!important;
  overflow-wrap:normal!important;
}
.archive-topbar p{
  display:block!important;
  margin-top:8px!important;
  max-width:calc(100% - 8px)!important;
  font-size:clamp(12px,3.1vw,15px)!important;
  line-height:1.12!important;
}
.archive-close-btn{
  position:relative!important;
  top:auto!important;
  right:auto!important;
  flex:0 0 50px!important;
  width:50px!important;
  height:50px!important;
  min-width:50px!important;
  min-height:50px!important;
  z-index:20!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.skin-grid{
  flex:1 1 auto!important;
  min-height:0!important;
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  column-gap:12px!important;
  row-gap:16px!important;
  align-items:start!important;
  align-content:start!important;
  justify-items:stretch!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  touch-action:pan-y!important;
  -webkit-overflow-scrolling:touch!important;
  padding:4px 2px 30px!important;
  scrollbar-width:none!important;
}
.skin-grid::-webkit-scrollbar{display:none!important;}
.skin-card{
  position:relative!important;
  width:100%!important;
  min-width:0!important;
  height:auto!important;
  min-height:248px!important;
  max-height:none!important;
  margin:0!important;
  padding:11px 8px 10px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:7px!important;
  overflow:hidden!important;
  border-radius:22px!important;
  box-sizing:border-box!important;
  transform:none!important;
}
.skin-card:hover,.skin-card:active{transform:none!important;}
.skin-image{
  flex:0 0 auto!important;
  width:86px!important;
  height:86px!important;
  margin:0 auto 3px!important;
  border-radius:20px!important;
}
.skin-lock{
  top:10px!important;
  right:10px!important;
}
.skin-name{
  width:100%!important;
  min-height:34px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:11.5px!important;
  line-height:1.05!important;
  text-align:center!important;
  white-space:normal!important;
  overflow:visible!important;
}
.skin-power-chip{
  width:100%!important;
  max-width:124px!important;
  min-height:34px!important;
  margin:0 auto!important;
  padding:6px 7px!important;
  font-size:8.5px!important;
  line-height:1.08!important;
  white-space:normal!important;
}
.skin-card .rarity-badge{
  flex:0 0 auto!important;
  margin:0 auto!important;
  min-height:28px!important;
  padding:6px 9px!important;
  font-size:8px!important;
  line-height:1!important;
}
.skin-price,
.skin-action{
  flex:0 0 auto!important;
  width:100%!important;
  max-width:100%!important;
  min-height:34px!important;
  margin:0 auto!important;
  padding:8px 7px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:14px!important;
  font-size:9px!important;
  line-height:1!important;
  white-space:normal!important;
  overflow:hidden!important;
}
@media (min-width:760px){
  .skin-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;column-gap:16px!important;row-gap:18px!important;}
  .skin-card{min-height:268px!important;padding:13px 10px 12px!important;}
  .skin-image{width:96px!important;height:96px!important;}
  .skin-name{font-size:12px!important;}
}
@media (max-height:700px){
  .archive-topbar h2{font-size:clamp(30px,8vh,48px)!important;}
  .archive-topbar p{font-size:11px!important;line-height:1.08!important;}
  .skin-card{min-height:232px!important;padding:9px 7px 9px!important;gap:6px!important;}
  .skin-image{width:76px!important;height:76px!important;}
  .skin-name{min-height:30px!important;font-size:10px!important;}
  .skin-power-chip{min-height:30px!important;font-size:8px!important;}
  .skin-card .rarity-badge{min-height:25px!important;font-size:7.5px!important;}
  .skin-price,.skin-action{min-height:31px!important;font-size:8px!important;}
}


/* === FINAL TARGETED MAIN MENU CENTER + SHORT CARD PATCH === */
/* Scope: main menu only. Removes Signal/Rank/Lanes strip and tightens card height. */
#mainMenu.active{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:
    calc(12px + env(safe-area-inset-top))
    14px
    calc(14px + env(safe-area-inset-bottom))!important;
  gap:8px!important;
}

#mainMenu .logo-wrap{
  width:100%!important;
  max-width:340px!important;
  margin:0 auto 6px!important;
  text-align:center!important;
  flex:0 0 auto!important;
}

#mainMenu .logo-title span,
#mainMenu .logo-title strong{
  font-size:clamp(44px,9.4vh,68px)!important;
  line-height:.82!important;
}

#mainMenu .logo-sub{
  margin-top:7px!important;
  padding:6px 13px!important;
  font-size:9.5px!important;
}

#mainMenu .hero-card{
  width:min(92vw,360px)!important;
  max-width:360px!important;
  max-height:none!important;
  margin:0 auto!important;
  padding:14px 14px 13px!important;
  border-radius:26px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  align-items:stretch!important;
  overflow:hidden!important;
}

#mainMenu .protocol-row{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  margin:0 0 10px!important;
  text-align:center!important;
}

#mainMenu .menu-mascot-preview{
  width:clamp(106px,20vh,136px)!important;
  height:clamp(106px,20vh,136px)!important;
  margin:0 auto 1px!important;
  background-size:70% auto!important;
}

#mainMenu .menu-mascot-preview:before{
  inset:-10px!important;
}

#mainMenu .menu-mascot-preview:after{
  inset:-18px!important;
}

#mainMenu .protocol-copy{
  width:100%!important;
  max-width:310px!important;
  margin:0 auto!important;
}

#mainMenu .eyebrow{
  font-size:clamp(20px,4.8vh,30px)!important;
  line-height:.95!important;
  letter-spacing:.08em!important;
}

#mainMenu .tagline{
  margin-top:6px!important;
  font-size:11.5px!important;
  line-height:1.18!important;
}

#mainMenu .primary-btn,
#mainMenu .archive-menu-btn,
#mainMenu .leaderboard-menu-btn{
  width:100%!important;
  min-height:46px!important;
  margin-top:7px!important;
  padding:11px 12px!important;
  border-radius:17px!important;
  font-size:15px!important;
  line-height:1!important;
  letter-spacing:.09em!important;
}

/* User requested removing Signal / Rank / Lanes from the main menu */
#mainMenu .stat-strip{
  display:none!important;
}

#mainMenu .footer-row{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:7px!important;
  margin-top:9px!important;
  text-align:center!important;
  align-items:center!important;
  justify-content:center!important;
}

#mainMenu .footer-row > span{
  display:block!important;
  width:100%!important;
  font-size:9.5px!important;
  line-height:1!important;
  letter-spacing:.13em!important;
}

#mainMenu .footer-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  width:100%!important;
}

#mainMenu .footer-actions .footer-link{
  width:100%!important;
  min-height:38px!important;
  padding:8px 8px!important;
  border-radius:999px!important;
  font-size:10px!important;
  line-height:1!important;
  letter-spacing:.08em!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}

/* Short displays: keep everything centered and prevent bottom clipping */
@media (max-height:760px){
  #mainMenu.active{
    gap:6px!important;
    padding-top:calc(8px + env(safe-area-inset-top))!important;
    padding-bottom:calc(10px + env(safe-area-inset-bottom))!important;
  }

  #mainMenu .logo-title span,
  #mainMenu .logo-title strong{
    font-size:clamp(38px,8.7vh,58px)!important;
  }

  #mainMenu .logo-sub{
    margin-top:5px!important;
    padding:5px 11px!important;
    font-size:8.5px!important;
  }

  #mainMenu .hero-card{
    width:min(90vw,348px)!important;
    max-width:348px!important;
    padding:12px 12px 11px!important;
    border-radius:24px!important;
  }

  #mainMenu .menu-mascot-preview{
    width:clamp(86px,17vh,116px)!important;
    height:clamp(86px,17vh,116px)!important;
  }

  #mainMenu .menu-mascot-preview:before{
    inset:-8px!important;
  }

  #mainMenu .menu-mascot-preview:after{
    inset:-14px!important;
  }

  #mainMenu .protocol-row{
    gap:5px!important;
    margin-bottom:8px!important;
  }

  #mainMenu .eyebrow{
    font-size:clamp(17px,4.1vh,24px)!important;
  }

  #mainMenu .tagline{
    font-size:10.5px!important;
    line-height:1.12!important;
    display:block!important;
  }

  #mainMenu .primary-btn,
  #mainMenu .archive-menu-btn,
  #mainMenu .leaderboard-menu-btn{
    min-height:42px!important;
    margin-top:6px!important;
    padding:9px 10px!important;
    font-size:13.5px!important;
  }

  #mainMenu .footer-row{
    gap:6px!important;
    margin-top:7px!important;
  }

  #mainMenu .footer-row > span{
    font-size:8.5px!important;
  }

  #mainMenu .footer-actions .footer-link{
    min-height:34px!important;
    padding:7px 7px!important;
    font-size:9px!important;
  }
}

@media (max-width:430px){
  #mainMenu .hero-card{
    width:min(92vw,350px)!important;
    max-width:350px!important;
  }

  #mainMenu .primary-btn,
  #mainMenu .archive-menu-btn,
  #mainMenu .leaderboard-menu-btn{
    font-size:14px!important;
  }
}

/* === ARCHIVE GRID FORCE FIX — ONLY ARCHIVE PLACEMENT / CARD ALIGNMENT === */
.archive-screen.active{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
}

.archive-screen{
  padding:calc(14px + env(safe-area-inset-top)) 12px calc(14px + env(safe-area-inset-bottom))!important;
}

.archive-shell{
  width:min(100%, 680px)!important;
  height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  max-height:calc(100dvh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  margin:0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:14px!important;
}

.archive-topbar{
  flex:0 0 auto!important;
  position:relative!important;
  top:auto!important;
  display:grid!important;
  grid-template-columns:1fr 56px!important;
  align-items:start!important;
  gap:12px!important;
  margin:0 0 12px!important;
  padding:6px 0 12px!important;
}

.archive-topbar h2{
  font-size:clamp(38px, 8.4vw, 58px)!important;
  line-height:.86!important;
  margin:4px 0 0!important;
}

.archive-topbar p{
  max-width:360px!important;
  line-height:1.15!important;
  margin-top:8px!important;
}

.archive-close-btn{
  grid-column:2!important;
  grid-row:1 / span 2!important;
  justify-self:end!important;
  align-self:start!important;
  position:relative!important;
  width:52px!important;
  height:52px!important;
  min-width:52px!important;
  min-height:52px!important;
  flex:0 0 52px!important;
  margin:0!important;
  transform:none!important;
}

.skin-grid{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  gap:12px!important;
  align-items:start!important;
  align-content:start!important;
  justify-items:stretch!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:4px 2px 22px!important;
  scroll-behavior:smooth!important;
}

.skin-card{
  width:100%!important;
  min-width:0!important;
  min-height:218px!important;
  height:auto!important;
  padding:12px 9px 11px!important;
  display:grid!important;
  grid-template-rows:auto auto auto auto auto!important;
  align-items:center!important;
  justify-items:center!important;
  gap:7px!important;
  overflow:hidden!important;
  transform:none!important;
  animation:none!important;
}

.skin-card:hover,
.skin-card:active{
  transform:none!important;
}

.skin-image{
  width:82px!important;
  height:82px!important;
  margin:0!important;
  flex:0 0 auto!important;
  display:block!important;
  background-size:contain!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}

.skin-lock{
  top:12px!important;
  right:12px!important;
}

.skin-name{
  width:100%!important;
  min-height:32px!important;
  max-height:40px!important;
  margin:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-size:12px!important;
  line-height:1.08!important;
  white-space:normal!important;
  overflow:hidden!important;
}

.skin-power-chip{
  width:100%!important;
  max-width:150px!important;
  min-height:32px!important;
  max-height:36px!important;
  margin:0 auto!important;
  padding:6px 8px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-size:9px!important;
  line-height:1.05!important;
  white-space:normal!important;
  overflow:hidden!important;
}

.skin-card .rarity-badge{
  min-height:28px!important;
  margin:0!important;
  padding:6px 10px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:8px!important;
  line-height:1!important;
  white-space:nowrap!important;
}

.skin-action{
  width:100%!important;
  min-height:32px!important;
  margin:0!important;
  padding:7px 8px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:9px!important;
  line-height:1!important;
  white-space:normal!important;
  overflow:hidden!important;
}

.skin-price{
  margin:0!important;
  font-size:10px!important;
  line-height:1!important;
}

@media (min-width:760px){
  .archive-shell{
    width:min(100%, 700px)!important;
  }

  .skin-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
    gap:12px!important;
  }

  .skin-card{
    min-height:218px!important;
  }

  .skin-image{
    width:84px!important;
    height:84px!important;
  }
}

@media (max-width:430px){
  .archive-screen{
    padding:calc(12px + env(safe-area-inset-top)) 10px calc(12px + env(safe-area-inset-bottom))!important;
  }

  .archive-shell{
    height:calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    max-height:calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    padding:12px!important;
  }

  .archive-topbar{
    grid-template-columns:1fr 50px!important;
    gap:10px!important;
    margin-bottom:10px!important;
    padding-bottom:10px!important;
  }

  .archive-topbar h2{
    font-size:clamp(36px, 12vw, 52px)!important;
  }

  .archive-topbar p{
    font-size:12px!important;
    line-height:1.14!important;
  }

  .archive-close-btn{
    width:50px!important;
    height:50px!important;
    min-width:50px!important;
    min-height:50px!important;
    flex-basis:50px!important;
  }

  .skin-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
    gap:10px!important;
    padding:3px 1px 20px!important;
  }

  .skin-card{
    min-height:210px!important;
    padding:10px 7px!important;
    gap:6px!important;
  }

  .skin-image{
    width:74px!important;
    height:74px!important;
  }

  .skin-name{
    min-height:30px!important;
    max-height:38px!important;
    font-size:11px!important;
  }

  .skin-power-chip{
    min-height:30px!important;
    max-height:34px!important;
    font-size:8px!important;
    padding:5px 6px!important;
  }

  .skin-card .rarity-badge{
    min-height:26px!important;
    font-size:8px!important;
  }

  .skin-action{
    min-height:30px!important;
    font-size:8px!important;
  }
}

@media (max-height:700px){
  .archive-shell{
    padding:10px!important;
  }

  .archive-topbar{
    margin-bottom:8px!important;
    padding-bottom:8px!important;
  }

  .archive-topbar h2{
    font-size:clamp(32px, 8vh, 46px)!important;
  }

  .archive-topbar p{
    font-size:11px!important;
    margin-top:6px!important;
  }

  .skin-card{
    min-height:190px!important;
  }

  .skin-image{
    width:66px!important;
    height:66px!important;
  }

  .skin-name{
    min-height:28px!important;
    max-height:34px!important;
    font-size:10px!important;
  }

  .skin-power-chip{
    min-height:28px!important;
    max-height:32px!important;
    font-size:8px!important;
  }

  .skin-card .rarity-badge{
    min-height:24px!important;
  }

  .skin-action{
    min-height:28px!important;
  }
}


/* === FORCE ARCHIVE COLUMN GAP FIX ONLY === */
.archive-screen.active .archive-shell{
  padding-left:18px!important;
  padding-right:18px!important;
}

.archive-screen.active #skinGrid.skin-grid,
.archive-screen.active .skin-grid{
  display:grid!important;
  grid-template-columns:repeat(2, minmax(0, 1fr))!important;
  column-gap:30px!important;
  row-gap:22px!important;
  gap:22px 30px!important;
  justify-content:center!important;
  justify-items:stretch!important;
  align-items:start!important;
  align-content:start!important;
  padding-left:4px!important;
  padding-right:4px!important;
  padding-bottom:42px!important;
}

.archive-screen.active .skin-card{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  margin:0!important;
  transform:none!important;
}

.archive-screen.active .skin-card:hover,
.archive-screen.active .skin-card:active{
  transform:none!important;
}

.archive-screen.active .skin-card:nth-child(2n){
  animation-delay:0s!important;
}

@media (max-width:430px){
  .archive-screen.active .archive-shell{
    padding-left:16px!important;
    padding-right:16px!important;
  }

  .archive-screen.active #skinGrid.skin-grid,
  .archive-screen.active .skin-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr))!important;
    column-gap:26px!important;
    row-gap:20px!important;
    gap:20px 26px!important;
    padding-left:3px!important;
    padding-right:3px!important;
  }

  .archive-screen.active .skin-card{
    padding-left:7px!important;
    padding-right:7px!important;
  }
}

@media (max-width:380px){
  .archive-screen.active #skinGrid.skin-grid,
  .archive-screen.active .skin-grid{
    column-gap:22px!important;
    gap:18px 22px!important;
  }
}

/* === FINAL ARCHIVE BUY BUTTON / TRUNCATION FIX ===
   Scope: archive only. Keeps the existing visual style and only repairs card sizing,
   internal scrolling, and buy-button visibility. */
#archiveScreen.archive-screen,
.archive-screen{
  overflow:hidden!important;
  padding:calc(10px + env(safe-area-inset-top)) 10px calc(10px + env(safe-area-inset-bottom))!important;
}

#archiveScreen .archive-shell,
.archive-screen .archive-shell{
  height:calc(100dvh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  max-height:calc(100dvh - 20px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding:12px!important;
}

#archiveScreen .archive-topbar,
.archive-screen .archive-topbar{
  flex:0 0 auto!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 50px!important;
  align-items:start!important;
  gap:10px!important;
  margin:0 0 10px!important;
  padding:4px 0 10px!important;
  border-radius:20px!important;
}

#archiveScreen .archive-topbar h2,
.archive-screen .archive-topbar h2{
  font-size:clamp(34px,8.6vw,48px)!important;
  line-height:.86!important;
  margin-top:4px!important;
}

#archiveScreen .archive-topbar p,
.archive-screen .archive-topbar p{
  font-size:12px!important;
  line-height:1.12!important;
  margin-top:6px!important;
}

#archiveScreen .archive-close-btn,
.archive-screen .archive-close-btn{
  width:50px!important;
  height:50px!important;
  min-width:50px!important;
  min-height:50px!important;
  flex:0 0 50px!important;
  pointer-events:auto!important;
}

#archiveScreen #skinGrid.skin-grid,
#archiveScreen .skin-grid,
.archive-screen #skinGrid.skin-grid,
.archive-screen .skin-grid{
  flex:1 1 auto!important;
  min-height:0!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  touch-action:pan-y!important;
  padding:4px 2px 36px!important;
  align-content:start!important;
  align-items:start!important;
  justify-items:stretch!important;
  scrollbar-width:none!important;
}
#archiveScreen .skin-grid::-webkit-scrollbar,
.archive-screen .skin-grid::-webkit-scrollbar{display:none!important;}

#archiveScreen .skin-card,
.archive-screen .skin-card{
  width:100%!important;
  min-width:0!important;
  min-height:218px!important;
  height:auto!important;
  padding:10px 8px!important;
  display:grid!important;
  grid-template-rows:auto auto auto auto!important;
  align-items:center!important;
  justify-items:center!important;
  gap:6px!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  transform:none!important;
  animation:none!important;
}

#archiveScreen .skin-card:hover,
#archiveScreen .skin-card:active,
.archive-screen .skin-card:hover,
.archive-screen .skin-card:active{
  transform:none!important;
}

#archiveScreen .skin-image,
.archive-screen .skin-image{
  width:76px!important;
  height:76px!important;
  min-width:76px!important;
  min-height:76px!important;
  margin:0!important;
  background-size:contain!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}

#archiveScreen .skin-name,
.archive-screen .skin-name{
  width:100%!important;
  min-height:30px!important;
  max-height:none!important;
  margin:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-size:11px!important;
  line-height:1.08!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}

#archiveScreen .skin-power-chip,
.archive-screen .skin-power-chip{
  width:100%!important;
  max-width:140px!important;
  min-height:30px!important;
  max-height:none!important;
  margin:0 auto!important;
  padding:5px 6px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-size:8px!important;
  line-height:1.08!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}

#archiveScreen .skin-card .rarity-badge,
.archive-screen .skin-card .rarity-badge{
  min-height:25px!important;
  margin:0!important;
  padding:5px 8px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:8px!important;
  line-height:1!important;
  white-space:nowrap!important;
}

#archiveScreen .skin-price,
.archive-screen .skin-price{
  display:none!important;
}

#archiveScreen .skin-action,
.archive-screen .skin-action{
  width:100%!important;
  min-height:32px!important;
  margin:0!important;
  padding:7px 6px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:13px!important;
  font-size:9px!important;
  line-height:1.05!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
  pointer-events:auto!important;
  z-index:4!important;
}

@media (min-width:760px){
  #archiveScreen .archive-shell,
  .archive-screen .archive-shell{max-width:700px!important;}

  #archiveScreen .skin-card,
  .archive-screen .skin-card{min-height:226px!important;}

  #archiveScreen .skin-image,
  .archive-screen .skin-image{width:82px!important;height:82px!important;min-width:82px!important;min-height:82px!important;}
}

@media (max-width:430px){
  #archiveScreen.archive-screen,
  .archive-screen{padding:calc(8px + env(safe-area-inset-top)) 8px calc(8px + env(safe-area-inset-bottom))!important;}

  #archiveScreen .archive-shell,
  .archive-screen .archive-shell{
    height:calc(100dvh - 16px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    max-height:calc(100dvh - 16px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    padding:10px!important;
  }

  #archiveScreen .archive-topbar,
  .archive-screen .archive-topbar{grid-template-columns:minmax(0,1fr) 46px!important;margin-bottom:8px!important;padding-bottom:8px!important;}

  #archiveScreen .archive-topbar h2,
  .archive-screen .archive-topbar h2{font-size:clamp(32px,11vw,46px)!important;}

  #archiveScreen .archive-close-btn,
  .archive-screen .archive-close-btn{width:46px!important;height:46px!important;min-width:46px!important;min-height:46px!important;flex-basis:46px!important;}

  #archiveScreen #skinGrid.skin-grid,
  #archiveScreen .skin-grid,
  .archive-screen #skinGrid.skin-grid,
  .archive-screen .skin-grid{gap:12px!important;padding-bottom:34px!important;}

  #archiveScreen .skin-card,
  .archive-screen .skin-card{min-height:214px!important;padding:9px 7px!important;gap:5px!important;}

  #archiveScreen .skin-image,
  .archive-screen .skin-image{width:72px!important;height:72px!important;min-width:72px!important;min-height:72px!important;}
}

@media (max-height:700px){
  #archiveScreen .archive-topbar h2,
  .archive-screen .archive-topbar h2{font-size:clamp(28px,7.8vh,40px)!important;}

  #archiveScreen .archive-topbar p,
  .archive-screen .archive-topbar p{font-size:11px!important;line-height:1.08!important;}

  #archiveScreen .skin-card,
  .archive-screen .skin-card{min-height:198px!important;padding:8px 7px!important;gap:5px!important;}

  #archiveScreen .skin-image,
  .archive-screen .skin-image{width:64px!important;height:64px!important;min-width:64px!important;min-height:64px!important;}

  #archiveScreen .skin-name,
  .archive-screen .skin-name{font-size:10px!important;min-height:28px!important;}

  #archiveScreen .skin-power-chip,
  .archive-screen .skin-power-chip{min-height:28px!important;font-size:7.5px!important;}

  #archiveScreen .skin-action,
  .archive-screen .skin-action{min-height:29px!important;font-size:8px!important;}
}

/* === OMO ARCHIVE — PREMIUM CLARITY GUI OVERHAUL ONLY === */
#archiveScreen.archive-screen,
.archive-screen{
  background:
    radial-gradient(circle at 50% -8%,rgba(0,247,255,.24),transparent 31%),
    radial-gradient(circle at 78% 22%,rgba(255,31,220,.18),transparent 34%),
    radial-gradient(circle at 18% 78%,rgba(114,75,255,.16),transparent 30%),
    linear-gradient(180deg,rgba(1,3,12,.74),rgba(0,0,0,.94))!important;
}
#archiveScreen .archive-shell,
.archive-screen .archive-shell{
  background:
    linear-gradient(155deg,rgba(5,10,28,.94),rgba(16,8,43,.88) 58%,rgba(3,7,20,.96))!important;
  border:1px solid rgba(174,255,255,.46)!important;
  box-shadow:
    0 26px 88px rgba(0,0,0,.76),
    0 0 48px rgba(0,247,255,.20),
    0 0 38px rgba(255,31,220,.12),
    inset 0 0 42px rgba(255,255,255,.045)!important;
}
#archiveScreen .archive-shell:after,
.archive-screen .archive-shell:after{
  content:"";
  position:absolute;
  inset:1px;
  z-index:1;
  pointer-events:none;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,.075);
  box-shadow:inset 0 0 0 1px rgba(0,247,255,.055);
}
#archiveScreen .archive-topbar,
.archive-screen .archive-topbar{
  background:
    linear-gradient(180deg,rgba(5,10,28,.98),rgba(5,10,28,.80))!important;
  border-bottom:1px solid rgba(143,255,255,.26)!important;
  box-shadow:0 12px 26px rgba(0,0,0,.28),0 1px 0 rgba(255,255,255,.055)!important;
}
#archiveScreen .archive-eyebrow,
.archive-screen .archive-eyebrow{
  color:#76ffff!important;
  text-shadow:0 0 12px rgba(0,247,255,.82),0 0 22px rgba(0,247,255,.32)!important;
  letter-spacing:.24em!important;
}
#archiveScreen .archive-topbar h2,
.archive-screen .archive-topbar h2{
  color:#fff!important;
  text-shadow:
    0 0 2px rgba(255,255,255,.95),
    0 0 18px rgba(0,247,255,.72),
    2px 0 0 rgba(0,247,255,.16),
    -2px 0 0 rgba(255,31,220,.16)!important;
  -webkit-font-smoothing:antialiased;
}
#archiveScreen .archive-topbar p,
.archive-screen .archive-topbar p{
  color:#efffff!important;
  text-shadow:0 0 10px rgba(0,247,255,.25)!important;
}
#archiveScreen .archive-close-btn,
.archive-screen .archive-close-btn{
  color:#fff!important;
  background:
    radial-gradient(circle at 50% 20%,rgba(255,255,255,.13),transparent 34%),
    linear-gradient(145deg,rgba(2,10,28,.98),rgba(31,9,48,.90))!important;
  border-color:rgba(143,255,255,.62)!important;
  box-shadow:0 0 26px rgba(0,247,255,.24),0 10px 24px rgba(0,0,0,.38),inset 0 0 18px rgba(255,255,255,.08)!important;
}
#archiveScreen .skin-grid,
.archive-screen .skin-grid{
  z-index:3!important;
  scrollbar-width:none!important;
}
#archiveScreen .skin-card,
.archive-screen .skin-card{
  background:
    radial-gradient(circle at 50% 0%,rgba(0,247,255,.20),transparent 34%),
    linear-gradient(160deg,rgba(8,15,39,.96),rgba(17,10,42,.92) 54%,rgba(5,9,25,.97))!important;
  border:1px solid rgba(151,255,255,.42)!important;
  box-shadow:
    0 15px 36px rgba(0,0,0,.38),
    0 0 24px rgba(0,247,255,.13),
    inset 0 0 24px rgba(255,255,255,.055)!important;
  transform:translateZ(0);
}
#archiveScreen .skin-card:before,
.archive-screen .skin-card:before{
  border-color:rgba(255,255,255,.11)!important;
  box-shadow:inset 0 0 18px rgba(0,247,255,.045)!important;
}
#archiveScreen .skin-card:after,
.archive-screen .skin-card:after{
  background:linear-gradient(180deg,transparent 44%,rgba(0,0,0,.18))!important;
}
#archiveScreen .skin-card:hover,
#archiveScreen .skin-card:active,
.archive-screen .skin-card:hover,
.archive-screen .skin-card:active{
  border-color:rgba(255,255,255,.70)!important;
  box-shadow:
    0 0 34px rgba(0,247,255,.26),
    0 0 28px rgba(255,31,220,.16),
    0 18px 42px rgba(0,0,0,.46),
    inset 0 0 26px rgba(255,255,255,.08)!important;
}
#archiveScreen .skin-image,
.archive-screen .skin-image{
  border:1px solid rgba(191,255,255,.36)!important;
  background-color:rgba(1,6,20,.88)!important;
  border-radius:24px!important;
  box-shadow:
    0 0 0 4px rgba(0,247,255,.035),
    0 0 22px rgba(0,247,255,.34),
    0 0 20px rgba(255,31,220,.10),
    inset 0 0 18px rgba(255,255,255,.055)!important;
  filter:contrast(1.08) saturate(1.08) drop-shadow(0 0 14px rgba(0,247,255,.32))!important;
}
#archiveScreen .skin-card.locked .skin-image,
.archive-screen .skin-card.locked .skin-image{
  filter:grayscale(.15) brightness(.88) contrast(1.06) drop-shadow(0 0 14px rgba(255,31,220,.22))!important;
}
#archiveScreen .skin-name,
.archive-screen .skin-name{
  color:#fff!important;
  font-weight:1000!important;
  letter-spacing:.025em!important;
  text-shadow:0 0 2px rgba(255,255,255,.70),0 0 12px rgba(0,247,255,.36)!important;
}
#archiveScreen .skin-power-chip,
.archive-screen .skin-power-chip{
  color:#f5ffff!important;
  border-color:rgba(143,255,255,.36)!important;
  background:
    linear-gradient(90deg,rgba(0,247,255,.17),rgba(114,75,255,.18),rgba(255,31,220,.14))!important;
  box-shadow:0 0 14px rgba(0,247,255,.13),inset 0 0 12px rgba(255,255,255,.06)!important;
  text-shadow:0 0 8px rgba(0,247,255,.32)!important;
}
#archiveScreen .rarity-badge,
.archive-screen .rarity-badge{
  border-width:1px!important;
  box-shadow:0 0 14px rgba(255,255,255,.10),inset 0 0 12px rgba(255,255,255,.07)!important;
  text-shadow:0 0 9px rgba(255,255,255,.28)!important;
}
#archiveScreen .rarity-common,
.archive-screen .rarity-common{background:linear-gradient(90deg,rgba(162,175,196,.24),rgba(212,225,245,.18))!important;border-color:rgba(220,232,255,.46)!important;color:#f3f7ff!important;}
#archiveScreen .rarity-rare,
.archive-screen .rarity-rare{background:linear-gradient(90deg,rgba(0,122,255,.34),rgba(0,247,255,.18))!important;border-color:rgba(92,206,255,.78)!important;color:#e9ffff!important;}
#archiveScreen .rarity-epic,
.archive-screen .rarity-epic{background:linear-gradient(90deg,rgba(142,63,255,.36),rgba(255,31,220,.18))!important;border-color:rgba(205,135,255,.80)!important;color:#fff!important;}
#archiveScreen .rarity-legendary,
.archive-screen .rarity-legendary{background:linear-gradient(90deg,rgba(255,190,40,.38),rgba(255,244,92,.18))!important;border-color:rgba(255,234,118,.86)!important;color:#fff9c7!important;}
#archiveScreen .rarity-mythic,
.archive-screen .rarity-mythic{background:linear-gradient(90deg,rgba(255,31,78,.38),rgba(255,31,220,.20))!important;border-color:rgba(255,121,156,.86)!important;color:#fff!important;}
#archiveScreen .skin-action,
.archive-screen .skin-action{
  color:#fff!important;
  background:
    linear-gradient(94deg,#ff25df 0%,#754bff 46%,#00f7ff 100%)!important;
  border:1px solid rgba(255,255,255,.42)!important;
  border-radius:14px!important;
  box-shadow:0 0 20px rgba(0,247,255,.24),0 8px 18px rgba(0,0,0,.30),inset 0 0 14px rgba(255,255,255,.16)!important;
  text-shadow:0 0 9px rgba(255,255,255,.65)!important;
  letter-spacing:.095em!important;
}
#archiveScreen .skin-card.owned .skin-action,
.archive-screen .skin-card.owned .skin-action{
  background:linear-gradient(94deg,rgba(0,247,255,.70),rgba(116,75,255,.60))!important;
  border-color:rgba(143,255,255,.62)!important;
}
#archiveScreen .skin-lock,
.archive-screen .skin-lock{
  color:#fff8bf!important;
  background:radial-gradient(circle,rgba(255,244,92,.22),rgba(0,0,0,.72))!important;
  border-color:rgba(255,244,92,.56)!important;
  box-shadow:0 0 16px rgba(255,244,92,.20),inset 0 0 10px rgba(255,255,255,.08)!important;
}
#purchaseScreen.purchase-screen,
.purchase-screen{
  background:rgba(0,0,0,.74)!important;
  backdrop-filter:blur(12px) saturate(130%)!important;
  -webkit-backdrop-filter:blur(12px) saturate(130%)!important;
}
#purchaseScreen .purchase-card,
.purchase-screen .purchase-card{
  background:
    radial-gradient(circle at 50% 0%,rgba(0,247,255,.20),transparent 34%),
    linear-gradient(155deg,rgba(6,12,32,.98),rgba(22,8,50,.96) 58%,rgba(4,8,23,.98))!important;
  border-color:rgba(174,255,255,.48)!important;
  box-shadow:0 28px 90px rgba(0,0,0,.78),0 0 48px rgba(0,247,255,.20),0 0 36px rgba(255,31,220,.13),inset 0 0 38px rgba(255,255,255,.055)!important;
}
#purchaseScreen .purchase-mascot,
.purchase-screen .purchase-mascot{
  border:1px solid rgba(191,255,255,.34)!important;
  background-color:rgba(1,6,20,.88)!important;
  box-shadow:0 0 34px rgba(0,247,255,.26),inset 0 0 18px rgba(255,255,255,.055)!important;
}
#purchaseScreen .purchase-card h2,
.purchase-screen .purchase-card h2{
  text-shadow:0 0 2px rgba(255,255,255,.82),0 0 18px rgba(0,247,255,.44)!important;
}
#purchaseScreen .purchase-price,
.purchase-screen .purchase-price{
  color:#fff9c7!important;
  background:linear-gradient(90deg,rgba(255,244,92,.20),rgba(255,190,40,.13))!important;
  border-color:rgba(255,244,92,.70)!important;
  box-shadow:0 0 22px rgba(255,244,92,.18),inset 0 0 12px rgba(255,255,255,.07)!important;
}
@media (max-width:430px){
  #archiveScreen .skin-card,
  .archive-screen .skin-card{border-radius:22px!important;}
  #archiveScreen .skin-image,
  .archive-screen .skin-image{border-radius:20px!important;}
  #archiveScreen .skin-action,
  .archive-screen .skin-action{font-size:9px!important;letter-spacing:.075em!important;}
}
@media (max-height:700px){
  #archiveScreen .skin-action,
  .archive-screen .skin-action{border-radius:12px!important;}
  #archiveScreen .skin-power-chip,
  .archive-screen .skin-power-chip{padding:5px 6px!important;}
}

/* === GAMEPLAY PERFORMANCE PATCH — SMOOTH RUN MODE ONLY ===
   Applies only while no overlay screen is active, which is the live gameplay state.
   Menu, archive, purchase, settings, game-over, and share screens keep their premium effects.
*/
@supports selector(#game-shell:has(.screen.active)) {
  #game-shell:not(:has(.screen.active))::before,
  #game-shell:not(:has(.screen.active))::after {
    display: none !important;
    content: none !important;
    animation: none !important;
    background: none !important;
    opacity: 0 !important;
  }

  #game-shell:not(:has(.screen.active)) .hud,
  #game-shell:not(:has(.screen.active)) .hud *,
  #game-shell:not(:has(.screen.active)) .hud-panel,
  #game-shell:not(:has(.screen.active)) .evo-bar,
  #game-shell:not(:has(.screen.active)) .pause-btn,
  #game-shell:not(:has(.screen.active)) .ability-btn,
  #game-shell:not(:has(.screen.active)) .power-bar,
  #game-shell:not(:has(.screen.active)) .power-bar::after,
  #game-shell:not(:has(.screen.active)) .ability-btn.ready,
  #game-shell:not(:has(.screen.active)) .ability-btn.active {
    animation: none !important;
    transition: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    filter: none !important;
  }

  #game-shell:not(:has(.screen.active)) .hud-panel,
  #game-shell:not(:has(.screen.active)) .evo-bar,
  #game-shell:not(:has(.screen.active)) .pause-btn,
  #game-shell:not(:has(.screen.active)) .ability-btn {
    background: rgba(3,8,22,.72) !important;
    box-shadow: 0 0 8px rgba(0,247,255,.10), inset 0 0 8px rgba(255,31,220,.035) !important;
  }

  #game-shell:not(:has(.screen.active)) .power-bar::after,
  #game-shell:not(:has(.screen.active)) .primary-btn::before,
  #game-shell:not(:has(.screen.active)) .secondary-btn::before,
  #game-shell:not(:has(.screen.active)) .ghost-btn::before {
    display: none !important;
    content: none !important;
  }

  #game-shell:not(:has(.screen.active)) .ability-btn.ready,
  #game-shell:not(:has(.screen.active)) .ability-btn.active,
  #game-shell:not(:has(.screen.active)) .power-bar.ready {
    box-shadow: 0 0 12px rgba(255,244,92,.18), 0 0 10px rgba(0,247,255,.12), inset 0 0 8px rgba(255,255,255,.08) !important;
  }

  #game-shell:not(:has(.screen.active)) .toast {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 0 10px rgba(0,247,255,.10) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

/* === OMO POWER DOCK + EVEN HUD FINAL PATCH === */
#game-shell .hud{
  top:calc(10px + env(safe-area-inset-top));
  left:8px;
  right:8px;
  z-index:8;
  display:grid;
  grid-template-columns:minmax(58px,.72fr) minmax(126px,1.42fr) minmax(60px,.78fr) 44px !important;
  gap:7px;
  align-items:start;
  pointer-events:none;
}
#game-shell .hud-panel,#game-shell .pause-btn,#game-shell .power-bar{
  min-width:0;
  pointer-events:auto;
}
#game-shell .score-panel,#game-shell .variant-panel{
  min-height:50px;
  border-radius:17px;
  padding:7px 7px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
}
#game-shell .hud-panel strong{
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:clip;
}
#game-shell .variant-panel{
  text-align:center;
}
#game-shell .variant-panel strong{
  font-size:clamp(10px,3.1vw,15px);
  line-height:1.05;
  padding-top:2px;
}
#game-shell .hud-center{
  padding-top:0 !important;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:5px;
  min-height:50px;
}
#game-shell .ability-name,#game-shell #comboLabel{
  width:100%;
  max-width:100%;
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
#game-shell .power-bar{
  width:100%;
  height:10px;
}
#game-shell .pause-btn{
  width:44px;
  height:50px;
  min-width:44px;
  min-height:50px;
  border-radius:17px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  line-height:1;
}
#game-shell .ability-dock{
  position:absolute;
  right:calc(14px + env(safe-area-inset-right));
  bottom:calc(94px + env(safe-area-inset-bottom));
  z-index:9;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.50));
}
#game-shell .ability-dock.hidden{display:none!important}
#game-shell .ability-float-btn,
#game-shell .ability-btn.ability-float-btn{
  pointer-events:auto;
  width:82px;
  height:82px;
  min-width:82px;
  min-height:82px;
  border-radius:50%;
  padding:0;
  border:1px solid rgba(255,244,92,.70);
  background:
    radial-gradient(circle at 50% 38%,rgba(255,255,255,.28),transparent 22%),
    radial-gradient(circle at 50% 50%,rgba(255,112,24,.98),rgba(255,31,78,.88) 42%,rgba(55,8,20,.94) 72%),
    conic-gradient(from 0deg,rgba(255,244,92,.92),rgba(255,31,220,.76),rgba(0,247,255,.78),rgba(255,244,92,.92));
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  box-shadow:
    0 0 0 4px rgba(255,122,24,.10),
    0 0 28px rgba(255,122,24,.50),
    0 0 34px rgba(255,31,220,.25),
    inset 0 0 19px rgba(255,255,255,.20),
    inset 0 -16px 28px rgba(0,0,0,.30);
  animation:omoFireFloat 2.1s ease-in-out infinite;
  overflow:visible;
}
#game-shell .ability-float-btn:before{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:1px solid rgba(0,247,255,.38);
  box-shadow:0 0 20px rgba(0,247,255,.22),inset 0 0 18px rgba(255,31,220,.18);
  animation:omoFireRing 1.55s ease-in-out infinite;
  pointer-events:none;
}
#game-shell .ability-float-btn:after{
  content:"";
  position:absolute;
  inset:6px;
  border-radius:50%;
  border-top:2px solid rgba(255,255,255,.55);
  border-right:2px solid rgba(255,244,92,.28);
  opacity:.85;
  pointer-events:none;
}
#game-shell .ability-float-btn span{
  font-size:31px;
  line-height:.9;
  text-shadow:0 0 12px rgba(255,244,92,.90),0 0 22px rgba(255,31,78,.80);
}
#game-shell .ability-float-btn b{
  font-size:11px;
  line-height:1;
  letter-spacing:.08em;
  text-shadow:0 0 8px rgba(255,255,255,.72);
}
#game-shell .ability-float-btn.ready{
  border-color:rgba(255,244,92,1);
  box-shadow:
    0 0 0 5px rgba(255,244,92,.10),
    0 0 34px rgba(255,244,92,.58),
    0 0 42px rgba(0,247,255,.25),
    inset 0 0 22px rgba(255,255,255,.24);
}
#game-shell .ability-float-btn.active{
  animation:omoFireActive .48s ease-in-out infinite alternate;
}
#game-shell .ability-float-btn.locked{
  opacity:.96;
  border-color:rgba(191,255,255,.42);
  background:
    radial-gradient(circle at 50% 38%,rgba(255,255,255,.20),transparent 22%),
    radial-gradient(circle at 50% 50%,rgba(60,72,96,.86),rgba(23,28,48,.92) 54%,rgba(4,7,20,.96) 78%),
    conic-gradient(from 0deg,rgba(0,247,255,.55),rgba(255,31,220,.45),rgba(255,244,92,.42),rgba(0,247,255,.55));
  box-shadow:0 0 26px rgba(0,247,255,.20),0 0 22px rgba(255,31,220,.10),inset 0 0 18px rgba(255,255,255,.11);
}
#game-shell .ability-float-btn:disabled{
  opacity:.78;
  cursor:default;
}
#game-shell .toast{
  bottom:calc(50% - 8px);
  transform:translate(-50%,50%);
  z-index:14;
  max-width:min(86vw,360px);
  white-space:normal;
  text-align:center;
  border-radius:20px;
  padding:13px 18px;
  background:linear-gradient(160deg,rgba(3,8,22,.94),rgba(22,8,42,.92));
  border-color:rgba(191,255,255,.42);
  box-shadow:0 0 28px rgba(0,247,255,.20),0 0 24px rgba(255,31,220,.12),0 18px 42px rgba(0,0,0,.45);
}
@keyframes omoFireFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-3px) scale(1.025)}}
@keyframes omoFireRing{0%,100%{transform:scale(.96);opacity:.62}50%{transform:scale(1.08);opacity:1}}
@keyframes omoFireActive{0%{transform:scale(.96) rotate(-1deg)}100%{transform:scale(1.05) rotate(1deg)}}
@media (max-width:430px){
  #game-shell .hud{
    left:6px;
    right:6px;
    gap:5px;
    grid-template-columns:minmax(50px,.64fr) minmax(112px,1.38fr) minmax(48px,.58fr) 38px !important;
  }
  #game-shell .score-panel,#game-shell .variant-panel,#game-shell .hud-center,#game-shell .pause-btn{min-height:46px;height:46px}
  #game-shell .hud-panel strong{font-size:16px}
  #game-shell .variant-panel strong{font-size:10px}
  #game-shell .hud-kicker{font-size:6px;letter-spacing:.15em}
  #game-shell .ability-name,#game-shell #comboLabel{font-size:7px;letter-spacing:.08em}
  #game-shell .pause-btn{width:38px;min-width:38px;font-size:18px;border-radius:14px}
  #game-shell .ability-dock{right:calc(13px + env(safe-area-inset-right));bottom:calc(88px + env(safe-area-inset-bottom))}
  #game-shell .ability-float-btn,#game-shell .ability-btn.ability-float-btn{width:74px;height:74px;min-width:74px;min-height:74px}
  #game-shell .ability-float-btn span{font-size:28px}
  #game-shell .ability-float-btn b{font-size:10px}
}
@media (max-width:370px){
  #game-shell .hud{grid-template-columns:48px minmax(96px,1fr) 45px 36px !important}
  #game-shell .hud-panel{padding-left:4px;padding-right:4px}
  #game-shell .hud-panel strong{font-size:14px}
  #game-shell .variant-panel strong{font-size:9px}
  #game-shell .ability-dock{bottom:calc(82px + env(safe-area-inset-bottom))}
  #game-shell .ability-float-btn,#game-shell .ability-btn.ability-float-btn{width:68px;height:68px;min-width:68px;min-height:68px}
}


/* MODE TEXT TRUNCATION FIX */
.variant-panel{min-width:82px!important;}
.variant-panel strong{white-space:nowrap!important;overflow:visible!important;font-size:12px!important;}


/* === TARGETED SMOOTHNESS + MAIN MENU CLEANUP PATCH === */
/* Main menu only: cover live gameplay canvas so lane guides/enemies never show behind start screen */
#mainMenu.active{
  background:
    radial-gradient(circle at 50% 18%,rgba(0,247,255,.16),transparent 31%),
    radial-gradient(circle at 50% 62%,rgba(255,31,220,.11),transparent 38%),
    linear-gradient(180deg,rgba(2,3,10,.96),rgba(2,3,10,.92))!important;
}
#mainMenu.active::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 16%,rgba(0,247,255,.12),transparent 34%),
    radial-gradient(circle at 50% 70%,rgba(255,31,220,.08),transparent 42%),
    linear-gradient(180deg,rgba(2,3,10,.94),rgba(2,3,10,.90))!important;
}
#mainMenu.active .logo-wrap,
#mainMenu.active .hero-card{
  position:relative;
  z-index:3;
}

/* Gameplay smoothness: reduce costly infinite CSS effects while preserving the premium look */
#game-shell,
#gameCanvas{
  transform:translateZ(0);
  backface-visibility:hidden;
}
.hud-panel,
.evo-bar,
.pause-btn,
.ability-btn,
.menu-card{
  transform:translateZ(0);
}
.power-bar:after{
  animation-duration:3.8s!important;
  opacity:.58!important;
}
.ability-btn.ready{
  animation-duration:2.2s!important;
}
.ability-btn.active{
  animation-duration:.9s!important;
}

/* Mobile/WebView performance guard */
@media (max-width:520px), (max-height:720px){
  #game-shell:after{
    opacity:.18!important;
  }
  .screen:before{
    opacity:.055!important;
  }
  .hud-panel,
  .evo-bar,
  .pause-btn,
  .ability-btn,
  .menu-card,
  .hero-card{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
  }
  .power-bar:after{
    animation:none!important;
    opacity:.22!important;
  }
}

/* === MOBILE ARCHIVE SCROLL BLUR FIX + STYLE SMOOTHNESS PATCH === */
/* Fix iPhone Safari blur/smear when scrolling archive cards */
.archive-screen.active{
  display:flex!important;
  overflow:hidden!important;
  contain:layout paint!important;
}
.archive-shell{
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
  will-change:auto!important;
  overflow:hidden!important;
}
.archive-topbar{
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
}
.skin-grid{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
  will-change:scroll-position!important;
  contain:layout paint!important;
}
.skin-card{
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
  will-change:auto!important;
}

/* Smoothness: reduce costly active UI effects without changing layout or gameplay */
#game-shell,
#gameCanvas{
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
}
.hud,
.ability-dock,
.ability-btn,
.hud-panel,
.evo-bar,
.pause-btn,
.toast{
  transform:translateZ(0)!important;
  backface-visibility:hidden!important;
  -webkit-backface-visibility:hidden!important;
}

/* Keep premium feel but slow down constant decorative animations */
.power-bar:after{
  animation-duration:4s!important;
  opacity:.45!important;
}
.ability-btn.ready{
  animation-duration:2.4s!important;
}
.ability-btn.active{
  animation-duration:1s!important;
}
.breach-grid,
.archive-screen:after,
#game-shell:after{
  animation-duration:14s!important;
}
.skin-card{
  animation-duration:7.5s!important;
}
.menu-mascot-preview,
.menu-mascot-preview:before,
.menu-mascot-preview:after{
  animation-duration:7s!important;
}

/* Mobile/WebView-specific performance guard */
@media (max-width:520px), (max-height:760px){
  #game-shell:after{
    opacity:.14!important;
  }
  .screen:before{
    opacity:.045!important;
  }

  .archive-shell,
  .archive-topbar,
  .skin-card,
  .purchase-card,
  .hero-card,
  .menu-card,
  .hud-panel,
  .evo-bar,
  .pause-btn,
  .ability-btn,
  .toast{
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
  }

  .archive-shell{
    background:linear-gradient(155deg,rgba(4,9,25,.96),rgba(17,7,39,.94))!important;
  }
  .archive-topbar{
    background:linear-gradient(180deg,rgba(4,8,22,.98),rgba(4,8,22,.94))!important;
  }
  .skin-card{
    background:radial-gradient(circle at 50% 8%,rgba(0,247,255,.11),transparent 30%),linear-gradient(160deg,rgba(7,13,34,.92),rgba(18,8,38,.90))!important;
    box-shadow:inset 0 0 14px rgba(0,247,255,.045),0 8px 20px rgba(0,0,0,.24)!important;
  }

  .skin-shine,
  .hero-card:before,
  .purchase-card:before,
  .primary-btn:before,
  .secondary-btn:before,
  .ghost-btn:before,
  .archive-menu-btn:before,
  .power-bar:after{
    animation:none!important;
  }

  .skin-image{
    filter:drop-shadow(0 0 8px rgba(0,247,255,.24))!important;
  }
  .menu-mascot-preview{
    box-shadow:0 0 0 6px rgba(0,247,255,.025),0 0 20px rgba(0,247,255,.24),inset 0 0 24px rgba(0,247,255,.08)!important;
  }
}

/* Motion safety: keeps UI stable on weaker browsers */
@media (prefers-reduced-motion: reduce){
  *,
  *:before,
  *:after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
}


/* === OMO RUN STABLE UI INTEGRATION v3 — SAFE VISIBILITY + CONSISTENT HUD === */

/* Absolute safety: previous HUD overrides used !important display:grid.
   This restores the original hidden behaviour everywhere. */
#game-shell .hidden,
#game-shell .hud.hidden,
#game-shell .ability-dock.hidden,
#game-shell .evolution-overlay.hidden,
#game-shell .toast.hidden{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

/* HUD should only display when Engine removes .hidden */
#game-shell .hud:not(.hidden){
  display:grid!important;
  visibility:visible!important;
  opacity:1!important;
}

/* Ability dock should only display when Engine removes .hidden */
#game-shell .ability-dock:not(.hidden){
  display:flex!important;
  visibility:visible!important;
  opacity:1!important;
}

/* Keep main menu clean: no gameplay HUD, no fire dock on top of the menu. */
#game-shell #mainMenu.active ~ #hud,
#game-shell #mainMenu.active ~ #abilityDock{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

/* Main menu: restore Settings + OMO Chat without making the card too tall */
#game-shell #mainMenu.active{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
}

#game-shell #mainMenu .hero-card{
  position:relative!important;
  width:min(92vw,360px)!important;
  max-width:360px!important;
  max-height:calc(100dvh - 126px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
  padding:13px 14px 82px!important;
  overflow:hidden!important;
}

#game-shell #mainMenu .protocol-row{
  margin-bottom:8px!important;
}

#game-shell #mainMenu .menu-mascot-preview{
  width:clamp(88px,17vh,124px)!important;
  height:clamp(88px,17vh,124px)!important;
  margin-bottom:0!important;
}

#game-shell #mainMenu .eyebrow{
  font-size:clamp(18px,4.2vh,26px)!important;
  line-height:.96!important;
}

#game-shell #mainMenu .tagline{
  display:block!important;
  font-size:10.5px!important;
  line-height:1.14!important;
  margin-top:5px!important;
}

#game-shell #mainMenu .primary-btn,
#game-shell #mainMenu .archive-menu-btn,
#game-shell #mainMenu .leaderboard-menu-btn{
  min-height:42px!important;
  margin-top:6px!important;
  padding:9px 11px!important;
  border-radius:17px!important;
  font-size:13.5px!important;
}

#game-shell #mainMenu .stat-strip{
  display:none!important;
}

#game-shell #mainMenu .footer-row{
  position:absolute!important;
  left:14px!important;
  right:14px!important;
  bottom:13px!important;
  z-index:8!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:7px!important;
  margin:0!important;
  padding:0!important;
  text-align:center!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}

#game-shell #mainMenu .footer-row > span{
  display:block!important;
  width:100%!important;
  color:#bfffff!important;
  font-size:8.5px!important;
  line-height:1!important;
  letter-spacing:.13em!important;
  white-space:nowrap!important;
  opacity:1!important;
  visibility:visible!important;
}

#game-shell #mainMenu .footer-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:8px!important;
  width:100%!important;
  min-width:0!important;
  opacity:1!important;
  visibility:visible!important;
}

#game-shell #mainMenu .footer-actions .footer-link{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  min-width:0!important;
  min-height:36px!important;
  padding:8px 7px!important;
  border-radius:999px!important;
  font-size:9.5px!important;
  line-height:1!important;
  letter-spacing:.07em!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}

/* Stable 4-column gameplay HUD.
   HTML children: score, power, mode, pause. Fire is in abilityDock. */
#game-shell .hud:not(.hidden){
  top:calc(10px + env(safe-area-inset-top))!important;
  left:8px!important;
  right:8px!important;
  z-index:8!important;
  grid-template-columns:minmax(62px,.72fr) minmax(132px,1.28fr) minmax(78px,.82fr) 42px!important;
  gap:7px!important;
  align-items:start!important;
  pointer-events:none!important;
}

#game-shell .hud-panel,
#game-shell .hud-center,
#game-shell .pause-btn{
  min-width:0!important;
  pointer-events:auto!important;
}

#game-shell .score-panel,
#game-shell .variant-panel{
  min-height:48px!important;
  height:48px!important;
  padding:6px 7px!important;
  border-radius:16px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  overflow:hidden!important;
}

#game-shell .score-panel{
  text-align:left!important;
}

#game-shell .variant-panel{
  text-align:center!important;
}

#game-shell .hud-kicker{
  font-size:6px!important;
  letter-spacing:.15em!important;
  line-height:1!important;
  white-space:nowrap!important;
}

#game-shell .hud-panel strong{
  max-width:100%!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:clip!important;
}

#game-shell .score-panel strong{
  font-size:17px!important;
}

#game-shell .variant-panel strong{
  font-size:clamp(10px,3vw,14px)!important;
  line-height:1!important;
  padding-top:2px!important;
  white-space:nowrap!important;
  overflow:visible!important;
}

#game-shell .hud-center{
  justify-self:stretch!important;
  align-self:start!important;
  max-width:none!important;
  min-height:48px!important;
  height:48px!important;
  padding-top:0!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  align-items:stretch!important;
  gap:4px!important;
}

#game-shell .ability-name,
#game-shell #comboLabel{
  width:100%!important;
  max-width:100%!important;
  text-align:center!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

#game-shell .ability-name{
  font-size:8px!important;
  letter-spacing:.09em!important;
  margin:0!important;
}

#game-shell #comboLabel{
  font-size:7.5px!important;
  letter-spacing:.08em!important;
}

#game-shell .power-bar{
  width:100%!important;
  max-width:none!important;
  height:10px!important;
  border-radius:999px!important;
}

#game-shell .pause-btn{
  width:42px!important;
  min-width:42px!important;
  height:48px!important;
  min-height:48px!important;
  border-radius:16px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:19px!important;
  line-height:1!important;
}

/* Fire button: one consistent premium circular dock for every mascot */
#game-shell .ability-dock:not(.hidden){
  position:absolute!important;
  right:calc(18px + env(safe-area-inset-right))!important;
  bottom:calc(19% + env(safe-area-inset-bottom))!important;
  z-index:9!important;
  align-items:center!important;
  justify-content:center!important;
  pointer-events:none!important;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.46))!important;
}

#game-shell .ability-float-btn,
#game-shell .ability-btn.ability-float-btn{
  pointer-events:auto!important;
  position:relative!important;
  width:76px!important;
  height:76px!important;
  min-width:76px!important;
  min-height:76px!important;
  max-width:76px!important;
  max-height:76px!important;
  aspect-ratio:1/1!important;
  border-radius:50%!important;
  padding:0!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:2px!important;
  border:1px solid rgba(255,244,92,.76)!important;
  color:#fff!important;
  background:
    radial-gradient(circle at 50% 38%,rgba(255,255,255,.28),transparent 22%),
    radial-gradient(circle at 50% 50%,rgba(255,112,24,.96),rgba(255,31,78,.88) 43%,rgba(38,7,18,.94) 72%),
    conic-gradient(from 0deg,rgba(255,244,92,.94),rgba(255,31,220,.78),rgba(0,247,255,.80),rgba(255,244,92,.94))!important;
  box-shadow:
    0 0 0 4px rgba(255,122,24,.10),
    0 0 28px rgba(255,122,24,.46),
    0 0 34px rgba(255,31,220,.22),
    inset 0 0 18px rgba(255,255,255,.20),
    inset 0 -15px 26px rgba(0,0,0,.30)!important;
  overflow:visible!important;
}

#game-shell .ability-float-btn:before{
  content:""!important;
  position:absolute!important;
  inset:-7px!important;
  border-radius:50%!important;
  border:1px solid rgba(0,247,255,.40)!important;
  box-shadow:0 0 20px rgba(0,247,255,.22),inset 0 0 18px rgba(255,31,220,.18)!important;
  pointer-events:none!important;
}

#game-shell .ability-float-btn:after{
  content:""!important;
  position:absolute!important;
  inset:7px!important;
  border-radius:50%!important;
  border-top:2px solid rgba(255,255,255,.52)!important;
  border-right:2px solid rgba(255,244,92,.24)!important;
  pointer-events:none!important;
}

#game-shell .ability-float-btn span{
  font-size:28px!important;
  line-height:.9!important;
  text-shadow:0 0 12px rgba(255,244,92,.88),0 0 21px rgba(255,31,78,.78)!important;
}

#game-shell .ability-float-btn b{
  font-size:10px!important;
  line-height:1!important;
  letter-spacing:.08em!important;
  text-shadow:0 0 8px rgba(255,255,255,.72)!important;
}

#game-shell .ability-float-btn.locked{
  opacity:.95!important;
  border-color:rgba(191,255,255,.46)!important;
  background:
    radial-gradient(circle at 50% 38%,rgba(255,255,255,.20),transparent 22%),
    radial-gradient(circle at 50% 50%,rgba(57,70,96,.88),rgba(23,28,48,.92) 55%,rgba(4,7,20,.96) 78%),
    conic-gradient(from 0deg,rgba(0,247,255,.58),rgba(255,31,220,.48),rgba(255,244,92,.42),rgba(0,247,255,.58))!important;
  box-shadow:0 0 26px rgba(0,247,255,.20),0 0 22px rgba(255,31,220,.10),inset 0 0 18px rgba(255,255,255,.11)!important;
}

@media (max-width:430px){
  #game-shell .hud:not(.hidden){
    left:6px!important;
    right:6px!important;
    gap:6px!important;
    grid-template-columns:minmax(52px,.62fr) minmax(122px,1.18fr) minmax(70px,.78fr) 38px!important;
  }

  #game-shell .score-panel,
  #game-shell .variant-panel,
  #game-shell .hud-center{
    min-height:46px!important;
    height:46px!important;
  }

  #game-shell .score-panel,
  #game-shell .variant-panel{
    padding:5px 6px!important;
    border-radius:15px!important;
  }

  #game-shell .score-panel strong{
    font-size:15px!important;
  }

  #game-shell .variant-panel strong{
    font-size:11px!important;
  }

  #game-shell .ability-name{
    font-size:7.2px!important;
  }

  #game-shell #comboLabel{
    font-size:7px!important;
  }

  #game-shell .power-bar{
    height:9px!important;
  }

  #game-shell .pause-btn{
    width:38px!important;
    min-width:38px!important;
    height:46px!important;
    min-height:46px!important;
    border-radius:15px!important;
    font-size:18px!important;
  }

  #game-shell .ability-dock:not(.hidden){
    right:calc(16px + env(safe-area-inset-right))!important;
    bottom:calc(18% + env(safe-area-inset-bottom))!important;
  }

  #game-shell .ability-float-btn,
  #game-shell .ability-btn.ability-float-btn{
    width:70px!important;
    height:70px!important;
    min-width:70px!important;
    min-height:70px!important;
    max-width:70px!important;
    max-height:70px!important;
  }

  #game-shell .ability-float-btn span{
    font-size:26px!important;
  }

  #game-shell .ability-float-btn b{
    font-size:9.5px!important;
  }
}

@media (max-width:370px){
  #game-shell .hud:not(.hidden){
    grid-template-columns:48px minmax(108px,1fr) 62px 36px!important;
    gap:5px!important;
  }

  #game-shell .variant-panel strong{
    font-size:9.5px!important;
  }

  #game-shell .ability-dock:not(.hidden){
    right:calc(13px + env(safe-area-inset-right))!important;
    bottom:calc(17% + env(safe-area-inset-bottom))!important;
  }

  #game-shell .ability-float-btn,
  #game-shell .ability-btn.ability-float-btn{
    width:64px!important;
    height:64px!important;
    min-width:64px!important;
    min-height:64px!important;
    max-width:64px!important;
    max-height:64px!important;
  }
}

@media (max-height:760px){
  #game-shell #mainMenu .hero-card{
    max-height:calc(100dvh - 108px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    padding-bottom:76px!important;
  }

  #game-shell #mainMenu .menu-mascot-preview{
    width:clamp(80px,15vh,108px)!important;
    height:clamp(80px,15vh,108px)!important;
  }

  #game-shell #mainMenu .logo-title span,
  #game-shell #mainMenu .logo-title strong{
    font-size:clamp(36px,8.4vh,56px)!important;
  }

  #game-shell #mainMenu .primary-btn,
  #game-shell #mainMenu .archive-menu-btn,
  #game-shell #mainMenu .leaderboard-menu-btn{
    min-height:40px!important;
    font-size:13px!important;
  }
}


/* === OMO MENU FOOTER FORCE FIX v4 — SHELL-BASED LAYOUT === */
/* Uses #game-shell percentage sizing instead of 100dvh, because Telegram's top chrome can make dvh larger than the actual game canvas.
   This prevents SETTINGS / OMO CHAT from being clipped on reopen. */

#game-shell #mainMenu.active{
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  align-items:center!important;
  gap:6px!important;
  padding:12px 14px 12px!important;
  padding-top:calc(12px + env(safe-area-inset-top))!important;
  padding-bottom:calc(12px + env(safe-area-inset-bottom))!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  touch-action:pan-y!important;
}

#game-shell #mainMenu.active .logo-wrap{
  flex:0 0 auto!important;
  width:100%!important;
  max-width:360px!important;
  margin:0 0 5px!important;
}

#game-shell #mainMenu.active .logo-title span,
#game-shell #mainMenu.active .logo-title strong{
  font-size:clamp(40px,7.6vh,58px)!important;
  line-height:.84!important;
}

#game-shell #mainMenu.active .logo-sub{
  margin-top:6px!important;
  padding:6px 12px!important;
  font-size:9px!important;
}

#game-shell #mainMenu.active .hero-card{
  flex:0 0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  align-items:stretch!important;
  gap:6px!important;
  width:min(92vw,360px)!important;
  max-width:360px!important;
  height:auto!important;
  max-height:none!important;
  min-height:0!important;
  padding:12px!important;
  padding-bottom:12px!important;
  overflow:visible!important;
  border-radius:24px!important;
}

#game-shell #mainMenu.active .protocol-row{
  flex:0 0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  gap:5px!important;
  margin:0 0 6px!important;
}

#game-shell #mainMenu.active .menu-mascot-preview{
  flex:0 0 auto!important;
  display:block!important;
  width:clamp(88px,17.5vh,128px)!important;
  height:clamp(88px,17.5vh,128px)!important;
  margin:0 auto!important;
  visibility:visible!important;
  opacity:1!important;
  background-size:72% auto!important;
  background-position:center!important;
  background-repeat:no-repeat!important;
}

#game-shell #mainMenu.active .eyebrow{
  font-size:clamp(17px,3.6vh,22px)!important;
  line-height:.96!important;
}

#game-shell #mainMenu.active .tagline{
  display:block!important;
  margin-top:4px!important;
  font-size:11px!important;
  line-height:1.12!important;
}

#game-shell #mainMenu.active .primary-btn,
#game-shell #mainMenu.active .archive-menu-btn,
#game-shell #mainMenu.active .leaderboard-menu-btn{
  flex:0 0 auto!important;
  min-height:38px!important;
  height:38px!important;
  margin-top:4px!important;
  padding:7px 10px!important;
  border-radius:15px!important;
  font-size:12.5px!important;
  line-height:1!important;
}

#game-shell #mainMenu.active .stat-strip{
  display:none!important;
}

/* Footer must be normal document flow, visible, and compact. */
#game-shell #mainMenu.active .footer-row{
  position:relative!important;
  inset:auto!important;
  left:auto!important;
  right:auto!important;
  bottom:auto!important;
  top:auto!important;
  transform:none!important;
  flex:0 0 auto!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:6px!important;
  width:100%!important;
  margin:5px 0 0!important;
  padding:0!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  overflow:visible!important;
}

#game-shell #mainMenu.active .footer-row > span{
  display:block!important;
  width:100%!important;
  min-height:10px!important;
  color:#bfffff!important;
  font-size:8px!important;
  font-weight:1000!important;
  line-height:1!important;
  letter-spacing:.14em!important;
  text-align:center!important;
  white-space:nowrap!important;
  opacity:1!important;
  visibility:visible!important;
}

#game-shell #mainMenu.active .footer-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:7px!important;
  width:100%!important;
  min-width:0!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}

#game-shell #mainMenu.active .footer-actions .footer-link,
#game-shell #mainMenu.active #settingsButton,
#game-shell #mainMenu.active #omoChatButton{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  min-width:0!important;
  min-height:32px!important;
  height:32px!important;
  padding:7px 8px!important;
  border-radius:999px!important;
  font-size:8.8px!important;
  line-height:1!important;
  letter-spacing:.07em!important;
  white-space:nowrap!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:none!important;
  overflow:hidden!important;
}

/* Very short Telegram WebView fallback: shrink entire menu content slightly instead of clipping the footer. */
@media (max-height:720px){
  #game-shell #mainMenu.active{
    padding-top:calc(8px + env(safe-area-inset-top))!important;
    gap:4px!important;
  }

  #game-shell #mainMenu.active .logo-title span,
  #game-shell #mainMenu.active .logo-title strong{
    font-size:clamp(34px,7vh,48px)!important;
  }

  #game-shell #mainMenu.active .logo-sub{
    margin-top:5px!important;
    padding:5px 10px!important;
    font-size:8px!important;
  }

  #game-shell #mainMenu.active .hero-card{
    gap:5px!important;
    padding:10px!important;
    border-radius:22px!important;
  }

  #game-shell #mainMenu.active .menu-mascot-preview{
    width:clamp(76px,15vh,108px)!important;
    height:clamp(76px,15vh,108px)!important;
  }

  #game-shell #mainMenu.active .tagline{
    font-size:10px!important;
    line-height:1.05!important;
  }

  #game-shell #mainMenu.active .primary-btn,
  #game-shell #mainMenu.active .archive-menu-btn,
  #game-shell #mainMenu.active .leaderboard-menu-btn{
    min-height:34px!important;
    height:34px!important;
    font-size:11px!important;
    margin-top:3px!important;
  }

  #game-shell #mainMenu.active .footer-row{
    gap:5px!important;
    margin-top:4px!important;
  }

  #game-shell #mainMenu.active .footer-actions .footer-link,
  #game-shell #mainMenu.active #settingsButton,
  #game-shell #mainMenu.active #omoChatButton{
    min-height:30px!important;
    height:30px!important;
    font-size:8px!important;
  }
}

@media (max-height:640px){
  #game-shell #mainMenu.active .tagline{
    display:none!important;
  }

  #game-shell #mainMenu.active .menu-mascot-preview{
    width:74px!important;
    height:74px!important;
  }
}
