* ===========================
GLOBAL
=========================== */
body{
margin:0;
padding:0;
font-family:Arial,Helvetica,sans-serif;
color:#222;
overflow-x:hidden;
}

.section-space{
padding:90px 0;
}

.container{
max-width:1300px;
margin:auto;
padding:0 15px;
}

img{
max-width:100%;
display:block;
}

a{
text-decoration:none;
transition:.3s;
}

.sec-head{
text-align:center;
margin-bottom:50px;
}

.sec-head span{
color:#d4af37;
font-weight:700;
display:block;
margin-bottom:10px;
}

.sec-head h2{
font-size:42px;
margin:0;
}

.bg-light{
background:#f8f8f8;
}

/* ===========================
HERO
=========================== */
.hero-home{
padding:100px 0;
background:linear-gradient(135deg,#013220,#046844);
color:#fff;
position:relative;
overflow:hidden;
}

.hero-overlay{
position:absolute;
inset:0;
background:radial-gradient(circle at top right,rgba(255,255,255,.08),transparent 45%);
}

.hero-inner{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:center;
position:relative;
z-index:2;
}

.hero-tag{
display:inline-block;
background:#d4af37;
color:#000;
padding:8px 18px;
border-radius:30px;
font-weight:700;
margin-bottom:20px;
}

.hero-left h1{
font-size:56px;
line-height:1.1;
margin-bottom:20px;
}

.hero-left p{
font-size:19px;
line-height:1.8;
margin-bottom:25px;
}

.hero-btns a{
display:inline-block;
padding:14px 28px;
border-radius:35px;
font-weight:700;
margin-right:10px;
}

.btn-gold{
background:#d4af37;
color:#000;
}

.btn-white{
background:#fff;
color:#000;
}

.hero-stats{
display:flex;
gap:35px;
margin-top:30px;
}

.hero-stats h3{
margin:0;
color:#d4af37;
font-size:28px;
}

.hero-slider{
position:relative;
height:540px;
border-radius:25px;
overflow:hidden;
box-shadow:0 25px 50px rgba(0,0,0,.25);
}

.slide{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
opacity:0;
transition:1s;
transform:scale(1.08);
}

.slide.active{
opacity:1;
transform:scale(1);
z-index:1;
}

.slide img{
width:100%;
height:100%;
}

.hero-slider:after{
content:'';
position:absolute;
inset:0;
background:linear-gradient(to top,rgba(0,0,0,.6),rgba(0,0,0,.1));
z-index:2;
}

.slider-caption{
position:absolute;
left:30px;
bottom:60px;
z-index:4;
color:#fff;
max-width:430px;
}

.slider-caption h3{
font-size:34px;
margin-bottom:10px;
}

.slider-btn-book{
display:inline-block;
padding:12px 24px;
background:#d4af37;
color:#000;
border-radius:30px;
font-weight:700;
margin-top:10px;
}

.slider-btn{
position:absolute;
top:50%;
transform:translateY(-50%);
width:45px;
height:45px;
border:none;
border-radius:50%;
background:#fff;
z-index:5;
cursor:pointer;
font-size:20px;
}

.prev{left:15px;}
.next{right:15px;}

.slider-dots{
position:absolute;
right:25px;
bottom:20px;
display:flex;
gap:10px;
z-index:5;
}

.dot{
width:12px;
height:12px;
border-radius:50%;
background:rgba(255,255,255,.5);
cursor:pointer;
}

.dot.active{
background:#d4af37;
}

/* ===========================
CARDS
=========================== */
.villa-grid,
.why-grid,
.amenity-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
}

.villa-card{
background:#fff;
border-radius:20px;
overflow:hidden;
box-shadow:0 15px 35px rgba(0,0,0,.08);
position:relative;
transition:.4s;
}

.villa-card:hover{
transform:translateY(-10px);
}

.villa-card img {
    height: 223px;
    width: 100%;
    object-fit: contain;
    object-position: top;
}

.tag-gold{
position:absolute;
top:15px;
left:15px;
background:#d4af37;
padding:8px 14px;
border-radius:30px;
font-size:12px;
font-weight:700;
}

