
:root{
  --bg:#091220;--bg2:#0e1a2d;--panel:rgba(11,20,36,.78);--line:rgba(255,255,255,.08);--text:#eff7ff;--muted:#97aac8;
  --cyan:#6ee7ff;--blue:#60a5fa;--pink:#fb7185;--yellow:#fbbf24;--green:#34d399;--violet:#a78bfa;
  --shadow:0 20px 50px rgba(0,0,0,.35);--radius:24px
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}
body{
  font-family:Inter,system-ui,sans-serif;color:var(--text);
  background:linear-gradient(180deg,#08101c,#0b1422 50%,#0b1724 100%);
  overflow-x:hidden; -webkit-tap-highlight-color: transparent; padding-bottom: env(safe-area-inset-bottom);
}
body[data-theme="sunset"]{background:linear-gradient(180deg,#1a1120,#27152b 50%,#241220 100%)}
body[data-theme="mint"]{background:linear-gradient(180deg,#081818,#0c2220 50%,#0b1d1a 100%)}
.app-bg{position:fixed;inset:0;pointer-events:none;background:
 radial-gradient(circle at 15% 15%,rgba(96,165,250,.18),transparent 22%),
 radial-gradient(circle at 85% 10%,rgba(167,139,250,.18),transparent 20%),
 radial-gradient(circle at 50% 100%,rgba(251,191,36,.1),transparent 28%)}
.topbar,.layer-card,.modal,.hud-pill,.chip,.touch-btn,.mode-card,.side-stat,.mini-stat,.history-item,.setting-card{
  position:relative;border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 0 rgba(0,0,0,.14), var(--shadow);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
}
.topbar::after,.layer-card::after,.modal::after,.hud-pill::after,.chip::after,.touch-btn::after,.mode-card::after,.side-stat::after,.mini-stat::after,.history-item::after,.setting-card::after{
  content:"";position:absolute;inset:1px;border-radius:inherit;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent 22%,transparent 78%,rgba(255,255,255,.03))
}
.topbar{margin:10px auto 0; width:min(1360px,calc(100% - 20px)); padding:14px 16px;border-radius:24px;display:flex;justify-content:space-between;gap:14px;align-items:center}
.brand{display:flex;gap:14px;align-items:center;min-width:0}
.brand-logo{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;font-size:28px;background:linear-gradient(135deg,rgba(110,231,255,.24),rgba(96,165,250,.18))}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--cyan)}
.title{font-size:clamp(24px,3vw,38px);font-weight:900;line-height:1;letter-spacing:-.05em}
.subtitle{color:var(--muted);font-size:14px;margin-top:4px}
.top-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.lang-switch{display:inline-flex;padding:4px;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.lang-btn,.theme-pill,.mode-card,.btn{font:800 14px Inter,sans-serif}
.lang-btn{border:0;background:transparent;color:var(--text);border-radius:10px;min-width:42px;min-height:40px;cursor:pointer}
.lang-btn.active{background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.18))}
.btn{
  appearance:none;border:0;border-bottom:4px solid rgba(0,0,0,.22);cursor:pointer;min-height:52px;padding:0 16px;border-radius:16px;color:var(--text);
  display:inline-flex;align-items:center;justify-content:center;gap:10px;touch-action:manipulation;transition:.14s ease;white-space:nowrap
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(2px);border-bottom-width:2px}
.btn-primary{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#05111c}
.btn-ghost{background:rgba(255,255,255,.06)}
.icon-btn .btn-text{min-width:0;overflow:hidden;text-overflow:ellipsis}
.shell{width:min(1360px,calc(100% - 20px));margin:12px auto 18px;display:grid;gap:14px}
.hero{border-radius:28px;padding:18px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px}
.hero h1{font-size:clamp(28px,4vw,48px);line-height:.95;letter-spacing:-.05em;margin:0 0 10px}
.hero p{margin:0;color:var(--muted);line-height:1.7}
.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.chip{padding:10px 14px;border-radius:999px;font-weight:800}
.hero-stats{display:grid;gap:12px}
.mini-stat{border-radius:20px;padding:16px}
.mini-stat small,.side-stat small,.setting-card small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.14em;margin-bottom:8px}
.mini-stat strong,.side-stat strong{font-size:28px;font-weight:900;letter-spacing:-.04em}
.game-wrap{display:grid;grid-template-columns:minmax(0,1.6fr) 350px;gap:14px}
.game-panel{border-radius:30px;padding:0;overflow:hidden;position:relative;min-height:760px}
#game{display:block;width:100%;height:100%;background:linear-gradient(180deg,#06101d,#091522)}
.hud{position:absolute;inset:14px 14px auto 14px;display:flex;justify-content:space-between;gap:10px;z-index:5}
.hud-left{display:flex;gap:8px;flex-wrap:wrap}
.hud-pill{padding:12px 14px;border-radius:18px;display:flex;gap:10px;align-items:center;background:rgba(8,14,24,.72);backdrop-filter:blur(12px)}
.hud-pill strong{font-size:18px}
.boss-box{min-width:240px;padding:12px 14px;border-radius:18px;background:rgba(8,14,24,.72)}
.boss-box small{display:block;color:var(--muted);margin-bottom:8px}
.boss-bar{height:14px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.boss-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--pink),var(--yellow));transition:width .2s ease}
.touch-controls{position:absolute;left:14px;right:14px;bottom:14px;display:flex;justify-content:space-between;align-items:end;z-index:5}
.touch-btn{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;color:var(--text);background:linear-gradient(180deg,rgba(16,26,42,.96),rgba(6,12,21,.95));touch-action:manipulation}
.touch-btn.main{width:82px;height:82px;font-size:22px}
.overlay{position:absolute;inset:0;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(3,7,14,.74);backdrop-filter:blur(8px);z-index:8;overscroll-behavior:contain;pointer-events:none}
.overlay.active{display:flex;pointer-events:auto}
.page-overlay{position:fixed;z-index:30}
.modal{width:min(580px,100%);padding:26px;border-radius:28px}
.wide-modal{width:min(860px,100%)}
.big-modal{width:min(680px,100%)}
.modal h2{font-size:clamp(28px,4vw,42px);line-height:.95;letter-spacing:-.05em;margin:0 0 12px}
.modal p{color:var(--muted);line-height:1.65;margin:0}
.modal-kicker{display:inline-flex;gap:8px;color:var(--cyan);font-size:11px;text-transform:uppercase;letter-spacing:.14em;font-weight:800;margin-bottom:12px}
.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.mode-card{border-radius:20px;padding:18px;background:rgba(255,255,255,.04);cursor:pointer;text-align:left}
.mode-card.active{outline:2px solid rgba(110,231,255,.38)}
.mode-icon{font-size:32px;margin-bottom:10px}
.mode-title{font-size:18px;font-weight:900}
.mode-desc{color:var(--muted);font-size:13px;margin-top:6px}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.result-grid,.profile-grid,.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}
.theme-pill{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:var(--text);min-height:42px;padding:0 12px;border-radius:999px;cursor:pointer}
.theme-pill.active{background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.18))}
.toggle-list{display:grid;gap:10px}
.onboarding-art{margin:18px auto 0;width:112px;height:112px;border-radius:28px;display:grid;place-items:center;font-size:52px;background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.14))}
.dots{display:flex;justify-content:center;gap:8px;margin-top:14px}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(255,255,255,.18)}
.dot.active{width:30px;background:linear-gradient(135deg,var(--cyan),var(--blue))}
.sidebar{display:grid;gap:14px}
.side-card{border-radius:28px;padding:16px}
.side-title{font-size:18px;font-weight:900;letter-spacing:-.03em;margin-bottom:12px}
.side-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.side-stat{border-radius:18px;padding:14px}
.history-card{margin-top:14px;padding:14px;border-radius:20px}
.history-item{border-radius:16px;padding:12px 14px;display:flex;justify-content:space-between;gap:10px;align-items:center;margin-top:8px}
.history-text{min-width:0}
.history-text strong{display:block}
.history-text span{display:block;color:var(--muted);font-size:12px;margin-top:4px}
.reward-row{display:flex;justify-content:space-between;align-items:center;gap:12px}
.tiny{font-size:12px;color:var(--muted);margin-top:8px}
#notification{position:fixed;right:16px;bottom:16px;z-index:60;max-width:min(380px,calc(100vw - 32px));padding:14px 16px;border-radius:18px;background:rgba(8,14,24,.92);border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow);opacity:0;transform:translateY(12px);transition:.2s ease;pointer-events:none}
#notification.show{opacity:1;transform:translateY(0)}
#flash{position:fixed;inset:0;pointer-events:none;opacity:0;z-index:50;transition:opacity .15s ease;background:white}
.toast{position:absolute;top:84px;left:50%;transform:translateX(-50%);padding:12px 16px;border-radius:999px;background:rgba(8,14,24,.84);z-index:6;font-weight:800}
.hidden{display:none !important}
@media (max-width:1100px){
  .hero,.game-wrap{grid-template-columns:1fr}
}
@media (max-width:760px){
  .topbar,.shell{width:min(100%,calc(100% - 10px))}
  .topbar{flex-direction:column;align-items:stretch}
  .top-actions{justify-content:stretch}
  .top-actions>*{flex:1 1 auto}
  .result-grid,.profile-grid,.settings-grid,.mode-grid{grid-template-columns:1fr}
  .icon-btn .btn-text{display:none}
}
@media (max-width:520px){
  .topbar{width:100%;border-radius:0;margin:0;padding:12px}
  .shell{width:100%;margin:0;gap:0}
  .hero{border-radius:0;padding:14px}
  .hero-stats,.sidebar{display:none}
  .game-panel{border-radius:0;min-height:100vh}
  .hud{inset:8px 8px auto 8px}
  .hud-pill{padding:8px 10px;border-radius:14px}
  .touch-controls{left:10px;right:10px;bottom:10px}
  .touch-btn{width:58px;height:58px}
  .touch-btn.main{width:72px;height:72px}
  .modal{padding:18px;border-radius:22px}
}


