:root {
  --bg-0: #0b1018;
  --bg-1: #0f1725;
  --bg-2: #161f30;
  --panel: #182235;
  --panel-strong: #131d2f;
  --panel-soft: #1e2a40;
  --line: rgba(204, 224, 255, 0.18);
  --line-strong: rgba(255, 191, 109, 0.42);

  --text: #f2f6ff;
  --text-dim: #aebcd7;
  --text-soft: #8f9eb8;

  --gold-1: #ffe39f;
  --gold-2: #ffc468;
  --gold-3: #d08a2f;
  --ember: #ff7347;
  --aqua: #3ad0ff;
  --mint: #69f2cc;

  --danger: #ff6f7c;
  --ok: #60f0a2;

  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --radius-xl: 30px;

  --shadow-sm: 0 10px 24px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 18px 45px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.55);

  --font-ui: Rajdhani, Segoe UI, Arial, sans-serif;
  --font-head: Cinzel, Georgia, serif;
  --font-tech: Orbitron, Arial, sans-serif;

  --safe-top: env(safe-area-inset-top);
  --safe-bottom: env(safe-area-inset-bottom);

  --btn-h: 46px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
}

::selection {
  background: rgba(255, 196, 104, 0.33);
  color: #fff;
}

body {
  margin: 0;
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 18px;
  line-height: 1.35;
  background:
    radial-gradient(1200px 520px at 5% -10%, rgba(255, 115, 71, 0.16), transparent 62%),
    radial-gradient(900px 430px at 92% -6%, rgba(58, 208, 255, 0.18), transparent 58%),
    radial-gradient(700px 300px at 50% 100%, rgba(255, 196, 104, 0.08), transparent 65%),
    linear-gradient(180deg, var(--bg-0) 0%, var(--bg-1) 42%, var(--bg-2) 100%);
  background-attachment: fixed;
  overflow-x: hidden;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -3;
}

body::before {
  background:
    linear-gradient(115deg, rgba(255, 196, 104, 0.04), transparent 33%),
    linear-gradient(-115deg, rgba(58, 208, 255, 0.05), transparent 35%);
  animation: fogShift 24s ease-in-out infinite alternate;
}

body::after {
  background-image:
    radial-gradient(circle, rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    radial-gradient(circle, rgba(255, 191, 109, 0.08) 1px, transparent 1px);
  background-size: 180px 180px, 260px 260px;
  background-position: 0 0, 130px 140px;
  opacity: 0.25;
  animation: sparkDrift 36s linear infinite;
}

@keyframes fogShift {
  from {
    transform: translate3d(-1.5%, -1.5%, 0) scale(1);
  }
  to {
    transform: translate3d(1.5%, 1.5%, 0) scale(1.03);
  }
}

@keyframes sparkDrift {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-180px);
  }
}

a {
  color: inherit;
}

img {
  max-width: 100%;
}

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

textarea {
  resize: vertical;
}

:focus-visible {
  outline: 2px solid var(--aqua);
  outline-offset: 2px;
}

::-webkit-scrollbar {
  width: 11px;
  height: 11px;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(255, 196, 104, 0.9), rgba(255, 115, 71, 0.9));
  border-radius: 999px;
}

::-webkit-scrollbar-track {
  background: rgba(8, 12, 20, 0.55);
}

.fx-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -2;
}

.fx-overlay {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(900px 380px at 13% 15%, rgba(58, 208, 255, 0.08), transparent 60%),
    radial-gradient(1000px 430px at 86% 18%, rgba(255, 191, 109, 0.08), transparent 60%),
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.015) 0 1px,
      transparent 1px 24px
    );
  mix-blend-mode: screen;
  animation: overlayDrift 12s ease-in-out infinite alternate;
}

@keyframes overlayDrift {
  from {
    transform: translateY(-10px);
  }
  to {
    transform: translateY(10px);
  }
}

.hidden {
  display: none !important;
}

.muted {
  color: var(--text-dim);
}

.gold {
  color: transparent;
  background: linear-gradient(95deg, var(--gold-1), var(--gold-2), var(--gold-3));
  -webkit-background-clip: text;
  background-clip: text;
}

.glow {
  text-shadow: 0 0 20px rgba(255, 196, 104, 0.4);
}

.divider {
  height: 1px;
  margin: 14px 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 191, 109, 0.45),
    rgba(58, 208, 255, 0.35),
    transparent
  );
}

.ico {
  width: 18px;
  height: 18px;
  object-fit: contain;
  vertical-align: middle;
}

.ico--title {
  width: 22px;
  height: 22px;
}

.ico--btn {
  width: 16px;
  height: 16px;
}

.ico--inline {
  width: 15px;
  height: 15px;
}

.ico--nav {
  width: 20px;
  height: 20px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: calc(12px + var(--safe-top)) 18px 12px;
  background:
    linear-gradient(180deg, rgba(17, 26, 43, 0.96), rgba(12, 19, 32, 0.92)),
    radial-gradient(circle at 20% -20%, rgba(255, 191, 109, 0.12), transparent 60%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.brand {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.brand__mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255, 191, 109, 0.45);
  background:
    linear-gradient(145deg, rgba(255, 191, 109, 0.28), rgba(58, 208, 255, 0.18)),
    rgba(13, 20, 34, 0.95);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.08),
    0 14px 34px rgba(0, 0, 0, 0.45);
  font-size: 0;
  position: relative;
  overflow: hidden;
}

.brand__mark::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 24px;
  height: 24px;
  background: url("assets/icons/sparkles.svg") center/contain no-repeat;
  filter: drop-shadow(0 0 10px rgba(255, 196, 104, 0.45));
}

.brand__title {
  font-family: var(--font-head);
  font-size: clamp(1rem, 2.4vw, 1.38rem);
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1;
}

.brand__sub {
  margin-top: 2px;
  font-size: 0.8rem;
  color: var(--text-soft);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.topbar__right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.userpill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(13, 22, 38, 0.9);
  box-shadow: var(--shadow-sm);
}

.userpill__name {
  color: var(--text-dim);
  white-space: nowrap;
}

.iconbtn {
  border: 1px solid var(--line);
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: rgba(16, 24, 40, 0.88);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

.iconbtn:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 191, 109, 0.42);
  background: rgba(24, 34, 55, 0.96);
}

.iconbtn--small {
  width: 36px;
  height: 36px;
}

.iconbtn__lines {
  position: relative;
  width: 17px;
  height: 2px;
  background: var(--text);
  border-radius: 99px;
}

.iconbtn__lines::before,
.iconbtn__lines::after {
  content: "";
  position: absolute;
  left: 0;
  width: 17px;
  height: 2px;
  background: var(--text);
  border-radius: 99px;
}

.iconbtn__lines::before {
  top: -6px;
}

.iconbtn__lines::after {
  top: 6px;
}

.sidenav {
  position: fixed;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 50;
}

.sidenav--right {
  left: auto;
  right: 16px;
}

.sidenav__item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(174, 188, 215, 0.24);
  background:
    linear-gradient(145deg, rgba(18, 28, 45, 0.96), rgba(13, 21, 36, 0.92));
  color: var(--text-dim);
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: transform 180ms ease, border-color 180ms ease, color 180ms ease;
}

.sidenav__item:hover {
  transform: translateX(2px);
  border-color: rgba(255, 191, 109, 0.52);
  color: #fff;
}

.sidenav__item.is-active {
  border-color: rgba(255, 191, 109, 0.6);
  color: #fff;
  box-shadow:
    0 0 0 1px rgba(255, 191, 109, 0.2),
    0 14px 28px rgba(0, 0, 0, 0.45);
}

.sidenav__label {
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  z-index: 80;
}

.drawer {
  position: fixed;
  right: 0;
  top: 0;
  width: min(84vw, 360px);
  height: 100dvh;
  padding: calc(16px + var(--safe-top)) 16px calc(16px + var(--safe-bottom));
  display: flex;
  flex-direction: column;
  gap: 14px;
  background:
    linear-gradient(180deg, rgba(17, 27, 44, 0.98), rgba(11, 18, 31, 0.98));
  border-left: 1px solid rgba(174, 188, 215, 0.24);
  box-shadow: -20px 0 42px rgba(0, 0, 0, 0.45);
  z-index: 81;
}

.drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.drawer__title {
  font-family: var(--font-head);
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: 0.03em;
}

.drawer__nav {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}

.drawer__link {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(174, 188, 215, 0.2);
  border-radius: var(--radius-sm);
  padding: 12px 12px;
  text-decoration: none;
  background: rgba(18, 29, 48, 0.8);
  color: var(--text-dim);
  transition: transform 160ms ease, border-color 160ms ease;
}

.drawer__link.is-active {
  border-color: rgba(255, 191, 109, 0.55);
  color: #fff;
  background: rgba(27, 40, 63, 0.95);
}

.drawer__link:hover {
  transform: translateX(2px);
  border-color: rgba(255, 191, 109, 0.45);
}

.drawer__txt {
  font-weight: 700;
}

.drawer__foot {
  margin-top: auto;
}

.main {
  width: min(1260px, calc(100% - 2.2rem));
  margin: 28px auto 34px;
}

.view {
  display: none;
}

.view.is-active {
  display: block;
  animation: viewIn 380ms ease both;
}

/* Important for mobile: transformed ancestors break fixed-position modals */
.view,
.view.is-active {
  transform: none !important;
}

@keyframes viewIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.pagehead {
  margin-bottom: 16px;
}

.pagehead__title {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-head);
  letter-spacing: 0.04em;
  font-size: clamp(1.35rem, 2.9vw, 2.05rem);
  line-height: 1.1;
}

.pagehead__sub {
  margin: 8px 0 0;
}

.pagehead__actions {
  margin-top: 10px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255, 191, 109, 0.33);
  padding: clamp(1.2rem, 3.4vw, 2.4rem);
  background:
    linear-gradient(140deg, rgba(255, 191, 109, 0.14), transparent 38%),
    linear-gradient(-145deg, rgba(58, 208, 255, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(25, 37, 60, 0.92), rgba(20, 30, 48, 0.95));
  box-shadow: var(--shadow-lg);
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 82% 8%, rgba(255, 191, 109, 0.35), transparent 38%),
    linear-gradient(95deg, transparent 30%, rgba(255, 255, 255, 0.05) 50%, transparent 65%);
  mix-blend-mode: screen;
}

.hero::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -50px;
  width: 260px;
  height: 260px;
  pointer-events: none;
  background: url("logo.webp") center/contain no-repeat;
  opacity: 0.1;
  filter: saturate(0.9);
}

.hero > * {
  position: relative;
  z-index: 1;
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(174, 188, 215, 0.33);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  background: rgba(8, 14, 24, 0.48);
}

.pulse-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 0 rgba(96, 240, 162, 0.45);
  animation: pulseDot 1.5s ease-in-out infinite;
}

@keyframes pulseDot {
  0% {
    box-shadow: 0 0 0 0 rgba(96, 240, 162, 0.5);
  }
  70% {
    box-shadow: 0 0 0 12px rgba(96, 240, 162, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(96, 240, 162, 0);
  }
}

.hero__title {
  margin: 12px 0 10px;
  font-family: var(--font-head);
  font-size: clamp(1.6rem, 4.5vw, 3rem);
  line-height: 1.08;
  letter-spacing: 0.03em;
}

.hero__lead {
  max-width: 68ch;
  margin: 0;
  color: var(--text-dim);
}

.grid {
  display: grid;
  gap: 16px;
  margin-top: 16px;
}

.grid--2,
.grid--3 {
  grid-template-columns: 1fr;
}

.grid--2.is-logged {
  grid-template-columns: 1fr;
}

.card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(32, 46, 72, 0.75), rgba(22, 33, 52, 0.82)),
    var(--panel);
  padding: 16px;
  box-shadow: var(--shadow-md);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(130deg, rgba(255, 191, 109, 0.08), transparent 35%);
}

