/* =============================================================================
   SaalaPay — Design System
   -----------------------------------------------------------------------------
   Tokens centralisés (couleurs, typo, spacing, radius, shadows) + composants
   utilitaires sobres préfixés `sp-` pour ne jamais entrer en conflit avec
   Tailwind ou les classes existantes du markup.
   ============================================================================= */

:root {
    /* ------- Brand : vert profond, aligné sur la palette marketing --mk-primary.
       Le dashboard partage la même couleur de marque que le site public.
       Pour distinguer une « info » bleue, utiliser --sp-info-* (sémantique). ------- */
    --sp-primary-50:  #E6F4EE;
    --sp-primary-100: #C2E4D2;
    --sp-primary-300: #5DB089;
    --sp-primary-500: #006B3F;   /* couleur principale (vert profond) */
    --sp-primary-600: #005C36;
    --sp-primary-700: #004A2A;
    --sp-primary-900: #002618;

    /* ------- Accent ocre — highlights chaleureux (badges, deltas, indicateurs).
       Aligné sur --mk-accent-*. ------- */
    --sp-accent-50:   #FCF3E2;
    --sp-accent-100:  #F8E4B7;
    --sp-accent-300:  #F0BD68;
    --sp-accent-500:  #E89B30;
    --sp-accent-700:  #B07418;

    /* ------- Neutrals : une seule rampe gris froid neutre ------- */
    --sp-gray-0:   #FFFFFF;
    --sp-gray-50:  #F8FAFC;
    --sp-gray-100: #F1F5F9;
    --sp-gray-200: #E2E8F0;
    --sp-gray-300: #CBD5E1;
    --sp-gray-400: #94A3B8;
    --sp-gray-500: #64748B;
    --sp-gray-600: #475569;
    --sp-gray-700: #334155;
    --sp-gray-800: #1E293B;
    --sp-gray-900: #0F172A;

    /* ------- Semantic ------- */
    --sp-success-50:  #ECFDF5;
    --sp-success-500: #10B981;
    --sp-success-700: #047857;

    --sp-warning-50:  #FFFBEB;
    --sp-warning-500: #F59E0B;
    --sp-warning-700: #B45309;

    --sp-danger-50:   #FEF2F2;
    --sp-danger-500:  #DC2626;
    --sp-danger-700:  #991B1B;

    --sp-info-50:     #EFF6FF;
    --sp-info-500:    #2563EB;
    --sp-info-700:    #1D4ED8;

    /* ------- Surfaces ------- */
    --sp-surface:        var(--sp-gray-0);
    --sp-surface-muted:  var(--sp-gray-50);
    --sp-border:         var(--sp-gray-200);
    --sp-border-strong:  var(--sp-gray-300);
    --sp-text:           var(--sp-gray-900);
    --sp-text-muted:     var(--sp-gray-500);
    --sp-text-on-brand:  var(--sp-gray-0);

    /* ------- Sidebar (un seul gris foncé, pas de gradient) ------- */
    --sp-sidebar-bg:     #111827;
    --sp-sidebar-border: #1F2937;
    --sp-sidebar-text:   #CBD5E1;
    --sp-sidebar-active-bg: rgba(0, 107, 63, 0.14);  /* vert mk-primary à 14% */
    --sp-sidebar-active-bar: var(--sp-primary-500);

    /* ------- Typography ------- */
    --sp-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --sp-font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;

    --sp-fs-xs:   0.75rem;    /* 12 */
    --sp-fs-sm:   0.875rem;   /* 14 */
    --sp-fs-base: 1rem;       /* 16 */
    --sp-fs-lg:   1.125rem;   /* 18 */
    --sp-fs-xl:   1.375rem;   /* 22 */
    --sp-fs-2xl:  1.75rem;    /* 28 */
    --sp-fs-3xl:  2.25rem;    /* 36 */

    --sp-lh-tight:  1.2;
    --sp-lh-body:   1.5;

    /* ------- Spacing (4px base) ------- */
    --sp-s-1: 4px;  --sp-s-2: 8px;  --sp-s-3: 12px; --sp-s-4: 16px;
    --sp-s-5: 20px; --sp-s-6: 24px; --sp-s-8: 32px; --sp-s-10: 40px;
    --sp-s-12: 48px; --sp-s-16: 64px;

    /* ------- Radius ------- */
    --sp-r-sm: 4px;  --sp-r-md: 6px;  --sp-r-lg: 10px;
    --sp-r-xl: 14px; --sp-r-2xl: 20px; --sp-r-pill: 9999px;

    /* ------- Shadow elevation (4 niveaux nets, pas de halo violet) ------- */
    --sp-shadow-1: 0 1px 2px rgba(15, 23, 42, .04);
    --sp-shadow-2: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);
    --sp-shadow-3: 0 4px 12px rgba(15, 23, 42, .08);
    --sp-shadow-modal: 0 20px 50px rgba(15, 23, 42, .25);
}

/* =============================================================================
   Reset / base
   ============================================================================= */

html {
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--sp-font-sans);
    font-size: var(--sp-fs-base);
    line-height: var(--sp-lh-body);
    color: var(--sp-text);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Tabular numerals partout où l'on affiche de l'argent ou des compteurs. */
.sp-num,
.sp-money,
.sp-table td,
.sp-metric-value {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

/* Focus visible discret mais clair — accessibilité minimum. */
:where(a, button, [role="button"], input, select, textarea):focus-visible {
    outline: 2px solid var(--sp-primary-500);
    outline-offset: 2px;
    border-radius: var(--sp-r-sm);
}

/* Scrollbars neutres (pas de gradient bleu→indigo). */
.sp-scrollbar::-webkit-scrollbar { width: 8px; height: 8px; }
.sp-scrollbar::-webkit-scrollbar-track { background: transparent; }
.sp-scrollbar::-webkit-scrollbar-thumb { background: var(--sp-gray-300); border-radius: 4px; }
.sp-scrollbar::-webkit-scrollbar-thumb:hover { background: var(--sp-gray-400); }

/* =============================================================================
   Composants utilitaires (préfixés sp-, optin)
   ============================================================================= */

/* Page header : titre + sous-titre + actions à droite. */
.sp-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-s-4);
    margin-bottom: var(--sp-s-6);
}
.sp-page-header__title {
    font-size: var(--sp-fs-2xl);
    font-weight: 600;
    line-height: var(--sp-lh-tight);
    letter-spacing: -0.01em;
    color: var(--sp-text);
    margin: 0;
}
.sp-page-header__subtitle {
    font-size: var(--sp-fs-sm);
    color: var(--sp-text-muted);
    margin: var(--sp-s-1) 0 0;
}
.sp-page-header__actions { display: flex; gap: var(--sp-s-2); flex-shrink: 0; }

/* Card : surface neutre, ombre discrète, hover doux (pas de translateY). */
.sp-card {
    background: var(--sp-surface);
    border: 1px solid var(--sp-border);
    border-radius: var(--sp-r-xl);
    box-shadow: var(--sp-shadow-2);
}
.sp-card--interactive {
    transition: box-shadow .15s ease, border-color .15s ease;
}
.sp-card--interactive:hover {
    box-shadow: var(--sp-shadow-3);
    border-color: var(--sp-border-strong);
}
.sp-card__header {
    padding: var(--sp-s-5) var(--sp-s-6);
    border-bottom: 1px solid var(--sp-border);
}
.sp-card__body { padding: var(--sp-s-6); }
.sp-card__footer {
    padding: var(--sp-s-4) var(--sp-s-6);
    border-top: 1px solid var(--sp-border);
    background: var(--sp-surface-muted);
    border-bottom-left-radius: var(--sp-r-xl);
    border-bottom-right-radius: var(--sp-r-xl);
}

/* Metric card : KPI sobre, pas de gradient violet. */
.sp-metric {
    background: var(--sp-surface);
    border: 1px solid var(--sp-border);
    border-radius: var(--sp-r-lg);
    padding: var(--sp-s-5);
}
.sp-metric__label {
    font-size: var(--sp-fs-xs);
    color: var(--sp-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0;
}
.sp-metric__value {
    font-size: var(--sp-fs-2xl);
    font-weight: 600;
    color: var(--sp-text);
    margin: var(--sp-s-2) 0 0;
    line-height: var(--sp-lh-tight);
}
.sp-metric__delta {
    font-size: var(--sp-fs-xs);
    margin-top: var(--sp-s-1);
}
.sp-metric__delta--up   { color: var(--sp-success-700); }
.sp-metric__delta--down { color: var(--sp-danger-700); }

/* Form fields : input / select / textarea — un seul style cohérent. */
.sp-input,
input.sp-input,
select.sp-input,
textarea.sp-input {
    display: block;
    width: 100%;
    padding: var(--sp-s-3) var(--sp-s-4);
    font-size: var(--sp-fs-sm);
    font-family: inherit;
    line-height: var(--sp-lh-normal, 1.5);
    color: var(--sp-text);
    background-color: var(--sp-surface);
    background-image: none;
    border: 1px solid var(--sp-border-strong);
    border-radius: var(--sp-r-lg);
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.04);
    transition: border-color .15s ease, box-shadow .15s ease;
    appearance: none;
    -webkit-appearance: none;
}
.sp-input::placeholder { color: var(--sp-gray-400); }
.sp-input:hover { border-color: var(--sp-gray-400); }
.sp-input:focus,
.sp-input:focus-visible {
    outline: none;
    border-color: var(--sp-primary-500);
    box-shadow: 0 0 0 3px rgba(0, 107, 63, 0.12);
}
.sp-input:disabled,
.sp-input[readonly] {
    background-color: var(--sp-surface-muted);
    color: var(--sp-text-muted);
    cursor: not-allowed;
}
.sp-input.is-invalid,
.sp-input[aria-invalid="true"] {
    border-color: var(--sp-danger-500);
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}
/* OTP input : code 6 chiffres centré, mono, espacé. Utilisé par 2FA setup + challenge.
   Avant : style inline `font-size: var(--sp-fs-2xl); font-family: var(--sp-font-mono);
   letter-spacing: 0.4em; text-align: center;` dupliqué dans plusieurs templates. */
