/* ============================================
   LIVRE ROUGE - Professional Design System
   ============================================ */

/* CSS Variables - Professional Color Palette */
:root {
  /* Brand Colors - Refined Red Palette */
  --brand-900: #7f1d1d;
  --brand-800: #991b1b;
  --brand-700: #b91c1c;
  --brand-600: #dc2626;
  --brand-500: #ef4444;
  --brand-400: #f87171;
  --brand-300: #fca5a5;
  --brand-200: #fecaca;
  --brand-100: #fee2e2;
  --brand-50: #fff1f2;

  /* Neutral Colors */
  --ink-900: #0f172a;
  --ink-800: #1e293b;
  --ink-700: #334155;
  --ink-600: #475569;
  --ink-500: #64748b;
  --ink-400: #94a3b8;
  --ink-300: #cbd5e1;
  --ink-200: #e2e8f0;
  --ink-100: #f1f5f9;
  --ink-50: #f8fafc;

  /* Semantic Colors */
  --success: #059669;
  --success-bg: #d1fae5;
  --warning: #d97706;
  --warning-bg: #fef3c7;
  --error: #dc2626;
  --error-bg: #fee2e2;
  --info: #0284c7;
  --info-bg: #dbeafe;

  /* Surfaces */
  --surface: rgba(255, 255, 255, 0.92);
  --surface-solid: #ffffff;
  --line: rgba(226, 232, 240, 0.92);
  --line-light: rgba(226, 232, 240, 0.5);

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
  --shadow-md: 0 4px 6px rgba(15, 23, 42, 0.07);
  --shadow-lg: 0 10px 15px rgba(15, 23, 42, 0.1);
  --shadow-xl: 0 20px 25px rgba(15, 23, 42, 0.1);
  --shadow-2xl: 0 25px 50px rgba(15, 23, 42, 0.15);

  /* Layout */
  --layout-max: 1600px;
  --layout-gutter: 36px;

  /* Typography */
  --font-family: 'Plus Jakarta Sans', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;
  --font-size-4xl: 2.25rem;

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  /* Border Radius */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-2xl: 28px;
  --radius-full: 9999px;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 350ms ease;
}

/* Color Scheme */
:root {
  color-scheme: light;
  font-family: var(--font-family);
  color: var(--ink-900);
  font-size: 16px;
  line-height: 1.6;
}

/* Background */
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at 10% 5%, rgba(220, 38, 38, 0.08), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(15, 23, 42, 0.06), transparent 24%),
    linear-gradient(135deg, #fff7f7 0%, #f8fafc 42%, #eef2ff 100%);
  background-attachment: fixed;
}

/* Subtle grid pattern overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(15, 23, 42, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 23, 42, 0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), transparent 75%);
  z-index: 0;
}

/* Bottom glow effect */
body::after {
  content: '';
  position: fixed;
  inset: auto -12% -22% -12%;
  height: 42vh;
  pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(239, 68, 68, 0.08), transparent 68%);
  filter: blur(12px);
  z-index: 0;
}

* {
  box-sizing: border-box;
}

/* ============================================
   LAYOUT
   ============================================ */

.app-shell {
  width: min(var(--layout-max), calc(100% - var(--layout-gutter)));
  margin: 0 auto;
  padding: 28px 0 48px;
  position: relative;
  z-index: 1;
  animation: appFadeIn 0.5s ease both;
}

@media (max-width: 768px) {
  .app-shell {
    width: calc(100% - 20px);
    padding: 20px 0 32px;
  }
}

@keyframes appFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================
   HEADER - Professional Brand Header
   ============================================ */

header {
  position: relative;
  overflow: hidden;
  margin-bottom: 28px;
  padding: 28px 36px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-2xl);
  background:
    linear-gradient(135deg, var(--brand-900) 0%, var(--brand-700) 50%, var(--brand-600) 100%),
    radial-gradient(circle at 88% 10%, rgba(255, 255, 255, 0.2), transparent 24%);
  box-shadow:
    0 0 0 1px rgba(127, 29, 29, 0.3),
    0 8px 32px rgba(127, 29, 29, 0.2),
    0 24px 64px rgba(15, 23, 42, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  animation: headerDrop 0.6s ease both;
}

header::before {
  content: '';
  position: absolute;
  left: -55px;
  top: -65px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  animation: floatOrb 8s ease-in-out infinite;
}

header::after {
  content: '';
  position: absolute;
  right: -55px;
  top: -65px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  animation: floatOrb 7s ease-in-out infinite 1s;
}

@keyframes headerDrop {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes floatOrb {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-15px, 12px) scale(1.08); }
}

.brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.brand-left {
  display: flex;
  align-items: center;
  gap: 16px;
}

.brand-left h1 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.brand-left p {
  margin: 0;
  color: rgba(255, 255, 255, 0.75);
  font-size: 0.9rem;
  font-weight: 400;
}

.brand-subtitle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-full);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

/* ============================================
   CARDS - Glassmorphism Design
   ============================================ */

.card {
  position: relative;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-2xl);
  padding: 26px;
  margin-bottom: 24px;
  box-shadow:
    0 24px 70px rgba(15, 23, 42, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(20px);
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
  animation: cardEnter 0.5s ease both;
}

.card:hover {
  transform: translateY(-2px);
  border-color: var(--brand-200);
  box-shadow:
    0 30px 80px rgba(15, 23, 42, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.card:nth-of-type(2) { animation-delay: 0.05s; }
.card:nth-of-type(3) { animation-delay: 0.1s; }
.card:nth-of-type(4) { animation-delay: 0.15s; }
.card:nth-of-type(5) { animation-delay: 0.2s; }

@keyframes cardEnter {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

h1 {
  margin: 0;
  color: var(--ink-900);
  font-size: var(--font-size-3xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

h2 {
  margin: 0 0 20px 0;
  color: var(--ink-900);
  font-size: var(--font-size-xl);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

h3 {
  margin: 0 0 16px 0;
  color: var(--ink-800);
  font-size: var(--font-size-lg);
  font-weight: 600;
}

p {
  margin: 8px 0;
  color: var(--ink-500);
  font-weight: 400;
  line-height: 1.6;
}

/* ============================================
   FORMS - Professional Input Design
   ============================================ */

form {
  display: grid;
  gap: 16px;
}

label {
  display: block;
  font-weight: 700;
  color: var(--ink-800);
  font-size: var(--font-size-sm);
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}

input, select, textarea {
  width: 100%;
  padding: 14px 18px;
  border: 2px solid var(--ink-200);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-base);
  font-weight: 500;
  font-family: inherit;
  color: var(--ink-900);
  background: var(--surface-solid);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
}

input::placeholder,
textarea::placeholder {
  color: var(--ink-400);
  font-weight: 400;
}

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--brand-400);
  box-shadow:
    0 0 0 4px var(--brand-100),
    var(--shadow-md);
  transform: translateY(-1px);
}

input:hover, select:hover, textarea:hover {
  border-color: var(--ink-300);
}

textarea {
  resize: vertical;
  min-height: 80px;
}

/* Select custom arrow */
select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 44px;
  cursor: pointer;
}

/* ============================================
   BUTTONS - Modern Button System
   ============================================ */

button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  min-height: 46px;
  border: none;
  border-radius: var(--radius-lg);
  font-family: inherit;
  font-size: var(--font-size-sm);
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

/* Primary Button */
button[type="submit"],
button:not(.secondary):not(.tertiary):not(.profile-menu-item):not(.profile-trigger) {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
  color: #ffffff;
  box-shadow:
    0 4px 12px rgba(220, 38, 38, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

button[type="submit"]:hover,
button:not(.secondary):not(.tertiary):not(.profile-menu-item):not(.profile-trigger):hover {
  background: linear-gradient(135deg, var(--brand-600), var(--brand-500));
  transform: translateY(-2px);
  box-shadow:
    0 8px 20px rgba(220, 38, 38, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

button[type="submit"]:active,
button:not(.secondary):not(.tertiary):not(.profile-menu-item):not(.profile-trigger):active {
  transform: translateY(0);
  box-shadow:
    0 2px 8px rgba(220, 38, 38, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

/* Secondary Button */
button.secondary {
  background: linear-gradient(135deg, var(--ink-700), var(--ink-600));
  color: #ffffff;
  box-shadow:
    0 4px 12px rgba(51, 65, 85, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

button.secondary:hover {
  background: linear-gradient(135deg, var(--ink-600), var(--ink-500));
  transform: translateY(-2px);
  box-shadow:
    0 8px 20px rgba(51, 65, 85, 0.35);
}

button.secondary:active {
  transform: translateY(0);
}

/* Button shimmer effect */
button::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
  transform: translateX(-100%);
  transition: transform 0.6s ease;
}

button:hover::after {
  transform: translateX(100%);
}

/* ============================================
   LOGIN CARD — Centered
   ============================================ */

.login-card {
  max-width: 420px;
  margin: 60px auto 24px;
  padding: 40px 36px;
  animation: loginCardIn 0.6s cubic-bezier(0.2, 0.85, 0.25, 1) both;
}

@keyframes loginCardIn {
  from { opacity: 0; transform: translateY(30px) scale(0.96); filter: blur(4px); }
  to   { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

.login-card-logo {
  text-align: center;
  margin-bottom: 32px;
}

.login-logo-icon {
  width: 64px; height: 64px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
  display: grid;
  place-items: center;
  margin: 0 auto 16px;
  box-shadow: 0 8px 24px rgba(185,28,28,0.28), inset 0 1px 0 rgba(255,255,255,0.2);
}

.login-logo-icon i { color: #fff; font-size: 1.6rem; }

.login-card-title {
  margin: 0 0 4px;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--ink-900);
  letter-spacing: -0.02em;
}

.login-card-sub {
  margin: 0;
  color: var(--ink-400);
  font-size: 0.88rem;
}

/* Input with icon */
.input-icon-group {
  position: relative;
  margin-bottom: 0;
}

.input-icon-group input {
  padding-left: 46px;
}

.iig-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-400);
  font-size: 0.9rem;
  pointer-events: none;
  z-index: 1;
  transition: color var(--transition-base);
}

.input-icon-group:focus-within .iig-icon {
  color: var(--brand-500);
}

.login-card-footer {
  margin-top: 24px;
  text-align: center;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-400);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}


.error {
  color: var(--brand-700);
  font-size: var(--font-size-sm);
  padding: 12px;
  background: var(--brand-100);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--brand-600);
}

#login-error:not(:empty) {
  animation: errorShake 0.4s ease both;
}

@keyframes errorShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

.hint {
  padding: 14px;
  border-radius: var(--radius-lg);
  background: var(--ink-50);
  font-size: var(--font-size-sm);
  color: var(--ink-500);
  border: 1px solid var(--ink-200);
}

/* ============================================
   TOP BAR - User Menu & Navigation
   ============================================ */

.top-bar {
  position: sticky;
  top: 12px;
  z-index: 20;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 24px;
  padding: 8px 16px;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(20px);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow:
    0 8px 32px rgba(15, 23, 42, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.button-group {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  align-items: center;
  flex-shrink: 0;
  margin-left: auto;
}

/* User Menu */
.user-menu {
  position: relative;
}

.profile-trigger {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: auto;
  padding: 8px 14px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top right, rgba(239, 68, 68, 0.2), transparent 40%),
    linear-gradient(135deg, var(--ink-900), var(--ink-800));
  color: #ffffff;
  box-shadow:
    0 16px 36px rgba(15, 23, 42, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  cursor: pointer;
  font-family: inherit;
  font-size: var(--font-size-sm);
  border: none;
  transition: all var(--transition-base);
}

.profile-trigger:hover {
  transform: translateY(-2px);
  box-shadow:
    0 20px 40px rgba(15, 23, 42, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.profile-avatar {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-700), var(--brand-500));
  color: white;
  font-weight: 700;
  font-size: 1rem;
  box-shadow:
    0 2px 8px rgba(185, 28, 28, 0.3),
    inset 0 -2px 4px rgba(15, 23, 42, 0.15);
  border: 2px solid rgba(255, 255, 255, 0.2);
  position: relative;
  overflow: hidden;
  animation: avatarPulse 3s ease-in-out infinite;
}

@keyframes avatarPulse {
  0%, 100% { box-shadow: 0 2px 8px rgba(185, 28, 28, 0.3), inset 0 -2px 4px rgba(15, 23, 42, 0.15); }
  50% { box-shadow: 0 2px 12px rgba(185, 28, 28, 0.5), inset 0 -2px 4px rgba(15, 23, 42, 0.15); }
}

.profile-avatar::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(
    45deg,
    transparent 30%,
    rgba(255, 255, 255, 0.1) 50%,
    transparent 70%
  );
  transform: rotate(45deg) translateX(-100%);
  transition: transform 0.6s ease;
}

.profile-avatar:hover::after {
  transform: rotate(45deg) translateX(100%);
}

.profile-avatar.large {
  width: 64px;
  height: 64px;
  font-size: 1.5rem;
}

.profile-avatar-wrap {
  position: relative;
  display: inline-flex;
  flex-shrink: 0;
}

.profile-badge {
  position: absolute;
  right: -5px;
  top: -5px;
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--success);
  color: white;
  font-size: 0.7rem;
  font-weight: 900;
  border: 2px solid var(--ink-900);
}

.profile-info {
  display: grid;
  gap: 1px;
  text-align: left;
  min-width: 0;
}

.profile-info strong {
  color: #ffffff;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.profile-info small {
  color: rgba(255,255,255,0.55);
  font-weight: 500;
  font-size: 0.72rem;
  white-space: nowrap;
}

/* Profile Dropdown Menu */
.profile-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  z-index: 50;
  width: 320px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--surface);
  box-shadow: var(--shadow-2xl);
  backdrop-filter: blur(20px);
  animation: menuDropIn 0.25s ease both;
}

@keyframes menuDropIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.profile-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--line-light);
}

.profile-card-head .profile-avatar.large {
  display: none;
}

.profile-card-head strong {
  display: block;
  color: var(--ink-900);
  font-size: 1rem;
  font-weight: 700;
}

.profile-card-head small {
  display: block;
  color: var(--ink-500);
  font-weight: 500;
  font-size: 0.82rem;
}

.profile-card-head a {
  display: inline-block;
  margin-top: 6px;
  color: var(--brand-600);
  font-weight: 600;
  font-size: var(--font-size-sm);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.profile-card-head a:hover {
  color: var(--brand-700);
  text-decoration: underline;
}

.profile-id {
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--ink-100);
  color: var(--ink-500);
  font-size: 0.72rem;
  font-weight: 700;
  font-family: monospace;
}

.profile-menu-item {
  position: relative;
  width: 100%;
  padding: 14px 20px 14px 48px;
  border: none;
  border-bottom: 1px solid var(--line-light);
  border-radius: 0;
  background: transparent;
  color: var(--ink-600);
  box-shadow: none;
  text-align: left;
  font-weight: 600;
  font-size: var(--font-size-sm);
  font-family: inherit;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.profile-menu-item:hover {
  transform: none;
  background: linear-gradient(90deg, var(--brand-100), transparent);
  color: var(--brand-700);
}

.profile-menu-item:last-child {
  border-bottom: none;
}

.profile-menu-item::before {
  content: '';
  position: absolute;
  left: 18px;
  top: 50%;
  width: 16px;
  height: 16px;
  border-radius: 4px;
  background: var(--ink-200);
  transform: translateY(-50%);
  transition: background var(--transition-fast);
}

.profile-menu-item:hover::before {
  background: var(--brand-300);
}

#profile-logout-button::before {
  display: none;
}

#profile-logout-button {
  padding-left: 20px;
  color: var(--brand-600);
}

#profile-logout-button:hover {
  background: var(--brand-100);
}

/* ============================================
   MAIN NAVIGATION BAR
   ============================================ */

.main-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  overflow-y: visible;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.main-nav::-webkit-scrollbar { display: none; }

.nav-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px !important;
  min-height: unset !important;
  border: none !important;
  border-radius: var(--radius-lg) !important;
  background: transparent !important;
  color: var(--ink-500) !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  transition: all 0.18s ease !important;
  white-space: nowrap;
  flex-shrink: 0;
}

.nav-tab i {
  font-size: 0.85rem;
}

.nav-tab span {
  display: inline;
}

.nav-tab:hover {
  background: var(--brand-50) !important;
  color: var(--brand-700) !important;
  transform: none !important;
}

.nav-tab.active {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600)) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(185,28,28,0.28) !important;
}

.nav-tab.active:hover {
  background: linear-gradient(135deg, var(--brand-600), var(--brand-500)) !important;
  transform: translateY(-1px) !important;
}

@media (max-width: 640px) {
  .nav-tab span { display: none; }
  .nav-tab { padding: 10px 12px !important; }
  .main-nav { gap: 2px; }
}

/* ============================================
   SECTION HEADERS & CARD HEADERS
   ============================================ */

.card-section-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1.5px solid var(--line-light);
}

.card-section-header h2,
.card-section-header .section-title {
  margin: 0 0 3px;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--ink-800);
  letter-spacing: -0.01em;
}

.section-icon-badge {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  border-radius: 10px;
  background: var(--ink-100);
  border: 1.5px solid var(--ink-200);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--ink-500);
  font-size: 1rem;
  line-height: 1;
}

.section-icon-badge i {
  margin: 0;
  padding: 0;
  display: block;
  line-height: 1;
}

.section-icon-badge.brand {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 2px 8px rgba(185,28,28,0.20);
}

.section-subtitle {
  margin: 0 !important;
  font-size: 0.8rem !important;
  color: var(--ink-400) !important;
  font-weight: 500 !important;
}

/* ============================================
   HEADER LOGO ICON
   ============================================ */

.header-logo-icon {
  width: 48px;
  height: 48px;
  background: rgba(255,255,255,0.15);
  border-radius: 14px;
  display: grid;
  place-items: center;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.2);
}

.header-logo-icon i { color: #ffffff; font-size: 1.4rem; }

/* ============================================
   STATS CARD — KPI TILES
   ============================================ */

.stats-card-header {
  margin-bottom: 20px;
}

.stats-card-title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.stats-card-title h2 {
  margin: 0 0 2px;
}

.kpi-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 16px;
}

.kpi-tile {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.kpi-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15,23,42,0.08);
}

.kpi-tile-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.kpi-tile-body strong {
  display: block;
  font-size: 1.65rem;
  font-weight: 800;
  line-height: 1;
  margin-bottom: 3px;
  letter-spacing: -0.02em;
}

