/* =========================================
   1. VARIABLES & CONFIGURACIÓN
   ========================================= */
:root {
  /* Colores Principales */
  --wf-bg: #0f1115;
  --wf-card: #1b1e23;
  --wf-input-bg: #0a0b0d;
  --wf-blue: #00e5ff;
  --wf-green: #4fbd4f;
  --wf-gold-text: #c5a856;
  --wf-orokin: #d4af37;
  --wf-error: #ff4444;

  /* Rarezas */
  --wf-common: #cd7f32;
  --wf-uncommon: #c0c0c0;
  --wf-rare: #e6c200;
  --wf-forma: #a8b5c2;
  --wf-vaulted: #e04545;
  --wf-aya: #a545e0;
  --wf-riven: #a235e2;
  --wf-lfg: #42f56c;

  /* Fondos Gradientes */
  --bg-common: linear-gradient(135deg,
      rgba(205, 127, 50, 0.2) 0%,
      rgba(0, 0, 0, 0) 90%);
  --bg-uncommon: linear-gradient(135deg,
      rgba(192, 192, 192, 0.15) 0%,
      rgba(0, 0, 0, 0) 90%);
  --bg-rare: linear-gradient(135deg,
      rgba(255, 215, 0, 0.2) 0%,
      rgba(0, 0, 0, 0) 90%);
  --bg-forma: linear-gradient(135deg,
      rgba(168, 181, 194, 0.1) 0%,
      rgba(0, 0, 0, 0) 90%);

  /* Tema Dinámico (se sobrescribe por JS) */
  --active-theme-color: var(--wf-blue);

  /* SISTEMA DE CAPAS (Z-INDEX) */
  --z-back: 0;
  --z-normal: 1;
  --z-card: 10;
  --z-header: 100;
  --z-footer: 100;
  --z-sidebar: 1000;
  --z-dropdown: 1000;
  --z-toast: 3000;
  --z-modal-backdrop: 9999;
  --z-modal: 10000;
  --z-scanner-overlay: 20000;
  --z-fab: 99999;
  --z-tooltip: 999999;
}

/* =========================================
   2. ANIMACIONES
   ========================================= */
@keyframes pulse {
  0% {
    transform: scale(1);
    color: #fff;
  }

  50% {
    transform: scale(1.02);
    color: var(--wf-blue);
  }

  to {
    transform: scale(1);
  }
}

@keyframes slideInRight {
  0% {
    opacity: 0;
    transform: translate(50px, -50%);
  }

  to {
    opacity: 1;
    transform: translate(0, -50%);
  }
}

@keyframes slideInRightSimple {
  from {
    opacity: 0;
    transform: translateX(30px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideDown {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes loadingScan {
  0% {
    background-position: 100% 0;
  }

  to {
    background-position: -100% 0;
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes scanPulse {

  0%,
  100% {
    box-shadow: 0 4px 15px rgba(66, 245, 108, 0.4);
    transform: scale(1);
  }

  50% {
    box-shadow: 0 4px 25px rgba(66, 245, 108, 0.8);
    transform: scale(1.05);
  }
}

@keyframes gaussCrashSequence {

  0%,
  15% {
    transform: translateX(0) skewX(-10deg) scaleX(0.8);
    opacity: 1;
  }

  35% {
    transform: translateX(-400%) skewX(30deg) scaleX(0.6);
    opacity: 0;
  }

  36% {
    transform: translateX(400%) scaleX(-0.8) skewX(30deg);
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  60% {
    transform: translateX(50%) scaleX(-0.9) skewX(20deg);
  }

  65% {
    transform: translateX(0) scaleX(0.5) scaleY(1.3) skewX(0deg);
    color: #fff;
    filter: drop-shadow(0 0 30px #fff) brightness(3);
  }

  85% {
    transform: translateX(20%) scaleX(1.1) scaleY(0.9) skewX(-15deg);
    color: #f05;
    filter: drop-shadow(0 0 15px #f05);
  }

  to {
    transform: translateX(0) skewX(-10deg) scaleX(0.8);
    filter: drop-shadow(0 0 2px var(--wf-blue));
    color: var(--wf-blue);
  }
}

@keyframes redlineShake {

  0%,
  to {
    transform: translate(0, 0) skewX(-10deg) scale(1.1);
  }

  50% {
    transform: translate(1px, -1px) skewX(-12deg) scale(1.15);
  }
}

.pulse-anim {
  animation: pulse 0.3s ease;
}

/* =========================================
   3. RESET & BASE
   ========================================= */
html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 100%;
  min-height: 100vh;
  position: relative;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-color: #1a1a2e;
  background-image: url(assets/fondo.jpg);
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  color: #fff;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

* {
  scrollbar-width: thin;
  scrollbar-color: #333 var(--wf-bg);
  box-sizing: border-box;
}

::-webkit-scrollbar {
  width: 8px;
  background: var(--wf-bg);
}

::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: #555;
}

.hidden {
  display: none !important;
}

#void-traces-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-back);
  pointer-events: none;
  opacity: 0.7;
  mix-blend-mode: screen;
}

/* =========================================
   4. LAYOUT PRINCIPAL (Header, Card, Footer)
   ========================================= */
/* Header */
.site-header {
  width: 100%;
  background: rgba(10, 12, 16, 0.98);
  backdrop-filter: blur(12px);
  border-bottom: 2px solid var(--active-theme-color, #333);
  z-index: var(--z-header);
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 4% !important;
  height: 65px !important;
  position: sticky;
  top: 0;
  transition: all 0.4s ease;
}

.site-header {
  border-bottom-color: var(--active-theme-color) !important;
}

.header-title {
  font-size: 1.5rem;
  margin: 0;
  background: linear-gradient(180deg, #fff 0%, var(--active-theme-color, var(--wf-blue)) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 950;
  letter-spacing: 2px;
  text-shadow: 0 0 15px rgba(255, 255, 255, 0.1);
  transition: all 0.4s ease;
}

.header-subtitle {
  display: none;
}

.header-controls {
  display: flex;
  align-items: center;
  gap: 25px;
}

/* Añadido para el selector de idioma */

/* Selector de Idioma */
.lang-custom-container {
  position: relative;
  font-family: "Segoe UI", sans-serif;
  z-index: 1500;
}

.lang-trigger {
  border: 1px solid #444;
  border-radius: 4px;
  display: flex;
  background: rgba(0, 0, 0, 0.4);
  color: #ccc;
  padding: 6px 10px;
  cursor: pointer;
  font-size: 0.85em;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
  min-width: 80px;
  justify-content: space-between;
}

.lang-trigger:hover {
  border-color: var(--wf-blue);
  color: #fff;
  background: rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.2);
}

.lang-options {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 5px;
  background: #15171b;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.8);
  min-width: 120px;
  flex-direction: column;
  display: flex;
  border: 1px solid #444;
  border-radius: 4px;
}

.lang-option-item {
  padding: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  color: #bbb;
  font-size: 0.9em;
  transition: background 0.2s;
}

.lang-option-item:hover {
  background: var(--wf-blue);
  color: #000;
  font-weight: 700;
}

.lang-trigger img,
.lang-option-item img {
  border-radius: 2px;
  width: 18px;
  height: auto;
  box-shadow: 0 0 2px rgba(255, 255, 255, 0.3);
}

/* Main Card */
.card {
  background: var(--wf-card);
  max-width: 800px;
  border: 1px solid var(--active-theme-color, #333);
  overflow: hidden;
  height: auto !important;
  transition: border-color 0.3s ease;

  position: relative !important;
  top: auto !important;
  left: 0 !important;
  width: 100% !important;
  margin: 0 !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 0 !important;
  z-index: 10 !important;
  box-shadow: none !important;
  align-self: center !important;
}

.content-area {
  padding: 15px;
  overflow-y: auto;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  position: relative;
}

/* Loading Overlay Global */
#loading {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.95);
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--wf-blue);
  flex-direction: column;
}

/* Footer & Disclaimer */
.footer-output {
  background: #0a0b0d;
  padding: 25px 20px;
  border-top: 3.5px solid #333;
  text-align: center;
  flex-shrink: 0;
  transition:
    border-color 0.5s ease,
    box-shadow 0.5s ease;
  z-index: var(--z-footer);
}

.message-display {
  font-size: 1.5em;
  color: var(--wf-blue);
  font-family: monospace;
  font-weight: 700;
  margin-bottom: 10px;
  min-height: 1.2em;
  word-break: break-all;
}

.site-footer {
  width: 100%;
  padding: 15px 20px;
  background: linear-gradient(180deg, rgba(10, 11, 13, 0.9) 0, #050505 100%);
  border-top: 1px solid #222;
  text-align: center;
  color: #666;
  font-size: 0.85em;
  position: relative;
  z-index: var(--z-footer);
}

.footer-row {
  margin-bottom: 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
}

.footer-separator {
  color: #333;
  margin: 0 8px;
  font-weight: 100;
}

.footer-link,
.contact-link,
.footer-link-btn {
  color: #888;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
  padding: 2px 5px;
  border-radius: 4px;
  position: relative;
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: inherit;
  font-family: inherit;
}

.footer-link-btn:hover {
  color: var(--wf-blue);
  text-shadow: 0 0 8px rgba(0, 229, 255, 0.4);
  background: rgba(0, 229, 255, 0.05);
}


.footer-disclaimer {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background-color: rgba(5, 5, 5, 0.95);
  color: #888;
  padding: 15px 25px;
  border-radius: 8px;
  font-size: 0.75em;
  line-height: 1.4;
  text-align: center;
  width: 90%;
  max-width: 600px;
  z-index: 5000;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.5);
  opacity: 1;
  visibility: visible;
  transition:
    opacity 1.5s ease-out,
    visibility 1.5s;
  pointer-events: auto;
}

.footer-disclaimer.fade-out {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* =========================================
   5. COMPONENTES INTERFAZ
   ========================================= */
/* Tabs Navigation */
.card-top-bar {
  display: flex;
  background: #15171b;
  border-bottom: 2px solid #2a2a2a;
  align-items: stretch;
  flex-shrink: 0;
  min-height: 45px;
}

.tabs {
  display: flex;
  width: 100%;
  flex-grow: 1;
  overflow: visible;
}

.tabs::-webkit-scrollbar {
  display: none;
}

.tab-btn {
  flex: 1;
  padding: 10px 5px;
  background: 0 0;
  border: 0;
  color: #666;
  cursor: pointer;
  font-weight: 700;
  font-size: 0.85em;
  transition: 0.3s;
  border-bottom: 3px solid transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  z-index: 1;
  position: relative;
  margin-bottom: -2px;
}

.tab-btn:hover {
  background: #222;
  color: #fff;
  z-index: 100;
}

.tab-btn.active {
  background: var(--wf-card);
  color: var(--active-theme-color);
  border-bottom-color: var(--active-theme-color);
}

.tab-icon-img {
  width: 3rem;
  height: 3rem;
  object-fit: contain;
  vertical-align: middle;
  margin-right: 6px;
  filter: drop-shadow(0 0 2px rgba(255, 255, 255, 0.3));
  transition: transform 0.2s ease;
}

.tab-btn:hover .tab-icon-img {
  transform: scale(1.2);
  filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.6));
}

/* Inputs & Forms */
.form-group {
  margin-bottom: 15px;
}

label {
  text-transform: uppercase;
  display: block;
  margin-bottom: 8px;
  color: #888;
  font-size: 0.75em;
  font-weight: 800;
  letter-spacing: 1px;
}

.wf-input {
  width: 100%;
  padding: 12px;
  border-radius: 4px;
  border: 1px solid #444;
  background-color: var(--wf-input-bg);
  color: #eee;
  font-size: 1em;
  outline: 0;
  transition: all 0.2s ease;
  font-family: "Segoe UI", sans-serif;
}

.wf-input:focus {
  border-color: var(--active-theme-color) !important;
  box-shadow: 0 0 8px var(--active-theme-color) !important;
  background-color: #0f1113;
}

select.wf-input {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 30px;
  cursor: pointer;
  background-image: url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%2300E5FF%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);
  background-repeat: no-repeat;
  background-position: right 12px top 50%;
  background-size: 10px auto;
}

option {
  background: #1b1e23;
  color: #fff;
  padding: 10px;
}

/* Custom Dropdowns */
.custom-search-container {
  position: relative;
  width: 100%;
}

.custom-dropdown,
#relicDropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #111;
  border: 1px solid var(--active-theme-color) !important;
  border-top: none !important;
  max-height: 200px;
  overflow-y: auto;
  z-index: var(--z-dropdown);
  border-radius: 0 0 4px 4px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5);
}

.custom-dropdown.hidden {
  display: none;
}

.dropdown-item {
  padding: 10px 12px;
  cursor: pointer;
  color: #eee;
  font-size: 0.9em;
  transition: background 0.2s;
  border-bottom: 1px solid #222;
}

.dropdown-item:hover {
  background: var(--active-theme-color) !important;
  color: #050505 !important;
  font-weight: 700;
}

/* Buttons General */
.action-btn.confirm {
  background: #005f6b;
  color: #fff;
  border: 1px solid #00e5ff;
  padding: 10px 30px;
  cursor: pointer;
  transition: all 0.2s;
  text-transform: uppercase;
  font-weight: 700;
}

.action-btn.confirm:hover {
  background: #00e5ff;
  color: #000;
  box-shadow: 0 0 15px #00e5ff;
}

.copy-btn {
  background: 0 0;
  border: 2px solid var(--active-theme-color, var(--wf-blue));
  color: var(--active-theme-color, var(--wf-blue));
  font-size: 1.1em;
  font-weight: 700;
  padding: 12px 30px;
  border-radius: 4px;
  cursor: pointer;
  letter-spacing: 1px;
  transition: all 0.2s ease;
  text-transform: uppercase;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}

.copy-btn:hover {
  background: var(--active-theme-color, var(--wf-blue));
  color: #050505;
  box-shadow: 0 0 8px var(--active-theme-color, var(--wf-blue));
  transform: translateY(-1px);
}

.mini-action-btn {
  background: 0 0;
  border: 1px solid var(--wf-blue);
  color: var(--wf-blue);
  font-size: 0.85em;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
  text-transform: uppercase;
  transition: 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.mini-action-btn:hover {
  color: #000;
  background: var(--wf-blue);
}

.dashed-btn {
  background: 0 0;
  border: 1px dashed #666;
  color: #888;
  padding: 8px 15px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.8em;
  transition: all 0.2s;
  text-transform: uppercase;
}

.dashed-btn:hover {
  border-color: var(--wf-blue);
  color: var(--wf-blue);
  background: rgba(0, 229, 255, 0.05);
}

.dashed-btn.red:hover {
  border-color: #f44;
  color: #f44;
  background: rgba(255, 68, 68, 0.05);
}

/* Toasts */
/* Stackable Toast System */
.wf-toast-container {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10002;
  display: flex;
  flex-direction: column-reverse;
  gap: 8px;
  pointer-events: none;
  width: 100%;
  max-width: 400px;
  align-items: center;
}

.wf-toast {
  pointer-events: auto;
  background: rgba(13, 19, 33, 0.96);
  border: 1px solid rgba(0, 229, 255, 0.4);
  color: #00e5ff;
  padding: 10px 16px;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.6);
  font-size: 0.82em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 280px;
  animation: toast-in 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transition: all 0.3s;
  backdrop-filter: blur(8px);
}

.wf-toast.success {
  border-color: rgba(0, 255, 120, 0.4);
  color: #00ff78;
}

.wf-toast.error {
  border-color: rgba(255, 68, 68, 0.4);
  color: #ff5555;
}

.wf-toast.warning {
  border-color: rgba(255, 180, 50, 0.4);
  color: #f0b040;
}

.wf-toast.fade-out {
  opacity: 0;
  transform: translateY(15px) scale(0.95);
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateY(25px) scale(0.9);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.wf-toast .toast-close {
  cursor: pointer;
  opacity: 0.4;
  font-size: 1.4em;
  line-height: 1;
  padding: 0 4px;
  transition: opacity 0.2s;
}

.wf-toast .toast-close:hover {
  opacity: 1;
}

.wf-toast .toast-message {
  flex: 1;
}

/* Tooltips */
.global-tooltip {
  position: fixed;
  z-index: var(--z-tooltip);
  pointer-events: none;
  background: rgba(10, 11, 13, 0.95);
  color: #eee;
  border: 1px solid var(--active-theme-color, #00e5ff);
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.85rem;
  font-family: "Segoe UI", sans-serif;
  line-height: 1.4;
  max-width: 350px;
  max-height: 400px;
  overflow-y: auto;
  overflow-x: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(5px);
  opacity: 1;
  transition: opacity 0.15s ease;
}

.global-tooltip.hidden {
  opacity: 0;
  visibility: hidden;
}

.global-tooltip.mega-mode {
  pointer-events: auto;
  min-width: 280px;
}

.global-tooltip::-webkit-scrollbar {
  width: 6px;
}

.global-tooltip::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
}

.global-tooltip::-webkit-scrollbar-thumb {
  background: var(--wf-blue);
  border-radius: 3px;
}

.tooltip-header {
  font-weight: 800;
  color: var(--wf-gold-text);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  padding-bottom: 5px;
  margin-bottom: 8px;
  font-size: 0.95em;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.tooltip-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tooltip-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-size: 0.85em;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.1);
  gap: 15px;
}

.tooltip-list li:last-child {
  border-bottom: none;
}

.t-row {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.t-loc {
  color: #ddd;
  font-weight: 600;
  font-size: 0.9em;
}

.rot-badge {
  display: inline-block;
  background: rgba(0, 229, 255, 0.15);
  color: var(--wf-blue);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 0.85em;
  font-weight: 700;
  margin-top: 2px;
  width: fit-content;
}

.drop-chance {
  color: var(--wf-green);
  font-weight: 800;
  white-space: nowrap;
}

.top-drop {
  background: linear-gradient(90deg,
      rgba(0, 229, 255, 0.1) 0%,
      transparent 100%);
  border-left: 2px solid var(--wf-blue);
  padding-left: 8px !important;
}

.info-icon {
  font-style: normal;
  opacity: 0.7;
  transition: opacity 0.2s;
  cursor: help;
  font-size: 0.9em;
}

.info-icon:hover {
  opacity: 1;
}

/* =========================================
   6. PANELES LATERALES (Deslizantes)
   ========================================= */
/* Comunes */
#inventory-container,
#best-missions-container,
#cloud-sync-container {
  position: fixed;
  background: rgba(15, 17, 21, 0.98);
  border: 1px solid var(--wf-blue);
  z-index: var(--z-sidebar);
  transition:
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    right 0.3s,
    left 0.3s;
  box-shadow: -5px 5px 20px rgba(0, 0, 0, 0.6);
  display: flex;
  flex-direction: column;
}

.panel-main-header {
  padding: 15px;
  background: linear-gradient(90deg,
      rgba(0, 229, 255, 0.15) 0,
      transparent 80%);
  border-bottom: 1px solid var(--wf-blue);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 1.1em;
  color: #fff;
  text-shadow: 0 0 10px var(--wf-blue);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  cursor: default;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: background 0.3s;
}



.inv-action-btn {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 5px 10px;
  border-radius: 4px;
  color: #fff;
  font-size: 0.7em;
  font-weight: 900;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  min-width: 80px;
  justify-content: center;
}

.export-btn {
  border-left: 3px solid var(--wf-blue);
}

.export-btn:hover {
  background: rgba(0, 229, 255, 0.12);
  border-color: var(--wf-blue);
  box-shadow: 0 0 12px rgba(0, 229, 255, 0.3);
  transform: translateY(-1px);
}

.import-btn {
  border-right: 3px solid var(--wf-gold-text);
}

.import-btn:hover {
  background: rgba(212, 175, 55, 0.12);
  border-color: var(--wf-gold-text);
  box-shadow: 0 0 12px rgba(212, 175, 55, 0.3);
  transform: translateY(-1px);
}

.inv-action-btn .btn-icon {
  font-size: 1.1em;
}

.panel-main-header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 4px;
  background: var(--wf-blue);
  box-shadow: 0 0 15px var(--wf-blue);
}

.panel-main-header:hover {
  background: linear-gradient(90deg, rgba(255, 0, 85, 0.15) 0, transparent 80%);
  border-bottom-color: #f05;
  text-shadow: 0 0 10px #f05;
}

.mission-toggle-btn,
#inv-toggle-btn,
.side-toggle-btn {
  position: absolute;
  width: 45px;
  height: 45px;
  padding: 8px;
  display: flex !important;
  /* Restore flex for centering */
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1000;
  transition: all 0.3s ease;
}

.toggle-img {
  width: 4.5rem;
  height: 4.5rem;
  object-fit: contain;
  filter: drop-shadow(0 0 5px rgba(0, 229, 255, 0.6));
  transition: transform 0.4s ease;

}

/* Panel Inventario */
#inventory-container {
  top: 15%;
  left: -450px;
  width: 450px;
  max-width: 95vw;
  height: auto;
  max-height: 80vh;
  background: rgba(15, 20, 25, 0.95);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(0, 229, 255, 0.3);
  border-left: none;
  border-radius: 0 12px 12px 0;
  box-shadow: 10px 0 30px rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  z-index: 900 !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: visible !important;
}

#inventory-container.open {
  transform: translateX(450px);
}

