/* lucyna.dev — edet-outliner.css (Batch-2 P3)
   Spreadsheet outline of scenes. Tokens only. */

.dr-otl { display: flex; flex-direction: column; gap: 0.6rem; height: 100%; }
.dr-otl-bar { display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.dr-otl-filter {
    height: 30px; min-width: 180px;
    background: var(--bg-elevated); color: var(--fg);
    border: 1px solid var(--rule); border-radius: 6px; padding: 0 0.5rem;
    font-family: var(--font-mono); font-size: var(--text-sm);
}
.dr-otl-bar .dr-btn { height: var(--control-h-compact); font-size: var(--text-xs); }
.dr-otl-bulk {
    height: 30px; background: var(--bg-elevated); color: var(--fg);
    border: 1px solid var(--rule); border-radius: 6px; font-family: var(--font-mono); font-size: var(--text-xs);
}
.dr-otl-bulk:disabled { opacity: 0.5; }
.dr-otl-selcount { color: var(--accent); font-size: var(--text-xs); }
.dr-otl-hint { margin-left: auto; color: var(--fg-dim); font-size: var(--text-xs); }

.dr-otl-scroll { flex: 1 1 auto; overflow: auto; border: 1px solid var(--rule); border-radius: 8px; }
.dr-otl-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.dr-otl-table th, .dr-otl-table td { padding: 0.3rem 0.5rem; text-align: left; border-bottom: 1px solid var(--rule); vertical-align: middle; }
.dr-otl-th {
    position: sticky; top: 0; z-index: 1;
    background: var(--bg-raised, var(--bg-elevated)); color: var(--fg-dim);
    font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.03em;
    cursor: pointer; white-space: nowrap; user-select: none;
}
.dr-otl-th:hover { color: var(--accent); }
.dr-otl-sel { width: 28px; text-align: center; }
.dr-otl-num { text-align: right; }
.dr-otl-group td {
    background: var(--bg-raised, var(--bg-elevated)); color: var(--accent);
    font-family: var(--font-mono); font-size: var(--text-xs);
    text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600;
    position: sticky; top: 26px;
}
.dr-otl-row:hover td { background: var(--row-hover); }
.dr-otl-title { min-width: 160px; }
.dr-otl-open {
    background: transparent; border: none; color: var(--fg); cursor: pointer;
    font-family: var(--font-mono); font-size: var(--text-sm); text-align: left; padding: 0;
    max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.dr-otl-open:hover { color: var(--accent); text-decoration: underline; }
.dr-otl-dim { color: var(--fg-muted); }
.dr-otl-in {
    width: 100%; min-width: 70px; height: 24px; box-sizing: border-box;
    background: transparent; color: var(--fg);
    border: 1px solid transparent; border-radius: 4px; padding: 0 0.3rem;
    font-family: var(--font-mono); font-size: var(--text-sm);
}
.dr-otl-in:hover { border-color: var(--rule); }
.dr-otl-in:focus { border-color: var(--accent); background: var(--bg-elevated); outline: none; }
.dr-otl-num.dr-otl-in { max-width: 70px; text-align: right; }
.dr-otl-empty { color: var(--fg-dim); text-align: center; padding: 1.4rem; }
