.contact-page{
    min-height:100vh;
    padding:70px 24px 220px;

    background-color:#050505;

    background-image:
        linear-gradient(180deg, rgba(0,0,0,.20), rgba(0,0,0,.32)),
        var(--shop-contact-bg-image);


    background-position:center top;
    background-repeat:no-repeat;
    background-attachment:fixed;
}

.contact-container{
    width:820px;
    margin-left:305px;

    min-height:760px;

    display:flex;
    flex-direction:column;
    justify-content:flex-start;

    padding-top:90px;
}

.contact-header{
    text-align:left;
    width:700px;

    margin:0 0 34px 0;
}

.contact-header h1{
    font-size:54px;
    line-height:1;
    font-weight:800;
    color:#fff;
    margin-bottom:22px;
    letter-spacing:-1px;
}

.contact-header p{
    max-width:720px;
    margin:0;

    color:rgba(255,255,255,.86);

    line-height:1.65;
    font-size:16px;
}

.contact-type-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:18px;

    width:760px;
    margin:0;
}

.contact-type-card{
    position:relative;

    background:rgba(12,12,12,.58);

    border:1px solid rgba(255,255,255,.12);
    border-radius:22px;

    padding:12px 24px;

    min-height:108px;

    text-align:left;

    backdrop-filter:blur(10px);

    transition:.25s ease;

    cursor:pointer;

    overflow:hidden;
}

.contact-type-card:nth-child(3){
    grid-column:1 / 3;
    min-height:98px;
}

.contact-type-card::before{
    content:'';

    position:absolute;
    inset:0;

    background:
        radial-gradient(circle at top right,
        rgba(255,43,61,.13),
        transparent 45%);

    opacity:0;

    transition:.25s ease;
}

.contact-type-card:hover{
    transform:translateY(-2px);

    border-color:rgba(255,255,255,.22);

    background:rgba(24,24,24,.78);
}

.contact-type-card:hover::before{
    opacity:1;
}

.contact-type-card.active{
    border-color:#ff2b3d;

    box-shadow:
        0 0 28px rgba(255,43,61,.18),
        inset 0 0 0 1px rgba(255,43,61,.14);
}

.contact-type-card.active::before{
    opacity:1;
}

.contact-type-icon{
    display:block;

    font-size:28px;

    margin-bottom:12px;
}

.contact-type-card h3{
    color:#fff;

    font-size:21px;

    font-weight:700;

    margin-bottom:8px;
}

.contact-type-card p{
    color:rgba(255,255,255,.76);

    line-height:1.5;

    font-size:14px;
}

.contact-form-panel{
    display:none;

    background:rgba(10,10,10,.52);

    border:1px solid rgba(255,255,255,.10);

    border-radius:24px;

    padding:20px 22px;

    backdrop-filter:blur(10px);
}

.contact-form-panel.active{
    display:block;

    animation:contactFade .25s ease;
}

/* Allgemeine Anfrage */
.contact-form-general{
    width:700px;

    margin-top:65px;
    margin-left:0px;
}

/* Bestellung */
.contact-form-order{
    width:700px;

    margin-top:42px;
    margin-left:0px;
}

/* LEGO anbieten */
.contact-form-usedlego{
    width:700px;

    margin-top:22px;
    margin-left:0px;

    padding:18px 22px;
}

