/* Header Component Styles */

/* Main Header Styles */
.theme-main-menu {
  background: #fff;
  position: relative;
  z-index: 999;
  padding: 15px 40px;
  -webkit-transition: all 0.4s ease-in-out 0s;
  -moz-transition: all 0.4s ease-in-out 0s;
  -ms-transition: all 0.4s ease-in-out 0s;
  -o-transition: all 0.4s ease-in-out 0s;
  transition: all 0.4s ease-in-out 0s;
}

.theme-main-menu.menu-overlay {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  background: transparent;
}

.theme-main-menu.fixed {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 999;
  background: rgba(237, 241, 238, 0.8) !important;
  backdrop-filter: blur(10px);
}

.theme-main-menu.menu-style-two {
  padding: 0;
  background: #EDF1EE;
}

.theme-main-menu.menu-style-two .info-row {
  padding-top: 12px;
  padding-bottom: 12px;
  overflow: hidden;
}

.theme-main-menu.menu-style-two .gap-fix {
  padding-left: 40px;
  padding-right: 40px;
}

.theme-main-menu.menu-style-two .greetings {
  font-size: 18px;
  color: #19352D;
}

.theme-main-menu.menu-style-two .contact-info {
  margin: 0 -15px;
}

.theme-main-menu.menu-style-two .contact-info li {
  padding: 0 15px;
}

.theme-main-menu.menu-style-two .contact-info li a {
  font-size: 18px;
  color: #19352D;
}

.theme-main-menu.menu-style-two .contact-info li a:hover {
  text-decoration: underline;
}

.theme-main-menu.menu-style-two .inner-content {
  padding: 8px 0;
  border-top: 1px solid #E0E0E0;
}

.theme-main-menu.menu-style-two .inner-content .btn--waitlist {
  color: black;
  background-color: #ccf080;
  font-weight: 500;
  padding: 8px 20px;
  border: 2px solid black;
  border-radius: 40px;
}

.theme-main-menu.menu-style-two .inner-content .logo img {
  width: 150px;
}

.theme-main-menu.menu-style-two.fixed .info-row {
  display: none;
}

.theme-main-menu.menu-style-two.fixed {
  padding: 0;
}

/* Navbar Toggler Styles */
.theme-main-menu .navbar-toggler {
  width: 48px;
  height: 44px;
  padding: 0;
  border-radius: 0.375rem;
  position: relative;
  border: none;
  background: #ccf080;
}

.theme-main-menu.menu-style-three .navbar-toggler {
  background: #000;
}

.theme-main-menu.menu-style-four .navbar-toggler {
  background: #E6FD5A;
}

.theme-main-menu.menu-style-five .navbar-toggler {
  background: #DFFF5E;
}

.theme-main-menu .navbar-toggler:focus {
  box-shadow: none;
}

.theme-main-menu .navbar-toggler::before,
.theme-main-menu .navbar-toggler::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 11px;
  width: 26px;
  height: 2px;
  transform-origin: 50% 50%;
  background: #29594B;
}

.theme-main-menu .navbar-toggler span {
  position: absolute;
  left: 11px;
  overflow: hidden;
  width: 26px;
  height: 2px;
  top: 50%;
  transition: opacity 0.25s;
  background: #29594B;
}

.theme-main-menu.menu-style-three .navbar-toggler:before, 
.theme-main-menu.menu-style-three .navbar-toggler:after, 
.theme-main-menu.menu-style-three .navbar-toggler span {
  background: #fff;
}

.theme-main-menu .navbar-toggler::before {
  -webkit-transform: translate3d(0, -9px, 0) scale3d(1, 1, 1);
  transform: translate3d(0, -9px, 0) scale3d(1, 1, 1);
}

.theme-main-menu .navbar-toggler::after {
  -webkit-transform: translate3d(0, 8px, 0) scale3d(1, 1, 1);
  transform: translate3d(0, 8px, 0) scale3d(1, 1, 1);
}

.theme-main-menu .navbar-toggler[aria-expanded=true] span {
  opacity: 0;
}

.theme-main-menu .navbar-toggler[aria-expanded=true]::before {
  -webkit-transform: rotate3d(0, 0, 1, 45deg);
  transform: rotate3d(0, 0, 1, 45deg);
}

.theme-main-menu .navbar-toggler[aria-expanded=true]::after {
  -webkit-transform: rotate3d(0, 0, 1, -45deg);
  transform: rotate3d(0, 0, 1, -45deg);
}

