/* =========================================================
   DDJ UI Kit — Themes
   Thèmes activés avec <body data-theme="...">.
   ========================================================= */

/* ---------------------------------------------------------
   Thèmes colorés sobres
--------------------------------------------------------- */

body[data-theme="blue"] {
  --ddj-primary: #2563eb;
  --ddj-primary-dark: #1d4ed8;
}

body[data-theme="green"] {
  --ddj-primary: #16a34a;
  --ddj-primary-dark: #15803d;
}

body[data-theme="purple"] {
  --ddj-primary: #7c3aed;
  --ddj-primary-dark: #6d28d9;
}

body[data-theme="red"] {
  --ddj-primary: #dc2626;
  --ddj-primary-dark: #b91c1c;
}

body[data-theme="minimal"] {
  --ddj-primary: #111827;
  --ddj-primary-dark: #020617;
  --ddj-radius: 0.35rem;
  --ddj-radius-lg: 0.5rem;
}

/* ---------------------------------------------------------
   Thème gris professionnel
   Gris moyen, pas trop clair, adapté back-office.
--------------------------------------------------------- */

body[data-theme="pro-gray"] {
  --ddj-primary: #334155;
  --ddj-primary-dark: #1f2937;
  --ddj-bg: #aeb8c4;
  --ddj-surface: #cbd3dc;
  --ddj-surface-soft: #b8c2cd;
  --ddj-border: #8793a3;
  --ddj-text: #111827;
  --ddj-muted: #3f4a5a;
  --ddj-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.12);
  --ddj-shadow: 0 12px 28px rgba(15, 23, 42, 0.18);
  --ddj-shadow-lg: 0 24px 60px rgba(15, 23, 42, 0.24);
}

/* ---------------------------------------------------------
   Thème sombre professionnel 1 — Executive Navy
   Ambiance direction, SaaS, dashboard financier.
--------------------------------------------------------- */

body[data-theme="pro-navy"] {
  --ddj-primary: #38bdf8;
  --ddj-primary-dark: #0ea5e9;
  --ddj-bg: #07111f;
  --ddj-surface: #0d1b2f;
  --ddj-surface-soft: #10243d;
  --ddj-border: #1d3554;
  --ddj-text: #e5eef9;
  --ddj-muted: #9fb2cc;
  --ddj-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.28);
  --ddj-shadow: 0 14px 32px rgba(0, 0, 0, 0.34);
  --ddj-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.45);
}

/* ---------------------------------------------------------
   Thème sombre professionnel 2 — Graphite
   Très neutre, sérieux, idéal outils métier.
--------------------------------------------------------- */

body[data-theme="pro-graphite"] {
  --ddj-primary: #a3e635;
  --ddj-primary-dark: #84cc16;
  --ddj-bg: #0d0f12;
  --ddj-surface: #16191d;
  --ddj-surface-soft: #1d2127;
  --ddj-border: #2a3038;
  --ddj-text: #edf0f3;
  --ddj-muted: #a4adb8;
  --ddj-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.30);
  --ddj-shadow: 0 14px 34px rgba(0, 0, 0, 0.36);
  --ddj-shadow-lg: 0 26px 70px rgba(0, 0, 0, 0.48);
}

/* ---------------------------------------------------------
   Thème sombre professionnel 3 — Burgundy
   Premium, institutionnel, moins technique.
--------------------------------------------------------- */

body[data-theme="pro-burgundy"] {
  --ddj-primary: #f4b183;
  --ddj-primary-dark: #ea8c55;
  --ddj-bg: #160b10;
  --ddj-surface: #241018;
  --ddj-surface-soft: #2d1620;
  --ddj-border: #4b2633;
  --ddj-text: #f8edf0;
  --ddj-muted: #c7aab4;
  --ddj-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.32);
  --ddj-shadow: 0 14px 34px rgba(0, 0, 0, 0.38);
  --ddj-shadow-lg: 0 26px 70px rgba(0, 0, 0, 0.50);
}

/* ---------------------------------------------------------
   Thème marbre sombre
   Reprend l'effet premium demandé pour les heroes.
--------------------------------------------------------- */

