/* ============================================
   Glassmorphism Theme - KickStreamerServer
   Modern glass UI with MudBlazor integration
   ============================================ */

:root {
    --header-height: 60px;
    --chat-stream-width: 50%;

    /* Glassmorphism - Dark Mode */
    --glass-bg-dark: rgba(30, 30, 46, 0.6);
    --glass-bg-dark-solid: rgba(30, 30, 46, 0.85);
    --glass-border-dark: rgba(255, 255, 255, 0.08);
    --glass-border-dark-hover: rgba(255, 255, 255, 0.15);

    /* Glassmorphism - Light Mode */
    --glass-bg-light: rgba(255, 255, 255, 0.7);
    --glass-bg-light-solid: rgba(255, 255, 255, 0.9);
    --glass-border-light: rgba(0, 0, 0, 0.08);
    --glass-border-light-hover: rgba(0, 0, 0, 0.15);

    /* Blur Effects */
    --glass-blur: blur(20px);
    --glass-blur-light: blur(12px);

    /* Shadows */
    --shadow-sm: 0 4px 15px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 8px 30px rgba(0, 0, 0, 0.15);
    --shadow-lg: 0 15px 50px rgba(0, 0, 0, 0.2);
    --shadow-glow: 0 0 40px rgba(var(--mud-palette-primary-rgb), 0.2);

    /* Transitions */
    --transition-fast: 0.15s ease;
    --transition-normal: 0.25s ease;
    --transition-smooth: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ============================================
   Base Styles
   ============================================ */

html, body {
    font-family: 'Inter', 'Segoe UI', 'Roboto', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Custom scrollbar - Dark theme */
.mud-theme-dark ::-webkit-scrollbar,
.mud-theme-dark::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.mud-theme-dark ::-webkit-scrollbar-track,
.mud-theme-dark::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.02);
}

.mud-theme-dark ::-webkit-scrollbar-thumb,
.mud-theme-dark::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
}

.mud-theme-dark ::-webkit-scrollbar-thumb:hover,
.mud-theme-dark::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.18);
}

/* Custom scrollbar - Light theme */
.mud-theme-light ::-webkit-scrollbar,
.mud-theme-light::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.mud-theme-light ::-webkit-scrollbar-track,
.mud-theme-light::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.02);
}

.mud-theme-light ::-webkit-scrollbar-thumb,
.mud-theme-light::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.12);
    border-radius: 4px;
}

.mud-theme-light ::-webkit-scrollbar-thumb:hover,
.mud-theme-light::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.2);
}

/* Selection highlighting */
::selection {
    background: rgba(var(--mud-palette-primary-rgb), 0.25);
}

/* ============================================
   MudBlazor Glassmorphism Overrides - Dark
   ============================================ */

/* Paper/Card - Dark */
.mud-theme-dark .mud-paper {
    background: var(--glass-bg-dark) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-dark) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-normal);
}

.mud-theme-dark .mud-paper:hover {
    border-color: var(--glass-border-dark-hover) !important;
}

/* Elevated paper gets subtle glow */
.mud-theme-dark .mud-paper.mud-elevation-1,
.mud-theme-dark .mud-paper.mud-elevation-2,
.mud-theme-dark .mud-paper.mud-elevation-3,
.mud-theme-dark .mud-paper.mud-elevation-4 {
    box-shadow: var(--shadow-sm), 0 0 30px rgba(0, 0, 0, 0.3);
}

/* Dialog - Dark */
.mud-theme-dark .mud-dialog {
    background: var(--glass-bg-dark-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-dark) !important;
    border-radius: 16px !important;
    box-shadow: var(--shadow-lg), 0 0 60px rgba(0, 0, 0, 0.4);
}

