/* =========================================================
   MOBILE OPTIMIZATION
   ========================================================= */

html {
    max-width: 100%;
    overflow-x: hidden;
}

body {
    max-width: 100%;
    overflow-x: hidden;
}

img,
video,
iframe {
    max-width: 100%;
    height: auto;
}

* {
    box-sizing: border-box;
}

/* Планшеты */
@media (max-width: 1024px) {
    .container {
        width: min(100% - 32px, 1180px);
        margin-left: auto;
        margin-right: auto;
    }

    section {
        overflow: hidden;
    }

    .hero,
    .hero-section,
    .main-hero {
        padding-top: 70px;
        padding-bottom: 60px;
    }

    .hero-grid,
    .hero-content,
    .service-hero-card,
    .service-info-grid,
    .reviews-v2-grid,
    .gallery-grid,
    .services-grid,
    .features-grid,
    .stats-grid {
        grid-template-columns: 1fr !important;
    }

    .service-hero-card,
    .review-form-card,
    .reviews-v2-form-card,
    .service-application-card {
        padding: 24px !important;
    }
}

/* Телефоны */
@media (max-width: 768px) {
    body {
        font-size: 15px;
        line-height: 1.55;
        background-attachment: scroll !important;
    }

    .container {
        width: calc(100% - 24px);
        max-width: 100%;
        padding-left: 0;
        padding-right: 0;
    }

    header,
    .site-header,
    .topbar,
    .navbar {
        width: 100%;
    }

    .site-header .container,
    header .container,
    .topbar .container,
    .navbar .container {
        display: flex;
        flex-direction: column;
        gap: 12px;
        align-items: stretch;
    }

    nav,
    .nav,
    .navbar-nav,
    .site-nav {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        width: 100%;
    }

    nav a,
    .nav a,
    .site-nav a,
    .navbar-nav a {
        flex: 1 1 auto;
        text-align: center;
        padding: 10px 12px;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.07);
    }

    h1 {
        font-size: clamp(34px, 11vw, 46px) !important;
        line-height: 1.05 !important;
        word-break: break-word;
    }

    h2 {
        font-size: clamp(28px, 9vw, 38px) !important;
        line-height: 1.12 !important;
        word-break: break-word;
    }

    h3 {
        font-size: 22px !important;
        line-height: 1.2 !important;
    }

    p {
        font-size: 15px;
    }

    .section-head,
    .reviews-v2-head,
    .reviews-v2-form-title {
        margin-bottom: 22px !important;
    }

    section,
    .section,
    .reviews-v2-section,
    .service-page {
        padding-top: 48px !important;
        padding-bottom: 48px !important;
    }

    .hero,
    .hero-section,
    .main-hero {
        min-height: auto !important;
        padding-top: 48px !important;
        padding-bottom: 48px !important;
    }

    .hero-card,
    .glass-card,
    .card,
    .service-hero-card,
    .service-side-card,
    .service-info-card,
    .service-application-card,
    .reviews-v2-card,
    .reviews-v2-form-card,
    .review-form-card,
    .empty-card {
        border-radius: 20px !important;
        padding: 20px !important;
    }

    .btn,
    button,
    input[type="submit"],
    .reviews-v2-btn,
    .logs-btn {
        width: 100%;
        min-height: 48px;
        justify-content: center;
        text-align: center;
        font-size: 15px !important;
    }

    .hero-actions,
    .service-actions,
    .form-actions,
    .reviews-v2-actions,
    .logs-actions {
        display: flex;
        flex-direction: column;
        gap: 10px;
        width: 100%;
    }

    .form-grid,
    .reviews-v2-form-grid,
    .application-form .form-grid,
    .admin-filter-grid,
    .logs-filter-grid {
        display: grid;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    input,
    select,
    textarea {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 46px;
        font-size: 16px !important;
    }

    textarea {
        min-height: 120px;
    }

    .policy-check,
    .reviews-v2-policy {
        align-items: flex-start !important;
        gap: 10px !important;
        font-size: 14px !important;
    }

    .policy-check input,
    .reviews-v2-policy input {
        width: 20px !important;
        min-width: 20px !important;
        height: 20px !important;
        margin-top: 2px !important;
    }

    .reviews-v2-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .reviews-v2-card-top {
        flex-direction: column;
        gap: 8px !important;
    }

    .reviews-v2-stars {
        font-size: 20px !important;
    }

    .gallery-grid,
    .services-grid,
    .features-grid,
    .stats-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .service-hero-card,
    .service-info-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .service-lead {
        font-size: 16px !important;
    }

    .service-text {
        font-size: 15px !important;
    }

    .service-back {
        font-size: 14px;
        margin-bottom: 14px !important;
    }

    table {
        min-width: 720px;
    }

    .admin-table-card,
    .logs-table-card,
    .table-card {
        overflow-x: auto;
    }

    .admin-table-wrap,
    .logs-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    footer,
    .site-footer {
        text-align: center;
    }

    footer .container,
    .site-footer .container {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }
}

/* Маленькие телефоны */
@media (max-width: 480px) {
    .container {
        width: calc(100% - 18px);
    }

    h1 {
        font-size: 32px !important;
    }

    h2 {
        font-size: 28px !important;
    }

    .hero-card,
    .glass-card,
    .card,
    .service-hero-card,
    .service-side-card,
    .service-info-card,
    .service-application-card,
    .reviews-v2-card,
    .reviews-v2-form-card,
    .review-form-card {
        padding: 16px !important;
        border-radius: 18px !important;
    }

    input,
    select,
    textarea {
        padding: 12px 13px !important;
    }

    .reviews-v2-section,
    .service-page,
    section,
    .section {
        padding-top: 38px !important;
        padding-bottom: 38px !important;
    }

    .reviews-v2-head h2,
    .reviews-v2-form-title h3 {
        font-size: 30px !important;
    }

    .reviews-v2-head p,
    .reviews-v2-form-title p {
        font-size: 15px !important;
    }
}

/* Очень узкие экраны */
@media (max-width: 360px) {
    .container {
        width: calc(100% - 14px);
    }

    h1 {
        font-size: 29px !important;
    }

    h2 {
        font-size: 25px !important;
    }

    .btn,
    button,
    input[type="submit"],
    .reviews-v2-btn {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
}