:root{
  --bg0:#0b0c2d;
  --bg1:#151447;
  --bg-glow-1:rgba(255,189,255,.16);
  --bg-glow-2:rgba(180,210,255,.14);
  --bg-glow-3:rgba(132,180,255,.12);
  --canvas-bg:#050912;
  --canvas-opacity:.9;
  --panel:rgba(24,24,68,.86);
  --panel2:rgba(34,28,82,.76);
  --panel-soft:rgba(255,255,255,.09);
  --panel-strong:rgba(255,255,255,.16);
  --surface-faint:rgba(255,255,255,.04);
  --surface-border:rgba(255,255,255,.12);
  --text:rgba(251,249,255,.96);
  --muted:rgba(235,232,255,.82);
  --accent:rgba(158,222,255,.97);
  --accent-strong:rgba(212,245,255,.98);
  --accent2:rgba(202,168,255,.96);
  --bubble:rgba(255,185,245,.85);
  --deep-glow:rgba(132,193,255,.32);
  --danger:rgba(255,110,110,.95);
  --ok:rgba(120,255,180,.95);
  --title-color:#f9fbff;
  --title-glow:rgba(200,230,255,.55);
  --button-bg-start:rgba(255,255,255,.16);
  --button-bg-end:rgba(255,255,255,.06);
  --button-hover-start:rgba(255,255,255,.22);
  --button-hover-end:rgba(255,255,255,.1);
  --button-primary-start:rgba(180,230,255,.46);
  --button-primary-end:rgba(140,210,255,.22);
  --button-primary-hover-start:rgba(205,240,255,.7);
  --button-primary-hover-end:rgba(150,210,255,.28);
  --focus-ring:rgba(180,230,255,.9);
  --sparkle-glow:rgba(255,255,255,.88);
  --sparkle-opacity:1;
  --scrollbar-track:rgba(255,255,255,.06);
  --scrollbar-thumb-start:rgba(170,220,255,.75);
  --scrollbar-thumb-end:rgba(150,180,255,.62);
  --panel-blur:16px;
  --parallax-opacity:.9;
  --glass:backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}

html,body{
  height:100%;margin:0;overflow:hidden;
  background:
    radial-gradient(circle at 14% 12%,var(--bg-glow-1),transparent 28%),
    radial-gradient(circle at 78% 10%,var(--bg-glow-2),transparent 30%),
    radial-gradient(circle at 68% 68%,var(--bg-glow-3),transparent 32%),
    linear-gradient(180deg,var(--bg0),var(--bg1));
  font-family:"Baloo 2","Inter",-apple-system,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  letter-spacing:.1px;
}

#wrap{position:fixed;inset:0}
canvas{position:absolute;inset:0;width:100%;height:100%;display:block;background:var(--canvas-bg);opacity:var(--canvas-opacity)}
.screen{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;padding:16px;overflow:hidden}
.panel{
  pointer-events:auto;width:min(1100px,calc(100vw - 28px));
  padding:18px;border-radius:24px;position:relative;
  background:linear-gradient(160deg,var(--panel),var(--panel2));
  border:1px solid var(--surface-border);
  box-shadow:0 20px 70px rgba(0,0,0,.58),0 0 70px var(--deep-glow);
  backdrop-filter:blur(var(--panel-blur));-webkit-backdrop-filter:blur(var(--panel-blur));
  z-index:1;
}
.panel.menu-panel{
  background:none;
  border:none;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  position:relative;
  display:flex;
  flex-direction:column;
  max-height:calc(100vh - 32px);
  min-height:0;
  overflow:hidden;
}
.menu-parallax{
  position:absolute;inset:-12% -10%;
  pointer-events:none;
  overflow:hidden;
  z-index:0;
  filter:saturate(1.04);
  opacity:var(--parallax-opacity);
}
.menu-parallax-layer{
  position:absolute;inset:0;
  transform:translate3d(0,0,0) rotate(0deg);
  transition:transform .32s ease;
  will-change:transform;
}
.menu-parallax-stars{
  background:
    radial-gradient(1.5px 1.5px at 12% 20%,var(--accent-strong),transparent 60%),
    radial-gradient(1.5px 1.5px at 80% 12%,var(--accent),transparent 58%),
    radial-gradient(1.5px 1.5px at 50% 64%,var(--bubble),transparent 55%),
    radial-gradient(2px 2px at 18% 78%,var(--accent-strong),transparent 55%),
    radial-gradient(2px 2px at 70% 70%,var(--bubble),transparent 58%),
    radial-gradient(120% 120% at 50% 50%,var(--surface-faint),transparent 60%);
  opacity:.9;
  filter:drop-shadow(0 0 10px var(--deep-glow));
}
.menu-parallax-dust{
  background:
    radial-gradient(60% 50% at 20% 30%,var(--accent),transparent),
    radial-gradient(70% 60% at 72% 24%,var(--bubble),transparent),
    radial-gradient(50% 40% at 28% 80%,var(--deep-glow),transparent);
  mix-blend-mode:screen;
  opacity:.7;
  filter:blur(3px);
}
.menu-parallax-glow{
  background:
    radial-gradient(36% 32% at 18% 40%,var(--accent),transparent),
    radial-gradient(32% 30% at 72% 26%,var(--bubble),transparent),
    radial-gradient(45% 50% at 66% 76%,var(--deep-glow),transparent),
    radial-gradient(48% 44% at 36% 70%,var(--accent-strong),transparent);
  opacity:.8;
  filter:blur(18px) drop-shadow(0 20px 40px rgba(0,0,0,.2));
}
.menu-offline-status{
  position:absolute;
  top:12px;
  left:18px;
  max-width:380px;
  font-size:11px;
  line-height:1.3;
  color:rgba(255,180,180,.92);
  text-shadow:0 1px 6px rgba(0,0,0,.45);
  z-index:2;
  pointer-events:none;
}

.menu-header{display:flex;flex-direction:column;gap:8px;padding:14px 18px 10px;align-items:center;text-align:center}
.menu-title-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;justify-content:center;gap:10px;width:100%}
.menu-title-shell{display:flex;align-items:center;justify-content:center}
.menu-back-slot{display:flex;align-items:center;justify-content:center;min-width:56px}
.menu-back-slot .menu-back{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  min-width:48px;
  border-radius:14px;
  border:1px solid var(--surface-border);
  background:linear-gradient(180deg,var(--button-bg-start),var(--button-bg-end));
  box-shadow:0 10px 26px rgba(0,0,0,.32),0 0 0 1px var(--surface-faint);
  font-size:22px;
  font-weight:900;
  letter-spacing:.25px;
  line-height:1;
}
.menu-title-row .menu-back[hidden]{display:none}
.menu-back-placeholder{visibility:hidden}
.menu-back-ghost{
  width:48px;
  height:48px;
}
.title{
  font-weight:900;letter-spacing:.8px;line-height:1.1;
  font-size:clamp(48px,6.2vw,92px);margin:0;
  color:var(--title-color);padding:0;
  max-width:100%;overflow-wrap:break-word;
  text-shadow:0 12px 32px rgba(0,0,0,.35),0 0 18px var(--title-glow),0 0 36px var(--deep-glow);
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.18));
  text-align:center;
  display:inline-flex;align-items:center;justify-content:center;
}
.title::first-letter{font-size:1.04em}
.title-cloud{position:relative;display:inline-block;padding:0;border-radius:30px;background:none;box-shadow:none}
.title-cloud::after{content:none}
.title.danger{color:var(--danger)}
.sub{color:var(--muted);font-size:15px;line-height:1.55;margin:0;max-width:840px;text-shadow:0 6px 14px rgba(0,0,0,.25)}