/* Navigation Styles */
.theme-main-menu .nav-item .nav-link {
  font-family: "Satoshi";
  font-weight: 500;
  font-size: 16px;
  color: #19352D;
  text-transform: capitalize;
  line-height: 1.2;
  padding: 20px 0;
  margin: 0 30px;
  -webkit-transition: all 0.2s ease-in-out 0s;
  -moz-transition: all 0.2s ease-in-out 0s;
  -ms-transition: all 0.2s ease-in-out 0s;
  -o-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
}

.theme-main-menu .nav-item:hover .nav-link {
  color: #0C3A30;
}

.theme-main-menu.white-vr .nav-item .nav-link {
  color: #fff;
}

.theme-main-menu.white-vr .nav-item:hover .nav-link {
  color: #ccf080;
}

.theme-main-menu.white-vr.fixed {
  background: #0C3A30;
  border: none;
}

.theme-main-menu.menu-style-one {
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.theme-main-menu.menu-style-six .nav-item .nav-link {
  color: #044F3B;
}

.theme-main-menu.menu-style-six .nav-item:hover .nav-link {
  color: #0C3A30;
}

.theme-main-menu .navbar {
  position: static;
}

/* Dropdown Menu Styles */
.navbar .dropdown-menu .dropdown-item {
  text-transform: capitalize;
  line-height: 35px;
  color: #19352D;
  font-size: 16px;
  font-weight: 500;
  padding: 8px 20px;
  -webkit-transition: all 0.2s ease-in-out 0s;
  -moz-transition: all 0.2s ease-in-out 0s;
  -ms-transition: all 0.2s ease-in-out 0s;
  -o-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
  display: flex;
  align-items: center;
}

.navbar .dropdown-menu .dropdown-item span {
  position: relative;
  transition: color .2s ease;
}

.navbar .dropdown-menu .dropdown-item:hover span {
  color: rgba(0, 0, 0, 0.5);
}

.navbar [class*=mega-dropdown] .dropdown-menu {
  padding: 0 0 15px;
  margin: 0;
  right: 0;
}

.navbar .mega-dropdown-sm .dropdown-menu {
  min-width: 600px;
  left: 0;
  padding: 10px;
}

.navbar [class*=mega-dropdown] .menu-column {
  padding: 5px 0;
}

.navbar [class*=mega-dropdown] .menu-column .mega-menu-title {
  font-family: "Satoshi";
  font-size: 14px;
  font-weight: 500;
  color: #19352D;
  text-transform: capitalize;
  line-height: 1.2;
  padding-left: 15px;
}

/* Button Styles */
.theme-main-menu .login-btn-one a {
  color: #000;
}

.theme-main-menu .login-btn-one a:hover {
  text-decoration: underline;
}

.theme-main-menu .login-btn-two a {
  color: #044F3B;
}

.theme-main-menu .login-btn-two a:hover {
  text-decoration: underline;
}

.theme-main-menu .signup-btn-one span {
  display: inline-block;
  font-weight: 500;
  color: #19352D;
  line-height: 49px;
  padding: 0 30px;
  border: 1px solid #29594B;
  border-radius: 40px;
  -webkit-transition: all 0.2s ease-in-out 0s;
  -moz-transition: all 0.2s ease-in-out 0s;
  -ms-transition: all 0.2s ease-in-out 0s;
  -o-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
}

.theme-main-menu .signup-btn-one .icon {
  width: 49px;
  height: 49px;
  background: #29594B;
  color: #fff;
  line-height: 49px;
  text-align: center;
  border-radius: 50%;
  margin-left: 10px;
  -webkit-transition: all 0.2s ease-in-out 0s;
  -moz-transition: all 0.2s ease-in-out 0s;
  -ms-transition: all 0.2s ease-in-out 0s;
  -o-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
}

.theme-main-menu .signup-btn-one:hover span {
  background: #29594B;
  color: #fff;
}

.theme-main-menu .signup-btn-one:hover .icon {
  background: #ccf080;
  color: #29594B;
}

.theme-main-menu .signup-btn-two {
  color: #044F3B;
  line-height: 50px;
  border: 1px solid #044F3B;
  border-radius: 40px;
  padding: 0 32px;
  text-align: center;
}

.theme-main-menu .signup-btn-two:hover {
  background: #29594B;
  color: #fff;
}

.theme-main-menu .quote-one {
  line-height: 48px;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  border: 1px solid #fff;
  border-radius: 40px;
}

.theme-main-menu .quote-one:hover {
  background: #ccf080;
  color: #19352D;
}

/* Header-specific waitlist button styling */
.theme-main-menu.menu-style-two .inner-content .btn--waitlist {
  color: black;
  background-color: #ccf080;
  font-weight: 500;
  padding: 8px 20px;
  border: 2px solid black;
  border-radius: 40px;
}

/* Hide Join Waitlist button on mobile devices */
@media (max-width: 991px) {
  .theme-main-menu .btn--waitlist {
    display: none !important;
  }
}

/* Locale Switcher Styles */
.locale-switcher {
  position: relative;
  display: inline-block;
  margin-right: 15px;
}

.locale-switcher__current {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid #e0e0e0;
  transition: all 0.3s ease;
}

.locale-switcher__current:hover {
  border-color: #19352D;
  box-shadow: 0 2px 8px rgba(25, 53, 45, 0.15);
}

.locale-switcher__flag {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
}

.locale-switcher__dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  background: white;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  z-index: 1000;
  margin-top: 5px;
}

