:root{
  --green:#103d35;
  --green-2:#1f6a55;
  --gold:#c49a49;
  --gold-2:#e5c978;
  --sand:#f7f1e7;
  --cream:#fffaf1;
  --ink:#17201e;
  --muted:#65716e;
  --line:#eadfcf;
  --white:#fff;
  --shadow:0 24px 70px rgba(16,61,53,.16);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1180px,92%);margin-inline:auto}
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:14px 4%;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(196,154,73,.18);
}
.brand{display:flex;align-items:center;gap:12px;min-width:max-content}
.brand-mark{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;font-weight:900;
  border:2px solid var(--gold-2);box-shadow:0 8px 22px rgba(16,61,53,.18)
}
.brand strong{display:block;font-size:1rem;letter-spacing:.02em;color:var(--green)}
.brand small{display:block;font-size:.75rem;color:var(--gold);font-weight:700}
.nav{display:flex;gap:18px;align-items:center;font-size:.92rem;color:var(--muted);font-weight:700}
.nav a:hover{color:var(--green)}
.nav-cta,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:46px;padding:0 22px;border-radius:999px;font-weight:900;transition:.25s ease;
}
.nav-cta,.btn.primary{background:linear-gradient(135deg,var(--green),var(--green-2));color:white;box-shadow:0 12px 28px rgba(16,61,53,.24)}
.btn.ghost{background:var(--white);border:1px solid var(--line);color:var(--green)}
.btn:hover,.nav-cta:hover{transform:translateY(-2px)}
.btn.full{width:100%}
.hero{position:relative;overflow:hidden;padding:88px 0 72px;background:radial-gradient(circle at top right,#e8f5ed 0,#fff 38%,#fff 100%)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,61,53,.07),transparent 44%),url("../assets/portada-sol-y-mar.jpeg") center/cover;opacity:.09;filter:saturate(.8)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--gold);font-weight:900}
h1,h2,h3{line-height:1.05;margin:0;color:var(--green)}
h1{font-family:"Playfair Display",serif;font-size:clamp(3rem,7vw,6.8rem);letter-spacing:-.04em}
h2{font-family:"Playfair Display",serif;font-size:clamp(2rem,4.5vw,4rem)}
h3{font-size:1.35rem}
.hero-text{font-size:1.25rem;max-width:640px;color:#40504c;margin:22px 0 26px}
.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.hero-pills span{padding:10px 14px;border-radius:999px;background:var(--cream);border:1px solid var(--line);font-weight:800;color:var(--green)}
.hero-card{background:#fff;border:1px solid var(--line);border-radius:34px;padding:14px;box-shadow:var(--shadow);transform:rotate(1.2deg)}
.hero-card img{border-radius:24px;width:100%;height:auto;object-fit:contain;background:#f4efe6}
.section{padding:78px 0}
.section-heading{max-width:760px;margin:0 auto 38px;text-align:center}
.section-heading p:last-child{color:var(--muted);font-size:1.08rem}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature-card,.why-box,.price-card,.finance-card,.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:0 20px 45px rgba(20,49,43,.08)
}
.feature-card{position:relative;overflow:hidden}
.feature-card::after{content:"";position:absolute;right:-45px;top:-45px;width:150px;height:150px;border-radius:50%;background:rgba(196,154,73,.12)}
.icon{font-size:2rem;display:inline-grid;place-items:center;width:62px;height:62px;border-radius:18px;background:var(--sand);margin-bottom:16px}
ul{padding-left:20px;margin-bottom:0}
.small-note{font-weight:800;color:var(--green);background:var(--sand);padding:12px;border-radius:16px}
.location{background:linear-gradient(180deg,#fff,var(--sand))}
.split{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.panel.dark{border-radius:var(--radius);padding:38px;background:linear-gradient(135deg,var(--green),#09241f);color:#fff;box-shadow:var(--shadow)}
.panel.dark h2,.panel.dark .eyebrow{color:#fff}
.panel.dark .eyebrow{color:var(--gold-2)}
.timeline{display:grid;gap:16px;margin-top:28px}
.timeline div{display:grid;grid-template-columns:150px 1fr;gap:14px;align-items:center;padding:16px;border-radius:20px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16)}
.timeline strong{font-size:1.15rem;color:var(--gold-2)}
.timeline span{color:#eff7f4}
.check-list{display:grid;gap:14px;list-style:none;padding:0;margin:24px 0 0}
.check-list li{padding:16px 16px 16px 46px;border-radius:18px;background:var(--cream);border:1px solid var(--line);position:relative;font-weight:800;color:#31423e}
.check-list li::before{content:"✓";position:absolute;left:16px;top:14px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:var(--green-2);color:white;font-size:.85rem}
.prices{background:#fff}
.price-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:stretch}
.price-card.main{background:linear-gradient(145deg,#fff,#fff8eb)}
.badge{display:inline-flex;margin-bottom:16px;background:var(--gold);color:#fff;border-radius:999px;padding:8px 14px;font-weight:900;text-transform:uppercase;font-size:.78rem;letter-spacing:.08em}
.price-card h3{font-size:clamp(2.4rem,5vw,4.8rem);font-family:"Playfair Display",serif;color:var(--green)}
.price-line{display:flex;justify-content:space-between;gap:18px;border-top:1px solid var(--line);padding:18px 0;font-weight:700;color:var(--muted)}
.price-line strong{color:var(--green);text-align:right}
.finance-card{display:flex;flex-direction:column;justify-content:center;background:var(--green);color:#fff}
.finance-card h3{color:#fff;font-size:2rem}.finance-card p{color:#eaf5f0}
.contact{background:linear-gradient(135deg,var(--sand),#fff)}
.contact-card{display:flex;justify-content:space-between;gap:28px;align-items:center;background:#fff;border:2px solid rgba(196,154,73,.18)}
.slogan{font-size:1.35rem;color:var(--gold);font-weight:900;margin:12px 0}
.phone{display:block;font-size:clamp(1.5rem,3vw,2.45rem);font-weight:900;color:var(--green)}
.float-wa{position:fixed;right:18px;bottom:18px;z-index:60;background:#25d366;color:white;padding:14px 18px;border-radius:999px;font-weight:900;box-shadow:0 14px 28px rgba(0,0,0,.22)}
.footer{padding:28px 0;background:var(--green);color:#fff}
.footer-inner{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap}
.footer a{font-weight:900;color:var(--gold-2)}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}.reveal.show{opacity:1;transform:none}
@media (max-width:920px){
  .nav{display:none}.hero-grid,.split,.price-layout{grid-template-columns:1fr}.feature-grid{grid-template-columns:1fr}.hero{padding-top:58px}.hero-card{transform:none}.contact-card{align-items:flex-start;flex-direction:column}.timeline div{grid-template-columns:1fr}.topbar{padding:12px 4%}.nav-cta{display:none}
}
@media (max-width:560px){
  .brand small{display:none}.hero-actions .btn{width:100%}.section{padding:56px 0}.feature-card,.why-box,.price-card,.finance-card,.contact-card{padding:22px}.price-line{display:block}.price-line strong{display:block;text-align:left;margin-top:6px}.footer-inner{display:block}.footer a{display:block;margin-top:8px}
}