.menu-shell{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:14px;
  align-items:start;
  padding:8px;
  padding-right:14px;
  min-height:0;
  flex:1 1 auto;
  overflow-y:auto;
  position:relative;
}
.menu-shell::-webkit-scrollbar{width:12px}
.menu-shell::-webkit-scrollbar-track{
  background:var(--scrollbar-track);
  border-radius:999px;
}
.menu-shell::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--scrollbar-thumb-start),var(--scrollbar-thumb-end));
  border-radius:999px;
  border:2px solid rgba(0,0,0,.25);
  box-shadow:0 4px 10px rgba(0,0,0,.35);
}
.menu-shell::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,var(--scrollbar-thumb-start),var(--scrollbar-thumb-end));
}
.menu-shell{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-start) var(--scrollbar-track)}
.menu-shell[data-view="settings"],.menu-shell[data-view="achievements"]{grid-template-columns:1fr}
.menu-shell[data-view="settings"] .side-stack,.menu-shell[data-view="achievements"] .side-stack{display:none}
@media (max-width: 900px){ .menu-shell{grid-template-columns:1fr} }

.panel-main{grid-template-columns:1fr;gap:14px}
.panel-settings{grid-template-columns:1fr;gap:14px}

.card{
  border-radius:18px;border:1px solid var(--panel-strong);background:var(--surface-faint);
  padding:14px 14px 12px;box-shadow:0 10px 34px rgba(0,0,0,.26);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.card-soft{background:var(--surface-faint);border-color:var(--surface-border)}

.row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-start}
.row.space-between{justify-content:space-between}
.row.actions-row{margin-top:14px}
.top-actions{gap:12px;justify-content:center}
.card-actions{display:flex;justify-content:flex-start;gap:10px;margin-top:8px}
.card-actions.center{justify-content:center}
.card-actions.callout-stack{flex-direction:column;align-items:center;gap:6px}
.card-actions .card-nav{min-width:180px}
.card-actions.center .cta-btn,
.card-actions.center .card-nav{
  flex:1 1 0;
  min-width:0;
  width:100%;
}
.howto-card .card-actions .settings-nav{
  flex:1 1 auto;
  width:100%;
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
  align-self:center;
  flex-direction:column;
  gap:4px;
  text-align:center;
  white-space:normal;
}
.howto-card .howto-actions{
  flex-wrap:wrap;
}

button,.card-nav{
  appearance:none;border:1px solid var(--surface-border);background:linear-gradient(180deg,var(--button-bg-start),var(--button-bg-end));
  color:var(--text);padding:12px 16px;border-radius:16px;font-weight:900;font-size:16px;cursor:pointer;
  box-shadow:0 12px 28px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.08);
  transition:transform .08s ease,box-shadow .18s ease,background .16s ease,translate .08s ease,filter .14s ease;
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none;
}
button:hover,.card-nav:hover{background:linear-gradient(180deg,var(--button-hover-start),var(--button-hover-end));transform:translateY(-1px);box-shadow:0 16px 32px rgba(0,0,0,.32),0 0 0 1px rgba(255,255,255,.14);filter:drop-shadow(0 8px 18px rgba(255,200,255,.18))}
button:active,.card-nav:active{transform:translateY(0);translate:0 1px}
button.primary,.card-nav.primary{border-color:var(--accent-strong);background:linear-gradient(180deg,var(--button-primary-start),var(--button-primary-end));color:#0d1a27;text-shadow:0 1px 0 rgba(255,255,255,.4)}
button.primary:hover,.card-nav.primary:hover{background:linear-gradient(180deg,var(--button-primary-hover-start),var(--button-primary-hover-end))}
button[disabled]{opacity:.58;cursor:not-allowed;transform:none;translate:0}
button:focus-visible,.card-nav:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--focus-ring);outline-offset:2px;box-shadow:0 0 0 4px rgba(180,230,255,.2)
}
.cta-btn{padding:14px 26px;min-width:160px;font-size:17px;letter-spacing:.3px}
.cta-btn.wide{min-width:190px}
.cta-btn.small{padding:10px 16px;min-width:0;font-size:14px;letter-spacing:.2px}
.cta-btn.sparkle{position:relative;overflow:hidden;isolation:isolate;box-shadow:0 14px 32px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.12)}
.cta-btn.sparkle::after{
  content:"";position:absolute;inset:-40% -30%;pointer-events:none;
  background:
    radial-gradient(10px 10px at 20% 30%,var(--sparkle-glow),transparent 55%),
    radial-gradient(8px 8px at 60% 40%,var(--accent-strong),transparent 60%),
    radial-gradient(12px 12px at 80% 70%,var(--bubble),transparent 55%),
    radial-gradient(9px 9px at 30% 80%,var(--accent),transparent 60%);
  opacity:calc(var(--sparkle-opacity) * 0);transform:translateY(10px);
  transition:opacity .16s ease,transform .18s ease;
  mix-blend-mode:screen;
  animation:sparkle-drift 2.2s linear infinite;
}
.cta-btn.sparkle:hover::after{opacity:var(--sparkle-opacity);transform:translateY(0)}

.pill{display:inline-flex;gap:8px;align-items:center;font-size:13px;color:var(--muted);
  border:1px solid var(--surface-border);background:var(--panel-soft);padding:8px 12px;border-radius:999px;box-shadow:0 10px 22px rgba(0,0,0,.28)}
.dot{width:9px;height:9px;border-radius:999px;background:rgba(255,200,120,.95);box-shadow:0 0 14px rgba(255,200,120,.35)}
.pill.ok .dot{background:var(--ok);box-shadow:0 0 14px rgba(120,255,180,.35)}
.pill.bad .dot{background:var(--danger);box-shadow:0 0 14px rgba(255,110,110,.35)}
.pill.neutral .dot{background:rgba(170,170,170,.9);box-shadow:0 0 14px rgba(170,170,170,.25)}

.stats{margin-top:8px;padding-top:10px;border-top:1px solid var(--surface-border);color:var(--muted);font-size:13.8px;line-height:1.55}
.kbd{display:inline-block;padding:2px 7px;border-radius:9px;border:1px solid var(--surface-border);
  background:var(--panel-soft);color:var(--text);font-weight:900;font-size:13px}
.hidden{display:none!important}