#inv-toggle-btn {
  right: -45px;
  top: 20px;
  border-radius: 0 8px 8px 0;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

#inv-toggle-btn:hover {
  right: -45px;
  width: 50px;
  /* Increased from 45px */
}

#inventory-container.open .toggle-img {
  transform: rotate(-180deg);
  filter: drop-shadow(0 0 10px rgba(0, 229, 255, 0.8));
}

.inv-row {
  background: rgba(30, 35, 45, 0.4);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  border-left: 3px solid transparent;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  flex-shrink: 0;
  display: grid !important;
  grid-template-columns: 1fr 100px 110px;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 16px;
  cursor: pointer;
}

.inv-row:hover {
  background: rgba(45, 55, 75, 0.6);
  border-left-color: var(--wf-blue);
  box-shadow: inset 0 0 20px rgba(0, 229, 255, 0.05);
}

.inv-name-group {
  text-align: left;
  min-width: 0;
}

#inventory-list,
#inventory-list-parts {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 0;
  flex-grow: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: 50px;
  padding-right: 5px;
}

.inv-name {
  font-weight: 700;
  color: #fff;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: normal;
  line-height: 1.2;
  margin-bottom: 4px;
  word-break: break-word;
  overflow: hidden;
}

.inv-meta {
  font-size: 0.7em;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}

.relic-status-tag {
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 900;
  letter-spacing: 0.5px;
}

.relic-status-tag.active {
  background: rgba(0, 229, 255, 0.1);
  color: #00e5ff;
  border: 1px solid rgba(0, 229, 255, 0.3);
}

.relic-status-tag.vaulted {
  background: rgba(255, 77, 77, 0.1);
  color: #ff4d4d;
  border: 1px solid rgba(255, 77, 77, 0.3);
}

.ducat-tag {
  color: var(--wf-gold-text);
  font-weight: 600;
  opacity: 0.8;
}

.inv-qty-controls {
  background: rgba(0, 0, 0, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.inv-btn {
  background: transparent;
  border: none;
  color: #aaa;
  width: 30px;
  height: 30px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.2rem;
  transition: all 0.2s;
}

.inv-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.inv-btn.plus:hover {
  color: #00e5ff;
}

.inv-btn.minus:hover {
  color: #ff4d4d;
}

#inventory-list::-webkit-scrollbar {
  width: 6px;
}

#inventory-list::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.2);
}

#inventory-list::-webkit-scrollbar-thumb {
  background: rgba(0, 229, 255, 0.3);
  border-radius: 10px;
}

#inventory-list::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 229, 255, 0.5);
}

.inv-price-tag {
  font-family: "Segoe UI", MONOSPACE, sans-serif;
  font-weight: 800;
  color: var(--wf-blue);
  background: rgba(0, 229, 255, 0.1);
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid rgba(0, 229, 255, 0.3);
  font-size: 0.9rem;
  min-width: 70px;
  text-align: center;
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.1);
}

.inv-price-tag .qty-label {
  font-size: 0.8em;
  opacity: 0.8;
  color: var(--wf-gold-text);
  border-left: 1px solid rgba(255, 255, 255, 0.2);
  padding-left: 6px;
}

.inv-tiers-row {
  display: flex;
  gap: 4px;
  justify-content: space-between;
}

.inventory-loading {
  opacity: 0.5;
  pointer-events: none;
  transition: opacity 0.2s ease;
  filter: blur(1px);
}

/* Panel Fisuras */
#best-missions-container {
  top: 15%;
  right: -280px;
  width: 280px;
  height: auto;
  max-height: 80vh;
  border-right: none;
  border-radius: 12px 0 0 12px;
  display: flex !important;
  flex-direction: column !important;
  background: rgba(15, 20, 25, 0.95);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(0, 229, 255, 0.3);
  box-shadow: -10px 0 30px rgba(0, 0, 0, 0.5);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: visible !important;
}

#best-missions-container.open {
  right: 0 !important;
}

.mission-toggle-btn {
  left: -45px;
  top: 20px;
  display: flex !important;
}

.mission-toggle-btn:hover {
  width: 50px;
  left: -45px;
  filter: brightness(1.2);
}

#best-missions-container.open .toggle-img {
  transform: rotate(180deg);
  filter: drop-shadow(0 0 10px rgba(212, 175, 55, 0.8));
}

.gauss-icon {
  width: 40px;
  height: 30px;
  color: var(--wf-blue);
  fill: currentColor;
  stroke: currentColor;
  filter: drop-shadow(0 0 2px var(--wf-blue));
  transform-origin: center;
  transition:
    color 0.3s,
    filter 0.3s;
  transform: skewX(-10deg);
  z-index: 2;
}

.panel-main-header:hover .gauss-icon {
  color: #f05;
  filter: drop-shadow(0 0 8px #f05);
  animation: redlineShake 0.15s infinite;
  transform: skewX(-10deg);
}

.gauss-icon.is-running {
  color: #f05;
  filter: drop-shadow(0 0 8px #f05);
  animation: gaussCrashSequence 3s cubic-bezier(0.25, 1, 0.5, 1) forwards !important;
}

.fissures-scroll-area {
  overflow-y: auto;
  overflow-x: hidden;
  flex-grow: 1;
  padding: 5px;
  scrollbar-width: thin;
  border-radius: 0 0 0 8px;
}

.fissure-group {
  margin-bottom: 5px;
  border: 1px solid #333;
  border-radius: 4px;
  background: #15171b;
  overflow: hidden;
  transition: all 0.3s ease;
}

.fissure-group.active {
  border-color: var(--wf-gold-text);
  box-shadow: 0 0 10px rgba(197, 168, 86, 0.2);
}

.tier-header-btn {
  width: 100%;
  padding: 8px 12px;
  background: #1f2329;
  color: #aaa;
  font-weight: 800;
  text-transform: uppercase;
  border: 0;
  border-bottom: 1px solid transparent;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background 0.2s;
}

.fissure-group.active .tier-header-btn {
  background: linear-gradient(90deg,
      rgba(197, 168, 86, 0.2) 0,
      transparent 100%);
  color: var(--wf-gold-text);
  border-bottom-color: rgba(197, 168, 86, 0.3);
  animation: goldPulse 3s infinite ease-in-out;
}

@keyframes goldPulse {

  0%,
  100% {
    text-shadow: 0 0 5px rgba(197, 168, 86, 0.2);
  }

  50% {
    text-shadow: 0 0 15px rgba(197, 168, 86, 0.6);
  }
}

.tier-content {
  max-height: 500px;
  transition:
    max-height 0.3s ease-out,
    opacity 0.3s ease;
  opacity: 1;
  overflow: hidden;
}

.fissure-group.collapsed .tier-content {
  max-height: 0;
  opacity: 0;
  padding: 0;
  border: 0;
}

.arrow-icon {
  display: inline-block;
  transition: transform 0.3s ease;
}

.fissure-group.collapsed .arrow-icon {
  transform: rotate(-90deg);
}

.no-fissures-msg {
  padding: 15px 10px;
  background: rgba(255, 165, 0, 0.05);
  border-left: 3px solid #666;
  color: #888;
  font-size: 0.85em;
  font-style: italic;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 5px;
  border-radius: 0 4px 4px 0;
}

.fissure-group.active .no-fissures-msg {
  border-left-color: var(--wf-gold-text);
  color: #aaa;
  background: linear-gradient(90deg,
      rgba(197, 168, 86, 0.05) 0,
      transparent 100%);
}

.warning-icon {
  color: #ca0;
  font-size: 1.2em;
  filter: drop-shadow(0 0 5px rgba(204, 170, 0, 0.2));
}

.mission-item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #1a1c20;
  border: 1px solid #444;
  border-left: 4px solid #444;
  border-radius: 4px;
  padding: 10px 12px;
  min-width: 140px;
  flex: 1;
  transition: all 0.2s ease;
  position: relative;
  z-index: 1;
}

.mission-item:hover {
  z-index: 100 !important;
  background: rgba(35, 38, 43, 0.95);
  border-color: var(--wf-blue);
  border-left-color: var(--wf-blue);
  transform: translateX(5px) scale(1.02);
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.2);
}