.card > * {
  position: relative;
  z-index: 1;
}

.card:hover {
  transform: translateY(-3px);
  border-color: rgba(255, 191, 109, 0.4);
  box-shadow:
    0 0 0 1px rgba(255, 191, 109, 0.12),
    0 26px 58px rgba(0, 0, 0, 0.47);
}

.card--vip {
  border-color: rgba(58, 208, 255, 0.38);
  background:
    linear-gradient(140deg, rgba(58, 208, 255, 0.14), transparent 40%),
    linear-gradient(180deg, rgba(26, 44, 67, 0.84), rgba(19, 33, 54, 0.9));
}

.card--wide {
  margin-top: 16px;
}

.card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.card__title {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-tech);
  font-size: clamp(1rem, 2.3vw, 1.2rem);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-weight: 800;
}

.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 4px 11px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(13, 22, 38, 0.7);
  color: var(--text-dim);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 700;
}

.pill--gold {
  color: #1e1405;
  border-color: rgba(255, 191, 109, 0.6);
  background: linear-gradient(95deg, var(--gold-1), var(--gold-2));
}

.pill--neon {
  color: #dff7ff;
  border-color: rgba(58, 208, 255, 0.55);
  background: rgba(58, 208, 255, 0.16);
}

.btn {
  min-height: var(--btn-h);
  padding: 0 16px;
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.25);
  background: rgba(18, 28, 46, 0.92);
  color: #f5f8ff;
  font-family: var(--font-tech);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-size: 0.86rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
  position: relative;
  overflow: hidden;
}

.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255, 255, 255, 0.2) 50%, transparent 70%);
  transform: translateX(-115%);
  transition: transform 400ms ease;
  pointer-events: none;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn:hover::after {
  transform: translateX(115%);
}

.btn:disabled {
  cursor: not-allowed;
  opacity: 0.6;
  transform: none;
}

.btn--block {
  width: 100%;
}

.btn--sm {
  min-height: 36px;
  padding-inline: 12px;
  font-size: 0.75rem;
}

.btn--primary {
  border-color: rgba(255, 191, 109, 0.52);
  color: #241500;
  background: linear-gradient(100deg, var(--gold-1), var(--gold-2));
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 8px 20px rgba(255, 191, 109, 0.28);
}

.btn--neon {
  border-color: rgba(58, 208, 255, 0.55);
  background: linear-gradient(100deg, rgba(58, 208, 255, 0.95), rgba(26, 168, 219, 0.95));
  color: #021018;
  box-shadow: 0 8px 22px rgba(58, 208, 255, 0.25);
}

.btn--ghost {
  border-color: var(--line);
  color: var(--text-dim);
  background: rgba(15, 24, 38, 0.58);
}

.btn__spark {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}

.btn__spinner {
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: btnSpin 0.7s linear infinite;
}

@keyframes btnSpin {
  to {
    transform: rotate(360deg);
  }
}

.form {
  display: grid;
  gap: 10px;
}

.form__row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.form__row > .btn {
  flex: 1 1 180px;
}

.field {
  display: grid;
  gap: 5px;
}

.field__label {
  font-size: 0.84rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-soft);
  font-weight: 700;
}

.field__wrap {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.24);
  background: rgba(9, 15, 25, 0.7);
  overflow: hidden;
}

.field__wrap:focus-within {
  border-color: rgba(58, 208, 255, 0.55);
  box-shadow: 0 0 0 3px rgba(58, 208, 255, 0.15);
}

.field__ico {
  margin-left: 11px;
  margin-right: 8px;
  opacity: 0.82;
}

.field__wrap input,
.field__wrap select,
.field__wrap textarea {
  width: 100%;
  min-height: 44px;
  border: 0;
  background: transparent;
  color: #f6f8ff;
  padding: 10px 12px 10px 2px;
}

.field__wrap textarea {
  min-height: 90px;
  padding-left: 11px;
}

.field__wrap input::placeholder,
.field__wrap textarea::placeholder {
  color: rgba(174, 188, 215, 0.66);
}

.field__toggle {
  border: 0;
  background: transparent;
  height: 100%;
  width: 42px;
  display: grid;
  place-items: center;
  cursor: pointer;
  color: var(--text-soft);
}

.msg {
  margin-top: 2px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.28);
  background: rgba(11, 17, 28, 0.78);
  color: var(--text-dim);
  font-size: 0.95rem;
}

.msg.ok,
.msg--ok {
  border-color: rgba(96, 240, 162, 0.48);
  background: rgba(96, 240, 162, 0.13);
  color: #cbffdf;
}

.msg.err,
.msg--err {
  border-color: rgba(255, 111, 124, 0.5);
  background: rgba(255, 111, 124, 0.13);
  color: #ffd6db;
}

.news {
  display: grid;
  gap: 10px;
}

.news__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(174, 188, 215, 0.2);
  border-radius: 12px;
  padding: 10px;
  background: rgba(8, 14, 24, 0.45);
}

.news__tag {
  min-width: 66px;
  text-align: center;
  border-radius: 9px;
  padding: 4px 8px;
  border: 1px solid rgba(255, 191, 109, 0.45);
  color: #201102;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(95deg, var(--gold-1), var(--gold-2));
  font-weight: 800;
}

.news__txt {
  color: var(--text-dim);
}

.coins__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.stat {
  min-height: 96px;
  border-radius: 14px;
  border: 1px solid rgba(174, 188, 215, 0.2);
  background: rgba(8, 13, 22, 0.55);
  display: grid;
  place-items: center;
  gap: 4px;
}

.coinstat__k {
  color: var(--text-soft);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.72rem;
}

.coinstat__v {
  font-family: var(--font-tech);
  font-size: clamp(1.1rem, 3vw, 1.5rem);
  color: var(--gold-1);
}

.chars-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}

.charmini {
  border-radius: 16px;
  border: 1px solid rgba(174, 188, 215, 0.22);
  background:
    linear-gradient(180deg, rgba(22, 34, 55, 0.9), rgba(16, 26, 42, 0.96));
  padding: 12px;
  box-shadow: var(--shadow-sm);
}

.charmini__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.charmini__id {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.charmini__face {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.28);
  object-fit: cover;
  background: rgba(8, 14, 24, 0.75);
}

.charmini__name {
  font-family: var(--font-tech);
  font-size: 0.98rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.charmini__meta {
  margin-top: 3px;
  color: var(--text-soft);
  font-size: 0.82rem;
}

.charmini__actions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.charmini__actions .btn {
  flex: 1 1 160px;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(12, 20, 33, 0.76);
  color: var(--text-dim);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 700;
}

.badge--gold {
  color: #241500;
  border-color: rgba(255, 191, 109, 0.6);
  background: linear-gradient(95deg, var(--gold-1), var(--gold-2));
}

.badge--neon {
  color: #dff7ff;
  border-color: rgba(58, 208, 255, 0.55);
  background: rgba(58, 208, 255, 0.15);
}

.ranktools {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}

.ranktools__field {
  min-width: 0;
}

.ranktools__right {
  display: grid;
  gap: 10px;
}

.ranktools__btn {
  width: 100%;
}

.ranktools__limit select {
  cursor: pointer;
}

.ranklist {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.benefits-head {
  margin-bottom: 10px;
}

.benefits-title {
  font-family: var(--font-tech);
  font-size: 0.97rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.feature-grid {
  display: grid;
  gap: 10px;
}

.feature {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(174, 188, 215, 0.18);
  border-radius: 12px;
  padding: 10px;
  background: rgba(9, 15, 25, 0.46);
  color: var(--text-dim);
}

.modal-backdrop,
.welcome-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.68);
  backdrop-filter: blur(5px);
}

.modal-backdrop {
  z-index: 90;
}

.welcome-backdrop {
  z-index: 95;
}

.modal,
.welcome-modal,
.tools-modal,
.inv-modal {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(980px, calc(100vw - 20px));
  max-height: min(90vh, calc(100vh - 20px));
  overflow: auto;
  border-radius: 20px;
  border: 1px solid rgba(174, 188, 215, 0.26);
  background:
    linear-gradient(180deg, rgba(24, 37, 60, 0.97), rgba(16, 25, 42, 0.97));
  box-shadow: var(--shadow-lg);
  z-index: 96;
}

.modal {
  z-index: 91;
}

.modal__head,
.tools-modal__head,
.inv-modal__head,
.welcome-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid rgba(174, 188, 215, 0.18);
}

.modal__title,
.tools-modal__title,
.inv-modal__title,
.welcome-modal__title {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-tech);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.94rem;
}

/* Keep the close button visible while scrolling equipment on mobile */
#equipModal .modal__head {
  position: sticky;
  top: 0;
  z-index: 4;
  background: var(--panel);
}

#equipModal .modal__title {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#equipCloseBtn {
  flex: 0 0 auto;
}

#equipCloseBtn .ico {
  display: none;
}

#equipCloseBtn::before {
  content: "X";
  font-size: 1.45rem;
  line-height: 1;
  font-weight: 700;
}

#equipCharName {
  display: inline-block;
  max-width: min(46vw, 240px);
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
}

.modal__body,
.tools-modal__body,
.inv-modal__body,
.welcome-modal__body {
  padding: 14px;
}

.modal__foot,
.inv-modal__foot,
.welcome-modal__foot {
  padding: 14px;
  border-top: 1px solid rgba(174, 188, 215, 0.18);
}

.equip {
  display: grid;
  gap: 12px;
}

.equip__board {
  position: relative;
  width: 100%;
  aspect-ratio: 270 / 250;
  border-radius: 16px;
  border: 1px solid rgba(174, 188, 215, 0.25);
  overflow: hidden;
  background:
    url("img/inventory/equipment_bg.png") center/100% 100% no-repeat,
    radial-gradient(circle at 20% 12%, rgba(255, 191, 109, 0.16), transparent 54%),
    radial-gradient(circle at 85% 20%, rgba(58, 208, 255, 0.13), transparent 55%),
    rgba(9, 14, 25, 0.82);
}

.equip__slot {
  position: absolute;
  border-radius: 13px;
  border: 1px solid rgba(174, 188, 215, 0.25);
  background: rgba(5, 9, 16, 0.36);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.equip__slot:hover {
  transform: translateY(-1px);
  border-color: rgba(58, 208, 255, 0.55);
  box-shadow: 0 0 18px rgba(58, 208, 255, 0.18);
}

.equip__slot.is-selected {
  border-color: rgba(255, 191, 109, 0.7);
  box-shadow:
    0 0 0 1px rgba(255, 191, 109, 0.28),
    0 0 22px rgba(255, 191, 109, 0.2);
}

.equip__slot img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: pixelated;
  pointer-events: none;
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.55));
}

.equip__slotlbl {
  position: absolute;
  left: 50%;
  bottom: 5px;
  transform: translateX(-50%);
  border-radius: 999px;
  padding: 2px 6px;
  border: 1px solid rgba(174, 188, 215, 0.26);
  background: rgba(5, 9, 16, 0.78);
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-soft);
  opacity: 0;
  transition: opacity 120ms ease;
  pointer-events: none;
  white-space: nowrap;
}

