/* Core Theme: dark green, black, gold with white sections */
:root{
  --green:#0e2a26;
  --green-700:#123833;
  --green-600:#1a4a42;
  --black:#0a0f0f;
  --gold:#c9a227;
  --gold-600:#b28e21;
  --white:#ffffff;
  --gray-50:#fafbfc;
  --gray-100:#f6f7f8;
  --gray-200:#e9ecef;
  --gray-300:#d9dee3;
  --gray-600:#6b737a;
  --gray-700:#495057;
  --container:1200px;
}

/* Smooth reveal for IntersectionObserver targets */
.metric, .card, .member, .contact-card{
  opacity: 0;
  transform: translateY(8px);
  transition: transform .35s cubic-bezier(.2,.8,.2,1), opacity .35s ease-out;
}
.fade-in{
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Subtle stagger for cards to appear more fluidly */
.card-grid .card.fade-in:nth-child(1){ transition-delay: 0ms; }
.card-grid .card.fade-in:nth-child(2){ transition-delay: 30ms; }
.card-grid .card.fade-in:nth-child(3){ transition-delay: 60ms; }
.card-grid .card.fade-in:nth-child(4){ transition-delay: 90ms; }
.card-grid .card.fade-in:nth-child(5){ transition-delay: 120ms; }
.card-grid .card.fade-in:nth-child(6){ transition-delay: 150ms; }

/* Performance hints for common hover transforms */
.thumbnail, .gallery-nav, .nav a, .btn{ will-change: transform; }

/* Respect user's reduced motion preference */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation: none !important; transition: none !important; }
}

/* Fullscreen lightbox */
.lightbox{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3000;
  cursor: zoom-out;
}
.lightbox img{
  max-width: 95vw;
  max-height: 95vh;
  border-radius: 8px;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.lightbox .lb-nav{
  position: absolute;
  top: 50%;
  left: 0; right: 0;
  display: flex;
  justify-content: space-between;
  padding: 0 20px;
  transform: translateY(-50%);
  pointer-events: none;
}
.lightbox .lb-btn{
  pointer-events: all;
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.1);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .2s ease, background .2s ease;
}
.lightbox .lb-btn:hover{ background: rgba(255,255,255,.2); transform: scale(1.05); }

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,Helvetica,sans-serif;
  color:var(--black);
  background:var(--white);
  line-height:1.6;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}

/* Header */
header.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: linear-gradient(180deg, var(--green) 0%, #0f1c1a 100%) !important;
  border-bottom: 1px solid rgba(201, 162, 39, 0.3) !important;
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1) !important;
  padding: 10px 0;
  transition: none !important;
  transform: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  background-color: var(--green) !important;
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  height: 90px;
}

.brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-weight: 700;
  font-size: 20px;
  color: var(--white);
  text-align: center;
  min-width: 120px;
}

.brand img.logo-img {
  width: 40px;
  height: auto;
  transition: transform 0.3s ease;
}

.brand:hover img { 
  transform: scale(1.05); 
}

.nav ul { 
  list-style: none;
  display: flex;
  gap: 20px;
  margin: 0;
  padding: 0;
}

.nav a {
  padding: 8px 0;
  opacity: 0.9;
  border-bottom: 2px solid transparent;
  transition: all 0.3s ease;
  color: var(--white);
  font-weight: 500;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: 0.5px;
}

.nav a:hover {
  opacity: 1;
  border-color: var(--gold);
  color: var(--gold);
}

.nav a.active {
  color: var(--gold);
  border-color: var(--gold);
  font-weight: 600;
}
.brand{
  display:flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 20px;
  color: var(--white);
  text-align: center;
}
.brand img.logo-img {
  width: 40px;
  height: 49px;
  transition: transform 0.3s ease;
  margin-bottom: 4px;
}
.brand:hover img { transform: scale(1.05); }
.nav ul{list-style:none;display:flex;gap:24px}
.nav a{padding:8px 2px;opacity:.9;border-bottom:2px solid transparent;transition:all .3s ease;color:var(--white)}
.nav a:hover{opacity:1;border-color:rgba(201,162,39,.6);color:var(--gold)}
.nav a.active{color:var(--gold);border-color:var(--gold)}
.lang-select{
  background:whitesmoke;border:1px solid rgba(201,162,39,.5);color:var(--black);
  padding:8px 12px;border-radius:8px;cursor:pointer;transition:all 0.3s ease
}
.lang-select:hover{border-color:var(--gold)}

/* Mobile menu */
.mobile-menu-toggle{
  display:none;flex-direction:column;gap:4px;cursor:pointer;padding:8px
}
.mobile-menu-toggle span{
  width:24px;height:3px;background:var(--white);border-radius:2px;transition:all 0.3s ease
}
.mobile-menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.mobile-menu-toggle.active span:nth-child(2){opacity:0}
.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}

/* Transparent overlay only to capture outside clicks (no visual dim) */
.mobile-overlay{
  position: fixed;
  inset: 0;
  background: transparent;
  display: none;
  z-index: 900;
}
.mobile-overlay.active{ display: block; }

/* Tap feedback animation used by script.js */
@keyframes tapPulse { 0%{transform:scale(1);opacity:1} 50%{transform:scale(.98);opacity:.85} 100%{transform:scale(1);opacity:1} }
.tap-anim{ animation: tapPulse .18s ease-in-out; }

main{padding-top:100px;background:var(--white)}

/* Desktop nav refinement: pill hover, subtle background */
.nav a{
  padding: 10px 14px;
  border-radius: 999px;
  line-height: 1;
}
.nav a:hover{
  background: rgba(255,255,255,0.06);
}