.kpi-tile-body span {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.kpi-sales {
  background: linear-gradient(135deg, #eff6ff, #dbeafe);
  border-color: rgba(59,130,246,0.15);
}
.kpi-sales .kpi-tile-icon {
  background: linear-gradient(135deg, #3b82f6, #2563eb);
  color: #fff;
  box-shadow: 0 4px 12px rgba(59,130,246,0.3);
}
.kpi-sales .kpi-tile-body strong { color: #1d4ed8; }
.kpi-sales .kpi-tile-body span { color: #3b82f6; }

.kpi-revenue {
  background: linear-gradient(135deg, #f0fdf4, #dcfce7);
  border-color: rgba(5,150,105,0.15);
}
.kpi-revenue .kpi-tile-icon {
  background: linear-gradient(135deg, #059669, #047857);
  color: #fff;
  box-shadow: 0 4px 12px rgba(5,150,105,0.3);
}
.kpi-revenue .kpi-tile-body strong { color: #065f46; }
.kpi-revenue .kpi-tile-body span { color: #059669; }

.kpi-validated {
  background: linear-gradient(135deg, var(--brand-50), #ffe4e6);
  border-color: rgba(220,38,38,0.12);
}
.kpi-validated .kpi-tile-icon {
  background: linear-gradient(135deg, var(--brand-600), var(--brand-700));
  color: #fff;
  box-shadow: 0 4px 12px rgba(220,38,38,0.28);
}
.kpi-validated .kpi-tile-body strong { color: var(--brand-800); }
.kpi-validated .kpi-tile-body span { color: var(--brand-600); }

/* ============================================
   GRID LAYOUT
   ============================================ */

.grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
  gap: 24px;
  align-items: start;
  width: 100%;
  max-width: 100%;
}

@media (max-width: 1480px) {
  .grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* ============================================
   STATS CARD
   ============================================ */

.stats-card {
  display: grid;
  gap: 12px;
}

.stat-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 20px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(248, 250, 252, 0.9));
  border-radius: var(--radius-xl);
  border: 1px solid rgba(148, 163, 184, 0.15);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.stat-item:hover {
  transform: translateY(-2px);
  box-shadow:
    0 8px 20px rgba(15, 23, 42, 0.06),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.stat-item strong {
  font-size: 1.8rem;
  color: var(--brand-700);
  font-weight: 800;
  line-height: 1;
}

.stat-item span {
  color: var(--ink-500);
  font-weight: 600;
  font-size: var(--font-size-sm);
  text-align: right;
}

/* Export Buttons */
.export-actions {
  display: flex;
  gap: 10px;
  margin-top: 8px;
}

.export-button {
  flex: 1;
  padding: 12px 16px;
  font-size: var(--font-size-xs);
  border-radius: var(--radius-md);
}

.export-button span {
  display: inline-block;
  padding: 2px 6px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 800;
  margin-right: 4px;
}

.pdf-export span {
  background: var(--brand-500);
}

.excel-export span {
  background: var(--success);
}

/* ============================================
   FILTERS
   ============================================ */

.filter-card {
  padding-bottom: 20px;
}

.filters {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, 1fr);
  align-items: end;
  padding: 16px 0 0;
}

.filter-field-full {
  grid-column: 1 / -1;
}

.filters label {
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.filters label i {
  color: var(--ink-300);
  font-size: 0.75rem;
}

/* Filter action buttons row */
.filter-actions {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 6px;
  flex-wrap: wrap;
}

.filter-actions-spacer { flex: 1; }

.filter-ghost-btn,
.filter-ghost-btn:not(.secondary):not(.tertiary) {
  background: var(--ink-100) !important;
  color: var(--ink-600) !important;
  border: 1.5px solid var(--line-light) !important;
  box-shadow: none !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  padding: 8px 14px !important;
  min-height: unset !important;
  height: auto !important;
  border-radius: var(--radius-md) !important;
  transition: background 0.15s, color 0.15s !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.filter-ghost-btn:hover,
.filter-ghost-btn:not(.secondary):not(.tertiary):hover {
  background: var(--ink-200) !important;
  color: var(--ink-800) !important;
  transform: none !important;
}

.filter-search-btn,
.filter-search-btn:not(.secondary):not(.tertiary) {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600)) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(185,28,28,0.28) !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  padding: 8px 22px !important;
  min-height: unset !important;
  height: auto !important;
  border-radius: var(--radius-md) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.filter-search-btn:hover {
  opacity: 0.9 !important;
  transform: translateY(-1px) !important;
}

.site-filter-buttons {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.site-filter-button {
  width: auto;
  padding: 8px 16px;
  border: 1px solid var(--brand-200);
  border-radius: var(--radius-full);
  background: var(--brand-50);
  color: var(--brand-700);
  box-shadow: none;
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.site-filter-button.active,
.site-filter-button:hover {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(185, 28, 28, 0.2);
  border-color: transparent;
}

/* ============================================
   SITE SUMMARY CARD
   ============================================ */

.site-summary-card {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) 1.2fr;
  gap: 20px;
  align-items: center;
  border-color: var(--brand-200);
  background: linear-gradient(135deg, #ffffff, var(--brand-50));
  box-shadow:
    0 24px 70px rgba(185, 28, 28, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.site-summary-card > div:first-child span {
  color: var(--ink-500);
  font-weight: 700;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.site-summary-card h2 {
  margin: 4px 0 0;
  color: var(--brand-700);
}

.site-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(100px, 1fr));
  gap: 12px;
}

.site-summary-grid div {
  padding: 14px;
  border: 1px solid var(--brand-100);
  border-radius: var(--radius-lg);
  background: var(--surface-solid);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.site-summary-grid div:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.site-summary-grid strong {
  display: block;
  color: var(--brand-700);
  font-size: 1.4rem;
  font-weight: 800;
}

.site-summary-grid span {
  color: var(--ink-500);
  font-weight: 600;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* ============================================
   TABLES - Professional Data Display
   ============================================ */

.table-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  flex-wrap: wrap;
  gap: 12px;
}

.table-card-header h2 {
  margin: 0;
}

/* Quick filter bar */
.table-quick-filters {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 0 16px;
  border-bottom: 2px solid var(--line);
  margin-bottom: 0;
  flex-wrap: wrap;
}

.tqf-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.tqf-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.tqf-type-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.tqf-tab {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 6px 14px !important;
  min-height: unset !important;
  height: 32px !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  border-radius: var(--radius-full) !important;
  border: 1.5px solid var(--line) !important;
  background: var(--surface) !important;
  color: var(--ink-500) !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: pointer;
  transition: all 0.15s !important;
  white-space: nowrap;
}

.tqf-tab::after { display: none !important; }

.tqf-tab:hover {
  background: var(--ink-50) !important;
  color: var(--ink-700) !important;
  border-color: var(--ink-300) !important;
  transform: none !important;
  box-shadow: none !important;
}

.tqf-tab.active {
  background: var(--ink-800) !important;
  color: #fff !important;
  border-color: var(--ink-800) !important;
}

.tqf-tab.active[data-type="VENTE"] { background: #15803d !important; border-color: #15803d !important; }
.tqf-tab.active[data-type="PT"]    { background: #d97706 !important; border-color: #d97706 !important; }
.tqf-tab.active[data-type="CE"]    { background: #7c3aed !important; border-color: #7c3aed !important; }
.tqf-tab.active[data-type="WI"]    { background: #0284c7 !important; border-color: #0284c7 !important; }
.tqf-tab.active[data-type="A1"]    { background: #be185d !important; border-color: #be185d !important; }

.tqf-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tqf-dot.vente { background: #16a34a; }
.tqf-dot.pt    { background: #d97706; }
.tqf-dot.ce    { background: #7c3aed; }
.tqf-dot.wi    { background: #0284c7; }
.tqf-dot.a1    { background: #be185d; }
.tqf-dot.pod   { background: #475569; }

.tqf-date-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: var(--radius-full);
  padding: 0 10px 0 12px;
  height: 34px;
}

.tqf-date-wrap i { color: var(--ink-400); font-size: 0.78rem; }

.tqf-date-wrap input[type="date"] {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  height: auto !important;
  min-height: unset !important;
  font-size: 0.78rem;
  color: var(--ink-700);
  box-shadow: none !important;
  width: 126px;
}

.tqf-clear-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  min-height: unset !important;
  padding: 0 !important;
  background: var(--ink-200) !important;
  border: none !important;
  border-radius: 50% !important;
  color: var(--ink-500) !important;
  font-size: 0.7rem !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: pointer;
  line-height: 1;
}
.tqf-clear-btn::after { display: none !important; }
.tqf-clear-btn:hover { background: var(--ink-300) !important; color: var(--ink-700) !important; transform: none !important; }

.tqf-count {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--ink-400);
  white-space: nowrap;
  padding: 4px 10px;
  background: var(--ink-50);
  border-radius: var(--radius-full);
  border: 1px solid var(--line);
}

@media (max-width: 768px) {
  .table-quick-filters { flex-direction: column; align-items: flex-start; }
  .tqf-right { width: 100%; justify-content: space-between; }
}

table {
  width: 100%;
  min-width: 980px;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--surface-solid);
  box-shadow: var(--shadow-lg);
}

.card:has(table) {
  overflow-x: auto;
}

thead {
  background: linear-gradient(135deg, var(--brand-900), var(--brand-600));
  color: #ffffff;
}

th {
  padding: 14px 16px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: left;
  border-bottom: none;
  white-space: nowrap;
}

th:first-child {
  padding-left: 20px;
}

th:last-child {
  padding-right: 20px;
}

td {
  padding: 14px 16px;
  font-size: var(--font-size-sm);
  color: var(--ink-700);
  border-bottom: 1px solid var(--line-light);
  vertical-align: middle;
  white-space: nowrap;
}

td:first-child {
  padding-left: 20px;
}

td:last-child {
  padding-right: 20px;
}

tbody tr {
  transition: background var(--transition-fast);
  animation: rowEnter 0.3s ease both;
}

@keyframes rowEnter {
  from {
    opacity: 0;
    transform: translateX(-8px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

tbody tr:nth-child(even) {
  background: var(--ink-50);
}

tbody tr:hover {
  background: var(--brand-50);
}

tbody tr:hover td {
  color: var(--ink-900);
}

thead th {
  position: sticky;
  top: 0;
  z-index: 1;
}

/* Clickable rows */
.clickable-row {
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.clickable-row:hover {
  background-color: var(--brand-50);
  transform: scale(1.002);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.clickable-row:hover td {
  color: var(--brand-700);
}

.clickable-row::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--brand-500);
  transform: scaleY(0);
  transition: transform 0.2s ease;
}

.clickable-row:hover::before {
  transform: scaleY(1);
}

.clickable-row:active {
  transform: scale(0.998);
}

/* Indicateur de clic pour les tableaux - SUPPRIMÉ */
/*
.table-container::after {
  content: '💡 Cliquez sur une ligne pour voir les détails';
  display: block;
  font-size: 0.8rem;
  color: var(--ink-300);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}
*/

/* Styles pour les liens d'audit */
.audit-sale-link {
  color: var(--brand-600);
  font-weight: 600;
  padding: 2px 6px;
  background: var(--brand-50);
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.85em;
}

.clickable-row .audit-sale-link {
  transition: all 0.2s ease;
}

.clickable-row:hover .audit-sale-link {
  background: var(--brand-100);
  color: var(--brand-700);
}

/* Amélioration des tableaux cliquables */
.clickable-row td {
  position: relative;
}

.clickable-row:hover td {
  border-color: var(--brand-200);
}

/* Indicateur spécial pour les tableaux avec toutes les lignes cliquables - SUPPRIMÉ */
/*
table:has(.clickable-row)::after {
  content: '👆 Cliquez sur une ligne pour voir les détails de l\'opération';
  display: block;
  font-size: 0.75rem;
  color: var(--ink-400);
  text-align: center;
  margin-top: 8px;
  padding: 6px;
  background: var(--surface-subtle);
  border-radius: 4px;
  border: 1px dashed var(--line);
}
*/

/* Pour les conteneurs de tables spécifiques - SUPPRIMÉ */
/*
#sales-table-card::after,
.cheque-table-container::after,
#audit-table-container::after {
  content: '💡 Cliquez sur une ligne pour voir les détails';
  display: block;
  font-size: 0.8rem;
  color: var(--ink-300);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
  animation: fadeIn 0.3s ease;
}
*/

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   STATUS BADGES
   ============================================ */

.status-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 80px;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
  animation: badgePop 0.3s ease both;
}

@keyframes badgePop {
  from {
    opacity: 0;
    transform: scale(0.85);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.status-pending {
  background: var(--warning-bg);
  color: var(--warning);
}

.status-validated {
  background: var(--success-bg);
  color: var(--success);
}

.status-blocked {
  background: var(--error-bg);
  color: var(--error);
}

/* Operation Type Badges */
.type-operation-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 6px 10px;
  border-radius: var(--radius-full);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
  animation: badgePop 0.3s ease both;
}

.type-vente {
  background: #dcfce7;
  color: #166534;
}

.type-pt {
  background: var(--warning-bg);
  color: var(--warning);
}

.type-ce {
  background: var(--info-bg);
  color: var(--info);
}

.type-wi {
  background: #ede9fe;
  color: #6d28d9;
}

.type-a1 {
  background: #ffe4e6;
  color: #be123c;
}

.type-pod {
  background: #f1f5f9;
  color: #334155;
}

/* ============================================
   PILLS & TAGS
   ============================================ */

.pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  background: var(--brand-100);
  color: var(--brand-700);
  font-weight: 700;
  font-size: 0.8rem;
}

.site-pill {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 130px;
  padding: 6px 10px 6px 14px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, var(--brand-100), var(--brand-50));
  border: 1px solid var(--brand-200);
  color: var(--brand-700);
  font-weight: 700;
  font-size: 0.8rem;
  box-shadow: 0 4px 12px rgba(185, 28, 28, 0.06);
}


/* ============================================
   ADMIN PANEL
   ============================================ */

.admin-panel-header {
  display: flex;
  align-items: center;
  gap: 16px;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding: 12px;
  border-radius: var(--radius-xl);
  background: rgba(248, 250, 252, 0.7);
}

.admin-panel-header h2 {
  margin: 0;
  width: 100%;
}

.admin-tab-button {
  width: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-md);
  background: var(--ink-50);
  color: var(--ink-700);
  box-shadow: none;
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: inherit;
}

.admin-tab-button:hover {
  background: var(--ink-100);
  transform: translateY(-1px);
}

.admin-tab-button.active {
  border-color: var(--brand-300);
  background: var(--brand-50);
  color: var(--brand-700);
}

.admin-tab-button span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--brand-100);
  font-size: 0.85rem;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}

@media (max-width: 900px) {
  .admin-grid {
    grid-template-columns: 1fr;
  }
}

.admin-user-form-card {
  padding: 24px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-xl);
  background: var(--surface-solid);
  box-shadow: var(--shadow-md);
}

.admin-user-form-card h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 20px;
  color: var(--ink-900);
  font-size: var(--font-size-lg);
}

.admin-user-form-card label {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 12px 0 6px;
  color: var(--ink-700);
  font-weight: 600;
}

.admin-user-form-card input,
.admin-user-form-card select {
  height: auto;
  min-height: 42px;
  padding: 9px 16px;
  line-height: 1.4;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-sm);
  background: var(--surface-solid);
  box-shadow: none;
  font-size: var(--font-size-sm);
}

.admin-user-form-card small {
  display: block;
  margin-top: 4px;
  color: var(--ink-500);
  font-weight: 500;
  font-size: var(--font-size-xs);
}

.admin-user-form-card button[type="submit"] {
  margin-top: 16px;
  width: 100%;
}

.platform-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  margin-top: 10px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-sm);
  background: var(--surface-solid);
  gap: 8px;
}

.platform-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.platform-name {
  font-weight: 600;
  color: var(--ink-900);
  font-size: var(--font-size-sm);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.platform-url {
  font-size: 0.75rem;
  color: var(--ink-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.platform-status {
  font-size: 0.75rem;
  font-weight: 600;
}

.platform-status.active { color: var(--success); }
.platform-status.inactive { color: var(--ink-400); }

.platform-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.platform-toggle,
.platform-delete {
  padding: 4px 10px;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 600;
}

.platform-toggle {
  background: var(--primary);
  color: #fff;
}

.platform-delete {
  background: var(--danger, #ef4444);
  color: #fff;
}

#admin-site-form {
  align-self: start;
  padding: 24px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-xl);
  background: var(--surface-solid);
  box-shadow: var(--shadow-md);
}

#admin-site-form h3 {
  margin: 0 0 16px;
  color: var(--ink-900);
  font-size: var(--font-size-lg);
}

#admin-site-form label {
  margin: 0 0 8px;
  color: var(--ink-700);
  font-weight: 600;
}

#admin-site-form input {
  height: 42px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  box-shadow: none;
  border: 1px solid var(--ink-200);
}

#admin-site-form button {
  width: auto;
  min-width: 150px;
  justify-self: start;
  padding: 10px 18px;
  border-radius: var(--radius-md);
  margin-top: 12px;
}

.admin-list {
  margin-top: 20px;
}

.site-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px 6px 14px;
  background: var(--brand-50);
  border: 1px solid var(--brand-200);
  border-radius: var(--radius-full);
  color: var(--brand-700);
  font-size: var(--font-size-sm);
  font-weight: 600;
  white-space: nowrap;
}

.delete-site-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--brand-600);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  cursor: pointer;
  flex-shrink: 0;
  user-select: none;
  font-family: Arial, sans-serif;
}

.delete-site-button:hover {
  background: #991b1b;
}

#admin-sites-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* Gestion utilisateurs */
.admin-users-panel {
  grid-column: 1 / -1;
  margin-top: 8px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface-solid);
}

.admin-users-panel-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.admin-users-panel-header h3 {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink-900);
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-users-panel-header h3 i { color: var(--ink-500); }

.admin-users-panel-sub {
  margin: 0;
  font-size: 0.8rem;
  color: var(--ink-500);
}

.admin-users-count-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 700;
  background: var(--brand-50, #fef2f2);
  color: var(--brand-700, #b91c1c);
  border: 1px solid var(--brand-200, #fecaca);
  white-space: nowrap;
}

.admin-users-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
  align-items: center;
}

.admin-users-search-wrap {
  flex: 1 1 200px;
  min-width: 180px;
  position: relative;
  display: flex;
  align-items: center;
}

.admin-users-search-wrap i {
  position: absolute;
  left: 12px;
  color: var(--ink-400);
  font-size: 0.8rem;
  pointer-events: none;
}

.admin-users-search-wrap input {
  width: 100%;
  padding: 10px 12px 10px 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-size: 0.85rem;
}

.admin-users-filter-select {
  flex: 0 1 160px;
  min-width: 140px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  background: #fff;
}

.admin-users-toolbar-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--ink-50, #f8fafc);
  color: var(--ink-700);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
}

.admin-users-toolbar-btn:hover {
  background: var(--ink-100);
  border-color: var(--ink-300);
}

.admin-users-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.admin-users-empty {
  margin: 12px 0 0;
  text-align: center;
  font-size: 0.85rem;
  color: var(--ink-500);
}

.admin-username-preview {
  margin: 4px 0 0;
}

.admin-user-row {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) auto auto;
  gap: 12px 16px;
  align-items: center;
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: #fff;
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.admin-user-row-self {
  border-color: var(--brand-200, #fecaca);
  background: linear-gradient(90deg, #fff 0%, #fffbfb 100%);
}

.admin-user-row:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--ink-200);
}

/* Avatar circle */
.admin-user-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-600), var(--brand-700));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* Name + username stacked */
.admin-user-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.admin-user-info strong {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--ink-900);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-user-info span {
  font-size: 0.75rem;
  color: var(--ink-400);
  font-weight: 500;
}

/* Role + site pills */
.admin-user-pills {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.user-role-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.user-role-pill.role-admin    { background: #fef2f2; color: #b91c1c; border: 1px solid #fca5a5; }
.user-role-pill.role-manager  { background: #eff6ff; color: #1d4ed8; border: 1px solid #93c5fd; }
.user-role-pill.role-reception{ background: #f0fdf4; color: #15803d; border: 1px solid #86efac; }
.user-role-pill.role-finance  { background: #fdf4ff; color: #7e22ce; border: 1px solid #d8b4fe; }
.user-role-pill.role-control  { background: #fff7ed; color: #c2410c; border: 1px solid #fdba74; }
.user-role-pill.role-mc       { background: #f0f9ff; color: #0369a1; border: 1px solid #7dd3fc; }
.user-role-pill.role-default  { background: var(--ink-100); color: var(--ink-600); border: 1px solid var(--line); }

.user-site-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  font-size: 0.68rem;
  font-weight: 600;
  background: var(--ink-50, #f8fafc);
  color: var(--ink-500);
  border: 1px solid var(--line);
}
.user-site-pill i { font-size: 0.6rem; }

.admin-user-self-tag {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--brand-600);
}

.admin-user-pw-flag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
  font-size: 0.68rem;
  font-weight: 600;
  color: #c2410c;
}

.user-site-pill-muted {
  opacity: 0.75;
  font-style: italic;
}

/* Action buttons */
.admin-user-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.admin-user-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--line);
  background: #f8fafc;
  color: var(--ink-700);
  white-space: nowrap;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.admin-user-btn:hover {
  transform: none;
  box-shadow: none;
}

.admin-user-btn-edit:hover {
  background: #eff6ff;
  color: #1d4ed8;
  border-color: #93c5fd;
}

.admin-user-btn-delete:hover {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fca5a5;
}

/* Page overlay — gestion utilisateur */
body.edit-user-overlay-open {
  overflow: hidden;
}

.edit-user-page-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--ink-100, #f1f5f9);
  animation: editUserPageIn 0.28s ease both;
}

.edit-user-page-overlay.hidden {
  display: none !important;
}

@keyframes editUserPageIn {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.edit-user-page-shell {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 100dvh;
}

.edit-user-page-topbar {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 14px 20px;
  background: #fff;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.edit-user-page-topbar::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand-800, #991b1b), var(--brand-600, #dc2626));
  pointer-events: none;
}

.edit-user-page-topbar {
  position: relative;
}

.edit-user-page-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--ink-700);
  font-size: 0.85rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  white-space: nowrap;
}

.edit-user-page-back:hover {
  background: var(--ink-50);
  border-color: var(--ink-300);
  color: var(--ink-900);
}

.edit-user-page-topbar-title {
  min-width: 0;
  text-align: center;
}

.edit-user-page-kicker {
  margin: 0 0 2px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-400);
}

.edit-user-page-topbar-title h2 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink-900);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.edit-user-page-topbar-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.edit-user-page-scroll {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.edit-user-page-layout {
  display: grid;
  grid-template-columns: minmax(260px, 300px) minmax(0, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 20px 40px;
  align-items: start;
}

.edit-user-page-aside {
  position: sticky;
  top: 0;
}

.edit-user-profile-card {
  padding: 28px 22px;
  border-radius: var(--radius-xl);
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-md);
  text-align: center;
}

.edit-user-page-avatar {
  width: 72px;
  height: 72px;
  margin: 0 auto 14px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
  box-shadow: 0 8px 20px rgba(185, 28, 28, 0.25);
}

.edit-user-page-name {
  margin: 0 0 4px;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink-900);
  word-break: break-word;
}

.edit-user-page-login {
  margin: 0 0 16px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--ink-500);
  font-family: ui-monospace, 'Cascadia Code', monospace;
}

.edit-user-page-meta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.edit-user-page-main {
  min-width: 0;
}

.edit-user-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.edit-user-form-card {
  padding: 22px 24px;
  border-radius: var(--radius-xl);
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}

.edit-user-form-card .edit-user-section + .edit-user-section {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.edit-user-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 14px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-500);
}

.edit-user-section-title i {
  color: var(--brand-600);
  font-size: 0.85rem;
}

.edit-user-fields {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.edit-user-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.edit-user-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ink-700);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px;
}

.edit-user-label-hint {
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--ink-400);
}

.edit-user-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.edit-user-input-icon {
  position: absolute;
  left: 14px;
  z-index: 1;
  font-size: 0.8rem;
  color: var(--ink-400);
  pointer-events: none;
}

.edit-user-input,
.edit-user-select {
  width: 100%;
  padding: 12px 14px 12px 42px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-family: inherit;
  color: var(--ink-900);
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}

.edit-user-input:focus,
.edit-user-select:focus {
  outline: none;
  border-color: var(--brand-400, #f87171);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}

.edit-user-select {
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.edit-user-input:disabled,
.edit-user-select:disabled {
  background: var(--ink-50, #f8fafc);
  color: var(--ink-400);
  cursor: not-allowed;
}

.edit-user-toggle {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  background: var(--ink-50, #f8fafc);
  border: 1px solid var(--line);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.edit-user-toggle:hover {
  border-color: var(--brand-200, #fecaca);
  background: #fffbfb;
}

.edit-user-toggle-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.edit-user-toggle-track {
  flex-shrink: 0;
  width: 44px;
  height: 26px;
  margin-top: 2px;
  border-radius: 999px;
  background: var(--ink-200, #e2e8f0);
  position: relative;
  transition: background 0.2s;
}

.edit-user-toggle-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  transition: transform 0.2s ease;
}

.edit-user-toggle-input:checked + .edit-user-toggle-track {
  background: var(--brand-600, #dc2626);
}

.edit-user-toggle-input:checked + .edit-user-toggle-track .edit-user-toggle-thumb {
  transform: translateX(18px);
}

.edit-user-toggle-input:focus-visible + .edit-user-toggle-track {
  outline: 2px solid var(--brand-500);
  outline-offset: 2px;
}

.edit-user-toggle-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.edit-user-toggle-copy strong {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink-800);
  line-height: 1.35;
}

.edit-user-toggle-copy small {
  font-size: 0.75rem;
  color: var(--ink-500);
  line-height: 1.4;
}

.edit-user-error {
  margin: 14px 0 0;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  font-size: 0.82rem;
}

.edit-user-error.hidden {
  display: none !important;
}

/* Panneau réinitialisation mot de passe (dans la page gestion utilisateur) */
.edit-user-reset-panel {
  margin-top: 20px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--brand-200, #fecaca);
  box-shadow: 0 8px 24px rgba(185, 28, 28, 0.1);
  animation: editUserResetIn 0.25s ease both;
}

.edit-user-reset-panel.hidden {
  display: none !important;
}

@keyframes editUserResetIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.edit-user-reset-hero {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 18px;
  color: #fff;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.18), transparent 45%),
    linear-gradient(135deg, var(--brand-900, #7f1d1d), var(--brand-600, #dc2626));
}

.edit-user-reset-hero-icon {
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.25);
  font-size: 1rem;
}

.edit-user-reset-kicker {
  margin: 0 0 2px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.88;
}

.edit-user-reset-hero h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
}

.edit-user-reset-sub {
  margin: 6px 0 0;
  font-size: 0.8rem;
  opacity: 0.92;
}

.edit-user-reset-sub strong {
  font-weight: 700;
}

.edit-user-reset-body {
  padding: 18px;
  background: #fffbfb;
}

.edit-user-reset-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}

.edit-user-reset-actions .edit-user-btn {
  flex: 1 1 160px;
}

.edit-user-page-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 4px 0 8px;
}

.edit-user-page-overlay .edit-user-btn,
.edit-user-page-topbar .edit-user-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex: 1 1 140px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  border: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
}

.edit-user-page-overlay .edit-user-btn:active,
.edit-user-page-topbar .edit-user-btn:active {
  transform: scale(0.98);
}

.edit-user-page-overlay .edit-user-btn-outline,
.edit-user-page-topbar .edit-user-btn-outline {
  background: #fff;
  color: var(--ink-700);
  border: 1px solid var(--line);
}

.edit-user-page-overlay .edit-user-btn-outline:hover,
.edit-user-page-topbar .edit-user-btn-outline:hover {
  background: var(--ink-50);
  border-color: var(--ink-300);
  color: var(--ink-900);
}

.edit-user-page-overlay .edit-user-btn-primary,
.edit-user-page-topbar .edit-user-btn-primary {
  background: linear-gradient(135deg, var(--brand-700, #b91c1c), #dc2626);
  color: #fff;
  box-shadow: 0 4px 14px rgba(185, 28, 28, 0.35);
}

.edit-user-page-overlay .edit-user-btn-primary:hover,
.edit-user-page-topbar .edit-user-btn-primary:hover {
  background: linear-gradient(135deg, var(--brand-800, #991b1b), var(--brand-700, #b91c1c));
  box-shadow: 0 6px 18px rgba(185, 28, 28, 0.4);
}

.edit-user-page-overlay .edit-user-btn-danger,
.edit-user-page-topbar .edit-user-btn-danger {
  background: #fff;
  color: #b91c1c;
  border: 1px solid #fca5a5;
}

.edit-user-page-overlay .edit-user-btn-danger:hover,
.edit-user-page-topbar .edit-user-btn-danger:hover {
  background: #fef2f2;
  border-color: #f87171;
}

.edit-user-page-topbar .edit-user-btn-save-top {
  flex: 0 1 auto;
  min-width: 120px;
}

@media (max-width: 900px) {
  .edit-user-page-layout {
    grid-template-columns: 1fr;
  }
  .edit-user-page-aside {
    position: static;
  }
}

@media (max-width: 720px) {
  .edit-user-page-topbar {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 10px;
    padding: 12px 14px;
  }
  .edit-user-page-topbar-title {
    text-align: left;
    order: -1;
    grid-column: 1 / -1;
  }
  .edit-user-page-topbar-actions {
    grid-column: 1 / -1;
    width: 100%;
  }
  .edit-user-page-topbar-actions .edit-user-btn {
    flex: 1;
  }
  .edit-user-btn-save-top {
    display: none;
  }
  .edit-user-page-layout {
    padding: 16px 14px 32px;
  }
}

@media (max-width: 480px) {
  .edit-user-page-footer {
    flex-direction: column-reverse;
  }
  .edit-user-page-footer .edit-user-btn {
    flex: 1 1 auto;
    width: 100%;
  }
}

@media (max-width: 720px) {
  .admin-user-row {
    grid-template-columns: 40px 1fr;
    grid-template-rows: auto auto auto;
  }
  .admin-user-pills { grid-column: 2; }
  .admin-user-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }
  .admin-user-btn { flex: 1; justify-content: center; }
}

.admin-user-actions button.btn-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px !important;
  height: 30px !important;
  min-height: unset !important;
  padding: 0 !important;
  border-radius: var(--radius-md) !important;
  font-size: 0.72rem !important;
  font-weight: normal !important;
  transition: background 0.15s, color 0.15s, border-color 0.15s !important;
  transform: none !important;
  box-shadow: none !important;
}

.admin-user-actions button.btn-icon:hover {
  transform: none !important;
  box-shadow: none !important;
}

.admin-user-actions button.btn-icon::after { display: none !important; }

.admin-user-actions button.btn-edit {
  background: #f8fafc !important;
  color: var(--ink-500) !important;
  border: 1px solid var(--line) !important;
}
.admin-user-actions button.btn-edit:hover {
  background: #eff6ff !important;
  color: #1d4ed8 !important;
  border-color: #93c5fd !important;
}

.admin-user-actions button.btn-delete {
  background: #f8fafc !important;
  color: var(--ink-500) !important;
  border: 1px solid var(--line) !important;
}
.admin-user-actions button.btn-delete:hover {
  background: #fef2f2 !important;
  color: #dc2626 !important;
  border-color: #fca5a5 !important;
}

.admin-actions {
  display: flex;
  justify-content: flex-end;
  margin: 12px 0 16px;
  gap: 8px;
}

@media (max-width: 768px) {
  .admin-user-row {
    grid-template-columns: 36px 1fr auto;
    grid-template-rows: auto auto;
  }
  .admin-user-pills { grid-column: 2; }
  .admin-user-actions { grid-row: 1; grid-column: 3; }
}

/* ============================================
   RAPPORT DE CAISSE
   ============================================ */

/* Cash report panel */
.cash-report-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 12px;
}

.cash-report-panel-header h2 { margin: 0 0 4px; }

.cash-report-panel-subtitle {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-400);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 5px;
}

/* Cash report full-width section */
.cash-report-section {
  margin-top: 0;
}

.cash-report-section form {
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.cash-report-controls {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr auto;
  gap: 16px;
  align-items: end;
  margin-bottom: 4px;
}

@media (max-width: 900px) {
  .cash-report-controls { grid-template-columns: 1fr 1fr; }
  .cash-report-btn-wrap { grid-column: 1 / -1; }
}

@media (max-width: 500px) {
  .cash-report-controls { grid-template-columns: 1fr; }
}

.cash-report-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cash-report-field label {
  font-weight: 600;
  color: var(--ink-700);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
}

.cash-report-field input,
.cash-report-field select {
  width: 100%;
  min-height: 42px;
  padding: 9px 16px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-sm);
  background: var(--surface-solid);
  font-size: var(--font-size-sm);
}

.cash-report-btn-wrap button {
  white-space: nowrap;
  height: 42px;
  padding: 0 24px;
}

@media (max-width: 768px) {
  .cash-report-controls {
    grid-template-columns: 1fr;
  }
  .cash-report-btn-wrap button { width: 100%; }
  .cash-report-field label[style*="visibility:hidden"] { display: none; }
}

/* Report results */
.report-summary {
  margin-top: 24px;
  padding: 20px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
}

.report-summary h4 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink-900);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
}

.report-totals {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}

@media (max-width: 900px) {
  .report-totals { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 600px) {
  .report-totals { grid-template-columns: repeat(2, 1fr); }
}

.report-total-item {
  background: var(--surface-solid);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.report-total-item strong {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--brand-700);
}

.report-total-item span {
  font-size: 0.68rem;
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
}

.report-total-item.highlight {
  background: linear-gradient(135deg, var(--brand-600), var(--brand-700));
  border-color: var(--brand-700);
}

.report-total-item.highlight strong,
.report-total-item.highlight span { color: #fff; }

.report-sales-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  margin-top: 4px;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--line);
}

.report-sales-table thead tr {
  background: var(--ink-800);
}

.report-sales-table th {
  padding: 10px 12px;
  text-align: left;
  font-weight: 600;
  color: #fff;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.report-sales-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  color: var(--ink-700);
  vertical-align: middle;
}

.report-sales-table tbody tr:nth-child(even) td { background: var(--surface); }
.report-sales-table tbody tr:last-child td { border-bottom: none; }
.report-sales-table tbody tr:hover td { background: var(--brand-50); }

.report-download-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 20px;
}

@media (max-width: 600px) {
  .report-download-actions { grid-template-columns: 1fr; }
}

/* ============================================
   CHECKBOX
   ============================================ */

.checkbox-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px;
  border-radius: var(--radius-lg);
  background: rgba(248, 250, 252, 0.7);
  cursor: pointer;
  color: var(--ink-600);
  font-weight: 500;
  transition: background var(--transition-fast);
}

.checkbox-label:hover {
  background: rgba(248, 250, 252, 1);
}

.checkbox-label input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand-600);
  cursor: pointer;
}

