/* Portal SENAC - responsividade compartilhada para layouts de módulos e GridView/Krajee */

.portal-module-shell {
    min-height: 100vh;
    background: #f4f7fb;
}

.portal-module-main {
    flex: 1 0 auto;
}

.kv-grid-container,
.grid-view .table-responsive {
    width: 100%;
}

.grid-view table {
    vertical-align: middle;
}

@media (max-width: 991.98px) {
    .navbar-custom .navbar-collapse {
        margin-top: .75rem;
        padding: .75rem;
        max-height: calc(100vh - 92px);
        overflow-y: auto;
        background: linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.08));
        border: 1px solid rgba(255,255,255,.16);
        border-radius: 18px;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
    }

    .navbar-custom .navbar-collapse .navbar-nav {
        gap: .4rem;
    }

    .navbar-custom .navbar-collapse .nav-link,
    .navbar-custom .navbar-collapse .dropdown-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: .75rem .9rem;
        border-radius: 14px;
        background: rgba(255,255,255,.12);
    }

    .navbar-custom .navbar-collapse .dropdown-menu {
        position: static;
        width: 100%;
        margin: .4rem 0 0;
        transform: none;
        box-shadow: none;
    }

    .navbar-custom .navbar-collapse .dropdown-menu.show,
    .navbar-custom .navbar-collapse .dropdown-submenu:hover > .dropdown-menu {
        display: block;
        opacity: 1;
        visibility: visible;
        transform: none;
    }

    .navbar-custom .navbar-collapse .dropdown-submenu > .dropdown-menu {
        left: auto;
        margin-left: .75rem;
    }
}

@media (max-width: 767.98px) {
    .grid-view.portal-grid-cards {
        width: 100%;
        overflow: visible;
    }

    .kv-grid-container,
    .grid-view .table-responsive {
        overflow: visible !important;
    }

    .grid-view.portal-grid-cards .summary {
        padding: .75rem 0;
        color: #475569;
        font-size: .92rem;
    }

    .grid-view.portal-grid-cards table,
    .grid-view.portal-grid-cards thead,
    .grid-view.portal-grid-cards tbody,
    .grid-view.portal-grid-cards tr,
    .grid-view.portal-grid-cards th,
    .grid-view.portal-grid-cards td {
        display: block;
        width: 100% !important;
        max-width: none !important;
    }

    .grid-view.portal-grid-cards table {
        min-width: 0 !important;
        table-layout: auto !important;
        border: 0;
        background: transparent;
    }

    .grid-view.portal-grid-cards thead {
        display: none;
    }

    .grid-view.portal-grid-cards tbody tr {
        margin: 0 0 .85rem;
        padding: .55rem .75rem;
        border: 1px solid #dfe6f1;
        border-radius: 18px;
        background: #ffffff;
        box-shadow: 0 10px 22px rgba(15, 23, 42, .07);
    }

    .grid-view.portal-grid-cards tbody tr:hover {
        background: #ffffff;
    }

    .grid-view.portal-grid-cards tbody tr.filters {
        display: none !important;
    }

    .grid-view.portal-grid-cards tbody td {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 1rem;
        padding: .55rem 0;
        border: 0;
        border-bottom: 1px solid #eef2f7;
        color: #0f172a;
        text-align: right !important;
        white-space: normal !important;
        word-break: break-word;
    }

    .grid-view.portal-grid-cards tbody td:last-child {
        border-bottom: 0;
    }

    .grid-view.portal-grid-cards tbody td::before {
        content: attr(data-label);
        flex: 0 0 42%;
        color: #64748b;
        font-size: .72rem;
        font-weight: 800;
        letter-spacing: .06em;
        line-height: 1.25;
        text-align: left;
        text-transform: uppercase;
    }

    .grid-view.portal-grid-cards tbody td[data-label=""],
    .grid-view.portal-grid-cards tbody td[data-label="#"] {
        display: none;
    }

    .grid-view.portal-grid-cards tbody td[data-label="Ações"],
    .grid-view.portal-grid-cards tbody td.action-column {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        text-align: left !important;
    }

    .grid-view.portal-grid-cards tbody td[data-label="Ações"]::before,
    .grid-view.portal-grid-cards tbody td.action-column::before {
        flex-basis: 42%;
    }

    .grid-view.portal-grid-cards .pagination {
        flex-wrap: wrap;
        justify-content: center;
        gap: .25rem;
    }

    .grid-view.portal-grid-cards .btn,
    .grid-view.portal-grid-cards .dropdown-toggle {
        min-height: 34px;
    }

    .grid-view.portal-grid-cards .empty {
        display: block;
        padding: 1rem;
        text-align: center !important;
    }

    .grid-view.portal-grid-cards .empty::before {
        content: "";
        display: none;
    }

    [data-portal-grid-mode="scroll"] {
        max-width: 100%;
        overflow: hidden;
    }

    [data-portal-grid-mode="scroll"] .kv-grid-container,
    [data-portal-grid-mode="scroll"] .table-responsive,
    .grid-view[data-portal-grid-mode="scroll"] .kv-grid-container,
    .grid-view[data-portal-grid-mode="scroll"] .table-responsive {
        overflow-x: auto !important;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
    }

    [data-portal-grid-mode="scroll"] .grid-view table,
    .grid-view[data-portal-grid-mode="scroll"] table {
        display: table;
        min-width: 980px;
        width: max-content;
    }
}