.equip__slot:hover .equip__slotlbl,
.equip__slot.is-selected .equip__slotlbl {
  opacity: 1;
}

.equip__side {
  border-radius: 16px;
  border: 1px solid rgba(174, 188, 215, 0.22);
  background: rgba(10, 16, 26, 0.64);
  padding: 12px;
}

.equip__hint {
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.22);
  background: rgba(20, 31, 49, 0.64);
  padding: 10px;
  color: var(--text-dim);
}

.equip__info {
  margin-top: 10px;
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.2);
  background: rgba(8, 13, 22, 0.66);
  min-height: 170px;
  padding: 10px;
}

.equip__kv {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(174, 188, 215, 0.25);
}

.equip__kv:last-child {
  border-bottom: 0;
}

.equip__k {
  color: var(--text-soft);
  font-size: 0.9rem;
}

.equip__v {
  color: var(--text);
  font-weight: 700;
  text-align: right;
}

.equip__titleline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.equip__itemname {
  font-family: var(--font-tech);
  font-size: 0.94rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.equip__itemname.is-exc {
  color: var(--gold-1);
}

.equip__lvl {
  font-weight: 800;
  color: var(--mint);
}

.equip__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 8px 0;
}

.itag {
  border: 1px solid rgba(174, 188, 215, 0.3);
  border-radius: 999px;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: rgba(13, 20, 33, 0.8);
}

.itag--exc {
  border-color: rgba(255, 191, 109, 0.58);
  color: var(--gold-1);
}

.itag--anc {
  border-color: rgba(58, 208, 255, 0.52);
  color: #b7ecff;
}

.itag--luck {
  border-color: rgba(96, 240, 162, 0.5);
  color: #c7ffe0;
}

.itag--skill {
  border-color: rgba(255, 115, 71, 0.58);
  color: #ffd2c2;
}

.equip__subttl {
  margin-top: 8px;
  margin-bottom: 4px;
  font-family: var(--font-tech);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.78rem;
  color: var(--text-soft);
}

.equip__list {
  margin: 6px 0 0;
  padding-left: 18px;
  color: var(--text-dim);
}

.equip__slot[data-slot="8"] {
  left: 1.7%;
  top: 2%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="2"] {
  left: 38%;
  top: 2%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="7"] {
  left: 70%;
  top: 4%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="0"] {
  left: 1%;
  top: 36%;
  width: 27%;
  height: 30%;
}

.equip__slot[data-slot="3"] {
  left: 37%;
  top: 36%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="1"] {
  left: 73%;
  top: 38%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="5"] {
  left: 2%;
  top: 70%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="4"] {
  left: 37%;
  top: 70%;
  width: 26.7%;
  height: 28.8%;
}

.equip__slot[data-slot="6"] {
  left: 74.1%;
  top: 70%;
  width: 25.6%;
  height: 28.8%;
}

.equip__slot[data-slot="9"] {
  left: 25.5%;
  top: 31%;
  width: 13.3%;
  height: 14.4%;
  border-radius: 12px;
}

.equip__slot[data-slot="10"] {
  left: 25.9%;
  top: 69.4%;
  width: 14.8%;
  height: 16%;
  border-radius: 12px;
}

.equip__slot[data-slot="11"] {
  left: 61.4%;
  top: 70%;
  width: 14.8%;
  height: 16%;
  border-radius: 12px;
}

.packlist {
  display: grid;
  gap: 10px;
}

.pack-admin__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.pack-admin__meta {
  color: var(--text-soft);
  font-size: 0.82rem;
}

.pack-admin__rows {
  display: grid;
  gap: 10px;
}

.pack-admin__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
  border-radius: 14px;
  border: 1px solid rgba(174, 188, 215, 0.22);
  background: rgba(10, 16, 26, 0.64);
  padding: 12px;
}

.pack-admin__row .field {
  margin: 0;
}

.pack-admin__remove {
  min-width: 96px;
}

.pack-admin__empty {
  border-radius: 14px;
  border: 1px dashed rgba(174, 188, 215, 0.24);
  background: rgba(10, 16, 26, 0.42);
  color: var(--text-soft);
  padding: 12px;
}

.pack {
  border: 1px solid rgba(174, 188, 215, 0.24);
  border-radius: 14px;
  padding: 12px;
  background: rgba(11, 17, 28, 0.72);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.pack:hover {
  transform: translateY(-1px);
  border-color: rgba(58, 208, 255, 0.52);
}

.pack.is-selected {
  border-color: rgba(255, 191, 109, 0.64);
  box-shadow: 0 0 0 1px rgba(255, 191, 109, 0.2);
}

.pack__left {
  min-width: 0;
}

.pack__name {
  font-family: var(--font-tech);
  font-size: 0.96rem;
  text-transform: uppercase;
}

.pack__desc {
  margin-top: 4px;
  color: var(--text-soft);
  font-size: 0.84rem;
}

.pack__right {
  text-align: right;
}

.pack__price {
  color: var(--gold-1);
  font-family: var(--font-tech);
  font-size: 0.98rem;
}

.pack__priceUsd {
  margin-top: 2px;
  color: var(--text-soft);
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 800;
}

.pack__tag {
  color: var(--text-soft);
  font-size: 0.74rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.paygrid {
  display: grid;
  gap: 10px;
}

.paycard {
  border: 1px solid rgba(174, 188, 215, 0.22);
  border-radius: 14px;
  background: rgba(10, 16, 26, 0.64);
  padding: 12px;
}

.paycard__title {
  font-family: var(--font-tech);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 8px;
}

.payline {
  color: var(--text-dim);
  margin-bottom: 3px;
}

.welcome-modal {
  width: min(620px, calc(100vw - 20px));
  z-index: 98;
}

.welcome-modal__head {
  justify-content: center;
}

.welcome-modal__title {
  font-size: 1rem;
}

.welcome-modal__body {
  display: grid;
  place-items: center;
}

.welcome-modal__logo {
  width: min(82vw, 290px);
  max-height: 220px;
  object-fit: contain;
  filter: drop-shadow(0 18px 30px rgba(0, 0, 0, 0.55));
}

.tools-modal {
  width: min(640px, calc(100vw - 20px));
  z-index: 98;
}

.tools-modal__body {
  display: grid;
  place-items: center;
  gap: 10px;
  min-height: 230px;
}

.tools-note {
  max-width: 40ch;
  text-align: center;
  font-weight: 700;
  line-height: 1.35;
}

.tools-sub {
  text-align: center;
}

#toolsDownloadBtn,
#toolsModalMsg {
  width: min(100%, 420px);
}

.tools-clock {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  border: 1px solid rgba(174, 188, 215, 0.25);
  display: grid;
  place-items: center;
  background: rgba(9, 15, 25, 0.66);
  animation: spinClock 6s linear infinite;
}

@keyframes spinClock {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.tools-soon {
  font-family: var(--font-tech);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-1);
}

.download-modal__body {
  gap: 14px;
  min-height: 0;
}

.download-modal__cta-title {
  width: 100%;
  text-align: center;
  font-family: var(--font-tech);
  font-size: clamp(1.2rem, 3.1vw, 2rem);
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gold-2);
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.12);
}

.download-modal__imgbtn {
  width: clamp(180px, 42vw, 290px);
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}

.download-modal__img {
  width: 100%;
  height: 100%;
  object-fit: cover;

  border: 2px solid rgba(174, 188, 215, 0.35);
  background: rgba(9, 15, 25, 0.5);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.download-modal__imgbtn:hover .download-modal__img {
  transform: scale(1.02);
  border-color: rgba(255, 191, 109, 0.6);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.32);
}

.download-modal__imgbtn:active .download-modal__img {
  transform: scale(0.99);
}

.inv-modal {
  width: min(900px, calc(100vw - 20px));
  z-index: 98;
}

.inv-modal__head {
  align-items: center;
}

.inv-modal__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.inv-adminhint {
  font-size: 0.78rem;
  color: var(--text-soft);
}

.inv-list {
  display: grid;
  gap: 10px;
}

.inv {
  border: 1px solid rgba(174, 188, 215, 0.22);
  border-radius: 14px;
  overflow: hidden;
  background: rgba(10, 16, 26, 0.66);
}

.inv[open] {
  border-color: rgba(255, 191, 109, 0.48);
}

