/* ================== GLOBAL WEBFONT (no cambia la API de estilos) ==================
   Carga la familia 'Comic' como fuente web, respetando todo tu CSS existente que ya usa
   font-family: 'Comic', sans-serif;  (no rompe nada). Asegúrate de subir los archivos
   a /fonts/ en tu servidor. Si solo tienes .otf, se usa como fallback.
*/
/* --- Fix distorsión del ícono hamburguesa (SVG) --- */
.hamburger { 
  width: 30px; height: 30px; 
  display: block; cursor: pointer;
  /* evita que Flex lo estire cuando cambia el header */
  flex: 0 0 30px;
}

.hamburger svg {
  width: 30px; height: 30px;
  display: block;
  overflow: visible;               /* que no recorte los paths al rotar */
}

.hamburger svg path {
  /* que el grosor del trazo no se deforme al escalar/rotar */
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
  transition: transform .25s ease, opacity .2s ease;
  /* MUY IMPORTANTE para que roten sobre sí mismos */
  transform-box: fill-box;
  transform-origin: 50% 50%;
}

/* Estado base (por claridad; sin transform) */
.hamburger .top-bar,
.hamburger .bottom-bar { transform: none; }

/* Cuando abres el menú (tu JS ya pone .active a .hamburger) */
.hamburger.active .top-bar    { transform: translateY(6px) rotate(45deg);  }
.hamburger.active .bottom-bar { transform: translateY(-6px) rotate(-45deg); }
.roominfo-btn.tile[disabled]{
  opacity:.55;
  filter:grayscale(1);
  cursor:not-allowed;
}
.roominfo-btn.tile[disabled] .tile-icon{
  filter:grayscale(1) brightness(.9);
}

@font-face {
  font-family: 'Comic';
  src: url('https://petsocietyislandcloud.com/wiki/fonts/Comic.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/* Permite que el navegador sintetice negrita/itálica si no hay variantes */
:root { font-synthesis: weight style; }
/* Formularios heredan la fuente */
button, input, select, textarea { font: inherit; }


/* ================================================================================ */
/* Definir la fuente personalizada Comic */
/*@font-face {
  font-family: 'Comic';
  src: url('fonts/Comic.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}*/

/* Definir variables para temas y colores */
:root {
  --background-color-light: #f0f4f8;
  --background-color-dark: #2c3e50;
  --text-color-light: #333;
  --text-color-dark: #ecf0f1;
  --modal-bg-light: rgba(255, 255, 255, 0.9);
  --modal-bg-dark: rgba(44, 62, 80, 0.9);
  --button-bg-light: #dfe6e9;
  --button-bg-dark: #34495e;
  --button-hover-light: #b2bec3;
  --button-hover-dark: #4a677c;
  --pastel-blue: #b3e5fc;
  --pastel-yellow: #fff9c4;
  --pastel-green: #c8e6c9;
  --pastel-red: #ffcdd2;
}

/* Temas claro y oscuro */
[data-theme="light"] {
  --background-color: var(--background-color-light);
  --text-color: var(--text-color-light);
  --modal-bg: var(--modal-bg-light);
  --button-bg: var(--button-bg-light);
  --button-hover: var(--button-hover-light);
  --header-bg: var(--background-color-light);
  --search-bar-bg: var(--background-color-light);
}

[data-theme="dark"] {
  --background-color: var(--background-color-dark);
  --text-color: var(--text-color-dark);
  --modal-bg: var(--modal-bg-dark);
  --button-bg: var(--button-bg-dark);
  --button-hover: var(--button-hover-dark);
  --header-bg: var(--background-color-dark);
  --search-bar-bg: var(--background-color-dark);
}

/* Estilos generales */
body {
  background-color: var(--background-color);
  color: var(--text-color);
  font-family: 'Comic', sans-serif;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  position: relative;
}

/* Bloquear scroll del fondo cuando el modal o menú está abierto */
body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
}

/* Fondo animado degradado */
.background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    linear-gradient(rgba(0,0,0,0.2), rgba(0,0,0,0.2)),
    url(https://petsocietyislandcloud.com/wiki/webBG.png) no-repeat 50% / cover;
    filter: blur(5px);
  z-index: -1;
  animation: gradientShift 30s ease infinite;
}

[data-theme="dark"] .background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.4)),
    url(https://petsocietyislandcloud.com/wiki/webBG.png) no-repeat 50% / cover;
    filter: blur(5px);
  z-index: -1;
  animation: gradientShift 30s ease infinite;
}
@font-face{
  font-family: 'GROBOLD';
  src: url('https://petsocietyislandcloud.com/wiki/fonts/GROBOLD.woff2') format('woff2'),
       url('https://petsocietyislandcloud.com/wiki/fonts/GROBOLD.woff') format('woff'),
       url('https://petsocietyislandcloud.com/wiki/fonts/GROBOLD.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}
@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Nubes animadas con efecto blur */
.clouds {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
}

.cloud {
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  width: 200px;
  height: 60px;
  filter: blur(15px);
  animation: drift infinite linear;
}

.cloud::before,
.cloud::after {
  content: '';
  position: absolute;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  filter: blur(15px);
}

.cloud::before {
  width: 100px;
  height: 100px;
  top: -50px;
  left: 30px;
}

.cloud::after {
  width: 80px;
  height: 80px;
  top: -30px;
  right: 30px;
}

.cloud:nth-child(1) { top: 15%; left: -200px; animation-duration: 35s; }
.cloud:nth-child(2) { top: 25%; left: -200px; animation-duration: 45s; }
.cloud:nth-child(3) { top: 40%; left: -200px; animation-duration: 55s; }
.cloud:nth-child(4) { top: 60%; left: -200px; animation-duration: 65s; }

@keyframes drift {
  0% { transform: translateX(-200px); }
  100% { transform: translateX(100vw); }
}

/* Encabezado */
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 20px;
  background-color: var(--header-bg);
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 1000;
  box-sizing: border-box;
  border-bottom: 2px solid var(--pastel-blue);
  border-radius: 0 0 10px 10px;
}

.logo-container {
  flex: 0 0 auto;
}

.logo-img {
  height: 40px;
}

.header-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.theme-switch, .login-btn, .profile-btn {
  cursor: pointer;
  padding: 5px 10px;
  border: none;
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 8px;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.language-select {
  cursor: pointer;
  padding: 6px 10px;
  border: 2px solid var(--pastel-blue);
  background: var(--pastel-yellow);
  color: var(--text-color);
  border-radius: 8px;
  font-family: 'Comic', sans-serif;
  font-size: 13px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.08);
  max-width: 170px;
}

.menu-language-wrap {
  margin-top: 12px;
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.menu-language-label {
  font-family: 'Comic', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-color);
}

.menu .language-select {
  width: 100%;
  max-width: none;
}

.theme-switch:hover, .login-btn:hover, .profile-btn:hover {
  background: var(--pastel-green);
}

/* Menú hamburguesa */
.hamburger {
  display: block;
  cursor: pointer;
  width: 30px;
  height: 30px;
}

.hamburger svg {
  width: 100%;
  height: 100%;
  stroke: var(--text-color);
  stroke-width: 2;
  fill: none;
}

.hamburger.active .top-bar {
  transform: translateY(6px) rotate(45deg);
}

.hamburger.active .bottom-bar {
  transform: translateY(-6px) rotate(-45deg);
}

/* Menú de navegación con categorías en dropdown */
.menu {
  display: none;
  flex-direction: column;
  background-color: var(--pastel-blue);
  position: fixed;
  top: 0;
  left: 0;
  width: 250px;
  height: 100%;
  padding: 20px;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.2);
  z-index: 1001;
  transform: translateX(-100%);
  transition: transform 0.3s ease-in-out;
}

.menu.active {
  display: flex;
  transform: translateX(0);
}

.menu-backdrop {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
}

.menu-backdrop.active {
  display: block;
}

.dropdown {
  position: relative;
  overflow: visible; /* Asegurar que el dropdown no restrinja el contenido */
  z-index: 1002; /* Asegurar que el dropdown esté por encima del backdrop */
}

.dropdown-toggle {
  color: var(--text-color);
  padding: 10px;
  border-radius: 8px;
  background: var(--pastel-blue);
  cursor: pointer;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.dropdown-toggle:hover {
  background: var(--pastel-green);
}

.dropdown-menu {
  display: none;
  flex-direction: column;
  background: #ffffff;
  border-radius: 8px;
  margin-top: 5px;
  padding: 5px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  max-height: 300px; /* Limitar altura para permitir scroll */
  overflow-y: auto; /* Habilitar scroll vertical */
  overflow-x: hidden; /* Evitar scroll horizontal */
  scrollbar-width: none; /* Ocultar scrollbar en Firefox */
  -ms-overflow-style: none; /* Ocultar scrollbar en IE y Edge */
  z-index: 1003; /* Asegurar que el dropdown esté por encima de otros elementos */
}

.dropdown-menu::-webkit-scrollbar {
  display: none; /* Ocultar scrollbar en Chrome, Safari, etc. */
}

.dropdown-menu.active {
  display: flex;
}

.dropdown-menu a {
  color: var(--text-color);
  text-decoration: none;
  padding: 5px 10px;
  border-radius: 5px;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  background: #ffffff;
  white-space: nowrap; /* Evitar que el texto se divida en varias líneas */
}

.dropdown-menu a:hover {
  background: var(--pastel-blue);
}

/* Barra de búsqueda */
.search-bar {
  position: fixed;
  top: 60px;
  width: 100%;
  padding: 10px 20px;
  background-color: #ffffff9e;
  z-index: 998;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  border-radius: 0 0 10px 10px;
}

.search-bar form {
  display: flex;
  gap: 10px;
  width: 100%;
  max-width: 500px;
}

.search-bar input[type="text"] {
  flex: 1;
  padding: 8px;
  border: 2px solid var(--pastel-blue);
  border-radius: 50px;
  font-size: 16px;
  background: var(--pastel-yellow);
  font-family: 'Comic', sans-serif;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}

.search-bar button {
  padding: 8px 15px;
  border: none;
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  border-radius: 50px;
}

.search-bar button:hover {
  background: var(--pastel-green);
}

/* Contenido principal */
main {
  padding: 120px 20px 20px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 15px;
  width: 100%;
  max-width: 1200px;
}

.item {
  background: #ffffff;
  border-radius: 15px;
  padding: 10px;
  text-align: center;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  height: 220px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
}

.item:hover {
  transform: scale(1.05);
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.15);
}

.wishlist-count {
  position: absolute;
  top: 5px;
  right: 5px;
  display: flex;
  align-items: center;
  gap: 3px;
  background: var(--pastel-blue);
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 12px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.wishlist-count svg {
  width: 14px;
  height: 14px;
  fill: #d91c1c;
}

.placeholder-img {
  width: 100%;
  height: 100px;
  object-fit: contain;
  object-position: center;
  margin-bottom: 10px;
}

.item div {
  font-size: 14px;
  margin-bottom: 5px;
  font-family: 'Comic', sans-serif;
}

.details {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
}

.tag {
  display: flex;
  align-items: center;
  gap: 3px;
  background: var(--pastel-blue);
  padding: 3px 8px;
  border-radius: 8px;
  font-size: 12px;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.tag.coins {
  background: var(--pastel-yellow);
}

.tag.sellable {
  background: var(--pastel-green);
}

.tag.giftable {
  background: var(--pastel-blue);
}

.tag img {
  width: 12px;
  height: 12px;
}

/* Paginación */
.pagination {
  margin-top: 20px;
  display: flex;
  gap: 5px;
}

.pagination a {
  padding: 5px 12px;
  border: 2px solid var(--pastel-blue);
  border-radius: 8px;
  text-decoration: none;
  color: var(--text-color);
  background: var(--pastel-yellow);
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.pagination a:hover {
  background: var(--pastel-blue);
}

.pagination a.active {
  background: var(--pastel-green);
  font-weight: bold;
}

/* Modales */
.preview-modal, .login-modal, .profile-modal, .wishlist-modal, .inventory-modal, .closet-modal, .alert-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1002;
  justify-content: center;
  align-items: center;
}

/* Profile modal sizing to keep rounded corners visible on mobile */
#profileModal{
  padding: 10px 0 !important;
}
#profileModal .profile-content{
  width: min(940px, 96vw) !important;
  max-height: 86vh !important;
  border-radius: 18px !important;
}