/* ========== Responsive Navigation (Phone) ========== */
@media (max-width: 768px){
  /* Show hamburger */
  .mobile-menu-toggle{ display:flex; }

  /* Compact header on phones */
  header.site-header{ padding: 10px 0; animation: headerSlideDown .35s ease both; }
  header .container.nav{ height: 78px; }
  .brand img.logo-img{ width: 38px; height: 48px; }
  .brand{ gap: 6px; font-size: 18px; }

  /* Left-side frosted glass drawer */
  .nav ul{
    position: fixed;
    top: 0; left: 0; right: auto;
    height: 100vh;
    width: min(84vw, 340px);
    overflow-y: auto;
    background: linear-gradient(180deg, rgba(15, 28, 26, 0.92), rgba(15, 28, 26, 0.86));
    border-right: 1px solid rgba(201,162,39,.25);
    box-shadow: 10px 0 30px rgba(0,0,0,.35);
    padding: 92px 18px 22px; /* match adjusted header height */
    display: flex;
    flex-direction: column;
    gap: 10px;
    transform: translateX(-100%);
    transition: transform .3s cubic-bezier(.2,.8,.2,1);
    z-index: 950;
    backdrop-filter: saturate(120%) blur(8px);
    -webkit-backdrop-filter: saturate(120%) blur(8px);
  }
  .nav ul.active{ transform: translateX(0); }

  /* Staggered reveal for menu items */
  .nav ul li{ opacity: 0; transform: translateX(-8px); }
  .nav ul.active li{ animation: menuItemIn .35s ease forwards; }
  .nav ul.active li:nth-child(1){ animation-delay: .02s; }
  .nav ul.active li:nth-child(2){ animation-delay: .06s; }
  .nav ul.active li:nth-child(3){ animation-delay: .1s; }
  .nav ul.active li:nth-child(4){ animation-delay: .14s; }
  .nav ul.active li:nth-child(5){ animation-delay: .18s; }
  .nav ul.active li:nth-child(6){ animation-delay: .22s; }
  .nav ul.active li:nth-child(7){ animation-delay: .26s; }
  .nav ul.active li:nth-child(8){ animation-delay: .3s; }

  .nav li a{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 14px;
    font-size: 16px;
    border-radius: 14px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(201,162,39,.22);
    box-shadow: 0 6px 18px rgba(0,0,0,.16), inset 0 0 0 1px rgba(255,255,255,.04);
    transition: background .2s ease, transform .15s ease, box-shadow .2s ease, border-color .2s ease;
  }
  .nav li a:hover{
    background: rgba(255,255,255,0.07);
    box-shadow: 0 10px 24px rgba(0,0,0,.2);
    border-color: rgba(201,162,39,.35);
  }
  .nav li a:active{ transform: scale(.985); }

  /* Right chevron indicator */
  .nav li a::after{
    content: '›';
    font-size: 20px;
    line-height: 1;
    color: var(--gold);
    opacity: .85;
    transform: translateX(0);
    transition: transform .2s ease, opacity .2s ease;
  }
  .nav li a:hover::after{ transform: translateX(2px); opacity: 1; }

  /* Active item gets a gold accent */
  .nav li a.active{
    background: rgba(201,162,39,0.12);
    border-color: var(--gold);
    box-shadow: 0 10px 26px rgba(201,162,39,.18), inset 0 0 0 1px rgba(255,255,255,.06);
  }

  /* Language selector inside menu keeps its original colors */
  .nav .lang-item{ padding: 6px 2px 0; }
  .nav .lang-item .lang-select{ width: 100%; }

  /* Dim overlay when menu is open */
  .mobile-overlay.active{ background: rgba(0,0,0,.42); }

  /* Buttons: bigger tap targets and bouncy tap animation on phones */
  .btn{ padding: 15px 26px; font-size: 17px; border-radius: 12px; }
  .btn:active{ transform: scale(.98); }
  @keyframes btnBounce {
    0% { transform: scale(1); }
    50% { transform: scale(.985); }
    100% { transform: scale(1); }
  }
  .btn.tap-anim{ animation: btnBounce .22s ease; }
}

/* Keyframes for staggered menu items */
@keyframes menuItemIn {
  0% { opacity: 0; transform: translateX(-8px); }
  100% { opacity: 1; transform: translateX(0); }
}

/* Smooth modal entrance (ensure keyframes exist) */
@keyframes modalFadeIn {
  0% { transform: translateY(12px); opacity: 0; }
  100% { transform: translateY(0); opacity: 1; }
}

/* Phone header entrance animation */
@keyframes headerSlideDown {
  0% { transform: translateY(-8px); opacity: .0; }
  100% { transform: translateY(0); opacity: 1; }
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;border-radius:10px;
  padding:14px 24px;font-weight:600;cursor:pointer;border:none;
  transition:all .3s cubic-bezier(.2,.8,.2,1);font-size:16px;gap:8px
}
.btn:active{transform:translateY(1px)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%, var(--gold-600) 100%);
  color:#1b1b1b;box-shadow:0 8px 20px rgba(201,162,39,.3)
}
.btn-gold:hover{
  box-shadow:0 12px 28px rgba(201,162,39,.4);transform:translateY(-2px)
}
.btn-ghost{
  background:transparent;border:2px solid rgba(201,162,39,.6);color:var(--green);
  font-weight:600
}
.btn-ghost:hover{
  background:var(--gold);border-color:var(--gold);color:var(--white);transform:translateY(-2px)
}

/* Secondary filter button style (visually distinct from primary) */
.btn-secondary{
  background: var(--gray-100);
  border: 2px solid var(--gray-300);
  color: var(--green);
  font-weight: 600;
  border-radius: 999px;
}
.btn-secondary:hover{
  background: var(--gray-200);
  border-color: var(--gold);
  color: var(--green);
}
.btn-secondary.active{
  background: var(--gold);
  color: white;
  border-color: var(--gold);
}

/* Ghost-secondary button (used for Reset Filters) */
.btn-ghost-secondary{
  background: transparent;
  border: 1px dashed var(--gray-300);
  color: var(--gray-700);
  border-radius: 999px;
}
.btn-ghost-secondary:hover{
  border-color: var(--gold);
  color: var(--green);
  background: var(--gray-100);
}

.btn-goll{
  background:transparent;border:2px solid rgba(201,162,39,.6);color:var(--white);
  font-weight:600
}
.btn-goll:hover{
  background:var(--gold);border-color:var(--gold);color:var(--white);transform:translateY(-2px)
}
/* Hero Section */
.hero{
  position:relative;min-height:80vh;display:grid;place-items:center;
  color:var(--white);overflow:hidden;background:var(--green)
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(14,42,38,0.8), rgba(10,15,15,0.9));
  z-index:0
}
.hero img.bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(20%) saturate(110%)
}
.hero .content{
  position:relative;z-index:1;text-align:center;padding:40px 20px;max-width:800px
}
.hero h1{
  font-size:clamp(32px,5vw,56px);margin-bottom:20px;font-weight:700;
  text-shadow:0 2px 4px rgba(0,0,0,0.3)
}
.hero p{
  max-width:760px;margin:0 auto 30px;color:#e6e8ea;font-size:20px;
  line-height:1.6
}
.hero .cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* Hero Icon */
.hero-icon{
  width:80px;height:80px;margin:0 auto 20px;color:var(--gold);
  filter:drop-shadow(0 4px 8px rgba(0,0,0,0.3))
}

