/* ── Phase 2/3/4: 태스크 큐, 컨텍스트 맵, 스킬 DAG 스타일 ── */

/* ============================================
   Phase 2: 태스크 큐 (요청) 패널
   접두사: .rq-* / .tq-*
   ============================================ */

.rq-panel {
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
    padding: var(--s-2);
}

.rq-toolbar {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    flex-wrap: wrap;
}

.rq-filters {
    display: flex;
    gap: var(--s-1);
}

.rq-stats {
    display: flex;
    gap: var(--s-2);
    margin-left: auto;
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.rq-stat {
    display: flex;
    align-items: center;
    gap: var(--s-1);
}

.rq-view-toggle {
    padding: var(--s-1) var(--s-1);
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    color: var(--text-sub);
    cursor: pointer;
    display: flex;
    align-items: center;
    transition: color var(--fast), background-color var(--fast);
}

.rq-view-toggle:hover {
    background: var(--surface-hover);
    color: var(--text);
}
.rq-view-toggle:active { transform: scale(var(--active-scale-btn)); transition-duration: var(--duration-instant); }
.rq-view-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* 상태 도트 */
.tq-dot {
    width: var(--s-1-5);
    height: var(--s-1-5);
    border-radius: 50%;
    display: inline-block;
}

.tq-dot--pending    { background: var(--amber); }
.tq-dot--assigned   { background: var(--accent); }
.tq-dot--in_progress { background: var(--accent); animation: tqPulse 2s infinite; }
.tq-dot--completed  { background: var(--green); }

@keyframes tqPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* 리스트 뷰 — 상태 그룹 */
.rq-group {
    margin-bottom: var(--s-1);
}

.rq-group-header {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    padding: var(--s-1) var(--s-1);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    cursor: pointer;
    user-select: none;
}

.rq-group-count {
    background: var(--surface);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-pill, 99px);
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.rq-group-chevron {
    margin-left: auto;
    transition: transform var(--smooth);
}

.rq-group--collapsed .rq-group-chevron {
    transform: rotate(-90deg);
}

.rq-group--collapsed .rq-group-items {
    display: none;
}

.rq-group-items {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}

/* 태스크 카드 */
.rq-card {
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    padding: var(--s-1) var(--s-2);
    cursor: pointer;
    /* transition → animations.css §10b 단일 권위 선언으로 통합 */
}

.rq-card:hover {
    background: var(--surface-hover);
    box-shadow: var(--shadow-float);
}

.rq-card--high {
    background: color-mix(in srgb, var(--amber) 6%, var(--surface));
}

.rq-card--critical {
    background: color-mix(in srgb, var(--red) 8%, var(--surface));
}

.rq-card-header {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    margin-bottom: var(--s-1);
}

.rq-card-target {
    font-weight: var(--weight-semibold);
    font-size: var(--text-sm);
    color: var(--accent);
}

.rq-card-action {
    font-size: var(--text-sm);
    color: var(--text);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rq-card-meta {
    display: flex;
    gap: var(--s-1);
    align-items: center;
    margin-bottom: var(--s-1);
}

.rq-card-source {
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.rq-card-priority {
    font-size: var(--text-sm);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-pill, 99px);
}

.rq-card-priority--critical { background: var(--clr-error-bg-md); color: var(--red); }
.rq-card-priority--high { background: var(--clr-warning-bg-md); color: var(--amber); }
.rq-card-priority--normal { background: var(--surface); color: var(--text-sub); }
.rq-card-priority--low { background: transparent; color: var(--text-sub); }

.rq-card-footer {
    display: flex;
    gap: var(--s-2);
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.rq-card-jobid {
    font-family: var(--font-mono);
}

/* 칸반 뷰 */
.rq-kanban-view {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--s-1);
    min-height: var(--layout-lg);
}

.rq-kanban-col {
    background: var(--surface);
    border-radius: var(--radius-s);
    padding: var(--s-1);
    display: flex;
    flex-direction: column;
}

.rq-kanban-header {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    padding-bottom: var(--s-1);
    border-bottom: 1px solid var(--line);
    margin-bottom: var(--s-1);
    display: flex;
    align-items: center;
    gap: var(--s-1);
}

.rq-kanban-count {
    background: var(--bg-raised);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-pill, 99px);
    font-size: var(--text-sm);
}

.rq-kanban-items {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
    overflow-y: auto;
    flex: 1;
}

/* 빈 상태 */
.rq-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--s-1);
    padding: var(--s-6);
    color: var(--text-sub);
    font-size: var(--text-sm);
}

