/**
 * Dark/Light Theme Styles
 * Professional dark mode implementation with smooth transitions
 */

/* ===================================
   CORE THEME VARIABLES
   =================================== */

/* Theme transition for smooth dark/light mode switching */
:root,
body,
.sidebar,
.card,
.modal-content,
.table,
.form-control,
.form-select,
.btn {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

/* ===================================
   DARK MODE - BASE CONFIGURATION
   =================================== */

/* Dark mode specific styles */
[data-bs-theme="dark"] {
    --bs-body-bg: #1a1d23;
    --bs-body-color: #e9ecef;
    --bs-border-color: #3a3f47;
}

[data-bs-theme="dark"] .sidebar {
    background-color: #212529 !important;
    border-right: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .card {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .table {
    --bs-table-bg: #2b3035;
    --bs-table-striped-bg: #252a2e;
    --bs-table-hover-bg: #2e3338;
    --bs-table-border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    background-color: #2b3035;
    border-color: #0d6efd;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .form-control::placeholder {
    color: #6c757d;
}

[data-bs-theme="dark"] .modal-content {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .modal-header {
    border-bottom-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .modal-footer {
    border-top-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .breadcrumb {
    background-color: #2b3035;
}

[data-bs-theme="dark"] .badge {
    filter: brightness(1.2);
}

[data-bs-theme="dark"] .card:hover {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5) !important;
}

[data-bs-theme="dark"] .modern-breadcrumb {
    background: linear-gradient(to right, #2b3035 0%, #1a1d23 100%);
}

[data-bs-theme="dark"] .list-group-item {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .list-group-item:hover {
    background-color: #2e3338;
}

[data-bs-theme="dark"] hr {
    border-color: var(--bs-border-color);
    opacity: 0.3;
}

[data-bs-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

[data-bs-theme="dark"] code {
    background-color: #1a1d23;
    color: #f8f9fa;
}

[data-bs-theme="dark"] pre {
    background-color: #1a1d23;
    border-color: var(--bs-border-color);
}

/* Override hardcoded bg-white in dark mode */
[data-bs-theme="dark"] .bg-white {
    background-color: #2b3035 !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .bg-light {
    background-color: #2b3035 !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .table-light {
    --bs-table-bg: #252a2e;
    --bs-table-color: var(--bs-body-color);
}

[data-bs-theme="dark"] .card-header.bg-primary,
[data-bs-theme="dark"] .card-header.bg-success,
[data-bs-theme="dark"] .card-header.bg-dark,
[data-bs-theme="dark"] .card-header.bg-info {
    filter: brightness(0.85);
}

[data-bs-theme="dark"] .border,
[data-bs-theme="dark"] .border-bottom {
    border-color: var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .text-dark {
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .text-muted {
    color: #adb5bd !important;
}

[data-bs-theme="dark"] input[type="text"],
[data-bs-theme="dark"] input[type="email"],
[data-bs-theme="dark"] input[type="password"],
[data-bs-theme="dark"] input[type="number"],
[data-bs-theme="dark"] textarea,
[data-bs-theme="dark"] select {
    background-color: #2b3035 !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .dropdown-menu {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .dropdown-item {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .dropdown-item:hover {
    background-color: #2e3338;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .alert {
    filter: brightness(0.9);
}

/* Light mode enhancements */
[data-bs-theme="light"] .modern-breadcrumb {
    background: linear-gradient(to right, #f8f9fa 0%, #ffffff 100%);
}

[data-bs-theme="light"] .sidebar {
    background-color: #212529 !important;
}

/* Dashboard cards dark mode */
[data-bs-theme="dark"] .card.border-0 {
    background-color: #2b3035;
    border-color: transparent !important;
}

[data-bs-theme="dark"] .shadow-sm {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.5) !important;
}

[data-bs-theme="dark"] .shadow {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5) !important;
}

/* Navbar and top elements */
[data-bs-theme="dark"] .navbar {
    background-color: #2b3035 !important;
    border-bottom: 1px solid var(--bs-border-color);
}

/* Server list specific dark mode */
[data-bs-theme="dark"] .server-card,
[data-bs-theme="dark"] .service-card {
    background-color: #2b3035 !important;
    border-color: var(--bs-border-color) !important;
}

/* Pagination dark mode */
[data-bs-theme="dark"] .pagination .page-link {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .pagination .page-link:hover {
    background-color: #2e3338;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .pagination .page-item.active .page-link {
    background-color: #0d6efd;
    border-color: #0d6efd;
}

/* Icon backgrounds */
[data-bs-theme="dark"] .icon-shape {
    background-color: rgba(13, 110, 253, 0.1) !important;
}

/* Fix for specific gradient backgrounds */
[data-bs-theme="dark"] .gradient-primary {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
}

/* Ensure all text inputs respect dark mode */
[data-bs-theme="dark"] input:not([type="checkbox"]):not([type="radio"]),
[data-bs-theme="dark"] textarea,
[data-bs-theme="dark"] select {
    background-color: #2b3035 !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] input:disabled,
[data-bs-theme="dark"] textarea:disabled,
[data-bs-theme="dark"] select:disabled {
    background-color: #1a1d23 !important;
    opacity: 0.6;
}

/* Stats cards icons */
[data-bs-theme="dark"] .stat-icon {
    opacity: 0.9;
}

/* Search inputs and filters */
[data-bs-theme="dark"] .input-group-text {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

/* Tabs dark mode */
[data-bs-theme="dark"] .nav-tabs {
    border-bottom-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .nav-tabs .nav-link {
    color: var(--bs-body-color);
    border-color: transparent;
}

[data-bs-theme="dark"] .nav-tabs .nav-link:hover {
    border-color: var(--bs-border-color);
    background-color: #2e3338;
}

[data-bs-theme="dark"] .nav-tabs .nav-link.active {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    border-bottom-color: transparent;
    color: var(--bs-body-color);
}

/* Offcanvas dark mode */
[data-bs-theme="dark"] .offcanvas {
    background-color: #2b3035;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .offcanvas-header {
    border-bottom-color: var(--bs-border-color);
}

/* Accordion dark mode */
[data-bs-theme="dark"] .accordion-item {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .accordion-button {
    background-color: #2b3035;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .accordion-button:not(.collapsed) {
    background-color: #2e3338;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .accordion-button::after {
    filter: invert(1);
}

/* Progress bars dark mode */
[data-bs-theme="dark"] .progress {
    background-color: #1a1d23;
}

/* Toast notifications dark mode */
[data-bs-theme="dark"] .toast {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .toast-header {
    background-color: #252a2e;
    border-bottom-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

/* Popovers and tooltips */
[data-bs-theme="dark"] .popover {
    background-color: #2b3035;
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .popover-header {
    background-color: #252a2e;
    border-bottom-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .popover-body {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .tooltip-inner {
    background-color: #1a1d23;
}

/* Custom scrollbar dark mode */
[data-bs-theme="dark"] ::-webkit-scrollbar-track {
    background: #1a1d23;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb {
    background: #495057;
}

[data-bs-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: #6c757d;
}

/* Server status badges consistency */
[data-bs-theme="dark"] .badge.bg-success,
[data-bs-theme="dark"] .badge.bg-danger,
[data-bs-theme="dark"] .badge.bg-warning,
[data-bs-theme="dark"] .badge.bg-info,
[data-bs-theme="dark"] .badge.bg-primary,
[data-bs-theme="dark"] .badge.bg-secondary {
    filter: brightness(1.1);
}

/* ===================================
   TERMINAL & CODE BLOCKS - RESPONSIVE THEME
   =================================== */

/* Terminal output area */
.terminal-container {
    height: 500px;
    border-radius: 4px;
}

[data-bs-theme="light"] .terminal-container {
    background: #f8f9fa;
    border: 1px solid #dee2e6;
}

[data-bs-theme="dark"] .terminal-container {
    background: #1e1e1e;
    border: 1px solid var(--bs-border-color);
}

.terminal-output {
    height: 500px;
    overflow-y: auto;
    padding: 1rem;
    font-family: 'Courier New', Monaco, monospace;
    font-size: 14px;
    line-height: 1.5;
}

[data-bs-theme="light"] .terminal-output {
    color: #212529;
    background: #ffffff;
}

[data-bs-theme="dark"] .terminal-output {
    color: #d4d4d4;
    background: #1e1e1e;
}

/* Log viewer areas */
.log-viewer {
    max-height: 600px;
    overflow-y: auto;
    padding: 1.25rem;
    border-radius: 4px;
    font-family: 'Courier New', Monaco, monospace;
    font-size: 0.85rem;
}

[data-bs-theme="light"] .log-viewer {
    background-color: #f8f9fa;
    color: #212529;
    border: 1px solid #dee2e6;
}

[data-bs-theme="dark"] .log-viewer {
    background-color: #1e1e1e;
    color: #d4d4d4;
    border: 1px solid var(--bs-border-color);
}

.log-viewer pre {
    margin: 0;
    white-space: pre-wrap;
    word-wrap: break-word;
    color: inherit;
}

/* Code block containers */
.code-container {
    border-radius: 4px;
    padding: 1.25rem;
    max-height: 500px;
    overflow-y: auto;
    font-family: 'Courier New', Monaco, monospace;
}

[data-bs-theme="light"] .code-container {
    background: #f8f9fa;
    color: #212529;
    border: 1px solid #dee2e6;
}

[data-bs-theme="dark"] .code-container {
    background: #1e1e1e;
    color: #d4d4d4;
    border: 1px solid var(--bs-border-color);
}

.code-container pre {
    margin: 0;
    color: inherit;
}

/* Ansible output specific */
.ansible-output {
    background-color: #1e1e1e;
    color: #d4d4d4;
    padding: 1.25rem;
    font-family: 'Courier New', Monaco, monospace;
    font-size: 13px;
    max-height: 600px;
    overflow-y: auto;
    border-radius: 4px;
}

[data-bs-theme="light"] .ansible-output {
    background-color: #f8f9fa;
    color: #212529;
    border: 1px solid #dee2e6;
}

[data-bs-theme="dark"] .ansible-output {
    background-color: #1e1e1e;
    color: #d4d4d4;
    border: 1px solid var(--bs-border-color);
}

.ansible-output pre {
    margin: 0;
    color: inherit;
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* Inline code styling */
code {
    padding: 0.2rem 0.4rem;
    border-radius: 0.25rem;
}

[data-bs-theme="light"] code {
    background-color: #f8f9fa;
    color: #212529;
}

[data-bs-theme="dark"] code {
    background-color: #1a1d23;
    color: #d4d4d4;
}

/* Theme toggle button animation */
#themeToggle {
    position: relative;
    overflow: hidden;
}

#themeToggle i {
    transition: transform 0.3s ease;
}

#themeToggle:hover i {
    transform: rotate(20deg);
}

/* Prevent flash of unstyled content */
html:not([data-bs-theme]) {
    visibility: hidden;
}

html[data-bs-theme] {
    visibility: visible;
}
