:root {
  color-scheme: dark;
  --tacticus-void: #070809;
  --tacticus-black: #0b0d0f;
  --tacticus-gunmetal: #14181d;
  --tacticus-steel: #1d242b;
  --tacticus-steel-light: #2e3841;
  --tacticus-bone: #e8dfc8;
  --tacticus-parchment: #cfc4aa;
  --tacticus-ash: #928b7e;
  --tacticus-brass: #b08a3c;
  --tacticus-brass-bright: #d1ad5a;
  --tacticus-crimson: #8f1f2d;
  --tacticus-crimson-bright: #ba2c3d;
  --tacticus-toxic: #7fa64c;
  --tacticus-amber: #c58d36;
  --tacticus-danger: #d5534c;
  --bs-body-bg: var(--tacticus-void);
  --bs-body-color: var(--tacticus-bone);
  --bs-border-color: rgba(176, 138, 60, 0.26);
  --bs-border-color-translucent: rgba(176, 138, 60, 0.18);
  --bs-link-color: var(--tacticus-brass-bright);
  --bs-link-hover-color: #f0cf78;
  --bs-secondary-color: var(--tacticus-ash);
  --bs-tertiary-color: rgba(207, 196, 170, 0.72);
  --bs-primary: var(--tacticus-crimson);
  --bs-primary-rgb: 143, 31, 45;
  --bs-secondary: var(--tacticus-steel-light);
  --bs-secondary-rgb: 46, 56, 65;
  --bs-danger: var(--tacticus-danger);
  --bs-warning: var(--tacticus-amber);
  --bs-success: var(--tacticus-toxic);
  --bs-focus-ring-color: rgba(209, 173, 90, 0.32);
}

* {
  scrollbar-color: var(--tacticus-brass) var(--tacticus-black);
}

body {
  min-height: 100vh;
  background:
    linear-gradient(160deg, rgba(143, 31, 45, 0.16), transparent 34rem),
    linear-gradient(24deg, rgba(176, 138, 60, 0.1), transparent 26rem),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 7px),
    var(--tacticus-void);
  color: var(--tacticus-bone);
  font-family: Nunito, sans-serif;
  font-size: 1em;
  font-weight: 400;
}

body::before {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  content: "";
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.025), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.02)),
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
  background-size: auto, 100% 44px, 44px 100%;
  mix-blend-mode: screen;
  opacity: 0.25;
}

.container {
  max-width: 1180px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #f2e7cd;
  font-family: Cinzel, Georgia, serif;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

p {
  color: var(--tacticus-parchment);
}

a {
  color: var(--bs-link-color);
  text-decoration-color: rgba(209, 173, 90, 0.5);
}

a:hover,
a:focus {
  color: var(--bs-link-hover-color);
}

.text-secondary {
  color: var(--tacticus-ash) !important;
}

.card,
.modal-content {
  color: var(--tacticus-bone);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 38%),
    linear-gradient(145deg, rgba(176, 138, 60, 0.1), transparent 42%),
    var(--tacticus-gunmetal);
  border: 1px solid rgba(176, 138, 60, 0.3);
  border-radius: 8px;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.42), inset 0 1px rgba(255, 255, 255, 0.04);
}

.card-body,
.modal-body {
  position: relative;
}

.card-body::before,
.modal-body::before {
  display: block;
  width: 4rem;
  height: 2px;
  margin-bottom: 1rem;
  content: "";
  background: linear-gradient(90deg, var(--tacticus-brass), transparent);
}

.modal-body.text-center::before {
  margin-right: auto;
  margin-left: auto;
  background: linear-gradient(90deg, transparent, var(--tacticus-brass), transparent);
}

.shadow-sm,
.shadow-lg {
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.5) !important;
}

.btn {
  border-radius: 4px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.btn:focus-visible,
.form-control:focus,
.form-select:focus,
.page-link:focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem var(--bs-focus-ring-color);
}