@keyframes contactFade{
    from{
        opacity:0;
        transform:translateY(10px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }
}

.contact-form-grid{
    display:grid;

    grid-template-columns:repeat(2,minmax(0,1fr));

    gap:14px;
}

.contact-field{
    display:flex;
    flex-direction:column;
}

.contact-field-full{
    grid-column:1 / 3;
}

.contact-field label{
    color:#fff;

    font-size:14px;

    font-weight:600;

    margin-bottom:8px;
}

.contact-field input,
.contact-field textarea{
    width:100%;

    box-sizing:border-box;

    background:rgba(255,255,255,.06);

    border:1px solid rgba(255,255,255,.10);

    border-radius:14px;

    padding:10px 14px;

    color:#fff;

    font-size:14px;

    outline:none;

    transition:.2s ease;
}

.contact-field textarea{
    resize:vertical;

    min-height:96px;
}

.contact-form-usedlego .contact-field textarea{
    min-height:72px;
}

.contact-field input[type="file"]{
    padding:9px 12px;
}

.contact-field input:focus,
.contact-field textarea:focus{
    border-color:rgba(255,43,61,.55);

    box-shadow:0 0 18px rgba(255,43,61,.16);

    background:rgba(255,255,255,.08);
}

.contact-submit{
    margin-top:14px;

    border:none;

    background:linear-gradient(135deg,#ff2b3d,#ff4455);

    color:#fff;

    font-size:14px;

    font-weight:700;

    border-radius:14px;

    padding:11px 24px;

    cursor:pointer;

    transition:.25s ease;
}

.contact-submit:hover{
    transform:translateY(-2px);

    box-shadow:0 0 24px rgba(255,43,61,.30);
}

@media(max-width:1100px){

    .contact-page{
        background-size:cover;
        padding:150px 20px 120px;
    }

    .contact-container{
        width:100%;
        margin-left:0;
        padding-top:40px;
    }

    .contact-header{
        width:100%;
        text-align:center;
    }

    .contact-header h1{
        font-size:48px;
    }

    .contact-header p{
        margin:0 auto;
    }

    .contact-type-grid{
        width:100%;
        grid-template-columns:1fr;
    }

    .contact-type-card:nth-child(3){
        grid-column:auto;
    }
}

@media(max-width:700px){

    .contact-header h1{
        font-size:38px;
    }

    .contact-header p{
        font-size:15px;
    }

    .contact-type-card{
        padding:18px 20px;
    }

    .contact-type-card h3{
        font-size:18px;
    }
}

.contact-success-overlay{
    position:fixed;

    inset:0;

    background:rgba(0,0,0,.52);

    backdrop-filter:blur(3px);

    z-index:9999;

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

    animation:contactSuccessFadeIn .25s ease;
}

.contact-success-modal{
    width:min(520px, calc(100% - 40px));

    background:
        linear-gradient(
            180deg,
            rgba(18,18,18,.96),
            rgba(10,10,10,.96)
        );

    border:1px solid rgba(90,255,140,.30);

    border-radius:24px;

    padding:30px 34px;

    text-align:center;

    color:#e8fff0;

    font-size:20px;

    font-weight:700;

    line-height:1.5;

    box-shadow:
        0 0 50px rgba(80,255,120,.16),
        0 0 120px rgba(0,0,0,.45);

    animation:contactSuccessPop .32s ease;
}

@keyframes contactSuccessFadeIn{
    from{
        opacity:0;
    }

    to{
        opacity:1;
    }
}

@keyframes contactSuccessPop{
    from{
        opacity:0;
        transform:translateY(14px) scale(.96);
    }

    to{
        opacity:1;
        transform:translateY(0) scale(1);
    }
}

.contact-upload-overlay{
    position:fixed;

    inset:0;

    background:rgba(0,0,0,.58);

    backdrop-filter:blur(4px);

    z-index:10000;

    display:none;
    align-items:center;
    justify-content:center;
}

.contact-upload-overlay.active{
    display:flex;
}

.contact-upload-box{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
}

.contact-upload-circle{
    width:150px;
    height:150px;

    border-radius:50%;

    position:relative;

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

    background:transparent;

    box-shadow:
        0 0 34px rgba(255,43,61,.30),
        0 0 80px rgba(255,150,0,.16);
}

.contact-upload-circle::before{
    content:'';

    position:absolute;

    inset:0;

    border-radius:50%;

    border:8px solid rgba(255,255,255,.10);
    border-top-color:#ffb11f;
    border-right-color:#ff7a18;
    border-bottom-color:#ff2b3d;
    border-left-color:#ff2b3d;

    animation:contactUploadSpin 1s linear infinite;
}

.contact-upload-circle span{
    color:#fff;

    font-size:34px;

    font-weight:800;

    letter-spacing:-1px;
}

.contact-upload-text{
    margin-top:24px;

    color:#fff;

    font-size:18px;

    font-weight:600;

    text-align:center;
}

@keyframes contactUploadSpin{
    from{
        transform:rotate(0deg);
    }

    to{
        transform:rotate(360deg);
    }
}