*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    font-family:'Poppins',sans-serif;
    background:#0a0a0a;
    color:#ffffff;
    line-height:1.7;
    overflow-x:hidden;
}

img{
    max-width:100%;
    display:block;
}

a{
    text-decoration:none;
    color:inherit;
    transition:.3s;
}

.container{
    width:min(1200px, 90%);
    margin:auto;
}

section{
    padding:100px 0;
}

h1,h2,h3{
    font-weight:600;
}

.pink{
    color:#ff0090;
    font-size:2.5rem;
}

.section-title{
    font-size:2.8rem;
    margin-bottom:30px;
    line-height:1.1;
}

/* ELINE */

.eline{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    position:relative;
    background:
    linear-gradient(rgba(0,0,0,.72), rgba(0,0,0,.82)),
    url('eline.jpg') center/cover;
}

.eline-content{
    max-width:850px;
}

.eline-content img{
    width:320px;
    margin:auto;
    margin-bottom:40px;
}

.eline h1{
    font-size:4rem;
    margin-bottom:20px;
    line-height:1.1;
}

.eline p{
    max-width:700px;
    margin:auto;
    color:#d0d0d0;
    font-size:1.1rem;
}

.btn{
    display:inline-block;
    margin-top:40px;
    padding:15px 34px;
    border:2px solid #ff0090;
    border-radius:60px;
    font-weight:500;
    transition:.3s;
}

.btn:hover{
    background:#ff0090;

}

/* ABOUT */

.about{
    background:#111;
}

.grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:70px;
    align-items:center;
}

.about img{
    width:100%;
    border-radius:24px;
}

.about p{
    color:#d0d0d0;
    margin-bottom:20px;
}

/* SERVICES */

.services{
    text-align:center;
}

.services-grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:24px;
    margin-top:60px;
}

.card{
    background:#151515;
    border:1px solid #222;
    border-radius:22px;
    padding:32px 24px;
    transition:.3s;
}

.card:hover{
    transform:translateY(-5px);
    border-color:#ff0090;
}

.card h3{
    margin-bottom:12px;
    font-size:1.05rem;
}

.card p{
    color:#bdbdbd;
    font-size:.92rem;
}

/* GALLERY */

.gallery{
    background:#111;
}

.gallery-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:24px;
    margin-top:50px;
}

.gallery-grid img{
    width:100%;
    height:420px;
    object-fit:cover;
    border-radius:24px;
}

/* CONTACT */

.contact{
    text-align:center;
}

.contact-box{
    margin-top:40px;
    background:#151515;
    padding:55px 30px;
    border-radius:24px;
    max-width:700px;
    margin-inline:auto;
}

.contact-box p{
    margin:10px 0;
    color:#d0d0d0;
}

.contact-box a:hover{
    color:#ff0090;
}

/* CONTACT FORM */

.contact-form{
    cursor:pointer;
}

.form-group{
    width:100%;
}

.contact-form input,
.contact-form textarea{
    width:100%;
    background:#101010;
    border:1px solid #222;
    border-radius:18px;
    padding:18px 20px;
    color:#fff;
    font-family:'Poppins',sans-serif;
    font-size:.95rem;
    transition:.3s;
}

.contact-form input:focus,
.contact-form textarea:focus{
    outline:none;
    border-color:#ff0090;
}

.contact-form textarea{
    min-height:160px;
    resize:vertical;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
    color:#888;
}

.contact-form .btn{
    appearance:none;
    -webkit-appearance:none;
    border:2px solid #ff0090;
    background:transparent;
    color:#fff;
    font-family:'Poppins',sans-serif;
    font-size:1rem;
    font-weight:500;
    line-height:1;
    padding:16px 38px;
    border-radius:60px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
}

.contact-form .btn:hover{
    background:#ff2aa3;
    border-color:#ff2aa3;
}

.hidden-field{
    display:none;
}

/* MOBILE */

@media(max-width:600px){

    .contact-form input,
    .contact-form textarea{
        padding:16px 18px;
        border-radius:16px;
    }

}

/* FOOTER */

footer{
    padding:30px 0;
    text-align:center;
    border-top:1px solid #1f1f1f;
    color:#777;
    font-size:.9rem;
}

/* TABLET */

@media(max-width:1000px){

    section{
        padding:80px 0;
    }

    .eline{
        min-height:auto;
        padding:80px 0;
    }

    .eline-content img{
        width:240px;
        margin-bottom:30px;
    }

    .eline h1{
        font-size:3rem;
        line-height:1.2;
    }

    .eline p{
        font-size:1rem;
        max-width:600px;
    }

    .grid{
        grid-template-columns:1fr;
        gap:50px;
    }

    .services-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .gallery-grid{
        grid-template-columns:1fr;
    }

    .gallery-grid img{
        height:360px;
    }

    .section-title{
        font-size:2.2rem;
    }

}

/* MOBILE */

@media(max-width:600px){

    body{
        line-height:1.5;
    }

    section{
        padding:65px 0;
    }

    .container{
        width:92%;
    }

    .eline{
        min-height:auto;
        padding:60px 0;
        background-position:center;
    }

    .eline-content img{
        width:180px;
        margin-bottom:25px;
    }

    .eline h1{
        font-size:2rem;
        line-height:1.2;
        margin-bottom:18px;
    }

    .eline p{
        font-size:.95rem;
    }

    .btn{
        width:100%;
        max-width:320px;
        padding:14px 20px;
        font-size:.95rem;
    }

    .section-title{
        font-size:1.8rem;
        margin-bottom:20px;
    }

    .grid{
        gap:35px;
    }

    .about img{
        border-radius:18px;
    }

    .services-grid{
        grid-template-columns:1fr;
        gap:18px;
        margin-top:35px;
    }

    .card{
        padding:25px 20px;
    }

    .card h3{
        font-size:1rem;
    }

    .card p{
        font-size:.9rem;
    }

    .gallery-grid{
        gap:18px;
    }

    .gallery-grid img{
        height:260px;
        border-radius:18px;
    }

    .contact-box{
        padding:35px 20px;
        border-radius:18px;
    }

    footer{
        font-size:.8rem;
        padding:20px 0;
    }

}