/* ==========================================================================
   Arua ROSE Online Armory — Tabler / Bootstrap 5 Theme
   Loaded after tabler.min.css (1.2.0). Dark theme by default.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design Tokens
   -------------------------------------------------------------------------- */
:root {
  /* Brand */
  --tblr-primary:         #0096ff;   /* Arua blue */
  --tblr-primary-rgb:     0, 150, 255;
  --tblr-primary-darken:  #0078d4;
  --tblr-primary-lighten: #40b3ff;

  /* Font */
  --tblr-font-sans-serif: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* Page — dark game-database aesthetic */
  --tblr-body-bg:    #0f172a;
  --tblr-body-color: #c9d1d9;

  /* Card */
  --tblr-card-border-radius: 0.75rem;
  --tblr-card-cap-bg:        transparent;

  /* Border */
  --tblr-border-color: #1e293b;

  /* Custom armory tokens */
  --armory-navbar-bg:    #0a1020;
  --armory-navbar-border: rgba(255,255,255,0.06);
  --armory-card-bg:      #111827;
  --armory-card-hover-bg: #161f30;
  --armory-surface:      #1e293b;

  --armory-text-muted:   #64748b;
  --armory-text-dim:     #475569;

  --armory-shadow-sm:  0 1px 3px 0 rgba(0,0,0,0.3), 0 1px 2px -1px rgba(0,0,0,0.2);
  --armory-shadow-md:  0 4px 6px -1px rgba(0,0,0,0.3), 0 2px 4px -2px rgba(0,0,0,0.2);
  --armory-shadow-lg:  0 10px 15px -3px rgba(0,0,0,0.35), 0 4px 6px -4px rgba(0,0,0,0.2);
  --armory-shadow-blue: 0 0 12px rgba(0,150,255,0.25);

  --armory-radius-sm:  6px;
  --armory-radius-md:  8px;
  --armory-radius-lg:  12px;

  --armory-transition: 150ms ease-out;
}

/* Force dark theme at the html level (set by JS on load) */
[data-bs-theme="dark"] {
  --tblr-body-bg:    #0f172a;
  --tblr-body-color: #c9d1d9;
  --tblr-border-color: #1e293b;
}


/* --------------------------------------------------------------------------
   2. Base
   -------------------------------------------------------------------------- */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color-scheme: dark;
}

body {
  font-family: var(--tblr-font-sans-serif);
  background: var(--tblr-body-bg);
  color: var(--tblr-body-color);
}

/* Selection */
::selection {
  background: rgba(0, 150, 255, 0.18);
  color: #40b3ff;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #1e293b; border-radius: 9999px; }
::-webkit-scrollbar-thumb:hover { background: #334155; }

a {
  color: var(--tblr-primary);
  text-decoration: none;
  transition: color var(--armory-transition);
}

a:hover { color: var(--tblr-primary-lighten); }


/* --------------------------------------------------------------------------
   3. Navbar (dark horizontal)
   -------------------------------------------------------------------------- */
.navbar.armory-navbar {
  background: var(--armory-navbar-bg);
  border-bottom: 1px solid var(--armory-navbar-border);
  box-shadow: 0 2px 12px rgba(0,0,0,0.4);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 1030;
}

.armory-navbar .navbar-brand {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -0.02em;
  color: #fff;
  padding: 0.75rem 0;
  white-space: nowrap;
}

.armory-navbar .navbar-brand:hover {
  color: var(--tblr-primary-lighten);
}

.armory-navbar .navbar-brand img {
  height: 32px;
  width: auto;
}

/* Nav links in top bar */
.armory-navbar .nav-link {
  color: #94a3b8;
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.875rem 0.875rem;
  white-space: nowrap;
  transition: color var(--armory-transition), background var(--armory-transition);
  border-bottom: 2px solid transparent;
}

.armory-navbar .nav-link:hover,
.armory-navbar .nav-link:focus {
  color: #e2e8f0;
  background: rgba(255,255,255,0.04);
}

.armory-navbar .nav-link.active {
  color: #fff;
  border-bottom-color: var(--tblr-primary);
}

.armory-navbar .navbar-toggler {
  color: #94a3b8;
  border-color: rgba(255,255,255,0.12);
  padding: 0.375rem 0.625rem;
}

.armory-navbar .navbar-toggler:focus {
  box-shadow: 0 0 0 3px rgba(0,150,255,0.2);
}

/* Server badge in navbar */
.armory-navbar .server-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 0.25rem 0.625rem;
  border-radius: 9999px;
  background: rgba(0,150,255,0.12);
  color: var(--tblr-primary-lighten);
  border: 1px solid rgba(0,150,255,0.2);
}


/* --------------------------------------------------------------------------
   4. Navbar Search
   -------------------------------------------------------------------------- */
.armory-navbar .navbar-search {
  position: relative;
  min-width: 220px;
  max-width: 320px;
  flex: 1 1 auto;
}

.armory-navbar .navbar-search .form-control {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--armory-radius-md);
  color: #e2e8f0;
  font-size: 0.875rem;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  transition: border-color var(--armory-transition), background var(--armory-transition), box-shadow var(--armory-transition);
}

