/* ============================================
   OFFGRID AI INTEL - Showcase Demo Page
   Walkthrough + Live Demo Styles
   ============================================ */

/* --- Demo Hero Override --- */
.demo-hero {
    min-height: 480px;
}
.demo-hero .inner {
    padding: 60px 40px;
}

/* --- Walkthrough Container --- */
.walkthrough-container {
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 20px;
    overflow: hidden;
    margin-top: 32px;
}

/* Progress Bar */
.wt-progress {
    height: 3px;
    background: rgba(212, 175, 55, 0.1);
    position: relative;
}
.wt-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--gold), var(--gold-light));
    width: 0%;
    transition: width 0.5s ease;
}

/* Step Indicators */
.wt-step-indicators {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 20px 24px 0;
}
.wt-step-dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid rgba(212, 175, 55, 0.2);
    background: transparent;
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}
.wt-step-dot.active {
    border-color: var(--gold);
    background: var(--gold-glow);
    color: var(--gold);
}
.wt-step-dot.complete {
    border-color: var(--accent-green);
    background: rgba(76, 175, 80, 0.15);
    color: var(--accent-green);
}

/* Walkthrough Screen */
.wt-screen {
    padding: 32px;
    min-height: 420px;
    position: relative;
}

/* Slides */
.wt-slide {
    display: none;
    animation: fadeSlideIn 0.4s ease;
}
.wt-slide.active {
    display: block;
}
@keyframes fadeSlideIn {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

.wt-slide-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 8px;
}
.wt-slide h3 {
    font-size: 24px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 24px;
}
.wt-caption {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.7;
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--border-subtle);
}

/* --- Step 0: Mock Input UI --- */
.wt-mock-ui {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    overflow: hidden;
}
.wt-mock-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-subtle);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}
.wt-mock-mode {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--gold);
    background: var(--gold-glow);
    padding: 4px 12px;
    border-radius: 20px;
}
.wt-mock-input {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    gap: 12px;
}
.wt-typing-text {
    flex: 1;
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.6;
    min-height: 40px;
    font-family: 'Inter', sans-serif;
}
.wt-typing-text::after {
    content: '|';
    animation: blink 0.8s infinite;
    color: var(--gold);
}
@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}
.wt-mock-send {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--gold);
    color: #1A1611;
    border: none;
    cursor: pointer;
    font-size: 14px;
}

/* --- Step 1: Council Grid --- */
.wt-council-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.wt-model-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 24px 16px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.wt-model-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}
.wt-model-card.scout::before { background: linear-gradient(90deg, #4CAF50, #81C784); }
.wt-model-card.medic::before { background: linear-gradient(90deg, #42A5F5, #90CAF9); }
.wt-model-card.navigator::before { background: linear-gradient(90deg, #FFA726, #FFB74D); }
.wt-model-card.ranger::before { background: linear-gradient(90deg, #EF5350, #EF9A9A); }

.wt-model-indicator {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    top: 12px;
    right: 12px;
}
.wt-model-indicator.thinking {
    background: var(--gold);
    animation: pulse 1.5s infinite;
}
@keyframes pulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.3); }
}
.wt-model-emoji {
    font-size: 36px;
    margin-bottom: 8px;
}
.wt-model-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 2px;
}
.wt-model-id {
    font-size: 11px;
    font-weight: 600;
    color: var(--gold);
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}
.wt-model-status {
    font-size: 12px;
    color: var(--text-muted);
    animation: fadeInOut 2s infinite;
}
@keyframes fadeInOut {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

/* --- Step 2: Peer Review --- */
.wt-review-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 24px;
}
.wt-review-grid {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.wt-review-row {
    display: flex;
    align-items: center;
    gap: 16px;
}
.wt-reviewer {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    min-width: 130px;
}
.wt-review-labels {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.wt-label {
    font-size: 12px;
    font-weight: 600;
    padding: 4px 14px;
    border-radius: 20px;
    background: var(--gold-glow);
    color: var(--gold);
    border: 1px solid rgba(212, 175, 55, 0.2);
}
.wt-label[data-rank="1"] {
    background: rgba(76, 175, 80, 0.15);
    color: var(--accent-green);
    border-color: rgba(76, 175, 80, 0.3);
}
.wt-review-note {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-subtle);
    font-size: 12px;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 8px;
}

/* --- Step 3: Scoring --- */
.wt-scoring-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 24px;
}
.wt-score-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 0;
}
.wt-score-bar:not(:last-of-type) {
    border-bottom: 1px solid var(--border-subtle);
}
.wt-score-model {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 130px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}
.wt-score-emoji {
    font-size: 20px;
}
.wt-bar-track {
    flex: 1;
    height: 8px;
    background: rgba(212, 175, 55, 0.1);
    border-radius: 4px;
    overflow: hidden;
}
.wt-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, rgba(212, 175, 55, 0.4), rgba(212, 175, 55, 0.6));
    border-radius: 4px;
    transition: width 1s ease;
}
.wt-bar-fill.chairman {
    background: linear-gradient(90deg, var(--gold), var(--gold-light));
}
.wt-score-value {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-secondary);
    min-width: 70px;
    text-align: right;
}
.wt-score-value.chairman-badge {
    color: var(--gold);
}
.wt-formula {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-subtle);
    text-align: center;
}
.wt-formula code {
    font-size: 13px;
    color: var(--gold);
    background: var(--gold-glow);
    padding: 6px 16px;
    border-radius: 6px;
    font-family: 'Inter', monospace;
}

