/* ========================================================
   CORRUPTED CHRONICLES UNIFIED APP CSS
   Combines Player, Builder, and Crafter Wizard Styles
   ======================================================== */

/* ===== SECTION 1: PLAYER PAGE STYLES ===== */

.player-page {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 1rem;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(108, 63, 160, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 50%, rgba(201, 162, 39, 0.06) 0%, transparent 50%),
        var(--color-bg);
}

.player-container {
    width: 100%;
    max-width: 420px;
    text-align: center;
}

.player-header {
    margin-bottom: 2.5rem;
}

.player-title {
    font-family: var(--font-display);
    font-size: 2.2rem;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
}

.player-subtitle {
    color: var(--color-text-muted);
}

.story-number-input {
    text-align: center;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
    padding: 1rem;
}

.story-number-input::-webkit-inner-spin-button,
.story-number-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.story-number-input {
    -moz-appearance: textfield;
}

.btn-block {
    width: 100%;
    justify-content: center;
}

.player-footer {
    margin-top: 3rem;
}

.back-link {
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 0.9rem;
}

.back-link:hover {
    color: var(--color-primary);
}

/* ===== Story Page ===== */
.story-container {
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

.story-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.story-header .player-title {
    font-size: 1.5rem;
    margin: 0;
}

.story-loading {
    text-align: center;
    padding: 3rem 0;
    color: var(--color-text-muted);
}

.story-loading .spinner {
    width: 2rem;
    height: 2rem;
    margin-bottom: 1rem;
}

.story-error {
    text-align: center;
    padding: 3rem 0;
}

.story-error h2 {
    color: var(--color-danger);
    margin-bottom: 0.5rem;
}

.story-error p {
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
}

.story-number-badge {
    display: inline-block;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 0.3rem 1rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-bottom: 1rem;
}

.story-title {
    font-family: var(--font-display);
    font-size: 1.8rem;
    color: var(--color-primary);
    margin-bottom: 1.5rem;
    line-height: 1.3;
}

.audio-section {
    margin-bottom: 2rem;
    padding: 1rem;
    background: var(--color-surface);
    border-radius: var(--radius);
    border: 1px solid var(--color-border);
}

.audio-section audio {
    width: 100%;
}

.story-text {
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--color-text);
}

.story-text p {
    margin-bottom: 1.2rem;
}

/* ===== SECTION 2: BUILDER PAGE STYLES ===== */

.builder-page {
    min-height: 100vh;
    padding: 0;
    display: block;
    align-items: stretch;
}

.builder-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    min-height: 100vh;
}

.builder-sidebar {
    background: var(--color-surface);
    border-right: 1px solid var(--color-border);
    padding: 1.5rem;
    overflow-y: auto;
}

.builder-sidebar h2 {
    font-family: var(--font-display);
    font-size: 1.2rem;
    color: var(--color-primary);
    margin-bottom: 1rem;
}

.builder-main {
    padding: 2rem;
    overflow-y: auto;
}

/* ===== Dashboard Welcome Screen ===== */
.dash {
    max-width: 920px;
    margin: 0 auto;
}
.dash-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}
.dash-title {
    font-family: var(--font-display);
    font-size: 1.6rem;
    color: var(--color-primary);
    margin: 0 0 0.2rem 0;
}
.dash-subtitle {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin: 0;
}
.dash-btn-new {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dim) 100%);
    color: #111;
    border: none;
    border-radius: 8px;
    padding: 0.55rem 1.3rem;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}
.dash-btn-new:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(201, 162, 39, 0.3);
}

/* Stats Bar */
.dash-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
    margin-bottom: 1.75rem;
}
.dash-stat {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 0.9rem 1rem;
    text-align: center;
    transition: border-color 0.2s;
}
.dash-stat:hover {
    border-color: var(--color-primary-dim);
}
.dash-stat-num {
    display: block;
    font-family: var(--font-display);
    font-size: 1.6rem;
    color: var(--color-primary);
    line-height: 1.1;
}
.dash-stat-label {
    display: block;
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 0.2rem;
}

/* Section Headers */
.dash-section {
    margin-bottom: 1.75rem;
}
.dash-section-header {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.75rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--color-border);
}

/* Tale Grid */
.dash-tale-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 0.85rem;
}
.dash-tale-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 1rem 1.15rem;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    gap: 0.9rem;
    align-items: flex-start;
}
.dash-tale-card:hover {
    border-color: var(--color-primary-dim);
    background: var(--color-surface-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.35);
}
.dash-tale-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(108,63,160,0.25) 0%, rgba(201,162,39,0.2) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.dash-tale-body {
    flex: 1;
    min-width: 0;
}
.dash-tale-name {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--color-text);
    margin-bottom: 0.15rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dash-tale-desc {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin-bottom: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
}
.dash-tale-meta {
    display: flex;
    gap: 0.6rem;
    align-items: center;
    font-size: 0.7rem;
    color: var(--color-text-muted);
}
.dash-tale-badge {
    background: rgba(201, 162, 39, 0.12);
    color: var(--color-primary);
    padding: 0.1rem 0.45rem;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.68rem;
}
.dash-tale-empty {
    color: var(--color-text-muted);
    font-style: italic;
    font-size: 0.88rem;
    padding: 1.5rem 0;
    text-align: center;
    grid-column: 1 / -1;
}

/* Card Breakdown */
.dash-card-breakdown {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.6rem;
}
.dash-card-type {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.7rem 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    transition: border-color 0.2s;
}
.dash-card-type:hover {
    border-color: var(--color-primary-dim);
}
.dash-card-type-icon {
    font-size: 1.15rem;
    width: 28px;
    text-align: center;
    flex-shrink: 0;
}
.dash-card-type-info {
    display: flex;
    flex-direction: column;
}
.dash-card-type-count {
    font-family: var(--font-display);
    font-size: 1.1rem;
    color: var(--color-text);
    line-height: 1.1;
}
.dash-card-type-label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.builder-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border);
}

.builder-header h1 {
    font-family: var(--font-display);
    font-size: 1.6rem;
    color: var(--color-primary);
}

/* Password gate */
.password-gate {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 1rem;
}

.password-form {
    text-align: center;
    max-width: 360px;
    width: 100%;
}

.password-form h1 {
    font-family: var(--font-display);
    color: var(--color-primary);
    margin-bottom: 0.5rem;
}

.password-form p {
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
}

/* Story list in sidebar */
.story-list {
    list-style: none;
}

.story-list-item {
    padding: 0.6rem 0.8rem;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    transition: background 0.15s;
    margin-bottom: 2px;
}

.story-list-item:hover {
    background: var(--color-surface-hover);
    color: var(--color-text);
}

.story-list-item.active {
    background: var(--color-surface-hover);
    color: var(--color-primary);
    font-weight: 600;
}

.story-list-item .story-list-num {
    color: var(--color-primary-dim);
    font-weight: 600;
    margin-right: 0.4rem;
}

/* Builder form sections */
.builder-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.builder-section h3 {
    font-size: 1rem;
    color: var(--color-primary);
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.builder-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* QR Code display */
.qr-section {
    text-align: center;
}

.qr-code-wrapper {
    display: inline-block;
    background: #fff;
    padding: 1rem;
    border-radius: var(--radius);
    margin-bottom: 1rem;
}

.qr-url {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    word-break: break-all;
    margin-bottom: 1rem;
}

/* Audio preview in builder */
.audio-preview {
    margin-top: 1rem;
}

.audio-preview audio {
    width: 100%;
}

.audio-status {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-top: 0.5rem;
}

.audio-status-error {
    color: #e74c3c;
}

.audio-status-success {
    color: #27ae60;
}

.audio-status-info {
    color: var(--color-primary);
}

/* ===== Tale Picker ===== */
.tale-picker h2 {
    font-family: var(--font-display);
    font-size: 1.1rem;
    color: var(--color-primary);
    margin: 0;
}

/* ===== Modal ===== */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    padding: 1rem;
}

.modal-content {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 2rem;
    max-width: 560px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
}

