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

body{
    font-family:Arial, Helvetica, sans-serif;
    background:#111;
}

/* ===== LOADER ===== */

#loader{
    position:fixed;
    inset:0;
    width:100%;
    height:100vh;
    background:#0f172a; /* cambia color si quieres */
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:99999;
    transition:opacity .5s ease, visibility .5s;
}

#loader.hidden{
    opacity:0;
    visibility:hidden;
}

.spinner{
    width:70px;
    height:70px;
    border:6px solid rgba(255,255,255,.2);
    border-top:6px solid #c9a46c;
    border-radius:50%;
    animation:spin 1s linear infinite;
}

@keyframes spin{
    to{
        transform:rotate(360deg);
    }
}

/* NAVBAR */

.navbar{

    position:fixed;

    top:0;
    left:0;

    width:100%;

    height:90px;

    padding:0 60px;

    display:flex;

    justify-content:space-between;

    align-items:center;

    z-index:9999;

    /* background:rgba(0,0,0,0.5); */

    backdrop-filter:blur(10px);
}

/* LOGO */

.logo img{

    width:180px;
    height: 80px;

    object-fit:contain;
}

/* MENU */

.nav-menu ul{

    display:flex;

    gap:40px;

    list-style:none;
}

.nav-menu a{

    color:white;

    text-decoration:none;

    text-transform:uppercase;

    letter-spacing:2px;

    font-size:0.9rem;

    transition:0.3s;
}

.nav-menu a:hover{

    color:#d4af37;
}

/* HAMBURGUESA */

.hamburger{

    width:35px;

    height:28px;

    display:none;

    flex-direction:column;

    justify-content:space-between;

    cursor:pointer;

    z-index:10001;
}

.hamburger span{

    width:100%;

    height:3px;

    background:white;

    border-radius:10px;

    transition:0.4s;
}

/* ANIMACION */

.hamburger.active span:nth-child(1){

    transform:
        rotate(45deg)
        translate(7px, 7px);
}

.hamburger.active span:nth-child(2){

    opacity:0;
}

.hamburger.active span:nth-child(3){

    transform:
        rotate(-45deg)
        translate(8px, -8px);
}

/* MOBILE MENU */

.mobile-menu{

    position:fixed;

    top:0;
    right:-100%;

    width:100%;
    height:100vh;

    background:#000;

    display:flex;

    justify-content:center;
    align-items:center;

    transition:0.6s ease;

    z-index:9990;
}

.mobile-menu.active{

    right:0;
}

.mobile-menu ul{

    list-style:none;

    text-align:center;
}

.mobile-menu li{

    margin:30px 0;
}

.mobile-menu a{

    color:white;

    text-decoration:none;

    font-size:1rem;

    text-transform:uppercase;

    letter-spacing:4px;

    transition:0.3s;
}

.mobile-menu a:hover{

    color:#d4af37;
}


/* LOGO */

.logo{

    display:flex;

    align-items:center;

    z-index:10000;
}

.logo-link{

    display:flex;

    align-items:center;

    gap:15px;

    text-decoration:none;
}

.logo-img{

    width:65px;

    height:auto;

    object-fit:contain;
}

/* TEXTO LOGO */

.logo-text{

    display:flex;

    flex-direction:column;

    line-height:1;
}

.logo-title{

    color:white;

    font-size:1rem;

    font-weight:700;

    letter-spacing:3px;
}

.logo-subtitle{

    color:#d4af37;

    font-size:0.75rem;

    letter-spacing:6px;

    margin-top:5px;
}

/* RESPONSIVE */

@media(max-width:768px){

    .logo-img{

        width:50px;
    }

    .logo-title{

        font-size:0.8rem;
    }

    .logo-subtitle{

        font-size:0.65rem;

        letter-spacing:4px;
    }
}

/* RESPONSIVE */

@media(max-width:992px){

    .nav-menu{

        display:none;
    }

    .hamburger{

        display:flex;
    }

    .navbar{

        padding:0 30px;
    }

    .logo img{

        width:140px;
    }
}

/* fin menu */

/* slider  */



body{
    font-family:Arial, Helvetica, sans-serif;
    overflow-x:hidden;
}