/* --- Step 4: Synthesis --- */
.wt-synthesis-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    overflow: hidden;
}
.wt-synthesis-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-subtle);
}
.wt-synthesis-badge {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
}
.wt-synthesis-meta {
    font-size: 11px;
    color: var(--text-muted);
}
.wt-synthesis-content {
    padding: 20px;
    max-height: 280px;
    overflow-y: auto;
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.7;
}
.wt-synthesis-content h2 {
    font-size: 18px;
    color: var(--gold);
    margin: 16px 0 8px;
}
.wt-synthesis-content h2:first-child {
    margin-top: 0;
}
.wt-synthesis-content h3 {
    font-size: 15px;
    color: var(--text-primary);
    margin: 12px 0 6px;
}
.wt-synthesis-content p {
    margin-bottom: 8px;
}
.wt-consensus {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    border-top: 1px solid var(--border-subtle);
}
.wt-consensus-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
}
.wt-consensus-bar {
    flex: 1;
    height: 6px;
    background: rgba(76, 175, 80, 0.1);
    border-radius: 3px;
    overflow: hidden;
}
.wt-consensus-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--accent-green), #81C784);
    border-radius: 3px;
}
.wt-consensus-level {
    font-size: 12px;
    font-weight: 700;
    color: var(--accent-green);
}

/* --- Step 5: Image Generation --- */
.wt-image-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    overflow: hidden;
}
.wt-image-studio-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border-subtle);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}
.wt-image-status {
    font-size: 12px;
    font-weight: 600;
    color: var(--gold);
}
.wt-image-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--text-secondary);
    font-size: 14px;
}
.wt-image-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(212, 175, 55, 0.2);
    border-top-color: var(--gold);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: 16px;
}
@keyframes spin {
    to { transform: rotate(360deg); }
}
.wt-image-complete {
    text-align: center;
}

/* --- Step 6: Parts List --- */
.wt-parts-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    overflow: hidden;
}
.wt-parts-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border-subtle);
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
}
.wt-parts-list {
    padding: 16px 20px;
}
.wt-part-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 14px;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-subtle);
}
.wt-part-item:last-child {
    border-bottom: none;
}
.wt-part-item i {
    color: var(--accent-green);
    font-size: 12px;
    min-width: 16px;
}

/* --- Step 7: Save & Print --- */
.wt-save-visual {
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 32px;
}
.wt-save-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
.wt-save-card {
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 12px;
    padding: 24px 16px;
    text-align: center;
    transition: all 0.3s ease;
}
.wt-save-card:hover {
    border-color: rgba(212, 175, 55, 0.3);
    transform: translateY(-2px);
}
.wt-save-card i {
    font-size: 28px;
    color: var(--gold);
    margin-bottom: 12px;
}
.wt-save-card span {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 4px;
}
.wt-save-card small {
    font-size: 12px;
    color: var(--text-muted);
}
.wt-save-message {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: var(--gold-glow);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: 12px;
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.6;
}

/* --- Walkthrough Navigation --- */
.wt-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 32px;
    border-top: 1px solid var(--border-subtle);
    background: rgba(26, 22, 17, 0.5);
}
.wt-nav-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 8px;
    border: 1px solid var(--border-card);
    background: transparent;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}