.villa-content{
padding:25px;
}

.villa-content h3{
font-size:24px;
margin-bottom:10px;
}

.villa-content a{
display:inline-block;
background:#013220;
color:#fff;
padding:12px 22px;
border-radius:30px;
margin-top:10px;
}

/* ===========================
TABLE
=========================== */
.compare-table{
width:100%;
border-collapse:collapse;
background:#fff;
}

.compare-table th,
.compare-table td{
padding:15px;
border:1px solid #ddd;
text-align:center;
}

.compare-table th{
background:#013220;
color:#fff;
}

/* ===========================
WHY BOOK
=========================== */
.why-book,
.why-emerald-island{
background:#013220;
color:#fff;
}

.why-box{
background:rgba(255,255,255,.07);
padding:35px;
border-radius:20px;
text-align:center;
}

.why-box i{
font-size:40px;
color:#d4af37;
margin-bottom:15px;
}

/* ===========================
AMENITIES
=========================== */
.amenity-card{
background:#f8f8f8;
padding:35px;
text-align:center;
border-radius:18px;
transition:.3s;
}

.amenity-card:hover{
background:#013220;
color:#fff;
transform:translateY(-8px);
}

.amenity-card i{
font-size:42px;
color:#d4af37;
margin-bottom:15px;
}

/* ===========================
CTA
=========================== */
.final-cta{
padding:100px 0;
background:linear-gradient(135deg,#d4af37,#f5db74);
text-align:center;
}

.final-cta h2{
font-size:48px;
margin-bottom:15px;
}

.final-cta a{
display:inline-block;
padding:15px 28px;
background:#013220;
color:#fff;
border-radius:35px;
font-weight:700;
}

/* ===========================
MOBILE BUTTON
=========================== */
.mobile-book-btn{
display:none;
}

/* ===========================
RESPONSIVE
=========================== */
@media(max-width:992px){

.hero-inner,
.villa-grid,
.why-grid,
.amenity-grid{
grid-template-columns:1fr;
}

.hero-left h1{
font-size:38px;
}

.hero-slider{
height:380px;
margin-top:20px;
}

.hero-stats{
flex-direction:column;
gap:10px;
}

.sec-head h2{
font-size:30px;
}

.mobile-book-btn{
display:block;
position:fixed;
left:0;
right:0;
bottom:0;
background:#013220;
color:#fff;
padding:16px;
text-align:center;
z-index:9999;
font-weight:700;
}


}

/* ADD CSS */

.why-choose-sec{
background:#f8f8f8;
}

.why-choose-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-top:20px;
}

.choose-box{
background:#fff;
padding:35px 28px;
border-radius:20px;
box-shadow:0 15px 35px rgba(0,0,0,.07);
text-align:center;
transition:.4s;
position:relative;
overflow:hidden;
}

.choose-box:hover{
transform:translateY(-10px);
box-shadow:0 20px 45px rgba(0,0,0,.12);
}

.choose-box:before{
content:'';
position:absolute;
top:0;
left:0;
width:100%;
height:4px;
background:#d4af37;
}

.choose-icon{
width:75px;
height:75px;
border-radius:50%;
background:#013220;
margin:0 auto 20px;
display:flex;
align-items:center;
justify-content:center;
animation:float 4s infinite ease-in-out;
}

.choose-icon i{
font-size:30px;
color:#d4af37;
}

.choose-box h3{
font-size:24px;
margin-bottom:12px;
color:#013220;
}

.choose-box p{
font-size:16px;
line-height:1.8;
color:#555;
}

/* MOBILE */
@media(max-width:992px){

.why-choose-grid{
grid-template-columns:1fr;
gap:20px;
}

.choose-box h3{
font-size:22px;
}

}
/* ADD CSS */

.distance-magic-sec{
background:#f8f8f8;
}

.distance-grid{
display:grid;
grid-template-columns:1fr 1.1fr;
gap:45px;
align-items:start;
margin-top:30px;
}

.distance-map-box{
position:relative;
overflow:hidden;
border-radius:22px;
box-shadow:0 20px 45px rgba(0,0,0,.08);
}