.field{display:flex;flex-direction:column;gap:6px}
.lbl{font-size:12px;color:var(--muted);font-weight:800;letter-spacing:.35px;text-transform:uppercase}
input[type="text"], select{
  appearance:none;width:100%;padding:11px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.25);color:rgba(255,255,255,.92);font-weight:800;outline:none;
  box-shadow:inset 0 2px 6px rgba(0,0,0,.26);
}
input[type="text"]::placeholder{color:rgba(255,255,255,.45)}
.skill-behavior-matrix{display:flex;flex-direction:column;gap:10px}
.skill-behavior-row{
  display:grid;
  grid-template-columns:minmax(170px,.9fr) repeat(2,minmax(220px,1fr));
  gap:10px;
  align-items:stretch;
}
.skill-behavior-header{align-items:end}
.skill-row-label{
  font-size:13px;
  color:rgba(255,255,255,.7);
  font-weight:900;
  letter-spacing:.35px;
  text-transform:uppercase;
  padding:10px 2px;
}
.skill-row-label.spacer{padding:0}
.skill-column-label{
  font-weight:900;
  letter-spacing:.35px;
  text-transform:uppercase;
  font-size:13px;
  color:rgba(255,255,255,.9);
  padding:10px 12px;
  border-radius:12px;
  text-align:center;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 10px 22px rgba(0,0,0,.22);
}
.skill-behavior-header .skill-column-label{background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06))}
.skill-option{
  --skill-accent:var(--accent);
  --skill-accent-strong:var(--accent-strong);
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  padding:12px 14px;
  border-radius:14px;
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-rows:auto auto;
  gap:10px;
  align-items:start;
  color:var(--text);
  cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 10px 22px rgba(0,0,0,.22);
  transition:transform .08s ease,box-shadow .2s ease,background .14s ease,border-color .18s ease;
}
.skill-option.behavior-destroy{
  --skill-accent:rgba(255,185,155,.94);
  --skill-accent-strong:rgba(255,215,185,.98);
}
.skill-option.behavior-explosion{
  --skill-accent:rgba(255,195,140,.94);
  --skill-accent-strong:rgba(255,224,170,.98);
}
.skill-option.behavior-slow{
  --skill-accent:rgba(170,210,255,.90);
  --skill-accent-strong:rgba(210,235,255,.98);
}
.skill-option.behavior-normal{
  --skill-accent:rgba(195,200,255,.94);
  --skill-accent-strong:rgba(230,236,255,.98);
}
.skill-option.behavior-explode{
  --skill-accent:rgba(255,170,160,.94);
  --skill-accent-strong:rgba(255,205,195,.98);
}
.skill-option.behavior-short{
  --skill-accent:rgba(160,230,210,.94);
  --skill-accent-strong:rgba(200,250,235,.98);
}
.skill-option.behavior-long{
  --skill-accent:rgba(200,180,255,.94);
  --skill-accent-strong:rgba(225,210,255,.98);
}
.skill-option:hover{
  background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 14px 26px rgba(0,0,0,.26);
  transform:translateY(-1px);
}
.skill-option.selected{
  border-color:var(--skill-accent);
  box-shadow:0 0 0 2px var(--skill-accent),0 14px 30px rgba(0,0,0,.26);
}
.skill-option-icon{
  width:56px;
  height:56px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.skill-option-icon{grid-row:1 / span 2}
.skill-option-text{display:flex;flex-direction:column;gap:2px;grid-column:2;grid-row:1}
.skill-option-title{font-weight:900;letter-spacing:.25px;font-size:16px}
.skill-option-sub{color:var(--muted);font-size:13px;line-height:1.3}
.skill-option-meta{grid-column:2;grid-row:2;display:flex;align-items:center;gap:8px;margin-top:2px;font-size:12.5px;color:rgba(255,255,255,.75)}
.skill-option-meta-label{
  padding:4px 8px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.08);
  font-weight:850;
  letter-spacing:.2px;
  font-size:11.5px;
  text-transform:uppercase;
}
.skill-option-meta-value{font-weight:900;color:var(--text)}
.skill-option-meta-value::after{content:"";display:block;height:0}
.skill-glyph{width:46px;height:46px}
.skill-glyph-wall{fill:rgba(255,255,255,.12);stroke:rgba(255,255,255,.18);stroke-width:2}
.skill-glyph-path{fill:none;stroke:var(--skill-accent);stroke-width:3.2;stroke-linecap:round;stroke-linejoin:round}
.skill-glyph-accent{fill:var(--skill-accent-strong);stroke:var(--skill-accent-strong);stroke-width:1.6}
.skill-glyph-node{fill:var(--skill-accent-strong)}
.skill-glyph-wave{fill:none;stroke:var(--skill-accent-strong);stroke-width:2.4;stroke-linecap:round}
.skill-glyph-fill{fill:var(--skill-accent);stroke:var(--skill-accent-strong);stroke-width:2.4}
.skill-glyph-crack{fill:none;stroke:var(--skill-accent-strong);stroke-width:2.4;stroke-linecap:round}
.skill-behavior-row .skill-option{height:100%}
.skill-behavior-row .skill-option .skill-option-meta{margin-top:4px}
.skill-behavior-row .skill-option .skill-option-sub{line-height:1.4}
@media (max-width: 960px){
  .skill-behavior-row{grid-template-columns:1fr}
  .skill-behavior-header{display:none}
  .skill-row-label{padding:4px 0}
}
.minirow{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.seed-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(120px,auto);
  align-items:center;
  gap:10px;
}
.seed-row input{width:100%}
.seed-row button{height:100%;min-height:44px;min-width:120px;padding:12px 16px;white-space:nowrap}
@media (max-width: 600px){
  .seed-row{grid-template-columns:1fr}
  .seed-row button{width:100%;justify-self:start}
}
.user-row{flex-wrap:nowrap}
.user-row input{flex:1;min-width:0}
.user-row button{white-space:nowrap}
.hint{font-size:12.5px;color:rgba(255,255,255,.66);line-height:1.35}
.nav-callout{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:0;
  border-radius:0;
  border:none;
  background:none;
  color:rgba(255,255,255,.9);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.3px;
  text-shadow:0 1px 3px rgba(8,18,36,.45);
  animation:navBubbleFloat 3.6s ease-in-out infinite;
  white-space:nowrap;
}
.settings-nav-subtext{
  display:block;
  font-size:12px;
  font-weight:700;
  text-transform:none;
  letter-spacing:.2px;
  color:rgba(255,255,255,.78);
  white-space:normal;
}
.theme-callout{
  position:fixed;
  right:92px;
  bottom:78px;
  z-index:6;
  pointer-events:none;
  max-width:none;
  text-align:center;
}
.menu-shell:not([data-view="main"]) .theme-callout{display:none}
.social-dock{
  position:fixed;
  left:16px;
  bottom:16px;
  z-index:6;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
  pointer-events:auto;
}
.social-item{position:relative}
.social-btn{
  min-width:120px;
  font-weight:900;
  letter-spacing:.4px;
}
.social-popover{
  position:absolute;
  left:0;
  bottom:calc(100% + 10px);
  background:linear-gradient(160deg,rgba(255,210,252,.2),rgba(170,210,255,.22));
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  padding:12px 14px;
  box-shadow:0 14px 34px rgba(0,0,0,.38),0 0 18px rgba(200,230,255,.2);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--text);
  text-align:left;
  z-index:10;
}
.social-popover::after{
  content:"";
  position:absolute;
  left:18px;
  bottom:-8px;
  width:16px;
  height:16px;
  background:linear-gradient(160deg,rgba(255,210,252,.2),rgba(170,210,255,.22));
  border-right:1px solid rgba(255,255,255,.18);
  border-bottom:1px solid rgba(255,255,255,.18);
  transform:rotate(45deg);
  border-bottom-right-radius:4px;
}
.discord-popover{padding:8px}
.discord-widget{border:0;border-radius:16px;display:block}
.donate-popover{max-width:460px;width:460px}
.donate-copy{
  margin:0 0 6px;
  font-size:13px;
  font-weight:800;
  line-height:1.4;
  text-shadow:0 1px 8px rgba(80,40,120,.25);
}
.donate-venmo{
  margin:0;
  font-size:13px;
  font-weight:900;
  color:var(--accent-strong);
  text-shadow:0 1px 8px rgba(120,200,255,.4);
}
.support-popover{max-width:440px;width:440px}
.support-copy,
.support-reward,
.support-provider{
  margin:0 0 6px;
  font-size:13px;
  font-weight:800;
  line-height:1.4;
  text-shadow:0 1px 8px rgba(80,40,120,.25);
}
.support-reward{font-weight:900;color:var(--accent-strong)}
.support-provider{
  margin:0;
  font-size:12px;
  font-weight:700;
  color:rgba(200,230,255,.8);
  text-shadow:0 1px 8px rgba(80,120,180,.25);
}
.trail-preview-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;filter:saturate(1.08) drop-shadow(0 12px 28px rgba(0,0,0,.32))}
.trail-preview-glow{
  position:absolute;inset:-18% -12%;pointer-events:none;
  background:
    radial-gradient(50% 40% at 20% 30%,rgba(140,210,255,.26),transparent),
    radial-gradient(55% 45% at 70% 78%,rgba(255,180,245,.18),transparent);
  filter:blur(26px);opacity:.7
}
.trail-preview-overlay{
  position:absolute;inset:-6% -10%;z-index:0;overflow:hidden;
  pointer-events:none;border-radius:0;
  background:linear-gradient(180deg,rgba(6,10,22,.42),rgba(6,8,18,.20))
}
.trail-preview-overlay .trail-preview-glow{z-index:0}
.trail-preview-overlay .trail-preview-canvas{z-index:1}
.trail-field-launcher{position:relative}
.hint.good{color:rgba(120,255,160,.80)}
.hint.bad{color:rgba(255,110,110,.85)}
.hint.warn{color:rgba(255,210,120,.88)}
.hint.space-top{margin-top:10px}
.section-title{font-weight:900;letter-spacing:.4px;font-size:15px;margin-bottom:6px;color:#eef6ff;text-transform:uppercase;letter-spacing:.6px}
.section-title.small{font-size:14px;margin:0}
.soft-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);margin:10px 0}

