*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{
    --black:#050505;
    --white:#ffffff;
    --gray:#6f6f6f;
    --soft:#f5f5f5;
    --border:#e8e8e8;
    --accent:#8A2BE2;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Inter', sans-serif;
    background:var(--white);
    color:var(--black);
    overflow-x:hidden;
}

a{
    color:inherit;
    text-decoration:none;
}

.container{
    width:min(1180px, calc(100% - 40px));
    margin:auto;
}

/* NAVBAR */

.navbar{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    background:rgba(255,255,255,0.9);
    backdrop-filter:blur(18px);
    border-bottom:1px solid var(--border);
    z-index:1000;
}

.nav-content{
    height:72px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:32px;
}

.brand{
    display:flex;
    align-items:center;
}

.brand-logo{
    width:80px;
    object-fit:contain;
    display:block;
    align-items: left;
}

.nav-links{
    display:flex;
    align-items:center;
    gap:10px;
}

.nav-links a{
    height:44px;
    padding:0 16px;
    border-radius:999px;
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--gray);
    font-size:15px;
    font-weight:700;
    transition:
        background 0.25s,
        color 0.25s,
        transform 0.25s;
}

.nav-links a i{
    font-size:14px;
}

.nav-links a:not(.nav-pill-active):hover{
    background:#f1f1f1;
    color:var(--black);
    transform:translateY(-1px);
}

.nav-pill-active{
    background:var(--black);
    color:white !important;
}

.nav-pill-active:hover{
    background:var(--black);
    color:white !important;
}

.menu-btn{
    display:none;
    background:none;
    border:0;
    cursor:pointer;
}

.menu-btn span{
    display:block;
    width:28px;
    height:2px;
    background:var(--black);
    margin:6px 0;
}
/* GENERAL */

.section{
    padding:100px 0;
}

.eyebrow{
    display:block;
    margin-bottom:18px;
    color:var(--gray);
    font-size:13px;
    font-weight:900;
    letter-spacing:0.14em;
    text-transform:uppercase;
}

h1{
    font-size:clamp(42px, 6vw, 82px);
    line-height:0.92;
    letter-spacing:-0.07em;
}

h2{
    font-size:clamp(34px, 5vw, 58px);
    line-height:1;
    letter-spacing:-0.06em;
}

h3{
    font-size:24px;
    letter-spacing:-0.04em;
}

p{
    line-height:1.7;
    color:var(--gray);
}

/* HOME HERO */

.hero{
    min-height:calc(100vh - 72px);
    position:relative;
    display:flex;
    align-items:center;
    padding-top:80px;
    padding-bottom:150px;
    overflow:hidden;
}

.hero-bg{
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size:54px 54px;
    mask-image:radial-gradient(circle at center, black, transparent 75%);
    opacity:0.5;
}

.hero-content{
    position:relative;
    display:grid;
    grid-template-columns:1fr 0.85fr;
    gap:40px;
    align-items:center;
}

.hero-text{
    max-width:620px;
}

.hero-text h1{
    max-width:560px;
}

.hero-text p{
    max-width:520px;
    margin-top:22px;
    font-size:17px;
}

.hero-actions{
    display:flex;
    gap:14px;
    margin-top:28px;
    padding-bottom:10px;
    flex-wrap:wrap;
}

.btn{
    min-height:50px;
    padding:0 24px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    font-weight:800;
    transition:0.25s;
}

.btn:hover{
    transform:translateY(-4px);
}

.btn-primary{
    background:var(--black);
    color:white;
}

.btn-secondary{
    border:1px solid var(--border);
    background:white;
}

.window-card{
    width:100%;
    max-width:410px;
    background:var(--black);
    color:white;
    border-radius:32px;
    padding:26px;
    box-shadow:0 35px 80px rgba(0,0,0,0.18);
    overflow:hidden;
    position:relative;
}

.window-card::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
    background-size:38px 38px;
}

.window-dots,
.code-box{
    position:relative;
    z-index:1;
}

.window-dots{
    display:flex;
    gap:8px;
    margin-bottom:28px;
}

.window-dots span{
    width:11px;
    height:11px;
    background:white;
    border-radius:50%;
    opacity:0.35;
}

.code-box{
    display:grid;
    gap:14px;
}

.code-box p{
    color:white;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.08);
    padding:15px;
    border-radius:16px;
}

.hero-nosotros{
    position:relative;
    overflow:hidden;
}

.hero-nosotros::before{
    content:"";
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size:54px 54px;
    opacity:0.35;
    animation:gridMove 18s linear infinite;
}

@keyframes gridMove{

    0%{
        transform:translateY(0);
    }

    100%{
        transform:translateY(54px);
    }

}

