/* =========================================================
   INMOTOKEN - style.css
   Diseño responsive premium para plataforma inmobiliaria
========================================================= */

:root{
    --bg:#07111f;
    --bg-soft:#0d1a2b;
    --panel:rgba(255,255,255,.08);
    --panel-strong:rgba(255,255,255,.12);
    --stroke:rgba(255,255,255,.12);
    --text:#e8edf5;
    --muted:#9fb0c8;
    --gold:#c69a43;
    --gold-soft:#e1bd72;
    --blue:#1f4f8a;
    --blue-2:#284f7f;
    --white:#ffffff;
    --success:#3cc98c;
    --shadow:0 22px 60px rgba(0,0,0,.30);
    --radius:28px;
    --radius-sm:18px;
    --max:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;
    color:var(--text);
    background:
        radial-gradient(circle at top left, rgba(198,154,67,.16), transparent 28%),
        radial-gradient(circle at top right, rgba(31,79,138,.24), transparent 32%),
        linear-gradient(180deg, #07111f 0%, #0a1627 55%, #0c1728 100%);
    line-height:1.55;
    overflow-x:hidden;
}
body.loaded #preloader{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit}

.sr-only{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
}
.container{
    width:min(100% - 36px, var(--max));
    margin-inline:auto;
}

/* PRELOADER */
#preloader{
    position:fixed;
    inset:0;
    z-index:99999;
    display:grid;
    place-items:center;
    background:
        radial-gradient(circle at center, rgba(198,154,67,.12), transparent 22%),
        linear-gradient(180deg, #06111d 0%, #091524 100%);
    transition:.55s ease;
}
.preloader-box{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
}
.preloader-logo-wrap{
    width:128px;
    height:128px;
    border-radius:32px;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 0 0 12px rgba(255,255,255,.02), 0 22px 60px rgba(0,0,0,.35);
    animation:floatLogo 2.8s ease-in-out infinite;
}
.preloader-logo-wrap img{
    width:92px;
    height:auto;
    filter:drop-shadow(0 8px 18px rgba(0,0,0,.25));
}
.preloader-ring{
    width:56px;height:56px;border-radius:50%;
    border:2px solid rgba(255,255,255,.12);
    border-top-color:var(--gold);
    animation:spin 1s linear infinite;
}
.preloader-text{
    color:var(--muted);
    font-size:14px;
    letter-spacing:.14em;
    text-transform:uppercase;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floatLogo{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* BG */
.bg-grid{
    position:fixed;
    inset:0;
    z-index:-1;
    background-image:
        linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px);
    background-size:40px 40px;
    mask-image:linear-gradient(180deg, rgba(0,0,0,.92), rgba(0,0,0,.32));
    pointer-events:none;
}

/* HEADER */
.site-header{
    position:sticky;
    top:0;
    z-index:1000;
    backdrop-filter:blur(16px);
    background:rgba(7,17,31,.72);
    border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{
    min-height:82px;
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    gap:18px;
}
.brand{
    grid-column:2;
    display:flex;
    align-items:center;
    justify-content:center;
}
.brand img{
    height:66px;
    width:auto;
    object-fit:contain;
    filter:drop-shadow(0 10px 18px rgba(0,0,0,.25));
}
.nav-right{
    grid-column:3;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:12px;
}

/* BUTTONS */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-height:50px;
    padding:0 20px;
    border-radius:999px;
    font-weight:800;
    letter-spacing:.01em;
    transition:.25s ease;
    border:1px solid transparent;
    white-space:nowrap;
    cursor:pointer;
}
.btn-primary{
    color:#08111c;
    background:linear-gradient(135deg, var(--gold-soft), var(--gold));
    box-shadow:0 14px 30px rgba(198,154,67,.24);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(198,154,67,.32)}
.btn-outline{
    color:var(--white);
    border-color:rgba(255,255,255,.14);
    background:rgba(255,255,255,.04);
}
.btn-outline:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}

/* HERO */
.hero{
    position:relative;
    padding:66px 0 42px;
}
.hero-grid{
    display:grid;
    grid-template-columns:.85fr 1.15fr;
    gap:44px;
    align-items:start;
}
.eyebrow{
    display:inline-flex;
    align-items:center;
    gap:10px;
    min-height:42px;
    padding:0 16px;
    border-radius:999px;
    color:var(--gold-soft);
    border:1px solid rgba(198,154,67,.20);
    background:rgba(198,154,67,.08);
    font-size:13px;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.hero h1{
    margin:22px 0 14px;
    font-size:clamp(42px, 5.6vw, 78px);
    line-height:.98;
    letter-spacing:-.045em;
}
.hero h1 .accent{
    background:linear-gradient(135deg, var(--gold-soft), var(--gold));
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
}
.hero p.lead{
    margin:0;
    max-width:680px;
    color:var(--muted);
    font-size:clamp(17px, 2vw, 21px);
}
.hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:28px;
}
.hero-kpis{
    margin-top:28px;
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:14px;
}
.kpi{
    padding:18px;
    border-radius:20px;
    background:linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.04));
    border:1px solid rgba(255,255,255,.09);
    box-shadow:var(--shadow);
}
.kpi strong{
    display:block;
    font-size:24px;
    line-height:1;
    margin-bottom:8px;
}
.kpi span{
    display:block;
    color:var(--muted);
    font-size:14px;
}