.sp-input--otp {
    font-size: var(--sp-fs-2xl);
    font-family: var(--sp-font-mono);
    letter-spacing: 0.4em;
    text-align: center;
}
/* Select natif — chevron via background-image car appearance: none retire le défaut OS. */
select.sp-input {
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'%3E%3Cpath fill-rule='evenodd' d='M5.23 7.21a.75.75 0 011.06.02L10 11.06l3.71-3.83a.75.75 0 111.08 1.04l-4.25 4.39a.75.75 0 01-1.08 0L5.21 8.27a.75.75 0 01.02-1.06z' clip-rule='evenodd'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--sp-s-3) center;
    background-size: 18px 18px;
    padding-right: var(--sp-s-10);
}
textarea.sp-input { min-height: 80px; line-height: 1.5; resize: vertical; }
/* Checkbox / radio natifs : juste assurer la couleur de l'accent. */
input[type="checkbox"], input[type="radio"] {
    accent-color: var(--sp-primary-500);
}

/* ──────────────────────────────────────────────────────────────────────
   Utilities accent (compat Tailwind-like sans buildtime).
   Le projet n'a pas de tailwind.config.js qui génère une palette `accent`,
   mais certains templates Ops (kyc_queue, kyc_show, kyc_history,
   payouts_queue) utilisent les class names Tailwind `bg-accent-*`,
   `text-accent-*`, `border-accent-*`. Sans ces utilities, ces classes ne
   produisent rien et les boutons orangés deviennent invisibles
   (cf. bug bouton "Review" sur /ops/marketplace/kyc).

   On expose 500/600/700 même si --sp-accent-600 n'existe pas (on retombe
   sur 700 pour les hover/focus states). Volontaire : la palette projet
   est plus parcimonieuse que celle de Tailwind par défaut.
   ────────────────────────────────────────────────────────────────────── */
.bg-accent-500 { background-color: var(--sp-accent-500); }
.bg-accent-600 { background-color: var(--sp-accent-500); }
.bg-accent-700 { background-color: var(--sp-accent-700); }
.hover\:bg-accent-500:hover { background-color: var(--sp-accent-500); }
.hover\:bg-accent-600:hover { background-color: var(--sp-accent-500); }
.hover\:bg-accent-700:hover { background-color: var(--sp-accent-700); }
.text-accent-500 { color: var(--sp-accent-500); }
.text-accent-700 { color: var(--sp-accent-700); }
.border-accent-500 { border-color: var(--sp-accent-500); }
.border-accent-600 { border-color: var(--sp-accent-500); }
.border-accent-700 { border-color: var(--sp-accent-700); }

/* Buttons : 3 variants, pas de gradient. */
.sp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-s-2);
    padding: var(--sp-s-3) var(--sp-s-4);
    font-size: var(--sp-fs-sm);
    font-weight: 500;
    line-height: 1;
    border-radius: var(--sp-r-lg);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background-color .15s ease, border-color .15s ease, color .15s ease;
    text-decoration: none;
    white-space: nowrap;
}
.sp-btn:disabled, .sp-btn[aria-disabled="true"] {
    opacity: 0.6;
    cursor: not-allowed;
}
.sp-btn--primary {
    background: var(--sp-primary-500);
    color: var(--sp-text-on-brand);
}
.sp-btn--primary:hover { background: var(--sp-primary-600); }
.sp-btn--primary:active { background: var(--sp-primary-700); }
.sp-btn--secondary {
    background: var(--sp-surface);
    color: var(--sp-text);
    border-color: var(--sp-border-strong);
}
.sp-btn--secondary:hover { background: var(--sp-gray-50); }
.sp-btn--ghost {
    background: transparent;
    color: var(--sp-text-muted);
}
.sp-btn--ghost:hover { background: var(--sp-gray-100); color: var(--sp-text); }
.sp-btn--danger {
    background: var(--sp-danger-500);
    color: var(--sp-text-on-brand);
}
.sp-btn--danger:hover { background: var(--sp-danger-700); }
.sp-btn--sm { padding: var(--sp-s-2) var(--sp-s-3); font-size: var(--sp-fs-xs); }
.sp-btn--lg { padding: var(--sp-s-4) var(--sp-s-6); font-size: var(--sp-fs-base); }

/* Badge / Status pill — couleur sémantique + marker visuel (pour daltonisme). */
.sp-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-s-2);
    padding: 2px var(--sp-s-2);
    font-size: var(--sp-fs-xs);
    font-weight: 500;
    border-radius: var(--sp-r-pill);
    line-height: 1.4;
}
.sp-badge::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
}
.sp-badge--success { background: var(--sp-success-50); color: var(--sp-success-700); }
.sp-badge--warning { background: var(--sp-warning-50); color: var(--sp-warning-700); }
.sp-badge--danger  { background: var(--sp-danger-50);  color: var(--sp-danger-700); }
.sp-badge--info    { background: var(--sp-info-50);    color: var(--sp-info-700); }
.sp-badge--neutral { background: var(--sp-gray-100);   color: var(--sp-gray-700); }

/* Table : zebra discrète, hover, sticky header. */
.sp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--sp-fs-sm);
}
.sp-table thead th {
    text-align: left;
    font-weight: 500;
    color: var(--sp-text-muted);
    background: var(--sp-surface-muted);
    padding: var(--sp-s-3) var(--sp-s-4);
    border-bottom: 1px solid var(--sp-border);
    position: sticky;
    top: 0;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: var(--sp-fs-xs);
}
.sp-table tbody td {
    padding: var(--sp-s-4);
    border-bottom: 1px solid var(--sp-border);
    color: var(--sp-text);
    vertical-align: middle;
}
.sp-table tbody tr:hover { background: var(--sp-gray-50); }
.sp-table .sp-table__num { text-align: right; font-variant-numeric: tabular-nums; }

/* Empty state. */
.sp-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--sp-s-12) var(--sp-s-6);
    color: var(--sp-text-muted);
}
.sp-empty__icon {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--sp-gray-100);
    color: var(--sp-text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-fs-xl);
    margin-bottom: var(--sp-s-4);
}
.sp-empty__title {
    color: var(--sp-text);
    font-size: var(--sp-fs-lg);
    font-weight: 600;
    margin: 0 0 var(--sp-s-2);
}
.sp-empty__hint { font-size: var(--sp-fs-sm); margin: 0 0 var(--sp-s-4); max-width: 36ch; }

/* Money display : tabular numerals + alignement à droite par défaut quand utilisé en tableau. */
.sp-money {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}
.sp-money__amount { font-weight: 600; color: var(--sp-text); }
.sp-money__currency { color: var(--sp-text-muted); font-size: 0.85em; margin-left: 4px; }
.sp-money--credit .sp-money__amount { color: var(--sp-success-700); }
.sp-money--debit  .sp-money__amount { color: var(--sp-danger-700); }

/* Alert / flash : 4 variants sémantiques sobres. */
.sp-alert {
    display: flex;
    gap: var(--sp-s-3);
    padding: var(--sp-s-4);
    border-radius: var(--sp-r-lg);
    border: 1px solid;
    margin-bottom: var(--sp-s-3);
    font-size: var(--sp-fs-sm);
}
.sp-alert__icon { flex-shrink: 0; font-size: var(--sp-fs-lg); }
.sp-alert__body { flex: 1; }
.sp-alert__title { font-weight: 600; margin: 0; }
.sp-alert__message { margin: var(--sp-s-1) 0 0; }
.sp-alert__close {
    background: transparent;
    border: 0;
    color: inherit;
    cursor: pointer;
    opacity: 0.6;
    padding: 0 var(--sp-s-1);
}
.sp-alert__close:hover { opacity: 1; }

.sp-alert--success { background: var(--sp-success-50); border-color: var(--sp-success-500); color: var(--sp-success-700); }
.sp-alert--warning { background: var(--sp-warning-50); border-color: var(--sp-warning-500); color: var(--sp-warning-700); }
.sp-alert--danger  { background: var(--sp-danger-50);  border-color: var(--sp-danger-500);  color: var(--sp-danger-700); }
.sp-alert--info    { background: var(--sp-info-50);    border-color: var(--sp-info-500);    color: var(--sp-info-700); }

/* =============================================================================
   Sidebar / dashboard layout (overrides ciblés des classes existantes)
   -----------------------------------------------------------------------------
   Le markup garde ses classes existantes (.sidebar, .nav-item, .card, etc.) —
   on les redéfinit ici de façon sobre pour aligner toute l'app sur les tokens.
   ============================================================================= */

