/* ═══════════════════════════════════════════
   HOME / INDEX — eligemicasa.com
   Extraído del inline para mejorar rendimiento
   ═════════════════════��═════════════════════ */
:root{
    --bg:#eef3f9;--surface:#f8faff;--surface-2:#e0e8f4;
    --text:#1a2a42;--muted:#4a6080;--line:rgba(42,82,140,.12);
    --brand:#2a5296;--brand-2:#3b72c4;--brand-3:#5a96e0;--brand-dark:#1e3f7a;
    --ok:#237a48;--danger:#bf4b3f;
    --shadow:0 18px 50px rgba(30,60,110,.09);
    --radius:22px;--radius-sm:16px;--container:1360px;
}
:root.light,html.light{
    --bg:#f7f1ea;--surface:#fffdf9;--surface-2:#f3e7da;
    --text:#2f241c;--muted:#6b5a4a;--line:rgba(30,60,110,.12);
    --brand:#2a5296;--brand-2:#8f6346;--brand-3:#a97858;--brand-dark:#1e3f7a;
    --ok:#2c7a4b;--shadow:0 18px 50px rgba(30,60,110,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);background:radial-gradient(circle at top right, color-mix(in oklab, var(--brand) 10%, transparent), transparent 28%),linear-gradient(180deg, var(--surface) 0%, var(--bg) 100%);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.panel,.card-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}

/* ── HERO ── */
.hero{padding:40px 0 28px}
.hero__inner{display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:stretch}
.hero__main{position:relative;overflow:visible;padding:38px;display:flex;flex-direction:column;justify-content:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}
.hero__main::before{content:'';position:absolute;inset:0;border-radius:inherit;overflow:hidden;background:radial-gradient(circle at 85% 15%, color-mix(in oklab, var(--brand) 14%, transparent), transparent 28%),linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 100%);z-index:0;pointer-events:none}
.hero__main > *{position:relative;z-index:1}
.hero__chip{display:inline-flex;width:fit-content;padding:7px 14px;border-radius:999px;font-size:.82rem;font-weight:800;color:var(--brand-2);border:1px solid var(--line);background:rgba(255,255,255,.5);margin-bottom:14px}
.hero h1{margin:0 0 10px;font-size:clamp(1.6rem, 4vw, 2.6rem);line-height:1.08;letter-spacing:-.04em;font-weight:900}
.hero p.hero__sub{margin:0 0 22px;color:var(--muted);font-size:1rem;line-height:1.6;max-width:560px}
.hero__kpis{display:flex;gap:18px;margin-top:18px;flex-wrap:wrap}
.hero__kpi{display:flex;flex-direction:column;padding:10px 16px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.5)}
.hero__kpi strong{font-size:1.5rem;font-weight:900;color:var(--brand-dark);line-height:1}
.hero__kpi span{font-size:.78rem;color:var(--muted);margin-top:2px}