.distance-map-box img{
width:100%;
height:100%;
min-height:620px;
object-fit:cover;
transition:1s;
}

.distance-map-box:hover img{
transform:scale(1.05);
}

.map-badge{
position:absolute;
left:20px;
bottom:20px;
background:#013220;
color:#fff;
padding:12px 18px;
border-radius:35px;
font-weight:700;
box-shadow:0 10px 25px rgba(0,0,0,.15);
}

.map-badge i{
color:#d4af37;
margin-right:8px;
}

.distance-table{
background:#fff;
border-radius:20px;
overflow:hidden;
box-shadow:0 15px 35px rgba(0,0,0,.06);
margin-bottom:25px;
}

.distance-row{
display:grid;
grid-template-columns:1.5fr 1fr 1fr;
padding:16px 20px;
border-bottom:1px solid #eee;
align-items:center;
font-size:15px;
}

.distance-row:last-child{
border-bottom:none;
}

.distance-row.head{
background:#013220;
color:#fff;
font-weight:700;
}

.distance-row:not(.head):hover{
background:#faf7eb;
}

.local-advantage{
background:#013220;
padding:30px;
border-radius:20px;
color:#fff;
box-shadow:0 15px 35px rgba(0,0,0,.08);
}

.local-advantage h3{
font-size:26px;
margin-bottom:18px;
color:#d4af37;
}

.local-advantage ul{
margin:0;
padding-left:18px;
}

.local-advantage li{
margin-bottom:14px;
line-height:1.8;
font-size:16px;
}

/* MOBILE */
@media(max-width:992px){

.distance-grid{
grid-template-columns:1fr;
gap:25px;
}

.distance-map-box img{
min-height:340px;
}

.distance-row{
grid-template-columns:1fr;
gap:6px;
padding:14px 16px;
}

.distance-row.head{
display:none;
}

.distance-row div{
padding:2px 0;
}

.local-advantage h3{
font-size:22px;
}

}
/* ADD CSS */

.trust-faq-sec{
background:#ffffff;
}

.trust-faq-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
margin-top:30px;
align-items:start;
}

.trust-box,
.faq-main-box{
background:#fff;
padding:35px;
border-radius:22px;
box-shadow:0 15px 35px rgba(0,0,0,.06);
}

.trust-box{
border-top:5px solid #d4af37;
}

.faq-main-box{
border-top:5px solid #013220;
}

.trust-box h3,
.faq-main-box h3{
font-size:28px;
margin-bottom:22px;
color:#013220;
}

.trust-points{
padding-left:18px;
margin:0;
}

.trust-points li{
margin-bottom:16px;
line-height:1.8;
font-size:16px;
color:#444;
}

.trust-badge-row{
display:flex;
flex-wrap:wrap;
gap:10px;
margin-top:25px;
}

.trust-badge-row span{
background:#013220;
color:#fff;
padding:10px 14px;
border-radius:30px;
font-size:13px;
font-weight:700;
}

.faq-item-box{
border-bottom:1px solid #eee;
padding:12px 0;
}

.faq-item-box:last-child{
border-bottom:none;
}

.faq-btn{
width:100%;
background:none;
border:none;
text-align:left;
font-size:17px;
font-weight:700;
padding:0;
cursor:pointer;
position:relative;
padding-right:30px;
color:#013220;
}

.faq-btn:after{
content:'+';
position:absolute;
right:0;
top:0;
font-size:24px;
color:#d4af37;
}

.faq-btn.active:after{
content:'−';
}

.faq-answer{
display:none;
padding-top:12px;
line-height:1.8;
font-size:15px;
color:#555;
}

.faq-answer.open{
display:block;
}

/* MOBILE */
@media(max-width:992px){

.trust-faq-grid{
grid-template-columns:1fr;
gap:25px;
}

.trust-box,
.faq-main-box{
padding:25px;
}

.trust-box h3,
.faq-main-box h3{
font-size:24px;
}

.faq-btn{
font-size:16px;
}

}

/* ADD CSS */

