/* ============================================================
   idearsm v2 — Editorial newsroom design system
   Fonts: Fraunces (display serif) + DM Sans (UI) + JetBrains Mono
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300..700&family=Fraunces:opsz,wght@9..144,300..600&family=JetBrains+Mono:wght@400;500&display=swap');

/* -- Design tokens ------------------------------------------- */
:root {
    --font-display: 'Fraunces', Georgia, serif;
    --font-body:    'DM Sans', system-ui, -apple-system, sans-serif;
    --font-mono:    'JetBrains Mono', ui-monospace, monospace;

    /* Warm neutrals (stone scale) */
    --paper:     #fafaf9;
    --paper-2:   #f5f5f4;
    --paper-3:   #efeeec;
    --ink-50:    #f5f5f4;
    --ink-100:   #e7e5e4;
    --ink-150:   #dedcd8;
    --ink-200:   #d6d3d1;
    --ink-300:   #a8a29e;
    --ink-400:   #78716c;
    --ink-500:   #57534e;
    --ink-600:   #44403c;
    --ink-700:   #292524;
    --ink-800:   #1c1917;
    --ink-900:   #0c0a09;

    /* Editorial accents */
    --accent:        #0c0a09;
    --accent-soft:   #292524;
    --stamp:         #b91c1c;       /* sello rojo / errors */
    --highlight:     #fef08a;        /* marker yellow */
    --success:       #15803d;
    --warning:       #b45309;
    --info:          #075985;

    --link:          #1c1917;
    --link-hover:    #0c0a09;

    /* Radii bajos editoriales */
    --r-1: 3px;
    --r-2: 5px;
    --r-3: 8px;
    --r-4: 12px;
    --r-full: 9999px;

    /* Shadows sutiles */
    --sh-1: 0 1px 0 rgba(12,10,9,0.04), 0 0 0 1px rgba(12,10,9,0.06);
    --sh-2: 0 1px 2px rgba(12,10,9,0.04), 0 0 0 1px rgba(12,10,9,0.06);
    --sh-3: 0 8px 24px -10px rgba(12,10,9,0.15), 0 0 0 1px rgba(12,10,9,0.06);
    --sh-pop: 0 12px 32px -8px rgba(12,10,9,0.18), 0 0 0 1px rgba(12,10,9,0.08);

    /* Transitions */
    --t-fast: 120ms cubic-bezier(0.16, 1, 0.3, 1);
    --t-base: 180ms cubic-bezier(0.16, 1, 0.3, 1);
    --t-slow: 260ms cubic-bezier(0.16, 1, 0.3, 1);

    /* Layout */
    --sidebar-w: 232px;
    --topbar-h: 56px;
    --content-max: 1400px;

    /* Bootstrap overrides */
    --bs-body-bg:       var(--paper);
    --bs-body-color:    var(--ink-800);
    --bs-border-color:  var(--ink-150);
    --bs-secondary-bg:  var(--paper-2);
    --bs-link-color:    var(--link);
    --bs-link-hover-color: var(--link-hover);
    --bs-primary-rgb:   12,10,9;
}

[data-theme="dark"] {
    --paper:     #0c0a09;
    --paper-2:   #14110f;
    --paper-3:   #1c1917;
    --ink-50:    #1c1917;
    --ink-100:   #292524;
    --ink-150:   #35302e;
    --ink-200:   #44403c;
    --ink-300:   #57534e;
    --ink-400:   #78716c;
    --ink-500:   #a8a29e;
    --ink-600:   #d6d3d1;
    --ink-700:   #e7e5e4;
    --ink-800:   #f5f5f4;
    --ink-900:   #fafaf9;

    --accent:        #fafaf9;
    --accent-soft:   #e7e5e4;
    --stamp:         #ef4444;
    --highlight:     #facc15;
    --success:       #22c55e;
    --warning:       #f59e0b;
    --info:          #38bdf8;

    --link:          #fafaf9;
    --link-hover:    #ffffff;

    --sh-1: 0 1px 0 rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.06);
    --sh-2: 0 1px 2px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.06);
    --sh-3: 0 8px 24px -10px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.08);
    --sh-pop: 0 12px 32px -8px rgba(0,0,0,0.75), 0 0 0 1px rgba(255,255,255,0.1);

    --bs-body-bg:       var(--paper);
    --bs-body-color:    var(--ink-700);
    --bs-border-color:  var(--ink-150);
    --bs-secondary-bg:  var(--paper-2);
    color-scheme: dark;
}

/* -- Base --------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

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

body {
    margin: 0;
    background: var(--paper);
    color: var(--ink-800);
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.55;
    font-feature-settings: "ss01", "cv11";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, .display {
    font-family: var(--font-display);
    font-weight: 500;
    letter-spacing: -0.022em;
    color: var(--ink-900);
    margin: 0;
}

h1 { font-size: 1.875rem; line-height: 1.15; }
h2 { font-size: 1.4rem;   line-height: 1.2; }
h3 { font-size: 1.1rem;   line-height: 1.3; }

p { margin: 0; }

a { color: var(--link); text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--link-hover); text-decoration: underline; text-underline-offset: 3px; }

code, pre, kbd, .font-mono {
    font-family: var(--font-mono);
    font-size: 0.875em;
}

::selection { background: var(--highlight); color: var(--ink-900); }

/* -- App shell --------------------------------------------- */
.app-shell {
    display: grid;
    grid-template-columns: var(--sidebar-w) 1fr;
    min-height: 100vh;
}

@media (max-width: 768px) {
    .app-shell { grid-template-columns: 1fr; }
}

/* -- Sidebar ----------------------------------------------- */
.sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    background: var(--paper-2);
    border-right: 1px solid var(--ink-150);
    display: flex;
    flex-direction: column;
    padding: 18px 14px;
    z-index: 30;
}

@media (max-width: 768px) {
    .sidebar { display: none; }
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 4px 8px 18px;
    border-bottom: 1px dashed var(--ink-150);
    margin-bottom: 14px;
}

.brand-mark {
    width: 30px; height: 30px;
    display: grid; place-items: center;
    background: var(--ink-900);
    color: var(--paper);
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 14px;
    border-radius: var(--r-2);
    letter-spacing: -0.04em;
}

[data-theme="dark"] .brand-mark { background: var(--paper); color: var(--ink-900); }

.brand-name {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 18px;
    letter-spacing: -0.02em;
    color: var(--ink-900);
}

.brand-tagline {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-400);
    margin-top: -2px;
}

.sidebar-section {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-400);
    padding: 16px 10px 6px;
    font-weight: 500;
}

.sidebar-nav { display: flex; flex-direction: column; gap: 1px; flex: 1; }

.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: var(--r-2);
    color: var(--ink-600);
    font-size: 13.5px;
    font-weight: 450;
    transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
    text-decoration: none;
}

.nav-item:hover {
    background: var(--paper-3);
    color: var(--ink-900);
    text-decoration: none;
}

.nav-item.is-active {
    background: var(--ink-900);
    color: var(--paper);
    box-shadow: var(--sh-1);
}

[data-theme="dark"] .nav-item.is-active {
    background: var(--paper);
    color: var(--ink-900);
}

.nav-item.is-active svg { opacity: 1; }

.nav-item svg {
    width: 16px; height: 16px;
    stroke-width: 1.75;
    opacity: 0.7;
    flex-shrink: 0;
}

.sidebar-footer {
    padding-top: 14px;
    border-top: 1px dashed var(--ink-150);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.user-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: var(--r-2);
    transition: background var(--t-fast);
    color: var(--ink-700);
}

.user-chip:hover { background: var(--paper-3); text-decoration: none; color: var(--ink-900); }

.user-avatar {
    width: 28px; height: 28px;
    border-radius: var(--r-full);
    background: var(--ink-900);
    color: var(--paper);
    display: grid; place-items: center;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    flex-shrink: 0;
}

[data-theme="dark"] .user-avatar { background: var(--paper); color: var(--ink-900); }

.user-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--ink-900);
    line-height: 1.1;
}

.user-role {
    font-size: 10.5px;
    color: var(--ink-400);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.1;
}