body[data-theme="dark-marble"] {
  --ddj-primary: #6f86a6;
  --ddj-primary-dark: #8fa4c2;
  --ddj-bg: #05070a;
  --ddj-surface: #0b0d10;
  --ddj-surface-soft: #111318;
  --ddj-border: rgba(148, 163, 184, 0.24);
  --ddj-text: #f8fafc;
  --ddj-muted: #aab4c1;
  --ddj-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.30);
  --ddj-shadow: 0 16px 40px rgba(0, 0, 0, 0.40);
  --ddj-shadow-lg: 0 28px 80px rgba(0, 0, 0, 0.54);
}

/* ---------------------------------------------------------
   Fonds marbre
--------------------------------------------------------- */

.ddj-bg-marble-light {
  background:
    linear-gradient(115deg, transparent 0 42%, rgba(148, 163, 184, 0.20) 43%, transparent 45%),
    linear-gradient(135deg, transparent 0 55%, rgba(100, 116, 139, 0.16) 56%, transparent 58%),
    linear-gradient(75deg, transparent 0 62%, rgba(203, 213, 225, 0.30) 63%, transparent 66%),
    radial-gradient(circle at 25% 25%, rgba(255, 255, 255, 0.95), transparent 32%),
    radial-gradient(circle at 80% 30%, rgba(226, 232, 240, 0.75), transparent 35%),
    linear-gradient(135deg, #ffffff 0%, #f8fafc 45%, #e2e8f0 100%);
  background-size:
    420px 420px,
    520px 520px,
    360px 360px,
    100% 100%,
    100% 100%,
    100% 100%;
}

body[data-theme="dark-marble"],
.ddj-bg-marble-dark {
  color: #f8fafc;
  background:
    linear-gradient(115deg, transparent 0 41%, rgba(148, 163, 184, 0.16) 42%, transparent 46%),
    linear-gradient(135deg, transparent 0 54%, rgba(96, 165, 250, 0.18) 55%, transparent 59%),
    linear-gradient(75deg, transparent 0 61%, rgba(203, 213, 225, 0.12) 62%, transparent 66%),
    radial-gradient(circle at 18% 22%, rgba(59, 130, 246, 0.12), transparent 28%),
    radial-gradient(circle at 82% 28%, rgba(148, 163, 184, 0.14), transparent 32%),
    radial-gradient(circle at 50% 85%, rgba(15, 23, 42, 0.95), transparent 40%),
    linear-gradient(135deg, #05070a 0%, #0b0d10 35%, #111318 70%, #171a1f 100%);
  background-size:
    460px 460px,
    560px 560px,
    380px 380px,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%;
  background-blend-mode:
    screen,
    screen,
    screen,
    soft-light,
    soft-light,
    normal,
    normal;
}

.ddj-marble-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(3rem, 8vw, 6rem);
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: var(--ddj-radius-xl);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 24px 70px rgba(2, 6, 23, 0.32);
}

.ddj-marble-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 40%, rgba(255, 255, 255, 0.10), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 36%, rgba(0, 0, 0, 0.22));
  opacity: 0.75;
}

.ddj-marble-hero > * {
  position: relative;
  z-index: 1;
}

.ddj-marble-title {
  margin-bottom: 0.75rem;
  color: currentColor;
  font-family: var(--ddj-font-serif);
  font-size: clamp(2.5rem, 7vw, 5.5rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
  text-align: center;
}

.ddj-marble-subtitle {
  max-width: 620px;
  margin: 1rem auto 0;
  color: rgba(248, 250, 252, 0.74);
  font-size: 1.15rem;
  text-align: center;
}

.ddj-marble-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  width: min(260px, 70%);
  margin-inline: auto;
  color: rgba(217, 191, 142, 0.82);
}

.ddj-marble-divider::before,
.ddj-marble-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: 0.55;
}

.ddj-marble-divider span {
  display: inline-block;
  width: 0.65rem;
  height: 0.65rem;
  background: currentColor;
  transform: rotate(45deg);
}

@media (max-width: 768px) {
  .ddj-marble-hero {
    padding: 3rem 1.25rem;
  }
}


