
@font-face{
    font-family: "ITC Blair W02 Bold";
    src: url("22b70f43836adaf193ffa8f48834c984.eot");
    src: url("22b70f43836adaf193ffa8f48834c984.eot?#iefix")format("embedded-opentype"),
        url("22b70f43836adaf193ffa8f48834c984.woff")format("woff"),
        url("22b70f43836adaf193ffa8f48834c984.woff2")format("woff2"),
        url("22b70f43836adaf193ffa8f48834c984.ttf")format("truetype"),
        url("22b70f43836adaf193ffa8f48834c984.svg#ITC Blair W02 Bold")format("svg");
    font-weight:normal;
    font-style:normal;
    font-display:swap;
  }

  @font-face {
    font-family: 'BlairITCStdRegular'; /* The name you want to use for the font */
    src: url('Fonts/Blair\ ITC\ Std\ Regular.otf') format('opentype'); /* Adjust the path based on where you placed your font file */
    font-weight: normal;
    font-style: normal;
  }
  
.main{
        
    background-image: url("Pictures-Screenshots/backgrounds/white-simple-textured-design-background.jpg ");
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    background-color: #f4f4f4;

    background-size: cover;
    background-attachment: fixed; /* This will keep the background fixed while scrolling */
    background-position: center;
    background-repeat: no-repeat;
  }
  
  /*apply this font across all h2 and h4 elements*/
  
  h2{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 22px;
  }
  
  
  
  h1{
    font-family: 'BlairITCStdRegular', sans-serif;
   
  }

  .logo{
    font-family: 'Dancing Script', sans-serif;
    color: black
  }
  
  p{
    font-family: "Titillium Web";
   }
    
  
  .column {
    float: left;
    width: 50%;
    /* padding: 5px; */
    flex: 1 1 750px;
    color: black;
  }
  
  
  .column h4{
  font-family: "Titillium Web";
  font-size: medium;
  }

  .video-container {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-style: solid;
    border-color: #1111117a;
}

#background-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ensures the video covers the entire container */
}

.service-box-row{
  position: relative;
  z-index: 1; /* Ensures the content is above the video */
  background-color: rgba(255, 255, 255, 0.8); /* Optional: adds a slight white background for better readability */
  padding: 20px;
  border-radius: 8px;
}


/* Specific container for the booking form */
.booking-form-row {
  margin-top: 10px;
  font-family: "Titillium Web";
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 10px;
  z-index: 1;
}



.booking-form-column {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 25px;
    box-sizing: border-box;
}


.booking-room-selection-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly;
  align-items: center;
  gap: 20px; /* Adds space between items */
  padding: 20px;
  background-color: #f9f9f9;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  position: relative;
  
}


.booking-room-selection-item {
  width: 180px;
  position: relative; /* Ensure that dropdown positions relative to this */
}

#decluttering{
  
  max-width: 170px; /* Resets max width for mobile */
  min-width: auto; /* No minimum width in mobile */
}

@media screen and (max-width: 768px) {
  .booking-room-selection-item {
      flex: 1 1 100%; /* Ensures buttons take full width in mobile view */
      max-width: 180px; /* Resets max width for mobile */
      min-width: auto; /* No minimum width in mobile */
  }


  #decluttering{
    flex: 1 1 100%; /* Ensures buttons take full width in mobile view */
    max-width: 170px; /* Resets max width for mobile */
    min-width: auto; /* No minimum width in mobile */
}
}

@media screen and (max-width: 310px){
  .booking-room-selection-item {
    flex: 1 1 100%; /* Ensures buttons take full width in mobile view */
    max-width: 180px; /* Resets max width for mobile */
    min-width: auto; /* No minimum width in mobile */
}
}

.dropdown-toggle {
  width: 100%;
  background-color: white;
  color: black;
  border: none;
  border-radius: 4px;
  padding: 10px;
  cursor: pointer;
  text-align: left;
  font-size: 16px;
  transition: background-color 0.3s ease;
  display: flex;
  align-items: center;
  white-space: nowrap;
}

.dropdown-toggle:hover {
  background-color: #d6d6d6;
}

.dropdown-toggle:hover,
.active-dropdown { /* Maintain hover-like style when active */
    background-color: #d6d6d6;
}