/* -- Topbar ------------------------------------------------ */
.app-topbar {
    height: var(--topbar-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    border-bottom: 1px solid var(--ink-150);
    background: color-mix(in srgb, var(--paper) 80%, transparent);
    backdrop-filter: saturate(180%) blur(8px);
    position: sticky; top: 0; z-index: 20;
}

.breadcrumb-editorial {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px;
    color: var(--ink-500);
}

.breadcrumb-editorial .crumb {
    color: var(--ink-500);
    text-decoration: none;
}
.breadcrumb-editorial .crumb:hover { color: var(--ink-900); }
.breadcrumb-editorial .crumb.is-current {
    color: var(--ink-900);
    font-weight: 500;
}
.breadcrumb-editorial .sep {
    color: var(--ink-300);
    font-family: var(--font-display);
}

.topbar-actions { display: flex; align-items: center; gap: 8px; }

.icon-btn {
    width: 34px; height: 34px;
    display: grid; place-items: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--r-2);
    color: var(--ink-500);
    transition: all var(--t-fast);
    cursor: pointer;
}

.icon-btn:hover {
    background: var(--paper-2);
    color: var(--ink-900);
    border-color: var(--ink-150);
}

.icon-btn svg { width: 16px; height: 16px; stroke-width: 1.75; }

/* -- Main content ------------------------------------------ */
.app-main { min-width: 0; display: flex; flex-direction: column; }
.app-content {
    padding: 32px 28px 80px;
    max-width: var(--content-max);
    width: 100%;
    margin: 0 auto;
}

/* -- Page header ------------------------------------------- */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--ink-150);
    margin-bottom: 28px;
}

.page-eyebrow {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--ink-400);
    font-weight: 500;
    margin-bottom: 6px;
}

.page-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 2.1rem;
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--ink-900);
}

.page-subtitle {
    margin-top: 6px;
    color: var(--ink-500);
    max-width: 64ch;
    font-size: 14px;
}

.page-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* -- Buttons ----------------------------------------------- */
.btn {
    --btn-bg: transparent;
    --btn-fg: var(--ink-700);
    --btn-bd: var(--ink-200);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
    background: var(--btn-bg);
    color: var(--btn-fg);
    border: 1px solid var(--btn-bd);
    border-radius: var(--r-2);
    cursor: pointer;
    transition: background var(--t-fast), color var(--t-fast),
                border-color var(--t-fast), transform var(--t-fast),
                box-shadow var(--t-fast);
    text-decoration: none;
    white-space: nowrap;
}

.btn:hover {
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: var(--sh-1);
}

.btn:active { transform: translateY(0); box-shadow: none; }

.btn svg { width: 14px; height: 14px; stroke-width: 1.9; flex-shrink: 0; }

.btn-primary {
    --btn-bg: var(--ink-900);
    --btn-fg: var(--paper);
    --btn-bd: var(--ink-900);
}
.btn-primary:hover { --btn-bg: var(--ink-800); --btn-bd: var(--ink-800); color: var(--paper); }
[data-theme="dark"] .btn-primary { --btn-bg: var(--paper); --btn-fg: var(--ink-900); --btn-bd: var(--paper); }
[data-theme="dark"] .btn-primary:hover { --btn-bg: var(--ink-700); --btn-fg: var(--ink-900); --btn-bd: var(--ink-700); color: var(--ink-900); }

.btn-outline-secondary {
    --btn-bg: transparent;
    --btn-fg: var(--ink-700);
    --btn-bd: var(--ink-200);
}
.btn-outline-secondary:hover { --btn-bg: var(--paper-2); color: var(--ink-900); }

.btn-outline-danger {
    --btn-bg: transparent;
    --btn-fg: var(--stamp);
    --btn-bd: color-mix(in srgb, var(--stamp) 30%, var(--ink-200));
}
.btn-outline-danger:hover {
    --btn-bg: color-mix(in srgb, var(--stamp) 8%, transparent);
    color: var(--stamp);
}

.btn-ghost {
    --btn-bd: transparent;
    --btn-fg: var(--ink-500);
}
.btn-ghost:hover { --btn-bg: var(--paper-2); color: var(--ink-900); }

.btn-lg { padding: 10px 18px; font-size: 14px; }
.btn-sm { padding: 5px 10px; font-size: 12px; }

/* -- Cards ------------------------------------------------- */
.card {
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    box-shadow: none;
    overflow: hidden;
}

.card-header {
    background: var(--paper-2);
    border-bottom: 1px solid var(--ink-150);
    padding: 12px 16px;
    font-weight: 500;
    color: var(--ink-800);
    font-size: 13px;
}

.card-header strong {
    font-family: var(--font-display);
    font-weight: 500;
    letter-spacing: -0.01em;
    font-size: 14px;
}

.card-body { padding: 18px; }

/* -- Stat card --------------------------------------------- */
.stat-card {
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    padding: 18px 20px;
    position: relative;
    overflow: hidden;
    transition: border-color var(--t-base), transform var(--t-base);
}

.stat-card:hover { border-color: var(--ink-200); transform: translateY(-1px); }

.stat-card::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 4px;
    background: var(--ink-900);
    opacity: 0;
    transition: opacity var(--t-base);
}

.stat-card:hover::after { opacity: 1; }

.stat-card-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-400);
    font-weight: 500;
    margin-bottom: 8px;
}

.stat-card-value {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 2.3rem;
    color: var(--ink-900);
    line-height: 1;
    letter-spacing: -0.03em;
    font-feature-settings: "tnum";
}

.stat-card-meta {
    margin-top: 10px;
    font-size: 12px;
    color: var(--ink-500);
    display: flex;
    align-items: center;
    gap: 6px;
}

.stat-card-meta .dot {
    width: 6px; height: 6px;
    border-radius: var(--r-full);
    background: var(--ink-400);
}
.stat-card-meta.positive .dot { background: var(--success); }

/* -- Tables ------------------------------------------------ */
.table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 0;
    font-size: 13px;
    color: var(--ink-700);
}

.table thead th {
    font-size: 10.5px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-400);
    background: var(--paper-2);
    padding: 10px 16px;
    text-align: left;
    border-bottom: 1px solid var(--ink-150);
    border-top: 1px solid var(--ink-150);
}

.table tbody td {
    padding: 13px 16px;
    border-bottom: 1px solid var(--ink-100);
    vertical-align: middle;
}

.table tbody tr { transition: background var(--t-fast); }
.table tbody tr:hover { background: var(--paper-2); }
.table tbody tr:last-child td { border-bottom: 0; }

.table-light { background: var(--paper-2); }

/* -- Forms -------------------------------------------------- */
.form-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--ink-700);
    margin-bottom: 5px;
    display: block;
    letter-spacing: 0.01em;
}

.form-label .small, .form-label small {
    font-weight: 400;
    color: var(--ink-400);
    font-size: 11px;
}

.form-control, .form-select {
    width: 100%;
    padding: 8px 12px;
    background: var(--paper);
    color: var(--ink-900);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-2);
    font-size: 13.5px;
    font-family: var(--font-body);
    transition: border-color var(--t-fast), box-shadow var(--t-fast);
    line-height: 1.4;
}

.form-control:hover, .form-select:hover { border-color: var(--ink-300); }

.form-control:focus, .form-select:focus {
    outline: none;
    border-color: var(--ink-700);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ink-700) 14%, transparent);
}

.form-control:disabled { background: var(--paper-2); color: var(--ink-400); }

.form-control-lg { padding: 11px 14px; font-size: 15px; }

textarea.form-control { line-height: 1.55; min-height: 84px; }

.form-check {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 4px 0;
}

.form-check-input {
    width: 16px; height: 16px;
    margin: 0;
    accent-color: var(--ink-900);
    cursor: pointer;
}

.form-check-label { font-size: 13.5px; color: var(--ink-700); cursor: pointer; }

.form-switch .form-check-input {
    width: 32px; height: 18px;
    border-radius: 9999px;
    appearance: none;
    background: var(--ink-200);
    position: relative;
    transition: background var(--t-fast);
}

