/*!**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[11].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[11].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/layout.js","import":"Inter","arguments":[{"subsets":["latin"],"display":"swap","variable":"--font-inter"}],"variableName":"inter"} ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/ba9851c3c22cd980-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/21350d82a1f187e9-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/df0a9ae256c0569c-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/8e9860b6e62d6359-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: '__Inter_f367f3';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: '__Inter_Fallback_f367f3';src: local("Arial");ascent-override: 90.20%;descent-override: 22.48%;line-gap-override: 0.00%;size-adjust: 107.40%
}.__className_f367f3 {font-family: '__Inter_f367f3', '__Inter_Fallback_f367f3';font-style: normal
}.__variable_f367f3 {--font-inter: '__Inter_f367f3', '__Inter_Fallback_f367f3'
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[11].oneOf[12].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[11].oneOf[12].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
@tailwind base;
@tailwind components;
@tailwind utilities;

:root {
  /* Colors - Light Mode */
  --color-primary: #7c3aed;
  --color-primary-light: #a78bfa;
  --color-primary-dark: #6d28d9;
  
  --color-success: #10b981;
  --color-warning: #f59e0b;
  --color-error: #ef4444;
  --color-info: #3b82f6;
  
  --color-bg-primary: #ffffff;
  --color-bg-secondary: #f9fafb;
  --color-bg-tertiary: #f3f4f6;
  
  --color-text-primary: #111827;
  --color-text-secondary: #6b7280;
  --color-text-tertiary: #9ca3af;
  
  --color-border: #e5e7eb;
  --color-border-light: #f3f4f6;
  
  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  
  /* Gradients */
  --gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);
  --gradient-warning: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  --gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  
  /* Spacing */
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2rem;
  --spacing-2xl: 3rem;
  
  /* Border Radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;
  
  /* Transitions */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