/* Highlights Section - White Background */
.highlights{
  background:var(--white);padding:80px 0;border-top:1px solid var(--gray-200)
}
.highlights h2{
  text-align:center;font-size:36px;margin-bottom:50px;color:var(--green);
  font-weight:700
}
.highlights .grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:30px
}
.metric{
  background:var(--white);border:2px solid var(--gray-200);border-radius:16px;
  padding:40px 30px;text-align:center;transition:all 0.3s ease;
  box-shadow:0 4px 20px rgba(0,0,0,0.05)
}
.metric:hover{
  transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,0.1);
  border-color:var(--gold)
}
.metric h3{color:var(--gold);font-size:32px;margin-bottom:12px;font-weight:700}
.metric p{color:var(--gray-700);font-size:16px;line-height:1.5}

/* Highlights Icon */
.highlights-icon{
  width:60px;height:60px;margin:0 auto 20px;color:var(--green);
  opacity:0.8
}

/* Testimonials Section - Dark Background */
.testimonials{
  padding:80px 0;background:linear-gradient(135deg,var(--green),var(--black));
  color:var(--white)
}
.testimonials h2{
  text-align:center;font-size:36px;margin-bottom:50px;color:var(--gold);
  font-weight:700
}
.carousel{
  position:relative;overflow:hidden;border-radius:16px;
  border:2px solid rgba(201,162,39,.3);max-width:800px;margin:0 auto
}
.slides{display:flex;transition:transform .6s ease}
.slides{ will-change: transform; }
.slide{
  flex:0 0 100%;padding:50px 40px;background:rgba(255,255,255,0.05);
  backdrop-filter:blur(10px);text-align:center
}
.slide q{
  display:block;font-size:20px;color:#e7eaed;line-height:1.6;font-style:italic
}
.slide .author{
  margin-top:20px;color:var(--gold);font-weight:600;font-size:16px
}
.carousel .dots{
  display:flex;gap:12px;justify-content:center;padding:20px;
  background:rgba(0,0,0,0.3);border-top:1px solid rgba(201,162,39,.3)
}
.dot{
  width:12px;height:12px;border-radius:50%;background:#55615f;
  border:2px solid rgba(201,162,39,.4);cursor:pointer;transition:all 0.3s ease
}
.dot:hover{background:var(--gold);border-color:var(--gold)}
.dot.active{background:var(--gold);border-color:var(--gold);transform:scale(1.2)}

/* Testimonials Icon */
.testimonials-icon{
  width:70px;height:70px;margin:0 auto 30px;color:var(--gold);
  opacity:0.9
}

 /* Promo Spot Section (renamed from ad-spot to avoid ad blockers) */
 .promo-spot{
  padding: 80px 0;
  background:
    radial-gradient(1200px 400px at 50% -10%, rgba(255,255,255,0.08), transparent 60%),
    linear-gradient(135deg, #0b2a25, var(--green));
  border-top: 0;
  border-bottom: 0;
}
.promo-spot h2{
  text-align:center;
  font-size: 36px;
  margin-bottom: 10px;
  color: var(--white);
  font-weight: 700;
}
.promo-spot .lead{
  text-align:center;
  color: var(--gray-100);
  max-width: 780px;
  margin: 0 auto 22px;
}
.promo-spot .promo-placeholder{
  width: min(970px, 100%);
  height: 250px;
  border: 2px solid var(--gold);
  border-radius: 16px;
  margin: 16px auto 18px;
  display:flex;align-items:center;justify-content:center;
  color: var(--green);
  background: #ffffff;
  box-shadow: 0 10px 30px rgba(201,162,39,.15), inset 0 0 0 1px rgba(255,255,255,.5);
  transition: all .3s ease;
}
.promo-spot .promo-placeholder:hover{
  background: #fffef7;
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 16px 36px rgba(201,162,39,.18);
}
.promo-spot .promo-placeholder span{
  font-weight: 700;
  letter-spacing: .5px;
}

 /* Promo card container */
 .promo-spot .promo-card{
  background: #ffffff;
  border: 2px solid rgba(201,162,39,.35);
  border-radius: 16px;
  padding: 28px;
  box-shadow: 0 10px 28px rgba(0,0,0,0.06);
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}
.promo-spot .promo-card::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 6px;
  background: linear-gradient(90deg, var(--gold), rgba(201,162,39,.4));
}
.promo-spot .promo-card h2{ margin-top: 6px; color: var(--green); }
.promo-spot .promo-card .lead{ color: var(--gray-700); }
.promo-spot .promo-cta{ display:flex; justify-content:center; margin-top:14px; }
.promo-spot .promo-cta .btn{ padding:12px 22px; font-size:16px; box-shadow: 0 6px 16px rgba(201,162,39,.25); }

/* Responsive tweaks */
 @media (max-width: 640px){
  /* Make Reset Filters more prominent and touch-friendly on phones */
  #resetFilters{
    order: 99;
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
    border-width: 2px;
    font-size: 14px;
    border-radius: 999px;
  }

  /* Pagination larger tap targets on phones */
  #pagination{ gap: 8px; }
  #pagination .page-btn{
    min-width: 46px;
    height: 46px;
    border-radius: 14px;
    font-size: 14px;
  }
  .promo-spot .promo-placeholder{ height: 160px; }
 }

/* Services Section */
.section{padding:80px 0}
.section h2{
  font-size:36px;margin-bottom:30px;color:var(--green);font-weight:700;
  text-align:center
}
.section h3{
  font-size:28px;margin-bottom:20px;color:var(--green);font-weight:600;
  text-align:center
}
.filters{
  display:flex;flex-wrap:wrap;gap:12px;margin-bottom:40px;justify-content:center
}
.filters button{
  padding:12px 24px;border-radius:10px;font-weight:600;transition:all 0.3s ease
}

/* Reset Filters button specific styles */
#resetFilters.btn-ghost-secondary{
  border-style: dashed;
  border-width: 2px;
  color: var(--green);
  background: #fffefc;
}
#resetFilters.btn-ghost-secondary:hover{
  background: #fff8e0;
  border-color: var(--gold);
  color: var(--green);
  box-shadow: 0 4px 14px rgba(201,162,39,.18);
}

/* Pagination buttons */
#pagination{
  display: flex;
  gap: 10px;
}
#pagination .page-btn{
  min-width: 42px;
  height: 42px;
  padding: 0 12px;
  border-radius: 12px;
  border: 2px solid var(--gray-300);
  background: #ffffff;
  color: var(--green);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: all .2s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