/* Tale list items in modal */
.tale-list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 0.8rem;
    border-radius: var(--radius);
    font-size: 0.9rem;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    margin-bottom: 0.5rem;
}

.tale-list-item .tale-name {
    font-weight: 600;
    color: var(--color-text);
}

.tale-list-item .tale-count {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.tale-list-actions {
    display: flex;
    gap: 0.4rem;
    flex-shrink: 0;
}

.tale-list-actions button {
    padding: 0.2rem 0.5rem;
    font-size: 0.75rem;
}

/* ===== Tale Structure Slots ===== */
.structure-slot-list {
    list-style: none;
    margin-bottom: 0;
}

.structure-slot-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.8rem;
    border-radius: var(--radius);
    margin-bottom: 2px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: background 0.15s;
    border: 1px solid transparent;
}

.structure-slot-item:hover {
    background: var(--color-surface-hover);
}

.structure-slot-item.active {
    background: var(--color-surface-hover);
    border-color: var(--color-primary-dim);
}

.structure-slot-label {
    font-weight: 600;
    color: var(--color-primary);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.structure-slot-title {
    color: var(--color-text);
    font-size: 0.85rem;
    margin-top: 0.15rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.structure-slot-empty {
    color: var(--color-text-muted);
    font-style: italic;
    font-size: 0.8rem;
}

.structure-slot-create-btn {
    background: none;
    border: 1px dashed var(--color-border);
    color: var(--color-primary);
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius);
    font-size: 0.75rem;
    cursor: pointer;
    font-weight: 600;
    transition: border-color 0.15s, background 0.15s;
    flex-shrink: 0;
}

.structure-slot-create-btn:hover {
    border-color: var(--color-primary);
    background: rgba(201, 162, 39, 0.1);
}

/* Story type badge in editor */
.story-type-badge {
    background: rgba(108, 63, 160, 0.2);
    border: 1px solid rgba(108, 63, 160, 0.4);
    color: #b388ff;
    padding: 0.3rem 0.8rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 1rem;
}

/* ===== Encounter Tables (Builder) ===== */
.encounter-chapter-group {
    margin-bottom: 1.5rem;
}

.encounter-chapter-heading {
    font-family: var(--font-display);
    font-size: 1rem;
    color: var(--color-primary);
    margin-bottom: 0.75rem;
}

.encounter-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0.5rem;
}

.encounter-table th {
    text-align: left;
    padding: 0.4rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--color-border);
}

.encounter-table td {
    padding: 0.4rem 0.5rem;
    vertical-align: middle;
}

.encounter-th-type {
    width: 60px;
}

.encounter-th-cl {
    width: 60px;
    text-align: center;
}

.encounter-type-cell {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-accent);
    white-space: nowrap;
}

.encounter-name-input {
    padding: 0.4rem 0.6rem !important;
    font-size: 0.9rem !important;
}

.encounter-cl-input {
    padding: 0.4rem !important;
    font-size: 0.9rem !important;
    text-align: center !important;
    width: 56px !important;
    -moz-appearance: textfield;
}

.encounter-cl-input::-webkit-inner-spin-button,
.encounter-cl-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* ===== Condition Editor (Builder) ===== */
.condition-editor {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.condition-editor-heading {
    font-size: 1rem;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.condition-encounter-rows {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

.condition-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(51, 51, 51, 0.3);
}

.condition-toggle-row:last-child {
    border-bottom: none;
}

.condition-enc-name {
    font-size: 0.9rem;
    color: var(--color-text);
    font-weight: 600;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.condition-toggle-btns {
    display: flex;
    gap: 0.3rem;
    flex-shrink: 0;
}

.condition-opt {
    padding: 0.35rem 0.7rem !important;
    font-size: 0.8rem !important;
    border: 1px solid var(--color-border) !important;
    background: transparent !important;
    color: var(--color-text-muted) !important;
    cursor: pointer;
    transition: all 0.15s;
}

.condition-opt.selected {
    border-color: var(--color-primary) !important;
    background: rgba(201, 162, 39, 0.15) !important;
    color: var(--color-primary) !important;
    font-weight: 600;
}

/* Condition badge in sidebar */
.condition-badge {
    display: inline-block;
    background: rgba(201, 162, 39, 0.15);
    border: 1px solid rgba(201, 162, 39, 0.3);
    color: var(--color-primary);
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    vertical-align: middle;
    margin-left: 0.3rem;
}

.condition-badge--default {
    background: rgba(108, 63, 160, 0.15);
    border-color: rgba(108, 63, 160, 0.3);
    color: #b388ff;
}

/* ===== Status Messages ===== */
.status-msg {
    padding: 0.75rem 1rem;
    border-radius: var(--radius);
    font-size: 0.9rem;
    margin-top: 1rem;
}

.status-msg--success {
    background: rgba(39, 174, 96, 0.15);
    color: var(--color-success);
    border: 1px solid rgba(39, 174, 96, 0.3);
}

.status-msg--error {
    background: rgba(192, 57, 43, 0.15);
    color: var(--color-danger);
    border: 1px solid rgba(192, 57, 43, 0.3);
}

.status-msg--info {
    background: rgba(108, 63, 160, 0.15);
    color: #b388ff;
    border: 1px solid rgba(108, 63, 160, 0.3);
}

/* ===== Game App Styles ===== */
.game-app {
    width: 100%;
    min-height: 100vh;
}

.game-view {
    min-height: 100vh;
}

/* ===== Home View ===== */
.home-wrapper {
    max-width: 400px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    justify-content: center;
}

.game-header {
    margin-bottom: 3rem;
}

.game-logo {
    font-family: var(--font-display);
    font-size: 2.4rem;
    color: var(--color-primary);
    margin-bottom: 0.3rem;
    line-height: 1.2;
}

.game-tagline {
    color: var(--color-text-muted);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 600;
}

.home-actions {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: 1.1rem;
    min-height: 52px;
}

.btn-sm {
    padding: 0.4rem 0.8rem;
    font-size: 0.85rem;
}

/* Home divider */
.home-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1.5rem 0;
}

.home-divider::before,
.home-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

.home-divider-text {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Rejoin section */
.rejoin-section {
    text-align: left;
}

.rejoin-label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.5rem;
    text-align: center;
}

.rejoin-row {
    display: flex;
    gap: 0.5rem;
}

.rejoin-input {
    flex: 1;
    text-align: center;
    font-size: 1.1rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

/* Story lookup section */
.story-lookup-section {
    text-align: left;
}

.story-lookup-section .rejoin-input {
    text-transform: none;
}

/* Game footer */
.game-footer {
    margin-top: 3rem;
}

/* ===== View Container ===== */
.view-container {
    max-width: 600px;
    margin: 0 auto;
    padding: 1.5rem;
}

.view-container--narrow {
    max-width: 480px;
}

.view-top-bar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.view-heading {
    font-family: var(--font-display);
    font-size: 1.4rem;
    color: var(--color-primary);
    margin: 0;
}

/* ===== Tale Selection Cards ===== */
.tale-cards-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tale-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
    cursor: pointer;
    transition: border-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

.tale-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(201, 162, 39, 0.15);
}

.tale-card:active {
    transform: translateY(0);
}

.tale-card-name {
    font-family: var(--font-display);
    font-size: 1.3rem;
    color: var(--color-primary);
    margin-bottom: 0.4rem;
}

.tale-card-desc {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.5;
    margin-bottom: 0.6rem;
}

.tale-card-stories {
    font-size: 0.8rem;
    color: var(--color-accent);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.tale-cards-loading {
    text-align: center;
    padding: 3rem 0;
    color: var(--color-text-muted);
}

.tale-cards-loading .spinner {
    width: 2rem;
    height: 2rem;
    margin-bottom: 1rem;
}

/* ===== Player Setup ===== */
.setup-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
}

.setup-tale-badge {
    background: rgba(108, 63, 160, 0.15);
    border: 1px solid rgba(108, 63, 160, 0.3);
    border-radius: var(--radius);
    padding: 0.6rem 1rem;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    margin-bottom: 1.5rem;
    text-align: center;
}

.setup-tale-badge strong {
    color: var(--color-primary);
}

.player-names-list {
    margin-bottom: 1.5rem;
}

.player-name-input {
    text-align: center;
}

/* ===== Game Hub ===== */
.hub-header {
    margin-bottom: 1rem;
}

.hub-header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.hub-tale-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    color: var(--color-primary);
    margin: 0;
}

.session-key-badge {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 0.3rem 0.8rem;
    font-size: 0.8rem;
    color: var(--color-text-muted);
    font-weight: 600;
    letter-spacing: 0.06em;
    font-family: monospace;
}

/* ===== Breadcrumb ===== */
.breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.3rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

.breadcrumb-segment {
    color: var(--color-text-muted);
}

.breadcrumb-segment.active {
    color: var(--color-primary);
    font-weight: 600;
}

.breadcrumb-sep {
    color: var(--color-border);
    font-size: 1.1rem;
}

/* ===== Chapter Progress ===== */
.chapter-progress {
    margin-bottom: 1.5rem;
}

.chapter-progress-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.chapter-node {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    border: 2px solid var(--color-border);
    color: var(--color-text-muted);
    background: var(--color-bg);
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.chapter-node.active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgba(201, 162, 39, 0.12);
    box-shadow: 0 0 12px rgba(201, 162, 39, 0.25);
}

.chapter-node.completed {
    border-color: var(--color-accent);
    background: var(--color-accent);
    color: #fff;
}

.chapter-connector {
    width: 36px;
    height: 2px;
    background: var(--color-border);
    transition: background 0.3s ease;
}

.chapter-connector.completed {
    background: var(--color-accent);
}

/* ===== Phase Card ===== */
.phase-card-container {
    margin-bottom: 1.5rem;
}

.phase-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
}

