/* Dark Theme with Natural Color Images */

/* Images display in their natural colors - no filters applied */

/* Add more space between sections */
section {
  padding-top: 120px !important;
  padding-bottom: 120px !important;
  margin-bottom: 60px !important;
}

/* Exception for sections that should not have this spacing */
section#section-hero,
section.no-top,
section.no-bottom,
section.management-section {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* Desktop padding for benefits and luxury sections */
section.benefits-section {
  padding-top: 200px !important;
  padding-bottom: 250px !important;
  margin-bottom: 0 !important;
}

section.luxury-apartments-section {
  padding-top: 200px !important;
  padding-bottom: 250px !important;
  margin-bottom: 0 !important;
}

/* Header pricing boxes styling */
.pricing-header .price-box {
  padding: 15px 20px;
  background-color: transparent;
  border-right: 1px solid rgba(255, 255, 255, 0.5);
  transition: all 0.3s ease;
  text-align: left;
}

.pricing-header .col-md-3:last-child .price-box {
  border-right: none;
}

.pricing-header .price-box:hover {
  transform: translateY(-5px);
}

.pricing-header .price-amount {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 5px;
}

.pricing-header .price-duration {
  font-size: 14px;
  opacity: 0.8;
}

/* Increase hero section height */
.mh-800 {
  min-height: 800px !important;
}

/* Availability button styling */
.btn-availability {
  display: inline-block;
  padding: 15px 40px;
  background-color: transparent;
  color: #ffffff;
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  border: 2px solid #ffffff;
  transition: all 0.3s ease;
  text-decoration: none;
}

.btn-availability:hover {
  background-color: #ffffff;
  color: #000000;
}

/* Car brand tags styling */
.car-brands {
  display: flex;
  gap: 10px;
}

.car-brand-tag {
  display: inline-block;
  padding: 4px 10px;
  background-color: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
}

/* Car carousel styling */
.car-carousel-container {
  position: relative;
  overflow: hidden;
  height: 100%;
}

.car-image-container {
  height: 600px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.car-image-container img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}

#car-carousel .owl-dots {
  position: absolute;
  bottom: 40px;
  width: 100%;
  text-align: center;
}

#car-carousel .owl-dot span {
  background: rgba(255, 255, 255, 0.5);
}

#car-carousel .owl-dot.active span {
  background: #ffffff;
}

/* Booking buttons styling */
.booking-buttons {
  display: flex;
  flex-direction: column;
  width: calc(100% - 20px);
  margin-right: 20px;
}

.btn-booking {
  display: block;
  padding: 12px 20px;
  background-color: #000000;
  color: #ffffff;
  font-size: 16px;
  font-weight: 500;
  border: 1px solid #ffffff;
  transition: all 0.3s ease;
  text-decoration: none;
  width: 100%;
}

.btn-booking:hover {
  background-color: #ffffff;
  color: #000000;
  text-decoration: none;
}

/* Add dividers between sections for better visual separation */
section:not(#section-hero):not(.no-divider):not(.management-section):before {
  content: '';
  height: 1px;
  background-color: rgba(255,255,255,0.1);
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

/* Make menu items all caps and match button typography */
#mainmenu a.menu-item {
  text-transform: uppercase !important;
  font-size: 14px !important;
  letter-spacing: 1px !important;
  font-weight: 500 !important;
}

/* Fix header and hero section z-index issues */
header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  z-index: 2000 !important;
  background-color: rgba(0,0,0,0.85) !important;
}

header.transparent {
  background-color: rgba(0,0,0,0.85) !important;
}

#section-hero {
  position: relative !important;
  z-index: 1000 !important;
  padding-top: 100px !important;
  margin-top: 0 !important;
}

body {
  padding-top: 80px !important; /* Add space for fixed header */
}

/* Change facilities sections to white background with black text */
section.bg-dark.section-dark.text-light {
  background-color: #ffffff !important;
}

section.bg-dark.section-dark.text-light .subtitle,
section.bg-dark.section-dark.text-light h2,
section.bg-dark.section-dark.text-light p,
section.bg-dark.section-dark.text-light li,
section.bg-dark.section-dark.text-light .ul-check {
  color: #000000 !important;
}

/* Override any background colors with grayscale values */
.bg-dark {
  background-color: #222222 !important;
}

.section-dark {
  background-color: #111111 !important;
}

/* Ensure text colors are properly contrasted */
.text-light {
  color: #ffffff !important;
}

body {
  color: #333333;
}

/* Style buttons in black and white */
.btn-main {
  background-color: #000000;
  color: #ffffff;
}

.btn-line {
  border-color: #000000;
}

/* Override any colored gradients */
.gradient-edge-bottom {
  background: linear-gradient(to top, rgba(0,0,0,0.8), transparent) !important;
}

.gradient-soft, .gradient-soft-2, .gradient-soft-45 {
  background: linear-gradient(180deg, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0) 100%) !important;
}

/* Override any colored overlays */
.sw-overlay {
  background-color: rgba(0,0,0,0.4) !important;
}

/* Style hover effects */
.hover .bg-blur {
  background-color: rgba(0,0,0,0.7) !important;
}

/* Make header black and sticky */
header.transparent {
  background-color: #000000 !important;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  transition: all 0.3s ease;
}

header.transparent.logo-center {
  background-color: #000000 !important;
  border-bottom: 1px solid #333333;
}

/* Add padding to body to prevent content from being hidden under sticky header */
body {
  padding-top: 80px;
}

/* Make footer icons smaller and white */
footer .icon_phone,
footer .icon_clock,
footer .icon_mail {
  font-size: 40px !important;
  color: #ffffff !important;
}

/* Override any id-color class in the footer to make icons white */
footer .id-color {
  color: #ffffff !important;
}

/* Make social media icons in subfooter smaller and white */
.social-icons a i {
  font-size: 14px !important;
  color: #ffffff !important;
}

/* Mobile menu fixes */
@media only screen and (max-width: 992px) {
  /* Fix mobile menu button color */
  #menu-btn {
    color: #ffffff !important;
  }
  
  /* Fix mobile menu background */
  #mainmenu {
    background-color: #000000 !important;
    border-right: 1px solid #333333 !important;
    left: 0 !important;
    padding-left: 20px !important;
  }
  
  /* Fix mobile menu items */
  #mainmenu li {
    border-bottom: solid 1px #333333 !important;
  }
  
  #mainmenu a.menu-item {
    color: #ffffff !important;
  }
  
  #mainmenu a.menu-item:hover {
    background: #333333 !important;
  }
  
  /* Fix header on mobile */
  header, header.fixed {
    background: #000000 !important;
    position: fixed !important;
    width: 100% !important;
    top: 0 !important;
  }
  
  /* Add padding to body for fixed header on mobile */
  body {
    padding-top: 90px !important;
  }

  /* Mobile padding for Výnimočná lokalita section */
  section.luxury-apartments-section {
    padding: 125px 0 !important;
  }

  /* Mobile padding for Starostlivosť section */
  section.benefits-section {
    padding: 125px 0 !important;
  }
}