.preview-content, .login-content, .profile-content, .wishlist-content, .inventory-content, .closet-content, .alert-content {
  background: #fff;
  padding: 20px;
  border-radius: 20px;
  max-width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
  width: 100%;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.preview-content::-webkit-scrollbar,
.login-content::-webkit-scrollbar,
.profile-content::-webkit-scrollbar,
.wishlist-content::-webkit-scrollbar,
.inventory-content::-webkit-scrollbar,
.closet-content::-webkit-scrollbar,
.alert-content::-webkit-scrollbar {
  display: none;
}

.close-preview, .close-login, .close-profile, .close-wishlist, .close-inventory, .close-closet {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 24px;
  cursor: pointer;
  color: var(--text-color);
  background: var(--pastel-blue);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.close-preview:hover, .close-login:hover, .close-profile:hover, .close-wishlist:hover, .close-inventory:hover, .close-closet:hover {
  background: var(--pastel-green);
}

/* Contenedor para centrar la imagen del preview */
.preview-img-container {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 120px;
  margin: 10px 0;
  overflow: hidden;
}

.preview-content img {
  max-width: 100px;
  max-height: 100px;
  object-fit: contain;
  border-radius: 10px;
  display: block;
}

.sell-value {
  font-size: 14px;
  margin: 10px 0;
  color: var(--text-color);
  font-family: 'Comic', sans-serif;
  display: flex;
  align-items: center;
  gap: 5px;
  justify-content: center;
}

.bell-icon {
  width: 16px !important;
  height: 16px !important;
  object-fit: contain;
}

.add-wishlist-btn, .inventory-btn, .closet-btn, .wishlist-btn, .logout-btn, .alert-close-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 8px 15px;
  border: none;
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.3s ease;
  margin: 5px 0;
  width: 100%;
  justify-content: center;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.add-wishlist-btn {
  background: var(--pastel-yellow);
}

.inventory-btn {
  background: var(--pastel-green);
}

.closet-btn {
  background: var(--pastel-blue);
}

.wishlist-btn {
  background: var(--pastel-yellow);
}

.logout-btn {
  background: var(--pastel-red);
}

.alert-close-btn {
  background: var(--pastel-blue);
}

.add-wishlist-btn:hover, .inventory-btn:hover, .closet-btn:hover, .wishlist-btn:hover, .logout-btn:hover, .alert-close-btn:hover {
  background: var(--pastel-green);
}

.add-wishlist-btn svg, .button-icon {
  width: 20px;
  height: 20px;
  fill: #d91c1c;
}

.login-content form, .logout-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.login-content input {
  padding: 8px;
  border: 2px solid var(--pastel-blue);
  border-radius: 8px;
  font-size: 16px;
  background: var(--pastel-yellow);
  font-family: 'Comic', sans-serif;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}

.login-content button {
  padding: 8px;
  border: none;
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.login-content button:hover {
  background: var(--pastel-green);
}

.login-error {
  display: none;
  color: #e74c3c;
  margin-top: 10px;
  font-size: 14px;
  text-align: center;
  font-family: 'Comic', sans-serif;
}

.forgot-password {
  display: block;
  margin-top: 10px;
  text-align: center;
  color: var(--text-color);
  text-decoration: underline;
  font-size: 14px;
  font-family: 'Comic', sans-serif;
}

.forgot-password:hover {
  color: var(--pastel-blue);
}

.balance-info {
  font-weight: normal;
}

.balance-info p {
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 5px 0;
  font-family: 'Comic', sans-serif;
}

.balance-info img {
  width: 30px;
  height: 30px;
}

.balance-info span {
  font-weight: normal;
}

.profile-content h2 {
  font-weight: normal;
}

.wishlist-scroll-container, .inventory-scroll-container, .closet-scroll-container {
  max-height: 300px;
  overflow-y: auto;
  margin-top: 10px;
  background: var(--pastel-yellow);
  border-radius: 10px;
  padding: 10px;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
}

.wishlist-empty, .inventory-empty, .closet-empty {
  text-align: center;
  color: var(--text-color);
  font-style: italic;
  font-family: 'Comic', sans-serif;
}

.wishlist-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-bottom: 1px solid var(--pastel-blue);
  background: #ffffff;
  border-radius: 8px;
  margin-bottom: 5px;
}

.wishlist-item img {
  width: 50px;
  height: 50px;
  object-fit: contain;
  border-radius: 8px;
}

.wishlist-item-details {
  flex: 1;
}

.wishlist-item-details .name {
  font-weight: bold;
  font-family: 'Comic', sans-serif;
}

.wishlist-item-details .timestamp {
  font-size: 12px;
  color: #666;
  font-family: 'Comic', sans-serif;
}

.remove-wishlist-btn {
  padding: 5px 10px;
  border: none;
  background: var(--pastel-red);
  color: white;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.remove-wishlist-btn:hover {
  background: #e74c3c;
}

.inventory-grid, .closet-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 10px;
}

.inventory-item, .closet-item {
  background: #ffffff;
  border-radius: 10px;
  padding: 5px;
  text-align: center;
  cursor: pointer;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}

.inventory-item img, .closet-item img {
  width: 100%;
  height: 80px;
  object-fit: contain;
  border-radius: 8px;
}

.inventory-item .name, .closet-item .name {
  font-size: 12px;
  margin: 5px 0;
  font-family: 'Comic', sans-serif;
}

.inventory-item .quantity, .closet-item .quantity {
  font-size: 10px;
  color: #666;
  font-family: 'Comic', sans-serif;
}

/* Estilos para el modal de alerta */
.alert-modal {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.alert-modal.active {
  display: flex;
  opacity: 1;
}

.alert-content {
  background: #ffffff;
  padding: 20px;
  border-radius: 20px;
  text-align: center;
  max-width: 300px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.alert-content p {
  margin: 0 0 15px 0;
  font-size: 16px;
  color: var(--text-color);
  font-family: 'Comic', sans-serif;
}

.alert-close-btn {
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 10px;
  padding: 8px 20px;
  font-size: 14px;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Estilos para la sección de comentarios en el modal de preview */
.comment-section {
  margin-top: 20px;
  border-top: 1px solid var(--pastel-blue);
  padding-top: 10px;
  width: 100%;
  box-sizing: border-box;
}

.comment-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 15px;
}

.comment-form textarea {
  padding: 8px;
  border: 2px solid var(--pastel-blue);
  border-radius: 8px;
  font-size: 14px;
  background: var(--pastel-yellow);
  font-family: 'Comic', sans-serif;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
  resize: vertical;
  min-height: 80px;
  width: 100%;
  box-sizing: border-box;
}

.comment-form button {
  padding: 8px 15px;
  border: none;
  background: var(--pastel-blue);
  color: var(--text-color);
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.3s ease;
  font-family: 'Comic', sans-serif;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.comment-form button:hover {
  background: var(--pastel-green);
}

.comments-container {
  max-height: 200px;
  overflow-y: auto;
  overflow-x: hidden;
  background: var(--pastel-yellow);
  border-radius: 10px;
  padding: 10px;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1);
  width: 100%;
  box-sizing: border-box;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.comments-container::-webkit-scrollbar {
  display: none;
}


[data-theme="dark"] .comment {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px;
  border-bottom: 1px solid var(--pastel-blue);
  background: #121921;
  border-radius: 8px;
  margin-bottom: 5px;
  width: 100%;
  box-sizing: border-box;
}

.comment {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px;
  border-bottom: 1px solid var(--pastel-blue);
  background: #ffffff;
  border-radius: 8px;
  margin-bottom: 5px;
  width: 100%;
  box-sizing: border-box;
}

.comment img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
}

.comment-details {
  flex: 1;
}

.comment-details .username {
  font-size: 14px;
  font-family: 'Comic', sans-serif;
  color: #2C3E50;
}

[data-theme="dark"] .comment-details .username {
  font-size: 14px;
  font-family: 'Comic', sans-serif;
  color: #56C9DD;
}

.comment-details .content {
  font-size: 14px;
  color: #666;
  font-family: 'Comic', sans-serif;
  word-break: break-word;
}

.no-comments {
  text-align: center;
  color: var(--text-color);
  font-style: italic;
  font-family: 'Comic', sans-serif;
}

/* Estilos para el encabezado del perfil (foto + título) */
.profile-header {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 20px;
}

.profile-pic-container {
  position: relative;
}

.profile-pic-preview {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--pastel-blue);
}

.profile-header h2 {
  font-size: 20px;
  margin: 0;
  font-family: 'Comic', sans-serif;
}

/* Estilos para el formulario de subida de foto */
.profile-pic-form {
  position: absolute;
  bottom: 0;
  right: -5px;
}

.upload-pic-btn {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--pastel-blue);
  color: var(--text-color);
  border: none;
  font-size: 16px;
  font-family: 'Comic', sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.upload-pic-btn:hover {
  background: var(--pastel-green);
}

.profile-pic-error {
  display: none;
  color: #e74c3c;
  margin-top: 10px;
  font-size: 14px;
  text-align: center;
  font-family: 'Comic', sans-serif;
}

/* Ajustes responsivos para móviles */
@media (max-width: 600px) {
  .preview-content {
    padding: 15px;
    max-width: 95%;
    max-height: 85vh;
  }

  .preview-img-container {
    height: 100px;
  }

  .preview-content img {
    max-width: 80px;
    max-height: 80px;
  }

  .sell-value {
    font-size: 12px;
  }

  .bell-icon {
    width: 14px !important;
    height: 14px !important;
  }

  .comment-section {
    margin-top: 15px;
  }

  .comment-form textarea {
    font-size: 12px;
    min-height: 60px;
  }

  .comment-form button {
    font-size: 12px;
    padding: 6px 12px;
  }

  .comments-container {
    max-height: 150px;
  }

  .comment img {
    width: 30px;
    height: 30px;
  }

  .comment-details .username,
  .comment-details .content {
    font-size: 12px;
  }

  .dropdown-menu {
    max-height: 200px; /* Menor altura en móviles para mejor usabilidad */
  }
}

@media (max-width: 700px){
  #profileModal{
    align-items: flex-start !important;
    padding: calc(10px + env(safe-area-inset-top)) 0 calc(14px + env(safe-area-inset-bottom)) !important;
  }
  #profileModal .profile-content{
    width: 92vw !important;
    max-height: min(76dvh, 76vh) !important;
    border-radius: 16px !important;
    margin: 0 auto !important;
    padding: 12px !important;
    overflow-y: auto !important;
  }
}

/* ====== DARK THEME: PALETA PASTEL AJUSTADA A OSCURO ====== */
[data-theme="dark"] {
  /* Pasteles ajustados (eran muy claros en oscuro) */
  --pastel-blue:   #2b3b4a;
  --pastel-yellow: #4a4631;
  --pastel-green:  #2d4a39;
  --pastel-red:    #5a2c2c;

  /* Superficies semánticas para tarjetas/menús/modales */
  --card-bg:       #1f2a36;
  --surface-2:     #233142;
  --surface-3:     #2a3b4e;

  /* Texto secundario legible en oscuro */
  --muted-text:    #b8c2cc;
}

/* ====== DARK THEME: OVERRIDES DE COMPONENTES QUE HOY USAN #fff ====== */

/* Tarjetas, ítems y contenedores */
[data-theme="dark"] .item,
[data-theme="dark"] .wishlist-item,
[data-theme="dark"] .inventory-item,
[data-theme="dark"] .closet-item {
  background: var(--card-bg);
  box-shadow: 0 3px 8px rgba(0,0,0,.35);
}

/* Contenidos de modales (preview/login/perfil/wishlist/inventory/closet/alert) */
[data-theme="dark"] .preview-content,
[data-theme="dark"] .login-content,
[data-theme="dark"] .profile-content,
[data-theme="dark"] .wishlist-content,
[data-theme="dark"] .inventory-content,
[data-theme="dark"] .closet-content,
[data-theme="dark"] .alert-content {
  background: var(--surface-2);
  color: var(--text-color);
}

/* Dropdowns y menú lateral */
[data-theme="dark"] .dropdown-menu {
  background: var(--surface-2);
}
[data-theme="dark"] .dropdown-menu a {
  background: transparent;
}
[data-theme="dark"] .menu {
  background: var(--surface-3);
}

/* Badges y chips */
[data-theme="dark"] .wishlist-count,
[data-theme="dark"] .tag,
[data-theme="dark"] .tag.coins,
[data-theme="dark"] .tag.sellable,
[data-theme="dark"] .tag.giftable {
  background: var(--surface-3);
  color: var(--text-color);
}

/* Inputs / áreas con fondo pastel en claro */
[data-theme="dark"] .search-bar input[type="text"],
[data-theme="dark"] .login-content input,
[data-theme="dark"] .comment-form textarea,
[data-theme="dark"] .comments-container,
[data-theme="dark"] .wishlist-scroll-container,
[data-theme="dark"] .inventory-scroll-container,
[data-theme="dark"] .closet-scroll-container {
  background: #1F2A36;
  color: #fff;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.2);
}

/* Texto secundario */
[data-theme="dark"] .wishlist-item-details .timestamp,
[data-theme="dark"] .inventory-item .quantity,
[data-theme="dark"] .closet-item .quantity,
[data-theme="dark"] .comment-details .content {
  color: var(--muted-text);
}

/* Botones en modales/acciones */
[data-theme="dark"] .close-preview,
[data-theme="dark"] .close-login,
[data-theme="dark"] .close-profile,
[data-theme="dark"] .close-wishlist,
[data-theme="dark"] .close-inventory,
[data-theme="dark"] .alert-close-btn,
[data-theme="dark"] .add-wishlist-btn,
[data-theme="dark"] .inventory-btn,
[data-theme="dark"] .closet-btn,
[data-theme="dark"] .wishlist-btn,
[data-theme="dark"] .logout-btn,
[data-theme="dark"] .login-content button {
  background: var(--pastel-blue);
  color: var(--text-color);
}

/* Hover de dropdown */
[data-theme="dark"] .dropdown-menu a:hover {
  background: var(--surface-3);
}

/* Bordes inferiores y separadores */
[data-theme="dark"] header,
[data-theme="dark"] .comment-section {
  border-color: var(--pastel-blue);
}

[data-theme="dark"] .search-bar{
  background-color: #2c3e508c;
}
[data-theme="dark"] .language-select{
  background: #1f2f3c;
  color: #f0f6ff;
  border-color: #4f6a84;
}
[data-theme="dark"] .menu-language-label{
  color: #e8f1ff;
}
/* Transición suave (opcional) */
html, body, header, .search-bar, .item, .preview-content, .login-content, .profile-content,
.wishlist-content, .inventory-content, .closet-content, .dropdown-menu, .menu {
  transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

.delete-comment-btn {
  --del-bg: #e74c3c;         /* rojo base */
  --del-bg-hover: #c0392b;   /* rojo más oscuro */
  --del-fg: #fff;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 10px;
  min-width: 36px;
  height: 36px;
  border: none;
  border-radius: 10px;
  background: var(--del-bg);
  color: var(--del-fg);
  cursor: pointer;
  transition: background .2s ease, transform .05s ease;
  box-shadow: 0 2px 4px rgba(0,0,0,.12);
}

.delete-comment-btn:hover { background: var(--del-bg-hover); }
.delete-comment-btn:active { transform: translateY(1px); }
.delete-comment-btn svg { width: 18px; height: 18px; display: block; fill: currentColor; }

/* Cuando el comentario es estrecho, que el botón no rompa el layout */
.comment .delete-comment-btn { margin-left: auto; }

/* Dark theme: mantener contraste */
[data-theme="dark"] .delete-comment-btn {
  --del-bg: #e74c3c;
  --del-bg-hover: #cf3d2d;
  --del-fg: #fff;
}
/* ====== Pretty Confirm Modal ====== */
/* ====== Pretty Confirm Modal ====== */
.pmodal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;

  /* claves para ganar la pila */
  z-index: 100;      /* súbelo por encima del modal existente */
  isolation: isolate;   /* crea su propio stacking context */
}
.pmodal[aria-hidden="false"] { display: flex; }

/* asegura las capas internas */

.pmodal__backdrop { position: absolute; inset: 0; z-index: 0; background: rgba(0,0,0,.35);
 }
.pmodal__dialog   { position: relative; z-index: 1; width: min(92vw, 420px); background: #fff; border-radius: 18px; box-shadow: 0 12px 40px rgba(0,0,0,.18); padding: 20px 18px 16px; animation: pmodal-pop .18s ease-out; }


@keyframes pmodal-pop {
  from { transform: translateY(8px) scale(.98); opacity: 0; }
  to   { transform: translateY(0)   scale(1);    opacity: 1; }
}

.pmodal__title {
  margin: 0 32px 6px 0;
  font-size: 1.05rem; font-weight: 700; color: #2b2b2b;
}
.pmodal__text  { margin: 0 0 14px; color: #4a4a4a; line-height: 1.4; white-space: pre-line; }
.pmodal__desc-block{
  margin-bottom: 10px;
  font-weight: 600;
  color: inherit;
}
.pmodal__meta-list{
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
}
.pmodal__meta-row{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 10px;
  padding: 8px 10px;
}
.pmodal__meta-label{
  font-weight: 700;
  color: #425a70;
}
.pmodal__meta-value{
  font-weight: 700;
  color: #1a2a39;
  text-align: right;
  word-break: break-word;
}
.pmodal__warning{
  border: 1px solid #ffd0d6;
  background: #fff2f4;
  color: #7c1f34;
  border-radius: 10px;
  padding: 9px 10px;
  font-size: 13px;
}

.pmodal__close {
  position: absolute; top: 8px; right: 8px;
  width: 32px; height: 32px;
  border: none; border-radius: 10px;
  background: #f2f2f2; color: #555; cursor: pointer;
}
.pmodal__close:hover { background: #e8e8e8; }

.pmodal__actions {
  display: flex; gap: 10px; justify-content: flex-end;
}

.pmodal__btn {
  appearance: none; border: none; cursor: pointer;
  padding: 10px 14px; border-radius: 12px; font-weight: 600;
  box-shadow: 0 2px 4px rgba(0,0,0,.08);
  transition: transform .05s ease, filter .15s ease;
}
.pmodal__btn:active { transform: translateY(1px); }

/* Pasteles */
.pmodal__btn--cancel {
  background: #e8f0fe;           /* azul pastel */
  color: #1f3b7a;
}
.pmodal__btn--cancel:hover { filter: brightness(.96); }

.pmodal__btn--ok {
  background: #ffdfe0;           /* rosa pastel */
  color: #7b1e2e;
}
.pmodal__btn--ok:hover { filter: brightness(.96); }

/* Modo oscuro si lo usas */
[data-theme="dark"] .pmodal__dialog { background:#111315; color:#f5f5f5; }
[data-theme="dark"] .pmodal__text { color:#d7d7d7; }
[data-theme="dark"] .pmodal__meta-row{ background:#1d2329; border-color:#384450; }
[data-theme="dark"] .pmodal__meta-label{ color:#a7c2dc; }
[data-theme="dark"] .pmodal__meta-value{ color:#e5eef8; }
[data-theme="dark"] .pmodal__warning{ background:#3a2126; border-color:#6e3943; color:#ffd7df; }
[data-theme="dark"] .pmodal__close { background:#1a1c1f; color:#ddd; }
[data-theme="dark"] .pmodal__btn--cancel { background:#1f2a44; color:#d9e5ff; }
[data-theme="dark"] .pmodal__btn--ok { background:#3a2226; color:#ffd6db; }

/* Username change confirm variant */
.pmodal--username-change .pmodal__dialog {
  width: min(94vw, 460px);
  border: 2px solid #ffe0b2;
  background: linear-gradient(180deg, #fffdf9 0%, #fff7ea 100%);
}
.pmodal--username-change .pmodal__title {
  color: #7a4c00;
  font-size: 1.08rem;
}
.pmodal--username-change .pmodal__text {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid #ffd9a3;
  border-radius: 12px;
  padding: 12px 12px;
  color: #5f4308;
}
.pmodal--username-change .pmodal__btn--ok {
  background: #ffd39a;
  color: #5c3100;
  font-weight: 700;
}
.pmodal--username-change .pmodal__meta-row{
  background: rgba(255,255,255,.95);
  border-color: #f0c78f;
}
.pmodal--username-change .pmodal__meta-label{
  color: #7f5718;
}
.pmodal--username-change .pmodal__meta-value{
  color: #4d3203;
}
.pmodal--username-change .pmodal__warning{
  background: #fff3e1;
  border-color: #f0c88a;
  color: #704302;
}

[data-theme="dark"] .pmodal--username-change .pmodal__dialog {
  border-color: #5f4a2c;
  background: linear-gradient(180deg, #1d1a14 0%, #17140f 100%);
}
[data-theme="dark"] .pmodal--username-change .pmodal__title { color: #ffdca8; }
[data-theme="dark"] .pmodal--username-change .pmodal__text {
  background: rgba(30, 24, 18, 0.9);
  border-color: #705535;
  color: #f0d5ab;
}
[data-theme="dark"] .pmodal--username-change .pmodal__btn--ok {
  background: #8a5a20;
  color: #fff0dc;
}

@media (max-width: 520px) {
  .pmodal--username-change .pmodal__dialog {
    width: calc(100vw - 24px);
    border-radius: 16px;
    padding: 16px 14px 14px;
  }
  .pmodal--username-change .pmodal__actions {
    gap: 8px;
  }
  .pmodal--username-change .pmodal__btn {
    padding: 10px 12px;
  }
}
#eruda, .eruda, .eruda-container {
  z-index: 2147483647 !important;
  pointer-events: auto !important;
  touch-action: auto !important;
  position: fixed !important;
}

/* If you ever see the UI "frozen" on Safari mobile while eruda is enabled,
   you can temporarily disable pointer events on the overlay by uncommenting:
#eruda, .eruda, .eruda-container { pointer-events: none !important; }
*/

#eruda * { touch-action: auto !important; }

/* Safari perf hints para muchas tarjetas */
.item {
  contain: paint;         /* aisla layout/paint de cada card */
  will-change: transform;   /* previene jank en hover/scroll */
}

/* Si en móviles se nota pesado, desactiva sombras fuertes */
@supports (-webkit-touch-callout: none) {
  .item { box-shadow: 0 1px 3px rgba(0,0,0,.12); }
}


/* === PATCH: Visibilidad modal de confirmación === */
#confirmModal {
  position: fixed;
  inset: 0;
  display: none; /* será controlado por aria-hidden */
  align-items: center;
  justify-content: center;
  z-index: 100; /* será subido por JS si hace falta */
  isolation: isolate;
}
#confirmModal[aria-hidden="false"] { display: flex; }

/* Si usas clase pmodal, mantenemos compatibilidad */
.pmodal[aria-hidden="false"] { display: flex; }
.pmodal[aria-hidden="true"]  { display: none; }

/* Backdrop básico si no existiera */
.pmodal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.5);
}

/* === PATCH: overlays que pueden tapar botones === */
/* Deja pasar clics del contenedor, pero mantiene clickeables sus hijos */
.search-bar { pointer-events: none; }
.search-bar * { pointer-events: auto; }

/* ===== Level rewards: tile en el menú ===== */
/* ===== Tiles del menú: Level rewards + Free Gift ===== */
.menu .menu-tile.levelrewards-tile,
.menu .menu-tile.levelrewards-tile-gifts{
  width: 100%;
  aspect-ratio: 1 / 1;      /* cuadrado */
  background: var(--pastel-yellow);
  border: 2px solid var(--pastel-blue);
  border-radius: 16px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
  transition: transform .15s ease, filter .15s ease, background .2s ease;
  margin-bottom: 0px;
}

.menu .menu-tile.levelrewards-tile:hover,
.menu .menu-tile.levelrewards-tile-gifts:hover{
  transform: translateY(-2px);
  background: #fff3a8;
}

.menu .menu-tile.levelrewards-tile:active,
.menu .menu-tile.levelrewards-tile-gifts:active{
  transform: translateY(0);
}

.menu .menu-tile.levelrewards-tile .tile-icon,
.menu .menu-tile.levelrewards-tile-gifts .tile-icon{
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.menu .menu-tile.levelrewards-tile .tile-label,
.menu .menu-tile.levelrewards-tile-gifts .tile-label{
  font-family: 'Comic', sans-serif;
  font-size: 14px;
  color: var(--text-color);
}

/* Modo oscuro */
[data-theme="dark"] .menu .menu-tile.levelrewards-tile,
[data-theme="dark"] .menu .menu-tile.levelrewards-tile-gifts{
  background: var(--pastel-yellow);
  border-color: var(--pastel-blue);
}

[data-theme="dark"] .menu .menu-tile.levelrewards-tile:hover,
[data-theme="dark"] .menu .menu-tile.levelrewards-tile-gifts:hover{
  filter: brightness(1.05);
}



.menu-special-tiles{
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.menu .menu-tile.levelrewards-tile{
  width: 100%;
  margin: 0;
  flex-shrink: 0;
}
/* ===== Level rewards: modal y grid ===== */
.levelrewards-content{
  width: min(980px, 96vw);
  max-width: 980px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.levelrewards-filters{
  display:flex; align-items:center; gap:8px; margin-top: 6px;
}
.levelrewards-filters input[type="number"]{
  width:120px; padding:6px 8px; border:2px solid var(--pastel-blue);
  border-radius:10px; background: var(--pastel-yellow);
  font-family: 'Comic', sans-serif;
}

.levelrewards-scroll-container{
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow-y: auto;
  overflow-x: hidden;
  margin-top: 12px;
  background: var(--pastel-yellow);
  border-radius: 10px;
  padding: 12px;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.1);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  touch-action: pan-y;
}

/* Cada sección de nivel */
.level-block{
  background: #fff;
  border-radius: 12px;
  padding: 10px;
  margin-bottom: 12px;
  box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
[data-theme="dark"] .level-block{
  background: var(--card-bg);
}

.gift-modal{
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: none;
}

.gift-modal.active{
  display: block;
}

.gift-modal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
}

.gift-modal__dialog{
  position: relative;
  z-index: 1;
  width: min(92vw, 420px);
  margin: 8vh auto 0;
  border-radius: 22px;
  padding: 22px 18px 20px;
  text-align: center;
  box-shadow: 0 20px 50px rgba(0,0,0,.28);
  overflow: hidden !important;

  background-image: url('https://petsocietyislandcloud.com/wiki/images/modalclaim.png') !important;
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-color: transparent !important;
}
.gift-modal__claim{
  border: none;
  outline: none;
  background: url('https://petsocietyislandcloud.com/wiki/images/redBtn.png') center center / 100% 100% no-repeat;
  width: 220px;
  height: 72px;
  cursor: pointer;
  font-family: 'GROBOLD', sans-serif;
  font-size: 25px;
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0,0,0,.25);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-shadow: none;
}

.gift-modal__dialog::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.15);
  z-index: 0;
}

.gift-modal__dialog > *{
  position: relative;
  z-index: 1;
}.gift-modal__content{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 18px;
  background: transparent !important;
}

.gift-modal__close{
  position: absolute;
  top: 10px;
  right: 12px;
  border: none;
  background: transparent;
  font-size: 28px;
  cursor: pointer;
  color: #666;
}



.gift-modal__title{
  margin: 4px 0 16px;
  font-size: 24px;
  font-weight: normal;
  font-family: 'GROBOLD', sans-serif;
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0,0,0,.25);
}
.gift-modal__content{
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 18px;
  background: rgba(255,255,255,.88);
  border-radius: 18px;
  padding: 16px;
}

.gift-modal__image{
  max-width: 220px;
  max-height: 220px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.gift-result-modal{
  position: fixed;
  inset: 0;
  z-index: 6000;
  display: none;
}

.gift-result-modal.active{
  display: block;
}

.gift-result-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
}

.gift-result-dialog{
  position: relative;
  z-index: 1;
  width: min(92vw, 360px);
  margin: 14vh auto 0;
  background: #fff;
  border-radius: 20px;
  padding: 24px 20px;
  text-align: center;
  box-shadow: 0 20px 50px rgba(0,0,0,.28);
}

.gift-result-dialog h3{
  margin: 0 0 10px;
  font-size: 24px;
}

.gift-result-dialog p{
  margin: 0 0 18px;
  font-size: 16px;
  color: #444;
}

.gift-result-ok{
  border: none;
  border-radius: 14px;
  padding: 12px 22px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(135deg, #22c55e, #16a34a);
}

/* ===== Free gift modal (authoritative responsive polish) ===== */
#freeGiftModal.gift-modal{
  display: none;
  place-items: center;
}
#freeGiftModal.gift-modal.active{
  display: grid;
}
#freeGiftModal .gift-modal__backdrop{
  background: radial-gradient(circle at 18% 18%, rgba(255,255,255,.16), rgba(0,0,0,.62));
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  opacity: 0;
}
#freeGiftModal .gift-modal__dialog{
  width: min(92vw, 430px);
  min-height: 0 !important;
  margin: 0 auto !important;
  padding: 18px 16px 16px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.55);
  display: grid !important;
  justify-items: center;
  align-content: start;
  gap: 10px;
  box-shadow: 0 22px 55px rgba(17, 27, 36, .4);
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.05)),
    url('https://petsocietyislandcloud.com/wiki/images/modalclaim.png') !important;
  background-position: center !important;
  background-size: cover !important;
  background-repeat: no-repeat !important;
  opacity: 0;
  transform: translateY(14px) scale(.96);
}
#freeGiftModal .gift-modal__close{
  position: absolute !important;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.5);
  background: rgba(20, 36, 48, .35);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
#freeGiftModal .gift-modal__close:hover{
  background: rgba(20, 36, 48, .55);
}
#freeGiftModal .gift-modal__title{
  margin: 4px 34px 0;
  text-align: center;
  font-family: 'GROBOLD', sans-serif;
  font-size: 30px;
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0,0,0,.34);
}
#freeGiftModal .gift-modal__subtitle{
  margin: -4px 24px 2px;
  text-align: center;
  color: #eef7ff;
  font-size: 13px;
  line-height: 1.2;
  text-shadow: 1px 1px 0 rgba(0,0,0,.24);
}
#freeGiftModal .gift-modal__content{
  width: min(94%, 310px);
  margin: 0;
  padding: 12px 10px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,250,255,.92)) !important;
  border: 1px solid rgba(173, 207, 228, .7);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 8px 18px rgba(55, 86, 110, .18);
  display: grid;
  justify-items: center;
  gap: 10px;
}
#freeGiftModal .gift-modal__image{
  width: min(100%, 220px) !important;
  max-width: 220px;
  max-height: 220px;
  height: auto !important;
  margin: 0;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(33, 54, 74, .2));
}
#freeGiftModal .gift-modal__claim{
  width: min(220px, 74vw);
  height: clamp(60px, 10vw, 72px);
  font-size: clamp(20px, 5.2vw, 25px);
  letter-spacing: .3px;
  transform: translateZ(0);
}