#pagination .page-btn:hover{
  border-color: var(--gold);
  box-shadow: 0 4px 12px rgba(201,162,39,.18);
  transform: translateY(-1px);
}
#pagination .page-btn.active{
  background: linear-gradient(135deg,var(--gold),var(--gold-600));
  border-color: var(--gold);
  color: #1b1b1b;
  box-shadow: 0 6px 16px rgba(201,162,39,.28);
}
#pagination .page-btn[disabled]{
  opacity: .5;
  cursor: not-allowed;
  transform: none;
}
.card-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:30px
}
.card{
  background:var(--white);border:2px solid var(--gray-200);border-radius:16px;
  overflow:hidden;display:flex;flex-direction:column;transition:all 0.3s ease;
  box-shadow:0 4px 20px rgba(0,0,0,0.05)
}
.card{ will-change: transform, box-shadow; }
.card:hover{
  transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,0.1);
  border-color:var(--gold)
}
.card img{width:100%;height:250px;object-fit:cover}
.status-badge{
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(14,42,38,.9);
  color: #fff;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .3px;
  border: 1px solid rgba(201,162,39,.4);
}
.card .image-wrap{ position:relative }
.card-body{
  padding:24px;display:flex;flex-direction:column;gap:12px;flex:1
}
.card .title{font-size:20px;font-weight:600;color:var(--green)}
.card .muted{color:var(--gray-600)}
.price{color:var(--gold);font-weight:700;font-size:24px}
.card .btn{width:100%;margin-top:auto}

/* Services Icon */
.services-icon{
  width:70px;height:70px;margin:0 auto 20px;color:var(--green);
  opacity:0.8
}

/* Property Details Modal */
.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(5px);
  z-index: 2000;
  overflow: hidden;
  padding: 20px;
  box-sizing: border-box;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.modal.open {
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 1;
}

.modal-dialog {
  background: white;
  border-radius: 12px;
  width: 100%;
  max-width: 1100px;
  max-height: 92vh;
  position: relative;
  margin: 20px auto;
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.3);
  animation: modalFadeIn 0.35s cubic-bezier(.2,.8,.2,1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(201, 162, 39, 0.2);
}

.modal.open .modal-dialog {
  transform: translateY(0);
  opacity: 1;
}

.modal-content {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.modal-body {
  padding: 0;
  display: flex;
  flex-direction: column;
  flex: 1;
  /* Allow modal content to scroll within the dialog */
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.close-btn {
  position: absolute;
  top: 20px;
  right: 20px;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(5px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 10;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.close-btn:hover {
  background: var(--gold);
  transform: rotate(90deg) scale(1.1);
  box-shadow: 0 6px 16px rgba(201, 162, 39, 0.4);
}

.close-btn svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.5px;
}

/* Property Gallery */
.property-gallery {
  position: relative;
  height: clamp(220px, 35vh, 360px);
  background: #f8f9fa;
  overflow: hidden;
  border-radius: 16px 16px 0 0;
}

.main-image {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.main-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(.2,.8,.2,1);
}
.main-image img{ will-change: transform; }

.main-image:hover img {
  transform: scale(1.02);
}

/* Zoom-on-click support */
.main-image { cursor: zoom-in; }
.main-image.zoomed { cursor: zoom-out; }
.main-image.zoomed img {
  transform: scale(2) !important;
  transform-origin: var(--tx, 50%) var(--ty, 50%);
}

.image-counter {
  position: absolute;
  bottom: 20px;
  right: 20px;
  background: rgba(0, 0, 0, 0.6);
  color: white;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 500;
  z-index: 5;
  backdrop-filter: blur(5px);
}

.gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(5px);
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.2);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
}

.property-gallery:hover .gallery-nav {
  opacity: 1;
  visibility: visible;
}

.gallery-nav:hover {
  background: var(--gold);
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 6px 16px rgba(201, 162, 39, 0.4);
}

.gallery-nav svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.5px;
}

.gallery-nav.prev {
  left: 20px;
}

.gallery-nav.next {
  right: 20px;
}

.thumbnail-container {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  padding: 0 20px;
  z-index: 5;
  background: rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(5px);
  border-radius: 20px;
  padding: 8px 12px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.property-gallery:hover .thumbnail-container {
  opacity: 1;
  visibility: visible;
}

.thumbnail {
  width: 60px;
  height: 40px;
  border-radius: 6px;
  border: 2px solid transparent;
  cursor: pointer;
  opacity: 0.7;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.thumbnail:hover, .thumbnail.active {
  opacity: 1;
  border-color: var(--gold);
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(201, 162, 39, 0.3);
}

.thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.thumbnail:hover img {
  transform: scale(1.1);
}

/* Property Details */
.property-details {
  padding: 20px;
  overflow: visible;
  flex: 1;
  background: white;
}

.property-header {
  margin-bottom: 16px;
  position: relative;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(201, 162, 39, 0.12);
}

.property-tags {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.property-tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: rgba(201, 162, 39, 0.1);
  color: var(--gold);
  transition: all 0.3s ease;
}

.property-tag.featured {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

.property-header h1 {
  font-size: 24px;
  margin: 6px 0 8px;
  color: var(--green);
  line-height: 1.25;
  font-weight: 700;
}

.property-address {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--gray-600);
  margin-bottom: 10px;
  font-size: 14px;
}

.property-address svg {
  flex-shrink: 0;
  color: var(--gold);
  width: 16px;
  height: 16px;
}

.property-price {
  font-size: 22px;
  font-weight: 700;
  color: var(--gold);
  margin: 8px 0 0;
  letter-spacing: 0.4px;
  position: relative;
  display: inline-block;
}

.property-price::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 50px;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), transparent);
  border-radius: 2px;
}

.property-features {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 12px 0;
  padding: 12px 0;
  border-top: 1px solid rgba(201, 162, 39, 0.12);
  border-bottom: 1px solid rgba(201, 162, 39, 0.12);
}

.feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--gray-700);
  background: rgba(201, 162, 39, 0.05);
  padding: 6px 10px;
  border-radius: 8px;
  transition: all 0.3s ease;
  border: 1px solid rgba(201, 162, 39, 0.12);
}

.feature:hover {
  background: white;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  border-color: rgba(201, 162, 39, 0.2);
}

.feature svg {
  color: var(--gold);
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}

.property-section {
  margin: 16px 0;
  animation: fadeInUp 0.5s ease-out forwards;
  opacity: 0;
  transform: translateY(10px);
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.property-section:nth-child(2) { animation-delay: 0.1s; }
.property-section:nth-child(3) { animation-delay: 0.2s; }
.property-section:nth-child(4) { animation-delay: 0.3s; }

.section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  position: relative;
}