.page-hero-grid{
    position:relative;
    z-index:2;
}

.brand-panel{
    animation:floatCard 5s ease-in-out infinite;
}

@keyframes floatCard{

    0%{
        transform:translateY(0);
    }

    50%{
        transform:translateY(-10px);
    }

    100%{
        transform:translateY(0);
    }

}

.about-visual-section{
    margin-top:-28px;
    position:relative;
    z-index:5;
}

/* SCROLL PREVIEW */

.scroll-preview{
    position:relative;
    margin-top:-150px;
    z-index:5;
    pointer-events:none;
}

.scroll-preview-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}

.scroll-preview span{
    background:white;
    border:1px solid var(--border);
    border-radius:22px;
    padding:22px 24px;
    font-weight:900;
    box-shadow:0 18px 45px rgba(0,0,0,0.06);
}


/* PAGE HERO GENERAL */

.page-hero{
    padding:140px 0 80px;
    background:var(--soft);
    border-bottom:1px solid var(--border);
}

.page-hero h1{
    max-width:900px;
    font-size:clamp(40px, 5.4vw, 68px);
    line-height:0.98;
    letter-spacing:-0.065em;
}

.page-hero p{
    max-width:680px;
    margin-top:24px;
    font-size:18px;
}

.page-hero-grid{
    display:grid;
    grid-template-columns:1fr 0.8fr;
    gap:70px;
    align-items:center;
}

/* NOSOTROS */

/* NOSOTROS */

.hero-nosotros{
    background:#f4f4f4;
    position:relative;
    overflow:hidden;
}

.page-hero-grid{
    display:grid;
    grid-template-columns:1fr 0.8fr;
    gap:70px;
    align-items:center;
    position:relative;
    z-index:2;
}

.brand-panel{
    background:white;
    border:1px solid var(--border);
    border-radius:34px;
    padding:40px;
    min-height:280px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    box-shadow:0 24px 70px rgba(0,0,0,0.06);
}

.brand-panel span{
    font-size:14px;
    font-weight:900;
    color:var(--gray);
    text-transform:uppercase;
    letter-spacing:0.14em;
}

.brand-panel strong{
    font-size:38px;
    line-height:1;
    letter-spacing:-0.06em;
}

.brand-panel p{
    margin-top:20px;
}


.about-visual-grid{
    display:grid;
    grid-template-columns:1fr 0.9fr;
    gap:24px;
    align-items:stretch;
}

.about-card{
    background:white;
    border:1px solid var(--border);
    border-radius:34px;
    padding:48px;
    box-shadow:0 20px 60px rgba(0,0,0,0.04);
}

.about-image-card{
    border-radius:34px;
    overflow:hidden;
    min-height:520px;
    background:#f2f2f2;
    box-shadow:0 20px 60px rgba(0,0,0,0.05);
}

.about-image-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

/* MISION Y VISION */

.mission-vision-section{
    padding-top:40px;
}

.mission-vision-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:24px;
}

.mission-card{
    background:white;
    border:1px solid var(--border);
    border-radius:34px;
    min-height:340px;
    padding:42px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    transition:0.25s;
    box-shadow:0 20px 60px rgba(0,0,0,0.04);
}

.mission-card:hover{
    transform:translateY(-6px);
    box-shadow:0 26px 70px rgba(0,0,0,0.08);
}

.mission-card span{
    font-size:13px;
    font-weight:900;
    color:var(--gray);
    letter-spacing:0.12em;
}

.mission-card h2{
    font-size:clamp(40px, 5vw, 68px);
    line-height:1;
}

.mission-card p{
    font-size:24px;
    line-height:1.3;
    letter-spacing:-0.04em;
    max-width:500px;
    color:var(--black);
}

.mission-card.dark{
    background:var(--black);
    border-color:var(--black);
    color:white;
}

.mission-card.dark p,
.mission-card.dark span{
    color:rgba(255,255,255,0.75);
}

/* SERVICIOS */

.hero-servicios{
    background:#050505;
    color:white;
}

.hero-servicios p,
.hero-servicios .eyebrow{
    color:rgba(255,255,255,0.68);
}

.services-visual{
    display:grid;
    gap:14px;
}

.services-visual div{
    background:rgba(255,255,255,0.08);
    border:1px solid rgba(255,255,255,0.14);
    color:white;
    border-radius:24px;
    padding:24px;
    font-size:24px;
    font-weight:900;
}

.services-visual div:nth-child(2),
.services-visual div:nth-child(4){
    transform:translateX(40px);
}

.services-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
}

/* INTRO / TEXT */