.form-switch .form-check-input::after {
    content: '';
    position: absolute;
    top: 2px; left: 2px;
    width: 14px; height: 14px;
    border-radius: 9999px;
    background: var(--paper);
    transition: transform var(--t-fast);
    box-shadow: var(--sh-1);
}

.form-switch .form-check-input:checked { background: var(--ink-900); }
.form-switch .form-check-input:checked::after { transform: translateX(14px); }

/* -- Badges ------------------------------------------------ */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 500;
    border-radius: var(--r-full);
    background: var(--paper-2);
    color: var(--ink-700);
    border: 1px solid var(--ink-150);
    line-height: 1.2;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.badge .dot {
    width: 7px; height: 7px;
    border-radius: 9999px;
    background: currentColor;
    flex-shrink: 0;
    display: inline-block;
}

/* Estados (con sombra de color de fondo más visible) */
.badge-status-pendiente    { color: #92400e; background: #fef3c7; border-color: #fde68a; }
.badge-status-procesada    { color: #1e40af; background: #dbeafe; border-color: #bfdbfe; }
.badge-status-generando    { color: #1e40af; background: #dbeafe; border-color: #bfdbfe; }
.badge-status-generada     { color: #065f46; background: #d1fae5; border-color: #a7f3d0; }
.badge-status-publicada    { color: #047857; background: #ecfdf5; border-color: #6ee7b7; }
.badge-status-distribuyendo{ color: #3730a3; background: #e0e7ff; border-color: #c7d2fe; }
.badge-status-error        { color: #991b1b; background: #fee2e2; border-color: #fecaca; }
.badge-status-descartada   { color: var(--ink-500); background: var(--paper-2); border-color: var(--ink-200); }
.badge-status-activa, .badge-status-activo  { color: #065f46; background: #d1fae5; border-color: #a7f3d0; }

[data-theme="dark"] .badge-status-pendiente    { color: #fcd34d; background: rgba(252,211,77,0.10); border-color: rgba(252,211,77,0.30); }
[data-theme="dark"] .badge-status-procesada    { color: #93c5fd; background: rgba(147,197,253,0.10); border-color: rgba(147,197,253,0.30); }
[data-theme="dark"] .badge-status-generando    { color: #93c5fd; background: rgba(147,197,253,0.10); border-color: rgba(147,197,253,0.30); }
[data-theme="dark"] .badge-status-generada     { color: #6ee7b7; background: rgba(110,231,183,0.10); border-color: rgba(110,231,183,0.30); }
[data-theme="dark"] .badge-status-publicada    { color: #6ee7b7; background: rgba(110,231,183,0.14); border-color: rgba(110,231,183,0.40); }
[data-theme="dark"] .badge-status-distribuyendo{ color: #a5b4fc; background: rgba(165,180,252,0.10); border-color: rgba(165,180,252,0.30); }
[data-theme="dark"] .badge-status-error        { color: #fca5a5; background: rgba(252,165,165,0.10); border-color: rgba(252,165,165,0.30); }

/* Orígenes — colores propios por canal de captura */
.badge-origen-manual {
    color: #5b21b6;
    background: #ede9fe;
    border-color: #ddd6fe;
}
.badge-origen-rss {
    color: #c2410c;
    background: #ffedd5;
    border-color: #fed7aa;
}
.badge-origen-telegram {
    color: #075985;
    background: #e0f2fe;
    border-color: #bae6fd;
}
.badge-origen-unsplash {
    color: #f5f5f4;
    background: #18181b;
    border-color: #27272a;
}
.badge-origen-pexels {
    color: #ffffff;
    background: #05a081;
    border-color: #047857;
}
.badge-origen-upload {
    color: var(--ink-600);
    background: var(--paper-2);
    border-color: var(--ink-200);
}
.badge-origen-generada {
    color: #6d28d9;
    background: #f5f3ff;
    border-color: #ddd6fe;
}

[data-theme="dark"] .badge-origen-manual    { color: #c4b5fd; background: rgba(196,181,253,0.12); border-color: rgba(196,181,253,0.30); }
[data-theme="dark"] .badge-origen-rss       { color: #fdba74; background: rgba(253,186,116,0.12); border-color: rgba(253,186,116,0.30); }
[data-theme="dark"] .badge-origen-telegram  { color: #7dd3fc; background: rgba(125,211,252,0.12); border-color: rgba(125,211,252,0.30); }
[data-theme="dark"] .badge-origen-upload    { color: var(--ink-500); background: var(--paper-3); }
[data-theme="dark"] .badge-origen-generada  { color: #c4b5fd; background: rgba(196,181,253,0.12); border-color: rgba(196,181,253,0.30); }

/* CMS tipos */
.badge-cms-nuntiuscms  { color: #1e3a8a; background: #dbeafe; border-color: #bfdbfe; }
.badge-cms-wordpress   { color: #1d4ed8; background: #eff6ff; border-color: #dbeafe; }
.badge-cms-custom      { color: var(--ink-600); background: var(--paper-2); border-color: var(--ink-200); }

[data-theme="dark"] .badge-cms-nuntiuscms { color: #93c5fd; background: rgba(147,197,253,0.10); border-color: rgba(147,197,253,0.28); }
[data-theme="dark"] .badge-cms-wordpress  { color: #93c5fd; background: rgba(147,197,253,0.08); border-color: rgba(147,197,253,0.24); }

/* Roles — colores por jerarquía */
.badge-role {
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.06em;
    padding: 3px 9px;
    font-weight: 600;
}
.badge-role-super_admin { color: #9f1239; background: #ffe4e6; border-color: #fecdd3; }
.badge-role-admin_medio { color: #1e40af; background: #dbeafe; border-color: #bfdbfe; }
.badge-role-editor      { color: #065f46; background: #d1fae5; border-color: #a7f3d0; }
.badge-role-redactor    { color: #374151; background: #f3f4f6; border-color: #d1d5db; }
.badge-role-observador  { color: var(--ink-500); background: var(--paper-2); border-color: var(--ink-200); }

[data-theme="dark"] .badge-role-super_admin { color: #fda4af; background: rgba(253,164,175,0.12); border-color: rgba(253,164,175,0.30); }
[data-theme="dark"] .badge-role-admin_medio { color: #93c5fd; background: rgba(147,197,253,0.12); border-color: rgba(147,197,253,0.30); }
[data-theme="dark"] .badge-role-editor      { color: #6ee7b7; background: rgba(110,231,183,0.12); border-color: rgba(110,231,183,0.30); }
[data-theme="dark"] .badge-role-redactor    { color: var(--ink-500); background: var(--paper-3); border-color: var(--ink-200); }

/* Tipo (compat con código legacy — mantiene monospace pero más visible) */
.badge-tipo {
    font-family: var(--font-mono);
    font-size: 11.5px;
    padding: 3px 9px;
    font-weight: 500;
    text-transform: lowercase;
}

.badge-ok {
    color: #065f46;
    background: #d1fae5;
    border-color: #a7f3d0;
}
[data-theme="dark"] .badge-ok { color: #6ee7b7; background: rgba(110,231,183,0.12); border-color: rgba(110,231,183,0.30); }

.badge-off {
    color: var(--ink-500);
    background: var(--paper-2);
    border-color: var(--ink-200);
}

/* -- Alerts ------------------------------------------------ */
.alert {
    border: 1px solid var(--ink-150);
    background: var(--paper-2);
    border-radius: var(--r-3);
    padding: 11px 14px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--ink-700);
    font-size: 13.5px;
    margin-bottom: 18px;
    position: relative;
}

.alert svg { width: 16px; height: 16px; stroke-width: 1.9; flex-shrink: 0; margin-top: 2px; }

.alert-success { color: var(--success); border-color: color-mix(in srgb, var(--success) 26%, var(--ink-150)); background: color-mix(in srgb, var(--success) 6%, var(--paper)); }
.alert-danger  { color: var(--stamp);   border-color: color-mix(in srgb, var(--stamp) 26%, var(--ink-150));   background: color-mix(in srgb, var(--stamp) 6%, var(--paper)); }
.alert-info    { color: var(--info);    border-color: color-mix(in srgb, var(--info) 26%, var(--ink-150));    background: color-mix(in srgb, var(--info) 6%, var(--paper)); }

.alert .btn-close {
    margin-left: auto;
    background: transparent;
    border: none;
    color: currentColor;
    opacity: 0.5;
    font-size: 16px;
    cursor: pointer;
    transition: opacity var(--t-fast);
    line-height: 1;
}
.alert .btn-close:hover { opacity: 1; }
.alert .btn-close::before { content: '✕'; font-family: var(--font-body); }

/* -- Empty state ------------------------------------------- */
.empty-state {
    text-align: center;
    padding: 56px 24px;
    color: var(--ink-500);
}

.empty-icon {
    width: 56px; height: 56px;
    margin: 0 auto 18px;
    display: grid; place-items: center;
    background: var(--paper-2);
    color: var(--ink-400);
    border-radius: var(--r-full);
    border: 1px dashed var(--ink-200);
}

.empty-icon svg { width: 24px; height: 24px; stroke-width: 1.5; }

.empty-title {
    font-family: var(--font-display);
    font-weight: 500;
    color: var(--ink-900);
    font-size: 1.05rem;
    margin-bottom: 4px;
}

.empty-text {
    color: var(--ink-500);
    margin-bottom: 16px;
    font-size: 13.5px;
}

/* -- Login (auth) shell ------------------------------------ */
.auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--paper);
}

@media (max-width: 900px) {
    .auth-shell { grid-template-columns: 1fr; }
    .auth-aside { display: none; }
}

.auth-aside {
    background: var(--ink-900);
    color: var(--paper-2);
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

.auth-aside::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
      radial-gradient(800px 400px at 20% 20%, rgba(254,240,138,0.06), transparent 60%),
      radial-gradient(600px 300px at 80% 90%, rgba(185,28,28,0.08), transparent 60%);
    pointer-events: none;
}

.auth-aside-quote {
    font-family: var(--font-display);
    font-size: 1.45rem;
    line-height: 1.3;
    letter-spacing: -0.015em;
    max-width: 28ch;
    color: var(--paper);
    position: relative;
}

.auth-aside-quote::before {
    content: '“';
    position: absolute;
    top: -28px; left: -16px;
    font-size: 6rem;
    color: var(--highlight);
    line-height: 1;
    opacity: 0.7;
    font-family: var(--font-display);
}

.auth-aside-attr {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--ink-400);
    margin-top: 18px;
}

.auth-aside-foot {
    font-size: 11px;
    color: var(--ink-400);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    position: relative;
}

.auth-form-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}

.auth-form-card {
    width: 100%;
    max-width: 380px;
}

.auth-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 36px;
}

.auth-headline {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 500;
    color: var(--ink-900);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: 6px;
}

.auth-sub {
    color: var(--ink-500);
    font-size: 13.5px;
    margin-bottom: 24px;
}

.auth-form { display: flex; flex-direction: column; gap: 14px; }

.auth-foot {
    margin-top: 28px;
    font-size: 11px;
    color: var(--ink-400);
    letter-spacing: 0.08em;
    text-align: center;
    text-transform: uppercase;
}

/* OTP large input */
.otp-input {
    width: 100%;
    font-family: var(--font-mono);
    font-size: 28px;
    letter-spacing: 8px;
    text-align: center;
    padding: 14px;
    background: var(--paper-2);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-3);
    color: var(--ink-900);
}

.otp-input:focus {
    outline: none;
    border-color: var(--ink-900);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--ink-900) 14%, transparent);
}

/* QR de 2FA */
.qr-wrap {
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    padding: 14px;
    text-align: center;
}

.qr-wrap img { display: block; margin: 0 auto; max-width: 100%; }

.qr-secret {
    margin-top: 12px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-500);
    word-break: break-all;
    text-align: center;
    background: var(--paper-2);
    padding: 8px;
    border-radius: var(--r-2);
}

/* -- Dropdown ---------------------------------------------- */
.dropdown-menu {
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    box-shadow: var(--sh-pop);
    padding: 5px;
    min-width: 200px;
    font-size: 13px;
}

.dropdown-item {
    padding: 7px 10px;
    border-radius: var(--r-2);
    color: var(--ink-700);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
}

.dropdown-item:hover { background: var(--paper-2); color: var(--ink-900); text-decoration: none; }

.dropdown-divider { border-color: var(--ink-150); }

/* -- Misc -------------------------------------------------- */
.text-muted     { color: var(--ink-400) !important; }
.text-primary   { color: var(--ink-900) !important; }
.text-danger    { color: var(--stamp)   !important; }
.text-success   { color: var(--success) !important; }
.bg-white       { background: var(--paper) !important; }
.bg-light       { background: var(--paper-2) !important; }
.bg-body-tertiary { background: var(--paper) !important; }
.border-0       { border: 0 !important; }
.shadow-sm      { box-shadow: none !important; }
.shadow         { box-shadow: var(--sh-2) !important; }

hr {
    border: 0;
    border-top: 1px dashed var(--ink-150);
    margin: 16px 0;
}

footer { font-size: 11px; color: var(--ink-400); letter-spacing: 0.06em; text-transform: uppercase; padding: 18px 28px; }

/* Tag pill (slug) */
code {
    background: var(--paper-2);
    color: var(--ink-700);
    padding: 1px 6px;
    border-radius: var(--r-1);
    font-size: 11.5px;
    border: 1px solid var(--ink-150);
}

/* -- Detail / article content ------------------------------ */
.article-body {
    font-size: 15px;
    line-height: 1.7;
    color: var(--ink-700);
}
.article-body p { margin: 0 0 12px; }
.article-body h2 { font-size: 1.25rem; margin: 20px 0 8px; }

.lead {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 1.25rem;
    line-height: 1.4;
    color: var(--ink-800);
    letter-spacing: -0.01em;
}

/* -- Tiny utilities ---------------------------------------- */
.kbd {
    background: var(--paper-2);
    border: 1px solid var(--ink-200);
    border-bottom-width: 2px;
    border-radius: var(--r-2);
    padding: 1px 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-600);
}

.divider-dot {
    color: var(--ink-300);
    margin: 0 6px;
}

/* -- Grid utility (sustituye Bootstrap row/col) ------------ */
.grid {
    display: grid;
    gap: 16px;
}
.grid.gap-3  { gap: 12px; }
.grid.gap-4  { gap: 16px; }
.grid.gap-5  { gap: 24px; }

.grid-cols-1 { grid-template-columns: 1fr; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.grid-cols-stats { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-main  { grid-template-columns: 2fr 1fr; }

@media (max-width: 1100px) {
    .grid-cols-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .grid-cols-main  { grid-template-columns: 1fr; }
    .grid-cols-3, .grid-cols-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
    .grid-cols-stats { grid-template-columns: 1fr; }
    .grid-cols-2, .grid-cols-3, .grid-cols-4 { grid-template-columns: 1fr; }
}

/* Fallback compat para vistas que aún usan Bootstrap classes */
.row { display: grid; gap: 16px; grid-template-columns: repeat(12, minmax(0, 1fr)); }
.row > [class*="col-"] { grid-column: span 12; }

.col-12 { grid-column: span 12; }
@media (min-width: 768px) {
    .col-md-2  { grid-column: span 2; }
    .col-md-3  { grid-column: span 3; }
    .col-md-4  { grid-column: span 4; }
    .col-md-5  { grid-column: span 5; }
    .col-md-6  { grid-column: span 6; }
    .col-md-7  { grid-column: span 7; }
    .col-md-8  { grid-column: span 8; }
    .col-md-9  { grid-column: span 9; }
    .col-md-12 { grid-column: span 12; }
}
@media (min-width: 992px) {
    .col-lg-2  { grid-column: span 2; }
    .col-lg-3  { grid-column: span 3; }
    .col-lg-4  { grid-column: span 4; }
    .col-lg-5  { grid-column: span 5; }
    .col-lg-6  { grid-column: span 6; }
    .col-lg-7  { grid-column: span 7; }
    .col-lg-8  { grid-column: span 8; }
    .col-lg-9  { grid-column: span 9; }
}

.g-3 > * { /* placeholder cuando bs g-3 viene heredado */ }

/* -- Stat card enriched ------------------------------------ */
.stat-card { position: relative; padding-right: 60px; }

.stat-card-icon {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 32px; height: 32px;
    display: grid; place-items: center;
    background: var(--paper-2);
    border-radius: var(--r-2);
    color: var(--ink-500);
    transition: background var(--t-base), color var(--t-base);
}
.stat-card-icon svg { width: 16px; height: 16px; stroke-width: 1.75; }
.stat-card:hover .stat-card-icon { background: var(--ink-900); color: var(--paper); }
[data-theme="dark"] .stat-card:hover .stat-card-icon { background: var(--paper); color: var(--ink-900); }

/* Sparkline (barras de tendencia 7 días) */
.sparkline {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 28px;
    margin-top: 12px;
}
.sparkline-bar {
    flex: 1;
    background: var(--ink-200);
    border-radius: 2px;
    min-height: 3px;
    transition: background var(--t-base), transform var(--t-base);
    animation: spark-grow 600ms cubic-bezier(0.16, 1, 0.3, 1) backwards;
}
.stat-card:hover .sparkline-bar { background: var(--ink-700); }
.sparkline-bar:last-child { background: var(--ink-700); }
.stat-card:hover .sparkline-bar:last-child { background: var(--ink-900); }
[data-theme="dark"] .stat-card:hover .sparkline-bar { background: var(--ink-500); }
[data-theme="dark"] .stat-card:hover .sparkline-bar:last-child { background: var(--paper); }

@keyframes spark-grow {
    from { transform: scaleY(0); transform-origin: bottom; }
    to   { transform: scaleY(1); transform-origin: bottom; }
}

/* Live pulse indicator */
.live-dot {
    position: relative;
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 9999px;
    background: var(--success);
    flex-shrink: 0;
}
.live-dot::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 9999px;
    background: var(--success);
    opacity: 0.5;
    animation: pulse 2s cubic-bezier(0.16, 1, 0.3, 1) infinite;
}
@keyframes pulse {
    0%   { transform: scale(1);   opacity: 0.6; }
    70%  { transform: scale(2.4); opacity: 0; }
    100% { transform: scale(2.4); opacity: 0; }
}

/* Delta indicator */
.stat-delta {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 500;
    padding: 1px 6px;
    border-radius: var(--r-full);
    background: var(--paper-2);
    color: var(--ink-500);
    margin-left: 8px;
}
.stat-delta.up   { color: var(--success); background: color-mix(in srgb, var(--success) 10%, var(--paper)); }
.stat-delta.down { color: var(--stamp);   background: color-mix(in srgb, var(--stamp) 10%, var(--paper)); }

/* Activity chart - barras por hora */
.activity-chart {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    height: 90px;
    padding: 8px 0;
}
.activity-bar {
    flex: 1;
    background: var(--ink-150);
    border-radius: 3px 3px 0 0;
    min-height: 4px;
    position: relative;
    transition: background var(--t-fast);
    animation: spark-grow 700ms cubic-bezier(0.16, 1, 0.3, 1) backwards;
}
.activity-bar:hover { background: var(--ink-700); }
.activity-bar.is-current {
    background: var(--ink-900);
}
[data-theme="dark"] .activity-bar.is-current { background: var(--paper); }
.activity-bar[data-count]::after {
    content: attr(data-count);
    position: absolute;
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-900);
    background: var(--paper);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-1);
    padding: 1px 5px;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--t-fast);
    white-space: nowrap;
    z-index: 2;
}
.activity-bar:hover[data-count]::after { opacity: 1; }
.activity-bar[data-count="0"]:hover::after { display: none; }

.activity-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 6px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-400);
}

/* Stagger animation on cards */
.fade-up {
    animation: fade-up 400ms cubic-bezier(0.16, 1, 0.3, 1) backwards;
}
@keyframes fade-up {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.stagger-1 { animation-delay: 0ms; }
.stagger-2 { animation-delay: 60ms; }
.stagger-3 { animation-delay: 120ms; }
.stagger-4 { animation-delay: 180ms; }
.stagger-5 { animation-delay: 240ms; }
.stagger-6 { animation-delay: 300ms; }

/* Hover lift más expresivo en cards */
.card.lift {
    transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
.card.lift:hover {
    transform: translateY(-2px);
    border-color: var(--ink-300);
    box-shadow: var(--sh-3);
}

/* Last-updated indicator */
.last-updated {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--ink-400);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* -- Modal system ------------------------------------------ */
.modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: color-mix(in srgb, var(--ink-900) 50%, transparent);
    backdrop-filter: saturate(140%) blur(6px);
    -webkit-backdrop-filter: saturate(140%) blur(6px);
    animation: modal-overlay-in 200ms cubic-bezier(0.16, 1, 0.3, 1);
}
.modal-overlay.is-open { display: flex; }

@keyframes modal-overlay-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.modal-card {
    width: 100%;
    max-width: 460px;
    background: var(--paper);
    border-radius: var(--r-4);
    box-shadow: 0 24px 60px -16px rgba(0,0,0,0.4), 0 0 0 1px var(--ink-150);
    overflow: hidden;
    animation: modal-card-in 240ms cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes modal-card-in {
    from { opacity: 0; transform: translateY(12px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.modal-body {
    padding: 24px 26px 18px;
    display: flex;
    gap: 16px;
    align-items: flex-start;
}

.modal-icon-wrap {
    width: 40px; height: 40px;
    flex-shrink: 0;
    border-radius: var(--r-full);
    background: var(--paper-2);
    color: var(--ink-700);
    display: grid;
    place-items: center;
    border: 1px solid var(--ink-150);
}
.modal-icon-wrap svg { width: 20px; height: 20px; stroke-width: 1.75; }

.modal-icon-wrap.is-danger {
    background: #fee2e2;
    color: #b91c1c;
    border-color: #fecaca;
}
[data-theme="dark"] .modal-icon-wrap.is-danger {
    background: rgba(239,68,68,0.14);
    color: #fca5a5;
    border-color: rgba(239,68,68,0.30);
}

.modal-icon-wrap.is-info {
    background: #dbeafe;
    color: #1e40af;
    border-color: #bfdbfe;
}
[data-theme="dark"] .modal-icon-wrap.is-info {
    background: rgba(147,197,253,0.14);
    color: #93c5fd;
    border-color: rgba(147,197,253,0.30);
}

.modal-text { flex: 1; min-width: 0; }

.modal-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.1rem;
    color: var(--ink-900);
    margin: 0 0 6px 0;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

.modal-message {
    font-size: 13.5px;
    color: var(--ink-600);
    line-height: 1.55;
    margin: 0;
    word-break: break-word;
}
.modal-message code { font-size: 12px; padding: 1px 6px; }

.modal-footer {
    padding: 14px 22px;
    background: var(--paper-2);
    border-top: 1px solid var(--ink-150);
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.modal-footer .btn { font-size: 13px; padding: 8px 16px; }
.modal-confirm.is-danger {
    background: #b91c1c;
    border-color: #b91c1c;
    color: #fef2f2;
}
.modal-confirm.is-danger:hover {
    background: #991b1b;
    border-color: #991b1b;
    color: #fef2f2;
}
[data-theme="dark"] .modal-confirm.is-danger {
    background: #ef4444;
    border-color: #ef4444;
    color: #fef2f2;
}

/* -- RSS auto-config: stepper animado --------------------- */
.autoconfig-overlay {
    position: fixed;
    inset: 0;
    z-index: 999;
    background: color-mix(in srgb, var(--ink-900) 55%, transparent);
    backdrop-filter: saturate(160%) blur(8px);
    -webkit-backdrop-filter: saturate(160%) blur(8px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: modal-overlay-in 220ms cubic-bezier(0.16, 1, 0.3, 1);
}
.autoconfig-overlay.is-open { display: flex; }

.autoconfig-card {
    width: 100%;
    max-width: 580px;
    background: var(--paper);
    border-radius: var(--r-4);
    box-shadow: 0 24px 60px -16px rgba(0,0,0,0.4), 0 0 0 1px var(--ink-150);
    overflow: hidden;
    animation: modal-card-in 240ms cubic-bezier(0.16, 1, 0.3, 1);
}

.autoconfig-head {
    padding: 22px 26px 16px;
    border-bottom: 1px solid var(--ink-150);
    background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
}
.autoconfig-head-eyebrow {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-400);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
}
.autoconfig-head-eyebrow svg { width: 14px; height: 14px; }
.autoconfig-head-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.25rem;
    color: var(--ink-900);
    line-height: 1.25;
    letter-spacing: -0.015em;
    margin: 0 0 4px;
}
.autoconfig-head-sub {
    color: var(--ink-500);
    font-size: 13px;
    margin: 0;
}

.autoconfig-progress {
    height: 3px;
    background: var(--ink-100);
    overflow: hidden;
}
.autoconfig-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--ink-700), var(--ink-900));
    width: 0%;
    transition: width 600ms cubic-bezier(0.16, 1, 0.3, 1);
}
[data-theme="dark"] .autoconfig-progress-bar {
    background: linear-gradient(90deg, var(--ink-500), var(--paper));
}

.autoconfig-body { padding: 22px 26px; }
.autoconfig-steps { display: flex; flex-direction: column; gap: 0; }

.autoconfig-step {
    display: flex;
    gap: 14px;
    padding: 10px 0;
    align-items: flex-start;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 380ms cubic-bezier(0.16, 1, 0.3, 1),
                transform 380ms cubic-bezier(0.16, 1, 0.3, 1);
}
.autoconfig-step.is-visible { opacity: 1; transform: translateY(0); }
.autoconfig-step.is-pending { opacity: 0.35; }

.autoconfig-step-icon {
    flex-shrink: 0;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--paper-2);
    border: 2px solid var(--ink-200);
    display: grid;
    place-items: center;
    color: var(--ink-400);
    transition: all 300ms cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
}
.autoconfig-step-icon svg { width: 13px; height: 13px; stroke-width: 2.5; }

.autoconfig-step.is-loading .autoconfig-step-icon {
    border-color: var(--ink-700);
    color: var(--ink-700);
}
.autoconfig-step.is-loading .autoconfig-step-icon::after {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: var(--ink-900);
    animation: spin 800ms linear infinite;
}
[data-theme="dark"] .autoconfig-step.is-loading .autoconfig-step-icon::after {
    border-top-color: var(--paper);
}
.autoconfig-step.is-done .autoconfig-step-icon {
    background: var(--success);
    border-color: var(--success);
    color: #fff;
    animation: step-done-pop 360ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.autoconfig-step.is-error .autoconfig-step-icon {
    background: var(--stamp);
    border-color: var(--stamp);
    color: #fff;
}

@keyframes step-done-pop {
    0%   { transform: scale(0.6); }
    60%  { transform: scale(1.15); }
    100% { transform: scale(1); }
}

.autoconfig-step-content { flex: 1; min-width: 0; }
.autoconfig-step-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--ink-900);
    font-family: var(--font-display);
    line-height: 1.25;
    margin-bottom: 2px;
}
.autoconfig-step.is-pending .autoconfig-step-label { color: var(--ink-500); }
.autoconfig-step-detail {
    font-size: 12.5px;
    color: var(--ink-500);
    line-height: 1.45;
    font-family: var(--font-mono);
    word-break: break-word;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 380ms cubic-bezier(0.16, 1, 0.3, 1), opacity 280ms 60ms;
}
.autoconfig-step.is-done .autoconfig-step-detail,
.autoconfig-step.is-error .autoconfig-step-detail {
    max-height: 100px;
    opacity: 1;
    margin-top: 4px;
}
.autoconfig-step-meta {
    margin-top: 6px;
    display: flex;
    gap: 10px;
    font-size: 11px;
    color: var(--ink-400);
    font-family: var(--font-mono);
    flex-wrap: wrap;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 380ms 80ms cubic-bezier(0.16, 1, 0.3, 1), opacity 280ms 120ms;
}
.autoconfig-step.is-done .autoconfig-step-meta { max-height: 40px; opacity: 1; }
.autoconfig-step-meta-chip {
    display: inline-flex; align-items: center; gap: 4px;
    background: var(--paper-2);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-full);
    padding: 1px 8px;
}

.autoconfig-result {
    margin-top: 18px;
    padding: 16px;
    background: color-mix(in srgb, var(--success) 8%, var(--paper-2));
    border: 1px solid color-mix(in srgb, var(--success) 22%, var(--ink-150));
    border-radius: var(--r-3);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 480ms 280ms cubic-bezier(0.16, 1, 0.3, 1),
                transform 480ms 280ms cubic-bezier(0.16, 1, 0.3, 1);
}
.autoconfig-result.is-visible { opacity: 1; transform: translateY(0); }
.autoconfig-result-head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.autoconfig-result-head svg { width: 18px; height: 18px; color: var(--success); }
.autoconfig-result-title {
    font-family: var(--font-display); font-weight: 500;
    color: var(--ink-900); font-size: 14.5px;
}
.autoconfig-result-reason {
    color: var(--ink-700);
    font-size: 13px;
    line-height: 1.5;
    margin: 0 0 10px;
}
.autoconfig-result-selector {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--font-mono); font-size: 12px;
    background: var(--paper); padding: 3px 9px; border-radius: var(--r-2);
    border: 1px solid var(--ink-150); color: var(--ink-800);
}
.autoconfig-result-preview {
    margin-top: 10px;
    padding: 10px 12px;
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-2);
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--ink-600);
    max-height: 90px;
    overflow: hidden;
    position: relative;
}
.autoconfig-result-preview::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0; height: 28px;
    background: linear-gradient(to bottom, transparent, var(--paper));
    pointer-events: none;
}
.autoconfig-result.is-info {
    background: color-mix(in srgb, var(--info) 8%, var(--paper-2));
    border-color: color-mix(in srgb, var(--info) 22%, var(--ink-150));
}
.autoconfig-result.is-info .autoconfig-result-head svg { color: var(--info); }
.autoconfig-result.is-error {
    background: color-mix(in srgb, var(--stamp) 8%, var(--paper-2));
    border-color: color-mix(in srgb, var(--stamp) 22%, var(--ink-150));
}
.autoconfig-result.is-error .autoconfig-result-head svg { color: var(--stamp); }

.autoconfig-foot {
    padding: 14px 22px;
    background: var(--paper-2);
    border-top: 1px solid var(--ink-150);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}
.autoconfig-foot-cost {
    font-size: 11px;
    color: var(--ink-500);
    font-family: var(--font-mono);
}

/* -- Extractor selector (fuentes RSS) ---------------------- */
.extractor-panel {
    margin-top: 14px;
    padding: 16px;
    background: var(--paper-2);
    border: 1px dashed var(--ink-200);
    border-radius: var(--r-3);
}

.extractor-step {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--ink-400);
    font-weight: 600;
    margin-bottom: 8px;
}

.extractor-candidates {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
    margin: 14px 0 8px;
}

.extractor-card {
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    padding: 14px;
    cursor: pointer;
    transition: all var(--t-fast);
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: relative;
}
.extractor-card:hover {
    border-color: var(--ink-300);
    transform: translateY(-1px);
    box-shadow: var(--sh-2);
}
.extractor-card.is-selected {
    border-color: var(--ink-900);
    background: color-mix(in srgb, var(--ink-900) 4%, var(--paper));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--ink-900) 18%, transparent);
}
[data-theme="dark"] .extractor-card.is-selected {
    border-color: var(--paper);
    background: color-mix(in srgb, var(--paper) 8%, var(--paper-2));
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--paper) 18%, transparent);
}

.extractor-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}
.extractor-card-label {
    font-family: var(--font-mono);
    font-size: 11.5px;
    color: var(--ink-700);
    line-height: 1.35;
    word-break: break-all;
    flex: 1;
}

.extractor-card-score {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--paper-2);
    color: var(--ink-600);
    border-radius: var(--r-full);
    padding: 2px 8px;
    font-size: 10px;
    font-weight: 600;
    font-family: var(--font-mono);
    flex-shrink: 0;
}
.extractor-card-score.is-high   { background: color-mix(in srgb, var(--success) 14%, var(--paper)); color: var(--success); }
.extractor-card-score.is-medium { background: color-mix(in srgb, var(--warning) 14%, var(--paper)); color: var(--warning); }
.extractor-card-score.is-low    { background: var(--paper-3); color: var(--ink-500); }

.extractor-card-preview {
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--ink-600);
    max-height: 110px;
    overflow: hidden;
    position: relative;
}
.extractor-card-preview::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 28px;
    background: linear-gradient(to bottom, transparent, var(--paper));
    pointer-events: none;
}
.extractor-card.is-selected .extractor-card-preview::after {
    background: linear-gradient(to bottom, transparent, color-mix(in srgb, var(--ink-900) 4%, var(--paper)));
}

.extractor-card-stats {
    display: flex;
    gap: 12px;
    font-size: 11px;
    color: var(--ink-400);
    font-family: var(--font-mono);
    padding-top: 8px;
    border-top: 1px solid var(--ink-150);
    margin-top: auto;
}

.extractor-card-checkmark {
    position: absolute;
    top: 10px; right: 10px;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--ink-900);
    color: var(--paper);
    display: none;
    place-items: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.18);
}
.extractor-card.is-selected .extractor-card-checkmark { display: grid; }
.extractor-card-checkmark svg { width: 13px; height: 13px; stroke-width: 2.5; }
[data-theme="dark"] .extractor-card-checkmark { background: var(--paper); color: var(--ink-900); }