.rs-slider{
    position:relative;
    width:100%;
    height:100vh;
    overflow:hidden;
}

.rs-slide{
    position:absolute;
    width:100%;
    height:100%;
    top:0;
    left:0;

    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;

    opacity:0;
    transform:scale(1.1);
    transition:
        opacity 1s ease,
        transform 6s ease;

    z-index:1;
}

.rs-slide.active{
    opacity:1;
    transform:scale(1);
    z-index:2;
}

.overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.45);
}

.content{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);

    text-align:center;
    color:white;

    z-index:10;

    width:90%;
}

.content h1{
    font-size:4rem;
    margin-bottom:20px;
    text-transform:uppercase;
    letter-spacing:3px;
}

.content p{
    font-size:1.3rem;
}

.prev,
.next{
    position:absolute;
    top:50%;
    transform:translateY(-50%);

    background:rgba(255,255,255,0.2);
    border:none;
    color:white;

    width:50px;
    height:50px;

    cursor:pointer;
    z-index:100;

    font-size:2rem;

    backdrop-filter:blur(5px);

    transition:0.3s;
}

.prev:hover,
.next:hover{
    background:white;
    color:black;
}

.prev{
    left:20px;
}

.next{
    right:20px;
}

@media(max-width:768px){

    .content h1{
        font-size:2rem;
    }

    .content p{
        font-size:1rem;
    }

    .prev,
    .next{
        width:40px;
        height:40px;
        font-size:1.5rem;
    }
}


/* fin slider */


/* TITULOS DE SECCIONES */
.section-title{
    width:100%;
    text-align:center;
    margin:60px 0 40px;
    
}

.section-title h2{
    font-size:clamp(2rem,4vw,3rem);
    font-weight:700;
    color:#fff; /* cambia si tu fondo es claro */
    margin:0;
    position:relative;
    display:inline-block;
    margin-bottom: 35px
}

/* linea decorativa opcional */
.section-title h2::after{
    content:'';
    display:block;
    width:60%;
    height:3px;
    margin:12px auto 0;
    background:#c9a46c;
    border-radius:10px;
}
.title-contact h2{
    padding:0 20px;
}



@media(max-width:768px){

    .section-title{
    width:100%;
    text-align:center;
    margin:60px 0 80px;
    /* padding:0 20px; */
}

.section-title h2{
    font-size:clamp(2rem,4vw,3rem);
    font-weight:400;
    color:#fff; /* cambia si tu fondo es claro */
    margin:0;
    position:relative;
    display:inline-block;
}

/* linea decorativa opcional */
.section-title h2::after{
    content:'';
    display:block;
    width:60%;
    height:3px;
    margin:12px auto 0;
    background:#c9a46c;
    border-radius:10px;
}
}

/* fin title */



/* areas de practica */

.services-section-movil{
    display: none;
}

.services-section{

    width:100%;

    padding:40px;

    display:grid;

    grid-template-columns:repeat(5,1fr);

    gap:20px;

    background:#111;
}

/* CARD */

.service-card{

    position:relative;

    height:320px;

    overflow:hidden;

    border-radius:12px;

    cursor:pointer;
}

.service-card img{

    width:100%;
    height:100%;

    object-fit:cover;

    transition:
        transform 0.8s ease,
        filter 0.8s ease;
}

.service-card:hover img{

    transform:scale(1.1);

    filter:brightness(0.4);
}

/* OVERLAY */

.service-overlay{

    position:absolute;

    inset:0;

    display:flex;

    flex-direction:column;

    justify-content:center;
    align-items:center;

    text-align:center;

    padding:20px;

    background:rgba(0,0,0,0.2);

    color:white;

    opacity:0;

    transform:translateY(40px);

    transition:
        opacity 0.5s ease,
        transform 0.5s ease;
}

.service-card:hover .service-overlay{

    opacity:1;

    transform:translateY(0);
}

/* TEXT */

.service-overlay h3{

    font-size:1.3rem;

    text-transform:uppercase;

    margin-bottom:15px;

    letter-spacing:2px;
}

.service-overlay p{

    margin-bottom:25px;

    line-height:1.6;
}