/* Drawer - Dark */
.mud-theme-dark .mud-drawer {
    background: var(--glass-bg-dark-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border-right: 1px solid var(--glass-border-dark) !important;
}

/* AppBar - Dark */
.mud-theme-dark .mud-appbar {
    background: var(--glass-bg-dark-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border-bottom: 1px solid var(--glass-border-dark) !important;
}

/* Menu/Popover - Dark */
.mud-theme-dark .mud-popover-paper {
    background: var(--glass-bg-dark-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-dark) !important;
    border-radius: 12px !important;
    box-shadow: var(--shadow-md);
}

/* Snackbar - Dark */
.mud-theme-dark .mud-snackbar {
    backdrop-filter: var(--glass-blur-light) !important;
    -webkit-backdrop-filter: var(--glass-blur-light) !important;
    border: 1px solid var(--glass-border-dark) !important;
    border-radius: 12px !important;
}

/* Chip - Dark */
.mud-theme-dark .mud-chip {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid var(--glass-border-dark);
}

/* Table - Dark */
.mud-theme-dark .mud-table {
    background: var(--glass-bg-dark) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-dark) !important;
    border-radius: 12px !important;
    overflow: hidden;
}

.mud-theme-dark .mud-table-row:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}

/* Tabs - Dark */
.mud-theme-dark .mud-tabs {
    background: transparent !important;
}

.mud-theme-dark .mud-tabs-panels {
    background: var(--glass-bg-dark) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-dark) !important;
    border-radius: 12px !important;
}

/* ============================================
   MudBlazor Glassmorphism Overrides - Light
   ============================================ */

/* Paper/Card - Light */
.mud-theme-light .mud-paper {
    background: var(--glass-bg-light) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-light) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-normal);
}

.mud-theme-light .mud-paper:hover {
    border-color: var(--glass-border-light-hover) !important;
}

/* Elevated paper - Light */
.mud-theme-light .mud-paper.mud-elevation-1,
.mud-theme-light .mud-paper.mud-elevation-2,
.mud-theme-light .mud-paper.mud-elevation-3,
.mud-theme-light .mud-paper.mud-elevation-4 {
    box-shadow: var(--shadow-sm);
}

/* Dialog - Light */
.mud-theme-light .mud-dialog {
    background: var(--glass-bg-light-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-light) !important;
    border-radius: 16px !important;
    box-shadow: var(--shadow-lg);
}

/* Drawer - Light */
.mud-theme-light .mud-drawer {
    background: var(--glass-bg-light-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border-right: 1px solid var(--glass-border-light) !important;
}

/* AppBar - Light */
.mud-theme-light .mud-appbar {
    background: var(--glass-bg-light-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border-bottom: 1px solid var(--glass-border-light) !important;
}

/* Menu/Popover - Light */
.mud-theme-light .mud-popover-paper {
    background: var(--glass-bg-light-solid) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-light) !important;
    border-radius: 12px !important;
    box-shadow: var(--shadow-md);
}

/* Snackbar - Light */
.mud-theme-light .mud-snackbar {
    backdrop-filter: var(--glass-blur-light) !important;
    -webkit-backdrop-filter: var(--glass-blur-light) !important;
    border: 1px solid var(--glass-border-light) !important;
    border-radius: 12px !important;
}

/* Chip - Light */
.mud-theme-light .mud-chip {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid var(--glass-border-light);
}

/* Table - Light */
.mud-theme-light .mud-table {
    background: var(--glass-bg-light) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-light) !important;
    border-radius: 12px !important;
    overflow: hidden;
}

.mud-theme-light .mud-table-row:hover {
    background: rgba(0, 0, 0, 0.02) !important;
}

/* Tabs - Light */
.mud-theme-light .mud-tabs-panels {
    background: var(--glass-bg-light) !important;
    backdrop-filter: var(--glass-blur) !important;
    -webkit-backdrop-filter: var(--glass-blur) !important;
    border: 1px solid var(--glass-border-light) !important;
    border-radius: 12px !important;
}

/* ============================================
   Input Fields Enhancement
   ============================================ */