.extractor-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 24px;
    justify-content: center;
    color: var(--ink-500);
    font-size: 13.5px;
}

.extractor-empty {
    padding: 22px;
    text-align: center;
    color: var(--ink-500);
    font-size: 13px;
    border: 1px dashed var(--ink-200);
    border-radius: var(--r-2);
}

.extractor-custom {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px dashed var(--ink-200);
}
.extractor-custom-row {
    display: flex; gap: 8px; align-items: center;
}
.extractor-custom-row .form-control { flex: 1; }

.extractor-preview-box {
    margin-top: 10px;
    padding: 12px;
    background: var(--paper);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-2);
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--ink-600);
    max-height: 140px;
    overflow-y: auto;
}
.extractor-preview-box.is-error {
    border-color: color-mix(in srgb, var(--stamp) 30%, var(--ink-200));
    color: var(--stamp);
}

/* -- Help / docs page -------------------------------------- */
.help-layout {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 32px;
    align-items: start;
}
@media (max-width: 980px) {
    .help-layout { grid-template-columns: 1fr; }
    .help-toc { position: static !important; max-height: none !important; }
}

.help-toc {
    position: sticky;
    top: calc(var(--topbar-h) + 16px);
    max-height: calc(100vh - var(--topbar-h) - 32px);
    overflow-y: auto;
    padding: 4px 8px;
}
.help-toc::-webkit-scrollbar { width: 6px; }
.help-toc::-webkit-scrollbar-thumb { background: var(--ink-200); border-radius: 3px; }