.dropdown-icon {
  width: 35px;
  height: 31px;
  margin-right: 10px; /* Adds space between icon and text */
  border-radius: 5%;
}

.visible-count {
  font-family: 'BlairITCStdRegular', sans-serif;
  color: #000000;
  padding: 2px 10px;
  font-size: 17px;
  margin-left: 10px; /* Adds space between text and count */
}

.booking-room-dropdown {
  display: none;
  position: absolute;
  top: 100%; /* Position the dropdown just below the button */
  left: 0;
  width: 150px; /* Set a fixed width for the dropdown */
  background-color: white;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  padding: 10px;
  z-index: 1; /* Ensure it's above other content */
  border-radius: 4px;
}

.show-dropdown {
  display: block;
}

.booking-room-counter {
  font-family: 'Courier New', Courier, monospace;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 65px;
}

.booking-room-counter span{
  font-family: 'BlairITCStdRegular', sans-serif;
  background-color: #fff;
  color: #007bff;
  padding: 2px 8px;
  
  border-radius: 12px;
}

.dropdown-description {
  font-size: 14px;
  color: #555;
  margin-bottom: 10px; /* Space between description and counter */
  text-align: center;
}

.booking-button {
  background-color: #007bff;
  color: white;
  border: none;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: background-color 0.3s ease;
}

.booking-button:hover {
  background-color: #0056b3;
}

#bedroom-count, #living-room-count, #kitchen-count, #laundry-count {
  font-size: 16px;
  width: 40px;
  text-align: center;
}

/* Date and Time Picker Container */
.date-time-container {
  display: flex;
  gap: 20px;
  margin-top: 20px;
  background-color: #f9f9f9;
  padding: 20px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  border-radius: 12px;
}

@media screen and (max-width: 768px) {
  .date-time-container{
    display: block;
  }
}

.date-picker, .time-picker {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.date-picker label, .time-picker label {
  font-size: 16px;
  margin-bottom: 5px;
}

#booking-date, #booking-time {
  padding: 10px;
  font-size: 16px;
  border-radius: 5px;
  border: 1px solid #ccc;
  width: 200px;
  box-sizing: border-box;
}

#booking-date:focus, #booking-time:focus {
  border-color: #007bff;
  outline: none;
}