/* ============================================
   FORM LAYOUT HELPERS
   ============================================ */

.cheque-inputs {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
}

.cheque-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.cheque-row-dates {
  grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 900px) {
  .cheque-row-dates {
    grid-template-columns: repeat(4, 1fr);
  }
}

.cheque-row-dates input[type="date"] {
  min-height: 42px;
}

.autre-payment-inputs {
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
  padding: 14px;
  border-radius: var(--radius-md, 12px);
  border: 1px solid var(--ink-150, #e2e8f0);
  background: var(--ink-50, #f8fafc);
}

.autre-payment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

.autre-field-label {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-500);
  margin-bottom: 6px;
}

@media (min-width: 900px) {
  .autre-payment-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 680px) {
  .autre-payment-grid {
    grid-template-columns: 1fr;
  }
}

.client-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

@media (max-width: 680px) {
  .cheque-row,
  .client-row {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   MODALS
   ============================================ */

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(15, 23, 42, 0.5);
  backdrop-filter: blur(8px);
  animation: modalFadeIn 0.25s ease both;
}

@keyframes modalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.modal-card {
  width: min(780px, 100%);
  max-height: min(760px, calc(100vh - 48px));
  overflow-y: auto;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: var(--radius-2xl);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--shadow-2xl);
  animation: modalSlideUp 0.3s ease both;
}

@keyframes modalSlideUp {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 28px 20px;
  border-bottom: 1px solid var(--line-light);
}

.modal-header span {
  color: var(--ink-500);
  font-weight: 600;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.modal-header h2 {
  margin: 4px 0 0;
  color: var(--ink-900);
  font-size: var(--font-size-xl);
}

.modal-close {
  width: 40px;
  height: 40px;
  padding: 0;
  border-radius: 50%;
  background: var(--brand-100);
  color: var(--brand-700);
  box-shadow: none;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  border: none;
  font-family: inherit;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-close:hover {
  background: var(--brand-200);
  transform: rotate(90deg);
}

/* Sale Detail Modal - Special Styling */
.sale-detail-modal {
  position: relative;
  width: min(860px, calc(100vw - 36px));
  overflow: hidden;
}

.sale-detail-modal::before {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 120px;
  background:
    radial-gradient(circle at 88% 12%, rgba(255, 255, 255, 0.25), transparent 22%),
    linear-gradient(135deg, var(--brand-900), var(--brand-600));
  pointer-events: none;
  z-index: 0;
}

.sale-detail-modal .modal-header {
  position: relative;
  z-index: 1;
  align-items: center;
  margin: 0;
  padding: 28px 32px 24px;
  color: #ffffff;
  border-bottom: none;
}

.sale-detail-modal .modal-header span {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.75rem;
}

.sale-detail-modal .modal-header h2 {
  color: #ffffff;
  font-size: 1.6rem;
}

.sale-detail-modal .modal-close {
  border: 1px solid rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.15);
  color: #ffffff;
  backdrop-filter: blur(10px);
}

.sale-detail-modal .modal-close:hover {
  background: #ffffff;
  color: var(--brand-600);
  transform: rotate(90deg);
}

.sale-detail-content {
  position: relative;
  z-index: 1;
  max-height: min(560px, calc(100vh - 220px));
  overflow-y: auto;
  padding: 24px 28px 28px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  scrollbar-width: thin;
  scrollbar-color: var(--brand-200) transparent;
}

.sale-detail-content::-webkit-scrollbar {
  width: 6px;
}

.sale-detail-content::-webkit-scrollbar-track {
  background: transparent;
}

.sale-detail-content::-webkit-scrollbar-thumb {
  border-radius: var(--radius-full);
  background: var(--brand-200);
}

.sale-detail-content div {
  position: relative;
  overflow: hidden;
  min-height: 80px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, #ffffff, var(--ink-50)),
    radial-gradient(circle at 100% 0, rgba(239, 68, 68, 0.06), transparent 26%);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.sale-detail-content div:hover {
  transform: translateY(-2px);
  border-color: var(--brand-200);
  box-shadow: var(--shadow-md);
}

.sale-detail-content span {
  display: block;
  margin-bottom: 6px;
  color: var(--ink-500);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sale-detail-content strong {
  display: block;
  color: var(--ink-900);
  font-size: var(--font-size-base);
  font-weight: 600;
  line-height: 1.4;
  word-break: break-word;
}

.sale-detail-content div:nth-child(4) strong,
.sale-detail-content div:nth-child(5) strong {
  color: var(--brand-700);
  font-weight: 800;
  font-size: var(--font-size-lg);
}

.sale-detail-wide {
  grid-column: 1 / -1;
  min-height: 90px;
}

@media (max-width: 680px) {
  .sale-detail-content {
    grid-template-columns: 1fr;
  }

  .modal-header {
    padding: 20px;
  }

  .sale-detail-content {
    padding: 18px;
  }
}

/* ============================================
   SALE SUCCESS NOTIFICATION
   ============================================ */

.sale-notification {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 200;
  width: 340px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.18), 0 4px 16px rgba(0,0,0,0.08);
  overflow: hidden;
  animation: saleNotifIn 0.45s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.sale-notification.removing {
  animation: saleNotifOut 0.3s ease forwards;
}

@keyframes saleNotifIn {
  from { opacity: 0; transform: translateY(60px) scale(0.92); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}

@keyframes saleNotifOut {
  from { opacity: 1; transform: translateY(0) scale(1); }
  to   { opacity: 0; transform: translateY(40px) scale(0.9); }
}

.sale-notif-header {
  background: linear-gradient(135deg, #b91c1c, #dc2626);
  padding: 16px 16px 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
}

.sale-notif-check {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.2);
  border: 2px solid rgba(255,255,255,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  animation: checkPop 0.4s 0.15s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes checkPop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

.sale-notif-check i {
  color: #fff;
  font-size: 1.1rem;
}

.sale-notif-title {
  flex: 1;
}

.sale-notif-title strong {
  display: block;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2;
}

.sale-notif-title small {
  color: rgba(255,255,255,0.75);
  font-size: 0.72rem;
}

.sale-notif-close {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  width: 24px !important;
  height: 24px !important;
  min-height: unset !important;
  padding: 0 !important;
  background: rgba(255,255,255,0.15) !important;
  border: none !important;
  border-radius: 50% !important;
  color: rgba(255,255,255,0.85) !important;
  font-size: 0.85rem !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: pointer;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sale-notif-close::after { display: none !important; }
.sale-notif-close:hover { background: rgba(255,255,255,0.3) !important; transform: none !important; }

.sale-notif-body {
  padding: 14px 16px 10px;
}

.sale-notif-client {
  font-size: 1rem;
  font-weight: 700;
  color: #111;
  margin-bottom: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sale-notif-client span {
  font-size: 0.75rem;
  font-weight: 500;
  color: #64748b;
  margin-left: 6px;
}

.sale-notif-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.sale-notif-detail {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sale-notif-detail label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #94a3b8;
  font-weight: 600;
}

.sale-notif-detail strong {
  font-size: 0.88rem;
  font-weight: 700;
  color: #1e293b;
}

.sale-notif-detail.amount strong {
  color: #b91c1c;
  font-size: 1rem;
}

.sale-notif-status {
  margin: 10px 0 4px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: #d97706;
  font-weight: 600;
}

.sale-notif-status i { font-size: 0.7rem; }

.sale-notif-progress {
  height: 3px;
  background: #f1f5f9;
  margin: 0 -16px;
  position: relative;
  overflow: hidden;
}

.sale-notif-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, #b91c1c, #dc2626);
  animation: saleProgressShrink 5s linear forwards;
  transform-origin: left;
}

@keyframes saleProgressShrink {
  from { width: 100%; }
  to   { width: 0%; }
}

/* ============================================
   TOAST NOTIFICATIONS
   ============================================ */

.toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.toast {
  padding: 14px 20px;
  border-radius: var(--radius-lg);
  background: var(--surface-solid);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-xl);
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--ink-700);
  animation: toastSlideIn 0.35s ease both;
  max-width: 360px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.toast.toast-success {
  border-left: 4px solid var(--success);
}

.toast.toast-error {
  border-left: 4px solid var(--error);
}

.toast.toast-warning {
  border-left: 4px solid var(--warning);
}

@keyframes toastSlideIn {
  from {
    opacity: 0;
    transform: translateX(40px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* ============================================
   KPI DASHBOARD
   ============================================ */

#kpi-toggle-button.active {
  background: linear-gradient(135deg, var(--brand-700), var(--brand-600));
}

.kpi-dashboard {
  margin: 16px 0 22px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--ink-50);
}

.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 14px;
  margin: 18px 0;
}

@media (max-width: 900px) {
  .admin-kpi-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.admin-kpi-card {
  padding: 18px;
  border: 1px solid rgba(239, 68, 68, 0.12);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at top right, rgba(239, 68, 68, 0.1), transparent 40%),
    var(--surface-solid);
  box-shadow: var(--shadow-md);
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.admin-kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.admin-kpi-card span {
  display: block;
  color: var(--ink-500);
  font-weight: 600;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: 8px;
}

.admin-kpi-card strong {
  display: block;
  color: var(--brand-700);
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1;
}

/* ============================================
   ANALYTICS
   ============================================ */

.analytics-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface-solid);
  color: var(--ink-500);
  font-weight: 600;
}

.analytics-toolbar strong {
  color: var(--brand-700);
}

.analytics-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr;
  gap: 14px;
  margin-top: 14px;
}

@media (max-width: 900px) {
  .analytics-grid {
    grid-template-columns: 1fr;
  }
}

.analytics-card {
  min-height: 200px;
  padding: 18px;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-xl);
  background: var(--surface-solid);
  box-shadow: var(--shadow-md);
}

.analytics-card.wide {
  grid-row: span 2;
}

.analytics-card h3 {
  margin: 0 0 16px;
  color: var(--ink-700);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.line-chart {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  align-items: end;
  height: 160px;
  padding: 12px;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(rgba(148, 163, 184, 0.15) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148, 163, 184, 0.15) 1px, transparent 1px);
  background-size: 100% 25%;
}

.line-chart span {
  align-self: end;
  min-height: 8px;
  border-radius: var(--radius-sm) var(--radius-sm) 3px 3px;
  background: linear-gradient(180deg, var(--brand-500), var(--brand-700));
  animation: growMetric 0.8s ease both;
  transform-origin: bottom;
}

@keyframes growMetric {
  from {
    transform: scaleY(0.1);
    opacity: 0.5;
  }
  to {
    transform: scaleY(1);
    opacity: 1;
  }
}

.line-chart small {
  color: var(--ink-500);
  font-size: 0.65rem;
  text-align: center;
  font-weight: 600;
  margin-top: 6px;
}

.bar-list,
.metric-list {
  display: grid;
  gap: 10px;
}

.bar-row {
  display: grid;
  gap: 6px;
}

.bar-row div,
.metric-list div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--ink-500);
  font-weight: 600;
  font-size: var(--font-size-sm);
}

.bar-row span {
  color: var(--ink-400);
  font-size: 0.72rem;
}

.bar-row em {
  display: block;
  height: 8px;
  overflow: hidden;
  border-radius: var(--radius-full);
  background: var(--brand-100);
}

.bar-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand-500), var(--brand-700));
}