.sidebar {
    /* Aplat sombre, plus de gradient bleu→noir. */
    background: var(--sp-sidebar-bg) !important;
    border-right: 1px solid var(--sp-sidebar-border);
}
.sidebar .nav-item {
    color: var(--sp-sidebar-text);
    transition: background-color .12s ease, color .12s ease;
    border-left: 3px solid transparent;
}
.sidebar .nav-item:hover {
    background: rgba(255, 255, 255, 0.04);
    color: var(--sp-text-on-brand);
}
.sidebar .nav-item.active {
    background: var(--sp-sidebar-active-bg);
    border-left-color: var(--sp-sidebar-active-bar);
    color: var(--sp-text-on-brand);
}
.sidebar .nav-item.active i { color: var(--sp-primary-500); }

/* Groupes pliables — cf. assets/controllers/sidebar_collapsible_controller.js.
   Le bouton ressemble au <p> d'origine (tracking, taille, couleur) mais avec
   un curseur pointeur et un chevron qui tourne en mode replié. */
.sidebar .group-header {
    background: transparent;
    border: 0;
    cursor: pointer;
    text-align: left;
}
.sidebar .group-header:hover { color: var(--sp-text-on-brand); }
.sidebar .group-header .chevron { transition: transform .15s ease; }
.sidebar .sidebar-group.collapsed .group-header .chevron { transform: rotate(-90deg); }
.sidebar .sidebar-group.collapsed .group-items { display: none; }

/* Card existant (markup utilisant .card) → bord net + ombre légère, pas de hover translateY. */
.card {
    background: var(--sp-surface) !important;
    border-radius: var(--sp-r-xl) !important;
    box-shadow: var(--sp-shadow-2) !important;
    border: 1px solid var(--sp-border) !important;
    transition: box-shadow .15s ease !important;
    transform: none !important;
}
.card:hover {
    box-shadow: var(--sp-shadow-3) !important;
    transform: none !important;
}

/* Metric-card existant → on enlève la barre gradient bleu/violet sur ::before. */
.metric-card {
    position: relative;
    overflow: hidden;
}
.metric-card::before {
    content: "" !important;
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 3px;
    background: var(--sp-primary-500) !important;  /* aplat, plus de gradient */
}

/* Status indicators existants → couleurs sémantiques de la rampe. */
.status-online   { background-color: var(--sp-success-500) !important; }
.status-warning  { background-color: var(--sp-warning-500) !important; }
.status-offline  { background-color: var(--sp-danger-500) !important; }
.status-active   { background-color: var(--sp-success-500) !important; }
.status-pending  { background-color: var(--sp-warning-500) !important; }
.status-inactive { background-color: var(--sp-gray-400) !important; }

/* Topbar custom-scrollbar uniformisée. */
.custom-scrollbar { /* alias hérité */ }
.custom-scrollbar::-webkit-scrollbar { width: 8px; height: 8px; }
.custom-scrollbar::-webkit-scrollbar-track { background: transparent; }
.custom-scrollbar::-webkit-scrollbar-thumb { background: var(--sp-gray-300); border-radius: 4px; }
.custom-scrollbar::-webkit-scrollbar-thumb:hover { background: var(--sp-gray-400); }

/* =============================================================================
   Primitives haut de gamme — pour la landing et autres pages marketing
   ============================================================================= */

/* Skip-to-content link (accessibilité — apparaît au focus clavier). */
.sp-skip {
    position: absolute;
    left: var(--sp-s-4);
    top: -200px;
    background: var(--sp-gray-900);
    color: white;
    padding: var(--sp-s-3) var(--sp-s-4);
    border-radius: var(--sp-r-md);
    font-size: var(--sp-fs-sm);
    font-weight: 500;
    text-decoration: none;
    transition: top .15s ease-out;
    z-index: 100;
}
.sp-skip:focus { top: var(--sp-s-4); }

/* Section number — petit badge "01", "02"… pour numéroter les sections.
   Pattern Stripe / Linear, donne du rythme à la lecture. */
.sp-section-num {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-s-2);
    font-size: var(--sp-fs-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sp-primary-600);
    margin-bottom: var(--sp-s-3);
}
.sp-section-num::before {
    content: attr(data-num);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 6px;
    background: var(--sp-primary-50);
    color: var(--sp-primary-700);
    font-size: 10px;
    font-weight: 700;
    border: 1px solid var(--sp-primary-100);
}

/* Lien avec underline animé (hover). */
.sp-link-underline {
    position: relative;
    color: var(--sp-primary-600);
    text-decoration: none;
    font-weight: 500;
}
.sp-link-underline::after {
    content: "";
    position: absolute;
    left: 0; bottom: -2px;
    height: 1px;
    width: 100%;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .2s ease-out;
}
.sp-link-underline:hover::after { transform: scaleX(1); }

/* Browser chrome — barre du haut style macOS Safari, avec dots couleur sobres et URL bar.
   Wrappe un mockup pour le faire ressembler à une vraie capture d'écran. */
.sp-browser {
    border-radius: var(--sp-r-xl);
    overflow: hidden;
    border: 1px solid var(--sp-border);
    background: var(--sp-surface);
    box-shadow: var(--sp-shadow-3);
}
.sp-browser__chrome {
    display: flex;
    align-items: center;
    gap: var(--sp-s-3);
    padding: var(--sp-s-3) var(--sp-s-4);
    background: var(--sp-gray-100);
    border-bottom: 1px solid var(--sp-border);
}
.sp-browser__dots {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.sp-browser__dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--sp-gray-300);
}
.sp-browser__dot:nth-child(1) { background: #FF5F57; }
.sp-browser__dot:nth-child(2) { background: #FEBC2E; }
.sp-browser__dot:nth-child(3) { background: #28C840; }
.sp-browser__url {
    flex: 1;
    background: var(--sp-surface);
    border: 1px solid var(--sp-border);
    border-radius: var(--sp-r-md);
    padding: 4px var(--sp-s-3);
    font-size: var(--sp-fs-xs);
    color: var(--sp-text-muted);
    text-align: center;
    font-family: var(--sp-font-mono);
}
.sp-browser__url i { color: var(--sp-success-700); margin-right: 6px; }

/* Marquee infinite scroll — défilement sobre des moyens de paiement.
   Mask gauche/droite via mask-image pour fade-in/out. */
@keyframes sp-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}
.sp-marquee {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
            mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.sp-marquee__track {
    display: flex;
    gap: var(--sp-s-12);
    width: max-content;
    animation: sp-marquee 30s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
    .sp-marquee__track { animation: none; }
}

/* Spot lumineux — radial-gradient discret dans un coin (pas un blob flottant). */
.sp-spot-tl::before {
    content: "";
    position: absolute;
    top: -200px; left: -200px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, var(--sp-primary-100), transparent 70%);
    opacity: 0.6;
    pointer-events: none;
    border-radius: 50%;
    z-index: 0;
}
.sp-spot-br::before {
    content: "";
    position: absolute;
    bottom: -200px; right: -200px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, var(--sp-primary-100), transparent 70%);
    opacity: 0.4;
    pointer-events: none;
    border-radius: 50%;
    z-index: 0;
}

/* Slider montant — input range custom. */
input[type="range"].sp-range {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    background: var(--sp-gray-200);
    border-radius: var(--sp-r-pill);
    outline: none;
}
input[type="range"].sp-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--sp-primary-500);
    border: 3px solid white;
    box-shadow: var(--sp-shadow-2);
    cursor: pointer;
    transition: transform .12s ease-out;
}
input[type="range"].sp-range::-webkit-slider-thumb:hover {
    transform: scale(1.15);
}
input[type="range"].sp-range::-moz-range-thumb {
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--sp-primary-500);
    border: 3px solid white;
    box-shadow: var(--sp-shadow-2);
    cursor: pointer;
}

/* Syntax highlighting CSS-only — tokens posés à la main dans le markup.
   Palette sobre, lisible, inspirée GitHub Dark / Linear. */
