:root {
  --primary: #114da0;
  --primary-dark: #02155e;
  --soft-blue: #c3dedb;
  --soft-bg: #f6f6f4;
  --accent: #dfed37;
  --white: #fff;
  --text: #1b1b1b;
  --muted: #5c6470;
  --border: #dfe5ea;
  --radius: 24px;
  --shadow: 0 18px 48px rgba(2, 21, 94, .12);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body { font-family: Roboto, Arial, sans-serif; color: var(--text); background: var(--white); line-height: 1.65; }
h1, h2, h3, h4, .brand, .btn { font-family: Poppins, Arial, sans-serif; }
h1, h2, h3 { line-height: 1.14; }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button, input, select, textarea { font: inherit; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--accent); outline-offset: 3px;
}
.skip-link { position: fixed; left: 12px; top: -60px; z-index: 2000; padding: 10px 16px; background: var(--accent); color: var(--primary-dark); border-radius: 8px; font-weight: 700; }
.skip-link:focus { top: 12px; }
.container { width: min(1160px, 88%); margin-inline: auto; }
.section { padding: 88px 0; }
.section.soft { background: var(--soft-bg); }
.section.blue { background: var(--primary-dark); color: var(--white); }
.section-heading { max-width: 760px; margin-bottom: 42px; }
.section-heading.center { text-align: center; margin-inline: auto; }
.section-heading h2 { color: var(--primary-dark); font-size: clamp(2rem, 4vw, 3.25rem); margin: 10px 0 16px; }
.blue .section-heading h2 { color: var(--white); }
.eyebrow { color: var(--primary); font: 700 .78rem/1 Poppins, sans-serif; letter-spacing: .11em; text-transform: uppercase; }
.hero .eyebrow, .blue .eyebrow { color: var(--accent); }
.lead { font-size: 1.12rem; color: var(--muted); }
.blue .lead { color: rgba(255,255,255,.82); }
.grid { display: grid; gap: 24px; }
.grid.two { grid-template-columns: repeat(2, 1fr); }
.grid.three { grid-template-columns: repeat(3, 1fr); }
.grid.four { grid-template-columns: repeat(4, 1fr); }
.card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 30px; box-shadow: 0 10px 30px rgba(2,21,94,.05); }
.card h3 { color: var(--primary-dark); margin-bottom: 12px; font-size: 1.23rem; }
.card p { color: var(--muted); }
.card .number { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 20px; border-radius: 50%; background: var(--primary); color: var(--white); font: 700 1rem Poppins, sans-serif; }
.icon-mark { width: 44px; height: 4px; margin-bottom: 22px; border-radius: 99px; background: var(--accent); box-shadow: 14px 8px 0 var(--soft-blue); }

.site-header { position: fixed; inset: 0 0 auto; z-index: 1000; background: rgba(2,21,94,.94); color: var(--white); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255,255,255,.12); }
.nav-wrap { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-size: 1.22rem; font-weight: 700; }
.brand-mark { display: grid; place-items: center; width: 37px; height: 37px; border-radius: 50% 50% 50% 12px; background: var(--accent); color: var(--primary-dark); font-size: 1.15rem; transform: rotate(-8deg); }
.brand-mark span { transform: rotate(8deg); }
.site-nav { display: flex; align-items: center; gap: 20px; }
.site-nav a { font-size: .86rem; font-weight: 500; color: rgba(255,255,255,.88); }
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--accent); }
.menu-button { display: none; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.35); border-radius: 12px; color: var(--white); background: transparent; cursor: pointer; }
.menu-button span, .menu-button::before, .menu-button::after { content: ""; display: block; width: 21px; height: 2px; margin: 5px auto; background: currentColor; transition: .2s; }

.hero { position: relative; min-height: 680px; padding: 150px 0 82px; display: flex; align-items: center; color: var(--white); overflow: hidden; background: var(--primary-dark); }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(2,21,94,.93) 0%, rgba(2,21,94,.72) 46%, rgba(2,21,94,.18) 100%), var(--hero-image) center/cover no-repeat; }
.hero::after { content: ""; position: absolute; left: -8%; bottom: -120px; width: 55%; height: 190px; border: 2px solid rgba(195,222,219,.26); border-radius: 50%; transform: rotate(-6deg); }
.hero-content { position: relative; z-index: 2; max-width: 750px; }
.hero h1 { font-size: clamp(2.65rem, 6vw, 5.4rem); letter-spacing: -.045em; margin: 18px 0 22px; }
.hero p { max-width: 680px; font-size: clamp(1rem, 2vw, 1.2rem); color: rgba(255,255,255,.9); }
.actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 12px 22px; border: 1px solid transparent; border-radius: 999px; font-size: .88rem; font-weight: 700; cursor: pointer; transition: transform .2s, box-shadow .2s, background .2s; }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.btn.primary { background: var(--accent); color: var(--primary-dark); }
.btn.secondary { background: var(--white); color: var(--primary-dark); }
.btn.outline { border-color: rgba(255,255,255,.66); color: var(--white); }
.btn.blue { background: var(--primary); color: var(--white); }