[data-theme="dark"] {
  --color-bg-primary: #111827;
  --color-bg-secondary: #1f2937;
  --color-bg-tertiary: #374151;
  
  --color-text-primary: #f9fafb;
  --color-text-secondary: #d1d5db;
  --color-text-tertiary: #9ca3af;
  
  --color-border: #374151;
  --color-border-light: #4b5563;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: var(--font-inter), -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background-color: var(--color-bg-secondary);
  color: var(--color-text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Utilities */
.glass {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

[data-theme="dark"] .glass {
  background: rgba(31, 41, 55, 0.7);
  border: 1px solid rgba(75, 85, 99, 0.18);
}

.card {
  background: var(--color-bg-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

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

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  font-weight: 600;
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  transition: all var(--transition-base);
  font-size: 0.875rem;
  line-height: 1.25rem;
}

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

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

.btn-primary {
  background: var(--gradient-primary);
  color: white;
}

.btn-success {
  background: var(--gradient-success);
  color: white;
}

.btn-warning {
  background: var(--gradient-warning);
  color: white;
}

.btn-error {
  background: var(--color-error);
  color: white;
}

.input {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  font-size: 1rem;
  transition: all var(--transition-fast);
}

.input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

/* Animations */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

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

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

.animate-fade-in {
  animation: fadeIn var(--transition-base);
}

.animate-slide-up {
  animation: slideUp var(--transition-slow);
}

.animate-slide-down {
  animation: slideDown var(--transition-slow);
}

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

::-webkit-scrollbar-track {
  background: var(--color-bg-tertiary);
}

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

::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-tertiary);
}

/* ===== DARK MODE ===== */
:root {
  --bg-primary: #f8f7ff;
  --bg-card: #ffffff;
  --bg-nav: rgba(255,255,255,0.92);
  --text-primary: #111827;
  --text-secondary: #6b7280;
  --border-color: #e5e7eb;
  --bg-input: #ffffff;
  --bg-hover: rgba(124,58,237,0.06);
}

[data-theme="dark"] {
  --bg-primary: #0f0f1a;
  --bg-card: #1a1a2e;
  --bg-nav: rgba(15,15,26,0.95);
  --text-primary: #f1f5f9;
  --text-secondary: #94a3b8;
  --border-color: #2d2d44;
  --bg-input: #1e1e32;
  --bg-hover: rgba(124,58,237,0.15);
}

[data-theme="dark"] body {
  background: var(--bg-primary);
  color: var(--text-primary);
}

[data-theme="dark"] nav {
  background: var(--bg-nav) !important;
  border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .card,
[data-theme="dark"] [class*="card"] {
  background: var(--bg-card) !important;
  border-color: var(--border-color) !important;
}

/* Exclure les cards des pages publiques */
[data-theme="dark"] [data-page="public"] .card,
[data-theme="dark"] [data-page="public"] [class*="card"] {
  background: unset !important;
  border-color: unset !important;
}

/* Dark: tous les divs blancs → dark card */
[data-theme="dark"] div[style*="background: '#fff'"],
[data-theme="dark"] div[style*='background: "#fff"'] {
  background: var(--bg-card) !important;
}

/* Dark mode - backgrounds pages */
[data-theme="dark"] div[style] {
  color: inherit;
}
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: var(--bg-input) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}
[data-theme="dark"] table {
  color: var(--text-primary) !important;
}
[data-theme="dark"] tr:hover td {
  background: var(--bg-hover) !important;
}

/* ===== DARK MODE GLOBAL OVERRIDE ===== */
[data-theme="dark"] {
  color-scheme: dark;
}

/* Background pages */
[data-theme="dark"] body,
[data-theme="dark"] div[style*="background: 'linear-gradient(145deg,#f8f7ff"],
[data-theme="dark"] div[style*="background: 'linear-gradient(145deg, #f8f7ff"],
[data-theme="dark"] div[style*="minHeight: '100vh'"] {
  background: #0f0f1a !important;
}

/* Toutes les cards blanches */
[data-theme="dark"] div[style*="background: '#fff'"],
[data-theme="dark"] div[style*='background: "#fff"'],
[data-theme="dark"] div[style*="background: 'white'"],
[data-theme="dark"] div[style*="background: '#fafafa'"],
[data-theme="dark"] div[style*="background: '#f9fafb'"],
[data-theme="dark"] div[style*="background: '#f8f9fa'"],
[data-theme="dark"] div[style*="background: rgba(255, 255, 255"],
[data-theme="dark"] div[style*="background: rgba(255,255,255"] {
  background: #1a1a2e !important;
  border-color: #2d2d44 !important;
}

/* Textes foncés → blancs */
[data-theme="dark"] *[style*="color: '#111827'"],
[data-theme="dark"] *[style*="color: '#1f2937'"],
[data-theme="dark"] *[style*="color: '#374151'"],
[data-theme="dark"] *[style*="color: '#4b5563'"] {
  color: #f1f5f9 !important;
}

/* Textes gris → gris clair */
[data-theme="dark"] *[style*="color: '#6b7280'"],
[data-theme="dark"] *[style*="color: '#9ca3af'"],
[data-theme="dark"] *[style*="color: '#d1d5db'"] {
  color: #94a3b8 !important;
}

/* Inputs & selects */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: #1e1e32 !important;
  color: #f1f5f9 !important;
  border-color: #2d2d44 !important;
}

[data-theme="dark"] input::placeholder {
  color: #64748b !important;
}

/* Tables */
[data-theme="dark"] table {
  color: #f1f5f9 !important;
}
[data-theme="dark"] th {
  color: #94a3b8 !important;
  background: transparent !important;
}
[data-theme="dark"] td {
  color: #f1f5f9 !important;
  border-color: #2d2d44 !important;
}
[data-theme="dark"] tr[style*="background: '#f9fafb'"],
[data-theme="dark"] tr[style*="background: '#fafafa'"] {
  background: #16162a !important;
}

/* Borders */
[data-theme="dark"] div[style*="borderBottom: '1px solid #f3f4f6'"],
[data-theme="dark"] div[style*="border: '1px solid #f3f4f6'"],
[data-theme="dark"] div[style*="border: '1px solid #e5e7eb'"] {
  border-color: #2d2d44 !important;
}

/* Backgrounds gris clair → dark */
[data-theme="dark"] div[style*="background: '#f3f4f6'"],
[data-theme="dark"] div[style*="background: '#f5f3ff'"],
[data-theme="dark"] div[style*="background: '#ede9fe'"],
[data-theme="dark"] div[style*="background: rgba(243,244,246"],
[data-theme="dark"] div[style*="background: rgba(249,250,251"] {
  background: #16162a !important;
}

/* Modal overlays */
[data-theme="dark"] div[style*="position: 'fixed'"][style*="background: 'rgba(0,0,0"] {
  background: rgba(0,0,0,0.75) !important;
}

/* Badges statuts */
[data-theme="dark"] span[style*="background: '#f0fdf4'"] { background: #052e16 !important; }
[data-theme="dark"] span[style*="background: '#eff6ff'"] { background: #1e3a5f !important; }
[data-theme="dark"] span[style*="background: '#fff7ed'"] { background: #431407 !important; }
[data-theme="dark"] span[style*="background: '#f9fafb'"] { background: #1a1a2e !important; }

/* Nav links actifs */
[data-theme="dark"] a[style*="color: '#7c3aed'"] {
  color: #a78bfa !important;
}
[data-theme="dark"] a[style*="color: '#6b7280'"] {
  color: #94a3b8 !important;
}

/* Page backgrounds light gradient */
[data-theme="dark"] div[style*="background: 'linear-gradient(145deg,#f8f"],
[data-theme="dark"] div[style*="background: linear-gradient(145deg, #f8f"] {
  background: #0f0f1a !important;
}

/* Headings */
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3 {
  color: #f1f5f9 !important;
}

/* Labels */
[data-theme="dark"] label {
  color: #cbd5e1 !important;
}

/* Dropdown menus */
[data-theme="dark"] div[style*="background: 'rgba(255, 255, 255, 0.97)'"],
[data-theme="dark"] div[style*="background: 'rgba(255,255,255,0.97)'"],
[data-theme="dark"] div[style*="background: 'rgba(255, 255, 255, 0.95)'"] {
  background: #1a1a2e !important;
  border-color: #2d2d44 !important;
}


/* ===== DARK MODE NUCLEAR OVERRIDE ===== */
[data-theme="dark"] * {
  color: #e2e8f0 !important;
  border-color: #2d2d44 !important;
}

[data-theme="dark"] body,
[data-theme="dark"] main,
[data-theme="dark"] section,
[data-theme="dark"] article,
[data-theme="dark"] div,
[data-theme="dark"] nav,
[data-theme="dark"] header,
[data-theme="dark"] footer {
  background-color: transparent;
}

/* Reset backgrounds to dark */
[data-theme="dark"] body {
  background: #0f0f1a !important;
}

/* Cards et containers */
[data-theme="dark"] div {
  --white-bg: #1a1a2e;
}

/* Forcer backgrounds blancs en dark */
[data-theme="dark"] div:not([style*="gradient"]):not([style*="linear"]):not([style*="#7c3aed"]):not([style*="#10b981"]):not([style*="#3b82f6"]):not([style*="#f59e0b"]):not([style*="#ef4444"]):not([style*="#8b5cf6"]) {
  background-color: transparent;
}

/* Pages principales */
[data-theme="dark"] div[style*="minHeight"] {
  background: #0f0f1a !important;
}

/* Tous les éléments avec background blanc */
[data-theme="dark"] [style*="background: rgb(255, 255, 255)"],
[data-theme="dark"] [style*="background: white"],
[data-theme="dark"] [style*="background-color: white"],
[data-theme="dark"] [style*="background-color: rgb(255, 255, 255)"] {
  background: #1a1a2e !important;
}

/* Nav */
[data-theme="dark"] nav {
  background: rgba(15,15,26,0.97) !important;
}

/* Inputs */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: #252540 !important;
  color: #f1f5f9 !important;
}

/* Garder les couleurs violettes/colorées */
[data-theme="dark"] *[style*="color: rgb(124, 58, 237)"],
[data-theme="dark"] *[style*="color: rgb(16, 185, 129)"],
[data-theme="dark"] *[style*="color: rgb(239, 68, 68)"],
[data-theme="dark"] *[style*="color: rgb(59, 130, 246)"],
[data-theme="dark"] *[style*="color: rgb(245, 158, 11)"] {
  color: inherit !important;
}

/* Texte violet brand */
[data-theme="dark"] *[style*="WebkitTextFillColor"] {
  -webkit-text-fill-color: #a78bfa !important;
}

/* ===== RESPONSIVE MODALS MOBILE ===== */
@media (max-width: 640px) {
  /* Overlay en bas sur mobile */
  div[style*="position: fixed"][style*="inset: 0"][style*="alignItems: 'center'"] {
    align-items: flex-end !important;
    padding: 0 !important;
  }

  /* Modal box pleine largeur */
  div[style*="maxWidth: 400"],
  div[style*="maxWidth: 520"],
  div[style*="maxWidth: 640"],
  div[style*="maxWidth: 680"] {
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 20px 20px 0 0 !important;
    max-height: 92vh !important;
  }

  /* Padding réduit dans modals */
  div[style*="maxWidth: 400"] > div,
  div[style*="maxWidth: 520"] > *,
  div[style*="maxWidth: 640"] > *,
  div[style*="maxWidth: 680"] > * {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Header modal padding */
  div[style*="borderRadius: 20px 20px 0 0"] div[style*="padding: 24"],
  div[style*="borderRadius: 20px 20px 0 0"] div[style*="padding: 32"] {
    padding: 20px 16px !important;
  }

  /* Grid 2 colonnes → 1 colonne dans modals */
  div[style*="maxWidth: 680"] div[style*="gridTemplateColumns: '1fr 1fr'"],
  div[style*="maxWidth: 520"] div[style*="gridTemplateColumns: '1fr 1fr'"] {
    grid-template-columns: 1fr !important;
  }

  /* Table prestations scroll horizontal */
  div[style*="maxWidth: 680"] div[style*="border: "][style*="borderRadius: 12"][style*="overflow: 'hidden'"] {
    overflow-x: auto !important;
  }
}

/* ================================================================
   DESIGN UPGRADE — FacturaPro Premium UI
   ================================================================ */

/* ── Fond principal avec texture subtile ──────────────────────── */
body {
  background-image:
    radial-gradient(ellipse 80% 50% at 20% -10%, rgba(124,58,237,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 110%, rgba(16,185,129,0.05) 0%, transparent 50%);
  background-attachment: fixed;
}
[data-theme="dark"] body {
  background-image:
    radial-gradient(ellipse 80% 50% at 20% -10%, rgba(124,58,237,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 110%, rgba(16,185,129,0.08) 0%, transparent 50%);
}

/* ── Cards premium ────────────────────────────────────────────── */
.card {
  border: 1px solid rgba(124,58,237,0.08);
  box-shadow:
    0 1px 3px rgba(0,0,0,0.05),
    0 4px 12px rgba(0,0,0,0.06),
    0 0 0 1px rgba(255,255,255,0.5) inset;
  transition: transform 220ms cubic-bezier(.22,1,.36,1),
              box-shadow 220ms cubic-bezier(.22,1,.36,1);
  will-change: transform;
}
.card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 4px 8px rgba(0,0,0,0.06),
    0 12px 30px rgba(124,58,237,0.1),
    0 0 0 1px rgba(255,255,255,0.6) inset;
}
[data-theme="dark"] .card {
  border: 1px solid rgba(124,58,237,0.15);
  box-shadow:
    0 1px 3px rgba(0,0,0,0.3),
    0 4px 12px rgba(0,0,0,0.25),
    0 0 0 1px rgba(255,255,255,0.04) inset;
}
[data-theme="dark"] .card:hover {
  box-shadow:
    0 4px 8px rgba(0,0,0,0.35),
    0 12px 30px rgba(124,58,237,0.2),
    0 0 0 1px rgba(255,255,255,0.06) inset;
}

/* ── Stat cards icone ─────────────────────────────────────────── */
.stat-icon-box {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.15);
  flex-shrink: 0;
}

/* ── Boutons premium ──────────────────────────────────────────── */
.btn {
  position: relative;
  overflow: hidden;
  letter-spacing: 0.01em;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, transparent 100%);
  pointer-events: none;
  border-radius: inherit;
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.14);
}
.btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(0,0,0,0.1);
}
.btn-primary {
  background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 50%, #6d28d9 100%);
  box-shadow: 0 4px 14px rgba(124,58,237,0.35);
}
.btn-primary:hover {
  box-shadow: 0 6px 20px rgba(124,58,237,0.45);
}

/* ── Inputs premium ───────────────────────────────────────────── */
.input, input[type="text"], input[type="email"],
input[type="date"], input[type="number"], input[type="password"],
select, textarea {
  transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}
.input:focus, input:focus, select:focus, textarea:focus {
  box-shadow: 0 0 0 3px rgba(124,58,237,0.12), 0 1px 3px rgba(0,0,0,0.06);
}

/* ── Status badges ────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.badge-paid    { background: rgba(16,185,129,0.12); color: #059669; border: 1px solid rgba(16,185,129,0.25); }
.badge-sent    { background: rgba(59,130,246,0.12); color: #2563eb; border: 1px solid rgba(59,130,246,0.25); }
.badge-draft   { background: rgba(107,114,128,0.12); color: #4b5563; border: 1px solid rgba(107,114,128,0.25); }
.badge-overdue { background: rgba(239,68,68,0.12);  color: #dc2626; border: 1px solid rgba(239,68,68,0.25); }
.badge-pending { background: rgba(245,158,11,0.12); color: #b45309; border: 1px solid rgba(245,158,11,0.25); }
[data-theme="dark"] .badge-paid    { background: rgba(16,185,129,0.18);  color: #34d399; }
[data-theme="dark"] .badge-sent    { background: rgba(59,130,246,0.18);  color: #60a5fa; }
[data-theme="dark"] .badge-draft   { background: rgba(107,114,128,0.18); color: #9ca3af; }
[data-theme="dark"] .badge-overdue { background: rgba(239,68,68,0.18);   color: #f87171; }
[data-theme="dark"] .badge-pending { background: rgba(245,158,11,0.18);  color: #fbbf24; }

/* ── Tables premium ───────────────────────────────────────────── */
.premium-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13.5px;
}
.premium-table thead th {
  padding: 11px 16px;
  text-align: left;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  background: var(--color-bg-tertiary);
  border-bottom: 1px solid var(--color-border);
}
.premium-table thead th:first-child { border-radius: 10px 0 0 0; }
.premium-table thead th:last-child  { border-radius: 0 10px 0 0; }
.premium-table tbody tr {
  transition: background 150ms ease;
}
.premium-table tbody tr:hover td {
  background: rgba(124,58,237,0.04);
}
[data-theme="dark"] .premium-table tbody tr:hover td {
  background: rgba(124,58,237,0.10);
}
.premium-table tbody td {
  padding: 13px 16px;
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text-primary);
  vertical-align: middle;
}
.premium-table tbody tr:last-child td { border-bottom: none; }