.metric-list div {
  padding: 8px 0;
  border-bottom: 1px solid var(--ink-100);
}

.metric-list strong {
  color: var(--brand-700);
}

/* ============================================
   AMOUNT MANAGER
   ============================================ */

/* Panel header */
.amount-panel-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--ink-100);
}
.amount-panel-icon {
  width: 46px; height: 46px;
  border-radius: 13px;
  background: linear-gradient(135deg, var(--brand-600), #b91c1c);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(220,38,38,0.28);
}
.amount-panel-title {
  margin: 0 0 3px;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink-900);
}
.amount-panel-sub {
  margin: 0;
  font-size: 0.75rem;
  color: var(--ink-400);
  font-weight: 500;
}

/* Sections */
.amount-section {
  border: 1.5px solid var(--ink-100);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 14px;
}
.amount-section:last-child { margin-bottom: 0; }
.amount-section-pt { margin-top: 0; }

.amount-section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 16px;
  background: var(--ink-50);
  border-bottom: 1.5px solid var(--ink-100);
}
.amount-section-badge {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem; flex-shrink: 0;
}
.amount-section-badge.standard {
  background: #fff1f2; color: var(--brand-600);
  border: 1px solid rgba(220,38,38,0.15);
}
.amount-section-badge.pt {
  background: #fffbeb; color: #d97706;
  border: 1px solid rgba(217,119,6,0.18);
}
.amount-section-badge.pod {
  background: #f5f3ff; color: #6d28d9;
  border: 1px solid rgba(109,40,217,0.18);
}
.amount-section-title {
  font-size: 0.88rem; font-weight: 700;
  color: var(--ink-800); margin: 0 0 2px;
}
.amount-section-sub {
  font-size: 0.72rem; color: var(--ink-400); font-weight: 500;
}

/* Section body */
.amount-section-body {
  padding: 14px 16px;
  background: #fff;
}

/* Add row form */
.amount-add-row {
  display: flex;
  gap: 10px;
  align-items: center;
}
.amount-add-row input[type="number"] {
  flex: 1;
  min-width: 0;
  padding: 9px 14px;
  border: 1.5px solid var(--ink-200);
  border-radius: 10px;
  font-size: 0.875rem;
  font-family: inherit;
  color: var(--ink-800);
  background: var(--ink-50);
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
  -moz-appearance: textfield;
  appearance: textfield;
}
.amount-add-row input[type="number"]::-webkit-inner-spin-button,
.amount-add-row input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.amount-add-row input[type="number"]:focus {
  outline: none;
  border-color: var(--brand-400);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(220,38,38,0.07);
}
.amount-add-row button[type="submit"] {
  padding: 9px 18px !important;
  min-height: unset !important;
  height: auto !important;
  border-radius: 10px !important;
  font-size: 0.84rem !important;
  font-weight: 600 !important;
  white-space: nowrap;
  background: var(--brand-600) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(220,38,38,0.2) !important;
  flex-shrink: 0;
  gap: 6px !important;
  transition: background 0.15s, box-shadow 0.15s !important;
}
.amount-add-row button[type="submit"]:hover {
  background: var(--brand-700) !important;
  box-shadow: 0 3px 12px rgba(220,38,38,0.28) !important;
}

/* Amount pills */
.amount-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 8px 5px 13px;
  border-radius: 999px;
  background: #fff;
  border: 1.5px solid rgba(220,38,38,0.13);
  color: var(--ink-700);
  font-weight: 700;
  font-size: 0.8rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.amount-pill:hover {
  border-color: rgba(220,38,38,0.3);
  box-shadow: 0 2px 8px rgba(220,38,38,0.09);
}

.delete-amount-button,
.delete-amount-pt-button,
.delete-amount-pod-button {
  width: 18px !important;
  height: 18px !important;
  min-height: unset !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 50% !important;
  background: rgba(220,38,38,0.09) !important;
  color: var(--brand-500) !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.68rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s !important;
  gap: 0 !important;
}
.delete-amount-button:hover {
  background: var(--brand-600) !important;
  color: #fff !important;
}

/* PT pill */
.amount-pill-pt {
  background: #fffbeb !important;
  border-color: rgba(217,119,6,0.18) !important;
  color: #92400e !important;
}
.amount-pill-pt:hover {
  border-color: rgba(217,119,6,0.38) !important;
  box-shadow: 0 2px 8px rgba(217,119,6,0.1) !important;
}
.amount-pill-pt .delete-amount-pt-button {
  background: rgba(217,119,6,0.1) !important;
  color: #b45309 !important;
}
.amount-pill-pt .delete-amount-pt-button:hover {
  background: #d97706 !important;
  color: #fff !important;
}

/* POD pill */
.amount-pill-pod {
  background: #f5f3ff !important;
  border-color: rgba(109,40,217,0.18) !important;
  color: #5b21b6 !important;
}
.amount-pill-pod:hover {
  border-color: rgba(109,40,217,0.35) !important;
  box-shadow: 0 2px 8px rgba(109,40,217,0.1) !important;
}
.amount-pill-pod .delete-amount-pod-button {
  background: rgba(109,40,217,0.1) !important;
  color: #6d28d9 !important;
}
.amount-pill-pod .delete-amount-pod-button:hover {
  background: #6d28d9 !important;
  color: #fff !important;
}

.amounts-list-empty {
  display: block;
  width: 100%;
  margin-top: 14px;
  font-size: 0.8rem;
  color: var(--ink-400);
  font-weight: 500;
}

.amounts-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
  min-height: 20px;
}

/* ============================================
   BACKUP SECTION
   ============================================ */

.backup-section {
  border: 1px solid var(--success);
  background: linear-gradient(135deg, #f0fdf4, var(--surface-solid));
}

.backup-section h3 {
  color: var(--success);
}

.admin-danger-zone {
  margin-top: 20px;
  padding: 16px 18px;
  border-radius: 12px;
  border: 1px solid rgba(220, 38, 38, 0.35);
  background: linear-gradient(135deg, #fef2f2, #fff5f5);
}

.admin-danger-zone-title {
  margin: 0 0 8px;
  font-weight: 700;
  color: #b91c1c;
  font-size: 0.95rem;
}

.admin-danger-zone-desc {
  margin: 0 0 14px;
  font-size: 0.875rem;
  color: var(--ink-600);
  line-height: 1.45;
}

.admin-danger-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(135deg, #dc2626, #b91c1c);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.admin-danger-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(220, 38, 38, 0.35);
}

.admin-danger-btn:active {
  transform: translateY(0);
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

@media (max-width: 980px) {
  .grid {
    grid-template-columns: 1fr;
  }

  .filters {
    grid-template-columns: 1fr 1fr;
  }

  .site-summary-card {
    grid-template-columns: 1fr;
  }

  .site-summary-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .app-shell {
    width: calc(100% - 20px);
    padding-top: 12px;
  }

  header,
  .card {
    border-radius: var(--radius-xl);
    padding: 20px;
  }

  .top-bar {
    gap: 8px;
    padding: 6px 12px;
  }

  .profile-trigger {
    min-width: unset;
  }

  h1 {
    font-size: 2rem;
  }

  .admin-grid,
  .admin-user-row {
    grid-template-columns: 1fr;
  }

  .export-actions {
    flex-direction: column;
  }

  .export-button {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .brand-subtitle {
    align-self: flex-start;
  }

  .site-summary-grid {
    grid-template-columns: 1fr 1fr;
  }

  .admin-kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.hidden {
  display: none !important;
}

.muted {
  color: var(--ink-400);
  font-size: var(--font-size-sm);
}

.small {
  font-size: var(--font-size-xs);
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* Focus visible for accessibility */
:focus-visible {
  outline: 2px solid var(--brand-500);
  outline-offset: 2px;
}

/* Scrollbar styling */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--ink-50);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb {
  background: var(--ink-300);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--ink-400);
}

/* Selection styling */
::selection {
  background: var(--brand-200);
  color: var(--brand-900);
}

/* ============================================
   ATTACHMENT / PIÈCES JOINTES
   ============================================ */

.attachment-section {
  margin-top: 18px;
}

.attachment-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--ink-600);
  margin-bottom: 8px;
}

.attachment-hint {
  font-weight: 400;
  color: var(--ink-400);
  font-size: 0.72rem;
}

.attachment-dropzone {
  border: 2px dashed var(--ink-300);
  border-radius: var(--radius-lg);
  background: var(--ink-50);
  transition: border-color 0.2s, background 0.2s;
  cursor: pointer;
}

.attachment-dropzone.drag-over {
  border-color: var(--brand-500);
  background: var(--brand-50);
}

.attachment-dropzone-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 16px;
  pointer-events: none;
}

.attachment-drop-icon {
  font-size: 2rem;
  color: var(--ink-300);
}

.attachment-dropzone-inner p {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--ink-400);
}