.armory-navbar .navbar-search .form-control::placeholder {
  color: #475569;
}

.armory-navbar .navbar-search .form-control:focus {
  background: rgba(255,255,255,0.09);
  border-color: var(--tblr-primary);
  box-shadow: 0 0 0 3px rgba(0,150,255,0.15);
  outline: none;
  color: #f1f5f9;
}

.armory-navbar .navbar-search .search-submit {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: #64748b;
  padding: 0;
  line-height: 1;
  cursor: pointer;
  transition: color var(--armory-transition);
}

.armory-navbar .navbar-search .search-submit:hover {
  color: var(--tblr-primary);
}


/* --------------------------------------------------------------------------
   5. Mega Menu (.mega-menu) — full-width dropdown for ITEMS
   -------------------------------------------------------------------------- */
.mega-menu-wrapper {
  position: static;
}

/* The dropdown panel itself */
.mega-menu {
  /* display:none comes before the show/media overrides — source order correct */
  display: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  background: #0c1628;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  padding: 1.25rem 0;
  z-index: 1020;
}

.mega-menu.show {
  display: block;
}

.mega-menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.5rem 1.5rem;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* Category column */
.mega-menu-col {
  /* column wrapper */
}

.mega-menu-heading {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--tblr-primary);
  margin-bottom: 0.5rem;
  padding-bottom: 0.375rem;
  border-bottom: 1px solid rgba(0,150,255,0.2);
}

.mega-menu-subheading {
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.5);
  margin-top: 0.5rem;
  margin-bottom: 0.25rem;
}

.mega-menu-col .dropdown-item {
  font-size: 0.8125rem;
  font-weight: 400;
  color: #94a3b8;
  padding: 0.2rem 0.25rem;
  border-radius: var(--armory-radius-sm);
  transition: color var(--armory-transition), background var(--armory-transition), padding-left var(--armory-transition);
}

.mega-menu-col .dropdown-item:hover {
  color: #e2e8f0;
  background: rgba(255,255,255,0.04);
  padding-left: 0.5rem;
  text-decoration: none;
}


/* --------------------------------------------------------------------------
   6. Page Header
   -------------------------------------------------------------------------- */
.page-header {
  padding: 1.25rem 0 0.75rem;
  border-bottom: 1px solid var(--tblr-border-color);
  margin-bottom: 1.5rem;
}

.page-pretitle {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--armory-text-muted);
  margin-bottom: 0.25rem;
}

.page-pretitle a {
  color: var(--armory-text-muted);
}

.page-pretitle a:hover {
  color: var(--tblr-primary);
}

.page-title {
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: #f1f5f9;
  margin: 0;
  line-height: 1.3;
}

.page-title-count {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--armory-text-muted);
  margin-left: 0.5rem;
}

/* Section sub-headers replacing nested container/row/col patterns */
h3.section-title {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--tblr-primary);
  margin: 0 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(0,150,255,0.15);
}


/* --------------------------------------------------------------------------
   7. Cards
   -------------------------------------------------------------------------- */
.card {
  background: var(--armory-card-bg);
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--tblr-card-border-radius);
  box-shadow: var(--armory-shadow-sm);
  transition: box-shadow var(--armory-transition), background var(--armory-transition);
}

.card:hover {
  box-shadow: var(--armory-shadow-md);
}

.card-header {
  background: transparent;
  border-bottom: 1px solid var(--tblr-border-color);
  padding: 0.875rem 1.25rem;
}

.card-header .card-title {
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #e2e8f0;
  margin: 0;
}

.card-body {
  padding: 1rem 1.25rem;
}

.card-footer {
  background: rgba(255,255,255,0.02);
  border-top: 1px solid var(--tblr-border-color);
  padding: 0.75rem 1.25rem;
}


/* --------------------------------------------------------------------------
   8. Tables
   -------------------------------------------------------------------------- */