/* ---------------------------------------------------------
   Correctifs thèmes sombres
   Évite les surfaces Bootstrap trop claires dans les thèmes
   sombres, notamment `dark-marble`.
--------------------------------------------------------- */

body[data-theme="pro-navy"] .card,
body[data-theme="pro-graphite"] .card,
body[data-theme="pro-burgundy"] .card,
body[data-theme="dark-marble"] .card,
body[data-theme="pro-navy"] .card-body,
body[data-theme="pro-graphite"] .card-body,
body[data-theme="pro-burgundy"] .card-body,
body[data-theme="dark-marble"] .card-body {
  color: var(--ddj-text);
  background: var(--ddj-surface);
}

body[data-theme="pro-navy"] .card-header,
body[data-theme="pro-graphite"] .card-header,
body[data-theme="pro-burgundy"] .card-header,
body[data-theme="dark-marble"] .card-header,
body[data-theme="pro-navy"] .card-footer,
body[data-theme="pro-graphite"] .card-footer,
body[data-theme="pro-burgundy"] .card-footer,
body[data-theme="dark-marble"] .card-footer {
  color: var(--ddj-text);
  background: var(--ddj-surface-soft);
  border-color: var(--ddj-border);
}

body[data-theme="pro-navy"] .table,
body[data-theme="pro-graphite"] .table,
body[data-theme="pro-burgundy"] .table,
body[data-theme="dark-marble"] .table {
  --bs-table-color: var(--ddj-text);
  --bs-table-bg: var(--ddj-surface);
  --bs-table-border-color: var(--ddj-border);
  --bs-table-striped-color: var(--ddj-text);
  --bs-table-striped-bg: color-mix(in srgb, var(--ddj-surface-soft) 80%, transparent);
  --bs-table-hover-color: var(--ddj-text);
  --bs-table-hover-bg: color-mix(in srgb, var(--ddj-primary) 12%, var(--ddj-surface));
  color: var(--ddj-text);
  background: var(--ddj-surface);
}

body[data-theme="pro-navy"] .table > :not(caption) > * > *,
body[data-theme="pro-graphite"] .table > :not(caption) > * > *,
body[data-theme="pro-burgundy"] .table > :not(caption) > * > *,
body[data-theme="dark-marble"] .table > :not(caption) > * > * {
  color: var(--ddj-text);
  background-color: var(--bs-table-bg);
  border-bottom-color: var(--ddj-border);
}

body[data-theme="pro-navy"] .list-group-item,
body[data-theme="pro-graphite"] .list-group-item,
body[data-theme="pro-burgundy"] .list-group-item,
body[data-theme="dark-marble"] .list-group-item {
  color: var(--ddj-text);
  background: var(--ddj-surface);
  border-color: var(--ddj-border);
}

body[data-theme="pro-navy"] .list-group-item.active,
body[data-theme="pro-graphite"] .list-group-item.active,
body[data-theme="pro-burgundy"] .list-group-item.active,
body[data-theme="dark-marble"] .list-group-item.active {
  color: #ffffff;
  background: var(--ddj-primary);
  border-color: var(--ddj-primary);
}

body[data-theme="pro-navy"] .list-group-item.disabled,
body[data-theme="pro-graphite"] .list-group-item.disabled,
body[data-theme="pro-burgundy"] .list-group-item.disabled,
body[data-theme="dark-marble"] .list-group-item.disabled,
body[data-theme="pro-navy"] .list-group-item:disabled,
body[data-theme="pro-graphite"] .list-group-item:disabled,
body[data-theme="pro-burgundy"] .list-group-item:disabled,
body[data-theme="dark-marble"] .list-group-item:disabled {
  color: var(--ddj-muted);
  background: var(--ddj-surface-soft);
}

body[data-theme="pro-navy"] .page-link,
body[data-theme="pro-graphite"] .page-link,
body[data-theme="pro-burgundy"] .page-link,
body[data-theme="dark-marble"] .page-link {
  color: var(--ddj-text);
  background: var(--ddj-surface);
  border-color: var(--ddj-border);
}