/* ── Overlay modaux premium ───────────────────────────────────── */
.modal-overlay {
  backdrop-filter: blur(6px) saturate(1.2);
  -webkit-backdrop-filter: blur(6px) saturate(1.2);
  background: rgba(15,10,30,0.45);
}
[data-theme="dark"] .modal-overlay {
  background: rgba(5,5,15,0.65);
}

/* ── Séparateur avec dégradé ──────────────────────────────────── */
.gradient-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124,58,237,0.3), transparent);
  border: none;
  margin: 1.5rem 0;
}

/* ── Animations améliorées ────────────────────────────────────── */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.97) translateY(8px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}
@keyframes shimmer {
  from { background-position: -200% 0; }
  to   { background-position:  200% 0; }
}
.animate-slide-up {
  animation: slideUp 380ms cubic-bezier(.22,1,.36,1) both;
}
.animate-scale-in {
  animation: scaleIn 280ms cubic-bezier(.22,1,.36,1) both;
}

/* ── Skeleton loader ──────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg,
    var(--color-bg-tertiary) 25%,
    var(--color-border) 50%,
    var(--color-bg-tertiary) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--radius-md);
}

/* ── Scrollbar fine premium ───────────────────────────────────── */
::-webkit-scrollbar       { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(124,58,237,0.25);
  border-radius: 999px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(124,58,237,0.45); }

