/* ===================================================
   VALLE GRID
=================================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{
    --bg-dark:#05090E;
    --bg-dark-alt:#071B33;
    --primary-blue:#0A74FF;
    --primary-blue-hover:#2B8CFF;
    --text-light:#ffffff;
    --text-dark:#090b0e;
    --serif:'Playfair Display', serif;
    --sans:'Inter', sans-serif;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:var(--sans);
    background:var(--bg-dark);
    color:var(--text-light);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
}

.serif-text{
    font-family:var(--serif);
    font-style:italic;
    font-weight:400;
}

.section-tagline{
    text-transform:uppercase;
    letter-spacing:3px;
    font-size:.72rem;
    color:var(--primary-blue);
    font-weight:700;
}

.main-title{
    font-family:var(--serif);
    font-size:5rem;
    line-height:1.05;
    font-weight:500;
    margin-top:18px;
    margin-bottom:28px;
}

/* ==========================================
   NAVIGATION
========================================== */

.navbar{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    background:var(--bg-dark);
    border-bottom:1px solid rgba(255,255,255,.05);
    z-index:9999;
}

.nav-container{
    max-width:1500px;
    margin:0 auto;
    padding:0 80px;
    height:110px;
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.logo-wrapper{
    display:flex;
    align-items:center;
    background:transparent;
    text-decoration:none;
}

.nav-logo-img{
    height:100px;
    width:auto;
    display:block;
}

.nav-links{
    display:flex;
    gap:36px;
    align-items:center;
}

.nav-links a{
    color:rgba(255,255,255,.75);
    text-decoration:none;
    font-size:.85rem;
    font-weight:600;
    transition:.25s;
}

.nav-links a:hover{
    color:var(--primary-blue);
}

.btn-nav-cta{
    background:var(--primary-blue);
    color:white !important;
    padding:14px 24px;
    border-radius:4px;
}

.btn-nav-cta:hover{
    background:var(--primary-blue-hover);
    color:white;
}

/* ==========================================
   HERO
========================================== */

.hero-section{
    min-height:100vh;
    padding-top:180px;
    padding-bottom:120px;
    background:#03080c;
}

.hero{
    position:relative;
    overflow:hidden;
    isolation:isolate;
}

.hero .layout-container{
    position:relative;
    z-index:2;
}

.hero-image-layer{
    position:absolute;
    inset:0;
    z-index:-2;

    background:
    linear-gradient(
        90deg,
        rgba(3,8,12,.96) 0%,
        rgba(3,8,12,.82) 34%,
        rgba(3,8,12,.32) 64%,
        rgba(3,8,12,.08) 100%
    ),
    url("hero image.png");

    background-repeat:no-repeat;
    background-position:64% center;
    background-size:cover;
    filter:brightness(1.1);
    overflow:hidden;
    pointer-events:none;
}

.hero::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:72%;
    bottom:-8%;
    z-index:-1;
    pointer-events:none;

    background:
        radial-gradient(circle, rgba(10,116,255,.30) 0 1.4px, transparent 3px) 0 0 / 90px 52px;

    opacity:.08;
}

.hero::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;

    background:
    radial-gradient(circle at 72% 38%, rgba(10,116,255,.12), transparent 30%),
    linear-gradient(180deg, rgba(3,8,12,.04), rgba(3,8,12,.14));

    pointer-events:none;
}

.layout-container{
    max-width:1500px;
    margin:0 auto;
    padding:0 80px;
}

.hero-grid{
    position:relative;
    z-index:2;
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:90px;
    align-items:start;
}

.hero-copy,
.hero-panel,
.hero-actions{
    position:relative;
    z-index:2;
}

.hero-market-panel{
    border-left:1px solid rgba(255,255,255,.1);
    padding-left:48px;
}

.hero-market-item{
    margin-bottom:48px;
}

.hero-market-label{
    color:var(--primary-blue);
    font-size:.8rem;
    letter-spacing:3px;
    font-weight:700;
}

.hero-market-item h3{
    margin-top:10px;
    font-family:var(--serif);
    font-size:2rem;
    font-weight:500;
    line-height:1.15;
}

/* ==========================================
   VISUAL IMAGE SECTIONS
========================================== */

.visual-section{
    position:relative;
    overflow:hidden;
    isolation:isolate;
    min-height:760px;
    padding:120px 0;
    background:#03080d;
}

.visual-section-bg{
    position:absolute;
    inset:0;
    z-index:-3;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
}

.visual-section-shade{
    position:absolute;
    inset:0;
    z-index:-2;
    background:
    linear-gradient(90deg, rgba(3,8,13,.96) 0%, rgba(3,8,13,.72) 38%, rgba(3,8,13,.42) 70%, rgba(3,8,13,.78) 100%),
    linear-gradient(180deg, rgba(3,8,13,.48) 0%, rgba(3,8,13,.82) 100%);
}

.visual-section-inner{
    width:min(1500px, calc(100% - 160px));
    margin:0 auto;
    position:relative;
    z-index:2;
}

.visual-section-heading{
    max-width:760px;
    margin-bottom:60px;
}

.visual-title{
    margin-top:18px;
    font-family:var(--serif);
    color:white;
    font-size:clamp(3rem, 6vw, 5.8rem);
    line-height:.95;
    font-weight:500;
}

.visual-blue{
    color:var(--primary-blue);
}

.visual-intro-grid{
    display:grid;
    grid-template-columns:1fr .8fr;
    gap:90px;
    align-items:end;
    margin-bottom:70px;
}