.rq-empty svg {
    opacity: 0.4;
}

/* ============================================
   Phase 3: 컨텍스트 맵 편집기
   접두사: .ctxmap-*
   ============================================ */

.ctxmap-container {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--s-2);
    min-height: clamp(280px, 35vw, 400px);
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    overflow: hidden;
}

/* 좌측: 에이전트 목록 */
.ctxmap-agents {
    background: var(--surface);
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--line);
}

.ctxmap-search {
    padding: var(--s-1) var(--s-2);
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--line);
    color: var(--text);
    font-size: var(--text-sm);
    outline: none;
}

.ctxmap-search::placeholder {
    color: var(--text-sub);
}

.ctxmap-agent-list {
    flex: 1;
    overflow-y: auto;
}

.ctxmap-agent-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--s-1) var(--s-2);
    cursor: pointer;
    transition: background var(--motion-hover);
}

.ctxmap-agent-item:hover {
    background: var(--surface-hover);
}

.ctxmap-agent-item.active {
    background: var(--surface-active);
}

.ctxmap-agent-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text);
}

.ctxmap-agent-count {
    font-size: var(--text-sm);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-pill, 99px);
    background: var(--bg-raised);
    color: var(--text-sub);
}

.ctxmap-add-btn {
    padding: var(--s-1) var(--s-2);
    background: transparent;
    border: none;
    border-top: 1px solid var(--line);
    color: var(--accent);
    font-size: var(--text-sm);
    cursor: pointer;
    text-align: center;
    transition: background var(--motion-hover);
}

.ctxmap-add-btn:hover {
    background: var(--surface-w5);
}
.ctxmap-add-btn:active { transform: scale(var(--active-scale)); transition-duration: var(--duration-instant); }
.ctxmap-add-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* 우측: 컨텍스트 매핑 */
.ctxmap-mapping {
    display: flex;
    flex-direction: column;
    padding: var(--s-2);
}

.ctxmap-mapping-header {
    padding-bottom: var(--s-1);
    border-bottom: 1px solid var(--line);
    margin-bottom: var(--s-1);
}

.ctxmap-checklist {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}

.ctxmap-check-item {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    padding: var(--s-1) var(--s-1);
    border-radius: var(--radius-s);
    cursor: pointer;
    font-size: var(--text-sm);
    transition: background var(--motion-hover);
}

.ctxmap-check-item:hover {
    background: var(--surface);
}

.ctxmap-check-item--locked {
    opacity: 0.6;
    cursor: default;
}

.ctxmap-check-label {
    flex: 1;
    color: var(--text);
}

.ctxmap-check-tokens {
    font-size: var(--text-sm);
    color: var(--text-sub);
    font-family: var(--font-mono);
}

.ctxmap-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--s-1);
    border-top: 1px solid var(--line);
    margin-top: var(--s-1);
}

.ctxmap-token-count {
    font-size: var(--text-sm);
    color: var(--text-sub);
    font-family: var(--font-mono);
}

.ctxmap-btn {
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
    font-size: var(--text-sm);
    cursor: pointer;
    transition: color var(--fast), background-color var(--fast);
}

.ctxmap-btn--ghost {
    background: transparent;
    border: 1px solid var(--line);
    color: var(--text-sub);
}

.ctxmap-btn--ghost:hover {
    background: var(--surface);
    color: var(--text);
}
.ctxmap-btn--ghost:active { transform: scale(var(--active-scale-btn)); transition-duration: var(--duration-instant); }
.ctxmap-btn--ghost:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.ctxmap-btn--primary {
    background: var(--accent);
    border: none;
    color: var(--accent-on);
    font-weight: var(--weight-semibold);
}

.ctxmap-btn--primary:hover {
    opacity: 0.9;
}
.ctxmap-btn--primary:active:not(:disabled) { transform: scale(var(--active-scale-btn)); transition-duration: var(--duration-instant); }
.ctxmap-btn--primary:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