.phase-card-label {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-accent);
    margin-bottom: 0.5rem;
}

.phase-card-title {
    font-family: var(--font-display);
    font-size: 1.4rem;
    color: var(--color-primary);
    margin-bottom: 1rem;
    line-height: 1.3;
}

.phase-card-body {
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 0.5rem;
}

/* ===== Phase Checklist ===== */
.phase-checklist {
    list-style: none;
    margin: 0;
    padding: 0;
}

.phase-checklist-item {
    position: relative;
    padding: 0.65rem 0 0.65rem 2rem;
    color: var(--color-text);
    font-size: 0.95rem;
    line-height: 1.5;
    border-bottom: 1px solid rgba(51, 51, 51, 0.5);
}

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

.phase-checklist-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 2px solid var(--color-border);
    background: transparent;
}

/* ===== Player Ring ===== */
.player-ring {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    margin-bottom: 1.5rem;
}

.player-token {
    padding: 0.5rem 1rem;
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 600;
    background: var(--color-bg);
    border: 2px solid var(--color-border);
    color: var(--color-text-muted);
    transition: all 0.25s ease;
}

.player-token.active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgba(201, 162, 39, 0.12);
    box-shadow: 0 0 10px rgba(201, 162, 39, 0.2);
}

/* ===== Turn Actions ===== */
.turn-actions-label {
    text-align: center;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.75rem;
}

.turn-actions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
}

.turn-action-btn {
    min-height: 52px;
    font-size: 0.95rem;
    justify-content: center;
    border-radius: var(--radius);
}

.turn-action-pass {
    grid-column: 1 / -1;
}

.pass-counter {
    text-align: center;
    margin-top: 1rem;
    padding: 0.5rem;
    font-size: 0.85rem;
    color: var(--color-text-muted);
    background: rgba(201, 162, 39, 0.08);
    border-radius: var(--radius);
}

/* ===== Hub Actions ===== */
.hub-actions {
    text-align: center;
}

.action-btn {
    min-height: 52px;
    font-size: 1.05rem;
    width: 100%;
    justify-content: center;
}

/* ===== Game Complete ===== */
.game-complete-card {
    text-align: center;
    padding: 2rem;
    border-color: var(--color-accent);
}

.game-complete-card .phase-card-title {
    font-size: 1.8rem;
}

/* ===== Story Display (narration view) ===== */
.story-display {
    padding-top: 2rem;
}

.story-display-title {
    font-family: var(--font-display);
    font-size: 1.8rem;
    color: var(--color-primary);
    margin-bottom: 1.5rem;
    text-align: center;
    line-height: 1.3;
}

.story-display-text {
    font-size: 1.05rem;
    line-height: 1.8;
    color: var(--color-text);
    margin-bottom: 2rem;
}

.story-display-text p {
    margin-bottom: 1.2rem;
}

.story-display .btn-block {
    margin-top: 1rem;
}

/* ===== Encounter Setup Cards (Game Tracker) ===== */
.encounter-setup-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.encounter-setup-card {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.encounter-setup-type {
    font-weight: 700;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    min-width: 50px;
}

.encounter-setup-name {
    flex: 1;
    font-size: 1rem;
    color: var(--color-text);
    font-weight: 600;
}

.encounter-setup-cl {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    white-space: nowrap;
}

.encounter-setup-cl strong {
    color: var(--color-primary);
    font-size: 1.2rem;
}

/* ===== Encounter Results (Game Tracker) ===== */
.encounter-result-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.encounter-result-card {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.encounter-result-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.result-toggle-group {
    display: flex;
    gap: 0.4rem;
    flex-shrink: 0;
}

.result-btn {
    padding: 0.5rem 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    border: 2px solid var(--color-border);
    background: transparent;
    color: var(--color-text-muted);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
}

.result-btn:hover {
    border-color: var(--color-text-muted);
}

.result-btn.selected-win {
    border-color: #27ae60;
    background: rgba(39, 174, 96, 0.15);
    color: #2ecc71;
}

.result-btn.selected-loss {
    border-color: #c0392b;
    background: rgba(192, 57, 43, 0.15);
    color: #e74c3c;
}

/* ===== Disabled Button States ===== */
.builder-section .btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

.audio-regen-prompt {
    background: rgba(255, 193, 7, 0.15);
    border: 1px solid rgba(255, 193, 7, 0.4);
    color: var(--color-text);
    padding: 0.6rem 1rem;
    border-radius: 6px;
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

/* Main app container — shown as flex by JS; must be column so modes fill full width */
#app-container {
    display: flex;
    flex-direction: column;
    width: 100%;
}

/* ===== SECTION 3: UNIFIED APP HEADER & MODE SWITCHER ===== */

#app-header {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    padding: 0.75rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 100;
}

.app-header-left {
    display: flex;
    align-items: baseline;
    gap: 1rem;
}

.app-header-title {
    font-family: var(--font-display);
    color: var(--color-primary);
    font-size: 1.4rem;
    margin: 0;
}

.app-header-subtitle {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

#mode-switcher {
    display: flex;
    gap: 0.5rem;
}

.mode-btn {
    padding: 0.5rem 1.25rem;
    border: 1px solid var(--color-border);
    background: transparent;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius);
    font-size: 0.9rem;
    font-family: var(--font-body);
    transition: all 0.2s ease;
}

.mode-btn:hover {
    background: var(--color-surface-hover);
    color: var(--color-text);
    border-color: var(--color-text-muted);
}

.mode-btn.active {
    background: var(--color-primary);
    color: #000;
    border-color: var(--color-primary);
    font-weight: 600;
}

/* ===== SECTION 4: CRAFTER WIZARD STYLES ===== */

/* Wizard layout */
#crafter-mode {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Card Builder sidebar wrapper */
.crafter-with-sidebar {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 100vh;
}

.crafter-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.wizard-progress {
    position: sticky;
    top: 0;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    padding: 1.5rem 2rem;
    z-index: 90;
}

.progress-container {
    max-width: 1400px;
    margin: 0 auto;
}

.progress-track {
    height: 4px;
    background: var(--color-border);
    border-radius: 2px;
    position: relative;
    overflow: hidden;
}