/* juice effects */
#flash.flash-hit{background:rgba(255,255,255,1);opacity:.42!important}
#flash.flash-damage{background:rgba(255,70,70,1);opacity:.18!important}
#flash.flash-ultimate{background:radial-gradient(circle, rgba(255,255,255,.95), rgba(255,210,120,.65), rgba(255,255,255,0));opacity:.62!important}
.game-panel.shake{animation:panelShake .18s linear}
@keyframes panelShake{0%{transform:translate(0,0)}20%{transform:translate(-4px,2px)}40%{transform:translate(5px,-2px)}60%{transform:translate(-3px,1px)}80%{transform:translate(3px,-1px)}100%{transform:translate(0,0)}}
.score-pop{position:absolute;z-index:12;font-weight:900;font-size:18px;color:#fff;text-shadow:0 4px 14px rgba(0,0,0,.35);pointer-events:none;animation:scorePop .7s ease forwards}
@keyframes scorePop{0%{opacity:0;transform:translate(-50%,8px) scale(.8)}15%{opacity:1;transform:translate(-50%,-4px) scale(1.05)}100%{opacity:0;transform:translate(-50%,-36px) scale(.96)}}
.wave-badge{position:absolute;left:50%;top:110px;transform:translateX(-50%);z-index:11;padding:12px 18px;border-radius:999px;font-weight:900;background:rgba(8,14,24,.86);border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 28px rgba(0,0,0,.28);animation:waveEnter 1.2s ease forwards}
@keyframes waveEnter{0%{opacity:0;transform:translateX(-50%) translateY(-12px) scale(.94)}20%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}80%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}100%{opacity:0;transform:translateX(-50%) translateY(-8px) scale(.98)}}
.touch-btn.main.ready{box-shadow:0 0 0 0 rgba(110,231,255,.55), 0 10px 26px rgba(96,165,250,.24);animation:pulseReady 1.1s infinite}
@keyframes pulseReady{0%{box-shadow:0 0 0 0 rgba(110,231,255,.45),0 10px 26px rgba(96,165,250,.24)}70%{box-shadow:0 0 0 16px rgba(110,231,255,0),0 10px 26px rgba(96,165,250,.24)}100%{box-shadow:0 0 0 0 rgba(110,231,255,0),0 10px 26px rgba(96,165,250,.24)}}