.m-type {
  font-weight: 800;
  font-size: 0.95rem;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.m-node {
  font-size: 0.85rem;
  color: #ccc;
  font-weight: 500;
}

.m-timer-box {
  margin-top: 8px;
  border-top: 1px solid #333;
  padding-top: 4px;
  text-align: right;
}

.m-eta {
  font-size: 0.85rem;
  color: var(--wf-blue);
  font-family: monospace;
  font-weight: 700;
  background: rgba(0, 229, 255, 0.1);
  padding: 2px 6px;
  border-radius: 4px;
}

.mission-item.sp-row {
  border-color: #722 #722 #722 #f44;
  background: linear-gradient(90deg, rgba(50, 0, 0, 0.3) 0, transparent 100%);
}

.mission-item.sp-row .m-type {
  color: #faa;
}

.mission-item.sp-row .m-eta {
  color: #f77;
  background: rgba(255, 50, 50, 0.15);
}

.omnia-tag.big {
  font-size: 0.7em;
  vertical-align: middle;
  padding: 2px 6px;
  background: #fff;
  color: #000;
  border-radius: 3px;
  margin-left: 5px;
  box-shadow: 0 0 5px #fff;
}

.sp-icon {
  display: inline-block;
  background: #a55;
  color: #fff;
  font-size: 0.7em;
  font-weight: 700;
  padding: 1px 4px;
  border-radius: 3px;
  margin-left: 5px;
  cursor: help;
  border: 1px solid #f77;
  box-shadow: 0 0 5px rgba(255, 0, 0, 0.3);
}

/* Panel Sync */
#cloud-sync-container {
  bottom: 30px;
  top: auto;
  left: -280px;
  right: auto !important;
  width: 280px;
  max-height: 500px;
  border-left: none;
  border-radius: 0 8px 8px 0;
  z-index: 1001 !important;
  box-shadow: 2px 2px 15px rgba(0, 0, 0, 0.5);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  will-change: transform;
}

#cloud-sync-container.open {
  transform: translateX(280px) !important;
}

.side-toggle-btn {
  right: -50px;
  left: auto !important;
  bottom: 7.5px;
  /* Offset to align centers with 65px scanner circle */
  top: auto;
  width: 50px;
  height: 50px;
  background: #15171b;
  border: 1px solid var(--wf-blue);
  border-left: none;
  border-radius: 0 8px 8px 0;
  display: flex !important;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5);
  transition: all 0.2s;
}

.side-toggle-btn:hover {
  background: #222;
  filter: brightness(1.2);
  width: 60px;
  left: -60px;
}

#cloud-sync-container.open .side-toggle-btn {
  background: var(--wf-blue);
  color: #000;
}

.sync-content-area {
  padding: 15px;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.sync-tabs {
  display: flex;
  gap: 5px;
  background: #111;
  padding: 3px;
  border-radius: 4px;
}

.sync-tab {
  flex: 1;
  background: 0 0;
  border: 0;
  color: #666;
  padding: 8px;
  cursor: pointer;
  font-weight: 700;
  border-radius: 3px;
  transition: 0.2s;
}

.sync-tab.active {
  background: var(--wf-blue);
  color: #050505;
}

.big-code {
  font-size: 2.5em;
  text-align: center;
  font-weight: 900;
  letter-spacing: 5px;
  color: #fff;
  text-shadow: 0 0 10px var(--wf-blue);
  margin: 10px 0;
  font-family: monospace;
}

.big-input {
  font-size: 1.5em !important;
  text-align: center;
  letter-spacing: 3px;
  margin-bottom: 10px;
}

.sync-instruction {
  color: #aaa;
  font-size: 0.85em;
  text-align: center;
  margin: 0;
}

.sync-status {
  text-align: center;
  font-size: 0.8em;
  min-height: 20px;
}

.sync-limits-footer {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed #333;
  font-size: 0.7em;
  color: #555;
  text-align: center;
  line-height: 1.3;
}

.loader-bar {
  height: 3px;
  width: 100%;
  background: linear-gradient(90deg, transparent, var(--wf-blue), transparent);
  background-size: 200% 100%;
  animation: loadingScan 1.5s infinite linear;
  margin-top: 5px;
}

/* =========================================
   7. MODULOS (Reliquias, LFG, Perfil, Riven)
   ========================================= */
body.theme-relic {
  --active-theme-color: var(--wf-blue);
}

body.theme-set {
  --active-theme-color: var(--wf-orokin);
}

body.theme-riven {
  --active-theme-color: var(--wf-riven);
}

body.theme-profile {
  --active-theme-color: #ffffff;
}

body.theme-lfg {
  --active-theme-color: var(--wf-lfg);
}

body.theme-bounties {
  --active-theme-color: #ff8c00;
}

.inv-filters {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  width: 100%;
  gap: 5px;
  overflow-x: auto;
  margin-bottom: 10px;
}

#inventory-container button {
  background-color: #15171b;
  color: #888;
  border: 1px solid #444;
  padding: 8px;
  margin: 2px;
  border-radius: 4px;
  font-weight: 700;
  font-size: 0.75em;
  cursor: pointer;
  transition: all 0.2s ease;
  text-transform: uppercase;
}

/* 2. Efecto Hover (al pasar el ratón) */
#inventory-container button:hover {
  background-color: var(--wf-blue);
  color: #000;
  border-color: var(--wf-blue);
  box-shadow: 0 0 8px rgba(0, 229, 255, 0.4);
}

/* 3. Estilo para el SELECT (Recently added...) */
#inventory-container select {
  width: 100%;
  background-color: #0a0b0d;
  color: #eee;
  border: 1px solid #444;
  padding: 8px;
  margin-bottom: 10px;
  border-radius: 4px;
  outline: none;
}

#inventory-container .inv-btn {
  background: transparent !important;
  border: none !important;
  width: 25px !important;
  margin: 0 !important;
  box-shadow: none !important;
}

#inventory-container .inv-btn:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
}

/* inventory-list-parts styling handled elsewhere */

.inv-filter-btn {
  flex: 1;
  background: transparent;
  border: 1px solid #444;
  color: #888;
  padding: 6px 4px;
  font-size: 0.75em;
  font-weight: 700;
  cursor: pointer;
  border-radius: 3px;
  transition: all 0.2s;
  text-align: center;
  min-width: 40px;
}

#inventory-container .inv-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid #333;
  width: 100% !important;
}

.inv-filter-btn:hover {
  background: #252830;
  color: #fff;
  border-color: #666;
}

.inv-filter-btn.active {
  background: var(--wf-blue);
  color: #050505;
  border-color: var(--wf-blue);
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.2);
}

/* 3. Selector de Ordenación (Recently added, AVG Plat...) */
.inv-sort-select {
  width: 100%;
  margin-bottom: 10px;
  background-color: #0f1115;
  color: #eee;
  border: 1px solid #444;
  padding: 8px;
  border-radius: 4px;
  font-size: 0.85em;
  cursor: pointer;
}

.inv-sort-select:focus {
  border-color: var(--wf-blue);
  outline: none;
}

/* 4. Botones de Acción (EXPORT / IMPORT) */
.inv-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed #333;
}

.inv-action-btn {
  flex: 1;
  background: #1a1c20;
  border: 1px solid #444;
  color: #aaa;
  font-size: 0.75em;
  padding: 8px 0;
  cursor: pointer;
  border-radius: 3px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: all 0.2s;
}

.inv-action-btn:hover {
  background: #222;
  color: #fff;
  border-color: var(--wf-blue);
}

.inv-action-btn span {
  font-size: 1.1em;
}

#import-file-input {
  display: none;
}

/* Relic UI */
#relic-controls-wrapper {
  margin-top: 20px;
  padding-top: 15px;
  border-top: 1px dashed #333;
}

.relic-input-wrapper {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  position: relative;
}

.camera-btn {
  background: rgba(15, 17, 21, 0.85);
  border: 1px solid var(--wf-blue);
  color: var(--wf-blue);
  border-radius: 4px;
  height: 42px;
  width: auto;
  padding: 0 20px;
  font-family: sans-serif;
  font-size: 0.85rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.2s ease-in-out;
  box-shadow: 0 0 5px rgba(0, 229, 255, 0.1);
  flex-shrink: 0;
  font-weight: 700;
  cursor: pointer;
}

.camera-btn:hover {
  background: rgba(0, 229, 255, 0.15);
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.5);
  transform: translateY(-1px);
  color: #fff;
}

.camera-btn:active {
  transform: scale(0.95);
  box-shadow: 0 0 5px rgba(0, 229, 255, 0.8);
}

.counter-inline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #0f1115;
  border: 1px solid #444;
  border-radius: 4px;
  padding: 5px;
  height: 42px;
}

.c-btn {
  background: 0 0;
  border: 0;
  color: var(--wf-blue);
  font-size: 1.5em;
  width: 40px;
  height: 100%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s;
}

.c-btn:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}

.c-val {
  font-weight: 700;
  font-size: 1.1em;
  color: #fff;
}

#relic-contents {
  margin-top: 20px;
  border-top: 1px dashed #333;
  padding-top: 15px;
  display: flex;
  flex-direction: column;
  gap: 15px;
  overflow: visible !important;
}

.total-profit-box {
  background: #15171b;
  padding: 15px;
  border-radius: 6px;
  border: 1px solid #333;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
}

.profit-label {
  color: #bbb;
  font-size: 0.9em;
  text-transform: uppercase;
  font-weight: 700;
}

.relic-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)) !important;
  gap: 8px;
  width: 100%;
}

.relic-chip {
  background: #222;
  border: 1px solid #333;
  border-left-width: 5px;
  border-radius: 4px;
  padding: 8px 10px;
  cursor: pointer;
  transition: 0.2s;
  display: flex;
  flex-direction: column;
  gap: 5px;
  overflow: visible !important;
  position: relative;
  z-index: 1;
  transform: none !important;
}

.relic-chip:hover {
  transform: translateY(-2px);
  border-color: #555;
  filter: brightness(1.1);
  z-index: 9999;
}

.relic-chip.common {
  border-left-color: var(--wf-common) !important;
  background: var(--bg-common);
}

.relic-chip.uncommon {
  border-left-color: var(--wf-uncommon) !important;
  background: var(--bg-uncommon);
}

.relic-chip.rare {
  border-left-color: var(--wf-rare) !important;
  background: var(--bg-rare);
  border: 1px solid rgba(255, 215, 0, 0.3);
  border-left-width: 5px;
}

#relicInput {
  flex: 1;
  width: 100%;
  padding: 12px;
  border-radius: 4px;
  border: 1px solid #444;
  background-color: var(--wf-input-bg);
  color: #eee;
  font-size: 1em;
  outline: 0;
  transition: all 0.2s ease;
  font-family: "Segoe UI", sans-serif;
}

#relicInput:focus {
  border-color: var(--active-theme-color);
  box-shadow: 0 0 8px var(--active-theme-color);
  background-color: #0f1113;
}

.relic-chip-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.relic-name {
  font-weight: 800;
  font-size: 0.95em;
  color: #fff;
}

.relic-img {
  width: 24px;
  max-height: 24px;
  filter: drop-shadow(0 0 2px rgba(255, 255, 255, 0.2));
}

.chip-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 2px;
}

.rarity-text {
  font-size: 0.7em;
  font-weight: 800;
  text-transform: uppercase;
}

.rarity-text.common {
  color: var(--wf-common) !important;
}

.rarity-text.uncommon {
  color: var(--wf-uncommon) !important;
}

.rarity-text.rare {
  color: var(--wf-rare) !important;
}

.status-badge {
  font-size: 0.6em;
  font-weight: 700;
  padding: 1px 4px;
  border-radius: 3px;
  border: 1px solid;
}

.status-badge.active {
  background: rgba(50, 200, 50, 0.1);
  color: var(--wf-green);
  border-color: #2a4b2a;
}

.status-badge.vaulted {
  background: rgba(224, 69, 69, 0.15);
  color: var(--wf-vaulted);
  border-color: #5a1a1a;
}

.status-badge.aya {
  background: rgba(165, 69, 224, 0.15);
  color: var(--wf-aya);
  border-color: #6a2a4b;
}

.component-row {
  background: linear-gradient(90deg,
      rgba(20, 22, 26, 0.9) 0,
      rgba(30, 33, 40, 0.6) 100%);
  border: 1px solid #333;
  border-left-width: 4px;
  border-radius: 4px;
  padding: 12px 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 0.2s ease;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
  margin-bottom: 8px;
  overflow: visible !important;
  position: relative;
  z-index: 1;
  transform: none !important;
}