.locale-switcher:hover .locale-switcher__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.locale-switcher__option {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  border-bottom: 1px solid #f5f5f5;
  white-space: nowrap;
}

.locale-switcher__option:last-child {
  border-bottom: none;
}

.locale-switcher__option:hover {
  background-color: #f8f9fa;
}

.locale-switcher__option .locale-switcher__flag {
  margin-right: 12px;
  width: 20px;
  height: 20px;
}

.locale-switcher__language {
  font-size: 14px;
  color: #333;
  font-weight: 500;
}

/* Desktop Dropdown Styles */
@media screen and (min-width: 992px) {
  .navbar .dropdown-menu {
    font-size: 1em;
    z-index: 5;
    background-color: #fff;
    border: 0;
    border-radius: 10px;
    box-shadow: 0 20px 30px -10px rgba(0, 0, 0, 0.15);
    padding: 0;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transform-origin: 0 0;
    transition: all 0.3s ease-out;
  }

  .navbar .dropdown-menu:before {
    content: "";
    position: absolute;
    left: 30px;
    top: -17px;
  }

  .navbar .dropdown-menu .dropdown-menu {
    left: calc(100% + 5px);
    top: 0;
    right: auto;
    box-shadow: 0 20px 30px -10px rgba(0, 0, 0, 0.15);
    transform: translateY(0);
  }

  .navbar .dropdown:hover > .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  .navbar .dropdown-toggle::after {
    display: none;
  }

  .navbar .show.dropdown-toggle::after {
    transform: rotate(180deg);
  }
}

/* Mobile Styles */
@media screen and (max-width: 991px) {
  .navbar {
    padding: 0;
  }

  .navbar-collapse .logo {
    margin-bottom: 10vh;
    padding-left: 12px;
  }

  .white-vr .navbar-collapse {
    background-color: #0C3A30;
  }

  .navbar-collapse {
    position: fixed;
    top: 0;
    background-color: #EDF1EE;
    width: 100%;
    height: 100vh;
    left: 0;
    z-index: 9999;
    padding: 16px 0 20px;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  /* Close button for mobile menu */
  .navbar-collapse .mobile-menu-close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    font-size: 24px;
    color: #000;
    cursor: pointer;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.3s ease;
  }

  .navbar-collapse .mobile-menu-close:hover {
    background-color: rgba(0, 0, 0, 0.1);
    color: #000;
  }

  .white-vr .navbar-collapse .mobile-menu-close {
    color: #fff;
  }

  .white-vr .navbar-collapse .mobile-menu-close:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: #fff;
  }

  /* Also disable html scroll for better compatibility */
  .navbar-collapse.show {
    transform: translateX(0);
    box-shadow: 15px 0 25px rgba(35, 35, 35, 0.09);
  }

  .theme-main-menu .navbar .mega-dropdown {
    position: relative;
  }

  .navbar .navbar-nav .nav-link {
    margin: 0;
    padding: 15px 12px;
    border-top: 1px dashed rgba(0, 0, 0, 0.1);
  }

  .navbar .navbar-nav .logo {
    width: 150px;
  }

  .white-vr .navbar .navbar-nav .nav-link {
    border-top: 1px dashed rgba(255, 255, 255, 0.15);
  }

  .navbar .dropdown-menu .dropdown-item {
    padding: 0 10px;
    line-height: 46px;
  }

  .navbar .dropdown-menu {
    border: none;
    padding: 0;
    margin: 0;
    background: #fff;
  }

  .navbar [class*=mega-dropdown] .dropdown-menu {
    padding: 0;
    min-width: 100%;
  }

  .navbar [class*=mega-dropdown] .menu-column {
    padding: 0;
  }

  .navbar .dropdown-toggle::after {
    position: absolute;
    right: 15px;
    top: calc(50% - 2px);
  }

  .dashboard-menu .nav-link::before {
    right: auto;
    left: 0;
  }

  /* Hide Join Waitlist button on mobile devices */
  .theme-main-menu .btn--waitlist {
    display: none !important;
  }
}

