/* =========================================================================
   AutomationFactory — Design System
   -------------------------------------------------------------------------
   Source de vérité unique des tokens et composants de l'interface.
   Inspiration : esthétique des applications bancaires en ligne
   (vert de marque dominant, surfaces blanches, boutons arrondis, sobriété).

   ⚠️  PROPRIÉTÉ INTELLECTUELLE
   Ce fichier ne contient AUCUN asset de marque tiers (logo, police
   propriétaire, visuel). Pour rebrander vers une charte officielle,
   remplacer les valeurs du bloc :root ci-dessous et la pile de polices.

   Convention contributeurs (projet à 3) :
   - Ne JAMAIS coder une couleur/espacement « en dur » dans un composant :
     toujours référencer un token var(--xxx).
   - Ajouter un composant = ajouter sa section + l'illustrer dans la page
     /design-system/ (templates/design_system.html).
   ========================================================================= */

/* =========================================================================
   1. TOKENS — modifier ICI pour rebrander tout le système
   ========================================================================= */
:root {
    /* ---- Couleurs de marque (vert bancaire) ---------------------------- */
    --color-primary-900: #004d33;
    --color-primary-700: #00734d;
    --color-primary-600: #007e53;   /* couleur de marque principale (AA sur blanc) */
    --color-primary-500: #00a06b;
    --color-primary-300: #5cc79e;
    --color-primary-100: #d6f0e5;   /* fond tinté (chips, hovers doux)     */
    --color-primary-050: #ecf7f2;

    /* ---- Accent secondaire (teal, pour graphes / variations) ----------- */
    --color-accent-600:  #0a7e8c;
    --color-accent-100:  #d7eef1;

    /* ---- Neutres ------------------------------------------------------- */
    --color-ink:         #14241d;   /* texte principal                     */
    --color-ink-soft:    #45554e;   /* texte secondaire                    */
    --color-muted:       #5e6d66;   /* texte tertiaire / légendes (AA)     */
    --color-line:        #e2eae6;   /* bordures                            */
    --color-line-strong: #cdd9d3;
    --color-surface:     #ffffff;   /* cartes, panneaux                    */
    --color-surface-2:   #f6f9f7;   /* fond de page (vert très désaturé)   */
    --color-overlay:     rgba(20, 36, 29, .48);

    /* ---- Statuts ------------------------------------------------------- */
    --color-success:     #15793f;
    --color-success-bg:  #e6f4ec;
    --color-warning:     #855400;
    --color-warning-bg:  #fcf1dc;
    --color-danger:      #c4321f;
    --color-danger-bg:   #fbe9e6;
    --color-info:        #0a6ec4;
    --color-info-bg:     #e6f1fb;

    /* ---- Typographie --------------------------------------------------- */
    /* "Brand Sans" = police de charte officielle (déposée dans static/fonts/,
       déclarée dans brand-fonts.css). Repli sur Inter tant qu'elle est absente. */
    --font-sans: "Brand Sans", "Inter", "Segoe UI", system-ui, -apple-system, Roboto, Helvetica, Arial, sans-serif;
    --font-mono: "SFMono-Regular", "Cascadia Code", Consolas, "Liberation Mono", monospace;

    --fs-display: 40px;
    --fs-h1:      30px;
    --fs-h2:      24px;
    --fs-h3:      19px;
    --fs-h4:      16px;
    --fs-body:    15px;
    --fs-sm:      13px;
    --fs-xs:      11.5px;

    --fw-regular: 400;
    --fw-medium:  500;
    --fw-semibold:600;
    --fw-bold:    700;

    --lh-tight:   1.2;
    --lh-normal:  1.55;

    /* ---- Espacement (échelle 4px) ------------------------------------- */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 24px;
    --space-6: 32px;
    --space-7: 48px;
    --space-8: 64px;

    /* ---- Rayons -------------------------------------------------------- */
    --radius-sm:   8px;
    --radius-md:   12px;
    --radius-lg:   18px;
    --radius-pill: 999px;

    /* ---- Élévation ----------------------------------------------------- */
    --shadow-sm: 0 1px 2px rgba(20, 36, 29, .06), 0 1px 3px rgba(20, 36, 29, .05);
    --shadow-md: 0 4px 12px rgba(20, 36, 29, .08);
    --shadow-lg: 0 14px 38px rgba(20, 36, 29, .14);
    --focus-ring: 0 0 0 3px rgba(0, 126, 83, .35);

    /* ---- Transitions --------------------------------------------------- */
    --ease: 160ms cubic-bezier(.4, 0, .2, 1);

    /* ---- Navigation (chrome de l'application) -------------------------- */
    --nav-utility-bg:     #3c7458;   /* barre utilitaire (vert, AA sur blanc) */
    --nav-utility-active: rgba(0, 0, 0, .20);   /* assombrit → conserve le contraste */
    --nav-side-top:       #16352a;   /* menu latéral — dégradé sombre       */
    --nav-side-bottom:    #0a1c14;
    --nav-promo:          linear-gradient(135deg, #6a4a9e, #b14e93); /* item actif accentué */
    --nav-footer-bg:      #1b1b1b;   /* pied de page sombre                 */
    --nav-footer-head:    #5cc79e;   /* titres de colonnes (vert)           */
    --nav-footer-text:    #9b9b9b;
    --header-h:           84px;
    --utility-h:          48px;
    --sidenav-w:          132px;
}

/* =========================================================================
   2. RESET & BASE
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }

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

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    line-height: var(--lh-normal);
    color: var(--color-ink);
    background: var(--color-surface-2);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* =========================================================================
   3. TYPOGRAPHIE
   ========================================================================= */
.ds-display, .ds-h1, .ds-h2, .ds-h3, .ds-h4 {
    margin: 0;
    color: var(--color-ink);
    line-height: var(--lh-tight);
    font-weight: var(--fw-bold);
    letter-spacing: -.01em;
}
.ds-display { font-size: var(--fs-display); }
.ds-h1      { font-size: var(--fs-h1); }
.ds-h2      { font-size: var(--fs-h2); }
.ds-h3      { font-size: var(--fs-h3); font-weight: var(--fw-semibold); }
.ds-h4      { font-size: var(--fs-h4); font-weight: var(--fw-semibold); }

.ds-lead   { font-size: 17px; color: var(--color-ink-soft); line-height: var(--lh-normal); margin: 0; }
.ds-text   { font-size: var(--fs-body); margin: 0; }
.ds-small  { font-size: var(--fs-sm); }
.ds-muted  { color: var(--color-muted); }
.ds-strong { font-weight: var(--fw-semibold); }

.ds-eyebrow {
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--color-primary-600);
}