.emerald-choice-sec,
.ei-amenities{
background:#013220;
color:#fff;
}

.white-center{
text-align:center;
}

.white-center h2,
.white-center p{
color:#fff;
}

.resort-features-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:30px;
margin-top:35px;
}

.feature-box{
background:rgba(255,255,255,.05);
padding:35px 25px;
border-radius:20px;
border:1px solid rgba(212,175,55,.15);
text-align:center;
transition:.4s;
}

.feature-box:hover{
transform:translateY(-10px);
background:rgba(255,255,255,.08);
border-color:#d4af37;
}

.feature-icon{
font-size:46px;
margin-bottom:18px;
}

.feature-box h3{
font-size:22px;
color:#d4af37;
margin-bottom:10px;
}

.feature-box p{
font-size:15px;
line-height:1.7;
opacity:.9;
}

.amenities-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-top:35px;
}

.amenity-item{
background:rgba(255,255,255,.05);
padding:35px 25px;
border-radius:20px;
border:1px solid rgba(212,175,55,.12);
text-align:center;
transition:.4s;
}

.amenity-item:hover{
transform:translateY(-8px);
border-color:#d4af37;
background:rgba(255,255,255,.08);
}

.amenity-icon{
font-size:42px;
margin-bottom:18px;
}

.amenity-item h4{
font-size:20px;
margin-bottom:10px;
color:#d4af37;
}

.amenity-item p{
font-size:15px;
line-height:1.7;
opacity:.9;
}

/* MOBILE */
@media(max-width:992px){

.resort-features-grid{
grid-template-columns:1fr 1fr;
gap:20px;
}

.amenities-grid{
grid-template-columns:1fr;
gap:20px;
}

}

@media(max-width:576px){

.resort-features-grid{
grid-template-columns:1fr;
}

}
/* Global Styles (if not already defined) */
  .container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
  
  .ei-property-cards { padding: 60px 0; background-color: #ffffff; text-align: center;}
  
  .section-title { 
    color: #013220; /* Forest Green */
    font-size: 32px; 
    font-weight: 800;
    margin-bottom: 40px;
    text-transform: uppercase;
    letter-spacing: 1px;
  }

  /* Grid Layout */
  .property-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
  }

  /* Card Styling */
  .property-card {
    text-decoration: none;
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: block;
    height: 350px; /* Uniform height */
  }

  .property-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(1, 50, 32, 0.2);
  }

  /* Background Image Setup */
  .card-image {
    background-size: cover;
    background-position: center;
    height: 100%;
    width: 100%;
    position: relative;
    transition: transform 0.5s ease;
  }
  
  .property-card:hover .card-image {
      transform: scale(1.05); /* Subtle zoom on hover */
  }

  /* The Overlay (Forest Green to Transparent) */
  .card-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 30px;
    background: linear-gradient(to top, rgba(1, 50, 32, 0.9) 0%, rgba(1, 50, 32, 0.6) 50%, rgba(1, 50, 32, 0) 100%);
    color: #ffffff;
    text-align: left;
    box-sizing: border-box;
  }

  .card-overlay h3 {
    font-size: 22px;
    margin-bottom: 8px;
    color: #ffffff;
    font-weight: 700;
  }

  .card-overlay p {
    font-size: 14px;
    opacity: 0.9;
    margin-bottom: 15px;
    line-height: 1.4;
  }

  /* The View Button (Gold) */
  .card-btn {
    display: inline-block;
    color: #D4AF37; /* Gold */
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
  }
  /* ===========================
HERO SLIDER ONLY
=========================== */

.hero-right{
position:relative;
}

.hero-slider{
position:relative;
height:540px;
border-radius:25px;
overflow:hidden;
box-shadow:0 25px 50px rgba(0,0,0,.25);
isolation:isolate;
}

/* DARK OVERLAY */
.hero-slider:after{
content:'';
position:absolute;
inset:0;
background:linear-gradient(to top,rgba(0,0,0,.65),rgba(0,0,0,.15));
z-index:2;
pointer-events:none; /* button clickable fix */
}

/* EACH SLIDE */
.slide{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
opacity:0;
transform:scale(1.08);
transition:all .9s ease;
z-index:1;
}