.attachment-btns {
  display: flex;
  gap: 8px;
  pointer-events: auto;
}

.attachment-btns button {
  font-size: 0.8rem !important;
  padding: 6px 14px !important;
  min-height: unset !important;
  height: auto !important;
}

.attachment-previews {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.attachment-preview-item {
  position: relative;
  width: 90px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

.attachment-preview-item img {
  width: 90px;
  height: 70px;
  object-fit: cover;
  display: block;
}

.attachment-preview-pdf {
  width: 90px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff7f7;
}

.attachment-preview-pdf i {
  font-size: 2rem;
  color: var(--brand-500);
}

.attachment-preview-info {
  padding: 4px 6px;
  font-size: 0.62rem;
  color: var(--ink-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}

.attachment-preview-remove {
  position: absolute !important;
  top: 3px !important;
  right: 3px !important;
  width: 18px !important;
  height: 18px !important;
  min-height: unset !important;
  padding: 0 !important;
  background: rgba(0,0,0,0.55) !important;
  border: none !important;
  border-radius: 50% !important;
  color: #fff !important;
  font-size: 0.65rem !important;
  line-height: 1 !important;
  box-shadow: none !important;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.attachment-preview-remove:hover {
  background: rgba(185,28,28,0.85) !important;
}

/* Attachments in sale detail modal */
.sale-detail-attachments {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  grid-column: 1 / -1;
}

.sale-detail-attachments h4 {
  margin: 0 0 10px;
  font-size: 0.8rem;
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.sale-detail-attachment-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sale-detail-attachment-thumb {
  width: 80px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  background: #fff;
  transition: box-shadow 0.15s;
}

.sale-detail-attachment-thumb:hover {
  box-shadow: var(--shadow-md);
}

.sale-detail-attachment-thumb img {
  width: 80px;
  height: 60px;
  object-fit: cover;
  display: block;
}

.sale-detail-attachment-pdf {
  width: 80px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff7f7;
}

.sale-detail-attachment-pdf i {
  font-size: 1.8rem;
  color: var(--brand-500);
}

.sale-detail-attachment-name {
  padding: 3px 5px;
  font-size: 0.6rem;
  color: var(--ink-500);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================
   ANALYTICS DASHBOARD - Advanced Charts & KPIs
   ============================================ */

/* ──── CHEQUE ANALYTICS DASHBOARD ──────────── */
.cheque-analytics-grid {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cheque-kpi-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.cheque-kpi-card {
  background: var(--surface-elevated);
  border: 1px solid var(--line-light);
  border-radius: 12px;
  padding: 20px;
  transition: all 0.2s ease;
  position: relative;
  overflow: hidden;
}

.cheque-kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--brand-500);
  transition: height 0.2s ease;
}

.cheque-kpi-card:hover {
  border-color: var(--brand-200);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px -8px var(--shadow-brand);
}

.cheque-kpi-card:hover::before {
  height: 4px;
}

.cheque-kpi-card.total-cheques::before { background: var(--brand-500); }
.cheque-kpi-card.valid-cheques::before { background: var(--success-500); }
.cheque-kpi-card.anomaly-cheques::before { background: var(--error-500); }
.cheque-kpi-card.pending-cheques::before { background: var(--warning-500); }

.cheque-kpi-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.cheque-kpi-title {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--ink-400);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.cheque-kpi-header i {
  font-size: 18px;
  color: var(--brand-400);
  opacity: 0.7;
}

.cheque-kpi-card.valid-cheques .cheque-kpi-header i { color: var(--success-500); }
.cheque-kpi-card.anomaly-cheques .cheque-kpi-header i { color: var(--error-500); }
.cheque-kpi-card.pending-cheques .cheque-kpi-header i { color: var(--warning-500); }

.cheque-kpi-value {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--ink-base);
  line-height: 1.1;
  margin-bottom: 4px;
}

.cheque-kpi-sub {
  font-size: var(--font-size-sm);
  color: var(--ink-300);
  font-weight: 500;
}

.cheque-charts-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.analytics-chart-card.cheque-chart {
  min-height: 320px;
}

.cheque-anomalies-section,
.cheque-details-section {
  width: 100%;
}

.cheque-anomalies-container {
  max-height: 400px;
  overflow-y: auto;
}

.cheque-anomaly-item {
  display: flex;
  align-items: flex-start;
  padding: 14px 16px;
  border: 1px solid var(--ink-200);
  border-radius: 12px;
  margin-bottom: 12px;
  background: var(--surface-solid);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  cursor: pointer;
  border-left-width: 5px;
}

.cheque-anomaly-item:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.cheque-anomaly-item.severity-high {
  border-left-color: #dc2626;
  border-color: #fecaca;
  background: linear-gradient(105deg, #fef2f2 0%, #fff 55%);
}

.cheque-anomaly-item.severity-medium {
  border-left-color: #d97706;
  border-color: #fde68a;
  background: linear-gradient(105deg, #fffbeb 0%, #fff 55%);
}

.cheque-anomaly-item.severity-low {
  border-left-color: #0284c7;
  border-color: #bae6fd;
  background: linear-gradient(105deg, #eff6ff 0%, #fff 55%);
}

.cheque-anomaly-item.type-missing_number {
  border-left-color: #b91c1c;
}

.cheque-anomaly-item.type-long_pending {
  border-left-color: #c2410c;
}

.cheque-anomaly-item.type-amount_mismatch {
  border-left-color: #7c3aed;
}

.cheque-anomaly-item.type-high_amount_pending {
  border-left-color: #be185d;
}

.cheque-anomaly-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 14px;
  font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}

.cheque-anomaly-icon.severity-high {
  background: #dc2626;
  color: #fff;
}

.cheque-anomaly-icon.severity-medium {
  background: #d97706;
  color: #fff;
}

.cheque-anomaly-icon.severity-low {
  background: #0284c7;
  color: #fff;
}

.cheque-anomaly-content {
  flex: 1;
  min-width: 0;
}

.cheque-anomaly-title {
  font-weight: 800;
  font-size: 0.92rem;
  margin-bottom: 4px;
}

.cheque-anomaly-item.severity-high .cheque-anomaly-title {
  color: #991b1b;
}

.cheque-anomaly-item.severity-medium .cheque-anomaly-title {
  color: #92400e;
}

.cheque-anomaly-item.severity-low .cheque-anomaly-title {
  color: #075985;
}

.cheque-anomaly-description {
  font-size: var(--font-size-sm);
  line-height: 1.45;
  font-weight: 500;
}

.cheque-anomaly-item.severity-high .cheque-anomaly-description {
  color: #b91c1c;
}

.cheque-anomaly-item.severity-medium .cheque-anomaly-description {
  color: #b45309;
}

.cheque-anomaly-item.severity-low .cheque-anomaly-description {
  color: #0369a1;
}

.cheque-anomaly-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  margin-top: 10px;
  font-size: 0.72rem;
  color: var(--ink-500);
}

.cheque-anomaly-severity {
  padding: 3px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-left: auto;
}

.cheque-anomaly-severity.severity-high {
  background: #dc2626;
  color: #fff;
}

.cheque-anomaly-severity.severity-medium {
  background: #d97706;
  color: #fff;
}

.cheque-anomaly-severity.severity-low {
  background: #0284c7;
  color: #fff;
}

.cheque-empty-state--ok i {
  color: var(--success);
}

.btn-refresh-anomalies {
  background: var(--brand-500);
  color: white;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.btn-refresh-anomalies:hover {
  background: var(--brand-600);
  transform: translateY(-1px);
}

.btn-refresh-anomalies i {
  font-size: 12px;
}

.cheque-filters {
  display: flex;
  gap: 12px;
  align-items: center;
}

.cheque-filter {
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink-base);
  font-size: var(--font-size-sm);
}

.cheque-table-container {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  border: 1px solid var(--ink-100);
  margin-top: 8px;
}

.cheque-table-container .cheque-list-table {
  width: 100%;
  min-width: 1080px;
  table-layout: fixed;
  border-collapse: collapse;
  border-spacing: 0;
  margin: 0;
  box-shadow: none;
  border: none;
  border-radius: 0;
  background: #fff;
}

.cheque-table-container .cheque-list-table thead tr {
  background: linear-gradient(135deg, #991b1b, #b91c1c);
}

.cheque-table-container .cheque-list-table th {
  position: static;
  top: auto;
  z-index: auto;
  padding: 11px 10px;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #fff;
  border-bottom: none;
  white-space: nowrap;
  text-align: left;
}

.cheque-table-container .cheque-list-table td {
  padding: 10px;
  font-size: 0.8rem;
  color: var(--ink-700);
  border-bottom: 1px solid var(--ink-100);
  vertical-align: middle;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cheque-table-container .cheque-list-table tbody tr {
  animation: none;
  transform: none;
}

.cheque-table-container .cheque-list-table tbody tr:nth-child(even) {
  background: #fffafb;
}

.cheque-table-container .cheque-list-table tbody tr:hover {
  background: var(--brand-50);
}

.cheque-table-container .clickable-row::before {
  display: none;
}

.cheque-table-container .clickable-row:hover {
  transform: none;
  box-shadow: none;
}

.cheque-table-container .chq-col-id { width: 52px; }
.cheque-table-container .chq-col-client { width: 130px; white-space: normal; word-break: break-word; }
.cheque-table-container .chq-col-amount { width: 95px; font-weight: 700; color: var(--brand-800); }
.cheque-table-container .chq-col-num { width: 90px; font-family: var(--font-mono, ui-monospace, monospace); font-size: 0.75rem; }
.cheque-table-container .chq-col-chq-amt { width: 110px; }
.cheque-table-container .chq-col-status { width: 100px; text-align: center; }
.cheque-table-container .chq-col-receptionist { width: 130px; }
.cheque-table-container .chq-col-site { width: 100px; font-weight: 600; }
.cheque-table-container .chq-col-age { width: 88px; text-align: center; }
.cheque-table-container .chq-col-anomaly { width: 108px; text-align: center; overflow: visible; }

.cheque-age-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--ink-100);
  color: var(--ink-600);
  font-size: 0.72rem;
  font-weight: 700;
}

.cheque-ok-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 999px;
  background: #f0fdf4;
  color: #15803d;
  font-size: 0.68rem;
  font-weight: 700;
}

.cheque-status-badge {
  padding: 4px 8px;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
}

.cheque-status-badge.status-validée {
  background: var(--success-100);
  color: var(--success-700);
}

.cheque-status-badge.status-en-attente {
  background: var(--warning-100);
  color: var(--warning-700);
}

.cheque-status-badge.status-rejeté {
  background: var(--error-100);
  color: var(--error-700);
}

.cheque-anomaly-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fff1f2;
  color: #be123c;
  border: 1px solid #fecdd3;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  white-space: nowrap;
}

.cheque-table-container .cheque-status-badge {
  min-width: 0;
  display: inline-flex;
}

.cheque-empty-state {
  text-align: center;
  padding: 40px;
  color: var(--ink-300);
}

.cheque-empty-state i {
  font-size: 3rem;
  margin-bottom: 16px;
  opacity: 0.5;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .cheque-charts-row {
    grid-template-columns: 1fr;
  }

  .cheque-kpi-cards {
    grid-template-columns: 1fr;
  }

  .cheque-filters {
    flex-direction: column;
    align-items: stretch;
  }
}

#analytics-section {
  animation: cardEnter 0.5s ease both;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
}

.analytics-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line-light);
}

.analytics-header h2 {
  margin: 0;
  display: flex;
  align-items: center;
}

.analytics-controls {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.analytics-period-select,
.analytics-site-select {
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--ink-200);
  background: var(--surface-solid);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--ink-700);
  cursor: pointer;
  min-width: 160px;
  transition: all var(--transition-base);
}

.analytics-period-select:hover,
.analytics-site-select:hover {
  border-color: var(--brand-300);
}

.analytics-period-select:focus,
.analytics-site-select:focus {
  outline: none;
  border-color: var(--brand-400);
  box-shadow: 0 0 0 3px var(--brand-100);
}

/* KPI Cards Grid */
.analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

@media (max-width: 700px) {
  .analytics-kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .analytics-kpi-grid {
    grid-template-columns: 1fr;
  }
}

.analytics-kpi-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  background: var(--surface-solid);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  animation: kpiSlideIn 0.5s ease both;
}

.analytics-kpi-card:nth-child(1) { animation-delay: 0.05s; }
.analytics-kpi-card:nth-child(2) { animation-delay: 0.1s; }
.analytics-kpi-card:nth-child(3) { animation-delay: 0.15s; }
.analytics-kpi-card:nth-child(4) { animation-delay: 0.2s; }

@keyframes kpiSlideIn {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.analytics-kpi-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--brand-200);
}

.kpi-icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: var(--radius-lg);
  font-size: 1.3rem;
  flex-shrink: 0;
}

.analytics-kpi-card:nth-child(1) .kpi-icon {
  background: linear-gradient(135deg, #fef3c7, #fbbf24);
  color: #92400e;
}

.analytics-kpi-card:nth-child(2) .kpi-icon {
  background: linear-gradient(135deg, #dbeafe, #60a5fa);
  color: #1e40af;
}

.analytics-kpi-card:nth-child(3) .kpi-icon {
  background: linear-gradient(135deg, #d1fae5, #34d399);
  color: #065f46;
}

.analytics-kpi-card:nth-child(4) .kpi-icon {
  background: linear-gradient(135deg, #ede9fe, #a78bfa);
  color: #5b21b6;
}

.kpi-content {
  flex: 1;
  min-width: 0;
}

.kpi-label {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--ink-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 4px;
}

.kpi-value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--ink-900);
  line-height: 1.2;
}

.kpi-change {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  font-weight: 700;
  margin-top: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-full);
}

.kpi-change.positive {
  color: var(--success);
  background: var(--success-bg);
}

.kpi-change.negative {
  color: var(--error);
  background: var(--error-bg);
}

.kpi-change.neutral {
  color: var(--ink-500);
  background: var(--ink-100);
}

.kpi-sublabel {
  font-size: var(--font-size-xs);
  color: var(--ink-400);
  font-weight: 600;
  margin-top: 4px;
}

/* Charts Grid */
.analytics-charts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

@media (max-width: 900px) {
  .analytics-charts-grid {
    grid-template-columns: 1fr;
  }
}

.analytics-chart-card {
  background: var(--surface-solid);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 20px;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.analytics-chart-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--brand-200);
}

.analytics-chart-card.full-width {
  grid-column: 1 / -1;
}

.analytics-chart-card h3 {
  margin: 0 0 16px 0;
  font-size: var(--font-size-base);
  font-weight: 700;
  color: var(--ink-800);
  display: flex;
  align-items: center;
}

.chart-container {
  position: relative;
  height: 280px;
  width: 100%;
}

.analytics-chart-card.full-width .chart-container {
  height: 320px;
}

/* Chart.js custom styling */
.chart-container canvas {
  max-width: 100%;
}

/* Analytics loading state */
.analytics-loading {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 60px 20px;
  color: var(--ink-400);
  font-weight: 600;
}

.analytics-loading::before {
  content: '';
  width: 32px;
  height: 32px;
  border: 3px solid var(--ink-200);
  border-top-color: var(--brand-600);
  border-radius: 50%;
  margin-right: 12px;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Empty state for analytics */
.analytics-empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--ink-400);
}

.analytics-empty i {
  font-size: 3rem;
  color: var(--ink-200);
  margin-bottom: 16px;
  display: block;
}

.analytics-empty p {
  font-size: var(--font-size-sm);
  color: var(--ink-400);
}

/* Analytics section block titles */
.analytics-section-block {
  margin: 28px 0 8px;
}
.analytics-section-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink-700);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.analytics-section-title i { color: var(--brand-600); }

/* Site detail cards grid */
.site-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.site-detail-card {
  background: var(--surface-1, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 14px;
  padding: 18px 16px;
  transition: box-shadow 0.2s, transform 0.2s;
}
.site-detail-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,0.09); transform: translateY(-2px); }
.site-detail-card .site-name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--brand-600);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.site-detail-card .site-stat {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.82rem;
  padding: 4px 0;
  border-bottom: 1px solid var(--border, #f0f0f0);
  color: var(--ink-500);
}
.site-detail-card .site-stat:last-child { border-bottom: none; }
.site-detail-card .site-stat strong { color: var(--ink-800); font-size: 0.88rem; }
.site-validation-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 700;
  background: var(--success-bg, #d1fae5);
  color: var(--success, #059669);
}

/* Analytics performance tables */
.analytics-tables-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 24px;
}
@media (max-width: 860px) {
  .analytics-tables-grid { grid-template-columns: 1fr; }
}

.analytics-table-card {
  background: #fff;
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-xl);
  padding: 20px 0 0;
  overflow: visible;
  box-shadow: var(--shadow-sm);
}

.analytics-table-card > div:first-child {
  padding: 0 20px 16px;
  border-bottom: 1px solid var(--ink-100);
}

.analytics-perf-table-wrap {
  overflow-x: auto;
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

.analytics-perf-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.83rem;
  table-layout: auto;
}

.analytics-perf-table thead tr {
  background: var(--ink-50);
}

.analytics-perf-table th {
  text-align: left;
  padding: 9px 14px;
  color: var(--ink-400);
  font-weight: 700;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  white-space: nowrap;
  border-bottom: 1px solid var(--ink-200);
}

.analytics-perf-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--ink-100);
  color: var(--ink-800);
  vertical-align: middle;
  white-space: nowrap;
}

.analytics-perf-table tr:last-child td { border-bottom: none; }

.analytics-perf-table tbody tr:hover td {
  background: var(--ink-50);
}

.analytics-perf-table td:first-child {
  font-weight: 600;
}

/* Rank badges */
.perf-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--ink-100);
  color: var(--ink-500);
  font-weight: 700;
  font-size: 0.7rem;
  margin-right: 8px;
  flex-shrink: 0;
}
.perf-rank.gold   { background: #fef3c7; color: #b45309; }
.perf-rank.silver { background: #f1f5f9; color: #475569; }
.perf-rank.bronze { background: #fef0e7; color: #b45309; }

/* Revenue cell — fluid bar + amount */
.perf-rev-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 120px;
}

.perf-rev-bar-track {
  height: 4px;
  background: var(--ink-100);
  border-radius: 4px;
  overflow: hidden;
  width: 100%;
}

.perf-rev-bar-fill {
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--brand-700), var(--brand-400));
  transition: width 0.5s ease;
}

