/*
 * Responsive fixes for Trámite en Línea PWA.
 * Loaded after the vendor/admin styles so mobile views stay usable inside the installed app.
 */

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

img,
svg,
canvas,
video,
iframe {
    max-width: 100%;
}

.content-wrapper,
.main-content,
.page-content,
.container,
.container-fluid {
    min-width: 0;
}

.content-wrapper,
.main-content {
    overflow-x: clip;
}

.card,
.card-body,
.card-header,
.row > [class*="col-"] {
    min-width: 0;
}

.card-header .card-title,
.card-header h1,
.card-header h2,
.card-header h3,
.card-header h4,
.card-header h5,
.card-header h6 {
    min-width: 0;
    overflow-wrap: anywhere;
}

.table-responsive,
.gridjs-wrapper,
.dataTables_wrapper,
.table-wrap,
.responsive-table {
    width: 100%;
    max-width: 100%;
}

.table-responsive,
.gridjs-wrapper,
.table-wrap,
.responsive-table {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
}

table,
.gridjs-table {
    max-width: 100%;
}

.table th,
.table td,
.gridjs-th,
.gridjs-td {
    vertical-align: middle;
}

.gridjs-container,
.gridjs-wrapper,
.gridjs-table {
    min-width: 0 !important;
}

.gridjs-search,
.gridjs-search-input,
.dataTables_filter,
.dataTables_filter input,
.dataTables_length,
.dataTables_paginate,
.dataTables_info {
    max-width: 100%;
}

.gridjs-pagination,
.dataTables_paginate {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: .25rem;
}

.btn,
.btn-group,
.input-group,
.form-control,
.custom-select,
.select2-container,
.select2,
.choices,
.flatpickr-input {
    max-width: 100%;
}

.btn-group,
.btn-toolbar,
.action-buttons,
.actions,
.dt-buttons {
    flex-wrap: wrap;
    gap: .35rem;
}

.modal-dialog {
    max-width: calc(100% - 1rem);
}

.modal-content {
    max-height: calc(100vh - 1rem);
}

.modal-body {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.dropdown-menu {
    max-width: calc(100vw - 1rem);
    overflow-wrap: anywhere;
}

.main-header .navbar-nav {
    min-width: 0;
}

.main-header .dropdown-menu-lg {
    max-width: calc(100vw - 1rem);
}

@media (max-width: 991.98px) {
    body,
    body[data-layout="vertical"] {
        min-width: 0 !important;
    }

    .content-wrapper,
    .main-content {
        margin-left: 0 !important;
    }

    .page-content {
        padding: 76px .75rem 4.5rem;
    }

    .content-header {
        padding: .75rem .5rem .25rem;
    }

    .content {
        padding: 0 .5rem;
    }

    .container-fluid {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .main-footer,
    .footer {
        left: 0 !important;
        margin-left: 0 !important;
        text-align: center;
        padding-left: .75rem;
        padding-right: .75rem;
    }

    .main-sidebar,
    .vertical-menu {
        max-width: min(86vw, 280px);
    }

    .main-header .navbar-nav .nav-link {
        padding-left: .65rem;
        padding-right: .65rem;
    }

    .navbar-brand-box {
        width: auto !important;
        max-width: 58vw;
    }

    .logo-lg img,
    .brand-link img {
        max-width: 100%;
        object-fit: contain;
    }
}

@media (max-width: 767.98px) {
    h1,
    .h1 {
        font-size: 1.55rem;
    }

    h2,
    .h2 {
        font-size: 1.35rem;
    }

    h3,
    .h3 {
        font-size: 1.2rem;
    }

    .card {
        border-radius: .55rem;
    }

    .card-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: .75rem;
        flex-wrap: wrap;
    }

    .card-header .card-options,
    .card-header .card-tools,
    .page-title-box .page-title-right,
    .content-header .breadcrumb {
        position: static !important;
        margin-left: auto;
        max-width: 100%;
    }

    .card-body,
    .card-header,
    .card-footer {
        padding: .85rem;
    }

    .card:hover {
        transform: none;
    }

    .row {
        margin-left: -.4rem;
        margin-right: -.4rem;
    }

    .row > [class*="col-"] {
        padding-left: .4rem;
        padding-right: .4rem;
    }

    .form-group,
    .form-group-modern {
        margin-bottom: .9rem;
    }

    .input-group {
        flex-wrap: wrap;
    }

    .input-group > .form-control,
    .input-group > .custom-select {
        min-width: 0;
    }

    .btn {
        white-space: normal;
    }

    .btn i {
        margin-right: .25rem;
    }

    .table th,
    .table td,
    .gridjs-th,
    .gridjs-td {
        padding: .55rem .65rem !important;
        font-size: .86rem;
    }

    .gridjs-search,
    .gridjs-search-input {
        width: 100% !important;
    }

    .gridjs-pages {
        display: flex;
        flex-wrap: nowrap;
        gap: .25rem;
    }

    .gridjs-pages button,
    .dataTables_paginate .paginate_button {
        min-width: 34px;
    }

    .modal-dialog {
        margin: .5rem auto;
    }

    .modal-header,
    .modal-body,
    .modal-footer {
        padding: .85rem;
    }

    .modal-footer {
        gap: .5rem;
    }

    .modal-footer > * {
        margin: 0;
    }

    .toast-top-right {
        top: .75rem;
        right: .75rem;
        left: .75rem;
        width: auto;
    }
}

@media (max-width: 575.98px) {
    .page-content {
        padding-left: .5rem;
        padding-right: .5rem;
    }

    .content,
    .container-fluid {
        padding-left: .35rem;
        padding-right: .35rem;
    }

    .content-header h1,
    .page-title-box h4,
    .card-title {
        font-size: 1rem !important;
        line-height: 1.25;
    }

    .card-header {
        align-items: flex-start;
    }

    .card-header .card-options,
    .card-header .card-tools,
    .page-title-box .page-title-right {
        width: 100%;
        margin-left: 0;
    }

    .btn-group,
    .btn-toolbar,
    .action-buttons,
    .actions,
    .dt-buttons {
        width: 100%;
    }

    .btn-group > .btn,
    .btn-toolbar .btn,
    .action-buttons .btn,
    .actions .btn,
    .dt-buttons .btn {
        flex: 1 1 auto;
    }

    .main-header .dropdown-menu-lg,
    #notificaciones-menu {
        left: .5rem !important;
        right: .5rem !important;
        width: auto !important;
        min-width: 0;
    }

    .main-footer {
        font-size: .82rem;
    }
}