.slide.active{
opacity:1;
transform:scale(1);
z-index:5;
}

.slide img {
    width: 100%;
    height: 100%;
    /* object-fit: contain; */
}

/* CAPTION */
.slider-caption{
position:absolute;
left:30px;
bottom:55px;
z-index:20;
max-width:430px;
color:#fff;
pointer-events:auto;
}

.slider-caption .hero-tag{
display:inline-block;
background:#d4af37;
color:#000;
padding:8px 16px;
border-radius:30px;
font-size:13px;
font-weight:700;
margin-bottom:15px;
}

.slider-caption h3{
font-size:34px;
line-height:1.2;
font-weight:800;
margin-bottom:10px;
}

.slider-caption p{
font-size:16px;
line-height:1.7;
margin-bottom:15px;
opacity:.95;
}

/* BOOK BUTTON */
.slider-btn-book{
display:inline-block;
padding:12px 24px;
background:#d4af37;
color:#000;
border-radius:35px;
font-weight:700;
font-size:15px;
position:relative;
z-index:30;
cursor:pointer;
}

.slider-btn-book:hover{
transform:translateY(-3px);
}

/* PREV / NEXT */
.slider-btn{
position:absolute;
top:50%;
transform:translateY(-50%);
width:48px;
height:48px;
border:none;
border-radius:50%;
background:#fff;
color:#000;
font-size:22px;
cursor:pointer;
z-index:25;
box-shadow:0 10px 25px rgba(0,0,0,.12);
transition:.3s;
}

.slider-btn:hover{
background:#d4af37;
}

.prev{
left:15px;
}

.next{
right:15px;
}

/* DOTS */
.slider-dots{
position:absolute;
right:25px;
bottom:20px;
display:flex;
gap:10px;
z-index:25;
}

.dot{
width:12px;
height:12px;
border-radius:50%;
background:rgba(255,255,255,.45);
cursor:pointer;
transition:.3s;
}

.dot.active{
background:#d4af37;
transform:scale(1.2);
}

/* MOBILE */
@media(max-width:992px){

.hero-slider{
height:380px;
margin-top:20px;
}

.slider-caption{
left:20px;
right:20px;
bottom:30px;
max-width:100%;
}

.slider-caption h3{
font-size:24px;
}

.slider-caption p{
font-size:14px;
}

.slider-btn{
width:42px;
height:42px;
font-size:18px;
}

.slider-dots{
right:18px;
bottom:15px;
}

}

@media(max-width:576px){

.hero-slider{
height:320px;
}

.slider-caption h3{
font-size:20px;
}

.slider-btn-book{
padding:10px 18px;
font-size:14px;
}

}

 /* =========================
LUXURY COMPARISON TABLE
========================= */