#freeGiftModal.gift-modal.active .gift-modal__backdrop{
  animation: freeGiftFadeIn .24s ease forwards;
}

#freeGiftModal.gift-modal.active .gift-modal__dialog{
  animation: freeGiftPopIn .28s cubic-bezier(.2,.8,.2,1) forwards;
}

@keyframes freeGiftFadeIn{
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes freeGiftPopIn{
  0% {
    opacity: 0;
    transform: translateY(14px) scale(.96);
  }
  70% {
    opacity: 1;
    transform: translateY(-2px) scale(1.01);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 700px){
  #freeGiftModal.gift-modal{
    align-items: center;
    justify-items: center;
    padding: max(10px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
  }
  #freeGiftModal .gift-modal__dialog{
    width: min(94vw, 420px);
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 20px);
    overflow-y: auto;
    border-radius: 18px;
    padding: 14px 12px 12px;
    gap: 8px;
  }
  #freeGiftModal .gift-modal__title{
    font-size: 26px;
    margin-left: 28px;
    margin-right: 28px;
  }
  #freeGiftModal .gift-modal__subtitle{
    font-size: 12px;
    margin-left: 16px;
    margin-right: 16px;
  }
  #freeGiftModal .gift-modal__content{
    width: min(100%, 292px);
    padding: 10px;
  }
  #freeGiftModal .gift-modal__image{
    width: min(86vw, 190px) !important;
    max-width: 190px;
    max-height: 190px;
  }
}