.hero__aside{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.hero__aside h2{font-size:1.15rem;font-weight:800;margin:0 0 6px}
.hero__aside p{color:var(--muted);font-size:.92rem;line-height:1.5;margin:0}
.hero__steps{display:flex;flex-direction:column;gap:14px}
.hero__step{display:flex;gap:12px;align-items:flex-start}
.hero__step-num{flex-shrink:0;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg, var(--brand), var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.88rem}
.hero__step div strong{display:block;font-size:.9rem;font-weight:800;margin-bottom:2px}
.hero__step div span{font-size:.82rem;color:var(--muted);line-height:1.4}

/* ── Search ── */
.search-shell{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:20px;padding:14px;backdrop-filter:blur(10px)}
.search-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start}
.search-box{position:relative}
.search-box input{width:100%;height:56px;border-radius:16px;border:1px solid rgba(42,82,140,.18);padding:0 16px;background:#fff;color:var(--text);outline:none;font-size:1rem}
.search-box input:focus{border-color:var(--brand-2);box-shadow:0 0 0 4px rgba(42,82,140,.08)}
.search-form button,.btn{border:none;border-radius:16px;height:56px;padding:0 24px;cursor:pointer;font-weight:800;font-size:.98rem;transition:transform .18s ease,opacity .18s ease,box-shadow .18s ease,filter .18s ease,background-color .18s ease,border-color .18s ease}
.search-form button,.btn-primary{background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);color:#fff;box-shadow:0 14px 26px rgba(42,82,140,.18)}
.search-form button:hover,.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.03)}
.btn-secondary{background:var(--surface);border:1px solid var(--line);color:var(--text)}
.btn-secondary:hover{border-color:var(--brand-2)}
.geo-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid rgba(42,82,140,.14);border-radius:16px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.10);z-index:100;display:none;max-height:320px;overflow-y:auto}
.geo-result-item{padding:12px 14px;border-bottom:1px solid rgba(42,82,140,.08);cursor:pointer;display:flex;justify-content:space-between;gap:10px}
.geo-result-item:last-child{border-bottom:none}
.geo-result-item:hover,.geo-result-item.is-active{background:#eef2fb}
.geo-result-item__type{color:var(--muted);font-size:.86rem;white-space:nowrap}

/* ── Sections ── */
.sec{padding:32px 0}
.sec__head{margin-bottom:22px}
.sec__head h2{font-size:clamp(1.3rem,3vw,1.8rem);font-weight:900;letter-spacing:-.03em;margin:0 0 6px}
.sec__head p{color:var(--muted);font-size:.95rem;margin:0;max-width:640px}

/* ── Section toggle ── */
.sec__toggle{display:flex;justify-content:space-between;align-items:center;width:100%;border:none;background:none;cursor:pointer;padding:0;margin-bottom:22px;text-align:left;font-family:inherit;color:var(--text);gap:16px}
.sec__toggle h2{font-size:clamp(1.3rem,3vw,1.8rem);font-weight:900;letter-spacing:-.03em;margin:0 0 4px}
.sec__toggle p{color:var(--muted);font-size:.95rem;margin:0;max-width:640px}
.sec__toggle-icon{width:24px;height:24px;flex-shrink:0;color:var(--muted);transition:transform .25s ease;will-change:transform}
.sec__toggle.is-open .sec__toggle-icon{transform:rotate(180deg)}
.sec__collapsible{overflow:hidden;opacity:0;max-height:0;transition:max-height .35s ease,opacity .25s ease;contain:layout style paint}
.sec__collapsible.is-open{max-height:800px;opacity:1}

/* ── How it works ── */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.how-card{padding:28px;text-align:center}
.how-card__icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg, var(--brand), var(--brand-2));color:#fff;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px}
.how-card__icon svg{width:26px;height:26px}
.how-card h3{font-size:1.05rem;font-weight:800;margin:0 0 8px}
.how-card p{color:var(--muted);font-size:.9rem;line-height:1.5;margin:0}

