/*
 * ISAV V8 - Thème global sécurisé
 * Harmonisation visuelle uniquement.
 * Aucune donnée, route, option ou entrée de menu n'est modifiée.
 */

:root {
  --v8-bg:#f4f7fb;
  --v8-card:#ffffff;
  --v8-soft:#f8fafc;
  --v8-border:#dbe3ef;
  --v8-text:#0f172a;
  --v8-muted:#64748b;
  --v8-blue:#2563eb;
  --v8-blue2:#4f46e5;
  --v8-green:#16a34a;
  --v8-red:#dc2626;
  --v8-orange:#f59e0b;
  --v8-radius:18px;
  --v8-shadow:0 12px 34px rgba(15,23,42,.07);
}

html { scroll-behavior:smooth; }

body {
  background: radial-gradient(circle at top left, rgba(37,99,235,.08), transparent 34%),
              linear-gradient(135deg,#f8fbff,var(--v8-bg)) !important;
  color:var(--v8-text);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  -webkit-font-smoothing:antialiased;
}

main,.content,.page-content,.app-content,.container,.dashboard,.clients-page,.tickets-page,.contracts-page,.loan-page {
  max-width:1480px;
}

h1,h2,h3 { color:var(--v8-text); letter-spacing:-.02em; }
h1 { font-size:clamp(24px,3vw,34px); font-weight:950; }
h2 { font-size:clamp(19px,2vw,24px); font-weight:900; }
h3 { font-size:17px; font-weight:850; }

p,.muted,.text-muted,small { color:var(--v8-muted); }

.card,.panel,.box,.widget,.stat-card,.dashboard-card,.client-card,.ticket-card,.contract-card,.loan-card,.loan-result,.loan-form-card {
  border:1px solid var(--v8-border) !important;
  border-radius:var(--v8-radius) !important;
  background:rgba(255,255,255,.94) !important;
  box-shadow:var(--v8-shadow) !important;
}

.btn,button,input[type="submit"],input[type="button"],.button,a.btn {
  border-radius:12px !important;
  min-height:38px;
  font-weight:850 !important;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}

.btn:not(.secondary):not(.danger),button.btn:not(.secondary):not(.danger),input[type="submit"] {
  background:linear-gradient(135deg,var(--v8-blue),var(--v8-blue2)) !important;
  color:#fff !important;
  border:0 !important;
  box-shadow:0 10px 24px rgba(37,99,235,.22);
}

.btn.secondary,.btn.outline,.button.secondary,a.btn.secondary {
  background:#fff !important;
  color:var(--v8-text) !important;
  border:1px solid var(--v8-border) !important;
  box-shadow:none !important;
}

.btn.danger,button.danger,.btn.btn-danger {
  background:linear-gradient(135deg,#ef4444,var(--v8-red)) !important;
  color:#fff !important;
  border:0 !important;
}

.btn:hover,button:hover,input[type="submit"]:hover,.button:hover {
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(15,23,42,.12);
}

input,select,textarea {
  border-radius:12px !important;
  border:1px solid #cbd5e1 !important;
  background:#fff !important;
  color:var(--v8-text) !important;
  transition:border-color .16s ease, box-shadow .16s ease;
}

input:focus,select:focus,textarea:focus {
  outline:none !important;
  border-color:var(--v8-blue) !important;
  box-shadow:0 0 0 4px rgba(37,99,235,.13) !important;
}

label { color:#334155; font-weight:750; }

table {
  border-collapse:separate !important;
  border-spacing:0 !important;
  width:100%;
  background:#fff;
  border-radius:var(--v8-radius);
}

thead th,table th {
  background:var(--v8-soft) !important;
  color:#334155 !important;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.04em;
  border-bottom:1px solid var(--v8-border) !important;
}

tbody td,table td { border-bottom:1px solid #edf2f7 !important; }
tbody tr:hover td { background:#f8fbff !important; }

.badge,.label,.pill,.status,[class*="badge"] {
  border-radius:999px !important;
  font-weight:900;
}

.alert,.flash,.notice,.message {
  border-radius:16px !important;
  border:1px solid var(--v8-border);
  box-shadow:0 8px 22px rgba(15,23,42,.05);
}

.alert.success,.flash.success,.notice.success {
  background:#dcfce7 !important;
  color:#166534 !important;
  border-color:#bbf7d0 !important;
}

.alert.error,.alert.danger,.flash.error,.notice.error {
  background:#fee2e2 !important;
  color:#991b1b !important;
  border-color:#fecaca !important;
}

.alert.warning,.flash.warning,.notice.warning {
  background:#fef3c7 !important;
  color:#92400e !important;
  border-color:#fde68a !important;
}

.sidebar a,.side-menu a,nav.sidebar a,aside a,.menu a {
  border-radius:12px;
  transition:background .16s ease, transform .16s ease, color .16s ease;
}

.sidebar a:hover,.side-menu a:hover,nav.sidebar a:hover,aside a:hover,.menu a:hover {
  background:rgba(37,99,235,.10);
  transform:translateX(2px);
}

.stat strong,.stat-card strong,.kpi strong,.kpi-card strong {
  font-size:clamp(24px,3vw,36px);
  font-weight:950;
}

img,.preview,.photo,.thumbnail { border-radius:14px; max-width:100%; }

@media (max-width:900px) {
  body { font-size:15px; }
  main,.content,.page-content,.app-content,.container {
    padding-left:12px !important;
    padding-right:12px !important;
  }
  .card,.panel,.box,.widget { border-radius:16px !important; }
  table { font-size:13px; }
  .btn,button,input[type="submit"],input[type="button"] { min-height:42px; }
}

@media print {
  body { background:#fff !important; }
  .card,.panel,.box,.widget { box-shadow:none !important; }
}

/* === ISAV V8 FIX LISIBILITE MENU START ===
 * Correction du rendu texte menu : plus net, moins agressif.
 * Ne modifie aucun lien / aucune option.
 */
.sidebar,
.side-menu,
nav.sidebar,
aside,
.menu {
    -webkit-font-smoothing: auto !important;
    text-rendering: geometricPrecision !important;
}

.sidebar a,
.side-menu a,
nav.sidebar a,
aside a,
.menu a {
    font-weight: 650 !important;
    letter-spacing: 0 !important;
    text-shadow: none !important;
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    transform: none !important;
    color: inherit;
}

.sidebar a:hover,
.side-menu a:hover,
nav.sidebar a:hover,
aside a:hover,
.menu a:hover {
    transform: none !important;
    background: rgba(37, 99, 235, .08) !important;
}

.sidebar a span,
.side-menu a span,
nav.sidebar a span,
aside a span,
.menu a span {
    text-shadow: none !important;
    filter: none !important;
}

.sidebar a.active,
.side-menu a.active,
nav.sidebar a.active,
aside a.active,
.menu a.active,
.sidebar a[aria-current="page"],
.side-menu a[aria-current="page"] {
    font-weight: 750 !important;
    text-shadow: none !important;
}
/* === ISAV V8 FIX LISIBILITE MENU END === */

/* === ISAV V8 FIX NETTETE MENU V2 START ===
 * Menu plus net : contraste, rendu texte natif, aucun flou ni effet transform.
 * Ne modifie aucune option du menu.
 */
.sidebar,
.side-menu,
nav.sidebar,
aside,
.menu,
.sidebar *,
.side-menu *,
nav.sidebar *,
aside *,
.menu * {
    -webkit-font-smoothing: subpixel-antialiased !important;
    -moz-osx-font-smoothing: auto !important;
    text-rendering: auto !important;
    font-smooth: auto !important;
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    text-shadow: none !important;
    transform: none !important;
}

.sidebar a,
.side-menu a,
nav.sidebar a,
aside a,
.menu a {
    opacity: 1 !important;
    color: #f8fafc !important;
    font-family: Arial, "Segoe UI", system-ui, sans-serif !important;
    font-size: 14.5px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
    transform: none !important;
    will-change: auto !important;
    transition: background-color .12s ease, color .12s ease !important;
}

.sidebar a:hover,
.side-menu a:hover,
nav.sidebar a:hover,
aside a:hover,
.menu a:hover {
    color: #ffffff !important;
    background: rgba(255, 255, 255, .10) !important;
    transform: none !important;
}

.sidebar a.active,
.side-menu a.active,
nav.sidebar a.active,
aside a.active,
.menu a.active,
.sidebar a[aria-current="page"],
.side-menu a[aria-current="page"],
nav.sidebar a[aria-current="page"],
aside a[aria-current="page"],
.menu a[aria-current="page"] {
    color: #ffffff !important;
    font-weight: 700 !important;
    background: rgba(37, 99, 235, .34) !important;
    box-shadow: inset 3px 0 0 #60a5fa !important;
}

.sidebar a svg,
.side-menu a svg,
nav.sidebar a svg,
aside a svg,
.menu a svg,
.sidebar a img,
.side-menu a img,
nav.sidebar a img,
aside a img,
.menu a img {
    filter: none !important;
    opacity: 1 !important;
    transform: none !important;
}

/* Correction spécifique si le menu utilise des spans internes */
.sidebar a span,
.side-menu a span,
nav.sidebar a span,
aside a span,
.menu a span {
    color: inherit !important;
    opacity: 1 !important;
    font-weight: inherit !important;
    letter-spacing: 0 !important;
    text-shadow: none !important;
    filter: none !important;
    transform: none !important;
}

/* Si le navigateur rend mal la police Inter sur fond sombre, on force une police système plus nette dans le menu */
.sidebar,
.side-menu,
nav.sidebar,
aside,
.menu {
    font-family: Arial, "Segoe UI", system-ui, sans-serif !important;
}
/* === ISAV V8 FIX NETTETE MENU V2 END === */

/* === ISAV V8 ETAPE 2 PAGES PRIORITAIRES START ===
 * Harmonisation visuelle des pages principales.
 * Aucun menu, aucune option, aucune donnée n'est modifié.
 */

/* Structure pages principales */
.dashboard,
.clients-page,
.tickets-page,
.contracts-page,
.loan-page,
.sms-page,
.technicians-page,
.admin-page,
main > .card:first-child,
.content > .card:first-child,
.page-content > .card:first-child {
    animation: isavV8SoftEnter .22s ease-out;
}

@keyframes isavV8SoftEnter {
    from {
        opacity: .92;
        transform: translateY(4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* En-têtes de page */
.page-header,
.dashboard-header,
.clients-header,
.tickets-header,
.contracts-header,
.loan-hero,
.hero,
.header-card,
main > h1:first-child,
.content > h1:first-child,
.page-content > h1:first-child {
    margin-bottom: 16px !important;
}

.page-header,
.dashboard-header,
.clients-header,
.tickets-header,
.contracts-header,
.hero,
.header-card {
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    border-radius: 22px !important;
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(239,246,255,.90)) !important;
    box-shadow: 0 12px 34px rgba(15,23,42,.06) !important;
    padding: 18px !important;
}

/* Grilles statistiques dashboard et modules */
.stats,
.stats-grid,
.dashboard-grid,
.kpi-grid,
.cards-grid,
.summary-grid,
.ticket-stats,
.client-stats,
.contract-stats,
.loan-stats {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
    gap: 14px !important;
    align-items: stretch !important;
}

.stat,
.stat-card,
.kpi,
.kpi-card,
.summary-card,
.dashboard-card {
    min-height: 96px;
    padding: 16px !important;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 8px;
}

.stat span,
.stat-card span,
.kpi span,
.kpi-card span,
.summary-card span {
    color: #64748b !important;
    font-size: 11px !important;
    font-weight: 950 !important;
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
}

.stat strong,
.stat-card strong,
.kpi strong,
.kpi-card strong,
.summary-card strong {
    color: #0f172a !important;
    line-height: 1 !important;
}

/* Listes clients / tickets / contrats / prêts */
.clients-list,
.tickets-list,
.contracts-list,
.loan-grid,
.list-grid,
.results-grid {
    display: grid;
    gap: 14px;
}

.client-row,
.ticket-row,
.contract-row,
.loan-result,
.result-card,
.list-card {
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.94) !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.05) !important;
    padding: 14px !important;
}

/* Tableaux pages principales */
.clients-page table,
.tickets-page table,
.contracts-page table,
.loan-page table,
main table,
.content table {
    overflow: hidden;
    box-shadow: 0 8px 22px rgba(15,23,42,.04);
}

.clients-page table th,
.tickets-page table th,
.contracts-page table th,
.loan-page table th,
main table th,
.content table th {
    height: 44px;
}

.clients-page table td,
.tickets-page table td,
.contracts-page table td,
.loan-page table td,
main table td,
.content table td {
    padding-top: 11px !important;
    padding-bottom: 11px !important;
}

/* Formulaires création / édition */
form.card,
.form-card,
form.panel,
.form-panel,
.create-form,
.edit-form,
.client-form,
.ticket-form,
.contract-form,
.loan-form-card {
    padding: 18px !important;
}

form .row,
.form-row,
.fields-row {
    gap: 12px !important;
}

form label,
.form-group label,
.field label {
    margin-bottom: 6px;
}

/* Fiche client / ticket / contrat : blocs plus lisibles */
.detail-card,
.info-card,
.profile-card,
.client-detail,
.ticket-detail,
.contract-detail,
.loan-card {
    padding: 16px !important;
}

.detail-grid,
.info-grid,
.meta-grid,
.ticket-meta,
.client-meta,
.contract-meta,
.loan-show-metas {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    gap: 12px !important;
}

.detail-grid > *,
.info-grid > *,
.meta-grid > *,
.ticket-meta > *,
.client-meta > *,
.contract-meta > *,
.loan-show-metas > * {
    border-radius: 14px !important;
}

/* Actions haut de page */
.actions,
.page-actions,
.btn-group,
.toolbar,
.client-actions,
.ticket-actions,
.contract-actions,
.loan-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
}

/* Boutons d'action plus homogènes */
.actions .btn,
.page-actions .btn,
.btn-group .btn,
.toolbar .btn,
.client-actions .btn,
.ticket-actions .btn,
.contract-actions .btn,
.loan-actions .btn {
    white-space: nowrap;
}

/* Urgences / priorités */
.badge.urgent,
.status-urgent,
.ticket-urgent,
.priority-urgent,
[class*="urgent"] {
    color: #991b1b !important;
    background: #fee2e2 !important;
    border-color: #fecaca !important;
}

.badge.high,
.status-high,
.priority-high {
    color: #92400e !important;
    background: #fef3c7 !important;
    border-color: #fde68a !important;
}

/* Prêts matériel : intégration plus propre avec V8 */
.loan-page .loan-hero,
.loan-page .loan-filter,
.loan-page .loan-result,
.loan-page .loan-form-card,
.loan-page .loan-card {
    background: rgba(255,255,255,.96) !important;
}

.loan-page .loan-result h2,
.loan-page .loan-card h2 {
    margin-bottom: 4px !important;
}

/* Contrats : blocs plus lisibles */
.contract-inventory-card,
.contract-inventory-link-card,
.isav-contract-box,
.isav-contract-number-card {
    background: rgba(255,255,255,.96) !important;
    border-radius: 20px !important;
}

/* Tickets : avancement/commentaires */
.comment,
.ticket-comment,
.timeline-item,
.progress-item,
.history-item {
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    padding: 12px !important;
    box-shadow: 0 6px 18px rgba(15,23,42,.04) !important;
}

/* Mobile-first : lisibilité et boutons */
@media (max-width: 900px) {
    .page-header,
    .dashboard-header,
    .clients-header,
    .tickets-header,
    .contracts-header,
    .hero,
    .header-card {
        padding: 14px !important;
        border-radius: 18px !important;
    }

    .stats,
    .stats-grid,
    .dashboard-grid,
    .kpi-grid,
    .cards-grid,
    .summary-grid,
    .ticket-stats,
    .client-stats,
    .contract-stats,
    .loan-stats {
        grid-template-columns: 1fr !important;
    }

    .actions,
    .page-actions,
    .btn-group,
    .toolbar,
    .client-actions,
    .ticket-actions,
    .contract-actions,
    .loan-actions {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .actions .btn,
    .page-actions .btn,
    .btn-group .btn,
    .toolbar .btn,
    .client-actions .btn,
    .ticket-actions .btn,
    .contract-actions .btn,
    .loan-actions .btn,
    .actions button,
    .page-actions button,
    .toolbar button {
        width: 100% !important;
        justify-content: center !important;
        text-align: center !important;
    }

    table {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}
/* === ISAV V8 ETAPE 2 PAGES PRIORITAIRES END === */

/* === ISAV V8 ETAPE 3 FINITIONS RESPONSIVE START ===
 * Finitions globales : lisibilité, responsive, alignements et cohérence.
 * Aucun menu, aucune option, aucune donnée n'est modifié.
 */

/* Largeur et respiration générale */
main,
.content,
.page-content,
.app-content,
.container {
    width: 100%;
    box-sizing: border-box;
}

main > *,
.content > *,
.page-content > *,
.app-content > * {
    box-sizing: border-box;
}

/* Espacement vertical plus régulier entre blocs */
.card + .card,
.panel + .panel,
.box + .box,
.widget + .widget,
form + .card,
.card + form,
.table + .card,
.card + .table {
    margin-top: 14px !important;
}

/* Titres et actions alignés proprement */
h1 + .actions,
h1 + .page-actions,
h1 + .toolbar,
h2 + .actions,
h2 + .page-actions,
h2 + .toolbar {
    margin-top: 10px !important;
}

/* Barres de filtres : clients, tickets, contrats, prêts */
.filters,
.filter-bar,
.search-bar,
.table-filters,
.client-filters,
.ticket-filters,
.contract-filters,
.loan-filter {
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.94) !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.05) !important;
    padding: 14px !important;
    margin-bottom: 14px !important;
}

/* Champs de filtre dans une ligne respirante */
.filters form,
.filter-bar form,
.search-bar form,
.table-filters form,
.client-filters form,
.ticket-filters form,
.contract-filters form,
.loan-filter form {
    gap: 10px !important;
    align-items: end !important;
}

/* Pagination homogène */
.pagination,
.pager,
.pages {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    align-items: center !important;
    justify-content: center !important;
    margin-top: 16px !important;
}

.pagination a,
.pagination span,
.pager a,
.pager span,
.pages a,
.pages span {
    min-width: 36px;
    min-height: 36px;
    border-radius: 10px !important;
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    background: #ffffff !important;
    color: #0f172a !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    font-weight: 800 !important;
}

.pagination .active,
.pager .active,
.pages .active,
.pagination a.active,
.pager a.active,
.pages a.active {
    background: #2563eb !important;
    color: #ffffff !important;
    border-color: #2563eb !important;
}

/* Tableaux : coins plus propres et scroll mobile */
.table-wrapper,
.table-responsive,
.data-table,
.table-container {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 18px;
}

table th:first-child {
    border-top-left-radius: 14px;
}

table th:last-child {
    border-top-right-radius: 14px;
}

/* Actions dans les tableaux */
table .btn,
table button,
td .btn,
td button {
    min-height: 34px !important;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
    font-size: 13px !important;
}

/* Badges de statut plus lisibles */
.status,
.badge,
.pill,
.label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 26px;
    padding: 4px 9px;
    line-height: 1.1;
}

.status.open,
.status-ouvert,
.badge.open,
.badge-ouvert {
    background: #dbeafe !important;
    color: #1d4ed8 !important;
}

.status.closed,
.status-cloture,
.status-closed,
.badge.closed,
.badge-cloture {
    background: #dcfce7 !important;
    color: #166534 !important;
}

.status.pending,
.status-attente,
.badge.pending,
.badge-attente {
    background: #fef3c7 !important;
    color: #92400e !important;
}

.status.urgent,
.badge.urgent,
.ticket-urgent,
.priority-urgent {
    background: #fee2e2 !important;
    color: #991b1b !important;
}

/* Uploads et photos */
input[type="file"] {
    padding: 10px !important;
    background: #f8fafc !important;
}

.photo-grid,
.attachments,
.files-list,
.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
}

/* Fiches détail : séparation claire */
.detail-section,
.section-card,
.info-section,
.client-section,
.ticket-section,
.contract-section {
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    border-radius: 18px !important;
    background: rgba(255,255,255,.94) !important;
    padding: 16px !important;
    margin-bottom: 14px !important;
}

/* Commentaires / historique */
.comments,
.history,
.timeline,
.activity-log {
    display: grid;
    gap: 10px;
}

/* Modales si existantes */
.modal,
.dialog,
.popup {
    border-radius: 22px !important;
}

.modal-content,
.dialog-content,
.popup-content {
    border-radius: 22px !important;
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    box-shadow: 0 24px 70px rgba(15,23,42,.22) !important;
}

/* Menus déroulants */
.dropdown,
.dropdown-menu,
.select-menu {
    border-radius: 14px !important;
    border: 1px solid var(--v8-border, #dbe3ef) !important;
    box-shadow: 0 14px 34px rgba(15,23,42,.12) !important;
}

/* Mobile : moins d'effet massif, plus lisible */
@media (max-width: 900px) {
    .filters form,
    .filter-bar form,
    .search-bar form,
    .table-filters form,
    .client-filters form,
    .ticket-filters form,
    .contract-filters form,
    .loan-filter form {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    .card,
    .panel,
    .box,
    .widget,
    .detail-section,
    .section-card,
    .info-section {
        padding: 14px !important;
    }

    h1 {
        font-size: 24px !important;
        line-height: 1.12 !important;
    }

    h2 {
        font-size: 20px !important;
        line-height: 1.15 !important;
    }

    table th,
    table td {
        white-space: nowrap;
    }

    .pagination,
    .pager,
    .pages {
        justify-content: flex-start !important;
        overflow-x: auto;
        padding-bottom: 4px;
    }
}

/* Très petit écran */
@media (max-width: 520px) {
    main,
    .content,
    .page-content,
    .app-content,
    .container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    .card,
    .panel,
    .box,
    .widget {
        border-radius: 14px !important;
    }

    .btn,
    button,
    input[type="submit"],
    input[type="button"] {
        width: 100%;
    }
}
/* === ISAV V8 ETAPE 3 FINITIONS RESPONSIVE END === */

/* === ISAV V8 MENU STABLE RESET FINAL START ===
 * Menu stable, lisible, fonctionnel.
 * Neutralise les anciens essais d’icônes et garantit l’affichage texte + icône.
 */

/* Neutralisation des anciens pseudo-éléments */
.sidebar a::before,
.sidebar a::after,
.side-menu a::before,
.side-menu a::after,
nav.sidebar a::before,
nav.sidebar a::after,
aside a::before,
aside a::after,
.menu a::before,
.menu a::after {
    content: none !important;
    display: none !important;
}

/* Neutralisation des anciens systèmes */
.isav-v7-menu-icon,
.isav-v7-menu-label,
.isav-v8-svg-icon,
.isav-v8-menu-text,
.isav-v8-icon-fixed-color-size,
.isav-menu-clean-icon,
.isav-menu-clean-label {
    display: none !important;
}

/* Liens menu : clairs et stables */
.sidebar a,
.side-menu a,
nav.sidebar a,
aside a,
.menu a {
    display: flex !important;
    align-items: center !important;
    gap: 11px !important;
    width: 100% !important;
    min-height: 38px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    box-sizing: border-box !important;
    text-decoration: none !important;
    overflow: visible !important;
}

/* Icône compacte et lisible */
.sidebar a .isav-menu-stable-icon,
.side-menu a .isav-menu-stable-icon,
nav.sidebar a .isav-menu-stable-icon,
aside a .isav-menu-stable-icon,
.menu a .isav-menu-stable-icon {
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    flex: 0 0 24px !important;
    border-radius: 10px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 13px !important;
    line-height: 1 !important;
    overflow: hidden !important;
    color: #ffffff !important;
    box-sizing: border-box !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.20), 0 7px 14px rgba(0,0,0,.14) !important;
}

/* Libellé toujours visible */
.sidebar a .isav-menu-stable-label,
.side-menu a .isav-menu-stable-label,
nav.sidebar a .isav-menu-stable-label,
aside a .isav-menu-stable-label,
.menu a .isav-menu-stable-label {
    display: inline-block !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    color: inherit !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    overflow: visible !important;
}

/* Couleurs premium */
.isav-menu-stable-dashboard { background: linear-gradient(135deg, #38bdf8, #2563eb) !important; }
.isav-menu-stable-loans { background: linear-gradient(135deg, #fb923c, #ea580c) !important; }
.isav-menu-stable-clients { background: linear-gradient(135deg, #a78bfa, #7c3aed) !important; }
.isav-menu-stable-tickets { background: linear-gradient(135deg, #facc15, #d97706) !important; }
.isav-menu-stable-contracts { background: linear-gradient(135deg, #c4b5fd, #4f46e5) !important; }
.isav-menu-stable-sms { background: linear-gradient(135deg, #f0abfc, #c026d3) !important; }
.isav-menu-stable-technicians { background: linear-gradient(135deg, #fb7185, #e11d48) !important; }
.isav-menu-stable-search { background: linear-gradient(135deg, #60a5fa, #2563eb) !important; }
.isav-menu-stable-space { background: linear-gradient(135deg, #34d399, #059669) !important; }
.isav-menu-stable-health { background: linear-gradient(135deg, #22d3ee, #0891b2) !important; }
.isav-menu-stable-activity { background: linear-gradient(135deg, #f59e0b, #b45309) !important; }
.isav-menu-stable-rights { background: linear-gradient(135deg, #fbbf24, #d97706) !important; }
.isav-menu-stable-employees { background: linear-gradient(135deg, #818cf8, #4f46e5) !important; }
.isav-menu-stable-logout { background: linear-gradient(135deg, #fb923c, #ef4444) !important; }

/* Survol discret */
.sidebar a:hover .isav-menu-stable-icon,
.side-menu a:hover .isav-menu-stable-icon,
nav.sidebar a:hover .isav-menu-stable-icon,
aside a:hover .isav-menu-stable-icon,
.menu a:hover .isav-menu-stable-icon {
    transform: translateY(-1px);
}

/* Mobile */
@media (max-width: 900px) {
    .sidebar a,
    .side-menu a,
    nav.sidebar a,
    aside a,
    .menu a {
        min-height: 38px !important;
        gap: 10px !important;
    }

    .sidebar a .isav-menu-stable-icon,
    .side-menu a .isav-menu-stable-icon,
    nav.sidebar a .isav-menu-stable-icon,
    aside a .isav-menu-stable-icon,
    .menu a .isav-menu-stable-icon {
        width: 23px !important;
        min-width: 23px !important;
        max-width: 23px !important;
        height: 23px !important;
        min-height: 23px !important;
        max-height: 23px !important;
        flex-basis: 23px !important;
        font-size: 12px !important;
    }
}
/* === ISAV V8 MENU STABLE RESET FINAL END === */

/* === ISAV V8 FIX ICONES PRET DECONNEXION START ===
 * Correction ciblée des icônes Prêts matériel et Déconnexion.
 */
.sidebar a .isav-menu-twofix-icon,
.side-menu a .isav-menu-twofix-icon,
nav.sidebar a .isav-menu-twofix-icon,
aside a .isav-menu-twofix-icon,
.menu a .isav-menu-twofix-icon {
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    flex: 0 0 24px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    line-height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

.sidebar a .isav-menu-twofix-icon svg,
.side-menu a .isav-menu-twofix-icon svg,
nav.sidebar a .isav-menu-twofix-icon svg,
aside a .isav-menu-twofix-icon svg,
.menu a .isav-menu-twofix-icon svg {
    width: 15px !important;
    min-width: 15px !important;
    max-width: 15px !important;
    height: 15px !important;
    min-height: 15px !important;
    max-height: 15px !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    fill: none !important;
    stroke: #ffffff !important;
    stroke-width: 2.2 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}

.sidebar a .isav-menu-twofix-label,
.side-menu a .isav-menu-twofix-label,
nav.sidebar a .isav-menu-twofix-label,
aside a .isav-menu-twofix-label,
.menu a .isav-menu-twofix-label {
    display: inline-block !important;
    line-height: 1.15 !important;
    min-width: 0 !important;
    color: inherit !important;
}

/* Couleurs propres et fixes */
.isav-menu-stable-loans.isav-menu-twofix-icon {
    background: linear-gradient(135deg, #fb923c, #ea580c) !important;
    color: #ffffff !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.20), 0 7px 14px rgba(0,0,0,.14) !important;
}

.isav-menu-stable-logout.isav-menu-twofix-icon {
    background: linear-gradient(135deg, #fb923c, #ef4444) !important;
    color: #ffffff !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.20), 0 7px 14px rgba(0,0,0,.14) !important;
}
/* === ISAV V8 FIX ICONES PRET DECONNEXION END === */



/* === ISAV V8 FIX ENTOURAGE MENU BOUTONS START ===
 * Retire les contours / rings / ombres parasites des boutons du menu.
 * Garde le menu fonctionnel et lisible.
 */

/* Liens du menu : pas d'entourage parasite */
.sidebar a,
.side-menu a,
nav.sidebar a,
aside a,
.menu a {
    outline: none !important;
    box-shadow: none !important;
    border: 0 !important;
    -webkit-tap-highlight-color: transparent !important;
}

/* Focus accessible mais discret, pas de gros contour */
.sidebar a:focus,
.sidebar a:focus-visible,
.side-menu a:focus,
.side-menu a:focus-visible,
nav.sidebar a:focus,
nav.sidebar a:focus-visible,
aside a:focus,
aside a:focus-visible,
.menu a:focus,
.menu a:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    background: rgba(255,255,255,.08) !important;
}

/* Boutons / icônes internes du menu : pas de contour ni d'effet bouton */
.sidebar a .isav-menu-stable-icon,
.sidebar a .isav-mobile-clean-icon,
.sidebar a .isav-menu-twofix-icon,
.side-menu a .isav-menu-stable-icon,
.side-menu a .isav-mobile-clean-icon,
.side-menu a .isav-menu-twofix-icon,
nav.sidebar a .isav-menu-stable-icon,
nav.sidebar a .isav-mobile-clean-icon,
nav.sidebar a .isav-menu-twofix-icon,
aside a .isav-menu-stable-icon,
aside a .isav-mobile-clean-icon,
aside a .isav-menu-twofix-icon,
.menu a .isav-menu-stable-icon,
.menu a .isav-mobile-clean-icon,
.menu a .isav-menu-twofix-icon {
    outline: none !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* Prêts matériel / Déconnexion : icône plus sobre, sans entourage fort */
.sidebar a .isav-mobile-clean-loans,
.side-menu a .isav-mobile-clean-loans,
nav.sidebar a .isav-mobile-clean-loans,
aside a .isav-mobile-clean-loans,
.menu a .isav-mobile-clean-loans,
.sidebar a .isav-menu-stable-loans,
.side-menu a .isav-menu-stable-loans,
nav.sidebar a .isav-menu-stable-loans,
aside a .isav-menu-stable-loans,
.menu a .isav-menu-stable-loans {
    background: linear-gradient(135deg, #fb923c, #ea580c) !important;
    box-shadow: none !important;
}

.sidebar a .isav-mobile-clean-logout,
.side-menu a .isav-mobile-clean-logout,
nav.sidebar a .isav-mobile-clean-logout,
aside a .isav-mobile-clean-logout,
.menu a .isav-mobile-clean-logout,
.sidebar a .isav-menu-stable-logout,
.side-menu a .isav-menu-stable-logout,
nav.sidebar a .isav-menu-stable-logout,
aside a .isav-menu-stable-logout,
.menu a .isav-menu-stable-logout {
    background: linear-gradient(135deg, #fb923c, #ef4444) !important;
    box-shadow: none !important;
}

/* Survol discret */
.sidebar a:hover,
.side-menu a:hover,
nav.sidebar a:hover,
aside a:hover,
.menu a:hover {
    box-shadow: none !important;
}

.sidebar a:hover .isav-menu-stable-icon,
.sidebar a:hover .isav-mobile-clean-icon,
.sidebar a:hover .isav-menu-twofix-icon,
.side-menu a:hover .isav-menu-stable-icon,
.side-menu a:hover .isav-mobile-clean-icon,
.side-menu a:hover .isav-menu-twofix-icon,
nav.sidebar a:hover .isav-menu-stable-icon,
nav.sidebar a:hover .isav-mobile-clean-icon,
nav.sidebar a:hover .isav-menu-twofix-icon,
aside a:hover .isav-menu-stable-icon,
aside a:hover .isav-mobile-clean-icon,
aside a:hover .isav-menu-twofix-icon,
.menu a:hover .isav-menu-stable-icon,
.menu a:hover .isav-mobile-clean-icon,
.menu a:hover .isav-menu-twofix-icon {
    transform: none !important;
    box-shadow: none !important;
}
/* === ISAV V8 FIX ENTOURAGE MENU BOUTONS END === */





/* === ISAV V8 HIDE BLUE MOBILE MENU FORCE START ===
 * Masquage forcé de l'ancien bouton bleu Menu mobile.
 * Le bouton blanc #isavMobileMenuButton reste actif.
 */
@media (max-width: 900px) {
    .isav-force-hide-old-mobile-menu,
    .mobile-menu-toggle:not(#isavMobileMenuButton),
    .mobile-menu-button:not(#isavMobileMenuButton):not(.isav-mobile-menu-button),
    .menu-toggle:not(#isavMobileMenuButton),
    .sidebar-toggle:not(#isavMobileMenuButton),
    .hamburger:not(#isavMobileMenuButton),
    .hamburger-menu:not(#isavMobileMenuButton),
    .nav-toggle:not(#isavMobileMenuButton),
    .navbar-toggler:not(#isavMobileMenuButton),
    button[aria-label="Menu"]:not(#isavMobileMenuButton),
    button[title="Menu"]:not(#isavMobileMenuButton) {
        display: none !important;
        visibility: hidden !important;
        pointer-events: none !important;
        width: 0 !important;
        min-width: 0 !important;
        max-width: 0 !important;
        height: 0 !important;
        min-height: 0 !important;
        max-height: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
        opacity: 0 !important;
    }

    #isavMobileMenuButton,
    body.isav-mobile-menu-ready #isavMobileMenuButton {
        display: inline-flex !important;
        visibility: visible !important;
        pointer-events: auto !important;
        opacity: 1 !important;
        width: auto !important;
        min-width: auto !important;
        max-width: none !important;
        height: 40px !important;
        min-height: 40px !important;
        max-height: 40px !important;
    }
}
/* === ISAV V8 HIDE BLUE MOBILE MENU FORCE END === */

/* === ISAV V8 FINAL REPAIR MENU PRETS LOGIN START === */

/* Menu propre */
.sidebar .brand {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.sidebar .menu,
.sidebar nav.menu {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.sidebar .menu-link,
.sidebar nav.menu a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 40px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    outline: none !important;
    border: 0 !important;
    box-shadow: none !important;
}

.sidebar .menu-link:hover,
.sidebar .menu-link.active,
.sidebar nav.menu a:hover {
    background: rgba(255,255,255,.08) !important;
}

.sidebar .menu-icon {
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    flex: 0 0 24px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    line-height: 1 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.sidebar .menu-title {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    opacity: .85 !important;
    margin: 8px 10px 6px !important;
}

/* Neutralise les anciennes classes cassées uniquement dans la sidebar */
.sidebar .isav-menu-stable-icon,
.sidebar .isav-mobile-clean-icon,
.sidebar .isav-menu-plain-icon,
.sidebar .isav-menu-twofix-icon,
.sidebar .isav-v8-svg-icon,
.sidebar .isav-v7-menu-icon {
    display: none !important;
}

/* Page Prêts matériel : labels propres */
.isav-loans-page-label {
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1.15 !important;
    font-weight: 800 !important;
}

/* Login : aucun menu affiché */
body.isav-login-page .sidebar,
body.isav-login-page nav.sidebar,
body.isav-login-page aside.sidebar,
body.isav-login-page .side-menu,
body.isav-login-page .menu,
body.isav-login-page #isavMobileMenuButton,
body.isav-login-page .isav-mobile-menu-button,
body.isav-login-page #isavMobileMenuOverlay,
body.isav-login-page .isav-mobile-menu-overlay {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* Login premium */
body.isav-login-page {
    min-height: 100vh !important;
    background:
        radial-gradient(circle at top left, rgba(37,99,235,.22), transparent 34%),
        radial-gradient(circle at bottom right, rgba(14,165,233,.18), transparent 34%),
        linear-gradient(135deg, #eef6ff 0%, #f8fbff 50%, #eef2ff 100%) !important;
}

body.isav-login-page main,
body.isav-login-page .content,
body.isav-login-page .page-content,
body.isav-login-page .app-content,
body.isav-login-page .container {
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100vh !important;
    display: grid !important;
    place-items: center !important;
    padding: 24px !important;
    box-sizing: border-box !important;
}

/* Mobile menu stable */
.isav-mobile-menu-button,
.isav-mobile-menu-overlay {
    display: none;
}

@media (max-width: 900px) {
    body.isav-mobile-menu-ready {
        padding-top: 56px !important;
        overflow-x: hidden !important;
    }

    body.isav-mobile-menu-ready .isav-mobile-menu-button {
        display: inline-flex !important;
        position: fixed !important;
        top: 10px !important;
        left: 10px !important;
        z-index: 10050 !important;
        height: 40px !important;
        align-items: center !important;
        gap: 8px !important;
        border: 1px solid rgba(37,99,235,.18) !important;
        border-radius: 14px !important;
        padding: 0 13px !important;
        background: rgba(255,255,255,.96) !important;
        color: #0f172a !important;
        box-shadow: 0 12px 28px rgba(15,23,42,.18) !important;
        font-family: Arial, system-ui, sans-serif !important;
        font-size: 14px !important;
        cursor: pointer !important;
    }

    body.isav-mobile-menu-ready .isav-mobile-menu-button strong {
        font-size: 13px !important;
        font-weight: 900 !important;
    }

    body.isav-mobile-menu-ready .isav-mobile-menu-overlay {
        display: none !important;
        position: fixed !important;
        inset: 0 !important;
        z-index: 10030 !important;
        background: rgba(15,23,42,.34) !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    body.isav-mobile-menu-open .isav-mobile-menu-overlay {
        display: block !important;
    }

    body.isav-mobile-menu-ready .isav-mobile-menu-target {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: min(84vw, 320px) !important;
        max-width: 320px !important;
        height: 100vh !important;
        z-index: 10040 !important;
        transform: translateX(-112%) !important;
        transition: transform .22s ease !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        filter: none !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        box-shadow: 18px 0 45px rgba(15,23,42,.22) !important;
    }

    body.isav-mobile-menu-open .isav-mobile-menu-target {
        transform: translateX(0) !important;
    }

    body.isav-mobile-menu-open .isav-mobile-menu-target,
    body.isav-mobile-menu-open .isav-mobile-menu-target * {
        filter: none !important;
        -webkit-filter: none !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    body.isav-mobile-menu-ready main,
    body.isav-mobile-menu-ready .content,
    body.isav-mobile-menu-ready .page-content,
    body.isav-mobile-menu-ready .app-content,
    body.isav-mobile-menu-ready .container {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }
}
/* === ISAV V8 FINAL REPAIR MENU PRETS LOGIN END === */

/* === ISAV V8 RESTORE FULL MENU MAIN START === */
.sidebar .menu,
.sidebar nav.menu {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.sidebar .menu-link,
.sidebar nav.menu a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 40px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    outline: none !important;
    border: 0 !important;
    box-shadow: none !important;
}

.sidebar .menu-link:hover,
.sidebar .menu-link.active {
    background: rgba(255,255,255,.08) !important;
}

.sidebar .menu-icon,
.sidebar .menu-link .menu-icon {
    width: 24px !important;
    min-width: 24px !important;
    height: 24px !important;
    flex: 0 0 24px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    line-height: 1 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.sidebar .menu-title {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    opacity: .85 !important;
    margin: 8px 10px 6px !important;
}
/* === ISAV V8 RESTORE FULL MENU MAIN END === */

/* === ISAV V8 SLA TICKETS COUNTER START === */
.isav-sla-counter-panel{margin:16px 0 20px;padding:16px;border:1px solid rgba(148,163,184,.24);border-radius:20px;background:rgba(255,255,255,.82);box-shadow:0 16px 42px rgba(15,23,42,.08)}
.isav-sla-counter-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.isav-sla-counter-head strong{display:block;font-size:18px;color:#0f172a}
.isav-sla-counter-head span{display:block;color:#64748b;font-size:13px;margin-top:2px}
.isav-sla-counter-grid{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px}
.isav-sla-counter-card{border-radius:16px;padding:14px;border:1px solid rgba(148,163,184,.22);background:#f8fafc}
.isav-sla-counter-card span{display:block;font-size:28px;line-height:1;font-weight:950;color:#0f172a}
.isav-sla-counter-card small{display:block;margin-top:6px;color:#64748b;font-weight:800}
.isav-sla-counter-card.late{background:#fee2e2;border-color:#fecaca}
.isav-sla-counter-card.today{background:#ffedd5;border-color:#fed7aa}
.isav-sla-counter-card.soon{background:#fef3c7;border-color:#fde68a}
.isav-sla-counter-card.none{background:#e2e8f0;border-color:#cbd5e1}
.isav-sla-upcoming{margin-top:12px;display:grid;gap:8px}
.isav-sla-line{display:flex;justify-content:space-between;gap:12px;align-items:center;border-radius:14px;padding:10px 12px;background:#f8fafc;border:1px solid rgba(148,163,184,.22)}
.isav-sla-line span{min-width:0;color:#334155;font-weight:800}
.isav-sla-line strong{white-space:nowrap;font-weight:950}
.isav-sla-line.late strong{color:#dc2626}
.isav-sla-line.soon strong{color:#d97706}
.isav-sla-line.ok strong{color:#16a34a}
.isav-sla-create-box{margin:16px 0;padding:16px;border-radius:18px;border:1px solid rgba(37,99,235,.18);background:#eff6ff}
.isav-sla-create-box h3{margin:0 0 6px;color:#0f172a}
.isav-sla-create-box p{margin:0 0 12px;color:#475569}
.isav-sla-create-box label{display:grid;gap:6px;font-weight:800;color:#334155}
.isav-sla-create-box select,.isav-sla-create-box input{min-height:40px;border-radius:12px;border:1px solid rgba(148,163,184,.35);padding:0 10px;background:white}
.isav-sla-manual-grid{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:10px;margin-top:10px}
@media(max-width:760px){.isav-sla-counter-grid,.isav-sla-manual-grid{grid-template-columns:1fr}.isav-sla-line{align-items:flex-start;flex-direction:column}}
/* === ISAV V8 SLA TICKETS COUNTER END === */

/* === ISAV V8 TICKET SLA EDIT START === */
.isav-ticket-sla-edit-card {
    margin: 16px 0 20px;
    padding: 16px;
    border: 1px solid rgba(37,99,235,.18);
    border-radius: 20px;
    background: rgba(255,255,255,.9);
    box-shadow: 0 16px 42px rgba(15,23,42,.08);
}

.isav-ticket-sla-edit-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 12px;
}

.isav-ticket-sla-edit-head strong {
    display: block;
    font-size: 18px;
    color: #0f172a;
}

.isav-ticket-sla-edit-head span {
    display: block;
    color: #64748b;
    font-size: 13px;
    margin-top: 2px;
}

.isav-ticket-sla-status {
    border-radius: 999px;
    padding: 8px 12px;
    font-weight: 950;
    white-space: nowrap;
    background: #e2e8f0;
    color: #334155;
}

.isav-ticket-sla-status.ok {
    background: #dcfce7;
    color: #166534;
}

.isav-ticket-sla-status.soon {
    background: #fef3c7;
    color: #92400e;
}

.isav-ticket-sla-status.late {
    background: #fee2e2;
    color: #991b1b;
}

.isav-ticket-sla-alert {
    margin: 10px 0;
    padding: 10px 12px;
    border-radius: 14px;
    font-weight: 800;
}

.isav-ticket-sla-alert.ok {
    background: #dcfce7;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.isav-ticket-sla-alert.error {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.isav-ticket-sla-current {
    display: grid;
    grid-template-columns: repeat(4, minmax(130px, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.isav-ticket-sla-current div {
    padding: 12px;
    border-radius: 16px;
    background: #f8fafc;
    border: 1px solid rgba(148,163,184,.22);
}

.isav-ticket-sla-current small {
    display: block;
    color: #64748b;
    font-weight: 800;
    margin-bottom: 4px;
}

.isav-ticket-sla-current strong {
    display: block;
    color: #0f172a;
    font-weight: 950;
}

.isav-ticket-sla-form {
    display: grid;
    gap: 12px;
}

.isav-ticket-sla-form label {
    display: grid;
    gap: 6px;
    color: #334155;
    font-weight: 800;
}

.isav-ticket-sla-form select,
.isav-ticket-sla-form input {
    min-height: 42px;
    border-radius: 12px;
    border: 1px solid rgba(148,163,184,.35);
    padding: 0 10px;
    background: #fff;
    color: #0f172a;
}

.isav-ticket-sla-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(160px, 1fr));
    gap: 10px;
}

.isav-ticket-sla-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.isav-ticket-sla-actions button {
    min-height: 42px;
    border: 0;
    border-radius: 12px;
    padding: 0 16px;
    font-weight: 950;
    color: white;
    background: linear-gradient(135deg, #2563eb, #06b6d4);
    cursor: pointer;
}

.isav-ticket-sla-actions small {
    color: #64748b;
    font-weight: 700;
}

@media (max-width: 760px) {
    .isav-ticket-sla-edit-head,
    .isav-ticket-sla-actions {
        align-items: flex-start;
        flex-direction: column;
    }

    .isav-ticket-sla-current,
    .isav-ticket-sla-grid {
        grid-template-columns: 1fr;
    }
}
/* === ISAV V8 TICKET SLA EDIT END === */

/* === ISAV V8 MOBILE RESPONSIVE AUDIT START === */
/*
 * Bloc responsive officiel V8.
 * Sert aussi de repère pour l'audit : @media max-width.
 * Ne change pas les données, uniquement l'adaptation mobile.
 */

@media (max-width: 900px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    .app,
    .layout,
    .main,
    .main-content,
    .content,
    .page-content,
    .app-content {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }

    .main-content,
    .content,
    .page-content,
    .app-content {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .sidebar {
        max-width: 86vw !important;
    }

    table {
        max-width: 100%;
    }

    .table-responsive,
    .table-wrap,
    .responsive-table {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .card,
    .panel,
    .box,
    .loan-card,
    .loan-hero,
    .loan-filter,
    .loan-result,
    .isav-sla-counter-panel,
    .isav-ticket-sla-edit-card {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .grid,
    .cards,
    .loan-grid,
    .loan-stats,
    .dashboard-grid,
    .stats-grid,
    .isav-sla-counter-grid,
    .isav-ticket-sla-current,
    .isav-ticket-sla-grid {
        grid-template-columns: 1fr !important;
    }

    form,
    .form,
    .form-grid,
    .filters,
    .actions,
    .button-row,
    .btn-row {
        max-width: 100% !important;
        flex-wrap: wrap !important;
    }

    input,
    select,
    textarea,
    button,
    .btn {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    img,
    video,
    canvas {
        max-width: 100% !important;
        height: auto !important;
    }
}

@media (max-width: 640px) {
    h1 {
        font-size: 24px !important;
        line-height: 1.15 !important;
    }

    h2 {
        font-size: 20px !important;
        line-height: 1.2 !important;
    }

    .btn,
    button,
    input[type="submit"] {
        min-height: 42px;
    }

    .isav-sla-line,
    .isav-ticket-sla-edit-head,
    .isav-ticket-sla-actions {
        align-items: flex-start !important;
        flex-direction: column !important;
    }
}
/* === ISAV V8 MOBILE RESPONSIVE AUDIT END === */

/* === ISAV V8 CONTRACT ACTIONS FIX START === */
.isav-contract-actions-fixed {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.isav-contract-actions-fixed .btn,
.isav-contract-actions-fixed a {
    min-height: 34px;
    border-radius: 12px;
    padding: 8px 12px;
    font-weight: 900;
    text-decoration: none;
    line-height: 1;
    white-space: nowrap;
}

.isav-contract-action-open {
    background: #ffffff !important;
    color: #0f172a !important;
    border: 1px solid rgba(148,163,184,.35) !important;
    box-shadow: none !important;
}

.isav-contract-action-edit {
    background: linear-gradient(135deg, #2563eb, #4f46e5) !important;
    color: #ffffff !important;
    border: 0 !important;
    box-shadow: 0 10px 25px rgba(37,99,235,.20) !important;
}

@media (max-width: 900px) {
    .isav-contract-actions-fixed {
        width: 100%;
    }

    .isav-contract-actions-fixed .btn,
    .isav-contract-actions-fixed a {
        flex: 1 1 auto;
        justify-content: center;
        text-align: center;
    }
}
/* === ISAV V8 CONTRACT ACTIONS FIX END === */

/* === ISAV V8 MOBILE AUDIT MARKER START === */
/*
 * Bloc mobile officiel détectable par l'audit V8.
 * Contient volontairement plusieurs syntaxes max-width pour compatibilité audit.
 */

@media screen and (max-width: 900px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    .app,
    .layout,
    .main,
    .main-content,
    .content,
    .page-content,
    .app-content {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }

    .main-content,
    .content,
    .page-content,
    .app-content {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .grid,
    .cards,
    .dashboard-grid,
    .stats-grid,
    .loan-grid,
    .loan-stats,
    .isav-ticket-sla-current,
    .isav-ticket-sla-grid {
        grid-template-columns: 1fr !important;
    }

    .table-responsive,
    .table-wrap,
    .responsive-table {
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    table {
        max-width: 100%;
    }

    img,
    video,
    canvas {
        max-width: 100% !important;
        height: auto !important;
    }

    input,
    select,
    textarea,
    button,
    .btn {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
}

@media (max-width: 640px) {
    h1 {
        font-size: 24px !important;
        line-height: 1.15 !important;
    }

    h2 {
        font-size: 20px !important;
        line-height: 1.2 !important;
    }

    .actions,
    .button-row,
    .btn-row {
        flex-wrap: wrap !important;
    }
}
/* === ISAV V8 MOBILE AUDIT MARKER END === */
