@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap");

body.vibe-ui-enabled {
  --vibe-ink: #040915;
  --vibe-ink-soft: #091428;
  --vibe-header-bg: linear-gradient(145deg, rgba(7, 15, 31, 0.94), rgba(4, 10, 22, 0.95));
  --vibe-panel: rgba(10, 20, 42, 0.78);
  --vibe-panel-strong: rgba(8, 16, 34, 0.92);
  --vibe-border: rgba(122, 164, 255, 0.24);
  --vibe-border-strong: rgba(98, 186, 255, 0.42);
  --vibe-cyan: #4bc7ff;
  --vibe-blue: #3f7eff;
  --vibe-red: #ff6e5a;
  --vibe-gold: #ffcf64;
  --vibe-text: #e9f1ff;
  --vibe-text-soft: #a7bce3;
  --vibe-shadow: 0 16px 42px rgba(3, 8, 19, 0.4);
  --vibe-ring: 0 0 0 0.2rem rgba(75, 199, 255, 0.2);
  --bs-body-bg: #05070d;
  --bs-body-color: #e9f1ff;
  font-family: "Space Grotesk", "Exo 2", "Segoe UI", sans-serif;
  background: #05070d !important;
  background-color: #05070d !important;
  background-image: none !important;
  background-attachment: initial !important;
}

/* In battle pages keep Battle background only (avoid vibe overlay washout) */
body.vibe-ui-enabled.battle-zone {
  background-image: none !important;
  background-attachment: initial !important;
}

body.vibe-ui-enabled.battle-zone::after {
  display: none !important;
}

body.vibe-ui-enabled::after { display: none !important; }
body.vibe-ui-enabled::before { display: none !important; }

body.vibe-ui-enabled > * {
  position: relative;
  z-index: 1;
}

body.vibe-ui-enabled .container,
body.vibe-ui-enabled .container-fluid {
  max-width: min(1320px, 96vw);
}

body.vibe-ui-enabled main h1,
body.vibe-ui-enabled main h2,
body.vibe-ui-enabled main h3,
body.vibe-ui-enabled .section-title {
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-wrap: balance;
}

body.vibe-ui-enabled .text-secondary,
body.vibe-ui-enabled .text-muted {
  color: var(--vibe-text-soft) !important;
}

body.vibe-ui-enabled .fecod-header,
body.vibe-ui-enabled .battle-header {
  border-bottom: 1px solid var(--vibe-border-strong) !important;
  background: var(--vibe-header-bg) !important;
  box-shadow:
    0 10px 30px rgba(2, 5, 12, 0.44),
    inset 0 -1px 0 rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(12px);
}