a.ds-link { color: var(--color-primary-700); text-decoration: none; font-weight: var(--fw-medium); }
a.ds-link:hover { text-decoration: underline; }

code.ds-code {
    font-family: var(--font-mono);
    font-size: .88em;
    background: var(--color-primary-050);
    color: var(--color-primary-900);
    padding: 2px 6px;
    border-radius: 6px;
}

/* =========================================================================
   4. BOUTONS
   ========================================================================= */
.ds-btn {
    --_bg: var(--color-primary-600);
    --_fg: #fff;
    --_bd: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    font-weight: var(--fw-semibold);
    line-height: 1;
    padding: 12px 22px;
    border: 1.5px solid var(--_bd);
    border-radius: var(--radius-pill);
    background: var(--_bg);
    color: var(--_fg);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--ease), border-color var(--ease),
                box-shadow var(--ease), transform var(--ease);
}
.ds-btn:hover     { background: var(--color-primary-700); }
.ds-btn:active    { transform: translateY(1px); }
.ds-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.ds-btn:disabled, .ds-btn[aria-disabled="true"] {
    opacity: .5; cursor: not-allowed; transform: none;
}

/* Variantes */
.ds-btn--secondary {
    --_bg: transparent; --_fg: var(--color-primary-700); --_bd: var(--color-primary-600);
}
.ds-btn--secondary:hover { background: var(--color-primary-050); }