.inv__sum {
  list-style: none;
  cursor: pointer;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.inv__sum::-webkit-details-marker {
  display: none;
}

.inv__name {
  font-family: var(--font-tech);
  font-size: 0.92rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.inv__meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.inv__badge {
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(174, 188, 215, 0.3);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(13, 21, 33, 0.8);
}

.inv__badge--empty {
  color: var(--text-soft);
}

.inv__badge--soon {
  border-color: rgba(58, 208, 255, 0.52);
  color: #c8f1ff;
  background: rgba(58, 208, 255, 0.16);
}

.inv__badge--active {
  border-color: rgba(96, 240, 162, 0.58);
  color: #cbffe0;
  background: rgba(96, 240, 162, 0.16);
}

.inv__next {
  color: var(--text-soft);
  font-size: 0.78rem;
}

.inv__body {
  padding: 0 12px 12px;
}

.inv__thumbWrap {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(174, 188, 215, 0.24);
  max-height: 200px;
}

.inv__thumb {
  width: 100%;
  max-height: 200px;
  object-fit: cover;
}

.inv__info,
.inv__schedule,
.inv__timer {
  margin-top: 10px;
}

.inv__count {
  font-family: var(--font-tech);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
}

.inv__count.is-active {
  color: #cbffe0;
}

.inv__progress {
  margin-top: 6px;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(11, 17, 27, 0.9);
  border: 1px solid rgba(174, 188, 215, 0.22);
  overflow: hidden;
}

.inv__bar {
  width: 0;
  height: 100%;
  background: linear-gradient(90deg, rgba(58, 208, 255, 0.95), rgba(96, 240, 162, 0.95));
  transition: width 0.95s linear;
}

.inv__bar.is-active {
  background: linear-gradient(90deg, rgba(96, 240, 162, 1), rgba(255, 191, 109, 0.98));
}

.inv__map {
  margin-top: 6px;
  color: var(--text-soft);
  font-size: 0.84rem;
}

.inv__admin {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.inv__edit {
  border-radius: 12px;
  border: 1px solid rgba(174, 188, 215, 0.22);
  background: rgba(7, 12, 20, 0.72);
  padding: 8px;
}

.inv-input-info,
.inv-input-img {
  width: 100%;
}

.inv__edit .form__row {
  margin-top: 8px;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: calc(14px + var(--safe-bottom));
  transform: translateX(-50%);
  z-index: 100;
  border-radius: 999px;
  border: 1px solid rgba(255, 191, 109, 0.5);
  background: rgba(10, 16, 27, 0.92);
  color: var(--text);
  padding: 10px 14px;
  box-shadow: var(--shadow-md);
}

.footer {
  border-top: 1px solid rgba(174, 188, 215, 0.16);
  background: rgba(10, 15, 25, 0.68);
  backdrop-filter: blur(6px);
}

.footer__inner {
  width: min(1260px, calc(100% - 2.2rem));
  margin: 0 auto;
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.footer__links {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.link {
  color: var(--text-dim);
  text-decoration: none;
  border: 1px solid rgba(174, 188, 215, 0.24);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.76rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.link:hover {
  border-color: rgba(255, 191, 109, 0.45);
  color: #fff;
}

.left-floater,
.right-floater {
  position: fixed;
  bottom: 8px;
  width: min(22vw, 240px);
  aspect-ratio: 1 / 1.6;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom;
  pointer-events: none;
  opacity: 0.18;
  z-index: -1;
}

.left-floater {
  left: -24px;
  background-image: url("izquierda.webp");
  animation: floaterL 6s ease-in-out infinite;
}

.right-floater {
  right: -24px;
  background-image: url("derecha.webp");
  animation: floaterR 7s ease-in-out infinite;
}

@keyframes floaterL {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

@keyframes floaterR {
  0%,
  100% {
    transform: translateY(-2px);
  }
  50% {
    transform: translateY(8px);
  }
}

.reveal {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 380ms ease, transform 380ms ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal.is-visible:nth-of-type(2) {
  transition-delay: 45ms;
}

.reveal.is-visible:nth-of-type(3) {
  transition-delay: 90ms;
}

.reveal.is-visible:nth-of-type(4) {
  transition-delay: 130ms;
}

@media (min-width: 760px) {
  .main {
    margin-top: 32px;
  }

  .chars-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .paygrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ranktools {
    grid-template-columns: 1fr auto;
    align-items: end;
  }

  .ranktools__right {
    grid-template-columns: auto auto;
    align-items: end;
  }
}

@media (min-width: 900px) {
  .grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .chars-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ranklist .charmini {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .ranklist .charmini__top {
    margin: 0;
    flex: 1 1 auto;
  }

  .ranklist .charmini__actions {
    margin: 0;
    width: 240px;
    justify-content: flex-end;
  }
}

@media (min-width: 1080px) {
  .chars-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .equip {
    grid-template-columns: 1.06fr 0.94fr;
  }
}

@media (min-width: 980px) {
  #menuBtn {
    display: none;
  }
}

@media (max-width: 979px) {
  .sidenav {
    display: none;
  }

  .main {
    width: min(1260px, calc(100% - 1.1rem));
    margin-top: 16px;
  }
}

@media (max-width: 760px) {
  body {
    font-size: 17px;
  }

  .topbar {
    padding-left: 12px;
    padding-right: 12px;
  }

  .brand__sub {
    display: none;
  }

  .hero {
    border-radius: 18px;
  }

  .card {
    padding: 13px;
  }

  .coins__stats {
    grid-template-columns: 1fr;
  }

  .form__row {
    flex-direction: column;
  }

  .form__row > .btn {
    width: 100%;
  }

  .footer__inner {
    min-height: 78px;
    padding-top: 8px;
    padding-bottom: 8px;
    flex-direction: column;
    justify-content: center;
  }

  .left-floater,
  .right-floater {
    display: none;
  }
}

@media (max-width: 560px) {
  .modal,
  .welcome-modal,
  .tools-modal,
  .inv-modal {
    left: 50%;
    top: calc(5px + var(--safe-top));
    transform: translateX(-50%);
    width: calc(100vw - 10px);
    max-height: calc(100dvh - var(--safe-top) - var(--safe-bottom) - 10px);
    border-radius: 14px;
  }

  #welcomeModal {
    top: 50%;
    transform: translate(-50%, -50%);
  }

  #equipModal {
    width: calc(100vw - 16px);
    max-height: calc(100dvh - var(--safe-top) - var(--safe-bottom) - 16px);
  }

  #equipModal .equip {
    gap: 10px;
  }

  #equipModal .equip__side {
    padding: 10px;
  }

  #equipModal .equip__info {
    min-height: 140px;
  }

  .modal__head,
  .modal__body,
  .modal__foot,
  .inv-modal__head,
  .inv-modal__body,
  .inv-modal__foot,
  .welcome-modal__head,
  .welcome-modal__body,
  .welcome-modal__foot,
  .tools-modal__head,
  .tools-modal__body {
    padding: 10px;
  }

  .charmini__face {
    width: 56px;
    height: 56px;
  }

  .pack-admin__row {
    grid-template-columns: 1fr;
  }

  .pack-admin__remove {
    width: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
  }

  .reveal {
    opacity: 1 !important;
    transform: none !important;
  }
}

.brand__txt {
  display: grid;
}

.title__ico {
  width: 48px;
  height: 48px;
}

.drawer__ico {
  width: 54px;
  height: 54px;
}

.sidenav__ico {
  width: 56px;
  height: 56px;
}

.ico--check,
.ico--clock {
  width: 16px;
  height: 16px;
}

.card--tilt {
  transform-style: preserve-3d;
  will-change: transform;
}

.coinstat {
  position: relative;
}

.info-stats,
.info-events {
  display: grid;
  gap: 6px;
}

.inv-edit,
.inv-save,
.inv-cancel {
  min-width: 120px;
}

/* =========================================================
   Mu Gold Age Rebuild Theme
   ========================================================= */

:root {
  --bg-0: #f8edd5;
  --bg-1: #efdeba;
  --bg-2: #e5cfa1;
  --panel: #fff4dd;
  --panel-strong: #f3ddad;
  --panel-soft: #f8e9c9;
  --line: rgba(88, 49, 12, 0.26);
  --line-strong: rgba(158, 96, 28, 0.54);

  --text: #241404;
  --text-dim: #513118;
  --text-soft: #785335;

  --gold-1: #fff0b2;
  --gold-2: #efbe61;
  --gold-3: #ab6f28;
  --ember: #c7611f;
  --aqua: #b56f24;
  --mint: #2f7f4c;

  --danger: #b42b23;
  --ok: #2f7f4c;

  --shadow-sm: 0 8px 22px rgba(64, 33, 7, 0.14);
  --shadow-md: 0 18px 45px rgba(64, 33, 7, 0.2);
  --shadow-lg: 0 30px 80px rgba(64, 33, 7, 0.26);

  --font-ui: "Bai Jamjuree", "Trebuchet MS", sans-serif;
  --font-head: "Cinzel", Georgia, serif;
  --font-tech: "Cormorant Garamond", Georgia, serif;
}

body {
  color: var(--text);
  background:
    radial-gradient(1300px 520px at -3% -10%, rgba(255, 219, 150, 0.9), transparent 62%),
    radial-gradient(980px 520px at 105% -8%, rgba(161, 94, 21, 0.22), transparent 60%),
    radial-gradient(1280px 560px at 50% 118%, rgba(150, 84, 22, 0.13), transparent 74%),
    linear-gradient(180deg, var(--bg-0) 0%, var(--bg-1) 48%, var(--bg-2) 100%);
  background-attachment: scroll;
}

body::before {
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.36), transparent 25%),
    linear-gradient(-120deg, rgba(173, 111, 46, 0.13), transparent 30%),
    repeating-linear-gradient(
      0deg,
      rgba(117, 71, 24, 0.05) 0 2px,
      transparent 2px 28px
    );
}

body::after {
  background-image:
    radial-gradient(circle, rgba(255, 255, 255, 0.28) 1px, transparent 1px),
    radial-gradient(circle, rgba(164, 102, 34, 0.22) 1px, transparent 1px);
  background-size: 140px 140px, 220px 220px;
  opacity: 0.38;
}

.fx-overlay {
  background:
    radial-gradient(900px 380px at 12% 14%, rgba(249, 206, 132, 0.16), transparent 62%),
    radial-gradient(1000px 410px at 88% 16%, rgba(182, 104, 33, 0.13), transparent 64%),
    repeating-linear-gradient(
      90deg,
      rgba(102, 61, 26, 0.035) 0 1px,
      transparent 1px 24px
    );
  mix-blend-mode: multiply;
}

.topbar {
  background:
    linear-gradient(180deg, rgba(51, 27, 7, 0.93), rgba(35, 18, 6, 0.9)),
    radial-gradient(circle at 18% -20%, rgba(255, 219, 150, 0.18), transparent 60%);
  border-bottom: 1px solid rgba(255, 211, 141, 0.2);
}

.userpill {
  border-color: rgba(255, 216, 146, 0.38);
  background: rgba(255, 220, 149, 0.14);
}

.userpill__name {
  color: #ffe3bb;
}

.iconbtn {
  border-color: rgba(106, 62, 22, 0.32);
  background: rgba(255, 246, 222, 0.92);
  color: #4a2a11;
}

.topbar .iconbtn,
.drawer .iconbtn {
  border-color: rgba(255, 216, 147, 0.36);
  background: rgba(255, 224, 160, 0.12);
  color: #ffe6be;
}

.iconbtn__lines,
.iconbtn__lines::before,
.iconbtn__lines::after {
  background: currentColor;
}

.brand__mark {
  border-color: rgba(255, 214, 142, 0.52);
  background:
    linear-gradient(145deg, rgba(255, 219, 149, 0.36), rgba(128, 71, 24, 0.2)),
    rgba(30, 17, 7, 0.9);
  color: #ffd89c;
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  display: grid;
  place-items: center;
}

.brand__mark::before {
  display: none;
}

.brand__title {
  color: #ffe4bb;
}

.brand__sub {
  color: rgba(255, 219, 152, 0.74);
}

.sidenav__item {
  border: 1px solid rgba(86, 48, 16, 0.28);
  background:
    linear-gradient(140deg, rgba(255, 240, 204, 0.88), rgba(247, 224, 171, 0.86));
  color: #53331a;
}

.sidenav__item:hover {
  border-color: rgba(168, 101, 29, 0.56);
  color: #2f1a07;
}

.sidenav__item.is-active {
  border-color: rgba(168, 101, 29, 0.7);
  color: #1f1205;
  box-shadow:
    0 0 0 1px rgba(168, 101, 29, 0.24),
    0 14px 28px rgba(71, 35, 8, 0.2);
}

.drawer {
  background:
    linear-gradient(180deg, rgba(48, 26, 8, 0.96), rgba(29, 16, 6, 0.97));
  border-left-color: rgba(255, 216, 149, 0.2);
}

.drawer__title {
  color: #ffe2b3;
}

.drawer__link {
  border-color: rgba(255, 220, 159, 0.2);
  background: rgba(255, 225, 163, 0.08);
  color: #efd5ac;
}

.drawer__link.is-active {
  border-color: rgba(255, 215, 140, 0.58);
  background: rgba(255, 221, 163, 0.16);
  color: #fff5e4;
}

.hero {
  border: 1px solid rgba(167, 100, 29, 0.34);
  background:
    linear-gradient(125deg, rgba(255, 214, 145, 0.26), transparent 40%),
    linear-gradient(-140deg, rgba(128, 67, 24, 0.24), transparent 35%),
    linear-gradient(180deg, rgba(77, 42, 16, 0.9), rgba(43, 24, 10, 0.95));
}

.hero::before {
  background:
    radial-gradient(circle at 82% 8%, rgba(255, 211, 139, 0.3), transparent 38%),
    linear-gradient(95deg, transparent 30%, rgba(255, 255, 255, 0.08) 50%, transparent 65%);
}

.hero__title,
.hero__lead {
  color: #fbe8ca;
}

.hero__lead {
  max-width: 65ch;
}

.hero__actions {
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hero__actions .btn {
  min-width: 180px;
}

.hero__badge {
  border-color: rgba(255, 218, 150, 0.4);
  background: rgba(22, 12, 4, 0.46);
  color: rgba(255, 226, 174, 0.9);
}

.card {
  border: 1px solid rgba(88, 49, 12, 0.25);
  background:
    linear-gradient(180deg, rgba(255, 245, 219, 0.93), rgba(246, 224, 176, 0.94)),
    var(--panel);
  box-shadow: var(--shadow-md);
}

.card::before {
  background: linear-gradient(130deg, rgba(196, 124, 35, 0.14), transparent 34%);
}

.card:hover {
  border-color: rgba(167, 100, 29, 0.52);
  box-shadow:
    0 0 0 1px rgba(167, 100, 29, 0.16),
    0 26px 58px rgba(64, 33, 7, 0.24);
}

.card--vip {
  border-color: rgba(141, 76, 27, 0.44);
  background:
    linear-gradient(140deg, rgba(255, 219, 147, 0.22), transparent 40%),
    linear-gradient(180deg, rgba(247, 232, 199, 0.95), rgba(239, 212, 160, 0.95));
}

.card__title {
  color: #4c2c13;
}

.muted {
  color: var(--text-dim);
}

.pill {
  border: 1px solid rgba(106, 62, 22, 0.32);
  background: rgba(255, 249, 236, 0.82);
  color: #684020;
}

.pill--gold {
  color: #2f1a05;
  border-color: rgba(167, 100, 29, 0.66);
}

.pill--neon {
  border-color: rgba(118, 75, 36, 0.5);
  color: #532f15;
  background: rgba(173, 109, 48, 0.2);
}

.btn {
  border: 1px solid rgba(95, 57, 20, 0.38);
  background: linear-gradient(180deg, rgba(252, 242, 216, 0.98), rgba(245, 225, 179, 0.95));
  color: #41250d;
  font-family: var(--font-ui);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.btn--primary {
  border-color: rgba(166, 98, 28, 0.64);
  color: #2e1905;
  background: linear-gradient(100deg, #ffe7b2, #e4a844);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.25),
    0 8px 20px rgba(170, 102, 30, 0.26);
}

.btn--neon,
.btn--ghost {
  border-color: rgba(114, 69, 29, 0.42);
  color: #4c2b12;
  background: rgba(255, 244, 217, 0.92);
}

.field__label {
  color: #7e5535;
}

.field__wrap {
  border: 1px solid rgba(99, 59, 23, 0.28);
  background: rgba(255, 249, 236, 0.82);
}

.field__wrap:focus-within {
  border-color: rgba(167, 100, 29, 0.55);
  box-shadow: 0 0 0 3px rgba(167, 100, 29, 0.16);
}

.field__wrap input,
.field__wrap select,
.field__wrap textarea {
  color: #2b1a07;
}

.field__wrap input::placeholder,
.field__wrap textarea::placeholder {
  color: rgba(104, 66, 35, 0.72);
}

.msg {
  border: 1px solid rgba(106, 63, 21, 0.3);
  background: rgba(255, 243, 210, 0.72);
  color: #553317;
}

.news__item,
.feature,
.stat,
.charmini,
.paycard,
.pack {
  border-color: rgba(99, 59, 23, 0.24);
  background: rgba(255, 249, 236, 0.8);
}

.news__tag {
  color: #2b1604;
}

.coinstat__v {
  color: #925514;
}

.charmini__face {
  border-color: rgba(104, 63, 25, 0.28);
  background: rgba(248, 229, 186, 0.64);
}

.charmini__meta,
.coinstat__k,
.badge,
.equip__k,
.equip__subttl {
  color: #6b4528;
}

.badge {
  background: rgba(255, 248, 228, 0.84);
}

.badge--neon {
  color: #533214;
  border-color: rgba(106, 66, 29, 0.45);
  background: rgba(200, 142, 67, 0.18);
}

.modal,
.welcome-modal,
.tools-modal,
.inv-modal {
  border: 1px solid rgba(103, 61, 22, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 245, 219, 0.98), rgba(243, 220, 170, 0.96));
}

.modal__title,
.tools-modal__title,
.inv-modal__title,
.welcome-modal__title {
  color: #4b2b12;
}

.equip__board {
  border: 1px solid rgba(120, 74, 31, 0.5);
  background:
    url("img/inventory/equipment_bg.png") center/100% 100% no-repeat,
    radial-gradient(circle at 20% 12%, rgba(255, 211, 139, 0.2), transparent 54%),
    radial-gradient(circle at 85% 20%, rgba(143, 84, 26, 0.2), transparent 55%),
    rgba(73, 41, 15, 0.86);
}

.equip__slot {
  border-color: rgba(255, 232, 188, 0.34);
  background: rgba(43, 24, 8, 0.46);
}

.equip__slot:hover {
  border-color: rgba(255, 208, 129, 0.62);
  box-shadow: 0 0 18px rgba(255, 211, 138, 0.3);
}

.equip__slotlbl {
  border-color: rgba(255, 228, 177, 0.26);
  background: rgba(23, 12, 4, 0.74);
  color: #f5d9a5;
}

.equip__side,
.equip__hint,
.equip__info,
.inv,
.inv__edit,
.inv__progress {
  border-color: rgba(98, 60, 24, 0.26);
  background: rgba(255, 247, 229, 0.84);
}

.inv__name,
.pack__name,
.paycard__title {
  color: #4d2e15;
}

.inv__bar {
  background: linear-gradient(90deg, rgba(182, 110, 36, 0.94), rgba(223, 167, 75, 0.95));
}

.inv__bar.is-active {
  background: linear-gradient(90deg, rgba(91, 130, 47, 0.95), rgba(225, 170, 78, 0.96));
}

.toast {
  border: 1px solid rgba(167, 100, 29, 0.58);
  background: rgba(50, 27, 9, 0.92);
  color: #ffecce;
}

.footer {
  border-top: 1px solid rgba(103, 61, 22, 0.22);
  background: rgba(244, 228, 190, 0.66);
}

.link {
  color: #623c1f;
  border: 1px solid rgba(106, 63, 21, 0.24);
  background: rgba(255, 247, 226, 0.72);
}

.link:hover {
  border-color: rgba(167, 100, 29, 0.56);
  color: #2e1a08;
}

.left-floater,
.right-floater {
  opacity: 0.24;
}

@media (max-width: 760px) {
  .hero__actions .btn {
    width: 100%;
  }
}

/* =========================================================
   Contrast + Hover Upgrade
   Inspired by MDN transition/transform/box-shadow patterns
   and Hover.css interaction style.
   ========================================================= */

:root {
  --text: #1b0f04;
  --text-dim: #37200d;
  --text-soft: #57361a;
}

body,
.field__wrap input,
.field__wrap select,
.field__wrap textarea {
  color: var(--text);
}

.muted,
.pagehead__sub,
.hero__lead,
.news__txt,
.payline,
.inv__next,
.inv-adminhint,
.coinstat__k,
.charmini__meta,
.field__label,
.equip__k,
.equip__subttl {
  color: var(--text-dim);
}

.card__title,
.benefits-title,
.pagehead__title,
.modal__title,
.tools-modal__title,
.inv-modal__title,
.welcome-modal__title,
.pack__name,
.paycard__title {
  color: #41240d;
}

.sidenav__label,
.link {
  color: #4b2b12;
}

.drawer__txt {
  color: inherit;
}

.badge,
.pill,
.msg {
  color: #44260f;
}

.brand__mark {
  transition: transform 280ms ease, box-shadow 280ms ease, border-color 280ms ease;
}

.brand:hover .brand__mark {
  transform: translateY(-1px) rotate(-5deg) scale(1.06);
  border-color: rgba(255, 217, 147, 0.72);
  box-shadow:
    inset 0 0 0 1px rgba(255, 248, 220, 0.24),
    0 16px 34px rgba(44, 23, 7, 0.38);
}

.topbar .btn--ghost {
  color: #ffe8c6;
  border-color: rgba(255, 218, 148, 0.34);
  background: rgba(255, 223, 157, 0.1);
}

.sidenav__item,
.drawer__link,
.link,
.btn,
.news__item,
.feature,
.stat,
.charmini,
.pack,
.paycard,
.inv {
  transition:
    transform 250ms ease,
    box-shadow 250ms ease,
    border-color 250ms ease,
    background-color 250ms ease,
    color 250ms ease;
}

.card,
.charmini,
.pack,
.news__item,
.feature {
  position: relative;
  overflow: hidden;
}

.card::after,
.charmini::after,
.pack::after,
.news__item::after,
.feature::after {
  content: "";
  position: absolute;
  top: 0;
  left: -140%;
  width: 68%;
  height: 100%;
  transform: skewX(-18deg);
  background: linear-gradient(110deg, transparent 0%, rgba(255, 255, 255, 0.42) 45%, transparent 100%);
  pointer-events: none;
  transition: left 520ms ease;
  z-index: 0;
}

.charmini > *,
.pack > *,
.news__item > *,
.feature > * {
  position: relative;
  z-index: 1;
}

.card:hover::after,
.charmini:hover::after,
.pack:hover::after,
.news__item:hover::after,
.feature:hover::after {
  left: 155%;
}

.card:hover,
.charmini:hover,
.pack:hover,
.news__item:hover,
.feature:hover,
.stat:hover,
.paycard:hover,
.inv:hover {
  transform: translateY(-4px);
  border-color: rgba(166, 96, 25, 0.48);
  box-shadow: 0 18px 34px rgba(66, 34, 8, 0.2);
}

.sidenav__item,
.drawer__link {
  position: relative;
  overflow: hidden;
}

.sidenav__item::before,
.drawer__link::before {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 3px;
  background: linear-gradient(90deg, #eab053, #fff0bc);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 220ms ease;
}

.sidenav__item:hover::before,
.drawer__link:hover::before,
.sidenav__item.is-active::before,
.drawer__link.is-active::before {
  transform: scaleX(1);
}

.sidenav__item .ico,
.drawer__link .ico,
.btn .ico,
.card__title .ico {
  transition: transform 220ms ease, filter 220ms ease;
}

.sidenav__item:hover .ico,
.drawer__link:hover .ico {
  transform: translateX(2px) scale(1.08);
}

.btn:hover .ico {
  transform: translateX(3px) scale(1.04);
}

.card:hover .card__title .ico {
  transform: translateY(-2px) rotate(-7deg);
}

.btn {
  will-change: transform;
}

.btn:hover {
  transform: translateY(-2px) scale(1.01);
}

.btn:active {
  transform: translateY(0) scale(0.985);
}

.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 0 0 0 rgba(255, 255, 255, 0.42);
  transition: box-shadow 220ms ease;
}

.btn:hover::before {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.36);
}

.link {
  position: relative;
  overflow: hidden;
}

.link::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 4px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(172, 100, 28, 0.9), rgba(255, 233, 182, 0.95));
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 220ms ease;
}