.progress-fill {
    position: absolute;
    height: 100%;
    background: var(--color-primary);
    transition: width 0.3s ease;
}

.progress-steps {
    display: flex;
    justify-content: space-between;
    margin-top: 1rem;
}

.progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    opacity: 0.5;
    transition: opacity 0.3s ease;
}

.progress-step.active,
.progress-step.completed {
    opacity: 1;
}

.step-circle {
    width: 36px;
    height: 36px;
    border: 2px solid var(--color-border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    color: var(--color-text-muted);
    transition: all 0.3s ease;
}

.progress-step.active .step-circle {
    border-color: var(--color-primary);
    color: var(--color-primary);
    box-shadow: 0 0 12px rgba(201, 162, 39, 0.3);
}

.progress-step.completed .step-circle {
    background: var(--color-success);
    border-color: var(--color-success);
    color: white;
}

.step-label {
    font-size: 0.75rem;
    margin-top: 0.4rem;
    color: var(--color-text-muted);
}

.progress-step.active .step-label {
    color: var(--color-primary);
}

/* Wizard content area */
.wizard-content {
    flex: 1;
    overflow-y: auto;
    padding: 2rem;
    width: 100%;
    box-sizing: border-box;
}

.wizard-step {
    display: none;
}

.wizard-step.active {
    display: block;
}

.step-container {
    max-width: 1400px;
    margin: 0 auto;
}

.step-title {
    font-family: var(--font-display);
    color: var(--color-primary);
    font-size: 1.6rem;
    margin-bottom: 0.5rem;
}

.step-description {
    color: var(--color-text-muted);
    margin-bottom: 2rem;
    line-height: 1.6;
}

/* Form elements */
.form-section {
    margin-bottom: 1.5rem;
}

.form-label {
    display: block;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin-bottom: 0.4rem;
    font-weight: 600;
}

.required {
    color: var(--color-danger);
    margin-left: 2px;
}

.form-input {
    width: 100%;
    padding: 0.7rem 1rem;
    background: #111;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 0.95rem;
    font-family: var(--font-body);
    transition: border-color 0.2s;
}

.form-input:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 2px rgba(201, 162, 39, 0.15);
}

.form-textarea {
    width: 100%;
    padding: 0.7rem 1rem;
    background: #111;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 0.95rem;
    font-family: var(--font-body);
    min-height: 100px;
    resize: vertical;
    line-height: 1.6;
    transition: border-color 0.2s;
}

.form-textarea:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 2px rgba(201, 162, 39, 0.15);
}

.form-select {
    width: 100%;
    padding: 0.7rem 1rem;
    background: #111;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 0.95rem;
    font-family: var(--font-body);
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    padding-right: 2.5rem;
    transition: border-color 0.2s;
}

.form-select:focus {
    border-color: var(--color-primary);
    outline: none;
}

.form-input-small {
    width: 80px;
    text-align: center;
}

.field-help {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-top: 0.3rem;
}

.source-input-group {
    display: flex;
    gap: 0.5rem;
}

.source-input-group .form-input {
    flex: 1;
}

.chip-container {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.source-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--color-surface-hover);
    border: 1px solid var(--color-border);
    padding: 0.3rem 0.7rem;
    border-radius: 20px;
    font-size: 0.85rem;
    color: var(--color-text);
}

.source-chip .chip-remove {
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 1.1rem;
    transition: color 0.2s;
}

.source-chip .chip-remove:hover {
    color: var(--color-danger);
}

.btn-full {
    width: 100%;
}

.btn-large {
    padding: 1rem 2rem;
    font-size: 1.1rem;
}

/* Variants (AI generation) */
.variants-panel {
    margin-top: 1.5rem;
    padding: 1.5rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
}

.variants-title {
    font-family: var(--font-display);
    color: var(--color-primary);
    font-size: 1.1rem;
    margin-bottom: 0.3rem;
}

.variants-help {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-bottom: 1rem;
}

.variants-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.variant-card {
    background: #111;
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.25rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.variant-card:hover {
    border-color: var(--color-text-muted);
    background: var(--color-surface-hover);
}

.variant-card.selected {
    border-color: var(--color-primary);
    background: rgba(201, 162, 39, 0.08);
}

.variant-card-title {
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.variant-card-text {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    max-height: 150px;
    overflow-y: auto;
}

.variant-card-select {
    margin-top: 0.75rem;
    text-align: right;
}

.variants-saved-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

/* Encounter grid */
.encounter-grid-container {
    margin-top: 1rem;
}

.encounter-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.encounter-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.encounter-card:hover {
    border-color: var(--color-text-muted);
    transform: translateY(-2px);
}

.encounter-card .encounter-chapter {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    margin-bottom: 0.3rem;
}

.encounter-card .encounter-type-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 3px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

.encounter-type-badge.might {
    background: rgba(201, 162, 39, 0.15);
    color: var(--color-primary);
}

.encounter-type-badge.mind {
    background: rgba(108, 63, 160, 0.15);
    color: var(--color-accent);
}

.encounter-type-badge.spirit {
    background: rgba(39, 174, 96, 0.15);
    color: var(--color-success);
}

.encounter-card .encounter-name {
    font-weight: 600;
    margin-top: 0.4rem;
    font-size: 0.95rem;
}

.encounter-card .encounter-description {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-top: 0.3rem;
}

.encounters-summary {
    padding: 0.75rem 1rem;
    background: var(--color-surface);
    border-radius: var(--radius);
    margin-bottom: 1rem;
}

.chapter-regenerate-controls {
    margin-top: 1rem;
}

.controls-label {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin-bottom: 0.5rem;
}

.button-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

/* Encounter editor (step 4) */
.encounters-editor-layout {
    display: flex;
    gap: 1.5rem;
    min-height: 500px;
}

.encounters-sidebar {
    width: 260px;
    flex-shrink: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow-y: auto;
}

.sidebar-header {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.sidebar-header h3 {
    font-size: 0.9rem;
    margin: 0;
}

.encounter-count {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.encounters-list {
    list-style: none;
    padding: 0;
}

.encounter-list-item {
    padding: 0.6rem 1rem;
    cursor: pointer;
    border-bottom: 1px solid rgba(51, 51, 51, 0.5);
    font-size: 0.85rem;
    transition: all 0.15s ease;
}

.encounter-list-item:hover {
    background: var(--color-surface-hover);
}

.encounter-list-item.active {
    background: rgba(201, 162, 39, 0.1);
    border-left: 3px solid var(--color-primary);
}

.encounter-list-item .item-chapter {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
}

.encounter-list-item .item-status {
    float: right;
    font-size: 0.7rem;
}

.encounter-list-item .item-status.complete {
    color: var(--color-success);
}

.encounter-list-item .item-status.incomplete {
    color: var(--color-text-muted);
}

.encounter-editor {
    flex: 1;
    min-width: 0;
}

.editor-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--color-text-muted);
    font-style: italic;
}

.editor-content {
    padding: 0;
}

.encounter-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border);
}

.encounter-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.encounter-name {
    font-size: 1.2rem;
    font-weight: 600;
}

.chapter-label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.encounters-progress-box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    background: var(--color-surface);
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
}

.progress-summary {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.progress-label {
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.progress-stat {
    font-size: 1.1rem;
}

.content-stats {
    display: flex;
    gap: 1.5rem;
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-top: 0.5rem;
}

.editor-controls {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

/* Chapter outro tabs */
.chapter-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border);
    margin-bottom: 1.5rem;
}

.chapter-tab {
    padding: 0.6rem 1.5rem;
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 0.9rem;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.2s ease;
}

.chapter-tab:hover {
    color: var(--color-text);
}

.chapter-tab.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
    font-weight: 600;
}

.subsection-title {
    font-size: 1rem;
    color: var(--color-text);
    margin-bottom: 0.75rem;
    font-weight: 600;
}

.encounter-list-compact {
    margin-bottom: 1rem;
}

/* Condition pattern editor */
.condition-pattern-editor {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.condition-pattern-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
    margin-bottom: 1rem;
}

/* Conclusion (radio, range) */
.radio-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.radio-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--color-text);
}