.table {
  font-size: 0.875rem;
  color: var(--tblr-body-color);
  margin-bottom: 0;
}

.table > thead > tr > th {
  background: rgba(255,255,255,0.03);
  color: var(--armory-text-muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  white-space: nowrap;
  border-bottom: 1px solid var(--tblr-border-color);
  padding: 0.625rem 1rem;
}

.table > tbody > tr {
  transition: background var(--armory-transition);
}

.table > tbody > tr:hover {
  background: rgba(255,255,255,0.03);
}

.table > tbody > tr > td,
.table > tbody > tr > th {
  padding: 0.625rem 1rem;
  vertical-align: middle;
  border-color: var(--tblr-border-color);
  color: #c9d1d9;
}

.table > tbody > tr > th {
  font-weight: 500;
  color: #e2e8f0;
}

/* Horizontal scroll wrapper for wide tables on mobile */
.table-responsive {
  -webkit-overflow-scrolling: touch;
}

.row-click {
  cursor: pointer;
}


/* --------------------------------------------------------------------------
   9. Armory-specific Components
   -------------------------------------------------------------------------- */

/* Item icon — 40x40px game icons */
.armory-icon {
  width: 40px;
  min-width: 40px;
  height: 40px;
  object-fit: contain;
  image-rendering: pixelated;
  display: inline-block;
  flex-shrink: 0;
}

/* NPC / monster portrait */
.armory-npc-icon {
  height: 80px;
  width: auto;
  object-fit: contain;
  image-rendering: pixelated;
  display: block;
}

.armory-npc-icon-small {
  height: 60px;
  width: auto;
  object-fit: contain;
  image-rendering: pixelated;
  display: block;
}

/* Icon columns in tables — shrink to content width */
.armory-table th:has(.armory-icon),
.armory-table td:has(.armory-icon),
.armory-table th:has(.armory-npc-icon),
.armory-table td:has(.armory-npc-icon),
.armory-table th:has(.armory-npc-icon-small),
.armory-table td:has(.armory-npc-icon-small),
.armory-table th:has(img),
.armory-table td:has(img) {
  white-space: nowrap;
  padding: 0.25rem 0.5rem;
}

/* Generic armory card (wraps icon + name, used in card-grid views) */
.armory-card {
  background: var(--armory-card-bg);
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--armory-radius-md);
  padding: 0.75rem;
  transition: border-color var(--armory-transition), background var(--armory-transition), transform var(--armory-transition), box-shadow var(--armory-transition);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.5rem;
}

.armory-card:hover {
  border-color: rgba(0,150,255,0.3);
  background: var(--armory-card-hover-bg);
  transform: translateY(-2px);
  box-shadow: var(--armory-shadow-md), var(--armory-shadow-blue);
}

.armory-card .armory-card-name {
  font-size: 0.8125rem;
  font-weight: 500;
  color: #c9d1d9;
  line-height: 1.3;
  word-break: break-word;
}

.armory-card .armory-card-class {
  font-size: 0.6875rem;
  color: var(--armory-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}


/* --------------------------------------------------------------------------
   10. Item Grid
   -------------------------------------------------------------------------- */
.item-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

.item-card {
  background: var(--armory-card-bg);
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--armory-radius-md);
  padding: 0.75rem 0.625rem 0.875rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.5rem;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--armory-transition), transform var(--armory-transition), box-shadow var(--armory-transition), background var(--armory-transition);
}

.item-card:hover {
  border-color: rgba(0,150,255,0.3);
  background: var(--armory-card-hover-bg);
  transform: translateY(-2px);
  box-shadow: var(--armory-shadow-md);
  color: #e2e8f0;
  text-decoration: none;
}

.item-card .item-card-icon {
  width: 40px;
  height: 40px;
  object-fit: contain;
  image-rendering: pixelated;
}

.item-card .item-card-name {
  font-size: 0.8125rem;
  font-weight: 500;
  color: #c9d1d9;
  line-height: 1.35;
  word-break: break-word;
}

