/**
 * Correctifs version mobile - GEPAVE
 * Améliore l’affichage et l’usage sur smartphones et tablettes.
 */

/* --- Viewport et conteneur global --- */
@media (max-width: 767px) {
    html {
        -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
    }
    body {
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .wrapper {
        overflow-x: hidden;
    }
    .content-wrapper {
        overflow-x: hidden;
        padding-left: 10px;
        padding-right: 10px;
    }
}

/* --- En-tête de page (breadcrumbs + infos) --- */
@media (max-width: 767px) {
    .content-heading {
        display: block !important;
        padding: 10px 0;
        min-height: auto;
    }
    .content-heading .pull-right {
        float: none !important;
        display: block;
        margin-top: 8px;
        text-align: left;
    }
    .content-heading .pull-right small,
    .content-heading .pull-right .text-sm {
        font-size: 12px;
        white-space: normal;
        word-break: break-word;
    }
}

/* --- Tableaux : défilement horizontal --- */
@media (max-width: 767px) {
    .table-responsive {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
        margin-bottom: 15px;
    }
    .panel-body .table,
    .panel-body .DataTables {
        min-width: 100%;
    }
    .dataTables_wrapper {
        overflow-x: auto;
    }
}

/* --- Navbar admin : zones tactiles, texte noir (hover inclus), débordement --- */
@media (max-width: 767px) {
    .topnavbar .navbar-nav > li > a,
    .topnavbar .navbar-nav > li > a:hover,
    .topnavbar .navbar-nav > li > a:focus,
    .topnavbar .navbar-nav > .open > a,
    .topnavbar .navbar-nav > .open > a:hover,
    .topnavbar .navbar-nav > .open > a:focus,
    .topnavbar .navbar-nav > li > a span {
        color: #000000 !important;
    }
    .topnavbar .navbar-nav > li > a {
        padding: 15px 12px;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    .topnavbar .navbar-header .navbar-brand {
        max-width: 160px;
    }
    .topnavbar .navbar-header .navbar-brand img {
        max-height: 36px;
        width: auto;
    }
}

/* --- Sidebar (menu latéral) mobile --- */
@media (max-width: 767px) {
    .aside .sidebar {
        -webkit-overflow-scrolling: touch;
        overflow-x: hidden;
    }
    .sidebar .nav > li > a {
        padding: 12px 15px;
        min-height: 44px;
    }
}

/* --- Boutons et liens tactiles --- */
@media (max-width: 767px) {
    .btn {
        min-height: 44px;
        padding: 10px 16px;
    }
    .btn-sm {
        min-height: 36px;
        padding: 8px 12px;
    }
    .dropdown-menu > li > a {
        padding: 12px 20px;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
}

/* --- Formulaires --- */
@media (max-width: 767px) {
    .form-horizontal .form-group .control-label {
        text-align: left;
    }
    .form-horizontal .form-group .col-sm-offset-3,
    .form-horizontal .form-group .col-sm-offset-4 {
        margin-left: 0;
    }
    input[type="text"],
    input[type="password"],
    input[type="email"],
    input[type="number"],
    select.form-control,
    textarea.form-control {
        font-size: 16px; /* évite le zoom auto sur iOS */
        max-width: 100%;
    }
}

/* --- Panneaux et cartes --- */
@media (max-width: 767px) {
    .panel-heading {
        padding: 10px 12px;
    }
    .panel-title {
        font-size: 14px;
        line-height: 1.4;
    }
    .panel-body {
        padding: 12px;
    }
}

/* --- Modales --- */
@media (max-width: 767px) {
    .modal-dialog {
        margin: 10px;
        max-width: calc(100% - 20px);
    }
    .modal-body {
        padding: 15px;
    }
}

/* --- Login : petits écrans --- */
@media (max-width: 480px) {
    .login-center {
        width: 100% !important;
        max-width: 100%;
        padding: 15px !important;
        box-sizing: border-box;
    }
    .block-center.wd-xl {
        width: 100% !important;
        max-width: 100%;
    }
    .wd-xl {
        width: 100% !important;
    }
}
@media (max-width: 380px) {
    .login-center {
        padding: 10px !important;
    }
    .wd-xl {
        width: 100% !important;
    }
}
