/**
 * Prompt Builder - Theme Styles
 * Handles dark mode and theme variations
 */

/* Light Theme (Default) */
.light-theme {
    --bg-primary: #ffffff;
    --bg-secondary: #f8f9fa;
    --bg-tertiary: #e9ecef;
    --text-primary: #212529;
    --text-secondary: #495057;
    --text-muted: #6c757d;
    --border-color: #dee2e6;
    --shadow-color: rgba(0, 0, 0, 0.15);
    --input-bg: #ffffff;
    --input-border: #ced4da;
    --input-text: #212529;
    --card-bg: #ffffff;
    --toast-bg: #ffffff;
    --toast-border: #dee2e6;
    --modal-bg: #ffffff;
    --modal-border: #dee2e6;
}

/* Dark Theme */
.dark-theme {
    --bg-primary: #212529;
    --bg-secondary: #343a40;
    --bg-tertiary: #495057;
    --text-primary: #f8f9fa;
    --text-secondary: #e9ecef;
    --text-muted: #adb5bd;
    --border-color: #495057;
    --shadow-color: rgba(0, 0, 0, 0.3);
    --input-bg: #343a40;
    --input-border: #495057;
    --input-text: #f8f9fa;
    --card-bg: #343a40;
    --toast-bg: #343a40;
    --toast-border: #495057;
    --modal-bg: #343a40;
    --modal-border: #495057;
}

/* Apply Theme Variables */
body {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
}

.app-header {
    background-color: var(--bg-primary);
    box-shadow: 0 2px 4px var(--shadow-color);
}

.app-footer {
    background-color: var(--bg-primary);
    border-top: 1px solid var(--border-color);
}

.app-footer p {
    color: var(--text-muted);
}

.form-container {
    background-color: var(--bg-primary);
    box-shadow: 0 0.5rem 1rem var(--shadow-color);
}

.section-header {
    border-bottom: 1px solid var(--border-color);
}

.section-header h2 {
    color: var(--primary-color);
}

.section-header p {
    color: var(--text-muted);
}

.section-footer {
    border-top: 1px solid var(--border-color);
}

.tech-category h3 {
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.tech-option label {
    background-color: var(--bg-secondary);
}

.tech-option label:hover {
    background-color: var(--bg-tertiary);
}

.tech-option input[type="checkbox"]:checked + label {
    background-color: rgba(67, 97, 238, 0.1);
    border-color: var(--primary-color);
}

.tech-option label i {
    color: var(--text-secondary);
}

.tech-option label span {
    color: var(--text-secondary);
}

.complexity-slider-container {
    background-color: var(--bg-secondary);
}

.complexity-description {
    background-color: var(--bg-primary);
    box-shadow: 0 2px 4px var(--shadow-color);
}

.complexity-description p {
    color: var(--text-secondary);
}

.features-list-container,
.suggestions-container,
.instructions-container,
.advanced-options-container {
    background-color: var(--bg-secondary);
}

.feature-item,
.suggestion-item {
    background-color: var(--bg-primary);
    box-shadow: 0 2px 4px var(--shadow-color);
}

.feature-input {
    background-color: transparent;
    color: var(--text-primary);
}

.feature-actions button {
    color: var(--text-muted);
}

.feature-actions button:hover {
    color: var(--text-secondary);
}

.suggestion-item:hover {
    background-color: rgba(67, 97, 238, 0.1);
}

.empty-state {
    color: var(--text-muted);
}

#special-instructions {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--input-border);
}

.advanced-option-group h3 {
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}

.advanced-option label {
    color: var(--text-secondary);
}

.sidebar-section {
    background-color: var(--bg-primary);
    box-shadow: 0 0.5rem 1rem var(--shadow-color);
}

.sidebar-section h3 {
    color: var(--primary-color);
}

.list-group-item {
    background-color: var(--bg-primary);
    border-color: var(--border-color);
}

.prompt-name {
    color: var(--text-secondary);
}

