/* ==========================================================================
   MERMAID SECURITY — Badge et avertissements liés au securityLevel
   --------------------------------------------------------------------------
   Styles partagés par :
     • la pastille de niveau (en-tête de l'éditeur) ;
     • la carte détaillée et la bannière d'avertissement dans la modale
       de configuration du diagramme.

   Les couleurs sont pilotées par l'attribut data-tone (safe / moderate /
   warning / isolated) afin de rester neutres vis-à-vis du thème clair /
   sombre global.
   ========================================================================== */

/* ----- Pastille "status-pill" dans la barre de l'éditeur ----- */

.security-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
    padding: 0.2em 0.55em;
    border-radius: 999px;
    font-size: var(--fs-xs, 11px);
    font-weight: 600;
    line-height: 1;
    border: 1px solid transparent;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    cursor: help;
    user-select: none;
    white-space: nowrap;
    transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}

.security-pill i {
    font-size: 0.95em;
}

.security-pill[hidden] {
    display: none;
}

/* Tonalités sémantiques */
.security-pill[data-tone="safe"] {
    background: color-mix(in srgb, #16a34a 10%, var(--bg-tertiary));
    border-color: color-mix(in srgb, #16a34a 35%, transparent);
    color: #15803d;
}

.security-pill[data-tone="moderate"] {
    background: color-mix(in srgb, #ca8a04 10%, var(--bg-tertiary));
    border-color: color-mix(in srgb, #ca8a04 35%, transparent);
    color: #a16207;
}

.security-pill[data-tone="warning"] {
    background: color-mix(in srgb, #dc2626 14%, var(--bg-tertiary));
    border-color: color-mix(in srgb, #dc2626 45%, transparent);
    color: #b91c1c;
    animation: ms-pulse 2.8s ease-in-out infinite;
}

.security-pill[data-tone="isolated"] {
    background: color-mix(in srgb, #0369a1 10%, var(--bg-tertiary));
    border-color: color-mix(in srgb, #0369a1 35%, transparent);
    color: #0369a1;
}

/* Thème sombre : on recolore la typo pour rester lisible */
[data-theme="dark"] .security-pill[data-tone="safe"]     { color: #4ade80; }
[data-theme="dark"] .security-pill[data-tone="moderate"] { color: #facc15; }
[data-theme="dark"] .security-pill[data-tone="warning"]  { color: #fca5a5; }
[data-theme="dark"] .security-pill[data-tone="isolated"] { color: #7dd3fc; }

@keyframes ms-pulse {
    0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, #dc2626 0%, transparent); }
    50%      { box-shadow: 0 0 0 4px color-mix(in srgb, #dc2626 18%, transparent); }
}

@media (prefers-reduced-motion: reduce) {
    .security-pill[data-tone="warning"] { animation: none; }
}

/* ----- Bloc "niveau de sécurité" dans la modale de config ----- */

.mc-security {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-4);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
}

.mc-security-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    flex-wrap: wrap;
}

.mc-security-title {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-sm);
    font-weight: 600;
    color: var(--text-primary);
}

.mc-security-title i {
    color: var(--accent);
}

.mc-security-control {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    min-width: 0;
}

.mc-security-control select {
    min-width: 170px;
}

/* Description du niveau sélectionné (change à la volée) */
.mc-security-desc {
    margin: 0;
    font-size: var(--fs-xs);
    line-height: 1.55;
    color: var(--text-secondary);
}

/* Bannière d'avertissement lorsqu'un niveau risqué est choisi */
.mc-security-warning {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--radius-md);
    border: 1px solid color-mix(in srgb, #dc2626 40%, transparent);
    background: color-mix(in srgb, #dc2626 10%, var(--bg-secondary));
    color: #b91c1c;
    font-size: var(--fs-xs);
    line-height: 1.55;
}

.mc-security-warning i {
    margin-top: 0.15em;
    flex-shrink: 0;
}

.mc-security-warning strong {
    color: inherit;
}

[data-theme="dark"] .mc-security-warning {
    color: #fecaca;
    background: color-mix(in srgb, #dc2626 18%, transparent);
}

.mc-security-warning[hidden] {
    display: none;
}

/* Petit tag de confirmation pour "J'ai compris" (coche + clic) */
.mc-security-confirm {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    margin-top: var(--sp-1);
    font-size: var(--fs-xs);
    color: inherit;
    cursor: pointer;
    user-select: none;
}

.mc-security-confirm input {
    accent-color: #dc2626;
}
