/*
 Theme Name:     Divi Child
 Theme URI:      https://www.elegantthemes.com/gallery/divi/
 Description:    Divi Child Theme
 Author:         Elegant Themes
 Author URI:     https://www.elegantthemes.com
 Template:       Divi
 Version:        1.0.0
*/


/* =Theme customization starts here
------------------------------------------------------- */

.wpcf7-not-valid-tip{font-size:0.9rem !important}
.current-menu-parent a:first-child{color:#63ff49 !important}
.image-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 20px;
  row-gap: 30px;
}

.image-grid a {
  display: block;
  text-decoration: none;
}

.image-grid img{transition: transform 0.3s ease;overflow:hidden !important;}
.image-grid img:hover{  transform: scale(1.05);}

.grid-image {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
  
  transition: transform 0.2s ease;
}


/* Tablet: 2 columns */
@media (max-width: 1024px) {
  .image-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: 1 column + sticky images */
@media (max-width: 768px) {
  .image-grid {
    grid-template-columns: 1fr;
  }

  .image-grid .grid-image {
    position: sticky;
    top: 120px;
    padding-bottom: 30px;
    margin-bottom: 0 !important;
  }
}


.reverse-columns-mobile {
  display: flex;
  flex-direction: row; /* default for desktop */
  flex-wrap: wrap;
}

@media (max-width: 767px) {
  .reverse-columns-mobile {
    flex-direction: column-reverse; /* reverse column order on mobile */
  }
}

.et_pb_column .et_pb_module{margin-bottom:1.5rem !important }
footer .et_pb_module.footer-cta{margin-bottom:0rem !important}
.et_pb_module.et_pb_post_content.et_pb_post_content_0_tb_body{margin-bottom:0 !important}

.gradient-button-cta .wpcf7-submit{color: #fff;
    text-align: center;
    background-color: #000;
    border-radius: 1000px;
    padding: 10px;font-size:1.1rem;
    text-decoration: none;
    transition: all .1s cubic-bezier(.6,.04,.98,.335);
    position: relative;
    right: auto;font-weight:600;color:#000;
    background-image: linear-gradient(140deg, #63ff49 0%, #05fff6 100%) !important;}
h1,h2,h3,h4,h5,h6{padding-bottom:0px}
p{margin-top:1rem;margin-bottom:1rem;padding-bottom:0 !important}
.vanishing-border {
  position: relative;
  background: black;
  height: 1px; /* Thickness of the border */
  width: 200px;
	max-width:60%;
  overflow: hidden; 
}

.vanishing-border::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(to right, white, transparent);
}

/*Contact Form 7 Styles*/


.wpcf7-form {

	
}

.wpcf7-textarea {
	width:100%; height:100px;border-radius:20px;padding:15px;
}

.wpcf7 input {
	padding:12px;
	width:100%;
	height:50%;border-radius:50px
	
}


.wpcf7-submit {
 background: #fff;
 color: #000; 
	background-color: #fff;
	width:150px !important;border-radius:5px; display:block;margin-left:auto;margin-right:auto;
	border:none;
}


.df-site-logo {
  position: fixed;
  transition: all 0.3s ease;
  left: 5% !important;
  top:65px;
  height: 100px !important;
	width:auto !important;
  z-index: 9999;
}
.df-site-logo.fixed {
  position: fixed;
  top: 65px;
	height: 100px !important;
}

.circular-logo-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
}

.circular-text {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height:100%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

@media only screen and (max-width: 767px) {
	.df-site-logo {
  position: fixed;
  transition: all 0.3s ease;
  left: 5% !important;
  top: 30px;
  height: 80px !important;
  z-index: 9999;
}
.df-site-logo.fixed {
  position: fixed;
  top: 60px;
	height: 70px !important;
}
	
	.hamburger {
		top:40px !important;
	}
	
}

  .hamburger {
    position: fixed;
    top: 60px;
    right: 5%;
    width: 60px;
    height:60px;
    background: white;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    z-index: 1001;
    opacity: 0;
    transform: translateY(-20px) scale(0.8);
    transition: opacity 0.3s ease, transform 0.3s ease;

	  display:none;
	  
	  text-align:center;padding-top:0px;color:#000;
  }

  .hamburger.show {
    opacity: 1;
    transform: scale(1);
    display: flex;
  }

  .hamburger-icon {
    font-size: 40px;
    line-height: 1;
	  height: 60px
  }

  .menu-overlay {
    position: fixed !important;
    bottom: -120%; /* Hidden below screen */
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    z-index: 1000;
    transition: bottom 0.4s ease;
    overflow-y: auto;
  }

  .menu-overlay.active {
    bottom: 0;
  }

.et_pb_module.et_pb_text p:first-child{margin-top:0 !important}

  body.no-scroll {
    overflow: hidden;
  }
.green-gradient
{    -webkit-text-fill-color: transparent; font-weight:800;
    background-image: linear-gradient(90deg, #63ff49, #05fff6);
    -webkit-background-clip: text;
    background-clip: text;}
.purple-blue-gradient {
    background-image: linear-gradient(90deg, #9d00ff, #0099f8);
    -webkit-text-fill-color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
}

.df-cpt-inner-wrap{padding-top:0 !important;padding-bottom:0 !important}