/* BUTTON */

.service-btn{

    padding:12px 24px;

    border:2px solid white;

    background:transparent;

    color:white;

    cursor:pointer;

    text-transform:uppercase;

    letter-spacing:2px;

    transition:0.4s ease;
}

.service-btn:hover{

    background:white;

    color:black;

    transform:translateY(-5px);
}


/* =========================
   SERVICES MOBILE FIXED
========================= */

@media screen and (max-width:768px){

    body{
        overflow-x:hidden;
    }
    .services-section{
        display: none;
    }

    .services-section-movil{
        display: flex;
        position:relative;
        width:100%;
        overflow:hidden;
        padding:25px 0;
    }

    /* espacio real para el carrusel */

    .services-carousel{
        width:100%;
        overflow:hidden;
        padding:0 50px;
        margin:0 auto;
    }

    .services-track{
        display:flex;
        gap:0;
        transition:transform .5s ease;
        will-change:transform;
    }

    /* card centrada */

    .service-card{
        flex:0 0 calc(100vw - 100px);
        max-width:calc(100vw - 100px);
        height:420px;
        border-radius:18px;
        overflow:hidden;
        position:relative;
        margin:0 auto;
        flex-shrink:0;
    }

    .service-card img{
        width:100%;
        height:100%;
        object-fit:cover;
        display:block;
    }

    .service-overlay{
        position:absolute;
        inset:0;
        background:linear-gradient(
            to top,
            rgba(0,0,0,.75),
            rgba(0,0,0,.15)
        );
        display:flex;
        flex-direction:column;
        justify-content:flex-end;
        padding:25px;
        color:white;
    }

    .service-overlay h3{
        font-size:1.1rem;
        margin-bottom:8px;
        line-height:1.2;
    }

    .service-overlay p{
        font-size:.95rem;
        line-height:1.4;
        margin-bottom:18px;
    }

    .service-btn{
        width:max-content;
        padding:10px 18px;
        border-radius:8px;
    }

    /* flechas */

    .services-arrow{
        position:absolute;
        top:50%;
        transform:translateY(-50%);
        width:42px;
        height:42px;
        border:none;
        border-radius:50%;
        background:white;
        z-index:100;
        display:flex;
        justify-content:center;
        align-items:center;
        box-shadow:0 4px 12px rgba(0,0,0,.25);
        cursor:pointer;
    }

    .services-arrow i{
        font-size:15px;
    }

    .prev{
        left:5px;
    }

    .next{
        right:5px;
    }
}

/* POPUP OVERLAY */

.popup-overlay{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,0.75);

    backdrop-filter:blur(5px);

    opacity:0;

    visibility:hidden;

    transition:0.4s ease;

    z-index:9998;
}

.popup-overlay.active{

    opacity:1;

    visibility:visible;
}

/* POPUP */

.popup-box{

    position:fixed;

    top:50%;
    left:50%;

    transform:
        translate(-50%, -50%)
        scale(0.8);

    width:90%;
    max-width:650px;

    background:#1a1a1a;

    color:white;

    padding:50px;

    border-radius:20px;

    z-index:9999;

    opacity:0;

    visibility:hidden;

    transition:0.4s ease;
}

.popup-box.active{

    opacity:1;

    visibility:visible;

    transform:
        translate(-50%, -50%)
        scale(1);
}

/* CLOSE */

.close-popup{

    position:absolute;

    top:20px;
    right:20px;

    width:40px;
    height:40px;

    border:none;

    border-radius:50%;

    background:white;

    color:black;

    cursor:pointer;

    font-size:1rem;

    transition:0.3s;
}

.close-popup:hover{

    transform:rotate(90deg);
}

/* TITLES */

.popup-box h2{

    font-size:2.5rem;

    margin-bottom:15px;

    text-transform:uppercase;

    letter-spacing:3px;
}

.popup-box h4{

    font-size:1.1rem;

    color:#d4af37;

    margin-bottom:30px;

    letter-spacing:2px;
}

.popup-box p{

    line-height:2;

    color:#d1d1d1;

    font-size:1rem;

    text-align: justify;
}

/* TABLET */

