:root{--bg:#f7f9f8;--bg2:#eef2ef;--text:#121212;--muted:#5f6b63;--line:#dbe3de;--accent:#63b58a;--accent2:#4b9b72;--card:#ffffff;--nav:#000}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro Display","Helvetica Neue",Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
.container{max-width:1140px;margin:auto;padding:0 34px}

.site-header{background:transparent;padding-bottom:0;overflow:visible}

@keyframes heroFadeA{
  0%,50%{opacity:1;transform:scale(1.05) translateX(0)}
  58%,92%{opacity:0;transform:scale(1.08) translateX(-1%)}
  100%{opacity:1;transform:scale(1.05) translateX(0)}
}
@keyframes heroFadeB{
  0%,42%{opacity:0;transform:scale(1.08) translateX(1%)}
  50%,92%{opacity:1;transform:scale(1.05) translateX(0)}
  100%{opacity:0;transform:scale(1.08) translateX(1%)}
}
.nav-shell{width:100%;background:var(--nav);border-bottom:none}
.nav{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:20px;padding:20px 22px;border-radius:0}
.logo img{height:58px;width:auto;display:block}

nav{display:flex;justify-content:center;gap:28px;align-items:center}
nav a{color:#ececec;text-decoration:none;font-size:14px;letter-spacing:.08em;text-transform:uppercase;font-weight:400}
nav a:hover{color:#fff}

.lang-switcher{position:relative;display:flex;align-items:center}
.lang{border:1px solid transparent;background:#0c0c0c;color:#cbd5e1;border-radius:8px;padding:6px 9px;font-size:12px;font-weight:700;cursor:pointer}
.lang.active{background:var(--accent);color:#0f172a;border-color:var(--accent)}

.btn{display:inline-block;background:linear-gradient(180deg,var(--accent),var(--accent2));color:#ffffff;padding:12px 18px;border-radius:12px;font-weight:600;text-decoration:none;box-shadow:0 6px 16px rgba(72,155,114,.20);transition:transform .18s ease,box-shadow .2s ease,filter .2s ease}.btn:hover{filter:brightness(1.03);transform:translateY(-1px);box-shadow:0 10px 22px rgba(72,155,114,.24)}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}

.hero{display:grid;grid-template-columns:1.12fr .88fr;gap:30px;align-items:center;min-height:54vh;padding-top:0;padding-bottom:0}
.eyebrow{color:#b9e2cc;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
h1{font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Helvetica,Arial,sans-serif;font-size:44px;line-height:1.06;margin:.45rem 0 1rem;letter-spacing:-.012em;font-weight:500;color:#ffffff;text-shadow:0 6px 24px rgba(0,0,0,.45)}
.sub{color:#d6ddd9;max-width:62ch;font-size:18px;line-height:1.6}
.hero-actions{display:flex;gap:14px;align-items:center;margin-top:22px}
.link{color:#fff;text-decoration:none}

.hero-card{background:rgba(255,255,255,.92);border:none;padding:24px;border-radius:14px;backdrop-filter:blur(3px);box-shadow:0 12px 30px rgba(16,24,20,.12)}
.hero-card h3{margin-top:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Helvetica,Arial,sans-serif;font-size:26px;font-weight:500;color:#111}
.hero-card ul{list-style:none;padding-left:0;margin:0}
.hero-card li{margin:11px 0;color:#33413a;padding-left:30px;position:relative;min-height:22px;display:flex;align-items:center}.hero-card li:before{content:"→";position:absolute;left:0;top:50%;transform:translateY(-50%);width:20px;height:20px;border-radius:999px;background:rgba(99,181,138,.18);color:#3f8f66;font-size:12px;line-height:20px;text-align:center;font-weight:700}

.section{padding:56px 0}
.section h2{font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Helvetica,Arial,sans-serif;font-size:38px;margin:0 0 22px;letter-spacing:-.008em;font-weight:500;padding-left:2px}
.grid{display:grid;gap:16px}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:none;padding:24px;border-radius:14px;box-shadow:0 10px 28px rgba(16,24,20,.08)}
.card h3{margin-top:0;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Helvetica,Arial,sans-serif;font-size:25px;font-weight:500}
.card p{color:var(--muted);line-height:1.7}.card{transition:transform .2s ease,border-color .2s ease}.card:hover{transform:translateY(-2px);border-color:#2a3e33}

.section-dark{background:linear-gradient(180deg,#f2f5f3,#edf2ef);border-top:none;border-bottom:none}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.steps div{background:#ffffff;border:none;padding:16px;border-radius:12px;box-shadow:0 8px 20px rgba(16,24,20,.08)}
.steps span{display:inline-block;color:#9fd6b6;font-weight:800;margin-bottom:8px}

.cta{padding-top:24px}
.cta-wrap{background:linear-gradient(180deg,#ffffff,#f5f8f6);border:none;border-radius:14px;padding:24px;display:flex;justify-content:space-between;align-items:center;gap:16px;box-shadow:0 14px 30px rgba(16,24,20,.10)}

@media (max-width:980px){
  .nav-right{grid-column:1/-1;align-items:flex-start;width:100%;gap:8px}
  #top-nav{width:100%;justify-content:flex-start}

  .nav{grid-template-columns:1fr;gap:10px;justify-items:start}
  nav{justify-content:flex-start;flex-wrap:wrap;gap:14px}
  .hero{grid-template-columns:1fr}
  .cols-3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  h1{font-size:46px}
}
@media (max-width:640px){
  .container{padding:0 20px}

  h1{font-size:36px}
  .sub{font-size:16px}
  .cols-3,.cols-2,.steps{grid-template-columns:1fr}
  .cta-wrap{flex-direction:column;align-items:flex-start}
}

#servicios{padding-top:26px}

.hero-slideshow{position:relative;overflow:hidden;padding:20px 0 54px;margin-bottom:0;background:#000}
.hero-slideshow:before,.hero-slideshow:after{content:"";position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;z-index:0;transform:scale(1.05)}
.hero-slideshow:before{background-image:linear-gradient(180deg,rgba(0,0,0,.68),rgba(0,0,0,.48) 46%,rgba(11,11,11,.72) 72%,rgba(11,11,11,.55)),url('hero-01.webp');animation:heroFadeA 24s ease-in-out infinite}
.hero-slideshow:after{background-image:linear-gradient(180deg,rgba(0,0,0,.68),rgba(0,0,0,.48) 46%,rgba(11,11,11,.72) 72%,rgba(11,11,11,.55)),url('hero-02.jpg');animation:heroFadeB 24s ease-in-out infinite}
.hero-slideshow > *{position:relative;z-index:1}

.site-footer{background:#000000;color:#d6dfd9;padding:44px 0 24px;margin-top:36px}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:24px}
.site-footer h4{margin:0 0 10px;font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:#f1f5f2}
.site-footer a{display:block;color:#aebcb3;text-decoration:none;margin:6px 0;font-size:14px}
.site-footer a:hover{color:#fff}
.footer-note{margin-top:12px;padding-top:0;border-top:none;font-size:13px;color:#95a39a}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

.lang-pill{border:none;background:rgba(255,255,255,.16);color:#f6fbf8;border-radius:14px;padding:6px 10px;min-width:132px;min-height:34px;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 7px 15px rgba(0,0,0,.17),inset 0 0 0 1px rgba(255,255,255,.20);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.lang-pill:hover{transform:translateY(-1px);background:linear-gradient(180deg,rgba(255,255,255,.22),rgba(255,255,255,.14));box-shadow:0 18px 40px rgba(0,0,0,.26),inset 0 0 0 1px rgba(255,255,255,.26)}
.lang-pill:focus{outline:none;box-shadow:0 0 0 4px rgba(131,220,173,.24),0 18px 40px rgba(0,0,0,.28),inset 0 0 0 1px rgba(255,255,255,.28)}
.lang-caret{opacity:.95;font-size:16px;padding-left:8px}
.lang-menu{position:absolute;right:0;top:calc(100% + 10px);min-width:132px;background:rgba(22,31,26,.84);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:24px;padding:10px;display:none;box-shadow:0 16px 36px rgba(0,0,0,.30),inset 0 0 0 1px rgba(255,255,255,.12);z-index:40}
.lang-menu.open{display:block}
.lang-option{width:100%;text-align:left;border:none;background:transparent;color:#eef7f1;padding:8px 10px;border-radius:10px;font-size:12px;cursor:pointer;font-weight:500}
.lang-option:hover{background:rgba(255,255,255,.08)}

.nav-toggle{display:none;border:none;background:transparent;color:#f3f3f3;font-size:26px;line-height:1;cursor:pointer;padding:6px 8px;border-radius:8px}
.nav-toggle:hover{background:rgba(255,255,255,.08)}

@media (max-width:980px){
  .nav-right{grid-column:1/-1;align-items:flex-start;width:100%;gap:8px}
  #top-nav{width:100%;justify-content:flex-start}

  .nav{grid-template-columns:auto auto 1fr;align-items:start}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  #top-nav{display:flex;justify-content:flex-end;gap:28px;align-items:center}
  #top-nav.open{display:flex}
  #top-nav a{padding:6px 2px;font-size:14px}
  .lang-switcher{margin-left:auto}
}

#top-nav{display:flex;justify-content:flex-end;gap:28px;align-items:center}
.nav .lang-switcher{justify-self:end;margin-bottom:10px}

.footer-logo{display:inline-block}
.footer-logo img{height:64px;width:auto;display:block;filter:brightness(1.03)}

.nav-right{display:flex;flex-direction:column;align-items:flex-end;justify-self:end;gap:10px}
#top-nav{display:flex;justify-content:flex-end;gap:28px;align-items:center}

@media (max-width:980px){
  .nav-right{grid-column:1/-1;align-items:flex-start;width:100%;gap:8px}
  #top-nav{width:100%;justify-content:flex-start}
.nav-right{display:flex;flex-direction:column;align-items:flex-end;justify-self:end;gap:10px}.lang-switcher{margin-left:0}}

.lang-pill span:first-child{display:inline-block;min-width:0;text-align:center;flex:1}



main .container, main.container{padding-left:56px;padding-right:56px}
@media (max-width:980px){main .container, main.container{padding-left:34px;padding-right:34px}}
@media (max-width:640px){main .container, main.container{padding-left:22px;padding-right:22px}}

/* Mobile nav behavior fix: collapse into hamburger + slide-down menu */
.site-header #top-nav { display: flex; }

@media (max-width: 980px) {
  .site-header .nav {
    grid-template-columns: auto auto 1fr;
    align-items: center;
    gap: 12px;
  }

  .site-header .logo { z-index: 61; }

  .site-header .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 61;
  }

  .site-header .nav-right {
    position: relative;
    grid-column: 1 / -1;
    width: 100%;
    align-items: stretch;
    gap: 10px;
  }

  .site-header .lang-switcher {
    margin-left: 0;
    align-self: flex-end;
    z-index: 62;
  }

  .site-header #top-nav {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    width: 100%;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-8px);
    pointer-events: none;
    transition: max-height .28s ease, opacity .22s ease, transform .24s ease;
    background: rgba(10, 10, 10, .96);
    border-radius: 12px;
    padding: 0 10px;
    box-shadow: 0 12px 24px rgba(0,0,0,.24);
  }

  .site-header #top-nav.open {
    max-height: 360px;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    padding: 10px;
  }

  .site-header #top-nav a {
    display: block;
    width: 100%;
    padding: 12px 10px;
    border-radius: 8px;
    font-size: 13px;
    letter-spacing: .06em;
  }

  .site-header #top-nav a:hover {
    background: rgba(255,255,255,.08);
  }
}

/* Mobile header alignment polish (logo, hamburger, language switcher) */
@media (max-width: 980px) {
  .site-header .nav {
    position: relative;
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: 14px 18px;
    min-height: 78px;
  }

  .site-header .logo {
    display: inline-flex;
    align-items: center;
    min-height: 48px;
  }

  .site-header .nav-toggle {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    justify-self: end;
    margin: 0;
    font-size: 24px;
    padding: 8px;
  }

  .site-header .nav-right {
    grid-column: 1 / -1;
    margin-top: 8px;
    padding-top: 0;
  }

  .site-header .lang-switcher {
    position: absolute;
    right: 58px;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
    z-index: 70;
  }

  .site-header .lang-pill {
    min-height: 32px;
    padding: 5px 10px;
    border-radius: 12px;
  }

  .site-header .lang-menu {
    top: calc(100% + 8px);
    right: 0;
  }

  .site-header #top-nav {
    margin-top: 2px;
  }
}

@media (max-width: 640px) {
  .site-header .lang-switcher { right: 52px; }
}

/* Mobile header layout v2: keep logo + language + hamburger on one row */
@media (max-width: 980px) {
  .site-header .nav {
    grid-template-columns: 1fr auto auto;
    grid-template-rows: auto auto;
    align-items: center;
    column-gap: 10px;
    row-gap: 8px;
  }

  .site-header .nav-right {
    display: contents;
  }

  .site-header .logo {
    grid-column: 1;
    grid-row: 1;
  }

  .site-header .lang-switcher {
    position: static;
    transform: none;
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    justify-self: end;
    z-index: 70;
  }

  .site-header .nav-toggle {
    grid-column: 3;
    grid-row: 1;
    align-self: center;
    justify-self: end;
  }

  .site-header #top-nav {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: 0;
  }
}

@media (max-width: 640px) {
  .site-header .lang-pill {
    min-width: 118px;
    font-size: 11px;
    padding: 5px 9px;
  }
}

/* Final mobile header pass: stronger sizing/alignment overrides */
@media (max-width: 980px) {
  .site-header .nav-shell { overflow: visible; }

  .site-header .nav {
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    grid-template-rows: auto auto !important;
    align-items: center !important;
    padding: 14px 16px !important;
    min-height: 74px !important;
    column-gap: 10px !important;
    row-gap: 8px !important;
  }

  .site-header .logo,
  .site-header .logo img {
    display: block;
  }

  .site-header .logo {
    grid-column: 1 !important;
    grid-row: 1 !important;
    align-self: center !important;
  }

  .site-header .lang-switcher {
    grid-column: 2 !important;
    grid-row: 1 !important;
    position: static !important;
    transform: none !important;
    align-self: center !important;
    justify-self: end !important;
    margin: 0 !important;
  }

  .site-header .lang-pill {
    min-width: 122px !important;
    min-height: 34px !important;
    padding: 6px 10px !important;
    border-radius: 12px !important;
    font-size: 11.5px !important;
  }

  .site-header .nav-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    align-self: center !important;
    justify-self: end !important;
    font-size: 24px !important;
    line-height: 1 !important;
    padding: 8px !important;
    background: rgba(255,255,255,.08) !important;
    border-radius: 10px !important;
  }

  .site-header #top-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    margin-top: 0 !important;
  }
}

@media (max-width: 420px) {
  .site-header .lang-pill { min-width: 112px !important; }
}

/* Services cards: consistent vector icon set, left of title */
.services-grid .service-card{
  position:relative;
  overflow:hidden;
  padding:18px 20px;
}
.services-grid .service-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:180px;
  height:120px;
  background:radial-gradient(circle at top left, rgba(99,181,138,.15) 0%, rgba(99,181,138,.08) 30%, rgba(99,181,138,0) 72%);
  pointer-events:none;
}
.services-grid .service-head{
  position:relative;
  z-index:1;
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:12px;
}
.services-grid .service-icon{
  width:40px;
  height:40px;
  color:#2f7e5d;
  flex:0 0 40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.services-grid .service-icon svg{width:34px;height:34px;display:block}
.services-grid .service-card h3,
.services-grid .service-card p{position:relative;z-index:1}
.services-grid .service-card h3{margin:0;line-height:1.2}
.services-grid .service-card p{margin-top:2px}

/* Mobile fix: keep language dropdown attached to pill */
@media (max-width: 980px) {
  .site-header .lang-switcher {
    position: relative !important;
  }

  .site-header .lang-menu {
    top: calc(100% + 4px) !important;
    right: 0 !important;
    left: auto !important;
    transform: none !important;
    z-index: 120 !important;
  }
}

/* Mobile header correction: keep language selector inline with hamburger */
@media (max-width: 980px) {
  .site-header .nav {
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    align-items: center !important;
  }

  .site-header .lang-switcher {
    grid-column: 2 !important;
    grid-row: 1 !important;
    position: relative !important;
    justify-self: end !important;
    align-self: center !important;
    margin: 0 6px 0 0 !important;
    transform: none !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
  }

  .site-header .nav-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: center !important;
    margin: 0 !important;
  }

  .site-header .lang-menu {
    top: calc(100% + 6px) !important;
    right: 0 !important;
    left: auto !important;
  }
}

/* Keep bottom CTA aligned with wrapped sections on mobile */
@media (max-width: 640px) {
  #contacto .container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #contacto .cta-wrap {
    margin-left: 22px;
    margin-right: 22px;
    width: auto;
  }
}


/* Mobile CTA padding polish */
@media (max-width: 640px) {
  #contacto.section.cta {
    padding-top: 34px;
    padding-bottom: 34px;
  }

  #contacto .cta-wrap {
    padding: 20px 18px;
    border-radius: 12px;
    gap: 12px;
  }

  #contacto .cta-wrap h2 {
    margin: 0 0 10px;
    line-height: 1.2;
  }

  #contacto .cta-wrap p {
    margin: 0;
    line-height: 1.45;
  }
}


/* Mobile CTA internal padding match with other cards/sections */
@media (max-width: 640px) {
  #contacto .cta-wrap {
    box-sizing: border-box;
    padding: 24px 22px !important;
  }
}

/* Inner page spacing polish (About page mobile) */
.page-main h2 {
  margin-top: 0;
}

@media (max-width: 640px) {
  .page-main {
    padding-top: 24px !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
}

/* Final CTA mobile layout override: match wrapped sections cleanly */
@media (max-width: 640px) {
  #contacto {
    padding-top: 34px !important;
    padding-bottom: 34px !important;
  }

  #contacto > .container.cta-wrap {
    margin-left: 22px !important;
    margin-right: 22px !important;
    width: auto !important;
    box-sizing: border-box !important;
    padding: 24px 22px !important;
    border-radius: 12px !important;
    gap: 12px !important;
  }

  #contacto > .container.cta-wrap h2 {
    margin: 0 0 10px !important;
    line-height: 1.2 !important;
  }

  #contacto > .container.cta-wrap p {
    margin: 0 !important;
    line-height: 1.45 !important;
  }
}

/* Desktop CTA width alignment with main content boxes */
@media (min-width: 981px) {
  #contacto > .container.cta-wrap {
    max-width: 1028px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* CTA container alignment fix: match other section gutters */
#contacto .container {
  padding-left: 56px;
  padding-right: 56px;
}

#contacto .cta-wrap {
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
  width: 100%;
  box-sizing: border-box;
}

@media (max-width: 980px) {
  #contacto .container {
    padding-left: 34px !important;
    padding-right: 34px !important;
  }
}

@media (max-width: 640px) {
  #contacto .container {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  #contacto .cta-wrap {
    padding: 24px 22px !important;
  }
}


/* Floating WhatsApp button */
.wa-float{
  position:fixed;
  right:18px;
  bottom:18px;
  width:56px;
  height:56px;
  border-radius:999px;
  background:#25D366;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 24px rgba(0,0,0,.22);
  z-index:150;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.wa-float:hover{transform:translateY(-1px) scale(1.02);filter:brightness(1.03);box-shadow:0 16px 30px rgba(0,0,0,.28)}
.wa-float svg{width:31px;height:31px;display:block}
@media (max-width:640px){
  .wa-float{right:14px;bottom:14px;width:52px;height:52px}
  .wa-float svg{width:28px;height:28px}
}

/* Contact page form */
.contact-card{max-width:none;width:100%}
.contact-form{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#314039}
.contact-form input,.contact-form textarea{border:1px solid #d8e0db;border-radius:10px;padding:10px 12px;font:inherit;color:#141414;background:#fff}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#82caa4;box-shadow:0 0 0 3px rgba(99,181,138,.18)}
.contact-alert{background:#fff3f2;border:1px solid #ffd1cd;color:#8d2a20;padding:10px 12px;border-radius:10px;margin:10px 0}
.contact-sep{border:0;border-top:1px solid #e4ebe7;margin:18px 0}
.hp-field{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.wa-link-btn{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#fff !important;text-decoration:none;padding:7px 12px;border-radius:999px;font-weight:600}
.wa-link-btn:hover{filter:brightness(1.03)}
.contact-thankyou h3{margin:.2rem 0 .6rem}
.contact-thankyou p{margin:0 0 12px;color:#48564f}
@media (max-width:640px){.contact-grid{grid-template-columns:1fr}}

.wa-link-btn{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#fff !important;text-decoration:none;padding:9px 14px;border-radius:999px;font-weight:700;box-shadow:0 8px 18px rgba(20,84,46,.22)}
.wa-link-btn svg{width:18px;height:18px;display:block}
.wa-link-btn:hover{filter:brightness(1.03);transform:translateY(-1px)}
.contact-form .btn{background:linear-gradient(180deg,#1f2a24,#161d19);box-shadow:0 8px 18px rgba(15,20,17,.24);border:none !important} 
.contact-form .btn:hover{filter:brightness(1.08)}

.contact-form .btn{width:auto;align-self:flex-start;padding:10px 16px}
.contact-wa-row{margin:10px 0 6px}

.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:18px;align-items:start;margin-top:10px}
.contact-left,.contact-right{background:#fff;border:1px solid #e2e9e4;border-radius:12px;padding:16px}
.contact-left h3,.contact-right h3{margin:0 0 8px;font-size:20px;line-height:1.25}
.contact-left p{margin:0 0 12px;color:#4b5a52}
@media (max-width:860px){.contact-layout{grid-template-columns:1fr}.contact-left,.contact-right{padding:14px}}

/* Invest page */
.invest-page{display:flex;flex-direction:column;gap:18px}
.invest-intro{color:#425047;line-height:1.7;max-width:90ch;margin-top:-4px}
.invest-metrics .metric-card h3{margin:.15rem 0 .4rem;font-size:30px;line-height:1.05}
.metric-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:#4c6558;font-weight:700;margin:0}
.invest-reasons .card h3{margin:.1rem 0 .5rem}
.invest-cta-block{margin-top:4px}
.invest-cta-block .btn{margin-top:8px}
@media (max-width:980px){.invest-metrics{grid-template-columns:1fr}.invest-reasons{grid-template-columns:1fr}}

/* List your property page */
.list-page{display:flex;flex-direction:column;gap:18px}
.list-hero{position:relative;overflow:hidden;color:#f2faf6}
.list-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(99,181,138,.28),transparent 52%);pointer-events:none}
.list-hero > *{position:relative;z-index:1}
.list-hero-kicker{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#bfe7d1;font-weight:700;margin:0 0 8px}
.list-hero h2{margin:0 0 10px;font-size:44px;line-height:1.06;color:#fff}
.list-hero-sub{margin:0 0 14px;max-width:70ch;color:#f2f6f4;line-height:1.6}
.list-metrics .card h3,.list-reasons .card h3{margin:.1rem 0 .5rem}
.list-cta h3{margin:.1rem 0 .5rem}
.list-cta .btn{margin-top:8px}
@media (max-width:980px){.list-metrics{grid-template-columns:1fr}.list-reasons{grid-template-columns:1fr}.list-hero h2{font-size:34px}}
@media (max-width:640px){.list-hero h2{font-size:30px}}

.invest-hero{position:relative;overflow:hidden;color:#f4faf7}
.invest-hero h2{margin:0 0 10px;color:#fff;font-size:46px;line-height:1.06;text-shadow:0 8px 22px rgba(0,0,0,.45)}
.invest-hero .invest-intro{color:#f1f6f3;max-width:74ch}



/* Shared full-width hero styling (like homepage) */
.page-hero-full{
  position:relative;
  overflow:hidden;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  margin-top:0 !important;
  border-radius:0;
  padding:0;
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center center;
}
.page-hero-inner{
  max-width:1140px;
  margin:0 auto;
  padding:34px 56px;
  position:relative;
  z-index:1;
}
@media (max-width:980px){.page-hero-inner{padding:28px 34px}}
@media (max-width:640px){.page-hero-inner{padding:24px 22px}}

.list-hero.page-hero-full{
  background:linear-gradient(180deg,rgba(6,10,8,.74),rgba(6,10,8,.58)),url('lp-hero.jpg');
  color:#f2faf6;
  min-height:380px;
  background-position:center 28%;
}
.list-hero.page-hero-full:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(99,181,138,.28),transparent 52%);pointer-events:none}

.invest-hero.page-hero-full{
  background:linear-gradient(180deg,rgba(0,0,0,.62),rgba(0,0,0,.48)),url('invest-hero.jpg');
  color:#f4faf7;
  box-shadow:none;
  min-height:430px;
}

.contact-hero.page-hero-full{
  background:linear-gradient(180deg,rgba(0,0,0,.60),rgba(0,0,0,.48)),url('hero-02.jpg');
  color:#f4faf7;
  margin-bottom:16px;
  min-height:280px;
}
.contact-hero h2{margin:0;color:#fff;text-shadow:0 8px 22px rgba(0,0,0,.45)}

.contact-page.page-main,.invest-page.page-main,.list-page.page-main{padding-top:0 !important}

/* Hero full-bleed fix (prevents right-edge repeat strip) */
.page-hero-full{
  width: 100vw !important;
  margin-left: 50% !important;
  margin-right: 0 !important;
  transform: translateX(-50%);
  background-repeat: no-repeat !important;
  background-size: cover !important;
  background-position: center center !important;
}
.contact-hero-sub{margin:10px 0 0;max-width:74ch;color:#e5ece8;line-height:1.6;text-shadow:0 2px 10px rgba(0,0,0,.35)}

@media (max-width:640px){.invest-hero.page-hero-full{min-height:320px}}

.contact-hero .page-hero-inner{min-height:320px;display:flex;flex-direction:column;justify-content:center}

.list-hero .page-hero-inner{min-height:380px;display:flex;flex-direction:column;justify-content:center}
@media (max-width:640px){.list-hero .page-hero-inner{min-height:340px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}}

.list-hero .btn{align-self:flex-start;width:auto}

.list-hero .page-hero-inner h2,.list-hero .page-hero-inner .list-hero-sub{ text-shadow:0 3px 14px rgba(0,0,0,.55); }

@media (max-width:640px){.list-hero.page-hero-full{background-position:center 22%;min-height:340px}}

.invest-hero .page-hero-inner{min-height:430px;display:flex;flex-direction:column;justify-content:center}
@media (max-width:640px){.invest-hero .page-hero-inner{min-height:320px}}

.invest-hero .page-hero-inner h2,.invest-hero .page-hero-inner .invest-intro{ text-shadow:0 4px 18px rgba(0,0,0,.65), 0 1px 2px rgba(0,0,0,.55); }

.book-page.page-main{padding-top:0 !important}
.book-hero.page-hero-full{
  background:linear-gradient(180deg,rgba(0,0,0,.58),rgba(0,0,0,.42)),url('bd-hero.jpg');
  color:#f4faf7;
  min-height:360px;
  margin-bottom:16px;
  background-position:center center;
}
.book-hero h2{
  margin:0 0 10px;
  font-size:44px;
  line-height:1.06;
  color:#fff;
  max-width:780px;
  text-shadow:0 4px 18px rgba(0,0,0,.62),0 1px 2px rgba(0,0,0,.52);
}
.book-hero .page-hero-inner{
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
}
@media (max-width:640px){
  .book-hero.page-hero-full{min-height:290px}
  .book-hero .page-hero-inner{min-height:290px}
}
@media (max-width:640px){.invest-hero h2{font-size:31px;line-height:1.12}}

.book-hero-sub{margin:0 0 14px;max-width:70ch;color:#f2f6f4;line-height:1.6;text-shadow:0 3px 14px rgba(0,0,0,.55)}


.invest-hero .btn{align-self:flex-start;width:auto}

.book-page .book-hero{margin-bottom:16px}

.invest-hero .invest-hero-btn{display:inline-flex !important; width:auto !important; max-width:max-content !important; align-self:flex-start !important;}

@media (max-width:980px){.book-hero h2{font-size:34px}}
@media (max-width:640px){.book-hero h2{font-size:30px}}

/* Vertical variety bands for Invest/List pages */
.content-band{
  background:#ffffff;
  border-radius:14px;
  padding:20px;
  box-shadow:0 10px 24px rgba(16,24,20,.06);
}
.content-band.soft{
  background:var(--bg-dark);
}
.section-head{
  margin:0 0 12px;
}
.section-head h3{
  margin:0;
  font-size:22px;
  line-height:1.2;
  color:#1b2320;
}
.content-band.soft .section-head h3{color:#1f2a24}

.invest-page .content-band,
.list-page .content-band{
  margin-top:2px;
}

@media (max-width:640px){
  .content-band{padding:16px}
  .section-head h3{font-size:19px}
}

/* Replace inner wrappers with full-width alternating section bands */
.list-page .full-bleed.section-dark,
.invest-page .full-bleed.section-dark{
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding-top:28px;
  padding-bottom:28px;
}

.list-page .list-dark-band h3,
.invest-page .invest-dark-band h3{
  margin:0 0 12px;
}

.list-performance,
.invest-signals{
  margin-top:2px;
}

/* neutralize old wrapper style if present */
.content-band{
  background:transparent !important;
  border-radius:0 !important;
  padding:0 !important;
  box-shadow:none !important;
}

@media (max-width:980px){
  .list-page .full-bleed.section-dark,
  .invest-page .full-bleed.section-dark{
    padding-top:24px;
    padding-bottom:24px;
  }
}

.invest-dark-band > .container > h3{font-size:32px;line-height:1.15;margin:0 0 14px;font-weight:500}
@media (max-width:640px){.invest-dark-band > .container > h3{font-size:32px;line-height:1.15;margin:0 0 14px;font-weight:500}}

.list-page .section-head h3{font-size:29px;line-height:1.2;margin:0 0 12px;font-weight:500;letter-spacing:0}
.list-dark-band > .container > h3{font-size:29px;line-height:1.2;margin:0 0 12px;font-weight:500;letter-spacing:0}
@media (max-width:640px){.list-page .section-head h3,.list-dark-band > .container > h3{font-size:29px;line-height:1.2;margin:0 0 12px;font-weight:500;letter-spacing:0}}

.invest-signals .section-head h3{font-size:32px;line-height:1.15;margin:0 0 14px;font-weight:500}

@media (max-width:640px){.invest-dark-band > .container > h3,.invest-signals .section-head h3{font-size:26px;line-height:1.18;font-weight:500}}

@media (max-width:640px){.list-page .section-head h3,.list-dark-band > .container > h3{font-size:24px;line-height:1.24;font-weight:500}}


/* Footer redesign */
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;align-items:start}
.footer-grid h4{margin:0 0 10px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#e8efe9}
.footer-grid a{display:block;margin:7px 0;color:#c7d3cc;text-decoration:none}
.footer-grid a:hover{color:#fff}
.footer-note{padding-left:2px}
@media (max-width:980px){.footer-grid{grid-template-columns:1fr 1fr;gap:22px}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr;gap:18px}.footer-note{padding-left:0}}

/* Footer alignment fix */
.site-footer .container{padding-left:34px;padding-right:34px}
.site-footer .footer-note{padding-left:0 !important;margin-left:0 !important;text-align:left}
@media (max-width:640px){.site-footer .container{padding-left:20px;padding-right:20px}}