.wt-nav-btn:hover:not(:disabled) {
    border-color: var(--gold);
    color: var(--gold);
}
.wt-nav-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}
.wt-nav-btn.primary {
    background: var(--gold);
    color: #1A1611;
    border-color: var(--gold);
}
.wt-nav-btn.primary:hover {
    background: var(--gold-light);
    color: #1A1611;
}
.wt-step-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
    letter-spacing: 0.5px;
}


/* ============================================
   LIVE DEMO SECTION
   ============================================ */

/* Transition Section */
.demo-transition {
    text-align: center;
    position: relative;
}
.demo-transition::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 1px;
    height: 40px;
    background: linear-gradient(180deg, transparent, var(--gold));
}
.demo-credit-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--gold-glow);
    border: 1px solid rgba(212, 175, 55, 0.3);
    border-radius: 30px;
    padding: 10px 24px;
    font-size: 14px;
    font-weight: 700;
    color: var(--gold);
    margin-top: 20px;
    transition: all 0.3s ease;
}
.demo-credit-badge.exhausted {
    background: rgba(76, 175, 80, 0.1);
    border-color: rgba(76, 175, 80, 0.3);
    color: var(--accent-green);
}

/* Demo Panel */
.demo-panel {
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 16px;
    overflow: hidden;
}
.demo-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 24px;
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(26, 22, 17, 0.5);
}
.demo-header-left {
    display: flex;
    align-items: center;
    gap: 10px;
}
.demo-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
}
.demo-mode-badge {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1.5px;
    color: var(--accent-green);
    background: rgba(76, 175, 80, 0.15);
    border: 1px solid rgba(76, 175, 80, 0.3);
    padding: 2px 10px;
    border-radius: 20px;
}
.demo-privacy {
    font-size: 12px;
    color: var(--text-muted);
}
.demo-privacy i {
    color: var(--gold);
    margin-right: 4px;
}

/* Prompt Chips */
.demo-prompts {
    padding: 24px;
    border-bottom: 1px solid var(--border-subtle);
}
.demo-prompts-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 12px;
}
.demo-prompt-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.demo-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 20px;
    border: 1px solid var(--border-card);
    background: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}
.demo-chip:hover {
    border-color: var(--gold);
    background: var(--gold-glow);
    color: var(--gold);
}
.demo-chip i {
    font-size: 12px;
    color: var(--gold);
}

/* Chat Area */
.demo-chat {
    min-height: 100px;
    max-height: 600px;
    overflow-y: auto;
    padding: 16px 24px;
}

/* Messages */
.demo-msg {
    margin-bottom: 20px;
    animation: fadeSlideIn 0.3s ease;
}
.demo-msg.user .demo-msg-content {
    background: var(--gold-glow);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: 12px 12px 4px 12px;
    padding: 14px 18px;
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.6;
    max-width: 85%;
    margin-left: auto;
}
.demo-msg.assistant {
    border: 1px solid #e0ddd8;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}
.demo-msg-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 18px;
    background: #f8f6f3;
    border-bottom: 1px solid #e8e5e0;
}
.demo-msg-name {
    font-size: 13px;
    font-weight: 700;
    color: #8b7355;
}
.demo-msg-meta {
    font-size: 11px;
    color: #999;
}
.demo-msg.assistant .demo-msg-content {
    padding: 24px 28px;
    font-size: 14px;
    color: #2c2c2c;
    line-height: 1.8;
    background: #ffffff;
    font-family: Georgia, 'Times New Roman', serif;
    max-height: 500px;
    overflow-y: auto;
}
.demo-msg.assistant .demo-msg-content::-webkit-scrollbar {
    width: 6px;
}
.demo-msg.assistant .demo-msg-content::-webkit-scrollbar-track {
    background: #f5f5f5;
}
.demo-msg.assistant .demo-msg-content::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 3px;
}
.demo-msg.assistant .demo-msg-content h1,
.demo-msg.assistant .demo-msg-content h2 {
    font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
    font-size: 18px;
    color: #1a1a1a;
    margin: 20px 0 10px;
    padding-bottom: 6px;
    border-bottom: 2px solid #d4af37;
}
.demo-msg.assistant .demo-msg-content h3 {
    font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
    font-size: 15px;
    color: #333;
    margin: 16px 0 8px;
    font-weight: 600;
}
.demo-msg.assistant .demo-msg-content p {
    margin-bottom: 10px;
    color: #444;
}
.demo-msg.assistant .demo-msg-content ul,
.demo-msg.assistant .demo-msg-content ol {
    padding-left: 24px;
    margin-bottom: 10px;
}
.demo-msg.assistant .demo-msg-content li {
    margin-bottom: 5px;
    color: #444;
}
.demo-msg.assistant .demo-msg-content strong {
    color: #1a1a1a;
    font-weight: 700;
}
.demo-msg.assistant .demo-msg-content code {
    background: #f5f3f0;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 13px;
    color: #8b4513;
}
.demo-msg.assistant .demo-msg-content pre {
    background: #f8f6f3;
    padding: 16px;
    border-radius: 8px;
    overflow-x: auto;
    border: 1px solid #e8e5e0;
    font-size: 13px;
}
.demo-msg.assistant .demo-msg-content hr {
    border: none;
    border-top: 1px solid #e8e5e0;
    margin: 16px 0;
}
.demo-msg.assistant .demo-msg-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 16px 0;
    font-size: 13px;
}
.demo-msg.assistant .demo-msg-content table th,
.demo-msg.assistant .demo-msg-content table td {
    border: 1px solid #d0cdc8;
    padding: 8px 12px;
    text-align: left;
}
.demo-msg.assistant .demo-msg-content table th {
    background: #f5f3f0;
    font-weight: 700;
    color: #333;
    font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
}
.demo-msg.assistant .demo-msg-content table td {
    color: #444;
}
.demo-msg.assistant .demo-msg-content table tr:nth-child(even) td {
    background: #faf9f7;
}
.demo-msg.assistant .demo-msg-content table tr:hover td {
    background: #f5f0e6;
}
.demo-msg.error .demo-msg-content {
    background: rgba(239, 83, 80, 0.1);
    border: 1px solid rgba(239, 83, 80, 0.2);
    border-radius: 12px;
    padding: 18px;
    font-size: 14px;
    color: var(--text-secondary);
}

