/* Extra Small Device */
@media only screen and (max-width: 430px) {
    .mobile-menu .offcanvas-start {
        width: 100%;
    }
}

/* Small Device :550px. */
@media only screen and (min-width: 576px) {
    .container {
        width: 540px;
        padding: 0 12px;
    }

    .logo--header {
        max-width: 328px;
    }
    .service--section,
    .reliable--section,
    .project--section {
        padding: 64px 0;
    }
    .card__thumb {
        height: 260px;
    }
    .card__title {
        font-size: 24px;
    }
    .contact__wrapper {
        padding: 64px 24px 24px;
    }
}

/* Medium Device. */
@media only screen and (min-width: 768px) {
    .container {
        width: 720px;
    }

    .fs-1 {
        font-size: 44px !important;
    }
    .fs-2 {
        font-size: 40px !important;
    }
    .fs-3 {
        font-size: 36px !important;
    }

    .card__content {
        padding: 24px;
    }
    .project__slide__btn {
        width: 48px;
        height: 48px;
    }
    .form__input {
        padding: 20px 0;
    }
    .footer__content {
        padding: 128px 0 80px;
    }
}

/* LG Device. */
@media only screen and (min-width: 992px) {
    .container {
        width: 960px;
    }

    body {
        font-size: 17px;
    }
    .btn__content {
        padding: 16px 36px;
        font-size: 18px;
    }
    .btn--trans .btn__content {
        font-size: 17px !important;
    }
    .btn__icon {
        width: 21px;
        height: 21px;
    }
    .section__head__para {
        font-size: 18px;
    }

    .hero--section {
        background: url('../imgs/icons-objs/dot-patteren-obj.png') repeat,
            var(--primary);
    }
    .hero--section::after {
        display: none;
    }
    .hero__wrapper {
        padding: 108px 0 48px;
    }
    .hero__button {
        margin-bottom: 60px;
    }
    .statistics__title {
        font-size: 28px;
    }
    .statistics {
        gap: 52px;
    }
    .statistics__item::after {
        left: auto;
        bottom: auto;
        right: -26px;
        top: 50%;
        transform: translateY(-50%);
        width: 1px;
        height: 83%;
    }
    .service--section,
    .reliable__content,
    .project--section {
        padding: 80px 0;
    }
    .reliable--section {
        padding: 0;
    }
    .reliable__thumb__item {
        height: inherit;
    }
    .reliable__thumb__item--two {
        margin-top: 80px;
    }
    .reliable__content {
        max-width: 584px;
        padding-right: 24px;
    }
    .project__slide__btn {
        width: auto;
        height: auto;
        border: none;
        background-color: transparent;
        backdrop-filter: unset;
        color: var(--secondary);
    }
    .project__slide__btn:hover {
        color: var(--primary);
    }
    .project__slide__btn svg {
        height: 100%;
    }
    .project__slider .swiper-button-prev {
        left: -48px;
    }
    .project__slider .swiper-button-next {
        right: -48px;
    }
    .contact__wrapper {
        padding: 0;
    }
    .contact__content {
        padding: 64px;
        padding-right: 0;
    }
    .contact__thumb {
        height: 100%;
    }
    .footer__wrapper__row.g-lg-5 {
        --bs-gutter-x: 70px;
        --bs-gutter-y: 70px;
    }
    .logo--footer {
        max-width: 252px;
    }
    .footer__nav__wrap {
        gap: 14px;
    }
}