/* HERO PROJECT */
.hero-project-card{
    overflow:hidden;
    border-radius:34px;
    border:1px solid rgba(255,255,255,.11);
    background:linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
    box-shadow:var(--shadow);
}
.project-slider{
    width:100%;
    height:420px;
    position:relative;
    overflow:hidden;
    background:#091423;
}
.project-slider-track{
    display:flex;
    height:100%;
    transition:transform .7s cubic-bezier(.2,.8,.2,1);
    will-change:transform;
}
.project-slide{
    flex:0 0 100%;
    width:100%;
    height:100%;
    overflow:hidden;
}
.project-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.project-slider::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, transparent 40%, rgba(7,17,31,.45));
    pointer-events:none;
}
.slider-btn{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:42px;
    height:42px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.20);
    background:rgba(7,17,31,.62);
    color:#fff;
    font-size:34px;
    line-height:1;
    display:grid;
    place-items:center;
    cursor:pointer;
    z-index:5;
    backdrop-filter:blur(8px);
}
.slider-prev{left:14px}
.slider-next{right:14px}
.slider-dots{
    position:absolute;
    left:0;
    right:0;
    bottom:16px;
    z-index:6;
    display:flex;
    justify-content:center;
    gap:8px;
}
.slider-dot{
    width:9px;
    height:9px;
    border-radius:999px;
    border:none;
    background:rgba(255,255,255,.48);
    cursor:pointer;
    transition:.25s ease;
}
.slider-dot.active{
    width:28px;
    background:var(--gold-soft);
}
.hero-project-info{
    padding:30px;
}
.badge-proyecto{
    display:inline-flex;
    align-items:center;
    min-height:42px;
    padding:0 18px;
    border-radius:999px;
    background:linear-gradient(135deg, var(--gold-soft), var(--gold));
    color:#07111f;
    font-weight:900;
    box-shadow:0 14px 28px rgba(198,154,67,.22);
}
.hero-project-info h2{
    margin:22px 0 12px;
    font-size:clamp(31px, 3.6vw, 54px);
    line-height:1.06;
    letter-spacing:-.035em;
}
.hero-project-info p{
    margin:0;
    color:#d1dceb;
    font-size:17px;
}
.mini-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:14px;
    margin:24px 0;
}
.mini-card{
    min-height:116px;
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.11);
    border-radius:20px;
    padding:17px;
}
.mini-icon{
    display:block;
    font-size:20px;
    margin-bottom:8px;
}
.mini-card small{
    display:block;
    color:#c6d4e4;
    font-size:12px;
    margin-bottom:7px;
    text-transform:uppercase;
    letter-spacing:.10em;
}
.mini-card strong{
    display:block;
    font-size:20px;
    line-height:1.15;
}