.villa-comparison{
padding:90px 20px;
background:linear-gradient(to bottom,#ffffff,#f8f8f8);
}

.compare-head{
text-align:center;
margin-bottom:40px;
}

.compare-head span{
display:inline-block;
color:#D4AF37;
font-weight:700;
letter-spacing:1px;
margin-bottom:10px;
text-transform:uppercase;
font-size:14px;
}

.compare-head h2{
font-size:44px;
font-weight:800;
color:#013220;
margin-bottom:10px;
}

.compare-head p{
font-size:17px;
color:#666;
}

.table-wrapper{
overflow-x:auto;
border-radius:20px;
box-shadow:0 20px 50px rgba(0,0,0,.08);
background:#fff;
}

.comparison-table{
width:100%;
min-width:950px;
border-collapse:collapse;
}

.comparison-table th,
.comparison-table td{
padding:18px 15px;
text-align:center;
border-bottom:1px solid #eee;
font-size:15px;
transition:.3s;
}

.comparison-table thead th{
background:#013220;
color:#fff;
font-size:13px;
letter-spacing:1px;
text-transform:uppercase;
font-weight:700;
position:sticky;
top:0;
z-index:2;
}

/* REMOVE OLD ROW HOVER */
.comparison-table tbody tr:hover td{
background:transparent;
transform:none;
}

/* NEW HOVER = ONLY GOLDEN BORDER */
.comparison-table tbody tr td{
transition:.3s ease;
border-bottom:1px solid #eee;
}

.comparison-table tbody tr:hover td{
border-top:1px solid #D4AF37;
border-bottom:1px solid #D4AF37;
}

.comparison-table tbody tr:hover td:first-child{
border-left:1px solid #D4AF37;
}

.comparison-table tbody tr:hover td:last-child{
border-right:1px solid #D4AF37;
}

.highlight{
background:rgba(212,175,55,.06);
border-left:2px solid #D4AF37;
border-right:2px solid #D4AF37;
font-weight:700;
}

.yes{
color:#1a8a3b;
font-weight:700;
}

.gold-btn{
background:#D4AF37 !important;
color:#000 !important;
}

.table-btn{
display:inline-block;
padding:11px 18px;
background:#013220;
color:#fff;
font-size:13px;
font-weight:800;
border-radius:40px;
transition:.3s;
box-shadow:0 8px 18px rgba(0,0,0,.08);
}

.table-btn:hover{
transform:translateY(-4px);
box-shadow:0 12px 25px rgba(0,0,0,.12);
background:#02542f;
color:#fff !important;
}

.gold-btn:hover{
background:#c89d1f !important;
color:#fff !important;
}

.action-row td{
padding-top:24px;
padding-bottom:24px;
background:#fff;
}

.mobile-hint{
display:none;
text-align:center;
margin-top:15px;
font-size:13px;
color:#777;
}

/* ANIMATION */
.comparison-table tbody tr{
animation:fadeUp .6s ease both;
}

.comparison-table tbody tr:nth-child(2){animation-delay:.05s;}
.comparison-table tbody tr:nth-child(3){animation-delay:.1s;}
.comparison-table tbody tr:nth-child(4){animation-delay:.15s;}
.comparison-table tbody tr:nth-child(5){animation-delay:.2s;}
.comparison-table tbody tr:nth-child(6){animation-delay:.25s;}

@keyframes fadeUp{
from{
opacity:0;
transform:translateY(15px);
}
to{
opacity:1;
transform:translateY(0);
}
}

/* MOBILE */
@media(max-width:768px){

.villa-comparison{
padding:70px 15px;
}

.compare-head h2{
font-size:30px;
}

.mobile-hint{
display:block;
}

}

.about-owners { padding: 80px 20px; background-color: #ffffff; border-bottom: 1px solid #eee; }
  .owner-flex { display: flex; align-items: center; gap: 60px; max-width: 1100px; margin: 0 auto; }
  
  .owner-text { flex: 1; }
  .owner-text h3 { color: #013220; font-size: 20px; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 1px; }
  .owner-text p { line-height: 1.7; color: #444; font-size: 16px; margin-bottom: 20px; }

  .owner-badges { display: flex; gap: 15px; margin-bottom: 30px; flex-wrap: wrap; }
  .badge { 
    background: #013220; color: #D4AF37; padding: 8px 15px; 
    border-radius: 4px; font-size: 13px; font-weight: 700; border: 1px solid #D4AF37;
  }

  .owner-promise { border-left: 4px solid #D4AF37; padding-left: 20px; font-size: 18px !important; color: #013220 !important; }

  .owner-image-box { flex: 0 0 350px; }
  .profile-img { width: 100%; border-radius: 8px; box-shadow: 15px 15px 0px #D4AF37; }

  /* Mobile Responsive */
  @media (max-width: 900px) {
    .owner-flex { flex-direction: column; text-align: center; }
    .owner-image-box { order: -1; flex: 0 0 auto; width: 80%; }
    .owner-badges { justify-content: center; }
    .owner-promise { border-left: none; border-top: 2px solid #D4AF37; padding-top: 15px; padding-left: 0; }
  }

 /* ===============================
   SEARCH BOX SINGLE FINAL CSS
================================= */

/* HERO SECTION */
.hero-home{
    position:relative;
    overflow:visible !important;
    padding-bottom:140px;
}

/* SEARCH WRAP */
.hero-search-wrap{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    bottom:-78px;
    width:100%;
    max-width:1320px;
    z-index:999;
    padding:0 20px;
}

/* MAIN BOX */
.hero-search-form{
    background:#ffffff;
    border-radius:28px;
    box-shadow:0 18px 45px rgba(0,0,0,.14);
    border: 1px solid #0d6f3e;
    padding:22px;
    display:grid;
    grid-template-columns:1.2fr 1.2fr 1fr 1fr 1fr 92px;
    gap:14px;
    align-items:end;
    position:relative;
    overflow:visible;
}

section.section-space.themagic5 {
    padding-top: 150px;
}
/* LABEL */
.Island-filed label{
    display:block;
    font-size:13px;
    font-weight:700;
    color:#006b39;
    margin-bottom:8px;
    padding-left:4px;
}

/* INPUT / SELECT */
.Island-filed input,
.Island-filed select{
    width:100%;
    height:56px;
    border:1px solid #ddd;
    border-radius:14px;
    padding:0 16px;
    font-size:16px;
    background:#fff;
    transition:.3s;
}

.Island-filed input:focus,
.Island-filed select:focus{
    border-color:#d4af37;
    outline:none;
}

/* SEARCH BUTTON */
.submit-btn button{
    width:100%;
    height:56px;
    border:none;
    border-radius:14px;
    background:#006b39;
    color:#fff;
    font-size:22px;
    cursor:pointer;
    transition:.3s;
}

.submit-btn button:hover{
    background:#d4af37;
    color:#000;
}

/* ADVANCE BUTTON */
.advance-toggle{
    text-align: center;
    position: absolute;
    z-index: 20;
    left: 50%;
    transform: translateX(-50%);
    bottom: -33px;
}

.advance-toggle a{
    display:inline-flex;
    justify-content:center;
    align-items:center;
    width:54px;
    height:34px;
    background:#0a7a3f;
    color:#fff;
    border-radius:0 0 14px 14px;
    text-decoration:none;
    font-size:18px;
    box-shadow:0 8px 20px rgba(0,0,0,.12);
    transition:.3s;
}

/* ADVANCE BOX */
.bottom-form{
    background: #fff;
    border: 1px solid #0d6f3e;
    border-radius: 0 0 24px 24px;
    padding: 18px;
    margin-top: 0;
    position: absolute;
    width: 0px;
    display: flex;
    left: 50%;
    transform: translateX(-50%);
    top: 0px;
    transition: 0.5s;
    visibility: hidden;
    z-index: 1000;
    justify-content: space-between;
}

/* SHOW ON HOVER */
.advance-toggle:hover div#advanceBox {
    width: 800px;
    visibility: visible;
}

.bottom-form .Island-filed {
    width: 45%;
}

/* ICON ROTATE */
.hero-search-form:hover #advancedBtn i{
    transform:rotate(180deg);
    transition:.3s;
}

/* NEXT SECTION GAP */
.choose-section,
.featured-section,
.home-section{
    padding-top:80px;
}

/* ===============================
   TABLET
================================= */
@media(max-width:1100px){

.hero-search-wrap{
    bottom:-120px;
}

.hero-search-form{
    grid-template-columns:repeat(2,1fr);
}

.bottom-form{
    grid-template-columns:repeat(2,1fr);
}

.choose-section,
.featured-section,
.home-section{
    padding-top:150px;
}

}

/* ===============================
   MOBILE
================================= */
@media(max-width:576px){

    .hero-search-wrap{
        bottom:0px;
        position: initial;
        transform: initial;
        margin-top: 20px;
    }
    .hero-stats {
        flex-direction: row;
        gap: 10px;
    }
    .hero-search-form{
        grid-template-columns:1fr;
    }

    .bottom-form{
        grid-template-columns:1fr;
    }

    .choose-section,
    .featured-section,
    .home-section{
        padding-top:250px;
    }
    .advance-toggle:hover div#advanceBox{
        width: 300px;
    }
    .villa-card img {
        height: 223px;
        width: 100%;
        object-fit: contain;
        object-position: top;
    }

    .slide img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

}