.component-row:hover {
  background: linear-gradient(90deg, #252830 0, #2a2d35 100%);
  transform: translateX(3px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
  z-index: 9999;
}

.component-row[data-rarity="common"] {
  border-left-color: var(--wf-common);
}

.component-row[data-rarity="common"] .rarity-indicator {
  color: var(--wf-common);
  text-shadow: 0 0 2px rgba(205, 127, 50, 0.2);
}

.component-row[data-rarity="uncommon"] {
  border-left-color: var(--wf-uncommon);
}

.component-row[data-rarity="uncommon"] .rarity-indicator {
  color: var(--wf-uncommon);
  text-shadow: 0 0 2px rgba(192, 192, 192, 0.2);
}

.component-row[data-rarity="rare"] {
  border-left-color: var(--wf-rare);
  box-shadow: 0 0 10px rgba(255, 215, 0, 0.1);
}

.component-row[data-rarity="rare"] .rarity-indicator {
  color: var(--wf-rare);
  text-shadow: 0 0 8px var(--wf-rare);
}

.component-row[data-rarity="forma"] {
  border-left-color: var(--wf-forma);
}

.component-row[data-rarity="forma"] .rarity-indicator {
  color: var(--wf-forma);
}

.component-info {
  display: flex;
  align-items: center;
  gap: 15px;
  flex-grow: 1;
  min-width: 0;
}

.rarity-indicator {
  font-family: monospace;
  font-weight: 900;
  font-size: 1.2em;
  width: 24px;
  text-align: center;
  flex-shrink: 0;
  transition: text-shadow 0.3s ease;
}

.name-wrapper {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow: visible;
}

.component-name {
  font-weight: 600;
  letter-spacing: 0.5px;
  color: #eee;
  text-transform: uppercase;
  font-size: 0.9em;
}

.component-name.item-interactive {
  cursor: pointer;
  border-bottom: 1px solid transparent;
}

.component-name.item-interactive:hover {
  color: var(--wf-blue);
  text-shadow: 0 0 8px rgba(0, 229, 255, 0.5);
  padding-left: 5px;
}

.component-name.forma {
  color: var(--wf-forma);
  font-weight: 700;
  font-style: italic;
}

.market-link-icon {
  color: #666;
  opacity: 0;
  transition: opacity 0.2s;
  margin-left: 10px;
}

.component-row:hover .market-link-icon {
  opacity: 1;
  color: var(--wf-blue);
}

.price-badge {
  font-family: monospace;
  font-weight: 700;
  font-size: 1.1em;
  color: var(--wf-blue);
  background: rgba(0, 229, 255, 0.1);
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid rgba(0, 229, 255, 0.3);
  min-width: 50px;
  text-align: center;
  display: inline-block;
  margin-right: 10px;
  overflow: visible !important;
  position: relative;
  z-index: 1;
  transform: none !important;
}

.price-badge.loading {
  color: #666;
  border-color: #444;
  background: 0 0;
  font-size: 0.8em;
}

.price-badge.forma {
  color: #bbb;
  border-color: #555;
  background: rgba(255, 255, 255, 0.05);
}

/* Set Module */
#setResults {
  padding-right: 5px;
  overflow-y: auto;
}

.set-container {
  margin-bottom: 25px;
  border: 1px solid #333;
  border-radius: 6px;
  background: #15171b;
  transition: border-color 0.2s;
  overflow: visible !important;
  position: relative;
  z-index: 10;
  transform: none !important;
}

.set-container:hover {
  border-color: var(--wf-orokin);
  z-index: 9999;
}

.set-header {
  background: #1f2329;
  padding: 10px 15px;
  border-bottom: 1px solid #333;
  color: var(--wf-orokin);
  font-weight: 700;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.set-header-link,
.market-link {
  text-decoration: none;
  color: inherit;
  display: inline-flex;
  align-items: center;
  transition: color 0.2s;
}

.set-header-link {
  transition: all 0.2s ease;
  margin-left: 5px;
}

.set-header-link span:first-child {
  border-bottom: 1px dotted var(--wf-gold-text);
  transition: all 0.2s ease;
}

.set-header-link:hover span:first-child {
  color: #fff !important;
  border-bottom-style: solid;
  text-shadow: 0 0 10px var(--wf-gold-text);
}

.market-link:hover {
  color: var(--wf-blue);
  text-shadow: 0 0 8px rgba(0, 229, 255, 0.4);
}

#set-tracker,
.profile-stat-box {
  padding: 10px;
  border: 1px solid #333;
}

#set-tracker {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 6px;
}

#tracker-list {
  overflow-y: auto;
  padding-right: 5px;
  overflow-x: visible;
}

.tracker-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px;
  background: #222;
  border: 1px solid #333;
  margin-bottom: 5px;
  border-radius: 4px;
  transition: 0.2s;
  overflow: visible !important;
  position: relative;
  z-index: 1;
  transform: none !important;
}

.tracker-item:hover {
  z-index: 9999;
}

.tracker-item.done {
  opacity: 0.4;
  text-decoration: line-through;
  border-color: #222;
}

.tracker-item .market-link-icon {
  margin-left: 8px;
  font-size: 1em;
  opacity: 0.5;
}

.tracker-item:hover .market-link-icon {
  opacity: 1;
  color: var(--wf-blue);
}

.component-row {
  margin-top: 5px;
  padding: 8px 10px;
  border-top: 1px dashed #333;
  transition: background-color 0.2s;
  position: relative;
  overflow: visible !important;
  z-index: 1;
}

.component-row:hover {
  background: rgba(255, 255, 255, 0.02);
  z-index: 100;
}

.t-check {
  cursor: pointer;
  background: #333;
  border: 1px solid #555;
  color: #fff;
  padding: 2px 8px;
  border-radius: 3px;
}

.t-check:hover {
  background: var(--wf-green);
  border-color: var(--wf-green);
}

/* Riven Module */
.riven-btn {
  background: var(--wf-riven);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  border: 0;
  padding: 15px;
  width: 100%;
  margin-top: 15px;
  cursor: pointer;
  border-radius: 4px;
}

.riven-btn:hover {
  filter: brightness(1.2);
}

#riven-avg-box {
  background: rgba(162, 53, 226, 0.1);
  border: 1px solid var(--wf-riven);
  padding: 10px;
  border-radius: 5px;
  text-align: center;
  margin-bottom: 15px;
  display: none;
}

.riven-avg-val {
  font-size: 1.5em;
  font-weight: 700;
  color: #fff;
}

.riven-row.input-group {
  display: flex;
  gap: 10px;
  margin-bottom: 8px;
}

.riven-stat-select {
  flex: 2;
}

.riven-val-input {
  flex: 1;
  min-width: 60px;
  text-align: right;
  font-family: monospace;
}

/* Profile Module */
.profile-stat-box {
  background: #222;
  border-radius: 4px;
  margin-bottom: 10px;
  text-align: center;
}

#profile-data {
  overflow-y: auto;
  padding-right: 5px;
}

.standing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px;
  margin-top: 15px;
}

.standing-item {
  background: #1a1c20;
  padding: 8px;
  border-radius: 4px;
  border: 1px solid #333;
  text-align: center;
}

.standing-val {
  color: var(--wf-green);
  font-weight: 700;
}

/* LFG Module */
.lfg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.lfg-checkbox-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1a1c20;
  padding: 12px 10px;
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid #333;
  transition: all 0.2s ease;
  user-select: none;
}

.lfg-checkbox-wrapper:hover {
  border-color: var(--wf-lfg);
  background: #25282e;
  transform: translateY(-1px);
}

.lfg-checkbox-wrapper:has(input:checked) {
  background: rgba(66, 245, 108, 0.15);
  border-color: var(--wf-lfg);
  color: #fff;
  box-shadow: 0 0 10px rgba(66, 245, 108, 0.15);
}

.lfg-label {
  font-size: 0.9em;
  font-weight: 700;
  color: #aaa;
  text-transform: uppercase;
}

.lfg-checkbox-wrapper:has(input:checked) .lfg-label {
  color: var(--wf-lfg);
  text-shadow: 0 0 5px rgba(66, 245, 108, 0.5);
}

.card.theme-lfg select.wf-input {
  background-image: url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%2342f56c%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E) !important;
}

.lfg-presets-container {
  margin-bottom: 15px;
  background: rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  padding: 8px;
  border: 1px dashed #333;
}

.presets-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.presets-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.preset-chip {
  background: #1f2329;
  border: 1px solid #444;
  border-left: 3px solid var(--wf-lfg);
  border-radius: 3px;
  padding: 5px 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
  user-select: none;
}

.preset-chip:hover {
  background: #2a2e35;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  border-color: #666;
}

.preset-chip:active {
  transform: translateY(0);
}

.p-name {
  font-weight: 700;
  color: #eee;
  font-size: 0.9em;
}

.p-act {
  font-size: 0.7em;
  background: rgba(255, 255, 255, 0.1);
  padding: 1px 4px;
  border-radius: 2px;
  color: #aaa;
}

.p-del {
  background: 0 0;
  border: 0;
  color: #666;
  font-size: 1.1em;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
}

.p-del:hover {
  color: #f44;
}

/* =========================================
   8. SCANNER SYSTEM (OCR & LIVE)
   ========================================= */
.scanner-wrapper {
  position: relative;
  z-index: 1000;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  width: auto;
  transition: all 0.3s ease;
}

.scanner-toggle-btn {
  justify-content: center;
  gap: 12px;
  padding: 6px 16px;
  min-width: 150px;
  width: fit-content;
  background: rgba(10, 11, 13, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 4px;
  cursor: pointer;
  overflow: hidden;
  display: flex;
  align-items: center;
  font: 900 0.85rem MONOSPACE, sans-serif;
}

.scanner-toggle-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  border-color: #c5a059;
}

.scanner-toggle-btn.active {
  background: rgba(0, 229, 255, 0.1);
  border-color: #00e5ff;
  color: #00e5ff;
  box-shadow: 0 0 10px rgba(0, 229, 255, 0.2);
}

.toggle-content {
  display: flex;
  align-items: center;
  font:
    600 1rem "Segoe UI",
    sans-serif;
  justify-content: center;
  gap: 10px;
  flex-grow: 1;
}

.icon-pulse {
  color: #f44;
  font-size: 1.2em;
  transition: color 0.3s;
}

.scanner-toggle-btn.active .icon-pulse {
  color: #00e5ff;
  animation: pulse 2s infinite;
  text-shadow: 0 0 8px #00e5ff;
}

.arrow-indicator {
  font-size: 0.7em;
  color: #555;
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
}

.scanner-toggle-btn.active .arrow-indicator {
  transform: rotate(180deg);
  color: #c5a059;
}

.label {
  font:
    800 0.85rem "Segoe UI",
    sans-serif;
  letter-spacing: 1.5px;
  color: #eee;
  text-transform: uppercase;
  white-space: nowrap;
}

.scanner-toggle-btn.active .label {
  color: #00e5ff;
}

.scanner-drawer {
  background: #000;
  transition:
    max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.3s ease;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.8);
  border-radius: 0 0 4px 4px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: -1;
}

.scanner-drawer.closed {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
  display: none;
}

.scanner-drawer.open {
  max-height: 0;
  opacity: 0;
  display: flex !important;
  pointer-events: none;
  position: fixed;
  top: -9999px;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  z-index: -1;
}

#live-scroll-guide {
  transition: all 0.3s ease;
  min-height: 1.5em;
}

#live-inventory-status button:hover,
#live-inventory-list-overlay button:hover {
  filter: brightness(1.2);
  transform: scale(1.05);
}

.scanner-info-icon {
  position: relative;
  left: 0;
  top: auto;
  transform: none;
  width: 24px;
  height: 24px;
  background: rgba(0, 0, 0, 0.6);
  color: var(--wf-blue);
  border: 1px solid var(--wf-blue);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  cursor: help;
  transition: all 0.2s;
  z-index: 1002;
}

.scanner-info-icon:hover {
  background: var(--wf-blue);
  color: #000;
  box-shadow: 0 0 10px var(--wf-blue);
}

.scanner-notice {
  position: absolute;
  top: 70px;
  right: 0;
  width: 300px;
  background: #0f1115;
  border: 1px solid #f44;
  border-radius: 8px;
  padding: 0;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.9);
  z-index: 10005;
  overflow: hidden;
  animation: slideDown 0.3s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

.notice-header {
  background: rgba(255, 68, 68, 0.15);
  color: #f44;
  padding: 10px 15px;
  font:
    800 0.9em "Segoe UI",
    sans-serif;
  border-bottom: 1px solid #f44;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.notice-body {
  padding: 15px;
  color: #ddd;
  font-size: 0.9em;
  line-height: 1.5;
}

.notice-body p {
  margin: 0 0 10px;
}

.beta-warning {
  background: rgba(255, 255, 0, 0.05);
  border-left: 3px solid #fe0;
  padding: 8px;
  color: #fe0;
  font-size: 0.8em !important;
  font-style: italic;
}

.action-btn.full-width {
  width: 100%;
  border-radius: 0;
  margin: 0;
  border: 0;
  border-top: 1px solid #333;
  padding: 12px;
}

.action-btn.full-width:hover {
  background: var(--wf-blue);
  color: #000;
}

#live-viewport {
  position: relative;
  width: 100%;
  height: 50vh;
  background: #000;
}

#live-video {
  display: none;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#live-overlay {
  pointer-events: none;
}

#close-drawer-btn {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(200, 0, 0, 0.7);
  color: #fff;
  border: 0;
  padding: 5px 10px;
  border-radius: 4px;
  cursor: pointer;
  z-index: 20;
}

/* Fullscreen Scanner (OCR Overlay) */
.fullscreen-scanner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: var(--z-scanner-overlay);
  display: flex;
  flex-direction: column;
}

.scanner-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scanner-ui {
  position: absolute;
  inset: 0;
  pointer-events: none;
  justify-content: space-between;
  padding: 20px;
  display: flex;
  flex-direction: column;
}

.control-btn,
.scanner-close-btn,
.shutter-btn {
  pointer-events: auto;
}

.scanner-close-btn {
  align-self: flex-end;
  background: rgba(0, 0, 0, 0.5);
  border: 0;
  color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1.5em;
  cursor: pointer;
  backdrop-filter: blur(4px);
}