.path-card { position: relative; min-height: 285px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; color: var(--white); background: var(--primary-dark); }
.path-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(2,21,94,.05), rgba(2,21,94,.96)), var(--card-image) center/cover no-repeat; }
.path-card > * { position: relative; z-index: 1; }
.path-card h3, .path-card p { color: var(--white); }
.path-card .text-link { margin-top: 16px; color: var(--accent); font-weight: 700; }
.quote { max-width: 930px; margin-inline: auto; text-align: center; font: 600 clamp(1.8rem, 4vw, 3.4rem)/1.28 Poppins, sans-serif; }
.cta-band { display: flex; justify-content: space-between; align-items: center; gap: 28px; padding: 42px; border-radius: var(--radius); background: var(--soft-blue); }
.cta-band h2 { max-width: 720px; color: var(--primary-dark); font-size: clamp(1.7rem, 3.2vw, 2.7rem); }
.media-split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.media-split img { min-height: 430px; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow); }
.check-list { display: grid; gap: 15px; margin-top: 24px; list-style: none; }
.check-list li { position: relative; padding-left: 31px; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 0; display: grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: var(--primary-dark); font-weight: 900; }

.steps { counter-reset: step; display: grid; gap: 18px; }
.step { counter-increment: step; display: grid; grid-template-columns: 64px 1fr; gap: 20px; align-items: start; padding: 26px; background: var(--white); border: 1px solid var(--border); border-radius: 20px; }
.step::before { content: counter(step, decimal-leading-zero); display: grid; place-items: center; width: 54px; height: 54px; border-radius: 50%; background: var(--primary); color: var(--white); font: 700 .95rem Poppins, sans-serif; }
.step h3 { color: var(--primary-dark); margin: 3px 0 6px; }
.data-chips { display: flex; flex-wrap: wrap; gap: 12px; }
.data-chips span { padding: 12px 18px; border: 1px solid var(--border); border-radius: 999px; background: var(--white); color: var(--primary-dark); font-weight: 600; }