.visual-context{
    color:rgba(255,255,255,.74);
    font-size:1.08rem;
    max-width:560px;
    margin-bottom:14px;
}

.overlay-card-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:28px;
}

.overlay-card{
    min-height:100%;
    padding:34px;
    background:linear-gradient(180deg, rgba(7,27,51,.88), rgba(3,8,13,.82));
    border:1px solid rgba(10,116,255,.34);
    box-shadow:0 18px 50px rgba(0,0,0,.28);
    backdrop-filter:blur(6px);
}

.overlay-card h3{
    position:relative;
    padding-bottom:15px;
    margin-bottom:18px;
    font-family:var(--serif);
    color:white;
    font-size:1.8rem;
    line-height:1.1;
    font-weight:500;
}

.overlay-card h3::after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:58px;
    height:2px;
    background:var(--primary-blue);
}

.overlay-card p{
    color:rgba(255,255,255,.76);
    font-size:.98rem;
}

.overlay-card ul{
    list-style:none;
    margin-top:24px;
}

.overlay-card li{
    position:relative;
    padding-left:22px;
    margin-top:12px;
    color:rgba(255,255,255,.86);
    font-size:.93rem;
}

.overlay-card li::before{
    content:"+";
    position:absolute;
    left:0;
    top:-1px;
    color:var(--primary-blue);
    font-weight:800;
}

.analysis-card-grid{
    grid-template-rows:repeat(2, auto);
}

.cta-card{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}

.cta-card .btn-solid{
    margin-top:auto;
}

/* ==========================================
   CONTACT
========================================== */

.section-block{
    padding:120px 0;
}

.split-grid{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:90px;
    align-items:start;
}

.contact-section{
    background:var(--bg-dark);
    color:var(--text-light);
}

.contact-form-card{
    background:#f8f8f6;
    border:1px solid rgba(255,255,255,.14);
    border-radius:12px;
    padding:48px;
    color:var(--text-dark);
}

.contact-form-card form{
    margin-top:32px;
}

.contact-form-card label{
    display:block;
    margin-bottom:8px;
    color:var(--text-dark);
    font-size:.82rem;
    font-weight:700;
}

.contact-form-card input,
.contact-form-card select,
.contact-form-card textarea{
    width:100%;
    margin-bottom:20px;
    padding:16px;
    background:white;
    border:1px solid #d8dde5;
    border-radius:6px;
    color:var(--text-dark);
    font:inherit;
}

.contact-form-card textarea{
    resize:vertical;
}

.contact-form-card button{
    background:var(--primary-blue);
    color:white;
    border:none;
    border-radius:4px;
    padding:18px 34px;
    font:inherit;
    font-weight:600;
    cursor:pointer;
    transition:.25s;
}

.contact-form-card button:hover{
    background:var(--primary-blue-hover);
}

.form-success-message{
    display:none;
    margin-top:22px;
    color:var(--text-dark);
    font-weight:600;
}

.form-success-message.is-visible{
    display:block;
}

/* ==========================================
   BUTTONS
========================================== */

.btn-row{
    display:flex;
    gap:18px;
    margin-top:42px;
}

.btn-solid{
    background:var(--primary-blue);
    color:white;
    text-decoration:none;
    padding:18px 34px;
    font-weight:600;
    display:inline-block;
}

.btn-solid:hover{
    background:var(--primary-blue-hover);
}

.btn-outline{
    border:1px solid rgba(255,255,255,.2);
    color:white;
    text-decoration:none;
    padding:18px 34px;
    font-weight:600;
    display:inline-block;
}

.btn-outline:hover{
    background:rgba(255,255,255,.05);
    border-color:var(--primary-blue);
    color:var(--primary-blue);
}

/* ==========================================
   FOOTER
========================================== */

.footer-wrapper{
    background:var(--bg-dark);
    border-top:1px solid rgba(255,255,255,.05);
    padding:100px 0 60px;
}

.footer-grid{
    max-width:1500px;
    margin:0 auto;
    padding:0 80px;
    display:grid;
    grid-template-columns:2fr 1fr 1fr;
    gap:80px;
}

.footer-grid a:hover{
    color:var(--primary-blue) !important;
}

/* ==========================================
   MOBILE
========================================== */

@media(max-width:992px){
    .nav-container{
        padding:0 24px;
    }

    .layout-container{
        padding:0 24px;
    }

    .nav-links{
        gap:18px;
    }

    .hero-grid,
    .split-grid,
    .visual-intro-grid{
        grid-template-columns:1fr;
        gap:60px;
    }

    .hero-market-panel{
        padding-left:28px;
    }

    .main-title{
        font-size:3rem;
    }

    .visual-section{
        min-height:auto;
        padding:90px 0;
    }

    .visual-section-inner{
        width:min(100% - 48px, 1500px);
    }

    .visual-title{
        font-size:3.2rem;
    }

    .overlay-card-grid{
        grid-template-columns:1fr;
    }

    .footer-grid{
        grid-template-columns:1fr;
        padding:0 24px;
    }
}

@media(max-width:640px){
    .nav-container{
        height:96px;
    }

    .nav-logo-img{
        height:82px;
    }

    .nav-links{
        gap:12px;
        font-size:.78rem;
    }

    .nav-links a:not(.btn-nav-cta){
        display:none;
    }

    .hero-section{
        padding-top:150px;
        padding-bottom:80px;
    }

    .visual-section-inner{
        width:min(100% - 32px, 1500px);
    }

    .visual-title{
        font-size:2.45rem;
    }

    .overlay-card{
        padding:28px;
    }

    .btn-row{
        flex-direction:column;
    }
}