html[data-theme="dark"] #freeGiftModal .gift-modal__dialog{
  border-color: rgba(94, 130, 156, .7);
  box-shadow: 0 22px 55px rgba(0, 0, 0, .56);
}
html[data-theme="dark"] #freeGiftModal .gift-modal__content{
  background: linear-gradient(180deg, rgba(26,45,60,.92), rgba(22,39,53,.9)) !important;
  border-color: rgba(78, 116, 142, .75);
}
html[data-theme="dark"] #freeGiftModal .gift-modal__subtitle{
  color: #d5e8f7;
}

.no-scroll{
  overflow: hidden;
}

/* Softer body lock for long modals (keeps inner touch scroll responsive) */
body.no-scroll-level{
  overflow: hidden;
}

/* Header del nivel */
.level-header{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom: 10px;
}
.level-title{
  font-weight: 700; font-size: 16px;
}

/* Grid de premios */
.level-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(95px, 1fr));
  gap:10px;
}

/* Slot del premio (similar a .item pero compacto) */
.level-slot{
  background:#ffffff;
  border-radius:10px;
  padding:6px;
  text-align:center;
  box-shadow: 0 2px 4px rgba(0,0,0,.08);
}
[data-theme="dark"] .level-slot{ background: var(--surface-2); }

.level-slot img{
  width:100%; height:70px; object-fit:contain; border-radius:8px;
  background: #fafafa;
}
[data-theme="dark"] .level-slot img{ background:#1f2a36; }

.level-slot .name{
  font-size:12px; margin-top:6px; min-height: 30px;
  display:flex; align-items:center; justify-content:center;
  color: var(--text-color);
}

/* Ancla para hacer jump-to-level */
.level-anchor{
  position: relative;
  top: -70px; /* compensa el header fijo si lo tienes */
  visibility: hidden;
}

/* --- Menú en cuadrícula 3 × Y --- */
.menu,
.menu.active{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-content: start;
}

/* El bloque de categorías ocupa todo el ancho arriba */
.menu .dropdown{
  grid-column: 1 / -1;
}

/* Tamaño compacto para todos los tiles del menú */
.menu .menu-tile{
  width: 100%;
  aspect-ratio: 1 / 1;      /* cuadrado */
  padding: 8px;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* Icono y etiqueta más pequeños */
.menu .menu-tile .tile-icon{
  width: 44px;
  height: 44px;
  object-fit: contain;
}
.menu .menu-tile .tile-label{
  font-size: 12px;
  line-height: 1.1;
}

/* Asegura que el tile Level rewards siga el look pastel y compacto */
.menu .menu-tile.levelrewards-tile{
  background: var(--pastel-yellow, #ffef96);
  border: 2px solid var(--pastel-blue, #a3c4f3);
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
  transition: transform .15s ease, filter .15s ease;
}
.menu .menu-tile.levelrewards-tile:hover{ transform: translateY(-1px); }

/* Responsive opcional:
   - Muy estrecho: 2 columnas
   - Tablet: 4 columnas
   - Desktop grande: 5 columnas */
@media (max-width: 360px){
  .menu, .menu.active{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 640px){
  .menu, .menu.active{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}
@media (min-width: 1200px){
  .menu, .menu.active{ grid-template-columns: repeat(5, minmax(0,1fr)); }
}

/* Evita que la grid estire la altura de los tiles */
.menu,
.menu.active{
  align-items: start;               /* no estirar verticalmente */
  grid-auto-rows: auto;             /* deja que cada tile mida su propio alto */
}

/* Fuerza proporción 1:1 y evita estiramientos accidentales */
.menu .menu-tile{
  aspect-ratio: 1 / 1;              /* moderno */
  height: auto;                     /* previene que algo lo fuerce */
  min-height: 0;                    /* importante en algunos layouts */
}

/* Fallback sólido si el navegador ignora aspect-ratio o la grid fuerza alto:
   - Coloca contenido en posición absoluta dentro de un cuadro cuadrado */
@supports not (aspect-ratio: 1 / 1){
  .menu .menu-tile{
    position: relative;
    padding: 0;                     /* lo maneja el pseudo-elemento */
  }
  .menu .menu-tile::before{
    content: "";
    display: block;
    padding-top: 100%;              /* 1:1 */
  }
  .menu .menu-tile > *{
    position: absolute;
    inset: 8px;                     /* respeta tu padding compacto */
  }
}

/* (Opcional) Ajuste específico por escritorio si notas estiramiento en pantallas anchas */
@media (min-width: 900px){
  .menu, .menu.active{
    align-items: start;
    grid-auto-rows: auto;
  }
}

.current-level{
  margin: 6px 0 10px;
  font-weight: 600;
}

/* Oscuro: contenedor principal del listado */
[data-theme="dark"] .levelrewards-scroll-container{
  background: #0e2942;          /* azul muy oscuro */
  border: 1px solid #1f3b5b;    /* borde sutil */
  box-shadow: inset 0 1px 3px rgba(0,0,0,.35);
}

/* Oscuro: input del salto de nivel */
[data-theme="dark"] .levelrewards-filters input[type="number"]{
  background: #0e2942;
  border-color: #3b6ea9;
  color: #e8f0ff;
}
[data-theme="dark"] .levelrewards-filters input[type="number"]::placeholder{
  color: #a5c0e0;
}

#levelRewardsModal{
  padding: 10px 0;
}
#levelRewardsModal .inventory-content.levelrewards-content{
  width: min(980px, 96vw);
}

@media (max-width: 900px){
  #levelRewardsModal{
    align-items: flex-start !important;
    justify-content: center !important;
    padding: calc(8px + env(safe-area-inset-top)) 0 calc(10px + env(safe-area-inset-bottom));
  }
  #levelRewardsModal .inventory-content.levelrewards-content{
    width: 92vw;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 18px);
    margin: 0 auto;
    border-radius: 16px;
    padding: 14px 12px 12px;
  }
  .levelrewards-filters{
    flex-wrap: wrap;
    gap: 7px;
  }
  .levelrewards-filters input[type="number"]{
    width: 100%;
    max-width: 180px;
  }
  .levelrewards-scroll-container{
    margin-top: 8px;
    padding: 10px;
  }
}

/* (Opcional) Oscuro: tarjetas/slots para armonizar con el azul */
[data-theme="dark"] .level-block{
  background: #0b2036;
}
[data-theme="dark"] .level-slot{
  background: #0f2741;
}
[data-theme="dark"] .level-slot img{
  background: #0b2036;
}

/* ==== FIX para el tile Level rewards (sin desbordes y cuadrado) ==== */
.menu .menu-tile.levelrewards-tile{
  /* cuadrado y sin estirarse */
  aspect-ratio: 1 / 1;
  height: auto;
  min-height: 0;
  position: relative;
  overflow: hidden;          /* evita que imagen/texto se salgan */
  box-sizing: border-box;
  padding: 10px;             /* un poco más de aire para PC */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* Icono: que NUNCA se salga del botón */
.menu .menu-tile.levelrewards-tile .tile-icon{
  display: block;
  width: auto;
  height: auto;
  max-width: 70%;            /* caben márgenes laterales */
  max-height: 58%;           /* evita que empuje al texto fuera */
  object-fit: contain;
}

/* Texto: que no se corte ni se salga */
.menu .menu-tile.levelrewards-tile .tile-label{
  max-width: 90%;
  text-align: center;
  white-space: normal;       /* permite salto si es necesario */
  word-break: break-word;
  line-height: 1.1;
  font-size: 13px;           /* un poquito más grande para PC */
}

/* Por si alguna regla previa empuja alturas en la grid del menú */
.menu, .menu.active{
  align-items: start;
  grid-auto-rows: auto;
}

/* ===== Hard mobile fit for My Profile modal (keep rounded corners visible) ===== */
@media (max-width: 900px){
  #profileModal{
    align-items: flex-start !important;
    justify-content: center !important;
    padding: 0 !important;
  }

  #profileModal .profile-content{
    width: 92vw !important;
    height: auto !important;
    min-height: 0 !important;
    margin-top: calc(10px + env(safe-area-inset-top)) !important;
    margin-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
    overflow-y: auto !important;
    border-radius: 16px !important;
  }
}