.intro-grid,
.two-columns,
.contact-grid{
    display:grid;
    grid-template-columns:0.9fr 1.1fr;
    gap:70px;
}

.section-text{
    display:grid;
    gap:22px;
    font-size:18px;
}

/* QUICK SERVICES */

.highlight-section{
    background:var(--soft);
}

.center{
    text-align:center;
}

.center h2{
    max-width:820px;
    margin:auto;
}

.quick-services{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
    margin-top:60px;
    text-align:left;
}

.quick-card,
.service-card,
.value-card{
    border:1px solid var(--border);
    border-radius:30px;
    padding:32px;
    background:white;
    transition:0.25s;
}

.quick-card:hover,
.service-card:hover,
.value-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 60px rgba(0,0,0,0.07);
}

.quick-card span,
.service-card span{
    display:block;
    margin-bottom:50px;
    color:var(--gray);
    font-weight:900;
}

.quick-card p,
.service-card p,
.value-card p{
    margin-top:16px;
}

/* VALUES */

.values-section{
    background:var(--soft);
}

.values-grid,
.values-row{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
    margin-top:60px;
}

.values-row .value-card{
    background:white;
    min-height:250px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.values-row .value-card span{
    display:block;
    margin-bottom:30px;
    color:var(--gray);
    font-size:12px;
    font-weight:900;
    letter-spacing:0.12em;
}

.values-row .value-card h3{
    font-size:28px;
}

.values-row .value-card p{
    margin-top:16px;
}

/* PROJECTS PAGE */

.projects-header{
    padding:130px 0 34px;
    background:#f5f5f5;
    border-bottom:1px solid var(--border);
}

.projects-header h1{
    max-width:720px;
    font-size:clamp(34px, 4.5vw, 52px);
    line-height:1;
    letter-spacing:-0.055em;
}

.projects-header p{
    max-width:620px;
    margin-top:16px;
    font-size:17px;
}

.projects-showcase-section{
    padding:42px 0 110px;
    background:#f5f5f5;
}

.projects-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}

.project-showcase-card{
    background:white;
    border:1px solid var(--border);
    border-radius:28px;
    overflow:hidden;
    transition:0.28s;
    box-shadow:0 14px 40px rgba(0,0,0,0.04);
}

.project-showcase-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 60px rgba(0,0,0,0.08);
}

.project-image{
    height:220px;
    background:#f1f1f1;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px;
    overflow:hidden;
}

.project-image img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
}

.project-content{
    padding:24px;
    display:flex;
    flex-direction:column;
    gap:14px;
}

.project-category{
    display:block;
    font-size:11px;
    font-weight:900;
    letter-spacing:0.12em;
    text-transform:uppercase;
    color:var(--gray);
}

.project-content h2{
    font-size:28px;
    line-height:1;
    letter-spacing:-0.05em;
}

.project-content p{
    font-size:15px;
    margin-top:4px;
}

.project-link{
    margin-top:6px;
    font-size:14px;
    font-weight:800;
}

/* CONTACT */

.contact-cards-section{
    padding:50px 0 110px;
    background:#f5f5f5;
}

.contact-cards-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}

.contact-card{
    min-height:440px;
    background:white;
    border:1px solid var(--border);
    border-radius:28px;
    padding:34px;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    box-shadow:0 14px 40px rgba(0,0,0,0.04);
}

.contact-icon{
    width:56px;
    height:56px;
    border-radius:18px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    margin-bottom:20px;
}

.whatsapp-icon{
    background:rgba(37,211,102,0.12);
    color:#25D366;
}

.instagram-icon{
    background:rgba(225,48,108,0.12);
    color:#E1306C;
}

.mail-icon{
    background:rgba(255,87,51,0.12);
    color:#ff5733;
}

.contact-card h2{
    font-size:30px;
    letter-spacing:-0.05em;
}

.contact-card p{
    margin-top:14px;
    max-width:300px;
    font-size:15px;
}

.contact-btn,
.contact-disabled,
.contact-card-form button{
    width:100%;
    min-height:50px;
    margin-top:30px;
    border-radius:999px;
    border:0;
    background:var(--black);
    color:white;
    font-weight:900;
    display:flex;
    align-items:center;
    justify-content:center;
}

.contact-disabled{
    background:#f1f1f1;
    color:var(--gray);
}

.contact-card-form{
    width:100%;
    margin-top:24px;
    display:grid;
    gap:10px;
}

.contact-card-form input,
.contact-card-form textarea{
    width:100%;
    border:1px solid var(--border);
    border-radius:14px;
    padding:14px 16px;
    font-family:inherit;
    font-size:15px;
}