/* METRICS */
.metric-box{
    margin-top:18px;
}
.metric-box label{
    display:flex;
    justify-content:space-between;
    gap:12px;
    margin-bottom:8px;
    color:#dbe5f1;
    font-weight:800;
    font-size:14px;
}
.metric-box small{
    display:block;
    margin-top:7px;
    color:var(--muted);
}
.barra,
.progress{
    width:100%;
    height:12px;
    border-radius:999px;
    background:rgba(255,255,255,.09);
    overflow:hidden;
    position:relative;
}
.barra span,
.progress > span{
    display:block;
    height:100%;
    border-radius:999px;
    background:linear-gradient(90deg, var(--gold), var(--gold-soft));
    box-shadow:0 0 18px rgba(198,154,67,.22);
}
.barra-obra span{
    background:linear-gradient(90deg, #1ec95b, #74e3a5);
}
.progress.blue > span{
    background:linear-gradient(90deg, #1f4f8a, #5f92d4);
    box-shadow:0 0 18px rgba(31,79,138,.24);
}
.kpi-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:14px;
    margin-top:22px;
}
.kpi-card{
    padding:18px;
    border-radius:20px;
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.10);
    text-align:center;
}
.kpi-card span{
    font-size:22px;
}
.kpi-card small{
    display:block;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
    font-size:11px;
    margin:8px 0 6px;
}
.kpi-card strong{
    font-size:22px;
    line-height:1.1;
}
.project-foot{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
    margin-top:18px;
}
.project-foot > div{
    border-radius:18px;
    padding:16px;
    background:rgba(198,154,67,.08);
    border:1px solid rgba(198,154,67,.15);
}
.project-foot small{
    display:block;
    color:#e8d6aa;
    text-transform:uppercase;
    font-size:11px;
    letter-spacing:.08em;
}
.project-foot strong{
    display:block;
    font-size:22px;
}
.hero-buttons{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:22px;
}
.risk-note{
    font-size:13px!important;
    color:var(--muted)!important;
    margin-top:18px!important;
}

/* SECTIONS */
.section{
    padding:54px 0 0;
}
.section-heading{
    margin-bottom:24px;
}
.section-heading .tag{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:0 12px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.10);
    color:var(--gold-soft);
    background:rgba(255,255,255,.03);
    font-size:12px;
    letter-spacing:.1em;
    text-transform:uppercase;
    font-weight:800;
}
.section-heading h2{
    margin:14px 0 8px;
    font-size:clamp(30px, 4vw, 48px);
    line-height:1.04;
    letter-spacing:-.03em;
}
.section-heading p{
    margin:0;
    color:var(--muted);
    max-width:780px;
}
.cards-3{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:18px;
}
.info-card{
    border-radius:28px;
    padding:26px;
    background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
    border:1px solid rgba(255,255,255,.10);
    box-shadow:var(--shadow);
    transition:.25s ease;
}
.info-card:hover{transform:translateY(-4px)}
.info-card .icon{
    width:54px;height:54px;border-radius:16px;
    display:grid;place-items:center;
    background:linear-gradient(135deg, rgba(198,154,67,.25), rgba(31,79,138,.24));
    border:1px solid rgba(255,255,255,.10);
    margin-bottom:16px;
    font-size:22px;
    font-weight:900;
}
.info-card h3{
    margin:0 0 8px;
    font-size:22px;
}
.info-card p{
    margin:0;
    color:var(--muted);
}

/* PROJECT LIST */

.project-wrap{

    display:grid;

    gap:22px;

    position:relative;

    z-index:5;

}



.project-card{

    position:relative;

    overflow:visible;

    isolation:isolate;

    border-radius:30px;

    border:1px solid rgba(255,255,255,.10);

    background:linear-gradient(
        180deg,
        rgba(255,255,255,.07),
        rgba(255,255,255,.03)
    );

    box-shadow:var(--shadow);

    z-index:10;

}



.project-grid{

    position:relative;

    z-index:2;

}



.project-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
}
.project-media{
    position:relative;
    min-height:100%;
    background:#0b1524;
}
.render-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    padding:8px;
    height:100%;
}
.render-grid img{
    width:100%;
    height:220px;
    object-fit:cover;
    border-radius:18px;
}
.render-grid .big{
    grid-column:span 2;
    height:300px;
}
.project-content{
    padding:30px;
}
.project-top h3{
    margin:12px 0 8px;
    font-size:34px;
    line-height:1.04;
}
.project-top p{
    margin:0;
    color:var(--muted);
}
.pill{
    display:inline-flex;
    align-items:center;
    min-height:36px;
    padding:0 12px;
    border-radius:999px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.10);
    color:#d8e2ef;
    font-size:13px;
    font-weight:800;
    text-transform:uppercase;
}
.project-stats{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:14px;
    margin:22px 0;
}
.project-stats.compact{
    margin-top:18px;
}
.stat-box{
    padding:18px;
    border-radius:18px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.10);
}
.stat-box small{
    display:block;
    font-size:12px;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.08em;
    margin-bottom:6px;
}
.stat-box strong{
    font-size:22px;
    line-height:1.1;
}
.progress-group{
    display:grid;
    gap:16px;
    margin-top:8px;
}
.progress-item label{
    display:flex;
    justify-content:space-between;
    gap:12px;
    margin-bottom:8px;
    color:#dbe5f1;
    font-weight:800;
    font-size:14px;
}

