@media (max-width: 480px) {
    /* hero */
    .hero-section{
        gap: 3rem;
    }
    .hero-intro{
        gap: 3rem;
    }
    .hero-content{
        /* align-items: start; */
        flex-direction: column-reverse;
        gap: 2rem;
    }
    .status{
        font-size: .75rem;
        padding: .4rem 1rem;
    }
    .intro-text{
        gap: 1rem;
    }
    .welcome-text{
        font-size: 1.25rem;
    }
    .name-title{
        line-height: 1.3;
    }
    .name-title h1{
        font-size: 2rem;
    }
    .name-title h2{
        font-size: 1.4rem;
    }
    .description{
        gap: 2rem;
    }
    .description p{
        font-size: .85rem;
    }
    .logo{
        width: 100%;
    }
    .logo img{
        width: 40%;
        border-width: 6px;
    }
    .buttons{
        width: 100%;
        flex-direction: column;
        gap: .3rem;
    }
    .btn{
        justify-content: center;
        font-size: 1.2rem;
        padding: .75rem;
    }
    .spinner{
        --width: 7rem;
        --height: 3rem;
    }
    /* services */
    .services-section{
        gap: 1.875rem;
    }
    .services-header h3{
        font-size: 1.15rem;
    }
    .services-header h2{
        font-size: 1.75rem;
    }
    .services-cards{
        flex-direction: column;
        gap: 0.625rem;
    }
    .card{
        max-width: none;
    }
    /* faq */
    .faq-section{
        flex-direction: column-reverse;
        gap: 1.875rem;
    }
    .faq-right{
        align-items: center;
    }
    .faq-right h2{
        font-size: 1.75rem;
        display: flex;
        flex-direction: column;
        gap: .3rem;
    }
    .faq-header{
        line-height: 1.6;
    }
    .faq-right h3{
        font-size: 1.15rem;
        text-align: center;
        color: var(--color-text-secondary);
        font-weight: var(--weight-medium);
    }
    .faq-right svg{
        display: none;
    }
    .contact-right .options{
        position: absolute;
        width: 100%;
        box-sizing: border-box;
    }
    /* contact */
    .contact-section{
        flex-direction: column;
        gap: 1.875rem;
    }
    .contact-left{
        max-width: 100%;
    }
    .contact-left h2{
        font-size: 1.75rem;
        line-height: 2.5rem;
    }
    .contact-desc{
        font-size: 1rem;
    }
    .form-actions{
        flex-direction: column;
        gap: .3rem;
    }
    .form-btn{
        padding: 1rem;
        border-radius: 30px;
        font-size: 1rem;
    }
    :lang(cs-CZ) .status-label::before{ content: "K dispozici"; }
    :lang(en) .status-label::before{ content: "Available"; }
}
/* phone-small tablet */
@media (min-width: 481px) and (max-width: 768px) {
    /* hero */
    .hero-section{
        gap: 3rem;
    }
    .hero-intro{
        gap: 3rem;
    }
    .hero-content{
        flex-direction: column-reverse;
        gap: 2rem;
        width: 100%;
    }
    :lang(cs-CZ) .status-label::before{ content: "K dispozici"; }
    :lang(en) .status-label::before{ content: "Available"; }
    .intro-text{
        width: 100%;
    }
    .description{
        gap: 2rem;
    }
    .description p{
        max-width: 100%;
    }
    .logo{
        width: 100%;
    }
    .logo img{
        width: 30%;
        border-width: 10px;
    }
    .spinner{
        --width: 8rem;
        --height: 3.5rem;
    }
    /* services */
    .services-cards{
        flex-direction: column;
        gap: 1.25rem;
    }
    .card{
        max-width: 100%;
        min-height: fit-content;
        padding: 2rem;
    }
    .card-content{
        flex-direction: row;
        gap: 2.5rem;
    }
    .card-content i{
        height: fit-content;
    }
    .service-btn{
        text-align: center;
    }
    /* faq */
    .faq-section{
        flex-direction: column-reverse;
        gap: 1.875rem;
    }
    .faq-header{
        width: 100%;
        text-align: center;
    }
    .faq-header h3{
        text-align: center;
    }
    .faq-right svg{
        display: none;
    }
    .contact-right .options{
        position: absolute;
        width: 100%;
        box-sizing: border-box;
    }
    /* contact */
    .contact-section{
        flex-direction: column;
        gap: 1.875rem;
    }
    .contact-left{
        max-width: 100%;
    }
}
@media (min-width: 769px) and (max-width: 1024px) {
    /* hero */
    .hero-section{
        gap: 3rem;
    }
    .hero-intro{
        gap: 3rem;
    }
    .hero-content{
        flex-direction: column-reverse;
        gap: 2rem;
        width: 100%;
    }
    .intro-text{
        width: 100%;
    }
    .description{
        gap: 2rem;
    }
    .description p{
        max-width: 100%;
    }
    .logo{
        width: 100%;
    }
    .logo img{
        width: 35%;
        border-width: 10px;
    }
    .spinner{
        --width: 7.5rem;
        --height: 3.5rem;
    }
    /* services */
    .services-section{
        gap: 1.875rem;
    }
    .services-header{
        gap: 0;
        line-height: 1.5;
    }
    .services-cards{
        flex-direction: column;
        gap: 1.25rem;
    }
    .card{
        max-width: 100%;
        min-height: fit-content;
        padding: 2rem;
    }
    .card-content{
        flex-direction: row;
        gap: 2.5rem;
    }
    .card-content i{
        height: fit-content;
    }
    .service-btn{
        text-align: center;
    }
    /* faq */
    .faq-section{
        flex-direction: column-reverse;
        gap: 1.875rem;
    }
    .faq-header{
        width: 100%;
        text-align: center;
        line-height: 1.5;
    }
    .faq-header h3{
        text-align: center;
    }
    .faq-right svg{
        display: none;
    }
    /* contact */
    .contact-section{
        flex-direction: column;
        gap: 1.875rem;
    }
    .contact-left{
        max-width: 100%;
    }
}