.item-card .item-card-class {
  font-size: 0.6875rem;
  color: var(--armory-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Responsive grid: base = 1 col; grows at breakpoints */
@media (min-width: 480px) {
  .item-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
  .item-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
  .item-grid { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 1280px) {
  .item-grid { grid-template-columns: repeat(5, 1fr); }
}


/* --------------------------------------------------------------------------
   11. Rankings
   -------------------------------------------------------------------------- */
tr.rank-gold,
tr.rank-silver,
tr.rank-bronze {
  font-weight: 600;
  border-left: 3px solid transparent;
}

tr.rank-gold,
table.dataTable > tbody > tr.rank-gold {
  background-color: rgba(246, 201, 14, 0.15);
  border-left-color: #f6c90e;
}
tr.rank-gold th,
tr.rank-gold td {
  color: #f6c90e;
}
tr.rank-gold td a {
  color: #fad94a;
}

tr.rank-silver,
table.dataTable > tbody > tr.rank-silver {
  background-color: rgba(148, 163, 184, 0.12);
  border-left-color: #94a3b8;
}
tr.rank-silver th,
tr.rank-silver td {
  color: #b0bec5;
}
tr.rank-silver td a {
  color: #cfd8dc;
}

tr.rank-bronze,
table.dataTable > tbody > tr.rank-bronze {
  background-color: rgba(196, 129, 58, 0.13);
  border-left-color: #c4813a;
}
tr.rank-bronze th,
tr.rank-bronze td {
  color: #c4813a;
}
tr.rank-bronze td a {
  color: #d9a06e;
}

/* Rank number column — shrink to fit */
.armory-table th[scope="row"] {
  width: 1%;
  white-space: nowrap;
  padding-right: 0.25rem;
}

/* Rank number in first cell */
tr.rank-gold th:first-child,
tr.rank-silver th:first-child,
tr.rank-bronze th:first-child {
  font-size: 1.1rem;
  font-weight: 700;
}

/* Inline emblem/job icon next to player/clan name */
.armory-inline-icon {
  width: 40px;
  height: 40px;
  vertical-align: middle;
  margin-right: 6px;
}

/* Clan mark inline icon */
.armory-inline-clanmark {
  display: inline-block;
  vertical-align: middle;
  margin-right: 4px;
}
.armory-inline-clanmark img {
  width: 20px;
  height: 20px;
  vertical-align: middle;
}

/* Zebra-stripe all table rows (works with and without DataTables) */
.table > tbody > tr:nth-child(odd),
table.dataTable > tbody > tr:nth-child(odd) {
  background-color: rgba(255, 255, 255, 0.025);
}
.table > tbody > tr:nth-child(even),
table.dataTable > tbody > tr:nth-child(even) {
  background-color: transparent;
}

/* Ranking rows override zebra striping */
table.dataTable > tbody > tr.rank-gold,
.table > tbody > tr.rank-gold {
  background-color: rgba(246, 201, 14, 0.15);
}
table.dataTable > tbody > tr.rank-silver,
.table > tbody > tr.rank-silver {
  background-color: rgba(148, 163, 184, 0.12);
}
table.dataTable > tbody > tr.rank-bronze,
.table > tbody > tr.rank-bronze {
  background-color: rgba(196, 129, 58, 0.13);
}


/* --------------------------------------------------------------------------
   12. Tippy.js — Arua theme (transparent wrapper, no arrow, no padding)
   -------------------------------------------------------------------------- */
.tippy-box[data-theme~='arua'] {
  background-color: transparent;
  padding: 0;
  border-radius: 0;
  overflow: visible;
  max-width: none !important;
}

.tippy-box[data-theme~='arua'] > .tippy-content {
  padding: 0;
  overflow: visible;
}

.tippy-box[data-theme~='arua'] > .tippy-arrow {
  display: none;
}


/* --------------------------------------------------------------------------
   13. DataTables — dark theme overrides
   --------------------------------------------------------------------------
   Custom DOM from armory.js:
     .dataTables_wrapper
       .dt-top              ← search input
       <table>              ← the table itself
       .dt-bottom           ← info + pagination
   -------------------------------------------------------------------------- */

/* Top bar: search input, right-aligned */
.dt-top {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--tblr-border-color);
}

/* Bottom bar: info left, pagination right */
.dt-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 0.75rem;
  border-top: 1px solid var(--tblr-border-color);
}

/* Search input styling */
.dataTables_filter {
  margin: 0;
}
.dataTables_filter label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--armory-text-muted);
  margin: 0;
}
.dataTables_filter input {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--armory-radius-sm);
  color: #c9d1d9;
  padding: 0.3rem 0.5rem;
  font-size: 0.8125rem;
}
.dataTables_filter input:focus {
  border-color: var(--tblr-primary);
  box-shadow: 0 0 0 2px rgba(0,150,255,0.15);
  outline: none;
  background: rgba(255,255,255,0.07);
}

/* Info text */
.dataTables_info {
  font-size: 0.8125rem;
  color: var(--armory-text-muted);
  margin: 0;
  padding: 0;
}