.btn-primary {
  --bs-btn-color: #fff5df;
  --bs-btn-bg: var(--tacticus-crimson);
  --bs-btn-border-color: #d1ad5a;
  --bs-btn-hover-color: #fff8e8;
  --bs-btn-hover-bg: var(--tacticus-crimson-bright);
  --bs-btn-hover-border-color: #f0cf78;
  --bs-btn-focus-shadow-rgb: 209, 173, 90;
  --bs-btn-active-color: #fff8e8;
  --bs-btn-active-bg: #6f1824;
  --bs-btn-active-border-color: var(--tacticus-brass);
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.18), 0 8px 18px rgba(143, 31, 45, 0.28);
}

.btn-outline-primary {
  --bs-btn-color: var(--tacticus-brass-bright);
  --bs-btn-border-color: rgba(209, 173, 90, 0.72);
  --bs-btn-hover-color: #12100b;
  --bs-btn-hover-bg: var(--tacticus-brass-bright);
  --bs-btn-hover-border-color: var(--tacticus-brass-bright);
  --bs-btn-active-color: #12100b;
  --bs-btn-active-bg: var(--tacticus-brass);
  --bs-btn-active-border-color: var(--tacticus-brass);
}

.btn-outline-secondary {
  --bs-btn-color: var(--tacticus-parchment);
  --bs-btn-border-color: var(--tacticus-steel-light);
  --bs-btn-hover-color: var(--tacticus-bone);
  --bs-btn-hover-bg: var(--tacticus-steel-light);
  --bs-btn-hover-border-color: rgba(209, 173, 90, 0.5);
  --bs-btn-active-color: var(--tacticus-bone);
  --bs-btn-active-bg: #252d34;
  --bs-btn-active-border-color: var(--tacticus-brass);
}

.btn-link {
  --bs-btn-color: var(--tacticus-brass-bright);
  --bs-btn-hover-color: #f0cf78;
  --bs-btn-focus-shadow-rgb: 209, 173, 90;
  text-decoration-color: rgba(209, 173, 90, 0.5);
}

.btn:disabled,
.btn.disabled,
fieldset:disabled .btn {
  color: rgba(232, 223, 200, 0.42);
  pointer-events: none;
  background-color: rgba(29, 36, 43, 0.72);
  border-color: rgba(146, 139, 126, 0.32);
  opacity: 1;
}

.form-label {
  color: var(--tacticus-parchment);
  font-weight: 800;
  text-transform: uppercase;
}

.form-control,
.form-select {
  color: var(--tacticus-bone);
  background-color: #0e1114;
  border: 1px solid rgba(176, 138, 60, 0.32);
  border-radius: 4px;
}

.form-control:focus,
.form-select:focus {
  color: #fff5df;
  background-color: #12161a;
  border-color: var(--tacticus-brass-bright);
}

.form-control::placeholder {
  color: rgba(207, 196, 170, 0.46);
}

.alert {
  color: var(--tacticus-bone);
  border-radius: 6px;
  border-width: 1px;
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.04);
}

.alert-danger {
  background-color: rgba(107, 27, 28, 0.42);
  border-color: rgba(213, 83, 76, 0.52);
}

.alert-success {
  background-color: rgba(54, 86, 41, 0.4);
  border-color: rgba(127, 166, 76, 0.55);
}

.alert-warning {
  color: #fff0cf;
  background-color: rgba(110, 74, 26, 0.46);
  border-color: rgba(197, 141, 54, 0.58);
}

.table {
  --bs-table-color: var(--tacticus-bone);
  --bs-table-bg: rgba(20, 24, 29, 0.92);
  --bs-table-border-color: rgba(176, 138, 60, 0.2);
  --bs-table-striped-color: var(--tacticus-bone);
  --bs-table-striped-bg: rgba(46, 56, 65, 0.38);
  --bs-table-hover-color: #fff5df;
  --bs-table-hover-bg: rgba(176, 138, 60, 0.12);
  overflow: hidden;
  border: 1px solid rgba(176, 138, 60, 0.26);
  border-radius: 8px;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28);
}