/* Mobile view - Stack date and time fields */
@media screen and (max-width: 768px) {
  .booking-date-time-item {
      flex-direction: column;
      align-items: flex-start;
      width: 100%;
  }

  .booking-input-field, .booking-dropdown {
      width: 100%; /* Full width on mobile */
      margin-bottom: 10px; /* Space between fields when stacked */
  }
}

  

  .submit-button {
    text-decoration: none;
    color: white;
    font-size: 20px; /* Base font size */
    border: 2px solid #ffffff;
    padding: 12px 30px; /* Base padding */
    background-color: #08488d;
    font-family: "Titillium Web", sans-serif;
    border-radius: 5px;
    opacity: 0.75;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    margin: 10px; /* Margin for spacing between items */
    text-align: center;
  }
  
  .submit-button:hover{
    background-color: #08488dc6;
    border-color: #468ac5;
    opacity: 1;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
    transform: translateY(-3px);
  }


  .button {
    
    font-size: 18px;
    width: 30px;
    height: 30px;
    cursor: pointer;
    border-radius: 50%;
    border: none;
    background-color: #08488d;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s;
  }
  
  .button:hover {
    background-color: #0056b3;
  }
  
  .booking-room-counter span {
    font-size: 16px;
    width: 40px;
    text-align: center;
}
  
  .dropdown, .input-field {
    padding: 8px;
    font-size: 14px;
    border-radius: 5px;
    border: 1px solid #ddd;
    background-color: #f9f9f9;
    transition: border-color 0.3s, box-shadow 0.3s;
    width: 100%;
  }
  
  .dropdown:focus, .input-field:focus {
    border-color: #007bff;
    box-shadow: 0 0 5px rgba(0, 123, 255, 0.5);
  }
  
  @media (max-width: 768px) {
    .room-selection-container {
        padding: 10px;
        flex-direction: column;
        gap: 10px;
    }
  
    .room-selection-item, .date-time-item {
        width: 100%;
        flex-direction: row;
        justify-content: space-between;
    }
  
    .room-counter {
        gap: 8px;
    }
  
    .button {
        width: 28px;
        height: 28px;
        font-size: 16px;
    }
  
    #bedroom-count, #bathroom-count {
        font-size: 16px;
    }
  
    .dropdown, .input-field {
        max-width: 150px;
    }
  
    label {
        margin-right: 10px;
        margin-bottom: 0;
    }
  }
  
  @media (max-width: 480px) {
    .room-selection-container {
        padding: 8px;
    }
  
    .room-selection-item, .date-time-item {
        flex-direction: column;
        align-items: flex-start;
    }
  
    .room-counter {
        width: 100%;
        justify-content: space-between;
    }
  
    .button {
        width: 26px;
        height: 26px;
        font-size: 14px;
    }
  
    #bedroom-count, #bathroom-count {
        font-size: 14px;
    }
  
    .dropdown, .input-field {
        width: 100%;
        font-size: 13px;
        padding: 6px;
    }
  }
  
  .services-container {
  width: 70%;
  margin: 0 auto;
  border: 2px solid #a5a5a56b;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  background-color: #fff;
  font-family: "Titillium Web";
  }
  
  .additional-services {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  
  .additional-services h3{
    font-family: "Titillium Web";
  }
  .additional-services p{
    font-family: "Titillium Web";
  }

  .service-option {
    padding: 10px;
    background-color: #f9f9f9;
    border: 1px solid #ddd;
    cursor: pointer;
    display: flex;
    align-items: center;
    font-size: 16px;
    margin-bottom: 10px;
    border-radius: 5px;
    transition: background-color 0.3s;
  }
  
  .service-option.active {
    background-color: #e0e0e0;
  }
  
  .service-option.locked {
    background-color: #ffe54fb2; /* Different background for locked services /
    cursor: default; / No pointer cursor to indicate it's non-interactive */
  }
  
  .check-icon {
    display: none;
    color: #35689f;
    font-size: 18px;
  }
  
  .service-option.active .check-icon {
    display: inline;
  }
  
  .service-option.locked .service-title::before {
    content: '★ ';
    color: orange;
  }
  
  .service-details {
    display: none;
    list-style: none;
    padding: 0;
    margin: 5px 0 0 20px;
  }
  
  .service-image {
  width: 40px;  /* Adjust the size of the image tile */
  height: 40px;
  object-fit: cover; /* Ensure the image covers the tile without distortion */
  border-radius: 5px; /* Optional: Rounded corners for the image */
  margin-right: 10px; /* Space between the image and the service title */
  }
  
  .size-option {
    padding: 8px;
    background-color: #f2f2f2;
    border: 1px solid #ccc;
    cursor: pointer;
    margin: 5px 0;
    border-radius: 5px;
  }
  
  .size-option:hover {
    background-color: #d8d8d8;
  }
  
  .total-price-container {
    margin-top: 60px;
    font-size: 22px; /* Slightly larger for emphasis */
    font-weight: bold;
    text-align: center;
    font-family: "ITC Blair W02 Bold", sans-serif;
    background-color: #f9f9f9; /* Matches the form's background color */
    padding: 15px; /* Added padding for space around the text */
    border-radius: 8px; /* Rounded corners for consistency */
    border: 2px solid #a5a5a56b; /* Matches the border style of other elements */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Soft shadow for depth */
    color: #333; /* Darker text color to enhance readability */
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

  
  @media (max-width: 768px) {
    .room-selection-container {
        flex-direction: column;
        padding: 15px;
    }
  
    .room-selection, .date-time-selection {
        flex-direction: column;
        align-items: flex-start;
        width: 100%;
    }
  
    .input-field {
        width: 100%;
    }
  
    .service-option {
        font-size: 14px;
    }
  
    .button {
        width: 30px;
        height: 30px;
        font-size: 18px;
    }
  }
  
  @media (max-width: 480px) {
    .service-option {
        padding: 8px;
    }
  
    .button {
        width: 28px;
        height: 28px;
        font-size: 16px;
    }
  
    .room-selection-container {
        padding: 10px;
    }
  
    .room-selection label,
    .date-time-selection label {
        font-size: 14px;
    }
  }
  
  /*Header*/
  .header {
  padding: 8px;
  text-align: center;
  background: white;
  padding-top: 80px;
  }
  
  
  .header h5 {
  font-family: 'Dancing Script', sans-serif;
  font-size: x-large;
  color: rgb(7, 177, 7);
  }
  
  .header h4 {
  font-family: 'Dancing Script', sans-serif;
  font-size: x-large;
  color: black
  }
  
  .header h4.light{
  color: black
  }
  
  .header h1 {
  font-size: 36px;
  }
  
  
  
  .navbar {
    
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 20px;
  background-color: #ffffff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 10;
  height: 80px; /* Set the height to ensure consistency */
  font-family: "ITC Blair W02 Bold";
  }
  
  /* Logo */
  .logo a {
  font-size: 24px;
  font-weight: bold;
  color: #2c3e50;
  text-decoration: none;
  line-height: 80px; /* Ensures the logo text is vertically centered */
  }
  
  /* Navbar links */
  .nav-links {
  list-style: none;
  display: flex;
  gap: 20px;
  height: 100%; /* Make sure links align with the navbar height */
  }
  
  .nav-links li a {
  font-family: 'BlairITCStdRegular', sans-serif;
  text-decoration: none;
  color: #2c3e50;
  font-size: 18px;
  font-weight: 500;
  transition: color 0.3s ease;
  line-height: 80px; /* Ensures the links are vertically centered */
  }
  
  .nav-links li a:hover {
  color: #3498db;
  }
  
  /* Burger menu (for mobile view) */
  .burger {
  display: none;
  cursor: pointer;
  
  }
  
  .burger div {
  width: 25px;
  height: 3px;
  background-color: #2c3e50;
  margin: 5px;
  transition: all 0.3s ease;
  }
  
  /* Responsive design */
  @media screen and (max-width: 768px) {
    .nav-links {
      margin-top: 9px;
      display: none;
      position: absolute;
      right: 0;
      height:400px;
      top: 60px;
      flex-direction: column;
      background-color: #ffffff;
      width: 100%;
      align-items: center; 
  }
  
  .nav-links li {
      margin: 20px 0;
  }
  
  .burger {
      display: block;
  }
  
  .nav-active {
      display: flex;
      padding-left: 0 !important; /* Override any existing rule */

  }
  
  .burger.toggle .line1 {
      transform: rotate(-45deg) translate(-5px, 6px);
  }
  
  .burger.toggle .line2 {
      opacity: 0;
  }
  
  .burger.toggle .line3 {
      transform: rotate(45deg) translate(-5px, -6px);
  }
  }
  
  
  #mainContent.blur {
  filter: blur(5px); /* Blur effect for the main content */
  }
  
  #popupTile {
  display: none; /* Hidden by default */
  position: fixed;
  z-index: 2; /* Sit on top */
  left: 0;
  top: 0;
  width: 100%; /* Full width */
  height: 100%; /* Full height */
  background-color: rgba(0, 0, 0, 0.5); /* Black with opacity */
  overflow: hidden; /* Enable scroll if needed */
  
  }

  
  .popup-content {
  background-color: #fff;
  margin: auto; /* 5% from the top and centered */
  margin-bottom: 3%;
  margin-top: 1%;
  padding: 20px;
  border: 1px solid #888;
  width: 100%; /* Increased width */
  max-width: 1100px; /* Set a larger maximum width */
  height: 100%; /* Set a height to fit more content */
  max-height: 95vh; /* Maximum height to keep it within the viewport */
  border-radius: 10px; /* Rounded corners */
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.25); /* Shadow for depth */
  overflow-y: auto; /* Scroll within the pop-up if needed */
  text-align: center;
  }

  @media (max-width: 480px) {
    .popup-content{
     width: 100%;
    }
 }
  
  .close {
  color: #aaa;
  float: right;
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
  }
  
  .close:hover,
  .close:focus {
  color: black;
  text-decoration: none;
  cursor: pointer;
  }
  
  .service-options {
  margin-top: 20px;
  }
  
  .service-options a {
  display: block;
  margin: 10px 0;
  padding: 10px 0;
  background-color: #f2f2f2;
  border-radius: 5px;
  color: #333;
  text-decoration: none;
  }
  
  .service-options a:hover {
  background-color: #ddd;
  }
  
  .extra-content {
  margin-top: 20px;
  }
  
  
  
  
  /*Slideshow*/ /*may need this, not sure yet.. */
  * {box-sizing:border-box}
  
  /* Slideshow container */
  .slideshow-container {
  max-width: 1000px;
  position: relative;
  margin: auto;
  min-width: 400px;
  }
  
  .slideshow-container img{
  border-style: solid;
  color: #f1f1f1;
  }
  
  /* Hide the images by default */
  .mySlides {
  display: none;
  }
  
  /* Fading animation for slideshow*/
  .fade {
  animation-name: fade;
  animation-duration: 1.5s;
  }
  
  /* Footer */
  .footer {
  width: 100vw;
  display: block;
  overflow: hidden;
  padding: 70px 0;
  box-sizing: border-box;
  text-align: center;
  background: white;
  border-style:solid;
  border-width: 2px;
  border-color: #111;;
  }
  
  .inner_footer{
  display: block;
  margin: 0 auto;
  width: 1100px;
  height: 100%;
  
  }
  
  .inner_footer .logo_container{
    width: 30%;
    float: left;
    height: 100%;
    display: block;
  }
  
  
  .inner_footer .footer_third_1{
  width: calc(21.6666666667 - 20px);
  margin-right: 30px;
  float: left;
  height: 100%;
  }
  
  
  .inner_footer .footer_third_2{
  width: calc(21.6666666667 - 20px);
  margin-right: 30px;
  float: left;
  height: 100%;
  }
  
  .inner_footer .footer_third_3{
  width: calc(21.6666666667 - 10px);
  margin-right: 10px;
  float: left;
  height: 100%;
  }
  
  .inner_footer .footer_third_1 h1{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 20px;
  color: black;
  display: block;
  width: 100%;
  margin-bottom: 20px;
  
  }
  
  
  
  .inner_footer .footer_third_2 h1{
    font-family: 'BlairITCStdRegular', sans-serif;
   font-size: 20px;
   color: black;
   display: block;
   width: 100%;
   margin-bottom: 20px;
  
  }
  
  
  .inner_footer .footer_third_3 h1{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 20px;
  color: black;
  display: block;
  width: 100%;
  margin-bottom: 20px;
  
  }
  
  
  
  .inner_footer .footer_third_1 li{
  display: inline-block;
  padding: 0 5px;
  font-size: 20px;
  }
  
  
  .inner_footer .footer_third_2 li{
  display: inline-block;
  padding: 0 5px;
  font-size: 20px;
  }
  
  .inner_footer .footer_third_3 li{
  display: inline-block;
  padding: 0 5px;
  font-size: 20px;
  }
  
  .inner_footer .footer_third_1 a{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 12px;
  color: black;
  font-weight: 200px;
  display: block;
  width: 100%;
  padding-bottom: 5px;
  text-decoration: none;
  }
  
  .inner_footer .footer_third_2 a{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 12px;
  color: black;
  font-weight: 200px;
  display: block;
  width: 100%;
  padding-bottom: 5px;
  text-decoration: none;
  }
  
  .inner_footer .footer_third_3 a{
  font-family: 'BlairITCStdRegular', sans-serif;
  font-size: 12px;
  color: black;
  font-weight: 200px;
  display: block;
  width: 100%;
  padding-bottom: 5px;
  text-decoration: none;
  }
  
  
  
   /*Icon size, example - instagram*/
   .footer .fa{font-size: 30px;}
  /*---------------------------------------------------------------------------------------------------------------------------------------*/
  
  /* Add media queries for small screens (when the height of the screen is less than 450px, add a smaller padding and font-size) */
  
  
  /*footer screen queries*/
  @media(max-width: 800px){
  .footer ,.inner_footer, .header, .navigation{
    width: 100%;
  }
  .inner_footer .logo_container, .inner_footer .footer_third_1, .footer_third_2, .footer_third_3{
    width: 100%;
    margin-bottom: 30px;
  }
  }
  
  /* Responsive layout - makes the two columns stack on top of each other instead of next to each other */
  @media screen and (max-width: 800px) {
    .column {
      width: 100%;
    }
  
  }
  