/* =========================================================
   Omni-Dex Styles - Scoped to body.omni-dex
   Uses CSS custom properties for theming.
   ========================================================= */

body.omni-dex {
  --omni-dex-accent: #4392F1;
  --omni-dex-accent-secondary: #F46036;
  --omni-dex-card-bg: #ffffff;
  --omni-dex-card-border: var(--omni-dex-accent);
  --omni-dex-card-shadow: 0 2px 8px rgba(0,0,0,0.1);
  --omni-dex-text: #333333;
  --omni-dex-text-light: #888888;
  --omni-dex-stat-bg: #e0e0e0;
  --omni-dex-stat-fill: var(--omni-dex-accent);
  --omni-dex-tab-bg: #f0f0f0;
  --omni-dex-tab-active-bg: var(--omni-dex-accent);
  --omni-dex-tab-active-text: #ffffff;

  /* -- Modal variables - Pinnacle defaults -- */
  --modal-overlay: rgba(67, 146, 241, 0.7);
  --modal-bg: #ffffff;
  --modal-border: #000000;
  --modal-shadow: 8px 8px 0 var(--omni-dex-accent);
  --modal-titlebar-accent: #F46036;
  --modal-text: #333333;
  --modal-btn-stats-bg: #4392F1;
  --modal-btn-close-bg: #F46036;
  --modal-btn-next-bg: #4392F1;
  --modal-sidebar-bg: #ffffff;
  --modal-sidebar-accent-shadow: #F46036;
  --modal-tooltip-shadow: #F46036;
  --modal-stat-fill: var(--omni-dex-accent);
}

/* Exploded theme override (applied via JS) */
body.omni-dex[data-universe="exploded"] {
  --omni-dex-accent: #D4A017;
  --omni-dex-accent-secondary: #8B0000;
  --omni-dex-card-bg: #2a2a2a;
  --omni-dex-card-border: #D4A017;
  --omni-dex-card-shadow: 0 2px 8px rgba(212,160,23,0.3);
  --omni-dex-text: #f0f0f0;
  --omni-dex-text-light: #aaaaaa;
  --omni-dex-stat-bg: #444444;
  --omni-dex-stat-fill: #D4A017;
  --omni-dex-tab-bg: #333333;
  --omni-dex-tab-active-bg: #D4A017;
  --omni-dex-tab-active-text: #1a1a1a;

  /* -- Modal variables - Exploded palette -- */
  --modal-overlay: rgba(139, 0, 0, 0.7);
  --modal-bg: #2a1b0e;
  --modal-border: #1a1a1a;
  --modal-shadow: 8px 8px 0 #8B0000;
  --modal-titlebar-accent: #D4A017;
  --modal-text: #f0e6d0;
  --modal-btn-stats-bg: #8B0000;
  --modal-btn-close-bg: #8B0000;
  --modal-btn-next-bg: #D4A017;
  --modal-sidebar-bg: #2a1b0e;
  --modal-sidebar-accent-shadow: #8B0000;
  --modal-tooltip-shadow: #8B0000;
  --modal-stat-fill: #D4A017;
}

/* When modal is active, blur the page content behind the overlay */
body.omni-dex.modal-active .omni-tabs,
body.omni-dex.modal-active .omni-type-filters,
body.omni-dex.modal-active .omni-card-grid,
body.omni-dex.modal-active .omni-status {
  filter: blur(6px);
  -webkit-filter: blur(6px);
  pointer-events: none;
  transition: filter 0.3s;
}

/* Tabs (Universe Cartridges) */
.omni-tabs {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin: 1.5rem 0 1rem;
}
.omni-tab {
  padding: 0.6rem 1.5rem;
  font-family: 'Anton', sans-serif;
  font-size: 1.1rem;
  text-transform: uppercase;
  border: 2px solid var(--omni-dex-accent);
  background: var(--omni-dex-tab-bg);
  color: var(--omni-dex-text);
  cursor: pointer;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.omni-tab:hover {
  background: var(--omni-dex-accent);
  color: var(--omni-dex-tab-active-text);
}
.omni-tab.active {
  background: var(--omni-dex-tab-active-bg);
  color: var(--omni-dex-tab-active-text);
  border-color: var(--omni-dex-tab-active-bg);
}

/* Type Filter Pills */
.omni-type-filters {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.5rem 0 2rem;
}
.type-pill {
  padding: 0.4rem 1rem;
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  text-transform: uppercase;
  border: 1px solid var(--omni-dex-text-light);
  color: var(--omni-dex-text-light);
  cursor: pointer;
  border-radius: 20px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.type-pill:hover {
  border-color: var(--omni-dex-accent);
  color: var(--omni-dex-accent);
}
.type-pill.active {
  background: var(--omni-dex-accent);
  color: #ffffff;
  border-color: var(--omni-dex-accent);
}

/* Card Grid */
.omni-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
  padding: 0 0 2rem;
}

/* Individual Card */
.omni-card {
  background: var(--omni-dex-card-bg);
  border: 2px solid var(--omni-dex-card-border);
  border-radius: 8px;
  box-shadow: var(--omni-dex-card-shadow);
  padding: 1.2rem;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
}
.omni-card:hover {
  transform: scale(1.03);
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}

.omni-card-title {
  font-family: 'Anton', sans-serif;
  font-size: 1.5rem;
  margin: 0 0 0.3rem;
  color: var(--omni-dex-accent);
}
.omni-card-type {
  font-family: 'Courier New', monospace;
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--omni-dex-text-light);
  margin-bottom: 0.5rem;
}
.omni-card-desc {
  font-family: 'Open Sans', sans-serif;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--omni-dex-text);
  flex: 1;
}