.radio-label input[type="radio"] {
    accent-color: var(--color-primary);
}

.range-inputs {
    display: flex;
    gap: 1.5rem;
    margin-top: 0.5rem;
}

.range-input-group {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.range-input-group label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

/* Review & push */
.review-summary-box {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.summary-title {
    font-family: var(--font-display);
    color: var(--color-primary);
    font-size: 1.1rem;
    margin-bottom: 1rem;
}

.summary-grid {
    display: grid;
    gap: 0.75rem;
}

.summary-item {
    display: flex;
    gap: 0.75rem;
}

.summary-label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    min-width: 80px;
    flex-shrink: 0;
}

.summary-value {
    color: var(--color-text);
    font-size: 0.9rem;
}

.summary-text-long {
    line-height: 1.5;
}

/* Completion checklist */
.completion-checklist {
    margin-bottom: 1.5rem;
}

.checklist-title {
    font-size: 1rem;
    margin-bottom: 0.75rem;
    font-weight: 600;
}

.checklist-table {
    width: 100%;
    border-collapse: collapse;
}

.checklist-table th {
    text-align: left;
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid var(--color-border);
    color: var(--color-text-muted);
    font-size: 0.8rem;
    text-transform: uppercase;
}

.checklist-table td {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid rgba(51, 51, 51, 0.5);
}

.component-name {
    font-size: 0.9rem;
}

.status-badge {
    display: inline-block;
    padding: 0.15rem 0.6rem;
    border-radius: 3px;
    font-size: 0.75rem;
    font-weight: 600;
}

.status-badge.incomplete {
    background: rgba(192, 57, 43, 0.15);
    color: var(--color-danger);
}

.status-badge.complete {
    background: rgba(39, 174, 96, 0.15);
    color: var(--color-success);
}

.status-detail {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.completion-stats {
    display: flex;
    gap: 2rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.stat-item {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.stat-label {
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

.stat-value {
    color: var(--color-primary);
    font-size: 1.1rem;
}

/* Consistency results */
.consistency-results {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-top: 1rem;
}

.results-title {
    font-size: 1rem;
    margin-bottom: 0.75rem;
}

.results-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Push progress */
.push-progress {
    margin-top: 1.5rem;
    padding: 1.5rem;
    background: var(--color-surface);
    border-radius: var(--radius);
}

.progress-title {
    font-size: 1rem;
    margin-bottom: 0.75rem;
}

.progress-bar-container {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.progress-bar {
    flex: 1;
    height: 8px;
    background: #222;
    border-radius: 4px;
    overflow: hidden;
}

.progress-bar .progress-fill {
    height: 100%;
    background: var(--color-primary);
    transition: width 0.3s ease;
}

.progress-text {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    min-width: 100px;
}

.status-messages {
    margin-top: 0.75rem;
    font-size: 0.85rem;
    max-height: 200px;
    overflow-y: auto;
}

/* Wizard actions (bottom bar) */
.wizard-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
    position: sticky;
    bottom: 0;
    z-index: 50;
}

.action-spacer {
    flex: 1;
}

/* Encounter modal (crafter) */
.modal-dialog {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    max-width: 500px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--color-border);
}

.modal-header h2 {
    font-size: 1.1rem;
    margin: 0;
}

.modal-close {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0;
    transition: color 0.2s;
}

.modal-close:hover {
    color: var(--color-text);
}

.modal-body {
    padding: 1.5rem;
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--color-border);
}

/* Toast container */
.toast-container {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.toast {
    padding: 0.75rem 1.25rem;
    border-radius: var(--radius);
    font-size: 0.9rem;
    animation: toast-in 0.3s ease;
    max-width: 400px;
    box-shadow: var(--shadow);
}

.toast.success {
    background: rgba(39, 174, 96, 0.9);
    color: white;
}

.toast.error {
    background: rgba(192, 57, 43, 0.9);
    color: white;
}

.toast.info {
    background: rgba(108, 63, 160, 0.9);
    color: white;
}

@keyframes toast-in {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Loading spinner and overlay */
.loading-overlay {
    text-align: center;
    padding: 2rem;
    color: var(--color-text-muted);
}

.loading-text {
    margin-top: 0.5rem;
    font-size: 0.85rem;
}

/* ===== SECTION 4B: 11/12-STEP WIZARD NEW STYLES ===== */

/* 11-step progress bar: smaller circles */
.progress-steps-11 .step-circle {
    width: 28px;
    height: 28px;
    font-size: 0.7rem;
}

.progress-steps-11 .step-label {
    font-size: 0.65rem;
    max-width: 50px;
    text-align: center;
    line-height: 1.2;
}

/* 12-step progress bar: even smaller to fit */
.progress-steps-12 .step-circle {
    width: 26px;
    height: 26px;
    font-size: 0.65rem;
}

.progress-steps-12 .step-label {
    font-size: 0.6rem;
    max-width: 46px;
    text-align: center;
    line-height: 1.2;
}

.progress-steps-12 .progress-step {
    gap: 0.2rem;
}

/* 13-step progress bar: smallest to fit */
.progress-steps-13 .step-circle {
    width: 24px;
    height: 24px;
    font-size: 0.6rem;
}

.progress-steps-13 .step-label {
    font-size: 0.55rem;
    max-width: 42px;
    text-align: center;
    line-height: 1.2;
}

.progress-steps-13 .progress-step {
    gap: 0.15rem;
}

/* Tale Select Step */
.tale-select-container {
    max-width: 900px;
    margin: 0 auto;
}

.tale-select-section {
    margin-bottom: 1.5rem;
}

.tale-select-divider {
    text-align: center;
    margin: 1.5rem 0;
    position: relative;
}

.tale-select-divider::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 1px;
    background: var(--color-border);
}

.tale-select-divider span {
    position: relative;
    background: var(--color-bg-secondary, #1a1a2e);
    padding: 0 1rem;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.tale-select-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-height: 400px;
    overflow-y: auto;
}

.tale-select-loading {
    text-align: center;
    color: var(--color-text-muted);
    padding: 2rem;
}

.tale-select-empty {
    text-align: center;
    color: var(--color-text-muted);
    padding: 2rem;
    font-style: italic;
}

.tale-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    background: var(--color-bg, #0a0a0a);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}

.tale-card:hover {
    border-color: var(--color-accent);
    background: rgba(255, 255, 255, 0.03);
}

.tale-card-info {
    flex: 1;
}

.tale-card-name {
    font-weight: 600;
    color: var(--color-text);
    font-size: 1rem;
}

.tale-card-meta {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-top: 0.2rem;
}

.tale-card-arrow {
    color: var(--color-text-muted);
    font-size: 1.2rem;
    margin-left: 1rem;
}

/* Beat card full-width variant */
.beat-card-full {
    grid-column: 1 / -1;
}

/* Story Beats Grid (2-column on desktop) */
.story-beats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 0.75rem;
}

.beat-card {
    background: var(--color-bg, #0a0a0a);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.75rem;
    margin: 0;
}

.beat-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-accent);
    margin-bottom: 0.3rem;
}

.beat-textarea {
    font-size: 0.85rem;
    line-height: 1.4;
    resize: vertical;
    min-height: 60px;
}

.form-hint {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin: 0.25rem 0 0.5rem 0;
}

/* Tale Name Display (read-only on Intro step) */
.tale-name-display {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 1rem;
    background: rgba(212, 175, 55, 0.06);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: var(--radius);
    margin-bottom: 0.75rem;
}

.tale-name-label {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    font-weight: 600;
}

.tale-name-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-accent);
}

/* Tale header row: name + icon side by side */
.tale-header-row {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    margin-bottom: 0.75rem;
}

.tale-header-row .tale-name-display {
    flex: 1;
    margin-bottom: 0;
}

/* Tale Icon Upload */
.tale-icon-upload {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    flex-shrink: 0;
}

.tale-icon-preview {
    width: 64px;
    height: 64px;
    border-radius: 8px;
    border: 2px dashed rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.04);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    transition: all 0.2s ease;
    position: relative;
}

.tale-icon-preview:hover {
    border-color: var(--color-primary);
    background: rgba(201, 162, 39, 0.08);
}

.tale-icon-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--color-text-muted);
    opacity: 0.5;
    width: 100%;
    height: 100%;
}