/* Fallback si el navegador no soporta aspect-ratio (raro, pero seguro) */
@supports not (aspect-ratio: 1 / 1){
  .menu .menu-tile.levelrewards-tile{
    padding: 0;
  }
  .menu .menu-tile.levelrewards-tile::before{
    content: "";
    display: block;
    padding-top: 100%;       /* mantiene 1:1 */
  }
  .menu .menu-tile.levelrewards-tile > *{
    position: absolute;
    inset: 8px;
  }
}.menu .menu-tile.levelrewards-tile{
  min-width: 90px;   /* fuerza ancho mínimo mayor */
  min-height: 70px;  /* crece manteniendo 1:1 por aspect-ratio */
  padding: 12px;      /* opcional, más aire */
}

/* ===== Login modal refresh ===== */
#loginModal{
  padding: 10px 0;
}
#loginModal .login-content{
  width: min(520px, 94vw);
  max-height: 86vh;
  padding: 18px 16px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffdf6, #f5fff8);
  border: 1px solid #d8e7da;
}
#loginModal .close-login{
  top: 12px;
  right: 12px;
}
#loginModal h2{
  margin: 4px 36px 14px 0;
  font-size: 22px;
  line-height: 1.18;
  color: #2b3e51;
}
#loginModal #loginForm{
  display: grid;
  gap: 10px;
}
#loginModal #loginForm input[type="text"],
#loginModal #loginForm input[type="password"]{
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #c8dce0;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 15px;
  background: #ffffff;
  color: #243646;
}
#loginModal #loginForm input::placeholder{
  color: #6d7f90;
}
#loginModal #loginForm input:focus{
  outline: 2px solid #b7dfc3;
  outline-offset: 1px;
}
#loginModal #loginForm button[type="submit"]{
  margin-top: 2px;
  width: 100%;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 12px;
  background: #cfead4;
  color: #233d2d;
  border: 1px solid #a9d3b3;
  font-weight: 700;
}
#loginModal #loginForm button[type="submit"]:hover{
  background: #bee2c7;
}
#loginModal #loginError{
  min-height: 20px;
  margin-top: 6px;
}
#loginModal .forgot-password{
  display: inline-block;
  margin-top: 4px;
  color: #3d5d78;
  font-weight: 600;
}
#loginModal .forgot-password:hover{
  color: #2c4d66;
}

html[data-theme="dark"] #loginModal .login-content{
  background: linear-gradient(180deg, #1b2a35, #1a3328);
  border-color: #3a5a49;
}
html[data-theme="dark"] #loginModal h2{
  color: #d8e9f6;
}
html[data-theme="dark"] #loginModal #loginForm input[type="text"],
html[data-theme="dark"] #loginModal #loginForm input[type="password"]{
  background: #1f2f3d;
  border-color: #3f5f62;
  color: #edf5fc;
}
html[data-theme="dark"] #loginModal #loginForm input::placeholder{
  color: #9fb2c2;
}
html[data-theme="dark"] #loginModal #loginForm button[type="submit"]{
  background: #355643;
  color: #e8f7ed;
  border-color: #4f7a61;
}
html[data-theme="dark"] #loginModal #loginForm button[type="submit"]:hover{
  background: #406a52;
}
html[data-theme="dark"] #loginModal .forgot-password{
  color: #b7d3ea;
}
html[data-theme="dark"] #loginModal .forgot-password:hover{
  color: #d2e5f4;
}

@media (max-width: 700px){
  #loginModal{
    align-items: flex-start !important;
    padding: calc(10px + env(safe-area-inset-top)) 0 calc(12px + env(safe-area-inset-bottom));
  }
  #loginModal .login-content{
    width: 92vw;
    margin: 0 auto;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px);
    border-radius: 16px;
    padding: 14px 12px 12px;
  }
  #loginModal h2{
    font-size: 19px;
    margin-right: 34px;
  }
}

/* ===== Login modal polish overrides ===== */
#loginModal .login-content{
  position: relative;
  overflow: hidden;
  box-shadow: 0 14px 34px rgba(56, 86, 63, 0.24);
}
#loginModal .login-content::before{
  content: "";
  position: absolute;
  inset: -40% -10% auto -10%;
  height: 160px;
  background: radial-gradient(circle at 20% 40%, rgba(255, 232, 170, 0.38), transparent 55%),
              radial-gradient(circle at 78% 28%, rgba(198, 236, 210, 0.45), transparent 56%);
  pointer-events: none;
}
#loginModal h2{
  text-align: center;
  margin-left: 0;
}
#loginModal #loginForm,
#loginModal #loginError,
#loginModal .forgot-password{
  position: relative;
  z-index: 1;
}
#loginModal #loginForm button[type="submit"]{
  box-shadow: 0 6px 14px rgba(120, 166, 133, 0.28);
}
#loginModal .forgot-password{
  width: 100%;
  text-align: center;
}

html[data-theme="dark"] #loginModal .login-content{
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.42);
}
html[data-theme="dark"] #loginModal .login-content::before{
  background: radial-gradient(circle at 22% 42%, rgba(154, 126, 58, 0.28), transparent 56%),
              radial-gradient(circle at 80% 28%, rgba(80, 130, 96, 0.34), transparent 58%);
}

@media (max-width: 700px){
  #loginModal{
    align-items: center !important;
    justify-content: center !important;
    padding: calc(10px + env(safe-area-inset-top)) 10px calc(12px + env(safe-area-inset-bottom));
  }
  #loginModal .login-content{
    margin: 0 auto !important;
  }
}

/* ===== Login mobile hard-center fix ===== */
@media (max-width: 700px){
  #loginModal{
    padding-left: max(10px, env(safe-area-inset-left));
    padding-right: max(10px, env(safe-area-inset-right));
  }
  #loginModal .login-content{
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    width: min(92vw, 520px);
    margin: 0 !important;
  }
}

/* ===== Login mobile center fix v2 (remove transform shift) ===== */
@media (max-width: 700px){
  #loginModal{
    align-items: center !important;
    justify-content: center !important;
    padding-left: max(10px, env(safe-area-inset-left));
    padding-right: max(10px, env(safe-area-inset-right));
  }
  #loginModal .login-content{
    position: static !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: min(92vw, 520px) !important;
    margin: 0 auto !important;
  }
}