.hs-card{position:relative;overflow:hidden}
.hs-card::before{
  content:"";position:absolute;inset:-20% 20% auto -10%;height:160px;
  background:radial-gradient(circle at 20% 60%,rgba(255,255,255,.08),transparent 40%),
             radial-gradient(circle at 60% 30%,rgba(180,220,255,.1),transparent 45%);
  filter:blur(16px);opacity:.9;pointer-events:none;
}
.hsWrap{position:relative}
.hsTableWrap{
  max-height:none;
  overflow-y:auto;
  padding-right:4px;
  margin-top:2px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.04));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.hsTableWrap::-webkit-scrollbar{width:10px}
.hsTableWrap::-webkit-scrollbar-track{
  background:rgba(255,255,255,.04);
  border-radius:999px;
}
.hsTableWrap::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(170,220,255,.75),rgba(150,180,255,.62));
  border-radius:999px;
  border:2px solid rgba(0,0,0,.25);
  box-shadow:0 4px 10px rgba(0,0,0,.35);
}
.hsTableWrap::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(200,235,255,.9),rgba(170,205,255,.72));
}
.hsTableWrap{scrollbar-width:thin;scrollbar-color:rgba(180,220,255,.8) rgba(255,255,255,.06)}
.hsTable{width:100%;border-collapse:collapse;font-size:13.5px}
.hsTable th,.hsTable td{padding:8px 8px;border-bottom:1px solid rgba(255,255,255,.10);text-align:left}
.hsTable th{color:rgba(255,255,255,.78);font-weight:950}
.hs-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.hs-actions .btn{padding:4px 10px;font-size:12px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}

.bindList{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.bindRow{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;
  padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.bindName{font-weight:900;letter-spacing:.2px}
.bindKey{justify-self:end}
.bindBtn{padding:8px 11px;border-radius:10px;font-size:13px}
.bindRow.listen{border-color:rgba(160,220,255,.50);box-shadow:0 0 0 3px rgba(160,220,255,.16) inset}

.tab-toggle{display:flex;gap:10px;align-items:center;justify-content:center;padding:8px 10px;margin-top:4px}
.tab-toggle label{
  padding:12px 18px;border-radius:14px;font-weight:900;cursor:pointer;border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.06));color:var(--muted);transition:all .14s ease;box-shadow:0 10px 22px rgba(0,0,0,.25)
}
.tab-pill{min-width:150px;text-align:center;letter-spacing:.35px}
.tab-toggle label:hover{color:var(--text);border-color:rgba(255,255,255,.16);transform:translateY(-1px)}
.tab-radio{position:absolute;opacity:0;pointer-events:none}
#viewMain:checked ~ .menu-shell label[for="viewMain"]{background:linear-gradient(180deg,rgba(200,235,255,.5),rgba(140,200,255,.2));color:#0c1826;border-color:rgba(200,235,255,.8);box-shadow:0 10px 26px rgba(0,0,0,.32)}
#viewSettings:checked ~ .menu-shell label[for="viewSettings"]{background:linear-gradient(180deg,rgba(255,198,255,.52),rgba(180,150,255,.26));color:#0c1826;border-color:rgba(255,220,255,.85);box-shadow:0 10px 26px rgba(140,80,200,.32)}
#viewAchievements:checked ~ .menu-shell label[for="viewAchievements"]{background:linear-gradient(180deg,rgba(150,255,210,.52),rgba(120,220,190,.24));color:#0c1826;border-color:rgba(150,255,210,.85);box-shadow:0 10px 26px rgba(0,0,0,.32)}

.view-area{position:relative}
.tab-panel{display:none;animation:floatIn .28s ease;min-height:280px}
#viewMain:checked ~ .menu-shell .view-area .panel-main{display:grid}
#viewSettings:checked ~ .menu-shell .view-area .panel-settings{display:grid}
#viewAchievements:checked ~ .menu-shell .view-area .panel-achievements{display:grid}