/* CONTACT */
.contact-grid{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:20px;
}
.contact-box{
    padding:30px;
    border-radius:30px;
    background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
    border:1px solid rgba(255,255,255,.10);
    box-shadow:var(--shadow);
}
.contact-box h3{
    margin:0 0 8px;
    font-size:30px;
}
.contact-box p{
    margin:0;
    color:var(--muted);
}
.contact-list{
    display:grid;
    gap:14px;
    margin-top:18px;
}
.contact-item{
    display:flex;
    align-items:flex-start;
    gap:14px;
    padding:16px 18px;
    border-radius:18px;
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
}
.contact-item .dot{
    width:14px;height:14px;border-radius:50%;
    margin-top:6px;
    background:linear-gradient(135deg, var(--gold), var(--gold-soft));
    box-shadow:0 0 18px rgba(198,154,67,.30);
    flex:0 0 14px;
}
.contact-item strong{display:block;margin-bottom:4px}
.contact-item span,.contact-item a{color:var(--muted)}
.form{
    display:grid;
    gap:14px;
    margin-top:18px;
}
.field{
    display:grid;
    gap:8px;
}
.field label{
    font-size:14px;
    font-weight:800;
    color:#dbe5f1;
}
.field input,.field textarea{
    width:100%;
    min-height:54px;
    border:none;
    outline:none;
    border-radius:16px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    color:var(--white);
    padding:14px 16px;
    font:inherit;
}
.field textarea{
    min-height:130px;
    resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{
    color:#aab9cc;
}
.notice{
    margin-top:16px;
    padding:18px 20px;
    border-radius:18px;
    background:rgba(198,154,67,.08);
    border:1px solid rgba(198,154,67,.15);
    color:#e8d6aa!important;
    font-size:14px;
}

/* FOOTER */
footer{
    padding:44px 0 58px;
}
.footer-box{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    padding-top:26px;
    border-top:1px solid rgba(255,255,255,.08);
    color:var(--muted);
    font-size:14px;
}
.footer-brand{
    display:flex;
    align-items:center;
    gap:12px;
}
.footer-brand img{height:38px;width:auto}

/* WHATSAPP */
.wa-float{
    position:fixed;
    right:18px;
    bottom:18px;
    z-index:9900;
    width:66px;
    height:66px;
    border-radius:50%;
    display:grid;
    place-items:center;
    color:#fff;
    background:linear-gradient(135deg, #1ec95b, #14a647);
    box-shadow:0 16px 36px rgba(20,166,71,.34);
    border:1px solid rgba(255,255,255,.22);
}
.wa-float svg{
    width:30px;height:30px;
}
.wa-float::before,
.wa-float::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:50%;
    border:2px solid rgba(30,201,91,.38);
    animation:pulse 2.3s infinite;
}
.wa-float::after{animation-delay:1.1s}
@keyframes pulse{
    0%{transform:scale(1);opacity:.75}
    70%{transform:scale(1.7);opacity:0}
    100%{opacity:0}
}

/* LOGIN */
.login-modal{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.72);
    backdrop-filter:blur(10px);
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:9999;
    opacity:0;
    visibility:hidden;
    transition:.3s;
    padding:20px;
}
.login-modal.active{
    opacity:1;
    visibility:visible;
}
.login-box{
    width:min(100%, 400px);
    padding:38px;
    border-radius:24px;
    background:linear-gradient(180deg, #0f1b2d, #091423);
    border:1px solid rgba(255,255,255,.1);
    text-align:center;
    position:relative;
    box-shadow:0 24px 70px rgba(0,0,0,.42);
}
.login-logo{
    height:66px;
    width:auto;
    margin:0 auto 20px;
}
.login-box h3{
    margin:0 0 22px;
    font-size:24px;
}
.login-field{
    margin-bottom:16px;
    text-align:left;
}
.login-field label{
    display:block;
    font-size:14px;
    margin-bottom:7px;
    color:#dbe5f1;
    font-weight:800;
}
.login-field input{
    width:100%;
    min-height:52px;
    padding:12px 14px;
    border-radius:13px;
    border:1px solid rgba(255,255,255,.15);
    background:#091423;
    color:#fff;
    outline:none;
}
.login-box .btn{
    width:100%;
    border:none;
}
.cerrar-login{
    position:absolute;
    top:12px;
    right:16px;
    font-size:26px;
    cursor:pointer;
    background:none;
    border:none;
    color:#fff;
}

/* EMPTY */
.empty-project{
    border-radius:28px;
    padding:28px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
}

/* REVEAL */
.reveal{

    opacity:0;

    transform:translate3d(
        0,
        22px,
        0
    );

    backface-visibility:hidden;

    transition:
        opacity .7s ease,
        transform .7s ease;

}
.reveal.is-visible{
    opacity:1;
    transform:none;
}

/* RESPONSIVE */
@media (max-width: 1180px){
    .hero-grid{
        grid-template-columns:1fr;
    }
    .hero-copy{
        max-width:920px;
    }
}

@media (max-width: 980px){
    .project-grid,
    .contact-grid{
        grid-template-columns:1fr;
    }
    .cards-3{
        grid-template-columns:1fr;
    }
    .hero-kpis{
        grid-template-columns:1fr;
    }
}

@media (max-width: 780px){
    .container{
        width:min(100% - 24px, var(--max));
    }
    .nav{
        grid-template-columns:1fr;
        gap:10px;
        padding:12px 0;
    }
    .brand{
        grid-column:auto;
    }
    .brand img{
        height:54px;
        max-width:260px;
    }
    .nav-right{
        grid-column:auto;
        justify-content:center;
        width:100%;
    }
    .nav-right .btn{
        min-height:44px;
        padding:0 16px;
        font-size:14px;
    }
    .hero{
        padding-top:42px;
    }
    .hero h1{
        font-size:clamp(40px, 13vw, 64px);
    }
    .hero-actions{
        flex-direction:column;
    }
    .hero-actions .btn,
    .hero-buttons .btn{
        width:100%;
    }
    .project-slider{
        height:310px;
    }
    .hero-project-info{
        padding:22px;
    }
    .mini-grid,
    .kpi-grid,
    .project-foot,
    .project-stats{
        grid-template-columns:1fr;
    }
    .project-content,
    .contact-box,
    .info-card{
        padding:22px;
    }
    .render-grid .big,
    .render-grid img{
        height:220px;
    }
    .footer-box{
        flex-direction:column;
        align-items:flex-start;
    }
    .wa-float{
        width:60px;
        height:60px;
        right:14px;
        bottom:14px;
    }
}

@media (max-width: 420px){
    .brand img{
        height:48px;
        max-width:230px;
    }
    .nav-right{
        gap:8px;
    }
    .nav-right .btn{
        padding:0 13px;
        font-size:13px;
    }
    .project-slider{
        height:270px;
    }
    .mini-card{
        min-height:auto;
    }
}

@media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto}
    *,
    *::before,
    *::after{
        animation:none!important;
        transition:none!important;
    }
}
.project-top{

    display:block;

    width:100%;

    margin-bottom:30px;

}


