:root {
    --bg-color: #1e1e1e;
    --primary-bg: #2a2a2a;
    --secondary-bg: #3c3c3c;
    --text-color: #d4d4d4;
    --accent-color: #0e639c;
    --border-color: #4a4a4a;
    --font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

    --color-control: var(--primary-bg);
    --color-group: #333;
    --color-page: #233a4b;
    --color-selected: var(--accent-color);
}

body {
    font-family: var(--font-family);
    background-color: var(--bg-color);
    color: var(--text-color);
    margin: 0;
    padding: 1rem; /* 全体のパディングを維持 */
    padding-top: calc(1rem + 150px); /* 固定ヘッダーの高さ分を考慮 */
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* ビューポートの高さいっぱいにする */
    box-sizing: border-box; /* パディングを高さに含める */
}

header {
    padding-bottom: 0.5rem; /* 固定ボタン群との間にスペースを調整 */
}

.fixed-buttons {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background-color: var(--bg-color);
    padding: 1rem; /* ヘッダーのパディングと合わせる */
    box-sizing: border-box;
    border-bottom: 1px solid var(--border-color); /* 区切り線を追加 */
}

main {
    display: flex;
    gap: 1rem;
    flex-grow: 1; /* 残りのスペースを埋める */
    overflow-y: auto; /* コンテンツが溢れた場合にスクロールバーを表示 */
}

h1, h3 {
    margin-top: 0;
    font-weight: 500;
}
h1 { margin-bottom: 1rem; }
h3 { margin-bottom: 0.5rem; border-bottom: 1px solid var(--border-color); padding-bottom: 0.5rem;}


.button-group {
    margin-bottom: 0.5rem;
}

button {
    background-color: var(--secondary-bg);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    margin-right: 0.5rem;
    transition: background-color 0.2s, border-color 0.2s;
}

button:hover:not(:disabled) {
    background-color: #4f4f4f;
    border-color: #666;
}

button:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

#download-btn:not(:disabled) {
    background-color: var(--accent-color);
    border-color: #1c8cd1;
    color: white;
}

.container {
    background-color: var(--primary-bg);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#controls-container {
    width: 70%;
    overflow-y: auto;
}

#properties-container {
    width: 30%;
}

#controls-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid var(--secondary-bg);
    border-radius: 4px;
    background-color: var(--bg-color);
}

.list-item {
    padding: 6px 10px;
    border-bottom: 1px solid var(--secondary-bg);
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    transition: background-color 0.1s;
    font-size: 14px;
}

.list-item:last-child {
    border-bottom: none;
}

.list-item.control-item { background-color: var(--color-control); }
.list-item.group-item { background-color: var(--color-group); font-weight: 600; }
.list-item.page-item { background-color: var(--color-page); color: #7fcdf0; font-style: italic; justify-content: center; }

.list-item.selected {
    background-color: var(--color-selected) !important;
    color: white;
}

#property-editor {
    display: none;
}

#property-editor label {
    display: block;
    margin: 1rem 0 0.5rem 0;
    font-size: 0.9em;
    color: #aaa;
}

#property-editor input {
    width: calc(100% - 16px);
    padding: 8px;
    background-color: var(--secondary-bg);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    border-radius: 4px;
}

#output-area {
    margin-top: 1rem; /* mainとの間にスペースを設ける */
}

#output-text {
    height: 200px; /* 固定の高さを設定 */
    overflow-y: auto; /* テキストが溢れた場合にtextarea内でスクロール */
    width: calc(100% - 20px); /* 親要素のパディングを考慮 */
    padding: 10px;
    background-color: var(--bg-color);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    border-radius: 4px;
    resize: vertical; /* ユーザーが縦方向にリサイズできるようにする */
}

#output-area .button-group {
    margin-top: 1rem; /* Copy/Downloadボタンの上にマージンを追加 */
}

.clicked {
    background-color: #6c757d !important; /* A slightly darker shade for feedback */
    border-color: #5a6268 !important;
}
