/*! dark-mode.css - Toggleable dark mode variables and small helpers */

:root {
  --background-color: #ffffff;
  --default-color: #000210;
  --heading-color: #000210;
  --accent-color: #000633;
  --surface-color: #ffffff;
  --contrast-color: #ffffff;

  --nav-color: #000210;
  --nav-hover-color: #000633;
  --nav-mobile-background-color: #ffffff;
  --nav-dropdown-background-color: #ffffff;
  --nav-dropdown-color: #000210;
}

/* Dark mode variables applied when body has .dark-mode */
body.dark-mode {
  --background-color: #071025;
  /* overall page background */
  --default-color: #dbeafe;
  /* main text color */
  --heading-color: #ffffff;
  /* headings */
  --accent-color: #4f9cff;
  /* brand accent */
  --surface-color: #0b1220;
  /* cards, panels */
  --contrast-color: #0b1220;
  /* text color on accent */

  --nav-color: #dbeafe;
  --nav-hover-color: #9ec7ff;
  --nav-mobile-background-color: #071025;
  --nav-dropdown-background-color: #071025;
  --nav-dropdown-color: #e6f2ff;
}

/* Soft global transitions for theme switching */
body.dark-mode,
body.dark-mode .header,
body.dark-mode .navmenu,
body.dark-mode .footer,
body.dark-mode section,
body.dark-mode .card,
body.dark-mode .search-popup-content,
body.dark-mode .page-title {
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

a,
a:focus,
a:active,
button,
button:focus,
button:active {
  outline: none !important;
  box-shadow: none !important;
}

body.dark-mode #loading {
  position: fixed;
  inset: 0;
  background: var(--background-color);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
}

body.dark-mode #loading img {
  width: 300px;
  height: auto;
  animation: moving 2s infinite ease-in-out;
}

@keyframes moving {
  0% {
    transform: translateX(0);
  }

  25% {
    transform: translateX(-10px);
  }

  50% {
    transform: translateX(10px);
  }

  75% {
    transform: translateX(-10px);
  }

  100% {
    transform: translateX(0);
  }
}

body.dark-mode .hero-description {
  color: var(--default-color) !important;
}

body.dark-mode .swiper p {
  color: var(--default-color) !important;
}

/* Ensure search popup content matches surface color in dark */
body.dark-mode .search-popup-content {
  background: var(--surface-color);
  color: var(--default-color);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6);
}

/* Nav menu in mobile overlay */
body.dark-mode .navmenu>ul {
  background-color: var(--nav-mobile-background-color);
}

body.dark-mode .navmenu li a {
  color: var(--nav-color);
}

/* Dropdown background */
body.dark-mode .navmenu .dropdown ul {
  background: var(--nav-dropdown-background-color);
  color: var(--nav-color);
  border: 1px solid rgba(255, 255, 255, 0.04);
}

/* Footer adjustments */
body.dark-mode .footer {
  background-color: var(--background-color);
  color: var(--default-color);
}

/* Cards and surfaces */
body.dark-mode .card,
body.dark-mode .features-cards .feature-card,
body.dark-mode .report .visual-content .main-image,
body.dark-mode .testimonials .testimonial-content {
  background: var(--background-color);
  border-color: rgba(255, 255, 255);
  color: var(--default-color);
}

body.dark-mode .report h2 {
  color: var(--contrast-color);
}

/* Accent buttons */
body.dark-mode .btn-getstarted,
body.dark-mode .btn-primary,
body.dark-mode .btn-cta {
  background: var(--accent-color);
  color: var(--contrast-color);
  border-color: transparent;
}

/* Links & accents */
body.dark-mode a {
  color: var(--accent-color);
}

body.dark-mode a:hover {
  color: color-mix(in srgb, var(--accent-color), white 10%);
}

/* Small tweaks for icons visibility */
body.dark-mode .open-search,
body.dark-mode .mobile-nav-toggle,
body.dark-mode .navmenu a i {
  color: var(--nav-color);
}

/* Table / list contrast */
body.dark-mode table,
body.dark-mode .list-group-item {
  background: transparent;
  color: var(--default-color);
}

/* Scroll top button visibility */
body.dark-mode .scroll-top {
  background-color: var(--background-color) !important;

}

body.dark-mode .scroll-top i {
  background-color: var(--background-color) !important;
  color: #ffffff !important;
}

body.dark-mode .change-mode {
  background-color: var(--background-color) !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6);
}

body.dark-mode .change-mode i {
  background-color: var(--background-color) !important;
  color: #ffffff !important;
}

/* Optional utility - class to force elements to use surface colors */
.dark-surface {
  background: var(--surface-color) !important;
  color: var(--default-color) !important;
  border-color: rgba(255, 255, 255, 0.03) !important;
}

/* Accessibility: ensure focus outlines visible in dark mode */
body.dark-mode :focus {
  outline-color: color-mix(in srgb, var(--accent-color), white 20%);
  outline-width: 3px;
  outline-style: solid;
  outline-offset: 2px;
}

/* ==========================
   DARK MODE STYLES
   ========================== */