body[data-theme="pro-navy"] .page-item.active .page-link,
body[data-theme="pro-graphite"] .page-item.active .page-link,
body[data-theme="pro-burgundy"] .page-item.active .page-link,
body[data-theme="dark-marble"] .page-item.active .page-link {
  color: #ffffff;
  background: var(--ddj-primary);
  border-color: var(--ddj-primary);
}

body[data-theme="pro-navy"] .page-item.disabled .page-link,
body[data-theme="pro-graphite"] .page-item.disabled .page-link,
body[data-theme="pro-burgundy"] .page-item.disabled .page-link,
body[data-theme="dark-marble"] .page-item.disabled .page-link {
  color: var(--ddj-muted);
  background: var(--ddj-surface-soft);
  border-color: var(--ddj-border);
}

body[data-theme="pro-navy"] .ddj-error-state,
body[data-theme="pro-graphite"] .ddj-error-state,
body[data-theme="pro-burgundy"] .ddj-error-state,
body[data-theme="dark-marble"] .ddj-error-state {
  color: var(--ddj-text);
  background: var(--ddj-danger-bg);
  border-color: color-mix(in srgb, var(--ddj-danger-text) 38%, var(--ddj-border));
}

body[data-theme="pro-navy"] .btn-primary,
body[data-theme="pro-graphite"] .btn-primary,
body[data-theme="pro-burgundy"] .btn-primary,
body[data-theme="dark-marble"] .btn-primary,
body[data-theme="pro-navy"] .ddj-pill-primary,
body[data-theme="pro-graphite"] .ddj-pill-primary,
body[data-theme="pro-burgundy"] .ddj-pill-primary,
body[data-theme="dark-marble"] .ddj-pill-primary {
  color: #ffffff;
}

body[data-theme="pro-navy"] .btn:disabled,
body[data-theme="pro-graphite"] .btn:disabled,
body[data-theme="pro-burgundy"] .btn:disabled,
body[data-theme="dark-marble"] .btn:disabled {
  color: var(--ddj-muted);
  background: var(--ddj-surface-soft);
  border-color: var(--ddj-border);
}


/* ---------------------------------------------------------
   Correctifs thème pro-gray
   Le thème gris doit rester professionnel et lisible sans
   basculer vers un rendu blanc trop clair.
--------------------------------------------------------- */