.touch-controls-grid{
  display:grid;
  grid-template-columns:64px 64px 82px 64px 64px;
  justify-content:space-between;
  align-items:end;
}
@media (max-width:520px){
  .touch-controls-grid{
    grid-template-columns:58px 58px 72px 58px 58px;
  }
}


.zoom-box{display:flex;gap:8px;align-items:center}
.mini-zoom-btn{
  appearance:none;border:0;min-width:34px;height:34px;border-radius:10px;cursor:pointer;
  background:rgba(255,255,255,.08);color:var(--text);font:900 20px Inter,sans-serif;line-height:1;
}
.mini-zoom-btn:active{transform:translateY(1px)}


.zoom-box{display:flex;gap:8px;align-items:center}
.mini-zoom-btn{appearance:none;border:0;min-width:34px;height:34px;border-radius:10px;cursor:pointer;background:rgba(255,255,255,.08);color:var(--text);font:900 20px Inter,sans-serif;line-height:1}
.mini-zoom-btn:active{transform:translateY(1px)}
.touch-controls-grid{display:grid;grid-template-columns:64px 64px 82px 64px 64px;justify-content:space-between;align-items:end}
@media (max-width:520px){.touch-controls-grid{grid-template-columns:58px 58px 72px 58px 58px}}


.rarity-common{filter:none}
.rarity-rare{filter:drop-shadow(0 0 8px rgba(96,165,250,.18))}
.rarity-epic{filter:drop-shadow(0 0 10px rgba(167,139,250,.22))}
.rarity-legendary{filter:drop-shadow(0 0 12px rgba(251,191,36,.28))}