.link:hover::after {
  transform: scaleX(1);
}

.pagehead__title {
  position: relative;
  padding-bottom: 8px;
}

.pagehead__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: clamp(64px, 9vw, 120px);
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #b06e2a, #ffe9ba);
  transform-origin: left;
  transform: scaleX(0.45);
  transition: transform 280ms ease;
}

.view.is-active .pagehead__title::after,
.pagehead__title:hover::after {
  transform: scaleX(1);
}

.stat:hover .coinstat__v,
.charmini:hover .charmini__name,
.pack:hover .pack__price {
  color: #7e4a16;
}

.inv[open] .inv__sum,
.inv:hover .inv__sum {
  background: rgba(232, 198, 136, 0.18);
}

.field__wrap:hover {
  border-color: rgba(162, 96, 26, 0.5);
}

/* Welcome title readability fix */
.welcome-modal__title {
  padding: 8px 12px;
  border-radius: 12px;
  border: 1px solid rgba(113, 67, 25, 0.34);
  background: rgba(255, 240, 205, 0.84);
  color: #3a200c;
}

.welcome-modal__title .gold {
  background: linear-gradient(100deg, #6a3b14 0%, #a36624 52%, #f2ca7d 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 1px 0 rgba(255, 248, 232, 0.45), 0 2px 7px rgba(76, 38, 10, 0.22);
}

/* Invasions badge readability fix */
.inv__badge--soon {
  color: #321b08;
  border-color: rgba(135, 77, 24, 0.66);
  background: linear-gradient(95deg, #ffe4ad, #e9b35c);
  font-weight: 800;
  text-shadow: none;
}

/* Extra spacing between chronicles cards and guard mandates */
#view-informacion .grid + .card {
  margin-top: 24px;
}

/* Home layout spacing: separate stacked cards and inner stat boxes */
#view-inicio > .grid + .card,
#view-inicio > .card + .card {
  margin-top: 18px;
}

