/* ═══════════════════════════════════════════════════════════════════
   calendar2.css — Calendario nativo (reemplazo de EventCalendar)
   Basado en claude_design_v2/styles/screens-fk.css
   Usa los tokens del proyecto (--border, --text-primary, etc.)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Head: título + navegación a la IZQUIERDA, switcher a la DERECHA ── */
.cal2-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 52px;
    flex-wrap: wrap;
    padding: 0 4px 12px;
}
.cal2-head__actions {
    display: flex;
    align-items: center;
    gap: 10px;
}
.cal2-head__left {
    display: flex;
    align-items: center;
    gap: 20px;
}
.cal2-head h1 {
    margin: 0;
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--text-primary, var(--text));
}
.cal2-nav {
    display: flex;
    align-items: center;
    gap: 4px;
}
.cal2-nav__month {
    font-family: var(--font-mono, monospace);
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary, var(--text));
    padding: 0 10px;
    letter-spacing: 0.04em;
    min-width: 140px;
    text-align: center;
}
.cal2-nav__btn {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    background: transparent;
    border-radius: 6px;
    color: var(--text-secondary, var(--text2));
    cursor: pointer;
    transition: background .12s ease, color .12s ease;
}
.cal2-nav__btn:hover {
    background: var(--bg-muted, var(--bg2));
    color: var(--text-primary, var(--text));
}
.cal2-nav__today {
    padding: 5px 14px;
    border: 1px solid var(--border);
    background: transparent;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-primary, var(--text));
    cursor: pointer;
    margin-left: 4px;
}
.cal2-nav__today:hover {
    background: var(--bg-muted, var(--bg2));
}

/* Segmented control de vistas */
.cal2-seg {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
}
.cal2-seg .seg__btn {
    padding: 5px 14px;
    border: 0;
    background: transparent;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary, var(--text2));
    cursor: pointer;
    border-right: 1px solid var(--border);
    transition: background .12s ease, color .12s ease;
}
.cal2-seg .seg__btn:last-child { border-right: 0; }
.cal2-seg .seg__btn:hover {
    background: var(--bg-muted, var(--bg2));
}
.cal2-seg .seg__btn.is-active {
    background: var(--primary, #18181b);
    color: var(--primary-text, #fafafa);
}

/* ── Body: grid + sidebar ── */
.cal2-body {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 12px;
    flex: 1;
    min-height: 0;
    height: 100%;
}

/* El área principal del calendario */
#cal2-body {
    min-height: 520px;
    overflow: auto;
}

/* ═══ VISTA MES ═══ */

.cal2-grid {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--bg-card, var(--bg));
    height: 100%;
    min-height: 520px;
}
.cal2-grid__hdr {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--bg-muted, rgba(0,0,0,0.02));
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.cal2-grid__hdr-cell {
    padding: 8px 10px;
    font-size: 10px;
    font-weight: 600;
    color: var(--text-tertiary, var(--text3));
    letter-spacing: 0.08em;
    border-right: 1px solid var(--border);
    text-align: center;
}
.cal2-grid__hdr-cell:last-child { border-right: 0; }
.cal2-grid__cells {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-auto-rows: 1fr;
    flex: 1;
    min-height: 0;
}