.perf-rev-amount {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink-800);
  white-space: nowrap;
}

.perf-num {
  text-align: center;
  font-variant-numeric: tabular-nums;
  color: var(--ink-600);
  font-size: 0.82rem;
}

/* Site tag */
.perf-site-tag {
  display: inline-block;
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--ink-100);
  color: var(--ink-500);
  font-weight: 600;
}

/* Validation badge */
.site-validation-badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--success-bg);
  color: var(--success);
}

/* ── Staff filter tabs ── */
.staff-filter-tabs {
  display: flex;
  gap: 3px;
  background: var(--ink-100);
  border-radius: var(--radius-md);
  padding: 3px;
}

.staff-filter-tab,
.staff-filter-tab:not(.secondary):not(.tertiary) {
  border: none !important;
  background: transparent !important;
  padding: 5px 13px !important;
  min-height: unset !important;
  height: auto !important;
  border-radius: var(--radius-sm) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  color: var(--ink-500) !important;
  box-shadow: none !important;
  transition: background 0.15s, color 0.15s !important;
  letter-spacing: 0;
}

.staff-filter-tab:hover {
  background: rgba(255,255,255,0.7) !important;
  color: var(--ink-700) !important;
  transform: none !important;
}

.staff-filter-tab.active {
  background: #fff !important;
  color: var(--brand-700) !important;
  box-shadow: 0 1px 4px rgba(15,23,42,0.1) !important;
}

/* ── Staff type badges ── */
.staff-type-badge {
  display: inline-block;
  font-size: 0.68rem;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.staff-type-badge.mc      { background: #dbeafe; color: #1e40af; }
.staff-type-badge.coach   { background: #d1fae5; color: #065f46; }
.staff-type-badge.inconnu { background: var(--ink-100); color: var(--ink-400); font-weight: 500; letter-spacing: 0; }

.staff-scope-hint {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.staff-scope-pt {
  background: #ede9fe;
  color: #5b21b6;
}

.staff-scope-no-pt {
  background: #dbeafe;
  color: #1e40af;
}

.staff-scope-hint:not(.staff-scope-pt):not(.staff-scope-no-pt) {
  background: var(--ink-100);
  color: var(--ink-500);
}

.mc-coach-detail-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--brand-200);
  border-radius: var(--radius-full);
  background: var(--brand-50);
  color: var(--brand-700);
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}

.mc-coach-detail-btn:hover {
  background: var(--brand-100);
  border-color: var(--brand-300);
  transform: translateY(-1px);
}

.perf-actions {
  text-align: right;
  width: 1%;
  white-space: nowrap;
}

.mc-coach-perf-row:hover td {
  background: rgba(254, 242, 242, 0.5);
}

.mc-coach-detail-modal-card {
  max-width: 920px;
  width: min(96vw, 920px);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
}

.mc-coach-detail-header {
  border-bottom: 1px solid var(--ink-200);
  padding-bottom: 12px;
}

.mc-coach-detail-kicker {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--brand-600);
  margin-bottom: 4px;
}

.mc-coach-detail-subtitle {
  margin: 4px 0 0;
  font-size: 0.82rem;
  color: var(--ink-500);
}

.mc-coach-detail-content {
  overflow-y: auto;
  padding: 4px 2px 8px;
}

.mc-coach-kpi-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 18px 20px;
  margin-bottom: 16px;
  border-radius: 14px;
  background: linear-gradient(135deg, #991b1b 0%, #dc2626 55%, #f87171 100%);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.mc-coach-kpi-hero-amount {
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.mc-coach-kpi-period {
  margin: 8px 0 0;
  font-size: 0.8rem;
  opacity: 0.9;
}

.mc-coach-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

@media (max-width: 768px) {
  .mc-coach-kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .mc-coach-kpi-grid {
    grid-template-columns: 1fr;
  }
}

.mc-coach-kpi-tile {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid var(--ink-200);
  background: var(--surface-solid);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mc-coach-kpi-tile > i {
  font-size: 1rem;
  color: var(--brand-600);
  margin-bottom: 2px;
}

.mc-coach-kpi-tile strong {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--ink-900);
  line-height: 1.2;
}

.mc-coach-kpi-tile span {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-500);
}

.mc-coach-kpi-tile em {
  font-size: 0.75rem;
  font-style: normal;
  color: var(--ink-400);
  margin-top: 2px;
}

.mc-kpi-valid { border-color: #bbf7d0; background: #f0fdf4; }
.mc-kpi-valid > i { color: #15803d; }
.mc-kpi-pending { border-color: #fde68a; background: #fffbeb; }
.mc-kpi-pending > i { color: #d97706; }
.mc-kpi-pt { border-color: #ddd6fe; background: #f5f3ff; }
.mc-kpi-pt > i { color: #6d28d9; }

.mc-coach-detail-panels {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}

@media (max-width: 700px) {
  .mc-coach-detail-panels {
    grid-template-columns: 1fr;
  }
}

.mc-coach-detail-panel {
  border: 1px solid var(--ink-200);
  border-radius: 12px;
  padding: 14px;
  background: var(--ink-50);
}

.mc-coach-detail-panel--wide {
  grid-column: 1 / -1;
}

.mc-coach-detail-panel h3 {
  margin: 0 0 12px;
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--ink-800);
  display: flex;
  align-items: center;
  gap: 8px;
}

.mc-coach-detail-panel h3 i {
  color: var(--brand-600);
}

.mc-coach-subtable th {
  font-size: 0.68rem;
}

.mc-kpi-bar-track {
  height: 6px;
  background: var(--ink-200);
  border-radius: 999px;
  overflow: hidden;
  flex: 1;
  min-width: 48px;
}

.mc-kpi-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand-600), var(--brand-400));
  border-radius: 999px;
}

.mc-coach-subtable td:last-child {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mc-kpi-pct {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--ink-500);
  min-width: 32px;
  text-align: right;
}

.mc-coach-detail-empty {
  text-align: center;
  color: var(--ink-400);
  font-size: 0.85rem;
  padding: 12px !important;
}

.mc-coach-detail-hint {
  margin: 10px 0 0;
  font-size: 0.75rem;
  color: var(--ink-400);
}

.mc-coach-sale-row {
  cursor: pointer;
}

/* ============================================
   FINANCE VALIDATION PANEL
   ============================================ */

#finance-validation-panel {
  animation: cardEnter 0.4s ease both;
}

/* Finance KPI Grid — 5 statuts sur une ligne (desktop) */
.finance-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin: 18px 0 24px;
  width: 100%;
}

@media (max-width: 1100px) {
  .finance-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .finance-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 420px) {
  .finance-kpi-grid {
    grid-template-columns: 1fr;
  }
}

.finance-kpi-tile {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  border: 1.5px solid transparent;
  min-width: 0;
}

.finance-kpi-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  flex-shrink: 0;
}

.finance-kpi-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.finance-kpi-body strong {
  font-size: clamp(1.25rem, 2.2vw, 1.55rem);
  font-weight: 800;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.finance-kpi-body span {
  font-size: 0.72rem;
  color: var(--ink-500);
  font-weight: 500;
}

.finance-kpi-body em {
  font-size: 0.7rem;
  font-style: normal;
  font-weight: 600;
  opacity: 0.75;
}

.finance-kpi-pending {
  background: #fff7ed;
  border-color: #fed7aa;
}
.finance-kpi-pending .finance-kpi-icon { background: #ffedd5; color: #c2410c; }
.finance-kpi-pending .finance-kpi-body strong { color: #c2410c; }

.finance-kpi-validated {
  background: #f0fdf4;
  border-color: #bbf7d0;
}
.finance-kpi-validated .finance-kpi-icon { background: #dcfce7; color: #15803d; }
.finance-kpi-validated .finance-kpi-body strong { color: #15803d; }

.finance-kpi-total-validated {
  background: #eff6ff;
  border-color: #bfdbfe;
}
.finance-kpi-total-validated .finance-kpi-icon { background: #dbeafe; color: #1d4ed8; }
.finance-kpi-total-validated .finance-kpi-body strong { color: #1d4ed8; }

.finance-kpi-rejected {
  background: #fff1f2;
  border-color: #fecdd3;
}
.finance-kpi-rejected .finance-kpi-icon { background: #ffe4e6; color: #be123c; }
.finance-kpi-rejected .finance-kpi-body strong { color: #be123c; }

.finance-kpi-bloque {
  background: #fffbeb;
  border-color: #fde68a;
}
.finance-kpi-bloque .finance-kpi-icon { background: #fef3c7; color: #b45309; }
.finance-kpi-bloque .finance-kpi-body strong { color: #b45309; }

.finance-kpi-paye {
  background: #f0fdf4;
  border-color: #bbf7d0;
}
.finance-kpi-paye .finance-kpi-icon { background: #dcfce7; color: #15803d; }
.finance-kpi-paye .finance-kpi-body strong { color: #15803d; }

.finance-kpi-impaye {
  background: #fdf4ff;
  border-color: #e9d5ff;
}
.finance-kpi-impaye .finance-kpi-icon { background: #f3e8ff; color: #7e22ce; }
.finance-kpi-impaye .finance-kpi-body strong { color: #7e22ce; }

/* Refresh buttons */
#finance-refresh-btn,
#finance-bloques-refresh-btn,
#finance-history-refresh-btn,
#finance-refresh-btn:not(.secondary):not(.tertiary),
#finance-bloques-refresh-btn:not(.secondary):not(.tertiary),
#finance-history-refresh-btn:not(.secondary):not(.tertiary) {
  background: var(--ink-100) !important;
  color: var(--ink-600) !important;
  border: 1.5px solid var(--line-light) !important;
  box-shadow: none !important;
  font-size: 0.82rem !important;
  padding: 6px 14px !important;
  min-height: unset !important;
  height: auto !important;
  font-weight: 600 !important;
  border-radius: var(--radius-md) !important;
  transition: background 0.15s !important;
}
#finance-refresh-btn:hover,
#finance-bloques-refresh-btn:hover,
#finance-history-refresh-btn:hover {
  background: var(--ink-200) !important;
  color: var(--ink-800) !important;
}

/* Queue header */
.finance-queue-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0 12px;
  border-bottom: 1.5px solid var(--line-light);
  margin-bottom: 16px;
}

.finance-queue-header h3 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ink-700);
}

/* Shared filter panels (ventes + validations financières) */
.finance-filters {
  margin-bottom: 22px;
  border-radius: 16px;
  border: 1px solid var(--line-light);
  background: #fff;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.finance-filters-hero {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  background: linear-gradient(135deg, rgba(127, 29, 29, 0.94) 0%, rgba(185, 28, 28, 0.88) 55%, rgba(220, 38, 38, 0.82) 100%);
  position: relative;
  overflow: hidden;
}

.finance-filters-hero::after {
  content: '';
  position: absolute;
  right: -40px;
  top: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  pointer-events: none;
}

.finance-filters-hero-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.22);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.15rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.finance-filters-hero-text {
  position: relative;
  z-index: 1;
}

.finance-filters-hero-text h2 {
  margin: 0 0 4px;
  font-size: 1.12rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.02em;
}

.finance-filters-hero-text p {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.78);
}

.finance-filters-body {
  padding: 20px 24px 8px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.finance-filter-group {
  margin: 0;
  padding: 16px 18px;
  border-radius: 12px;
  background: linear-gradient(180deg, #fafbfc 0%, #fff 100%);
  border: 1px solid var(--ink-100);
}

.finance-filter-group--search {
  padding-bottom: 14px;
}

.finance-filter-group-title {
  margin: 0 0 14px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--brand-700);
  display: flex;
  align-items: center;
  gap: 8px;
}

.finance-filter-group-title i {
  font-size: 0.85rem;
  opacity: 0.85;
}

.finance-filter-group-grid {
  display: grid;
  gap: 14px 16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
}

.finance-filter-group-grid--period {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.finance-filter-site.hidden {
  display: none;
}

.finance-filter-group-grid--period:has(.finance-filter-site.hidden) {
  grid-template-columns: 1.2fr 1fr 1fr;
}

.finance-filter-field label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-500);
}

.finance-filter-control {
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  font-family: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ink-800);
  background: #fff;
  border: 1.5px solid var(--ink-200);
  border-radius: 10px;
  transition: border-color 0.15s, box-shadow 0.15s;
  min-height: 42px;
}

select.finance-filter-control {
  padding-right: 32px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-color: #fff;
}

.finance-filter-control:hover {
  border-color: var(--ink-300);
}

.finance-filter-control:focus {
  outline: none;
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}

.finance-search-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  background: #fff;
  border: 1.5px solid var(--ink-200);
  border-radius: 10px;
  min-height: 44px;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.finance-search-wrap:focus-within {
  border-color: var(--brand-500);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}

.finance-search-wrap i {
  color: var(--ink-400);
  font-size: 0.9rem;
}

.finance-search-wrap .finance-filter-control {
  border: none;
  padding: 10px 0;
  min-height: auto;
  box-shadow: none;
}

.finance-search-wrap .finance-filter-control:focus {
  box-shadow: none;
}

.finance-filters-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 16px 24px 20px;
  border-top: 1px solid var(--ink-100);
  background: var(--ink-50);
}

.finance-filters-footer--split {
  justify-content: space-between;
  flex-wrap: wrap;
}

.finance-filters-footer-start,
.finance-filters-footer-end {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.finance-filter-group--sites .site-filter-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  grid-column: unset;
}

.finance-filter-group--sites .site-filter-button {
  padding: 9px 16px;
  font-size: 0.82rem;
  border-radius: 999px;
}

.finance-btn-ghost,
.finance-btn-ghost:not(.secondary):not(.tertiary) {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 18px !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  color: var(--ink-600) !important;
  background: #fff !important;
  border: 1.5px solid var(--ink-200) !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  min-height: unset !important;
  height: auto !important;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s !important;
}

.finance-btn-ghost:hover {
  background: var(--ink-100) !important;
  border-color: var(--ink-300) !important;
  color: var(--ink-800) !important;
  transform: none !important;
}

.finance-btn-apply,
.finance-btn-apply:not(.secondary):not(.tertiary) {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 22px !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  background: linear-gradient(135deg, var(--brand-800), var(--brand-600)) !important;
  border: none !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 14px rgba(185, 28, 28, 0.28) !important;
  min-height: unset !important;
  height: auto !important;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s !important;
}

.finance-btn-apply:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 18px rgba(185, 28, 28, 0.35) !important;
  opacity: 1 !important;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 1100px) {
  .finance-filter-group-grid,
  .finance-filter-group-grid--period {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .finance-filter-group-grid--period:has(.finance-filter-site.hidden) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .finance-filters-hero {
    padding: 16px 18px;
  }
  .finance-filters-body {
    padding: 16px 18px 8px;
  }
  .finance-filters-footer,
  .finance-filters-footer--split {
    flex-direction: column;
    align-items: stretch;
    padding: 14px 18px 18px;
  }
  .finance-filters-footer-start,
  .finance-filters-footer-end {
    flex-direction: column;
    width: 100%;
  }
  .finance-filters-footer-end {
    flex-direction: column-reverse;
  }
  .finance-btn-ghost,
  .finance-btn-apply {
    width: 100%;
    justify-content: center !important;
  }
  .finance-filter-group-grid,
  .finance-filter-group-grid--period {
    grid-template-columns: 1fr;
  }
}

.finance-kpi-clickable {
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
}

.finance-kpi-clickable:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.1);
}

.finance-kpi-clickable.finance-kpi-active {
  outline: 2px solid var(--brand-600);
  outline-offset: 2px;
}

.finance-history-badge {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--ink-100);
  color: var(--ink-600);
}

.finance-pending-mode.paye { background: #dcfce7; color: #15803d; }
.finance-pending-mode.impaye { background: #f3e8ff; color: #7e22ce; }
.finance-pending-mode.rejected { background: #ffe4e6; color: #be123c; }

.finance-section-sub {
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--ink-400);
  margin-left: 6px;
}

.finance-item-bloque {
  border-left: 3px solid #f59e0b;
}

.finance-bloque-note {
  margin-top: 4px;
  font-size: 0.78rem;
  color: #b45309;
  font-style: italic;
}

.finance-reste-label {
  font-size: 0.75rem;
  color: #b45309;
  margin-top: 2px;
  font-weight: 500;
}

/* Pending list */
.finance-pending-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.finance-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 40px 20px;
  color: var(--ink-300);
  font-size: 0.88rem;
}

.finance-empty-state i {
  font-size: 2.2rem;
  color: #bbf7d0;
}

.finance-pending-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--surface-2);
  border-radius: var(--radius-lg);
  border: 1.5px solid var(--line-light);
  transition: border-color 0.2s;
}

.finance-pending-item:hover {
  border-color: #fed7aa;
}

.finance-pending-mode {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  background: #fff7ed;
  color: #c2410c;
}

.finance-pending-mode.cheque { background: #eff6ff; color: #1d4ed8; }
.finance-pending-mode.bloque { background: #fef3c7; color: #b45309; }

.finance-pending-info {
  flex: 1;
  min-width: 0;
}

.finance-pending-client {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--ink-800);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.finance-pending-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 3px;
}

.finance-pending-meta span {
  font-size: 0.72rem;
  color: var(--ink-500);
}

.finance-pending-meta span i {
  margin-right: 3px;
  opacity: 0.6;
}

.finance-pending-amount {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--ink-800);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

.finance-pending-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.finance-btn-paye,
.finance-btn-impaye,
.finance-btn-bloquer,
.finance-btn-reject,
.finance-btn-docs {
  border: none !important;
  border-radius: 8px !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  padding: 7px 13px !important;
  cursor: pointer !important;
  min-height: unset !important;
  height: auto !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: opacity 0.15s !important;
}

.finance-btn-paye {
  background: #dcfce7 !important;
  color: #15803d !important;
}
.finance-btn-paye:hover { opacity: 0.8 !important; }

.finance-btn-impaye {
  background: #f3e8ff !important;
  color: #7e22ce !important;
}
.finance-btn-impaye:hover { opacity: 0.8 !important; }

.finance-btn-bloquer {
  background: #fef3c7 !important;
  color: #b45309 !important;
}
.finance-btn-bloquer:hover { opacity: 0.8 !important; }

.finance-btn-reject {
  background: #ffe4e6 !important;
  color: #be123c !important;
}
.finance-btn-reject:hover { opacity: 0.8 !important; }

.finance-btn-docs {
  background: #dbeafe !important;
  color: #1d4ed8 !important;
}
.finance-btn-docs:hover { opacity: 0.8 !important; }

/* Finance status badge in sales table */
.finance-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.finance-status-badge.pending  { background: #fff7ed; color: #c2410c; border: 1px solid #fed7aa; }
.finance-status-badge.validated { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.finance-status-badge.rejected  { background: #fff1f2; color: #be123c; border: 1px solid #fecdd3; }
.finance-status-badge.na        { display: none; }

/* ── Tab view switching ── */
.view-hidden { display: none !important; }

@keyframes tabViewFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tab-view-enter {
  animation: tabViewFadeIn 0.28s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* ── Contrôle Interne — Journal d'audit ── */
.ci-audit-log {
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid var(--ink-100);
  margin-top: 8px;
}

.ci-audit-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.ci-audit-table thead tr {
  background: var(--ink-50, #f8fafc);
}

.ci-audit-table th {
  padding: 10px 14px;
  text-align: left;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--ink-500);
  text-transform: uppercase;
  border-bottom: 1px solid var(--ink-100);
  white-space: nowrap;
}

.ci-audit-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--ink-50, #f8fafc);
  color: var(--ink-700);
  vertical-align: middle;
}

.ci-audit-table tbody tr:last-child td { border-bottom: none; }
.ci-audit-table tbody tr:hover { background: #fafafa; }

.ci-audit-ts {
  font-variant-numeric: tabular-nums;
  color: var(--ink-400);
  font-size: 0.75rem;
  white-space: nowrap;
}

.ci-audit-notes {
  color: var(--ink-500);
  font-size: 0.75rem;
  max-width: 220px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ci-action-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 0.68rem;
  font-weight: 600;
  white-space: nowrap;
  background: var(--ink-100);
  color: var(--ink-600);
}

.ci-action-badge.audit-action-create   { background: #f0fdf4; color: #15803d; }
.ci-action-badge.audit-action-validate { background: #eff6ff; color: #1d4ed8; }
.ci-action-badge.audit-action-modify   { background: #fefce8; color: #a16207; }
.ci-action-badge.audit-action-finance  { background: #f0fdf4; color: #0f766e; }
.ci-action-badge.audit-action-reject   { background: #fff1f2; color: #be123c; }
.ci-action-badge.audit-action-login    { background: #eff6ff; color: #2563eb; }
.ci-action-badge.audit-action-logout   { background: var(--ink-100); color: var(--ink-500); }
.ci-action-badge.audit-action-ok       { background: #f0fdf4; color: #15803d; }

/* Traçabilité (carte ventes) */
#traceability-card .audit-table-wrap {
  margin-top: 12px;
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid var(--ink-100);
}

#traceability-card .audit-trace-table {
  width: 100%;
  min-width: 720px;
  table-layout: fixed;
}

#traceability-card .audit-trace-table thead tr {
  background: linear-gradient(135deg, #991b1b, #b91c1c);
}

#traceability-card .audit-trace-table th {
  color: #fff;
  border-bottom: none;
  font-size: 0.68rem;
  padding: 12px 10px;
}

#traceability-card .audit-trace-table th i {
  margin-right: 4px;
  opacity: 0.85;
}

#traceability-card .audit-trace-table td {
  white-space: normal;
  word-break: break-word;
  vertical-align: middle;
  padding: 10px;
}

#traceability-card .audit-col-action { width: 12%; }
#traceability-card .audit-col-user { width: 16%; }
#traceability-card .audit-col-sale { width: 9%; white-space: nowrap; }
#traceability-card .audit-col-ts { width: 14%; white-space: nowrap; font-variant-numeric: tabular-nums; }
#traceability-card .audit-col-notes { width: 49%; }

#traceability-card td.audit-col-notes {
  line-height: 1.35;
  font-size: 0.78rem;
  color: var(--ink-500);
  overflow-wrap: anywhere;
}

#traceability-card tbody tr {
  animation: none;
  transform: none;
}

#traceability-card tbody tr:nth-child(even) {
  background: #fffafb;
}

#traceability-card .audit-empty-cell {
  text-align: center;
  color: var(--ink-400);
  padding: 24px;
}

#traceability-card .clickable-row::before {
  display: none;
}

#traceability-card .clickable-row:hover {
  transform: none;
}

/* Liste des ventes — scroll unique (évite décalage en-tête / corps) */
#sales-table-card {
  overflow-x: visible;
}

#sales-table-card .sales-table-wrap {
  margin-top: 12px;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  border: 1px solid var(--ink-100);
}

#sales-table-card .sales-list-table {
  width: 100%;
  min-width: 1280px;
  table-layout: fixed;
  border-collapse: collapse;
  border-spacing: 0;
  margin: 0;
  box-shadow: none;
}