/* Council Meta Bar */
.demo-meta-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 18px;
    border-top: 1px solid #e8e5e0;
    background: #f8f6f3;
    flex-wrap: wrap;
}
.meta-chairman {
    font-size: 13px;
    font-weight: 700;
    color: #8b7355;
}
.meta-scores {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.meta-score {
    font-size: 11px;
    font-weight: 600;
    color: #777;
    background: #eee;
    padding: 2px 10px;
    border-radius: 12px;
}
.meta-score.chairman {
    color: #8b7355;
    background: #f5f0e6;
    border: 1px solid #d4af37;
}

/* Answer Actions */
.demo-answer-actions {
    display: flex;
    gap: 8px;
    padding: 12px 18px;
    border-top: 1px solid #e8e5e0;
    background: #f8f6f3;
    flex-wrap: wrap;
}
.demo-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 8px;
    border: 1px solid #ddd;
    background: #fff;
    color: #666;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}
.demo-action-btn:hover {
    border-color: #d4af37;
    color: #8b7355;
    background: #faf8f5;
}
.demo-action-btn.featured {
    background: var(--gold);
    color: #1A1611;
    border-color: var(--gold);
    font-weight: 700;
}
.demo-action-btn.featured:hover {
    background: var(--gold-light);
}

/* Input Area */
.demo-input-area {
    display: flex;
    gap: 12px;
    padding: 16px 24px;
    border-top: 1px solid var(--border-subtle);
    align-items: flex-end;
}
.demo-input-area textarea {
    flex: 1;
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 12px 16px;
    font-size: 14px;
    color: var(--text-primary);
    font-family: 'Inter', sans-serif;
    resize: none;
    outline: none;
    transition: border-color 0.2s ease;
}
.demo-input-area textarea:focus {
    border-color: var(--gold);
}
.demo-input-area textarea::placeholder {
    color: var(--text-muted);
}
#demoSendBtn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    border-radius: 10px;
    background: var(--gold);
    color: #1A1611;
    border: none;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
}
#demoSendBtn:hover {
    background: var(--gold-light);
}
#demoSendBtn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Deliberation Panel */
.demo-deliberation {
    padding: 24px;
}
.delib-status-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: var(--gold-glow);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: 10px;
    margin-bottom: 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--gold);
}
.delib-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid rgba(212, 175, 55, 0.2);
    border-top-color: var(--gold);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    flex-shrink: 0;
}
.delib-model-sub {
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 400;
}
.delib-step {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    opacity: 0.4;
    transition: all 0.3s ease;
}
.delib-step.active {
    opacity: 1;
}
.delib-step.complete {
    opacity: 0.7;
}
.delib-step-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--gold-glow);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
    font-size: 14px;
}
.delib-step.complete .delib-step-icon {
    background: rgba(76, 175, 80, 0.15);
    color: var(--accent-green);
}
.delib-step-text {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
}
.delib-models-grid {
    display: flex;
    gap: 16px;
    margin-left: auto;
    flex-wrap: wrap;
}
.delib-model {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
}
.delib-model.complete {
    color: var(--accent-green);
}
.delib-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}
.delib-dot.thinking {
    background: var(--gold);
    animation: pulse 1.5s infinite;
}
.delib-dot.complete {
    background: var(--accent-green);
}

