.api-card-disabled-btn {
    box-shadow: 0 10px 26px rgba(37, 99, 235, 0.22);
}

.api-card-disabled-btn[disabled] {
    opacity: 1;
    cursor: pointer;
    box-shadow: 0 10px 26px rgba(37, 99, 235, 0.22);
}

.api-card-summary,
.api-registry-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    align-items: stretch;
}

.api-registry-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 188px;
    padding: 18px 16px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.api-registry-card:hover,
.api-registry-card:focus-visible {
    border-color: #bfdbfe;
    box-shadow: 0 12px 28px rgba(59, 130, 246, 0.12);
    transform: translateY(-1px);
    outline: none;
}

.api-registry-status-badge {
    position: absolute;
    top: 14px;
    right: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-registry-status-badge.active {
    background: #dcfce7;
    color: #15803d;
}

.api-registry-status-badge.sandbox,
.api-registry-status-badge.inactive {
    background: #fef3c7;
    color: #b45309;
}

.api-registry-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: #eff6ff;
    color: #2563eb;
}

.api-registry-icon svg {
    width: 15px;
    height: 15px;
}

.api-registry-name {
    margin: 0;
    color: #111827;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
}

.api-registry-meta {
    color: #9ca3af;
    font-size: 9px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-registry-desc {
    min-height: 34px;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.api-registry-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    padding-top: 12px;
    border-top: 1px solid #f1f5f9;
}

.api-registry-metric {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.api-registry-metric-label {
    color: #9ca3af;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-registry-metric-value {
    color: #111827;
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
}

.api-registry-metric-value.success-good {
    color: #059669;
}

.api-registry-metric-value.success-warn {
    color: #d97706;
}

/* Tones WCAG AA partages avec setup_carte_api_detail_v2 (#0f766e / #b45309 / #b91c1c) */
.api-registry-metric-value.tone-green {
    color: #0f766e;
}

.api-registry-metric-value.tone-orange {
    color: #b45309;
}

.api-registry-metric-value.tone-red {
    color: #b91c1c;
}

.api-registry-metric-value.tone-muted {
    color: #94a3b8;
}

.api-registry-metrics-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.api-registry-metrics-3 .api-registry-metric-value {
    font-size: 18px;
}

/* Cas API inactive : carte conservee mais visuellement attenuee.
   Renforce vs cible : opacite 0.6 + titre/desc/metrics explicitement grises
   pour distinguer franchement les cartes exploitables des autres. */
.api-registry-card-inactive {
    opacity: 0.6;
    background: #fafafa;
}

.api-registry-card-inactive:hover,
.api-registry-card-inactive:focus-visible {
    opacity: 1;
}

.api-registry-card-inactive .api-registry-name {
    color: #94a3b8;
}

.api-registry-card-inactive .api-registry-desc {
    color: #cbd5e1;
}

.api-registry-card-inactive .api-registry-metric-value {
    color: #cbd5e1;
}

/* Toolbar globale du registre : selecteur de periode + tri + filtre statut.
   Style epure, sans cadre ni ombre, pour epouser le fond gris clair de la
   page (cf. maquette cible). */
.api-registry-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px 28px;
    padding: 0;
    margin: 8px 0 16px;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.api-registry-toolbar-group {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.api-registry-toolbar-label {
    color: #6b7280;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-registry-select {
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid #e5e7eb;
    background: #ffffff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;
    border-radius: 8px;
    padding: 7px 30px 7px 12px;
    color: #111827;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    min-width: 180px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.api-registry-select:hover {
    border-color: #cbd5e1;
}

.api-registry-select:focus-visible {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
}

.api-registry-cb-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid #f8fafc;
    color: #6b7280;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-registry-cb-state {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.api-registry-cb-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
}

.api-registry-cb-dot.green {
    background: #10b981;
}

.api-registry-cb-dot.orange {
    background: #f59e0b;
}

.api-registry-chevron {
    color: #cbd5e1;
    font-size: 14px;
    line-height: 1;
}

.api-registry-skeleton {
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 188px;
    padding: 18px 16px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.api-registry-skeleton-pill,
.api-registry-skeleton-icon,
.api-registry-skeleton-line,
.api-registry-skeleton-metric,
.api-registry-skeleton-footer {
    background: linear-gradient(90deg, #f1f5f9 0%, #e2e8f0 50%, #f1f5f9 100%);
    background-size: 200% 100%;
    animation: apiCardPulse 1.5s ease-in-out infinite;
}

.api-registry-skeleton-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.api-registry-skeleton-pill {
    width: 56px;
    height: 20px;
    border-radius: 999px;
    margin-left: auto;
}

.api-registry-skeleton-icon {
    width: 28px;
    height: 28px;
    border-radius: 8px;
}

.api-registry-skeleton-line {
    height: 10px;
    border-radius: 999px;
}

.api-registry-skeleton-line.title {
    width: 62%;
    height: 14px;
}

.api-registry-skeleton-line.meta {
    width: 44%;
}

.api-registry-skeleton-line.desc {
    width: 100%;
}

.api-registry-skeleton-line.desc.short {
    width: 84%;
}

.api-registry-skeleton-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    padding-top: 12px;
    border-top: 1px solid #f1f5f9;
}

.api-registry-skeleton-metric {
    height: 32px;
    border-radius: 10px;
}

.api-registry-skeleton-footer {
    width: 52%;
    height: 10px;
    border-radius: 999px;
    margin-top: auto;
}

@keyframes apiCardPulse {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

.api-card-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.api-card-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.api-card-badge.neutral {
    background: #f3f4f6;
    color: #374151;
}

.api-card-badge.info {
    background: #dbeafe;
    color: #1d4ed8;
}

.api-card-badge.success {
    background: #dcfce7;
    color: #15803d;
}

.api-card-badge.warning {
    background: #fef3c7;
    color: #b45309;
}

.api-card-badge.danger {
    background: #fee2e2;
    color: #b91c1c;
}

.api-card-documentation-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #2563eb;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
}

.api-card-documentation-link:hover {
    text-decoration: underline;
}

.api-card-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
    padding: 32px 24px;
}

.api-card-empty-icon {
    width: 92px;
    height: 92px;
    object-fit: contain;
}

.api-card-empty-title {
    font-size: 20px;
    font-weight: 700;
    color: #111827;
}

.api-card-empty-text {
    max-width: 620px;
    font-size: 14px;
    line-height: 1.6;
    color: #6b7280;
}

.api-detail-header-inline {
    margin-bottom: 18px;
    flex-shrink: 0;
}

.api-detail-header-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

.api-detail-header-main {
    min-width: 0;
}

.api-detail-title-row {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.api-card-back-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #6b7280;
    box-shadow: none;
}

.api-card-back-btn:hover {
    background: #f3f4f6;
    color: #111827;
}

.api-card-detail-title {
    margin: 0;
    color: #111827;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.25;
}

.api-card-detail-subtitle {
    margin: 10px 0 0;
    color: #6b7280;
    font-size: 14px;
    line-height: 1.6;
}

.api-card-detail-inline-meta {
    margin-top: 10px;
    color: #6b7280;
    font-size: 13px;
    line-height: 1.5;
}

.api-card-detail-inline-meta .api-card-mono {
    color: #374151;
    font-size: 12px;
}

.api-detail-header-actions {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.api-detail-action-btn {
    min-height: 42px;
    padding: 0 20px;
    border-radius: 11px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: -0.01em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    cursor: pointer;
    transition: background-color 140ms ease, border-color 140ms ease, box-shadow 140ms ease, color 140ms ease, transform 140ms ease;
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

.api-detail-action-btn svg {
    width: 17px;
    height: 17px;
    flex-shrink: 0;
}

.api-detail-action-btn:focus-visible {
    outline: none;
}

.api-detail-action-btn-secondary {
    background: #ffffff;
    color: #4b5563;
    border: 1px solid #e5e7eb;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.api-detail-action-btn-secondary:hover {
    background: #f8fafc;
    border-color: #d7dee8;
    color: #374151;
}

.api-detail-action-btn-secondary:focus-visible {
    box-shadow: 0 0 0 4px rgba(148, 163, 184, 0.18), 0 1px 2px rgba(15, 23, 42, 0.06);
}

.api-detail-action-btn-primary {
    background: linear-gradient(180deg, #3269f6 0%, #2c63ef 100%);
    color: #ffffff;
    border: 1px solid #2d63ec;
    box-shadow: 0 1px 2px rgba(37, 99, 235, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.api-detail-action-btn-primary:hover {
    background: linear-gradient(180deg, #2f64ec 0%, #285ce3 100%);
    border-color: #285ce3;
    transform: translateY(-1px);
}

.api-detail-action-btn-primary:focus-visible {
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.22), 0 1px 2px rgba(37, 99, 235, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.api-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 312px;
    grid-template-rows: minmax(0, 1fr);
    gap: 24px;
    align-items: stretch;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.api-detail-main {
    min-width: 0;
    min-height: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.api-detail-right-panel {
    position: sticky;
    top: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
}

/* Bandeau sélecteur de période (24h / 7j / 30j) */
.api-period-bar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    margin-bottom: 12px;
    flex-shrink: 0;
}

.api-period-label {
    color: #6b7280;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-period-selector {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
}

.api-period-btn {
    border: 0;
    background: transparent;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: #475569;
    cursor: pointer;
    line-height: 1;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.api-period-btn:hover {
    color: #111827;
}

.api-period-btn.active {
    background: #ffffff;
    color: #111827;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.api-period-btn:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

.api-kpi-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
    flex-shrink: 0;
}

.api-kpi-card {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 96px;
    padding: 16px 18px;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.api-kpi-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: #f8fafc;
    flex-shrink: 0;
}

.api-kpi-icon.success {
    color: #10b981;
}

.api-kpi-icon.info {
    color: #3b82f6;
}

.api-kpi-icon.purple {
    color: #9333ea;
}

.api-kpi-icon.amber {
    color: #d97706;
}

.api-kpi-icon svg {
    width: 20px;
    height: 20px;
}

.api-kpi-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.api-kpi-label {
    color: #9ca3af;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-kpi-value {
    color: #111827;
    font-size: 26px;
    font-weight: 700;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Tons WCAG AA pour le taux de succès (vert ≥ 99%, orange 95-98.9%, rouge < 95%) */
.api-kpi-card.tone-green .api-kpi-value {
    color: #047857;
}

.api-kpi-card.tone-orange .api-kpi-value {
    color: #b45309;
}

.api-kpi-card.tone-red .api-kpi-value {
    color: #b91c1c;
}

.api-card-section,
.api-conn-panel {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.api-card-section {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    padding: 0;
    overflow: hidden;
}

#api-card-endpoints {
    display: flex;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.api-endpoints-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 18px 14px;
    border-bottom: 1px solid #f1f5f9;
}

.api-endpoints-title {
    margin: 0;
    color: #111827;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.api-endpoints-search {
    position: relative;
    width: 250px;
    max-width: 100%;
}

.api-endpoints-search svg {
    position: absolute;
    top: 50%;
    left: 12px;
    width: 14px;
    height: 14px;
    color: #94a3b8;
    transform: translateY(-50%);
}

.api-endpoints-search input {
    width: 100%;
    height: 34px;
    padding: 0 34px 0 34px;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    background: #f8fafc;
    color: #111827;
    font-size: 12px;
}

.api-endpoints-search .v2-search-clear {
    position: absolute;
    top: 50%;
    right: 10px;
    display: none;
    border: none;
    background: transparent;
    color: #94a3b8;
    transform: translateY(-50%);
}

.api-cb-panel {
    padding: 18px;
    border-radius: 14px;
    background: #0f172a;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.18);
    color: #ffffff;
}

.api-cb-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.api-cb-title {
    color: #cbd5e1;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-cb-icon {
    color: #22c55e;
}

.api-cb-status {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 18px;
    margin-bottom: 18px;
}

.api-cb-status-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #10b981;
    flex-shrink: 0;
}

.api-cb-status-text {
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.api-cb-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 10px;
    font-size: 13px;
    line-height: 1.5;
}

.api-cb-row-label {
    color: #94a3b8;
}

.api-cb-row-value {
    color: #22c55e;
    font-weight: 600;
}

.api-cb-row-value.blue {
    color: #60a5fa;
}

.api-conn-panel {
    padding: 18px;
}

.api-conn-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}

.api-conn-title {
    margin: 0;
    color: #6b7280;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-conn-fields {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.api-conn-field-label {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-conn-field-value {
    color: #111827;
    font-size: 12px;
    line-height: 1.55;
    word-break: break-word;
}

.api-card-mono {
    font-family: ui-monospace, SFMono-Regular, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
}

.api-card-json-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.api-card-json-panel {
    min-width: 0;
}

.api-json-panel-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    color: #374151;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.api-card-json-block {
    margin: 0;
    padding: 14px 16px;
    border-radius: 10px;
    background: #172033;
    color: #dbe7ff;
    font-size: 12px;
    line-height: 1.6;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
}

.api-card-endpoints-list {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    height: 100%;
    max-height: none;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.api-card-endpoints-list::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
}

.api-card-endpoint {
    border-bottom: 1px solid #eef2f7;
    background: #ffffff;
}

.api-card-endpoint.inactive {
    opacity: 0.58;
    border-left: 3px solid #cbd5e1;
}

.api-card-endpoint:last-child {
    border-bottom: none;
}

.api-card-endpoint[open] {
    background: #ffffff;
}

.api-card-endpoint-summary {
    list-style: none;
    display: grid;
    grid-template-columns: 68px minmax(170px, 1.35fr) 128px minmax(180px, 2fr) auto 56px 20px;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    cursor: pointer;
}

.api-card-endpoint-summary > * {
    min-width: 0;
}

.api-card-endpoint-summary::-webkit-details-marker {
    display: none;
}

.api-card-method {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 10px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.api-card-method.get {
    background: #dbeafe;
    color: #1d4ed8;
}

.api-card-method.post {
    background: #dcfce7;
    color: #15803d;
}

.api-card-method.put,
.api-card-method.patch {
    background: #fef3c7;
    color: #b45309;
}

.api-card-method.delete {
    background: #fee2e2;
    color: #b91c1c;
}

.api-card-endpoint-path {
    display: block;
    min-width: 0;
    color: #374151;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-card-endpoint-path-wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.api-card-endpoint-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 20px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.api-card-endpoint-status-badge.active {
    background: #dcfce7;
    color: #15803d;
}

.api-card-endpoint-status-badge.inactive,
.api-card-endpoint-status-badge.sandbox {
    background: #e5e7eb;
    color: #4b5563;
}

.api-card-endpoint-id {
    display: block;
    min-width: 0;
    color: #111827;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-card-endpoint-desc {
    display: block;
    min-width: 0;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-card-endpoint-ttl {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: #eef2ff;
    color: #6366f1;
    font-size: 10px;
    font-weight: 700;
}

/* Indicateurs compacts inline (état endpoint replié, slot avant le TTL) */
.ep-inline-metric {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

.ep-inline-volume {
    color: #475569;
}

.ep-inline-rate {
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
}

.ep-inline-rate.tone-green {
    background: #dcfce7;
    color: #047857;
}

.ep-inline-rate.tone-orange {
    background: #ffedd5;
    color: #b45309;
}

.ep-inline-rate.tone-red {
    background: #fee2e2;
    color: #b91c1c;
}

.ep-inline-rate.neutral {
    background: #f1f5f9;
    color: #64748b;
}

.ep-inline-empty {
    color: #cbd5e1;
}

/* Bandeau runtime au sein du body endpoint déplié */
.ep-runtime-band {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
    padding: 10px 12px;
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
}

.ep-runtime-tile {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.ep-runtime-tile-label {
    color: #94a3b8;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ep-runtime-tile-value {
    color: #111827;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ep-runtime-tile.tone-green .ep-runtime-tile-value {
    color: #047857;
}

.ep-runtime-tile.tone-orange .ep-runtime-tile-value {
    color: #b45309;
}

.ep-runtime-tile.tone-red .ep-runtime-tile-value {
    color: #b91c1c;
}

.api-card-endpoint-chevron {
    color: #94a3b8;
    font-size: 14px;
    justify-self: end;
    transition: transform 0.2s ease;
}

.api-card-endpoint[open] .api-card-endpoint-chevron {
    transform: rotate(180deg);
}

.api-card-endpoint-body {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 0 18px 18px;
    background: #fbfdff;
}

.api-card-info-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.api-card-info-item {
    min-width: 0;
}

.api-card-info-label {
    display: block;
    margin-bottom: 6px;
    color: #6b7280;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-card-info-value {
    color: #111827;
    font-size: 13px;
    line-height: 1.55;
    word-break: break-word;
}

.api-card-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.api-card-section-title {
    margin: 0;
    color: #111827;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.api-card-section-subtitle {
    margin: 4px 0 0;
    color: #6b7280;
    font-size: 12px;
    line-height: 1.5;
}

.api-card-params-table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 12px;
}

.api-card-params-table th,
.api-card-params-table td {
    padding: 12px 10px;
    border-bottom: 1px solid #eef2f7;
    text-align: left;
    vertical-align: top;
}

.api-card-params-table th {
    color: #6b7280;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-card-params-table td {
    color: #374151;
    line-height: 1.5;
}

.api-card-params-table tr:last-child td {
    border-bottom: none;
}

.api-param-name-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.api-param-name-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 6px;
    background: #f3f4f6;
    color: #111827;
    font-size: 12px;
    font-weight: 600;
}

.api-param-requis {
    display: inline-flex;
    align-items: center;
    min-height: 18px;
    padding: 0 6px;
    border-radius: 999px;
    background: #fee2e2;
    color: #b91c1c;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.api-card-table-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #4b5563;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.api-param-type-string {
    color: #2563eb;
    font-weight: 600;
}

.api-param-type-date {
    color: #7c3aed;
    font-weight: 600;
}

.api-param-type-integer,
.api-param-type-number {
    color: #ea580c;
    font-weight: 600;
}

.api-card-empty-inline {
    padding: 14px 16px;
    border-radius: 12px;
    background: #f8fafc;
    color: #6b7280;
    font-size: 13px;
}

body.api-config-modal-open {
    overflow: hidden;
}

.api-config-overlay[hidden] {
    display: none !important;
}

.api-config-overlay {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: none;
    background: #ffffff;
}

.api-config-overlay.open {
    display: block;
}

.api-config-shell {
    position: relative;
    height: 100vh;
    display: flex;
    flex-direction: column;
    background: #ffffff;
}

.api-config-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    min-height: 72px;
    padding: 14px 28px;
    border-bottom: 1px solid #edf2f7;
    flex-shrink: 0;
    background: #ffffff;
}

.api-config-topbar-main {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    min-width: 0;
}

.api-config-back-btn {
    width: 34px;
    height: 34px;
    padding: 0;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #ffffff;
    color: #64748b;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}

.api-config-back-btn:hover {
    background: #f8fafc;
    color: #1e293b;
}

.api-config-heading {
    min-width: 0;
}

.api-config-title {
    margin: 0;
    color: #111827;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
}

.api-config-subtitle {
    margin: 4px 0 0;
    color: #94a3b8;
    font-size: 12px;
    line-height: 1.4;
}

.api-config-topbar-actions {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.api-config-layout {
    flex: 1;
    min-height: 0;
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    overflow: hidden;
}

.api-config-sidebar {
    border-right: 1px solid #e2e8f0;
    background: #f8fafc;
    padding: 20px 0 16px;
}

.api-config-sidebar-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #94a3b8;
    padding: 0 20px;
    margin-bottom: 20px;
}

.api-config-nav {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 0 12px;
}

.api-config-nav-btn {
    position: relative;
    width: 100%;
    min-height: 48px;
    padding: 10px 14px;
    border: none;
    border-radius: 12px;
    background: transparent;
    color: #475569;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.3;
    text-align: left;
    cursor: pointer;
}

.api-config-nav-btn:hover {
    background: rgba(241, 245, 249, 0.9);
    color: #334155;
}

.api-config-nav-btn.is-active {
    background: #ffffff;
    color: #2563eb;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 4px 12px rgba(15, 23, 42, 0.06);
}

.api-config-nav-btn.is-active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: calc(100% - 16px);
    min-height: 28px;
    background: #2563eb;
    border-radius: 999px;
}

.api-config-nav-icon {
    position: relative;
    z-index: 1;
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.api-config-nav-icon-img {
    width: 18px;
    height: 18px;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
}

/* SVG externes (Lucide) : teinte proche du texte inactif / actif */
.api-config-nav-btn:not(.is-active) .api-config-nav-icon-img {
    filter: invert(32%) sepia(14%) saturate(900%) hue-rotate(176deg) brightness(0.92);
}

.api-config-nav-btn.is-active .api-config-nav-icon-img {
    filter: invert(35%) sepia(95%) saturate(2200%) hue-rotate(210deg) brightness(0.96) contrast(1.02);
}

.api-config-nav-label {
    position: relative;
    z-index: 1;
    white-space: nowrap;
}

.api-config-content {
    min-width: 0;
    min-height: 0;
    overflow-y: auto;
    padding: 26px 28px 32px;
    background: #f8fafc;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.api-config-content::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
}

.api-config-tab-panel {
    width: min(980px, 100%);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.api-config-section {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.api-config-page-header,
.api-config-section-headline,
.api-config-subsection-header,
.api-config-endpoint-footer,
.api-config-dialog-footer,
.api-config-topbar-actions,
.api-config-inline-btn-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.api-config-page-title {
    margin: 0;
    color: #0f172a;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.025em;
}

.api-config-page-subtitle {
    margin: 4px 0 0;
    color: #94a3b8;
    font-size: 12px;
    line-height: 1.45;
}

.api-config-section-header {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.api-config-section-icon {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #2563eb;
    flex-shrink: 0;
}

.api-config-section-title {
    color: #0f172a;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.api-config-panel-card {
    border: 1px solid #eef2f7;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 4px 18px rgba(15, 23, 42, 0.04);
    padding: 18px 18px 16px;
}

/* PACK P1.15 — Espace vertical entre la grille (Nom/Fournisseur/Categories/
   Statut) et les champs qui suivent (Description, URL documentation). Sans
   ce gap, le label "DESCRIPTION" parait colle au champ Categories quand il
   passe sur 2 lignes (multi-select avec plusieurs chips). */
.api-config-panel-card > * + * {
    margin-top: 14px;
}

.api-config-grid {
    display: grid;
    gap: 14px 16px;
}

.api-config-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.api-config-connection-grid {
    grid-template-columns: minmax(0, 2fr) minmax(190px, 0.95fr);
}

.api-config-endpoint-top-grid {
    grid-template-columns: minmax(110px, 0.65fr) minmax(0, 1.7fr) minmax(0, 0.95fr) minmax(88px, 0.55fr);
}

.api-config-endpoint-main-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.95fr);
    align-items: start;
}

.api-config-field {
    display: flex;
    flex-direction: column;
    gap: 7px;
    min-width: 0;
}

.api-config-field-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.api-config-field-label {
    color: #64748b;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-config-field-helper {
    color: #60a5fa;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.api-config-input,
.api-config-textarea,
.api-config-codearea {
    width: 100%;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #ffffff;
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.65), 0 1px 2px rgba(15, 23, 42, 0.04);
    color: #111827;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 13px;
    line-height: 1.45;
}

.api-config-input {
    height: 40px;
    padding: 0 14px;
}

.api-config-textarea {
    min-height: 44px;
    padding: 10px 14px;
    resize: vertical;
}

.api-config-codearea {
    min-height: 104px;
    padding: 14px 16px;
    resize: vertical;
    border-color: #162033;
    background: #111827;
    color: #dbeafe;
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
    line-height: 1.6;
}

.api-config-input::placeholder,
.api-config-textarea::placeholder,
.api-config-codearea::placeholder {
    color: #c0cad8;
}

.api-config-input:focus,
.api-config-textarea:focus,
.api-config-codearea:focus {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

/* Liste déroulante personnalisée (configuration carte API) — maquette photo */
.api-config-dd {
    position: relative;
    width: 100%;
    z-index: 1;
}

.api-config-dd.is-open {
    z-index: 40;
}

.api-config-dd-trigger {
    width: 100%;
    min-height: 40px;
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #ffffff;
    color: #0f172a;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
    text-align: left;
    cursor: pointer;
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.65), 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.api-config-dd-trigger:hover {
    border-color: #cbd5e1;
}

.api-config-dd-trigger:focus {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.api-config-dd.is-open .api-config-dd-trigger {
    border-color: #2563eb;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.api-config-dd-value {
    flex: 1;
    min-width: 0;
}

.api-config-dd--uppercase .api-config-dd-value {
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.api-config-dd-chevron {
    flex-shrink: 0;
    display: inline-flex;
    color: #64748b;
    transition: transform 0.18s ease, color 0.15s ease;
}

.api-config-dd-trigger:focus .api-config-dd-chevron,
.api-config-dd.is-open .api-config-dd-chevron {
    color: #2563eb;
}

.api-config-dd.is-open .api-config-dd-chevron {
    transform: rotate(180deg);
}

.api-config-dd-panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 50;
    padding: 4px 0;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 4px 18px rgba(15, 23, 42, 0.1), 0 0 0 1px rgba(15, 23, 42, 0.03);
    max-height: 280px;
    overflow-y: auto;
    scrollbar-width: thin;
}

.api-config-dd-panel::-webkit-scrollbar {
    width: 6px;
}

.api-config-dd-panel::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 999px;
}

/* PACK P1.18.1 — `display: flex` ecrasait la regle navigateur
   `[hidden] { display: none }` (specificite de classe > attribut), donc
   les options filtrees restaient visibles. On retablit le masquage. */
.api-config-dd-option[hidden] {
    display: none !important;
}

.api-config-dd-option {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    border: none;
    background: transparent;
    color: #0f172a;
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
}

.api-config-dd-option:hover {
    background: #f8fafc;
}

.api-config-dd-option.is-selected {
    background: #eff6ff;
    color: #2563eb;
}

.api-config-dd-option-text--caps {
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.api-config-dd-check {
    flex-shrink: 0;
    width: 1.1em;
    font-size: 13px;
    font-weight: 700;
    color: #2563eb;
    text-align: right;
}

.api-config-dd-option:not(.is-selected) .api-config-dd-check {
    color: transparent;
}

.api-config-dd-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* PACK P1.15 — Dropdown multi-select avec chips (admin Cartes API) */
/* Wrapper du composant : compteur en haut a droite, champ au milieu,
   helper text discret en bas. */
.api-config-multi-wrap {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.api-config-multi-counter {
    align-self: flex-end;
    margin-top: -22px; /* remonte au niveau du label "CATEGORIES" */
    color: #64748b;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: none;
    pointer-events: none;
}

.api-config-multi-counter.is-over {
    color: #b45309;
}

.api-config-multi-helper {
    color: #94a3b8;
    font-size: 11.5px;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0;
    text-transform: none;
}

/* Le trigger devient un faux input multi-ligne. Il n'est plus un <button> :
   on cible juste son layout. Les chips occupent la zone superieure ; la
   sous-ligne "Tapez pour ajouter..." occupe la zone inferieure avec le
   chevron ancre a droite. */
.api-config-dd--multi {
    width: 100%;
}

.api-config-dd--multi .api-config-dd-trigger {
    width: 100%;
    min-height: 64px;
    height: auto;
    padding: 8px 12px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 6px;
    cursor: text;
    user-select: none;
}

.api-config-dd--multi .api-config-dd-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    min-height: 0;
    line-height: 1.2;
    width: 100%;
}

.api-config-dd--multi .api-config-dd-chips:empty {
    display: none;
}

.api-config-dd-input-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    min-height: 22px;
    cursor: pointer;
}

.api-config-dd--multi .api-config-dd-placeholder {
    flex: 1;
    color: #94a3b8;
    font-size: 13px;
    font-weight: 400;
    text-align: left;
}

/* PACK P1.18 — input de recherche du multi-select. Discret, sans bordure
   ni focus ring lourd : il vit dans la ligne d'ouverture du trigger. */
.api-config-dd-search {
    flex: 1;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    padding: 0;
    margin: 0;
    font: inherit;
    color: #1f2937;
    line-height: 22px;
}

.api-config-dd-search::placeholder {
    color: #94a3b8;
    font-weight: 400;
}

.api-config-dd-search:focus {
    outline: 0;
    box-shadow: none;
}

.api-config-dd--multi .api-config-dd-chevron {
    flex-shrink: 0;
}

/* PACK P1.18 — etat vide du panel quand le filtre ne matche rien. */
.api-config-dd-empty {
    padding: 10px 12px;
    font-size: 12px;
    color: #94a3b8;
    text-align: center;
    font-style: italic;
}

/* Chip (pill) selectionne */
.api-config-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 4px 3px 10px;
    border-radius: 999px;
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    max-width: 100%;
    white-space: nowrap;
    cursor: default;
}

.api-config-chip-label {
    display: inline-block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 220px;
}

.api-config-chip-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #1d4ed8;
    cursor: pointer;
    transition: background 0.12s ease, color 0.12s ease;
}

.api-config-chip-remove:hover {
    background: #1d4ed8;
    color: #ffffff;
}

.api-config-chip--legacy {
    background: #fef3c7;
    color: #92400e;
    border-color: #fde68a;
}

.api-config-chip--legacy .api-config-chip-remove {
    color: #92400e;
}

.api-config-chip--legacy .api-config-chip-remove:hover {
    background: #92400e;
    color: #ffffff;
}

/* Option du panneau avec checkbox (multi-select) */
.api-config-dd-option--check {
    gap: 10px;
    justify-content: flex-start;
}

.api-config-dd-option--check .api-config-dd-checkbox {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border: 1px solid #cbd5e1;
    border-radius: 4px;
    background: #ffffff;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    transition: background 0.12s ease, border-color 0.12s ease, color 0.12s ease;
}

.api-config-dd-option--check.is-selected .api-config-dd-checkbox {
    background: #2563eb;
    border-color: #2563eb;
    color: #ffffff;
}

.api-config-dd-option--check .api-config-dd-option-text {
    flex: 1;
    text-align: left;
}

.api-config-codearea:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.api-config-add-btn,
.api-config-subtle-add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 14px;
    border: none;
    border-radius: 10px;
    background: transparent;
    color: #2563eb;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    flex-shrink: 0;
}

.api-config-subtle-add-btn {
    min-height: 24px;
    padding: 0;
}

.api-config-add-btn:hover,
.api-config-subtle-add-btn:hover,
.api-config-link-btn:hover {
    color: #1d4ed8;
}

.api-config-endpoints-stack {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.api-config-endpoint-card {
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: #ffffff;
    overflow: hidden;
}

.api-config-endpoint-card-inactive {
    opacity: 0.58;
    border-color: #cbd5e1;
}

.api-config-endpoint-card-open {
    border-color: #93c5fd;
    box-shadow: 0 0 0 1px rgba(147, 197, 253, 0.35), 0 10px 30px rgba(59, 130, 246, 0.08);
}

.api-config-endpoint-summary {
    width: 100%;
    border: none;
    background: #ffffff;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto auto auto;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    cursor: pointer;
    text-align: left;
}

.api-config-method-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 0 10px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.api-config-method-badge.get {
    background: #e8f7ef;
    color: #1f8f56;
}

.api-config-method-badge.post {
    background: #e6f0ff;
    color: #2563eb;
}

.api-config-method-badge.put,
.api-config-method-badge.patch {
    background: #fff1de;
    color: #c27803;
}

.api-config-method-badge.delete {
    background: #fee7e7;
    color: #dc2626;
}

.api-config-endpoint-path-label {
    min-width: 0;
    color: #334155;
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 14px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-config-endpoint-id-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 20px;
    padding: 0 8px;
    border-radius: 999px;
    background: #eff6ff;
    color: #7c8bab;
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
}

.api-config-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 20px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.api-config-status-badge.active {
    background: #dcfce7;
    color: #15803d;
}

.api-config-status-badge.inactive {
    background: #e5e7eb;
    color: #4b5563;
}

.api-config-endpoint-param-count {
    color: #94a3b8;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.api-config-endpoint-chevron {
    color: #94a3b8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.api-config-endpoint-card-open .api-config-endpoint-chevron {
    transform: rotate(180deg);
}

.api-config-endpoint-preview {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.92fr);
    gap: 14px 16px;
    padding: 0 16px 16px;
}

.api-config-endpoint-preview-text {
    border-top: 1px solid #f1f5f9;
    padding-top: 14px;
}

.api-config-endpoint-preview-text p {
    margin: 6px 0 0;
    color: #1f2937;
    font-size: 12px;
    line-height: 1.55;
}

.api-config-code-preview {
    border-radius: 10px;
    background: #111827;
    color: #dbeafe;
    min-height: 84px;
    margin: 0;
    padding: 14px 16px;
    overflow: auto;
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 12px;
    line-height: 1.55;
}

.api-config-preview-table-wrap {
    grid-column: 1 / -1;
    border-top: 1px solid #f1f5f9;
    padding-top: 10px;
}

.api-config-link-btn {
    padding: 0;
    border: none;
    background: transparent;
    color: #2563eb;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
}

.api-config-endpoint-editor {
    border: 1px solid #dbeafe;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 18px 35px rgba(37, 99, 235, 0.09);
    overflow: visible;
}

.api-config-endpoint-editor-inactive {
    opacity: 0.72;
    border-color: #cbd5e1;
}

.api-config-endpoint-editor-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    border-bottom: 1px solid #eef2f7;
    background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
}

.api-config-endpoint-editor-title {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #0f172a;
    font-size: 16px;
    font-weight: 700;
}

.api-config-endpoint-header-actions {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.api-config-status-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    user-select: none;
}

.api-config-status-toggle-input {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.api-config-status-toggle-track {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 44px;
    height: 24px;
    padding: 2px;
    border-radius: 999px;
    background: #cbd5e1;
    transition: background 0.2s ease;
}

.api-config-status-toggle-thumb {
    width: 20px;
    height: 20px;
    border-radius: 999px;
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.16);
    transition: transform 0.2s ease;
}

.api-config-status-toggle-input:checked + .api-config-status-toggle-track {
    background: #2563eb;
}

.api-config-status-toggle-input:checked + .api-config-status-toggle-track .api-config-status-toggle-thumb {
    transform: translateX(20px);
}

.api-config-status-toggle-label {
    color: #374151;
    font-size: 12px;
    font-weight: 700;
}

.api-config-endpoint-dismiss,
.api-config-param-delete-btn {
    width: 28px;
    height: 28px;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #cbd5e1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.api-config-endpoint-editor-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px 18px 18px;
}

.api-config-subsection-header {
    margin-bottom: 10px;
}

.api-config-subsection-title {
    color: #64748b;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.api-config-params-table-wrap {
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    overflow: hidden;
}

.api-config-params-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.api-config-params-table th,
.api-config-params-table td {
    padding: 13px 16px;
    border-bottom: 1px solid #eef2f7;
    text-align: left;
    vertical-align: middle;
}

.api-config-params-table th {
    color: #64748b;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: #f8fafc;
}

.api-config-params-table tr:last-child td {
    border-bottom: none;
}

.api-config-param-cell {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.api-config-param-name {
    color: #1f2937;
    font-size: 12px;
    font-weight: 700;
}

.api-config-param-required {
    display: inline-flex;
    align-items: center;
    min-height: 19px;
    padding: 0 7px;
    border-radius: 999px;
    background: #fee2e2;
    color: #b91c1c;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.api-config-param-type {
    color: #2563eb;
    font-weight: 700;
}

.api-config-param-action-cell {
    width: 56px;
    text-align: right;
}

.api-config-checkbox-field {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 40px;
    color: #374151;
    font-size: 13px;
    font-weight: 500;
}

.api-config-checkbox-field input {
    width: 14px;
    height: 14px;
    margin: 0;
    accent-color: #2563eb;
}

.api-config-empty-params {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 126px;
    padding: 18px;
    border: 1px solid #edf2f7;
    border-radius: 14px;
    background: #fbfdff;
    text-align: center;
}

.api-config-empty-params-icon {
    color: #cbd5e1;
}

.api-config-empty-params-title {
    color: #475569;
    font-size: 14px;
    font-weight: 700;
}

.api-config-empty-params-text {
    color: #94a3b8;
    font-size: 12px;
    line-height: 1.5;
}

.api-config-delete-endpoint-btn,
.api-config-inline-btn,
.api-config-footer-btn,
.api-config-topbar-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 18px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
}

.api-config-delete-endpoint-btn {
    border: none;
    background: #fff1f2;
    color: #ef4444;
}

.api-config-inline-btn-secondary,
.api-config-footer-btn-secondary,
.api-config-topbar-btn-secondary {
    border: none;
    background: transparent;
    color: #374151;
}

.api-config-inline-btn-primary,
.api-config-footer-btn-primary,
.api-config-topbar-btn-primary {
    border: 1px solid #2d63ec;
    background: linear-gradient(180deg, #3269f6 0%, #2c63ef 100%);
    box-shadow: 0 1px 2px rgba(37, 99, 235, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.16);
    color: #ffffff;
}

.api-config-inline-btn-primary,
.api-config-footer-btn-primary,
.api-config-topbar-btn-primary {
    min-width: 176px;
}

.api-config-dialog-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    background: rgba(15, 23, 42, 0.35);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.api-config-dialog-card {
    width: min(620px, 100%);
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 30px 80px rgba(15, 23, 42, 0.24);
    overflow: visible;
}

.api-config-dialog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 20px;
    border-bottom: 1px solid #eef2f7;
}

.api-config-dialog-title {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #111827;
    font-size: 16px;
    font-weight: 700;
}

.api-config-dialog-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 18px 20px;
}

.api-config-dialog-footer {
    padding: 14px 20px 18px;
    border-top: 1px solid #eef2f7;
}

.api-config-empty-state {
    padding: 24px 18px;
    border: 1px dashed #dbe4ef;
    border-radius: 14px;
    background: #fbfdff;
    color: #64748b;
    text-align: center;
}

.api-config-overlay svg,
.api-config-overlay button svg {
    width: 16px;
    height: 16px;
}

@media (max-width: 1100px) {
    .api-config-content {
        padding: 22px 20px 26px;
    }

    .api-config-endpoint-main-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 960px) {
    .api-kpi-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .api-card-json-grid,
    .api-card-info-grid {
        grid-template-columns: 1fr;
    }

    .api-endpoints-header,
    .api-detail-header-top {
        flex-direction: column;
        align-items: flex-start;
    }

    .api-card-endpoint-summary {
        grid-template-columns: 1fr;
        align-items: flex-start;
    }

    .api-card-endpoint-chevron {
        justify-self: start;
    }

    .ep-runtime-band {
        grid-template-columns: 1fr;
    }

    .api-period-bar {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .api-config-layout {
        grid-template-columns: 1fr;
        grid-template-rows: auto 1fr;
    }

    .api-config-sidebar {
        padding: 10px 16px 0;
        border-right: none;
        border-bottom: 1px solid #eef2f7;
        background: #ffffff;
    }

    .api-config-sidebar-label {
        display: none;
    }

    .api-config-nav {
        flex-direction: row;
        gap: 8px;
        overflow-x: auto;
        padding: 0 0 10px;
        scrollbar-width: none;
    }

    .api-config-nav::-webkit-scrollbar {
        display: none;
    }

    .api-config-nav-btn {
        width: auto;
        min-width: 150px;
        justify-content: flex-start;
    }

    .api-config-nav-btn.is-active::before {
        display: none;
    }

    .api-config-nav-btn.is-active {
        box-shadow: none;
        border-bottom: 3px solid #2563eb;
        border-radius: 10px 10px 0 0;
        background: #ffffff;
    }

    .api-config-grid-two {
        grid-template-columns: 1fr;
    }

    .api-config-connection-grid,
    .api-config-endpoint-top-grid {
        grid-template-columns: 1fr;
    }

    .api-config-endpoint-summary {
        grid-template-columns: 1fr;
        align-items: flex-start;
    }

    .api-config-endpoint-preview {
        grid-template-columns: 1fr;
    }

    .api-config-page-header,
    .api-config-section-headline,
    .api-config-subsection-header,
    .api-config-endpoint-footer,
    .api-config-inline-btn-row,
    .api-config-dialog-footer,
    .api-config-topbar,
    .api-config-topbar-main {
        flex-direction: column;
        align-items: stretch;
    }

    .api-config-topbar-actions {
        width: 100%;
        justify-content: flex-end;
    }

    .api-config-inline-btn-primary,
    .api-config-footer-btn-primary,
    .api-config-topbar-btn-primary {
        min-width: 0;
        width: 100%;
    }
}

@media (max-width: 1180px) {
    .api-card-summary,
    .api-registry-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .api-card-summary,
    .api-registry-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .api-registry-toolbar {
        gap: 12px 16px;
    }

    .api-registry-select {
        min-width: 0;
        flex: 1;
    }
}

@media (max-width: 720px) {
    .api-card-summary,
    .api-registry-grid,
    .api-kpi-row {
        grid-template-columns: 1fr;
    }

    .api-registry-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .api-registry-toolbar-group {
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .api-registry-metrics-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .api-registry-metrics-3 .api-registry-metric-value {
        font-size: 16px;
    }

    .api-config-topbar,
    .api-config-content {
        padding-left: 16px;
        padding-right: 16px;
    }

    .api-config-dialog-overlay {
        padding: 12px;
    }

    .api-config-dialog-body,
    .api-config-dialog-header,
    .api-config-dialog-footer {
        padding-left: 16px;
        padding-right: 16px;
    }
}

/* ============================================================================
   API REGISTRY PAGE — refonte typographique scoped (v1.3.0)
   ----------------------------------------------------------------------------
   Tokens locaux pour aligner l'echelle typo de la page sur la maquette cible
   (titre plus generieux, valeurs metriques plus impactantes, etc.) sans
   contaminer les autres pages partageant les classes .v2-title / .v2-subtitle.
   ============================================================================ */
.api-registry-page {
    --typo-title-page: 32px;
    --typo-subtitle-page: 15px;
    --typo-card-title: 19px;
    --typo-card-meta: 11px;
    --typo-card-desc: 14px;
    --typo-metric-label: 11px;
    --typo-metric-value: 22px;
    --typo-toolbar-label: 12px;
    --typo-status-badge: 11px;
}

.api-registry-page .v2-title {
    font-size: var(--typo-title-page);
    letter-spacing: -0.02em;
    line-height: 1.15;
}

.api-registry-page .v2-subtitle {
    font-size: var(--typo-subtitle-page);
    line-height: 1.5;
}

.api-registry-page .api-registry-name {
    font-size: var(--typo-card-title);
    line-height: 1.25;
}

.api-registry-page .api-registry-meta {
    font-size: var(--typo-card-meta);
}

.api-registry-page .api-registry-desc {
    font-size: var(--typo-card-desc);
    line-height: 1.5;
    min-height: 42px;
}

.api-registry-page .api-registry-metric-label {
    font-size: var(--typo-metric-label);
}

.api-registry-page .api-registry-metrics-3 .api-registry-metric-value {
    font-size: var(--typo-metric-value);
}

.api-registry-page .api-registry-toolbar-label {
    font-size: var(--typo-toolbar-label);
}

.api-registry-page .api-registry-status-badge {
    font-size: var(--typo-status-badge);
    min-height: 24px;
    padding: 2px 10px;
}

/* Bouton periode "actif bleu plein" (scope page registre uniquement, la fiche
   detail conserve son style "blanc avec ombre" pour rester contextualisee). */
.api-registry-page .api-period-btn {
    text-transform: uppercase;
    font-size: 12px;
    padding: 8px 16px;
    letter-spacing: 0.04em;
}

.api-registry-page .api-period-btn.active {
    background: #2563eb;
    color: #ffffff;
    box-shadow: 0 1px 2px rgba(37, 99, 235, 0.18);
}

.api-registry-page .api-period-btn.active:hover {
    color: #ffffff;
}

/* Icone de carte agrandie pour accompagner la nouvelle echelle typo. */
.api-registry-page .api-registry-icon {
    width: 32px;
    height: 32px;
}

.api-registry-page .api-registry-icon svg {
    width: 18px;
    height: 18px;
}

@media (max-width: 720px) {
    .api-registry-page {
        --typo-title-page: 26px;
        --typo-card-title: 17px;
        --typo-metric-value: 19px;
    }
}

/* ----------------------------------------------------------------------------
   Fix v1.3.1 : scroll naturel sur la page registre.
   Apres avoir retire les classes .v2-models-list / .api-card-summary du
   conteneur grille (qui imposaient un flex column scrollable inadapte a une
   grille, voir RCA), on remet le scroll au niveau de .v2-content scope sur
   cette page uniquement. Sans cet override, .v2-content { overflow: hidden }
   herite de kb_document_v2.css couperait le contenu lorsqu'il depasse le
   viewport. Les autres pages (homepage, knowledge, dashboard...) restent
   inchangees.
   ---------------------------------------------------------------------------- */
.api-registry-page.v2-content {
    overflow-y: auto;
}

.api-registry-page .v2-content-inner {
    flex: 0 0 auto;
    min-height: 0;
}