.cal2-day {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 6px 7px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    min-height: 90px;
    overflow: hidden;
    transition: background .12s ease;
    position: relative;
}
.cal2-day:nth-child(7n) { border-right: 0; }
.cal2-day:hover { background: var(--bg-hover, rgba(0,0,0,0.02)); }
.cal2-day.is-muted {
    background: var(--bg-muted, rgba(0,0,0,0.015));
    color: var(--text-disabled, var(--text3));
}
.cal2-day.is-muted .cal2-day__num {
    color: var(--text-disabled, var(--text3));
    opacity: 0.5;
}
.cal2-day.is-weekend:not(.is-muted) {
    background: color-mix(in srgb, var(--bg-muted, #f4f4f5) 40%, transparent);
}
.cal2-day.is-today {
    background: color-mix(in srgb, var(--claude, #c77c4f) 8%, transparent);
    box-shadow: inset 0 0 0 2px var(--claude, #c77c4f);
}
.cal2-day.is-today .cal2-day__num {
    color: var(--claude, #c77c4f);
    font-weight: 700;
}
.cal2-day.is-drop-hover {
    background: color-mix(in srgb, var(--claude, #c77c4f) 14%, transparent) !important;
    box-shadow: inset 0 0 0 2px var(--claude, #c77c4f);
}
.cal2-day.is-feriado::after {
    content: '';
    position: absolute;
    top: 0; right: 0; bottom: 0; left: 0;
    background: repeating-linear-gradient(
        135deg,
        transparent, transparent 6px,
        color-mix(in srgb, var(--amber, #eab308) 4%, transparent) 6px,
        color-mix(in srgb, var(--amber, #eab308) 4%, transparent) 7px
    );
    pointer-events: none;
}

.cal2-day__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    flex-shrink: 0;
}
.cal2-day__num {
    font-family: var(--font-mono, monospace);
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary, var(--text2));
    line-height: 1;
}
.cal2-day__pill.feriado-pill {
    font-family: var(--font-mono, monospace);
    font-size: 8px;
    padding: 1px 5px;
    border-radius: 4px;
    background: color-mix(in srgb, var(--amber, #eab308) 20%, transparent);
    color: var(--amber, #a16207);
    letter-spacing: 0.04em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 90px;
    text-transform: uppercase;
}

.cal2-day__evs {
    display: flex;
    flex-direction: column;
    gap: 2px;
    overflow: hidden;
    flex: 1;
    min-height: 0;
}

/* ═══ EVENTOS ═══ */

.cal2-ev {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 6px 3px 8px;
    border-left: 3px solid var(--blue, #3b82f6);
    border-radius: 3px;
    font-size: 10.5px;
    color: var(--text-primary, var(--text));
    background: color-mix(in srgb, var(--blue, #3b82f6) 8%, transparent);
    cursor: pointer;
    transition: background .12s ease, transform .08s ease;
    overflow: hidden;
}
.cal2-ev:hover {
    background: color-mix(in srgb, var(--blue, #3b82f6) 14%, transparent);
    transform: translateX(1px);
}
.cal2-ev.is-dragging {
    opacity: 0.4;
}
.cal2-ev.is-done {
    opacity: 0.55;
    text-decoration: line-through;
}
.cal2-ev.is-mine {
    cursor: grab;
}
.cal2-ev.is-mine:active { cursor: grabbing; }

/* Colores por categoría */
.cal2-ev.ev-blue  { border-left-color: var(--blue,  #3b82f6); background: color-mix(in srgb, var(--blue,  #3b82f6) 8%, transparent); }
.cal2-ev.ev-red   { border-left-color: var(--red,   #ef4444); background: color-mix(in srgb, var(--red,   #ef4444) 8%, transparent); }
.cal2-ev.ev-amber { border-left-color: var(--amber, #eab308); background: color-mix(in srgb, var(--amber, #eab308) 8%, transparent); }
.cal2-ev.ev-green { border-left-color: var(--green, #22c55e); background: color-mix(in srgb, var(--green, #22c55e) 8%, transparent); }
.cal2-ev.ev-slate { border-left-color: var(--text-tertiary, #71717a); background: color-mix(in srgb, var(--text-tertiary, #71717a) 8%, transparent); }

.cal2-ev.ev-blue:hover  { background: color-mix(in srgb, var(--blue,  #3b82f6) 14%, transparent); }
.cal2-ev.ev-red:hover   { background: color-mix(in srgb, var(--red,   #ef4444) 14%, transparent); }
.cal2-ev.ev-amber:hover { background: color-mix(in srgb, var(--amber, #eab308) 14%, transparent); }
.cal2-ev.ev-green:hover { background: color-mix(in srgb, var(--green, #22c55e) 14%, transparent); }
.cal2-ev.ev-slate:hover { background: color-mix(in srgb, var(--text-tertiary, #71717a) 14%, transparent); }

.cal2-ev__dot {
    width: 5px;
    height: 5px;
    border-radius: 99px;
    flex-shrink: 0;
}
.cal2-ev__dot.d-blue  { background: var(--blue,  #3b82f6); }
.cal2-ev__dot.d-red   { background: var(--red,   #ef4444); }
.cal2-ev__dot.d-amber { background: var(--amber, #eab308); }
.cal2-ev__dot.d-green { background: var(--green, #22c55e); }
.cal2-ev__dot.d-slate { background: var(--text-tertiary, #71717a); }
.cal2-ev__l {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}
/* Badge de HH del día — aparece a la derecha del título cuando la acción
   tiene HH asignadas (duración + HH/día). */
.cal2-ev__hh {
    font-family: var(--font-mono, monospace);
    font-size: 9.5px;
    color: var(--text-secondary, var(--text2));
    padding: 1px 5px;
    border-radius: 3px;
    background: color-mix(in srgb, currentColor 8%, transparent);
    flex-shrink: 0;
    opacity: 0.85;
}

.cal2-day__more {
    font-size: 10px;
    color: var(--text-tertiary, var(--text3));
    font-family: var(--font-mono, monospace);
    padding: 2px 4px;
    cursor: pointer;
    border-radius: 3px;
    transition: background .12s ease;
}
.cal2-day__more:hover {
    background: var(--bg-muted, var(--bg2));
    color: var(--text-primary, var(--text));
}

/* ═══ VISTA SEMANA ═══ */

.cal2-week {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--bg-card, var(--bg));
    min-height: 520px;
}
.cal2-week__hdr {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--bg-muted, rgba(0,0,0,0.02));
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.cal2-week__hdr-cell {
    padding: 10px 8px;
    text-align: center;
    border-right: 1px solid var(--border);
}
.cal2-week__hdr-cell:last-child { border-right: 0; }
.cal2-week__hdr-cell.is-today {
    background: color-mix(in srgb, var(--claude, #c77c4f) 10%, transparent);
    color: var(--claude, #c77c4f);
}
.cal2-week__hdr-dow {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: var(--text-tertiary, var(--text3));
    margin-bottom: 4px;
}
.cal2-week__hdr-cell.is-today .cal2-week__hdr-dow {
    color: var(--claude, #c77c4f);
}
.cal2-week__hdr-num {
    font-size: 22px;
    font-weight: 600;
    color: var(--text-primary, var(--text));
    line-height: 1;
}
.cal2-week__hdr-cell.is-today .cal2-week__hdr-num {
    color: var(--claude, #c77c4f);
    font-weight: 700;
}

.cal2-week__cols {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    flex: 1;
    min-height: 0;
}
.cal2-week__col {
    padding: 8px;
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-height: 460px;
    overflow: auto;
    position: relative;
}
.cal2-week__col:last-child { border-right: 0; }
.cal2-week__col.is-today {
    background: color-mix(in srgb, var(--claude, #c77c4f) 4%, transparent);
}
.cal2-week__col.is-weekend {
    background: var(--bg-muted, rgba(0,0,0,0.015));
}
.cal2-week__col.is-feriado::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        135deg,
        transparent, transparent 8px,
        color-mix(in srgb, var(--amber, #eab308) 5%, transparent) 8px,
        color-mix(in srgb, var(--amber, #eab308) 5%, transparent) 9px
    );
    pointer-events: none;
}
.cal2-week__col.is-drop-hover {
    background: color-mix(in srgb, var(--claude, #c77c4f) 12%, transparent) !important;
}
.cal2-week__feriado {
    font-family: var(--font-mono, monospace);
    font-size: 9px;
    color: var(--amber, #a16207);
    background: color-mix(in srgb, var(--amber, #eab308) 14%, transparent);
    padding: 3px 6px;
    border-radius: 4px;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}
.cal2-week__empty {
    color: var(--text-tertiary, var(--text3));
    font-size: 11px;
    text-align: center;
    padding: 12px 4px;
    opacity: 0.5;
}
.cal2-ev--week {
    padding: 6px 8px;
    font-size: 11px;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
}
.cal2-ev--week .cal2-ev__title {
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cal2-ev--week .cal2-ev__sub {
    font-size: 10px;
    color: var(--text-tertiary, var(--text3));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ═══ VISTA DÍA ═══ */

.cal2-dia {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    background: var(--bg-card, var(--bg));
    min-height: 520px;
}
.cal2-dia__feriado {
    font-family: var(--font-mono, monospace);
    font-size: 12px;
    color: var(--amber, #a16207);
    background: color-mix(in srgb, var(--amber, #eab308) 16%, transparent);
    padding: 8px 12px;
    border-radius: 6px;
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.cal2-dia__empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-tertiary, var(--text3));
    font-size: 13px;
    font-style: italic;
}
.cal2-dia__list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.cal2-ev--dia {
    padding: 12px 14px;
    font-size: 13px;
    align-items: flex-start;
}
.cal2-ev--dia .cal2-ev__dot {
    width: 8px;
    height: 8px;
    margin-top: 5px;
}
.cal2-ev--dia .cal2-ev__body {
    flex: 1;
    min-width: 0;
}
.cal2-ev--dia .cal2-ev__title {
    font-weight: 600;
    font-size: 13px;
    margin-bottom: 4px;
}
.cal2-ev--dia .cal2-ev__meta {
    font-size: 11px;
    color: var(--text-tertiary, var(--text3));
    display: flex;
    flex-wrap: wrap;
    gap: 4px 8px;
    align-items: center;
}
.cal2-ev--dia .cal2-ev__meta i {
    font-size: 10px;
    opacity: 0.6;
    margin-right: 2px;
}
.cal2-ev__tag {
    font-family: var(--font-mono, monospace);
    font-size: 9.5px;
    padding: 1px 6px;
    border-radius: 4px;
    background: var(--bg-muted, var(--bg2));
    color: var(--text-secondary, var(--text2));
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ═══ VISTA LISTA ═══ */

.cal2-lista {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px 20px;
    background: var(--bg-card, var(--bg));
    min-height: 520px;
}
.cal2-lista__empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-tertiary, var(--text3));
    font-size: 13px;
    font-style: italic;
}
.cal2-lista__day {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
}
.cal2-lista__day:last-child { border-bottom: 0; }
.cal2-lista__day.is-today .cal2-lista__day-label {
    color: var(--claude, #c77c4f);
    font-weight: 700;
}
.cal2-lista__day-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}
.cal2-lista__day-label {
    font-family: var(--font-mono, monospace);
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary, var(--text2));
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.cal2-ev--lista {
    padding: 8px 10px;
    align-items: flex-start;
    margin-left: 4px;
}
.cal2-ev--lista .cal2-ev__dot {
    width: 7px;
    height: 7px;
    margin-top: 4px;
}
.cal2-ev--lista .cal2-ev__body {
    flex: 1;
    min-width: 0;
}
.cal2-ev--lista .cal2-ev__title {
    font-weight: 500;
    font-size: 12px;
    margin-bottom: 2px;
}
.cal2-ev--lista .cal2-ev__meta {
    font-size: 10.5px;
    color: var(--text-tertiary, var(--text3));
    display: flex;
    flex-wrap: wrap;
    gap: 3px 6px;
}

/* ═══ POPOVER (al click en evento) ═══ */

.cal2-popover {
    position: fixed;
    z-index: 9999;
    min-width: 280px;
    max-width: 380px;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12), 0 2px 6px rgba(0,0,0,0.06);
    font-size: 12.5px;
    color: var(--text-primary, var(--text));
    overflow: hidden;
    animation: cal2PopIn .14s ease-out;
}
@keyframes cal2PopIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cal2-pop__head {
    padding: 10px 12px;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
}
.cal2-pop__title {
    flex: 1;
    font-weight: 600;
    font-size: 13px;
    line-height: 1.3;
}
.cal2-pop__close {
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.85);
    cursor: pointer;
    font-size: 13px;
    padding: 2px 6px;
    border-radius: 4px;
}
.cal2-pop__close:hover { background: rgba(255,255,255,0.15); color: #fff; }
.cal2-pop__body {
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.cal2-pop__row {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 12px;
    color: var(--text-secondary, var(--text2));
    line-height: 1.4;
}
.cal2-pop__row i {
    width: 12px;
    text-align: center;
    margin-top: 2px;
    opacity: 0.7;
    font-size: 11px;
}
.cal2-pop__desc {
    display: flex;
    gap: 8px;
    padding: 8px 10px;
    background: color-mix(in srgb, var(--blue, #3b82f6) 6%, transparent);
    border-left: 3px solid var(--blue, #3b82f6);
    border-radius: 4px;
    font-size: 12px;
    line-height: 1.5;
    color: var(--text-primary, var(--text));
    white-space: pre-wrap;
    word-break: break-word;
}
.cal2-pop__desc i {
    opacity: 0.5;
    font-size: 10px;
    margin-top: 4px;
    flex-shrink: 0;
}
.cal2-pop__foot {
    padding: 8px 12px 10px;
    border-top: 1px solid var(--border);
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
    background: var(--bg-muted, rgba(0,0,0,0.02));
}
.cal2-pop__btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 11.5px;
    font-weight: 500;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border);
    color: var(--text-primary, var(--text));
    cursor: pointer;
}
.cal2-pop__btn:hover { background: var(--bg-hover, var(--bg2)); }
.cal2-pop__btn.primary {
    background: var(--primary, #18181b);
    color: var(--primary-text, #fafafa);
    border-color: var(--primary, #18181b);
}
.cal2-pop__btn.primary:hover { opacity: 0.9; }
.cal2-pop__btn.success {
    background: var(--green, #22c55e);
    color: #fff;
    border-color: var(--green, #22c55e);
}
.cal2-pop__btn.success:hover { background: color-mix(in srgb, var(--green, #22c55e) 88%, black); }

/* ═══ Modal de duración + HH al arrastrar acción al calendario ═══ */
.cal2-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    animation: cal2PopIn .12s ease-out;
}
.cal2-modal {
    width: 100%;
    max-width: 440px;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
    overflow: hidden;
    color: var(--text-primary, var(--text));
}
.cal2-modal__head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    background: color-mix(in srgb, var(--blue, #3b82f6) 6%, transparent);
}
.cal2-modal__eyebrow {
    font-family: var(--font-mono, monospace);
    font-size: 10px;
    letter-spacing: 0.08em;
    color: var(--text-tertiary, var(--text3));
    margin-bottom: 3px;
}
.cal2-modal__title {
    font-weight: 600;
    font-size: 14px;
    color: var(--text-primary, var(--text));
    line-height: 1.3;
}
.cal2-modal__close {
    background: transparent;
    border: none;
    color: var(--text-secondary, var(--text2));
    cursor: pointer;
    font-size: 14px;
    padding: 4px 8px;
    border-radius: 4px;
    flex-shrink: 0;
}
.cal2-modal__close:hover {
    background: var(--bg-muted, var(--bg2));
    color: var(--text-primary, var(--text));
}
.cal2-modal__body {
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.cal2-modal__row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.cal2-modal__row label {
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary, var(--text2));
    letter-spacing: 0.02em;
}
.cal2-modal__row input {
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--bg-card, #fff);
    color: var(--text-primary, var(--text));
    font-size: 13px;
    font-family: inherit;
}
.cal2-modal__row input:focus {
    outline: 2px solid color-mix(in srgb, var(--blue, #3b82f6) 40%, transparent);
    outline-offset: 0;
    border-color: var(--blue, #3b82f6);
}
.cal2-modal__hint {
    font-size: 10.5px;
    color: var(--text-tertiary, var(--text3));
    font-style: italic;
    margin-top: 2px;
}
/* ═══ Panel de entregables (status del control documental) ═══ */
.cal2-modal__docs {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 6px;
    background: var(--bg-muted, rgba(0,0,0,0.02));
    border: 1px solid var(--border);
    border-radius: 6px;
    max-height: 140px;
    overflow-y: auto;
}
.cal2-modal__doc {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 7px;
    background: var(--bg-card, #fff);
    border-radius: 4px;
    font-size: 11px;
    border-left: 3px solid var(--border);
}
.cal2-modal__doc-code {
    flex: 1;
    font-family: var(--font-mono, monospace);
    font-size: 10.5px;
    color: var(--text-primary, var(--text));
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cal2-modal__doc-rev {
    font-family: var(--font-mono, monospace);
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
    background: color-mix(in srgb, var(--claude, #c77c4f) 14%, transparent);
    color: var(--claude, #c77c4f);
    flex-shrink: 0;
}
.cal2-modal__doc-estado {
    font-size: 9.5px;
    font-weight: 500;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    flex-shrink: 0;
    text-align: center;
    min-width: 80px;
}
/* Colores por estado (mismos que control documental) */
.cal2-modal__doc-estado.en_elaboracion {
    background: color-mix(in srgb, var(--text-tertiary, #71717a) 14%, transparent);
    color: var(--text-secondary, var(--text2));
}
.cal2-modal__doc-estado.rev_interna {
    background: color-mix(in srgb, var(--blue, #3b82f6) 14%, transparent);
    color: var(--blue, #3b82f6);
}
.cal2-modal__doc-estado.enviado_cliente {
    background: color-mix(in srgb, var(--amber, #eab308) 18%, transparent);
    color: var(--amber, #a16207);
}
.cal2-modal__doc-estado.aprobado {
    background: color-mix(in srgb, var(--green, #22c55e) 16%, transparent);
    color: var(--green, #16a34a);
}
.cal2-modal__doc-estado.aprobado_obs {
    background: color-mix(in srgb, var(--green, #22c55e) 10%, transparent);
    color: var(--green, #16a34a);
}
.cal2-modal__doc-estado.rechazado {
    background: color-mix(in srgb, var(--red, #ef4444) 14%, transparent);
    color: var(--red, #ef4444);
}
.cal2-modal__preview {
    padding: 10px 12px;
    background: color-mix(in srgb, var(--blue, #3b82f6) 6%, transparent);
    border-left: 3px solid var(--blue, #3b82f6);
    border-radius: 4px;
    font-size: 12px;
    line-height: 1.5;
    color: var(--text-primary, var(--text));
}
.cal2-modal__preview i {
    font-size: 10px;
    opacity: 0.7;
    margin-right: 4px;
}
.cal2-modal__preview:empty { display: none; }
.cal2-modal__foot {
    padding: 10px 16px 14px;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    border-top: 1px solid var(--border);
    background: var(--bg-muted, rgba(0,0,0,0.02));
}
.cal2-pop__note {
    font-size: 10.5px;
    color: var(--text-tertiary, var(--text3));
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-style: italic;
}
