/* ============================================================================
   Weeks PRO — Refonte TOTALE du site prestataire (couche chargée en dernier)
   Marque = bleu marine du logo (#181839 / #101132). Aucun turquoise.
   Coquille premium : sidebar marine foncée pleine hauteur + topbar blanche +
   contenu clair. Composants modernes (cartes, boutons, formulaires, tableaux).
   ============================================================================ */
:root {
  --wk-navy: #181839;
  --wk-navy-deep: #101132;
  --wk-navy-mid: #23244f;
  --wk-blue: #3d5afe;
  --wk-blue-dark: #2a3eea;
  --wk-blue-soft: #eef1ff;
  --wk-bg: #eef1f8;
  --wk-surface: #ffffff;
  --wk-line: #e7ebf3;
  --wk-ink: #0f1330;
  --wk-muted: #5a6485;
  --wk-faint: #9aa3bd;
  --wk-radius: 20px;
  --wk-radius-sm: 14px;
  --wk-sidebar: 266px;
  --wk-sidebar-mini: 86px;
  --wk-shadow: 0 14px 34px -16px rgba(24, 24, 57, .18), 0 3px 8px rgba(24, 24, 57, .05);
  --wk-shadow-strong: 0 22px 44px -16px rgba(24, 24, 57, .34);
  --wk-grad: linear-gradient(180deg, #1c1c46 0%, #15153a 55%, #101132 100%);
  --wk-grad-blue: linear-gradient(135deg, var(--wk-blue) 0%, var(--wk-blue-dark) 100%);
}

* { -webkit-font-smoothing: antialiased; }
body { background: var(--wk-bg); color: var(--wk-ink); }
.content-page { background: var(--wk-bg); min-height: 100vh; }

/* ===========================================================================
   BARRE LATÉRALE — marine foncée, pleine hauteur, avec libellés
   =========================================================================== */
.leftside-menu {
  background: var(--wk-grad) !important;
  border: none !important;
  box-shadow: 6px 0 30px -18px rgba(16, 17, 50, .7);
}
.kd-side-navbar-wrap {
  height: 100vh;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 0 !important;
  gap: 0 !important;
  background: var(--wk-grad) !important;
}
.kd-wkbrand {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 24px 20px 14px !important;
  margin-bottom: 6px;
}
.kd-wkbrand img {
  filter: brightness(0) invert(1);
  max-height: 38px;
  width: auto;
  transition: max-height .2s ease;
}
.kd-main-sidenav {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0 !important;
}
.kd-side-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  list-style: none;
  margin: 0;
  padding: 6px 12px !important;
}
.kd-side-nav::-webkit-scrollbar { width: 6px; }
.kd-side-nav::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, .14); border-radius: 10px; }
.kd-side-nav li { margin: 0; }
.kd-side-nav li a {
  display: flex !important;
  align-items: center;
  gap: 14px;
  color: rgba(255, 255, 255, .72) !important;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  padding: 12px 14px !important;
  margin: 4px 0;
  border-radius: 14px;
  white-space: nowrap;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.kd-side-nav li a i,
.kd-side-nav li a .mdi { font-size: 21px; min-width: 22px; text-align: center; color: rgba(255, 255, 255, .85); transition: color .18s ease; }
.kd-side-nav li a span { display: inline !important; }
.kd-side-nav li a:hover {
  background: rgba(255, 255, 255, .08) !important;
  color: #fff !important;
  transform: translateX(2px);
}
.kd-side-nav li a:hover i { color: #fff; }
.kd-side-nav li a.active,
.kd-side-nav li a.nav-active {
  background: var(--wk-grad-blue) !important;
  color: #fff !important;
  box-shadow: 0 12px 24px -10px rgba(61, 90, 254, .65);
}
.kd-side-nav li a.active i,
.kd-side-nav li a.nav-active i,
.kd-side-nav li a.active .mdi,
.kd-side-nav li a.nav-active .mdi { color: #fff !important; }

/* Carte profil + déconnexion (bas de sidebar) */
.kdgrant-pro-wrap {
  margin: 10px 14px 16px;
  padding: 12px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.kdgrant-proinner { display: flex; align-items: center; gap: 10px; min-width: 0; }
.kdgrant-img { display: block !important; }
.kdgrant-img img { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255, 255, 255, .35); }
.kdgrant-info { min-width: 0; }
.kdgrant-info h5 { color: #fff !important; font-weight: 700; font-size: 14px; margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kdgrant-info span { color: rgba(255, 255, 255, .55) !important; font-size: 12px; }
.kdgrant-pro-wrap > a svg path { fill: rgba(255, 255, 255, .85) !important; }
.kdgrant-pro-wrap > a:hover svg path { fill: #fff !important; }

/* ===========================================================================
   BARRE DU HAUT — blanche, épurée
   =========================================================================== */
.kd-topnavbar,
.navbar-custom {
  background: var(--wk-surface) !important;
  box-shadow: 0 4px 20px -12px rgba(24, 24, 57, .25);
  border-bottom: 1px solid var(--wk-line);
}
.kd-topnavbar { padding: 14px 28px !important; }
.kd-topnavbar h1 {
  color: var(--wk-ink) !important;
  font-weight: 800 !important;
  letter-spacing: -.2px;
  font-size: 22px !important;
  text-transform: none;
}
/* recolorer les icônes (svg en blanc à l'origine) vers le marine */
.kd-topnavbar .kd-sidebar-toggle-btn svg path,
.kd-topnavbar #kd-hamburger svg path,
.kd-topnavbar #kd-hamburger-close svg path { fill: var(--wk-navy) !important; }
.kd-topnavbar .notify-link svg path { stroke: var(--wk-navy) !important; }
.kd-sidebar-toggle-btn { background: var(--wk-blue-soft); border: none; border-radius: 12px; width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; }
.kd-notfi-list .notify-link { background: var(--wk-blue-soft); border-radius: 12px; width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; }
.kd-accnt-avtarimg img { border: 2px solid var(--wk-line); border-radius: 50%; width: 44px; height: 44px; object-fit: cover; }

/* ===========================================================================
   POSITIONNEMENT (desktop) — sidebar fixe large + contenu décalé
   =========================================================================== */
@media (min-width: 992px) {
  .leftside-menu {
    position: fixed; top: 0; left: 0; bottom: 0;
    height: 100vh !important;
    width: var(--wk-sidebar) !important;
    display: block !important;
    overflow: visible;
    z-index: 1031;
  }
  .navbar-custom, .content-page { margin-left: var(--wk-sidebar) !important; transition: margin-left .22s ease; }
  .navbar-custom { position: sticky; top: 0; z-index: 1030; }
  .content-page { padding: 26px 30px !important; }

  /* État réduit (clic sur le bouton bascule) : icônes seules */
  body.sidebar-expanded .leftside-menu { width: var(--wk-sidebar-mini) !important; }
  body.sidebar-expanded .navbar-custom,
  body.sidebar-expanded .content-page { margin-left: var(--wk-sidebar-mini) !important; }
  body.sidebar-expanded .kdgrant-info { display: none !important; }
  body.sidebar-expanded .kd-side-nav { overflow: visible !important; }
  body.sidebar-expanded .kd-side-nav li a { justify-content: flex-start; position: relative; }
  /* Libellé caché en mode réduit, affiché en info-bulle au survol */
  body.sidebar-expanded .kd-side-nav li a span { display: none !important; }
  body.sidebar-expanded .kd-side-nav li a:hover span {
    display: block !important;
    position: absolute; left: calc(100% + 14px); top: 50%; transform: translateY(-50%);
    background: var(--wk-navy-deep); color: #fff; padding: 9px 14px; border-radius: 12px;
    white-space: nowrap; font-size: 13px; font-weight: 700; z-index: 1200;
    box-shadow: 0 12px 28px -8px rgba(0, 0, 0, .55); pointer-events: none;
  }
  body.sidebar-expanded .kd-side-nav li a:hover span::before {
    content: ""; position: absolute; left: -5px; top: 50%; transform: translateY(-50%) rotate(45deg);
    width: 10px; height: 10px; background: var(--wk-navy-deep);
  }
  body.sidebar-expanded .kdgrant-pro-wrap { justify-content: center; }
  body.sidebar-expanded .kd-wkbrand { justify-content: center; padding-left: 16px !important; padding-right: 16px !important; }
  body.sidebar-expanded .kd-wkbrand img { max-height: 26px; max-width: 56px; object-fit: contain; }
}

/* Mobile : sidebar coulissante */
@media (max-width: 991.98px) {
  .leftside-menu {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--wk-sidebar) !important;
    transform: translateX(-100%);
    transition: transform .25s ease;
    z-index: 1050;
    display: block !important;
  }
  .leftside-menu.menuitem-active { transform: translateX(0); }
  .navbar-custom, .content-page { margin-left: 0 !important; }
}

/* ===========================================================================
   COMPOSANTS
   =========================================================================== */
.pdb-card, .card, .kd-card {
  border-radius: var(--wk-radius) !important;
  box-shadow: var(--wk-shadow) !important;
  border: none !important;
  background: var(--wk-surface);
}
.pdb-card:hover, .card:hover { box-shadow: var(--wk-shadow-strong) !important; }

/* Boutons d'action (tableau de bord) */
.pdb-action-btn {
  background: var(--wk-grad) !important;
  border-radius: var(--wk-radius) !important;
  box-shadow: 0 16px 30px -16px rgba(24, 24, 57, .6);
  transition: transform .18s ease, box-shadow .18s ease;
}
.pdb-action-btn:hover { transform: translateY(-4px); box-shadow: var(--wk-shadow-strong); }
.pdb-action-icon i { color: #fff; }
.pdb-section-label, .pdb-sec-title, .pdb-earning-title, .pdb-earning-amt { color: var(--wk-navy) !important; }
.pdb-tab.active { background: var(--wk-blue-soft) !important; color: var(--wk-navy) !important; }

/* Titres de page (h2/h3 dans le contenu) */
.content-page h2 { font-weight: 800; color: var(--wk-ink); letter-spacing: -.3px; }

/* Boutons principaux */
.verify-btn, .btn-primary, .modal-btn-yes, .kd-savebtn, .btn-dark, .btn-weeks,
button[type="submit"].btn, .btn-success {
  background: var(--wk-grad) !important;
  border: none !important;
  border-radius: 14px !important;
  font-weight: 700 !important;
  color: #fff !important;
  box-shadow: 0 14px 26px -16px rgba(24, 24, 57, .55);
  transition: filter .15s ease, transform .15s ease;
}
.verify-btn:hover, .btn-primary:hover, .modal-btn-yes:hover, .kd-savebtn:hover,
.btn-dark:hover, button[type="submit"].btn:hover { filter: brightness(1.1); transform: translateY(-1px); color: #fff !important; }

.btn-outline-primary, .modal-btn-no, .btn-light {
  border: 1.5px solid var(--wk-line) !important;
  color: var(--wk-navy) !important;
  border-radius: 14px !important;
  font-weight: 700 !important;
  background: #fff !important;
}
.btn-outline-primary:hover, .modal-btn-no:hover { background: var(--wk-blue-soft) !important; }

a { color: var(--wk-navy); }
.text-primary, .pdb-view-all { color: var(--wk-blue) !important; }

/* Formulaires */
.form-control, .form-select, input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="tel"], input[type="search"], input[type="date"], textarea, select {
  border-radius: var(--wk-radius-sm) !important;
  border: 1px solid var(--wk-line) !important;
  background: #fff;
  padding: .65rem .9rem;
}
.form-control:focus, .form-select:focus, textarea:focus, select:focus, input:focus {
  border-color: var(--wk-blue) !important;
  box-shadow: 0 0 0 3px rgba(61, 90, 254, .15) !important;
  outline: none !important;
}
.form-label, label { color: var(--wk-ink); font-weight: 600; }

/* Tableaux (DataTables) */
.table { border-radius: var(--wk-radius); overflow: hidden; }
.table thead th {
  background: var(--wk-blue-soft); color: var(--wk-navy);
  border: none !important; font-weight: 700; padding: 14px 16px;
}
.table tbody td { border-color: var(--wk-line) !important; vertical-align: middle; padding: 14px 16px; }
.table tbody tr { transition: background .15s ease; }
.table tbody tr:hover { background: #fafbff; }
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--wk-grad) !important; border: none !important; border-radius: 8px !important; color: #fff !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button { border-radius: 8px !important; border: 1px solid var(--wk-line) !important; }

/* Badges / statuts */
.badge { border-radius: 50px; padding: .42em .85em; font-weight: 600; }
.badge.bg-success, .badge-success { background: #1fb87a !important; }
.badge.bg-danger, .badge-danger { background: #ff4d4f !important; }
.badge.bg-warning, .badge-warning { background: #ffa62a !important; color: #fff !important; }

/* Modales */
.modal-content { border-radius: 24px !important; border: none !important; box-shadow: var(--wk-shadow-strong); }

/* Divers */
::selection { background: rgba(61, 90, 254, .18); }

/* ============================================================================
   ANIMATIONS — apparition douce + cascade + survols fluides
   ============================================================================ */
@keyframes wkFadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
@keyframes wkPop { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: scale(1); } }
@keyframes wkFadeIn { from { opacity: 0; } to { opacity: 1; } }

/* Apparition des blocs principaux */
.wkd-hero, .wkd-next, .wkt, .wka, .wkw, .wkrev,
.wkd-card, .pdb-card, .card, .wkd-kpi, .wkd-qa > a,
.ag-card, .ag-kpi, .ag-legend,
.wkr-summary, .wkr-card,
.spx-list-card, .spx-form-card, .spx-staff,
.wkh, .table {
    animation: wkFadeUp .5s cubic-bezier(.16, 1, .3, 1) both;
}
.wkd-seclabel { animation: wkFadeIn .5s ease both; }

/* Cascade dans les grilles/listes */
.wkd-kpis > *:nth-child(1), .wkd-qa > *:nth-child(1), .ag-kpis > *:nth-child(1) { animation-delay: .02s; }
.wkd-kpis > *:nth-child(2), .wkd-qa > *:nth-child(2), .ag-kpis > *:nth-child(2), .wkr-grid > *:nth-child(2) { animation-delay: .08s; }
.wkd-kpis > *:nth-child(3), .wkd-qa > *:nth-child(3), .ag-kpis > *:nth-child(3), .wkr-grid > *:nth-child(3) { animation-delay: .14s; }
.wkd-kpis > *:nth-child(4), .wkd-qa > *:nth-child(4), .ag-kpis > *:nth-child(4), .wkr-grid > *:nth-child(4) { animation-delay: .20s; }
.wkr-grid > *:nth-child(5) { animation-delay: .26s; }
.wkr-grid > *:nth-child(6) { animation-delay: .32s; }
.spx-staff:nth-child(2) { animation-delay: .05s; }
.spx-staff:nth-child(3) { animation-delay: .10s; }
.spx-staff:nth-child(4) { animation-delay: .15s; }
.spx-staff:nth-child(5) { animation-delay: .20s; }
.spx-staff:nth-child(6) { animation-delay: .25s; }

/* Survols fluides uniformes */
.wkd-kpi, .wkd-card, .pdb-card, .wkr-card, .card { transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s ease; }
.wkd-kpi:hover, .wkr-card:hover { transform: translateY(-4px); box-shadow: var(--wk-shadow-strong); }

/* Boutons : léger ressort au survol */
.verify-btn, .btn-primary, .btn-dark, .wkd-btn, .ag-btn, .spx-btn, .pdb-action-btn { transition: transform .15s ease, filter .15s ease, box-shadow .15s ease; }
.wkd-btn:active, .ag-btn:active, .spx-btn:active, .btn:active { transform: scale(.97); }

/* Icônes de la sidebar : petit zoom au survol */
.kd-side-nav li a i { transition: transform .18s ease, color .18s ease; }
.kd-side-nav li a:hover i { transform: scale(1.12); }

/* Pastille de notification / FAB : petit pouls */
@keyframes wkPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.06); } }
.ag-fab-btn { animation: wkPop .4s ease both; }

/* Accessibilité : couper les animations si l'utilisateur le souhaite */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; }
}