.ds-btn--ghost {
    --_bg: transparent; --_fg: var(--color-ink); --_bd: var(--color-line-strong);
}
.ds-btn--ghost:hover { background: var(--color-surface-2); border-color: var(--color-muted); }

.ds-btn--danger { --_bg: var(--color-danger); }
.ds-btn--danger:hover { background: #a82817; }

.ds-btn--link {
    --_bg: transparent; --_fg: var(--color-primary-700); --_bd: transparent;
    padding-left: 6px; padding-right: 6px; border-radius: var(--radius-sm);
}
.ds-btn--link:hover { background: var(--color-primary-050); text-decoration: underline; }

/* Tailles */
.ds-btn--sm { padding: 8px 16px; font-size: var(--fs-sm); }
.ds-btn--lg { padding: 15px 30px; font-size: 16px; }
.ds-btn--block { display: flex; width: 100%; }

/* =========================================================================
   5. FORMULAIRES
   ========================================================================= */
.ds-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--space-4); }
.ds-label { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-ink-soft); }
.ds-hint  { font-size: var(--fs-xs); color: var(--color-muted); }

.ds-input, .ds-select, .ds-textarea {
    width: 100%;
    font-family: var(--font-sans);
    font-size: var(--fs-body);
    color: var(--color-ink);
    background: var(--color-surface);
    border: 1.5px solid var(--color-line-strong);
    border-radius: var(--radius-md);
    padding: 11px 14px;
    transition: border-color var(--ease), box-shadow var(--ease);
}
.ds-textarea { min-height: 96px; resize: vertical; }
.ds-input::placeholder, .ds-textarea::placeholder { color: var(--color-muted); }
.ds-input:focus, .ds-select:focus, .ds-textarea:focus {
    outline: none;
    border-color: var(--color-primary-600);
    box-shadow: var(--focus-ring);
}
.ds-input:disabled, .ds-select:disabled, .ds-textarea:disabled {
    background: var(--color-surface-2); color: var(--color-muted); cursor: not-allowed;
}
.ds-input--error { border-color: var(--color-danger); }
.ds-input--error:focus { box-shadow: 0 0 0 3px rgba(196, 50, 31, .22); }
.ds-error-text { font-size: var(--fs-xs); color: var(--color-danger); font-weight: var(--fw-medium); }

/* Choix (checkbox / radio) avec accent vert natif */
.ds-choice { display: flex; align-items: center; gap: 10px; font-size: var(--fs-body); cursor: pointer; }
.ds-choice input { width: 18px; height: 18px; accent-color: var(--color-primary-600); cursor: pointer; }

/* Interrupteur (switch) */
.ds-switch { position: relative; display: inline-flex; align-items: center; gap: 10px; cursor: pointer; }
.ds-switch input { position: absolute; opacity: 0; pointer-events: none; }
.ds-switch .track {
    width: 42px; height: 24px; border-radius: var(--radius-pill);
    background: var(--color-line-strong); transition: background var(--ease); position: relative;
}
.ds-switch .track::after {
    content: ""; position: absolute; top: 2px; left: 2px;
    width: 20px; height: 20px; border-radius: 50%; background: #fff;
    box-shadow: var(--shadow-sm); transition: transform var(--ease);
}
.ds-switch input:checked + .track { background: var(--color-primary-600); }
.ds-switch input:checked + .track::after { transform: translateX(18px); }
.ds-switch input:focus-visible + .track { box-shadow: var(--focus-ring); }

/* =========================================================================
   6. CARTES
   ========================================================================= */