.contact-card-form textarea{
    min-height:96px;
    resize:vertical;
}

.contact-card-form button{
    cursor:pointer;
    margin-top:6px;
}

/* FOOTER */

.footer{
    background:var(--black);
    color:white;
    padding:58px 0 26px;
    margin-top:80px;
}

.footer-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:60px;
}

.footer-column h3{
    display:flex;
    align-items:center;
    gap:10px;
    margin-bottom:24px;
    font-size:24px;
    font-weight:900;
    color:white;
}

.footer-column a,
.footer-column span{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:16px;
    color:rgba(255,255,255,0.72);
    font-size:16px;
    transition:0.25s;
}

.footer-column a:hover{
    transform:translateX(4px);
    color:white;
}

.footer-column p{
    max-width:340px;
    color:rgba(255,255,255,0.68);
    line-height:1.7;
}

.footer-column i{
    width:30px;
    color:white;
}

.footer-bottom{
    margin-top:42px;
    padding-top:22px;
    border-top:1px solid rgba(255,255,255,0.12);
}

.footer-bottom p{
    color:rgba(255,255,255,0.48);
    font-size:14px;
}

.footer{
    position:relative;
    overflow:hidden;
}

.footer::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:1px;
    background:rgba(255,255,255,0.08);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform 1.2s ease;
}

.footer.visible::before{
    transform:scaleX(1);
}

@media(max-width:900px){
    .footer-grid{
        grid-template-columns:1fr;
        gap:40px;
    }
}
/* RESPONSIVE */

@media(max-width:900px){

    .hero,
    .page-hero{
        padding-top:120px;
    }

    .hero{
        min-height:auto;
        padding-bottom:90px;
    }

    .hero-content,
    .intro-grid,
    .two-columns,
    .contact-grid,
    .page-hero-grid,
    .about-visual-grid,
    .mission-vision-grid{
        grid-template-columns:1fr;
    }

    .quick-services,
    .services-grid,
    .values-grid,
    .projects-grid,
    .values-row{
        grid-template-columns:1fr 1fr;
    }

    .nav-links{
        position:absolute;
        top:72px;
        left:0;
        width:100%;
        background:white;
        border-bottom:1px solid var(--border);
        padding:24px;
        display:none;
        flex-direction:column;
        align-items:flex-start;
        gap:10px;
    }

    .nav-links.active{
        display:flex;
    }

    .nav-links a{
        width:100%;
        justify-content:flex-start;
    }

    .menu-btn{
        display:block;
    }

    .services-visual div:nth-child(2),
    .services-visual div:nth-child(4){
        transform:none;
    }

    .window-card{
        max-width:100%;
    }

    .scroll-preview{
        margin-top:-45px;
    }

    .scroll-preview-grid{
        grid-template-columns:1fr;
    }

    .projects-header{
        padding-top:125px;
    }

    .project-image{
        height:200px;
    }

    .project-content h2{
        font-size:24px;
    }

    .about-image-card{
        min-height:420px;
    }

    .contact-cards-grid{
        grid-template-columns:1fr;
    }

    .contact-card{
        min-height:auto;
    }
}

@media(max-width:640px){

    .container{
        width:min(100% - 28px, 1180px);
    }

    .brand-logo{
        width:120px;
    }

    h1{
        font-size:48px;
    }

    .hero-text h1,
    .page-hero h1{
        font-size:48px;
    }

    .section{
        padding:80px 0;
    }

    .page-hero{
        padding:130px 0 70px;
    }

    .quick-services,
    .services-grid,
    .values-grid,
    .projects-grid,
    .values-row{
        grid-template-columns:1fr;
    }

    .about-card,
    .about-image-card,
    .mission-card{
        border-radius:26px;
    }

    .about-card,
    .mission-card{
        padding:30px;
    }

    .about-image-card{
        min-height:360px;
    }

    .mission-card{
        min-height:280px;
    }

    .mission-card p{
        font-size:20px;
    }

    .project-image{
        height:190px;
    }

    .project-content{
        padding:22px;
    }

    .footer-content{
        flex-direction:column;
    }
}

/* REVEAL */

/* REVEAL */

.reveal{
    opacity:0;
    transform:translateY(42px) scale(0.97);
    transition:
        opacity 0.75s ease,
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    will-change:opacity, transform;
}

.reveal.visible{
    opacity:1;
    transform:translateY(0) scale(1);
}

.delay-1{
    transition-delay:0.12s;
}

.delay-2{
    transition-delay:0.24s;
}

.delay-3{
    transition-delay:0.36s;
}