/* ===== Login final layout (authoritative override) ===== */
#loginModal{
  display: none;
  align-items: center !important;
  justify-content: center !important;
  padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
}
#loginModal .login-content{
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  margin: 0 auto !important;
  width: min(520px, calc(100vw - 20px)) !important;
  max-width: 520px !important;
  box-sizing: border-box;
  border-radius: 18px;
  overflow: hidden;
}
#loginModal .close-login{
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  margin: 0 !important;
  z-index: 5;
}
#loginModal .login-brand-logo{
  display: block;
  width: min(230px, 72%);
  max-height: 92px;
  object-fit: contain;
  margin: 6px auto 8px;
  position: relative;
  z-index: 1;
}
#loginModal h2{
  text-align: center;
  font-size: 17px !important;
  line-height: 1.2;
  margin: 0 34px 12px 34px !important;
}
#loginModal .forgot-password{
  display: block;
  width: 100%;
  text-align: center;
}

@media (max-width: 700px){
  #loginModal{
    align-items: center !important;
    justify-content: center !important;
    padding: max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
  }
  #loginModal .login-content{
    width: min(520px, calc(100vw - 16px)) !important;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 16px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  #loginModal .login-brand-logo{
    width: min(210px, 74%);
    max-height: 84px;
  }
  #loginModal h2{
    font-size: 15px !important;
    margin-left: 26px !important;
    margin-right: 26px !important;
  }
}

/* ===== Login center parity with other modals (final hard override) ===== */
#loginModal{
  position: fixed !important;
  inset: 0 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}
#loginModal .login-content{
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  margin: 0 !important;
  width: min(520px, 92vw) !important;
  max-width: min(520px, 92vw) !important;
  max-height: 86vh !important;
  box-sizing: border-box;
}
#loginModal .close-login{
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  left: auto !important;
  transform: none !important;
  z-index: 10 !important;
}
#loginModal .login-brand-logo{
  display: block;
  width: min(220px, 70%) !important;
  height: auto;
  margin: 8px auto 8px !important;
}
#loginModal h2{
  font-size: 15px !important;
  text-align: center !important;
  margin: 0 30px 12px 30px !important;
}
#loginModal .forgot-password{
  display: block !important;
  text-align: center !important;
  width: 100% !important;
}

@media (max-width: 700px){
  #loginModal{
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
  }
  #loginModal .login-content{
    width: min(520px, 92vw) !important;
    max-width: min(520px, 92vw) !important;
    max-height: 88vh !important;
    margin: 0 !important;
  }
}

/* ===== Login extras: remember me + show password ===== */
#loginModal #loginForm .password-field{
  position: relative;
}
#loginModal #loginForm .password-field input{
  padding-right: 46px !important;
}
#loginModal #loginForm .toggle-password-btn{
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  padding: 0;
  color: #5a7386;
  cursor: pointer;
}
#loginModal #loginForm .toggle-password-btn .eye-icon{
  width: 18px;
  height: 18px;
  fill: currentColor;
  display: block;
}
#loginModal #loginForm .toggle-password-btn .eye-off{
  display: none;
}
#loginModal #loginForm .toggle-password-btn.is-visible .eye-open{
  display: none;
}
#loginModal #loginForm .toggle-password-btn.is-visible .eye-off{
  display: block;
}
#loginModal #loginForm .toggle-password-btn:focus{
  outline: 2px solid #9bcab1;
  outline-offset: 2px;
  border-radius: 999px;
}
#loginModal #loginForm .remember-me-row{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 2px 0 0;
  color: #36586c;
  font-size: 13px;
  font-weight: 600;
  user-select: none;
}
#loginModal #loginForm .remember-me-row input[type="checkbox"]{
  width: 16px;
  height: 16px;
  accent-color: #6aa873;
}
html[data-theme="dark"] #loginModal #loginForm .toggle-password-btn{
  color: #bdd4e3;
}
html[data-theme="dark"] #loginModal #loginForm .remember-me-row{
  color: #c5deee;
}

/* ===== Username change modal ===== */
#usernameChangeModal .username-change-content{
  width: min(680px, 94vw);
  max-height: 90vh;
  overflow: auto;
  border-radius: 20px;
  border: 1px solid #ead4c1;
  background: linear-gradient(180deg, #fffaf4 0%, #fff 36%, #f8fcff 100%);
  box-shadow: 0 18px 42px rgba(84, 56, 31, 0.22);
  padding: 18px 18px 16px;
}
#usernameChangeModal .username-change-content h3{
  margin: 2px 30px 12px 2px;
  font-size: 22px;
  line-height: 1.15;
  color: #5f3f24;
}
#usernameChangeModal .username-change-note{
  font-size: 13px;
  line-height: 1.35;
  color: #3d5362;
  background: #f4f9ff;
  border: 1px solid #d6e7f6;
  border-radius: 12px;
  padding: 9px 11px;
  margin: 0 0 9px;
}
#usernameChangeModal .username-change-note.warning{
  background: linear-gradient(180deg, #fff3e3, #ffe7ce);
  border-color: #f2c59c;
  color: #6a3b16;
}
#usernameChangeModal .username-change-note.success{
  background: linear-gradient(180deg, #ecfff1, #ddf6e7);
  border-color: #b9e7c9;
  color: #1f5a3b;
}
#usernameChangeModal .username-change-row{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin: 9px 0;
  font-size: 13px;
  background: #ffffffcc;
  border: 1px solid #e3ebf4;
  border-radius: 10px;
  padding: 8px 10px;
}
#usernameChangeModal .username-change-row span{
  text-align: right;
  font-weight: 700;
  color: #2c4860;
}
#usernameChangeModal .username-change-form{
  display: grid;
  gap: 9px;
  margin-top: 12px;
  background: #ffffffcc;
  border: 1px solid #dce7f2;
  border-radius: 14px;
  padding: 12px;
}
#usernameChangeModal .username-change-form input[type=\"text\"]{
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #b7cfe5;
  border-radius: 14px;
  padding: 11px 13px;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  color: #1f3142;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.2px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 2px 8px rgba(113, 145, 173, 0.16);
  transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}
#usernameChangeModal .username-change-form input[type=\"text\"]::placeholder{
  color: #7e95aa;
  font-weight: 500;
}
#usernameChangeModal .username-change-form input[type=\"text\"]:focus{
  outline: 2px solid #f2c59c;
  outline-offset: 1px;
  border-color: #e2b78f;
  box-shadow: 0 0 0 3px rgba(242, 197, 156, 0.28), 0 8px 18px rgba(109, 83, 56, 0.18);
  transform: translateY(-1px);
}
#usernameChangeModal .username-consent{
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: #365268;
}
#usernameChangeModal .username-consent input{
  margin-top: 2px;
  accent-color: #6aa873;
}
#usernameChangeModal .username-history-wrap{
  margin-top: 13px;
  background: #ffffffc7;
  border: 1px solid #dce8f4;
  border-radius: 14px;
  padding: 11px;
}
#usernameChangeModal .username-history-wrap h4{
  margin: 0 0 8px;
  font-size: 15px;
  color: #355066;
}
#usernameChangeModal .username-history-list{
  display: grid;
  gap: 6px;
}
#usernameChangeModal .username-history-item{
  border: 1px solid #d9e5f1;
  border-radius: 10px;
  padding: 8px 10px;
  background: #f8fcff;
}
#usernameChangeModal .username-history-main{
  font-size: 13px;
  color: #263d50;
}
#usernameChangeModal .username-history-date{
  margin-top: 3px;
  font-size: 12px;
  color: #587087;
}
#usernameChangeModal #usernameChangeSubmitBtn:disabled{
  opacity: 0.58;
  cursor: not-allowed;
  filter: grayscale(0.08);
  transform: none !important;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-content{
  background: linear-gradient(180deg, #1a2b39 0%, #172634 45%, #1c2430 100%);
  border-color: #3a5366;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-content h3{
  color: #ffe2c6;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-note{
  background: #243a4b;
  border-color: #3d5c72;
  color: #dcebf7;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-note.warning{
  background: #5b3b21;
  border-color: #8a5f40;
  color: #ffe7d0;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-note.success{
  background: #234737;
  border-color: #356951;
  color: #dff8e8;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-form input[type=\"text\"]{
  background: linear-gradient(180deg, #263d4f, #203444);
  border-color: #486a82;
  color: #ecf4fb;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 2px 8px rgba(0,0,0,0.28);
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-form input[type=\"text\"]::placeholder{
  color: #9bb5c8;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-row{
  background: #203445;
  border-color: #35576d;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-row span{
  color: #dcedf9;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-change-form{
  background: #1e3242;
  border-color: #35566c;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-consent{
  color: #d2e4f2;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-history-item{
  background: #223645;
  border-color: #35556c;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-history-wrap{
  background: #1e3242;
  border-color: #35566c;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-history-main{
  color: #e6f1fa;
}
html[data-theme=\"dark\"] #usernameChangeModal .username-history-date{
  color: #a9c0d3;
}

/* ===== Username modal theme compatibility (light/dark) ===== */
#usernameChangeModal{
  --uc-bg: linear-gradient(180deg, #fffaf4 0%, #fff 36%, #f8fcff 100%);
  --uc-border: #ead4c1;
  --uc-shadow: 0 18px 42px rgba(84, 56, 31, 0.22);
  --uc-title: #5f3f24;
  --uc-note-bg: #f4f9ff;
  --uc-note-border: #d6e7f6;
  --uc-note-text: #3d5362;
  --uc-row-bg: #ffffffcc;
  --uc-row-border: #e3ebf4;
  --uc-row-value: #2c4860;
  --uc-form-bg: #ffffffcc;
  --uc-form-border: #dce7f2;
  --uc-label: #2f4b61;
  --uc-input-bg: linear-gradient(180deg, #ffffff, #f7fbff);
  --uc-input-border: #b7cfe5;
  --uc-input-text: #1f3142;
  --uc-input-placeholder: #7e95aa;
  --uc-history-bg: #ffffffc7;
  --uc-history-border: #dce8f4;
  --uc-history-title: #355066;
  --uc-history-item-bg: #f8fcff;
  --uc-history-item-border: #d9e5f1;
  --uc-history-main: #263d50;
  --uc-history-date: #587087;
  --uc-close-bg: #d7e9f8;
  --uc-close-color: #254159;
  --uc-close-hover: #c6dff2;
}

html[data-theme="dark"] #usernameChangeModal{
  --uc-bg: linear-gradient(180deg, #1a2b39 0%, #172634 45%, #1c2430 100%);
  --uc-border: #3a5366;
  --uc-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
  --uc-title: #ffe2c6;
  --uc-note-bg: #243a4b;
  --uc-note-border: #3d5c72;
  --uc-note-text: #dcebf7;
  --uc-row-bg: #203445;
  --uc-row-border: #35576d;
  --uc-row-value: #dcedf9;
  --uc-form-bg: #1e3242;
  --uc-form-border: #35566c;
  --uc-label: #d2e4f2;
  --uc-input-bg: linear-gradient(180deg, #263d4f, #203444);
  --uc-input-border: #486a82;
  --uc-input-text: #ecf4fb;
  --uc-input-placeholder: #9bb5c8;
  --uc-history-bg: #1e3242;
  --uc-history-border: #35566c;
  --uc-history-title: #d6e7f6;
  --uc-history-item-bg: #223645;
  --uc-history-item-border: #35556c;
  --uc-history-main: #e6f1fa;
  --uc-history-date: #a9c0d3;
  --uc-close-bg: #2a4559;
  --uc-close-color: #e6f2fd;
  --uc-close-hover: #35586f;
}

#usernameChangeModal .username-change-content{
  background: var(--uc-bg) !important;
  border-color: var(--uc-border) !important;
  box-shadow: var(--uc-shadow) !important;
}
#usernameChangeModal .username-change-content h3{
  color: var(--uc-title) !important;
}
#usernameChangeModal .username-change-note{
  background: var(--uc-note-bg) !important;
  border-color: var(--uc-note-border) !important;
  color: var(--uc-note-text) !important;
}
#usernameChangeModal .username-change-row{
  background: var(--uc-row-bg) !important;
  border-color: var(--uc-row-border) !important;
}
#usernameChangeModal .username-change-row span{
  color: var(--uc-row-value) !important;
}
#usernameChangeModal .username-change-form{
  background: var(--uc-form-bg) !important;
  border-color: var(--uc-form-border) !important;
}
#usernameChangeModal #newUsernameLabel,
#usernameChangeModal #usernameCurrentLabel,
#usernameChangeModal #usernameNextLabel{
  color: var(--uc-label) !important;
}
#usernameChangeModal .username-change-form input[type="text"]{
  background: var(--uc-input-bg) !important;
  border-color: var(--uc-input-border) !important;
  color: var(--uc-input-text) !important;
}
#usernameChangeModal .username-change-form input[type="text"]::placeholder{
  color: var(--uc-input-placeholder) !important;
}
#usernameChangeModal .username-history-wrap{
  background: var(--uc-history-bg) !important;
  border-color: var(--uc-history-border) !important;
}
#usernameChangeModal .username-history-wrap h4{
  color: var(--uc-history-title) !important;
}
#usernameChangeModal .username-history-item{
  background: var(--uc-history-item-bg) !important;
  border-color: var(--uc-history-item-border) !important;
}
#usernameChangeModal .username-history-main{
  color: var(--uc-history-main) !important;
}
#usernameChangeModal .username-history-date{
  color: var(--uc-history-date) !important;
}
#usernameChangeModal .close-closet{
  background: var(--uc-close-bg) !important;
  color: var(--uc-close-color) !important;
}
#usernameChangeModal .close-closet:hover{
  background: var(--uc-close-hover) !important;
}