.ds-card {
    background: var(--color-surface);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-5);
}
.ds-card--interactive { transition: box-shadow var(--ease), transform var(--ease), border-color var(--ease); cursor: pointer; }
.ds-card--interactive:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--color-line-strong); }
.ds-card__media {
    width: 46px; height: 46px; border-radius: var(--radius-md);
    display: grid; place-items: center; font-size: 22px; margin-bottom: var(--space-3);
    background: var(--color-primary-100); color: var(--color-primary-700);
}
.ds-card__title { font-size: var(--fs-h4); font-weight: var(--fw-semibold); margin: 0 0 4px; }
.ds-card__meta  { font-size: var(--fs-sm); color: var(--color-muted); }

/* =========================================================================
   7. BADGES, CHIPS & TAGS
   ========================================================================= */
.ds-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    padding: 4px 10px; border-radius: var(--radius-pill);
    background: var(--color-primary-100); color: var(--color-primary-900);
}
.ds-badge--success { background: var(--color-success-bg); color: var(--color-success); }
.ds-badge--warning { background: var(--color-warning-bg); color: var(--color-warning); }
.ds-badge--danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.ds-badge--info    { background: var(--color-info-bg);    color: var(--color-info); }
.ds-badge--neutral { background: var(--color-surface-2);  color: var(--color-ink-soft); }

.ds-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }

.ds-chip {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: var(--fs-sm); padding: 6px 12px;
    border: 1px solid var(--color-line-strong); border-radius: var(--radius-pill);
    background: var(--color-surface); color: var(--color-ink-soft);
}
.ds-chip button { border: none; background: none; cursor: pointer; color: var(--color-muted); font-size: 15px; line-height: 1; padding: 0; }

/* =========================================================================
   8. ALERTES
   ========================================================================= */
.ds-alert {
    display: flex; gap: var(--space-3); align-items: flex-start;
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--color-info);
    background: var(--color-info-bg); color: var(--color-ink);
    font-size: var(--fs-sm);
}
.ds-alert .ds-alert__ico { font-size: 18px; line-height: 1.3; }
.ds-alert__title { font-weight: var(--fw-semibold); margin: 0 0 2px; }
.ds-alert--success { border-color: var(--color-success); background: var(--color-success-bg); }
.ds-alert--warning { border-color: var(--color-warning); background: var(--color-warning-bg); }
.ds-alert--danger  { border-color: var(--color-danger);  background: var(--color-danger-bg); }

/* =========================================================================
   9. TABLEAUX
   ========================================================================= */
.ds-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.ds-table thead th {
    text-align: left; font-weight: var(--fw-semibold); color: var(--color-muted);
    text-transform: uppercase; font-size: var(--fs-xs); letter-spacing: .05em;
    padding: 10px 14px; border-bottom: 1px solid var(--color-line);
}
.ds-table tbody td { padding: 12px 14px; border-bottom: 1px solid var(--color-line); }
.ds-table tbody tr:hover { background: var(--color-primary-050); }
.ds-table--card { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); overflow: hidden; }

/* =========================================================================
   10. NAVIGATION (onglets & fil d'Ariane)
   ========================================================================= */
.ds-tabs { display: flex; gap: var(--space-1); border-bottom: 1px solid var(--color-line); }
.ds-tab {
    padding: 10px 16px; font-size: var(--fs-body); font-weight: var(--fw-medium);
    color: var(--color-ink-soft); background: none; border: none; cursor: pointer;
    border-bottom: 2.5px solid transparent; margin-bottom: -1px;
}
.ds-tab:hover { color: var(--color-primary-700); }
.ds-tab--active { color: var(--color-primary-700); border-bottom-color: var(--color-primary-600); font-weight: var(--fw-semibold); }

.ds-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: var(--fs-sm); color: var(--color-muted); }
.ds-breadcrumb a { color: var(--color-muted); text-decoration: none; }
.ds-breadcrumb a:hover { color: var(--color-primary-700); }
.ds-breadcrumb .sep { color: var(--color-line-strong); }

/* =========================================================================
   11. NAVIGATION — CHROME DE L'APPLICATION
   -------------------------------------------------------------------------
   Pattern : barre utilitaire (segments d'audience) > en-tête (logo + actions)
   > menu latéral à icônes avec méga-menu déroulant > pied de page sombre.
   ========================================================================= */