.tk-key   { color: #FF7AB2; }   /* keywords */
.tk-str   { color: #A5E075; }   /* strings */
.tk-num   { color: #79C0FF; }   /* numbers */
.tk-com   { color: #6E7781; font-style: italic; }   /* comments */
.tk-fn    { color: #D2A8FF; }   /* function names */
.tk-prop  { color: #79C0FF; }   /* property keys */
.tk-var   { color: #FFA657; }   /* env variables */
.tk-meta  { color: #C9D1D9; }   /* punctuation neutre */
.tk-url   { color: #79C0FF; text-decoration: underline; text-decoration-color: rgba(121,192,255,0.3); }

/* Bouton "copier" sur les blocs de code — feedback minimal. */
.sp-copy {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--sp-gray-400);
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 500;
    border-radius: var(--sp-r-sm);
    cursor: pointer;
    transition: background .12s ease-out;
}
.sp-copy:hover { background: rgba(255,255,255,0.1); color: white; }
.sp-copy.is-copied { color: var(--sp-success-500); }

/* Watermark de section — gros chiffre derrière un titre, opacité très faible. */
.sp-watermark {
    position: relative;
    isolation: isolate;
}
.sp-watermark::before {
    content: attr(data-watermark);
    position: absolute;
    top: -40px; right: -10px;
    font-size: 180px;
    font-weight: 800;
    color: var(--sp-gray-100);
    line-height: 1;
    z-index: -1;
    user-select: none;
    pointer-events: none;
}

/* =============================================================================
   FORMS — inputs/labels sobres pour les pages dashboard.
   Aligné sur la palette --sp-primary (vert). Compatible avec Symfony Forms :
   appliquer .sp-form-input en attribut sur form_widget(field).
   ============================================================================= */
.sp-form-label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sp-gray-800);
    margin-bottom: 0.4rem;
}
.sp-form-required {
    color: var(--sp-danger-500);
    font-weight: 600;
    margin-left: 0.15rem;
}
.sp-form-help {
    font-size: 0.75rem;
    color: var(--sp-gray-500);
    margin-top: 0.4rem;
    margin-bottom: 0;
}
.sp-form-input,
.sp-form-textarea,
.sp-form-select {
    width: 100%;
    border: 1px solid var(--sp-border);
    border-radius: 10px;
    padding: 0.625rem 0.875rem;
    font-size: 0.9375rem;
    background: var(--sp-surface);
    color: var(--sp-gray-900);
    transition: border-color 0.15s, box-shadow 0.15s;
    font-family: inherit;
}
.sp-form-input:focus,
.sp-form-textarea:focus,
.sp-form-select:focus {
    outline: none;
    border-color: var(--sp-primary-500);
    box-shadow: 0 0 0 3px var(--sp-primary-50);
}
.sp-form-textarea { min-height: 100px; resize: vertical; }
.sp-form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%2364748B' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.65rem center;
    background-size: 1.2em 1.2em;
    padding-right: 2.5rem;
}
.sp-form-error {
    display: block;
    font-size: 0.8125rem;
    color: var(--sp-danger-700);
    margin-top: 0.35rem;
}
/* Override Symfony Forms : ul.errors style. */
.sp-form-error ul,
ul.errors { margin: 0.35rem 0 0; padding: 0; list-style: none; }
.sp-form-error li,
ul.errors li {
    font-size: 0.8125rem;
    color: var(--sp-danger-700);
    padding: 0;
}
/* Bandeau d'erreurs globales du formulaire. */
.sp-form-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    border-radius: 10px;
    background: var(--sp-danger-50);
    border: 1px solid #FCA5A5;
    color: var(--sp-danger-700);
    font-size: 0.875rem;
}


/* Pull quote — citation sobre. */
.sp-pull {
    position: relative;
    font-size: var(--sp-fs-xl);
    font-weight: 500;
    color: var(--sp-gray-800);
    line-height: 1.4;
    padding-left: var(--sp-s-6);
    border-left: 3px solid var(--sp-primary-500);
}


/* =============================================================================
   MARKETING — palette dédiée + système bento (préfixe mk-).
   -----------------------------------------------------------------------------
   N'écrase pas le design system sp- (dashboard reste bleu).
   Inspiration : fintech africaine moderne — vert profond + ocre + crème.
   ============================================================================= */

:root {
    /* Vert profond — couleur principale "marque" Afrique de l'Ouest. */
    --mk-primary-50:  #E6F4EE;
    --mk-primary-100: #C2E4D2;
    --mk-primary-300: #5DB089;
    --mk-primary-500: #006B3F;
    --mk-primary-600: #005C36;
    --mk-primary-700: #004A2A;
    --mk-primary-900: #002618;

    /* Ocre — accent chaud, contraste avec le vert. */
    --mk-accent-50:   #FCF3E2;
    --mk-accent-100:  #F8E4B7;
    --mk-accent-300:  #F0BD68;
    --mk-accent-500:  #E89B30;
    --mk-accent-700:  #B07418;

    /* Surfaces chaudes — crème (clair) et sable (un cran plus chaud). */
    --mk-cream:   #FBF8F3;
    --mk-sand:    #F5EFE5;
    --mk-paper:   #FFFFFF;

    /* Encre profonde pour les fonds sombres + texte. */
    --mk-ink:        #1A1F2E;
    --mk-ink-muted:  #5C6373;
}

/* Body marketing — fond crème global (pages front uniquement). */
.mk-body { background: var(--mk-cream); color: var(--mk-ink); }


/* ----- Typo display marketing ----- */
.mk-display {
    font-family: var(--sp-font-sans);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.02;
    color: var(--mk-ink);
}
.mk-display-1 { font-size: clamp(2.75rem, 7vw, 5.25rem); }
.mk-display-2 { font-size: clamp(2.25rem, 5vw, 3.75rem); }

.mk-eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--mk-primary-700);
}

.mk-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    background: var(--mk-paper);
    border: 1px solid rgba(0,0,0,0.08);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--mk-ink);
}

.mk-num {
    font-family: var(--sp-font-mono);
    font-weight: 700;
    letter-spacing: -0.04em;
    color: var(--mk-ink);
    font-variant-numeric: tabular-nums;
}