/* Stat Bars */
.omni-card-stats {
  margin-top: 1rem;
}
.omni-stat {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.4rem;
  font-size: 0.8rem;
  font-family: 'Courier New', monospace;
  color: var(--omni-dex-text-light);
}
.omni-stat-label {
  width: 120px;
  flex-shrink: 0;
  text-transform: uppercase;
  overflow-wrap: break-word;
  word-break: break-word;
}
.omni-stat-bar {
  flex: 1;
  height: 10px;
  background: var(--omni-dex-stat-bg);
  border-radius: 5px;
  overflow: hidden;
}
.omni-stat-fill {
  height: 100%;
  border-radius: 5px;
  background: var(--omni-dex-stat-fill);
  width: 0%;
  transition: width 0.6s ease-out;
}
.omni-stat-value {
  width: 30px;
  text-align: right;
  font-weight: bold;
}

/* Per-card universe theming (used when mixing universes on "All" tab) */
.omni-card.card-exploded {
  --omni-dex-accent: #D4A017;
  --omni-dex-accent-secondary: #8B0000;
  --omni-dex-card-bg: #2a2a2a;
  --omni-dex-card-border: #D4A017;
  --omni-dex-card-shadow: 0 2px 8px rgba(212,160,23,0.3);
  --omni-dex-text: #f0f0f0;
  --omni-dex-text-light: #aaaaaa;
  --omni-dex-stat-bg: #444444;
  --omni-dex-stat-fill: #D4A017;
}
.omni-card.card-pinnacle {
  --omni-dex-accent: #4392F1;
  --omni-dex-accent-secondary: #F46036;
  --omni-dex-card-bg: #ffffff;
  --omni-dex-card-border: #4392F1;
  --omni-dex-card-shadow: 0 2px 8px rgba(0,0,0,0.1);
  --omni-dex-text: #333333;
  --omni-dex-text-light: #888888;
  --omni-dex-stat-bg: #e0e0e0;
  --omni-dex-stat-fill: #4392F1;
}

/* =========================================================
   Omni-Dex Modal - Nintendo KnowFlux Style (fully themable)
   ========================================================= */