.tale-icon-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.tale-icon-controls {
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.tale-icon-label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    white-space: nowrap;
}

.btn-icon-remove {
    background: none;
    border: none;
    color: var(--color-danger, #e74c3c);
    font-size: 1rem;
    cursor: pointer;
    padding: 0 0.15rem;
    line-height: 1;
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.btn-icon-remove:hover {
    opacity: 1;
}

/* Outline suggest button highlight */
.btn-outline-suggest {
    border-color: var(--color-accent) !important;
    color: var(--color-accent) !important;
}

.btn-outline-suggest:hover {
    background: rgba(212, 175, 55, 0.15) !important;
}

@media (max-width: 768px) {
    .story-beats-grid {
        grid-template-columns: 1fr;
    }
    .progress-steps-12 .step-label {
        font-size: 0.55rem;
        max-width: 40px;
    }
    .progress-steps-12 .step-circle {
        width: 22px;
        height: 22px;
        font-size: 0.6rem;
    }
    .progress-steps-13 .step-label {
        font-size: 0.5rem;
        max-width: 36px;
    }
    .progress-steps-13 .step-circle {
        width: 20px;
        height: 20px;
        font-size: 0.55rem;
    }
}

/* Writer-first two-panel layout */
.writer-layout {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
}

.writer-editor-panel {
    flex: 7;
    min-width: 0;
}

.writer-brainstorm-panel {
    flex: 3;
    min-width: 240px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-height: 600px;
    position: sticky;
    top: 1rem;
}

.writer-textarea {
    min-height: 250px;
    font-size: 1rem;
    line-height: 1.7;
}

.brainstorm-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.brainstorm-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.btn-brainstorm {
    background: rgba(201, 162, 39, 0.1);
    border: 1px solid rgba(201, 162, 39, 0.3);
    color: var(--color-primary);
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 0.85rem;
    font-family: var(--font-body);
    text-align: left;
    transition: all 0.2s ease;
}

.btn-brainstorm:hover {
    background: rgba(201, 162, 39, 0.2);
    border-color: var(--color-primary);
}

.btn-brainstorm:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.brainstorm-hint {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    line-height: 1.4;
}

.brainstorm-output {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.brainstorm-empty {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    text-align: center;
    padding: 1.5rem 0.5rem;
    font-style: italic;
}

.brainstorm-loading {
    font-size: 0.85rem;
    color: var(--color-primary);
    text-align: center;
    padding: 1.5rem 0.5rem;
    animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.brainstorm-error {
    font-size: 0.8rem;
    color: var(--color-danger, #e74c3c);
    padding: 0.75rem;
    background: rgba(231, 76, 60, 0.1);
    border-radius: var(--radius);
}

.brainstorm-result-title {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.brainstorm-idea-card {
    background: rgba(201, 162, 39, 0.05);
    border: 1px solid rgba(201, 162, 39, 0.15);
    border-radius: var(--radius);
    padding: 0.75rem;
}

.brainstorm-idea-text {
    font-size: 0.85rem;
    line-height: 1.5;
    color: var(--color-text);
    white-space: pre-wrap;
}

.btn-use-this {
    margin-top: 0.5rem;
    background: var(--color-primary);
    color: #000;
    border: none;
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 0.75rem;
    font-weight: 600;
    font-family: var(--font-body);
    transition: background 0.2s ease;
}

.btn-use-this:hover {
    background: var(--color-primary-hover, #d4b234);
}

/* ============================================================
   CHAPTER DESIGN: 3-COLUMN ENCOUNTER PANELS
   ============================================================ */

/* Chapter design steps need full width for 3-col layout */
#step-chapter-1-design,
#step-chapter-2-design,
#step-chapter-3-design,
#step-chapter-4-design {
    max-width: 100% !important;
}

/* 3 equal responsive columns */
.encounter-design-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    width: 100%;
}

@media (max-width: 900px) {
    .encounter-design-grid {
        grid-template-columns: 1fr;
    }
}

/* Chapter Panel cards */
.encounter-design-card {
    border-radius: 10px;
    padding: 1.25rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

/* Light colored backgrounds for each aspect */
.encounter-design-card.enc-might {
    background: rgba(192, 57, 43, 0.10);
    border: 1px solid rgba(192, 57, 43, 0.30);
}

.encounter-design-card.enc-mind {
    background: rgba(41, 128, 185, 0.10);
    border: 1px solid rgba(41, 128, 185, 0.30);
}

.encounter-design-card.enc-spirit {
    background: rgba(39, 174, 96, 0.10);
    border: 1px solid rgba(39, 174, 96, 0.30);
}

/* Hover glow */
.encounter-design-card.enc-might:hover {
    border-color: rgba(192, 57, 43, 0.55);
    box-shadow: 0 0 16px rgba(192, 57, 43, 0.10);
}
.encounter-design-card.enc-mind:hover {
    border-color: rgba(41, 128, 185, 0.55);
    box-shadow: 0 0 16px rgba(41, 128, 185, 0.10);
}
.encounter-design-card.enc-spirit:hover {
    border-color: rgba(39, 174, 96, 0.55);
    box-shadow: 0 0 16px rgba(39, 174, 96, 0.10);
}

/* Aspect badges */
.encounter-type-badge {
    display: inline-block;
    padding: 0.25rem 0.7rem;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.75rem;
    text-align: center;
}

.encounter-design-card.enc-might .encounter-type-badge {
    background: rgba(192, 57, 43, 0.25);
    color: #e74c3c;
}
.encounter-design-card.enc-mind .encounter-type-badge {
    background: rgba(41, 128, 185, 0.25);
    color: #3498db;
}
.encounter-design-card.enc-spirit .encounter-type-badge {
    background: rgba(39, 174, 96, 0.25);
    color: #2ecc71;
}

/* Compact inline challenge level row */
.challenge-level-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    flex-wrap: wrap;
}

.challenge-level-row .challenge-label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    font-weight: 600;
    white-space: nowrap;
}

.cl-inline-label {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    font-weight: 600;
}

.cl-inline-input {
    width: 48px !important;
    text-align: center;
    padding: 0.3rem 0.2rem !important;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 0.85rem;
    font-family: var(--font-body);
}

.cl-inline-input:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 2px rgba(201, 162, 39, 0.15);
}

.cl-inline-input::-webkit-inner-spin-button,
.cl-inline-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.cl-inline-input {
    -moz-appearance: textfield;
}

/* ============================================================
   ENCOUNTER CARD AREA (preview / create button)
   ============================================================ */
.encounter-card-area {
    margin-top: auto;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.btn-create-encounter-card {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.6rem 0.9rem;
    font-size: 0.8rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px dashed rgba(255, 255, 255, 0.2);
    color: var(--color-text-muted);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-create-encounter-card:hover {
    background: rgba(201, 162, 39, 0.12);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* Encounter card mini preview (shown after card is created) */
.encounter-card-preview {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0.75rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
}

.encounter-card-preview:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.25);
}

.encounter-card-preview .ecp-icon {
    font-size: 1.4rem;
    opacity: 0.8;
}

.encounter-card-preview .ecp-info {
    flex: 1;
    min-width: 0;
}

.encounter-card-preview .ecp-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.encounter-card-preview .ecp-meta {
    font-size: 0.7rem;
    color: var(--color-text-muted);
}

.encounter-card-preview .ecp-edit-hint {
    font-size: 0.7rem;
    color: var(--color-primary);
    opacity: 0;
    transition: opacity 0.2s ease;
    font-weight: 600;
}

.encounter-card-preview:hover .ecp-edit-hint {
    opacity: 1;
}

/* Encounter card rendered preview (actual card visual) */
.encounter-card-render-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    transition: all 0.2s ease;
    padding: 0.25rem 0;
    border-radius: var(--radius);
    overflow: hidden;
}

.encounter-card-render-wrap:hover {
    background: rgba(255, 255, 255, 0.06);
}

.ecrw-card-container {
    transform: scale(0.75);
    transform-origin: top center;
    width: 225px;
    height: 236px;
    pointer-events: none;
}

.ecrw-card-container .cb-preview-card {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

.ecrw-placeholder .ecrw-card-container {
    opacity: 0.45;
}

.ecrw-action-label {
    font-size: 0.7rem;
    color: var(--color-primary);
    font-weight: 600;
    opacity: 0;
    transition: opacity 0.2s ease;
    margin-top: -2px;
}

.encounter-card-render-wrap:hover .ecrw-action-label {
    opacity: 1;
}

/* ============================================================
   CARD BUILDER MODAL OVERLAY (centered, not sidebar)
   ============================================================ */
.cb-modal-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 200;
    justify-content: center;
    align-items: flex-start;
    padding: 3vh 2vw;
    overflow-y: auto;
}

.cb-modal-backdrop.open {
    display: flex;
}

/* Old challenge level styles (keep for backward compat) */
.challenge-level-group {
    display: flex;
    gap: 1rem;
    margin-top: 0.75rem;
}

.challenge-level-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
}

.challenge-level-item label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    font-weight: 600;
}

.challenge-level-input {
    width: 70px;
    text-align: center;
    padding: 0.5rem;
    background: #111;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 1rem;
    font-family: var(--font-body);
}

.challenge-level-input:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 2px rgba(201, 162, 39, 0.15);
}