/* ── Page title gradient ──────────────────────────────────────── */
.page-title-gradient {
  background: linear-gradient(135deg, var(--color-text-primary) 0%, var(--color-primary) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Numéro de facture mono ───────────────────────────────────── */
.invoice-number {
  font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.03em;
  background: rgba(124,58,237,0.08);
  color: var(--color-primary);
  padding: 2px 8px;
  border-radius: 6px;
  border: 1px solid rgba(124,58,237,0.15);
}
[data-theme="dark"] .invoice-number {
  background: rgba(124,58,237,0.18);
  color: #a78bfa;
  border-color: rgba(167,139,250,0.25);
}

/* ── Amount highlight ─────────────────────────────────────────── */
.amount-paid    { color: #059669; font-weight: 700; }
.amount-pending { color: #b45309; font-weight: 700; }
.amount-overdue { color: #dc2626; font-weight: 700; }
[data-theme="dark"] .amount-paid    { color: #34d399; }
[data-theme="dark"] .amount-pending { color: #fbbf24; }
[data-theme="dark"] .amount-overdue { color: #f87171; }

/* ── Pulse rouge pour les alertes retard ──────────────────────── */
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.6; transform: scale(1.3); }
}
.alert-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ef4444;
  animation: pulse-dot 1.8s ease-in-out infinite;
  display: inline-block;
}

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 768px) {
  .card { border-radius: var(--radius-lg); }
}

/* ── Action buttons dans les tables ──────────────────────────── */
.action-btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  border: 1px solid var(--color-border) !important;
  background: var(--color-bg-primary) !important;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.action-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1) !important;
  background: var(--color-bg-secondary) !important;
}
.action-btn:active { transform: translateY(0) !important; }
[data-theme="dark"] .action-btn {
  background: var(--bg-input) !important;
  border-color: var(--border-color) !important;
}

/* ── Stat cards grid ─────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-gap: 1.25rem;
  gap: 1.25rem;
}
@media (max-width: 640px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 0.875rem; }
}

/* ── Header page avec séparateur dégradé ─────────────────────── */
.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border-light);
  background: linear-gradient(90deg, transparent, rgba(124,58,237,0.04), transparent);
  background-size: 100% 1px;
  background-repeat: no-repeat;
  background-position: bottom;
}