body[data-biome="ocean"] .game-panel{box-shadow:0 0 0 1px rgba(110,231,255,.08),0 18px 46px rgba(0,0,0,.32)}
body[data-biome="laundry"] .game-panel{box-shadow:0 0 0 1px rgba(255,255,255,.10),0 18px 46px rgba(0,0,0,.28)}
body[data-biome="neon"] .game-panel{box-shadow:0 0 0 1px rgba(167,139,250,.14),0 18px 46px rgba(96,165,250,.20)}
body[data-biome="royal"] .game-panel{box-shadow:0 0 0 1px rgba(251,191,36,.16),0 18px 46px rgba(251,191,36,.16)}


.name-field{
  display:grid;
  gap:8px;
  margin-top:18px;
}
.name-field span{
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
}
.name-field input{
  width:100%;
  min-height:52px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:0 16px;
  outline:none;
  font:700 16px Inter,sans-serif;
}
.name-field input::placeholder{color:rgba(255,255,255,.35)}
.name-field input:focus{
  border-color:rgba(110,231,255,.35);
  box-shadow:0 0 0 3px rgba(110,231,255,.08);
}


.inventory-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:18px;
}
.inventory-card,.build-card{
  cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease;
}
.inventory-card:hover,.build-card:hover{transform:translateY(-2px)}
.inventory-card.active,.build-card.active{
  outline:2px solid rgba(110,231,255,.4);
  box-shadow:0 0 0 1px rgba(110,231,255,.14), 0 18px 36px rgba(0,0,0,.25);
}
.inventory-card{
  border-radius:20px;
  padding:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.08);
}
.inventory-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
}
.inventory-icon{
  font-size:28px;
}
.inventory-rarity{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--muted);
}
.inventory-title{
  margin-top:10px;
  font-size:16px;
  font-weight:900;
}
.inventory-meta{
  margin-top:6px;
  color:var(--muted);
  font-size:12px;
}
.build-value{
  font-size:34px;
  font-weight:900;
  letter-spacing:-.05em;
}
@media (max-width:760px){
  .inventory-grid{grid-template-columns:1fr}
}


.equipment-slots{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:18px;
}
.equip-slot{
  appearance:none;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  color:var(--text);
  border-radius:20px;
  min-height:112px;
  padding:14px;
  display:grid;
  gap:6px;
  text-align:left;
  cursor:pointer;
}
.equip-slot span{font-size:26px}
.equip-slot strong{font-size:14px}
.equip-slot small{color:var(--muted);font-size:12px}
.compare-box{
  margin-top:14px;
  border-radius:20px;
  padding:16px;
}
.compare-title{
  font-size:12px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.compare-content{
  margin-top:10px;
  line-height:1.5;
}
.inventory-card.rarity-common{border-color:rgba(255,255,255,.08)}
.inventory-card.rarity-rare{border-color:rgba(96,165,250,.45); box-shadow:0 0 0 1px rgba(96,165,250,.1),0 18px 36px rgba(0,0,0,.25)}
.inventory-card.rarity-epic{border-color:rgba(167,139,250,.55); box-shadow:0 0 0 1px rgba(167,139,250,.12),0 18px 36px rgba(0,0,0,.25)}
.inventory-card.rarity-legendary{border-color:rgba(251,191,36,.65); box-shadow:0 0 0 1px rgba(251,191,36,.14),0 18px 36px rgba(0,0,0,.25)}
.inventory-chip-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:8px;
}
.inventory-chip{
  padding:6px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  font-size:11px;
  font-weight:800;
}
.set-bonus-box{
  margin-top:14px;
  border-radius:20px;
  padding:14px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
}
@media (max-width:760px){
  .equipment-slots{grid-template-columns:1fr}
}


