/* Swiper Review*/
.reviews-slider, h3, p{font-family: "Montserrat", sans-serif;}

.reviews-container{ display: flex; align-items: center; background-color: #eeeeee;}

.reviews-container .reviews{max-width: 1200px; padding: 20px; overflow: hidden; margin: 0 auto;}

.reviews-slider{display: flex; align-items: center; gap: 20px; overflow-x: scroll; scroll-snap-type: x mandatory;}

.reviews-slider::-webkit-scrollbar{height: 0;}

.slide{scroll-snap-align: center; padding: 20px; background-color: #fff; border-radius: 5px;
box-shadow: var(--box-shadow); flex: 0 0 85%; max-width: 320px; user-select: none; height: 325px;}

.stars{font-size: 16px; color:#ff9d00;}

.title{font-size: 20px; margin: 10px 0; color:#00c8ff; line-height: 1.6; text-decoration: lowercase;}

.user{margin-top: 20px; display:flex; align-items: center; gap: 15px;}

.user h3{font-size: clamp(13px, 3.5vw, 18px); margin-bottom: 5px; line-height: 1.2; overflow-wrap: anywhere; word-break: break-word;}



.slide p{max-height: 90px; overflow-y: auto; padding-right: 8px;}

.user img{width:80px; height: 80px; border-radius: 50%; object-fit: cover;}

.reviews-container h2{font-size: clamp(1.5rem, 5vw, 2rem); text-align: center; color: #df6726; margin-bottom: 4%;}

.reviews-container .reviews .controls{display: flex; justify-content: center; margin-top: 20px; gap: 20px; font-size: 30px; cursor: pointer; color:#00c8ff;}
/*Controls for Ion icons so that they can function for slider*/

.reviews-container .reviews .controls :hover{color:#df6726;}

.google-reviews-link{text-align: center; margin-top: 1rem;}

.google-reviews-link a{display: inline-block; padding: 12px 25px; background-color: #4285F4; color: #fff; text-decoration: none; border-radius: 6px; font-weight: 600; transition: 0.3s ease;}

.google-reviews-link a:hover{background-color: #3367D6;}

@media (max-width:850px){
    .reviews-container .reviews{max-width: 800px; padding: 20px; overflow: hidden; margin: 0 auto;}

}

@media (max-width:450px){
    .reviews-container .reviews{max-width: 400px; padding: 20px; overflow: hidden; margin: 0 auto;}

    .user img{width:80px; height:80px; object-fit: cover; border-radius: 50%;}
    
    .title{font-size: 15px; margin: 10px 0;}

    .slide{flex: 0 0 85%; max-width: 85%;}

    .slide p{font-size: 15px;}
}

@media (max-width: 260px){
  .user {flex-direction: column; align-items: flex-start; gap: 4px;}
}


/*Contact Us*/
*,
*::before,
*::after{ box-sizing: border-box;}

.container4{font-family: "Montserrat", sans-serif; width: 100%; min-height: 100vh; padding: 2rem; background-color: #eeeeee; overflow: visible; display: flex; justify-content: center; align-items: center; overflow-x: hidden; margin-top: 4rem; margin-bottom: 0.5rem;}

.form {display: grid; grid-template-columns: 1fr 1fr; width: min(100%, 1000px); margin: 0 auto; background-color: #fff; border-radius: 10px; box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1); overflow: hidden; box-sizing: border-box;}

.form > *{min-width: 0; width: 100%;}

.contact-info{background-color: #fff; padding: 3rem 2rem; flex-direction: column; justify-content: flex-start; align-items: center; text-align: center; display: flex;}


.title-contact1{color: #eb8349; font-weight: 500; font-size: clamp(20px, 5vw, 35px); margin-bottom: 1rem; line-height: 1.2; text-align: center;}

.icon{font-size: 38px; color: #eb8349; margin-right: 1rem; align-content: center;}

.text-contact{color:#001130; margin: 1rem 0 1rem;}

.contact-form{background-color: #eb8349; position: relative; padding: 3rem 2rem; flex-direction: column; justify-content: flex-start; align-items: flex-start; text-align: center;}

.contact-form:before{content:""; position: absolute; width: 26px; height: 26px; background-color: #eb8349; transform: rotate(45deg); top: 50px; display: none !important; z-index: 3;}

.contact-info{display: flex; flex-direction: column; align-items: center; text-align: center;}

.contact-info, .contact-form{width: 100%; max-width: 100%; box-sizing: border-box;}

.title-contact2{color: #fff; font-weight: 500; font-size: 35px; margin-bottom: 1rem;}

.input-container{position: relative; margin: 1rem 0; overflow: hidden;}

.information{display: flex; color:#00c8ff; margin: 0.7rem 0; justify-content: center; align-items: center; font-size: 1rem; flex-wrap: wrap; word-break: break-word; text-align: center;}

.social-media p{font-size: 20px; margin-top: 1rem;}

.social-icon{display: flex; margin-top: 1rem; color:#fff; justify-content: center; align-items: center;}

.social-icon a{display: inline-block; height: 40px; width: 40px; background-color: rgba(255,255,255,0.2); margin: 10px; text-align: center; line-height: 40px; border-radius: 5px; transition: all 0.5s ease;}

.social-icon a:hover{color: #00c8ff; cursor: pointer; transform: scale(1.05);}

/* Center reCAPTCHA inside the form */
.contact-form [data-netlify-recaptcha] {display: flex; justify-content: center; width: 100%; height: 70px; overflow: hidden;}

.contact-form [data-netlify-recaptcha] iframe{transform: scale(0.72); transform-origin: center;}

.input{width: 100%; outline: none; background: none; padding: 1rem 2rem; color: #fff; font-weight: 500;
font-size: 1rem; letter-spacing: 0.5px; border-radius: 25px; transition: 0.3s; box-sizing: border-box;}

.input:focus{border-color: #00c8ff; box-shadow: 0 0 8px rgba(0,200,255,0.4);}

textarea.input{padding: 1rem 1.2rem; min-height: 150px; border-radius: 20px; resize: none; overflow-y: auto;}

.input-container label{position: absolute; top: 50%; left: 15px; transform: translateY(-50%); padding: 0 0.4rem; color: #001130; font-size: 1rem; font-weight: 400; pointer-events: none; z-index: 1000;
transition: 0.5s;}

.input-container.textarea textarea{height: auto;}

.input-container.textarea textarea{min-height: 120px; resize: vertical; padding-top: 1.2rem;}

.input-container.textarea label{top: 20px; transform: translateY(0)}

.send-btn{padding: 0.6rem 1.3rem; margin-top: 3px; background-color: #999; border: 2px solid #fafafa; font-size: 1rem; color: #fff; line-height: 1; border-radius: 25px; outline: none; cursor: pointer; transition: all 0.3s ease; display: block; margin: 1rem auto 0; text-align: center;}

.send-btn.unlocked{background-color: #00c8ff; color: #fff; transform: scale(1.05); box-shadow: 0 0 10px rgba(0,123,255,0.4);}

/*Loading state*/
.send-btn.loading{background: #0056b3; cursor: wait; transform: scale(1); box-shadow: none;}

/*Controls How Form Looks When User click each section of form*/
.input-container span{position: absolute; top:0; left: 25px; transform: translateY(-50%); font-size: 1rem; padding: 0 0.4rem; color: transparent; pointer-events: none; z-index: 500;}

.input-container span:before, .input-container span:after{content:""; position: absolute; width: 100%; opacity: 0; transition: 0.3s; height: 5px; background-color: #eb8349; top: 50%; transform: translateY(-50%);}

.input-container span:before{left: 50%;} .input-container span:after{left: 50%;}

.input-container.focus label{top:0; transform: translateY(-50%); left: 25px; font-size: 1rem;}

.input-container.focus span:before, .input-container.focus span:after{width: 100%; opacity: 1; left:2px;}


#form-status {
  opacity: 0;
  transform: scale(0.9) translateY(10px);
  transition: all 0.3s ease;
}

#form-status.show {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* ✨ pop animation */
#form-status.success {
  color: #2ecc71;
  animation: popIn 0.4s ease;
}

#form-status.error {
  color: #e74c3c;
  animation: popIn 0.4s ease;
}

@keyframes popIn {
  0% {
    transform: scale(0.8) translateY(15px);
    opacity: 0;
  }
  60% {
    transform: scale(1.05) translateY(-2px);
    opacity: 1;
  }
  100% {
    transform: scale(1) translateY(0);
  }
}

@media (max-width: 1200px){
    .form{grid-template-columns: 1fr;}

    .contact-info:before{bottom: initial; top: -75px; right: 65px; transform: scale(0.95);}

    .contact-form:before{top:-13px; left:initial; right:70px;}

    .text-contact{margin: 1rem 0 1.5rem 0;}

    .social-media{padding: 1.5rem 0 0 0;}

    
}

/* Responsive adjustments for screens under 680px */
@media (max-width: 875px) {
    .form {
        grid-template-columns: 1fr; /* stack columns */
    }

    .contact-form:before{display: none;}

    .contact-info, .contact-form {
        padding: 2rem; /* reduce padding */
    }

    .title-contact1, .title-contact2 {
        font-size: 24px; /* smaller titles */
        text-align: center;
    }

    .text-contact, .information, .social-media p {
        font-size: 0.85rem; /* smaller text */
        text-align: center;
    }

    .social-icon {
        justify-content: center; /* center social icons */
        margin-top: 0.8rem;
    }

    .social-icon a {
        width: 35px;
        height: 35px;
        line-height: 35px;
        margin: 6px;
    }

    .icon {
        font-size: 28px; /* smaller icon size */
        margin-right: 0.6rem;
    }

    .input {
        padding: 0.8rem 1.5rem; /* smaller inputs */
        font-size: 0.9rem;
    }

    .textarea.input {
        min-height: 100px; /* smaller textarea */
    }

    .send-btn {
        padding: 0.5rem 1rem; /* smaller button */
        font-size: 0.9rem;
    }

    /* Floating labels adjustments */
    .input-container label {
        font-size: 0.85rem;
        left: 12px;
    }

    .input-container.focus label {
        left: 15px;
    }

    /* Decorative element in contact form */
    .contact-form:before {top: 10px; left: -8px; width: 20px; height: 20px;}


    .contact-form [data-netlify-recaptcha], .contact-form .send-btn {width: 100%; max-width: 350px;}

    .send-btn {margin: 1rem auto 0;font-size: 0.95rem;}
}

@media (max-width: 463px) {
    .form {
        width: 95%;
        max-width: 420px;
    }

    .contact-info, 
    .contact-form {
        padding: 1.2rem 1rem; /* slightly tighter */
    }

    .title-contact1, 
    .title-contact2 {font-size: 22px;}

    .text-contact, 
    .information, 
    .social-media p {font-size: 0.8rem;}

    .input {padding: 0.75rem 1.2rem; font-size: 0.9rem;}

    .textarea.input {min-height: 95px;}

    .send-btn {
        width: 100%; /* 👈 BIG upgrade for mobile UX */
        padding: 0.7rem; font-size: 0.95rem;
    }

    .social-icon a {width: 32px; height: 32px; line-height: 32px;}

    .icon {font-size: 24px;}

    /* tighten floating labels slightly */
    .input-container label {font-size: 0.8rem; left: 10px;}

    .input-container.focus label {left: 12px;}
}

/* Fine-tuned layout for very small screens */
@media (max-width: 426px) {
  .form {
    width: 100%; max-width: 100%; margin: 0 auto; padding: 0.5rem; box-sizing: border-box;}

  .contact-info,
  .contact-form { width: 100%; padding: 1rem; box-sizing: border-box; text-align: center; align-items: center;}

  /* Titles */
  .title-contact1,
  .title-contact2 {
    font-size: 20px;   /* smaller but readable */
  }

  /* Text and info */
  .text-contact,
  .information,
  .social-media p {
    font-size: 0.75rem; /* shrink text */
  }

  /* Social icons */
  .social-icon a {
    width: 28px;
    height: 28px;
    line-height: 28px;
    margin: 4px;
  }

  .icon {
    font-size: 20px;    /* smaller icons */
    margin-right: 0.4rem;
  }

  /* Inputs */
  .input {padding: 0.6rem 1rem;font-size: 0.85rem;}

  .textarea.input {
    min-height: 80px;   /* shrink textarea */
  }

  /* Labels */
  .input-container label {font-size: 0.75rem;}

  /* reCAPTCHA */
  .contact-form [data-netlify-recaptcha] {display: flex; justify-content: center; width: 100%; max-width: 100%; margin: 1rem auto;}

  /* Submit button */
  .contact-form .send-btn {display: block; width: 100%; max-width: 100%; padding: 0.5rem; font-size: 0.85rem; margin: 0.8rem auto 0;}
}

@media (max-width: 400px) {
  .contact-form [data-netlify-recaptcha] iframe {
    transform: scale(0.785); transform-origin: center;
  }
}

@media (max-width: 350px) {
  .form{width: 100%; max-width: 100%;}

  .input-container{width: 100%;}

  .input {padding: 0.5rem 0.8rem; font-size: 0.8rem; width: 100%; max-width: 100%;}

  .contact-info,
  .contact-form {padding: 0.8rem;}

  .contact-form [data-netlify-recaptcha] iframe {
    transform: scale(0.8);
  }
}

@media (max-width: 345px){
  .wrapper, .container, .container2, .container4{margin-left: 0; padding-left: 0.5rem; padding-right: 0.5rem;}

  .container4{padding: 1rem 0.5rem; justify-content: center;}

  .contact-info, .contact-form{padding: 0.8rem;}

  .input{padding: 0.5rem 0.75rem; font-size: 0.8rem;}

  .textarea.input{min-height: 75px;}

  .send-btn{width: 100%; font-size: 0.85rem; padding: 0.6rem;}

  .contact-form [data-netlify-recaptcha] iframe{transform: scale(0.68) !important; transform-origin: center;}

  .social-icon a{width: 28px; height: 28px; line-height: 28px; margin: 3px;}

  .text-contact, .information, .social-media p{font-size: 0.75rem;}
}

/* FOOTER */
.footer{
  background-color:#001130;
  color:#fff;
  padding:40px 20px;
  text-align:center;
}

.footer-legal a{
  color:#bbbbbb;
  text-decoration:none;
  margin:0 10px;
  font-size:14px;
}

.footer-legal a:hover{
  color:#eb8349;
}

/* --- Modal --- */
.modal {
  display: none;
  position: fixed; z-index: 1000;
  left:0; top:0; width:100%; height:100%;
  background: rgba(0,0,0,0.7);
}

.modal-content {
  background: #fff;
  margin: 10% auto; padding: 30px;
  width: 80%; max-width:700px;
  border-radius:6px; position: relative;
  max-height: 80vh; overflow-y:auto;
}

.close {
  position: absolute; top:10px; right:15px;
  font-size:28px; cursor:pointer;
}

/* --- Responsive --- */
@media (max-width:600px){
  header nav { display:flex; flex-direction:column; }
  header nav a { margin:8px 0; }
  .modal-content { margin:20% auto; width:90%; }
}