/* ── Toast notifications premium ─────────────────────────────── */
.toast {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.16), 0 2px 8px rgba(0,0,0,0.08);
  border: 1px solid rgba(255,255,255,0.15);
}

/* ── Filter pills ────────────────────────────────────────────── */
.filter-pill {
  padding: 6px 16px;
  border-radius: 999px;
  border: 1.5px solid var(--color-border);
  background: var(--color-bg-primary);
  color: var(--color-text-secondary);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 150ms ease;
}
.filter-pill:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.filter-pill.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: white;
  box-shadow: 0 2px 8px rgba(124,58,237,0.3);
}

/* ========================================================
   PAGES PUBLIQUES : IMMUNITÉ AU DARK MODE
   Landing / Login / Register = toujours LIGHT
   data-preserve = sections intentionnellement sombres
   ======================================================== */

/* A) Wrapper racine */
[data-theme="dark"] [data-page="public"] {
  background: #ffffff !important;
  color: #111827 !important;
  -webkit-text-fill-color: unset !important;
}

/* B) Annuler les overrides dark de couleur de texte sur tous les enfants
      SAUF ceux dans data-preserve (qui ont leurs propres couleurs intentionnelles) */
[data-theme="dark"] [data-page="public"] *:not([data-preserve]):not([data-preserve] *) {
  color: unset !important;
  -webkit-text-fill-color: unset !important;
}