.challenge-level-input::-webkit-inner-spin-button,
.challenge-level-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.challenge-level-input {
    -moz-appearance: textfield;
}

/* Outro encounter summary */
.outro-encounter-summary {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.outro-encounter-summary .enc-summary-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--color-surface-hover);
    border: 1px solid var(--color-border);
    padding: 0.3rem 0.7rem;
    border-radius: 20px;
    font-size: 0.8rem;
}

/* Condition pattern builder (W/L/* selects) */
.condition-pattern-builder {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.condition-pattern-builder .pattern-encounter {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
}

.condition-pattern-builder .pattern-encounter label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
}

.condition-pattern-builder .pattern-encounter select {
    width: 70px;
    padding: 0.4rem;
    background: #111;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    font-size: 0.85rem;
    text-align: center;
    cursor: pointer;
}

.condition-pattern-builder .pattern-encounter select:focus {
    border-color: var(--color-primary);
    outline: none;
}

/* Win tier selector buttons */
.win-tier-selector {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.win-tier-btn {
    flex: 1;
    padding: 0.8rem 1rem;
    background: var(--color-surface);
    border: 2px solid var(--color-border);
    color: var(--color-text);
    border-radius: var(--radius);
    cursor: pointer;
    text-align: center;
    font-size: 0.9rem;
    font-family: var(--font-body);
    transition: all 0.2s ease;
}

.win-tier-btn:hover {
    border-color: var(--color-text-muted);
    background: var(--color-surface-hover);
}

.win-tier-btn.active {
    border-color: var(--color-primary);
    background: rgba(201, 162, 39, 0.1);
    color: var(--color-primary);
    font-weight: 600;
}

.win-tier-btn .tier-label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.2rem;
}

.win-tier-btn .tier-desc {
    display: block;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.win-tier-btn.active .tier-desc {
    color: var(--color-primary);
    opacity: 0.8;
}

/* Saved variants list (outros and conclusions) */
.saved-variants-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 1rem;
}

.saved-variant-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    position: relative;
}

.saved-variant-card .variant-condition {
    font-size: 0.75rem;
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.3rem;
}

.saved-variant-card .variant-title {
    font-weight: 600;
    margin-bottom: 0.3rem;
}

.saved-variant-card .variant-preview {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    max-height: 80px;
    overflow: hidden;
}

.saved-variant-card .variant-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

/* Outro Navigator */
.outro-navigator {
    margin-top: 1.5rem;
    border-top: 1px solid var(--color-border);
    padding-top: 1rem;
}

.outro-nav-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.outro-nav-count {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    background: var(--color-surface);
    padding: 0.2rem 0.6rem;
    border-radius: 12px;
    border: 1px solid var(--color-border);
}

.outro-nav-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.outro-nav-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.75rem 1rem;
    transition: border-color 0.2s;
}

.outro-nav-card:hover {
    border-color: var(--color-primary);
}

.outro-nav-card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.4rem;
}

.outro-nav-pattern {
    font-family: var(--font-mono, monospace);
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-accent);
    background: rgba(212, 175, 55, 0.1);
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
    letter-spacing: 0.1em;
}

.outro-nav-title {
    font-weight: 600;
    font-size: 0.9rem;
}

.outro-nav-preview {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    line-height: 1.4;
    margin-bottom: 0.5rem;
}

.outro-nav-actions {
    display: flex;
    gap: 0.5rem;
}

.outro-nav-btn-edit {
    font-size: 0.78rem;
    padding: 0.2rem 0.7rem;
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.outro-nav-btn-edit:hover {
    opacity: 0.85;
}

.outro-nav-btn-delete {
    font-size: 0.78rem;
    padding: 0.2rem 0.7rem;
    background: transparent;
    color: #e74c3c;
    border: 1px solid #e74c3c;
    border-radius: 4px;
    cursor: pointer;
}

.outro-nav-btn-delete:hover {
    background: #e74c3c;
    color: #fff;
}

/* ===== Outro Step Layout (sidebar + editor) ===== */
.outro-step-layout {
    display: flex;
    gap: 1.25rem;
    margin-top: 1rem;
    min-height: 500px;
    position: relative;
}

.outro-sidebar {
    flex: 0 0 260px;
    max-width: 300px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    overflow-y: auto;
    max-height: 700px;
}

.outro-sidebar-title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.outro-sidebar-count {
    font-size: 0.75rem;
    font-weight: 400;
    color: var(--color-text-muted);
    text-transform: none;
    letter-spacing: 0;
}

.outro-sidebar-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex: 1;
}

.outro-sidebar-empty {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    text-align: center;
    padding: 1.5rem 0.5rem;
    line-height: 1.5;
}