.project-top h3{

    margin:18px 0 18px 0;

    font-size:54px;

    line-height:1.05;

    font-weight:800;

    color:#ffffff;

}


.descripcion-proyecto{

    display:block;

    width:100%;

    margin-bottom:25px;

    font-size:18px;

    line-height:1.7;

    color:#c8d4e5;

    font-weight:400;

    opacity:.95;

    overflow:visible;

    height:auto;

    max-height:none;

    position:relative;

    z-index:10;

}


.project-stats{

    margin-top:20px;

}

.modal-avance{

    display:none;

    position:fixed;

    inset:0;

    z-index:999999;

    background:rgba(0,0,0,.92);

    padding:40px;

    overflow:auto;

}


.modal-avance.show{

    display:block;

}


.modal-avance-box{

    max-width:1200px;

    margin:auto;

}


.cerrar-avance{

    display:block;

    text-align:right;

    color:#fff;

    font-size:45px;

    cursor:pointer;

    margin-bottom:25px;

}


.avance-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));

    gap:20px;

}


.avance-grid img{

    width:100%;

    border-radius:20px;

    box-shadow:0 15px 40px rgba(0,0,0,.35);

}



@media(max-width:780px){

    .modal-avance{

        padding:20px;

    }

}

.avance-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));

    gap:25px;

}