/* ── Properties ── */
.layout-main{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.properties-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.property-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease;will-change:transform}
.property-card:hover{transform:translateY(-3px);box-shadow:0 24px 56px rgba(30,60,110,.14)}
.property-card__media{position:relative;aspect-ratio:16/10;background:#dce6f4;overflow:hidden}
.property-card__slides{position:relative;width:100%;height:100%}
.property-card__slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;pointer-events:none;transition:opacity .22s ease}
.property-card__slide.is-active{opacity:1;pointer-events:auto}
.property-card__badge{position:absolute;top:12px;left:12px;z-index:4;padding:8px 12px;border-radius:999px;font-size:.78rem;font-weight:900;background:rgba(20,40,70,.88);color:#fff}
.property-card__badge--360{left:auto;right:12px;background:linear-gradient(135deg,#6366f1,#3b82f6);display:inline-flex;align-items:center;gap:5px;animation:tour360glow 2.5s ease-in-out infinite}
.property-card__badge--360 i{font-size:.9rem}
@keyframes tour360glow{0%,100%{box-shadow:0 2px 8px rgba(99,102,241,.3)}50%{box-shadow:0 4px 20px rgba(99,102,241,.6)}}
.property-card__counter{position:absolute;top:12px;right:12px;z-index:4;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--brand-dark);font-size:.8rem;font-weight:800}
.property-card__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:48px;height:48px;border:none;border-radius:50%;background:rgba(20,40,70,.60);color:#fff;font-size:22px;cursor:pointer;opacity:0;transition:opacity .18s}
.property-card:hover .property-card__nav{opacity:1}
.property-card__nav.prev{left:10px}
.property-card__nav.next{right:10px}
.property-card__dots{position:absolute;bottom:0;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:0;align-items:center}
.property-card__dot{min-width:48px;min-height:48px;border-radius:0;border:none;background:transparent;cursor:pointer;padding:0;position:relative;display:inline-flex;align-items:center;justify-content:center}
.property-card__dot::after{content:'';width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.5);pointer-events:none}
.property-card__dot.is-active::after{background:#fff}
.property-card__body{padding:16px}
.property-card__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.property-card__price{font-weight:900;font-size:1.35rem;color:var(--brand-dark)}
.property-card__type{font-size:.82rem;color:var(--muted);font-weight:600}
.property-card__title{margin:0 0 4px;font-size:1rem;font-weight:800;line-height:1.25}
.property-card__title a{color:inherit;text-decoration:none}
.property-card__location{color:var(--muted);font-size:.88rem;margin:0 0 8px}
.property-card__meta{display:flex;gap:14px;font-size:.88rem;color:var(--muted);margin:0 0 8px}
.property-card__desc{color:var(--muted);font-size:.86rem;line-height:1.5;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.property-card__actions{display:flex;gap:10px}
.property-card__actions .btn{height:44px;font-size:.88rem;padding:0 16px;display:inline-flex;align-items:center}

/* ── Map ── */
.map-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;position:sticky;top:100px}
.map-head{padding:16px 18px}
.map-head h3{margin:0 0 4px;font-size:1rem;font-weight:800}
.map-head p{margin:0;color:var(--muted);font-size:.84rem}
#home-map{width:100%;height:380px}
.sell-cta{padding:20px;border-top:1px solid var(--line)}
.sell-cta__pill{display:inline-block;padding:5px 12px;border-radius:999px;font-size:.78rem;font-weight:800;color:var(--ok);border:1px solid color-mix(in oklab, var(--ok) 30%, transparent);margin-bottom:10px}
.sell-cta h4{margin:0 0 6px;font-size:1rem;font-weight:800}
.sell-cta p{margin:0 0 14px;color:var(--muted);font-size:.88rem;line-height:1.5}
.sell-cta .btn{height:44px;font-size:.88rem;padding:0 18px;display:inline-flex;align-items:center}

/* ── USP grid ── */
.usp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.usp-card{padding:24px}
.usp-card h3{font-size:1rem;font-weight:800;margin:0 0 6px}
.usp-card p{color:var(--muted);font-size:.88rem;line-height:1.5;margin:0}

/* ── Model ── */
.model-box{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.model-card{padding:28px}
.model-card h3{font-size:1.2rem;font-weight:900;margin:0 0 10px}
.model-card p{color:var(--muted);font-size:.92rem;line-height:1.6;margin:0 0 10px}
.model-price{font-size:2.2rem;font-weight:900;color:var(--brand-dark);margin:10px 0 4px}
.model-price span{font-size:.9rem;color:var(--muted);font-weight:500}
.model-list{list-style:none;padding:0;margin:12px 0 0}
.model-list li{padding:6px 0;font-size:.9rem;color:var(--muted);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.model-list li::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.model-card:first-child .model-list li::before{background:var(--ok)}
.model-card:last-child .model-list li::before{background:var(--danger)}

/* ── Viral banner ── */
.viral-banner{padding:32px;text-align:center;background:linear-gradient(135deg, color-mix(in oklab, var(--brand) 8%, var(--surface)), var(--surface-2));border:2px solid color-mix(in oklab, var(--brand) 20%, transparent)}
.viral-banner h2{font-size:clamp(1.3rem,3vw,1.7rem);font-weight:900;margin:0 0 8px}
.viral-banner p{color:var(--muted);font-size:1rem;line-height:1.6;margin:0 0 18px;max-width:700px;margin-left:auto;margin-right:auto}
.viral-banner .btn{height:52px;font-size:1rem;padding:0 32px;display:inline-flex;align-items:center}
.viral-banner__note{margin-top:14px;font-size:.82rem;color:var(--muted)}

/* ── Tools grid ── */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.tool-chip{padding:14px 16px;display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:700}
.tool-chip svg{width:20px;height:20px;color:var(--brand-2);flex-shrink:0}

/* ── Zones ── */
.zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.zone-link{display:block;padding:12px 16px;font-size:.9rem;font-weight:600;color:var(--text);transition:background-color .15s ease,border-color .15s ease}
.zone-link:hover{background:var(--surface-2);border-color:var(--brand-2)}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface)}
.faq-q{width:100%;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border:none;background:none;color:var(--text);font-size:.95rem;font-weight:700;cursor:pointer;text-align:left;font-family:inherit}
.faq-q svg{width:18px;height:18px;transition:transform .2s ease;flex-shrink:0;color:var(--muted);will-change:transform}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}
.faq-a>*{overflow:hidden}
.faq-item.is-open .faq-a{grid-template-rows:1fr}
.faq-item.is-open .faq-q svg{transform:rotate(180deg)}
.faq-a__inner{padding:0 20px 16px;color:var(--muted);font-size:.9rem;line-height:1.6}

/* ── Final CTA ── */
.final-cta{padding:48px 20px;text-align:center}
.final-cta h2{font-size:clamp(1.4rem,3vw,2rem);font-weight:900;margin:0 0 10px}
.final-cta p{color:var(--muted);font-size:1rem;margin:0 0 22px;max-width:600px;margin-left:auto;margin-right:auto}
.final-cta__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.final-cta__btns .btn{height:52px;padding:0 28px;display:inline-flex;align-items:center;font-size:1rem}

/* ── Lead modal ── */
.modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);display:flex;justify-content:center;align-items:center;padding:16px;visibility:hidden;opacity:0;transition:opacity .2s ease,visibility .2s ease;will-change:opacity}
.modal-overlay.is-open{visibility:visible;opacity:1}
.lead-modal{background:var(--surface);border-radius:var(--radius);max-width:560px;width:100%;max-height:92vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.25)}
.lead-modal__top{display:grid;grid-template-columns:200px 1fr;overflow:hidden}
.lead-modal__media{position:relative;min-height:220px}
.lead-modal__media img{width:100%;height:100%;object-fit:cover}
.lead-modal__close{position:absolute;top:6px;right:6px;z-index:2;width:48px;height:48px;border:none;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;font-size:18px;cursor:pointer}
.lead-modal__summary{padding:18px;display:flex;flex-direction:column;justify-content:center}
.lead-modal__summary h3{margin:0 0 4px;font-size:1.05rem;font-weight:800}
.lead-modal__summary > p{color:var(--muted);font-size:.85rem;margin:0 0 4px}
.lead-modal__chips{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.lead-modal__chips span{padding:4px 10px;border-radius:999px;background:var(--surface-2);font-size:.78rem;font-weight:700;color:var(--brand-dark)}
.lead-modal__body{padding:18px;border-top:1px solid var(--line)}
.lead-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lead-form label{display:block;font-size:.82rem;font-weight:700;color:var(--muted);margin-bottom:4px}
.lead-form input,.lead-form textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:12px;font-size:.92rem;background:#fff;color:var(--text);outline:none;font-family:inherit}
.lead-form input:focus,.lead-form textarea:focus{border-color:var(--brand-2)}
.lead-form textarea{height:80px;resize:vertical}
.lead-form__full{grid-column:1/-1}
.lead-form__check{grid-column:1/-1;display:flex;align-items:center;gap:8px;font-size:.85rem}
.lead-form__check input{width:18px;height:18px;accent-color:var(--brand)}
.lead-form__status{grid-column:1/-1;padding:10px;border-radius:10px;font-size:.88rem;display:none}
.lead-form__status.is-error{display:block;background:#fce8e6;color:#c62828}
.lead-form__status.is-ok{display:block;background:#e8f5e9;color:#2e7d32}
.lead-form__actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end}
.lead-form__actions .btn{height:44px;font-size:.9rem;padding:0 18px}

.notice-error{padding:16px;border-radius:12px;background:#fce8e6;color:#c62828;margin-bottom:18px}

/* ── Responsive ── */
@media (max-width:1100px){
    .hero__inner{grid-template-columns:1fr}
    .layout-main{grid-template-columns:1fr}
    .map-card{position:static}
    .model-box{grid-template-columns:1fr}
}
@media (max-width:768px){
    .how-grid{grid-template-columns:1fr}
    .properties-grid{grid-template-columns:1fr}
    .search-form{grid-template-columns:1fr}
    .lead-modal__top{grid-template-columns:1fr}
    .lead-modal__media{min-height:160px}
    .hero h1{font-size:1.6rem}
}