#sales-table-card .sales-list-table thead tr {
  background: linear-gradient(135deg, #991b1b, #b91c1c);
}

#sales-table-card .sales-list-table th {
  position: static;
  top: auto;
  z-index: auto;
  color: #fff;
  border-bottom: none;
  font-size: 0.68rem;
  padding: 12px 10px;
  white-space: nowrap;
}

#sales-table-card .sales-list-table th i {
  margin-right: 4px;
  opacity: 0.85;
}

#sales-table-card .sales-list-table td {
  padding: 10px;
  font-size: 0.8rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}

#sales-table-card .sales-col-id { width: 52px; }
#sales-table-card .sales-col-date { width: 118px; }
#sales-table-card .sales-col-client { width: 140px; }
#sales-table-card .sales-col-type { width: 72px; }
#sales-table-card .sales-col-amount { width: 100px; }
#sales-table-card .sales-col-mode { width: 110px; }
#sales-table-card .sales-col-cheque { width: 100px; }
#sales-table-card .sales-col-cheque-num { width: 90px; }
#sales-table-card .sales-col-cheque-name { width: 110px; }
#sales-table-card .sales-col-mc { width: 120px; }
#sales-table-card .sales-col-site { width: 110px; }
#sales-table-card .sales-col-receptionist { width: 150px; }
#sales-table-card .sales-col-status { width: 108px; }
#sales-table-card .sales-col-actions { width: 120px; }

#sales-table-card .sales-col-client,
#sales-table-card .sales-col-cheque-name,
#sales-table-card .sales-col-mc,
#sales-table-card .sales-col-receptionist {
  white-space: normal;
  word-break: break-word;
  line-height: 1.3;
}

#sales-table-card .sales-col-status {
  text-align: center;
}

#sales-table-card .sales-col-actions {
  text-align: center;
  overflow: visible;
}

#sales-table-card .sales-col-mode {
  white-space: normal;
  line-height: 1.35;
}

#sales-table-card .sales-receptionist-pending {
  color: var(--brand-700);
  font-weight: 600;
}

#sales-table-card tbody tr {
  animation: none;
  transform: none;
}

#sales-table-card tbody tr:nth-child(even) {
  background: #fffafb;
}

#sales-table-card .clickable-row::before {
  display: none;
}

#sales-table-card .clickable-row:hover {
  transform: none;
  box-shadow: none;
}

#sales-table-card .sales-actions-cell {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  align-items: center;
}

#sales-table-card .sales-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 5px 12px;
  margin: 0;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
  cursor: pointer;
  border: 1px solid transparent;
  box-shadow: none;
  transform: none;
  font-family: inherit;
}

#sales-table-card .sales-action-btn-confirm {
  background: var(--ink-800);
  color: #fff;
  border-color: var(--ink-800);
}

#sales-table-card .sales-action-btn-confirm:hover {
  background: var(--ink-900);
}

#sales-table-card .sales-action-btn-edit {
  background: #fff;
  color: var(--brand-700);
  border-color: var(--brand-200);
}

#sales-table-card .sales-action-btn-edit:hover {
  background: var(--brand-50);
}

#sales-table-card .status-label {
  min-width: 0;
  width: 100%;
  max-width: 100%;
  padding: 5px 8px;
  font-size: 0.68rem;
}

#sales-table-card .sales-empty-cell {
  text-align: center;
  color: var(--ink-400);
  padding: 28px 16px;
  white-space: normal;
}

#sales-table-card tr.sale-row-expanded td {
  background: var(--brand-50);
  border-bottom-color: transparent;
}

#sales-table-card tr.sale-detail-row td.sale-inline-detail-cell {
  padding: 0;
  background: linear-gradient(180deg, #fffbfb 0%, #ffffff 48%);
  border-bottom: 2px solid var(--brand-200);
  overflow: visible;
  white-space: normal;
}

#sales-table-card .sale-inline-detail {
  padding: 0;
  border-top: none;
  box-shadow: inset 4px 0 0 var(--brand-600);
}

#sales-table-card .sale-inline-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  background: linear-gradient(135deg, #7f1d1d 0%, #b91c1c 55%, #dc2626 100%);
  color: #fff;
}

#sales-table-card .sale-inline-detail-head-main {
  min-width: 0;
  flex: 1;
}

#sales-table-card .sale-inline-detail-kicker {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.72);
  margin-bottom: 6px;
}

#sales-table-card .sale-inline-detail-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

#sales-table-card .sale-inline-detail-id {
  font-size: 1.15rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.02em;
}

#sales-table-card .sale-inline-detail-title-row .type-operation-badge {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

#sales-table-card .sale-inline-detail-title-row .status-label {
  min-width: auto;
  padding: 4px 10px;
  font-size: 0.62rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

#sales-table-card .sale-inline-detail-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.88);
  margin: 0;
}

#sales-table-card .sale-inline-meta-sep {
  opacity: 0.5;
}

#sales-table-card .sale-inline-detail-head-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  flex-shrink: 0;
}

#sales-table-card .sale-inline-detail-amount {
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
  white-space: nowrap;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

#sales-table-card .sale-inline-close {
  width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  font-size: 0.9rem;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.15s ease, border-color 0.15s ease;
}

#sales-table-card .sale-inline-close:hover {
  background: rgba(255, 255, 255, 0.22);
  border-color: rgba(255, 255, 255, 0.55);
}

#sales-table-card .sale-inline-detail-export-btns,
.sale-detail-modal-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.sale-export-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 30px;
  padding: 5px 11px;
  margin: 0;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: none;
  transform: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.sale-export-btn:hover {
  background: rgba(255, 255, 255, 0.26);
  border-color: rgba(255, 255, 255, 0.65);
}

.sale-export-btn--excel {
  background: rgba(255, 255, 255, 0.95);
  color: #166534;
  border-color: #bbf7d0;
}

.sale-export-btn--excel:hover {
  background: #fff;
  color: #14532d;
}

.sale-detail-modal .sale-export-btn {
  border-color: rgba(255, 255, 255, 0.35);
}

.sale-detail-modal-actions {
  flex-shrink: 0;
}

.sale-detail-modal-actions .modal-close {
  margin-left: 2px;
}

#sales-table-card .sale-inline-detail-body {
  padding: 16px 20px 20px;
}

/* Panneau détail vente (inline + modal) */
.sale-detail-pro {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.sale-detail-section {
  background: #fff;
  border: 1px solid var(--ink-100);
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}

.sale-detail-section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-500);
}

.sale-detail-section-title i {
  color: var(--brand-600);
  font-size: 0.85rem;
}

.sale-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  gap: 10px;
}

.sale-detail-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  background: var(--ink-50);
  border-radius: 10px;
  border: 1px solid transparent;
  min-height: 0;
}

.sale-detail-field--wide {
  grid-column: 1 / -1;
}

.sale-detail-field--highlight .sale-detail-value {
  color: var(--brand-800);
  font-weight: 800;
  font-size: 0.95rem;
}

.sale-detail-field--status {
  justify-content: center;
}

.sale-detail-field--status .status-label {
  align-self: flex-start;
  min-width: 0;
}

.sale-detail-label {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-400);
}

.sale-detail-value {
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--ink-800);
  line-height: 1.35;
  word-break: break-word;
}

.sale-detail-field--empty .sale-detail-value {
  color: var(--ink-300);
  font-weight: 500;
}

.sale-detail-muted {
  margin: 0;
  font-size: 0.82rem;
  color: var(--ink-400);
  font-style: italic;
  padding: 8px 4px;
}

.sale-detail-muted--error {
  color: var(--error, #dc2626);
  font-style: normal;
}

.sale-detail-description {
  margin: 0;
  padding: 12px 14px;
  background: var(--ink-50);
  border-radius: 10px;
  font-size: 0.86rem;
  line-height: 1.55;
  color: var(--ink-700);
  border-left: 3px solid var(--brand-300);
}

.sale-finance-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  font-size: 0.72rem;
  font-weight: 700;
}

.sale-finance-pill--pending {
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
}

.sale-finance-pill--ok {
  background: #f0fdf4;
  color: #15803d;
  border: 1px solid #bbf7d0;
}

.sale-finance-pill--reject {
  background: #fff1f2;
  color: #be123c;
  border: 1px solid #fecdd3;
}

.sale-cheque-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sale-cheque-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: var(--ink-50);
  border-radius: 10px;
  border: 1px solid var(--ink-100);
}

.sale-cheque-badge {
  flex-shrink: 0;
  font-size: 0.62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--brand-700);
  background: var(--brand-50);
  border: 1px solid var(--brand-200);
  padding: 4px 8px;
  border-radius: 6px;
}

.sale-cheque-data {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 1;
}

.sale-cheque-amt {
  font-weight: 800;
  color: var(--ink-900);
  font-size: 0.88rem;
}

.sale-cheque-sep {
  width: 1px;
  height: 14px;
  background: var(--ink-200);
}

.sale-cheque-num {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ink-600);
}

.sale-cheque-date {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-500);
  white-space: nowrap;
}

.sale-cheque-name {
  margin: 10px 0 0;
  font-size: 0.8rem;
  color: var(--ink-600);
}

.sale-cheque-name span {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.65rem;
  letter-spacing: 0.05em;
  color: var(--ink-400);
  margin-right: 6px;
}

.sale-detail-section--attachments .sale-detail-attachment-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-height: 48px;
  align-items: flex-start;
}

.sale-detail-loading-state {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.82rem;
  color: var(--ink-400);
  padding: 8px 4px;
}

.sale-detail-spinner {
  width: 18px;
  height: 18px;
  border: 2px solid var(--ink-200);
  border-top-color: var(--brand-600);
  border-radius: 50%;
  animation: sale-detail-spin 0.7s linear infinite;
  flex-shrink: 0;
}

@keyframes sale-detail-spin {
  to { transform: rotate(360deg); }
}

.sale-detail-modal .sale-detail-content:has(.sale-detail-pro) {
  display: block;
  max-height: min(70vh, 640px);
  padding: 20px 24px 24px;
}

.sale-detail-modal .sale-detail-content:has(.sale-detail-pro) > .sale-detail-pro {
  gap: 12px;
}

@media (max-width: 640px) {
  #sales-table-card .sale-inline-detail-head {
    flex-direction: column;
    align-items: stretch;
  }
  #sales-table-card .sale-inline-detail-head-side {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }
  .sale-detail-grid {
    grid-template-columns: 1fr;
  }
}

.clickable-row.sale-row-expanded {
  cursor: default;
}