/* ===== Sidebar menu UX refresh (hamburger) ===== */
#menu.menu{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: min-content;
  align-content: start;
  gap: 12px;
  position: fixed;
  top: 0;
  left: 0;
  width: min(330px, 88vw);
  height: 100dvh;
  padding: 14px 14px 18px;
  overflow-y: auto;
  overflow-x: hidden;
  background: linear-gradient(180deg, #eaf6ff 0%, #f6fbff 36%, #fff8e8 100%);
  border-right: 1px solid #c8deef;
  box-shadow: 8px 0 28px rgba(32, 64, 90, 0.24);
  transform: translateX(-104%);
  transition: transform .24s ease, box-shadow .24s ease;
  z-index: 1001;
}

#menu.menu.active{
  display: grid !important;
  transform: translateX(0);
}

#menu.menu::before{
  content: "Menu";
  grid-column: 1 / -1;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .2px;
  color: #2e4960;
  background: #ffffffd4;
  border: 1px solid #cfe0ec;
  border-radius: 12px;
  padding: 8px 10px;
  text-align: center;
  box-shadow: 0 2px 10px rgba(80, 120, 150, 0.12);
}

#menu.menu .dropdown,
#menu.menu .menu-language-wrap,
#menu.menu .menu-special-tiles{
  grid-column: 1 / -1;
}

#menu.menu .dropdown-toggle{
  border: 1px solid #c6ddee;
  background: linear-gradient(180deg, #fff 0%, #eef8ff 100%);
  color: #294760;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(94, 139, 168, 0.14);
}

#menu.menu .dropdown-menu{
  margin-top: 8px;
  border: 1px solid #d5e5f1;
  background: #ffffffea;
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 6px 16px rgba(42, 67, 86, 0.16);
}

#menu.menu .dropdown-menu a{
  border-radius: 9px;
  padding: 7px 10px;
}

#menu.menu .dropdown-menu a:hover{
  background: #dff1ff;
}

#menu.menu .menu-language-wrap{
  margin: 0;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid #d4e5f2;
  background: #ffffffd1;
  display: grid;
  gap: 8px;
}

#menu.menu .menu-language-label{
  color: #33566f;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

#menu.menu .menu-language-label::before{
  content: "🌐";
  font-size: 14px;
  line-height: 1;
}

#menu.menu .language-select{
  width: 100%;
  border-radius: 10px;
  border: 1px solid #b8d3e5;
  background: #fffef1;
  box-shadow: none;
  padding: 9px 10px;
  font-size: 13px;
  font-weight: 700;
}

#menu.menu .menu-special-tiles{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 2px;
}

#menu.menu .menu-tile{
  width: 100%;
  min-height: 104px;
  border-radius: 14px;
  border: 1px solid #c8deef;
  background: linear-gradient(180deg, #fff9cf 0%, #fff3ab 100%);
  box-shadow: 0 4px 12px rgba(70, 95, 120, 0.14);
  transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
}

#menu.menu .menu-tile:hover{
  transform: translateY(-2px);
  filter: brightness(1.02);
  box-shadow: 0 8px 16px rgba(70, 95, 120, 0.2);
}

#menu.menu .menu-tile .tile-icon{
  width: 52px;
  height: 52px;
}

#menu.menu .menu-tile .tile-label{
  font-size: 12px;
  font-weight: 700;
  color: #2d4558;
}

.menu-backdrop{
  display: block;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  transition: opacity .2s ease, visibility .2s ease;
}

.menu-backdrop.active{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

html[data-theme="dark"] #menu.menu{
  background: linear-gradient(180deg, #152634 0%, #1a2e40 44%, #243421 100%);
  border-right-color: #35566d;
  box-shadow: 8px 0 30px rgba(0, 0, 0, 0.45);
}

html[data-theme="dark"] #menu.menu::before{
  background: #223749;
  border-color: #3c5e76;
  color: #dcecf8;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
}

html[data-theme="dark"] #menu.menu .dropdown-toggle{
  border-color: #3f6077;
  background: linear-gradient(180deg, #1f3547 0%, #253f53 100%);
  color: #d8ebfa;
}

html[data-theme="dark"] #menu.menu .dropdown-menu{
  border-color: #35566c;
  background: #1c3242f0;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] #menu.menu .dropdown-menu a{
  color: #deedf9;
  background: transparent;
}

html[data-theme="dark"] #menu.menu .dropdown-menu a:hover{
  background: #2c4c61;
}

html[data-theme="dark"] #menu.menu .menu-language-wrap{
  background: #1d3344;
  border-color: #365970;
}

html[data-theme="dark"] #menu.menu .menu-language-label{
  color: #cfe4f3;
}

html[data-theme="dark"] #menu.menu .language-select{
  border-color: #446984;
  background: #243a4d;
  color: #e7f2fb;
}

html[data-theme="dark"] #menu.menu .menu-tile{
  border-color: #4d6b2f;
  background: linear-gradient(180deg, #596f2a 0%, #4d6124 100%);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] #menu.menu .menu-tile .tile-label{
  color: #f1f8e8;
}

@media (max-width: 700px){
  #menu.menu{
    top: max(10px, env(safe-area-inset-top));
    left: 10px;
    width: min(300px, 78vw);
    height: auto;
    max-height: calc(100dvh - max(20px, env(safe-area-inset-top)) - max(20px, env(safe-area-inset-bottom)));
    padding: 12px 12px 16px;
    gap: 10px;
    border: 1px solid #c8deef;
    border-radius: 16px;
    border-right: 1px solid #c8deef;
    box-shadow: 0 10px 30px rgba(32, 64, 90, 0.28);
    overscroll-behavior: contain;
  }
}

/* ===== Bundle contents (preview) ===== */
.bundle-contents-btn{
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 12px;
  border: 1px solid #b8d9c4;
  border-radius: 10px;
  background: #eaf9ee;
  color: #274a34;
  font-family: 'Comic', sans-serif;
  font-weight: 700;
  cursor: pointer;
}
.bundle-contents-btn:hover{
  background: #d9f1e2;
}

#bundleContentsModal .bundle-contents-content{
  width: min(420px, 92vw);
  max-height: 80vh;
  text-align: left;
}
#bundleContentsModal #bundleContentsTitle{
  margin: 0 34px 10px 0;
  font-size: 18px;
}
#bundleContentsModal .bundle-contents-list{
  display: grid;
  gap: 8px;
  max-height: 52vh;
  overflow: auto;
  padding-right: 2px;
}
#bundleContentsModal .bundle-contents-item{
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #d8e4ee;
  border-radius: 10px;
  background: #fffdf6;
  padding: 8px;
}
#bundleContentsModal .bundle-contents-item img{
  width: 54px;
  height: 54px;
  object-fit: contain;
  border-radius: 8px;
  background: #ffffff;
}
#bundleContentsModal .bundle-contents-item-info .name{
  font-weight: 700;
  font-size: 13px;
}
#bundleContentsModal .bundle-contents-item-info .meta{
  font-size: 12px;
  color: #5f6f80;
}

html[data-theme="dark"] .bundle-contents-btn{
  background: #2b4a35;
  color: #e9f8ee;
  border-color: #4f7a61;
}
html[data-theme="dark"] .bundle-contents-btn:hover{
  background: #355b42;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-item{
  background: #1f2f3d;
  border-color: #365168;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-item img{
  background: #23384a;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-item-info .name{
  color: #e8f2fb;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-item-info .meta{
  color: #9fb4c7;
}

/* ===== Preview modal redesign + bundle modal layering fix ===== */
#previewModal{
  z-index: 1100 !important;
}
#previewModal .preview-content{
  width: min(860px, 94vw) !important;
  max-height: 88vh !important;
  border-radius: 18px;
  padding: 18px 16px 14px;
  background: linear-gradient(180deg, #fffdf6, #f7fff9);
  border: 1px solid #dbe8df;
}
#previewModal #previewTitle{
  margin: 0 38px 10px 0;
  font-size: 24px;
  line-height: 1.15;
  color: #2c3f52;
}
#previewModal .preview-top{
  display: grid;
  grid-template-columns: minmax(150px, 240px) 1fr;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
}
#previewModal .preview-img-container{
  height: 190px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid #d9e4ee;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.06);
}
#previewModal #previewImg{
  max-width: 150px;
  max-height: 150px;
}
#previewModal .preview-actions{
  display: grid;
  gap: 8px;
  align-content: start;
}
#previewModal .sell-value{
  justify-content: flex-start;
  margin: 0;
  border-radius: 10px;
  border: 1px solid #dbe8df;
  background: #eefaf0;
  padding: 7px 10px;
}
#previewModal .add-wishlist-btn,
#previewModal .bundle-contents-btn{
  width: 100%;
  justify-content: center;
  border-radius: 10px;
}
#previewModal .comment-section{
  margin-top: 10px;
  border-top: 1px solid #dbe8df;
  padding-top: 10px;
}
#previewModal .preview-possible-owners{
  margin: 2px 0 8px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid #d6e4f2;
  background: #f2f8ff;
  color: #32506a;
  font-size: 13px;
  line-height: 1.35;
}
#previewModal .comment-section h3{
  margin: 0 0 8px;
}

#bundleContentsModal{
  z-index: 1300 !important;
}
#bundleContentsModal .bundle-contents-content{
  position: relative;
  z-index: 1;
}

html[data-theme="dark"] #previewModal .preview-content{
  background: linear-gradient(180deg, #1e2d3a, #1b3328);
  border-color: #365168;
}
html[data-theme="dark"] #previewModal #previewTitle{
  color: #dbe9f6;
}
html[data-theme="dark"] #previewModal .preview-img-container{
  background: #203243;
  border-color: #3d5e76;
}
html[data-theme="dark"] #previewModal .sell-value{
  background: #223a2e;
  border-color: #3f6a52;
}
html[data-theme="dark"] #previewModal .comment-section{
  border-top-color: #365168;
}
html[data-theme="dark"] #previewModal .preview-possible-owners{
  border-color: #3d5c76;
  background: #223447;
  color: #d5e7f9;
}