.section-header svg {
  color: var(--gold);
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  stroke-width: 2.2px;
}

.section-header h3 {
  font-size: 20px;
  color: var(--green);
  margin: 0;
  font-weight: 600;
  position: relative;
  display: inline-block;
}

.section-header h3::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 40px;
  height: 2px;
  background: var(--gold);
  border-radius: 2px;
  transition: width 0.3s ease;
}

.section-header:hover h3::after {
  width: 60px;
}

.section-content {
  padding-left: 20px;
}

.property-description p {
  line-height: 1.6;
  color: var(--gray-700);
  margin: 0 0 12px;
  font-size: 14px;
}

.amenities-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.amenities-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--gray-700);
  padding: 6px 0 6px 0;
  position: relative;
  padding-left: 24px;
  transition: all 0.3s ease;
}

.amenities-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: bold;
  font-size: 14px;
  width: 20px;
  height: 20px;
  background: rgba(201, 162, 39, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.amenities-list li:hover {
  color: var(--green);
  transform: translateX(4px);
}

.amenities-list li:hover::before {
  background: var(--gold);
  color: white;
  transform: scale(1.1);
}

.cta-buttons {
  display: flex;
  gap: 16px;
  margin-top: 24px;
  flex-wrap: wrap;
}

.cta-buttons .btn {
  flex: 1;
  min-width: 160px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  font-weight: 600;
  border-radius: 8px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-align: center;
}

.cta-buttons .btn svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.2px;
}

.cta-buttons .btn.btn-ghost {
  border: 2px solid var(--gold);
  color: var(--gold);
  background: transparent;
}

.cta-buttons .btn.btn-ghost:hover {
  background: rgba(201, 162, 39, 0.1);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(201, 162, 39, 0.15);
}

/* Responsive adjustments */
@media (max-width: 1024px) {
  .property-gallery {
    height: 400px;
  }
  
  .property-header h1 {
    font-size: 28px;
  }
  
  .property-price {
    font-size: 24px;
  }
  
  .property-features {
    gap: 12px;
  }
  
  .feature {
    padding: 8px 14px;
    font-size: 14px;
  }
  
  .amenities-list {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
}

@media (max-width: 768px) {
  .modal {
    padding: 10px;
  }
  
  .modal-dialog {
    max-height: 95vh;
    margin: 10px auto;
    border-radius: 12px;
  }
  
  .property-gallery {
    height: 260px;
    border-radius: 12px 12px 0 0;
  }
  
  .property-details {
    padding: 16px;
  }
  
  .property-header {
    padding-bottom: 16px;
    margin-bottom: 16px;
  }
  
  .property-header h1 {
    font-size: 20px;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
  }
  
  .amenities-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .modal-dialog { max-height: 96vh; }
  .property-gallery { height: 210px; }
  .thumbnail-container { display: none; }
  .gallery-nav { 
    display: flex; 
    opacity: 1; 
    visibility: visible; 
  }
  
  .thumbnail {
    width: 60px;
    height: 45px;
  }
  
  .property-details { padding: 12px; }
  .property-tags .property-tag { font-size: 10px; padding: 3px 8px; }
  .property-header h1 { font-size: 18px; margin: 2px 0 6px; }
  .property-address { font-size: 12px; margin-bottom: 6px; }
  .property-price { font-size: 18px; }
  .property-features { grid-template-columns: 1fr; gap: 8px; padding: 8px 0; }
  .feature { font-size: 12px; padding: 4px 8px; }
  .section-header h3 { font-size: 16px; }
  .section-content { padding-left: 12px; }

  /* Extra scrolling for details on phones */
  .modal { padding: 6px; }
  .modal-content { height: 100%; display: flex; flex-direction: column; }
  .modal-body { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; }
  /* Make the details column scrollable below the gallery */
  .property-details { 
    max-height: calc(96vh - 220px); /* dialog height minus gallery */
    overflow-y: auto; 
    -webkit-overflow-scrolling: touch;
  }
}

/* Modal */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.8);display:none;
  align-items:center;justify-content:center;padding:20px;z-index:2000;
  backdrop-filter:blur(5px)
}
.modal.open{display:flex;animation:fadeIn 0.3s ease}
.modal-dialog{
  max-width:1000px;width:100%;background:var(--white);
  border:2px solid rgba(201,162,39,.25);border-radius:20px;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.3)
}
.modal-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px;border-bottom:2px solid var(--gray-200);background:var(--gray-50)
}
.modal-header h3{color:var(--green);font-size:24px;font-weight:600}
.close-btn{
  background:transparent;color:var(--gray-600);border:none;font-size:28px;
  cursor:pointer;padding:8px;border-radius:50%;transition:all 0.3s ease
}
.close-btn:hover{background:var(--gray-200);color:var(--green)}
.modal-body{
  display:grid;grid-template-columns:1.2fr .8fr;gap:24px;padding:24px
}
.gallery{position:relative}
.gallery img{
  width:100%;height:400px;object-fit:cover;border-radius:12px
}
.gallery .nav{
  position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;
  transform:translateY(-50%);padding:0 20px
}
.gallery .nav button{
  background:rgba(0,0,0,.6);border:none;color:#fff;padding:12px 16px;
  border-radius:50%;cursor:pointer;transition:all 0.3s ease;font-size:20px
}
.gallery .nav button:hover{background:var(--gold);transform:scale(1.1)}
.enquiry-form label{
  display:block;font-size:14px;color:var(--gray-700);margin-top:16px;
  font-weight:600
}
.enquiry-form input,.enquiry-form textarea{
  width:100%;background:var(--gray-50);border:2px solid var(--gray-200);
  color:var(--gray-700);border-radius:10px;padding:12px;margin-top:8px;
  transition:all 0.3s ease
}
.enquiry-form input:focus,.enquiry-form textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,0.1)
}
.enquiry-form textarea{min-height:120px;resize:vertical}

/* About Section */
.about-hero{
  background:linear-gradient(135deg,var(--green),var(--green-700));
  color:var(--white);padding:60px 0;text-align:center
}
.about-hero h1{font-size:48px;margin-bottom:20px;font-weight:700}
.about-hero p{font-size:20px;opacity:0.9;max-width:600px;margin:0 auto}