/* Pagination */
.dataTables_paginate {
  margin: 0;
  padding: 0;
}
.dataTables_paginate .pagination {
  margin: 0;
  gap: 2px;
}
.dataTables_wrapper .paginate_button {
  border-radius: var(--armory-radius-sm) !important;
  color: #94a3b8 !important;
}
.dataTables_wrapper .paginate_button.current,
.dataTables_wrapper .paginate_button.current:hover {
  background: var(--tblr-primary) !important;
  border-color: var(--tblr-primary) !important;
  color: #fff !important;
}
.dataTables_wrapper .paginate_button:hover:not(.current):not(.disabled) {
  background: rgba(255,255,255,0.06) !important;
  border-color: var(--tblr-border-color) !important;
  color: #e2e8f0 !important;
}
.dataTables_wrapper .paginate_button.disabled {
  color: #334155 !important;
}

/* Table borders */
table.dataTable thead th,
table.dataTable thead td {
  border-bottom: 1px solid var(--tblr-border-color) !important;
}
table.dataTable.no-footer {
  border-bottom: none !important;
}


/* --------------------------------------------------------------------------
   14. Map Page
   -------------------------------------------------------------------------- */
.map {
  position: relative;
  background: #050e1a;
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--armory-radius-lg);
  overflow: hidden;
  user-select: none;
}

.map img.map-image {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Map markers */
.map-marker {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--tblr-primary);
  border: 2px solid rgba(255,255,255,0.8);
  cursor: pointer;
  transition: transform var(--armory-transition), box-shadow var(--armory-transition);
}

.map-marker:hover {
  transform: translate(-50%, -50%) scale(1.5);
  box-shadow: 0 0 8px rgba(0,150,255,0.6);
}

.map-marker.marker-npc {
  background: #22c55e;
}

.map-marker.marker-mob {
  background: #ef4444;
}

.map-marker.marker-warp {
  background: #a855f7;
}


/* --------------------------------------------------------------------------
   15. Model Viewer
   -------------------------------------------------------------------------- */
#model-viewer {
  width: 100%;
  height: 400px;
  background: #050e1a;
  border: 1px solid var(--tblr-border-color);
  border-radius: var(--armory-radius-lg);
  overflow: hidden;
  position: relative;
}

#model-viewer canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
}


/* --------------------------------------------------------------------------
   16. Badges & Status Indicators
   -------------------------------------------------------------------------- */