.help-toc-title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-400);
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 10px;
}
.help-toc-link {
    display: block;
    padding: 7px 12px;
    margin: 1px 0;
    color: var(--ink-600);
    text-decoration: none;
    font-size: 13.5px;
    border-radius: var(--r-2);
    border-left: 2px solid transparent;
    transition: all var(--t-fast);
    line-height: 1.35;
}
.help-toc-link:hover { background: var(--paper-2); color: var(--ink-900); text-decoration: none; }
.help-toc-link.is-active {
    background: var(--paper-2);
    color: var(--ink-900);
    border-left-color: var(--ink-900);
    font-weight: 500;
}
[data-theme="dark"] .help-toc-link.is-active { border-left-color: var(--paper); }

.help-search-wrap { position: relative; margin-bottom: 16px; }
.help-search {
    width: 100%;
    padding: 11px 14px 11px 38px;
    background: var(--paper);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-3);
    font-size: 13.5px;
    font-family: var(--font-body);
    color: var(--ink-900);
}
.help-search:focus {
    outline: none;
    border-color: var(--ink-700);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ink-700) 12%, transparent);
}
.help-search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--ink-400);
    pointer-events: none;
}
.help-search-icon svg { width: 16px; height: 16px; }

.help-search-empty {
    padding: 30px 20px;
    text-align: center;
    color: var(--ink-400);
    font-size: 13.5px;
    display: none;
}
.help-search-empty.is-visible { display: block; }

