:root{
  --blue:#0b6dff;
  --royal:#0a35c7;
  --deep:#071126;
  --light:#f5f8ff;
  --text:#0f1930;
  --muted:#5f6f8a;
  --line:#dce4f5;
}
*{box-sizing:border-box}
body.site-body{margin:0;font-family:Inter,Arial,sans-serif;background:#fff;color:var(--text)}
a{text-decoration:none;color:inherit}
.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;padding:16px 40px;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{font-weight:900;letter-spacing:.06em;display:flex;align-items:center;gap:10px}
.site-logo{height:46px;width:auto;display:block}
.topbar nav{display:flex;gap:24px;color:#24324e;font-weight:600}
.phone,.btn-primary,button{background:linear-gradient(90deg,var(--blue),var(--royal));padding:12px 18px;border:none;color:#fff;font-weight:700;cursor:pointer;clip-path:polygon(8% 0,100% 0,92% 100%,0% 100%)}
.hero{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:80px 40px 50px;background:linear-gradient(170deg,#fff 60%,#eef4ff 60%)}
.hero-bg-pattern{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 20% 20%,rgba(8,109,255,.08),transparent 36%),radial-gradient(circle at 75% 60%,rgba(10,53,199,.1),transparent 30%)}
.hero-content{position:relative}
.eyebrow{color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.hero h1{font-size:clamp(2.3rem,6vw,4.7rem);line-height:1.04;margin:8px 0}
.hero h1 span{color:var(--blue)}
.hero-text{max-width:680px;color:var(--muted);font-size:1.05rem}
.hero-visual{display:flex;justify-content:center}
.hero-image-wrap{position:relative;max-width:560px;padding:14px;background:linear-gradient(145deg,var(--blue),var(--royal));clip-path:polygon(8% 0,100% 0,92% 100%,0 100%)}
.hero-image-wrap img{width:100%;display:block;clip-path:polygon(7% 0,100% 0,93% 100%,0 100%)}
.search-section{padding:0 40px 40px}
.search-box{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;background:#fff;padding:16px;border:1px solid var(--line);box-shadow:0 14px 35px rgba(8,43,118,.08);clip-path:polygon(2% 0,100% 0,98% 100%,0 100%)}
.search-box input,.search-box select,.filters input,.filters select,.quick-lead input,.quick-lead textarea{background:#fff;color:#0f1930;border:1px solid #cdd8f0;padding:11px 12px}
.benefits,.featured,.filters,.listing-header,.detail-grid,.footer,.categories,.map-section{padding:50px 40px}
.benefits{background:#f9fbff}
.benefit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.benefit-grid article{padding:18px;border:1px solid #d5e2fb;background:#fff;clip-path:polygon(8% 0,100% 0,92% 100%,0 100%);display:flex;gap:10px;align-items:center;font-weight:600;color:#13305f}
.benefit-grid i{color:var(--blue)}
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px}
.category-item{min-height:130px;display:grid;place-items:center;background:linear-gradient(160deg,#eaf2ff,#fff);border:1px solid #d2def7;clip-path:polygon(25% 5%,75% 5%,95% 50%,75% 95%,25% 95%,5% 50%);transition:.25s}
.category-item img{width:100%;height:100%;max-height:130px;object-fit:cover;clip-path:polygon(25% 5%,75% 5%,95% 50%,75% 95%,25% 95%,5% 50%);opacity:.9}
.category-item:hover{transform:translateY(-5px);box-shadow:0 15px 30px rgba(16,73,180,.2)}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.property-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.property-card{background:#fff;border:1px solid #d9e4fa;overflow:hidden;position:relative;transition:.25s;clip-path:polygon(0 0,96% 0,100% 10%,100% 100%,4% 100%,0 90%)}
.property-card:hover{transform:translateY(-6px);box-shadow:0 16px 28px rgba(9,52,146,.16)}
.property-card img{width:100%;height:200px;object-fit:cover}
.badge{position:absolute;top:14px;right:0;padding:6px 14px;background:linear-gradient(90deg,var(--blue),var(--royal));font-size:.75rem;color:#fff;text-transform:capitalize;clip-path:polygon(0 0,100% 0,92% 100%,0 100%)}
.badge.rented{background:linear-gradient(90deg,#4f5d75,#313d51)}
.badge.available{background:linear-gradient(90deg,#078a69,#04684e)}
.card-content{padding:16px}
.card-content strong{color:var(--blue);font-size:1.1rem}
.meta{display:flex;flex-wrap:wrap;gap:8px;color:#48607f;font-size:.9rem}
.card-actions{display:flex;gap:10px;margin-top:14px}
.card-actions a{font-size:.85rem;padding:9px 12px;border:1px solid #c5d7ff;color:#0d47aa;background:#f5f9ff}
.listing-header{background:linear-gradient(160deg,#fff,#f2f7ff)}
.filters{background:#fff}
.filters-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;padding:16px;border:1px solid var(--line);box-shadow:0 14px 24px rgba(18,70,170,.08)}
.filter-check{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#314767}
.breadcrumbs{padding:16px 40px 0;font-size:.9rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumbs a{color:var(--blue);font-weight:600}
.breadcrumbs span:last-child{color:#314767;font-weight:600}
.pagination-nav{display:flex;justify-content:center;align-items:center;gap:20px;padding:24px 40px 50px;flex-wrap:wrap}
.pagination-nav a{padding:10px 16px;border:1px solid #c5d7ff;color:#0d47aa;background:#f5f9ff;font-weight:600;font-size:.9rem}
.pagination-meta{color:var(--muted);font-size:.9rem}
.footer-legal{margin-top:14px}
.footer-legal a{color:#9ec5ff;font-size:.9rem;text-decoration:underline}
.detail-hero{position:relative;padding:52px 40px 40px;background:linear-gradient(150deg,#0a1c3f,#0b6dff);color:#fff}
.detail-hero-actions{margin-top:16px}
.detail-hero-actions .btn-primary{display:inline-block}
.detail-hero .hero-cta-row{margin-top:18px}
.detail-hero .btn-secondary-outline{border:2px solid rgba(255,255,255,.9);color:#fff;background:rgba(255,255,255,.08)}
.gallery{padding:20px 40px}
.main-image{width:100%;max-height:480px;object-fit:cover}
.thumbs{margin-top:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
.thumbs img{height:90px;width:100%;object-fit:cover}
.property-swiper{overflow:hidden;border:1px solid #cad9ff}
.swiper-button-prev,.swiper-button-next{color:#fff;background:rgba(10,47,131,.45);padding:26px 20px}
.swiper-pagination-bullet-active{background:#0d8bff}
.detail-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;background:#f8fbff}
.detail-grid article{background:#fff;border:1px solid #d9e3f7;padding:18px}
.map-section iframe{width:100%;height:360px;border:1px solid #d6e1f7}
.amenities{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-left:18px}
.footer{display:grid;grid-template-columns:1fr 1fr;gap:20px;background:#071126;color:#d9e6ff}
.footer-logo{height:54px;width:auto;display:block;margin-bottom:10px}
.social-links{display:flex;gap:10px;margin-top:12px}
.social-links a{width:34px;height:34px;display:grid;place-items:center;border:1px solid #36538d;background:rgba(255,255,255,.04);color:#d6e5ff}
.quick-lead{display:grid;gap:8px}
.quick-lead h3{margin:0 0 4px 0}
.footer-contact{display:grid;gap:10px;align-content:start}
.footer-contact h3{margin:0 0 4px 0}
.footer-contact-text{color:#b8c9e8;font-size:.92rem;margin:0;line-height:1.45}
.footer-contact-btn{display:inline-block;text-align:center;max-width:260px;margin-top:4px}
.footer-phone,.footer-email{margin:6px 0 0 0;font-size:.95rem}
.footer-phone a,.footer-email a{color:#9ec5ff}
.contact-hero p{max-width:720px}
.contact-layout{max-width:980px;margin:0 auto 50px;padding:0 40px;display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:start}
.contact-card,.contact-aside{background:#fff;border:1px solid var(--line);padding:22px 24px;color:var(--text);box-shadow:0 10px 28px rgba(18,70,170,.06)}
.contact-card h2{margin-top:0;color:#102a54;font-size:1.25rem}
.contact-aside h3{margin-top:0;color:#18448d;font-size:1.05rem}
.contact-aside p{color:#314767;line-height:1.55}
.contact-muted{font-size:.85rem;color:var(--muted);margin-top:14px}
.contact-form{display:grid;gap:14px}
.contact-form .field-label{display:grid;gap:6px;font-weight:600;color:#173a73;font-size:.95rem}
.contact-form .field-label small{display:block;font-weight:500;color:var(--muted);margin-top:2px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:11px 12px;border:1px solid #cdd8f0;font:inherit;border-radius:4px;background:#fff;color:var(--text)}
.contact-form-compact{display:grid;gap:8px}
.contact-inline-hint{font-size:.88rem;color:var(--muted);margin:0 0 10px 0;line-height:1.45}
.contact-inline-hint a{color:var(--blue);font-weight:600}
.topbar{align-items:center}
.topbar-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-contact-secondary{font-weight:700;color:#0d47aa;font-size:.88rem;padding:8px 12px;border:1px solid #c5d7ff;border-radius:6px;background:#f5f9ff}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:14px}
.hero .btn-secondary-outline{border:2px solid var(--blue);color:var(--blue);background:transparent;padding:12px 18px;font-weight:700;clip-path:polygon(8% 0,100% 0,92% 100%,0% 100%)}
.listing-header-actions{margin-top:14px}
.listing-header .btn-primary,.listing-header .btn-secondary-outline{clip-path:polygon(6% 0,100% 0,94% 100%,0% 100%);padding:11px 18px;font-weight:700}
.listing-header .btn-secondary-outline{border:2px solid var(--blue);color:var(--blue);background:#fff}
.card-contact-secondary{font-size:.82rem;padding:9px 11px;border:1px solid #9eb7ff;color:#0d47aa;background:#fafdff;font-weight:600}
.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;margin:0!important;padding:0!important}
.footer-cookies{font-size:.82rem;color:#9eb8e8;margin-top:14px;line-height:1.45}
.badge-detail{position:absolute;top:18px;left:40px;font-size:.82rem;padding:6px 14px;border-radius:8px;background:rgba(255,255,255,.22);color:#fff;font-weight:700}
.detail-grid-adaptive{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.property-specs-list{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:#314767;font-size:.95rem}
.detail-resource-links a{font-weight:700;color:var(--blue)}
.detail-resource-links a:hover{text-decoration:underline}
/* Páginas CMS (Nosotros / Legal) */
.cms-page{background:linear-gradient(180deg,#f5f9ff 0%,#fff 38%,#eef4ff 100%);padding-bottom:64px}
.cms-hero{position:relative;padding:40px 40px 52px;background:linear-gradient(148deg,#071126 0%,#0a2468 42%,#0b6dff 100%);color:#fff;overflow:hidden}
.cms-hero--legal{background:linear-gradient(148deg,#050c18 0%,#0c2d5c 48%,#154e9e 100%)}
.cms-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 90% 15%,rgba(255,255,255,.14),transparent 50%),radial-gradient(ellipse 60% 50% at 8% 85%,rgba(0,0,0,.25),transparent 45%);pointer-events:none}
.cms-hero-inner{position:relative;max-width:920px;margin:0 auto}
.cms-hero .breadcrumbs{padding:0 0 14px;font-size:.9rem;color:rgba(255,255,255,.72)}
.cms-hero .breadcrumbs a{color:#b8d9ff;font-weight:600}
.cms-hero .breadcrumbs a:hover{text-decoration:underline}
.cms-hero .breadcrumbs span:last-child{color:#fff;font-weight:700}
.cms-hero-eyebrow{margin:0 0 8px;font-size:.78rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.cms-hero h1{margin:0 0 14px;font-size:clamp(1.9rem,4.5vw,2.85rem);font-weight:900;letter-spacing:.02em;line-height:1.12;max-width:18ch}
.cms-hero-lead{margin:0;max-width:620px;font-size:1.02rem;line-height:1.58;color:rgba(255,255,255,.9);font-weight:500}
.cms-shell{max-width:920px;margin:-36px auto 0;padding:0 40px;position:relative;z-index:1}
.cms-body{display:grid;gap:22px;padding-bottom:8px}
.cms-card{background:#fff;border:1px solid #c9d9f4;box-shadow:0 18px 46px rgba(7,40,110,.11);padding:26px 28px 24px;clip-path:polygon(0 0,98% 0,100% 3%,100% 100%,2% 100%,0 97%)}
.cms-card--process{padding-bottom:28px}
.cms-card-head{display:flex;align-items:flex-start;gap:18px;margin-bottom:16px}
.cms-card-icon{width:54px;height:54px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(145deg,var(--blue),var(--royal));color:#fff;font-size:1.28rem;border-radius:14px;clip-path:polygon(10% 0,100% 0,90% 100%,0 100%);box-shadow:0 8px 22px rgba(11,109,255,.35)}
.cms-card-icon--muted{background:linear-gradient(145deg,#1e3a5f,#0c54a8);box-shadow:0 8px 22px rgba(10,40,90,.3)}
.cms-card h2{margin:0;font-size:1.24rem;color:#071126;font-weight:800;letter-spacing:.02em;line-height:1.22}
.cms-card-sub{margin:6px 0 0;font-size:.88rem;color:#5c6b82;font-weight:500;line-height:1.35}
.cms-prose p{font-size:.98rem;line-height:1.68;color:#334155;margin:0 0 14px}
.cms-prose p:last-child{margin-bottom:0}
.cms-step-list{list-style:none;padding:0;margin:0;display:grid;gap:14px;counter-reset:cmsstep}
.cms-step-list li{position:relative;margin:0;padding:17px 20px 17px 62px;background:linear-gradient(135deg,#f4f8ff,#fff);border:1px solid #d8e6fc;border-radius:12px;color:#24324e;line-height:1.55;font-size:.97rem;font-weight:600;counter-increment:cmsstep;box-shadow:0 4px 14px rgba(18,70,170,.06)}
.cms-step-list li::before{content:counter(cmsstep);position:absolute;left:16px;top:50%;transform:translateY(-50%);width:34px;height:34px;display:grid;place-items:center;background:linear-gradient(145deg,var(--blue),var(--royal));color:#fff;font-size:.85rem;font-weight:900;border-radius:10px;clip-path:polygon(15% 0,100% 0,85% 100%,0 100%)}
.cms-card--empty{text-align:center;padding:36px 28px;display:grid;gap:14px;place-items:center}
.cms-empty-icon{width:56px;height:56px;display:grid;place-items:center;background:#eef4ff;color:var(--blue);font-size:1.4rem;border-radius:50%;border:1px solid #c9daf8}
.cms-empty{color:#5c6b82;line-height:1.6;margin:0;max-width:420px;font-size:.98rem}
.cms-card--legacy-wrap{padding:28px 30px}
.cms-legacy.legal-html{font-size:.98rem;line-height:1.68;color:#334155}
.cms-legacy.legal-html h2{font-size:1.22rem;color:#071126;margin:28px 0 12px;font-weight:800}
.cms-legacy.legal-html h2:first-child{margin-top:0}
.cms-legacy.legal-html p{margin:0 0 14px}
.cms-legacy.legal-html ol{padding-left:1.35rem}
.cms-bottom-cta{margin-top:8px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;padding:22px 26px;background:linear-gradient(135deg,#071126,#0a2468);color:#e8f0ff;border:1px solid #1a3d6e;border-radius:14px;clip-path:polygon(0 0,97% 0,100% 12%,100% 100%,3% 100%,0 88%);box-shadow:0 16px 36px rgba(7,17,38,.2)}
.cms-bottom-cta--legal{background:linear-gradient(135deg,#050c18,#0c3566);border-color:#224a80}
.cms-bottom-cta-text{display:grid;gap:6px;max-width:480px}
.cms-bottom-cta-text strong{font-size:1.05rem;font-weight:800;color:#fff}
.cms-bottom-cta-text span{font-size:.9rem;color:rgba(232,240,255,.82);line-height:1.45}
.cms-bottom-cta-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.cms-bottom-cta .btn-primary{display:inline-block;padding:11px 20px;font-size:.92rem;clip-path:polygon(8% 0,100% 0,92% 100%,0 100%)}
.cms-bottom-cta-secondary{display:inline-block;padding:10px 18px;font-weight:700;font-size:.9rem;color:#b8d9ff;border:1px solid rgba(255,255,255,.35);border-radius:8px;background:rgba(255,255,255,.06)}
.cms-bottom-cta-secondary:hover{background:rgba(255,255,255,.12)}
@media (max-width:680px){
  .cms-hero{padding:28px 16px 40px}
  .cms-hero h1{max-width:none}
  .cms-shell{padding-left:16px;padding-right:16px;margin-top:-28px}
  .cms-card{padding:22px 18px}
  .cms-card-head{gap:14px}
  .cms-card-icon{width:48px;height:48px;font-size:1.15rem}
  .cms-bottom-cta{padding:20px 18px;flex-direction:column;align-items:stretch}
  .cms-bottom-cta-actions{justify-content:stretch}
  .cms-bottom-cta-actions .btn-primary,.cms-bottom-cta-secondary{text-align:center}
}
.not-found-page{min-height:58vh;display:grid;place-items:center;padding:56px 24px;background:linear-gradient(165deg,#eef4ff 0%,#fff 55%)}
.not-found-inner{text-align:center;max-width:520px}
.not-found-code{font-size:4.2rem;font-weight:900;color:var(--blue);margin:0;line-height:1;letter-spacing:.04em}
.not-found-inner h1{font-size:1.5rem;color:var(--text);margin:12px 0}
.not-found-text{color:var(--muted);margin:0 0 8px 0;line-height:1.5}
.not-found-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:24px}
.not-found-actions .btn-primary{clip-path:polygon(8% 0,100% 0,92% 100%,0% 100%)}
.not-found-actions .btn-secondary-outline{border:2px solid var(--blue);color:var(--blue);padding:12px 18px;font-weight:700;background:#fff;clip-path:polygon(8% 0,100% 0,92% 100%,0% 100%)}
.flash{padding:12px 20px}
.flash-success{background:#d8f9e7;color:#035936}
.flash-error{background:#ffe3e3;color:#7b1414}
@media (max-width:1080px){
  .hero{grid-template-columns:1fr}
  .search-box{grid-template-columns:1fr 1fr}
  .detail-grid,.footer{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .property-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
}
@media (max-width:680px){
  .topbar{padding:14px 16px}
  .topbar nav{display:none}
  .badge-detail{left:16px;top:14px}
  .breadcrumbs{padding-left:16px;padding-right:16px}
  .pagination-nav{padding-left:16px;padding-right:16px}
  .contact-layout{padding-left:16px;padding-right:16px;grid-template-columns:1fr}
  .hero,.search-section,.benefits,.featured,.filters,.listing-header,.detail-grid,.footer,.categories,.map-section,.gallery,.detail-hero{padding-left:16px;padding-right:16px}
  .search-box{grid-template-columns:1fr}
  .hero h1{font-size:2rem}
  .hero-text{font-size:.95rem}
  .card-actions{flex-direction:column}
  .thumbs{grid-template-columns:repeat(3,minmax(80px,1fr))}
}