.avance-card{

    overflow:hidden;

    border-radius:24px;

    background:linear-gradient(
        180deg,
        rgba(255,255,255,.08),
        rgba(255,255,255,.03)
    );

    border:1px solid rgba(255,255,255,.10);

    box-shadow:0 20px 40px rgba(0,0,0,.35);

}



.avance-card img{

    width:100%;

    height:280px;

    object-fit:cover;

    display:block;

}



.avance-info{

    padding:20px;

}



.avance-fecha{

    color:#dcb35c;

    font-size:14px;

    font-weight:700;

    margin-bottom:12px;

    letter-spacing:.04em;

}



.avance-descripcion{

    color:#ffffff;

    font-size:17px;

    line-height:1.5;

    font-weight:500;

}



@media(max-width:780px){


    .avance-card img{

        height:220px;

    }


}


.geo-modal{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,.82);

    backdrop-filter:blur(8px);

    z-index:999999;

    display:none;

    justify-content:center;

    align-items:center;

    padding:20px;

}



.geo-modal.show{

    display:flex;

}



.geo-card{

    width:100%;

    max-width:760px;

    padding:60px;

    border-radius:32px;

    background:#ffffff;

    text-align:center;

    position:relative;

    box-shadow:0 40px 100px rgba(0,0,0,.35);

}



.geo-close{

    position:absolute;

    right:25px;

    top:20px;

    border:none;

    background:none;

    font-size:34px;

    cursor:pointer;

    color:#999;

}



.geo-logo{

    height:80px;

    margin-bottom:25px;

}



.geo-badge{

    display:inline-block;

    padding:8px 18px;

    border-radius:30px;

    background:#f4f7fc;

    color:#1d3d72;

    font-size:14px;

    font-weight:700;

    margin-bottom:20px;

}



.geo-card h3{

    margin:0 0 20px;

    font-size:42px;

    color:#102b4e;

    font-weight:800;

}



.geo-card p{

    font-size:22px;

    line-height:1.6;

    color:#53657c;

    max-width:560px;

    margin:auto;

}



.geo-buttons{

    margin-top:40px;

    display:flex;

    justify-content:center;

    gap:20px;

    flex-wrap:wrap;

}



.geo-btn{

    border:none;

    padding:18px 35px;

    border-radius:16px;

    font-size:18px;

    font-weight:700;

    cursor:pointer;

    transition:.3s;

}



.geo-primary{

    background:#d8ae4b;

    color:#fff;

}



.geo-primary:hover{

    transform:translateY(-2px);

}



.geo-secondary{

    background:#eef2f8;

    color:#1c3358;

}



.geo-card small{

    display:block;

    margin-top:30px;

    color:#8c98a8;

    font-size:14px;

}



@media(max-width:780px){


    .geo-card{

        padding:35px 25px;

    }


    .geo-card h3{

        font-size:30px;

    }


    .geo-card p{

        font-size:17px;

    }


    .geo-logo{

        height:55px;

    }


}


.cinta-vendido{

    position:absolute;

    top:40px;

    right:-92px;

    width:340px;

    height:56px;

    display:flex;

    align-items:center;

    justify-content:center;

    background:linear-gradient(
        90deg,
        #b8860b,
        #f0c75e
    );

    color:#111;

    font-size:22px;

    font-weight:900;

    letter-spacing:2px;

    text-transform:uppercase;

    transform:rotate(45deg);

    -webkit-transform:rotate(45deg);

    box-shadow:
        0 12px 35px rgba(0,0,0,.45);

    border-top:2px solid rgba(255,255,255,.35);

    border-bottom:2px solid rgba(255,255,255,.25);

    z-index:99999;

    pointer-events:none;

}



.geo-benefits{

    margin-top:30px;

    margin-bottom:30px;

    display:flex;

    justify-content:center;

    gap:15px;

    flex-wrap:wrap;

}



.geo-item{

    padding:12px 18px;

    border-radius:14px;

    background:#f4f7fc;

    color:#1c3358;

    font-size:15px;

    font-weight:600;

}



@media(max-width:780px){


    .geo-benefits{

        flex-direction:column;

    }


}