.ctxmap-btn--primary:disabled {
    opacity: 0.4;
    cursor: default;
}

/* ============================================
   Phase 4: 스킬 체인 DAG 시각화
   접두사: .skill-dag-*
   ============================================ */

.skill-dag-panel {
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
    padding: var(--s-2);
}

.skill-dag-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--s-2);
    flex-wrap: wrap;
}

.skill-dag-chain-info {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
}

.dag-depth-dots {
    display: flex;
    gap: var(--s-1);
}

.dag-depth-dot {
    width: var(--s-2);
    height: var(--s-2);
    border-radius: 50%;
    border: 1.5px solid var(--text-sub);
    transition: background-color var(--duration-moderate) ease, border-color var(--duration-moderate) ease;
}

.dag-depth-dot--filled {
    background: var(--accent);
    border-color: var(--accent);
}

.dag-status-label {
    font-weight: var(--weight-semibold);
    font-size: var(--text-sm);
}

.dag-status--running   { color: var(--accent); }
.dag-status--completed { color: var(--green); }
.dag-status--failed    { color: var(--red); }

.skill-dag-content {
    display: flex;
    gap: var(--s-2);
}

.skill-dag-canvas {
    flex: 1;
    min-height: clamp(280px, 35vw, 400px);
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    overflow: hidden;
    background: var(--surface);
}

.skill-dag-canvas svg {
    display: block;
}

/* DAG 노드 */
.skill-dag-node rect {
    fill: var(--bg-raised);
    stroke: var(--text-sub);
    stroke-width: 1;
    transition: fill var(--duration-moderate) ease, stroke var(--duration-moderate) ease;
}

.skill-dag-node:hover rect {
    fill: var(--surface-hover);
}

.skill-dag-node--active rect {
    stroke: var(--accent);
    stroke-width: 2;
    filter: drop-shadow(0 0 6px var(--surface-active));
}

.skill-dag-node--complete rect {
    stroke: var(--green);
    stroke-width: 1.5;
}

.skill-dag-node--error rect {
    stroke: var(--red);
    stroke-width: 1.5;
}

.skill-dag-node--pending rect {
    stroke: var(--text-sub);
    stroke-dasharray: 4 3;
}

/* DAG 엣지 */
.skill-dag-edge {
    stroke: var(--text-sub);
    stroke-width: 1.5;
    fill: none;
    transition: stroke var(--duration-moderate);
}

.skill-dag-edge--fallback {
    stroke: var(--amber);
    stroke-dasharray: 6 3;
}

.skill-dag-edge--highlight {
    stroke: var(--accent);
    stroke-width: 2.5;
}

/* DAG 사이드바 */
.skill-dag-sidebar {
    width: var(--card-min);
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    padding: var(--s-2);
    overflow-y: auto;
}

.dag-detail-row {
    display: flex;
    justify-content: space-between;
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
    border-bottom: 1px solid var(--line);
}

.dag-detail-label {
    color: var(--text-sub);
    font-weight: var(--weight-semibold);
}

/* DAG 실행 로그 */
.skill-dag-log {
    max-height: clamp(120px, 18vw, 180px);
    overflow-y: auto;
    border: 1px solid var(--line);
    border-radius: var(--radius-s);
    padding: var(--s-1);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    background: var(--surface);
}

.dag-log-entry {
    padding: var(--s-1) 0;
    color: var(--text-sub);
    border-bottom: 1px solid var(--surface);
}

.dag-log-time {
    color: var(--text-sub);
    margin-right: var(--s-1);
}

/* ============================================
   반응형
   ============================================ */

@media (max-width: 1024px) {
    .rq-kanban-view {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 960px) {
    .skill-dag-content {
        flex-direction: column;
    }

    .skill-dag-sidebar {
        width: 100%;
    }

    .rq-kanban-view {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

    .ctxmap-agents {
        border-right: none;
        border-bottom: 1px solid var(--line);
        max-height: var(--card-min-sm);
    }

    .rq-kanban-view {
        grid-template-columns: 1fr;
    }

    .rq-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .rq-stats {
        margin-left: 0;
        justify-content: center;
    }

    .skill-dag-canvas {
        min-height: clamp(200px, 28vw, 300px);
    }
}