/* ----- Boutons marketing ----- */
.mk-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.25rem;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.9375rem;
    transition: transform 0.1s, background 0.15s, box-shadow 0.15s;
    text-decoration: none;
    cursor: pointer;
    border: none;
}
.mk-btn:active { transform: translateY(1px); }
.mk-btn--primary {
    background: var(--mk-primary-500); color: var(--mk-paper);
    box-shadow: 0 1px 0 var(--mk-primary-700) inset, 0 6px 16px -8px rgba(0,107,63,0.5);
}
.mk-btn--primary:hover { background: var(--mk-primary-600); }
.mk-btn--accent {
    background: var(--mk-accent-500); color: var(--mk-ink);
    box-shadow: 0 6px 16px -8px rgba(232,155,48,0.6);
}
.mk-btn--accent:hover { background: var(--mk-accent-700); color: white; }
.mk-btn--ink {
    background: var(--mk-ink); color: var(--mk-paper);
}
.mk-btn--ink:hover { background: #2A3043; }

.mk-link {
    color: var(--mk-primary-600);
    font-weight: 600;
    text-decoration: underline;
    text-decoration-color: var(--mk-primary-300);
    text-underline-offset: 4px;
    transition: text-decoration-color 0.15s;
}
.mk-link:hover { text-decoration-color: var(--mk-primary-600); }


/* =============================================================================
   BENTO GRID — 6 colonnes × N rangées, cellules de tailles variées.
   ============================================================================= */
.mk-bento {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 110px;
    gap: 1rem;
}
@media (min-width: 768px) {
    .mk-bento { grid-template-columns: repeat(4, 1fr); gap: 1.25rem; grid-auto-rows: 130px; }
}
@media (min-width: 1024px) {
    .mk-bento { grid-template-columns: repeat(6, 1fr); gap: 1.5rem; grid-auto-rows: 140px; }
}

.mk-bento__cell {
    border-radius: 18px;
    padding: 1.5rem;
    overflow: hidden;
    position: relative;
    display: flex;
    grid-column: span 2;
    grid-row: span 2;
}

/* Tailles. Notation NxM : N colonnes × M rangées. */
.mk-bento--2x2 { grid-column: span 2; grid-row: span 2; }
.mk-bento--3x2 { grid-column: span 2; grid-row: span 2; }
.mk-bento--3x3 { grid-column: span 2; grid-row: span 3; }
.mk-bento--4x4 { grid-column: span 2; grid-row: span 4; }
.mk-bento--6x4 { grid-column: span 2; grid-row: span 3; }

@media (min-width: 768px) {
    .mk-bento--2x2 { grid-column: span 2; grid-row: span 2; }
    .mk-bento--3x2 { grid-column: span 2; grid-row: span 2; }
    .mk-bento--3x3 { grid-column: span 2; grid-row: span 3; }
    .mk-bento--4x4 { grid-column: span 4; grid-row: span 3; }
    .mk-bento--6x4 { grid-column: span 4; grid-row: span 3; }
}
@media (min-width: 1024px) {
    .mk-bento--2x2 { grid-column: span 2; grid-row: span 2; }
    .mk-bento--3x2 { grid-column: span 3; grid-row: span 2; }
    .mk-bento--3x3 { grid-column: span 3; grid-row: span 3; }
    .mk-bento--4x4 { grid-column: span 4; grid-row: span 4; }
    .mk-bento--6x4 { grid-column: span 6; grid-row: span 3; }
}

/* Variantes de couleur — chacune avec un fond + texte cohérent. */
.mk-bento--brand    { background: var(--mk-primary-500); color: var(--mk-paper); }
.mk-bento--brand .mk-eyebrow { color: rgba(255,255,255,0.85); }
.mk-bento--accent       { background: var(--mk-accent-500); color: var(--mk-ink); }
.mk-bento--accent-soft  { background: var(--mk-accent-100); color: var(--mk-ink); }
.mk-bento--cream    { background: var(--mk-paper); color: var(--mk-ink); border: 1px solid rgba(0,0,0,0.06); }
.mk-bento--paper    { background: var(--mk-paper); color: var(--mk-ink); border: 1px solid rgba(0,0,0,0.06); }
.mk-bento--sand     { background: var(--mk-sand); color: var(--mk-ink); }
.mk-bento--ink      { background: var(--mk-ink); color: var(--mk-paper); }
.mk-bento--ink .mk-eyebrow { color: rgba(255,255,255,0.7); }


/* =============================================================================
   MOTIFS DÉCORATIFS — losanges (rappel wax sans imiter), grille, points.
   ============================================================================= */
.mk-pattern-rhombus {
    background-image:
        repeating-linear-gradient( 45deg, rgba(0,107,63,0.05) 0 1px, transparent 1px 36px),
        repeating-linear-gradient(-45deg, rgba(232,155,48,0.05) 0 1px, transparent 1px 36px);
    background-size: 36px 36px;
}
.mk-pattern-dots {
    background-image: radial-gradient(rgba(0,0,0,0.06) 1px, transparent 1px);
    background-size: 18px 18px;
}


/* =============================================================================
   SHOWCASE — case study éditorial (image-G / texte-D, alternance).
   ============================================================================= */
.mk-showcase {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
}
@media (min-width: 1024px) {
    .mk-showcase { grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: 4.5rem; }
    .mk-showcase--reverse > .mk-showcase__visual { order: 2; }
}

.mk-showcase__visual {
    border-radius: 22px;
    padding: 2rem;
    min-height: 420px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: relative;
    overflow: hidden;
    background: var(--mk-cream);
    border: 1px solid rgba(0,0,0,0.06);
}
.mk-showcase__visual--school {
    background:
        radial-gradient(circle at 15% 20%, var(--mk-primary-100), transparent 55%),
        radial-gradient(circle at 90% 90%, var(--mk-accent-100), transparent 55%),
        var(--mk-cream);
}
.mk-showcase__visual--ecom {
    background:
        radial-gradient(circle at 20% 80%, #FFE4D6, transparent 55%),
        radial-gradient(circle at 85% 15%, var(--mk-accent-100), transparent 55%),
        var(--mk-cream);
}
.mk-showcase__visual--ngo {
    background:
        radial-gradient(circle at 50% 25%, #E8DEFF, transparent 60%),
        radial-gradient(circle at 80% 85%, var(--mk-primary-100), transparent 55%),
        var(--mk-cream);
}

.mk-mock {
    background: var(--mk-paper);
    border: 1px solid rgba(0,0,0,0.07);
    border-radius: 14px;
    padding: 1rem 1.125rem;
    box-shadow: 0 8px 28px -16px rgba(0,0,0,0.18);
}


/* =============================================================================
   ANIMATIONS marketing.
   ============================================================================= */
@keyframes mk-tick { 0%, 100% { opacity: 0.35; } 10%, 90% { opacity: 1; } }
.mk-tick { animation: mk-tick 4s ease-in-out infinite; }
.mk-tick--2 { animation-delay: 1.3s; }
.mk-tick--3 { animation-delay: 2.6s; }

@keyframes mk-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.mk-marquee {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
            mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.mk-marquee__track {
    display: flex; gap: 4rem; width: max-content;
    animation: mk-marquee 50s linear infinite;
}

@keyframes mk-glow { 0%, 100% { opacity: 0.4; transform: scale(1); } 50% { opacity: 0.85; transform: scale(1.15); } }
.mk-glow { animation: mk-glow 3s ease-in-out infinite; }


/* =============================================================================
   SYNTAX HIGHLIGHTING tokens — utilisé dans les blocs <pre> sombres.
   ============================================================================= */
.tk-com  { color: #6E7681; font-style: italic; }
.tk-key  { color: #C4B5FD; }
.tk-str  { color: #86EFAC; }
.tk-num  { color: #FCA5A5; }
.tk-prop { color: #93C5FD; }
.tk-var  { color: #FDBA74; }
.tk-url  { color: #67E8F9; text-decoration: underline; text-decoration-color: rgba(103,232,249,0.3); }


/* =============================================================================
   TABS CSS-only (curl / Node / PHP).
   ============================================================================= */
.mk-tabs__panel { display: none; }
#mk-tab-curl:checked ~ .mk-tabs__panels #mk-panel-curl,
#mk-tab-node:checked ~ .mk-tabs__panels #mk-panel-node,
#mk-tab-php:checked  ~ .mk-tabs__panels #mk-panel-php { display: block; }
#mk-tab-curl:checked ~ .mk-tabs__nav label[for="mk-tab-curl"],
#mk-tab-node:checked ~ .mk-tabs__nav label[for="mk-tab-node"],
#mk-tab-php:checked  ~ .mk-tabs__nav label[for="mk-tab-php"] {
    background: var(--mk-ink); color: var(--mk-paper);
}


/* =============================================================================
   NAVBAR — CSS-only (pas de dépendance à Tailwind peer-checked, bulletproof).
   Palette adaptative : sp-* par défaut (dashboard), mk-* sur .mk-body (marketing).
   ============================================================================= */

.mk-nav {
    position: sticky; top: 0; z-index: 40;
    background: #FFFFFF;
    border-bottom: 1px solid var(--sp-border);
}
.mk-body .mk-nav {
    background: var(--mk-paper);
    border-bottom-color: rgba(0,0,0,0.06);
}

.mk-nav__container {
    display: flex; align-items: center; justify-content: space-between;
    height: 4rem;
}

.mk-nav__brand {
    display: flex; align-items: center; gap: 0.5rem;
    font-weight: 600;
    text-decoration: none;
    color: var(--sp-gray-900);
}
.mk-body .mk-nav__brand { color: var(--mk-ink); }

/* ----- Liens desktop ----- */
.mk-nav__links {
    display: none;
    gap: 0.25rem;
    margin-left: 2rem;
    list-style: none;
    padding: 0;
}

.mk-nav__link {
    display: inline-block;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 6px;
    color: var(--sp-gray-600);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}
.mk-nav__link:hover { color: var(--sp-gray-900); background: var(--sp-gray-50); }
.mk-nav__link[aria-current="page"] {
    color: var(--sp-primary-700);
    background: var(--sp-primary-50);
}

.mk-body .mk-nav__link { color: var(--mk-ink-muted); }
.mk-body .mk-nav__link:hover { color: var(--mk-ink); background: var(--mk-cream); }
.mk-body .mk-nav__link[aria-current="page"] {
    color: var(--mk-primary-700);
    background: var(--mk-primary-50);
}

/* ----- CTA droite (desktop) ----- */
.mk-nav__cta {
    display: none;
    align-items: center;
    gap: 0.5rem;
}

.mk-nav__login {
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.5rem 0.75rem;
    color: var(--sp-gray-600);
    text-decoration: none;
    border-radius: 6px;
    transition: color 0.15s;
}
.mk-nav__login:hover { color: var(--sp-gray-900); }
.mk-body .mk-nav__login { color: var(--mk-ink-muted); }
.mk-body .mk-nav__login:hover { color: var(--mk-ink); }

.mk-nav__cta-btn {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    background: var(--sp-primary-500);
    color: white;
    transition: background 0.15s;
}
.mk-nav__cta-btn:hover { background: var(--sp-primary-600); }
.mk-body .mk-nav__cta-btn {
    background: var(--mk-primary-500);
    box-shadow: 0 1px 0 var(--mk-primary-700) inset;
}
.mk-body .mk-nav__cta-btn:hover { background: var(--mk-primary-600); }

/* ----- Burger (mobile) ----- */
.mk-nav__burger {
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    width: 2.5rem; height: 2.5rem;
    border-radius: 8px;
    color: var(--sp-gray-700);
    background: transparent;
    transition: background 0.15s, color 0.15s;
}
.mk-nav__burger:hover { background: var(--sp-gray-50); color: var(--sp-gray-900); }
.mk-body .mk-nav__burger { color: var(--mk-ink); }
.mk-body .mk-nav__burger:hover { background: var(--mk-cream); }

/* Checkbox de toggle — visuellement cachée mais ACCESSIBLE au clavier
   (display:none casserait le focus, on garde sr-only-like). */
.mk-nav__toggle {
    position: absolute;
    opacity: 0;
    width: 1px; height: 1px;
    pointer-events: none;
}

/* Panneau mobile — masqué par défaut, visible quand toggle:checked. */
.mk-nav__mobile {
    display: none;
    border-top: 1px solid var(--sp-border);
    background: white;
}
.mk-body .mk-nav__mobile {
    background: var(--mk-paper);
    border-top-color: rgba(0,0,0,0.06);
}
.mk-nav__toggle:checked ~ .mk-nav__mobile { display: block; }

.mk-nav__mobile ul {
    list-style: none;
    padding: 0.75rem 0.75rem 1rem;
    margin: 0;
}

.mk-nav__mobile-link {
    display: block;
    padding: 0.625rem 0.875rem;
    margin-bottom: 0.25rem;
    border-radius: 8px;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--sp-gray-700);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}
.mk-nav__mobile-link:hover { background: var(--sp-gray-50); color: var(--sp-gray-900); }
.mk-nav__mobile-link[aria-current="page"] {
    color: var(--sp-primary-700); background: var(--sp-primary-50);
}
.mk-body .mk-nav__mobile-link { color: var(--mk-ink); }
.mk-body .mk-nav__mobile-link:hover { background: var(--mk-cream); }
.mk-body .mk-nav__mobile-link[aria-current="page"] {
    color: var(--mk-primary-700); background: var(--mk-primary-50);
}

.mk-nav__mobile-cta-row {
    margin: 0.75rem 0 0;
    padding-top: 0.75rem;
    border-top: 1px solid var(--sp-border);
    display: flex; flex-direction: column; gap: 0.5rem;
}
.mk-body .mk-nav__mobile-cta-row { border-top-color: rgba(0,0,0,0.06); }

.mk-nav__mobile-cta-row .mk-nav__cta-btn {
    width: 100%;
    justify-content: center;
    padding: 0.7rem 1rem;
}

/* ----- Breakpoints ----- */
@media (min-width: 768px) {
    .mk-nav__links { display: flex; }
    .mk-nav__cta { display: flex; }
    .mk-nav__burger { display: none; }
    .mk-nav__mobile { display: none !important; }
}

/* =============================================================================
   NAVBAR — Mega menu Produits
   - Desktop : :hover + :focus-within ouvrent le panel (zéro JS, accessible
     clavier via tabindex naturel sur les <a>).
   - Mobile : <details> natif gère l'ouverture/fermeture (full-keyboard,
     screen-reader friendly).
   ============================================================================= */

.mk-nav__has-dropdown { position: relative; }

.mk-nav__link--has-arrow { display: inline-flex; align-items: center; }
.mk-nav__chevron { transition: transform 0.18s ease; }
.mk-nav__has-dropdown:hover .mk-nav__chevron,
.mk-nav__has-dropdown:focus-within .mk-nav__chevron {
    transform: rotate(180deg);
}

/* Le panel — caché par défaut, dévoilé au hover ou focus-within. */
.mk-nav__panel {
    position: absolute;
    top: calc(100% + 0.25rem);
    left: -1rem;
    width: min(720px, calc(100vw - 2rem));
    background: white;
    border: 1px solid var(--sp-border);
    border-radius: 14px;
    box-shadow: 0 16px 48px -12px rgba(15, 23, 42, 0.18),
                0 4px 12px -4px rgba(15, 23, 42, 0.08);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity 0.18s ease,
                transform 0.18s ease,
                visibility 0s linear 0.18s;
    z-index: 50;
    overflow: hidden;
}
.mk-body .mk-nav__panel {
    background: var(--mk-paper);
    border-color: rgba(0, 0, 0, 0.06);
}
.mk-nav__has-dropdown:hover .mk-nav__panel,
.mk-nav__has-dropdown:focus-within .mk-nav__panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition-delay: 0s;
}
@media (prefers-reduced-motion: reduce) {
    .mk-nav__panel { transition: opacity 0.01s, visibility 0s; transform: none; }
    .mk-nav__chevron { transition: none; }
}

.mk-nav__panel-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    padding: 1.25rem;
}
.mk-nav__panel-col {}
.mk-nav__panel-heading {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-gray-500);
    margin: 0 0 0.6rem 0.5rem;
}
.mk-body .mk-nav__panel-heading { color: var(--mk-ink-muted); }

.mk-nav__panel-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.mk-nav__panel-card {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.6rem 0.65rem;
    border-radius: 10px;
    text-decoration: none;
    color: var(--sp-gray-700);
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}
.mk-nav__panel-card:hover {
    background: var(--sp-primary-50);
    color: var(--sp-primary-800);
    transform: translateX(2px);
}
.mk-nav__panel-card:focus-visible {
    outline: 2px solid var(--sp-primary-500);
    outline-offset: 2px;
    background: var(--sp-primary-50);
}
.mk-body .mk-nav__panel-card { color: var(--mk-ink); }
.mk-body .mk-nav__panel-card:hover {
    background: var(--mk-primary-50);
    color: var(--mk-primary-800);
}
.mk-body .mk-nav__panel-card:focus-visible {
    outline-color: var(--mk-primary-500);
    background: var(--mk-primary-50);
}

.mk-nav__panel-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: var(--sp-gray-100);
    color: var(--sp-primary-700);
    font-size: 1rem;
    transition: background 0.15s ease, color 0.15s ease;
}
.mk-nav__panel-card:hover .mk-nav__panel-icon {
    background: white;
    color: var(--sp-primary-600);
}
.mk-body .mk-nav__panel-icon {
    background: var(--mk-cream);
    color: var(--mk-primary-700);
}
.mk-body .mk-nav__panel-card:hover .mk-nav__panel-icon {
    background: white;
    color: var(--mk-primary-600);
}

.mk-nav__panel-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.mk-nav__panel-title {
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.3;
    color: inherit;
}
.mk-nav__panel-desc {
    font-size: 0.75rem;
    line-height: 1.35;
    color: var(--sp-gray-500);
    margin-top: 0.1rem;
}
.mk-body .mk-nav__panel-desc { color: var(--mk-ink-muted); }
.mk-nav__panel-card:hover .mk-nav__panel-desc { color: inherit; opacity: 0.85; }

.mk-nav__panel-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1rem;
    padding: 0.75rem 1.25rem;
    background: var(--sp-gray-50);
    border-top: 1px solid var(--sp-border);
}
.mk-body .mk-nav__panel-footer {
    background: var(--mk-cream);
    border-top-color: rgba(0, 0, 0, 0.06);
}
.mk-nav__panel-footer-link {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--sp-gray-700);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.55rem;
    border-radius: 6px;
    transition: background 0.15s ease, color 0.15s ease;
}
.mk-nav__panel-footer-link:hover {
    background: white;
    color: var(--sp-primary-700);
}
.mk-nav__panel-footer-link:focus-visible {
    outline: 2px solid var(--sp-primary-500);
    outline-offset: 2px;
}
.mk-body .mk-nav__panel-footer-link { color: var(--mk-ink); }
.mk-body .mk-nav__panel-footer-link:hover {
    background: white;
    color: var(--mk-primary-700);
}

/* Mobile : <details> accordion */
.mk-nav__mobile-details summary {
    list-style: none;
    cursor: pointer;
}
.mk-nav__mobile-details summary::-webkit-details-marker { display: none; }
.mk-nav__mobile-link--summary {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
}
.mk-nav__mobile-details[open] .mk-nav__chevron { transform: rotate(180deg); }

.mk-nav__mobile-sublist {
    padding: 0.25rem 0 0.5rem;
}
.mk-nav__mobile-subheading {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-gray-500);
    padding: 0.6rem 0.875rem 0.3rem;
    margin: 0;
}
.mk-body .mk-nav__mobile-subheading { color: var(--mk-ink-muted); }

.mk-nav__mobile-subitem {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    padding: 0.55rem 0.875rem;
    margin-bottom: 0.1rem;
    border-radius: 8px;
    text-decoration: none;
    color: var(--sp-gray-700);
    transition: background 0.15s ease, color 0.15s ease;
}
.mk-nav__mobile-subitem > i {
    width: 24px;
    flex-shrink: 0;
    color: var(--sp-primary-600);
    margin-top: 0.15rem;
}
.mk-nav__mobile-subitem:hover {
    background: var(--sp-gray-50);
    color: var(--sp-gray-900);
}
.mk-body .mk-nav__mobile-subitem { color: var(--mk-ink); }
.mk-body .mk-nav__mobile-subitem > i { color: var(--mk-primary-600); }
.mk-body .mk-nav__mobile-subitem:hover { background: var(--mk-cream); }
.mk-nav__mobile-subitem .mk-nav__panel-title { display: block; }
.mk-nav__mobile-subitem .mk-nav__panel-desc { display: block; }

/* =============================================================================
   PRODUCT PAGES — layout partagé /produits/{slug}
   ============================================================================= */

.mk-section-title {
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mk-ink-muted);
    margin: 0 0 1.25rem 0;
}

/* ---- Hero icône ---- */
.mk-product-hero-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 16px;
    background: var(--mk-primary-50);
    color: var(--mk-primary-600);
    font-size: 1.5rem;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset,
                0 4px 12px -4px rgba(22, 163, 74, 0.25);
}