.community-tools { display: grid; grid-template-columns: 1fr auto; gap: 18px; margin-bottom: 28px; }
.search-field { width: 100%; min-height: 50px; padding: 12px 18px; border: 1px solid var(--border); border-radius: 14px; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.filter { min-height: 44px; padding: 9px 14px; border: 1px solid var(--border); border-radius: 999px; background: var(--white); color: var(--primary-dark); cursor: pointer; }
.filter.active { background: var(--primary); color: var(--white); border-color: var(--primary); }
.community-layout { display: grid; grid-template-columns: 1fr 1.15fr; gap: 28px; }
.community-list { display: grid; gap: 18px; }
.community-card { display: grid; grid-template-columns: 130px 1fr; gap: 18px; align-items: stretch; }
.community-card img { height: 100%; min-height: 150px; object-fit: cover; border-radius: 16px; }
.community-card[hidden] { display: none; }
.status { display: inline-flex; padding: 5px 10px; margin-bottom: 9px; border-radius: 99px; background: var(--soft-blue); color: var(--primary-dark); font-size: .76rem; font-weight: 700; }
.map { position: relative; min-height: 610px; overflow: hidden; border-radius: var(--radius); background: linear-gradient(145deg, #d9eff0, #f6f6f4); border: 1px solid var(--border); }
.map::before { content: ""; position: absolute; inset: 70px 31% 55px 39%; background: rgba(17,77,160,.38); clip-path: polygon(48% 0,63% 9%,51% 20%,65% 31%,54% 42%,67% 58%,50% 72%,59% 90%,42% 100%,34% 82%,43% 67%,30% 51%,40% 35%,28% 20%,38% 10%); }
.map-title { position: absolute; top: 24px; left: 24px; z-index: 2; padding: 16px 20px; border-radius: 16px; background: var(--white); box-shadow: var(--shadow); }
.pin { position: absolute; z-index: 2; width: 19px; height: 19px; border: 4px solid var(--primary-dark); border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 8px rgba(223,237,55,.28); }
.pin.paita { top: 22%; left: 49%; }.pin.sanjose { top: 35%; left: 52%; }.pin.chorrillos { top: 63%; left: 54%; }
.empty-state { display: none; padding: 22px; border-radius: 16px; background: var(--soft-bg); color: var(--muted); }

.plans { grid-template-columns: repeat(5, 1fr); }
.plan { display: flex; flex-direction: column; }
.plan .price { display: block; margin: 6px 0 15px; color: var(--primary); font: 700 2rem Poppins, sans-serif; }
.plan p { flex: 1; margin-bottom: 22px; }
.plan.featured { border: 2px solid var(--primary); transform: translateY(-8px); }
.note { margin-top: 28px; padding: 22px; border-left: 5px solid var(--accent); background: var(--soft-bg); color: var(--muted); }
.timeline { position: relative; display: grid; gap: 22px; }
.timeline::before { content: ""; position: absolute; left: 25px; top: 18px; bottom: 18px; width: 2px; background: var(--soft-blue); }
.timeline-item { position: relative; padding: 26px 26px 26px 76px; border: 1px solid var(--border); border-radius: 20px; background: var(--white); }
.timeline-item::before { content: ""; position: absolute; left: 17px; top: 30px; width: 18px; height: 18px; border: 5px solid var(--primary); border-radius: 50%; background: var(--accent); }
.timeline-item h3 { color: var(--primary-dark); margin-bottom: 7px; }

.contact-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 54px; align-items: start; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding: 32px; border-radius: var(--radius); background: var(--soft-bg); }
.form-group { display: grid; gap: 7px; }
.form-group.full { grid-column: 1 / -1; }
.form-group label { color: var(--primary-dark); font-weight: 700; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 13px 15px; border: 1px solid #cbd3db; border-radius: 12px; background: var(--white); }
.form-group textarea { min-height: 140px; resize: vertical; }
.field-error { min-height: 1.2em; color: #a82323; font-size: .82rem; }
.form-alert { display: none; grid-column: 1 / -1; padding: 14px; border-radius: 12px; background: #fff0f0; color: #8c1c1c; }
.form-alert.show { display: block; }

.whatsapp { position: fixed; right: 22px; bottom: 22px; z-index: 900; display: inline-flex; align-items: center; gap: 9px; min-height: 50px; padding: 12px 17px; border-radius: 999px; background: #1fa855; color: var(--white); font-weight: 800; box-shadow: 0 12px 30px rgba(0,0,0,.2); }
.whatsapp::before { content: "✆"; font-size: 1.25rem; }
.site-footer { padding: 58px 0 24px; background: var(--primary-dark); color: var(--white); }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 44px; }
.site-footer p, .site-footer a { color: rgba(255,255,255,.76); }
.footer-links { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 20px; }
.site-footer h3 { margin-bottom: 14px; }
.copyright { margin-top: 40px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.15); font-size: .86rem; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .55s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 1040px) {
  .site-nav { gap: 12px; }.site-nav a { font-size: .78rem; }
  .grid.four, .plans { grid-template-columns: repeat(2, 1fr); }
  .grid.three { grid-template-columns: repeat(2, 1fr); }
  .community-layout, .contact-layout { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .menu-button { display: block; }
  .site-nav { position: absolute; top: 76px; left: 0; right: 0; display: none; flex-direction: column; align-items: stretch; padding: 22px 6%; background: var(--primary-dark); border-top: 1px solid rgba(255,255,255,.14); }
  .site-nav.open { display: flex; }.site-nav a { padding: 8px 0; font-size: .95rem; }
  .hero { min-height: 620px; }.hero::before { background: linear-gradient(90deg, rgba(2,21,94,.92), rgba(2,21,94,.55)), var(--hero-image) center/cover no-repeat; }
  .media-split, .community-tools, .footer-grid { grid-template-columns: 1fr; }
  .media-split img { min-height: 320px; }
  .cta-band { align-items: flex-start; flex-direction: column; }
  .map { min-height: 500px; }
}
@media (max-width: 600px) {
  .container { width: min(100% - 32px, 1160px); }
  .section { padding: 66px 0; }
  .hero { min-height: 680px; padding-top: 125px; align-items: flex-end; }
  .hero h1 { font-size: clamp(2.35rem, 12vw, 3.45rem); }
  .actions { flex-direction: column; align-items: stretch; }
  .grid.two, .grid.three, .grid.four, .plans { grid-template-columns: 1fr; }
  .plan.featured { transform: none; }
  .community-card { grid-template-columns: 1fr; }.community-card img { height: 190px; }
  .contact-form { grid-template-columns: 1fr; padding: 22px; }.form-group.full { grid-column: auto; }
  .step { grid-template-columns: 1fr; }
  .quote { font-size: 1.75rem; }
  .whatsapp { right: 14px; bottom: 14px; font-size: .85rem; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

.brand-logo {
  width: 44px !important;
  height: 44px !important;
  max-width: 44px;
  object-fit: contain;
  flex-shrink: 0;
}