/* Responsive Styles */
@media (min-width: 1200px) {
  .theme-main-menu {padding: 15px 25px;}
  .theme-main-menu.menu-style-two .gap-fix {padding-left: 25px; padding-right: 25px;}
  .theme-main-menu.menu-style-five .inner-content {padding: 16px 25px;}
}

@media (max-width: 1199px) {
  .theme-main-menu {padding: 10px 12px;}
  .theme-main-menu.menu-style-two .gap-fix {padding-left: 12px; padding-right: 12px;}
  .theme-main-menu.menu-style-five .inner-content {padding: 12px; border-radius: 15px;}
  .theme-main-menu.menu-style-two.fixed .inner-content {border: none;}
  .theme-main-menu .nav-item .nav-link {font-size: 16px;}
  .navbar .dropdown-menu .dropdown-item {font-size: 17px;}
}

@media (min-width: 992px) and (max-width: 1199px) {
  .theme-main-menu .nav-item .nav-link {margin: 0 20px;}
}

@media (max-width: 991px) {
  .theme-main-menu.fixed {padding-top: 10px; padding-bottom: 10px;}
  .theme-main-menu.menu-style-two.fixed {padding: 0;}
}

/* Category Menu Styles */
.category-menu {
  border-top: 1px solid #E9E9E9;
  border-bottom: 1px solid #E9E9E9;
  padding: 0 40px;
}

.category-menu li {
  position: relative;
  padding: 0 15px;
}

.category-menu li a {
  font-size: 15px;
  font-weight: 500;
  color: #536159;
  text-transform: capitalize;
  line-height: 1.2;
  padding: 20px 0;
  -webkit-transition: all 0.2s ease-in-out 0s;
  -moz-transition: all 0.2s ease-in-out 0s;
  -ms-transition: all 0.2s ease-in-out 0s;
  -o-transition: all 0.2s ease-in-out 0s;
  transition: all 0.2s ease-in-out 0s;
}

.category-menu li a:hover {
  color: #0C3A30;
}

.category-menu .dropdown-menu {
  padding: 0;
}

.category-menu .dropdown-menu li {
  padding: 0;
}

.category-menu .dropdown-menu li a {
  padding: 8px 15px;
  font-size: 14px;
}

/* Dashboard Menu Styles */
.dashboard-menu .nav-link::before {
  right: auto;
  left: 0;
  top: -2px;
}

/* Body Menu Open State */
body.menu-open {
  overflow: hidden !important;
}

/* Logo Styles */
.ogvio-logo {
  height: 25px;
}

@media (max-width: 767px) {
  .ogvio-logo {
    height: 20px;
  }
}

/* Contact Button Styles - Moved to global.css */

/* Hero Banner Right Widget Styles */
.hero-banner-three .right-widget .main-count {
  font-size: 58px;
  margin: -17px 0 -4px;
  color: #000;
}

/* Soon Badge Styles - Base styles moved to global.css */

/* Additional Responsive Styles */
@media (max-width: 1199px) {
  .navbar .dropdown-menu .dropdown-item {font-size: 17px;}
}

@media (min-width: 992px) and (max-width: 1199px) {
  .theme-main-menu .nav-item .nav-link {margin: 0 20px;}
}

@media (max-width: 991px) {
  .theme-main-menu.fixed {padding-top: 10px; padding-bottom: 10px;}
  .theme-main-menu.menu-style-two.fixed {padding: 0;}
}

/* Additional Responsive Styles from responsive.css */
@media (min-width: 1200px) and (max-width: 1399px) {
  .theme-main-menu {padding: 15px 25px;}
  .theme-main-menu.menu-style-two .gap-fix {padding-left: 25px; padding-right: 25px;}
  .theme-main-menu.menu-style-five .inner-content {padding: 16px 25px;}
}

@media (max-width: 1199px) {
  .theme-main-menu {padding: 10px 12px;}
  .theme-main-menu.menu-style-two .gap-fix {padding-left: 12px; padding-right: 12px;}
  .theme-main-menu.menu-style-five .inner-content {padding: 12px; border-radius: 15px;}
  .theme-main-menu.menu-style-two.fixed .inner-content {border: none;}
  .theme-main-menu .nav-item .nav-link {font-size: 16px;}
  .navbar .dropdown-menu .dropdown-item {font-size: 17px;}
}

@media (min-width: 992px) and (max-width: 1199px) {
  .theme-main-menu .nav-item .nav-link {margin: 0 20px;}
}

@media (max-width: 991px) {
  .theme-main-menu.fixed {padding-top: 10px; padding-bottom: 10px;}
  .theme-main-menu.menu-style-two.fixed {padding: 0;}
}