/* ---- Features grid ---- */
.mk-product-features {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 720px) {
    .mk-product-features { grid-template-columns: 1fr 1fr; gap: 1.25rem; }
}

.mk-product-feature {
    background: var(--mk-paper);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 14px;
    padding: 1.4rem 1.5rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.mk-product-feature:hover {
    transform: translateY(-2px);
    border-color: var(--mk-primary-300);
    box-shadow: 0 12px 24px -16px rgba(15, 23, 42, 0.12);
}
@media (prefers-reduced-motion: reduce) {
    .mk-product-feature, .mk-product-feature:hover { transform: none; transition: none; }
}

.mk-product-feature-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--mk-cream);
    color: var(--mk-primary-700);
    font-size: 1.05rem;
    margin-bottom: 0.85rem;
}

.mk-product-feature-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--mk-ink);
    margin: 0 0 0.35rem 0;
    line-height: 1.3;
}

.mk-product-feature-body {
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--mk-ink-muted);
    margin: 0;
}

/* ---- Code sample ---- */
.mk-product-code {
    background: #0f172a;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 12px 32px -12px rgba(15, 23, 42, 0.4);
}

.mk-product-code-header {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.7rem 1rem;
    background: rgba(255, 255, 255, 0.04);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.mk-product-code-dots {
    display: inline-flex; gap: 0.35rem;
}
.mk-product-code-dots span {
    width: 11px; height: 11px; border-radius: 50%;
    display: inline-block;
    background: rgba(255, 255, 255, 0.18);
}
.mk-product-code-dots span:nth-child(1) { background: #ff5f57; }
.mk-product-code-dots span:nth-child(2) { background: #febc2e; }
.mk-product-code-dots span:nth-child(3) { background: #28c840; }

.mk-product-code-label {
    flex: 1;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.65);
    font-weight: 500;
}

.mk-product-code-lang {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: rgba(22, 163, 74, 0.18);
    color: #86efac;
}

.mk-product-code-body {
    margin: 0;
    padding: 1.25rem 1.5rem;
    font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
    font-size: 0.85rem;
    line-height: 1.6;
    color: #e2e8f0;
    overflow-x: auto;
    white-space: pre;
    -webkit-font-smoothing: antialiased;
}
.mk-product-code-body code { color: inherit; background: none; padding: 0; }

/* ---- Metrics ---- */
.mk-product-metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}
@media (min-width: 720px) {
    .mk-product-metrics { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
}

.mk-product-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0.5rem;
}

.mk-product-metric-value {
    font-size: clamp(1.75rem, 5vw, 2.5rem);
    font-weight: 800;
    color: var(--mk-primary-700);
    line-height: 1.1;
    letter-spacing: -0.02em;
    font-variant-numeric: tabular-nums;
}

.mk-product-metric-label {
    font-size: 0.85rem;
    color: var(--mk-ink-muted);
    margin-top: 0.4rem;
    line-height: 1.4;
}

/* ---- Cross-link ---- */
.mk-product-crosslinks {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
}
@media (min-width: 720px) {
    .mk-product-crosslinks { grid-template-columns: repeat(3, 1fr); }
}

.mk-product-crosslink {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    background: var(--mk-paper);
    border: 1px solid rgba(0, 0, 0, 0.07);
    border-radius: 12px;
    text-decoration: none;
    color: var(--mk-ink);
    transition: border-color 0.2s ease, transform 0.2s ease,
                box-shadow 0.2s ease, background 0.2s ease;
}
.mk-product-crosslink:hover {
    border-color: var(--mk-primary-400);
    transform: translateY(-1px);
    box-shadow: 0 10px 24px -16px rgba(15, 23, 42, 0.15);
    background: var(--mk-primary-50);
}
.mk-product-crosslink:focus-visible {
    outline: 2px solid var(--mk-primary-500);
    outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
    .mk-product-crosslink, .mk-product-crosslink:hover { transform: none; transition: none; }
}

.mk-product-crosslink-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: var(--mk-cream);
    color: var(--mk-primary-700);
}
.mk-product-crosslink:hover .mk-product-crosslink-icon {
    background: white;
}

.mk-product-crosslink-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.mk-product-crosslink-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: inherit;
    line-height: 1.3;
}