/* Large Device. */
@media only screen and (min-width: 1200px) {
    .container {
        width: 1140px;
    }

    .fs-1 {
        font-size: 56px !important;
    }
    .fs-2 {
        font-size: 48px !important;
    }
    .fs-3 {
        font-size: 40px !important;
    }
    .btn__content {
        padding: 16px 40px;
        font-size: 20px;
        border-width: 2px;
    }
    .btn__icon {
        width: 24px;
        height: 24px;
    }
    .pretitle-badge {
        font-size: 16px;
        padding: 9px 30px;
    }
    .pretitle-badge .ellipse {
        width: 10px;
        height: 10px;
    }

    .logo--header {
        max-width: 168px;
    }
    .nav--header {
        gap: 80px;
    }
    .nav__wrap {
        gap: 40px;
    }
    .btn--header .btn__content {
        padding: 11px 27px !important;
        font-size: 17px !important;
    }
    .hero__button {
        margin-bottom: 104px;
    }
    .statistics__title {
        font-size: 32px;
    }
    .statistics {
        gap: 74px;
    }
    .statistics__item::after {
        right: -37px;
    }
    .service--section,
    .reliable__content,
    .project--section {
        padding: 114px 0;
    }
    .card--service .card__content {
        max-width: 324px;
        padding: 32px 22px 24px;
    }
    .card__title {
        font-size: 27px;
    }
    .reliable__inner__row.g-lg-5 {
        --bs-gutter-x: 72px;
    }
    .reliable__thumb__item--two {
        margin-top: 114px;
    }
    .contact__content {
        padding: 80px;
        padding-right: 0;
    }
    .form__input {
        padding: 24px 0;
    }
    .form__input--textarea {
        height: 104px;
    }
    .footer__content {
        padding: 128px 0 108px;
    }
}

/* XL Device. */
@media only screen and (min-width: 1400px) {
    .container {
        max-width: 1256px;
        width: 100%;
    }

    .fs-1 {
        font-size: 70px !important;
    }
    .fs-2 {
        font-size: 60px !important;
    }
    .fs-3 {
        font-size: 50px !important;
    }
    .btn--md .btn__content {
        padding: 17px 40px;
    }
    .btn--lg .btn__content {
        padding: 20px 40px;
    }
    .section__head__para {
        font-size: 20px;
    }

    .logo--header {
        max-width: 412px;
    }
    .nav--header {
        gap: 104px;
    }
    .nav__wrap {
        gap: 48px;
    }
    .nav__link {
        font-size: 18px;
    }
    .hero__wrapper {
        padding: 128px 0 48px;
    }
    .hero__para {
        font-size: 18px;
    }
    .hero__button {
        margin-bottom: 148px;
    }
    .statistics__title {
        font-size: 36px;
    }
    .hero__mask__thumb {
        right: -20px;
        bottom: -16px;
    }
    .mask-thumb__bg {
        width: calc(100% - 20px);
        height: calc(100% - 16px);
    }
    .statistics {
        gap: 96px;
    }
    .statistics__item::after {
        right: -48px;
    }
    .service--section {
        padding: 114px 0 152px;
    }
    .service__cards__row.g-sm-4 {
        --bs-gutter-x: 30px;
        --bs-gutter-y: 30px;
    }
    .reliable__inner__row.g-lg-5 {
        --bs-gutter-x: 96px;
    }
    .reliable__content {
        padding: 128px 0;
    }
    .reliable__thumb__item--two {
        margin-top: 148px;
    }
    .project--section {
        padding: 134px 0 144px;
    }
    .project__slider .swiper-button-prev {
        left: -64px;
    }
    .project__slider .swiper-button-next {
        right: -64px;
    }
    .contact__content {
        padding: 100px 78px;
        padding-right: 0;
    }
    .copyright-text {
        font-size: 20px;
    }
    .logo--footer {
        max-width: 300px;
    }
    .footer__nav__wrap {
        gap: 18px;
    }
    .copyright-text {
        font-size: 17px;
    }
}

/* XXL Device. */
@media only screen and (min-width: 1600px) {
    .logo--footer {
        max-width: 352px;
    }
    .project__slider .swiper-button-prev {
        left: -80px;
    }
    .project__slider .swiper-button-next {
        right: -80px;
    }
    .form__input {
        padding: 28px 0;
    }
}