.project-showcase-card{
    position:relative;
    overflow:hidden;
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.project-showcase-card:hover{
    transform:
        translateY(-10px)
        scale(1.015);

    box-shadow:
        0 30px 80px rgba(0,0,0,0.10);

    border-color:#d9d9d9;
}

.project-image img{
    transition:
        transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        filter 0.4s ease;
}

.project-showcase-card:hover .project-image img{
    transform:scale(1.05);
}

.project-link{
    transition:
        transform 0.25s ease,
        opacity 0.25s ease;
}

.project-showcase-card:hover .project-link{
    transform:translateX(6px);
}



.contact-card{
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.contact-card:hover{
    transform:
        translateY(-10px)
        scale(1.015);

    box-shadow:
        0 30px 80px rgba(0,0,0,0.10);

    border-color:#d9d9d9;
}

.contact-icon{
    transition:
        transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
        rotate 0.35s ease;
}

.contact-card:hover .contact-icon{
    transform:scale(1.08);
}

.contact-btn,
.contact-card-form button{
    transition:
        transform 0.25s ease,
        opacity 0.25s ease,
        background 0.25s ease;
}

.contact-btn:hover,
.contact-card-form button:hover{
    transform:translateY(-2px);
}

.contact-card-form input,
.contact-card-form textarea{
    transition:
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.25s ease;
}

.contact-card-form input:focus,
.contact-card-form textarea:focus{
    outline:none;
    border-color:#d7d7d7;
    box-shadow:0 0 0 4px rgba(0,0,0,0.04);
    transform:translateY(-1px);
}

/* HOME SIMPLE */

.home-simple{
    min-height:100vh;
    padding:150px 0 80px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    background:
        radial-gradient(circle at 75% 20%, rgba(0,0,0,0.06), transparent 32%),
        #ffffff;
}

.home-simple-content{
    max-width:900px;
}

.home-simple h1{
    max-width:880px;
}

.home-simple p{
    max-width:620px;
    margin-top:26px;
    font-size:19px;
}

.home-services-strip{
    margin-top:80px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}

.home-services-strip a{
    background:#f7f7f7;
    border:1px solid var(--border);
    border-radius:22px;
    padding:22px 24px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:20px;
    font-weight:900;
    transition:0.28s;
}

.home-services-strip a:hover{
    background:var(--black);
    color:white;
    transform:translateY(-5px);
}

.home-services-strip span{
    color:var(--gray);
    font-size:13px;
}

.home-services-strip a:hover span{
    color:rgba(255,255,255,0.65);
}

.home-about{
    background:#f5f5f5;
}

@media(max-width:900px){
    .home-services-strip{
        grid-template-columns:1fr;
        margin-top:50px;
    }

    .home-simple{
        padding-top:130px;
    }
}


/* SERVICES SIMPLE */

.services-hero-simple{
    padding:150px 0 70px;
    background:#050505;
    color:white;
}

.services-hero-simple .eyebrow,
.services-hero-simple p{
    color:rgba(255,255,255,0.68);
}

.services-hero-content{
    max-width:820px;
}

.services-hero-content h1{
    max-width:760px;
}

.services-hero-content p{
    max-width:620px;
    margin-top:24px;
    font-size:18px;
}

.services-list-section{
    padding:60px 0 90px;
    background:#f5f5f5;
}

.services-list{
    display:grid;
    gap:16px;
}

.service-line{
    background:white;
    border:1px solid var(--border);
    border-radius:28px;
    padding:28px;
    display:grid;
    grid-template-columns:80px 1fr;
    gap:24px;
    align-items:start;
    transition:0.3s;
}

.service-line:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 60px rgba(0,0,0,0.07);
}

.service-line span{
    color:var(--gray);
    font-weight:900;
    font-size:13px;
    letter-spacing:0.12em;
}

.service-line h2{
    font-size:36px;
}

.service-line p{
    max-width:700px;
    margin-top:12px;
    font-size:17px;
}

.services-cta-section{
    padding:0 0 110px;
    background:#f5f5f5;
}

.services-cta{
    background:var(--black);
    color:white;
    border-radius:34px;
    padding:46px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:24px;
}

.services-cta h2{
    max-width:650px;
    font-size:clamp(32px, 4vw, 52px);
}

.services-cta .btn-primary{
    background:white;
    color:var(--black);
    white-space:nowrap;
}

@media(max-width:900px){
    .service-line{
        grid-template-columns:1fr;
    }

    .services-cta{
        flex-direction:column;
        align-items:flex-start;
    }
}

.footer-column img{
    width:50px;
    height:50px;

    object-fit:contain;

    filter:
        drop-shadow(0 4px 10px rgba(0,0,0,.35));
}