.team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:30px
}
.member{
  background:var(--white);border:2px solid var(--gray-200);border-radius:16px;
  overflow:hidden;transition:all 0.3s ease;box-shadow:0 4px 20px rgba(0,0,0,0.05)
}
.member:hover{
  transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,0.1);
  border-color:var(--gold)
}
.member img{width:100%;height:200px;object-fit:cover}
.member .info{padding:20px;text-align:center}
.member strong{color:var(--green);font-size:18px;font-weight:600}
.muted{color:var(--gray-600);margin-top:4px}

/* About Icons */
.about-icon{
  width:80px;height:80px;margin:0 auto 20px;color:var(--gold);
  opacity:0.9
}

/* Values List */
.values-list{
  list-style:none;padding:0;margin:20px 0;max-width:600px;margin-left:auto;margin-right:auto
}
.values-list li{
  padding:12px 0;border-bottom:1px solid var(--gray-200);color:var(--gray-700);
  font-size:16px;position:relative;padding-left:30px
}
.values-list li:before{
  content:"✓";position:absolute;left:0;color:var(--gold);font-weight:bold;font-size:18px
}
.values-list li:last-child{border-bottom:none}

/* Achievements */
.achievements{
  margin-top:20px;max-width:500px;margin-left:auto;margin-right:auto
}
.achievement{
  padding:12px 16px;background:var(--gray-50);border:1px solid var(--gray-200);
  border-radius:8px;margin-bottom:12px;color:var(--gray-700)
}
.achievement strong{color:var(--gold);margin-right:8px}

/* About page: compact, elegant layout (scoped) */
.about-compact .container{ max-width:1000px }
.about-compact .about-hero{ padding:48px 0 }
.about-compact .about-hero h1{ font-size:clamp(28px,4vw,40px); margin-bottom:10px }
.about-compact .about-hero p{ font-size:18px; max-width:720px }

.about-compact .section{ padding:48px 0 }
.about-compact .section h3{ font-size:24px; margin-bottom:12px }

/* Floating Scroll-To-Top Button */
.scroll-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid rgba(201,162,39,.6);
  background: linear-gradient(135deg, var(--green-600), var(--green));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 28px rgba(0,0,0,.18), 0 8px 10px rgba(0,0,0,.12);
  cursor: pointer;
  z-index: 1100;
  opacity: 0;
  transform: translateY(20px) scale(.9);
  visibility: hidden;
  transition: opacity .25s ease, transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.scroll-top.show{
  opacity: 1;
  transform: translateY(0) scale(1);
  visibility: visible;
}
.scroll-top:hover{
  background: linear-gradient(135deg, var(--gold), var(--gold-600));
  color: #1b1b1b;
  box-shadow: 0 18px 36px rgba(201,162,39,.28);
}
.scroll-top:active{ transform: translateY(2px) scale(.98); }
.scroll-top svg{ width: 22px; height: 22px; }

/* Subtle pulse to draw attention */
.scroll-top.show::after{
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 2px solid rgba(201,162,39,.25);
  animation: pulseRing 1.6s ease-out infinite;
}
@keyframes pulseRing {
  0% { transform: scale(0.9); opacity: .7; }
  70% { transform: scale(1.15); opacity: 0; }
  100% { opacity: 0; }
}

@media (max-width: 640px){
  .scroll-top{ right: 12px; bottom: 12px; width: 56px; height: 56px; }
  .scroll-top svg{ width: 20px; height: 20px; }
}
.about-compact .lead{ font-size:17px }
.about-compact .about-icon{ width:60px; height:60px; margin-bottom:12px }

/* Values: compact two-column on desktop */
.about-compact .values-list{ 
  max-width:760px; 
  display:grid; 
  grid-template-columns:repeat(2,minmax(0,1fr)); 
  column-gap:24px; 
  row-gap:6px; 
  margin-top:12px; 
}
.about-compact .values-list li{ 
  border-bottom: none; 
  padding:8px 0 8px 26px; 
  font-size:15px; 
}

/* Achievements compact styling */
.about-compact .achievements{ 
  max-width:760px; 
  display:grid; 
  grid-template-columns:repeat(2,minmax(0,1fr)); 
  gap:10px; 
  margin-top:12px;  
}
.about-compact .achievement{ margin:0; padding:10px 12px }

/* Dubai block minor tightening */
.about-compact .cta .btn{ padding:12px 20px; border-radius:10px }

/* About compact: new components */
.about-compact .about-summary{
  display:flex; flex-wrap:wrap; gap:10px; justify-content:center; align-items:center;
  padding:16px 0; margin-top:12px
}
.about-compact .about-summary .pill{
  padding:8px 14px; border:1px solid var(--gray-200); border-radius:999px; font-weight:600;
  background:var(--gray-50); color:var(--green); font-size:14px
}

.about-compact .about-split{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:20px
}
.about-compact .about-card{
  background:var(--white); border:2px solid var(--gray-200); border-radius:16px; padding:20px;
  box-shadow:0 4px 20px rgba(0,0,0,0.05); transition:transform .3s ease, box-shadow .3s ease
}
.about-compact .about-card:hover{ transform:translateY(-4px); box-shadow:0 8px 28px rgba(0,0,0,0.1); border-color:var(--gold) }

.about-compact .about-stats{
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px; padding:12px 0 0
}
.about-compact .about-stats .stat{
  text-align:center; border:2px solid var(--gray-200); border-radius:14px; padding:18px;
  background:var(--white); transition:all .3s ease
}
.about-compact .about-stats .stat:hover{ border-color:var(--gold); transform:translateY(-3px) }
.about-compact .about-stats .kpi{ color:var(--gold); font-weight:800; font-size:28px; line-height:1 }
.about-compact .about-stats .label{ color:var(--gray-700); font-size:13px; margin-top:6px }

.about-compact .about-mini{ text-align:center; }
.about-compact .about-cta{ margin-top:10px }

  @media (max-width: 1024px){
    .about-compact .about-split{ grid-template-columns:1fr }
    .about-compact .about-stats{ grid-template-columns:repeat(2,minmax(0,1fr)) }
  }
@media (max-width: 560px){
  .about-compact .about-summary{ justify-content:flex-start }
  .about-compact .about-stats{ grid-template-columns:1fr }
}

  @media (max-width: 1024px){
    .about-compact .values-list{ grid-template-columns:1fr }
    .about-compact .achievements{ grid-template-columns:1fr }
  }
  @media (max-width: 768px){
    .about-compact .container{ max-width:100% }
    .about-compact .section{ padding:36px 0 }
    .about-compact .about-hero{ padding:36px 0 }
    .about-compact .about-hero p{ font-size:16px }
  }