.help-hero {
    border-bottom: 1px solid var(--ink-150);
    padding-bottom: 26px;
    margin-bottom: 32px;
}
.help-hero-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 2.2rem;
    color: var(--ink-900);
    line-height: 1.1;
    letter-spacing: -0.028em;
    margin: 0 0 10px;
}
.help-hero-sub {
    color: var(--ink-500);
    font-size: 15px;
    max-width: 65ch;
    line-height: 1.55;
    margin: 0;
}

.help-section {
    margin-bottom: 56px;
    scroll-margin-top: calc(var(--topbar-h) + 24px);
}
.help-section.is-hidden { display: none; }
.help-section.is-highlight {
    background: color-mix(in srgb, var(--highlight) 30%, transparent);
    border-radius: var(--r-3);
    padding: 8px 12px;
    margin: -8px -12px 48px;
    transition: background 1500ms;
}

.help-section-eyebrow {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-400);
    font-weight: 500;
    margin-bottom: 6px;
}
.help-section-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.65rem;
    color: var(--ink-900);
    letter-spacing: -0.018em;
    line-height: 1.2;
    margin: 0 0 12px;
}
.help-section-lead {
    color: var(--ink-600);
    font-size: 15px;
    line-height: 1.6;
    margin: 0 0 22px;
    max-width: 70ch;
}
.help-section h3 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.18rem;
    color: var(--ink-900);
    margin: 30px 0 10px;
    letter-spacing: -0.012em;
}
.help-section p {
    color: var(--ink-700);
    line-height: 1.65;
    margin: 0 0 14px;
    max-width: 75ch;
}
.help-section ul, .help-section ol {
    color: var(--ink-700);
    line-height: 1.6;
    padding-left: 22px;
    margin: 0 0 14px;
    max-width: 75ch;
}
.help-section li { margin-bottom: 6px; }
.help-section code { font-size: 12px; padding: 1px 7px; }

