/**
 * RepairBill — formularios POS y listados: móvil / tablet
 * - input-group + Select2: botones permanecen en la misma fila
 * - tablas anchas: desplazamiento horizontal táctil
 * - pestañas y controles: mejor uso en pantallas pequeñas
 */

/* Bootstrap 4: .input-group usa flex-wrap; con Select2 el append baja de línea → forzar una fila */
.content .input-group.mb-3,
.content .input-group.input-group-search {
    flex-wrap: nowrap;
    align-items: stretch;
}

.content .input-group > .select2-container,
.content .input-group > .select2-container--bootstrap4 {
    flex: 1 1 0%;
    width: 1% !important;
    min-width: 0;
    max-width: 100%;
}

.content .input-group .select2-container .select2-selection--single {
    height: calc(2.25rem + 2px);
}

.content .input-group-append,
.content .input-group-prepend {
    flex-shrink: 0;
}

.content .input-group-append .btn,
.content .input-group-prepend .btn {
    white-space: nowrap;
}

/* Tablas de detalle (venta, cotización, orden, compra, NC, etc.) */
.rb-table-products-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    margin-bottom: 1rem;
}

/* Pestañas de pago y similares: no romper en muchas columnas */
.content .nav-tabs.rb-nav-tabs-scroll,
.content ul.nav-tabs.flex-nowrap {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
}

.content .nav-tabs.rb-nav-tabs-scroll .nav-item,
.content ul.nav-tabs.flex-nowrap .nav-item {
    white-space: nowrap;
}

.content .nav-tabs.rb-nav-tabs-scroll .nav-link,
.content ul.nav-tabs.flex-nowrap .nav-link {
    white-space: nowrap;
}

/* Listados DataTables */
.dataTables_wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

/* TouchSpin: zona táctil mínima recomendada */
@media (max-width: 991.98px) {
    .bootstrap-touchspin .input-group-btn > .btn {
        min-height: 2.75rem;
        min-width: 2.65rem;
    }
}

/* Botones de pie de formulario POS */
@media (max-width: 575.98px) {
    .rb-form-actions-responsive .btn {
        display: block;
        width: 100%;
        margin: 0.4rem 0 !important;
    }

    /* Modales grandes: aprovechan el ancho en teléfono */
    .modal-dialog.modal-xl {
        max-width: calc(100vw - 1rem);
        margin-left: auto;
        margin-right: auto;
    }
}

/*
 * Pantallas ≤991px (móvil y tablet estrecha):
 * AdminLTE por defecto oculta el sidebar solo hasta 767px; entre 768–991 el menú sigue
 * fijo a 250px pero el contenido tiene margin-left: 0 → el área útil queda “comprimida”
 * detrás del menú. Misma lógica que en teléfono: sidebar fuera del lienzo hasta abrir.
 */