#view-inicio .coins__stats {
  gap: 12px;
}

#view-inicio .chars-grid {
  gap: 14px;
}

/* Make account character portraits much larger */
#accountArea .charmini__face {
  width: 124px;
  height: 124px;
  border-radius: 14px;
}

#accountArea .charmini__id {
  gap: 14px;
}

#accountArea .charmini__name {
  font-size: 1.24rem;
  font-weight: 900;
  letter-spacing: 0.02em;
}

@media (max-width: 560px) {
  #accountArea .charmini__face {
    width: 100px;
    height: 100px;
  }

  #accountArea .charmini__name {
    font-size: 1.08rem;
  }
}

/* Emoji readability fix on light backgrounds */
#view-informacion .equip__k,
#view-informacion .equip__v {
  font-family:
    "Bai Jamjuree",
    "Segoe UI Emoji",
    "Apple Color Emoji",
    "Noto Color Emoji",
    "Segoe UI Symbol",
    sans-serif;
  font-variant-emoji: emoji;
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.25),
    0 0 1px rgba(46, 26, 10, 0.38);
}

/* Packs modal readability fix */
#packsModal .modal__title {
  color: #3b220d;
  font-family: var(--font-ui);
  font-weight: 900;
  letter-spacing: 0.05em;
}

#packsModal .modal__title .gold {
  background: linear-gradient(100deg, #5f3411 0%, #9b5d21 55%, #d69a4f 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 1px 0 rgba(255, 245, 224, 0.4);
}

#packsModal .pack {
  border-color: rgba(122, 73, 28, 0.34);
  background: rgba(255, 247, 230, 0.92);
}

#packsModal .modal__body > .muted {
  color: #4b2a12;
  font-size: 1.08rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

#packsModal .pack__name {
  color: #3c230f;
  font-family:
    "Bai Jamjuree",
    "Trebuchet MS",
    sans-serif;
  font-size: 1.04rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-transform: uppercase;
}

#packsModal .pack__desc,
#packsModal .pack__tag {
  color: #5a391e;
  font-family:
    "Bai Jamjuree",
    "Trebuchet MS",
    sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
}

#packsModal .pack__price {
  color: #7f4616;
  font-family:
    "Bai Jamjuree",
    "Trebuchet MS",
    sans-serif;
  font-size: 1.02rem;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-shadow: 0 1px 0 rgba(255, 248, 232, 0.38);
}

#packsModal .pack__priceUsd {
  color: #6a421f;
  font-family:
    "Bai Jamjuree",
    "Trebuchet MS",
    sans-serif;
  font-size: 0.94rem;
  font-weight: 900;
  letter-spacing: 0.01em;
}

#packsModal .pack__desc {
  font-size: 0.96rem;
  line-height: 1.35;
}

#packsModal .pack__tag {
  font-size: 0.82rem;
  font-weight: 800;
}

#packsModal .pack:hover {
  border-color: rgba(160, 94, 31, 0.62);
  box-shadow: 0 14px 26px rgba(74, 39, 10, 0.16);
}

#packsModal .pack.is-selected {
  border-color: rgba(141, 83, 28, 0.78);
  box-shadow:
    0 0 0 1px rgba(141, 83, 28, 0.24),
    0 14px 28px rgba(67, 35, 10, 0.2);
}

#packsEditModal .field__label,
#packsEditModal .pack-admin__meta,
#packsEditModal .pack-admin__empty {
  font-family:
    "Bai Jamjuree",
    "Trebuchet MS",
    sans-serif;
  font-weight: 700;
}

/* Global readability pass for light theme */
.modal__title .gold,
.tools-modal__title .gold,
.inv-modal__title .gold {
  background: linear-gradient(100deg, #603512 0%, #9f6125 55%, #d8a15a 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 1px 0 rgba(255, 247, 228, 0.4);
}

.msg.ok,
.msg--ok {
  border-color: rgba(110, 147, 74, 0.5);
  background: rgba(136, 182, 92, 0.22);
  color: #2c4b1d;
}

.msg.err,
.msg--err {
  border-color: rgba(160, 74, 52, 0.5);
  background: rgba(196, 103, 79, 0.2);
  color: #5e2417;
}

.inv__badge--active {
  border-color: rgba(95, 135, 56, 0.62);
  color: #2f5120;
  background: rgba(140, 190, 98, 0.26);
  font-weight: 800;
}

.inv__count.is-active {
  color: #2d5c2d;
  text-shadow: 0 1px 0 rgba(255, 248, 235, 0.36);
}

.equip__itemname.is-exc {
  color: #713f14;
}

.itag--exc {
  border-color: rgba(138, 81, 30, 0.56);
  color: #5a3210;
  background: rgba(229, 188, 116, 0.25);
}

.itag--anc {
  border-color: rgba(92, 130, 160, 0.52);
  color: #284c67;
  background: rgba(137, 173, 201, 0.2);
}

.itag--luck {
  border-color: rgba(79, 128, 68, 0.56);
  color: #2d5c2c;
  background: rgba(138, 191, 123, 0.2);
}

.itag--skill {
  border-color: rgba(161, 86, 50, 0.56);
  color: #652f14;
  background: rgba(214, 140, 98, 0.2);
}

.tools-soon {
  color: #6b3f17;
}

.pack__price {
  color: #7f4616;
  font-weight: 900;
}

.payline b {
  color: #2f1a0a;
}

.sidenav__item .ico,
.card .ico,
.news__item .ico,
.feature .ico,
.stat .ico,
.charmini .ico,
.pack .ico,
.paycard .ico,
.modal .ico,
.welcome-modal .ico,
.tools-modal .ico,
.inv-modal .ico,
.field__ico,
.btn .ico {
  filter: brightness(0) saturate(100%);
}

.tools-clock .ico,
.topbar .ico,
.drawer .ico,
.topbar .btn .ico,
.drawer .btn .ico {
  filter: brightness(0) saturate(100%) invert(1);
}

/* Preserve original colors for custom PNG navigation icons */
.ico--native {
  filter: none !important;
}

/* Welcome title final readability + size boost */
#welcomeModal .welcome-modal__title {
  font-size: clamp(1.18rem, 3.2vw, 1.72rem);
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1.15;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid rgba(123, 73, 27, 0.44);
  background:
    linear-gradient(180deg, rgba(255, 244, 216, 0.98), rgba(244, 220, 171, 0.96));
  color: #301a09;
  box-shadow: 0 6px 18px rgba(87, 46, 12, 0.18);
}

#welcomeModal .welcome-modal__title .gold {
  background: linear-gradient(100deg, #2f1808 0%, #633817 55%, #8e5523 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow:
    0 1px 0 rgba(255, 244, 220, 0.18),
    0 2px 7px rgba(54, 26, 7, 0.45);
}

#welcomeModal .welcome-modal__title .ico--title {
  width: 24px;
  height: 24px;
}

/* Hotfix: welcome banner text stability */
#welcomeModal .welcome-modal__head {
  justify-content: center;
}

#welcomeModal .welcome-modal__title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  max-width: min(96%, 620px);
  text-align: center;
  white-space: normal;
  word-break: normal;
}

#welcomeModal .welcome-modal__title .gold {
  display: inline-block;
  line-height: 1.12;
}

@media (max-width: 560px) {
  #welcomeModal .welcome-modal__title {
    font-size: clamp(1.02rem, 5vw, 1.28rem);
    letter-spacing: 0.03em;
    padding: 9px 12px;
  }
}

/* Stabilize background layers to avoid visual seams */
body::before,
body::after {
  inset: 0;
  animation: none;
  transform: none;
}

/* Hero intro readability on dark banner */
#view-inicio .hero__lead {
  color: #f6dca8;
  text-shadow:
    0 1px 0 rgba(31, 15, 5, 0.45),
    0 2px 10px rgba(18, 9, 3, 0.45);
}

/* Side character art: fullscreen height, aligned to main box edges */
:root {
  --main-box-w: min(1260px, calc(100vw - 2.2rem));
  --side-art-w: clamp(360px, 34vw, 760px);
  --side-art-inset-left: 98px;
  --side-art-inset-right: 88px;
  --side-art-left-drop: -18px;
}

.left-floater,
.right-floater {
  bottom: 0;
  width: var(--side-art-w);
  height: 100dvh;
  aspect-ratio: auto;
  background-size: auto 100%;
  background-position: center bottom;
  opacity: 0.38;
  z-index: -1;
}

.left-floater {
  left: calc((100vw - var(--main-box-w)) / 2 - var(--side-art-w) + var(--side-art-inset-left));
  bottom: var(--side-art-left-drop);
}

.right-floater {
  right: calc((100vw - var(--main-box-w)) / 2 - var(--side-art-w) + var(--side-art-inset-right));
}

/* Keep root canvas non-white without duplicating layered gradients */
html {
  background-color: var(--bg-2);
}

body {
  min-height: 100dvh;
}

/* Keep content above side art while side art stays above background layers */
.main,
.footer {
  position: relative;
}

/* Invasiones hover fx: purple + gold glow + moving water */
@keyframes invWaterFlow {
  0% {
    transform: translate3d(-12%, -8%, 0) scale(1);
    background-position: 0 0, 0 0, 0 0;
  }
  50% {
    transform: translate3d(8%, 6%, 0) scale(1.06);
    background-position: 140px 70px, -120px 60px, 0 90px;
  }
  100% {
    transform: translate3d(-12%, -8%, 0) scale(1);
    background-position: 280px 140px, -240px 120px, 0 180px;
  }
}