@media (max-width: 760px){
  #previewModal .preview-content{
    width: 92vw !important;
    padding: 14px 12px 12px;
    border-radius: 16px;
  }
  #previewModal #previewTitle{
    font-size: 20px;
    margin-right: 34px;
  }
  #previewModal .preview-top{
    grid-template-columns: 1fr;
    gap: 10px;
  }
  #previewModal .preview-img-container{
    height: 150px;
  }
  #previewModal #previewImg{
    max-width: 120px;
    max-height: 120px;
  }
}

/* recipe/seed specific render in bundle modal */
#bundleContentsModal .bundle-contents-group{
  display: grid;
  gap: 8px;
}
#bundleContentsModal .bundle-contents-group-title{
  font-size: 13px;
  font-weight: 700;
  color: #35516a;
  margin-top: 2px;
}
#bundleContentsModal .bundle-contents-item.prize-item{
  border-color: #cfe6d6;
  background: #f3fff5;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-group-title{
  color: #b9d6ec;
}
html[data-theme="dark"] #bundleContentsModal .bundle-contents-item.prize-item{
  border-color: #4e7a62;
  background: #213a2d;
}

/* ===== CARD REDESIGN V2 (reversible block start) ===== */
.grid{
  gap: 16px;
}

.grid .item{
  border-radius: 18px;
  padding: 12px 11px 10px;
  min-height: 254px;
  height: auto;
  justify-content: flex-start;
  gap: 8px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcff 62%, #f4fbff 100%);
  border: 1px solid #d5e5f1;
  box-shadow: 0 6px 14px rgba(39, 65, 89, 0.16);
  transition: transform .16s ease, box-shadow .2s ease, border-color .2s ease, filter .2s ease;
}

.grid .item:hover{
  transform: translateY(-3px);
  box-shadow: 0 12px 20px rgba(39, 65, 89, 0.22);
  border-color: #bfd8eb;
  filter: brightness(1.01);
}

.grid .item .wiki-item-img{
  width: min(96px, 100%);
  height: 96px;
  object-fit: contain;
  object-position: center;
  border-radius: 12px;
  padding: 8px;
  background: transparent;
  border: none;
  box-shadow: none;
  margin-top: 14px;
}

.grid .item .item-name{
  margin: 2px 2px 0;
  min-height: 34px;
  max-height: 34px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 400;
  color: #2a4257;
}

.grid .item .details{
  margin-top: auto;
  width: 100%;
  gap: 6px;
  justify-content: center;
}

.grid .item .tag{
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 11px;
  font-weight: 400;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}

.grid .item .tag img{
  width: 13px;
  height: 13px;
}

.grid .item .wishlist-count{
  top: 32px;
  right: 6px;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  border: 1px solid #c8deee;
  background: #edf7ff;
}

.grid .item .wishlist-count svg{
  width: 13px;
  height: 13px;
}

.grid .item .owned-badge{
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1px;
  border: 1px solid #b7e2bf;
  background: #e8fbe9;
  color: #2a6b38;
}

html[data-theme="dark"] .grid .item{
  background: linear-gradient(180deg, #213344 0%, #1d2f3f 64%, #1b2a38 100%);
  border-color: #3c5f79;
  box-shadow: 0 8px 18px rgba(0,0,0,.34);
}

html[data-theme="dark"] .grid .item:hover{
  border-color: #5b84a4;
  box-shadow: 0 13px 22px rgba(0,0,0,.44);
}

html[data-theme="dark"] .grid .item .wiki-item-img{
  background: transparent;
  border: none;
  box-shadow: none;
}

html[data-theme="dark"] .grid .item .item-name{
  color: #e3f0fa;
}

html[data-theme="dark"] .grid .item .wishlist-count{
  border-color: #4b7291;
  background: #284056;
  color: #e2f0fa;
}

html[data-theme="dark"] .grid .item .owned-badge{
  border-color: #4c8f5b;
  background: #21422a;
  color: #c9f0d0;
}

@media (max-width: 760px){
  .grid{
    gap: 12px;
  }
  .grid .item{
    min-height: 236px;
    border-radius: 14px;
    padding: 10px 9px 9px;
  }
  .grid .item .wiki-item-img{
    width: min(88px, 100%);
    height: 88px;
    padding: 7px;
  }
  .grid .item .item-name{
    min-height: 32px;
    max-height: 32px;
    font-size: 12px !important;
  }
  .grid .item .tag{
    font-size: 10.5px;
    padding: 3px 8px;
  }
}
/* ===== CARD REDESIGN V2 (reversible block end) ===== */

/* ===== Unified responsive layout for utility modals (PC + Mobile) ===== */
:root{
  --panel-modal-gap: clamp(10px, 2vw, 22px);
}

#inventoryModal,
#closetModal,
#wishlistModal,
#friendsModal,
#houseLikesModal,
#mailboxModal,
#roomsModal,
#usernameChangeModal{
  padding: var(--panel-modal-gap) !important;
  align-items: center !important;
  justify-content: center !important;
}

#inventoryModal .inventory-content,
#closetModal .closet-content,
#roomsModal .inventory-content{
  width: min(1080px, calc(100vw - (var(--panel-modal-gap) * 2))) !important;
  max-height: calc(100dvh - (var(--panel-modal-gap) * 2)) !important;
  border-radius: 20px !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

#wishlistModal .wishlist-content,
#friendsModal .wishlist-content,
#houseLikesModal .wishlist-content,
#mailboxModal .wishlist-content{
  width: min(920px, calc(100vw - (var(--panel-modal-gap) * 2))) !important;
  max-height: calc(100dvh - (var(--panel-modal-gap) * 2)) !important;
  border-radius: 20px !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

#usernameChangeModal .username-change-content{
  width: min(760px, calc(100vw - (var(--panel-modal-gap) * 2))) !important;
  max-height: calc(100dvh - (var(--panel-modal-gap) * 2)) !important;
  border-radius: 20px !important;
  box-sizing: border-box !important;
}

#inventoryModal h2,
#closetModal h2,
#roomsModal h2,
#wishlistModal h2,
#friendsModal h2,
#houseLikesModal h2,
#mailboxModal h2{
  margin: 2px 38px 12px 2px !important;
}

#inventoryModal .inventory-scroll-container,
#closetModal .closet-scroll-container,
#roomsModal .rooms-scroll-container,
#wishlistModal .wishlist-scroll-container,
#friendsModal .wishlist-scroll-container,
#houseLikesModal .wishlist-scroll-container,
#mailboxModal .wishlist-scroll-container,
#mailboxModal #mailboxList{
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: auto !important;
}

#inventoryModal .close-inventory,
#closetModal .close-closet,
#roomsModal .close-inventory,
#wishlistModal .close-wishlist,
#friendsModal .close-wishlist,
#houseLikesModal .close-wishlist,
#mailboxModal .close-wishlist,
#usernameChangeModal .close-closet{
  top: 10px !important;
  right: 10px !important;
  z-index: 3 !important;
}

@media (max-width: 900px){
  #inventoryModal,
  #closetModal,
  #wishlistModal,
  #friendsModal,
  #houseLikesModal,
  #mailboxModal,
  #roomsModal,
  #usernameChangeModal{
    padding: max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left)) !important;
  }

  #inventoryModal .inventory-content,
  #closetModal .closet-content,
  #roomsModal .inventory-content,
  #wishlistModal .wishlist-content,
  #friendsModal .wishlist-content,
  #houseLikesModal .wishlist-content,
  #mailboxModal .wishlist-content{
    width: min(960px, calc(100vw - 16px)) !important;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 16px) !important;
    border-radius: 16px !important;
    padding: 12px !important;
  }

  #usernameChangeModal .username-change-content{
    width: min(760px, calc(100vw - 16px)) !important;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 16px) !important;
    border-radius: 16px !important;
    padding: 14px !important;
  }

  #inventoryModal h2,
  #closetModal h2,
  #roomsModal h2,
  #wishlistModal h2,
  #friendsModal h2,
  #houseLikesModal h2,
  #mailboxModal h2{
    margin: 2px 34px 10px 2px !important;
    font-size: 1.25rem !important;
  }
}

html[data-theme="dark"] #inventoryModal .inventory-content,
html[data-theme="dark"] #closetModal .closet-content,
html[data-theme="dark"] #roomsModal .inventory-content,
html[data-theme="dark"] #wishlistModal .wishlist-content,
html[data-theme="dark"] #friendsModal .wishlist-content,
html[data-theme="dark"] #houseLikesModal .wishlist-content,
html[data-theme="dark"] #mailboxModal .wishlist-content,
html[data-theme="dark"] #usernameChangeModal .username-change-content{
  border: 1px solid #3a566c !important;
}

/* Exclusive shop tile */
#menu.menu .menu-tile.exclusive-shop-tile{
  background: linear-gradient(180deg, #fff6c9 0%, #ffe389 100%);
  border: 1px solid #f0cd62;
  box-shadow: 0 10px 22px rgba(185, 141, 28, .26);
}
#menu.menu .menu-tile.exclusive-shop-tile .tile-label{
  color:#705710;
  font-weight: 800;
}
#menu.menu .menu-tile.exclusive-shop-tile .tile-icon{
  filter: drop-shadow(0 2px 2px rgba(120, 92, 13, .22));
}
#menu.menu .menu-tile.exclusive-shop-tile:hover{
  background: linear-gradient(180deg, #fff9dd 0%, #ffeaa8 100%);
  box-shadow: 0 14px 26px rgba(185, 141, 28, .30);
}
html[data-theme="dark"] #menu.menu .menu-tile.exclusive-shop-tile{
  background: linear-gradient(180deg, #5a4a21 0%, #7a6426 100%);
  border: 1px solid #9d8338;
  box-shadow: 0 10px 22px rgba(0, 0, 0, .35);
}
html[data-theme="dark"] #menu.menu .menu-tile.exclusive-shop-tile .tile-label{
  color:#ffe9a6;
}

/* Free Gift modal: Harajuku background layout */
#freeGiftModal .gift-modal__dialog{
  position: relative !important;
  width: min(94vw, 760px) !important;
  height: min(92dvh, 980px) !important;
  max-height: 92dvh !important;
  margin: 1.5vh auto 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: visible !important;
  background-image: url('https://petsocietyislandcloud.com/wiki/wiki_img/HARAJUKUFREEGIFTBG.png') !important;
  background-position: center center !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-color: transparent !important;
  display: block !important;
}
#freeGiftModal .gift-modal__dialog::before{
  background: transparent !important;
}
#freeGiftModal .gift-modal__content{
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: min(62%, 430px) !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
}
#freeGiftModal .gift-modal__image{
  width: min(100%, 280px) !important;
  max-width: 280px !important;
  max-height: 280px !important;
  height: auto !important;
  object-fit: contain !important;
  margin: 0 auto !important;
}
#freeGiftModal .gift-modal__claim{
  width: min(220px, 80%) !important;
}
#freeGiftModal .gift-modal__close{
  top: 14px !important;
  right: 14px !important;
  background: rgba(23, 43, 62, .38) !important;
  color: #fff !important;
  border-radius: 999px !important;
  width: 36px !important;
  height: 36px !important;
  line-height: 1 !important;
}

@media (max-width: 700px){
  #freeGiftModal .gift-modal__dialog{
    width: min(96vw, 520px) !important;
    height: min(86dvh, 760px) !important;
    border-radius: 0 !important;
  }
  #freeGiftModal .gift-modal__content{
    width: min(70%, 320px) !important;
    padding: 0 !important;
  }
  #freeGiftModal .gift-modal__image{
    width: min(100%, 210px) !important;
    max-width: 210px !important;
    max-height: 210px !important;
  }
}