/* C) Textes de base sur fond blanc : héritent #111827 du wrapper
      SANS !important → les inline styles (color:'#fff' dans les cards sombres) l'emportent */
[data-theme="dark"] [data-page="public"] h1:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] h2:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] h3:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] h4:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] p:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] li:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] label:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] span:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] div:not([data-preserve] *) {
  color: #111827;
}

/* D) Liens navigation */
[data-theme="dark"] [data-page="public"] a:not([data-preserve] *) {
  color: inherit;
}

/* E) Sections et nav : fonds transparents */
[data-theme="dark"] [data-page="public"] section:not([data-preserve]),
[data-theme="dark"] [data-page="public"] nav {
  background-color: transparent !important;
  background: transparent !important;
}

/* F) Inputs / selects / textareas : light mode */
[data-theme="dark"] [data-page="public"] input:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] select:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] textarea:not([data-preserve] *) {
  background: #ffffff !important;
  color: #111827 !important;
  border-color: #e5e7eb !important;
}
[data-theme="dark"] [data-page="public"] input::placeholder {
  color: #9ca3af !important;
}

/* ========================================================
   PAGES PUBLIQUES — Neutraliser les overrides de background
   Les règles dark globales changent background:'#fff' → #1a1a2e
   On doit les annuler pour les pages publiques
   ======================================================== */