/* Full-screen overlay - uses variable for colour & opacity */
.omni-modal {
  position: fixed;
  top: 0; left: 0; width: 100%; height: 100%;
  background: var(--modal-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.omni-modal.visible {
  opacity: 1;
  pointer-events: auto;
}

/* Per-universe overlay colours (data-universe set by JS on the modal) */
.omni-modal[data-universe="exploded"] {
  --modal-overlay: rgba(139, 0, 0, 0.7);
}
.omni-modal[data-universe="pinnacle"] {
  --modal-overlay: rgba(67, 146, 241, 0.7);
}

/* Modal body - themable background, border, shadow */
.omni-modal-content {
  background: var(--modal-bg);
  border: 4px solid var(--modal-border);
  border-radius: 0;
  width: 90%;
  max-width: 560px;
  display: flex;
  flex-direction: column;
  padding: 20px 16px 16px;
  box-shadow: var(--modal-shadow);
  transform: scale(0.92);
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}


.omni-modal.visible .omni-modal-content {
  transform: scale(1);
}

/* Per-entry modal theming - overrides when an entry's modal opens */
.omni-modal[data-universe="exploded"] .omni-modal-content {
  --modal-bg: #2a1b0e;
  --modal-border: #1a1a1a;
  --modal-shadow: 8px 8px 0 #8B0000;
  --modal-titlebar-accent: #D4A017;
  --modal-text: #f0e6d0;
  --modal-btn-stats-bg: #8B0000;
  --modal-btn-close-bg: #8B0000;
  --modal-btn-next-bg: #D4A017;
  --modal-sidebar-bg: #2a1b0e;
  --modal-sidebar-accent-shadow: #8B0000;
  --modal-tooltip-shadow: #8B0000;
  --modal-stat-fill: #D4A017;
}



/* Screen area */
.omni-modal-screen {
  display: flex;
  flex-direction: column;
  height: 350px;
  min-height: 200px;
  max-height: 80vh;
  overflow: hidden;
}

.omni-modal-titlebar {
  border-bottom: 4px solid var(--modal-titlebar-accent);
  padding: 0 8px 8px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.omni-modal-title {
  font-family: 'Anton', cursive;
  font-weight: normal;
  font-size: 1.5rem;
  color: var(--modal-text);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Stats toggle button - chunky Nintendo-style */
.omni-modal-stats-btn {
  background: var(--modal-btn-stats-bg);
  color: #fff;
  border: 3px solid var(--modal-border);
  font-family: 'Anton', cursive;
  font-size: 0.9rem;
  padding: 6px 14px;
  box-shadow: 4px 4px 0 var(--modal-border);
  text-transform: uppercase;
  letter-spacing: 1px;
  cursor: pointer;
  transition: transform 0.1s, box-shadow 0.1s;
}
.omni-modal-stats-btn:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--modal-border);
}
.omni-modal-stats-btn:active {
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 var(--modal-border);
}

/* Body wrapper: holds content and sidebar */
.omni-modal-body-wrapper {
  display: flex;
  flex: 1;
  overflow: hidden;
  position: relative;
}

.omni-modal-body {
  padding: 12px 0;
  overflow-y: auto;
  color: var(--modal-text);
  font-family: 'Open Sans', sans-serif;
  line-height: 1.7;
  flex: 1;
  font-size: 0.95rem;
}
.omni-modal-body p {
  margin: 0 0 0.8rem;
}

/* Stats sidebar - themable */
.omni-modal-stats-sidebar {
  position: absolute;
  top: 0;
  right: -320px;
  width: 300px;
  height: 100%;
  background: var(--modal-sidebar-bg);
  border-left: 4px solid var(--modal-border);
  box-shadow: -4px 0 0 var(--modal-sidebar-accent-shadow);
  padding: 12px;
  padding-top: 30px;
  overflow-y: auto;
  transition: right 0.3s ease;
  box-sizing: border-box;
  z-index: 10;
}
.omni-modal-stats-sidebar.open {
  right: 0;
}
.omni-modal-body-wrapper.sidebar-open .omni-modal-body {
  margin-right: 0;
}

/* Stat items inside sidebar */
.omni-modal-stats-sidebar .omni-stat-label {
  color: var(--modal-text);
  cursor: pointer;
  width: 150px;
  overflow-wrap: break-word;
  word-break: break-word;
}
.omni-modal-stats-sidebar .omni-stat-value {
  color: var(--modal-text);
}
.omni-modal-stats-sidebar .omni-stat-bar {
  background: var(--omni-dex-stat-bg);
}
.omni-modal-stats-sidebar .omni-stat-fill {
  background: var(--modal-stat-fill);
}

/* Tooltip that appears when a stat is clicked */
.omni-stat-tooltip {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--modal-sidebar-bg);
  color: var(--modal-text);
  font-family: 'Open Sans', sans-serif;
  font-size: 0.75rem;
  padding: 4px 8px;
  border: 3px solid var(--modal-border);
  box-shadow: 4px 4px 0 var(--modal-tooltip-shadow);
  z-index: 20;
  pointer-events: auto;
  word-wrap: break-word;
  white-space: normal;
}

/* Make stat label position relative so tooltip can be positioned absolutely */
.omni-modal-stats-sidebar .omni-stat {
  position: relative;
}

/* Controls row */
.omni-modal-controls {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
  padding: 0;
}

/* Chunky square buttons */
.omni-modal-btn {
  padding: 10px 22px;
  font-family: 'Anton', cursive;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 3px solid var(--modal-border);
  border-radius: 0;
  cursor: pointer;
  transition: transform 0.1s, box-shadow 0.1s;
  box-shadow: 4px 4px 0 var(--modal-border);
}
.omni-modal-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--modal-border);
}
.omni-modal-btn-close {
  background: var(--modal-btn-close-bg);
  color: #fff;
}
.omni-modal-btn-close:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--modal-border);
}
.omni-modal-btn-next {
  background: var(--modal-btn-next-bg);
  color: #fff;
}
.omni-modal-btn-next:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--modal-border);
}

/* Status messages */
.omni-status {
  text-align: center;
  padding: 2rem;
  font-size: 1.1rem;
  color: var(--omni-dex-text-light);
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 768px) {
  .omni-tabs { flex-wrap: wrap; }
  .omni-modal-content { width: 95%; padding: 14px 10px; }
  .omni-modal-screen { min-height: 150px; height: 280px; max-height: 70vh; }
  .omni-modal-title { font-size: 1rem; }
  .omni-modal-stats-sidebar { width: 260px; right: -280px; }
  .omni-modal-stats-sidebar.open { right: 0; }
  .omni-modal-body-wrapper.sidebar-open .omni-modal-body { margin-right: 0; }
}
@media (max-width: 600px) {
  .omni-card-grid { grid-template-columns: 1fr; }
  .omni-stat-label { width: 140px; overflow-wrap: break-word; word-break: break-word; }
  .omni-modal-controls { flex-wrap: wrap; gap: 8px; justify-content: center; }
  .omni-modal-screen { min-height: 150px; height: 240px; max-height: 70vh; }
  .omni-modal-stats-sidebar { width: 200px; right: -220px; }
  .omni-modal-stats-sidebar.open { right: 0; }
  .omni-modal-body-wrapper.sidebar-open .omni-modal-body { margin-right: 0; }
}