/* ---- 11.1 Barre utilitaire (haut) -------------------------------------- */
.ds-utilitybar {
    display: flex; align-items: stretch; justify-content: space-between;
    height: var(--utility-h);
    background: var(--nav-utility-bg); color: #fff; font-size: var(--fs-body);
}
.ds-utilitybar__seg { display: flex; }
.ds-utilitybar__seg a {
    display: flex; align-items: center; padding: 0 22px;
    color: #fff; text-decoration: none; font-weight: var(--fw-medium);
    transition: background var(--ease);
}
.ds-utilitybar__seg a:hover { background: rgba(0, 0, 0, .14); }
.ds-utilitybar__seg a.is-active,
.ds-utilitybar__seg a[aria-current] {
    background: var(--nav-utility-active); box-shadow: inset 0 -3px 0 #fff;
    font-weight: var(--fw-semibold);
}
.ds-utilitybar a:focus-visible { outline: 2px solid #fff; outline-offset: -3px; }
.ds-utilitybar__meta { display: flex; align-items: center; gap: 22px; padding: 0 22px; }
.ds-utilitybar__meta a { color: #fff; text-decoration: none; font-weight: var(--fw-medium); }
.ds-utilitybar__meta a:hover { text-decoration: underline; }

/* ---- 11.2 En-tête principal (logo + actions) --------------------------- */
.ds-header {
    position: relative; z-index: 30;
    display: flex; align-items: center; justify-content: space-between; gap: var(--space-5);
    height: var(--header-h); padding: 0 28px;
    background: var(--color-surface); border-bottom: 1px solid var(--color-line);
}
.ds-header__brand { display: flex; align-items: center; gap: 20px; min-width: 0; }
.ds-header__logo { height: 46px; width: auto; display: block; }
.ds-header__tagline {           /* emplacement libre : à renseigner par l'équipe */
    font-size: 20px; font-weight: var(--fw-semibold); color: var(--color-ink);
    border-left: 1px solid var(--color-line); padding-left: 20px;
}
.ds-header__actions { display: flex; align-items: center; gap: 14px; }
.ds-header__icon-btn {
    width: 46px; height: 46px; border-radius: 50%; border: none; cursor: pointer;
    background: none; display: grid; place-items: center; color: var(--color-ink); font-size: 20px;
    transition: background var(--ease);
}
.ds-header__icon-btn:hover { background: var(--color-surface-2); }

/* ---- 11.3 Menu latéral à icônes + méga-menu ---------------------------- */
.ds-sidenav {
    width: var(--sidenav-w); flex: none; align-self: stretch;
    background: linear-gradient(180deg, var(--nav-side-top), var(--nav-side-bottom));
    color: #fff; padding: 6px 0;
}
.ds-sidenav__item {
    position: relative;
    display: flex; align-items: center; gap: 11px; width: 100%;
    padding: 15px 14px; border: none; background: none; cursor: pointer;
    color: #fff; text-align: left; font-family: var(--font-sans);
    font-size: 14px; font-weight: var(--fw-semibold); line-height: 1.2;
    transition: background var(--ease);
}
.ds-sidenav__item .ico { font-size: 19px; flex: none; }
.ds-sidenav__item:hover { background: rgba(255, 255, 255, .07); }
.ds-sidenav__item.is-active { background: var(--nav-promo); }
.ds-sidenav__item.is-active::after {           /* flèche vers le méga-menu */
    content: ""; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
    border: 7px solid transparent; border-right-color: var(--color-surface);
}

/* Méga-menu : panneau blanc déroulé à droite de l'item */
.ds-megamenu {
    background: var(--color-surface); box-shadow: var(--shadow-lg);
    min-width: 520px; border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    padding: 4px 0; overflow: hidden;
}
.ds-megamenu__row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 28px; color: var(--color-ink); text-decoration: none;
    font-size: 17px; border-bottom: 1px solid var(--color-line);
    transition: color var(--ease), background var(--ease);
}
.ds-megamenu__row:last-child { border-bottom: none; }
.ds-megamenu__row:hover { color: var(--color-primary-700); background: var(--color-primary-050); }
.ds-megamenu__row .chev { color: var(--color-primary-600); font-size: 18px; }

/* ---- 11.4 Bandeau d'arguments (au-dessus du pied de page) -------------- */
.ds-feature-strip {
    display: flex; flex-wrap: wrap; gap: var(--space-6);
    background: var(--nav-side-bottom); color: #e7efe9;
    padding: 20px 32px; font-size: var(--fs-sm);
}
.ds-feature-strip__item { display: flex; align-items: center; gap: 12px; }
.ds-feature-strip__item .ico { font-size: 22px; color: var(--nav-footer-head); }

/* ---- 11.5 Pied de page ------------------------------------------------- */
.ds-footer { background: var(--nav-footer-bg); color: var(--nav-footer-text); padding: 40px 32px; }
.ds-footer__social {
    display: flex; align-items: center; justify-content: center; gap: 26px;
    padding-bottom: 28px; border-bottom: 1px solid rgba(255, 255, 255, .08);
    color: var(--nav-footer-text); font-size: 20px;
}
.ds-footer__cols {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6);
    padding-top: 30px;
}
.ds-footer__heading {
    color: var(--nav-footer-head); font-size: var(--fs-sm); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: .05em;
    border-left: 3px solid var(--nav-footer-head); padding-left: 11px; margin: 0 0 14px;
}
.ds-footer a { color: var(--nav-footer-text); text-decoration: none; display: block; padding: 4px 0; font-size: var(--fs-sm); }
.ds-footer a:hover { color: #fff; }

/* =========================================================================
   12. ICÔNES — jeu monochrome (trait = currentColor)
   -------------------------------------------------------------------------
   Usage : <svg class="ds-ico"><use href="#i-search"/></svg>
   Les symboles sont définis une seule fois dans un sprite SVG masqué
   (cf. templates/design_system.html). Couleur héritée du texte parent.
   ========================================================================= */
.ds-icon-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.ds-ico {
    width: 1.2em; height: 1.2em; display: inline-block; vertical-align: -.16em;
    fill: none; stroke: currentColor; stroke-width: 2;
    stroke-linecap: round; stroke-linejoin: round; flex: none;
}
.ds-ico--lg { width: 26px; height: 26px; }
.ds-sidenav__item .ds-ico       { width: 19px; height: 19px; }
.ds-feature-strip__item .ds-ico { width: 22px; height: 22px; }

/* =========================================================================
   13. UTILITAIRES MINIMAUX
   ========================================================================= */
.ds-stack > * + * { margin-top: var(--space-3); }
.ds-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3); }

/* =========================================================================
   14. ACCESSIBILITÉ — focus clavier visible & mouvement réduit
   -------------------------------------------------------------------------
   Anneau de focus visible au CLAVIER uniquement (:focus-visible), avec un
   contraste >= 3:1 vs l'arrière-plan : vert de marque sur fonds clairs,
   blanc sur fonds sombres (menu latéral, pied de page).
   ========================================================================= */
.ds-header__icon-btn:focus-visible,
.ds-tab:focus-visible,
.ds-breadcrumb a:focus-visible,
a.ds-link:focus-visible {
    outline: 2px solid var(--color-primary-600); outline-offset: 2px; border-radius: var(--radius-sm);
}
.ds-megamenu__row:focus-visible {
    outline: 2px solid var(--color-primary-600); outline-offset: -2px;
}
.ds-sidenav__item:focus-visible,
.ds-footer a:focus-visible,
.ds-footer__social a:focus-visible {
    outline: 2px solid #fff; outline-offset: -2px;
}
/* Cible tactile : garantir une zone d'au moins ~40px sur les liens du pied. */
.ds-footer a { min-height: 24px; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
        scroll-behavior: auto !important;
    }
    .ds-card--interactive:hover { transform: none; }
}
