/* Universal Prompt Builder - Custom Styles */

/* CSS Custom Properties for Brand Colors */
:root {
    --bs-primary: #5a54f0;
    --bs-link-color: #5a54f0;
    --bs-primary-rgb: 90, 84, 240;
    --bs-link-color-rgb: 90, 84, 240;
}

/* Dark theme adjustments */
[data-bs-theme="dark"] {
    --bs-primary: #6b66f0;
    --bs-link-color: #6b66f0;
    --bs-primary-rgb: 107, 102, 240;
    --bs-link-color-rgb: 107, 102, 240;
}

/* Base Styles */
body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.6;
}

/* Navbar Brand Styling */
.navbar-brand {
    color: var(--bs-primary) !important;
    font-size: 1.25rem;
}

.navbar-brand i {
    color: var(--bs-primary);
}

/* Form Styling */
.form-control:focus,
.form-select:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

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

.btn-primary:hover {
    background-color: #4a44d0;
    border-color: #4a44d0;
}

.btn-primary:focus {
    background-color: #4a44d0;
    border-color: #4a44d0;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.5);
}

/* Card Styling */
.card {
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.card-header {
    background-color: var(--bs-body-tertiary);
    border-bottom: 1px solid var(--bs-border-color);
}

/* Result Section Animations */
#resultSection {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

#resultSection.show {
    opacity: 1;
    transform: translateY(0);
}

/* Pre-formatted Text Styling */
pre.form-control {
    font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
    font-size: 0.875rem;
    line-height: 1.5;
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-tertiary);
    color: var(--bs-body-color);
}

/* Character Count Styling */
#charCount {
    font-weight: 500;
}

#charCount.warning {
    color: var(--bs-warning);
}

#charCount.danger {
    color: var(--bs-danger);
}

/* Language Toggle Styling */
.btn-group .btn-check:checked + .btn {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: white;
}

/* Theme Toggle Styling */
#themeToggle {
    transition: all 0.2s ease;
}

#themeToggle:hover {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: white;
}

/* Toast Styling */
.toast {
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.toast-header {
    background-color: var(--bs-body-tertiary);
    border-bottom: 1px solid var(--bs-border-color);
}

/* Accordion Styling */
.accordion-button:not(.collapsed) {
    background-color: var(--bs-primary);
    color: white;
}
/* Popover Styling */
.popover-info {
    max-width: 320px;
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}
.popover-info .popover-header {
    background-color: var(--bs-body-tertiary);
    font-weight: 600;
}
.popover-info .popover-body {
    font-size: 0.9rem;
    line-height: 1.5;
}


.accordion-button:not(.collapsed)::after {
    filter: brightness(0) invert(1);
}

/* Footer Styling */
footer {
    margin-top: auto;
    border-top: 1px solid var(--bs-border-color);
}

/* Responsive Adjustments */
@media (max-width: 767.98px) {
    .container-md {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    
    .btn-group .btn {
        padding: 0.375rem 0.75rem;
        font-size: 0.875rem;
    }
    
    .navbar-brand {
        font-size: 1.1rem;
    }
    
    pre.form-control {
        font-size: 0.8rem;
    }
}

@media (max-width: 575.98px) {
    .navbar .d-flex {
        flex-direction: column;
        gap: 0.5rem;
    }
    
    .btn-group {
        align-self: flex-end;
    }
    
    #themeToggle {
        align-self: flex-end;
    }
}

/* Loading State */
.btn:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}

.spinner-border-sm {
    width: 1rem;
    height: 1rem;
}

/* Copy Button Hover Effect */
[data-clipboard-target] {
    transition: all 0.2s ease;
}

[data-clipboard-target]:hover {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: white;
}

/* Form Validation Styling */
.form-control:invalid {
    border-color: var(--bs-danger);
}

.form-control:valid {
    border-color: var(--bs-success);
}

/* Accessibility Improvements */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Focus Visible Improvements */
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible {
    outline: 2px solid var(--bs-primary);
    outline-offset: 2px;
}

/* Print Styles */
@media print {
    .navbar,
    footer,
    .btn,
    .toast-container {
        display: none !important;
    }
    
    .card {
        border: 1px solid #000 !important;
        box-shadow: none !important;
    }
    
    pre.form-control {
        border: 1px solid #000 !important;
        background-color: transparent !important;
    }
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    :root {
        --bs-primary: #0000ff;
        --bs-link-color: #0000ff;
    }
    
    [data-bs-theme="dark"] {
        --bs-primary: #00ffff;
        --bs-link-color: #00ffff;
    }
    
    .card {
        border: 2px solid currentColor;
    }
    
    .btn-primary {
        background-color: var(--bs-primary);
        border: 2px solid currentColor;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    #resultSection {
        transition: none;
    }
}