/* Deliberation Results Panel */
.delib-results-panel {
    margin: 0;
    background: #ffffff;
    border-top: 1px solid #e8e5e0;
    padding: 20px 24px;
}
.delib-results-header {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 16px;
    font-family: 'Inter', sans-serif;
}
.delib-results-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}
.delib-info-item {
    background: #f8f6f3;
    border-radius: 8px;
    padding: 10px 14px;
}
.delib-info-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}
.delib-info-value {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #333;
}
.delib-scores-chart {
    margin-bottom: 16px;
}
.delib-scores-title {
    font-size: 13px;
    font-weight: 700;
    color: #666;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}
.delib-score-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
    padding: 6px 0;
}
.delib-score-row.chairman {
    background: #faf8f2;
    border-radius: 6px;
    padding: 6px 10px;
    margin-left: -10px;
    margin-right: -10px;
}
.delib-score-name {
    font-size: 13px;
    font-weight: 600;
    color: #333;
    min-width: 100px;
}
.delib-score-row.chairman .delib-score-name {
    color: #8b7355;
}
.delib-score-bar-wrap {
    flex: 1;
    height: 8px;
    background: #eee;
    border-radius: 4px;
    overflow: hidden;
}
.delib-score-bar {
    height: 100%;
    background: linear-gradient(90deg, #d4af37, #daa520);
    border-radius: 4px;
    transition: width 0.8s ease;
}
.delib-score-value {
    font-size: 12px;
    font-weight: 700;
    color: #666;
    min-width: 50px;
    text-align: right;
}
.delib-results-footer {
    font-size: 12px;
    color: #999;
    line-height: 1.5;
    padding-top: 12px;
    border-top: 1px solid #eee;
    font-style: italic;
}

/* Exhausted State */
.demo-exhausted {
    padding: 32px;
    text-align: center;
}
.demo-exhausted-inner {
    max-width: 400px;
    margin: 0 auto;
}
.demo-exhausted h3 {
    font-size: 20px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 12px 0 8px;
}
.demo-exhausted p {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 20px;
}
.demo-exhausted-btns {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}


/* ============================================
   IMAGE STUDIO DEMO
   ============================================ */

.image-panel {
    margin-top: 0;
}
.image-demo-content {
    padding: 24px;
}
.image-demo-desc {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 20px;
    line-height: 1.6;
}
.image-prompt-area {
    margin-bottom: 24px;
}
.image-prompt-area label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
}
.image-prompt-area textarea {
    width: 100%;
    background: var(--bg-secondary);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 14px 16px;
    font-size: 14px;
    color: var(--text-primary);
    font-family: 'Inter', sans-serif;
    resize: vertical;
    outline: none;
    transition: border-color 0.2s ease;
}
.image-prompt-area textarea:focus {
    border-color: var(--gold);
}
.image-prompt-actions {
    display: flex;
    gap: 12px;
    margin-top: 12px;
    flex-wrap: wrap;
}
.image-prompt-actions button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
}
.image-prompt-actions button:first-child {
    background: var(--gold);
    color: #1A1611;
}
.image-prompt-actions button:first-child:hover {
    background: var(--gold-light);
}
.image-prompt-actions button:first-child:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
.image-prompt-actions button.secondary {
    background: var(--bg-secondary);
    border: 1px solid var(--border-card);
    color: var(--text-secondary);
}
.image-prompt-actions button.secondary:hover {
    border-color: var(--gold);
    color: var(--gold);
}

/* Image Result */
.image-result {
    margin-top: 24px;
}
.image-result-display {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-card);
    background: var(--bg-secondary);
}
.image-result-display img {
    width: 100%;
    display: block;
}
.image-result-actions {
    display: flex;
    gap: 12px;
    margin-top: 16px;
    justify-content: center;
}
.image-result-actions button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: 10px;
    border: 1px solid var(--border-card);
    background: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}