.scanner-guide {
  flex-grow: 1;
  margin: 40px 20px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.scanner-text {
  background: rgba(0, 0, 0, 0.6);
  padding: 5px 10px;
  border-radius: 15px;
  color: #fff;
  font-size: 0.8em;
  text-transform: uppercase;
}

.guide-corner {
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: var(--wf-blue);
  border-style: solid;
}

.tl {
  top: -1px;
  left: -1px;
  border-width: 3px 0 0 3px;
}

.tr {
  top: -1px;
  right: -1px;
  border-width: 3px 3px 0 0;
}

.bl {
  bottom: -1px;
  left: -1px;
  border-width: 0 0 3px 3px;
}

.br {
  bottom: -1px;
  right: -1px;
  border-width: 0 3px 3px 0;
}

.scanner-controls-bar {
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding-bottom: 30px;
}

.shutter-btn {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: 0 0;
  border: 4px solid #fff;
  position: relative;
  transition: transform 0.1s;
  cursor: pointer;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

.shutter-btn::after {
  content: "";
  position: absolute;
  inset: 5px;
  background: #fff;
  border-radius: 50%;
  transition: 0.2s;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 54px;
  height: 54px;
}

.shutter-btn:active {
  transform: scale(0.9);
}

.shutter-btn:active::after {
  width: 45px;
  height: 45px;
  background: #ccc;
}

.control-btn {
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  border: 0;
  padding: 10px;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 1.2em;
}

.scanner-actions-bar {
  position: absolute;
  bottom: 40px;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 25px;
  z-index: 50;
  pointer-events: none;
}

.scanner-actions-bar button {
  pointer-events: auto;
}

.scanner-actions-bar .action-btn {
  height: 50px;
  min-width: 50px;
  border-radius: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 1rem;
  padding: 0 20px;
  transition:
    transform 0.1s,
    box-shadow 0.2s;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: rgba(20, 20, 30, 0.9);
  border: 1px solid #555;
  color: #ddd;
  cursor: pointer;
}

.scanner-actions-bar .action-btn:active {
  transform: scale(0.95);
}

.ocr-system-header {
  position: absolute;
  top: 30px;
  left: 0;
  width: 100%;
  text-align: center;
  color: var(--wf-blue);
  font-family: monospace;
  font-weight: 900;
  letter-spacing: 2px;
  font-size: 1.1em;
  text-transform: uppercase;
  text-shadow: 0 0 10px rgba(0, 229, 255, 0.6);
  z-index: 10011;
  pointer-events: none;
  user-select: none;
}

.ocr-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 5000;
  color: white;
  font-weight: bold;
  font-size: 1.2rem;
}

.ocr-spinner {
  width: 50px;
  height: 50px;
  border: 5px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  border-top-color: var(--wf-blue);
  animation: spin 1s ease-in-out infinite;
  margin-bottom: 15px;
}

.inventory-badge-btn {
  background: var(--wf-blue, #00e5ff) !important;
  color: #000 !important;
  border: none !important;
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.4) !important;
  position: relative;
  font-weight: bold;
}

.badge-count {
  position: absolute;
  top: -5px;
  right: -5px;
  background: var(--wf-red, #ff4444);
  color: #fff;
  font-size: 0.75rem;
  height: 20px;
  min-width: 20px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #111;
  font-weight: bold;
}

.badge-count.hidden {
  display: none;
}

/* (Botón flotante) */
.mobile-scan-fab {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 65px;
  height: 65px;
  border-radius: 50%;
  background: radial-gradient(circle at center, #1a1a1a 0%, #0f1115 100%);
  border: 2px solid #d4af37;
  box-shadow:
    0 0 15px rgba(212, 175, 55, 0.4),
    inset 0 0 10px rgba(0, 0, 0, 0.8);
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: var(--z-fab);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-tap-highlight-color: transparent;
}

.mobile-scan-fab:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 229, 255, 0.5);
  background: linear-gradient(135deg, #00e5ff, #00b8d4);
}

.mobile-scan-fab.scanning {
  animation: scanPulse 1.5s ease-in-out infinite;
  background: linear-gradient(135deg, #42f56c, #2ecc71);
  border-color: rgba(66, 245, 108, 0.6);
}

.mobile-scan-fab.scanning::before {
  content: "✓";
  font-size: 32px;
  color: #000;
  font-weight: bold;
}

.mobile-scan-fab::before {
  content: none;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

.mobile-scan-fab:active {
  transform: scale(0.95);
  box-shadow: 0 0 20px rgba(0, 229, 255, 0.6);
}

.mobile-scan-fab.processing {
  pointer-events: none;
  opacity: 0.6;
}

.mobile-scan-fab.processing::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: var(--wf-blue);
  animation: spin 0.8s linear infinite;
}

.mobile-scan-fab img.fab-icon {
  width: 36px;
  height: 36px;
  pointer-events: none;
  filter: drop-shadow(0 0 3px rgba(212, 175, 55, 0.6));
  transition: all 0.3s ease;
}

/* =========================================
   9. MODALES (Grading, Scan Results, Updates)
   ========================================= */
#scan-success-modal,
#grading-modal,
#update-modal,
#calibration-modal,
#orokin-confirm-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

#scan-success-modal:not(.hidden),
#grading-modal:not(.hidden),
#update-modal:not(.hidden),
#calibration-modal:not(.hidden),
#orokin-confirm-modal:not(.hidden) {
  opacity: 1;
  pointer-events: auto;
}

#grading-modal.hidden,
.scanner-notice.hidden {
  display: none !important;
}

.modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
}

.scan-result-card {
  position: relative;
  width: 98%;
  max-width: 1600px;
  background: rgba(15, 20, 28, 0.95);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(0, 229, 255, 0.3);
  box-shadow: 0 0 50px rgba(0, 0, 0, 0.8), 0 0 20px rgba(0, 229, 255, 0.1);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 2;
  animation: modalFadeIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes modalFadeIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(20px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.scan-header {
  padding: 15px 25px;
  background: rgba(0, 0, 0, 0.4);
  border-bottom: 1px solid rgba(0, 229, 255, 0.2);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.scan-header h3 {
  margin: 0;
  color: #00e5ff;
  letter-spacing: 2px;
  font-size: 1.1em;
  text-shadow: 0 0 10px rgba(0, 229, 255, 0.4);
}

.close-modal-btn {
  background: 0 0;
  border: 0;
  color: #888;
  font-size: 1.5em;
  cursor: pointer;
}

.scan-image-container {
  position: relative;
  width: 100%;
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
}

#scan-snapshot {
  width: 100%;
  height: auto;
  max-height: 85vh;
  object-fit: contain;
}

#scan-badges-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

#scan-badges-container {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.modal-badge {
  position: absolute;
  top: 48%;
  transform: translateX(-50%);
  background: rgba(10, 15, 20, 0.98);
  backdrop-filter: blur(25px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 15px;
  padding-top: 75px;
  border-radius: 14px;
  width: 200px;
  height: 265px;
  display: flex;
  flex-direction: column;
  pointer-events: auto;
  cursor: pointer;
  box-shadow: 0 15px 60px rgba(0, 0, 0, 0.9);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 10;
}

.modal-badge:active {
  transform: translateX(-50%) scale(0.95);
}

.modal-badge:hover {
  background: rgba(25, 30, 40, 0.95);
  border-color: var(--wf-blue);
  box-shadow: 0 15px 40px rgba(0, 229, 255, 0.3);
  transform: translateX(-50%) translateY(-5px) scale(1.05);
  z-index: 100 !important;
}

.modal-badge.best-pl,
.modal-badge.best-duc {
  z-index: 20;
}

.modal-badge.best-pl {
  border: 2px solid var(--wf-gold-text);
  box-shadow: 0 0 20px rgba(212, 175, 55, 0.3);
}

.modal-badge.best-duc {
  border: 2px solid #00e5ff;
  box-shadow: 0 0 20px rgba(0, 229, 255, 0.3);
}

.selected-reward {
  border-color: #00ff78 !important;
  box-shadow: 0 0 25px rgba(0, 255, 120, 0.4) !important;
}

.modal-badge-link {
  text-decoration: none;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
  gap: 8px;
  text-align: center;
}

.modal-badge-content-wrapper {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: flex-start;
  gap: 4px;
}

.modal-badge-name {
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: normal;
  line-height: 1.2;
  margin: 4px 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.modal-badge-row {
  display: flex;
  justify-content: center;
  gap: 15px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 5px;
}

.modal-badge-price,
.modal-badge-ducats {
  font-weight: 800;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  gap: 4px;
}

.modal-badge-price {
  color: var(--wf-gold-text);
}

.modal-badge-ducats {
  color: #00e5ff;
}

.currency-icon {
  width: 16px;
  height: 16px;
  object-fit: contain;
  transition: transform 0.2s;
}

.modal-badge:hover .currency-icon {
  transform: scale(1.2);
}

.best-badge {
  font-size: 0.7rem;
  font-weight: 900;
  padding: 3px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.best-badge.pl {
  background: var(--wf-gold-text);
  color: #000;
  box-shadow: 0 0 10px rgba(212, 175, 55, 0.4);
}

.best-badge.duc {
  background: #00e5ff;
  color: #000;
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.5);
}

.best-badge.set-finisher {
  background: #a29bfe;
  color: #000;
  box-shadow: 0 0 10px rgba(162, 155, 254, 0.4);
}

.modal-badge-labels {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: center;
  width: 100%;
  pointer-events: none;
  z-index: 100;
}

.badge-add-inventory-hint {
  font-size: 0.75rem;
  font-weight: 800;
  color: #00ff78;
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(0, 255, 120, 0.2);
  text-align: center;
  transition: all 0.2s;
}

.modal-badge:hover .badge-add-inventory-hint {
  color: #fff;
  text-shadow: 0 0 8px rgba(0, 255, 120, 0.8);
}

.metadata-row {
  font-size: 11px;
  color: #fff;
  margin-bottom: 10px;
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.inventory-app-count {
  color: #00ff78;
  font-weight: 900;
  background: rgba(0, 255, 120, 0.15);
  padding: 3px 8px;
  border-radius: 5px;
  border: 1px solid rgba(0, 255, 120, 0.3);
  display: inline-block;
  font-size: 12px;
}

.metadata-seen {
  color: #00e5ff;
  font-weight: 800;
}

.metadata-crafted {
  color: #ffa500;
  font-weight: 800;
}

.scan-footer {
  padding: 15px;
  display: flex;
  justify-content: center;
  background: #111;
  border-top: 1px solid #333;
}

#scanned-results-panel.results-drawer {
  position: fixed;
  bottom: 120px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  max-width: 400px;
  background: rgba(15, 15, 23, 0.95);
  border: 1px solid var(--wf-blue);
  border-radius: 12px;
  padding: 15px;
  z-index: var(--z-modal);
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.5);
  transition: all 0.3s ease;
}

#scanned-results-panel.hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(100%) !important;
  opacity: 0 !important;
  z-index: -999 !important;
}

.scanned-grid-container {
  max-height: 250px;
  overflow-y: auto;
  margin: 10px 0;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
  padding: 10px 0;
}

.scanned-item-card {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid #555;
  padding: 5px;
  border-radius: 4px;
  text-align: center;
  font-size: 0.8em;
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Grading Modal Specifics */
.grading-results {
  margin-top: 15px;
  padding: 10px;
  background: rgba(0, 0, 0, 0.3);
  border: 1px dashed #444;
  border-radius: 4px;
}

.grade-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  font-size: 0.9em;
}

.grade-label {
  width: 30px;
  font-weight: 700;
  text-align: center;
}

.grade-track {
  flex-grow: 1;
  overflow: hidden;
  position: relative;
  height: 4px;
  background: #222;
  border-radius: 2px;
  width: 100%;
}

.grade-fill {
  height: 100%;
  width: 0%;
  transition:
    width 0.3s ease,
    background-color 0.3s;
}

.grade-fill.S,
.grade-label.S,
.grade-badge-large.grade-s {
  background: linear-gradient(135deg, gold, #b8860b);
  color: #000;
  box-shadow: 0 0 5px #d4af37;
}

.grade-fill.A,
.grade-label.A,
.grade-badge-large.grade-a {
  background: linear-gradient(135deg, #00e5ff, #09c);
  color: #000;
}

.grade-fill.B,
.grade-label.B,
.grade-badge-large.grade-b {
  background: linear-gradient(135deg, #4fbd4f, #2e7d32);
  color: #fff;
}

.grade-fill.C,
.grade-label.C,
.grade-badge-large.grade-c {
  background: #333;
  color: #888;
}

.grade-fill.F,
.grade-label.F,
.grade-badge-large.grade-f {
  background: #333;
  color: #888;
}

.grade-range-text {
  font-size: 0.75em;
  color: #777;
  min-width: 80px;
  text-align: right;
}

.grading-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid #444;
  font-size: 0.85em;
  color: #888;
}

.grading-warning {
  color: var(--wf-blue);
  font-weight: 700;
  font-size: 0.8em;
  animation: pulse 2s infinite;
}

.grade-card {
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 6px;
  padding: 10px;
  margin-bottom: 8px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.grade-badge-large {
  width: 40px;
  height: 40px;
  font-weight: 900;
  font-size: 1.4em;
  border-radius: 4px;
  margin-right: 12px;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.grade-info {
  flex-grow: 1;
}

.grade-stat-name {
  font-weight: 700;
  color: #eee;
  font-size: 0.95em;
  margin-bottom: 2px;
}

.grade-values {
  font-size: 0.8em;
  color: #aaa;
  margin-bottom: 6px;
}

.grade-range {
  opacity: 0.7;
  margin-left: 5px;
}

#grading-inputs-container .riven-row {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  align-items: center;
}

#grading-inputs-container .mini-action-btn {
  padding: 8px 12px;
  font-size: 1.2em;
  line-height: 1;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid #444;
}

#grading-inputs-container .mini-action-btn:hover {
  background: rgba(255, 0, 0, 0.1);
  border-color: #f44;
}

/* Updates Modal */
.update-block {
  margin-bottom: 25px;
}

.update-block.old {
  opacity: 0.6;
  border-top: 1px solid #333;
  padding-top: 15px;
}

.update-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.update-version {
  font-weight: 900;
  color: var(--wf-gold-text);
  font-size: 1.2em;
}

.update-date {
  font-size: 0.8em;
  color: #666;
}

.update-list {
  padding-left: 20px;
  color: #ddd;
  font-size: 0.95em;
}

.update-list li {
  margin-bottom: 6px;
}

.update-list li::marker {
  color: var(--wf-blue);
}

/* =========================================
   10. MEDIA QUERIES 
   ========================================= */

/* Desktop Large (min-width: 1350px) */

@media (min-width: 1350px) {
  #inv-toggle-btn {
    left: auto !important;
    right: -80px !important;
    border-radius: 0 8px 8px 0 !important;
  }

  #mission-toggle-btn {
    right: auto !important;
    left: -80px !important;
    border-radius: 8px 0 0 8px !important;
  }

  .mission-toggle-btn {
    display: flex !important;
    width: 80px !important;
    height: 80px !important;
    position: absolute !important;
    top: 20px !important;
  }

  .mission-toggle-btn .toggle-img {
    width: 5rem !important;
    height: 5rem !important;
  }

  #best-missions-container {
    top: 50% !important;
    transform: translateY(-50%) !important;
    right: -300px;
    width: 300px !important;
    height: auto !important;
    max-height: 85vh !important;
    min-height: 200px !important;
    display: flex !important;
    flex-direction: column !important;
    border-radius: 12px 0 0 12px !important;
    border: 1px solid rgba(0, 229, 255, 0.3) !important;
    background: rgba(27, 30, 35, 0.95) !important;
    backdrop-filter: blur(20px) !important;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.5), 0 0 20px rgba(0, 229, 255, 0.1) !important;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
    animation: slideInRight 0.5s ease-out;
    overflow: visible !important;
  }

  #best-missions-container.open {
    right: 0 !important;
  }

  #cloud-sync-container {
    left: -290px;
    right: auto !important;
    top: auto;
    bottom: 30px;
    /* Large desktop scanner bottom */
    border-radius: 0 12px 12px 0;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }

  #cloud-sync-container.open {
    transform: translateX(290px) !important;
  }
}