.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.settings-grid{
  grid-template-columns:repeat(2,minmax(260px,1fr));
  align-items:start;
  grid-auto-flow:row;
}
.settings-grid .settings-feature{
  grid-column:span 2;
}
@media (max-width: 960px){
  .settings-grid{grid-template-columns:1fr}
  .settings-grid .settings-feature{grid-column:span 1}
  .settings-grid .settings-secondary{grid-column:span 1}
}
.settings-grid .settings-secondary{
  grid-column:span 2;
  background:var(--surface-faint);
  border-color:var(--surface-border);
  box-shadow:0 10px 22px rgba(0,0,0,.22);
}
.settings-grid .settings-utility{
  background:var(--surface-faint);
  border-color:var(--surface-border);
  box-shadow:0 8px 18px rgba(0,0,0,.2);
}
.settings-grid .settings-utility .section-title{
  color:var(--muted);
  letter-spacing:.5px;
}
.settings-grid .settings-utility .hint{
  color:var(--muted);
}
.text-custom-panel{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--surface-border);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.text-custom-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
}
.text-custom-field{gap:6px}
.text-custom-label{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.text-custom-value{
  font-size:12px;
  color:var(--muted);
  min-width:34px;
  text-align:right;
}
.text-custom-toggle{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12.5px;
  color:var(--text);
}
.text-color-input{
  height:32px;
  padding:0 4px;
  border-radius:8px;
  border:1px solid var(--surface-border);
  background:rgba(8,12,20,.55);
}
.theme-overlay{
  position:fixed;
  inset:0;
  z-index:90;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(6,12,24,.72);
  backdrop-filter:blur(4px);
}
.theme-overlay-panel{
  background:linear-gradient(180deg,rgba(30,41,59,.95),rgba(15,23,42,.95));
  border:1px solid var(--surface-border);
  border-radius:16px;
  padding:18px;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
  width:min(980px,92vw);
  max-height:82vh;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.theme-overlay-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.theme-overlay-close{
  background:rgba(255,255,255,.06);
  border:1px solid var(--surface-border);
  color:var(--text);
  border-radius:10px;
  padding:6px 10px;
  font-weight:800;
  cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease;
}
.theme-overlay-close:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.35)}
.theme-launcher{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:6;
  padding:12px 16px;
  font-size:20px;
  line-height:1;
}
.menu-shell[data-view="main"] .theme-launcher{display:inline-flex}
.menu-shell:not([data-view="main"]) .theme-launcher{display:none}
.theme-toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
}
.theme-select-wrap{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:200px;
}
.theme-select{
  appearance:none;
  border-radius:12px;
  padding:10px 12px;
  border:1px solid var(--surface-border);
  background:var(--surface-faint);
  color:var(--text);
  font-weight:800;
}
.theme-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.theme-actions button{
  padding:10px 14px;
  border-radius:12px;
  font-size:14px;
}
.theme-subtitle{
  font-weight:800;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.3px;
  font-size:12px;
}
.theme-palette-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.theme-palette{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  background:var(--panel-soft);
  color:var(--text);
  font-size:12px;
  font-weight:800;
}
.theme-editor{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.theme-group{
  border-radius:14px;
  border:1px solid var(--surface-border);
  background:var(--panel-soft);
  padding:12px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.theme-group-title{
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.4px;
  font-size:12px;
  margin-bottom:8px;
  color:var(--accent-strong);
}
.theme-group-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:10px;
}
.theme-control{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  padding:10px;
  border-radius:12px;
  border:1px solid var(--surface-border);
  background:var(--surface-faint);
}
.theme-control-label{
  display:flex;
  align-items:center;
  gap:6px;
  font-weight:800;
  color:var(--text);
  font-size:12px;
}
.theme-info{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  background:var(--panel);
  color:var(--accent-strong);
  font-size:11px;
  font-weight:900;
  cursor:help;
  padding:0;
}
.theme-info::before,
.theme-info::after{
  position:absolute;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
}
.theme-info::before{
  content:"";
  bottom:calc(100% + 2px);
  left:50%;
  transform:translateX(-50%) translateY(4px);
  border:6px solid transparent;
  border-top-color:rgba(0,0,0,.85);
}
.theme-info::after{
  content:attr(data-tooltip);
  bottom:calc(100% + 10px);
  left:50%;
  transform:translateX(-50%) translateY(4px);
  max-width:220px;
  background:rgba(0,0,0,.85);
  color:var(--text);
  font-size:11px;
  font-weight:700;
  line-height:1.3;
  padding:6px 8px;
  border-radius:8px;
  white-space:normal;
  box-shadow:0 10px 24px rgba(0,0,0,.35);
  z-index:5;
}
.theme-info:hover::before,
.theme-info:hover::after,
.theme-info:focus-visible::before,
.theme-info:focus-visible::after{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
.theme-control input[type="color"]{
  width:52px;
  height:34px;
  border-radius:10px;
  border:1px solid var(--surface-border);
  background:transparent;
  padding:0;
}
.theme-control input[type="range"]{
  grid-column:1 / -1;
}
.theme-control input[type="checkbox"]{
  width:20px;
  height:20px;
  accent-color:var(--accent);
}
.theme-control-output{
  font-weight:800;
  color:var(--muted);
  font-size:12px;
  text-align:right;
}
.theme-export-field{
  width:100%;
  border-radius:12px;
  border:1px solid var(--surface-border);
  background:rgba(0,0,0,.28);
  color:var(--text);
  padding:10px 12px;
  font-weight:700;
  font-size:12px;
  resize:vertical;
  min-height:80px;
}
.theme-mode-group{
  display:flex;
  flex-direction:column;
  gap:10px;
  border-radius:14px;
  border:1px solid var(--surface-border);
  background:var(--panel-soft);
  padding:12px;
}
.theme-mode-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.theme-mode-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.theme-mode-title{
  font-weight:800;
  font-size:13px;
  color:var(--text);
}
.theme-mode-hint{
  font-size:12px;
  color:var(--muted);
}
.theme-mode-toggle{
  width:20px;
  height:20px;
  accent-color:var(--accent);
}
.info-card{border-radius:14px;background:var(--surface-faint);border:1px solid var(--surface-border);padding:12px 12px 10px;box-shadow:0 12px 26px rgba(0,0,0,.24)}
.info-card .lbl{font-size:12.5px}
.howto{font-size:13.5px;line-height:1.55;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--panel-soft);color:var(--text);font-weight:800;font-size:12px;border:1px solid var(--surface-border)}
.pills-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.pills-row.tight{margin-top:6px}
.compact{font-size:12.5px;color:var(--muted)}
.spacer-sm{height:6px}
.accent-link{color:var(--accent-strong);text-decoration:none;font-weight:900;font-size:13px}
.volume-card{padding:16px 14px 14px}
.volume-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.slider-row{display:flex;flex-direction:column;gap:9px;padding:14px;border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 12px 26px rgba(0,0,0,.2)}
input[type="range"]{
  -webkit-appearance:none;appearance:none;width:100%;height:14px;border-radius:999px;background:linear-gradient(90deg,rgba(160,220,255,.9),rgba(167,139,255,.9));
  box-shadow:inset 0 1px 3px rgba(0,0,0,.45);outline:none;border:1px solid rgba(255,255,255,.08)
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:#fdfdff;border:2px solid rgba(160,220,255,.9);box-shadow:0 8px 14px rgba(0,0,0,.26)
}
input[type="range"]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;background:#fdfdff;border:2px solid rgba(160,220,255,.9);box-shadow:0 8px 14px rgba(0,0,0,.26)
}
.mute-row{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--text);padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 10px 20px rgba(0,0,0,.16)}

.howto-card{display:grid;grid-template-columns:1fr;gap:10px;align-items:center;text-align:center;padding:16px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(180,180,255,.08));border:1px solid rgba(255,255,255,.12)}
.howto-card .section-title{font-size:16px;letter-spacing:.8px}
.howto-header{display:flex;align-items:center;justify-content:center;gap:10px}
.howto-heading{font-weight:900;letter-spacing:.8px;color:var(--text);text-transform:uppercase;font-size:13px}
.howto-list{list-style:disc;margin:0;padding:0 0 0 18px;display:inline-flex;flex-direction:column;gap:6px;text-align:left}
.howto-list li{color:var(--text);font-weight:800;text-shadow:0 6px 12px rgba(0,0,0,.24)}
.howto-list li::marker{color:var(--bubble)}

.light-aurora{position:absolute;inset:-12% -8%;background:
  radial-gradient(60% 50% at 20% 30%,rgba(120,190,255,.18),transparent),
  radial-gradient(50% 40% at 80% 10%,rgba(210,160,255,.2),transparent),
  radial-gradient(60% 50% at 70% 80%,rgba(255,170,220,.14),transparent);
  filter:blur(30px);opacity:.82;pointer-events:none;z-index:1}
.content-layer{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1 1 auto;
  min-height:0;
  overflow:hidden;
}
.menu-body{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1 1 auto;
  min-height:0;
  overflow:hidden;
}

@keyframes floatIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes navBubbleFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}
@keyframes sparkle-drift{
  0%{transform:translateY(8px) rotate(0deg)}
  40%{transform:translateY(-4px) rotate(1deg)}
  70%{transform:translateY(2px) rotate(-1deg)}
  100%{transform:translateY(8px) rotate(0deg)}
}