.outro-sidebar-card {
    background: var(--color-bg, #0a0a0a);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.6rem 0.75rem;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}

.outro-sidebar-card:hover {
    border-color: var(--color-primary);
}

.outro-sidebar-card.active {
    border-color: var(--color-primary);
    background: rgba(212, 175, 55, 0.06);
}

.outro-sidebar-card-pattern {
    font-family: var(--font-mono, monospace);
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--color-accent);
    background: rgba(212, 175, 55, 0.1);
    padding: 0.1rem 0.4rem;
    border-radius: 3px;
    letter-spacing: 0.1em;
    display: inline-block;
}

.outro-sidebar-card-title {
    font-size: 0.82rem;
    font-weight: 600;
    margin-top: 0.3rem;
    line-height: 1.3;
}

.outro-sidebar-card-preview {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    line-height: 1.3;
    margin-top: 0.2rem;
    max-height: 2.6em;
    overflow: hidden;
}

.outro-sidebar-card-audio {
    margin-top: 0.3rem;
}

.outro-sidebar-card-audio audio {
    width: 100%;
    height: 28px;
}

.outro-sidebar-card-actions {
    display: flex;
    gap: 0.4rem;
    margin-top: 0.4rem;
}

.outro-sidebar-card-actions .btn {
    font-size: 0.72rem;
    padding: 0.15rem 0.5rem;
}

.outro-sidebar-btn-edit {
    background: rgba(212, 175, 55, 0.1);
    border: 1px solid var(--color-primary);
    color: var(--color-primary);
    cursor: pointer;
    border-radius: var(--radius);
    transition: background 0.2s;
}

.outro-sidebar-btn-edit:hover {
    background: rgba(212, 175, 55, 0.2);
}

.outro-sidebar-btn-delete {
    background: rgba(231, 76, 60, 0.1);
    border: 1px solid #e74c3c;
    color: #e74c3c;
    cursor: pointer;
    border-radius: var(--radius);
    transition: background 0.2s;
}

.outro-sidebar-btn-delete:hover {
    background: rgba(231, 76, 60, 0.2);
}

.outro-sidebar-audio-badge {
    font-size: 0.8rem;
    margin-left: 0.3rem;
}

.btn-sidebar-new {
    width: 100%;
    padding: 0.5rem;
    font-size: 0.82rem;
    background: transparent;
    border: 1px dashed var(--color-border);
    color: var(--color-text-muted);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s;
    margin-top: 0.25rem;
}

.btn-sidebar-new:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.outro-editor-area {
    flex: 1;
    min-width: 0;
}

/* Audio section hidden state */
.audio-section-hidden {
    display: none;
}

/* AI Help toggle button */
.btn-ai-help {
    background: rgba(201, 162, 39, 0.1);
    border: 1px solid rgba(201, 162, 39, 0.3);
    color: var(--color-primary);
    padding: 0.45rem 0.85rem;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 0.85rem;
    transition: all 0.2s;
}

.btn-ai-help:hover {
    background: rgba(201, 162, 39, 0.2);
    border-color: var(--color-primary);
}

/* AI Panel Overlay (slide-in from right) */
.ai-panel-overlay {
    position: absolute;
    top: 0;
    right: 0;
    width: 320px;
    max-height: 100%;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
    display: none;
    flex-direction: column;
    gap: 0.75rem;
    z-index: 20;
    box-shadow: -4px 0 20px rgba(0,0,0,0.3);
    overflow-y: auto;
}

.ai-panel-overlay.open,
.ai-panel-overlay.visible {
    display: flex;
}

.ai-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ai-panel-header .brainstorm-title {
    margin: 0;
}

.btn-ai-close {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    padding: 0;
    line-height: 1;
}

.btn-ai-close:hover {
    border-color: #e74c3c;
    color: #e74c3c;
}

/* Responsive: stack sidebar above editor on narrow screens */
@media (max-width: 768px) {
    .outro-step-layout {
        flex-direction: column;
    }
    .outro-sidebar {
        flex: none;
        max-width: 100%;
        max-height: 200px;
    }
    .ai-panel-overlay {
        width: 100%;
        position: fixed;
        top: auto;
        bottom: 0;
        left: 0;
        right: 0;
        max-height: 60vh;
        border-radius: var(--radius) var(--radius) 0 0;
    }
}

.outro-nav-audio-badge {
    font-size: 0.85rem;
    margin-left: auto;
    cursor: default;
}

.outro-nav-audio-player {
    margin: 0.4rem 0;
}

/* Audio section */
.audio-section {
    margin-top: 1rem;
    padding: 1rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
}

.audio-section .audio-controls {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.audio-section audio {
    width: 100%;
    margin-top: 0.5rem;
}

/* Publish step: review grid */
.publish-review-grid {
    display: grid;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.publish-encounter-grid {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.publish-encounter-grid th {
    text-align: left;
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid var(--color-border);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
}

.publish-encounter-grid td {
    padding: 0.4rem 0.75rem;
    border-bottom: 1px solid rgba(51, 51, 51, 0.5);
}

/* ===== SECTION 5: SHARED RESPONSIVE ===== */

@media (max-width: 1024px) {
    .encounter-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

    .builder-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--color-border);
        max-height: 200px;
    }

    .player-title {
        font-size: 1.8rem;
    }

    .encounters-editor-layout {
        flex-direction: column;
    }

    .encounters-sidebar {
        width: 100%;
    }

    .writer-layout {
        flex-direction: column;
    }

    .writer-brainstorm-panel {
        min-width: unset;
        position: static;
        max-height: none;
    }

    .progress-step .step-label {
        display: none;
    }

    .progress-steps-11 .step-circle {
        width: 24px;
        height: 24px;
        font-size: 0.6rem;
    }

    .win-tier-selector {
        flex-direction: column;
    }

    .challenge-level-group {
        flex-wrap: wrap;
    }

    .encounter-grid {
        grid-template-columns: 1fr;
    }

    #app-header {
        flex-direction: column;
        gap: 0.75rem;
        align-items: flex-start;
    }

    .app-header-left {
        width: 100%;
    }

    #mode-switcher {
        width: 100%;
    }

    .mode-btn {
        flex: 1;
    }
}

@media (max-width: 480px) {
    .game-logo {
        font-size: 1.9rem;
    }

    .hub-header-top {
        flex-direction: column;
        align-items: flex-start;
    }

    .chapter-node {
        width: 36px;
        height: 36px;
        font-size: 0.9rem;
    }

    .chapter-connector {
        width: 24px;
    }

    .phase-card-title {
        font-size: 1.2rem;
    }

    .turn-actions-grid {
        grid-template-columns: 1fr;
    }

    .turn-action-pass {
        grid-column: 1;
    }

    .encounter-setup-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .encounter-table th,
    .encounter-table td {
        padding: 0.3rem 0.25rem;
    }

    .encounter-cl-input {
        width: 48px !important;
    }

    .encounter-result-card {
        flex-direction: column;
        align-items: stretch;
        gap: 0.6rem;
    }

    .result-toggle-group {
        justify-content: center;
    }

    .condition-toggle-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .mode-btn {
        padding: 0.4rem 0.75rem;
        font-size: 0.8rem;
    }

    .app-header-title {
        font-size: 1.2rem;
    }

    .wizard-progress {
        padding: 1rem 1.5rem;
    }

    .wizard-content {
        padding: 1rem;
    }

    .wizard-actions {
        padding: 0.75rem 1rem;
    }

    .step-title {
        font-size: 1.3rem;
    }

    .form-label {
        font-size: 0.8rem;
    }

    .form-input,
    .form-textarea,
    .form-select {
        font-size: 0.9rem;
        padding: 0.6rem 0.8rem;
    }

    .variants-container {
        grid-template-columns: 1fr;
    }

    .encounters-editor-layout {
        gap: 1rem;
    }
}

/* ============================================================
   CONDITION SLOT (actual HTML class names used in outro page)
   ============================================================ */
.condition-slot {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
}

.condition-slot-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.condition-select {
    width: 75px;
    padding: 0.4rem 0.5rem;
    background: #111;
    border: 1px solid rgba(255,255,255,0.15);
    color: #fff;
    border-radius: 6px;
    font-size: 0.85rem;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s;
}

.condition-select:focus {
    border-color: var(--color-primary, #d4af37);
    outline: none;
}

.condition-pattern-display {
    font-family: monospace;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--color-primary, #d4af37);
    background: rgba(212,175,55,0.08);
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    border: 1px solid rgba(212,175,55,0.15);
    letter-spacing: 0.12em;
    margin-left: 0.5rem;
}

/* ============================================================
   ENCOUNTER SUMMARY CHIPS (Outro pages)
   ============================================================ */
.encounter-summary {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
    padding: 0.75rem;
    background: var(--color-surface, #12132a);
    border: 1px solid var(--color-border, rgba(255,255,255,0.1));
    border-radius: 8px;
}

.encounter-summary-title {
    width: 100%;
    font-size: 0.8rem;
    font-weight: 700;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.25rem;
}

.encounter-summary-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    padding: 0.3rem 0.7rem;
    border-radius: 20px;
    font-size: 0.78rem;
    color: rgba(255,255,255,0.8);
}

.encounter-summary-item .badge {
    font-size: 0.65rem;
    padding: 0.1rem 0.4rem;
    border-radius: 3px;
    font-weight: 700;
    text-transform: uppercase;
}

.badge-might { background: rgba(231,76,60,0.2); color: #e74c3c; border: 1px solid rgba(231,76,60,0.3); }
.badge-mind { background: rgba(52,152,219,0.2); color: #5dade2; border: 1px solid rgba(52,152,219,0.3); }
.badge-spirit { background: rgba(46,204,113,0.2); color: #2ecc71; border: 1px solid rgba(46,204,113,0.3); }
