/*
 * Oula Redesign — Design tokens + base + primitives
 *
 * All selectors are prefixed with `oula-` to avoid colliding with
 * Bootstrap / Velzon classes. CSS custom properties live on `:root`
 * with the `--oula-*` namespace so they are safe globally.
 *
 * Apply `.oula-scope` to the body of pages that use the Oula layout
 * to pick up typography + background.
 */

/* ───────────── Design tokens ───────────── */
:root {
    /* Marca */
    --oula-deep:         #0D2B26;
    --oula-deep-800:     #133A32;
    --oula-deep-700:     #1C4D43;
    --oula-deep-600:     #2A6558;
    --oula-electric:     #C7FC57;
    --oula-electric-600: #B3F03A;
    --oula-electric-200: #E5FBA4;
    --oula-neutral:      #5ED187;
    --oula-neutral-200:  #C9EED9;
    --oula-neutral-50:   #EAF8F0;

    /* Paper & neutrals */
    --oula-paper:   #F6F4EE;
    --oula-paper-2: #EEEBE1;
    --oula-card:    #FFFFFF;
    --oula-line:    #E5E2D8;
    --oula-line-2:  #DCD8CB;

    /* Texto */
    --oula-ink:    #0B1D1A;
    --oula-ink-2:  #2A3A36;
    --oula-mute:   #6B7874;
    --oula-mute-2: #99A19D;

    /* Semántico */
    --oula-danger:     #D94A38;
    --oula-danger-50:  #FBE8E4;
    --oula-warn:       #E8A33A;
    --oula-warn-50:    #FBEED6;
    --oula-info:       #4A6CF0;
    --oula-info-50:    #E4EAFD;
    --oula-ok:         #2E8B5C;
    --oula-ok-50:      #DDF1E5;

    /* Sombras */
    --oula-shadow-1: 0 1px 2px rgba(13,43,38,0.05), 0 1px 1px rgba(13,43,38,0.03);
    --oula-shadow-2: 0 1px 3px rgba(13,43,38,0.06), 0 8px 24px rgba(13,43,38,0.05);
    --oula-shadow-3: 0 10px 40px rgba(13,43,38,0.12), 0 2px 6px rgba(13,43,38,0.06);

    /* Fuentes */
    --oula-font:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --oula-display: 'Fraunces', 'Times New Roman', serif;
    --oula-mono:    'JetBrains Mono', 'SF Mono', ui-monospace, monospace;

    /* Radios */
    --oula-radius-sm: 6px;
    --oula-radius-md: 8px;
    --oula-radius-lg: 14px;
    --oula-radius-pill: 999px;
}

/* ───────────── Base (body scoped) ───────────── */
.oula-scope {
    font-family: var(--oula-font);
    color: var(--oula-ink);
    background: var(--oula-paper);
    padding: 6px 0 0 6px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: 'ss01', 'cv02';
}

.oula-scope * {
    box-sizing: border-box;
}

/* ───────────── Utilities ───────────── */
.oula-font-display { font-family: var(--oula-display); font-weight: 500; letter-spacing: -0.6px; }
.oula-font-mono    { font-family: var(--oula-mono); }
.oula-tabular      { font-variant-numeric: tabular-nums; }
.oula-uppercase    { text-transform: uppercase; letter-spacing: 1px; font-weight: 700; }

/* ───────────── App frame ───────────── */
.oula-frame {
    display: flex;
    min-height: calc(100vh - 6px);
    background: var(--oula-paper);
}

.oula-frame__main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.oula-frame__content {
    flex: 1;
    overflow: auto;
    padding: 24px 28px;
}

.oula-frame__content--bleed {
    padding: 0;
}

.oula-frame__content--kanban {
    overflow: hidden;
    padding: 0;
}

/* ───────────── Sidebar (248px, deep) ───────────── */
.oula-sidebar {
    width: 248px;
    background: var(--oula-deep);
    color: #fff;
    display: flex;
    flex-direction: column;
    padding: 18px 16px;
    border-right: 1px solid var(--oula-deep-700);
    border-top-left-radius: 14px;
    flex-shrink: 0;
}

.oula-sidebar__brand {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 4px 4px 18px;
}

.oula-sidebar__tenant-badge {
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.6px;
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(199, 252, 87, 0.12);
    color: var(--oula-electric);
}

.oula-sidebar__tenant {
    padding: 10px 12px;
    border-radius: 10px;
    background: var(--oula-deep-800);
    border: 1px solid var(--oula-deep-700);
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    margin-bottom: 14px;
    text-decoration: none;
    color: inherit;
}

.oula-sidebar__tenant-avatar {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--oula-electric);
    color: var(--oula-deep);
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 13px;
    flex-shrink: 0;
}

.oula-sidebar__tenant-name {
    font-size: 12.5px;
    font-weight: 600;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.oula-sidebar__tenant-sub {
    font-size: 10.5px;
    color: rgba(255, 255, 255, 0.5);
}

.oula-sidebar__section {
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 1.4px;
    color: rgba(255, 255, 255, 0.38);
    text-transform: uppercase;
    padding: 18px 12px 6px;
}

.oula-sidebar__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 8px;
    cursor: pointer;
    color: rgba(255, 255, 255, 0.78);
    font-size: 13.5px;
    font-weight: 500;
    text-decoration: none;
    position: relative;
    transition: background 120ms ease, color 120ms ease;
}

.oula-sidebar__item:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
}

.oula-sidebar__item.is-active {
    background: rgba(199, 252, 87, 0.12);
    color: var(--oula-electric);
    font-weight: 600;
}

.oula-sidebar__item.is-active::before {
    content: "";
    position: absolute;
    left: -16px;
    top: 6px;
    bottom: 6px;
    width: 3px;
    background: var(--oula-electric);
    border-radius: 99px;
}

.oula-sidebar__item-label {
    flex: 1;
}

.oula-sidebar__item-icon {
    flex-shrink: 0;
    opacity: 0.72;
    color: currentColor;
}

.oula-sidebar__item:hover .oula-sidebar__item-icon,
.oula-sidebar__item.is-active .oula-sidebar__item-icon {
    opacity: 1;
}

.oula-sidebar__badge {
    font-size: 11px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 99px;
    background: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.85);
    font-variant-numeric: tabular-nums;
}

.oula-sidebar__item.is-active .oula-sidebar__badge {
    background: var(--oula-electric);
    color: var(--oula-deep);
}

.oula-sidebar__copilot {
    margin-top: 14px;
    padding: 12px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--oula-deep-700), var(--oula-deep-600));
    border: 1px solid var(--oula-deep-600);
}