/* Contact Section */
.contact-layout{
  display:grid;grid-template-columns:2fr 1fr;gap:30px;margin-top:30px
}
.contact-card{
  background:var(--white);border:2px solid var(--gray-200);border-radius:16px;
  padding:30px;box-shadow:0 4px 20px rgba(0,0,0,0.05)
}
.contact-card h4{color:var(--green);font-size:20px;margin-bottom:16px;font-weight:600}
.map{
  height:300px;border:2px solid var(--gray-200);border-radius:16px;
  overflow:hidden;margin-top:20px
}
.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:16px
}
.error{color:#dc3545;font-size:13px;margin-top:6px}

/* Contact Icons */
.contact-icon-large{
  width:90px;height:90px;margin:0 auto 20px;color:var(--gold);
  opacity:0.9
}

.location-icon{
  width:60px;height:60px;margin:0 auto 16px;color:var(--green);
  opacity:0.8
}

/* Footer */
footer.site-footer{
  margin-top:80px;background:linear-gradient(135deg,var(--green),var(--black));
  color:var(--white);border-top:2px solid rgba(201,162,39,.25)
}
.footer-inner{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px;padding:40px 0
}
.footer-inner h3{color:var(--gold);font-size:24px;margin-bottom:16px;font-weight:600}
.footer-inner h4{color:var(--gold);font-size:18px;margin-bottom:12px;font-weight:600}
.newsletter input{
  width:100%;padding:12px;border-radius:10px;border:2px solid rgba(201,162,39,.25);
  background:rgba(255,255,255,0.1);color:var(--white);margin-right:8px;
  transition:all 0.3s ease
}
.newsletter input:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,0.2)
}
.newsletter input::placeholder{color:rgba(255,255,255,0.6)}
.footer-bottom{
  border-top:1px solid rgba(201,162,39,.18);padding:20px 0;
  color:var(--gray-300);display:flex;justify-content:space-between;align-items:center
}
.socials{display:flex;gap:12px}
.socials a{
  width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  border:2px solid rgba(201,162,39,.35);color:var(--white);transition:all 0.3s ease;
  overflow:hidden
}
.socials a picture, .socials a img{ width:100%; height:100%; display:block; }
.socials a img{ object-fit:cover; border-radius:50%; }

.social-links{ display:flex; gap:12px }
.social-links a{
  width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  border:2px solid rgba(201,162,39,.35); background:var(--green);
  transition:all .3s ease; overflow:hidden
}
.social-links a:hover{ background:var(--gold); transform:translateY(-3px) }
.social-links a picture, .social-links a img{ width:100%; height:100%; display:block }
.social-links a img{ object-fit:cover; border-radius:50% }

/* Contact Page Styles */
.contact-section {
  padding: 100px 0;
  text-align: center;
}

.contact-subtitle {
  color: var(--gray-600);
  margin-bottom: 50px;
  font-size: 1.2rem;
}

/* Card Grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 25px;
  margin: 30px 0 40px;
  min-height: 600px;
  position: relative;
}

/* Loading state for grid */
.card-grid.loading {
  opacity: 0.7;
  pointer-events: none;
}

.card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

.card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.card:hover img {
  transform: scale(1.03);
}

.card-body {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.card .title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--green);
  margin-bottom: 5px;
}

.card .muted {
  color: var(--gray-600);
  font-size: 0.9rem;
  margin-bottom: 5px;
}

.card .price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--gold);
  margin: 10px 0;
}

.card .desc {
  font-size: 0.9rem;
  color: var(--gray-700);
  margin-bottom: 15px;
  flex-grow: 1;
}

.card .btn-details {
  width: 100%;
  padding: 10px;
  margin-top: auto;
  font-weight: 500;
  letter-spacing: 0.5px;
  transition: all 0.3s ease;
}

/* Pagination */
.pagination-container {
  margin: 40px 0;
  display: flex;
  justify-content: center;
  width: 100%;
}

.pagination {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}

.pagination button {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--gray-200);
  background: white;
  color: var(--green);
  border-radius: 8px;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s ease;
}

.pagination button:hover:not(.active):not(.disabled) {
  border-color: var(--gold);
  color: var(--gold);
  transform: translateY(-2px);
}

.pagination button.active {
  background: var(--gold);
  border-color: var(--gold);
  color: white;
  font-weight: 600;
}

.pagination button.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.pagination button.ellipsis {
  border: none;
  background: transparent;
  cursor: default;
  width: auto;
  padding: 0 10px;
}

/* Filters */
.filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 25px 0;
  justify-content: center;
}

.filters .btn {
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 0.9rem;
  transition: all 0.2s ease;
  border: 1px solid transparent;
}

.filters .btn-ghost {
  background: transparent;
  color: var(--gray-700);
  border-color: var(--gray-200);
}

.filters .btn-ghost:hover,
.filters .btn-ghost.active {
  background: var(--gold);
  border-color: var(--gold);
  color: white;
}

/* Loading animation */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.card {
  animation: fadeIn 0.5s ease-out forwards;
  opacity: 0;
}

/* Stagger animations for cards */
.card:nth-child(1) { animation-delay: 0.1s; }
.card:nth-child(2) { animation-delay: 0.2s; }
.card:nth-child(3) { animation-delay: 0.3s; }
.card:nth-child(4) { animation-delay: 0.4s; }
.card:nth-child(5) { animation-delay: 0.5s; }

.contact-card {
  background: var(--white);
  border-radius: 10px;
  padding: 30px 20px;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border: 1px solid var(--gray-200);
}

.contact-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
}

.contact-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 20px;
  background: rgba(201, 162, 39, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}

.contact-icon svg {
  width: 30px;
  height: 30px;
}

.contact-card h3 {
  color: var(--green);
  margin-bottom: 15px;
  font-size: 1.3rem;
}

.contact-card p {
  color: var(--gray-600);
  line-height: 1.7;
}

.social-links {
  max-width: 600px;
  margin: 0 auto;
  padding: 40px 0;
}

.social-links h3 {
  color: var(--green);
  margin-bottom: 20px;
  font-size: 1.5rem;
}

.social-icons {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.social-icons a {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green);
  color: white;
  transition: all 0.3s ease;
}

.social-icons a:hover {
  background: var(--gold);
  transform: translateY(-3px);
}

.social-icons svg {
  width: 24px;
  height: 24px;
}

/* Responsive Styles */
@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Mobile Menu Toggle */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 30px;
  height: 21px;
  cursor: pointer;
  z-index: 1001;
}

.mobile-menu-toggle span {
  display: block;
  height: 3px;
  width: 100%;
  background: var(--white);
  border-radius: 3px;
  transition: all 0.3s ease;
}

