:root {
  --bs-primary: var(--bs-danger);
  --bs-primary-rgb: var(--bs-danger-rgb);
}

/* -----------------------------------
   HEADER WRAPPER & STRUCTURE
----------------------------------- */
.site-header-wrapper {
  position: relative;
  z-index: 300;
  width: 100%;
  background-color: var(--bs-tertiary-bg);
  border-bottom: 1px solid var(--bs-border-color);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.site-header {
  width: 100%;
  --header-height: 74px;
  height: var(--header-height);
}

.desktop-header {
  display: none;
}

@media (min-width: 768px) {
  .desktop-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

/* -----------------------------------
   LOGO
----------------------------------- */
.logo svg {
  display: block;
  height: auto;
  max-height: 40px;
  transition: fill .3s ease;
}

.logo svg .logo-fill {
  fill: var(--logo-fill);
  transition: fill .3s ease;
}

[data-bs-theme="light"] { --logo-fill: #000; }
[data-bs-theme="dark"]  { --logo-fill: #fff; }

/* Perfect mobile header */
.mobile-header {
  padding: .25rem 0;
  height: 64px;
}

.logo-mobile svg {
  height: 44px;
}

/* Make all red logo elements follow Bootstrap's danger color */
.logo svg {
  color: var(--bs-danger);
}

/* Keep themed black/white part controlled by --logo-fill */
.logo svg .logo-fill {
  fill: var(--logo-fill) !important;
}

/* Convert red parts to use currentColor */
.logo svg circle {
  stroke: currentColor !important;
}

.logo svg path:not(.logo-fill) {
  fill: currentColor !important;
}


/* -----------------------------------
   NAVIGATION (Top-level)
----------------------------------- */

/* Reset primary button into "nav link style" when not active */
nav .btn-primary {
  background-color: transparent !important;
  border: none !important;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  transition: color .25s ease, background-color .25s ease;
}

/* Ensure all nav items have equal height */
nav .btn-primary,
.modes-btn {
  height: 38px;
  display: inline-flex;
  align-items: center;
}

/* Inactive nav items — theme aware */
html[data-bs-theme="light"] nav .btn-primary:not(.active-page),
html[data-bs-theme="light"] .modes-btn:not(.active-page) {
  color: #000 !important;
}

html[data-bs-theme="dark"] nav .btn-primary:not(.active-page),
html[data-bs-theme="dark"] .modes-btn:not(.active-page) {
  color: #fff !important;
}

/* Active page state */
nav .btn-primary.active-page,
.modes-btn.active-page {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  color: #fff !important;
  border-radius: .375rem;
}

nav .btn-primary.active-page:hover,
.modes-btn.active-page:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.85) !important;
}

/* 🔥 Match hover style for all INACTIVE nav buttons */
nav .btn-primary:hover:not(.active-page),
.modes-btn:hover:not(.active-page) {
  background-color: var(--bs-secondary-bg) !important;
  color: var(--bs-body-color) !important;
}


/* -----------------------------------
   MODES BUTTON (“Quiz” dropdown trigger)
----------------------------------- */
.modes-btn {
  background: transparent;
  border: none;
  color: var(--bs-body-color);
  cursor: pointer;
  border-radius: 6px;
  transition: background 0.15s ease, color 0.15s ease;
  padding: 0 .75rem;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.modes-btn:hover:not(.active-page) {
  background-color: var(--bs-secondary-bg);
}

.modes-btn.active {
  background-color: color-mix(in srgb, var(--bs-danger) 8%, transparent);
  color: var(--bs-danger);
}

.modes-btn i {
  transition: transform .2s ease, color .2s ease;
}

/* -----------------------------------
   MEGA MENU (Desktop Dropdown)
----------------------------------- */
.mega-menu {
  position: absolute;
  top: calc(var(--header-height, 74px));
  left: 0;
  width: 100%;
  background: var(--bs-body-bg);
  border-bottom: 1px solid var(--bs-border-color);
  box-shadow: 0 18px 40px rgba(0,0,0,.18);
  z-index: 200;
  opacity: 0;
  transform: translateY(-12px);
  pointer-events: none;
  will-change: transform, opacity;
}

.mega-menu.open {
  pointer-events: auto;
  animation: megaSlideIn 280ms cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

.mega-menu.closing {
  animation: megaSlideOut 240ms cubic-bezier(0.4, 0.0, 0.2, 1) forwards;
}

@keyframes megaSlideIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes megaSlideOut {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(-10px); }
}

.mega-item {
  border-radius: 6px;
  text-decoration: none;
  color: var(--bs-body-color);
  transition: background .15s ease;
}

.mega-item:hover {
  background-color: var(--bs-secondary-bg);
}

.mega-item p {
  color: var(--bs-secondary-color);
}

.mega-item.active-page h2 {
  color: var(--bs-primary) !important;
}


/* Badge */
.klovn-badge-new {
  background: transparent !important;
  color: var(--bs-primary) !important;
  border: 1px solid var(--bs-primary);
  font-size: 0.65rem;
  padding: 0.2rem 0.45rem;
  border-radius: 0.35rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Hide mega menu on mobile */
@media (max-width: 767px) {
  #megaMenu {
    display: none !important;
  }
}

/* -----------------------------------
   MOBILE MENU (Slide-in)
----------------------------------- */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 260px;
  height: 100vh;
  background: var(--bs-body-bg);
  box-shadow: 4px 0 18px rgba(0,0,0,.25);
  transform: translateX(-100%);
  transition: transform .35s cubic-bezier(0.22,0.61,0.36,1);
  z-index: 5000;
  padding: 2rem 1.5rem;
}

.mobile-menu.open {
  transform: translateX(0);
}

.mobile-menu-inner {
  margin-top: 1rem;
}

.mobile-item {
  display: block;
  padding: 1rem 0;
  font-size: 1.25rem;
  color: var(--bs-body-color);
  text-decoration: none;
  transition: color .2s ease;
}
.mobile-item:hover {
  color: var(--bs-primary);
}

/* Remove dividers */
.mobile-item + .mobile-item {
  border-top: none !important;
}

/* Mobile theme toggle */
#mobileThemeToggle {
  width: 100%;
  text-align: left;
  font-size: 1.25rem;
  color: var(--bs-body-color);
  cursor: pointer;
}
#mobileThemeToggle:hover {
  color: var(--bs-primary);
}
#mobileThemeToggle:focus {
  outline: none;
  box-shadow: none;
}