@media (max-width: 1280px) {
  .mobile-scan-fab {
    display: flex;
    bottom: 20px;
    right: 20px;
    width: 55px;
    height: 55px;
  }

  .mobile-scan-fab img.fab-icon {
    width: 30px;
    height: 30px;
  }

  #cloud-sync-container {
    bottom: 20px;
    /* Matches 1280px scanner bottom */
  }

  #cloud-sync-container .side-toggle-btn {
    bottom: 2.5px;
    /* Centers 50px btn with 55px scanner circle */
  }
}

@media (max-width: 768px) {
  .tab-icon-img {
    width: 1.5rem;
    height: 1.5rem;
  }

  #global-tooltip,
  [data-tooltip]::after,
  [data-tooltip-html] {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    visibility: hidden !important;
  }

  html,
  body {
    height: 100vh !important;
    height: 100dvh !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  #best-missions-container,
  #inventory-container,
  .card {
    display: flex !important;
    position: fixed !important;
    top: 60px !important;
    width: 100% !important;
    margin: 0 !important;
  }

  .card {
    position: relative !important;
    top: auto !important;
    bottom: auto !important;
    left: auto !important;
    width: 100% !important;
    margin: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;

    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    z-index: 10 !important;
  }

  .content-area {
    flex: 1 !important;
    height: 100% !important;
    overflow-y: auto !important;
    padding: 15px 10px 100px 10px !important;

    -webkit-overflow-scrolling: touch;
    background-color: var(--wf-card) !important;
    padding-bottom: 30vh !important;
  }

  .header-subtitle,
  .site-footer {
    display: none !important;
  }

  .site-header {
    height: auto !important;
    min-height: 85px !important;
    padding: 10px 15px !important;
    border-bottom: 2px solid var(--active-theme-color) !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 0 !important;
  }

  .header-title {
    font-size: 1.35rem !important;
    text-align: center !important;
    width: 100% !important;
    margin-bottom: 2px !important;
  }

  .site-header .header-controls {
    display: flex !important;
    position: relative !important;
    width: 100% !important;
    justify-content: center !important;
    transform: scale(0.8) !important;
    margin-top: 0 !important;
  }

  /* Hide scanner instructions/notice from header on mobile */
  .scanner-wrapper,
  .scanner-notice,
  .scanner-info-icon {
    display: none !important;
  }

  /* Side Panels Behavior Mobile */
  #best-missions-container,
  #inventory-container {
    transform: none !important;
    backdrop-filter: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    height: calc(100% - 60px) !important;
    max-width: 350px !important;
    z-index: 9000 !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
    transition:
      left 0.3s cubic-bezier(0.4, 0, 0.2, 1),
      right 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }

  #inventory-container {
    left: -100% !important;
    right: auto !important;
    border-right: 1px solid var(--wf-blue) !important;
    border-radius: 0 0 12px 0 !important;
    box-shadow: 0 0 20px rgba(0, 229, 255, 0.15) !important;
  }

  #inventory-container.open {
    left: 0 !important;
  }

  #best-missions-container {
    right: -100% !important;
    left: auto !important;
    border-left: 1px solid var(--wf-blue) !important;
    border-radius: 0 0 0 12px !important;
  }

  #best-missions-container.open {
    right: 0 !important;
    border-radius: 0 !important;
    border-right: none !important;
  }

  /* Toggle Buttons Mobile */
  #best-missions-container .mission-toggle-btn,
  #inventory-container #inv-toggle-btn,
  .mission-toggle-btn {
    position: fixed !important;
    width: 3.2rem !important;
    height: 3.2rem !important;
    top: 15px !important;
    /* Move higher slightly */
    bottom: auto !important;
    background: rgba(15, 17, 21, 0.9) !important;
    backdrop-filter: blur(8px);
    border: 2px solid var(--active-theme-color, #00e5ff) !important;
    border-radius: 50% !important;
    z-index: 11000 !important;
    display: flex !important;
    justify-content: center;
    align-items: center;
    pointer-events: auto !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.6) !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  #inventory-container #inv-toggle-btn {
    left: 4px !important;
    top: 15px !important;
  }

  #best-missions-container .mission-toggle-btn,
  .mission-toggle-btn {
    right: 4px !important;
    top: 15px !important;
    left: auto !important;
  }

  #best-missions-container .mission-toggle-btn img,
  #inventory-container #inv-toggle-btn img,
  .toggle-img {
    width: 3rem !important;
    height: 3rem !important;
    display: block !important;
    object-fit: contain !important;
    opacity: 1 !important;
    visibility: visible !important;
    filter: drop-shadow(0 0 2px var(--active-theme-color)) !important;
    margin: 0 !important;
  }

  #best-missions-container.open .toggle-img {
    transform: rotate(180deg);
    filter: drop-shadow(0 0 10px rgba(212, 175, 55, 0.8)) !important;
  }

  #inventory-container.open .toggle-img {
    transform: rotate(180deg);
    filter: drop-shadow(0 0 10px rgba(0, 229, 255, 0.8)) !important;
  }

  /* Tabs Bottom Bar */
  .card-top-bar {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 70px !important;
    background: #0f1115 !important;
    border-top: 3px solid var(--active-theme-color) !important;
    z-index: 8000 !important;
    box-sizing: border-box !important;
  }

  .tabs {
    width: 100% !important;
    display: flex !important;
  }

  .tab-btn {
    flex: 1 !important;
    border-bottom: none !important;
    border-radius: 0 !important;
  }

  /* Floating Footer Message */
  #footer-relic {
    position: fixed !important;
    left: 0 !important;
    width: 100% !important;
    bottom: 70px !important;
    z-index: 4000 !important;
    background: #0f1115 !important;
    border-top: 2px solid var(--active-theme-color) !important;
    box-shadow: 0 -5px 20px rgba(0, 0, 0, 0.8) !important;
    padding: 15px 20px !important;
    transform: translateY(85%);
    opacity: 0.8;
    transition:
      transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
      opacity 0.3s ease;
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
  }

  #footer-relic.footer-visible {
    transform: translateY(0) !important;
    opacity: 1;
  }

  #footer-relic::before {
    content: "▼ SCROLL TO SEE/COPY MESSAGE ▼";
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 0.6em;
    color: var(--active-theme-color);
    font-weight: 800;
    opacity: 1;
    transition: opacity 0.2s;
  }

  #footer-relic.footer-visible::before {
    opacity: 0;
  }

  /* Mobile FAB Adjustments */
  .mobile-scan-fab {
    display: flex;
    bottom: 90px !important;
    right: 20px;
    width: 55px;
    height: 55px;
  }

  #cloud-sync-container {
    bottom: 90px !important;
    /* Matches mobile scanner bottom */
  }

  #cloud-sync-container .side-toggle-btn {
    bottom: 2.5px !important;
  }

  #footer-relic.footer-visible~.mobile-scan-fab {
    bottom: 220px !important;
    transition: bottom 0.3s ease;
  }

  #scan-success-modal:not(.hidden)~.mobile-scan-fab {
    display: none;
  }

  /* Modales en Móvil */
  #scan-success-modal .scan-result-card {
    width: 95% !important;
    max-height: 85vh !important;
  }

  /* Prevent Body Scroll on Mobile App Mode */
  body {
    display: flex !important;
    flex-direction: column !important;
    height: 100vh !important;
    overflow: hidden !important;
  }
}

/* Small Mobile (max-width: 480px) */
@media (max-width: 480px) {
  .scanner-wrapper {
    top: 10px;
    right: 10px;
  }

  .scanner-toggle-btn .label {
    display: none;
  }

  .scanner-toggle-btn::after {
    content: "SCAN";
    font-size: 0.8em;
  }
}

button[onclick*="exportInventory"]:hover {
  background-color: var(--wf-blue) !important;
  color: #000000 !important;
  border-color: var(--wf-blue) !important;
  box-shadow: 0 0 15px var(--wf-blue) !important;
  font-weight: 900 !important;
}

/* Botón IMPORTAR exportar */
button[onclick*="importInventory"]:hover {
  background-color: var(--wf-gold-text) !important;
  color: #000000 !important;
  border-color: var(--wf-gold-text) !important;
  box-shadow: 0 0 15px var(--wf-gold-text) !important;
  font-weight: 900 !important;
}

.card.theme-bounties {
  --active-theme-color: #ff8c00;
}

#bounties-list-container {
  padding: 10px;
  padding: 10px 5px;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.tab-btn.bounties:hover {
  color: #ff8c00;
}