body[data-theme="pro-gray"] .ddj-page-header {
  background:
    radial-gradient(circle at 0% 0%, rgba(51, 65, 85, 0.18), transparent 34%),
    linear-gradient(135deg, #b3bdc8 0%, #c7d0da 52%, #aeb8c4 100%);
  border-color: #8a96a6;
  box-shadow: var(--ddj-shadow-sm);
}

body[data-theme="pro-gray"] .ddj-surface,
body[data-theme="pro-gray"] .ddj-stat-card,
body[data-theme="pro-gray"] .ddj-toolbar,
body[data-theme="pro-gray"] .ddj-filterbar,
body[data-theme="pro-gray"] .ddj-font-card,
body[data-theme="pro-gray"] .card,
body[data-theme="pro-gray"] .ddj-card {
  background: var(--ddj-surface);
  border-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .navbar,
body[data-theme="pro-gray"] .ddj-sidebar {
  background: #c3ccd6;
  border-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .card-header,
body[data-theme="pro-gray"] .card-footer {
  background: var(--ddj-surface-soft);
  border-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .form-control,
body[data-theme="pro-gray"] .form-select,
body[data-theme="pro-gray"] .input-group-text {
  background-color: #d8dee6;
  color: var(--ddj-text);
  border-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .form-control::placeholder {
  color: #647084;
}

body[data-theme="pro-gray"] .table {
  --bs-table-color: var(--ddj-text);
  --bs-table-bg: var(--ddj-surface);
  --bs-table-border-color: var(--ddj-border);
  --bs-table-striped-color: var(--ddj-text);
  --bs-table-striped-bg: #bec8d3;
  --bs-table-hover-color: var(--ddj-text);
  --bs-table-hover-bg: #b4bfcb;
}

body[data-theme="pro-gray"] .table > :not(caption) > * > * {
  color: var(--ddj-text);
  background-color: var(--bs-table-bg);
  border-bottom-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .list-group-item,
body[data-theme="pro-gray"] .page-link {
  color: var(--ddj-text);
  background: var(--ddj-surface);
  border-color: var(--ddj-border);
}

body[data-theme="pro-gray"] .list-group-item.active,
body[data-theme="pro-gray"] .page-item.active .page-link {
  color: #ffffff;
  background: var(--ddj-primary);
  border-color: var(--ddj-primary);
}

body[data-theme="pro-gray"] .btn-primary,
body[data-theme="pro-gray"] .badge.bg-primary,
body[data-theme="pro-gray"] .ddj-pill-primary {
  color: #ffffff;
}

body[data-theme="pro-gray"] .btn-outline-primary {
  color: var(--ddj-primary-dark);
  border-color: var(--ddj-primary);
}

body[data-theme="pro-gray"] .btn-outline-primary:hover {
  color: #ffffff;
  background: var(--ddj-primary);
  border-color: var(--ddj-primary);
}

/* ---------------------------------------------------------
   Fond global dark-marble
   Applique l'effet marbre au background complet de la page.
   Les surfaces restent lisibles grâce à un fond semi-opaque.
--------------------------------------------------------- */

body[data-theme="dark-marble"] {
  background:
    linear-gradient(115deg, transparent 0 41%, rgba(148, 163, 184, 0.11) 42%, transparent 46%),
    linear-gradient(135deg, transparent 0 54%, rgba(96, 165, 250, 0.11) 55%, transparent 59%),
    linear-gradient(75deg, transparent 0 61%, rgba(203, 213, 225, 0.08) 62%, transparent 66%),
    radial-gradient(circle at 18% 18%, rgba(96, 165, 250, 0.12), transparent 28%),
    radial-gradient(circle at 82% 24%, rgba(148, 163, 184, 0.12), transparent 32%),
    radial-gradient(circle at 50% 95%, rgba(15, 23, 42, 0.95), transparent 42%),
    linear-gradient(135deg, #05070a 0%, #0b0d10 38%, #111318 72%, #171a1f 100%);
  background-attachment: fixed;
  background-size:
    540px 540px,
    720px 720px,
    460px 460px,
    100% 100%,
    100% 100%,
    100% 100%,
    100% 100%;
  background-blend-mode:
    screen,
    screen,
    screen,
    soft-light,
    soft-light,
    normal,
    normal;
}

body[data-theme="dark-marble"] .navbar,
body[data-theme="dark-marble"] .ddj-sidebar,
body[data-theme="dark-marble"] .ddj-surface,
body[data-theme="dark-marble"] .ddj-stat-card,
body[data-theme="dark-marble"] .ddj-toolbar,
body[data-theme="dark-marble"] .ddj-filterbar,
body[data-theme="dark-marble"] .ddj-font-card,
body[data-theme="dark-marble"] .ddj-card,
body[data-theme="dark-marble"] .card,
body[data-theme="dark-marble"] .modal-content,
body[data-theme="dark-marble"] .offcanvas,
body[data-theme="dark-marble"] .toast {
  background: rgba(11, 13, 16, 0.88);
  backdrop-filter: blur(14px);
}

body[data-theme="dark-marble"] .card-header,
body[data-theme="dark-marble"] .card-footer,
body[data-theme="dark-marble"] .toast-header,
body[data-theme="dark-marble"] .accordion-button,
body[data-theme="dark-marble"] .accordion-body,
body[data-theme="dark-marble"] .list-group-item,
body[data-theme="dark-marble"] .page-link,
body[data-theme="dark-marble"] .dropdown-menu {
  background: rgba(17, 19, 24, 0.92);
  backdrop-filter: blur(14px);
}

body[data-theme="dark-marble"] .form-control,
body[data-theme="dark-marble"] .form-select,
body[data-theme="dark-marble"] .input-group-text {
  background-color: rgba(5, 7, 10, 0.72);
  backdrop-filter: blur(10px);
}

body[data-theme="dark-marble"] .ddj-page-header {
  background:
    radial-gradient(circle at 0% 0%, rgba(148, 163, 184, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(11, 13, 16, 0.90), rgba(17, 19, 24, 0.72));
  backdrop-filter: blur(14px);
}