.chest-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.chest-card{
  min-height:170px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  color:var(--text);
  display:grid;
  place-items:center;
  text-align:center;
  cursor:pointer;
  padding:18px;
}
.chest-icon{font-size:48px}
.chest-title{margin-top:10px;font-size:18px;font-weight:900}
.chest-meta{margin-top:6px;color:var(--muted);font-size:13px}
.chest-wooden{border-color:rgba(180,120,70,.35)}
.chest-silver{border-color:rgba(180,190,220,.45)}
.chest-gold{border-color:rgba(251,191,36,.5)}
.chest-royal{border-color:rgba(167,139,250,.55)}
.key-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:8px}
.chest-opening-modal{text-align:center}
.chest-opening-scene{position:relative;display:grid;place-items:center;min-height:220px}
.chest-opening-box{
  width:140px;height:140px;border-radius:32px;display:grid;place-items:center;
  font-size:64px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 36px rgba(0,0,0,.25);
}
.chest-opening-box.animate{animation:chestBounce .9s ease}
@keyframes chestBounce{
  0%{transform:translateY(8px) scale(.94) rotate(-4deg)}
  20%{transform:translateY(-10px) scale(1.02) rotate(3deg)}
  40%{transform:translateY(2px) scale(.98) rotate(-2deg)}
  60%{transform:translateY(-6px) scale(1.04) rotate(2deg)}
  100%{transform:translateY(0) scale(1) rotate(0)}
}
.chest-opening-burst{
  position:absolute;width:220px;height:220px;border-radius:999px;pointer-events:none;
  background:radial-gradient(circle, rgba(255,255,255,.95), rgba(251,191,36,.38), rgba(255,255,255,0));
  opacity:0;transform:scale(.6);
}
.chest-opening-burst.active{animation:burst .8s ease}
@keyframes burst{
  0%{opacity:0;transform:scale(.6)}
  20%{opacity:.95;transform:scale(1)}
  100%{opacity:0;transform:scale(1.3)}
}
.reward-cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.reward-card{
  min-height:140px;
  border-radius:22px;
  padding:16px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  display:grid;
  align-content:center;
  justify-items:center;
  text-align:center;
}
.reward-card .icon{font-size:34px}
.reward-card .value{margin-top:10px;font-size:26px;font-weight:900}
.reward-card .label{margin-top:6px;color:var(--muted);font-size:12px}
@media (max-width:760px){
  .chest-grid,.reward-cards{grid-template-columns:1fr}
}


.pro-settings-modal{max-width:min(980px,100%)}
.pro-settings-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.settings-panel{border-radius:22px;padding:16px}
.settings-panel-title{font-size:16px;font-weight:900;letter-spacing:-.03em;margin-bottom:12px}
.settings-row{display:grid;gap:8px;margin-bottom:14px}
.settings-row small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.14em}
.slider-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}
.slider-wrap input[type="range"]{width:100%}
.pro-toggle-list{gap:12px}
.pro-toggle-list label{display:flex;align-items:center;gap:10px;font-weight:700}
.pro-toggle-list input{width:18px;height:18px}
.settings-hint{margin-top:8px}
body.ui-large{font-size:1.08em}
body.ui-large .btn{min-height:56px}
body.ui-large .hud-pill{padding:14px 16px}
body[data-graphics="low"] .app-bg{display:none}
body[data-graphics="low"] .layer-card::after,
body[data-graphics="low"] .modal::after{display:none}
body[data-graphics="medium"] .app-bg{opacity:.6}
@media (max-width:960px){.pro-settings-grid{grid-template-columns:1fr}}


.name-help{
  color:var(--muted);
  font-size:12px;
}