/* 2. Encabezado de Facción (Zariman, Cavia, etc.) */
.faction-header {
  background: linear-gradient(90deg,
      rgba(255, 255, 255, 0.05) 0%,
      transparent 80%);
  border-left-width: 4px;
  border-left-style: solid;
  padding: 12px 15px;
  border-radius: 0 6px 6px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
  margin-bottom: 5px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.faction-name {
  font-weight: 800;
  text-transform: uppercase;
  font-size: 1.1em;
  letter-spacing: 1px;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

/* 3. Tarjeta de Misión Individual */
.bounty-item {
  background-color: #16191d;
  border: 1px solid #333;
  border-radius: 6px;
  padding: 12px 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    background 0.2s;
  position: relative;
  overflow: hidden;
}

.bounty-item:hover {
  transform: translateX(5px);
  border-color: var(--active-theme-color, #fff);
  background-color: #1c2026;
}

/* Estilo específico para STEEL PATH */
.bounty-item.is-sp {
  border-color: rgba(255, 68, 68, 0.4);
  background: linear-gradient(90deg, rgba(220, 20, 60, 0.08) 0%, #16191d 60%);
}

.bounty-item.is-sp:hover {
  border-color: #ff4444;
  box-shadow: inset 0 0 20px rgba(255, 0, 0, 0.05);
}

/* 4. Tipografía y Datos */
.bounty-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

.bounty-type {
  color: #f0f0f0;
  font-size: 0.95em;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Etiqueta SP roja pequeña */
.sp-badge {
  background: #ff4444;
  color: #000;
  font-size: 0.65em;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 900;
  letter-spacing: 0.5px;
  box-shadow: 0 0 8px #ff4444;
}

.bounty-tag {
  font-size: 0.8em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.site-header .header-version {
  font-size: 0.6em;
  color: var(--wf-blue);
  opacity: 0.8;
  margin-left: 8px;
  vertical-align: top;
}

.site-header .header-controls {
  display: flex;
  align-items: center;
  gap: 15px;
}

.bounty-tag span {
  font-size: 0.9em;
  opacity: 0.7;
  margin-left: 8px;
  font-weight: normal;
  font-family: monospace;
}

/* 5. Botón de Drops */
.bounty-rewards-btn {
  width: auto !important;
  flex-shrink: 0;
  padding: 6px 12px;
  font-size: 0.75em;
  white-space: nowrap;
  height: fit-content;
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid currentColor;
  border-radius: 4px;
}

.bounty-rewards-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

@media (max-width: 480px) {
  .bounty-header-row {
    padding: 10px;
  }

  .bounty-type {
    font-size: 0.9em;
  }

  .bounty-tag span {
    display: none;
  }

  .condition-text {
    font-size: 0.7em;
    white-space: normal;
    max-width: 100%;
  }

  .bounty-rewards-btn {
    padding: 6px 8px;
    font-size: 0.65em;
  }
}

@media (min-width: 768px) {
  #inventory-container {
    width: 450px !important;
    /* Fix conflict: Keep the 450px width */
  }

  #inventory-container #inv-toggle-btn,
  #best-missions-container #mission-toggle-btn {
    position: absolute !important;
    top: 20px !important;
    display: flex !important;
    z-index: 1000 !important;
    visibility: visible !important;
    opacity: 1 !important;
    transition: all 0.3s ease;
  }

  #inventory-container #inv-toggle-btn {
    right: -80px !important;
    left: auto !important;
  }

  #best-missions-container #mission-toggle-btn {
    left: -80px !important;
    right: auto !important;
  }
}

.component-row {
  padding: 12px 16px !important;
  gap: 15px !important;
}

.name-wrapper {
  gap: 12px !important;
}

.name-column .component-name {
  font-size: 0.95em !important;
  font-weight: 700 !important;
  color: #fff !important;
  white-space: normal !important;
  overflow: visible !important;
}

.price-badge,
.price-badge-small {
  min-width: 65px !important;
  text-align: right !important;
  padding-right: 12px !important;
}

.header-main .set-title {
  font-size: 1rem !important;
  letter-spacing: 0.5px !important;
}

/* Responsive Grid Adjustments */
@media (max-width: 480px) {
  #inventory-container {
    width: 320px !important;
    max-width: 95vw !important;
  }

  /* Mobile Two-Row Set Header: Title on Top, Components Below */
  .inv-set-header {
    display: grid !important;
    grid-template-columns: auto auto auto auto 1fr auto !important;
    grid-template-areas:
      "title title title title title title"
      "controls icon tracker market . info" !important;
    align-items: center;
    gap: 8px 10px !important;
    padding: 10px 12px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .inv-set-header .header-main {
    display: contents !important;
  }

  .inv-set-header .set-title {
    grid-area: title;
    width: 100% !important;
    text-align: center !important;
    font-size: 0.95rem !important;
    white-space: normal !important;
    word-break: break-word !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding-bottom: 6px;
    margin-bottom: 2px;
  }

  .inv-set-header .header-controls {
    grid-area: controls;
  }

  .inv-set-header .item-icon-small {
    grid-area: icon;
    margin: 0 !important;
  }

  .inv-set-header .tracker-link-icon {
    grid-area: tracker;
  }

  .inv-set-header .market-link-icon {
    grid-area: market;
  }

  .inv-set-header .header-info {
    grid-area: info;
    align-items: flex-end;
  }

  /* Retain grid only for inventory mini-rows */
  .inv-row-mini {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 8px !important;
    padding: 10px !important;
  }

  .row-main {
    grid-column: 1 / -1;
  }


  .item-icon-small {
    width: 36px !important;
    height: 36px !important;
  }

  .item-icon-mini {
    width: 32px !important;
    height: 32px !important;
  }

  .set-title,
  .part-name {
    font-size: 0.8rem !important;
  }
}

/* Ajuste Móvil */
@media (max-width: 480px) {

  .component-row {
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px;
  }

  .component-info {
    width: 100% !important;
    flex: none !important;
    margin-bottom: 6px !important;
  }

  .actions-col-wrapper {
    flex: 1 !important;
    justify-content: flex-start !important;
    margin-right: auto !important;
  }

  .component-row>div:last-child {
    /* The Ducats & Price div */
    flex: 1 !important;
    justify-content: flex-end !important;
  }

  .bounty-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .bounty-rewards-btn {
    width: 100%;
    text-align: center;
    padding: 8px;
  }

  .faction-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
  }
}

.bounty-wrapper {
  background-color: #16191d;
  border: 1px solid #333;
  border-radius: 6px;
  overflow: hidden;
  transition: all 0.2s;
  position: relative;
  margin-bottom: 8px;
}

.bounty-wrapper:hover {
  border-color: var(--active-theme-color);
  background-color: #1c2026;
}

.bounty-wrapper.is-sp {
  border-color: #722 #722 #722 #f44;
  background: linear-gradient(90deg, rgba(50, 0, 0, 0.3) 0, transparent 100%);
}

.bounty-wrapper.is-sp:hover {
  border-color: #f44;
}

/* Cabecera de la tarjeta */
.bounty-header-row {
  padding: 12px 15px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
  background: linear-gradient(90deg,
      rgba(255, 255, 255, 0.02) 0%,
      transparent 100%);
}

.bounty-drops-drawer {
  max-height: 0;
  overflow: hidden;
  background: #0f1113;
  transition: max-height 0.3s ease-out;
  border-top: 1px solid transparent;
}

.bounty-drops-drawer.open {
  max-height: 60vh;
  overflow-y: auto;
  border-top-color: #333;
  scrollbar-width: thin;
  scrollbar-color: var(--active-theme-color) #0f1113;
}

.drop-list {
  list-style: none;
  padding: 10px;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.drop-item {
  font-size: 0.75em;
  color: #aaa;
  background: #1a1c20;
  padding: 3px 6px;
  border-radius: 3px;
  border: 1px solid #333;
}

.drop-item.highlight {
  color: var(--wf-gold-text);
  border-color: rgba(197, 168, 86, 0.3);
  background: rgba(197, 168, 86, 0.05);
  font-weight: 700;
}

/* Ajustes de texto */
.condition-text {
  font-size: 0.75em;
  color: #888;
  margin-top: 3px;
  font-style: italic;
  display: block;
  max-width: 300px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Estilos para Tablas de Drops Detalladas */
.stage-container {
  border-bottom: 1px solid #222;
  margin-bottom: 0;
}

.stage-header {
  background: #15171a;
  color: #666;
  font-size: 0.7rem;
  font-weight: 800;
  padding: 4px 12px;
  letter-spacing: 1px;
  border-top: 1px solid #222;
}

.stage-content {
  padding: 4px 12px;
}

.drop-row {
  display: flex;
  justify-content: space-between;
  padding: 3px 0;
  font-size: 0.85rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.drop-row:last-child {
  border-bottom: none;
}

.drop-name {
  color: #bbb;
  flex-grow: 1;
  padding-right: 10px;
}

.drop-name.aya {
  color: var(--wf-aya);
  text-shadow: 0 0 5px rgba(165, 69, 224, 0.3);
}

.drop-name.relic {
  color: #fff;
  font-weight: 500;
}

.drop-name.endo {
  color: var(--wf-gold-text);
}

.drop-name.mod {
  color: #aaa;
}

/* Instrucciones del Live Scanner */
.scanner-guide-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 10;
}

.scan-area-bracket {
  width: 80%;
  height: 20%;
  border: 2px dashed rgba(0, 229, 255, 0.5);
  border-radius: 8px;
  position: relative;
  margin-bottom: 20px;
}

.scanner-instructions-box {
  background: rgba(15, 17, 21, 0.8);
  border: 1px solid #444;
  border-left: 3px solid var(--wf-blue);
  padding: 10px 15px;
  border-radius: 4px;
  width: 85%;
  max-width: 400px;
  backdrop-filter: blur(4px);
}

.scanner-instructions-box p {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.4;
  color: #ddd;
}

.scanner-instructions-box strong {
  color: var(--wf-blue);
  text-transform: uppercase;
}



/* Item Icons */
.plat-icon-inline {
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url('assets/relic_contents/platinum.webp') no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}

.ducat-icon-inline {
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url('assets/Ducats.webp') no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}

.item-icon-mini {
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5));
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.2);
  display: block;
}

.item-icon-small {
  width: 32px;
  height: 32px;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 5px rgba(0, 0, 0, 0.6));
  border-radius: 6px;
  background: rgba(0, 0, 0, 0.3);
  display: block;
}

.component-name {
  white-space: normal !important;
  word-break: normal !important;
  line-height: 1.2;
}

.component-row {
  min-height: 48px;
}

.component-info {
  display: flex !important;
  align-items: center !important;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.name-wrapper {
  display: flex !important;
  align-items: center !important;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

.item-icon-mini:hover,
.item-icon-small:hover {
  transform: scale(1.1);
  filter: drop-shadow(0 0 8px var(--wf-blue));
  z-index: 10;
}

.item-icon-mini,
.item-icon-small {
  transition: transform 0.2s ease, filter 0.2s ease;
}

.inv-row-mini {
  display: grid !important;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 8px;
  padding: 3px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(0, 0, 0, 0.2);
  width: 100%;
  box-sizing: border-box;
}

.row-main {
  display: flex !important;
  align-items: center !important;
  gap: 10px;
  min-width: 100px;
  /* Reduced from 130px */
  flex: 1;
  cursor: pointer;
}

.name-column {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.row-info {
  display: flex;
  align-items: center;
  gap: 6px;
  /* Reduced from 10px */
}

.part-name {
  font-size: 0.85em;
  color: #eee;
  font-weight: 600;
  text-transform: uppercase;
  white-space: normal;
  line-height: 1.2;
  word-break: normal;
  /* Fixed from break-word */
  min-width: 100px;
  /* Healthy minimum width */
  flex: 1;
}

.inv-qty-controls-mini {
  display: flex;
  align-items: center;
  gap: 4px;
  /* Reduced from 8px */
  padding: 0 4px;
  box-sizing: border-box;
}

.inv-btn-small {
  background: transparent;
  border: 1px solid #444;
  color: #888;
  width: 20px;
  /* Reduced from 22px */
  height: 20px;
  cursor: pointer;
  border-radius: 3px;
  font-size: 12px;
  /* Reduced from 14px */
  display: flex;
  align-items: center;
  justify-content: center;
}

.inv-btn-small:hover {
  background: var(--wf-blue);
  color: #000;
  border-color: var(--wf-blue);
}

.qty-num {
  font-family: monospace;
  font-weight: bold;
  color: var(--wf-blue);
  min-width: 14px;
  /* Reduced from 25px */
  text-align: center;
  font-size: 0.9em;
}

.inv-set-header {
  cursor: pointer;
  user-select: none;
}

.inv-set-header .toggle-icon {
  display: inline-block;
  transition: transform 0.2s;
  font-size: 0.8em;
  color: var(--wf-gold-text);
}

.inv-set-group.collapsed .toggle-icon {
  transform: rotate(-90deg);
}

.inv-set-group.collapsed .inv-set-content {
  display: none;
}

.delete-set-btn {
  background: rgba(255, 68, 68, 0.1);
  border: 1px solid rgba(255, 68, 68, 0.4);
  color: #ff4444;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  cursor: pointer;
  pointer-events: auto !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  padding: 0;
  transition: all 0.2s;
  justify-self: center;
}

.delete-set-btn:hover {
  background: #ff4444;
  color: #fff;
  box-shadow: 0 0 10px rgba(255, 68, 68, 0.4);
}

/* Inventory Clickable & Navigation Styles */
.clickable-set-name {
  cursor: pointer;
  transition: color 0.2s;
  border-bottom: 1px dotted transparent;
}

.clickable-set-name:hover {
  color: var(--wf-blue);
}

.clickable-part-name {
  cursor: pointer;
  transition: color 0.2s;
}

.clickable-part-name:hover {
  color: var(--wf-blue);
  text-decoration: underline;
}

.market-link-icon {
  color: var(--wf-gold-text);
  text-decoration: none;
  font-size: 0.9em;
  opacity: 0.7;
  transition: opacity 0.2s;
  margin-left: 5px;
  display: inline-block;
}

.market-link-icon:hover {
  opacity: 1;
}

.market-link-icon-mini {
  color: #666;
  text-decoration: none;
  font-size: 0.8em;
  opacity: 0.5;
  transition: all 0.2s;
  margin-left: 4px;
  display: inline-block;
}

.market-link-icon-mini:hover {
  color: var(--wf-gold-text);
  opacity: 1;
}

.inv-row-mini .part-container {
  display: flex;
  align-items: center;
  flex: 1;
  overflow: hidden;
}

/* Tracker Dots wfor Sets */
.tracker-dots {
  display: flex;
  gap: 4px;
  align-items: center;
  margin-left: 10px;
}

.tracker-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  border: 1px solid #444;
  background: transparent;
  transition: all 0.3s ease;
  flex-shrink: 0;
}

.tracker-dot.filled {
  background: var(--wf-blue);
  border-color: var(--wf-blue);
  box-shadow: 0 0 5px var(--wf-blue);
}

.tracker-dots.complete .tracker-dot.filled {
  background: #4ef56c !important;
  border-color: #4ef56c !important;
  box-shadow: 0 0 8px rgba(78, 245, 108, 0.6) !important;
}

.progress-tooltip-wrapper {
  position: relative;
  display: inline-block;
  cursor: help;
}

.progress-tooltip-content {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 5px;
  z-index: 1000;
  transition: opacity 0.2s, visibility 0.2s;
  pointer-events: none;
}

.progress-tooltip-wrapper:hover .progress-tooltip-content {
  visibility: visible;
  opacity: 1;
}

#set-tracker {
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

#set-tracker.drag-hover {
  border-color: var(--wf-gold-text) !important;
  box-shadow: 0 0 15px rgba(221, 169, 56, 0.4) !important;
  background: rgba(221, 169, 56, 0.1) !important;
}

/* TOP Relics Farm Styles */
.inv-row.top-farm {
  border-left: 3px solid #ffcc00 !important;
  background: rgba(255, 204, 0, 0.05) !important;
}

.top-badge {
  color: #ffcc00;
  font-weight: 900;
  font-size: 0.85em;
  margin-right: 5px;
  text-shadow: 0 0 5px rgba(255, 204, 0, 0.3);
}

.ev-rad-hint {
  display: block;
  font-size: 0.75em;
  color: #888;
  margin-top: 2px;
  font-style: italic;
}

.inv-ev-display {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.ev-val {
  color: #42f56c;
  font-size: 1.1em;
  font-weight: 900;
}

.component-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 10px 12px !important;
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  gap: 12px;
  transition: background 0.2s;
}

.component-row:hover {
  background: rgba(255, 255, 255, 0.05);
}

.component-header {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0;
  flex: 1;
}

.component-info {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.name-wrapper {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1;
}

.name-column {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1;
  gap: 4px;
}

.component-name {
  font-weight: 700;
  color: #fff;
  white-space: normal;
  overflow: visible;
  line-height: 1.2;
}

.required-count {
  color: var(--wf-gold-text);
  font-size: 0.9em;
  font-weight: 900;
  margin-left: 5px;
  opacity: 0.9;
}

.rarity-indicator {
  min-width: 25px;
  text-align: center;
  font-weight: 900;
  font-size: 0.8em;
  opacity: 0.7;
}

.item-icon-mini {
  width: 24px;
  height: 24px;
  object-fit: contain;
}


/* =========================================
   DYNAMIC GAP & ICON SIZE ADJUSTMENTS
   ========================================= */
.item-icon-mini,
.item-icon-small {
  width: 40px !important;
  height: 40px !important;
  margin-right: 16px !important;
  margin-left: 12px !important;
  object-fit: contain;
  transition: transform 0.25s ease-out !important;
  position: relative;
  z-index: 5;
}

.item-icon-mini:hover,
.item-icon-small:hover {
  transform: scale(1.5) !important;
  z-index: 100;
}

.item-icon-set-header {
  width: 100px !important;
  height: 100px !important;
  min-width: 100px !important;
  min-height: 100px !important;
  margin-right: 20px !important;
  object-fit: contain;
  flex-shrink: 0;
  filter: drop-shadow(0 0 15px rgba(212, 175, 55, 0.4));
  transition: transform 0.3s ease;
}

.item-icon-set-header:hover {
  transform: scale(1.1);
}

.component-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100%;
  gap: 12px;
}

.name-col-wrapper {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
}

.name-row-content {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
}

.actions-col-wrapper {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;
}

@media (max-width: 500px) {

  .name-row-content,
  .component-header {
    flex-wrap: wrap !important;
  }

  .actions-col-wrapper {
    width: 100% !important;
    justify-content: flex-end;
    padding-top: 8px;
  }
}

.component-name {
  cursor: pointer;
  white-space: normal !important;
  overflow: visible !important;
  position: relative;
  word-break: break-word;
}

.component-name:hover {
  text-decoration: underline;
  color: #fff;
}

.market-btn-mini {
  background: rgba(0, 229, 255, 0.1);
  border: 1px solid var(--wf-blue);
  color: var(--wf-blue);
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: bold;
  letter-spacing: 0.5px;
  flex-shrink: 0 !important;
  transition: all 0.2s;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.market-btn-mini:hover {
  background: var(--wf-blue);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

.ducat-val {
  min-width: 45px;
  text-align: right;
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

.mini-action-btn {
  align-self: center !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  flex-shrink: 0 !important;
}

#mode-riven {
  background: rgba(162, 53, 226, 0.05);
  border-radius: 8px;
  padding: 15px;
  border: 1px solid rgba(162, 53, 226, 0.2);
}

.riven-input:focus {
  border-color: var(--wf-riven) !important;
  box-shadow: 0 0 10px rgba(162, 53, 226, 0.5) !important;
}

.riven-avg-val {
  color: var(--wf-riven) !important;
  text-shadow: 0 0 10px rgba(162, 53, 226, 0.3);
}

.riven-stat-select option[value=""] {
  color: rgba(255, 255, 255, 0.3);
  font-style: italic;
}

.riven-stats-grid .form-group select {
  border-color: rgba(162, 53, 226, 0.3);
  background-color: rgba(10, 11, 13, 0.8);
}

.riven-stats-grid .form-group select:focus {
  border-color: var(--wf-riven);
}

.inv-price-tag {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  margin-right: 10px;
  min-width: 60px;
}

.inv-price-tag .price-val {
  font-weight: bold;
  color: var(--wf-gold-text);
}

.inv-price-tag .qty-label {
  font-size: 0.8em;
  color: #aaa;
}

/* Riven Preview Styles */
.riven-weapon-preview {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  transition: transform 0.2s;
  cursor: help;
  padding-bottom: 20px;
}

.riven-weapon-img {
  width: 120px;
  height: auto;
  object-fit: contain;
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.2s ease;
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.5));
  opacity: 1;
}

.riven-weapon-img.loading {
  opacity: 0;
}

.riven-weapon-preview:hover .riven-weapon-img {
  transform: scale(1.2) translateY(-10px);
  z-index: 100;
}

.riven-disposition-row {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 8px;
  background: rgba(0, 0, 0, 0.3);
  padding: 4px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.dispo-circle {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #333;
  border: 1px solid #555;
  transition: all 0.3s ease;
}

/* Base Filled Circle - HIGH CONTRAST */
.dispo-circle.filled {
  background: #bd8aff;
  border-color: #fff;
  box-shadow: 0 0 8px var(--wf-purple);
  transition: all 0.3s ease;
}

/* Base Empty Circle */
.dispo-circle:not(.filled) {
  background: #1a1a1a;
  border-color: #444;
  box-shadow: inset 0 0 2px #000;
}

/* Dynamic Brightness Levels */
.dispo-level-1 .dispo-circle.filled {
  opacity: 0.8;
  box-shadow: 0 0 4px var(--wf-purple);
}

.dispo-level-2 .dispo-circle.filled {
  background: #bd8aff;
  box-shadow: 0 0 8px var(--wf-purple);
}

.dispo-level-3 .dispo-circle.filled {
  background: #dcb3ff;
  box-shadow: 0 0 12px var(--wf-purple), 0 0 2px #fff;
}

.dispo-level-4 .dispo-circle.filled {
  background: #fff;
  box-shadow: 0 0 15px var(--wf-purple), 0 0 5px #dcb3ff;
}

.dispo-level-5 .dispo-circle.filled {
  background: #fff;
  border-color: #fff;
  box-shadow: 0 0 20px var(--wf-purple), 0 0 10px #fff, 0 0 30px rgba(189, 138, 255, 0.8);
  animation: pulseDispoHigh 1.5s infinite alternate;
}

@keyframes pulseDispoHigh {
  from {
    transform: scale(1);
    box-shadow: 0 0 20px var(--wf-purple), 0 0 10px #fff;
  }

  to {
    transform: scale(1.2);
    box-shadow: 0 0 30px var(--wf-purple), 0 0 15px #fff;
  }
}

.dispo-text {
  font-size: 0.85em;
  color: #ddd;
  font-weight: bold;
  margin-left: 6px;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.8);
}


.preview-tooltip {
  position: absolute;
  top: 0;
  right: 120%;
  left: auto;
  transform: translateY(0);
  width: 300px;
  background: rgba(18, 18, 26, 0.98);
  border: 1px solid var(--wf-purple);
  border-radius: 8px;
  padding: 12px;
  z-index: 1000;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.9);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
  backdrop-filter: blur(10px);
}