@media(max-width:1200px){

    .services-section{

        grid-template-columns:repeat(3,1fr);
    }
}

/* MOBILE */

@media(max-width:768px){

    .services-section{

        grid-template-columns:1fr;

        padding:20px;
    }

    .service-card{

        height:280px;
    }

    .service-overlay{

        opacity:1;

        transform:none;

        background:rgba(0,0,0,0.35);
    }

    .popup-box{

        padding:35px 25px;
    }

    .popup-box h2{

        font-size:1.8rem;
    }

    .popup-box h4{

        font-size:1rem;
    }

    .popup-box p{

        font-size:0.95rem;

        line-height:1.7;
    }
}
/* fin area de practicas */

/* profesional */

.financing-section{

    width:100%;

    min-height:100vh;

    display:grid;

    grid-template-columns:40% 60%;

    background:#0f0f0f;
}

/* IZQUIERDA */

.financing-tabs{

    display:grid;

    grid-template-columns:1fr 1fr;

    grid-template-rows:1fr 1fr;

    height:100vh;
}

/* CARD */

.finance-card{

    position:relative;

    overflow:hidden;

    cursor:pointer;

    transition:0.5s ease;
}

.finance-card img{

    width:100%;
    height:100%;

    object-fit:cover;

    transition:
        transform 0.8s ease,
        filter 0.8s ease;
}

.finance-card:hover img{

    transform:scale(1.1);

    filter:brightness(0.5);
}

.finance-card.active img{

    filter:brightness(0.4);
}

/* OVERLAY */

.finance-overlay{

    position:absolute;

    inset:0;

    display:flex;

    justify-content:center;
    align-items:center;

    text-align:center;

    background:rgba(0,0,0,0.2);

    padding:20px;
}

.finance-overlay h3{

    color:white;

    font-size:1.3rem;

    text-transform:uppercase;

    letter-spacing:3px;

    z-index:10;
}

/* DERECHA */

.financing-content{

    position:relative;

    display:flex;

    align-items:center;

    justify-content:center;

    padding:80px;

    background:#151515;
}

/* CONTENT */

.content-box{

    position:absolute;

    opacity:0;

    transform:translateY(40px);

    transition:
        opacity 0.6s ease,
        transform 0.6s ease;

    max-width:700px;

    pointer-events:none;
}

.content-box.active{

    opacity:1;

    transform:translateY(0);

    pointer-events:auto;
}

.content-box h2{

    font-size:2rem;

    margin-bottom:30px;

    text-transform:uppercase;

    letter-spacing:4px;

    color: #777;
}

.content-box p{

    font-size:1.1rem;

    line-height:2;

    margin-bottom:40px;

    color:#d1d1d1;
}

/* BOTON */

.finance-btn{

    display:inline-block;

    padding:14px 34px;

    border:2px solid white;

    color:white;

    text-decoration:none;

    text-transform:uppercase;

    letter-spacing:3px;

    transition:0.4s ease;
}

.finance-btn:hover{

    background:white;

    color:black;

    transform:translateY(-5px);
}

/* RESPONSIVE */

@media(max-width:992px){

    .financing-section{

        grid-template-columns:1fr;
    }

    .financing-tabs{

        height:auto;

        grid-template-columns:1fr 1fr;
    }

    .finance-card{

        height:250px;
    }

    .financing-content{

        min-height:500px;

        padding:40px;
    }

    .content-box h2{

        font-size:2rem;
    }
}

@media(max-width:768px){

    .financing-tabs{

        grid-template-columns:1fr;
    }

    .finance-card{

        height:220px;
    }

    .content-box{

        position:relative;

        opacity:1;

        transform:none;

        display:none;
    }

    .content-box.active{

        display:block;
    }

    .financing-content{

        padding:30px;
    }

    .content-box h2{

        font-size:1.6rem;
    }

    .content-box p{

        font-size:1rem;

        line-height:1.7;
    }
}

/* fin profesional */


/* formulario de contacto */

/* =====================
MAPA
===================== */

.map-section{

    position:relative;

    width:calc(100% - 40px);

    height:52vh;

    margin:20px auto 0;

    border-radius:22px;

    overflow:hidden;

    z-index:1;
}