body.vibe-ui-enabled .navbar-nav .nav-link,
body.vibe-ui-enabled .battle-nav-list .nav-link {
  border-radius: 8px;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

body.vibe-ui-enabled .navbar-nav .nav-link:hover,
body.vibe-ui-enabled .navbar-nav .nav-link:focus,
body.vibe-ui-enabled .battle-nav-list .nav-link:hover,
body.vibe-ui-enabled .battle-nav-list .nav-link:focus,
body.vibe-ui-enabled .navbar-nav .nav-link.active,
body.vibe-ui-enabled .battle-nav-list .nav-link.active {
  background: var(--vibe-header-bg);
  box-shadow: 0 8px 20px rgba(3, 9, 23, 0.36);
  color: #ffffff !important;
  transform: translateY(-1px);
}

body.vibe-ui-enabled .dropdown-menu {
  border: 1px solid var(--vibe-border) !important;
  background: linear-gradient(145deg, rgba(8, 18, 36, 0.98), rgba(5, 13, 27, 0.98));
  box-shadow: var(--vibe-shadow);
  z-index: 1200;
  pointer-events: auto;
}

body.vibe-ui-enabled .dropdown-item:hover,
body.vibe-ui-enabled .dropdown-item:focus {
  background: rgba(75, 199, 255, 0.12);
}

body.vibe-ui-enabled .card,
body.vibe-ui-enabled .panel,
body.vibe-ui-enabled .hub-card,
body.vibe-ui-enabled .battle-card,
body.vibe-ui-enabled .hub-match,
body.vibe-ui-enabled .social-card,
body.vibe-ui-enabled .feature-card,
body.vibe-ui-enabled .cookie-card,
body.vibe-ui-enabled .legal-page,
body.vibe-ui-enabled .list-group-item {
  border-color: var(--vibe-border) !important;
  background: linear-gradient(145deg, var(--vibe-panel), var(--vibe-panel-strong)) !important;
  box-shadow: var(--vibe-shadow);
}

body.vibe-ui-enabled .card:hover,
body.vibe-ui-enabled .hub-card:hover,
body.vibe-ui-enabled .battle-card:hover,
body.vibe-ui-enabled .hub-match:hover,
body.vibe-ui-enabled .feature-card:hover {
  border-color: var(--vibe-border-strong) !important;
  box-shadow:
    0 20px 45px rgba(2, 7, 18, 0.46),
    0 0 0 1px rgba(75, 199, 255, 0.12);
}

body.vibe-ui-enabled .btn {
  border-radius: 10px;
  transition: transform 0.18s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

body.vibe-ui-enabled .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(4, 10, 22, 0.34);
}

body.vibe-ui-enabled .btn-primary,
body.vibe-ui-enabled .btn-success {
  border: 0;
  color: #ffffff;
  background: linear-gradient(135deg, var(--vibe-blue), var(--vibe-cyan));
}

body.vibe-ui-enabled .btn-outline-info,
body.vibe-ui-enabled .btn-outline-light,
body.vibe-ui-enabled .btn-outline-warning,
body.vibe-ui-enabled .btn-outline-secondary {
  border-color: var(--vibe-border-strong);
}

body.vibe-ui-enabled .btn-outline-info:hover,
body.vibe-ui-enabled .btn-outline-light:hover,
body.vibe-ui-enabled .btn-outline-warning:hover,
body.vibe-ui-enabled .btn-outline-secondary:hover {
  background: rgba(75, 199, 255, 0.14);
}

body.vibe-ui-enabled .badge {
  border: 1px solid rgba(128, 165, 245, 0.26);
}

body.vibe-ui-enabled .alert {
  border: 1px solid var(--vibe-border);
  backdrop-filter: blur(3px);
}

body.vibe-ui-enabled .alert-info {
  background: rgba(43, 115, 208, 0.17);
}

body.vibe-ui-enabled .alert-success {
  background: rgba(33, 167, 114, 0.16);
}

body.vibe-ui-enabled .alert-warning {
  background: rgba(201, 140, 36, 0.2);
}

body.vibe-ui-enabled .alert-danger {
  background: rgba(173, 62, 62, 0.2);
}

body.vibe-ui-enabled .table,
body.vibe-ui-enabled .table-dark {
  --bs-table-bg: rgba(9, 18, 36, 0.7);
  --bs-table-striped-bg: rgba(15, 28, 54, 0.66);
  --bs-table-hover-bg: rgba(22, 38, 70, 0.76);
  --bs-table-border-color: var(--vibe-border);
  color: var(--vibe-text);
}

body.vibe-ui-enabled .form-control,
body.vibe-ui-enabled .form-select,
body.vibe-ui-enabled textarea,
body.vibe-ui-enabled input:not([type="checkbox"]):not([type="radio"]) {
  border: 1px solid var(--vibe-border);
  background: rgba(7, 14, 30, 0.86);
  color: var(--vibe-text);
}

body.vibe-ui-enabled .form-control::placeholder,
body.vibe-ui-enabled .form-select::placeholder,
body.vibe-ui-enabled textarea::placeholder,
body.vibe-ui-enabled input::placeholder {
  color: #8ea6cf;
}

body.vibe-ui-enabled .form-control:focus,
body.vibe-ui-enabled .form-select:focus,
body.vibe-ui-enabled textarea:focus,
body.vibe-ui-enabled input:focus {
  border-color: var(--vibe-cyan);
  box-shadow: var(--vibe-ring);
}

body.vibe-ui-enabled .modal-content {
  border: 1px solid var(--vibe-border);
  background: linear-gradient(145deg, rgba(8, 16, 34, 0.98), rgba(7, 14, 28, 0.98));
}

body.vibe-ui-enabled .footer-dark,
body.vibe-ui-enabled .battle-footer {
  border-top: 1px solid var(--vibe-border);
  background: linear-gradient(180deg, rgba(6, 12, 24, 0.96), rgba(4, 9, 18, 0.98));
}

body.vibe-ui-enabled .mobile-nav-wrap .mobile-nav a.active {
  box-shadow: 0 0 0 1px rgba(75, 199, 255, 0.28);
}

body.vibe-ui-enabled .battle-zone .chall-card,
body.vibe-ui-enabled .battle-zone .battle-card,
body.vibe-ui-enabled .battle-zone .hub-match {
  position: relative;
  overflow: hidden;
}

body.vibe-ui-enabled .battle-zone .chall-card::before,
body.vibe-ui-enabled .battle-zone .battle-card::before,
body.vibe-ui-enabled .battle-zone .hub-match::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(125deg, rgba(75, 199, 255, 0.12), transparent 35%),
    linear-gradient(305deg, rgba(255, 110, 90, 0.1), transparent 36%);
}

body.vibe-ui-enabled .battle-zone .chall-card > *,
body.vibe-ui-enabled .battle-zone .battle-card > *,
body.vibe-ui-enabled .battle-zone .hub-match > * {
  position: relative;
  z-index: 1;
}

body.vibe-ui-enabled .vibe-in {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

body.vibe-ui-enabled .vibe-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 991.98px) {
  body.vibe-ui-enabled .container,
  body.vibe-ui-enabled .container-fluid {
    max-width: 100%;
  }

  body.vibe-ui-enabled .navbar-collapse.show {
    border: 1px solid var(--vibe-border);
    border-radius: 12px;
    background: linear-gradient(145deg, rgba(8, 17, 35, 0.96), rgba(6, 13, 26, 0.96));
    box-shadow: 0 10px 24px rgba(2, 8, 20, 0.4);
  }
}