.nickname-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}
.compact-field{margin-top:0}
.nick-color-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  min-height:52px;
}
.nick-color{
  appearance:none;
  border:2px solid rgba(255,255,255,.14);
  width:30px;
  height:30px;
  border-radius:999px;
  cursor:pointer;
  box-shadow:0 6px 12px rgba(0,0,0,.2);
}
.nick-color.active{
  transform:scale(1.08);
  border-color:rgba(255,255,255,.75);
  box-shadow:0 0 0 3px rgba(255,255,255,.08), 0 10px 20px rgba(0,0,0,.24);
}
.player-name-line{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
}
.player-tag{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:900;
  padding:4px 6px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
}
.player-code{
  font-size:11px;
  color:var(--muted);
  font-weight:800;
}
@media (max-width:760px){
  .nickname-grid{grid-template-columns:1fr}
}


.error-text{color:#fb7185}
.hidden{display:none!important}
.pro-profile-modal{max-width:min(980px,100%)}
.profile-hero{
  margin-top:18px;
  border-radius:24px;
  padding:18px;
  display:grid;
  grid-template-columns:90px minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
}
.profile-avatar-big{
  width:90px;height:90px;border-radius:24px;display:grid;place-items:center;
  font-size:42px;background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.16));
  border:1px solid rgba(255,255,255,.08);
}
.profile-identity{min-width:0}
.profile-name-line{
  font-size:26px;font-weight:900;letter-spacing:-.04em;line-height:1.05;
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
}
.profile-subline{margin-top:6px;color:var(--muted);font-size:13px}
.profile-rank-badge{
  padding:10px 14px;border-radius:999px;
  background:linear-gradient(135deg,rgba(251,191,36,.16),rgba(167,139,250,.12));
  border:1px solid rgba(255,255,255,.08);
  font-weight:900;
}
.pro-profile-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  margin-top:14px;
}
.profile-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.06);
  margin:6px 6px 0 0;font-size:12px;font-weight:800;
}
@media (max-width:760px){
  .profile-hero{grid-template-columns:1fr;justify-items:start}
  .pro-profile-grid{grid-template-columns:1fr}
}


.pro-profile-modal{
  max-height:min(88vh, 920px);
  overflow:auto;
  overscroll-behavior:contain;
  scrollbar-width:thin;
}
.profile-modal-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.profile-close-x{
  min-width:44px;
  width:44px;
  padding:0;
}
#profile-overlay{
  align-items:flex-start;
  padding-top:24px;
  padding-bottom:24px;
}


.repair-fab{
  position:absolute;right:18px;bottom:110px;z-index:7;width:64px;height:64px;border-radius:999px;
  border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  color:var(--text);font-size:26px;box-shadow:0 10px 24px rgba(0,0,0,.28);cursor:pointer
}
.repair-fab:active{transform:translateY(2px)}
.name-help{line-height:1.4}
@media (max-width:760px){
  .top-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
  .hero{padding:14px}
  .hero h1{font-size:28px}
  .game-panel{min-height:calc(100vh - 180px)}
  .sidebar{display:none}
  .hud-left{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:100%}
  .hud-pill{min-width:0;justify-content:center}
}
@media (max-width:520px){
  .repair-fab{width:58px;height:58px;right:10px;bottom:92px;font-size:24px}
  .hud-left{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
  .hud-pill strong{font-size:16px}
  .top-actions{grid-template-columns:repeat(3,minmax(0,1fr))}
  .icon-btn{min-height:46px}
  .icon-btn .btn-text{display:none}
  .game-panel{min-height:100vh}
}


.workshop-modal{max-width:min(980px,100%)}
.workshop-hero{
  display:flex;justify-content:space-between;gap:14px;align-items:center;
  margin-top:18px;padding:16px;border-radius:24px;
}
.workshop-hero-main{display:flex;gap:14px;align-items:center}
.workshop-big-icon{
  width:78px;height:78px;border-radius:22px;display:grid;place-items:center;font-size:38px;
  background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.14));
}
.workshop-name{font-size:18px;font-weight:900}
.workshop-sub{margin-top:4px;color:var(--muted)}
.workshop-resource-box{display:flex;gap:10px;flex-wrap:wrap}
.workshop-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px;
}
.upgrade-card{
  padding:16px;border-radius:22px;cursor:pointer;border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
}
.upgrade-card:hover{transform:translateY(-2px)}
.upgrade-top{display:flex;gap:10px;align-items:center}
.upgrade-top strong{font-size:16px}
.upgrade-value{font-size:34px;font-weight:900;letter-spacing:-.05em;margin-top:10px}
.upgrade-cost{
  margin-top:12px;display:inline-flex;gap:8px;align-items:center;
  padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.06);font-weight:900
}
@media (max-width:760px){
  .workshop-hero{display:grid}
  .workshop-grid{grid-template-columns:1fr}
}