/* Dark theme inputs */
.mud-theme-dark .mud-input-control .mud-input-outlined-border {
    border-color: var(--glass-border-dark) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.mud-theme-dark .mud-input-control:hover .mud-input-outlined-border {
    border-color: var(--glass-border-dark-hover) !important;
}

.mud-theme-dark .mud-input-control.mud-input-control-focused .mud-input-outlined-border {
    box-shadow: 0 0 0 1px var(--mud-palette-primary), 0 0 20px rgba(var(--mud-palette-primary-rgb), 0.15);
}

/* Light theme inputs */
.mud-theme-light .mud-input-control .mud-input-outlined-border {
    border-color: var(--glass-border-light) !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.mud-theme-light .mud-input-control:hover .mud-input-outlined-border {
    border-color: var(--glass-border-light-hover) !important;
}

.mud-theme-light .mud-input-control.mud-input-control-focused .mud-input-outlined-border {
    box-shadow: 0 0 0 1px var(--mud-palette-primary), 0 0 15px rgba(var(--mud-palette-primary-rgb), 0.1);
}

/* ============================================
   Button Enhancements
   ============================================ */

/* Filled buttons - subtle glow on hover */
.mud-button-filled:hover {
    box-shadow: 0 4px 15px rgba(var(--mud-palette-primary-rgb), 0.3);
    transform: translateY(-1px);
}

.mud-button-filled:active {
    transform: translateY(0);
}

/* Outlined buttons - glass effect */
.mud-theme-dark .mud-button-outlined {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-dark-hover) !important;
}

.mud-theme-light .mud-button-outlined {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-color: var(--glass-border-light-hover) !important;
}

/* ============================================
   Utility Classes
   ============================================ */

/* Glassmorphic card */
.glass-card {
    background: var(--glass-bg-dark);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border-dark);
    border-radius: 16px;
    transition: all var(--transition-normal);
}

.mud-theme-light .glass-card {
    background: var(--glass-bg-light);
    border-color: var(--glass-border-light);
}

.glass-card:hover {
    border-color: var(--glass-border-dark-hover);
    box-shadow: var(--shadow-md);
}

.mud-theme-light .glass-card:hover {
    border-color: var(--glass-border-light-hover);
}

/* Glow effect on primary color */
.glow-primary {
    box-shadow: 0 0 40px rgba(var(--mud-palette-primary-rgb), 0.25);
}

/* Gradient text using theme primary */
.gradient-text {
    background: linear-gradient(135deg, var(--mud-palette-primary), var(--mud-palette-secondary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ============================================
   Content & Layout
   ============================================ */

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

/* Fix MudBlazor popover positioning on scroll */
.mud-popover-cascading-value {
    position: fixed;
}

/* ============================================
   Form Validation
   ============================================ */

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--mud-palette-success);
    box-shadow: 0 0 10px rgba(var(--mud-palette-success-rgb), 0.15);
}

.invalid {
    outline: 1px solid var(--mud-palette-error);
    box-shadow: 0 0 10px rgba(var(--mud-palette-error-rgb), 0.15);
}

.validation-message {
    color: var(--mud-palette-error);
}

/* ============================================
   Error Boundary
   ============================================ */

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
    border-radius: 12px;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

/* ============================================
   Form Elements
   ============================================ */

.darker-border-checkbox.form-check-input {
    border-color: rgba(128, 128, 128, 0.5);
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* ============================================
   Accessibility
   ============================================ */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus visible for keyboard navigation */
:focus-visible {
    outline: 2px solid var(--mud-palette-primary);
    outline-offset: 2px;
}

/* High contrast mode - disable glass effects */
@media (prefers-contrast: high) {
    .mud-paper,
    .mud-dialog,
    .mud-drawer,
    .mud-appbar,
    .mud-popover-paper {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    .mud-theme-dark .mud-paper {
        background: rgba(30, 30, 46, 0.95) !important;
        border-color: rgba(255, 255, 255, 0.3) !important;
    }

    .mud-theme-light .mud-paper {
        background: rgba(255, 255, 255, 0.95) !important;
        border-color: rgba(0, 0, 0, 0.3) !important;
    }
}

/* ============================================
   Animation Utilities
   ============================================ */

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes pulse-glow {
    0%, 100% { box-shadow: 0 0 20px rgba(var(--mud-palette-primary-rgb), 0.2); }
    50% { box-shadow: 0 0 40px rgba(var(--mud-palette-primary-rgb), 0.4); }
}

.animate-fade-in {
    animation: fadeIn 0.3s ease-out;
}

.animate-pulse-glow {
    animation: pulse-glow 2s ease-in-out infinite;
}