.map-section iframe{

    width:100%;
    height:100%;

    border:none;

    border-radius:22px;

    /* filter:
        grayscale(100%)
        contrast(105%);

    box-shadow:
        0 15px 35px
        rgba(0,0,0,.12); */
}

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

.contact-section{

    position:relative;

    z-index:10;

    width:100%;

    /* SUPERPOSICION */

    /* margin-top:-145px; */

    padding:0 40px 30px;
}

/* WRAPPER */

.contact-wrapper{

    max-width:1280px;

    margin:auto;

    display:grid;

    grid-template-columns:38% 62%;

    gap:28px;
}

/* CARDS */

.contact-info,
.contact-form{

    background:white;

    border-radius:20px;

    /* MENOS PADDING */

    padding:30px;

    box-shadow:
        0 15px 35px
        rgba(0,0,0,.12);
}

/* =====================
TITULOS
===================== */

.contact-info h2,
.contact-form h2{

    /* MAS CHICO */

    font-size:1.5rem;

    margin-bottom:22px;

    letter-spacing:2px;

    text-transform:uppercase;

    color:#111;
}

/* =====================
INFO
===================== */

.info-block{

    margin-bottom:18px;
}

.info-block h3{

    font-size:.9rem;

    color:#777;

    margin-bottom:6px;

    letter-spacing:1px;
}

.info-block p{

    color:#111;

    /* MENOS LINEA */

    line-height:1.5;

    font-size:.92rem;
}

/* ICONOS */

.social-icons{

    display:flex;

    gap:14px;

    margin-top:20px;
}

.social-icons a{

    width:42px;
    height:42px;

    display:flex;

    justify-content:center;
    align-items:center;

    border:1px solid #111;

    border-radius:50%;

    color:#111;

    text-decoration:none;

    font-size:1rem;

    transition:.3s;
}

.social-icons a:hover{

    background:#111;

    color:white;
}

/* =====================
FORM
===================== */

#contactForm{

    display:flex;

    flex-direction:column;

    gap:12px;
}

#contactForm input,
#contactForm textarea{

    width:100%;

    /* MAS COMPACTO */

    padding:14px 16px;

    border:1px solid #ddd;

    border-radius:8px;

    background:white;

    outline:none;

    font-size:.92rem;

    transition:.3s;
}

#contactForm textarea{

    /* MAS CHICO */

    min-height:110px;

    resize:none;
}

#contactForm input:focus,
#contactForm textarea:focus{

    border-color:#111;
}

.contact-btn{

    padding:14px;

    border:none;

    border-radius:8px;

    background:#111;

    color:white;

    font-size:.85rem;

    letter-spacing:1.5px;

    text-transform:uppercase;

    cursor:pointer;

    transition:.3s;
}

.contact-btn:hover{

    background:#333;
}

/* =====================
RESPONSIVE
===================== */

/* =====================
RESPONSIVE
===================== */

@media(max-width:992px){

    /* MAPA */

    .map-section{

        width:100%;

        height:40vh;
    }

    /* QUITAR OVERLAP */

    .contact-section{

        margin-top:0;

        padding:35px 20px 40px;
    }

    /* APILAR */

    .contact-wrapper{

        grid-template-columns:1fr;

        gap:25px;
    }

    /* CARDS */

    .contact-info,
    .contact-form{

        padding:28px;

        border-radius:18px;
    }
}

/* MOBILE */

@media(max-width:768px){

    /* MAPA CUADRADO */

    .map-section{

        width:calc(100% - 24px);

        height:320px;

        margin:12px auto 0;

        border-radius:18px;
    }

    .map-section iframe{

        width:100%;
        height:100%;

        object-fit:cover;
    }

    /* SIN SUPERPOSICION */

    .contact-section{

        margin-top:0;

        padding:1px 18px 45px;
    }

    /* TITULOS */

    .contact-info h2,
    .contact-form h2{

        font-size:1.25rem;

        margin-bottom:20px;
    }

    /* TEXTO */

    .info-block p{

        font-size:.88rem;

        line-height:1.55;
    }

    /* INPUTS */

    #contactForm input,
    #contactForm textarea{

        padding:14px;

        font-size:.9rem;
    }

    #contactForm textarea{

        min-height:110px;
    }

    .contact-btn{

        padding:14px;
    }

    .social-icons{

        margin-top:15px;
    }
}
/* fin formulario de contacto */