.register-box{
  margin-top:14px;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
}
.register-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.register-title{font-weight:900}
.register-sub{margin-top:4px;color:var(--muted);font-size:13px;line-height:1.4}
.pro-sections-bar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:nowrap;
  overflow:auto;
  padding:4px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.06);
  scrollbar-width:none;
}
.pro-sections-bar::-webkit-scrollbar{display:none}
.pro-sections-bar .lang-switch{
  flex:0 0 auto;
  border-radius:18px;
}
.pro-sections-bar .icon-btn{
  flex:0 0 auto;
  min-height:56px;
  padding:0 18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 10px 20px rgba(0,0,0,.18);
}
.pro-sections-bar .icon-btn span:first-child{font-size:18px}
.pro-sections-bar .icon-btn.active-section{
  background:linear-gradient(135deg,rgba(110,231,255,.18),rgba(96,165,250,.18));
  border-bottom:4px solid rgba(0,0,0,.22);
}
@media (max-width:760px){
  .register-line{display:grid}
  .pro-sections-bar{
    margin-top:10px;
    padding:8px;
    gap:8px;
  }
}


.login-box{
  margin-top:12px;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
}
.login-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
@media (max-width:760px){
  .login-line{display:grid}
}


.smart-auth-box{
  margin-top:12px;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
}
.smart-auth-title{font-weight:900}
.smart-auth-text{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.4}
.smart-auth-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.smart-auth-box.mode-login{border-color:rgba(96,165,250,.3)}
.smart-auth-box.mode-register{border-color:rgba(52,211,153,.3)}
.smart-auth-box.mode-empty{border-color:rgba(255,255,255,.08)}
@media (max-width:760px){
  .smart-auth-actions{display:grid}
}


.smart-auth-box{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 12px 24px rgba(0,0,0,.18);
}
.smart-auth-box.mode-login{
  border-color:rgba(96,165,250,.38);
  box-shadow:0 0 0 1px rgba(96,165,250,.10), inset 0 1px 0 rgba(255,255,255,.08),0 12px 24px rgba(0,0,0,.18);
}
.smart-auth-box.mode-register{
  border-color:rgba(52,211,153,.34);
  box-shadow:0 0 0 1px rgba(52,211,153,.08), inset 0 1px 0 rgba(255,255,255,.08),0 12px 24px rgba(0,0,0,.18);
}
.name-field input.state-login{
  border-color:rgba(96,165,250,.45)!important;
  box-shadow:0 0 0 3px rgba(96,165,250,.08);
}
.name-field input.state-register{
  border-color:rgba(52,211,153,.45)!important;
  box-shadow:0 0 0 3px rgba(52,211,153,.08);
}

.login-box,.register-box{display:none !important;}
.name-help.helper-muted{color:var(--muted)!important}


.simple-auth-box{
  margin-top:14px;
  padding:16px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
}
.simple-auth-row{margin-top:14px}
.auth-code-field{margin-top:0}
.simple-auth-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
.account-created-card{
  margin-top:14px;
  padding:16px;
  border-radius:22px;
  border:1px solid rgba(96,165,250,.24);
  background:linear-gradient(180deg,rgba(96,165,250,.08),rgba(255,255,255,.025));
}
.account-created-main{
  margin-top:12px;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.03em;
}
.hidden{display:none!important}
@media (max-width:760px){
  .simple-auth-actions{display:grid}
}

.simple-auth-box.mode-login{border-color:rgba(96,165,250,.35)}
.simple-auth-box.mode-register{border-color:rgba(52,211,153,.32)}

.simple-auth-box,.account-created-card,.login-box,.register-box{display:none!important;}