.side-stack{display:flex;flex-direction:column;gap:12px}
.over-panel{display:flex;flex-direction:column;gap:14px}
.over-panel .title{width:100%;text-align:center}
.over-subtitle{margin-top:-6px;text-align:center}
.over-primary-actions{justify-content:center;gap:10px}
.over-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;align-items:stretch}
.over-stat-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:6px 10px;
  align-items:center;
  padding:0;
  border-radius:0;
  border:0;
  background:transparent;
  box-shadow:none;
  text-align:left;
}
.over-stat-label{
  font-weight:900;
  letter-spacing:.25px;
  color:var(--text);
  text-transform:none;
  font-size:15px;
}
.over-stat-value{
  font-weight:900;
  color:var(--accent-strong);
  font-size:16px;
  justify-self:end;
}
.over-final-card{
  grid-template-columns:1fr;
  justify-items:center;
  text-align:center;
  gap:8px;
  padding:12px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.04));
  border-color:rgba(255,255,255,.24);
  box-shadow:0 14px 36px rgba(0,0,0,.32),0 0 0 1px rgba(255,255,255,.1);
}
.over-final-label{
  font-size:clamp(28px,3vw,44px);
  letter-spacing:.6px;
  text-transform:uppercase;
}
.over-duration{
  display:flex;
  flex-direction:column;
  gap:2px;
  align-items:center;
}
.over-duration-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.25px;
  color:var(--muted);
}
.over-duration-value{
  font-weight:900;
  font-size:clamp(20px,2.4vw,30px);
  color:#e6f1ff;
  text-shadow:0 8px 20px rgba(0,0,0,.3);
}
.over-final-score{
  font-size:clamp(80px,9vw,140px);
  line-height:1;
  font-weight:900;
  color:#f5f1ff;
  text-shadow:0 12px 32px rgba(0,0,0,.35),0 0 28px rgba(200,230,255,.6),0 0 44px rgba(255,185,245,.4);
  filter:drop-shadow(0 8px 16px rgba(0,0,0,.24));
}
.over-best-stack{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:center;
}
.over-best-line{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  justify-content:center;
}
.over-best-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.2px;
}
.over-best-card{
  background:linear-gradient(180deg,rgba(170,220,255,.12),rgba(120,190,255,.06));
  border-color:rgba(170,220,255,.28);
}
.over-personal-best{
  font-size:clamp(32px,4vw,54px);
  font-weight:900;
  color:var(--accent-strong);
  text-shadow:0 10px 20px rgba(0,0,0,.26);
}
.over-pb-badge{
  margin-top:4px;
  padding:7px 12px;
  border-radius:999px;
  background:linear-gradient(90deg,rgba(160,255,210,.9),rgba(255,200,255,.9));
  color:#0b1321;
  font-weight:900;
  letter-spacing:.2px;
  box-shadow:0 12px 24px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.35);
}
.over-pb-status{
  text-align:center;
  font-size:15px;
  color:var(--muted);
  margin-top:-4px;
}
.over-pb-status.highlight{
  color:#c9ffe1;
  text-shadow:0 10px 22px rgba(0,0,0,.32),0 0 24px rgba(180,255,220,.5);
}
.over-details{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
}
.over-achievements{
  grid-column:1 / -1;
  padding:14px 14px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.over-achievements .section-title{
  margin-bottom:0;
  font-size:14px;
}
.over-achievements-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
}
.over-achievements-list.scrollable{
  max-height:260px;
  overflow-y:auto;
  padding-right:4px;
  overscroll-behavior:contain;
}
.over-achievement-item{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  box-shadow:0 8px 18px rgba(0,0,0,.22);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.over-achievement-title{
  font-weight:900;
  letter-spacing:.2px;
}
.over-achievement-desc{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.35;
}
.over-details .score-breakdown{
  margin:0;
}
.over-stats{
  padding:14px 14px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.over-stats-header{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  align-items:center;
  justify-content:space-between;
}
.over-stats-mode{
  font-size:12px;
  color:var(--muted);
  font-weight:800;
  letter-spacing:.2px;
  text-transform:uppercase;
}
.over-stats .section-title{margin-bottom:0;font-size:14px}
.over-stats-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
}
.over-stats .skill-usage{margin:0}
.skill-usage{
  margin:10px 0 6px;
  padding:10px 12px 6px;
  border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.skill-usage .section-title{
  margin-bottom:8px;
  font-size:14px;
}
.skill-usage-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  gap:8px;
}
.skill-usage-list.two-column{
  grid-template-columns:repeat(2,minmax(120px,1fr));
}
.skill-usage-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.skill-usage-label{
  font-weight:800;
  letter-spacing:.2px;
}
.skill-usage-count{
  font-weight:900;
  color:var(--accent-strong);
  font-size:15px;
}
.score-breakdown{
  margin:12px 0 4px;
  padding:14px 14px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.score-breakdown .section-title{margin-bottom:6px;font-size:14px}
.score-breakdown-list{
  display:grid;
  grid-template-columns:1.1fr auto auto;
  gap:6px 10px;
  align-items:center;
}
.score-breakdown-row{
  display:contents;
}
.score-breakdown-label{
  font-weight:900;
  letter-spacing:.25px;
  font-size:15px;
}
.score-breakdown-meta{
  font-size:13px;
  color:var(--muted);
}
.score-breakdown-points{
  font-weight:900;
  color:var(--accent-strong);
  font-size:16px;
  justify-self:end;
}
.score-breakdown-total{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:10px 12px;
  margin-top:8px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 12px 26px rgba(0,0,0,.26);
  display:grid;
  grid-template-columns:1.1fr auto auto;
  gap:6px 10px;
  align-items:center;
  grid-column:1 / -1;
}
.score-breakdown-total .score-breakdown-label,
.score-breakdown-total .score-breakdown-meta,
.score-breakdown-total .score-breakdown-points{display:block}
.score-breakdown-total .score-breakdown-label{font-size:16px}
.score-breakdown-total .score-breakdown-points{font-size:18px}
.over-replay-actions{justify-content:center;gap:10px}
@media (max-width: 860px){
  .over-details{grid-template-columns:1fr}
}
.menu-subtitle{margin-top:-4px}
.replay-hint{margin-top:10px}
.achievements-card .achievement-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;margin-top:8px;gap:10px}
.achievements-card .achievement-filter-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.achievements-card .achievement-filter-label{font-size:12px;color:var(--muted);letter-spacing:.2px;text-transform:uppercase;font-weight:800}
.achievements-card .achievement-controls .checkbox{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--text);
  cursor:pointer;
  user-select:none;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 10px 22px rgba(0,0,0,.24)
}
.achievements-card .achievement-controls .checkbox.pill{border-radius:999px}
.achievements-card .achievement-controls .checkbox input{
  appearance:none;
  width:18px;
  height:18px;
  border-radius:6px;
  border:1px solid rgba(255,255,255,.22);
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.3),transparent 55%),rgba(0,0,0,.35);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.45),0 6px 14px rgba(0,0,0,.24);
  position:relative;
  cursor:pointer;
  transition:all .14s ease;
}
.achievements-card .achievement-controls .checkbox input:checked{
  border-color:rgba(160,255,210,.85);
  background:linear-gradient(180deg,rgba(170,240,255,.85),rgba(120,210,255,.78));
  box-shadow:0 8px 16px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.5)
}
.achievements-card .achievement-controls .checkbox input:checked::after{
  content:"";
  position:absolute;
  inset:4px;
  border-radius:4px;
  background:linear-gradient(180deg,rgba(15,30,45,.9),rgba(25,40,65,.82));
  box-shadow:0 1px 3px rgba(0,0,0,.25);
}
.achievements-card .achievement-controls .checkbox:hover{
  border-color:rgba(255,255,255,.18);
  transform:translateY(-1px);
}
.achievements-card .achievement-controls .checkbox span{color:var(--text);font-weight:900;letter-spacing:.2px}
.achievements-card .achievement-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:10px;
  max-height:520px;
  overflow:auto;
  padding-right:6px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.03));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.achievement-list::-webkit-scrollbar{width:10px}
.achievement-list::-webkit-scrollbar-track{
  background:rgba(255,255,255,.04);
  border-radius:999px;
}
.achievement-list::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(170,220,255,.75),rgba(150,180,255,.62));
  border-radius:999px;
  border:2px solid rgba(0,0,0,.25);
  box-shadow:0 4px 10px rgba(0,0,0,.35);
}
.achievement-list::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,rgba(200,235,255,.9),rgba(170,205,255,.72));
}
.achievement-list{scrollbar-width:thin;scrollbar-color:rgba(180,220,255,.8) rgba(255,255,255,.06)}
.achievement-row{border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:12px 14px;background:rgba(255,255,255,.04);box-shadow:inset 0 1px 0 rgba(255,255,255,.05);display:flex;flex-direction:column;gap:6px}
.achievement-row.unlocked{border-color:rgba(160,255,210,.28);background:linear-gradient(180deg,rgba(30,40,35,.45),rgba(20,30,25,.35))}
.achievement-empty{color:var(--muted);font-size:13px;text-align:center;padding:16px;border:1px dashed rgba(255,255,255,.14);border-radius:12px;background:rgba(255,255,255,.03)}
.achievement-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.achievement-title{font-weight:900;letter-spacing:.3px;margin-bottom:2px;line-height:1.25}
.achievement-tag{font-size:11px;font-weight:900;letter-spacing:.3px;text-transform:uppercase;padding:5px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));color:var(--accent-strong)}
.achievement-desc{color:var(--muted);font-size:13px;margin-bottom:4px;line-height:1.35}
.achievement-meta{display:flex;flex-wrap:wrap;gap:10px;color:rgba(255,255,255,.85);font-size:12px;font-weight:700;letter-spacing:.1px}
.achievement-requirement{color:rgba(255,255,255,.75)}
.achievement-reward{color:var(--accent-strong);font-weight:800;font-size:12px;margin-bottom:2px}
.achievement-status{font-weight:800;font-size:12.5px;color:rgba(255,255,255,.85);margin-top:6px}
.achievement-status.unlocked{color:#bdf7c2}
.achievement-meter{height:8px;border-radius:8px;background:rgba(255,255,255,.08);overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,.35)}
.achievement-meter-fill{height:100%;background:linear-gradient(90deg,rgba(160,255,210,.9),rgba(120,200,255,.9));transition:width .2s ease}
.achievement-meter-fill.filled{background:linear-gradient(90deg,rgba(255,220,120,.95),rgba(255,170,80,.95))}