/* footer */
.footer-minimal {
    padding: 60px 0;
    text-align: center;
    background: #323232;
}

.footer-minimal .icon-bg-white {
    background: rgba(255,255,255,.05);
    color: #fff;
}

.footer-minimal * + .rights {
    margin-top: 45px;
}

@media (min-width: 992px) {
    .footer-minimal {
        padding: 90px 0;
    }
}

@media (min-width: 1200px) {
    .footer-minimal {
        padding: 120px 0 110px;
    }

    .footer-minimal * + .rights {
        margin-top: 100px;
    }
}

.footer-minimal .rights {
    color: rgba(255,255,255,.5);
}

.footer-minimal .rights a {
    color: rgba(255,255,255,.5);
}

.footer-minimal .social-list li {
    margin-top: 0;
}

/* NAV */

.footer-minimal-nav {
    display: inline-block;
}

.footer-minimal-nav li {
    padding: 0 20px;
    list-style: none;
}

@media (min-width: 768px) {
    .footer-minimal-nav li {
        display: inline-block;
    }
}

.footer-minimal-nav li + li {
    margin-top: 10px;
}

@media (min-width: 768px) {
    .footer-minimal-nav li + li {
        margin-top: 0;
        border-left: 1px solid rgba(255,255,255,.5);
    }
}

.footer-minimal-nav a {
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .02em;
    text-align: center;
    color: #fff;
    text-decoration: none;
}

/* SOCIAL */

ul.social-list {
    margin-left: -10px;
    margin-right: -10px;
    padding: 0;
}

ul.social-list > li {
    display: inline-block;
}

ul.social-list > * {
    margin-top: 20px;
    padding-left: 10px;
    padding-right: 10px;
}

ul.social-list a:hover {
    color: #fff;
    background: #44c8da;
}

@media (min-width: 768px) {
    ul.social-list {
        margin-left: -18px;
        margin-right: -18px;
    }

    ul.social-list > * {
        margin-top: 36px;
        padding-left: 18px;
        padding-right: 18px;
    }
}

/* RIGHTS */

p.rights {
    font-size: 14px;
    color: rgba(21,21,21,.8);
}

p.rights a {
    color: inherit;
}

/* fin de footer */


/* btn whatssaap */
/* BOTON WHATSAPP */

.btn-whatsapp{
    position: fixed;
    bottom: 25px;
    right: 25px;
    width: 65px;
    height: 65px;
    background: #25D366;
    color: #fff;
    border-radius: 50%;
    display:flex;
    justify-content:center;
    align-items:center;
    font-size:34px;
    text-decoration:none;
    box-shadow:0 5px 15px rgba(0,0,0,.35);
    z-index:9999;
    transition:.3s ease;
}

.btn-whatsapp:hover{
    transform:scale(1.1);
    box-shadow:0 8px 25px rgba(0,0,0,.45);
}

/* MOBILE */

@media(max-width:768px){

    .btn-whatsapp{
        width:58px;
        height:58px;
        font-size:30px;
        bottom:20px;
        right:20px;
    }

}
/* fin btn whatssap */

/* ===== REVEAL SCROLL ===== */

/* ===== REVEAL DIRECCIONAL ===== */

.reveal{
    opacity:0;
    transition:
        opacity .9s ease,
        transform .9s ease;
    will-change:transform, opacity;
}
.reveal-top{
    transform:translateY(-70px);
}
/* desde abajo */
.reveal-bottom{
    transform:translateY(70px);
}

/* desde izquierda */
.reveal-left{
    transform:translateX(-80px);
}

/* desde derecha */
.reveal-right{
    transform:translateX(80px);
}

.reveal.active{
    opacity:1;
    transform:translate(0,0);
}
img{max-width:100%;height:auto;display:block;}
.services-section-movil img,.service-card img{content-visibility:auto;}
