/* style.css */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{
    background:#050505;
    color:#ffffff;
    font-family:'Inter',sans-serif;
    overflow-x:hidden;
}

/* HERO */

.hero{
    position:relative;
    min-height:100vh;
    overflow:hidden;
}

.hero-bg{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:
    linear-gradient(to right,
    rgba(0,0,0,.88) 0%,
    rgba(0,0,0,.74) 35%,
    rgba(0,0,0,.38) 60%,
    rgba(0,0,0,.18) 100%);
}

.container{
    position:relative;
    z-index:2;
    width:100%;
    max-width:1700px;
    margin:0 auto;
    padding:0 32px;
}

/* NAVBAR */

.navbar{
    height:88px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

/* LOGO */

.logo-wrapper img{
    width:190px;
    display:block;
}

/* NAV CENTER */

.nav-center{
    display:flex;
    align-items:center;
    gap:52px;
}

.nav-center a{
    position:relative;
    text-decoration:none;
    color:#eaeaea;
    font-size:1rem;
    font-weight:600;
    transition:.25s ease;
    padding-bottom:8px;
}

.nav-center a:hover{
    color:#c76bff;

    text-shadow:
    0 0 10px rgba(199,107,255,.8),
    0 0 20px rgba(199,107,255,.45);
}

/* ACTIVE */

.nav-center a.active{
    color:#ffffff;
}

.nav-center a.active::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-2px;

    width:100%;
    height:2px;

    border-radius:10px;

    background:linear-gradient(
    90deg,
    #ff7dff,
    #b14dff,
    #7b2cff);

    box-shadow:
    0 0 8px rgba(177,77,255,.9),
    0 0 18px rgba(177,77,255,.6);

    animation:pulseLine 2s infinite ease-in-out;
}

@keyframes pulseLine{

    0%{
        opacity:.7;
        transform:scaleX(.95);
    }

    50%{
        opacity:1;
        transform:scaleX(1);
    }

    100%{
        opacity:.7;
        transform:scaleX(.95);
    }

}

/* DROPDOWN */

.dropdown{
    display:flex;
    align-items:center;
    gap:6px;
}

.dropdown-icon{
    width:16px;
    height:16px;
}

/* SOCIALS */

.nav-right{
    display:flex;
    align-items:center;
    gap:24px;
}

.social-icon{
    color:#ffffff;
    font-size:1.55rem;
    text-decoration:none;
    transition:.25s ease;
}

.social-icon:hover{
    color:#c76bff;

    text-shadow:
    0 0 10px rgba(199,107,255,.8),
    0 0 20px rgba(199,107,255,.45);

    transform:translateY(-2px);
}

/* HERO CONTENT */

.hero-content{
    display:flex;
    align-items:center;
    min-height:calc(100vh - 88px);
    padding-bottom:80px;
}

.hero-left{
    max-width:760px;
}

/* SMALL */

.hero-small{
    display:inline-block;
    margin-bottom:24px;

    color:#c76bff;

    font-size:1.05rem;
    letter-spacing:4px;
    font-weight:600;
}

/* TITLE */

.hero-left h1{
    font-family:'Bebas Neue',sans-serif;
    font-size:9rem;
    line-height:.9;
    letter-spacing:2px;
    margin-bottom:28px;
}

.hero-left h1 span{
    background:linear-gradient(
    180deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

    text-shadow:
    0 0 25px rgba(177,77,255,.25);
}

/* TEXT */

.hero-left p{
    color:#d7d7d7;
    font-size:1.35rem;
    line-height:1.8;
    max-width:720px;
    margin-bottom:42px;
}

/* BUTTONS */

.hero-buttons{
    display:flex;
    align-items:center;
    gap:18px;
    margin-bottom:58px;
}

.primary-btn,
.secondary-btn,
.process-btn{

    display:inline-flex;
    align-items:center;
    justify-content:center;

    height:64px;
    padding:0 38px;

    border:none;
    cursor:pointer;

    font-size:.96rem;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;

    transition:.3s ease;

    border-radius:2x;
}

/* PRIMARY */

.primary-btn{
    background:linear-gradient(
    135deg,
    #d95cff,
    #8c32ff);

    color:#ffffff;

    box-shadow:
    0 0 20px rgba(177,77,255,.25);
}

.primary-btn:hover{

    transform:translateY(-3px);

    box-shadow:
    0 0 22px rgba(177,77,255,.6),
    0 0 42px rgba(177,77,255,.25);

}

/* SECONDARY */

.secondary-btn{
    background:transparent;
    color:#ffffff;

    border:1px solid rgba(177,77,255,.5);
}

.secondary-btn:hover{
    background:rgba(177,77,255,.08);

    box-shadow:
    0 0 20px rgba(177,77,255,.25);

    transform:translateY(-3px);
}

/* =========================
   FEATURES
========================= */

.features{

    display:flex;
    align-items:center;
    flex-wrap:nowrap;

    gap:42px;

    margin-top:20px;

}

.feature{

    display:flex;
    align-items:center;
    gap:14px;

    min-width:max-content;

}

.feature span{

    color:#fff;

    font-size:1rem;
    font-weight:500;

}

/* ICONS */

.feature i{

    font-size:1.15rem;

    color:#d95cff;

    transition:.3s ease;

    text-shadow:
    0 0 12px rgba(217,92,255,.25);

}

/* HOVER */

.feature:hover i{

    color:#ff8dff;

    transform:translateY(-2px);

    text-shadow:
    0 0 18px rgba(217,92,255,.45);

}

/* GALLERY */

.gallery{
    padding:130px 32px;
    background:#050505;
}

.gallery-header{
    text-align:center;
    margin-bottom:70px;
}

.gallery-header span{
    color:#c76bff;
    letter-spacing:3px;
    font-weight:700;
}

.gallery-header h2{
    margin-top:18px;
    font-family:'Bebas Neue',sans-serif;
    font-size:5rem;
    line-height:.95;
}

.gallery-header h2 span{
    font-size:5rem;
}

.gallery-header p{
    margin:24px auto 0;
    max-width:760px;
    color:#bdbdbd;
    line-height:1.8;
    font-size:1.1rem;
}

/* GRID */

.gallery-grid{
    width:100%;
    max-width:1500px;
    margin:0 auto;

    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:26px;
}

.gallery-item{
    position:relative;
    overflow:hidden;
    border-radius:22px;
    min-height:420px;
    background:#111111;
}

.gallery-item img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;

    transition:.45s ease;
}

.gallery-item::after{
    content:"";
    position:absolute;
    inset:0;

    background:linear-gradient(
    to top,
    rgba(0,0,0,.45),
    transparent 60%);
}

.gallery-item:hover img{
    transform:scale(1.05);
}

/* =========================
   PROCESS SECTION
========================= */

.process-section{

    padding:140px 32px;
    background:#050505;

}

.process-container{

    max-width:1500px;
    margin:0 auto;

    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:120px;

}

/* LEFT */

.process-left{

    position:sticky;
    top:120px;
    height:fit-content;

}

.process-small{

    display:inline-block;

    margin-bottom:22px;

    color:#c76bff;

    letter-spacing:4px;
    font-size:.95rem;
    font-weight:700;

}

.process-left h2{

    font-family:'Bebas Neue',sans-serif;

    font-size:6rem;
    line-height:.92;

    margin-bottom:28px;

}

.process-left h2 span{

    background:linear-gradient(
    180deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

}

.process-left p{

    color:#bfbfbf;

    font-size:1.1rem;
    line-height:1.9;

    margin-bottom:42px;

}

/* BUTTON */

.process-btn{

    display:inline-flex;
    align-items:center;
    justify-content:center;

    height:64px;
    padding:0 38px;

    border-radius:2px;

    background:linear-gradient(
    135deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    color:#fff;
    text-decoration:none;

    font-size:.96rem;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;

    transition:.35s ease;

    box-shadow:
    0 0 20px rgba(199,107,255,.12);

}

.process-btn:hover{

    transform:translateY(-3px);

    box-shadow:
    0 0 45px rgba(199,107,255,.35);

}

/* RIGHT */

.process-right{

    position:relative;

    display:flex;
    flex-direction:column;
    gap:70px;

}

/* BASE LINE */

.process-line{

    position:absolute;

    left:30px;
    top:0;

    width:2px;

    /* WICHTIG */
    height:calc(100% - 120px);

    background:rgba(255,255,255,.06);

    overflow:hidden;

}

/* GLOW FILL */

.process-line-fill{

    position:absolute;

    top:0;
    left:0;

    width:100%;
    height:0%;

    background:linear-gradient(
    to bottom,
    #ff8dff,
    #d95cff,
    #8c32ff);

    box-shadow:
    0 0 20px rgba(199,107,255,.55),
    0 0 40px rgba(199,107,255,.25);

    transition:height .15s linear;

}

/* ITEM */

.process-item{

    position:relative;

    display:flex;
    gap:38px;

}

/* NUMBER */

.process-number{

    min-width:62px;
    height:62px;

    display:flex;
    align-items:center;
    justify-content:center;

    background:#090909;

    border:1px solid rgba(199,107,255,.55);

    color:#d66cff;

    font-size:1.8rem;
    font-weight:800;

    border-radius:2px;

    box-shadow:
    0 0 28px rgba(199,107,255,.12);

    z-index:2;

}

/* CONTENT */

.process-content h3{

    font-size:2rem;
    margin-bottom:14px;

    font-weight:800;

}

.process-content p{

    color:#c4c4c4;

    font-size:1.05rem;
    line-height:1.9;

    max-width:620px;

}

/* RESPONSIVE */

@media(max-width:1100px){

    .process-container{

        grid-template-columns:1fr;
        gap:80px;

    }

    .process-left{

        position:relative;
        top:0;

    }

}

@media(max-width:768px){

    .process-left h2{

        font-size:4.5rem;

    }

    .process-content h3{

        font-size:1.5rem;

    }

}

/* FOOTER */

.footer{
    background:#020202;
    border-top:1px solid rgba(255,255,255,.06);
}

.footer-top{
    padding:90px 32px;
    display:flex;
    justify-content:space-between;
    gap:80px;
    flex-wrap:wrap;
}

.footer-brand img{
    width:190px;
    margin-bottom:24px;
}

.footer-brand p{
    max-width:420px;
    color:#a8a8a8;
    line-height:1.8;
}

.footer-links{
    display:flex;
    gap:90px;
    flex-wrap:wrap;
}

.footer-column{
    display:flex;
    flex-direction:column;
    gap:16px;
}

.footer-column h4{
    color:#ffffff;
    margin-bottom:10px;
    font-size:1rem;
}

.footer-column a{
    text-decoration:none;
    color:#9f9f9f;
    transition:.25s ease;
}

.footer-column a:hover{
    color:#c76bff;
}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.05);
    padding:28px;
    text-align:center;
    color:#6e6e6e;
    font-size:.92rem;
}

/* RESPONSIVE */

@media(max-width:1400px){

    .features{
        flex-wrap:wrap;
    }

}

@media(max-width:1200px){

    .hero-left h1{
        font-size:6.8rem;
    }

}

@media(max-width:980px){

    .nav-center{
        display:none;
    }

    .hero-left h1{
        font-size:5.5rem;
    }

    .gallery-grid{
        grid-template-columns:1fr;
    }

    .features{
        flex-wrap:wrap;
    }

}

@media(max-width:680px){

    .hero-left h1{
        font-size:4.2rem;
    }

    .hero-left p{
        font-size:1.05rem;
    }

    .hero-buttons{
        flex-direction:column;
        align-items:flex-start;
    }

    .primary-btn,
    .secondary-btn{
        width:100%;
    }

}

/* ABOUT PAGE */

.about-hero{
    position:relative;
    min-height:100vh;
    overflow:hidden;
}

.about-bg{
    position:absolute;
    inset:0;

    width:100%;
    height:100%;

    object-fit:cover;
    object-position:center;

    opacity:.72;

    filter:
    brightness(.82)
    contrast(1.08)
    saturate(1.08);
}

.about-overlay{
    position:absolute;
    inset:0;

    background:
    linear-gradient(
    to right,
    rgba(0,0,0,.92) 0%,
    rgba(0,0,0,.82) 26%,
    rgba(0,0,0,.58) 52%,
    rgba(0,0,0,.48) 100%);
}

.about-hero-content{
    position:relative;
    z-index:2;

    padding-top:180px;
    padding-bottom:180px;

    max-width:760px;
}

.about-small{
    display:inline-block;
    margin-bottom:24px;

    color:#c76bff;

    font-size:1rem;
    letter-spacing:4px;
    font-weight:600;
}

.about-hero-content h1{
    font-family:'Bebas Neue',sans-serif;
    font-size:8rem;
    line-height:.9;
    margin-bottom:28px;
}

.about-hero-content h1 span{

    background:linear-gradient(
    180deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

    text-shadow:
    0 0 24px rgba(199,107,255,.25);
}

.about-hero-content p{
    font-size:1.3rem;
    line-height:1.9;
    color:#e4e4e4;

    max-width:720px;

    text-shadow:
    0 0 14px rgba(0,0,0,.7);
}

/* ABOUT SECTION */

.about-section{
    padding:140px 32px;
    background:#050505;
}

.about-grid{
    max-width:1500px;
    margin:0 auto;

    display:grid;
    grid-template-columns:1fr 1fr;
    gap:90px;
    align-items:center;
}

.about-image{
    overflow:hidden;
    border-radius:24px;
}

.about-image img{
    width:100%;
    display:block;
}

.about-text span{
    color:#c76bff;
    letter-spacing:3px;
    font-weight:700;
}

.about-text h2{
    margin-top:22px;
    margin-bottom:28px;

    font-family:'Bebas Neue',sans-serif;
    font-size:5rem;
    line-height:.95;
}

.about-text h2 span{

    background:linear-gradient(
    180deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

}

.about-text p{
    color:#c9c9c9;
    line-height:1.9;
    font-size:1.08rem;
    margin-bottom:24px;
}

/* STATS */

.about-stats{
    display:flex;
    gap:26px;
    margin-top:42px;
    flex-wrap:wrap;
}

.about-stat{
    flex:1;
    min-width:180px;

    padding:34px;

    border:1px solid rgba(255,255,255,.06);

    background:#0a0a0a;

    border-radius:22px;
}

.about-stat h3{
    font-size:3rem;
    margin-bottom:10px;

    color:#c76bff;
}

.about-stat span{
    color:#cfcfcf;
    letter-spacing:0;
    font-weight:500;
}

/* MOBILE SERVICE */

.mobile-service{
    padding:140px 32px;

    background:
    linear-gradient(
    rgba(0,0,0,.82),
    rgba(0,0,0,.82)),
    url("../assets/mobile-service.jpg");

    background-size:cover;
    background-position:center;

    text-align:center;
}

.mobile-service-content{
    max-width:850px;
    margin:0 auto;
}

.mobile-service-content span{
    color:#c76bff;
    letter-spacing:3px;
    font-weight:700;
}

.mobile-service-content h2{
    margin-top:20px;
    margin-bottom:28px;

    font-family:'Bebas Neue',sans-serif;
    font-size:5.5rem;
    line-height:.92;
}

.mobile-service-content h2 span{

    background:linear-gradient(
    180deg,
    #ff8dff 0%,
    #d95cff 45%,
    #8c32ff 100%);

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

}

.mobile-service-content p{
    color:#d0d0d0;
    font-size:1.1rem;
    line-height:1.9;
    margin-bottom:42px;
}

/* RESPONSIVE */

@media(max-width:1100px){

    .about-grid{
        grid-template-columns:1fr;
    }

}

@media(max-width:768px){

    .about-hero-content h1{
        font-size:5rem;
    }

    .about-text h2{
        font-size:4rem;
    }

    .mobile-service-content h2{
        font-size:4.2rem;
    }

}