/* Flow diagram horizontal */
.help-flow {
    display: flex;
    align-items: stretch;
    gap: 0;
    margin: 22px 0 28px;
    padding: 22px;
    background: var(--paper-2);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    overflow-x: auto;
}
.help-flow-step {
    flex: 1;
    min-width: 160px;
    background: var(--paper);
    border: 1px solid var(--ink-200);
    border-radius: var(--r-3);
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    box-shadow: var(--sh-1);
}
.help-flow-step-num {
    font-family: var(--font-mono);
    font-size: 10.5px;
    color: var(--ink-400);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
}
.help-flow-step-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 14px;
    color: var(--ink-900);
    line-height: 1.25;
    display: flex; align-items: center; gap: 6px;
}
.help-flow-step-title svg { width: 14px; height: 14px; stroke-width: 1.75; }
.help-flow-step-desc {
    font-size: 12px;
    color: var(--ink-500);
    line-height: 1.45;
}
.help-flow-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    flex-shrink: 0;
    color: var(--ink-400);
}
.help-flow-arrow svg { width: 16px; height: 16px; }

@media (max-width: 780px) {
    .help-flow { flex-direction: column; }
    .help-flow-arrow { width: auto; height: 32px; transform: rotate(90deg); }
}

/* Vertical pipeline */
.help-pipe {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 18px 0 28px;
    padding-left: 32px;
    position: relative;
}
.help-pipe::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: var(--ink-200);
}
.help-pipe-step {
    position: relative;
    padding: 0 0 18px 18px;
}
.help-pipe-step::before {
    content: '';
    position: absolute;
    left: -25px;
    top: 4px;
    width: 12px; height: 12px;
    background: var(--paper);
    border: 2px solid var(--ink-700);
    border-radius: 50%;
}
.help-pipe-step h4 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 14px;
    color: var(--ink-900);
    margin: 0 0 4px;
}
.help-pipe-step p { font-size: 13.5px; color: var(--ink-600); margin: 0; max-width: 70ch; }