.oula-sidebar__copilot-label {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
    font-size: 11.5px;
    font-weight: 700;
    color: var(--oula-electric);
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.oula-sidebar__copilot-body {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.4;
}

.oula-sidebar__copilot-cta {
    margin-top: 8px;
    width: 100%;
    height: 28px;
    background: var(--oula-electric);
    color: var(--oula-deep);
    border: 0;
    border-radius: 6px;
    font-size: 11.5px;
    font-weight: 700;
    font-family: var(--oula-font);
    cursor: pointer;
}

.oula-sidebar__spacer {
    flex: 1;
}

/* ───────────── Help secondary nav (220px) ───────────── */
.oula-help-nav {
    width: 220px;
    min-width: 220px;
    background: var(--oula-paper2, #EEEBE1);
    border-right: 1px solid var(--oula-line, #E5E2D8);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    padding: 20px 0 24px;
    flex-shrink: 0;
}

.oula-help-nav__heading {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.9px;
    color: var(--oula-mute, #6B7874);
    padding: 0 16px 10px;
    margin-bottom: 4px;
    border-bottom: 1px solid var(--oula-line, #E5E2D8);
}

.oula-help-nav__section {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--oula-mute, #6B7874);
    padding: 14px 16px 4px;
}

.oula-help-nav__section:first-of-type { padding-top: 8px; }

.oula-help-nav__item {
    display: block;
    padding: 7px 16px 7px 18px;
    font-size: 13px;
    font-weight: 500;
    color: #2A3A36;
    text-decoration: none;
    border-left: 2px solid transparent;
    transition: background 0.12s, color 0.12s;
    line-height: 1.4;
}

.oula-help-nav__item:hover {
    background: rgba(13, 43, 38, 0.06);
    color: var(--oula-deep, #0D2B26);
    text-decoration: none;
}

.oula-help-nav__item.is-active {
    color: var(--oula-deep, #0D2B26);
    font-weight: 600;
    background: rgba(13, 43, 38, 0.08);
    border-left-color: var(--oula-deep, #0D2B26);
}

/* ───────────── Header (52px) ───────────── */
.oula-header {
    height: 52px;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    border-bottom: 1px solid var(--oula-line);
}

.oula-header__search {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 12px;
    border-radius: 8px;
    background: var(--oula-paper);
    border: 1px solid var(--oula-line);
    width: 360px;
}

.oula-header__search input {
    border: 0;
    background: transparent;
    outline: none;
    flex: 1;
    font-size: 13px;
    font-family: var(--oula-font);
    color: var(--oula-ink);
}

.oula-header__kbd {
    font-size: 10.5px;
    color: var(--oula-mute);
    padding: 2px 6px;
    border: 1px solid var(--oula-line);
    border-radius: 4px;
    background: #fff;
    font-family: var(--oula-mono);
}

.oula-header__right {
    display: flex;
    gap: 14px;
    align-items: center;
}

/* Mobile hamburger inside oula-header — hidden on desktop */
.oula-header__mobile-hamburger {
    display: none;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 0;
    background: transparent;
    color: var(--oula-ink-2);
    cursor: pointer;
    flex-shrink: 0;
    border-radius: 8px;
    padding: 0;
}

.oula-header__bell {
    position: relative;
    border: 0;
    background: transparent;
    padding: 6px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--oula-ink-2);
}

.oula-header__bell-dot {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 7px;
    height: 7px;
    border-radius: 7px;
    background: var(--oula-danger);
    border: 1.5px solid #fff;
}

.oula-header__divider {
    width: 1px;
    height: 22px;
    background: var(--oula-line);
}

.oula-header__user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.oula-header__user-name {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--oula-ink);
    line-height: 1.1;
    text-align: right;
}

.oula-header__user-role {
    font-size: 10.5px;
    color: var(--oula-mute);
    text-align: right;
}

/* ───────────── Topbar ───────────── */
.oula-topbar {
    padding: 18px 28px 16px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    border-bottom: 1px solid var(--oula-line);
    background: var(--oula-paper);
    gap: 24px;
}

.oula-topbar__crumbs {
    font-size: 12px;
    color: var(--oula-mute);
    margin-bottom: 6px;
    display: flex;
    gap: 6px;
    align-items: center;
}

.oula-topbar__crumbs-sep {
    color: var(--oula-mute-2);
}

.oula-topbar__title {
    font-family: var(--oula-display);
    font-weight: 500;
    font-size: 26px;
    color: var(--oula-ink);
    letter-spacing: -0.6px;
    line-height: 1.1;
}

.oula-topbar__subtitle {
    font-size: 13.5px;
    color: var(--oula-mute);
    margin-top: 4px;
}

.oula-topbar__right {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* ───────────── Card ───────────── */
.oula-card {
    background: var(--oula-card);
    border-radius: var(--oula-radius-lg);
    border: 1px solid var(--oula-line);
    box-shadow: var(--oula-shadow-1);
}

.oula-card__header {
    padding: 16px 20px 12px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.oula-card__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--oula-ink);
    letter-spacing: -0.1px;
}

.oula-card__subtitle {
    font-size: 12.5px;
    color: var(--oula-mute);
    margin-top: 2px;
}

.oula-card__body {
    padding: 0 20px 20px;
}

.oula-card__body--pad {
    padding: 20px;
}

/* ───────────── Button ───────────── */
.oula-btn {
    height: 36px;
    padding: 0 14px;
    border-radius: 8px;
    border: 1px solid transparent;
    font-family: var(--oula-font);
    font-size: 13.5px;
    font-weight: 600;
    letter-spacing: -0.1px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease, transform 80ms ease;
    text-decoration: none;
}

.oula-btn:focus-visible {
    outline: 2px solid var(--oula-electric-600);
    outline-offset: 2px;
}

.oula-btn:active { transform: translateY(1px); }

.oula-btn--sm { height: 30px; padding: 0 12px; font-size: 13px; }
.oula-btn--lg { height: 44px; padding: 0 20px; font-size: 15px; }

.oula-btn--primary  { background: var(--oula-deep); color: #fff; }
.oula-btn--primary:hover  { background: var(--oula-deep-800); }

.oula-btn--accent   { background: var(--oula-electric); color: var(--oula-deep); }
.oula-btn--accent:hover   { background: var(--oula-electric-600); }

.oula-btn--ghost    { background: transparent; color: var(--oula-ink); border-color: var(--oula-line-2); }
.oula-btn--ghost:hover    { background: var(--oula-paper-2); }

.oula-btn--subtle   { background: var(--oula-paper-2); color: var(--oula-ink); }
.oula-btn--subtle:hover   { background: var(--oula-line); }

.oula-btn--danger   { background: #fff; color: var(--oula-danger); border-color: var(--oula-danger-50); }
.oula-btn--danger:hover   { background: var(--oula-danger-50); }

.oula-btn--on-dark  { background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.12); }
.oula-btn--on-dark:hover  { background: rgba(255,255,255,0.14); }

.oula-btn--block    { width: 100%; justify-content: center; }

/* ───────────── Avatar ───────────── */
.oula-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-family: var(--oula-font);
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

/* ───────────── Chips (state / priority / SLA / channel) ───────────── */
.oula-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 99px;
    font-size: 12px;
    font-weight: 600;
    font-family: var(--oula-font);
    letter-spacing: 0.1px;
    line-height: 1.2;
}

.oula-chip--sm { padding: 3px 8px; font-size: 11px; }

.oula-chip__dot {
    width: 6px;
    height: 6px;
    border-radius: 6px;
    background: currentColor;
    flex-shrink: 0;
}

/* State chips — 9 canonical states */
.oula-chip--state-creado     { background: #F0EDE3; color: var(--oula-ink-2); }
.oula-chip--state-creado .oula-chip__dot     { background: var(--oula-mute); }

.oula-chip--state-asignada   { background: var(--oula-info-50); color: #2B3F96; }
.oula-chip--state-asignada .oula-chip__dot   { background: var(--oula-info); }

.oula-chip--state-en_proceso { background: var(--oula-warn-50); color: #7A5418; }
.oula-chip--state-en_proceso .oula-chip__dot { background: var(--oula-warn); }

.oula-chip--state-en_espera  { background: #F0EDE3; color: #4A5550; }
.oula-chip--state-en_espera .oula-chip__dot  { background: #8A938E; }

.oula-chip--state-revisada   { background: var(--oula-neutral-50); color: #1F6847; }
.oula-chip--state-revisada .oula-chip__dot   { background: var(--oula-neutral); }

.oula-chip--state-completada { background: var(--oula-neutral-50); color: #1F6847; }
.oula-chip--state-completada .oula-chip__dot { background: var(--oula-ok); }

.oula-chip--state-rechazada  { background: var(--oula-danger-50); color: #7A231A; }
.oula-chip--state-rechazada .oula-chip__dot  { background: var(--oula-danger); }

.oula-chip--state-cancelada  { background: #F0EDE3; color: var(--oula-mute); }
.oula-chip--state-cancelada .oula-chip__dot  { background: var(--oula-mute-2); }

.oula-chip--state-reabierta  { background: #F4E4FB; color: #5A1E78; }
.oula-chip--state-reabierta .oula-chip__dot  { background: #8B3FB0; }

.oula-chip--state-archivada  { background: #E5E2D8; color: #4A5550; }
.oula-chip--state-archivada .oula-chip__dot  { background: #6B7874; }

/* Priority chip — square left bar + uppercase */
.oula-chip--prio {
    padding: 2px 8px 2px 6px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    gap: 6px;
}

.oula-chip--prio .oula-chip__bar {
    width: 3px;
    height: 10px;
    border-radius: 2px;
    flex-shrink: 0;
}

.oula-chip--prio-alta  { background: var(--oula-danger-50); color: #7A231A; }
.oula-chip--prio-alta .oula-chip__bar  { background: var(--oula-danger); }
.oula-chip--prio-media { background: var(--oula-warn-50); color: #7A5418; }
.oula-chip--prio-media .oula-chip__bar { background: var(--oula-warn); }
.oula-chip--prio-baja  { background: var(--oula-neutral-50); color: #1F6847; }
.oula-chip--prio-baja .oula-chip__bar  { background: var(--oula-neutral); }
.oula-chip--prio-sin   { background: #F0EDE3; color: var(--oula-mute); }
.oula-chip--prio-sin .oula-chip__bar   { background: var(--oula-mute-2); }

/* SLA pill — tabular nums, 5 kinds */
.oula-chip--sla {
    font-variant-numeric: tabular-nums;
    border-radius: 999px;
}

.oula-chip--sla-ok       { background: var(--oula-neutral-50); color: #1F6847; }
.oula-chip--sla-ok .oula-chip__dot       { background: var(--oula-ok); }
.oula-chip--sla-warn     { background: var(--oula-warn-50); color: #7A5418; }
.oula-chip--sla-warn .oula-chip__dot     { background: var(--oula-warn); }
.oula-chip--sla-danger   { background: var(--oula-danger-50); color: #7A231A; }
.oula-chip--sla-danger .oula-chip__dot   { background: var(--oula-danger); }
.oula-chip--sla-resolved { background: #EAF3ED; color: #2E5E45; }
.oula-chip--sla-resolved .oula-chip__dot { background: var(--oula-ok); }
.oula-chip--sla-none     { background: #F0EDE3; color: var(--oula-mute); }
.oula-chip--sla-none .oula-chip__dot     { background: var(--oula-mute-2); }

/* Channel chip — icon + label */
.oula-chip--channel {
    padding: 2px 8px 2px 6px;
    border-radius: 99px;
    gap: 5px;
    font-size: 11px;
}

.oula-chip--channel-email    { background: var(--oula-info-50); color: #2B3F96; }
.oula-chip--channel-whatsapp { background: #DDF1E5; color: #1F6847; }
.oula-chip--channel-form     { background: #F4E4FB; color: #5A1E78; }
.oula-chip--channel-manual   { background: #F0EDE3; color: var(--oula-ink-2); }
.oula-chip--channel-api      { background: #E8EBE5; color: var(--oula-deep); }

.oula-chip__icon {
    width: 11px;
    height: 11px;
    flex-shrink: 0;
}

/* ───────────── Toggle (switch) ───────────── */
.oula-toggle {
    --oula-toggle-w: 38px;
    --oula-toggle-h: 22px;
    --oula-toggle-knob: 16px;
    --oula-toggle-pad: 3px;

    position: relative;
    display: inline-block;
    width: var(--oula-toggle-w);
    height: var(--oula-toggle-h);
    flex-shrink: 0;
}

.oula-toggle--sm {
    --oula-toggle-w: 32px;
    --oula-toggle-h: 18px;
    --oula-toggle-knob: 12px;
    --oula-toggle-pad: 3px;
}

.oula-toggle input {
    position: absolute;
    opacity: 0;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    cursor: pointer;
}

.oula-toggle__track {
    position: absolute;
    inset: 0;
    background: var(--oula-line);
    border: 1px solid var(--oula-line-2);
    border-radius: 999px;
    transition: background 150ms ease, border-color 150ms ease;
}

.oula-toggle__knob {
    position: absolute;
    top: var(--oula-toggle-pad);
    left: var(--oula-toggle-pad);
    width: var(--oula-toggle-knob);
    height: var(--oula-toggle-knob);
    border-radius: 99px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(13, 43, 38, 0.2);
    transition: left 150ms ease, background 150ms ease;
}

.oula-toggle input:checked ~ .oula-toggle__track {
    background: var(--oula-deep);
    border-color: var(--oula-deep-800);
}

.oula-toggle input:checked ~ .oula-toggle__knob {
    left: calc(100% - var(--oula-toggle-knob) - var(--oula-toggle-pad));
    background: var(--oula-electric);
}

.oula-toggle input:focus-visible ~ .oula-toggle__track {
    outline: 2px solid var(--oula-electric-600);
    outline-offset: 2px;
}

/* ───────────── Inputs base (scoped) ───────────── */
.oula-input {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 12px;
    border: 1px solid var(--oula-line-2);
    border-radius: 8px;
    background: var(--oula-card);
    height: 44px;
    font-family: var(--oula-font);
    font-size: 14px;
    color: var(--oula-ink);
}

.oula-input--sm { height: 36px; font-size: 13px; }

.oula-input input,
.oula-input select {
    flex: 1;
    border: 0;
    outline: none;
    background: transparent;
    font-size: inherit;
    color: inherit;
    font-family: inherit;
}

.oula-input:focus-within {
    border-color: var(--oula-deep-600);
    box-shadow: 0 0 0 3px rgba(13, 43, 38, 0.08);
}

.oula-field-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    display: block;
    margin-bottom: 6px;
}

/* ───────────── Auth / Login split ───────────── */
.oula-login {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    min-height: 100vh;
    background: var(--oula-paper);
}

@media (max-width: 900px) {
    .oula-login { grid-template-columns: 1fr; }
    .oula-login__hero { min-height: 320px; }
}

.oula-login__hero {
    background: var(--oula-deep);
    color: #fff;
    padding: 48px 56px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.oula-login__burst {
    position: absolute;
    right: -140px;
    bottom: -140px;
    opacity: 0.1;
    pointer-events: none;
    z-index: 0;
}

.oula-login__logo {
    position: relative;
    z-index: 1;
}

.oula-login__hero-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 520px;
    position: relative;
    z-index: 1;
}

.oula-login__eyebrow {
    font-size: 12px;
    font-weight: 700;
    color: var(--oula-electric);
    letter-spacing: 1.6px;
    text-transform: uppercase;
    margin-bottom: 16px;
}

.oula-login__title {
    font-family: var(--oula-display);
    font-size: 56px;
    font-weight: 500;
    letter-spacing: -2px;
    line-height: 1.05;
    margin: 0 0 20px;
}

.oula-login__title-em {
    font-style: italic;
    color: var(--oula-electric);
}

.oula-login__desc {
    font-size: 16px;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.75);
    margin: 0;
    max-width: 460px;
}

.oula-login__stats {
    display: flex;
    gap: 22px;
    margin: 36px 0 0;
    padding: 0;
    flex-wrap: wrap;
}

.oula-login__stats dt,
.oula-login__stats dd {
    margin: 0;
    padding: 0;
}

.oula-login__stat-num {
    font-family: var(--oula-display);
    font-size: 30px;
    font-weight: 500;
    letter-spacing: -1px;
    color: var(--oula-electric);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.oula-login__stat-label {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.6);
    margin-top: 6px;
    line-height: 1.3;
    max-width: 120px;
}

.oula-login__legal {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    position: relative;
    z-index: 1;
}

.oula-login__form {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 32px;
}

.oula-login__form-wrap {
    width: 100%;
    max-width: 380px;
}

.oula-login__form-title {
    font-family: var(--oula-display);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: -0.8px;
    color: var(--oula-ink);
    margin: 0 0 6px;
}

.oula-login__form-subtitle {
    font-size: 13.5px;
    color: var(--oula-mute);
    margin: 0 0 28px;
}

.oula-login__sso {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 20px;
}

.oula-login__sso-btn {
    height: 44px;
    border: 1px solid var(--oula-line);
    background: var(--oula-card);
    border-radius: 8px;
    font-family: var(--oula-font);
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    text-decoration: none;
    transition: background 120ms ease, border-color 120ms ease;
}

.oula-login__sso-btn:hover:not(:disabled) {
    background: var(--oula-paper);
    border-color: var(--oula-line-2);
}

.oula-login__sso-btn:disabled,
.oula-login__sso-btn[aria-disabled="true"] {
    opacity: 0.55;
    cursor: not-allowed;
}

.oula-login__sso-btn svg {
    flex-shrink: 0;
}

.oula-input__icon {
    color: var(--oula-mute);
    flex-shrink: 0;
}

.oula-login__divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 20px 0;
}

.oula-login__divider::before,
.oula-login__divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--oula-line);
}

.oula-login__divider-text {
    font-size: 11px;
    color: var(--oula-mute);
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.oula-login__field {
    margin-bottom: 10px;
}

.oula-login__error {
    color: var(--oula-danger);
    font-size: 12px;
    margin-top: 2px;
    min-height: 0;
}

.oula-login__error:empty {
    display: none;
}

.oula-login__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 12px;
    margin-bottom: 20px;
}

.oula-login__remember {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    color: var(--oula-ink-2);
    cursor: pointer;
    margin: 0;
}

.oula-login__remember input {
    accent-color: var(--oula-deep);
    margin: 0;
}

.oula-login__forgot {
    font-size: 12.5px;
    color: var(--oula-deep);
    font-weight: 600;
    text-decoration: none;
}

.oula-login__forgot:hover { text-decoration: underline; }

.oula-login__callout {
    margin-top: 20px;
    padding: 14px;
    background: var(--oula-electric-200);
    border-radius: 10px;
    border: 1px solid #B8D071;
    display: flex;
    gap: 10px;
    font-size: 12px;
    color: #3F5615;
    line-height: 1.5;
}

.oula-login__callout-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--oula-electric-600);
}

.oula-login__callout a {
    color: var(--oula-deep);
    font-weight: 600;
    text-decoration: none;
}

.oula-login__callout a:hover { text-decoration: underline; }

/* Neutralize Bootstrap .form-control that sneaks in via yii\bootstrap5\ActiveForm */
.oula-input .form-control,
.oula-input input {
    box-shadow: none;
    padding: 0;
    background: transparent;
    border: 0;
    height: auto;
    color: inherit;
    font-size: inherit;
}

.oula-input .form-control:focus,
.oula-input input:focus {
    box-shadow: none;
    background: transparent;
}

/* ═══════════════════════════════════════════════════════
   Dashboard
   ═══════════════════════════════════════════════════════ */

.oula-dash__grid {
    display: grid;
    gap: 16px;
}

.oula-dash__grid--hero {
    grid-template-columns: 1.4fr 1fr;
    margin-bottom: 16px;
}

.oula-dash__grid--kpi {
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 16px;
}

.oula-dash__grid--middle {
    grid-template-columns: 1.8fr 1fr;
    margin-bottom: 16px;
}

.oula-dash__grid--bottom {
    grid-template-columns: 1fr 1fr;
}

@media (max-width: 1200px) {
    .oula-dash__grid--hero,
    .oula-dash__grid--middle,
    .oula-dash__grid--bottom { grid-template-columns: 1fr; }
    .oula-dash__grid--kpi { grid-template-columns: repeat(2, 1fr); }
}

/* ───── Hero: Execution Score ───── */
.oula-hero-score {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--oula-deep) 0%, var(--oula-deep-700) 100%);
    color: #fff;
    border-radius: 16px;
    padding: 24px;
    border: 1px solid var(--oula-deep-700);
}

.oula-hero-score__burst {
    position: absolute;
    right: -60px;
    top: -60px;
    opacity: 0.14;
    pointer-events: none;
}

.oula-hero-score__eyebrow {
    font-size: 11px;
    font-weight: 700;
    color: var(--oula-electric);
    letter-spacing: 1.4px;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.oula-hero-score__headline {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: -0.3px;
    font-family: var(--oula-display);
    color: #fff;
    max-width: 440px;
    margin: 0 0 16px;
    line-height: 1.25;
    position: relative;
}

.oula-hero-score__headline em {
    color: var(--oula-electric);
    font-style: italic;
}

.oula-hero-score__body {
    display: flex;
    align-items: center;
    gap: 28px;
    position: relative;
}

.oula-dial {
    position: relative;
    width: 130px;
    height: 130px;
    flex-shrink: 0;
}

.oula-dial__inner {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    text-align: center;
}

.oula-dial__num {
    font-family: var(--oula-display);
    font-size: 42px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -2px;
}

.oula-dial__max {
    font-size: 10.5px;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 1px;
    margin-top: 3px;
    text-transform: uppercase;
    font-weight: 600;
}

.oula-hero-score__metrics {
    flex: 1;
}

.oula-hero-score__metrics-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}

.oula-mini-metric__label {
    font-size: 10.5px;
    color: rgba(255, 255, 255, 0.55);
    letter-spacing: 0.8px;
    text-transform: uppercase;
    font-weight: 600;
}

.oula-mini-metric__value-row {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-top: 3px;
}

.oula-mini-metric__value {
    font-size: 19px;
    font-weight: 600;
    color: #fff;
    letter-spacing: -0.4px;
    font-variant-numeric: tabular-nums;
}

.oula-mini-metric__delta {
    font-size: 10.5px;
    font-weight: 600;
    color: var(--oula-electric);
}

.oula-mini-metric__delta--warn { color: var(--oula-warn); }
.oula-mini-metric__delta--muted { color: rgba(255, 255, 255, 0.55); }

.oula-hero-score__cta {
    display: flex;
    gap: 8px;
}

/* ───── Hero: SLA Ribbon ───── */
.oula-sla-card {
    background: var(--oula-card);
    border-radius: 16px;
    padding: 22px;
    border: 1px solid var(--oula-line);
}

.oula-sla-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 14px;
    gap: 12px;
}

.oula-sla-card__eyebrow {
    font-size: 11px;
    font-weight: 700;
    color: var(--oula-mute);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.oula-sla-card__title {
    font-size: 19px;
    font-weight: 600;
    color: var(--oula-ink);
    letter-spacing: -0.4px;
    font-family: var(--oula-display);
}

.oula-sla-ribbon {
    display: flex;
    height: 10px;
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: 18px;
    border: 1px solid var(--oula-line);
}

.oula-sla-ribbon__lane--danger  { background: var(--oula-danger); }
.oula-sla-ribbon__lane--warn    { background: var(--oula-warn); }
.oula-sla-ribbon__lane--ok      { background: var(--oula-neutral); }

.oula-sla-lanes {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.oula-sla-lane {
    display: flex;
    align-items: center;
    gap: 10px;
}

.oula-sla-lane__dot {
    width: 8px;
    height: 8px;
    border-radius: 8px;
    flex-shrink: 0;
}

.oula-sla-lane__dot--danger { background: var(--oula-danger); }
.oula-sla-lane__dot--warn   { background: var(--oula-warn); }
.oula-sla-lane__dot--ok     { background: var(--oula-neutral); }

.oula-sla-lane__label {
    font-size: 12px;
    color: var(--oula-ink-2);
    font-weight: 500;
}

.oula-sla-lane__sub {
    font-size: 10.5px;
    color: var(--oula-mute);
    margin-top: 1px;
}

.oula-sla-lane__count {
    font-size: 17px;
    font-weight: 600;
    color: var(--oula-ink);
    font-variant-numeric: tabular-nums;
    font-family: var(--oula-display);
}

/* ───── KPI tiles ───── */
.oula-kpi {
    background: var(--oula-card);
    border-radius: 14px;
    border: 1px solid var(--oula-line);
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
    text-decoration: none;
    color: inherit;
}

.oula-kpi:hover {
    transform: translateY(-1px);
    box-shadow: var(--oula-shadow-2);
    border-color: var(--oula-line-2);
}

.oula-kpi--danger { border-color: rgba(217, 74, 56, 0.35); }

.oula-kpi__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.oula-kpi__label {
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.oula-kpi__icon {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    background: var(--oula-paper-2);
    color: var(--oula-ink-2);
}

.oula-kpi__icon--danger   { background: var(--oula-danger-50); color: var(--oula-danger); }
.oula-kpi__icon--warn     { background: var(--oula-warn-50);   color: var(--oula-warn); }
.oula-kpi__icon--positive { background: var(--oula-ok-50);     color: var(--oula-ok); }

.oula-kpi__body {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
}

.oula-kpi__value {
    font-family: var(--oula-display);
    font-size: 32px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -1.2px;
    color: var(--oula-ink);
    font-variant-numeric: tabular-nums;
}

.oula-kpi__value--danger   { color: var(--oula-danger); }
.oula-kpi__value--positive { color: var(--oula-ok); }

.oula-kpi__delta {
    font-size: 11.5px;
    font-weight: 600;
    margin-top: 6px;
}

.oula-kpi__delta--up   { color: var(--oula-ok); }
.oula-kpi__delta--down { color: var(--oula-danger); }
.oula-kpi__delta--flat { color: var(--oula-mute); }

.oula-kpi__spark {
    flex-shrink: 0;
    opacity: 0.8;
}

/* ───── Requires Action ───── */
.oula-requires {
    background: var(--oula-card);
    border-radius: 16px;
    border: 1px solid var(--oula-line);
    overflow: hidden;
}

.oula-requires__head {
    padding: 18px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--oula-line);
    gap: 12px;
    flex-wrap: wrap;
}

.oula-requires__head-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.oula-requires__bang {
    width: 24px;
    height: 24px;
    border-radius: 6px;
    background: var(--oula-danger-50);
    color: var(--oula-danger);
    display: grid;
    place-items: center;
}

.oula-requires__title {
    font-size: 15px;
    font-weight: 600;
    color: var(--oula-ink);
}

.oula-requires__count {
    font-size: 11.5px;
    font-weight: 600;
    padding: 2px 7px;
    border-radius: 99px;
    background: var(--oula-danger-50);
    color: #7A231A;
}

.oula-requires__sub {
    font-size: 12.5px;
    color: var(--oula-mute);
    margin-top: 3px;
}

.oula-requires__row {
    padding: 12px 22px;
    display: grid;
    grid-template-columns: 56px 1fr auto auto auto;
    gap: 14px;
    align-items: center;
    border-bottom: 1px solid var(--oula-line);
    border-left: 3px solid var(--oula-mute-2);
    text-decoration: none;
    color: inherit;
    transition: background 120ms ease;
}

.oula-requires__row:last-child { border-bottom: none; }
.oula-requires__row:hover { background: var(--oula-paper); }
.oula-requires__row--alta  { border-left-color: var(--oula-danger); }
.oula-requires__row--media { border-left-color: var(--oula-warn); }
.oula-requires__row--baja  { border-left-color: var(--oula-neutral); }

.oula-requires__id {
    font-size: 11.5px;
    font-weight: 700;
    color: var(--oula-mute);
    font-family: var(--oula-mono);
}

.oula-requires__title-cell { min-width: 0; }

.oula-requires__subject {
    font-size: 13px;
    font-weight: 500;
    color: var(--oula-ink);
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.oula-requires__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 5px;
    font-size: 11px;
    color: var(--oula-mute);
}

.oula-requires__owner {
    display: flex;
    align-items: center;
    gap: 8px;
}

.oula-requires__empty {
    padding: 48px 24px;
    text-align: center;
    color: var(--oula-mute);
    font-size: 13px;
}

/* ───── Asistente IA column ───── */
.oula-copilot {
    background: var(--oula-deep);
    border-radius: 16px;
    padding: 20px;
    color: #fff;
    border: 1px solid var(--oula-deep-700);
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.oula-copilot__head {
    display: flex;
    align-items: center;
    gap: 10px;
}

.oula-copilot__badge {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: var(--oula-electric);
    color: var(--oula-deep);
    display: grid;
    place-items: center;
}

.oula-copilot__title {
    font-size: 14px;
    font-weight: 600;
}

.oula-copilot__sub {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.55);
}

.oula-copilot__card {
    background: var(--oula-deep-800);
    border-radius: 12px;
    padding: 14px;
    border: 1px solid var(--oula-deep-700);
    font-size: 12.5px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.88);
}

.oula-copilot__card b { color: var(--oula-electric); font-weight: 700; }

.oula-copilot__actions {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

.oula-copilot__btn-accent {
    height: 26px;
    padding: 0 10px;
    background: var(--oula-electric);
    color: var(--oula-deep);
    border: 0;
    border-radius: 6px;
    font-size: 11.5px;
    font-weight: 700;
    font-family: var(--oula-font);
    cursor: pointer;
}

.oula-copilot__btn-ghost {
    height: 26px;
    padding: 0 10px;
    background: transparent;
    color: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    font-size: 11.5px;
    font-weight: 600;
    font-family: var(--oula-font);
    cursor: pointer;
}

.oula-copilot__suggestion {
    display: flex;
    gap: 10px;
    padding: 8px 0;
    border-top: 1px solid var(--oula-deep-700);
}

.oula-copilot__suggestion-icon {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
    border-radius: 6px;
    background: rgba(199, 252, 87, 0.12);
    color: var(--oula-electric);
    display: grid;
    place-items: center;
}

.oula-copilot__suggestion-title {
    font-size: 12.5px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 2px;
}

.oula-copilot__suggestion-body {
    font-size: 11.5px;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.6);
}

.oula-copilot__suggestion-cta {
    margin-top: 6px;
    display: flex;
    gap: 10px;
}

.oula-copilot__suggestion-cta a {
    font-size: 11.5px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}

.oula-copilot__apply   { color: var(--oula-electric); }
.oula-copilot__dismiss { color: rgba(255, 255, 255, 0.45); }

.oula-copilot__footer {
    padding: 10px 12px;
    border: 1px dashed var(--oula-deep-600);
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11.5px;
    color: rgba(255, 255, 255, 0.55);
}

/* ───── Area Load + Throughput (bottom row) ───── */
.oula-area-row {
    display: grid;
    grid-template-columns: 1.4fr 2fr auto;
    gap: 14px;
    align-items: center;
    margin-bottom: 12px;
}

.oula-area-row:last-child { margin-bottom: 0; }

.oula-area-row__name {
    font-size: 13px;
    font-weight: 500;
    color: var(--oula-ink);
}

.oula-area-row__meta {
    font-size: 11px;
    color: var(--oula-mute);
    margin-top: 1px;
}

.oula-area-row__bar {
    height: 8px;
    background: var(--oula-paper-2);
    border-radius: 99px;
    position: relative;
    overflow: hidden;
}

.oula-area-row__bar-fill {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    border-radius: 99px;
    background: var(--oula-neutral);
}

.oula-area-row__bar-fill--warn   { background: var(--oula-warn); }
.oula-area-row__bar-fill--danger { background: var(--oula-danger); }

.oula-area-row__pct {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--oula-ink);
    font-variant-numeric: tabular-nums;
    min-width: 36px;
    text-align: right;
}

/* ───── Throughput bars ───── */
.oula-thru__chart {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    height: 140px;
    padding: 8px 0;
}

.oula-thru__day {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.oula-thru__bars {
    display: flex;
    gap: 2px;
    align-items: flex-end;
    height: 110px;
    width: 100%;
}

.oula-thru__bar {
    flex: 1;
    border-radius: 3px 3px 0 0;
    min-height: 2px;
}

.oula-thru__bar--in  { background: var(--oula-deep); }
.oula-thru__bar--out { background: var(--oula-electric); }

.oula-thru__label {
    font-size: 10px;
    color: var(--oula-mute);
    font-weight: 500;
}

.oula-thru__legend {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 11.5px;
}

.oula-thru__legend-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--oula-ink-2);
}

.oula-thru__legend-swatch {
    width: 8px;
    height: 8px;
    border-radius: 2px;
}

.oula-thru__legend-swatch--in  { background: var(--oula-deep); }
.oula-thru__legend-swatch--out { background: var(--oula-electric); }

.oula-thru__stats {
    display: flex;
    justify-content: space-between;
    margin-top: 10px;
    padding: 10px 0 0;
    border-top: 1px solid var(--oula-line);
    font-size: 12px;
}

.oula-thru__stat-label { color: var(--oula-mute); }

.oula-thru__stat-value {
    font-weight: 600;
    color: var(--oula-ink);
    font-size: 18px;
    font-family: var(--oula-display);
    font-variant-numeric: tabular-nums;
}

.oula-thru__stat-value--warn { color: var(--oula-warn); }
.oula-thru__stat-value--ok   { color: var(--oula-ok); }

.oula-dash__demo-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--oula-mute);
    background: var(--oula-paper-2);
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 6px;
    vertical-align: middle;
}

/* ─────────────────────────────────────────────────────────── */
/* Inbox editorial (Solicitud index)                            */
/* ─────────────────────────────────────────────────────────── */

.oula-tabs-editorial {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    border-radius: 12px;
    background: var(--oula-paper-2);
    border: 1px solid var(--oula-line);
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.oula-tabs-editorial__tab {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 14px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--oula-mute);
    font-family: var(--oula-font);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.12s ease, color 0.12s ease;
}

.oula-tabs-editorial__tab:hover {
    color: var(--oula-ink);
    background: rgba(13, 43, 38, 0.04);
}

.oula-tabs-editorial__tab.is-active {
    background: var(--oula-card);
    color: var(--oula-ink);
    box-shadow: var(--oula-shadow-1, 0 1px 2px rgba(15, 23, 42, 0.08));
}

.oula-tabs-editorial__count {
    font-size: 10.5px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 99px;
    background: rgba(13, 43, 38, 0.08);
    color: var(--oula-mute);
    font-variant-numeric: tabular-nums;
}

.oula-tabs-editorial__tab.is-active .oula-tabs-editorial__count {
    background: var(--oula-deep);
    color: var(--oula-electric);
}

.oula-ai-ribbon {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: var(--oula-deep);
    color: #fff;
    border-radius: 12px;
    margin-bottom: 14px;
    border: 1px solid var(--oula-deep-700);
}

.oula-ai-ribbon__icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: rgba(199, 252, 87, 0.14);
    display: grid;
    place-items: center;
    color: var(--oula-electric);
    flex-shrink: 0;
}

.oula-ai-ribbon__body {
    flex: 1;
    min-width: 0;
}

.oula-ai-ribbon__title {
    font-size: 12.5px;
    font-weight: 600;
}

.oula-ai-ribbon__sub {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.55);
    margin-top: 2px;
}

.oula-inbox-card {
    background: var(--oula-card);
    border-radius: 14px;
    border: 1px solid var(--oula-line);
    overflow: hidden;
}

.oula-inbox-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--oula-card);
    border-bottom: 1px solid var(--oula-line);
    flex-wrap: wrap;
}

.oula-inbox-toolbar__summary {
    font-size: 12px;
    color: var(--oula-mute);
    flex: 1;
}

.oula-inbox-toolbar__summary b {
    color: var(--oula-ink);
    font-weight: 600;
}

.oula-inbox-toolbar__controls {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.oula-inbox-toolbar__controls .form-select,
.oula-inbox-toolbar__controls .form-control {
    border-color: var(--oula-line);
    font-family: var(--oula-font);
    font-size: 12.5px;
    color: var(--oula-ink);
    background: var(--oula-card);
    border-radius: 8px;
    height: 32px;
    min-height: 32px;
    padding: 4px 10px;
}

.oula-inbox-toolbar__controls .btn {
    font-family: var(--oula-font);
    font-size: 12.5px;
    font-weight: 500;
    border-radius: 8px;
    padding: 6px 12px;
    min-height: 32px;
    line-height: 1.2;
}

.oula-inbox-toolbar__controls .btn-soft-secondary {
    background: var(--oula-card);
    border: 1px solid var(--oula-line);
    color: var(--oula-ink-2);
}

.oula-inbox-toolbar__controls .btn-soft-secondary:hover,
.oula-inbox-toolbar__controls .btn-soft-secondary.active {
    background: var(--oula-deep);
    color: var(--oula-electric);
    border-color: var(--oula-deep);
}

.oula-inbox-toolbar__controls .btn-primary {
    background: var(--oula-deep);
    border: 1px solid var(--oula-deep);
    color: var(--oula-electric);
}

.oula-inbox-toolbar__controls .btn-primary:hover {
    background: var(--oula-deep-600);
    border-color: var(--oula-deep-600);
    color: var(--oula-electric);
}

/* Editorial restyle for Yii GridView inside #solicitud-grid */
.oula-inbox-card #solicitud-grid > .grid-view,
.oula-inbox-card #solicitudGridMode > .grid-view {
    background: transparent;
    padding: 0;
}

.oula-inbox-card .solicitud-grid-table {
    --bs-table-bg: transparent;
    font-family: var(--oula-font);
    margin: 0;
}

.oula-inbox-card .solicitud-grid-table thead tr {
    background: var(--oula-paper);
}

.oula-inbox-card .solicitud-grid-table thead th {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--oula-mute);
    background: var(--oula-paper);
    border-bottom: 1px solid var(--oula-line);
    border-top: 0;
    padding: 10px 14px;
}

.oula-inbox-card .solicitud-grid-table tbody td {
    padding: 11px 14px;
    border-bottom: 1px solid var(--oula-line);
    border-top: 0;
    font-size: 13px;
    color: var(--oula-ink);
    vertical-align: middle;
}

.oula-inbox-card .solicitud-grid-table tbody tr:last-child td {
    border-bottom: 0;
}

.oula-inbox-card .solicitud-grid-table tbody tr:hover {
    background: rgba(13, 43, 38, 0.02);
}

.oula-inbox-card .solicitud-grid-table .badge {
    font-family: var(--oula-font);
    font-weight: 500;
    font-size: 11px;
    letter-spacing: 0;
    padding: 4px 8px;
    border-radius: 6px;
}

/* Soft pills inside grid */
.oula-inbox-card .solicitud-grid-table .bg-success {
    background: rgba(34, 139, 98, 0.12) !important;
    color: #1e7650 !important;
}

.oula-inbox-card .solicitud-grid-table .bg-danger {
    background: rgba(214, 85, 85, 0.12) !important;
    color: #b1413e !important;
}

.oula-inbox-card .solicitud-grid-table .bg-warning {
    background: rgba(232, 166, 42, 0.18) !important;
    color: #9f6c0b !important;
}

.oula-inbox-card .solicitud-grid-table .bg-info {
    background: rgba(60, 131, 178, 0.14) !important;
    color: #2e6a94 !important;
}

.oula-inbox-card .solicitud-grid-table .bg-dark {
    background: var(--oula-deep) !important;
    color: var(--oula-electric) !important;
}

.oula-inbox-card .solicitud-grid-table .bg-primary {
    background: rgba(13, 43, 38, 0.12) !important;
    color: var(--oula-deep) !important;
}

.oula-inbox-card .solicitud-grid-table .bg-secondary {
    background: rgba(13, 43, 38, 0.06) !important;
    color: var(--oula-ink-2) !important;
}

.oula-inbox-card .solicitud-grid-table .bg-light {
    background: var(--oula-paper) !important;
    color: var(--oula-mute) !important;
}

.oula-inbox-card .solicitud-asunto-type-badge {
    background: var(--oula-deep) !important;
    color: var(--oula-electric) !important;
    border-radius: 3px !important;
    padding: 2px 6px !important;
    font-size: 9.5px !important;
    letter-spacing: 0.6px !important;
}

.oula-inbox-card .pagination {
    margin: 0;
    padding: 12px 14px;
    gap: 4px;
    background: var(--oula-paper);
    border-top: 1px solid var(--oula-line);
}

.oula-inbox-card .pagination .page-item .page,
.oula-inbox-card .pagination .page-item .page-link {
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border-radius: 6px;
    border: 1px solid var(--oula-line);
    color: var(--oula-ink-2);
    background: transparent;
    font-family: var(--oula-font);
    font-size: 12.5px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.oula-inbox-card .pagination .page-item.active .page,
.oula-inbox-card .pagination .page-item.active .page-link {
    background: var(--oula-deep);
    color: #fff;
    border-color: var(--oula-deep);
}

.oula-inbox-card .pagination .page-item.disabled .page,
.oula-inbox-card .pagination .page-item.disabled .page-link {
    opacity: 0.4;
    cursor: not-allowed;
}

/* ================================================================
   Oula Kanban editorial — cards, columns, header, add button
   Used by views/solicitud/_kanban.php + _kanban_cards.php
   ================================================================ */

.oula-kanban-page {
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.oula-kanban-board {
    flex: 1;
    display: flex;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 20px 24px 32px;
    scroll-padding-left: 24px;
    align-items: flex-start;
    min-height: 0;
}

.oula-kanban-column {
    flex: 0 0 310px;
    min-width: 310px;
    display: flex;
    flex-direction: column;
    background: #EEEBE1;
    border: 1px solid #E5E2D8;
    border-radius: 14px;
    padding: 4px;
}

.oula-kanban-column__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 12px;
    border: none;
}

.oula-kanban-column__title {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
    letter-spacing: -0.005em;
}

.oula-kanban-column__dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    flex-shrink: 0;
}

.oula-kanban-column__dot--creado,
.oula-kanban-column__dot--asignada,
.oula-kanban-column__dot--por_asignar { background: #9ca3af; }
.oula-kanban-column__dot--en_proceso { background: #f59e0b; }
.oula-kanban-column__dot--en_espera { background: #22c55e; }
.oula-kanban-column__dot--revisada { background: #a3a300; }
.oula-kanban-column__dot--completada,
.oula-kanban-column__dot--completado,
.oula-kanban-column__dot--cerrada { background: #0d2b26; }
.oula-kanban-column__dot--rechazada,
.oula-kanban-column__dot--cancelada { background: #ef4444; }
.oula-kanban-column__dot--reabierta { background: #f97316; }

.oula-kanban-column__count {
    background: #fff;
    color: var(--oula-mute);
    font-size: 11px;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    min-width: 22px;
    text-align: center;
    line-height: 1.7;
    margin-left: 2px;
}

.oula-kanban-column__wip {
    font-size: 10.5px;
    font-variant-numeric: tabular-nums;
    background: #FBEED6;
    color: #E8A33A;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.oula-kanban-column__actions {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.oula-kanban-column__more {
    background: transparent;
    border: none;
    color: var(--oula-mute);
    padding: 4px 6px;
    border-radius: 6px;
    cursor: pointer;
    line-height: 0;
    display: inline-flex;
    align-items: center;
}

.oula-kanban-column__more:hover { background: var(--oula-line); color: var(--oula-ink); }

.oula-kanban-column__body {
    flex: 1 1 auto;
    min-height: 60px;
}

.solicitud-kanban-scroll {
    height: calc(100vh - 220px);
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
}

.oula-kanban-stack {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 60px;
    padding: 0 4px 4px;
    border-radius: 10px;
    transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.oula-kanban-stack.is-drop-target {
    background: rgba(34, 139, 98, 0.08);
    box-shadow: inset 0 0 0 1.5px rgba(34, 139, 98, 0.35);
}

/* Card */
.oula-kanban-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 10px;
    padding: 12px 12px 12px 16px;
    box-shadow: 0 1px 2px rgba(13, 43, 38, 0.05), 0 1px 1px rgba(13, 43, 38, 0.03);
    cursor: grab;
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
    user-select: none;
    overflow: hidden;
}

.oula-kanban-card::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 3px;
    background: var(--oula-line);
}

.oula-kanban-card--priority-alta::before { background: #ef4444; }
.oula-kanban-card--priority-media::before { background: #f59e0b; }
.oula-kanban-card--priority-baja::before { background: #10b981; }
.oula-kanban-card--priority-non::before { background: #9ca3af; }

.oula-kanban-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
    border-color: rgba(13, 43, 38, 0.18);
}

.oula-kanban-card.is-dragging { opacity: 0.5; cursor: grabbing; }
.oula-kanban-card.is-saving { opacity: 0.7; cursor: progress; }

.oula-kanban-card__head {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

.oula-kanban-card__id {
    font-size: 10.5px;
    font-weight: 600;
    color: var(--oula-mute);
    font-variant-numeric: tabular-nums;
    font-family: 'JetBrains Mono', 'SF Mono', ui-monospace, monospace;
    letter-spacing: 0;
}

.oula-kanban-card__id::before { content: "#"; color: var(--oula-mute); margin-right: 1px; }

.oula-kanban-card__pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 7px;
    border-radius: 4px;
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1.5;
    border: 1px solid transparent;
}

.oula-kanban-card__pill--priority-alta { background: #fef2f2; color: #b91c1c; border-color: #fecaca; }
.oula-kanban-card__pill--priority-media { background: #fff7ed; color: #c2410c; border-color: #fed7aa; }
.oula-kanban-card__pill--priority-baja { background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.oula-kanban-card__pill--priority-non { background: #f3f4f6; color: #4b5563; border-color: #e5e7eb; }

.oula-kanban-card__pill--priority-alta::before,
.oula-kanban-card__pill--priority-media::before,
.oula-kanban-card__pill--priority-baja::before,
.oula-kanban-card__pill--priority-non::before {
    content: "";
    display: inline-block;
    width: 3px;
    height: 9px;
    border-radius: 2px;
    background: currentColor;
    margin-right: 2px;
}

.oula-kanban-card__pill--ai {
    background: #ecfccb;
    color: #3f6212;
    border-color: #d9f99d;
}

.oula-kanban-card__title {
    font-size: 13px;
    font-weight: 500;
    color: var(--oula-ink);
    line-height: 1.35;
    margin: 0 0 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    letter-spacing: -0.003em;
}

.oula-kanban-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.oula-kanban-card__sla {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px 2px 7px;
    border-radius: 999px;
    letter-spacing: 0.01em;
    line-height: 1.5;
}

.oula-kanban-card__sla::before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: currentColor;
}

.oula-kanban-card__sla--ok { background: #dcfce7; color: #15803d; }
.oula-kanban-card__sla--warn { background: #fef3c7; color: #a16207; }
.oula-kanban-card__sla--overdue { background: #fee2e2; color: #b91c1c; }
.oula-kanban-card__sla--done { background: #dcfce7; color: #15803d; }
.oula-kanban-card__sla--none { background: #f3f4f6; color: #6b7280; }

.oula-kanban-card__channel {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px 2px 6px;
    border-radius: 999px;
    letter-spacing: 0.01em;
    line-height: 1.5;
}

.oula-kanban-card__channel svg { width: 11px; height: 11px; }

.oula-kanban-card__channel--email { background: #dbeafe; color: #1d4ed8; }
.oula-kanban-card__channel--whatsapp { background: #dcfce7; color: #15803d; }
.oula-kanban-card__channel--form { background: #ede9fe; color: #6d28d9; }
.oula-kanban-card__channel--manual { background: #f3f4f6; color: #4b5563; }

.oula-kanban-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-top: 8px;
    border-top: 1px solid var(--oula-line);
}

.oula-kanban-card__counts {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--oula-mute);
    font-size: 10.5px;
    font-variant-numeric: tabular-nums;
}

.oula-kanban-card__counts > span {
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.oula-kanban-card__counts svg { width: 11px; height: 11px; }

.oula-kanban-card__date {
    font-size: 10px;
    color: var(--oula-mute);
    font-variant-numeric: tabular-nums;
}

.oula-kanban-card__owner {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 10.5px;
    color: #2A3A36;
    font-weight: 500;
}

.oula-kanban-card__owner-avatar {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--oula-deep);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.03em;
    flex-shrink: 0;
}

.oula-kanban-card__owner--unassigned {
    color: #D94A38;
    font-weight: 500;
    font-style: italic;
}

.oula-kanban-card__owner--unassigned .oula-kanban-card__owner-avatar {
    background: #FBE8E4;
    color: #D94A38;
    border: 1px dashed #f4a89d;
}

/* Add request button */
.oula-kanban-add {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    background: transparent;
    border: 1px dashed #DCD8CB;
    border-radius: 10px;
    color: var(--oula-mute);
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
    margin-top: 2px;
    width: 100%;
    box-sizing: border-box;
}

.oula-kanban-add:hover {
    border-color: var(--oula-deep);
    color: var(--oula-deep);
    background: rgba(13, 43, 38, 0.03);
}

/* Loading state */
.oula-kanban-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    color: var(--oula-mute);
    font-size: 12px;
    padding: 8px;
}

.oula-kanban-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80px;
    border: 1px dashed var(--oula-line);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.55);
    color: var(--oula-mute);
    font-size: 12.5px;
    text-align: center;
    padding: 12px;
    pointer-events: none;
}

.oula-kanban-summary {
    color: var(--oula-mute);
    font-size: 13px;
    margin-bottom: 12px;
}

/* Empty column — 30% of normal width */
.solicitud-kanban-column-empty {
    flex: 0 0 93px !important;
    min-width: 93px !important;
}

.solicitud-kanban-column-empty .oula-kanban-column__title > span:not(.oula-kanban-column__dot):not(.oula-kanban-column__count) {
    display: none;
}

.solicitud-kanban-column-empty .oula-kanban-column__actions {
    display: none;
}

.solicitud-kanban-column-empty .oula-kanban-stack {
    min-height: 40px;
    padding: 0 2px 2px;
}

.solicitud-kanban-column-empty .oula-kanban-empty {
    display: none;
}

.solicitud-kanban-column-empty .oula-kanban-add {
    display: none;
}

@media (max-width: 767.98px) {
    .oula-kanban-column { flex: 0 0 280px; min-width: 280px; }
    .solicitud-kanban-column-empty { flex: 0 0 84px !important; min-width: 84px !important; }
}

/* ================================================================
   Oula Inbox editorial — filter bar, chips, summary, table, pager
   ================================================================ */

/* Filter chip bar */
.oula-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 16px 20px;
    border-bottom: 1px solid var(--oula-line);
    background: #fff;
}

.oula-filter-bar__search {
    flex: 1 1 260px;
    min-width: 200px;
    max-width: 340px;
    position: relative;
}

.oula-filter-bar__search input {
    width: 100%;
    height: 38px;
    padding: 0 12px 0 36px;
    border: 1px solid var(--oula-line);
    border-radius: 10px;
    background: #fff;
    font-size: 13px;
    color: var(--oula-ink);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.oula-filter-bar__search input::placeholder { color: var(--oula-mute); }

.oula-filter-bar__search input:focus {
    outline: none;
    border-color: var(--oula-deep);
    box-shadow: 0 0 0 3px rgba(13, 43, 38, 0.08);
}

.oula-filter-bar__search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--oula-mute);
    pointer-events: none;
}

.oula-filter-bar__chips {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
}

.oula-chip--filter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px 7px 14px;
    border: 1px solid var(--oula-line);
    border-radius: 999px;
    background: #fff;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--oula-ink);
    cursor: pointer;
    white-space: nowrap;
    transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.oula-chip--filter:hover { border-color: rgba(13, 43, 38, 0.22); }

.oula-chip--filter .oula-chip__label {
    color: var(--oula-mute);
    font-weight: 500;
}

.oula-chip--filter .oula-chip__value {
    color: var(--oula-ink);
    font-weight: 600;
    margin-left: 2px;
}

.oula-chip--filter svg { color: var(--oula-mute); width: 12px; height: 12px; }

.oula-chip--filter.is-active {
    background: #d9f99d;
    border-color: #bef264;
    color: var(--oula-ink);
}

.oula-chip--filter.is-active .oula-chip__label,
.oula-chip--filter.is-active .oula-chip__value {
    color: var(--oula-ink);
}

.oula-chip--filter.is-active svg { color: var(--oula-ink); }

.oula-filter-bar__save {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 38px;
    padding: 0 14px;
    border: 1px solid var(--oula-line);
    border-radius: 10px;
    background: #fff;
    font-size: 13px;
    font-weight: 500;
    color: var(--oula-ink);
    cursor: pointer;
}

.oula-filter-bar__save:hover { border-color: rgba(13, 43, 38, 0.22); }

.oula-filter-bar__save svg { width: 14px; height: 14px; color: var(--oula-mute); }

/* Summary row */
.oula-inbox-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    color: var(--oula-mute);
    font-size: 12.5px;
    border-bottom: 1px solid var(--oula-line);
    background: #fff;
}

.oula-inbox-summary strong {
    color: var(--oula-ink);
    font-weight: 600;
}

.oula-inbox-summary__right {
    display: inline-flex;
    align-items: center;
    gap: 18px;
}

/* Editorial table */
.oula-inbox-card .solicitud-grid-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 0;
    background: #fff;
}

.oula-inbox-card .solicitud-grid-table thead th {
    background: #fff;
    padding: 12px 16px;
    font-size: 10.5px;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: var(--oula-mute);
    text-transform: uppercase;
    border-bottom: 1px solid var(--oula-line);
    border-top: 1px solid var(--oula-line);
    white-space: nowrap;
}

.oula-inbox-card .solicitud-grid-table thead th a {
    color: var(--oula-mute);
    text-decoration: none;
}

.oula-inbox-card .solicitud-grid-table thead th a:hover { color: var(--oula-ink); }

/* Hide sort arrows */
.oula-inbox-card .solicitud-grid-table thead th .sort-icon,
.oula-inbox-card .solicitud-grid-table thead th .desc,
.oula-inbox-card .solicitud-grid-table thead th .asc { display: none; }

.oula-inbox-card .solicitud-grid-table tbody tr {
    cursor: pointer;
    transition: background 0.1s ease;
    position: relative;
}

.oula-inbox-card .solicitud-grid-table tbody tr:hover { background: #fafaf8; }

.oula-inbox-card .solicitud-grid-table tbody td {
    padding: 14px 16px;
    font-size: 13px;
    color: var(--oula-ink);
    border-bottom: 1px solid var(--oula-line);
    vertical-align: middle;
}

/* Row priority stripe */
.oula-inbox-card .solicitud-grid-table tbody tr td:first-child {
    position: relative;
    padding-left: 20px;
}

.oula-inbox-card .solicitud-grid-table tbody tr td:first-child::before {
    content: "";
    position: absolute;
    top: 6px;
    bottom: 6px;
    left: 8px;
    width: 3px;
    border-radius: 2px;
    background: var(--oula-line);
}

.oula-inbox-card .solicitud-grid-table tbody tr.oula-row--priority-alta td:first-child::before { background: #ef4444; }
.oula-inbox-card .solicitud-grid-table tbody tr.oula-row--priority-media td:first-child::before { background: #f59e0b; }
.oula-inbox-card .solicitud-grid-table tbody tr.oula-row--priority-baja td:first-child::before { background: #10b981; }
.oula-inbox-card .solicitud-grid-table tbody tr.oula-row--priority-non td:first-child::before { background: #9ca3af; }

/* ID column */
.oula-row-id {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: 13px;
    color: var(--oula-ink);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.005em;
}

.oula-row-id__dot {
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: #9ca3af;
    flex-shrink: 0;
}

.oula-row-id__dot--creado { background: #9ca3af; }
.oula-row-id__dot--asignada { background: #f59e0b; }
.oula-row-id__dot--en_proceso { background: #3b82f6; }
.oula-row-id__dot--en_espera { background: #a78bfa; }
.oula-row-id__dot--revisada { background: #10b981; }
.oula-row-id__dot--completada,
.oula-row-id__dot--completado,
.oula-row-id__dot--cerrada { background: #059669; }
.oula-row-id__dot--rechazada,
.oula-row-id__dot--cancelada { background: #ef4444; }
.oula-row-id__dot--reabierta { background: #f97316; }

/* Subject column: bucket badge + text */
.oula-row-subject {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    max-width: 300px;
}

.oula-row-subject__top {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.oula-row-bucket {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.6;
}

.oula-row-bucket--tarea { background: #0d2b26; color: #d9f99d; }
.oula-row-bucket--solicitud { background: #dbeafe; color: #1e40af; }
.oula-row-bucket--por_asignar { background: #fff7ed; color: #c2410c; }
.oula-row-bucket--seguimiento { background: #f3f4f6; color: #4b5563; }

.oula-row-subject__text {
    font-size: 13px;
    color: var(--oula-ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 260px;
    line-height: 1.35;
}

/* Area column: channel badge + area name */
.oula-row-area {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.oula-row-channel {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 2px 8px;
    background: #f3f4f6;
    border-radius: 6px;
    font-size: 11.5px;
    font-weight: 500;
    color: #4b5563;
    width: fit-content;
}

.oula-row-channel--email { background: #dbeafe; color: #1e40af; }
.oula-row-channel--whatsapp { background: #d1fae5; color: #047857; }
.oula-row-channel--form { background: #ede9fe; color: #6d28d9; }
.oula-row-channel--manual { background: #f3f4f6; color: #4b5563; }
.oula-row-channel svg { width: 12px; height: 12px; }

.oula-row-ia-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 6px;
    background: #ecfccb;
    color: #3f6212;
    border-radius: 6px;
    font-size: 10.5px;
    font-weight: 600;
    margin-left: 4px;
}

.oula-row-area__name {
    font-size: 12.5px;
    color: var(--oula-mute);
    line-height: 1.3;
}

/* SLA column */
.oula-row-sla {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
}

.oula-row-sla::before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: currentColor;
    flex-shrink: 0;
}

.oula-row-sla--ok { background: #ecfdf5; color: #047857; }
.oula-row-sla--warn { background: #fff7ed; color: #c2410c; }
.oula-row-sla--overdue { background: #fef2f2; color: #b91c1c; }
.oula-row-sla--done { background: #ecfdf5; color: #047857; }
.oula-row-sla--none { background: #f3f4f6; color: #6b7280; }

/* Estado column */
.oula-row-state {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
    background: #f3f4f6;
    color: #4b5563;
}

.oula-row-state::before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: currentColor;
    flex-shrink: 0;
}

.oula-row-state--creado { background: #f3f4f6; color: #6b7280; }
.oula-row-state--asignada { background: #fff7ed; color: #c2410c; }
.oula-row-state--en_proceso { background: #dbeafe; color: #1e40af; }
.oula-row-state--en_espera { background: #ede9fe; color: #6d28d9; }
.oula-row-state--revisada { background: #ecfdf5; color: #047857; }
.oula-row-state--completada,
.oula-row-state--completado,
.oula-row-state--cerrada { background: #d1fae5; color: #047857; }
.oula-row-state--rechazada,
.oula-row-state--cancelada { background: #fef2f2; color: #b91c1c; }
.oula-row-state--reabierta { background: #fff7ed; color: #c2410c; }

/* Owner column */
.oula-row-owner {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12.5px;
    color: var(--oula-ink);
}

.oula-row-owner__avatar {
    width: 26px;
    height: 26px;
    border-radius: 999px;
    background: var(--oula-deep);
    color: #fff;
    font-size: 10.5px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.03em;
    flex-shrink: 0;
}

.oula-row-owner--unassigned { color: #b91c1c; font-weight: 500; }
.oula-row-owner--unassigned .oula-row-owner__avatar {
    background: #fef2f2;
    color: #b91c1c;
    border: 1px dashed #fca5a5;
}

/* Priority pill */
.oula-row-priority {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px 3px 8px;
    border-radius: 6px;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.6;
    border: 1px solid transparent;
}

.oula-row-priority::before {
    content: "";
    display: inline-block;
    width: 3px;
    height: 10px;
    border-radius: 2px;
    background: currentColor;
}

.oula-row-priority--alta { background: #fef2f2; color: #b91c1c; border-color: #fecaca; }
.oula-row-priority--media { background: #fff7ed; color: #c2410c; border-color: #fed7aa; }
.oula-row-priority--baja { background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.oula-row-priority--non { background: #f3f4f6; color: #4b5563; border-color: #e5e7eb; }

/* Date column */
.oula-row-date {
    font-size: 12.5px;
    color: var(--oula-mute);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* Actions menu */
.oula-row-actions {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    color: var(--oula-mute);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.oula-row-actions:hover { background: var(--oula-line); color: var(--oula-ink); }

/* Editorial pagination */
.oula-inbox-card .pagination,
.oula-inbox-card nav > ul.pagination {
    display: flex;
    list-style: none;
    gap: 4px;
    margin: 0;
    padding: 16px 20px;
    background: #fff;
    align-items: center;
    justify-content: center;
}

.oula-inbox-card .pagination .page-item {
    list-style: none;
}

.oula-inbox-card .pagination .page,
.oula-inbox-card .pagination .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 10px;
    border: 1px solid transparent;
    border-radius: 8px;
    background: transparent;
    color: var(--oula-ink);
    font-size: 12.5px;
    font-weight: 500;
    text-decoration: none;
    font-variant-numeric: tabular-nums;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.oula-inbox-card .pagination .page:hover,
.oula-inbox-card .pagination .page-link:hover {
    background: var(--oula-line);
    color: var(--oula-ink);
}

.oula-inbox-card .pagination .page-item.active .page,
.oula-inbox-card .pagination .page-item.active .page-link {
    background: var(--oula-deep);
    border-color: var(--oula-deep);
    color: #fff;
}

.oula-inbox-card .pagination .page-item.disabled .page,
.oula-inbox-card .pagination .page-item.disabled .page-link {
    color: #d1d5db;
    cursor: not-allowed;
}

.oula-inbox-card .pagination .pagination-prev .page,
.oula-inbox-card .pagination .pagination-prev .page-link,
.oula-inbox-card .pagination .pagination-next .page,
.oula-inbox-card .pagination .pagination-next .page-link {
    color: var(--oula-mute);
}

/* ── Oula Pager ─────────────────────────────────────────────────── */
.oula-pager {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-top: 1px solid var(--oula-line);
    background: var(--oula-paper);
    gap: 12px;
}

.oula-pager__left  { flex: 1; }
.oula-pager__center { display: flex; gap: 4px; align-items: center; }
.oula-pager__right { flex: 1; display: flex; align-items: center; justify-content: flex-end; gap: 4px; }

.oula-pager__info {
    font-size: 12px;
    color: var(--oula-mute);
    font-variant-numeric: tabular-nums;
}

.oula-pager__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border-radius: 6px;
    border: 1px solid var(--oula-line);
    background: transparent;
    color: var(--oula-ink2);
    font-size: 12.5px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    font-variant-numeric: tabular-nums;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
    line-height: 1;
}
.oula-pager__btn:hover:not(.active):not(.disabled):not(.oula-pager__btn--dots) {
    background: var(--oula-line);
    color: var(--oula-ink);
    border-color: var(--oula-line);
    text-decoration: none;
}
.oula-pager__btn.active {
    background: var(--oula-deep);
    border-color: var(--oula-deep);
    color: #fff;
    cursor: default;
}
.oula-pager__btn.disabled {
    color: var(--oula-line2, #d1d5db);
    cursor: not-allowed;
    border-color: var(--oula-line);
}
.oula-pager__btn--dots {
    border-color: transparent;
    cursor: default;
    color: var(--oula-mute);
}

.oula-pager__rows-label {
    font-size: 12px;
    color: var(--oula-mute);
    margin-right: 2px;
}

.oula-pager__size {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    border-radius: 6px;
    border: 1px solid var(--oula-line);
    background: transparent;
    color: var(--oula-ink2);
    font-size: 12px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.oula-pager__size:hover:not(.active) {
    background: var(--oula-line);
    color: var(--oula-ink);
    border-color: var(--oula-line);
    text-decoration: none;
}
.oula-pager__size.active {
    background: var(--oula-deep);
    border-color: var(--oula-deep);
    color: #fff;
    cursor: default;
}

/* View toggle buttons in topRight */
.oula-view-toggle {
    display: inline-flex;
    gap: 6px;
    align-items: center;
}

.oula-view-toggle .oula-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.oula-view-toggle .oula-btn svg { width: 14px; height: 14px; }

.oula-view-toggle .oula-btn.is-active {
    background: var(--oula-ink);
    color: #fff;
    border-color: var(--oula-ink);
}

/* ================================================================
   Oula Request Detail (Phase 4)
   Used by views/solicitud/view.php
   ================================================================ */

.oula-detail {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    gap: 0;
    min-height: calc(100vh - 72px);
    background: var(--oula-paper);
    margin: -20px -24px -20px -24px;
}

.oula-detail__main {
    padding: 24px 32px 64px;
    overflow: auto;
    min-width: 0;
}

.oula-detail__side {
    border-left: 1px solid var(--oula-line);
    background: #fff;
    padding: 24px 22px 48px;
    overflow: auto;
}

.oula-detail__crumbs {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    font-size: 12px;
    color: var(--oula-mute);
    flex-wrap: wrap;
    gap: 10px;
}

.oula-detail__crumbs-path {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.oula-detail__crumbs-path .sep { color: var(--oula-mute); opacity: 0.6; }
.oula-detail__crumbs-path .current { color: var(--oula-ink); font-weight: 500; }

.oula-detail__crumbs-actions {
    display: inline-flex;
    gap: 6px;
}

.oula-detail__header-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.oula-detail__idpill {
    font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-mute);
    padding: 3px 8px;
    border-radius: 5px;
    background: var(--oula-paper);
    border: 1px solid var(--oula-line);
    letter-spacing: -0.01em;
}

.oula-detail__title {
    font-family: "Fraunces", Georgia, serif;
    font-size: 34px;
    font-weight: 500;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--oula-ink);
    margin: 0 0 10px;
    max-width: 820px;
}

.oula-detail__title code {
    font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
    font-size: 0.72em;
    background: var(--oula-paper);
    padding: 2px 8px;
    border-radius: 6px;
    letter-spacing: -0.01em;
    font-weight: 500;
    color: var(--oula-ink);
}

.oula-detail__subtitle {
    font-size: 13.5px;
    color: var(--oula-mute);
    margin-bottom: 20px;
    line-height: 1.55;
}

.oula-detail__subtitle b { color: var(--oula-ink); font-weight: 600; }

.oula-detail__section-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 10px;
}

.oula-detail__description {
    margin-bottom: 28px;
}

.oula-detail__description-body {
    font-size: 14px;
    line-height: 1.65;
    color: var(--oula-ink);
    max-width: 760px;
}

.oula-detail__description-body p { margin: 0 0 10px; }
.oula-detail__description-body p:last-child { margin-bottom: 0; }

.oula-detail__attachments {
    display: flex;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.oula-detail__activity {
    margin-bottom: 24px;
}

.oula-detail__activity-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    flex-wrap: wrap;
    gap: 10px;
}

.oula-detail__tabs {
    display: inline-flex;
    gap: 6px;
    padding: 3px;
    border-radius: 8px;
    background: var(--oula-paper);
    border: 1px solid var(--oula-line);
}

.oula-detail__tab {
    padding: 6px 10px;
    border: 0;
    background: transparent;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-mute);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.oula-detail__tab.is-active {
    background: #fff;
    color: var(--oula-ink);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

/* AI Summary callout */
.oula-ai-callout {
    position: relative;
    padding: 18px 20px 18px 56px;
    margin-bottom: 24px;
    border-radius: 14px;
    background: linear-gradient(180deg, #0d2b26 0%, #08211d 100%);
    color: #fff;
    border: 1px solid #08211d;
}

.oula-ai-callout__icon {
    position: absolute;
    left: 16px;
    top: 18px;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: #d9f99d;
    display: grid;
    place-items: center;
    color: #0d2b26;
}

.oula-ai-callout__eyebrow {
    font-size: 11px;
    font-weight: 700;
    color: #d9f99d;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.oula-ai-callout__body {
    font-size: 14px;
    line-height: 1.55;
}

.oula-ai-callout__body b { color: #fff; font-weight: 600; }
.oula-ai-callout__body em,
.oula-ai-callout__body .highlight {
    color: #d9f99d;
    font-style: normal;
    font-weight: 600;
}

.oula-ai-callout__body code {
    font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
    font-size: 12.5px;
    background: rgba(255, 255, 255, 0.08);
    padding: 1px 6px;
    border-radius: 4px;
}

.oula-ai-callout__actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
}

.oula-btn--onDark,
.oula-btn--on-dark {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: #fff;
}

.oula-btn--onDark:hover,
.oula-btn--on-dark:hover {
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
}

/* Attachments */
.oula-attach {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 12px 6px 6px;
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s ease, transform 0.12s ease;
}

.oula-attach:hover { border-color: rgba(13, 43, 38, 0.22); transform: translateY(-1px); }

.oula-attach__thumb {
    width: 34px;
    height: 34px;
    border-radius: 6px;
    background: var(--oula-paper);
    display: grid;
    place-items: center;
    color: var(--oula-mute);
    flex-shrink: 0;
}

.oula-attach__thumb--image {
    background: linear-gradient(135deg, #2F8A55, #0d2b26);
    color: #fff;
}

.oula-attach__name {
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-ink);
    line-height: 1.3;
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.oula-attach__size {
    font-size: 10.5px;
    color: var(--oula-mute);
    margin-top: 1px;
}

/* Timeline */
.oula-timeline {
    position: relative;
    padding-left: 22px;
}

.oula-timeline__rail {
    position: absolute;
    left: 14px;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background: var(--oula-line);
}

.oula-timeline__item {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
    position: relative;
}

.oula-timeline__dot {
    position: absolute;
    left: -22px;
    top: 0;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    border: 2px solid var(--oula-paper);
    color: #fff;
}

.oula-timeline__content {
    flex: 1;
    min-width: 0;
    margin-left: 14px;
}

.oula-timeline__head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}

.oula-timeline__who {
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
}

.oula-timeline__verb {
    font-size: 12px;
    color: var(--oula-mute);
}

.oula-timeline__target {
    font-size: 12px;
    color: var(--oula-ink);
    font-weight: 600;
}

.oula-timeline__state {
    font-size: 11px;
    padding: 1px 6px;
    border-radius: 4px;
    background: var(--oula-paper);
    border: 1px solid var(--oula-line);
    color: var(--oula-ink);
    font-family: inherit;
}

.oula-timeline__arrow { color: var(--oula-mute); }

.oula-timeline__when {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin-left: auto;
}

.oula-timeline__body {
    font-size: 13.5px;
    line-height: 1.55;
    color: var(--oula-ink);
}

.oula-timeline__body--comment {
    padding: 12px;
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 10px;
}

.oula-timeline__body--ai {
    padding-left: 12px;
    border-left: 2px solid #7fb86f;
    color: var(--oula-ink);
    font-style: italic;
}

/* Composer */
.oula-composer {
    margin-top: 20px;
    padding: 14px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid var(--oula-line);
}

.oula-composer__row {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.oula-composer__body {
    flex: 1;
    min-width: 0;
}

.oula-composer__tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 8px;
}

.oula-composer__input {
    border: 1px solid var(--oula-line);
    border-radius: 8px;
    padding: 12px;
    font-size: 13.5px;
    color: var(--oula-ink);
    min-height: 70px;
    background: var(--oula-paper);
    width: 100%;
    resize: vertical;
    font-family: inherit;
}

.oula-composer__input:focus {
    outline: none;
    border-color: rgba(13, 43, 38, 0.4);
    background: #fff;
}

.oula-composer__input::placeholder { color: var(--oula-mute); }

.oula-composer__toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    flex-wrap: wrap;
    gap: 8px;
}

.oula-composer__toolbar-group {
    display: flex;
    gap: 8px;
}

/* Side column */
.oula-sla-banner {
    padding: 16px;
    border-radius: 12px;
    background: #fee2e2;
    border: 1px solid #F5C5BD;
    margin-bottom: 20px;
}

.oula-sla-banner--warn { background: #fef3c7; border-color: #FBD38D; }
.oula-sla-banner--ok { background: #dcfce7; border-color: #BBF7D0; }

.oula-sla-banner__row {
    display: flex;
    align-items: center;
    gap: 14px;
}

.oula-sla-banner__eyebrow {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #7A231A;
}

.oula-sla-banner--warn .oula-sla-banner__eyebrow { color: #7A5418; }
.oula-sla-banner--ok .oula-sla-banner__eyebrow { color: #1F6847; }

.oula-sla-banner__value {
    font-family: "Fraunces", Georgia, serif;
    font-size: 19px;
    font-weight: 600;
    color: #7A231A;
    letter-spacing: -0.02em;
    margin-top: 2px;
}

.oula-sla-banner--warn .oula-sla-banner__value { color: #7A5418; }
.oula-sla-banner--ok .oula-sla-banner__value { color: #1F6847; }

.oula-sla-banner__meta {
    font-size: 11.5px;
    color: #7A231A;
    margin-top: 4px;
}

.oula-sla-banner--warn .oula-sla-banner__meta { color: #7A5418; }
.oula-sla-banner--ok .oula-sla-banner__meta { color: #1F6847; }

.oula-sla-ring {
    position: relative;
    flex-shrink: 0;
    display: inline-grid;
    place-items: center;
}

.oula-sla-ring__label {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    font-size: 11px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.oula-detail__actions {
    display: grid;
    gap: 8px;
    margin-bottom: 22px;
}

.oula-detail__actions-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.oula-work-timer {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--oula-line);
    border-radius: 12px;
    background: var(--oula-bg-soft, #f8fafb);
    text-align: center;
}

.oula-work-timer__label {
    font-size: 12px;
    color: var(--oula-text-muted, #6c7680);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.oula-work-timer__value {
    font-size: 28px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--oula-text, #0d2b26);
    letter-spacing: 0.02em;
}

/* Work progress ring */
.oula-work-progress {
    --ring-color: #00d97e;
    --ring-track: rgba(13, 43, 38, 0.08);
    display: grid;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--oula-line);
    border-radius: 14px;
    background: var(--oula-bg-soft, #f8fafb);
}

.oula-work-progress.is-state-ok    { --ring-color: #00d97e; }
.oula-work-progress.is-state-warn  { --ring-color: #f5a524; }
.oula-work-progress.is-state-over  { --ring-color: #e5484d; }

.oula-work-progress__row {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 14px;
    align-items: center;
}

.oula-work-progress__ring {
    position: relative;
    width: 96px;
    height: 96px;
}

.oula-work-progress__svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.oula-work-progress__track {
    fill: none;
    stroke: var(--ring-track);
    stroke-width: 8;
}

.oula-work-progress__fill {
    fill: none;
    stroke: var(--ring-color);
    stroke-width: 8;
    stroke-linecap: round;
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
    transition: stroke-dashoffset 0.6s ease, stroke 0.3s ease;
}

.oula-work-progress.is-running .oula-work-progress__ring {
    animation: oulaWorkPulse 2.4s ease-in-out infinite;
}

@keyframes oulaWorkPulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.035); }
}

.oula-work-progress__percent {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ring-color);
    font-family: 'Fraunces', 'Times New Roman', serif;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    pointer-events: none;
}

.oula-work-progress__percent-value { font-size: 24px; line-height: 1; }
.oula-work-progress__percent-sign  { font-size: 12px; line-height: 1; margin-left: 2px; align-self: center; opacity: 0.85; }

.oula-work-progress__meta {
    display: grid;
    gap: 4px;
}

.oula-work-progress__times {
    font-size: 16px;
    font-weight: 600;
    color: var(--oula-text, #0d2b26);
    font-variant-numeric: tabular-nums;
}

.oula-work-progress__sep {
    margin: 0 4px;
    opacity: 0.5;
    font-weight: 400;
}

.oula-work-progress__total {
    color: var(--oula-text-muted, #6c7680);
    font-weight: 500;
}

.oula-work-progress__remaining {
    font-size: 12px;
    color: var(--oula-text-muted, #6c7680);
}

.oula-work-progress__remaining.is-over {
    color: #e5484d;
    font-weight: 600;
}

.oula-work-progress__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.oula-work-progress__actions .oula-btn {
    justify-content: center;
}

.oula-work-progress__actions .oula-btn:only-child {
    grid-column: 1 / -1;
}

.oula-mail-origin-link {
    text-decoration: none;
    border-left-width: 3px;
    border-left-style: solid;
}

.oula-mail-origin-link:hover,
.oula-mail-origin-link:focus {
    text-decoration: none;
}

.oula-mail-origin-link--google {
    border-left-color: #ea4335;
}

.oula-mail-origin-link--google i.ri-google-fill {
    color: #ea4335;
}

.oula-mail-origin-link--outlook {
    border-left-color: #0078d4;
}

.oula-mail-origin-link--outlook i.ri-microsoft-fill {
    color: #0078d4;
}

/* Props */
.oula-prop {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--oula-line);
    align-items: center;
}

.oula-prop:last-child { border-bottom: 0; }

.oula-prop__label {
    font-size: 11.5px;
    color: var(--oula-mute);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.oula-prop__ai {
    width: 11px;
    height: 11px;
    color: #7fb86f;
    flex-shrink: 0;
}

.oula-prop__value {
    font-size: 12.5px;
    color: var(--oula-ink);
    font-weight: 500;
    min-width: 0;
    overflow-wrap: anywhere;
}

.oula-prop__value--warn {
    color: #b91c1c;
    font-weight: 600;
}

/* Phase 2.1: clickable variant of the property row */
.oula-prop--clickable {
    cursor: pointer;
    transition: background-color 0.15s ease;
}
.oula-prop--clickable:hover {
    background-color: rgba(0, 0, 0, 0.04);
}
.oula-prop--clickable:focus {
    outline: 2px solid var(--oula-primary, #4F46E5);
    outline-offset: 2px;
}

/* Detail: follow-up switch — tamaño legible + tokens Oula */
.oula-followup-detail {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
}

.oula-followup-detail .form-check.form-switch {
    padding-left: 0;
    margin-bottom: 0;
    min-height: 0;
}

.oula-followup-detail .form-check.form-switch .form-check-input {
    /* ~40% más chico que la versión grande (60% del tamaño anterior) */
    width: 2.1rem;
    height: 1.125rem;
    margin-left: 0 !important;
    margin-top: 0;
    cursor: pointer;
    border-radius: var(--oula-radius-pill);
    border: 1px solid var(--oula-line-2);
    background-color: var(--oula-paper-2);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%236B7874'/%3e%3c/svg%3e");
    background-size: 0.72rem 0.72rem;
    background-repeat: no-repeat;
    transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.oula-followup-detail .form-check.form-switch .form-check-input:focus {
    border-color: var(--oula-electric-600);
    box-shadow: 0 0 0 3px rgba(199, 252, 87, 0.35);
    outline: 0;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%232A3A36'/%3e%3c/svg%3e");
}

.oula-followup-detail .form-check.form-switch .form-check-input:checked {
    background-color: var(--oula-deep);
    border-color: var(--oula-deep-600);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23C7FC57'/%3e%3c/svg%3e");
}

.oula-followup-detail .form-check.form-switch .form-check-input:checked:focus {
    border-color: var(--oula-electric);
    box-shadow: 0 0 0 3px rgba(199, 252, 87, 0.4);
}

.oula-followup-detail .form-check.form-switch .form-check-input:disabled {
    cursor: not-allowed;
    opacity: 0.55;
}

.oula-followup-detail .text-muted {
    color: var(--oula-mute) !important;
    font-size: 12px;
    line-height: 1.4;
    font-weight: 400;
    max-width: 22rem;
}

/* Watchers */
.oula-watchers {
    display: flex;
    align-items: center;
    gap: 0;
}

.oula-watchers__avatar {
    margin-left: -8px;
    border: 2px solid #fff;
    border-radius: 999px;
    z-index: 2;
}

.oula-watchers__avatar:first-child { margin-left: 0; }

.oula-watchers__add {
    width: 26px;
    height: 26px;
    border-radius: 999px;
    border: 1px dashed var(--oula-line);
    margin-left: 6px;
    color: var(--oula-mute);
    background: #fff;
    font-size: 14px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* Related items */
.oula-related {
    display: block;
    padding: 10px;
    background: var(--oula-paper);
    border-radius: 10px;
    border: 1px solid var(--oula-line);
    margin-bottom: 8px;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.15s ease, transform 0.12s ease;
}

.oula-related:hover { border-color: rgba(13, 43, 38, 0.22); transform: translateY(-1px); }

.oula-related__head {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
}

.oula-related__id {
    font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
    font-size: 11px;
    font-weight: 600;
    color: var(--oula-mute);
}

.oula-related__sim {
    font-size: 10.5px;
    color: #3f6212;
    font-weight: 700;
    margin-left: auto;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.oula-related__subj {
    font-size: 12.5px;
    color: var(--oula-ink);
    font-weight: 500;
    line-height: 1.35;
    margin-bottom: 5px;
}

@media (max-width: 1199.98px) {
    .oula-detail {
        grid-template-columns: 1fr;
        margin: -20px -16px -20px -16px;
    }
    .oula-detail__side {
        border-left: 0;
        border-top: 1px solid var(--oula-line);
    }
}

/* ---- detail page: shims for the view.php block names ---- */

.oula-detail__header {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 22px;
}

.oula-detail__crumb-sep {
    color: var(--oula-mute);
    opacity: 0.55;
    margin: 0 2px;
}

.oula-detail__meta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 2px 0 4px;
}

.oula-detail__meta-spacer {
    flex: 1 1 auto;
    min-width: 8px;
}

.oula-detail__section {
    margin: 26px 0;
}

.oula-detail__section:first-of-type {
    margin-top: 20px;
}

.oula-detail__section-head {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 12px;
}

.oula-detail__section-title {
    font-family: var(--oula-display, 'Fraunces', Georgia, serif);
    font-size: 20px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--oula-ink);
    margin: 0;
}

.oula-detail__section-count {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--oula-mute);
    padding: 2px 8px;
    background: var(--oula-card-2, #F0EDE3);
    border-radius: 999px;
    line-height: 1.6;
}

.oula-detail__body {
    font-size: 15px;
    line-height: 1.65;
    color: var(--oula-ink);
    white-space: pre-wrap;
}

.oula-attach-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
}

.oula-detail__side-card {
    padding: 16px;
    background: #fff;
    border: 1px solid var(--oula-line, rgba(13, 43, 38, 0.10));
    border-radius: 16px;
    margin-bottom: 14px;
}

.oula-detail__side-card + .oula-detail__side-card {
    margin-top: 0;
}

.oula-detail__side-title {
    font-family: var(--oula-display, 'Fraunces', Georgia, serif);
    font-size: 15px;
    font-weight: 500;
    letter-spacing: -0.005em;
    color: var(--oula-ink);
    margin: 0 0 12px;
}

.oula-detail__side-block {
    margin-top: 10px;
}

.oula-sla-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 16px;
    margin-bottom: 14px;
}

.oula-sla-banner--danger {
    background: #FEE2E2;
    border: 1px solid #FCA5A5;
}

.oula-sla-banner--danger .oula-sla-banner__label,
.oula-sla-banner--danger .oula-sla-banner__value,
.oula-sla-banner--danger .oula-sla-banner__meta {
    color: #7F1D1D;
}

.oula-sla-banner__text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.oula-sla-banner__label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--oula-mute);
}

.oula-sla-banner--warn .oula-sla-banner__label { color: #7A5418; }
.oula-sla-banner--ok .oula-sla-banner__label { color: #1F6847; }

.oula-sla-banner__value {
    font-family: var(--oula-display, 'Fraunces', Georgia, serif);
    font-size: 22px;
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1.1;
    color: var(--oula-ink);
}

.oula-sla-banner__meta {
    font-size: 11px;
    color: var(--oula-mute);
    letter-spacing: 0.02em;
}

/* ───────────── Shared Oula modal shell ───────────── */
.oula-modal-open { overflow: hidden; }

.oula-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.oula-modal.is-open { display: flex; }

.oula-modal__scrim {
    position: absolute;
    inset: 0;
    background: rgba(11, 29, 26, 0.28);
    backdrop-filter: blur(4px);
}

.oula-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 520px);
    max-height: calc(100vh - 48px);
    background: #fff;
    border: 1px solid rgba(13, 43, 38, 0.08);
    border-radius: 18px;
    box-shadow: 0 24px 80px rgba(11, 29, 26, 0.18);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.oula-modal__dialog--wide { width: min(100%, 720px); }

.oula-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px 16px;
    border-bottom: 1px solid rgba(13, 43, 38, 0.08);
    background: linear-gradient(180deg, #fff 0%, #fcfbf7 100%);
}

.oula-modal__title {
    margin: 0;
    font-family: var(--oula-display, "Fraunces", Georgia, serif);
    font-size: 19px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--oula-ink);
}

.oula-modal__subtitle {
    margin-top: 4px;
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--oula-mute);
}

.oula-modal__close {
    width: 32px;
    height: 32px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--oula-mute);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}

.oula-modal__close:hover {
    background: var(--oula-paper-2, #F1EFE7);
    color: var(--oula-ink);
}

.oula-modal__body {
    padding: 20px 24px 24px;
    overflow-y: auto;
    flex: 1 1 auto;
}

.oula-modal__body--loading {
    padding: 48px 24px;
    text-align: center;
    color: var(--oula-mute);
    font-size: 13px;
}

.oula-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 24px;
    border-top: 1px solid rgba(13, 43, 38, 0.08);
    background: #fcfbf7;
}

/* Bootstrap form styling inside Oula modal */
.oula-modal .solicitud-form .form-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--oula-ink);
    letter-spacing: 0.01em;
    margin-bottom: 6px;
}

.oula-modal .solicitud-form .form-control,
.oula-modal .solicitud-form .form-select {
    border: 1px solid rgba(13, 43, 38, 0.14);
    border-radius: 10px;
    background: #fff;
    color: var(--oula-ink);
    font-size: 14px;
    font-family: var(--oula-font, 'Inter', sans-serif);
    transition: border-color 120ms ease, box-shadow 120ms ease;
    padding: 10px 14px;
}

.oula-modal .solicitud-form textarea.form-control {
    min-height: 110px;
    resize: vertical;
}

.oula-modal .solicitud-form .form-control:focus,
.oula-modal .solicitud-form .form-select:focus {
    outline: none;
    border-color: rgba(13, 43, 38, 0.38);
    box-shadow: 0 0 0 3px rgba(13, 43, 38, 0.08);
}

.oula-modal .solicitud-form .form-group,
.oula-modal .solicitud-form .mb-3 { margin-bottom: 14px; }

.oula-modal .solicitud-form .invalid-feedback,
.oula-modal .solicitud-form .help-block {
    font-size: 11.5px;
    color: #B43A2C;
    margin-top: 4px;
}

.oula-modal .solicitud-form .btn-group .btn {
    border-radius: 8px !important;
    font-size: 12px;
    font-weight: 600;
    padding: 6px 14px;
}

.oula-modal .solicitud-form .btn-group .btn + .btn { margin-left: 6px; }

.oula-modal .solicitud-form .hstack { display: none; } /* hide internal save/close, use modal footer */

.oula-modal .solicitud-form .oula-required {
    color: #e53e3e;
    font-weight: 700;
}

/* Prioridad button group */
.oula-prioridad-group {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.oula-prioridad-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    border: 1px solid rgba(13, 43, 38, 0.2);
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-ink);
    background: #fff;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease;
    user-select: none;
}

.oula-prioridad-btn:hover {
    background: var(--oula-paper-2, #F1EFE7);
    border-color: rgba(13, 43, 38, 0.3);
}

input.btn-check:checked + .oula-prioridad-btn {
    background: #F59E0B;
    border-color: #F59E0B;
    color: #1a1a1a;
}

/* File input */
.oula-file-input {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border: 1px solid rgba(13, 43, 38, 0.14);
    border-radius: 10px;
    background: #fff;
}

.oula-file-input__btn {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border: 1px solid rgba(13, 43, 38, 0.18);
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-ink);
    background: var(--oula-paper, #F5F3EC);
    cursor: pointer;
    white-space: nowrap;
    transition: background 120ms ease;
    flex-shrink: 0;
}

.oula-file-input__btn:hover { background: var(--oula-paper-2, #EDEBE2); }

.oula-file-input__name {
    font-size: 13px;
    color: var(--oula-mute);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.oula-file-input__hidden { display: none; }

/* Kind toggle (Solicitud / Tarea) */
.oula-kind-toggle {
    display: inline-flex;
    gap: 0;
    background: var(--oula-paper, #F5F3EC);
    border: 1px solid rgba(13, 43, 38, 0.12);
    border-radius: 10px;
    padding: 3px;
}

.oula-kind-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 16px;
    border-radius: 7px;
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-mute);
    cursor: pointer;
    transition: background 140ms ease, color 140ms ease, box-shadow 140ms ease;
    user-select: none;
}

.oula-kind-btn:hover { color: var(--oula-ink); }

input.btn-check:checked + .oula-kind-btn {
    background: #fff;
    color: var(--oula-ink);
    box-shadow: 0 1px 4px rgba(13, 43, 38, 0.12);
}

/* Self-assign badge (shown when kind = tarea) */
.oula-self-assign-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 14px;
    border: 1px solid rgba(13, 43, 38, 0.14);
    border-radius: 10px;
    background: var(--oula-paper, #F5F3EC);
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
    width: 100%;
}

/* ─── SweetAlert2 — Oula theme ─────────────────────────────── */

.swal2-container.oula-swal-container {
    z-index: 99999;
    padding: 24px;
    background: rgba(11, 29, 26, 0.28);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.swal2-popup.oula-swal {
    width: min(100%, 520px);
    padding: 0;
    border-radius: 18px;
    border: 1px solid rgba(13, 43, 38, 0.08);
    background: #fff;
    box-shadow: 0 24px 80px rgba(11, 29, 26, 0.18);
    overflow: hidden;
    font-family: var(--oula-font, 'Inter', sans-serif);
}

.swal2-popup.oula-swal.oula-swal--toast {
    width: auto;
    min-width: 280px;
    max-width: 380px;
    padding: 14px 16px;
    border-radius: 14px;
    background: #fff;
}

.swal2-popup.oula-swal .swal2-header { padding: 0; }
.swal2-popup.oula-swal .swal2-footer:empty,
.swal2-popup.oula-swal .swal2-footer { display: none; }

.swal2-popup.oula-swal .swal2-title,
.swal2-popup.oula-swal .swal2-html-container {
    margin: 0;
}

.swal2-title.oula-swal__title {
    padding: 22px 24px 8px;
    margin: 0;
    font-family: var(--oula-display, "Fraunces", Georgia, serif);
    font-size: 19px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--oula-ink);
    text-align: left;
}

.swal2-popup.oula-swal.oula-swal--toast .swal2-title.oula-swal__title {
    padding: 0;
    font-size: 15px;
    font-family: var(--oula-font);
    font-weight: 700;
}

.swal2-html-container.oula-swal__html {
    padding: 0 24px 20px;
    margin: 0;
    font-size: 13.5px;
    line-height: 1.6;
    color: var(--oula-mute);
    text-align: left;
}

.swal2-popup.oula-swal.oula-swal--toast .swal2-html-container.oula-swal__html {
    padding: 4px 0 0;
    font-size: 12.5px;
}

.swal2-actions.oula-swal__actions {
    width: 100%;
    margin: 0;
    padding: 14px 24px;
    gap: 10px;
    justify-content: flex-end;
    border-top: 1px solid rgba(13, 43, 38, 0.08);
    background: #fcfbf7;
}

.swal2-popup.oula-swal.oula-swal--toast .swal2-actions.oula-swal__actions {
    display: none;
}

.swal2-confirm.oula-swal__confirm,
.swal2-cancel.oula-swal__cancel {
    margin: 0;
    border: 0;
    border-radius: 10px;
    padding: 0 16px;
    min-height: 40px;
    font-family: var(--oula-font);
    font-size: 13.5px;
    font-weight: 600;
    line-height: 1;
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease, opacity 120ms ease;
}

.swal2-confirm.oula-swal__confirm {
    background: var(--oula-deep);
    color: #fff;
}

.swal2-confirm.oula-swal__confirm:hover {
    background: var(--oula-deep-800);
}

.swal2-cancel.oula-swal__cancel {
    background: transparent;
    color: var(--oula-ink);
    border: 1px solid var(--oula-line-2);
}

.swal2-cancel.oula-swal__cancel:hover {
    background: var(--oula-paper-2);
}

.swal2-select.oula-swal__select,
.swal2-textarea.oula-swal__textarea,
.swal2-input.oula-swal__input {
    width: 100%;
    margin: 0;
    border: 1px solid rgba(13, 43, 38, 0.14);
    border-radius: 10px;
    background: #fff;
    color: var(--oula-ink);
    font-size: 14px;
    font-family: var(--oula-font);
    box-shadow: none;
}

.swal2-select.oula-swal__select,
.swal2-input.oula-swal__input {
    height: 44px;
    padding: 0 14px;
}

.swal2-textarea.oula-swal__textarea {
    min-height: 132px;
    padding: 14px;
    resize: vertical;
}

.swal2-select.oula-swal__select:focus,
.swal2-textarea.oula-swal__textarea:focus,
.swal2-input.oula-swal__input:focus {
    border-color: rgba(13, 43, 38, 0.38);
    box-shadow: 0 0 0 3px rgba(13, 43, 38, 0.08);
}

.swal2-validation-message.oula-swal__validation {
    margin: 0 24px 18px;
    padding: 10px 12px;
    border-radius: 10px;
    background: #FEF2F2;
    color: #991B1B;
    font-size: 12.5px;
    line-height: 1.45;
    border: 1px solid #FECACA;
}

.swal2-icon.oula-swal__icon {
    margin: 24px 24px 0;
}

.swal2-close.oula-swal__close {
    color: var(--oula-mute);
}

.swal2-popup.oula-swal .swal2-icon.swal2-success {
    border-color: rgba(47, 138, 85, 0.22);
    color: #2F8A55;
}
.swal2-popup.oula-swal .swal2-icon.swal2-success .swal2-success-ring { border-color: rgba(47, 138, 85, 0.22); }
.swal2-popup.oula-swal .swal2-icon.swal2-success [class^="swal2-success-line"] { background-color: #2F8A55; }

.swal2-popup.oula-swal .swal2-icon.swal2-error {
    border-color: rgba(180, 58, 44, 0.22);
    color: #B43A2C;
}

.swal2-popup.oula-swal .swal2-icon.swal2-info {
    border-color: rgba(45, 97, 150, 0.22);
    color: #2D6196;
}
.swal2-popup.oula-swal .swal2-icon.swal2-info::before,
.swal2-popup.oula-swal .swal2-icon.swal2-info::after { background-color: #2D6196; }

.swal2-popup.oula-swal .swal2-icon.swal2-warning {
    border-color: rgba(192, 138, 42, 0.22);
    color: #C08A2A;
}

.oula-swal__bar { background: var(--oula-ink, #0D2B26); }

@media (max-width: 767.98px) {
    .swal2-container.oula-swal-container { padding: 16px; }
    .swal2-title.oula-swal__title,
    .swal2-html-container.oula-swal__html,
    .swal2-actions.oula-swal__actions {
        padding-left: 18px;
        padding-right: 18px;
    }
    .swal2-actions.oula-swal__actions { justify-content: stretch; }
    .swal2-confirm.oula-swal__confirm,
    .swal2-cancel.oula-swal__cancel {
        flex: 1 1 0;
        justify-content: center;
    }
}

/* ───────────── View-config (3-dots) popover ───────────── */
.oula-view-toggle { position: relative; }

.oula-view-menu-wrap { position: relative; display: inline-flex; }

.oula-view-menu__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: 1px solid rgba(13, 43, 38, 0.12);
    background: #fff;
    color: var(--oula-mute);
    border-radius: 8px;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}

.oula-view-menu__toggle:hover,
.oula-view-menu__toggle.is-open {
    background: var(--oula-paper-2, #F1EFE7);
    color: var(--oula-ink);
    border-color: rgba(13, 43, 38, 0.22);
}

.oula-popover {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 900;
    min-width: 220px;
    background: #fff;
    border: 1px solid rgba(13, 43, 38, 0.1);
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(11, 29, 26, 0.18);
    padding: 6px;
    display: none;
}

.oula-popover.is-open { display: block; }

.oula-popover__section + .oula-popover__section {
    border-top: 1px solid rgba(13, 43, 38, 0.08);
    margin-top: 4px;
    padding-top: 4px;
}

.oula-popover__label {
    padding: 8px 10px 4px;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--oula-mute);
}

.oula-popover__item {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 9px 10px;
    background: transparent;
    border: 0;
    border-radius: 9px;
    color: var(--oula-ink);
    font-size: 13px;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    transition: background 120ms ease;
    text-decoration: none;
}

.oula-popover__item:hover { background: var(--oula-paper-2, #F1EFE7); }

.oula-popover__item.is-active {
    background: rgba(13, 43, 38, 0.06);
    color: var(--oula-ink);
    font-weight: 600;
}

.oula-popover__item-check {
    width: 14px;
    height: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--oula-ink);
    opacity: 0;
}

.oula-popover__item.is-active .oula-popover__item-check { opacity: 1; }

.oula-popover__item-meta {
    font-size: 11px;
    color: var(--oula-mute);
    font-weight: 500;
}

/* ───────────── Density variants for inbox table ───────────── */
.oula-inbox-card--density-condensed .solicitud-grid-table tbody td { padding: 8px 14px; font-size: 12.5px; }
.oula-inbox-card--density-condensed .solicitud-grid-table thead th { padding: 8px 14px; }
.oula-inbox-card--density-condensed .oula-row-owner__avatar { width: 20px; height: 20px; font-size: 10px; }
.oula-inbox-card--density-condensed .solicitud-grid-table tbody tr td:first-child::before { top: 4px; bottom: 4px; }

.oula-inbox-card--density-applied .solicitud-grid-table tbody td { padding: 20px 18px; font-size: 13.5px; }
.oula-inbox-card--density-applied .solicitud-grid-table thead th { padding: 14px 18px; }
.oula-inbox-card--density-applied .oula-row-owner__avatar { width: 28px; height: 28px; font-size: 12px; }
.oula-inbox-card--density-applied .solicitud-grid-table tbody tr td:first-child::before { top: 10px; bottom: 10px; }

/* ───────────── Row actions popover ───────────── */
.oula-row-menu-wrap {
    position: relative;
    display: inline-flex;
}

/* ───────────── Profile dropdown ───────────── */
.oula-profile-wrap { position: relative; display: inline-flex; }

.oula-header__user--button {
    background: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    padding: 4px 6px 4px 10px;
    border-radius: 12px;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.oula-header__user--button:hover {
    background: var(--oula-paper-2, #F1EFE7);
    border-color: rgba(13, 43, 38, 0.1);
}

.oula-header__user--button[aria-expanded="true"] {
    background: #fff;
    border-color: var(--oula-deep);
    box-shadow: 0 0 0 3px rgba(13, 43, 38, 0.1);
}

.oula-popover--profile {
    right: 0;
    left: auto;
    min-width: 280px;
    padding: 6px;
}

.oula-profile-menu__welcome {
    padding: 14px 16px 12px;
    font-size: 13px;
    color: var(--oula-mute);
    border-bottom: 1px solid rgba(13, 43, 38, 0.08);
    margin-bottom: 4px;
}

.oula-profile-menu__welcome strong {
    color: var(--oula-ink);
    font-weight: 700;
}

.oula-profile-menu__item {
    padding: 10px 12px !important;
    font-weight: 500 !important;
    gap: 12px !important;
    justify-content: flex-start !important;
}

.oula-profile-menu__icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--oula-mute);
    flex-shrink: 0;
}

.oula-profile-menu__icon svg {
    width: 18px;
    height: 18px;
}

.oula-profile-menu__item > span:nth-child(2) { flex: 1 1 auto; }

.oula-profile-menu__badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--oula-electric, #C7FC57);
    color: var(--oula-deep, #0D2B26);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.oula-profile-menu__item--danger {
    color: #B43A2C !important;
    font-weight: 600 !important;
}

.oula-profile-menu__item--danger .oula-profile-menu__icon { color: #B43A2C; }

.oula-profile-menu__item--danger:hover {
    background: #FEF2F2 !important;
    color: #991B1B !important;
}

.oula-profile-menu__logout-form {
    margin: 0;
    padding: 0;
    display: block;
}

.oula-profile-menu__logout-form button {
    width: 100%;
    border: 0;
    cursor: pointer;
    font-family: inherit;
}

/* ───────────── Filter chip popover ───────────── */
.oula-chip-wrap {
    position: relative;
    display: inline-flex;
}

.oula-popover--filter {
    right: auto;
    left: 0;
    min-width: 220px;
    max-height: 320px;
    overflow-y: auto;
}

.oula-filter-bar__clear {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border: 1px dashed rgba(13, 43, 38, 0.22);
    border-radius: 999px;
    background: transparent;
    color: var(--oula-mute);
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.oula-filter-bar__clear:hover {
    background: var(--oula-paper-2, #F1EFE7);
    color: var(--oula-ink);
    border-color: rgba(13, 43, 38, 0.32);
}

/* ───────────── @mention composer popup + chips ───────────── */
.oula-mention-popup {
    z-index: 1080;
    min-width: 240px;
    max-width: 340px;
    max-height: 260px;
    overflow-y: auto;
    background: var(--oula-card, #fff);
    border: 1px solid var(--oula-line, rgba(13, 43, 38, 0.12));
    border-radius: 10px;
    box-shadow: 0 14px 38px rgba(13, 43, 38, 0.18);
    padding: 4px;
    font-family: var(--oula-font);
}

.oula-mention-popup[hidden] { display: none; }

.oula-mention-popup__empty {
    padding: 10px 12px;
    color: var(--oula-mute);
    font-size: 12.5px;
    text-align: center;
}

.oula-mention-popup__item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 10px;
    border: 0;
    background: transparent;
    border-radius: 7px;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
    color: var(--oula-ink);
    transition: background 120ms ease;
}

.oula-mention-popup__item:hover,
.oula-mention-popup__item.is-active {
    background: var(--oula-paper);
}

.oula-mention-popup__avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--oula-paper-2, #F1EFE7) center/cover no-repeat;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--oula-ink);
}

.oula-mention-popup__avatar--fallback {
    background: var(--oula-deep);
    color: var(--oula-electric);
}

.oula-mention-popup__meta {
    display: flex;
    flex-direction: column;
    min-width: 0;
    line-height: 1.2;
}

.oula-mention-popup__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.oula-mention-popup__handle {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin-top: 1px;
}

/* Rendered mention chip inside a comment */
.oula-mention {
    display: inline;
    color: var(--oula-deep, #0D2B26);
    background: var(--oula-electric-200, rgba(199, 252, 87, 0.35));
    font-weight: 600;
    padding: 0 5px;
    border-radius: 6px;
    text-decoration: none;
}

.oula-mention:hover {
    background: var(--oula-electric, #C7FC57);
    text-decoration: none;
    color: var(--oula-deep);
}

/* Live @mention highlighting inside the composer textarea.
   Renders via a mirror div behind the transparent-colored textarea. */
.oula-composer__textarea-wrap { position: relative; }

.oula-composer__highlight {
    position: absolute;
    inset: 0;
    margin: 0;
    padding: inherit;
    font: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    white-space: pre-wrap;
    word-wrap: break-word;
    overflow: hidden;
    color: var(--oula-deep, #0D2B26);
    pointer-events: none;
    background: transparent;
    border: 1px solid transparent;
    border-radius: inherit;
    z-index: 1;
}

.oula-composer__highlight .oula-mention--inline {
    color: var(--oula-deep, #0D2B26);
    background: var(--oula-electric-200, rgba(199, 252, 87, 0.35));
    font-weight: 700;
    border-radius: 4px;
    padding: 0 2px;
}

.oula-composer__input.has-mention-layer {
    position: relative;
    background: transparent !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent;
    z-index: 2;
    caret-color: var(--oula-deep, #0D2B26);
}

.oula-composer__input.has-mention-layer::selection {
    background: var(--oula-electric-200, rgba(199, 252, 87, 0.45));
    color: transparent;
    -webkit-text-fill-color: transparent;
}

/* ===== Configuration side nav ===== */
.oula-config-nav {
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 12px;
    padding: 12px;
    position: sticky;
    top: 16px;
    align-self: flex-start;
}

.oula-config-nav__head {
    padding: 6px 8px 12px;
    border-bottom: 1px solid var(--oula-line);
    margin-bottom: 8px;
}

.oula-config-nav__eyebrow {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--oula-mute);
    margin-bottom: 4px;
}

.oula-config-nav__hint {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin: 0;
    line-height: 1.4;
}

.oula-config-nav__list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.oula-config-nav__item {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px 12px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--oula-ink-2);
    transition: background 0.15s ease, color 0.15s ease;
}

.oula-config-nav__item:hover {
    background: var(--oula-paper-2);
    color: var(--oula-ink);
    text-decoration: none;
}

.oula-config-nav__item.is-active {
    background: var(--oula-paper-2);
    color: var(--oula-ink);
}

.oula-config-nav__item.is-active::before {
    content: '';
    position: absolute;
    left: -12px;
    top: 12px;
    bottom: 12px;
    width: 3px;
    background: var(--oula-deep);
    border-radius: 99px;
}

.oula-config-nav__label {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
}

.oula-config-nav__item:not(.is-active) .oula-config-nav__label {
    font-weight: 500;
}

.oula-config-nav__desc {
    font-size: 11.5px;
    color: var(--oula-mute);
    line-height: 1.35;
}

/* ===== Configuration page shared (blacklist/services) ===== */
.oula-config-page {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.oula-config-page__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.oula-config-page__title {
    font-size: 22px;
    font-weight: 700;
    color: var(--oula-ink);
    letter-spacing: -0.4px;
    margin: 0 0 4px;
}

.oula-config-page__subtitle {
    font-size: 13px;
    color: var(--oula-mute);
    margin: 0;
    max-width: 640px;
    line-height: 1.45;
}

.oula-config-page__filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--oula-paper-2);
    border: 1px solid var(--oula-line);
    border-radius: 99px;
    font-size: 12px;
    color: var(--oula-ink-2);
}

.oula-config-page__filter-label {
    color: var(--oula-mute);
}

.oula-link-mute {
    color: var(--oula-mute);
    text-decoration: underline;
    font-size: 12px;
}
.oula-link-mute:hover { color: var(--oula-ink); }

/* KPI row */
.oula-kpi-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

@media (max-width: 768px) {
    .oula-kpi-row { grid-template-columns: 1fr; }
}

.oula-kpi-card {
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 12px;
    padding: 14px 16px;
}

.oula-kpi-card--warn {
    background: #FFF8EB;
    border-color: #F4DEAA;
}

.oula-kpi-card__label {
    font-size: 10.5px;
    font-weight: 700;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: 6px;
}

.oula-kpi-card__value {
    font-size: 26px;
    font-weight: 700;
    color: var(--oula-ink);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.oula-kpi-card__value-sm {
    font-size: 16px;
    font-weight: 600;
    color: var(--oula-ink);
    line-height: 1.2;
}

.oula-kpi-card__hint {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin-top: 4px;
}

/* Card head (alternative spacing for blacklist/services cards) */
.oula-card__head {
    padding: 14px 18px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    border-bottom: 1px solid var(--oula-line);
}

/* Form bits */
.oula-form-label {
    display: block;
    font-size: 11.5px;
    font-weight: 600;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 6px;
}

.oula-select {
    width: 100%;
    height: 38px;
    padding: 0 10px;
    border: 1px solid var(--oula-line);
    border-radius: 8px;
    background: #fff;
    color: var(--oula-ink);
    font-family: var(--oula-font);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
}
.oula-select:focus { outline: 2px solid var(--oula-electric-600); outline-offset: 1px; }

/* Search bar */
.oula-search-bar {
    padding: 14px 18px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.oula-search-bar__input {
    flex: 1;
    min-width: 220px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    height: 38px;
    border: 1px solid var(--oula-line);
    border-radius: 8px;
    background: #fff;
    color: var(--oula-mute);
}

.oula-search-bar__input input {
    flex: 1;
    border: 0;
    outline: none;
    font-family: var(--oula-font);
    font-size: 13px;
    color: var(--oula-ink);
    background: transparent;
}

.oula-search-bar__input:focus-within {
    border-color: var(--oula-deep);
    color: var(--oula-ink);
}

/* Empty state */
.oula-empty {
    padding: 28px 18px;
    text-align: center;
}

.oula-empty__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--oula-ink);
    margin-bottom: 4px;
}

.oula-empty__hint {
    font-size: 12.5px;
    color: var(--oula-mute);
}

/* Table */
.oula-table-wrap {
    width: 100%;
    overflow-x: auto;
}

.oula-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.oula-table thead th {
    background: var(--oula-paper);
    font-size: 10.5px;
    font-weight: 700;
    color: var(--oula-mute);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    text-align: left;
    padding: 12px 18px;
    border-bottom: 1px solid var(--oula-line);
}

.oula-table tbody td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--oula-line);
    vertical-align: middle;
    color: var(--oula-ink);
}

.oula-table tbody tr:last-child td {
    border-bottom: 0;
}

.oula-table__th--center,
.oula-table__td--center { text-align: center; }
.oula-table__th--right,
.oula-table__td--right { text-align: right; }

.oula-table__muted {
    color: var(--oula-ink-2);
    font-size: 12.5px;
}

/* Pills */
.oula-pill {
    display: inline-flex;
    align-items: center;
    padding: 3px 9px;
    border-radius: 5px;
    font-size: 11px;
    font-weight: 700;
    text-transform: capitalize;
}

.oula-pill--neutral {
    background: var(--oula-paper-2);
    color: var(--oula-ink-2);
}

.oula-sla-pill {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.oula-sla-pill.is-set {
    background: var(--oula-deep);
    color: var(--oula-electric);
}

.oula-sla-pill.is-empty {
    background: #FFF1E5;
    color: #8C4A1A;
}

/* Inline form (used in tables for delete buttons etc.) */
.oula-inline-form { display: inline-flex; }

/* ===== cfg-* shared config page base (notifications, blacklist, whatsapp, integrations) ===== */
.cfg-notif__head { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:16px; }
.cfg-notif__title { font-family: var(--oula-display, 'Fraunces', serif); font-size: 22px; font-weight: 500; letter-spacing: -0.01em; color: var(--oula-ink); margin:0 0 4px; }
.cfg-notif__sub { font-size: 13px; color: var(--oula-mute); margin:0; line-height: 1.45; }

.cfg-card { background:#fff; border:1px solid rgba(13,43,38,.08); border-radius: 14px; padding: 20px; margin-bottom: 16px; }
.cfg-card__title { font-size: 14px; font-weight: 600; color: var(--oula-ink); margin: 0 0 4px; }
.cfg-card__sub { font-size: 12px; color: var(--oula-mute); margin: 0 0 16px; line-height: 1.4; }
.cfg-card__title:last-child, .cfg-card__sub:last-child { margin-bottom: 0; }

/* cfg stat row (used in blacklist / metrics strips) */
.cfg-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 16px; }
@media (max-width: 600px) { .cfg-stats { grid-template-columns: 1fr; } }
.cfg-stat { background:#fff; border:1px solid rgba(13,43,38,.08); border-radius:12px; padding:14px 16px; }
.cfg-stat__label { font-size:10.5px; font-weight:700; color:var(--oula-mute); text-transform:uppercase; letter-spacing:.8px; margin-bottom:6px; }
.cfg-stat__value { font-size:26px; font-weight:700; color:var(--oula-ink); line-height:1; font-variant-numeric:tabular-nums; }
.cfg-stat__value-sm { font-size:16px; font-weight:600; color:var(--oula-ink); line-height:1.2; }
.cfg-stat__hint { font-size:11.5px; color:var(--oula-mute); margin-top:4px; }

/* cfg list row (used inside cfg-card for lists of items) */
.cfg-list-row { display:flex; align-items:center; gap:14px; padding:12px 0; border-bottom:1px solid rgba(13,43,38,.06); }
.cfg-list-row:last-child { border-bottom:0; padding-bottom:0; }
.cfg-list-row:first-child { padding-top:0; }

/* cfg badge */
.cfg-badge { display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:600; padding:3px 8px; border-radius:99px; }
.cfg-badge--ok { background:rgba(47,138,85,.12); color:#2F8A55; }
.cfg-badge--warn { background:rgba(193,136,42,.12); color:#8B5E0A; }
.cfg-badge--mute { background:rgba(107,120,116,.10); color:var(--oula-mute); }

/* cfg icon box */
.cfg-icon-box { width:38px; height:38px; border-radius:10px; background:var(--oula-paper,#F6F4EE); border:1px solid rgba(13,43,38,.08); display:grid; place-items:center; flex-shrink:0; color:var(--oula-mute); }

/* ===== Blacklist view ===== */
.oula-blacklist-add__form {
    padding: 14px 18px 18px;
}

.oula-blacklist-add__row {
    display: flex;
    gap: 12px;
    align-items: flex-end;
    flex-wrap: wrap;
}

.oula-blacklist-add__field {
    flex: 1;
    min-width: 220px;
}

.oula-blacklist-email {
    font-family: var(--oula-mono, 'JetBrains Mono', ui-monospace, monospace);
    font-size: 13px;
    color: var(--oula-ink);
    font-weight: 500;
}

/* ===== Services view ===== */
.oula-services-table__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
}

.oula-services-table__desc {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin-top: 2px;
    line-height: 1.4;
    max-width: 480px;
}

.oula-services-table__actions {
    display: inline-flex;
    gap: 6px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

/* ===== Swal form modal (for SLA edit) ===== */
.oula-swal--form .swal2-html-container {
    text-align: left !important;
    margin: 8px 0 4px !important;
}

.oula-swal__field {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}

.oula-swal__row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.oula-swal__row .oula-swal__field { margin-bottom: 0; }

.oula-swal__static {
    padding: 8px 10px;
    background: var(--oula-paper-2);
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--oula-ink);
}

/* ===== Language switcher (topbar) ===== */
.oula-lang-switcher {
    position: relative;
    display: inline-flex;
}

.oula-lang-switcher__trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 32px;
    padding: 0 8px 0 6px;
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 8px;
    color: var(--oula-ink);
    font-family: var(--oula-font);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease;
}

.oula-lang-switcher__trigger:hover {
    background: var(--oula-paper-2);
    border-color: var(--oula-line-2);
}

.oula-lang-switcher__trigger[aria-expanded="true"] {
    background: var(--oula-paper-2);
    border-color: var(--oula-line-2);
}

.oula-lang-switcher__flag {
    display: inline-flex;
    line-height: 0;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 0 0 1px rgba(11,29,26,0.08);
}

.oula-lang-switcher__code {
    color: var(--oula-ink-2);
    letter-spacing: 0.4px;
}

.oula-lang-switcher__menu {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 180px;
    padding: 6px;
    background: #fff;
    border: 1px solid var(--oula-line);
    border-radius: 10px;
    box-shadow: var(--oula-shadow-2, 0 8px 24px rgba(13,43,38,0.08));
    display: none;
    z-index: 1050;
}

.oula-lang-switcher__menu.is-open { display: block; }

.oula-lang-switcher__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    color: var(--oula-ink);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
}

.oula-lang-switcher__item:hover {
    background: var(--oula-paper-2);
    text-decoration: none;
    color: var(--oula-ink);
}

.oula-lang-switcher__item.is-active {
    background: var(--oula-paper-2);
    font-weight: 600;
}

.oula-lang-switcher__label {
    flex: 1;
}

.oula-lang-switcher__check {
    color: var(--oula-deep);
}

/* ═══════════════════════════════════════════════════════════
   MOBILE SHELL — Fase 1 + Fase 2
   Breakpoint canónico: ≤ 900px = mobile
   ═══════════════════════════════════════════════════════════ */

/* ── Fase 1: Variables mobile ── */
:root {
    --oula-safe-bottom:        env(safe-area-inset-bottom, 0px);
    --oula-mobile-topbar-h:    56px;
    --oula-mobile-bottomnav-h: 64px;
}

/* ── Fase 1: Frame reset en mobile ── */
@media (max-width: 900px) {
    .oula-scope {
        padding: 0;
    }
}

/* ════════════════════════════════
   Bottom Navigation (hidden desktop)
   ════════════════════════════════ */
.oula-bottom-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1050;
    height: calc(var(--oula-mobile-bottomnav-h) + var(--oula-safe-bottom));
    padding: 8px 4px calc(var(--oula-safe-bottom) + 8px);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(20px) saturate(140%);
    -webkit-backdrop-filter: blur(20px) saturate(140%);
    border-top: 1px solid var(--oula-line);
    align-items: center;
    justify-content: space-around;
}

.oula-bottom-nav__tab {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    min-height: 44px;
    min-width: 44px;
    padding: 4px 2px;
    background: none;
    border: none;
    color: var(--oula-mute);
    font-family: var(--oula-font);
    font-size: 10px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    position: relative;
    transition: color 0.12s ease;
}

.oula-bottom-nav__tab.is-active,
.oula-bottom-nav__tab:focus-visible {
    color: var(--oula-deep);
    font-weight: 700;
    outline: none;
}

.oula-bottom-nav__tab svg {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
}

.oula-bottom-nav__badge {
    position: absolute;
    top: 2px;
    right: calc(50% - 20px);
    min-width: 14px;
    height: 14px;
    padding: 0 4px;
    border-radius: 7px;
    background: var(--oula-danger);
    color: #fff;
    font-size: 9.5px;
    font-weight: 700;
    font-family: var(--oula-mono);
    line-height: 14px;
    text-align: center;
    border: 1.5px solid #fff;
    display: none; /* shown via JS when count > 0 */
}

/* FAB central */
.oula-bottom-nav__fab {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    border: none;
    background: var(--oula-electric);
    color: var(--oula-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    cursor: pointer;
    text-decoration: none;
    margin-top: -14px;
    box-shadow: 0 6px 16px rgba(199, 252, 87, 0.5), 0 2px 4px rgba(13, 43, 38, 0.2);
    transition: box-shadow 0.12s ease, transform 0.12s ease;
}

.oula-bottom-nav__fab:active {
    transform: scale(0.95);
    box-shadow: 0 3px 8px rgba(199, 252, 87, 0.4), 0 1px 2px rgba(13, 43, 38, 0.15);
}

.oula-bottom-nav__fab svg {
    width: 24px;
    height: 24px;
}

/* ════════════════════════════════
   Drawer overlay
   ════════════════════════════════ */
.oula-drawer-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1060;
    background: rgba(11, 29, 26, 0.5);
    opacity: 0;
    transition: opacity 0.22s ease;
}

.oula-drawer-overlay.is-open {
    opacity: 1;
}

/* ════════════════════════════════
   Drawer panel
   ════════════════════════════════ */
.oula-drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 1070;
    width: min(290px, 85vw);
    background: var(--oula-deep);
    color: #fff;
    transform: translateX(-100%);
    transition: transform 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.oula-drawer.is-open {
    transform: translateX(0);
}

.oula-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 16px 16px;
    border-bottom: 1px solid var(--oula-deep-600);
    flex-shrink: 0;
}

.oula-drawer__close {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.12s ease;
}

.oula-drawer__close:hover {
    background: rgba(255, 255, 255, 0.16);
}

.oula-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: 12px 0 24px;
    -webkit-overflow-scrolling: touch;
}

.oula-drawer__section {
    padding: 0 0 4px;
}

.oula-drawer__section-label {
    padding: 16px 20px 6px;
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.9px;
    color: rgba(255, 255, 255, 0.4);
    font-family: var(--oula-font);
    display: block;
}

.oula-drawer__link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    color: rgba(255, 255, 255, 0.72);
    font-size: 14px;
    font-weight: 500;
    font-family: var(--oula-font);
    text-decoration: none;
    transition: background 0.12s ease, color 0.12s ease;
    border-radius: 0;
}

.oula-drawer__link svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.7;
    transition: opacity 0.12s ease;
}

.oula-drawer__link:hover,
.oula-drawer__link:focus-visible {
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
    text-decoration: none;
}

.oula-drawer__link:hover svg,
.oula-drawer__link:focus-visible svg {
    opacity: 1;
}

.oula-drawer__link.is-active {
    background: rgba(199, 252, 87, 0.1);
    color: var(--oula-electric);
    font-weight: 600;
}

.oula-drawer__link.is-active svg {
    opacity: 1;
}

.oula-drawer__divider {
    height: 1px;
    background: var(--oula-deep-600);
    margin: 8px 20px;
}

.oula-drawer__footer {
    flex-shrink: 0;
    border-top: 1px solid var(--oula-deep-600);
    padding: 16px 20px calc(var(--oula-safe-bottom) + 16px);
    display: flex;
    align-items: center;
    gap: 12px;
}

.oula-drawer__footer-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--oula-deep-600);
    color: var(--oula-electric);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
    overflow: hidden;
}

.oula-drawer__footer-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.oula-drawer__footer-name {
    font-size: 13.5px;
    font-weight: 600;
    color: #fff;
    line-height: 1.2;
}

.oula-drawer__footer-sub {
    font-size: 11.5px;
    color: rgba(255, 255, 255, 0.45);
    margin-top: 1px;
}

/* ════════════════════════════════
   Mobile topbar additions
   ════════════════════════════════ */
.oula-mobile-hamburger {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--oula-ink);
    padding: 0;
    flex-shrink: 0;
}

.oula-mobile-logo {
    display: none;
    align-items: center;
}

/* ════════════════════════════════
   @media ≤ 900px: activate mobile shell
   ════════════════════════════════ */
@media (max-width: 900px) {
    /* Show mobile elements */
    .oula-bottom-nav        { display: flex; }
    .oula-mobile-hamburger  { display: flex; }
    .oula-mobile-logo       { display: flex; }
    /* NOTE: .oula-drawer-overlay stays display:none until JS opens it.
       Forcing display:block here made an invisible overlay intercept every click. */

    /* Hide desktop sidebar — max specificity to beat Velzon's [data-layout=vertical] .app-menu */
    html[data-layout=vertical] body .app-menu.navbar-menu,
    html[data-layout=vertical] .app-menu.navbar-menu,
    html .app-menu.navbar-menu { display: none !important; }
    /* Also crush the margin-left trick Velzon uses on mobile */
    html[data-layout=vertical] .app-menu { margin-left: -100% !important; }

    #topnav-hamburger-icon  { display: none !important; }

    /* Pad main content so it clears the bottom nav */
    .main-content {
        padding-bottom: calc(var(--oula-mobile-bottomnav-h) + var(--oula-safe-bottom) + 8px) !important;
        margin-left: 0 !important;
    }

    /* Page content horizontal padding */
    .page-content {
        padding: 12px 0 !important;
    }

    .container-fluid {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* ── Oula layout (oula.php) mobile adaptations ── */
    /* Hide the custom sidebar on mobile */
    .oula-sidebar { display: none !important; }

    /* Make the frame fill the viewport */
    .oula-frame {
        flex-direction: column;
    }
    .oula-frame__main {
        width: 100%;
        min-width: 0;
    }

    /* Pad bottom of oula content to clear bottom nav */
    .oula-frame__content {
        padding-bottom: calc(var(--oula-mobile-bottomnav-h) + var(--oula-safe-bottom) + 16px);
    }

    /* Show mobile hamburger in oula-header */
    .oula-header__mobile-hamburger { display: flex; }

    /* Header compacto en mobile: esconder buscador y colapsar el botón de usuario
       a solo avatar para que el lado derecho no se desborde.
       Sticky para que el botón de perfil siga accesible al hacer scroll. */
    .oula-header                { padding: 0 12px !important; gap: 8px; position: sticky; top: 0; z-index: 50; }
    .oula-header__search        { display: none !important; }
    .oula-header__right         { gap: 8px; margin-left: auto; }
    .oula-header__user          { padding: 2px !important; }
    .oula-header__user > div:first-child { display: none !important; }
    .oula-header__divider       { display: none !important; }
    .oula-lang-switcher__code   { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   FASE 3 — Adaptaciones página por página (≤ 900px)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 900px) {

    /* ──────────────────────────────────────
       1. DASHBOARD
       ────────────────────────────────────── */

    /* Hero: body en columna (dial arriba, métricas abajo) */
    .oula-hero-score__body {
        flex-direction: column;
        gap: 20px;
    }

    .oula-dial {
        align-self: center;
    }

    /* Burst decorativo más pequeño para no ocupar espacio */
    .oula-hero-score__burst {
        width: 160px;
        height: 160px;
        right: -40px;
        top: -30px;
    }

    /* Métricas: 2×2 */
    .oula-hero-score__metrics-grid {
        grid-template-columns: 1fr 1fr;
    }

    /* CTAs: en fila igual */
    .oula-hero-score__cta {
        flex-direction: row;
        gap: 8px;
    }

    .oula-hero-score__cta > * {
        flex: 1;
        justify-content: center;
        text-align: center;
    }

    /* Headline más pequeño */
    .oula-hero-score__headline {
        font-size: 18px;
    }

    /* KPI: asegurar 2 columnas (ya hereda de ≤ 1200px) */
    .oula-dash__grid--kpi {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Asistente IA / managing / requires: full ancho */
    .oula-dash__grid--middle,
    .oula-dash__grid--bottom {
        grid-template-columns: 1fr;
    }

    /* Requires rows: más compactas */
    .oula-requires__row {
        padding: 10px 14px;
        gap: 10px;
    }

    .oula-requires__title {
        font-size: 13px;
    }

    /* ──────────────────────────────────────
       2. INBOX / SOLICITUDES
       ────────────────────────────────────── */

    /* Tabs → scroll horizontal con snap: labels tamaño natural,
       se deslizan con swipe, tab activo se ancla con scroll-snap */
    .oula-tabs-editorial {
        display: flex;
        width: 100%;
        flex-wrap: nowrap;
        gap: 4px;
        padding: 4px;
        border-radius: 10px;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x proximity;
        scrollbar-width: none;
        /* Fade lateral para indicar que hay más contenido */
        mask-image: linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
        -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    }

    .oula-tabs-editorial::-webkit-scrollbar { display: none; }

    .oula-tabs-editorial__tab {
        flex-shrink: 0;
        white-space: nowrap;
        font-size: 13px;
        padding: 8px 12px;
        scroll-snap-align: start;
    }

    /* Asegurar que el tab activo entre en vista al cargar */
    .oula-tabs-editorial__tab.is-active {
        scroll-snap-align: center;
    }

    /* Filter bar: stack vertical */
    .oula-filter-bar {
        flex-direction: column;
        gap: 10px;
    }

    .oula-filter-bar__search {
        width: 100%;
    }

    .oula-filter-bar__chips {
        flex-wrap: wrap;
        gap: 6px;
    }

    /* Toolbar: stack vertical */
    .oula-inbox-toolbar {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .oula-inbox-toolbar__controls {
        width: 100%;
        flex-wrap: wrap;
    }

    /* View toggle: ocultar en mobile (forzar lista) */
    .oula-view-toggle {
        display: none !important;
    }

    /* Table: scroll horizontal + hide less-critical columns */
    .oula-inbox-card .solicitud-grid-table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Hide: ID (col 1), Area (col 3), Assignee (col 6), Created (col 8), Actions (col 9) */
    .solicitud-grid-table th:nth-child(1),
    .solicitud-grid-table td:nth-child(1),
    .solicitud-grid-table th:nth-child(3),
    .solicitud-grid-table td:nth-child(3),
    .solicitud-grid-table th:nth-child(6),
    .solicitud-grid-table td:nth-child(6),
    .solicitud-grid-table th:nth-child(8),
    .solicitud-grid-table td:nth-child(8),
    .solicitud-grid-table th:nth-child(9),
    .solicitud-grid-table td:nth-child(9) {
        display: none !important;
    }

    /* Subject: 2 líneas max */
    .oula-row-subject__text {
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /* Solicitud ID más compacto */
    .oula-row-id {
        font-size: 11px;
    }

    /* ──────────────────────────────────────
       3. SOLICITUD DETAIL
       ────────────────────────────────────── */

    /* Composer: sticky sobre el bottom nav */
    .oula-composer {
        position: sticky;
        bottom: calc(var(--oula-mobile-bottomnav-h) + var(--oula-safe-bottom));
        z-index: 100;
        margin: 0 -16px;
        border-radius: 0;
        border-left: none;
        border-right: none;
        box-shadow: 0 -4px 20px rgba(13,43,38,0.1);
    }

    /* Timeline: reducir padding lateral */
    .oula-timeline {
        padding: 0;
    }

    .oula-timeline__item {
        padding-left: 32px;
    }

    /* Detail layout: single column, remove side padding */
    .oula-view-detail-grid,
    .oula-detail-grid {
        grid-template-columns: 1fr !important;
    }

    /* Activity + metadata: full width */
    .oula-detail-sidebar {
        display: none; /* colapsado por defecto en mobile */
    }

    /* Breadcrumb: truncar */
    .breadcrumb {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .breadcrumb::-webkit-scrollbar { display: none; }

    .breadcrumb-item + .breadcrumb-item {
        white-space: nowrap;
    }

    /* ──────────────────────────────────────
       4. PLAN DIARIO
       ────────────────────────────────────── */

    /* KPIs: 2 columnas (ya heredado de 767px en plan-diario.css) */
    .pd-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Título de página */
    .pd-page-title {
        font-size: 22px;
    }

    /* Week nav: más compacto */
    .pd-week-nav {
        gap: 8px;
    }

    .pd-week-nav__label {
        font-size: 13px;
    }

    /* Grid wrapper: full ancho, scroll horizontal ya activado */
    .plan-diario-grid-wrapper {
        margin: 0 -16px;
        padding: 0 16px;
    }

    /* Panel de asignación + tabla: full width */
    .pd-panel {
        margin: 0;
    }

    /* Distribution bar: compactar */
    .pd-dist-card {
        padding: 14px;
    }

    /* ──────────────────────────────────────
       5. CONFIGURACIÓN
       ────────────────────────────────────── */

    /* Sidebar de config: ocultar en mobile
       (ya stackea por Bootstrap col-12 col-xl-3,
        pero lo hacemos visualmente compacto) */
    .configuration-index .col-12.col-xl-3 {
        display: none !important;
    }

    .configuration-index .col-12.col-xl-9 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }

    /* Config nav compacto (cuando se muestra en otras vistas) */
    .oula-config-nav {
        display: flex;
        flex-direction: row;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        gap: 6px;
        padding: 12px 16px;
        border-radius: 12px;
        scrollbar-width: none;
    }

    .oula-config-nav::-webkit-scrollbar { display: none; }

    .oula-config-nav__head { display: none; }

    .oula-config-nav__list {
        display: flex;
        flex-direction: row;
        gap: 6px;
        padding: 0;
    }

    .oula-config-nav__item {
        flex-shrink: 0;
        border-radius: 20px;
        padding: 6px 14px;
        min-height: auto;
        gap: 0;
    }

    .oula-config-nav__item::before {
        display: none;
    }

    .oula-config-nav__desc {
        display: none;
    }

    .oula-config-nav__label {
        font-size: 12.5px;
        font-weight: 600;
    }

    /* Card grids ya son 1 columna por los @media que tienen */
    .cfg-areas__grid {
        grid-template-columns: 1fr;
    }

}

/* ═══════════════════════════════════════════════════════════
   OULA INBOX ITEM — rows planos dentro de un card único
   (match exacto con design handoff: "08 · Inbox (swipe)")
   ═══════════════════════════════════════════════════════════ */
.oula-inbox-list {
    background: var(--oula-card, #fff);
    border: 1px solid var(--oula-line, #e6e6e4);
    border-radius: 16px;
    overflow: hidden;
    margin: 0;
}

.oula-inbox-item {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    padding: 12px 14px 12px 11px;
    background: var(--oula-card, #fff);
    border-left: 3px solid var(--stripe, #99A19D);
    border-bottom: 1px solid var(--oula-line, #e6e6e4);
    text-decoration: none;
    color: inherit;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.12s ease;
}

.oula-inbox-item:last-child {
    border-bottom: none;
}

.oula-inbox-item:active {
    background: var(--oula-paper-2, #f4f1e7);
}

.oula-inbox-item:hover {
    color: inherit;
    text-decoration: none;
    background: var(--oula-paper-2, #f4f1e7);
}

/* Avatar circular con la inicial */
.oula-inbox-item__avatar {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: var(--oula-font);
    font-weight: 600;
    font-size: 12.5px;
    letter-spacing: 0.3px;
    margin-top: 1px;
}

/* Cuerpo — id/area, título, chips */
.oula-inbox-item__body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.oula-inbox-item__top {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 10.5px;
    line-height: 1.2;
    letter-spacing: 0.2px;
    font-weight: 500;
}

.oula-inbox-item__id {
    font-family: var(--oula-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
    font-weight: 500;
    color: var(--oula-mute, #8b8f94);
}

.oula-inbox-item__sep {
    color: var(--oula-mute-2, #99A19D);
}

.oula-inbox-item__area {
    color: var(--oula-ink-2, #4b5058);
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 45%;
}

.oula-inbox-item__ia {
    margin-left: auto;
    flex-shrink: 0;
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 1px 5px;
    border-radius: 4px;
    background: var(--oula-electric-200, #E5FBA4);
    color: var(--oula-deep, #0d2b26);
}

.oula-inbox-item__badge {
    flex-shrink: 0;
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 1px 6px;
    border-radius: 99px;
    line-height: 1.4;
    text-transform: uppercase;
    border: 1px solid transparent;
}

.oula-inbox-item__badge--task {
    background: var(--oula-deep, #0d2b26);
    color: #fff;
    border-color: var(--oula-deep, #0d2b26);
}

.oula-inbox-item__badge--request {
    background: var(--oula-paper-2, #EEEBE1);
    color: var(--oula-ink-2, #2A3A36);
    border-color: var(--oula-line, #E5E2D8);
}

.oula-inbox-item__badge--unassigned {
    background: var(--oula-warn-50, #FBEED6);
    color: #9A6A1F;
    border-color: var(--oula-warn-50, #FBEED6);
}

.oula-inbox-item__title {
    font-size: 13.5px;
    font-weight: 500;
    line-height: 1.3;
    color: var(--oula-ink, #1a1d21);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.oula-inbox-item__chips {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 2px;
}

.oula-inbox-item__channel {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 7px;
    border-radius: 99px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1.3;
}

.oula-inbox-item__channel .oula-inbox-item__dot {
    width: 5px;
    height: 5px;
}

.oula-inbox-item__sla {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 7px;
    border-radius: 99px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1.3;
    font-variant-numeric: tabular-nums;
}

.oula-inbox-item__sla .oula-inbox-item__dot {
    width: 5px;
    height: 5px;
    background: currentColor;
}

.oula-inbox-item__sla--ok {
    background: var(--oula-ok-50, #E8F5E9);
    color: var(--oula-ok, #2F8A4A);
}

.oula-inbox-item__sla--warn {
    background: var(--oula-warn-50, #FBF1DD);
    color: #9A6A1F;
}

.oula-inbox-item__sla--danger {
    background: var(--oula-danger-50, #F9DDD6);
    color: #A83524;
}

.oula-inbox-item__sla--resolved {
    background: var(--oula-paper-2, #f4f1e7);
    color: var(--oula-mute, #8b8f94);
}

.oula-inbox-item__state {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 7px;
    border-radius: 99px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1.3;
    text-transform: capitalize;
}

.oula-inbox-item__state .oula-inbox-item__dot {
    background: currentColor;
    width: 5px;
    height: 5px;
}

.oula-inbox-item__state--open {
    background: var(--oula-paper-2, #EEEBE1);
    color: var(--oula-ink-2, #2A3A36);
}

.oula-inbox-item__state--active {
    background: var(--oula-electric-200, #E5FBA4);
    color: var(--oula-deep, #0d2b26);
}

.oula-inbox-item__state--waiting {
    background: var(--oula-warn-50, #FBEED6);
    color: #9A6A1F;
}

.oula-inbox-item__state--info {
    background: #E4EAFD;
    color: #3B54C4;
}

.oula-inbox-item__state--done {
    background: var(--oula-ok-50, #DDF1E5);
    color: var(--oula-ok, #2E8B5C);
}

.oula-inbox-item__state--rejected {
    background: var(--oula-danger-50, #FBE8E4);
    color: #A83524;
}

.oula-inbox-item__dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    flex-shrink: 0;
}

.oula-inbox-item__time {
    margin-left: auto;
    font-family: var(--oula-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
    font-size: 10.5px;
    color: var(--oula-mute-2, #99A19D);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   SWIPE ACTIONS — solo para tareas (Aceptar / Rechazar)
   ═══════════════════════════════════════════════════════════ */
.oula-inbox-swipe {
    position: relative;
    overflow: hidden;
    background: var(--oula-card, #fff);
    border-bottom: 1px solid var(--oula-line, #e6e6e4);
}

.oula-inbox-swipe:last-child {
    border-bottom: none;
}

.oula-inbox-swipe .oula-inbox-item {
    border-bottom: none;
    position: relative;
    z-index: 2;
    background: var(--oula-card, #fff);
    transform: translate3d(0, 0, 0);
    transition: transform 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
    will-change: transform;
    touch-action: pan-y;
    user-select: none;
    -webkit-user-select: none;
    -webkit-user-drag: none;
}

.oula-inbox-swipe.is-dragging .oula-inbox-item {
    transition: none;
}

.oula-inbox-swipe__action {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 96px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.3px;
    z-index: 1;
    user-select: none;
    pointer-events: none;
}

.oula-inbox-swipe__action--accept {
    left: 0;
    background: var(--oula-ok, #2E8B5C);
}

.oula-inbox-swipe__action--reject {
    right: 0;
    background: var(--oula-danger, #D94A38);
}

.oula-inbox-swipe__icon {
    font-size: 18px;
    line-height: 1;
    font-weight: 700;
}

.oula-inbox-swipe__label {
    font-size: 11px;
    line-height: 1;
}

.oula-inbox-swipe.is-committing .oula-inbox-item {
    transition: transform 0.25s ease;
}

.oula-inbox-swipe.is-removing {
    transition: height 0.28s ease, opacity 0.2s ease, margin 0.28s ease;
    overflow: hidden;
}

/* Sentinel + estado de carga para infinite scroll */
.oula-inbox-sentinel {
    min-height: 1px;
    padding: 16px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.oula-inbox-sentinel__spinner {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--oula-line, #e6e6e4);
    border-top-color: var(--oula-deep, #0d2b26);
    animation: oula-spin 0.8s linear infinite;
}

.oula-inbox-sentinel.is-done {
    color: var(--oula-mute, #8b8f94);
    font-size: 12px;
    padding: 20px 0 28px;
}

@keyframes oula-spin {
    to { transform: rotate(360deg); }
}

/* ═══ Variante COMPACT (dashboard, widgets laterales) ═══════════════════
 * Densidad alta: padding reducido, avatar más chico, chevron a la derecha.
 * Reutiliza las clases .oula-inbox-* con modificadores --compact.
 */
.oula-inbox-list--compact {
    border-radius: 12px;
    overflow: hidden;
}

.oula-inbox-item--compact {
    padding: 10px 12px 10px 9px;
    gap: 10px;
    align-items: center;
}

.oula-inbox-item--compact .oula-inbox-item__body {
    gap: 4px;
    min-width: 0;
    flex: 1;
}

.oula-inbox-item__avatar--sm {
    width: 28px;
    height: 28px;
    font-size: 11px;
    font-weight: 600;
}

.oula-inbox-item--compact .oula-inbox-item__title {
    font-size: 13px;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.oula-inbox-item--compact .oula-inbox-item__top {
    font-size: 11px;
}

.oula-inbox-item--compact .oula-inbox-item__chips {
    gap: 6px;
}

.oula-inbox-item__chev {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--oula-mute, #8b8f94);
    margin-left: 2px;
}

/* En mobile: ajustes menores de padding */
@media (max-width: 900px) {
    .oula-inbox-list {
        border-radius: 14px;
    }
    .oula-inbox-item {
        padding: 11px 12px 11px 10px;
        gap: 10px;
    }
    .oula-inbox-item__avatar {
        width: 30px;
        height: 30px;
        font-size: 12px;
    }
    .oula-inbox-item__title {
        font-size: 13px;
    }
    /* En viewport angosto incluso el compact se ajusta */
    .oula-inbox-item--compact {
        padding: 10px 10px 10px 8px;
    }
    .oula-inbox-item--compact .oula-inbox-item__title {
        white-space: normal;
    }
}

/* ───────────── State Timeline (request detail) ───────────── */
.oula-state-timeline {
    --osl-done:        var(--oula-ok);
    --osl-active:      var(--oula-warn);
    --osl-active-ink:  #8A5A12;
    --osl-active-halo: rgba(232, 163, 58, 0.28);
    --osl-pending:     var(--oula-line-2);
    --osl-pending-ink: var(--oula-mute-2);

    list-style: none;
    margin: 0 0 18px;
    padding: 14px 0;
    display: flex;
    align-items: center;
    width: 100%;
    border-bottom: 1px solid var(--oula-line);
    font-family: var(--oula-font);
}

.oula-state-timeline__pill {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 14px 7px 12px;
    background: var(--oula-card);
    border-radius: var(--oula-radius-pill);
    border: 1.5px solid var(--osl-pending);
    color: var(--osl-pending-ink);
    font-size: 12.5px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.005em;
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    transition:
        border-color 220ms cubic-bezier(0.2, 0.7, 0.2, 1),
        color 220ms cubic-bezier(0.2, 0.7, 0.2, 1),
        background-color 220ms cubic-bezier(0.2, 0.7, 0.2, 1),
        transform 220ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

.oula-state-timeline__pill:hover {
    background: #FFFDF8;
    transform: translateY(-0.5px);
}

.oula-state-timeline__pill:focus-visible {
    outline: 2px solid var(--oula-ink);
    outline-offset: 2px;
}

.oula-state-timeline__pill--done {
    border-color: var(--osl-done);
    color: var(--osl-done);
}
.oula-state-timeline__pill--done:hover {
    background: var(--oula-ok-50);
}

.oula-state-timeline__pill--active {
    border-color: var(--osl-active);
    color: var(--osl-active-ink);
    z-index: 2;
}
.oula-state-timeline__pill--active:hover {
    background: var(--oula-warn-50);
}

.oula-state-timeline__pill--pending {
    border-color: var(--osl-pending);
    color: var(--osl-pending-ink);
}

.oula-state-timeline__line {
    flex: 1 1 auto;
    height: 2px;
    min-width: 24px;
    background: var(--oula-line);
    opacity: 0.7;
    transition: background 260ms cubic-bezier(0.2, 0.7, 0.2, 1), opacity 260ms cubic-bezier(0.2, 0.7, 0.2, 1);
    list-style: none;
}
.oula-state-timeline__line--done {
    background: var(--osl-done);
    opacity: 1;
}
.oula-state-timeline__line--neutral {
    background: var(--oula-line);
    opacity: 0.6;
}

.oula-state-timeline__ind {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    flex: 0 0 14px;
}
.oula-state-timeline__ind--done svg {
    width: 14px;
    height: 14px;
    color: var(--osl-done);
}
.oula-state-timeline__ind--active {
    position: relative;
    width: 14px;
    height: 14px;
}
.oula-state-timeline__ind--active::after {
    content: "";
    position: absolute;
    inset: 3px;
    background: var(--osl-active);
    border-radius: 50%;
    box-shadow: 0 0 0 3px var(--osl-active-halo);
}
.oula-state-timeline__ind--pending {
    width: 10px;
    height: 10px;
    border: 1.5px solid var(--osl-pending);
    border-radius: 50%;
}

.oula-state-timeline__label {
    line-height: 1;
}

.oula-state-timeline__badge {
    position: absolute;
    top: -7px;
    right: -7px;
    width: 18px;
    height: 18px;
    background: var(--osl-active);
    color: #FFFFFF;
    border: 2px solid var(--oula-paper);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--oula-font);
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
}

@media (max-width: 720px) {
    .oula-state-timeline {
        overflow-x: auto;
        flex-wrap: nowrap;
        scrollbar-width: none;
    }
    .oula-state-timeline::-webkit-scrollbar { display: none; }
    .oula-state-timeline__line { min-width: 16px; }
}

/* ─── Weekly Execution Score (Fase 1) ──────────────────────────────── */
.exec-score-hero {
    position: relative;
    background: linear-gradient(135deg, #0D2B26 0%, #133A32 100%);
    color: #fff;
    border-radius: 16px;
    border: 1px solid #1C4D43;
    overflow: hidden;
    margin-bottom: 16px;
}
.exec-score-hero__burst {
    position: absolute;
    right: -90px; top: -90px;
    width: 320px; height: 320px;
    opacity: 0.10;
    pointer-events: none;
}
.exec-score-hero__strip {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 24px 12px;
    border-bottom: 1px solid #1C4D43;
}
.exec-score-hero__strip-left {
    display: flex; align-items: center; gap: 14px; min-width: 0;
}
.exec-score-hero__label {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 11px; font-weight: 700; color: #C7FC57;
    letter-spacing: 1.4px; text-transform: uppercase;
}
.exec-score-hero__dot {
    width: 8px; height: 8px; border-radius: 8px; background: #C7FC57;
    box-shadow: 0 0 0 4px rgba(199,252,87,0.18);
}
.exec-score-hero__divider {
    width: 1px; height: 14px; background: #2A6558;
}
.exec-score-hero__week {
    font-size: 12.5px; color: rgba(255,255,255,0.72); white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
}
.exec-score-hero__weekno {
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    color: #fff; font-weight: 600;
}
.exec-score-hero__strip-actions {
    display: flex; gap: 8px; flex-shrink: 0;
}
.exec-score-hero__btn {
    display: inline-flex; align-items: center; gap: 6px;
    border-radius: 8px; padding: 7px 12px;
    font-size: 12px; font-weight: 600; cursor: pointer;
    line-height: 1; transition: background 0.15s, border-color 0.15s;
}
.exec-score-hero__btn--ghost {
    background: rgba(255,255,255,0.04); color: #fff;
    border: 1px solid rgba(255,255,255,0.14);
}
.exec-score-hero__btn--ghost:hover { background: rgba(255,255,255,0.08); }
.exec-score-hero__btn--accent {
    background: #C7FC57; color: #0D2B26; border: 1px solid #C7FC57;
}
.exec-score-hero__btn--accent:hover:not(:disabled) { background: #B3F03A; }
.exec-score-hero__btn:disabled { opacity: 0.6; cursor: not-allowed; }
.exec-score-hero__btn-ico { font-size: 12px; }

.exec-score-hero__body {
    position: relative;
    display: grid;
    grid-template-columns: 320px 1fr 1fr;
    gap: 28px;
    padding: 22px 24px 24px;
}

.exec-score-hero__col { min-width: 0; }
.exec-score-hero__col--dial { display: flex; flex-direction: column; gap: 16px; }

.exec-score-hero__seclabel {
    font-size: 10.5px; font-weight: 700;
    color: rgba(255,255,255,0.55);
    letter-spacing: 1px; text-transform: uppercase;
    margin-bottom: 10px;
}

.exec-score-hero__dial-row {
    display: flex; align-items: center; gap: 18px;
}
.exec-score-dial { position: relative; width: 156px; height: 156px; flex-shrink: 0; }
.exec-score-dial__center {
    position: absolute; inset: 0; display: grid; place-items: center; text-align: center;
}
.exec-score-dial__num {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 56px; font-weight: 500; line-height: 1; letter-spacing: -2.5px;
}
.exec-score-dial__cap {
    font-size: 10px; color: rgba(255,255,255,0.5);
    letter-spacing: 1.4px; text-transform: uppercase; margin-top: 4px;
}
.exec-score-hero__dial-side { flex: 1; min-width: 0; }
.exec-score-hero__sublabel {
    font-size: 10.5px; color: rgba(255,255,255,0.55);
    letter-spacing: 1px; text-transform: uppercase; font-weight: 700;
    margin-bottom: 6px;
}
.exec-score-hero__hint {
    font-size: 11.5px; color: rgba(255,255,255,0.55);
    margin-top: 8px; line-height: 1.5;
}
.exec-score-hero__hint b { color: #fff; font-weight: 600; }
.exec-score-hero__hint-strong { color: #C7FC57 !important; }

.exec-score-delta {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 12px; border-radius: 99px;
}
.exec-score-delta--up   { background: rgba(199,252,87,0.12); border: 1px solid rgba(199,252,87,0.32); color: #C7FC57; }
.exec-score-delta--down { background: rgba(217,74,56,0.16);  border: 1px solid rgba(217,74,56,0.4);   color: #E8634F; }
.exec-score-delta--none { color: rgba(255,255,255,0.4); font-size: 12px; padding: 6px 0; }
.exec-score-delta__arrow { font-size: 11px; }
.exec-score-delta__num   { font-size: 16px; font-weight: 600; }
.exec-score-delta__caption { font-size: 11px; opacity: 0.85; }

.exec-score-reading {
    padding: 12px 14px;
    background: rgba(199,252,87,0.07);
    border: 1px solid rgba(199,252,87,0.18);
    border-radius: 10px;
    font-size: 12px; line-height: 1.5;
    color: rgba(255,255,255,0.85);
}
.exec-score-reading__head {
    display: flex; align-items: center; gap: 6px;
    color: #C7FC57; font-weight: 700;
    font-size: 10.5px; letter-spacing: 0.8px; text-transform: uppercase;
    margin-bottom: 4px;
}
.exec-score-reading__ico { color: #C7FC57; }
.exec-score-reading__body b,
.exec-score-reading__body strong { color: #fff; font-weight: 600; }
.exec-score-reading__badge {
    margin-left: auto;
    padding: 1px 6px;
    border: 1px solid rgba(199, 252, 87, 0.45);
    border-radius: 999px;
    color: #C7FC57;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.6px;
    text-transform: uppercase;
}
.exec-score-move--flat {
    border-color: rgba(255,255,255,0.10);
}
.exec-score-move--flat .exec-score-move__ico { color: rgba(255,255,255,0.55); }

.exec-score-hero__sub-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.exec-score-sub {
    padding: 12px 14px; border-radius: 10px;
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07);
}
.exec-score-sub--warn {
    background: rgba(232,131,79,0.06);
    border-color: rgba(232,131,79,0.22);
}
.exec-score-sub__top {
    display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px;
}
.exec-score-sub__name { font-size: 12px; color: rgba(255,255,255,0.75); font-weight: 600; }
.exec-score-sub__weight { font-size: 10px; color: rgba(255,255,255,0.4); font-weight: 700; }
.exec-score-sub__row { display: flex; align-items: baseline; gap: 8px; }
.exec-score-sub__val {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 28px; font-weight: 500; letter-spacing: -1px;
}
.exec-score-sub__delta { font-size: 11px; font-weight: 700; }
.exec-score-sub__delta--up   { color: #C7FC57; }
.exec-score-sub__delta--down { color: #E8634F; }
.exec-score-sub__bar {
    margin-top: 8px; height: 4px; background: rgba(255,255,255,0.07); border-radius: 99px; overflow: hidden;
}
.exec-score-sub__bar-fill { height: 100%; background: #C7FC57; border-radius: 99px; }
.exec-score-sub--warn .exec-score-sub__bar-fill { background: #E8834F; }

.exec-score-moves { display: flex; flex-direction: column; gap: 8px; }
.exec-score-move {
    padding: 10px 12px; border-radius: 10px;
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07);
}
.exec-score-move--up   { background: rgba(199,252,87,0.05); border-color: rgba(199,252,87,0.18); }
.exec-score-move--down { background: rgba(217,74,56,0.06); border-color: rgba(217,74,56,0.22); }
.exec-score-move--flat { opacity: 0.85; }
.exec-score-move__head {
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 4px;
}
.exec-score-move__ico {
    width: 22px; height: 22px; border-radius: 6px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 700;
    background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.7);
}
.exec-score-move--up .exec-score-move__ico   { background: rgba(199,252,87,0.16); color: #C7FC57; }
.exec-score-move--down .exec-score-move__ico { background: rgba(217,74,56,0.18); color: #E8634F; }
.exec-score-move__title { flex: 1; font-size: 12.5px; font-weight: 600; color: #fff; }
.exec-score-move__delta { font-size: 12px; font-weight: 700; color: rgba(255,255,255,0.85); }
.exec-score-move--up .exec-score-move__delta   { color: #C7FC57; }
.exec-score-move--down .exec-score-move__delta { color: #E8634F; }
.exec-score-move__body { font-size: 11.5px; color: rgba(255,255,255,0.6); line-height: 1.45; padding-left: 30px; }
.exec-score-moves__hint {
    font-size: 10.5px; color: rgba(255,255,255,0.35);
    margin-top: 4px; font-style: italic;
}

.exec-score-hero__seclabel--spaced { margin-top: 18px; }

/* ─── DayCurve (Fase 2) ──────────────────────────────────────────────── */
.exec-score-daycurve {
    position: relative;
    margin-top: 10px;
    padding-top: 18px;
}
.exec-score-daycurve__bars {
    position: relative;
    height: 88px;
    display: flex;
    gap: 8px;
    align-items: flex-end;
}
.exec-score-daycurve__col {
    flex: 1; display: flex; flex-direction: column;
    align-items: stretch; justify-content: flex-end;
    height: 100%;
}
.exec-score-daycurve__bar-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-end;
}
.exec-score-daycurve__bar {
    width: 100%;
    background: #C7FC57;
    border-radius: 3px 3px 0 0;
    min-height: 4px;
    transition: height 0.3s ease;
}
.exec-score-daycurve__bar--partial {
    background: repeating-linear-gradient(
        45deg,
        #C7FC57,
        #C7FC57 4px,
        rgba(199, 252, 87, 0.4) 4px,
        rgba(199, 252, 87, 0.4) 8px
    );
}
.exec-score-daycurve__bar--empty {
    background: transparent;
    border: 1px dashed rgba(255, 255, 255, 0.18);
    min-height: 8px;
}
.exec-score-daycurve__today-tag {
    position: absolute;
    top: -16px; left: 50%;
    transform: translateX(-50%);
    font-size: 9.5px;
    color: #C7FC57;
    font-weight: 700;
    letter-spacing: 0.6px;
    white-space: nowrap;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.exec-score-daycurve__refline {
    position: absolute;
    left: 0; right: 0;
    height: 1px;
    border-top: 1px dashed rgba(255, 255, 255, 0.25);
    pointer-events: none;
}
.exec-score-daycurve__refline-tag {
    position: absolute;
    right: 0;
    transform: translateY(-100%);
    font-size: 9.5px;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 0.6px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    padding: 0 0 2px 0;
}
.exec-score-daycurve__labels {
    display: flex;
    gap: 8px;
    margin-top: 6px;
}
.exec-score-daycurve__label {
    flex: 1;
    text-align: center;
}
.exec-score-daycurve__label--today .exec-score-daycurve__d {
    color: #C7FC57;
}
.exec-score-daycurve__d {
    display: block;
    font-size: 10.5px;
    color: rgba(255, 255, 255, 0.6);
    font-weight: 600;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.exec-score-daycurve__v {
    display: block;
    font-size: 11px;
    color: #fff;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    margin-top: 1px;
}

/* ─── Weekly History Card (Fase 2) ──────────────────────────────────── */
.exec-history-card {
    background: var(--oula-card, #FAF8F4);
    border: 1px solid var(--oula-line, rgba(45, 51, 42, 0.10));
    border-radius: 16px;
    padding: 22px;
    margin-bottom: 16px;
}
.exec-history-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}
.exec-history-card__eyebrow {
    font-size: 11px;
    font-weight: 700;
    color: rgba(45, 51, 42, 0.55);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.exec-history-card__title {
    font-size: 19px;
    font-weight: 600;
    color: var(--oula-ink, #1A1F1A);
    letter-spacing: -0.4px;
    font-family: 'Fraunces', 'Times New Roman', serif;
    margin: 0;
    line-height: 1.3;
}
.exec-history-card__avg { color: var(--oula-deep, #2D332A); font-weight: 700; }
.exec-history-card__actions {
    display: flex;
    gap: 6px;
}
.exec-history-card__range.is-active {
    background: rgba(45, 51, 42, 0.08);
    border-color: rgba(45, 51, 42, 0.18);
}
.exec-history-card__chart {
    position: relative;
    height: 170px;
    margin-bottom: 6px;
}
.exec-history-card__current {
    position: absolute;
    right: 0; top: 0; bottom: 0;
    width: 80px;
    background: linear-gradient(90deg, transparent 0%, rgba(199, 252, 87, 0.06) 100%);
    border-left: 1px dashed rgba(45, 51, 42, 0.16);
    pointer-events: none;
}
.exec-history-card__current-tag {
    position: absolute;
    top: 6px; right: 6px;
    font-size: 9.5px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    color: rgba(45, 51, 42, 0.55);
    font-weight: 700;
    letter-spacing: 0.5px;
}
.exec-history-card__current-dot {
    position: absolute;
    right: 22px;
    transform: translate(50%, -50%);
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #A8E635;
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px rgba(199, 252, 87, 0.3);
}
.exec-history-card__xaxis {
    display: grid;
    font-size: 9.5px;
    color: rgba(45, 51, 42, 0.55);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-weight: 600;
    margin-bottom: 12px;
}
.exec-history-card__wk { text-align: center; }
.exec-history-card__wk--current { color: #5C8A1F; font-weight: 700; }
.exec-history-card__foot {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid rgba(45, 51, 42, 0.10);
}
.exec-history-card__stat { display: flex; flex-direction: column; }
.exec-history-card__stat-label {
    font-size: 10.5px;
    color: rgba(45, 51, 42, 0.55);
    letter-spacing: 0.8px;
    text-transform: uppercase;
    font-weight: 700;
}
.exec-history-card__stat-value {
    font-size: 24px;
    font-weight: 500;
    font-family: 'Fraunces', 'Times New Roman', serif;
    color: var(--oula-ink, #1A1F1A);
    letter-spacing: -0.6px;
    margin-top: 3px;
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.exec-history-card__stat-sub {
    font-size: 11px;
    color: rgba(45, 51, 42, 0.55);
    margin-top: 4px;
}
.exec-history-card__stat--electric .exec-history-card__stat-value { color: var(--oula-deep, #2D332A); }
.exec-history-card__stat--good     .exec-history-card__stat-value { color: #5C8A1F; }
.exec-history-card__stat--bad      .exec-history-card__stat-value { color: #C2410C; }
.exec-history-card__empty {
    padding: 32px 16px;
    text-align: center;
    color: rgba(45, 51, 42, 0.55);
    font-size: 13px;
    background: rgba(45, 51, 42, 0.03);
    border-radius: 10px;
    border: 1px dashed rgba(45, 51, 42, 0.12);
}

@media (max-width: 720px) {
    .exec-history-card__foot { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1280px) {
    .exec-score-hero__body { grid-template-columns: 320px 1fr; }
    .exec-score-hero__col--moves { grid-column: 1 / -1; }
}
@media (max-width: 900px) {
    .exec-score-hero__body { grid-template-columns: 1fr; }
    .exec-score-hero__col--moves { grid-column: auto; }
    .exec-score-hero__strip { flex-wrap: wrap; }
    .exec-score-hero__strip-actions { width: 100%; }
}

/* ─── Cron snapshot card ─────────────────────────────────────────────── */
.cron-snapshot-card {
    background: var(--oula-deep, #0B1D1A); color: #fff;
    border-radius: 16px; padding: 20px;
    border: 1px solid var(--oula-deep700, #112624);
    margin-bottom: 16px;
}
.cron-snapshot-card__head {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px;
}
.cron-snapshot-card__title { font-size: 14px; font-weight: 600; }
.cron-snapshot-card__badge {
    font-size: 10px; font-weight: 700;
    padding: 3px 8px; border-radius: 99px;
    background: rgba(94,209,135,0.14); color: #5ED187;
    border: 1px solid rgba(94,209,135,0.3);
}
.cron-snapshot-card__badge--degraded,
.cron-snapshot-card__badge--failed {
    background: rgba(217,74,56,0.16); color: #E8634F;
    border-color: rgba(217,74,56,0.4);
}
.cron-snapshot-card__badge--never_run {
    background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.6);
    border-color: rgba(255,255,255,0.15);
}
.cron-snapshot-card__body {
    display: grid; grid-template-columns: 1fr 12px 1fr; gap: 10px; align-items: center; margin-bottom: 12px;
}
.cron-snapshot-card__sep { height: 1px; background: rgba(255,255,255,0.18); }
.cron-snapshot-card__block {
    padding: 10px 12px; border-radius: 10px;
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07);
}
.cron-snapshot-card__lbl {
    font-size: 10px; font-weight: 700; color: rgba(255,255,255,0.55);
    letter-spacing: 0.8px; text-transform: uppercase; margin-bottom: 4px;
}
.cron-snapshot-card__val { font-size: 12.5px; color: #fff; }
.cron-snapshot-card__user {
    margin-top: 12px; padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
}

@media (max-width: 768px) {
    .exec-score-hero__body { grid-template-columns: 1fr; }
}

/* ─── Phase 2.1: participantes results inside oula-modal ─────────────── */
.oula-participante-results {
    list-style: none;
    margin: 12px 0 0;
    padding: 0;
    max-height: 280px;
    overflow-y: auto;
    border: 1px solid rgba(13, 43, 38, 0.08);
    border-radius: 12px;
    background: #fff;
}
.oula-participante-results:empty {
    display: none;
}
.oula-participante-results li {
    padding: 10px 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid rgba(13, 43, 38, 0.05);
    transition: background 120ms ease;
}
.oula-participante-results li:last-child { border-bottom: 0; }
.oula-participante-results li:hover,
.oula-participante-results li.is-selected {
    background: var(--oula-paper-2, #F1EFE7);
}
.oula-participante-results__name {
    font-weight: 500;
    color: var(--oula-ink);
}
.oula-participante-results__meta {
    font-size: 11.5px;
    color: var(--oula-mute);
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 2px;
}
.oula-participante-results__badge {
    font-size: 10.5px;
    padding: 2px 6px;
    border-radius: 999px;
    background: var(--oula-paper-2, #F1EFE7);
    color: var(--oula-ink);
}
.oula-participante-results__badge--contact { background: #fef3c7; color: #92400e; }
.oula-participante-results__badge--external { background: #f3f4f6; color: #374151; }
.oula-participante-results__external-hint {
    color: var(--oula-deep, #0d2b26);
    font-style: italic;
    border-top: 1px dashed rgba(13, 43, 38, 0.12);
}

/* ─── Phase 2.1: participantes popover ────────────────────────────── */
.oula-participante-popover[hidden] { display: none !important; }
.oula-participante-popover {
    position: absolute;
    z-index: 1100;
    min-width: 240px;
    background: #fff;
    border: 1px solid rgba(13, 43, 38, 0.08);
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(11, 29, 26, 0.18);
    padding: 0;
    overflow: hidden;
}
.oula-participante-popover__header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(13, 43, 38, 0.08);
    background: linear-gradient(180deg, #fff 0%, #fcfbf7 100%);
}
.oula-participante-popover__info { flex: 1; min-width: 0; }
.oula-participante-popover__name {
    font-weight: 600;
    color: var(--oula-ink);
    font-size: 14px;
}
.oula-participante-popover__kind {
    font-size: 11.5px;
    color: var(--oula-mute);
    margin-top: 2px;
}
.oula-participante-popover__close {
    width: 28px; height: 28px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--oula-mute);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    transition: background 120ms ease, color 120ms ease;
}
.oula-participante-popover__close:hover {
    background: var(--oula-paper-2, #F1EFE7);
    color: var(--oula-ink);
}
.oula-participante-popover__actions {
    display: flex;
    flex-direction: column;
    padding: 6px 0;
}
.oula-participante-popover__action {
    text-align: left;
    background: transparent;
    border: 0;
    padding: 9px 14px;
    cursor: pointer;
    font-size: 13.5px;
    color: var(--oula-ink);
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 120ms ease;
}
.oula-participante-popover__action i {
    color: var(--oula-mute);
    font-size: 15px;
    width: 18px;
    text-align: center;
}
.oula-participante-popover__action:hover {
    background: var(--oula-paper-2, #F1EFE7);
}
.oula-participante-popover__action--danger { color: #dc2626; }
.oula-participante-popover__action--danger i { color: #dc2626; }
.oula-participante-popover__action--danger:hover { background: #fef2f2; }