@media (hover: hover) and (pointer: fine) {
  .inv-list .inv {
    position: relative;
    overflow: hidden;
  }

  .inv-list .inv::before {
    content: "";
    position: absolute;
    inset: -55% -35%;
    pointer-events: none;
    z-index: 0;
    opacity: 0;
    transition: opacity 260ms ease;
    background:
      radial-gradient(circle at 20% 30%, rgba(155, 106, 255, 0.34), transparent 50%),
      radial-gradient(circle at 76% 68%, rgba(116, 196, 255, 0.22), transparent 48%),
      repeating-linear-gradient(
        115deg,
        rgba(255, 255, 255, 0.12) 0 10px,
        rgba(255, 255, 255, 0.02) 10px 24px,
        transparent 24px 38px
      );
    mix-blend-mode: screen;
    animation: invWaterFlow 8s linear infinite;
  }

  .inv-list .inv > * {
    position: relative;
    z-index: 1;
  }

  .inv-list .inv:hover {
    background:
      linear-gradient(165deg, rgba(72, 34, 124, 0.94), rgba(40, 19, 76, 0.96));
    border-color: rgba(185, 130, 255, 0.74);
    box-shadow:
      0 0 0 1px rgba(176, 118, 255, 0.3),
      0 18px 38px rgba(38, 14, 70, 0.48);
    transform: translateY(-3px) scale(1.004);
  }

  .inv-list .inv:hover::before {
    opacity: 0.9;
  }

  .inv-list .inv:hover .inv__sum {
    background: rgba(129, 79, 206, 0.24);
  }

  .inv-list .inv:hover .inv__name,
  .inv-list .inv:hover .inv__next,
  .inv-list .inv:hover .inv__count,
  .inv-list .inv:hover .inv__map,
  .inv-list .inv:hover .inv__info,
  .inv-list .inv:hover .muted {
    color: #ffd67b;
    text-shadow:
      0 0 10px rgba(255, 214, 124, 0.46),
      0 0 2px rgba(255, 245, 210, 0.65);
  }

  .inv-list .inv:hover .inv__badge {
    color: #3c230b;
    border-color: rgba(223, 170, 76, 0.9);
    background: linear-gradient(96deg, #ffe3a5, #dea348);
    box-shadow: 0 0 12px rgba(226, 170, 74, 0.38);
    text-shadow: none;
  }
}

/* Portada carousel */
.portada-carousel__viewport {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid rgba(174, 188, 215, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 247, 226, 0.86), rgba(239, 218, 173, 0.82));
  aspect-ratio: 16 / 7;
  min-height: 210px;
  touch-action: pan-y;
  cursor: grab;
}

.portada-carousel__viewport.is-dragging {
  cursor: grabbing;
}

.portada-carousel__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}

.portada-carousel__empty {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 16px;
  color: #6b4528;
  font-size: 0.95rem;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(174, 126, 67, 0.12) 0 14px,
      rgba(255, 241, 211, 0.32) 14px 28px
    );
}

.portada-carousel__dots {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 12px;
}

.portada-carousel__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(126, 75, 30, 0.42);
  background: rgba(255, 241, 214, 0.9);
  cursor: pointer;
  padding: 0;
  transition: transform 160ms ease, background-color 160ms ease, border-color 160ms ease;
}

.portada-carousel__dot:hover {
  transform: scale(1.08);
  border-color: rgba(168, 101, 29, 0.6);
}

.portada-carousel__dot.is-active {
  transform: scale(1.12);
  border-color: rgba(168, 101, 29, 0.75);
  background: linear-gradient(95deg, #ffe3a9, #dfa54c);
}

@media (max-width: 760px) {
  .portada-carousel__viewport {
    aspect-ratio: 16 / 9;
    min-height: 170px;
  }
}

/* Portada preview modal */
.portada-preview {
  position: fixed;
  inset: 12px;
  z-index: 99;
  display: grid;
  place-items: center;
}

.portada-preview__img {
  width: min(96vw, 1600px);
  max-height: calc(100dvh - 28px);
  object-fit: contain;
  border-radius: 14px;
  border: 1px solid rgba(255, 223, 170, 0.45);
  background: rgba(27, 15, 6, 0.78);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.46);
}

.portada-preview__close {
  position: fixed;
  top: calc(12px + var(--safe-top));
  right: 12px;
  z-index: 100;
}

@media (max-width: 560px) {
  .portada-preview {
    inset: 6px;
  }

  .portada-preview__img {
    border-radius: 10px;
    max-height: calc(100dvh - 18px);
  }
}

/* Background music player */
:root {
  --music-player-space: 0px;
}

body {
  padding-bottom: calc(var(--music-player-space) + var(--safe-bottom));
}

.music-player {
  position: fixed;
  right: 14px;
  bottom: calc(14px + var(--safe-bottom));
  display: grid;
  gap: 8px;
  width: min(300px, calc(100vw - 20px));
  padding: 10px 10px 9px;
  border-radius: 14px;
  border: 1px solid rgba(118, 71, 27, 0.34);
  background:
    linear-gradient(180deg, rgba(255, 246, 222, 0.97), rgba(244, 224, 180, 0.95));
  box-shadow:
    0 12px 24px rgba(73, 38, 9, 0.2),
    inset 0 0 0 1px rgba(255, 255, 255, 0.24);
  z-index: 70;
  color: #2f1908;
}

.music-player__meta {
  min-width: 0;
}

.music-player__track {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  font-weight: 800;
  color: #40230e;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.music-player__status {
  margin-top: 2px;
  font-size: 0.72rem;
  color: #6f4726;
  font-weight: 700;
}

.music-player__controls {
  display: flex;
  gap: 8px;
}

.music-player__btn {
  border: 1px solid rgba(116, 70, 28, 0.42);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(255, 246, 224, 0.98), rgba(239, 215, 165, 0.96));
  color: #2e1908;
  font-family: var(--font-ui);
  letter-spacing: 0.03em;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: none;
  min-height: 42px;
  padding: 0 10px;
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, box-shadow 140ms ease;
}

.music-player__btn:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: rgba(157, 95, 33, 0.66);
  box-shadow: 0 6px 14px rgba(87, 47, 14, 0.2);
}

.music-player__btn:active:not(:disabled) {
  transform: translateY(0);
}

.music-player__btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.music-player__btn--play {
  flex: 1 1 auto;
  font-size: 0.8rem;
}

.music-player__btn--next {
  flex: 0 0 86px;
}

.music-player__volume {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
}

.music-player__volume-label {
  font-size: 0.7rem;
  font-weight: 800;
  color: #5d3a1c;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.music-player__volume-value {
  font-size: 0.7rem;
  font-weight: 800;
  color: #5d3a1c;
  min-width: 36px;
  text-align: right;
}

.music-player__range {
  appearance: none;
  -webkit-appearance: none;
  height: 6px;
  border-radius: 999px;
  border: 1px solid rgba(116, 70, 28, 0.35);
  background: linear-gradient(90deg, rgba(230, 168, 79, 0.95), rgba(254, 230, 178, 0.95));
  cursor: pointer;
}

.music-player__range::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 999px;
  background: transparent;
}

.music-player__range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid rgba(108, 64, 24, 0.72);
  background: #fff5dc;
  box-shadow: 0 2px 6px rgba(90, 49, 16, 0.25);
  margin-top: -5px;
}

.music-player__range::-moz-range-track {
  height: 6px;
  border-radius: 999px;
  border: 1px solid rgba(116, 70, 28, 0.35);
  background: linear-gradient(90deg, rgba(230, 168, 79, 0.95), rgba(254, 230, 178, 0.95));
}

.music-player__range::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border: 1px solid rgba(108, 64, 24, 0.72);
  border-radius: 50%;
  background: #fff5dc;
  box-shadow: 0 2px 6px rgba(90, 49, 16, 0.25);
}

@media (max-width: 640px) {
  .music-player {
    right: 8px;
    left: 8px;
    width: auto;
    bottom: calc(8px + var(--safe-bottom));
    padding: 9px;
  }

  .music-player__btn {
    min-height: 40px;
  }

  .music-player__btn--next {
    flex-basis: 80px;
  }

  .music-player__volume-label {
    font-size: 0.66rem;
  }

  .music-player__volume-value {
    font-size: 0.66rem;
  }
}

/* 2026-02-25 - Acontecimientos modal */
.evt-modal {
  width: min(1080px, calc(100vw - 20px));
}

.evt-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
  margin-bottom: 10px;
}

.evt-kpi {
  border: 1px solid rgba(126, 78, 35, 0.32);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255, 247, 231, 0.82);
  box-shadow: 0 4px 14px rgba(62, 33, 10, 0.08);
}

.evt-kpi__label {
  font-size: 0.76rem;
  font-weight: 800;
  color: #684322;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.evt-kpi__value {
  margin-top: 4px;
  font-size: 1.15rem;
  font-weight: 900;
  color: #2d1908;
}

.evt-kpi__value--sm {
  font-size: 0.9rem;
  line-height: 1.35;
}

.evt-section {
  margin-top: 10px;
  border: 1px solid rgba(126, 78, 35, 0.28);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255, 250, 240, 0.86);
}

.evt-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.evt-section__title {
  margin: 0;
  font-size: 0.95rem;
  font-family: var(--font-tech);
  letter-spacing: 0.035em;
  text-transform: uppercase;
  color: #341f0e;
}

.evt-section__meta {
  font-size: 0.76rem;
  font-weight: 700;
  color: #704923;
}

.evt-live-list,
.evt-inv-list {
  display: grid;
  gap: 8px;
}

.evt-row,
.evt-inv {
  border: 1px solid rgba(123, 76, 33, 0.24);
  border-radius: 10px;
  padding: 9px;
  background: rgba(255, 245, 222, 0.8);
}

.evt-row__top,
.evt-inv__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.evt-row__title,
.evt-inv__name {
  font-weight: 900;
  color: #2f1a09;
}

.evt-row__time {
  font-size: 0.78rem;
  font-weight: 700;
  color: #6f4823;
  white-space: nowrap;
}

.evt-row__summary {
  margin-top: 4px;
  color: #3d240f;
}

.evt-row__meta {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.evt-row__detail {
  margin-top: 7px;
  font-size: 0.83rem;
  color: #5f3c1d;
}

.evt-tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(127, 79, 36, 0.36);
  background: rgba(255, 241, 211, 0.8);
  color: #4d2d13;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.evt-tag--soft {
  border-color: rgba(109, 70, 32, 0.22);
  background: rgba(255, 246, 224, 0.88);
  color: #674122;
}

.evt-tag--info {
  border-color: rgba(37, 108, 154, 0.35);
  background: rgba(167, 220, 255, 0.42);
  color: #184462;
}

.evt-tag--warn {
  border-color: rgba(172, 117, 28, 0.48);
  background: rgba(255, 222, 161, 0.54);
  color: #72400f;
}

.evt-tag--danger {
  border-color: rgba(168, 63, 49, 0.4);
  background: rgba(255, 175, 165, 0.45);
  color: #6f1f16;
}

.evt-tag--active {
  border-color: rgba(58, 143, 80, 0.5);
  background: rgba(153, 233, 170, 0.45);
  color: #215730;
}

.evt-tag--soon {
  border-color: rgba(170, 113, 34, 0.45);
  background: rgba(255, 227, 170, 0.52);
  color: #6f3d0f;
}

.evt-inv__line {
  margin-top: 4px;
  color: #3f250f;
}

.evt-grid2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.evt-col {
  border: 1px solid rgba(123, 76, 33, 0.24);
  border-radius: 10px;
  padding: 8px;
  background: rgba(255, 246, 228, 0.82);
}

.evt-col__title {
  margin: 0 0 8px;
  font-family: var(--font-tech);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #3b220d;
  font-size: 0.84rem;
}

.evt-col__body {
  display: grid;
  gap: 6px;
}

.evt-kv {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px dashed rgba(122, 73, 28, 0.24);
  border-radius: 8px;
  padding: 6px 8px;
  background: rgba(255, 249, 236, 0.85);
}

.evt-kv span {
  color: #5e3a1d;
  font-size: 0.84rem;
}

.evt-kv b {
  color: #2f1a09;
  font-weight: 900;
  font-size: 0.84rem;
}

@media (max-width: 760px) {
  .evt-grid2 {
    grid-template-columns: 1fr;
  }

  .evt-kpi__value {
    font-size: 1rem;
  }
}