.achievement-toasts{position:fixed;left:20px;bottom:20px;display:flex;flex-direction:column;gap:8px;z-index:50;pointer-events:none}
.achievement-toast{min-width:240px;max-width:320px;background:rgba(15,20,30,.92);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:10px 12px;box-shadow:0 12px 30px rgba(0,0,0,.35);opacity:0;transform:translateY(12px);transition:opacity .2s ease,transform .25s ease}
.achievement-toast.visible{opacity:1;transform:translateY(0)}
.achievement-toast.fade{opacity:0;transform:translateY(10px)}
.achievement-toast-title{font-size:12px;font-weight:900;color:var(--accent-strong);letter-spacing:.2px}
.achievement-toast-name{font-weight:900;margin:2px 0}
.achievement-toast-desc{color:var(--muted);font-size:12px}

.icon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px}
.icon-option{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;padding:10px;background:transparent;border:none;border-radius:14px;cursor:pointer;transition:transform .12s ease,filter .12s ease;color:#e5e7eb;position:relative}
.icon-option:hover{transform:translateY(-2px);filter:drop-shadow(0 12px 22px rgba(0,0,0,.35))}
.icon-option:focus-visible{outline:2px solid var(--accent-strong);outline-offset:6px}
.icon-swatch{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.icon-swatch.selected{box-shadow:0 0 0 4px rgba(125,211,252,.5),0 8px 18px rgba(0,0,0,.35),0 0 22px var(--icon-glow,rgba(255,200,120,.5))}
.icon-swatch-canvas{position:absolute;inset:-12%;width:124%;height:124%;pointer-events:none;filter:drop-shadow(0 0 18px var(--icon-glow,rgba(255,200,120,.5)));mix-blend-mode:screen}
.icon-option.selected .icon-swatch{box-shadow:0 0 0 4px rgba(125,211,252,.5),0 8px 18px rgba(0,0,0,.35),0 0 22px var(--icon-glow,rgba(255,200,120,.5))}
.icon-option.locked{opacity:.7;cursor:not-allowed}
.icon-option .icon-swatch{width:78px;height:78px;border-radius:50%;background:radial-gradient(circle at 32% 32%,var(--icon-core,#ffc285),var(--icon-fill,#ff8c1a));box-shadow:0 0 0 2px var(--icon-rim,#0f172a),0 12px 26px rgba(0,0,0,.45),0 0 22px var(--icon-glow,rgba(255,200,120,.5));transition:box-shadow .12s ease}
.icon-option-name,.trail-option-name{font-weight:800;font-size:14px;text-align:center;max-width:120px}
.icon-lock{position:absolute;right:18px;top:18px;font-size:16px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.45))}
.icon-overlay,.trail-overlay{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;background:rgba(6,12,24,.72);backdrop-filter:blur(4px)}
.modal-layer{pointer-events:auto}
.pipe-texture-overlay{position:fixed;inset:0;z-index:80;display:flex;align-items:flex-start;justify-content:center;padding:6vh 16px 18px;background:rgba(6,12,24,.78);box-sizing:border-box}
.icon-overlay-panel,.trail-overlay-panel{background:linear-gradient(180deg,rgba(30,41,59,.95),rgba(15,23,42,.95));border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:18px;box-shadow:0 24px 60px rgba(0,0,0,.45);width:min(900px,90vw);max-height:82vh;overflow:auto;display:flex;flex-direction:column;gap:12px}
.pipe-texture-overlay-panel{width:min(720px,92vw);max-height:78vh;display:flex;flex-direction:column;overflow:hidden}
.icon-overlay-header,.trail-overlay-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.icon-overlay-close,.trail-overlay-close{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#e5e7eb;border-radius:10px;padding:6px 10px;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.icon-overlay-close:hover,.trail-overlay-close:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.35)}
.icon-overlay-grid{padding:4px;max-height:60vh;overflow-y:auto;scrollbar-gutter:stable}
.icon-launcher,.trail-launcher,.pipe-texture-launcher{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.05);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}
.icon-launcher:hover,.trail-launcher:hover,.pipe-texture-launcher:hover{transform:translateY(-1px);border-color:rgba(125,211,252,.65);box-shadow:0 14px 32px rgba(0,0,0,.28)}
.icon-launcher:focus-visible,.trail-launcher:focus-visible,.pipe-texture-launcher:focus-visible{outline:2px solid var(--accent-strong);outline-offset:4px}
.icon-launcher-badge,.trail-launcher-badge,.pipe-texture-launcher-badge{display:flex;align-items:center;gap:12px}
.icon-launcher .icon-swatch,.trail-launcher .trail-swatch{width:64px;height:64px;border-radius:50%;background:radial-gradient(circle at 32% 32%,var(--icon-core,#ffc285),var(--icon-fill,#ff8c1a));box-shadow:0 0 0 2px var(--icon-rim,#0f172a),0 10px 24px rgba(0,0,0,.35),0 0 22px var(--icon-glow,rgba(255,200,120,.5))}
.pipe-texture-launcher .pipe-texture-swatch{width:84px;height:56px;border-radius:12px;background:#0f172a;box-shadow:0 0 0 2px rgba(15,23,42,.75),0 10px 24px rgba(0,0,0,.35);overflow:hidden;position:relative}
.pipe-texture-swatch-canvas{width:100%;height:100%;display:block;border-radius:12px}
.icon-launcher-label,.trail-launcher-label,.pipe-texture-launcher-label{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.pipe-texture-launcher-label{background:rgba(15,23,42,.6);border-radius:10px;padding:6px 8px;border:1px solid rgba(255,255,255,.08)}
.icon-launcher-name,.trail-launcher-name,.pipe-texture-launcher-name{font-weight:900;letter-spacing:.2px}
.icon-launcher-action,.trail-launcher-action,.pipe-texture-launcher-action{font-size:13px;color:var(--muted)}
.pipe-texture-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;flex:1;min-height:0;overflow:auto;padding:4px 4px 8px}
.pipe-texture-grid::-webkit-scrollbar{width:10px}
.pipe-texture-grid::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:999px}
.pipe-texture-grid::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(170,220,255,.75),rgba(150,180,255,.62));border-radius:999px;border:2px solid rgba(0,0,0,.25)}
.pipe-texture-grid::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(200,235,255,.9),rgba(170,205,255,.72))}
.pipe-texture-grid{scrollbar-width:thin;scrollbar-color:rgba(180,220,255,.8) rgba(255,255,255,.06)}
.pipe-texture-option{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;padding:8px;background:transparent;border:none;border-radius:12px;cursor:pointer;transition:transform .12s ease,filter .12s ease;color:#e5e7eb;position:relative}
.pipe-texture-option:hover{transform:translateY(-2px);filter:drop-shadow(0 12px 22px rgba(0,0,0,.35))}
.pipe-texture-option:focus-visible{outline:2px solid var(--accent-strong);outline-offset:6px}
.pipe-texture-option.locked{opacity:.7;cursor:not-allowed}
.pipe-texture-swatch{width:120px;height:68px;border-radius:12px;background:#0f172a;box-shadow:0 0 0 2px rgba(15,23,42,.75),0 12px 26px rgba(0,0,0,.45);overflow:hidden}
.pipe-texture-option.selected .pipe-texture-swatch{box-shadow:0 0 0 4px rgba(125,211,252,.5),0 12px 26px rgba(0,0,0,.45)}
.pipe-texture-option-name{font-weight:800;font-size:13px;text-align:center;max-width:150px;-webkit-text-stroke:1px rgba(7,11,22,.85);text-shadow:0 1px 2px rgba(7,11,22,.8),0 0 6px rgba(7,11,22,.85)}
.pipe-texture-lock{position:absolute;right:16px;top:16px;font-size:16px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.45))}
.pipe-texture-mode-options{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:8px 12px}
.pipe-texture-mode-btn{border:1px solid rgba(148,163,184,.35);background:rgba(15,23,42,.6);color:#e2e8f0;padding:6px 10px;border-radius:999px;font-size:12px;letter-spacing:.3px;cursor:pointer;transition:background .12s ease,border-color .12s ease}
.pipe-texture-mode-btn:hover{border-color:rgba(125,211,252,.6)}
.pipe-texture-mode-btn.selected{background:rgba(56,189,248,.22);border-color:rgba(125,211,252,.8);color:#f8fafc}
.unlock-cost{margin-top:4px;font-size:11px;font-weight:700;color:rgba(148,163,184,.9)}
.icon-option .unlock-cost,.trail-option .unlock-cost{display:block;text-align:center}
.pipe-texture-option .unlock-cost{text-align:center;-webkit-text-stroke:1px rgba(7,11,22,.85);text-shadow:0 1px 2px rgba(7,11,22,.8),0 0 6px rgba(7,11,22,.85)}
.purchasable:not(.locked)::after{content:"";display:none}

.shop-overlay,.purchase-modal,.replay-modal{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:6vh 16px;background:rgba(6,12,24,.78);backdrop-filter:blur(6px);box-sizing:border-box}
.shop-overlay.hidden,.purchase-modal.hidden,.replay-modal.hidden{display:none}
.shop-overlay-panel,.purchase-modal-panel,.replay-modal-panel{background:linear-gradient(180deg,rgba(30,41,59,.95),rgba(15,23,42,.95));border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:18px;box-shadow:0 24px 60px rgba(0,0,0,.45);width:min(760px,92vw);max-height:80vh;overflow:hidden;display:flex;flex-direction:column;gap:12px}
.shop-overlay-header,.purchase-modal-header,.replay-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.shop-overlay-close,.purchase-modal-close,.replay-modal-close{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#e5e7eb;border-radius:10px;padding:6px 10px;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.shop-overlay-close:hover,.purchase-modal-close:hover,.replay-modal-close:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.35)}
.shop-tabs{display:flex;flex-wrap:wrap;gap:8px}
.shop-tab-btn{border:1px solid rgba(148,163,184,.35);background:rgba(15,23,42,.6);color:#e2e8f0;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.3px;cursor:pointer;transition:background .12s ease,border-color .12s ease}
.shop-tab-btn:hover{border-color:rgba(125,211,252,.6)}
.shop-tab-btn.selected{background:rgba(56,189,248,.22);border-color:rgba(125,211,252,.8);color:#f8fafc}
.shop-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;overflow:auto;padding:4px;flex:1;min-height:0}
.shop-item{border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px;background:rgba(255,255,255,.04);display:flex;flex-direction:column;gap:6px;align-items:flex-start;cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;color:#e5e7eb;text-align:left;position:relative}
.shop-item:hover{transform:translateY(-2px);border-color:rgba(125,211,252,.6);box-shadow:0 14px 28px rgba(0,0,0,.35)}
.shop-item.owned{opacity:.7;cursor:not-allowed}
.shop-item-owned{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;background:rgba(15,23,42,.74);border-radius:12px;font-weight:900;font-size:13px;letter-spacing:.3px;text-transform:uppercase}
.shop-item-name{font-weight:800;font-size:14px}
.shop-item-meta{font-size:12px;color:rgba(148,163,184,.95);font-weight:700}
.purchase-modal-line,.replay-modal-line{font-size:14px;color:#e2e8f0}

/* ---- Replay Browser ---- */
.replay-browser-screen{align-items:flex-start;overflow:auto}
.replay-browser-panel{width:min(1200px,96vw);max-height:calc(100vh - 32px);display:flex;flex-direction:column;gap:16px}
.replay-browser-header{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.replay-browser-kicker{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);opacity:.85}
.replay-browser-title{margin:4px 0 6px;font-size:28px}
.replay-browser-subtitle{margin:0;font-size:14px;color:var(--muted)}
.replay-browser-actions{display:flex;gap:10px;flex-wrap:wrap}
.replay-browser-mobile-tabs{display:none;gap:10px;padding:8px;border-radius:14px;background:var(--panel-soft);border:1px solid var(--surface-border)}
.replay-browser-mobile-tabs .btn{flex:1;justify-content:center}
.replay-browser-mobile-tabs .btn.selected{background:rgba(56,189,248,.22);border-color:rgba(125,211,252,.8);color:#f8fafc}
.replay-browser-content{display:grid;grid-template-columns:minmax(240px,340px) minmax(0,1fr);gap:16px;min-height:0}
.replay-browser-sidebar{display:flex;flex-direction:column;gap:12px;min-height:0}
.replay-browser-filters{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:16px;background:var(--panel-soft);border:1px solid var(--surface-border)}
.replay-filter{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.replay-filter input,.replay-filter select{padding:8px 10px;border-radius:10px;border:1px solid var(--surface-border);background:rgba(10,14,32,.7);color:var(--text);font-family:inherit}
.replay-filter-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.replay-browser-count{font-size:12px;color:var(--muted)}
.replay-browser-list{display:flex;flex-direction:column;gap:8px;overflow:auto;min-height:120px;padding-right:4px}
.replay-card{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:14px;border:1px solid transparent;background:rgba(6,10,24,.5);color:var(--text);text-align:left;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}
.replay-card:hover{transform:translateY(-1px);border-color:var(--surface-border);background:rgba(14,20,42,.78)}
.replay-card.active{border-color:rgba(160,220,255,.6);box-shadow:0 0 18px rgba(120,200,255,.25)}
.replay-card-title{font-weight:700}
.replay-card-score{font-size:14px;color:var(--accent-strong)}
.replay-card-details{font-size:12px;color:var(--muted)}
.replay-empty{padding:10px;border-radius:12px;background:rgba(10,14,32,.55);border:1px dashed var(--surface-border);font-size:12px;color:var(--muted)}
.replay-browser-player{display:flex;flex-direction:column;gap:12px;min-height:0}
.replay-browser-status{font-size:13px;color:var(--muted)}
.replay-browser-status.bad{color:var(--danger)}
.replay-browser-details{display:flex;flex-direction:column;gap:6px;padding:12px;border-radius:16px;background:var(--panel-soft);border:1px solid var(--surface-border)}
.replay-detail-heading{font-weight:700;margin-bottom:4px}
.replay-detail-row{display:flex;justify-content:space-between;gap:12px;font-size:13px}
.replay-detail-label{color:var(--muted)}
.replay-detail-stats{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:4px}
.replay-detail-body{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text)}
.replay-browser-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.replay-speed{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.replay-speed select{padding:6px 8px;border-radius:10px;border:1px solid var(--surface-border);background:rgba(10,14,32,.7);color:var(--text)}
.replay-browser-progress{display:flex;flex-direction:column;gap:6px}
.replay-progress-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.replay-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .12s ease}
.replay-progress-meta{font-size:12px;color:var(--muted)}

body.replay-browser-page .replay-browser-screen{display:flex;align-items:stretch;justify-content:flex-end}
body.replay-browser-page .replay-browser-panel{width:min(560px,96vw);align-self:stretch}
body.replay-browser-page .replay-browser-content{grid-template-columns:1fr}
body.replay-browser-page [data-mobile-layout="true"] .replay-browser-mobile-tabs{display:flex}
body.replay-browser-page [data-mobile-layout="true"] .replay-browser-content{grid-template-columns:1fr}
body.replay-browser-page [data-mobile-layout="true"][data-replay-view="list"] .replay-browser-player{display:none}
body.replay-browser-page [data-mobile-layout="true"][data-replay-view="player"] .replay-browser-sidebar{display:none}

@media (max-width: 960px){
  .replay-browser-content{grid-template-columns:1fr}
  .replay-filter-row{grid-template-columns:1fr}
}
.purchase-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;flex-wrap:wrap}
.icon-field-launcher,.trail-field-launcher{position:relative}