.output-container {
    background-color: var(--bg-primary);
    box-shadow: 0 0.5rem 1rem var(--shadow-color);
}

.output-header {
    border-bottom: 1px solid var(--border-color);
}

.output-header h2 {
    color: var(--primary-color);
}

.output-content {
    background-color: var(--bg-secondary);
}

.output-text {
    color: var(--text-primary);
}

.output-footer {
    border-top: 1px solid var(--border-color);
}

.modal-content {
    background-color: var(--modal-bg);
    border-color: var(--modal-border);
}

.modal-header {
    border-bottom: 1px solid var(--border-color);
}

.modal-footer {
    border-top: 1px solid var(--border-color);
}

.toast {
    background-color: var(--toast-bg);
    border-color: var(--toast-border);
}

.toast-header {
    background-color: transparent;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.toast-body {
    color: var(--text-primary);
}

/* Form Controls */
.form-control,
.form-select {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--input-border);
}

.form-control:focus,
.form-select:focus {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.25rem rgba(67, 97, 238, 0.25);
}

/* Button Styles */
.btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-primary:hover {
    background-color: #3a56d4;
    border-color: #3a56d4;
}

.btn-secondary {
    background-color: var(--gray-600);
    border-color: var(--gray-600);
}

.btn-secondary:hover {
    background-color: var(--gray-700);
    border-color: var(--gray-700);
}

.btn-success {
    background-color: var(--success-color);
    border-color: var(--success-color);
}

.btn-success:hover {
    background-color: #3d8b40;
    border-color: #3d8b40;
}

.btn-danger {
    background-color: var(--danger-color);
    border-color: var(--danger-color);
}

.btn-danger:hover {
    background-color: #d32f2f;
    border-color: #d32f2f;
}

.btn-outline-primary {
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-outline-primary:hover {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.btn-outline-secondary {
    color: var(--text-secondary);
    border-color: var(--border-color);
}

.btn-outline-secondary:hover {
    background-color: var(--bg-tertiary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

.dark-theme .btn-outline-secondary {
    color: var(--text-secondary);
    border-color: var(--border-color);
}

.dark-theme .btn-outline-secondary:hover {
    background-color: var(--bg-tertiary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

/* Theme Toggle Button */
#theme-toggle-btn .fa-sun {
    color: #ff9800;
}

#theme-toggle-btn .fa-moon {
    color: #3a0ca3;
}

.dark-theme #theme-toggle-btn .fa-sun {
    color: #ff9800;
}

.dark-theme #theme-toggle-btn .fa-moon {
    color: #7b68ee;
}

/* Custom Theme Colors */
.theme-blue {
    --primary-color: #4361ee;
    --secondary-color: #3a0ca3;
}

.theme-green {
    --primary-color: #2e7d32;
    --secondary-color: #1b5e20;
}

.theme-purple {
    --primary-color: #7b1fa2;
    --secondary-color: #4a148c;
}

.theme-orange {
    --primary-color: #e65100;
    --secondary-color: #bf360c;
}

.theme-red {
    --primary-color: #c62828;
    --secondary-color: #b71c1c;
}

/* Accessibility Improvements */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

.high-contrast {
    --primary-color: #0000ff;
    --secondary-color: #6a0dad;
    --success-color: #008000;
    --danger-color: #ff0000;
    --warning-color: #ff8c00;
    --info-color: #0000ff;
    --text-primary: #000000;
    --text-secondary: #000000;
    --text-muted: #000000;
    --border-color: #000000;
}

.high-contrast.dark-theme {
    --primary-color: #00ffff;
    --secondary-color: #ff00ff;
    --success-color: #00ff00;
    --danger-color: #ff0000;
    --warning-color: #ffff00;
    --info-color: #00ffff;
    --text-primary: #ffffff;
    --text-secondary: #ffffff;
    --text-muted: #ffffff;
    --border-color: #ffffff;
}