.badge {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* Quality level badges */
.badge-quality-common   { background: rgba(200,200,200,0.12); color: #c9d1d9; }
.badge-quality-uncommon { background: rgba(34,197,94,0.12);   color: #4ade80; }
.badge-quality-rare     { background: rgba(59,130,246,0.12);  color: #60a5fa; }
.badge-quality-epic     { background: rgba(168,85,247,0.12);  color: #c084fc; }
.badge-quality-unique   { background: rgba(249,115,22,0.12);  color: #fb923c; }


/* --------------------------------------------------------------------------
   17. Buttons
   -------------------------------------------------------------------------- */
.btn-primary {
  --tblr-btn-bg: #0096ff;
  --tblr-btn-border-color: #0096ff;
  --tblr-btn-hover-bg: #0078d4;
  --tblr-btn-hover-border-color: #0078d4;
  box-shadow: 0 1px 3px rgba(0,150,255,0.3);
}

.btn-primary:hover,
.btn-primary:focus {
  box-shadow: 0 4px 12px rgba(0,150,255,0.4);
  transform: translateY(-1px);
}

.btn-primary:active {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(0,150,255,0.3);
}

.btn:focus-visible {
  box-shadow: 0 0 0 3px rgba(0,150,255,0.2);
}


/* --------------------------------------------------------------------------
   18. Forms
   -------------------------------------------------------------------------- */
.form-control,
.form-select,
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
  background-color: #111827;
  border-color: var(--tblr-border-color);
  color: #c9d1d9;
}

.form-control:focus,
.form-select:focus,
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
  background-color: #0f172a;
  border-color: var(--tblr-primary);
  box-shadow: 0 0 0 3px rgba(0,150,255,0.12);
  color: #f1f5f9;
}

.form-control::placeholder {
  color: #334155;
}

.form-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #94a3b8;
  margin-bottom: 0.375rem;
}

/* Native select/option dark backgrounds (Firefox, older Edge) */
.form-select option,
select option {
  background: #111827;
  color: #c9d1d9;
}

/* Autofill/autocomplete dark background (Chrome, Safari, Edge) */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
select:-webkit-autofill {
  -webkit-text-fill-color: #c9d1d9;
  -webkit-box-shadow: 0 0 0 1000px #111827 inset;
  border-color: var(--tblr-border-color);
  transition: background-color 5000s ease-in-out 0s;
}


/* --------------------------------------------------------------------------
   19. Dropdown Menus
   -------------------------------------------------------------------------- */
.dropdown-menu {
  background: #0c1628;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--armory-radius-md);
  box-shadow: var(--armory-shadow-lg);
  padding: 0.375rem;
}

.dropdown-item {
  border-radius: var(--armory-radius-sm);
  font-size: 0.875rem;
  font-weight: 500;
  color: #94a3b8;
  padding: 0.5rem 0.75rem;
  transition: background var(--armory-transition), color var(--armory-transition);
}

.dropdown-item:hover,
.dropdown-item:focus {
  background: rgba(255,255,255,0.05);
  color: #e2e8f0;
}

.dropdown-divider {
  border-color: rgba(255,255,255,0.06);
}

.dropdown-header {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #334155;
  padding: 0.5rem 0.75rem 0.25rem;
}


/* --------------------------------------------------------------------------
   20. Footer
   -------------------------------------------------------------------------- */
.armory-footer {
  background: var(--armory-navbar-bg);
  border-top: 1px solid var(--armory-navbar-border);
  padding: 1.5rem 0;
  margin-top: 3rem;
}

.armory-footer .footer-logo {
  height: 28px;
  width: auto;
  opacity: 0.7;
  transition: opacity var(--armory-transition);
}

.armory-footer .footer-logo:hover {
  opacity: 1;
}

.armory-footer p,
.armory-footer small {
  font-size: 0.8125rem;
  color: #334155;
  margin: 0;
}

.armory-footer a {
  color: #475569;
  transition: color var(--armory-transition);
}

.armory-footer a:hover {
  color: var(--tblr-primary);
}

.armory-footer .footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 1rem;
  list-style: none;
  padding: 0;
  margin: 0;
}


/* --------------------------------------------------------------------------
   21. Page Fade-in
   -------------------------------------------------------------------------- */
.page-body,
.armory-page-content {
  animation: armoryFadeIn 0.2s ease-out;
}

@keyframes armoryFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* --------------------------------------------------------------------------
   22. Alerts
   -------------------------------------------------------------------------- */
.alert {
  border-radius: var(--armory-radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  border: 1px solid rgba(255,255,255,0.07);
}


/* --------------------------------------------------------------------------
   23. Pagination
   -------------------------------------------------------------------------- */
.pagination .page-link {
  background: rgba(255,255,255,0.04);
  border-color: var(--tblr-border-color);
  color: #94a3b8;
  transition: background var(--armory-transition), color var(--armory-transition);
}

.pagination .page-link:hover {
  background: rgba(255,255,255,0.07);
  color: #e2e8f0;
  border-color: var(--tblr-border-color);
}

.pagination .page-item.active .page-link {
  background: var(--tblr-primary);
  border-color: var(--tblr-primary);
  color: #fff;
}

.pagination .page-item.disabled .page-link {
  background: rgba(255,255,255,0.02);
  color: #1e293b;
  border-color: var(--tblr-border-color);
}


/* --------------------------------------------------------------------------
   24. Responsive
   -------------------------------------------------------------------------- */

/* Mega menu: collapse to single-column on mobile */
@media (max-width: 991.98px) {
  .mega-menu {
    position: static;
    border-top: none;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding: 0.75rem 0;
  }

  .mega-menu-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .mega-menu-col {
    border-bottom: 1px solid rgba(255,255,255,0.04);
    padding-bottom: 0.75rem;
  }

  .mega-menu-col:last-child {
    border-bottom: none;
  }

  /* Horizontal-scroll tables on small screens */
  .table-responsive-armory {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .page-header {
    padding: 1rem 0 0.625rem;
    margin-bottom: 1rem;
  }

  .armory-navbar .navbar-search {
    min-width: 0;
    max-width: 100%;
    width: 100%;
    margin-top: 0.5rem;
  }
}

@media (max-width: 575.98px) {
  .page-title {
    font-size: 1.125rem;
  }

  .card-body {
    padding: 0.875rem 1rem;
  }

  .card-header {
    padding: 0.75rem 1rem;
  }

  .table > thead > tr > th {
    font-size: 0.6875rem;
  }

  #model-viewer {
    height: 280px;
  }
}