.table > :not(caption) > * > * {
  padding: 0.85rem 1rem;
  border-bottom-color: rgba(176, 138, 60, 0.18);
}

.table thead th {
  color: #f2e7cd;
  background:
    linear-gradient(180deg, rgba(176, 138, 60, 0.16), rgba(176, 138, 60, 0.05)),
    #11161b;
  border-bottom-color: rgba(209, 173, 90, 0.45);
  font-family: Cinzel, Georgia, serif;
  font-size: 0.88rem;
  letter-spacing: 0;
  text-transform: uppercase;
}

.faction-icon {
  max-height: 20px;
  filter: drop-shadow(0 0 5px rgba(209, 173, 90, 0.28));
}

.guest-app-preview {
  min-height: 70vh;
  filter: blur(2px) saturate(0.75);
  opacity: 0.4;
  pointer-events: none;
  user-select: none;
}

.guest-modal-backdrop {
  background-color: rgba(3, 4, 5, 0.76);
  backdrop-filter: blur(2px);
}

.guest-auth-modal {
  background-color: rgba(7, 8, 9, 0.22);
}

.guest-auth-modal .modal-content {
  border: 1px solid rgba(209, 173, 90, 0.36);
  border-radius: 8px;
}

.guest-auth-panel[hidden] {
  display: none;
}

.guest-auth-logo {
  width: 100%;
  max-width: 280px;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.48));
}

img[alt="Warhammer Tacticus Logo"] {
  max-width: 360px;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.48));
}

.dt-container {
  color: var(--tacticus-parchment);
}

.dt-container .dt-length,
.dt-container .dt-search,
.dt-container .dt-info {
  color: var(--tacticus-ash);
}

.dt-container .dt-input,
.dt-container .form-control,
.dt-container .form-select {
  color: var(--tacticus-bone);
  background-color: #0e1114;
  border-color: rgba(176, 138, 60, 0.34);
}

.dt-container .dt-input:focus,
.dt-container .form-control:focus,
.dt-container .form-select:focus {
  color: #fff5df;
  background-color: #12161a;
  border-color: var(--tacticus-brass-bright);
}

.dt-container .pagination {
  --bs-pagination-color: var(--tacticus-parchment);
  --bs-pagination-bg: var(--tacticus-gunmetal);
  --bs-pagination-border-color: rgba(176, 138, 60, 0.28);
  --bs-pagination-hover-color: #12100b;
  --bs-pagination-hover-bg: var(--tacticus-brass-bright);
  --bs-pagination-hover-border-color: var(--tacticus-brass-bright);
  --bs-pagination-focus-color: #12100b;
  --bs-pagination-focus-bg: var(--tacticus-brass-bright);
  --bs-pagination-focus-box-shadow: 0 0 0 0.2rem var(--bs-focus-ring-color);
  --bs-pagination-active-color: #fff5df;
  --bs-pagination-active-bg: var(--tacticus-crimson);
  --bs-pagination-active-border-color: var(--tacticus-brass);
  --bs-pagination-disabled-color: rgba(207, 196, 170, 0.38);
  --bs-pagination-disabled-bg: rgba(20, 24, 29, 0.66);
  --bs-pagination-disabled-border-color: rgba(146, 139, 126, 0.22);
}

.page-link {
  border-radius: 4px;
}

@media (max-width: 575.98px) {
  body {
    font-size: 0.95rem;
  }

  .container {
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .d-flex.align-items-center.justify-content-between {
    align-items: flex-start !important;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  .table > :not(caption) > * > * {
    padding: 0.72rem 0.78rem;
  }

  .table {
    display: block;
    max-width: 100%;
    overflow-x: auto;
    white-space: nowrap;
  }

  .dt-container .row {
    row-gap: 0.75rem;
  }
}