.image-result-actions button:hover {
    border-color: var(--gold);
    color: var(--gold);
}

/* Image Loading */
.image-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--text-secondary);
    font-size: 14px;
}


/* ============================================
   POST-DEMO CTA
   ============================================ */

.demo-cta-section {
    text-align: center;
}
.demo-cta-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 32px;
    margin-bottom: 32px;
}
.demo-cta-card {
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 16px;
    padding: 32px 24px;
    text-align: center;
    transition: all 0.3s ease;
    display: block;
}
.demo-cta-card:hover {
    border-color: rgba(212, 175, 55, 0.3);
    transform: translateY(-4px);
    background: var(--bg-card-hover);
}
.demo-cta-card.featured {
    border-color: var(--gold);
    background: var(--gold-glow);
}
.demo-cta-card.featured:hover {
    background: rgba(212, 175, 55, 0.2);
}
.demo-cta-icon {
    font-size: 32px;
    color: var(--gold);
    margin-bottom: 16px;
}
.demo-cta-card h3 {
    font-size: 18px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 8px;
}
.demo-cta-card p {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 16px;
}
.demo-cta-link {
    font-size: 13px;
    font-weight: 700;
    color: var(--gold);
}
.demo-cta-privacy {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.7;
    max-width: 600px;
    margin: 0 auto;
    padding: 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 12px;
}

/* Learn More Grid */
.learn-more-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-top: 32px;
}
.learn-more-card {
    background: var(--bg-card);
    border: 1px solid var(--border-card);
    border-radius: 12px;
    padding: 24px 20px;
    text-align: center;
    transition: all 0.3s ease;
    display: block;
}
.learn-more-card:hover {
    border-color: rgba(212, 175, 55, 0.3);
    transform: translateY(-2px);
}
.learn-more-card i {
    font-size: 24px;
    color: var(--gold);
    margin-bottom: 12px;
}
.learn-more-card h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 6px;
}
.learn-more-card p {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.5;
}

/* Toast */
.demo-toast {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: var(--bg-card);
    border: 1px solid var(--gold);
    color: var(--gold);
    padding: 10px 24px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    z-index: 9999;
    opacity: 0;
    transition: all 0.3s ease;
    pointer-events: none;
}
.demo-toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}


/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 1024px) {
    .wt-council-grid { grid-template-columns: repeat(2, 1fr); }
    .wt-save-options { grid-template-columns: repeat(3, 1fr); }
    .demo-cta-cards { grid-template-columns: 1fr; }
    .learn-more-grid { grid-template-columns: repeat(2, 1fr); }
    .delib-models-grid { margin-left: 0; margin-top: 8px; }
    .delib-step { flex-wrap: wrap; }
}

@media (max-width: 768px) {
    .demo-hero .inner { padding: 40px 20px; }
    .demo-hero h1 { font-size: 32px; }
    .wt-screen { padding: 20px; }
    .wt-slide h3 { font-size: 20px; }
    .wt-council-grid { grid-template-columns: 1fr 1fr; }
    .wt-review-row { flex-direction: column; align-items: flex-start; gap: 8px; }
    .wt-reviewer { min-width: auto; }
    .wt-save-options { grid-template-columns: 1fr; }
    .wt-nav { padding: 12px 20px; }
    .demo-prompts { padding: 16px; }
    .demo-input-area { flex-direction: column; }
    .demo-input-area textarea { width: 100%; }
    #demoSendBtn { width: 100%; justify-content: center; }
    .demo-answer-actions { flex-direction: column; }
    .demo-action-btn { justify-content: center; }
    .image-prompt-actions { flex-direction: column; }
    .image-prompt-actions button { justify-content: center; }
    .learn-more-grid { grid-template-columns: 1fr; }
    .wt-score-model { min-width: 100px; }
    .demo-cta-cards { grid-template-columns: 1fr; }
    .showcase-hero-buttons { flex-direction: column; align-items: center; }
}

@media (max-width: 480px) {
    .wt-step-indicators { gap: 4px; }
    .wt-step-dot { width: 28px; height: 28px; font-size: 11px; }
    .wt-council-grid { grid-template-columns: 1fr; }
    .demo-prompt-chips { flex-direction: column; }
    .demo-chip { justify-content: center; }
}