/* 2026-02-25b - Ensure Acontecimientos nav visibility */
.sidenav--right #evtOpenBtn {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

#drawer #evtDrawerBtn {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.evt-open-float {
  position: fixed;
  right: 16px;
  top: calc(50% + 58px);
  z-index: 52;
}

@media (max-width: 979px) {
  .evt-open-float {
    display: none !important;
  }
}

/* 2026-02-26 - Side art desktop visibility fix */
@media (min-width: 761px) {
  .left-floater,
  .right-floater {
    display: block !important;
    position: fixed !important;
    width: clamp(230px, 24vw, 460px) !important;
    height: min(100dvh, 980px) !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    opacity: 0.5 !important;
    z-index: 1 !important;
  }

  .left-floater {
    left: -54px !important;
    bottom: -8px !important;
    background-position: left bottom !important;
  }

  .right-floater {
    right: -54px !important;
    bottom: 0 !important;
    background-position: right bottom !important;
  }

  .main,
  .footer {
    z-index: 2;
  }
}

/* 2026-03-02 - Arsenal mini game */
.mu-arcade {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.mu-arcade__hud {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.mu-arcade__stat {
  border: 1px solid rgba(113, 88, 35, 0.34);
  border-radius: 12px;
  background: rgba(255, 246, 221, 0.84);
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.mu-arcade__stat span {
  font-size: 0.78rem;
  color: #6a451f;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 800;
}

.mu-arcade__stat b {
  font-size: 1rem;
  color: #2f1a0a;
  font-weight: 900;
}

.mu-arcade__stat b.is-lowlife {
  color: #8b1b11;
}

.mu-arcade__arena {
  position: relative;
  border: 1px solid rgba(102, 137, 69, 0.45);
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  min-height: 230px;
  touch-action: none;
  user-select: none;
  background:
    radial-gradient(circle at 20% 14%, rgba(202, 255, 150, 0.28), transparent 48%),
    radial-gradient(circle at 78% 84%, rgba(131, 191, 88, 0.28), transparent 42%),
    repeating-linear-gradient(
      90deg,
      rgba(48, 92, 31, 0.18) 0 2px,
      rgba(64, 120, 43, 0.2) 2px 11px
    ),
    linear-gradient(180deg, #7dc85b 0%, #529a3a 46%, #3d752c 100%);
}

.mu-arcade__arena canvas {
  width: 100%;
  height: 100%;
  display: block;
}

.mu-arcade__xpbar {
  position: absolute;
  left: 12px;
  right: 12px;
  top: 12px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  overflow: hidden;
  background: rgba(18, 42, 10, 0.46);
}

.mu-arcade__xpfill {
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ffffff, #fef2cc, #ffd06d);
  box-shadow: 0 0 12px rgba(255, 238, 193, 0.48);
  transition: width 180ms ease;
}

.mu-arcade__current {
  position: absolute;
  top: 24px;
  right: 12px;
  width: min(220px, 44%);
  border-radius: 11px;
  border: 1px solid rgba(255, 250, 214, 0.45);
  padding: 7px 8px;
  background: rgba(17, 45, 10, 0.62);
  backdrop-filter: blur(1px);
  color: #f7ffe6;
  box-shadow: 0 10px 24px rgba(16, 35, 8, 0.24);
  pointer-events: none;
}

.mu-arcade__current-title {
  margin-bottom: 5px;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 900;
  color: #fff4d0;
}

.mu-arcade__current-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 20px;
  padding: 2px 0;
}

.mu-arcade__current-row span {
  font-size: 0.72rem;
  color: rgba(238, 255, 218, 0.92);
}

.mu-arcade__current-row b {
  font-size: 0.74rem;
  color: #fff5d5;
  font-weight: 900;
}

.mu-arcade__hint {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 10px;
  padding: 7px 10px;
  background: rgba(14, 35, 10, 0.52);
  color: #f4ffe4;
  font-size: 0.82rem;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.36);
}

.mu-arcade__attrs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.mu-arcade__attr {
  border: 1px solid rgba(120, 78, 29, 0.38);
  border-radius: 10px;
  min-height: 42px;
  padding: 0 8px;
  background: rgba(255, 245, 217, 0.92);
  color: #4b2d14;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 900;
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, box-shadow 140ms ease;
}

.mu-arcade__attr:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: rgba(153, 95, 32, 0.64);
  box-shadow: 0 6px 14px rgba(83, 44, 11, 0.18);
}

.mu-arcade__attr:active:not(:disabled) {
  transform: translateY(0);
}

.mu-arcade__attr:disabled {
  opacity: 0.56;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.mu-arcade__controls {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.mu-arcade-rank {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.mu-arcade-rank__row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(109, 69, 25, 0.3);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(255, 245, 218, 0.86);
}

.mu-arcade-rank__pos {
  min-width: 24px;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 900;
  color: #5f3818;
}

.mu-arcade-rank__name {
  min-width: 0;
  font-size: 0.88rem;
  font-weight: 800;
  color: #3e220d;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mu-arcade-rank__pts {
  font-size: 0.84rem;
  font-weight: 900;
  color: #4f2d12;
  white-space: nowrap;
}

.mu-arcade-rank__meta {
  font-size: 0.72rem;
  color: #6e4624;
  white-space: nowrap;
}

.mu-arcade-rank__empty {
  border: 1px dashed rgba(118, 77, 31, 0.36);
  border-radius: 10px;
  padding: 10px;
  background: rgba(255, 248, 230, 0.72);
  color: #664021;
  font-size: 0.84rem;
}

.mu-arcade__ctrl {
  border: 1px solid rgba(119, 81, 30, 0.35);
  border-radius: 10px;
  padding: 10px 8px;
  background: rgba(255, 244, 214, 0.9);
  color: #4d2d13;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 900;
}

.mu-arcade__ctrl.is-held,
.mu-arcade__ctrl:active {
  transform: translateY(1px);
  border-color: rgba(120, 157, 80, 0.62);
  background: rgba(202, 236, 158, 0.92);
}

.mu-arcade__ctrl--shoot {
  border-color: rgba(142, 91, 28, 0.48);
  background: linear-gradient(95deg, #ffe4ad, #e4ae59);
  color: #3d230c;
}

.mu-arcade__ctrl:disabled {
  opacity: 0.56;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.mu-arcade-intro {
  position: absolute;
  inset: 0;
  z-index: 15;
  display: grid;
  place-items: center;
  padding: 10px;
  pointer-events: none;
}

.mu-arcade-intro__box {
  width: min(560px, calc(100% - 22px));
  border-radius: 16px;
  border: 1px solid rgba(122, 72, 24, 0.4);
  padding: 12px 13px;
  background:
    linear-gradient(180deg, rgba(255, 245, 218, 0.95), rgba(243, 218, 165, 0.95));
  box-shadow:
    0 16px 32px rgba(67, 35, 10, 0.28),
    inset 0 0 0 1px rgba(255, 255, 255, 0.32);
  color: #3a220d;
  text-align: center;
  pointer-events: auto;
}

.mu-arcade-intro__title {
  font-family: var(--font-tech);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 1rem;
  font-weight: 900;
  margin-bottom: 8px;
}

.mu-arcade-intro__line {
  font-size: 0.86rem;
  color: #4f3116;
  margin-top: 4px;
}

.mu-arcade-intro__line b {
  color: #2f1908;
}

.mu-arcade-intro__actions {
  margin-top: 12px;
}

.mu-arcade-intro__heroes {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.mu-arcade-hero {
  border: 1px solid rgba(132, 80, 28, 0.34);
  border-radius: 14px;
  padding: 10px;
  background:
    linear-gradient(180deg, rgba(255, 248, 226, 0.98), rgba(243, 221, 176, 0.95));
  display: grid;
  gap: 8px;
  align-items: start;
  text-align: center;
  color: #43270f;
  cursor: pointer;
  transition: transform 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}

.mu-arcade-hero:hover {
  transform: translateY(-2px);
  border-color: rgba(167, 98, 30, 0.58);
  box-shadow: 0 10px 20px rgba(76, 39, 10, 0.18);
}

.mu-arcade-hero__preview {
  min-height: 74px;
  border-radius: 12px;
  border: 1px solid rgba(139, 84, 28, 0.24);
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 245, 218, 0.98), rgba(255, 230, 180, 0.4) 42%, transparent 72%),
    linear-gradient(180deg, rgba(113, 178, 72, 0.22), rgba(66, 125, 43, 0.22));
  display: grid;
  place-items: center;
}

.mu-arcade-hero__preview--warrior {
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 242, 214, 0.98), rgba(255, 218, 162, 0.42) 42%, transparent 72%),
    linear-gradient(180deg, rgba(160, 96, 54, 0.16), rgba(113, 59, 31, 0.18));
}

.mu-arcade-hero__preview--archer {
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 247, 214, 0.98), rgba(255, 222, 158, 0.42) 42%, transparent 72%),
    linear-gradient(180deg, rgba(123, 173, 72, 0.22), rgba(79, 116, 37, 0.22));
}

.mu-arcade-hero__icon {
  width: 34px;
  height: 34px;
  opacity: 0.86;
}

.mu-arcade-hero__name {
  font-size: 0.9rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #351d0c;
}

.mu-arcade-hero__desc {
  font-size: 0.76rem;
  line-height: 1.3;
  font-weight: 700;
  color: #714727;
}

.mu-arcade-intro__tip {
  margin-top: 10px;
  border-radius: 10px;
  border: 1px solid rgba(137, 83, 28, 0.36);
  padding: 6px 8px;
  background: rgba(255, 236, 191, 0.62);
  font-size: 0.8rem;
  font-weight: 800;
  color: #5d3818;
  letter-spacing: 0.03em;
}

@media (hover: hover) and (pointer: fine) {
  .mu-arcade__controls {
    display: none;
  }
}

@media (max-width: 760px) {
  .mu-arcade__hud {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mu-arcade__stat--xp {
    grid-column: span 2;
  }

  .mu-arcade__stat--pts {
    grid-column: span 2;
  }

  .mu-arcade__arena {
    min-height: 190px;
  }

  .mu-arcade__current {
    top: 24px;
    right: 8px;
    width: min(180px, 52%);
    padding: 6px;
  }

  .mu-arcade__current-title {
    font-size: 0.64rem;
    margin-bottom: 3px;
  }

  .mu-arcade__current-row {
    min-height: 18px;
  }

  .mu-arcade__current-row span,
  .mu-arcade__current-row b {
    font-size: 0.66rem;
  }

  .mu-arcade__hint {
    font-size: 0.76rem;
  }

  .mu-arcade__attrs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mu-arcade__controls {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mu-arcade-rank__row {
    grid-template-columns: auto 1fr auto;
  }

  .mu-arcade-rank__meta {
    grid-column: 1 / -1;
    margin-top: -2px;
  }

  .mu-arcade__ctrl--shoot {
    grid-column: span 3;
  }

  .mu-arcade-intro__box {
    width: calc(100% - 16px);
    border-radius: 14px;
    padding: 10px 11px;
  }

  .mu-arcade-intro__title {
    font-size: 0.94rem;
  }

  .mu-arcade-intro__line {
    font-size: 0.8rem;
  }

  .mu-arcade-intro__heroes {
    grid-template-columns: 1fr;
  }

  .mu-arcade-hero__preview {
    min-height: 64px;
  }

  .mu-arcade-intro__tip {
    font-size: 0.75rem;
  }
}