.mk-product-crosslink-tag {
    font-size: 0.75rem;
    color: var(--mk-ink-muted);
    margin-top: 0.1rem;
    line-height: 1.35;
}

.mk-product-crosslink-arrow {
    flex-shrink: 0;
    color: var(--mk-ink-muted);
    transition: transform 0.2s ease, color 0.2s ease;
}
.mk-product-crosslink:hover .mk-product-crosslink-arrow {
    color: var(--mk-primary-600);
    transform: translateX(2px);
}


/* =============================================================================
   TOKENS ÉTENDUS — refresh fintech pro 2026-05-19
   -----------------------------------------------------------------------------
   Ajouts NON-BREAKING : rampes complétées (100/200/600/800/900 sur semantic,
   primary 200/400/800, accent 600/800/900), motion, z-index, weights, line-
   heights, fs display, shadows focus/popover/inset, palette chart.
   ============================================================================= */

:root {

    /* ------- PRIMARY : compléments rampe (200/400/800).
       Le green --sp-primary-500 #006B3F reste l'ancre. ------- */
    --sp-primary-200: #A3D2BA;
    --sp-primary-400: #2E8A60;
    --sp-primary-800: #003820;

    /* ------- ACCENT : compléments rampe (200/600/800/900).
       Le ocre --sp-accent-500 #E89B30 reste l'ancre. ------- */
    --sp-accent-200: #FAD49E;
    --sp-accent-600: #CC8526;
    --sp-accent-800: #8C5910;
    --sp-accent-900: #5F3C0A;

    /* ------- SUCCESS : rampe complète (100/200/300/600/800/900).
       Pour data-viz, sparklines, états santé graduels. ------- */
    --sp-success-100: #D1FAE5;
    --sp-success-200: #A7F3D0;
    --sp-success-300: #6EE7B7;
    --sp-success-600: #059669;
    --sp-success-800: #065F46;
    --sp-success-900: #064E3B;

    /* ------- WARNING : rampe complète. ------- */
    --sp-warning-100: #FEF3C7;
    --sp-warning-200: #FDE68A;
    --sp-warning-300: #FCD34D;
    --sp-warning-600: #D97706;
    --sp-warning-800: #92400E;
    --sp-warning-900: #78350F;

    /* ------- DANGER : rampe complète. ------- */
    --sp-danger-100: #FEE2E2;
    --sp-danger-200: #FECACA;
    --sp-danger-300: #FCA5A5;
    --sp-danger-600: #B91C1C;
    --sp-danger-800: #7F1D1D;
    --sp-danger-900: #6B1212;

    /* ------- INFO : rampe complète. ------- */
    --sp-info-100: #DBEAFE;
    --sp-info-200: #BFDBFE;
    --sp-info-300: #93C5FD;
    --sp-info-600: #1E40AF;
    --sp-info-800: #1E3A8A;
    --sp-info-900: #172554;

    /* ------- SURFACES : compléments. ------- */
    --sp-surface-elevated: var(--sp-gray-0);
    --sp-border-subtle: var(--sp-gray-100);
    --sp-overlay: rgba(15, 23, 42, .55);

    /* ------- TYPO : poids + line-heights + display. ------- */
    --sp-fw-regular:  400;
    --sp-fw-medium:   500;
    --sp-fw-semibold: 600;
    --sp-fw-bold:     700;
    --sp-lh-snug:  1.35;
    --sp-lh-loose: 1.7;
    --sp-fs-display: clamp(2rem, 1.5vw + 1.5rem, 2.75rem);  /* KPIs proéminents */

    /* ------- MOTION : durations + easings standards.
       Aligné Material 3 / Tailwind 4 motion specs, sobre. ------- */
    --sp-dur-instant: 50ms;
    --sp-dur-fast:    120ms;
    --sp-dur-normal:  180ms;
    --sp-dur-slow:    280ms;
    --sp-ease-standard: cubic-bezier(0.2, 0, 0, 1);
    --sp-ease-emphasis: cubic-bezier(0.3, 0, 0.1, 1);
    --sp-ease-decel:    cubic-bezier(0, 0, 0.2, 1);
    --sp-ease-accel:    cubic-bezier(0.4, 0, 1, 1);

    /* ------- Z-INDEX : échelle explicite, plus de valeurs magiques. ------- */
    --sp-z-base:     0;
    --sp-z-sticky:   20;
    --sp-z-sidebar:  40;
    --sp-z-dropdown: 50;
    --sp-z-popover:  60;
    --sp-z-modal:    80;
    --sp-z-toast:    100;
    --sp-z-tooltip:  120;

    /* ------- SHADOWS : compléments. ------- */
    --sp-shadow-focus:   0 0 0 3px rgba(0, 107, 63, 0.16);
    --sp-shadow-focus-danger: 0 0 0 3px rgba(220, 38, 38, 0.16);
    --sp-shadow-popover: 0 12px 32px -8px rgba(15, 23, 42, .12), 0 2px 6px -2px rgba(15, 23, 42, .08);
    --sp-shadow-inset:   inset 0 1px 2px rgba(15, 23, 42, .06);

    /* ------- CHART PALETTE : alignée sur les tokens sémantiques.
       Utilisable depuis Chart.js : `getComputedStyle(document.documentElement).getPropertyValue('--sp-chart-1')`.
       Plus de hex Tailwind hardcodés dans `merchant/analytics/index.html.twig`. ------- */
    --sp-chart-1: var(--sp-primary-500);
    --sp-chart-2: var(--sp-accent-500);
    --sp-chart-3: var(--sp-info-500);
    --sp-chart-4: var(--sp-danger-500);
    --sp-chart-5: var(--sp-warning-500);
    --sp-chart-6: var(--sp-success-500);
    --sp-chart-7: var(--sp-primary-300);
    --sp-chart-8: var(--sp-accent-300);
}

/* Préférences utilisateur — réduit les animations si demandé.
   Toute transition `var(--sp-dur-*)` devient instantanée, sans avoir à
   re-coder chaque composant. */
@media (prefers-reduced-motion: reduce) {
    :root {
        --sp-dur-instant: 0ms;
        --sp-dur-fast:    0ms;
        --sp-dur-normal:  0ms;
        --sp-dur-slow:    0ms;
    }
}

/* =============================================================================
   UTILITIES POUR TOKENS — opt-in, préfixe sp-.
   Évite de recourir à `style="background: var(--sp-…)"` inline (241 occurrences
   recensées dans l'audit). Utiliser .sp-bg-primary-50, .sp-text-success-700, etc.
   ============================================================================= */

/* Backgrounds par token semantic. */
.sp-bg-primary-50  { background-color: var(--sp-primary-50); }
.sp-bg-primary-100 { background-color: var(--sp-primary-100); }
.sp-bg-primary-500 { background-color: var(--sp-primary-500); }
.sp-bg-success-50  { background-color: var(--sp-success-50); }
.sp-bg-success-100 { background-color: var(--sp-success-100); }
.sp-bg-warning-50  { background-color: var(--sp-warning-50); }
.sp-bg-warning-100 { background-color: var(--sp-warning-100); }
.sp-bg-danger-50   { background-color: var(--sp-danger-50); }
.sp-bg-danger-100  { background-color: var(--sp-danger-100); }
.sp-bg-info-50     { background-color: var(--sp-info-50); }
.sp-bg-info-100    { background-color: var(--sp-info-100); }
.sp-bg-gray-50     { background-color: var(--sp-gray-50); }
.sp-bg-gray-100    { background-color: var(--sp-gray-100); }
.sp-bg-surface     { background-color: var(--sp-surface); }
.sp-bg-surface-muted { background-color: var(--sp-surface-muted); }

/* Text colors par token. */
.sp-text-primary-600  { color: var(--sp-primary-600); }
.sp-text-primary-700  { color: var(--sp-primary-700); }
.sp-text-success-700  { color: var(--sp-success-700); }
.sp-text-warning-700  { color: var(--sp-warning-700); }
.sp-text-danger-700   { color: var(--sp-danger-700); }
.sp-text-info-700     { color: var(--sp-info-700); }
.sp-text-muted        { color: var(--sp-text-muted); }
.sp-text             { color: var(--sp-text); }