/* Responsive Styles */
@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
  
  .mobile-menu-toggle {
    display: flex;
  }
  
  nav ul.nav {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    width: 80%;
    height: 100vh;
    background: var(--green);
    flex-direction: column;
    padding: 80px 30px;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
    z-index: 1000;
  }
  
  nav ul.nav.active {
    display: flex;
    transform: translateX(0);
  }
  
  .mobile-menu-toggle.active span:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
  }
  
  .mobile-menu-toggle.active span:nth-child(2) {
    opacity: 0;
  }
  
  .mobile-menu-toggle.active span:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
  }
}

.socials a:hover{
  background:var(--gold);border-color:var(--gold);transform:scale(1.1)
}
.socials svg{width:20px;height:20px}

/* Image-based social icons */
.social-icon,
.socials img,
.social-links img{
  width:20px;
  height:20px;
  display:block;
  object-fit:contain;
}

/* Contact Info Icons */
.contact-info{
  display:flex;align-items:center;gap:12px;margin-bottom:12px
}
.contact-info svg{
  width:20px;height:20px;color:var(--gold);flex-shrink:0
}

/* Utilities */
.lead{font-size:20px;color:var(--gray-700);line-height:1.6}
.hide{display:none !important}

/* Mobile overlay for menu */
.mobile-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.5);
  backdrop-filter: blur(2px);
  opacity:0;visibility:hidden;
  transition: opacity .25s ease, visibility .25s ease;
  z-index:999;
}
.mobile-overlay.active{ opacity:1; visibility:visible }

/* Animations */
@keyframes fadeIn{
  from{opacity:0;transform:scale(0.95)}
  to{opacity:1;transform:scale(1)}
}

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

.fade-in{animation:slideUp 0.6s ease forwards}

/* Menu animations */
@keyframes menuItemIn{
  from{opacity:0;transform:translateX(12px)}
  to{opacity:1;transform:translateX(0)}
}

@keyframes tapPress{
  0%{transform:scale(1);opacity:1}
  50%{transform:scale(0.96);opacity:.9}
  100%{transform:scale(1);opacity:1}
}

/* Responsive Design */
@media (max-width: 1024px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .modal-body{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-layout{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .highlights .grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 768px){
  /* Mobile Menu */
  .mobile-menu-toggle{
    display:flex;
    padding:10px;
    min-width:44px;
    min-height:44px;
    border-radius:12px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.3);
    box-shadow: 0 6px 18px rgba(0,0,0,0.2);
    z-index: 1002;
    transition: background .25s ease, border-color .25s ease, box-shadow .25s ease, transform .15s ease;
    backdrop-filter: blur(4px);
  }
  .mobile-menu-toggle:hover{
    background: rgba(255,255,255,0.18);
    border-color: rgba(255,255,255,0.45);
    box-shadow: 0 10px 24px rgba(0,0,0,0.28);
    transform: translateY(-1px);
  }
  .mobile-menu-toggle:active{ transform: scale(0.98) }
  .mobile-menu-toggle:focus-visible{ outline: 3px solid rgba(201,162,39,0.6); outline-offset: 2px }
  .mobile-menu-toggle span{ width:26px; height:3px; border-radius:3px }
  /* Active (open) state */
  .mobile-menu-toggle.active{
    background: var(--gold);
    border-color: var(--gold);
    box-shadow: 0 10px 28px rgba(201,162,39,0.45);
  }
  .mobile-menu-toggle.active span{ background: #0f1c1a }
  .nav ul{
    position:fixed;top:80px;left:0;right:0;background:var(--green);
    flex-direction:column;padding:20px;gap:16px;transform:translateY(-100%);
    transition:transform 0.3s ease;border-bottom:1px solid rgba(201,162,39,.3);
    z-index:1001;
  }
  .nav ul.active{transform:translateY(0)}
  .nav a{padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.1)}

  /* Staggered items: initial hidden state for mobile list items */
  .nav ul li{ opacity:0; transform: translateX(12px) }
  .nav ul.active li{ opacity:1; transform:none; animation: menuItemIn .35s ease forwards }
  .nav ul.active li:nth-child(1){ animation-delay: .02s }
  .nav ul.active li:nth-child(2){ animation-delay: .06s }
  .nav ul.active li:nth-child(3){ animation-delay: .1s }
  .nav ul.active li:nth-child(4){ animation-delay: .14s }
  .nav ul.active li:nth-child(5){ animation-delay: .18s }

  /* Tap/click feedback on mobile */
  .nav a.tap-anim{
    animation: tapPress .18s ease both;
    color: var(--gold);
    border-color: var(--gold);
  }

  /* Show language select only inside mobile menu, not in header container */
  .site-header .nav > .lang-select{ display:none }
  .nav ul .lang-item{ margin-bottom:12px; padding-bottom:12px; border-bottom:1px solid rgba(255,255,255,0.1) }
  .nav ul .lang-item .lang-select{
    display:block; width:100%;
    background: rgba(255,255,255,0.12);
    color:#fff;
    border:1px solid rgba(255,255,255,0.35);
    padding:10px 14px;
    border-radius:12px;
    font-size:14px;
    box-shadow:0 6px 18px rgba(0,0,0,0.25);
    backdrop-filter: blur(4px);
  }
  .nav ul .lang-item .lang-select:focus-visible{
    outline:3px solid rgba(201,162,39,0.6);
    outline-offset:2px;
  }
  .nav ul .lang-item .lang-select option{ color:#000 }
  
  /* Mobile Layout Adjustments */
  .hero h1{font-size:36px}
  .hero p{font-size:18px}
  .hero .cta{flex-direction:column;align-items:center}
  .highlights .grid{grid-template-columns:1fr}
  .card-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  
  /* Icon Sizes for Mobile */
  .hero-icon{width:60px;height:60px}
  .highlights-icon{width:50px;height:50px}
  .testimonials-icon{width:60px;height:60px}
  .services-icon{width:60px;height:60px}
  .about-icon{width:70px;height:70px}
  .contact-icon-large{width:80px;height:80px}
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce){
  .mobile-overlay,
  .mobile-menu-toggle,
  .nav ul,
  .nav ul.active li,
  .nav a.tap-anim{
    animation: none !important;
    transition: none !important;
  }
  .nav ul{ transform: none !important; }
}

@media (max-width: 480px){
  .container{padding:0 16px}
  .hero{padding:20px}
  .section{padding:60px 0}
  .modal-body{padding:16px}
  .gallery img{height:300px}
}