.riven-weapon-preview:hover .preview-tooltip,
.riven-weapon-preview.mobile-active .preview-tooltip {
  opacity: 1;
  pointer-events: auto;
}

/* Tooltip arrow/bridge */
.preview-tooltip::after {
  content: "";
  position: absolute;
  top: 20px;
  right: -20px;
  width: 20px;
  height: 60px;
  background: transparent;
}

/* Wiki Link Styling */
.wiki-link {
  color: var(--wf-blue);
  text-decoration: none;
  border-bottom: 1px dotted var(--wf-blue);
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.wiki-link:hover {
  filter: brightness(1.2);
  border-bottom-style: solid;
}

.wiki-link::after {
  content: "↗";
  font-size: 0.8em;
  opacity: 0.7;
}

.preview-tooltip h4 a {
  color: var(--wf-purple);
  border-color: var(--wf-purple);
}

.preview-tooltip h4 {
  margin: 0 0 10px 0;
  color: var(--wf-purple);
  font-size: 1.1em;
  border-bottom: 1px solid rgba(138, 43, 226, 0.3);
  padding-bottom: 6px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.tooltip-section {
  margin-bottom: 12px;
}

.tooltip-section-title {
  font-size: 0.75em;
  color: #aaa;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 6px;
  display: block;
  border-left: 3px solid var(--wf-purple);
  padding-left: 6px;
}

.tooltip-drop-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.85em;
  padding: 3px 0;
  border-bottom: 1px dashed #333;
}

.tooltip-drop-row:last-child {
  border-bottom: none;
}

.t-chance-high {
  color: var(--wf-gold-text);
  font-weight: bold;
}

.t-chance-med {
  color: var(--wf-blue);
}

.t-chance-low {
  color: #888;
}

.relic-link {
  color: var(--wf-lfg);
  text-decoration: none;
  cursor: pointer;
  border-bottom: 1px dotted var(--wf-lfg);
  transition: color 0.2s, border-color 0.2s;
}

.relic-link:hover {
  color: #fff;
  border-bottom: 1px solid #fff;
  background: rgba(255, 255, 255, 0.1);
}

.plat-icon {
  width: 1.2em;
  height: 1.2em;
  vertical-align: middle;
  margin-left: 2px;
  display: inline-block;
  background-image: url('assets/relic_contents/platinum.webp');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.ducat-icon {
  width: 2.2em;
  height: 1.2em;
  vertical-align: middle;
  margin-left: 2px;
  display: inline-block;
}

.relic-era-icon {
  width: 24px;
  height: 24px;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  filter: drop-shadow(0 0 2px rgba(255, 255, 255, 0.2));
  vertical-align: middle;
}

.relic-era-icon.lith {
  background-image: url('https://wiki.warframe.com/images/LithRelicIntact.png?ee7d7');
}

.relic-era-icon.meso {
  background-image: url('https://wiki.warframe.com/images/MesoRelicIntact.png?a9b4a');
}

.relic-era-icon.neo {
  background-image: url('https://wiki.warframe.com/images/NeoRelicIntact.png?6dc86');
}

.relic-era-icon.axi {
  background-image: url('https://wiki.warframe.com/images/AxiRelicIntact.png?6cadf');
}

.relic-era-icon.requiem {
  background-image: url('https://wiki.warframe.com/images/RequiemRelicIntact.png?03821');
}


.tooltip-res-img {
  width: 16px;
  height: 16px;
  vertical-align: middle;
  margin-right: 5px;
}

@media (max-width: 768px) {
  .riven-columns-container {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .riven-right-col {
    width: 100% !important;
    order: -1;
    margin-bottom: 15px;
    padding-top: 0 !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 10px;
    align-items: center !important;
  }

  .riven-weapon-preview {
    width: 100%;
    padding-bottom: 10px;
  }

  .preview-tooltip {
    position: absolute;
    top: 100%;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: 300px;
    max-width: 90vw;
    margin-top: 10px;
  }

  .preview-tooltip::after {
    top: -20px;
    left: 0;
    right: 0;
    width: 100%;
    height: 20px;
  }

  .riven-weapon-preview:hover .riven-weapon-img {
    transform: scale(1.1);
  }
}

/* RIVEN VARIANTS CAROUSEL */
.variants-carousel-scroll {
  display: flex;
  overflow-x: auto;
  gap: 15px;
  padding: 15px 10px;
  justify-content: flex-start;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--wf-blue) transparent;
  min-height: 140px;
  align-items: center;
  mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
}

.variants-carousel-scroll::-webkit-scrollbar {
  height: 4px;
}

.variants-carousel-scroll::-webkit-scrollbar-thumb {
  background: var(--wf-blue);
  border-radius: 2px;
}

.variant-card {
  flex: 0 0 auto;
  width: 140px;
  /* Increased from 110px */
  text-align: center;
  cursor: pointer;
  background: rgba(30, 30, 35, 0.6);
  border: 1px solid #3d3d42;
  border-radius: 8px;
  padding: 12px;
  /* Increased from 10px */
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow: visible;
}

.variant-card:hover {
  background: rgba(50, 50, 60, 0.8);
  border-color: var(--wf-blue);
  transform: translateY(-5px);
  z-index: 10;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.4);
}

.variant-card img {
  width: 100px;
  /* Increased from 80px */
  height: 60px;
  /* Increased from 50px */
  object-fit: contain;
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.5));
}

.variant-card:hover img {
  transform: scale(1.3);
  /* Adjusted from 1.4 */
}

.variant-card.active {
  border-color: var(--active-theme-color, var(--wf-blue));
  background: rgba(0, 229, 255, 0.1);
  box-shadow: inset 0 0 10px rgba(0, 229, 255, 0.2);
}

.v-name-small {
  font-size: 0.85em;
  /* Increased from 0.7em */
  font-weight: 900;
  /* Increased font-weight */
  color: #fff;
  margin-top: 10px;
  /* Increased margin */
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.v-dispo-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin-top: 6px;
}

.v-dispo-dots {
  display: flex;
  gap: 3px;
  /* Increased from 2px */
}

.v-dispo-dot {
  width: 8px;
  /* Increased from 5px */
  height: 8px;
  /* Increased from 5px */
  border-radius: 50%;
  background: #333;
  border: 1px solid #444;
}

.v-dispo-dot.filled {
  background: var(--wf-blue);
  border-color: #00e5ff;
  box-shadow: 0 0 5px rgba(0, 229, 255, 0.4);
}

/* Variant Set Shortcut */
.variant-set-shortcut {
  position: absolute;
  top: 5px;
  right: 5px;
  background: rgba(0, 0, 0, 0.6);
  color: var(--wf-gold-text);
  font-size: 0.65rem;
  font-weight: 800;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid rgba(199, 158, 66, 0.3);
  cursor: pointer;
  transition: all 0.2s ease;
  z-index: 5;
  opacity: 0.8;
}

.variant-set-shortcut:hover {
  background: var(--wf-purple);
  color: white;
  opacity: 1;
  transform: scale(1.1);
  border-color: var(--wf-purple);
}

.item-interactive {
  cursor: pointer;
  transition: color 0.2s ease;
}

.item-interactive:hover {
  color: var(--wf-blue) !important;
  text-decoration: underline;
}

.v-dispo-val {
  font-size: 0.85em;
  /* Increased from 0.65em */
  color: #fff;
  /* Changed from #888 to #fff for better visibility */
  font-weight: 900;
  /* Increased font-weight */
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.8);
}

@media (max-width: 768px) {
  .variants-carousel-scroll {
    gap: 10px;
    padding: 10px 5px;
    min-height: 120px;
    mask-image: none;
  }

  .variant-card {
    width: 120px;
    /* Increased from 90px */
    padding: 10px;
    /* Increased from 8px */
  }

  .variant-card img {
    width: 90px;
    /* Increased from 65px */
    height: 55px;
    /* Increased from 40px */
  }

  .variant-card:hover {
    transform: none;
    box-shadow: none;
  }

  .variant-card:hover img {
    transform: scale(1.1);
  }

  .v-name-small {
    font-size: 0.65em;
  }
}

/* NEW RIVEN LAYOUT UTILITIES */
.riven-columns-container {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
}

.riven-left-col {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
}

.riven-right-col {
  width: 150px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 10px;
  flex-shrink: 0;
  min-width: 0;
}

/* Fix for large images stretching the container */
.riven-weapon-img {
  max-width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 768px) {
  .riven-columns-container {
    flex-direction: column !important;
    gap: 15px !important;
  }

  .riven-right-col {
    width: 100% !important;
    padding-top: 0 !important;
  }

}

/* =========================================
   RELICTRACK POPUP (LIVE SCANNER)
   ========================================= */
.track-popup-anim {
  position: fixed;
  bottom: 80px;
  right: 20px;
  z-index: 10000;
  animation: slideInTrack 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
  pointer-events: auto;
}

.track-popup-anim.fade-out {
  animation: slideOutTrack 0.5s forwards ease-in;
}

.track-popup-content {
  background: rgba(15, 17, 21, 0.95);
  backdrop-filter: blur(10px);
  border: 1px solid var(--wf-blue);
  border-left: 4px solid var(--wf-blue);
  border-radius: 8px;
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 15px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6), 0 0 15px rgba(0, 229, 255, 0.2);
  min-width: 280px;
}

.relic-icon-mini {
  width: 32px;
  height: 32px;
  background: var(--wf-blue);
  color: #000;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 1.2em;
  box-shadow: 0 0 10px var(--wf-blue);
}

.track-text {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.track-title {
  color: #aaa;
  font-size: 0.75em;
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: 1px;
}

.track-name {
  color: #fff;
  font-size: 1.1em;
  font-weight: 800;
  text-shadow: 0 0 5px rgba(255, 255, 255, 0.3);
}

@keyframes priceLoadingBlink {
  0% {
    opacity: 0.4;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0.4;
  }
}

.price-loading-blink {
  animation: priceLoadingBlink 1.2s infinite ease-in-out;
  color: #888 !important;
}

.set-price-marker {
  font-family: MONOSPACE, sans-serif;
  font-size: 0.85em;
  font-weight: bold;
  color: var(--wf-gold-text);
  white-space: nowrap;
}