/* Borders par token. */
.sp-border        { border: 1px solid var(--sp-border); }
.sp-border-subtle { border: 1px solid var(--sp-border-subtle); }
.sp-border-strong { border: 1px solid var(--sp-border-strong); }

/* Tabular nums — pour tout chiffre financier. */
.sp-tnum {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

/* Typo display — pour les KPI géants (header dashboard). */
.sp-fs-display {
    font-size: var(--sp-fs-display);
    line-height: var(--sp-lh-tight);
    letter-spacing: -0.02em;
    font-weight: var(--sp-fw-bold);
}

/* =============================================================================
   TWIGCOMPONENT UI — variants additionnels pour les composants typés
   src/UI/Twig/Component/ (Button, Card, Badge, Stat, EmptyState, KeyValueList,
   Section). Ces classes ne touchent PAS les versions legacy.
   ============================================================================= */

/* Button — block (pleine largeur). */
.sp-btn--block { width: 100%; justify-content: center; }

/* Card — variants additionnels. */
.sp-card--elevated { box-shadow: var(--sp-shadow-3); }
.sp-card--bordered { box-shadow: none; border: 1px solid var(--sp-border-strong); }
.sp-card--flat     { box-shadow: none; background: transparent; border-color: transparent; }

/* Badge — taille small + no-dot. */
.sp-badge--sm     { font-size: 11px; padding: 1px var(--sp-s-2); }
.sp-badge--sm::before { width: 5px; height: 5px; }
.sp-badge--no-dot::before { display: none; }

/* Stat — variante avec icône à gauche dans un cercle. */
.sp-metric--with-icon {
    display: flex;
    gap: var(--sp-s-4);
    align-items: flex-start;
}
.sp-metric__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: var(--sp-r-lg);
    background: var(--sp-primary-50);
    color: var(--sp-primary-700);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-fs-lg);
}
.sp-metric__content { flex: 1; min-width: 0; }
.sp-metric__currency {
    font-size: var(--sp-fs-sm);
    font-weight: var(--sp-fw-regular);
    color: var(--sp-text-muted);
    margin-left: var(--sp-s-1);
}

/* Stat delta — avec flèche icône + gap. */
.sp-metric__delta {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-s-1);
}

/* EmptyState — compact (densité dans cards). */
.sp-empty--compact {
    padding: var(--sp-s-6) var(--sp-s-4);
}
.sp-empty--compact .sp-empty__icon {
    width: 36px;
    height: 36px;
    font-size: var(--sp-fs-base);
    margin-bottom: var(--sp-s-2);
}

/* KeyValueList — fiches entité.
   Layout par défaut "inline" : label gauche, valeur droite alignée.
   Layout "rows" : label dessus, valeur dessous (pour mobile ou form-like). */
.sp-kvl { margin: 0; padding: 0; }
.sp-kvl--inline .sp-kvl__item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--sp-s-4);
    padding: var(--sp-s-3) 0;
}
.sp-kvl--rows .sp-kvl__item {
    padding: var(--sp-s-3) 0;
}
.sp-kvl--bordered .sp-kvl__item {
    border-bottom: 1px solid var(--sp-border-subtle);
}
.sp-kvl--bordered .sp-kvl__item:last-child {
    border-bottom: 0;
}
.sp-kvl--compact .sp-kvl__item {
    padding: var(--sp-s-2) 0;
}
.sp-kvl__label {
    font-size: var(--sp-fs-sm);
    color: var(--sp-text-muted);
    margin: 0;
    font-weight: var(--sp-fw-regular);
}
.sp-kvl__hint {
    display: block;
    font-size: var(--sp-fs-xs);
    color: var(--sp-gray-400);
    margin-top: 2px;
}
.sp-kvl__value {
    font-size: var(--sp-fs-sm);
    font-weight: var(--sp-fw-medium);
    color: var(--sp-text);
    margin: 0;
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.sp-kvl--rows .sp-kvl__value {
    text-align: left;
    margin-top: var(--sp-s-1);
}
.sp-kvl__value--mono {
    font-family: var(--sp-font-mono);
    font-size: var(--sp-fs-xs);
    background: var(--sp-gray-50);
    padding: 2px var(--sp-s-2);
    border-radius: var(--sp-r-sm);
    border: 1px solid var(--sp-border-subtle);
    display: inline-block;
}

/* Section — wrapper sémantique léger. */
.sp-section { margin-bottom: var(--sp-s-6); }
.sp-section__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-s-4);
    margin-bottom: var(--sp-s-4);
}
.sp-section--divider .sp-section__header {
    padding-bottom: var(--sp-s-3);
    border-bottom: 1px solid var(--sp-border);
}
.sp-section__title-wrap { min-width: 0; flex: 1; }
.sp-section__title {
    font-size: var(--sp-fs-xl);
    font-weight: var(--sp-fw-semibold);
    margin: 0;
    color: var(--sp-text);
    line-height: var(--sp-lh-tight);
}
.sp-section__subtitle {
    font-size: var(--sp-fs-sm);
    color: var(--sp-text-muted);
    margin: var(--sp-s-1) 0 0;
}
.sp-section__actions {
    display: flex;
    gap: var(--sp-s-2);
    flex-shrink: 0;
}
.sp-section__body { /* slot principal — laisse le contenu respirer */ }

/* =============================================================================
   UX-Autocomplete overrides (Tom Select)
   -----------------------------------------------------------------------------
   Symfony UX-Autocomplete s'appuie sur Tom Select dont le CSS de base est
   importé dans assets/app.js. Les défauts visuels (border, radius, focus,
   couleurs) sont re-mappés ici sur les tokens `--sp-*` pour rester cohérent
   avec les autres inputs du dashboard merchant.
   ============================================================================= */

.ts-wrapper {
    /* Le wrapper Tom Select doit se comporter comme un input standard. */
    width: 100%;
}

.ts-control {
    /* Match `<input>` standard du dashboard : border-gray-300 rounded-lg px-3 py-2 */
    background-color: var(--sp-surface);
    border: 1px solid var(--sp-gray-300);
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
    font-size: var(--sp-fs-sm);
    line-height: var(--sp-lh-body);
    color: var(--sp-text);
    box-shadow: none;
    min-height: 2.5rem;
    transition: border-color 120ms ease-in-out, box-shadow 120ms ease-in-out;
}

.ts-wrapper.focus .ts-control,
.ts-control:focus-within {
    /* Focus ring aligné sur les inputs standard. */
    border-color: var(--sp-primary-500);
    box-shadow: 0 0 0 3px rgba(0, 107, 63, 0.18);
    outline: none;
}

.ts-wrapper.disabled .ts-control {
    background-color: var(--sp-gray-100);
    color: var(--sp-text-muted);
    cursor: not-allowed;
}

.ts-wrapper .ts-control > input {
    /* L'input nu à l'intérieur du control hérite des tokens couleur/typo. */
    color: var(--sp-text);
    font-size: var(--sp-fs-sm);
    line-height: var(--sp-lh-body);
}

.ts-wrapper .ts-control > input::placeholder {
    color: var(--sp-text-muted);
    opacity: 1;
}

.ts-dropdown {
    /* Panneau de suggestions — élévation + radius alignés sur les cards. */
    border: 1px solid var(--sp-border);
    border-radius: 0.5rem;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12);
    background-color: var(--sp-surface);
    margin-top: 0.25rem;
    overflow: hidden;
    z-index: 50;
}

.ts-dropdown .option {
    /* Chaque suggestion = ligne padded, couleur subtile au survol. */
    padding: var(--sp-s-2) var(--sp-s-3);
    font-size: var(--sp-fs-sm);
    line-height: var(--sp-lh-body);
    color: var(--sp-text);
    border-bottom: 1px solid var(--sp-gray-100);
}

.ts-dropdown .option:last-child {
    border-bottom: none;
}

.ts-dropdown .option.active,
.ts-dropdown .option:hover {
    /* Highlight cohérent avec le tone primaire de la marque. */
    background-color: var(--sp-primary-50);
    color: var(--sp-primary-700);
    cursor: pointer;
}

.ts-dropdown .option.selected {
    background-color: var(--sp-primary-100);
    color: var(--sp-primary-700);
    font-weight: var(--sp-fw-semibold);
}

.ts-dropdown .no-results,
.ts-dropdown .optgroup-header {
    padding: var(--sp-s-2) var(--sp-s-3);
    font-size: var(--sp-fs-xs);
    color: var(--sp-text-muted);
    background-color: var(--sp-gray-50);
}

.ts-wrapper.single .ts-control .item {
    /* Item sélectionné (single mode) : couleur texte standard, pas de pill. */
    color: var(--sp-text);
    padding: 0;
}

.ts-wrapper.multi .ts-control .item {
    /* Tags multi-select — variant pill cohérente avec sp-badge. */
    background-color: var(--sp-primary-50);
    color: var(--sp-primary-700);
    border: 1px solid var(--sp-primary-100);
    border-radius: 999px;
    padding: 0.125rem 0.5rem;
    margin: 0.125rem;
    font-size: var(--sp-fs-xs);
}

.ts-wrapper.multi .ts-control .item.active {
    background-color: var(--sp-primary-100);
}

.ts-dropdown .ts-dropdown-content {
    /* Scroll interne pour les listes longues — limite à ~10 items visibles. */
    max-height: 18rem;
}

