/* src/css/features.css - 特定高级功能面板的专属样式 */

/* --- 控制台虚拟滚动样式 --- */
#console-output.active {
    display: flex;
    flex-direction: row;
    padding: 0;
    height: 100%; /* <-- 新增，确保填满父容器 */
}

/* 控制台左侧工具栏 */
.console-toolbar {
    flex-shrink: 0;
    width: 35px;
    background-color: var(--bg-panel);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 5px;
    gap: 8px;
    user-select: none;
}

/* 工具栏按钮 */
.console-tool-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 1rem;
    padding: 6px;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s, color 0.2s;
    width: 28px;
    height: 28px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.console-tool-btn:hover {
    background-color: var(--border-color);
    color: var(--text-primary);
}

.console-tool-btn.active {
    background-color: var(--selection-color);
    color: var(--accent-color);
}

#console-output .console-viewport {
    flex-grow: 1; /* 占据剩余空间 */
    overflow-y: auto;
    overflow-x: auto;
    font-size: 0.9rem;
}

#console-output .console-content {
    position: relative;
    overflow: hidden;
    font-family: var(--font-family-mono);
    color: var(--text-primary);
}

#console-output .console-line {
    position: absolute;
    left: 0;
    padding: 0 10px;
    line-height: 1.5;
    white-space: pre-wrap;
    word-break: break-all;
}

#console-output.no-wrap .console-line {
    white-space: pre;
    word-break: normal;
    width: fit-content;
    max-width: 100%;
    overflow-x: auto;
}

#console-output .console-line.error { color: var(--color-error); }
#console-output .console-line.warn { color: var(--color-warning); }

/* --- 终端样式 --- */
#terminal-panel.panel-content.active {
    display: flex;
    flex-direction: column;
    padding: 0;
    height: 100%; /* <-- 新增，确保填满父容器 */
}

#terminal-output-container {
    flex-grow: 1;
    overflow-y: auto;
    font-family: var(--font-family-mono);
    line-height: 1.4;
    background-color: var(--terminal-bg);
    color: var(--terminal-fg);
    padding: 10px;
}

#terminal-output-container pre {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-all;
}

.ansi-black-fg { color: var(--terminal-black); }
.ansi-red-fg { color: var(--terminal-red); }
.ansi-green-fg { color: var(--terminal-green); }
.ansi-yellow-fg { color: var(--terminal-yellow); }
.ansi-blue-fg { color: var(--terminal-blue); }
.ansi-magenta-fg { color: var(--terminal-magenta); }
.ansi-cyan-fg { color: var(--terminal-cyan); }
.ansi-white-fg { color: var(--terminal-white); }
.ansi-bright-black-fg { color: var(--terminal-black); font-weight: bold; }
.ansi-bright-red-fg { color: var(--terminal-red); font-weight: bold; }
.ansi-bright-green-fg { color: var(--terminal-green); font-weight: bold; }
.ansi-bright-yellow-fg { color: var(--terminal-yellow); font-weight: bold; }
.ansi-bright-blue-fg { color: var(--terminal-blue); font-weight: bold; }
.ansi-bright-magenta-fg { color: var(--terminal-magenta); font-weight: bold; }
.ansi-bright-cyan-fg { color: var(--terminal-cyan); font-weight: bold; }
.ansi-bright-white-fg { color: var(--terminal-white); font-weight: bold; }
.ansi-black-bg { background-color: var(--terminal-black); }
.ansi-red-bg { background-color: var(--terminal-red); }
.ansi-green-bg { background-color: var(--terminal-green); }
.ansi-yellow-bg { background-color: var(--terminal-yellow); }
.ansi-blue-bg { background-color: var(--terminal-blue); }
.ansi-magenta-bg { background-color: var(--terminal-magenta); }
.ansi-cyan-bg { background-color: var(--terminal-cyan); }
.ansi-white-bg { background-color: var(--terminal-white); }
.terminal-input-container {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding: 5px 10px;
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-panel);
}
.terminal-prompt {
    font-family: var(--font-family-mono);
    color: var(--accent-color);
    margin-right: 8px;
    user-select: none;
}
#terminal-input {
    flex-grow: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text-primary);
    font-family: var(--font-family-mono);
    font-size: 1em;
}