@media (max-width: 991.98px) {
    .main-sidebar,
    .main-sidebar::before {
        margin-left: -250px !important;
        box-shadow: none !important;
    }

    body.sidebar-open .main-sidebar,
    body.sidebar-open .main-sidebar::before {
        margin-left: 0 !important;
    }

    body:not(.layout-top-nav) .wrapper .content-wrapper,
    body:not(.layout-top-nav) .wrapper .main-header,
    body:not(.layout-top-nav) .wrapper .main-footer {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .wrapper {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .wrapper .content-wrapper {
        overflow-x: hidden;
        min-width: 0;
    }

    .content-wrapper > .content {
        padding-left: max(0.35rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.35rem, env(safe-area-inset-right, 0px));
    }

    .content-header .container-fluid,
    section.content > .container-fluid {
        max-width: 100%;
        padding-left: max(0.5rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.5rem, env(safe-area-inset-right, 0px));
    }

    .content > .container {
        max-width: 100%;
        padding-left: 0.65rem;
        padding-right: 0.65rem;
    }

    /* Tarjetas: menos margen lateral para ganar ancho en pantallas angostas */
    .content .card .card-body {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .content .card .card-header {
        padding-left: 0.85rem;
        padding-right: 0.85rem;
    }

    /* Modales estándar: casi todo el ancho con notch seguro */
    .modal-dialog:not(.modal-xl) {
        max-width: calc(100vw - 1.25rem);
        margin-left: auto;
        margin-right: auto;
    }
}

@media (max-width: 575.98px) {
    .breadcrumb {
        padding-left: 0.5rem !important;
        padding-right: 0.5rem !important;
    }

    .content-header .container-fluid,
    section.content > .container-fluid {
        padding-left: max(0.35rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.35rem, env(safe-area-inset-right, 0px));
    }
}

/*
 * Panel (layout-top-nav / hzt_body): `.content > .container` usa max-width de Bootstrap.
 * Si el viewport efectivo es ancho (zoom alejado en el celular), la banda útil queda como
 * columna centrada con grandes márgenes. En táctil forzar 100 % como el escritorio estrecho real.
 */
/*
 * Barra superior: evitar fila única saturada (scroll horizontal / texto cortado).
 * En ≤991px (tablet) las acciones derechas pueden pasar a segunda fila con wrap.
 * En ≤767px (teléfono) se anula el wrap: una sola fila compacta (ver bloque siguiente).
 */
@media (max-width: 991.98px) {
    .main-header.navbar {
        flex-wrap: wrap;
        align-items: stretch;
        align-content: flex-start;
        row-gap: 0;
        padding-left: max(0.25rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.25rem, env(safe-area-inset-right, 0px));
        padding-bottom: 0.35rem;
    }

    /* Layout sidebar (dos <ul> directos): primera fila menú + segunda fila iconos */
    body:not(.layout-top-nav) .main-header.navbar > .navbar-nav.ml-auto {
        flex-basis: 100%;
        margin-left: 0 !important;
        padding-top: 0.35rem;
        margin-top: 0.15rem;
        border-top: 1px solid rgba(15, 23, 42, 0.08);
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 0.15rem;
    }

    html[data-theme='dark'] body:not(.layout-top-nav) .main-header.navbar > .navbar-nav.ml-auto {
        border-top-color: rgba(255, 255, 255, 0.08);
    }

    /* Layout menú superior: toolbar dentro de .container */
    body.layout-top-nav .main-header.navbar > .container {
        flex-wrap: wrap;
        max-width: 100%;
        min-width: 0;
    }

    body.layout-top-nav .main-header.navbar > .container > .navbar-nav.ml-auto {
        flex-basis: 100%;
        margin-left: 0 !important;
        padding-top: 0.35rem;
        margin-top: 0.2rem;
        border-top: 1px solid rgba(15, 23, 42, 0.08);
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 0.15rem;
    }

    html[data-theme='dark'] body.layout-top-nav .main-header.navbar > .container > .navbar-nav.ml-auto {
        border-top-color: rgba(255, 255, 255, 0.08);
    }

    .main-header .navbar-nav .nav-link {
        min-height: 2.75rem;
        display: inline-flex;
        align-items: center;
        flex-wrap: nowrap;
    }

    .main-header .navbar-nav .nav-item.d-flex.align-items-center {
        min-height: 2.75rem;
    }

    .main-header .navbar-nav .rb-theme-toggle {
        min-height: 2.65rem;
        min-width: 2.65rem;
    }

    /* Nombre de usuario / RUC / perfil: evitar desborde en una sola línea */
    .rb-navbar-truncate {
        display: inline-block;
        max-width: min(42vw, 11rem);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        vertical-align: bottom;
    }
}

/*
 * Teléfonos (≤767px): una sola fila de cabecera — la regla anterior (≤991) partía la barra
 * en dos hileras (hamburguesa arriba, iconos abajo) y ocupaba demasiado alto en móvil.
 * Los iconos derechos pueden desplazarse en horizontal si no caben.
 */
@media (max-width: 767.98px) {
    .main-header.navbar {
        flex-wrap: nowrap !important;
        align-items: center !important;
        align-content: center !important;
        row-gap: 0 !important;
        padding-top: 0.2rem !important;
        padding-bottom: 0.2rem !important;
        min-height: 0;
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
    }

    body:not(.layout-top-nav) .main-header.navbar > .navbar-nav:first-child {
        flex-shrink: 0;
    }

    body:not(.layout-top-nav) .main-header.navbar > .navbar-nav.ml-auto {
        flex: 1 1 0% !important;
        flex-basis: 0 !important;
        min-width: 0 !important;
        max-width: none !important;
        width: auto !important;
        margin-left: 0.25rem !important;
        padding-top: 0 !important;
        margin-top: 0 !important;
        border-top: none !important;
        flex-wrap: nowrap !important;
        /* overflow-x:auto recorta en Y y oculta dropdowns (campana). El scroll horizontal va en la barra. */
        overflow-x: visible !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-end;
        gap: 0;
        scrollbar-width: none;
    }

    body:not(.layout-top-nav) .main-header.navbar > .navbar-nav.ml-auto > .nav-item {
        flex-shrink: 0;
    }

    body:not(.layout-top-nav) .main-header.navbar > .navbar-nav.ml-auto::-webkit-scrollbar {
        display: none;
    }

    body.layout-top-nav .main-header.navbar > .container {
        flex-wrap: nowrap !important;
        align-items: center !important;
        padding-top: 0.2rem !important;
        padding-bottom: 0.2rem !important;
        min-width: 0;
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
    }

    body.layout-top-nav .main-header.navbar > .container > .navbar-nav.ml-auto {
        flex: 1 1 0% !important;
        flex-basis: 0 !important;
        min-width: 0 !important;
        margin-left: 0.25rem !important;
        padding-top: 0 !important;
        margin-top: 0 !important;
        border-top: none !important;
        flex-wrap: nowrap !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-end;
        scrollbar-width: none;
    }

    body.layout-top-nav .main-header.navbar > .container > .navbar-nav.ml-auto > .nav-item {
        flex-shrink: 0;
    }

    body.layout-top-nav .main-header.navbar > .container > .navbar-nav.ml-auto::-webkit-scrollbar {
        display: none;
    }

    .main-header .navbar-nav .nav-link {
        min-height: 2.35rem !important;
        padding: 0.3rem 0.45rem !important;
    }

    .main-header .navbar-nav .nav-item.d-flex.align-items-center {
        min-height: 2.35rem !important;
    }

    .main-header .navbar-nav .rb-theme-toggle {
        min-height: 2.35rem !important;
        min-width: 2.35rem !important;
    }
}

/* Teléfonos muy estrechos: tipografía base un poco mayor para lectura */
@media (max-width: 575.98px) {
    html {
        font-size: 16px;
    }
}

@media not all and (min-width: 992px) and (hover: hover) and (pointer: fine) {
    body.layout-top-nav .content-header > .container,
    body.layout-top-nav section.content > .container,
    body.layout-top-nav .content > .container {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: max(0.45rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.45rem, env(safe-area-inset-right, 0px));
        box-sizing: border-box;
    }

    body.layout-top-nav .wrapper {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    body.layout-top-nav .content-wrapper {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0;
        overflow-x: hidden;
    }

    body.layout-top-nav .dashboard-admin.container-fluid {
        padding-left: max(0.25rem, env(safe-area-inset-left, 0px));
        padding-right: max(0.25rem, env(safe-area-inset-right, 0px));
    }
}

/*
 * Portal técnico (recepción / técnico en celular): antes mucho texto usaba .small (80 %).
 * Tamaños y cajas de tiempo orientativo más legibles en ≤991px.
 */
@media (max-width: 991.98px) {
    .rb-technician-portal .card-body {
        font-size: 1.0625rem;
        line-height: 1.5;
    }

    .rb-technician-portal .card-header .card-title {
        font-size: 1.3rem;
        line-height: 1.25;
    }

    .rb-technician-portal .rb-portal-intro {
        font-size: 1rem;
        line-height: 1.45;
    }

    .rb-technician-portal .rb-portal-section-title {
        font-size: 1.05rem;
        font-weight: 600;
    }

    .rb-technician-portal .rb-portal-lead {
        font-size: 1.125rem;
        font-weight: 500;
        line-height: 1.4;
    }

    .rb-technician-portal .rb-portal-meta,
    .rb-technician-portal .rb-portal-detail-grid {
        font-size: 1rem !important;
        line-height: 1.45;
    }

    .rb-technician-portal .rb-portal-desc {
        font-size: 1.0625rem;
        line-height: 1.5;
    }

    .rb-technician-portal .rb-portal-intake {
        font-size: 1rem !important;
        line-height: 1.45;
    }

    .rb-technician-portal .rb-portal-intake strong {
        font-size: 1.05rem;
    }

    .rb-technician-portal .form-control {
        font-size: 1.05rem;
        min-height: 2.75rem;
    }

    .rb-technician-portal .form-control-file {
        font-size: 1rem;
    }

    .rb-technician-portal .rb-portal-history li {
        font-size: 1rem;
        line-height: 1.45;
        margin-bottom: 0.4rem;
    }

    .rb-technician-portal .badge {
        font-size: 0.9rem;
        padding: 0.35em 0.55em;
    }

    .rb-technician-portal .btn {
        font-size: 1rem;
    }
}

@media (max-width: 575.98px) {
    .rb-technician-portal .card-body {
        font-size: 1.1rem;
    }

    .rb-technician-portal .rb-portal-lead {
        font-size: 1.2rem;
    }

    .rb-technician-portal .rb-portal-desc {
        font-size: 1.1rem;
    }
}

/* Campana POS: grupos por tipo de notificación */
.rb-nav-notif-grouped .rb-notif-between-groups {
    margin: 0.15rem 0;
    opacity: 0.85;
}

.rb-nav-notif-grouped .rb-notif-group .dropdown-header {
    white-space: normal;
}

.rb-nav-notif-grouped .workshop-feed-item + .workshop-feed-item {
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}