/* desktop UX refresh */
.desktop-card-hint{display:none}
@media (min-width:761px){
  .topbar{
    position:sticky;
    top:10px;
    z-index:25;
    backdrop-filter:blur(18px);
  }
  .desktop-card-hint{
    display:block;
    margin:-2px 0 12px;
    color:var(--muted);
    font-size:12px;
    line-height:1.45;
  }
  .desktop-hover-glow,
  .pro-sections-bar .icon-btn,
  .lang-switch,
  .chip,
  .mini-stat,
  .side-stat,
  .history-item,
  .setting-card,
  .settings-panel,
  .equip-slot,
  .inventory-card,
  .build-card,
  .upgrade-card,
  .chest-card,
  .reward-card,
  .mode-card,
  .btn,
  .theme-pill,
  .hud-pill,
  .boss-box,
  .repair-fab{
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, filter .18s ease;
    will-change:transform;
  }
  .desktop-hover-glow:hover,
  .mini-stat:hover,
  .side-stat:hover,
  .history-item:hover,
  .setting-card:hover,
  .settings-panel:hover,
  .equip-slot:hover,
  .inventory-card:hover,
  .build-card:hover,
  .upgrade-card:hover,
  .chest-card:hover,
  .reward-card:hover,
  .mode-card:hover{
    transform:translateY(-3px);
    border-color:rgba(110,231,255,.18);
    box-shadow:0 0 0 1px rgba(110,231,255,.10), 0 20px 42px rgba(0,0,0,.28);
  }
  .pro-sections-bar .icon-btn:hover,
  .lang-switch:hover,
  .theme-pill:hover,
  .btn-ghost:hover,
  .repair-fab:hover,
  .chip:hover{
    transform:translateY(-2px);
    border-color:rgba(110,231,255,.18);
    box-shadow:0 12px 26px rgba(0,0,0,.24), 0 0 0 1px rgba(110,231,255,.10);
  }
  .btn-primary:hover{
    box-shadow:0 16px 30px rgba(96,165,250,.22), 0 0 0 1px rgba(110,231,255,.16);
  }
  .hud{
    inset:16px 16px auto 16px;
    align-items:flex-start;
  }
  .hud-left,.hud-right{align-items:flex-start}
  .hud-pill,
  .boss-box{
    background:linear-gradient(180deg,rgba(7,14,24,.86),rgba(7,14,24,.68));
    backdrop-filter:blur(14px);
  }
  .hud-pill:hover,
  .boss-box:hover{
    transform:translateY(-2px);
    box-shadow:0 12px 28px rgba(0,0,0,.26), 0 0 0 1px rgba(110,231,255,.12);
  }
  .hud-pill strong{letter-spacing:-.03em}
  .top-actions .icon-btn.active-section{
    box-shadow:0 14px 28px rgba(0,0,0,.22), 0 0 0 1px rgba(110,231,255,.14);
  }
  [data-tooltip]{position:relative}
  [data-tooltip]::before,
  [data-tooltip]::after{
    position:absolute;
    opacity:0;
    pointer-events:none;
    transition:opacity .16s ease, transform .16s ease;
    z-index:80;
  }
  [data-tooltip]::before{
    content:attr(data-tooltip);
    left:50%;
    bottom:calc(100% + 12px);
    transform:translate(-50%, 6px);
    min-width:max-content;
    max-width:240px;
    padding:10px 12px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.1);
    background:rgba(7,14,24,.96);
    color:var(--text);
    font-size:12px;
    font-weight:700;
    line-height:1.35;
    box-shadow:0 12px 28px rgba(0,0,0,.3);
    white-space:normal;
  }
  [data-tooltip]::after{
    content:"";
    left:50%;
    bottom:calc(100% + 6px);
    width:10px;
    height:10px;
    border-left:1px solid rgba(255,255,255,.1);
    border-bottom:1px solid rgba(255,255,255,.1);
    background:rgba(7,14,24,.96);
    transform:translateX(-50%) rotate(-45deg);
  }
  [data-tooltip]:hover::before,
  [data-tooltip]:hover::after,
  [data-tooltip]:focus-visible::before,
  [data-tooltip]:focus-visible::after{
    opacity:1;
    transform:translate(-50%, 0);
  }
  [data-tooltip]:focus-visible,
  .btn:focus-visible,
  .theme-pill:focus-visible,
  .lang-btn:focus-visible,
  .equip-slot:focus-visible,
  .inventory-card:focus-visible,
  .build-card:focus-visible,
  .mode-card:focus-visible,
  .mini-zoom-btn:focus-visible{
    outline:2px solid rgba(110,231,255,.6);
    outline-offset:2px;
  }
  .sidebar{align-content:start}
  .side-card{overflow:visible}
  .compare-box{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.02))}
}