/* --- 调试器 --- */
/* ========================= 修改 START ========================= */
#debugger-panel.active {
    display: flex;
    flex-direction: column;
    padding: 0; /* 移除内边距以允许子元素填满 */
    height: 100%;
}

.debugger-controls {
    display: flex;
    align-items: center; /* 垂直居中 */
    gap: 10px;
    padding: 5px 10px; /* 调整内边距 */
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.debugger-controls button {
    background-color: transparent; /* 透明背景 */
    border: none;
    color: var(--text-primary);
    padding: 6px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 1.1rem; /* 增大图标尺寸 */
    line-height: 1;
}
.debugger-controls button:hover { background-color: var(--border-color); }
.debugger-controls-separator {
    width: 1px;
    height: 20px;
    background-color: var(--border-color);
    margin: 0 5px;
}
.debugger-main-content {
    flex-grow: 1;
    display: flex;
    overflow: hidden; /* 确保内容不溢出 */
}

#debugger-info-panel {
    flex: 1 1 30%; /* 占据30%宽度，可伸缩 */
    min-width: 200px;
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    overflow: auto;
    padding: 10px;
}

#debugger-console-panel {
    flex: 1 1 70%; /* 占据70%宽度，可伸缩 */
    min-width: 300px;
    display: flex; /* 使用flex布局容纳工具栏和视口 */
    flex-direction: row;
}

/* 适配调试器内的虚拟控制台样式 */
#debugger-console-panel .console-viewport {
    flex-grow: 1;
    overflow-y: auto;
    overflow-x: auto;
    font-size: 0.9rem;
}
#debugger-console-panel .console-content {
    position: relative;
    overflow: hidden;
    font-family: var(--font-family-mono);
    color: var(--text-primary);
}
#debugger-console-panel .console-line {
    position: absolute;
    left: 0;
    padding: 0 10px;
    line-height: 1.5;
    white-space: pre-wrap;
    word-break: break-all;
}
#debugger-console-panel.no-wrap .console-line {
    white-space: pre;
    word-break: normal;
    width: fit-content;
    max-width: 100%;
    overflow-x: auto;
}

#debugger-console-panel .console-line.error { color: var(--color-error); }
#debugger-console-panel .console-line.warn { color: var(--color-warning); }

.debugger-info { flex-grow: 1; overflow: auto; }
.debugger-section { margin-bottom: 15px; }
.debugger-section h4 { font-size: 0.95rem; margin-bottom: 8px; padding-bottom: 5px; border-bottom: 1px dashed var(--border-color); }
.debugger-section ul { list-style: none; padding: 0; margin: 0; }
.debugger-section li { font-family: var(--font-family-mono); font-size: 0.85rem; padding: 4px 0; }
.debugger-section li.highlight { background-color: rgba(98, 163, 255, 0.2); border-radius: 4px; padding: 4px 5px; }
/* ========================= 修改 END =========================== */


/* --- Monaco/Debugger 特有样式 --- */
.debug-line-highlight { background-color: rgba(98, 163, 255, 0.2); }
.debug-line-decorator-gutter { width: 5px !important; background: var(--accent-color); margin-left: 3px; }
.breakpoint-decorator { width: 10px !important; height: 10px !important; background: var(--color-error); border-radius: 50%; margin-left: 5px; margin-top: 5px; }

/* --- 监控面板样式 --- */
#monitor-side-panel .panel-content-area {
    padding: 10px;
    display: flex;
}
.monitor-grid {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(3, 1fr);
    gap: 15px;
    width: 100%;
    height: 100%;
}
.chart-container {
    position: relative;
    width: 100%;
    height: 100%;
    background-color: var(--bg-primary);
    border-radius: 4px;
    padding: 10px;
    box-shadow: inset 0 0 5px rgba(0,0,0,0.1);
    min-width: 0;  /* 允许容器在flex/grid布局中收缩到小于其内容的固有宽度 */
    min-height: 0; /* 允许容器在flex/grid布局中收缩到小于其内容的固有高度 */
}