/* Callout */
.help-callout {
    display: flex;
    gap: 12px;
    padding: 14px 16px;
    background: var(--paper-2);
    border: 1px solid var(--ink-150);
    border-left: 3px solid var(--ink-700);
    border-radius: var(--r-2);
    margin: 18px 0 22px;
    font-size: 13.5px;
    color: var(--ink-700);
    line-height: 1.55;
}
.help-callout.is-warning {
    border-left-color: #d97706;
    background: color-mix(in srgb, #d97706 6%, var(--paper-2));
}
.help-callout.is-tip {
    border-left-color: var(--success);
    background: color-mix(in srgb, var(--success) 6%, var(--paper-2));
}
.help-callout svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; color: var(--ink-500); }
.help-callout.is-warning svg { color: #d97706; }
.help-callout.is-tip svg { color: var(--success); }

/* Tarjetas de roles */
.help-roles {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin: 18px 0 22px;
}
.help-role-card {
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    padding: 14px 16px;
    background: var(--paper);
}
.help-role-card h4 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 14px;
    margin: 0 0 4px;
    color: var(--ink-900);
    display: flex; align-items: center; gap: 6px;
}
.help-role-card p { font-size: 12.5px; color: var(--ink-500); margin: 0; line-height: 1.5; }

.help-anchor {
    color: var(--ink-300);
    margin-left: 8px;
    opacity: 0;
    transition: opacity var(--t-fast);
    font-weight: 400;
    text-decoration: none;
    font-size: 0.85em;
}
.help-section-title:hover .help-anchor { opacity: 1; }

/* -- Animations -------------------------------------------- */
@keyframes fade-in {
    from { opacity: 0; transform: translateY(2px); }
    to   { opacity: 1; transform: translateY(0); }
}

.app-content { animation: fade-in 240ms cubic-bezier(0.16, 1, 0.3, 1); }

/* Count-up number reveal */
[data-count-up] {
    font-variant-numeric: tabular-nums;
    transition: color var(--t-base);
}

/* -- Paginator --------------------------------------------- */
.paginator {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 18px;
    padding: 12px 4px;
    flex-wrap: wrap;
    gap: 12px;
}
.paginator-info {
    font-size: 12.5px;
    color: var(--ink-600);
    font-family: var(--font-mono);
}
.paginator-info strong { color: var(--ink-900); font-weight: 600; }

.paginator-pages {
    display: flex;
    gap: 4px;
    align-items: center;
}
.paginator-page {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 9px;
    border: 1px solid var(--ink-150);
    background: var(--paper);
    color: var(--ink-700);
    border-radius: var(--r-2);
    font-size: 12.5px;
    font-weight: 500;
    font-family: var(--font-mono);
    text-decoration: none;
    transition: all var(--t-fast);
}
.paginator-page:hover {
    background: var(--paper-2);
    border-color: var(--ink-300);
    color: var(--ink-900);
    text-decoration: none;
}
.paginator-page.is-current {
    background: var(--ink-900);
    color: var(--paper);
    border-color: var(--ink-900);
    cursor: default;
}
[data-theme="dark"] .paginator-page.is-current { background: var(--paper); color: var(--ink-900); border-color: var(--paper); }
.paginator-page.is-disabled {
    opacity: 0.4;
    pointer-events: none;
    cursor: default;
}
.paginator-page svg { width: 14px; height: 14px; stroke-width: 2; }
.paginator-gap {
    padding: 0 4px;
    color: var(--ink-400);
    font-size: 12px;
    font-family: var(--font-mono);
}

/* -- Bulk actions ------------------------------------------ */
.bulk-checkbox-col {
    width: 36px;
    padding-left: 12px !important;
    padding-right: 4px !important;
}
.bulk-checkbox-col input[type=checkbox] {
    width: 15px;
    height: 15px;
    accent-color: var(--ink-900);
    cursor: pointer;
    margin: 0;
    vertical-align: middle;
}

.table tbody tr.is-selected {
    background: color-mix(in srgb, var(--ink-700) 5%, var(--paper));
}
[data-theme="dark"] .table tbody tr.is-selected {
    background: color-mix(in srgb, var(--paper) 8%, var(--paper-2));
}

/* Wrapper de listado con bulk — contiene la bulk-bar (antes) y el card (después) */
.bulk-list-wrapper { display: block; }

.bulk-bar {
    /* Bloque normal — se desliza con el contenido al scrollear, no tapa el listado */
    position: relative;
    z-index: 5;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 16px 0;
    background: var(--ink-900);
    color: var(--paper);
    border-radius: var(--r-3);
    padding: 12px 18px;
    display: flex;
    align-items: center;
    gap: 14px;
    box-shadow: var(--sh-pop);
    animation: bulk-bar-in 220ms cubic-bezier(0.16, 1, 0.3, 1);
}

[data-theme="dark"] .bulk-bar {
    background: var(--paper);
    color: var(--ink-900);
}
@keyframes bulk-bar-in {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.bulk-bar-count {
    font-family: var(--font-mono);
    font-size: 13px;
    padding: 4px 10px;
    background: color-mix(in srgb, var(--paper) 14%, transparent);
    border-radius: var(--r-2);
    white-space: nowrap;
}
[data-theme="dark"] .bulk-bar-count {
    background: color-mix(in srgb, var(--ink-900) 14%, transparent);
}

.bulk-bar-actions {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
}

.bulk-bar-actions .btn {
    background: transparent;
    color: var(--paper);
    border-color: color-mix(in srgb, var(--paper) 25%, transparent);
    text-transform: none;
    letter-spacing: 0;
    font-family: var(--font-body);
}
.bulk-bar-actions .btn:hover {
    background: color-mix(in srgb, var(--paper) 14%, transparent);
    color: var(--paper);
}
.bulk-bar-actions .btn.is-danger {
    color: #fca5a5;
    border-color: color-mix(in srgb, #fca5a5 30%, transparent);
}
.bulk-bar-actions .btn.is-danger:hover {
    background: color-mix(in srgb, #ef4444 18%, transparent);
    color: #fef2f2;
}

[data-theme="dark"] .bulk-bar-actions .btn {
    color: var(--ink-900);
    border-color: color-mix(in srgb, var(--ink-900) 25%, transparent);
}
[data-theme="dark"] .bulk-bar-actions .btn:hover {
    background: color-mix(in srgb, var(--ink-900) 12%, transparent);
    color: var(--ink-900);
}

.bulk-bar-close {
    background: transparent;
    border: none;
    color: color-mix(in srgb, var(--paper) 60%, transparent);
    cursor: pointer;
    padding: 4px;
    margin-left: 4px;
    display: grid;
    place-items: center;
}
.bulk-bar-close:hover { color: var(--paper); }
.bulk-bar-close svg { width: 16px; height: 16px; }
[data-theme="dark"] .bulk-bar-close { color: color-mix(in srgb, var(--ink-900) 60%, transparent); }
[data-theme="dark"] .bulk-bar-close:hover { color: var(--ink-900); }

/* -- Filter bar -------------------------------------------- */
.filter-bar {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    padding: 14px 16px;
    background: var(--paper-2);
    border: 1px solid var(--ink-150);
    border-radius: var(--r-3);
    margin-bottom: 16px;
}
.filter-bar > * { margin: 0; }
.filter-bar input.form-control,
.filter-bar select.form-select {
    background: var(--paper);
}
.filter-bar .filter-grow { flex: 1; min-width: 180px; }
.filter-bar .filter-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-400);
    font-weight: 500;
    margin-right: 4px;
}
.filter-active-count {
    background: var(--ink-900);
    color: var(--paper);
    border-radius: 9999px;
    font-size: 10px;
    padding: 2px 7px;
    font-weight: 600;
    margin-left: 4px;
}
[data-theme="dark"] .filter-active-count { background: var(--paper); color: var(--ink-900); }