/* Header */
body.dark-mode .header {
  background-color: var(--surface-color) !important;
  color: var(--default-color);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

body.dark-mode .header.sticky-top {
  background-color: rgba(7, 16, 37, 0.95);
  backdrop-filter: blur(6px);
}

/* Card */
body.dark-mode .card {
  color: #e0e0e0;
  border: 1px solid #9c9c9c;
}

/* Tabs wrapper */
body.dark-mode .tabs-wrapper {
  background-color: #1c1c1c;
  border-radius: 6px;
  padding: 10px;
}

/* Nav tabs */
body.dark-mode .tabs-wrapper .nav-tabs .nav-link {
  background-color: transparent;
  color: #bbb;
  border: none;
  transition: all 0.3s ease;
}

body.dark-mode .tabs-wrapper .nav-tabs .nav-link:hover,
body.dark-mode .tabs-wrapper .nav-tabs .nav-link.active {
  background-color: #333;
  color: #fff;
  border-radius: 4px;
}

/* Tab content (inner divs) */
body.dark-mode .tabs-wrapper .nav-tabs .nav-link .tab-content {
  color: #bbb;
  transition: all 0.3s ease;
}

body.dark-mode .tabs-wrapper .nav-tabs .nav-link:hover .tab-content,
body.dark-mode .tabs-wrapper .nav-tabs .nav-link.active .tab-content {
  color: #fff;
}

body.dark-mode .text-muted {
  color: var(--default-color) !important;
}

body.dark-mode .report body.dark-mode .report h2,
body.dark-mode .report p {
  color: var(--contrast-color) !important;
}

body.dark-mode .contact h2,
body.dark-mode .report p,
body.dark-mode .report .section-category,
body.dark-mode .report .info-item span,
body.dark-mode .report i {
  color: var(--contrast-color) !important;
}

body.dark-mode .svm h2,
body.dark-mode .svm p {
  color: var(--bs-heading-color);
}

body.dark-mode .contact h2,
body.dark-mode .contact p,
body.dark-mode .contact span,
body.dark-mode .contact .section-category,
body.dark-mode .contact i {
  color: var(--contrast-color) !important;
}

body.dark-mode .contact a {
  color: var(--contrast-color);
}

body.dark-mode .contact span.description-title {
  color: color-mix(in srgb, var(--heading-color), transparent 95%) !important;
}

body.dark-mode .card-text {
  color: var(--default-color) !important;
}

body.dark-mode .main .page-title h1,
body.dark-mode .main .page-title li,
body.dark-mode .main .page-title p,
body.dark-mode .main .page-title a {
  color: var(--contrast-color) !important;
}

.open-search-web {
  display: block;
}


body.dark-mode .navmenu li a:hover {
  color: var(--nav-hover-color);
}

/* Dark mode - mobile navmenu */
@media (max-width: 1199px) {

  body.dark-mode.mobile-nav-active .navmenu>ul,
  body.dark-mode .navmenu.mobile-nav-active>ul,
  body.dark-mode.mobile-nav-active .navmenu>ul.active,
  body.dark-mode .navmenu.mobile-nav-active>ul.active {
    display: block !important;
    position: absolute !important;
    background: #1e1e1e !important;
    z-index: 99999 !important;
    height: auto !important;
    min-height: 87.5vh !important;
    overflow: visible !important;
    padding: 10px 0 !important;
    inset: 60px 20px 20px 20px !important;
  }

  body.dark-mode.mobile-nav-active .navmenu>ul.dropdown-active,
  body.dark-mode .navmenu.mobile-nav-active>ul.dropdown-active,
  body.dark-mode.mobile-nav-active .navmenu>ul .dropdown-active,
  body.dark-mode .navmenu.mobile-nav-active>ul .dropdown-active {
    display: block !important;
    background: #1e1e1e !important;
    z-index: 99999 !important;
    height: auto !important;
    overflow: visible !important;
    padding: 10px 0 !important;
    inset: 60px 20px 20px 20px !important;
  }

  .open-search-web {
    display: none;
  }

  body.dark-mode.mobile-nav-active .navmenu,
  body.dark-mode .navmenu.mobile-nav-active {
    position: fixed !important;
    inset: 0 !important;
    z-index: 99998 !important;
    /* background: rgba(18, 18, 18, 0.95) !important; */
    overflow: visible !important;
  }

  body.dark-mode .navmenu li a {
    color: var(--nav-color);
  }

  body.dark-mode .navmenu li a.active {
    color: var(--nav-color);
  }
}


body.dark-mode .structure {
  background-color: var(--background-color);
}

body.dark-mode .main-timeline::after {
  background: var(--default-color);
}

body.dark-mode .timeline::after {
  background: var(--default-color);
}

body.dark-mode .timeline.card {
  border: #e0e0e0 1px solid !important;
}

body.dark-mode .poch-application-container .poch-content__viewport {
  background-color: #ff0000 !important;
}

body.dark-mode .nodeFemale .rocItem .rocItemContent {
  background-color: pink;
}

body.dark-mode .nodeMale .rocItem .rocItemContent {
  background-color: green;
}

body.dark-mode #tree svg {
  background-color: var(--background-color) !important;
}

body.dark-mode #tree .boc-controls svg {
  color: var(--background-color) !important;
  background-color: #fff !important;
}

body.dark-mode .change-mode {
  background-color: var(--default-color) !important;
  border: 1px solid var(--default-color) !important;
}

body.dark-mode .change-mode i {
  color: var(--background-color) !important;
  background-color: var(--default-color) !important;
}


body.dark-mode .scroll-top {
  background-color: var(--default-color) !important;
  border: 1px solid var(--default-color) !important;
}

body.dark-mode .scroll-top i {
  color: var(--background-color) !important;
  background-color: var(--default-color) !important;
}

/* End of dark-mode.css */