/* Neutraliser la conversion background:#fff → #1a1a2e sur les pages publiques */
[data-theme="dark"] [data-page="public"] div[style*="background: '#fff'"],
[data-theme="dark"] [data-page="public"] div[style*='background: "#fff"'],
[data-theme="dark"] [data-page="public"] div[style*="background: 'white'"],
[data-theme="dark"] [data-page="public"] div[style*="background: '#fafafa'"],
[data-theme="dark"] [data-page="public"] div[style*="background: '#f9fafb'"],
[data-theme="dark"] [data-page="public"] div[style*="background: '#f5f3ff'"],
[data-theme="dark"] [data-page="public"] div[style*="background: '#f3f4f6'"],
[data-theme="dark"] [data-page="public"] div[style*="background: rgba(255,255,255"] {
  background: unset !important;
  border-color: unset !important;
}

/* Les feature cards, pricing cards, testimonials ont background:'#fff' → garder blanc */
/* En réalité on laisse l'inline style prendre le dessus avec "unset" */

/* Neutraliser aussi les backgrounds sombres forcés sur minHeight et body */
[data-theme="dark"] [data-page="public"] div[style*="minHeight: '100vh'"],
[data-theme="dark"] [data-page="public"] div[style*='minHeight: "100vh"'],
[data-theme="dark"] [data-page="public"] div[style*="minHeight:'100vh'"] {
  background: #ffffff !important;
}

/* Neutraliser la conversion des textes #111827 → #f1f5f9 sur pages publiques */
[data-theme="dark"] [data-page="public"] *[style*="color: '#111827'"]:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] *[style*="color: '#1f2937'"]:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] *[style*="color: '#374151'"]:not([data-preserve] *),
[data-theme="dark"] [data-page="public"] *[style*="color: '#6b7280'"]:not([data-preserve] *) {
  color: unset !important;
}