/* ── Notification Bell ── */
.notif-wrap {
  position: relative;
  flex-shrink: 0;
}
.notif-bell {
  width: 40px !important;
  height: 40px !important;
  min-height: unset !important;
  padding: 0 !important;
  border-radius: 10px !important;
  background: var(--ink-100) !important;
  color: var(--ink-600) !important;
  border: none !important;
  cursor: pointer;
  position: relative;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1rem !important;
  gap: 0 !important;
  transition: background 0.15s, color 0.15s !important;
  box-shadow: none !important;
}
.notif-bell:hover { background: var(--ink-200) !important; color: var(--ink-800) !important; }
.notif-badge {
  position: absolute;
  top: 4px; right: 4px;
  min-width: 17px; height: 17px;
  border-radius: 999px;
  background: var(--brand-600);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  padding: 0 4px;
  pointer-events: none;
  border: 2px solid #fff;
  line-height: 1;
}
.notif-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 340px;
  background: #fff;
  border: 1.5px solid var(--ink-100);
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12);
  z-index: 1000;
  overflow: hidden;
}
.notif-dropdown-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--ink-100);
  background: var(--ink-50);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--ink-700);
}
.notif-read-all-btn {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  color: var(--brand-600) !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  min-height: unset !important;
  height: auto !important;
  cursor: pointer;
  box-shadow: none !important;
}
.notif-read-all-btn:hover { text-decoration: underline !important; }
.notif-list { max-height: 360px; overflow-y: auto; }
.notif-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 32px 20px; gap: 8px; color: var(--ink-400); font-size: 0.82rem;
}
.notif-empty i { font-size: 1.5rem; opacity: 0.4; }
.notif-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--ink-50);
  cursor: pointer;
  transition: background 0.12s;
}
.notif-item:hover { background: var(--ink-50); }
.notif-unread { background: #fef9ff; }
.notif-unread::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 60%; background: var(--brand-500); border-radius: 0 3px 3px 0;
}
.notif-item { position: relative; }
.notif-item-icon {
  width: 32px; height: 32px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem; flex-shrink: 0;
  background: var(--ink-100); color: var(--ink-500);
}
.notif-type-pending { background: #fff7ed; color: #c2410c; }
.notif-type-ok      { background: #f0fdf4; color: #15803d; }
.notif-type-reject  { background: #fff1f2; color: #be123c; }
.notif-type-alert   { background: #fff1f2; color: #dc2626; }
.notif-type-admin   { background: #eff6ff; color: #2563eb; }
.notif-item-body { flex: 1; min-width: 0; }
.notif-item-body strong { font-size: 0.82rem; font-weight: 700; color: var(--ink-800); display: block; }
.notif-item-body p { font-size: 0.75rem; color: var(--ink-500); margin: 2px 0 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.notif-item-body time { font-size: 0.68rem; color: var(--ink-400); }

/* ── Alerts (CI Panel) ── */
.ci-alerts-section { margin-bottom: 8px; }
.ci-alerts-list { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.ci-alert-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1.5px solid transparent;
}
.ci-alert-card.alert-sev-critical {
  background: #fff1f2; border-color: #fecdd3;
}
.ci-alert-card.alert-sev-warning {
  background: #fff7ed; border-color: #fed7aa;
}
.ci-alert-icon {
  width: 34px; height: 34px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; flex-shrink: 0;
}
.alert-sev-critical .ci-alert-icon { background: #fee2e2; color: #dc2626; }
.alert-sev-warning  .ci-alert-icon { background: #ffedd5; color: #ea580c; }
.ci-alert-body { flex: 1; min-width: 0; }
.ci-alert-body strong { font-size: 0.82rem; font-weight: 700; color: var(--ink-800); display: block; }
.ci-alert-body span { font-size: 0.72rem; color: var(--ink-500); }
.ci-alert-ack {
  width: 30px !important; height: 30px !important;
  min-height: unset !important; padding: 0 !important;
  border-radius: 8px !important; border: none !important;
  background: rgba(0,0,0,0.06) !important;
  color: var(--ink-500) !important;
  cursor: pointer; font-size: 0.75rem !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  flex-shrink: 0; gap: 0 !important;
  transition: background 0.15s !important;
}
.ci-alert-ack:hover { background: #bbf7d0 !important; color: #15803d !important; }

/* ── Audit full viewer ── */
.audit-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 4px;
}
.audit-filter-input {
  flex: 1;
  min-width: 130px;
  max-width: 200px;
  padding: 8px 12px;
  border: 1.5px solid var(--ink-200);
  border-radius: 9px;
  font-size: 0.82rem;
  font-family: inherit;
  background: var(--ink-50);
  color: var(--ink-800);
}
.audit-filter-input:focus { outline: none; border-color: var(--brand-400); background: #fff; }
.audit-btn-search, .audit-btn-export {
  padding: 8px 16px !important;
  min-height: unset !important;
  height: auto !important;
  border-radius: 9px !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  border: none !important;
  cursor: pointer;
  flex-shrink: 0;
  gap: 6px !important;
}
.audit-btn-search { background: var(--brand-600) !important; color: #fff !important; }
.audit-btn-search:hover { background: var(--brand-700) !important; }
.audit-btn-export { background: var(--ink-100) !important; color: var(--ink-700) !important; }
.audit-btn-export:hover { background: var(--ink-200) !important; }
.audit-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 14px 0 4px;
  font-size: 0.8rem;
  color: var(--ink-500);
}
.audit-page-btn {
  width: 32px !important; height: 32px !important;
  min-height: unset !important; padding: 0 !important;
  border-radius: 8px !important; border: 1.5px solid var(--ink-200) !important;
  background: #fff !important; color: var(--ink-600) !important;
  cursor: pointer; display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 0.8rem !important; gap: 0 !important;
}
.audit-page-btn:hover:not(:disabled) { background: var(--ink-50) !important; border-color: var(--brand-400) !important; }
.audit-page-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Attachment warning on form */
.attachment-required-warning {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #fff7ed;
  border: 1.5px solid #fed7aa;
  border-radius: var(--radius-md);
  font-size: 0.8rem;
  color: #c2410c;
  font-weight: 600;
  margin-top: 8px;
}

.attachment-required-warning.visible {
  display: flex;
}

/* ── Module shared base ──────────────────────────────────────────────────────*/
.module-loading, .module-error, .module-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; padding: 40px 20px; color: var(--ink-300); font-size: 0.9rem; text-align: center;
}
.module-error { color: #dc2626; }
.module-empty i { font-size: 2rem; opacity: 0.35; }
.module-panel {
  background: var(--surface); border-radius: var(--radius-lg);
  border: 1px solid var(--border); overflow: hidden;
}
.module-panel-header {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, var(--brand-50) 0%, var(--surface) 100%);
}
.module-panel-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--brand-100); display: flex; align-items: center; justify-content: center;
  color: var(--brand-600); font-size: 1rem;
}
.module-panel-title { font-size: 1.05rem; font-weight: 700; color: var(--ink-900); }
.module-panel-sub  { font-size: 0.8rem; color: var(--ink-400); margin-top: 1px; }
.module-toolbar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 14px 22px; border-bottom: 1px solid var(--border); background: var(--ink-50);
}
.module-search {
  flex: 1; min-width: 180px; padding: 8px 14px 8px 36px; border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); font-size: 0.85rem; background: var(--surface);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: 10px center;
  transition: border-color .2s;
}
.module-search:focus { outline: none; border-color: var(--brand-400); }
.module-search-wrap { position: relative; flex: 1; min-width: 180px; }
.module-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--ink-400); font-size: 0.8rem; pointer-events: none; }
.module-search-wrap .module-search { padding-left: 30px; width: 100%; }
.module-action-btn {
  padding: 8px 16px !important; min-height: 36px !important; height: 36px !important;
  font-size: 0.82rem !important; font-weight: 600 !important; white-space: nowrap !important;
  background: var(--brand-600) !important; color: #fff !important;
  border: none !important; border-radius: var(--radius-sm) !important; cursor: pointer !important;
}
.module-action-btn:hover { background: var(--brand-700) !important; }
.module-form { padding: 14px 20px; border-bottom: 1px solid var(--border); background: var(--ink-50); }
.module-save-btn {
  padding: 7px 18px !important; min-height: 34px !important; height: 34px !important;
  font-size: 0.82rem !important; font-weight: 600 !important;
  background: var(--brand-600) !important; color: #fff !important;
  border: none !important; border-radius: var(--radius-sm) !important; cursor: pointer !important;
}
.module-save-btn:hover { background: var(--brand-700) !important; }
.module-cancel-btn {
  padding: 7px 14px !important; min-height: 34px !important; height: 34px !important;
  font-size: 0.82rem !important; font-weight: 600 !important;
  background: transparent !important; color: var(--ink-600) !important;
  border: 1.5px solid var(--border) !important; border-radius: var(--radius-sm) !important; cursor: pointer !important;
}
.module-cancel-btn:hover { background: var(--ink-100) !important; }
.module-form-section {
  padding: 18px 22px; border-bottom: 1px solid var(--border);
}
.module-form-section summary {
  font-size: 0.82rem; font-weight: 600; color: var(--ink-500);
  cursor: pointer; list-style: none; user-select: none;
  display: flex; align-items: center; gap: 6px;
}
.module-form-section summary::before { content: '+'; font-size: 1rem; color: var(--brand-500); }
details[open] .module-form-section summary::before { content: '−'; }
.module-form-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px; margin-top: 12px;
}
.module-form-grid input, .module-form-grid select, .module-form-grid textarea {
  padding: 8px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  font-size: 0.85rem; background: var(--surface); font-family: inherit;
  transition: border-color .2s;
}
.module-form-grid input:focus, .module-form-grid select:focus, .module-form-grid textarea:focus {
  outline: none; border-color: var(--brand-400);
}
.module-form-actions {
  display: flex; gap: 8px; margin-top: 12px; justify-content: flex-end;
}
.module-btn-primary {
  padding: 8px 20px !important; min-height: 36px !important; height: 36px !important;
  font-size: 0.83rem !important; font-weight: 600 !important;
  background: var(--brand-600) !important; color: #fff !important;
  border: none !important; border-radius: var(--radius-sm) !important; cursor: pointer !important;
}
.module-btn-primary:hover { background: var(--brand-700) !important; }

/* ── Dashboard stats tiles ───────────────────────────────────────────────────*/
.dash-stats-row {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px; margin-bottom: 18px;
}
.dash-stat-tile {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md);
  padding: 14px 16px; display: flex; flex-direction: column; gap: 4px;
}
.dash-stat-label { font-size: 0.72rem; color: var(--ink-400); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.dash-stat-value { font-size: 1.4rem; font-weight: 800; color: var(--ink-900); }
.dash-stat-tile.accent .dash-stat-value { color: var(--brand-600); }
.dash-stat-tile.warning .dash-stat-value { color: #d97706; }

/* ── Clients panel ───────────────────────────────────────────────────────────*/
.clients-list {
  display: flex; flex-direction: column; gap: 2px;
  max-height: 520px; overflow-y: auto; padding: 8px 16px;
}
.client-card {
  display: flex; align-items: center; gap: 14px; padding: 12px 10px;
  border-radius: var(--radius-md); cursor: pointer; transition: background .15s;
  border: 1px solid transparent;
}
.client-card:hover { background: var(--ink-50); border-color: var(--border); }
.client-card-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--brand-100); color: var(--brand-600);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 700; flex-shrink: 0;
}
.client-card-info { flex: 1; min-width: 0; }
.client-card-name { font-weight: 600; font-size: 0.88rem; color: var(--ink-900); }
.client-card-meta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 2px; }
.client-card-meta span { font-size: 0.75rem; color: var(--ink-400); }
.client-card-meta i { margin-right: 3px; }
.client-card-site { font-size: 0.72rem; color: var(--brand-600); font-weight: 600;
  background: var(--brand-50); padding: 3px 8px; border-radius: 20px; white-space: nowrap; }

/* Client detail modal — uses .module-modal* classes */
.module-modal {
  position: fixed; inset: 0; z-index: 2000;
  display: flex; align-items: center; justify-content: center; padding: 20px;
}
.module-modal.hidden { display: none; }
.module-modal-backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,.45);
}
.module-modal-box {
  position: relative; background: var(--surface); border-radius: var(--radius-lg);
  width: 100%; max-width: 640px; max-height: 85vh;
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.module-modal-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.module-modal-avatar {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  background: var(--brand-100); color: var(--brand-700);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 800;
}
.module-modal-header h3 { font-size: 1rem; font-weight: 700; color: var(--ink-900); margin: 0; }
.module-badge { font-size: 0.7rem; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.module-badge.blue { background: var(--brand-50); color: var(--brand-700); }
.module-modal-close {
  width: 32px !important; height: 32px !important; min-height: 32px !important;
  padding: 0 !important; border-radius: 50% !important; border: none !important;
  background: var(--ink-100) !important; color: var(--ink-600) !important;
  font-size: 0.85rem !important; cursor: pointer !important; display: flex !important;
  align-items: center !important; justify-content: center !important; margin-left: auto !important;
}
.module-modal-meta {
  display: flex; gap: 14px; flex-wrap: wrap; padding: 10px 20px;
  border-bottom: 1px solid var(--border); font-size: 0.8rem; color: var(--ink-500);
  background: var(--ink-50); flex-shrink: 0;
}
.module-modal-meta i { margin-right: 4px; }
.module-modal-tabs { display: flex; gap: 2px; padding: 10px 20px 0; flex-shrink: 0; }
.mdl-tab {
  padding: 6px 16px !important; min-height: 32px !important; height: 32px !important;
  font-size: 0.8rem !important; border-radius: var(--radius-sm) !important;
  border: 1.5px solid var(--border) !important; background: transparent !important;
  color: var(--ink-600) !important; cursor: pointer !important; font-weight: 600 !important;
}
.mdl-tab.active { background: var(--brand-600) !important; color: #fff !important; border-color: var(--brand-600) !important; }
.module-modal-section { flex: 1; overflow-y: auto; padding: 10px 20px; display: flex; flex-direction: column; gap: 4px; }
.module-modal-section.hidden { display: none; }
.detail-row {
  display: flex; gap: 12px; align-items: center; padding: 8px 10px;
  border-radius: var(--radius-sm); font-size: 0.82rem; color: var(--ink-700);
  background: var(--ink-50); flex-wrap: wrap;
}
.detail-row span { flex: 1; min-width: 80px; }

/* ── Subscriptions panel ─────────────────────────────────────────────────────*/
.sub-stats-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px; padding: 14px 20px; border-bottom: 1px solid var(--border);
}
.sub-stat-card {
  background: var(--ink-50); border-radius: var(--radius-md);
  padding: 12px 14px; display: flex; align-items: center; gap: 10px;
}
.sub-stat-card i { font-size: 1.2rem; opacity: 0.6; }
.sub-stat-card > div { display: flex; flex-direction: column; }
.sub-stat-card strong { font-size: 1.4rem; font-weight: 800; color: var(--ink-900); line-height: 1; }
.sub-stat-card span { font-size: 0.7rem; color: var(--ink-400); font-weight: 600; }
.sub-stat-active i, .sub-stat-active strong { color: var(--brand-600) !important; }
.sub-stat-expiring i, .sub-stat-expiring strong { color: #d97706 !important; }
.sub-stat-expired i, .sub-stat-expired strong { color: #dc2626 !important; }
.sub-stat-revenue i, .sub-stat-revenue strong { color: #7c3aed !important; }

.sub-filter-row {
  display: flex; gap: 6px; padding: 10px 20px; border-bottom: 1px solid var(--border);
  background: var(--ink-50); flex-wrap: wrap;
}
.sub-filter-btn {
  padding: 5px 14px !important; min-height: 30px !important; height: 30px !important;
  font-size: 0.78rem !important; font-weight: 600 !important; border-radius: 20px !important;
  border: 1.5px solid var(--border) !important; background: var(--surface) !important;
  color: var(--ink-600) !important; cursor: pointer !important;
}
.sub-filter-btn.active { background: var(--brand-600) !important; color: #fff !important; border-color: var(--brand-600) !important; }

.subscriptions-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 480px; overflow-y: auto; padding: 10px 16px;
}
.sub-card {
  display: flex; align-items: center; gap: 14px; padding: 12px 12px;
  border-radius: var(--radius-md); border: 1px solid var(--border);
  background: var(--surface); transition: box-shadow .15s;
}
.sub-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.07); }
.sub-card.expiring { border-color: #fbbf24; background: #fffbeb; }
.sub-card.expired  { border-color: #fca5a5; background: #fef2f2; }
.sub-card-icon {
  width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
  background: var(--brand-50); color: var(--brand-600);
  display: flex; align-items: center; justify-content: center; font-size: 1rem;
}
.sub-card-info { flex: 1; min-width: 0; }
.sub-card-name { font-weight: 600; font-size: 0.87rem; color: var(--ink-900); }
.sub-card-type { font-size: 0.75rem; color: var(--ink-400); margin-top: 1px; }
.sub-card-dates { display: flex; align-items: center; gap: 6px; font-size: 0.75rem; color: var(--ink-500); margin-top: 3px; flex-wrap: wrap; }
.sub-days-left { font-weight: 700; color: #d97706; padding: 1px 7px; background: #fef3c7; border-radius: 12px; }
.sub-card-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.sub-amount { font-size: 1rem; font-weight: 700; color: var(--ink-900); }
.sub-status-badge {
  font-size: 0.68rem; font-weight: 700; padding: 2px 8px; border-radius: 12px; text-transform: uppercase;
}
.sub-status-active  { background: #d1fae5; color: #065f46; }
.sub-status-expired { background: #fee2e2; color: #991b1b; }
.sub-status-cancelled { background: #f3f4f6; color: #6b7280; }
.sub-action-btn {
  padding: 3px 10px !important; min-height: 24px !important; height: 24px !important;
  font-size: 0.72rem !important; border-radius: var(--radius-sm) !important;
  border: 1px solid #fca5a5 !important; background: #fff !important;
  color: #dc2626 !important; cursor: pointer !important;
}

/* ── Commissions panel ───────────────────────────────────────────────────────*/
.commissions-summary { padding: 8px 16px; }
.comm-month-nav {
  width: 32px !important; height: 32px !important; min-height: 32px !important;
  padding: 0 !important; border-radius: var(--radius-sm) !important;
  border: 1.5px solid var(--border) !important; background: var(--surface) !important;
  color: var(--ink-600) !important; font-size: 0.85rem !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
}
.comm-month-nav:hover { background: var(--ink-100) !important; }

.commissions-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 440px; overflow-y: auto; padding: 10px 16px;
}
.comm-total-bar {
  padding: 8px 12px; background: var(--brand-50); border-radius: var(--radius-sm);
  font-size: 0.82rem; color: var(--brand-700); margin-bottom: 6px;
}
.comm-total-bar strong { color: var(--brand-800); }
.comm-row {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  border-radius: var(--radius-md); border: 1px solid var(--border);
  background: var(--surface);
}
.comm-row-avatar {
  width: 36px; height: 36px; border-radius: 50%; background: var(--ink-100);
  color: var(--ink-600); display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; font-weight: 700; flex-shrink: 0;
}
.comm-row-info { flex: 1; min-width: 0; }
.comm-row-name { font-weight: 600; font-size: 0.87rem; color: var(--ink-900); }
.comm-row-meta { font-size: 0.74rem; color: var(--ink-400); margin-top: 1px; }
.comm-row-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.comm-amount { font-size: 1rem; font-weight: 700; color: var(--ink-900); }
.comm-status { font-size: 0.68rem; font-weight: 700; padding: 2px 8px; border-radius: 12px; }
.comm-paid   { background: #d1fae5; color: #065f46; }
.comm-unpaid { background: #fef3c7; color: #92400e; }
.comm-pay-btn {
  padding: 3px 10px !important; min-height: 24px !important; height: 24px !important;
  font-size: 0.72rem !important; border-radius: var(--radius-sm) !important;
  border: 1px solid #6ee7b7 !important; background: #d1fae5 !important;
  color: #065f46 !important; cursor: pointer !important;
}

/* Commission rates config */
.comm-rates-section {
  border-top: 1px solid var(--border); padding: 16px 20px;
}
.comm-rates-title {
  font-size: 0.78rem; font-weight: 700; color: var(--ink-500);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 10px;
}
.comm-rates-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; }
.comm-rate-row {
  display: flex; align-items: center; gap: 10px; padding: 7px 10px;
  background: var(--ink-50); border-radius: var(--radius-sm); font-size: 0.82rem;
}
.comm-rate-staff { flex: 1; font-weight: 600; color: var(--ink-800); }
.comm-rate-site { color: var(--ink-400); font-size: 0.76rem; }
.comm-rate-pct { font-weight: 700; color: var(--brand-600); min-width: 36px; text-align: right; }
.comm-rate-del {
  width: 22px !important; height: 22px !important; min-height: 22px !important;
  padding: 0 !important; border-radius: 50% !important; border: none !important;
  background: #fee2e2 !important; color: #dc2626 !important;
  font-size: 0.85rem !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
}
.comm-rate-form {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 10px;
}
.comm-rate-form input, .comm-rate-form select {
  flex: 1; min-width: 100px; padding: 7px 10px;
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  font-size: 0.82rem; background: var(--surface); font-family: inherit;
}
.comm-rate-form input:focus, .comm-rate-form select:focus {
  outline: none; border-color: var(--brand-400);
}

/* ── Responsive: new panels ──────────────────────────────────────────────────*/
@media (max-width: 640px) {
  .sub-stats-row { grid-template-columns: repeat(2, 1fr); }
  .module-form-grid { grid-template-columns: 1fr; }
  .detail-info-grid { grid-template-columns: 1fr; }
  .comm-rate-form-row { flex-direction: column; }
}
