/* Alpine.js cloak - hide elements until Alpine initializes */
/* actually useful?
[x-cloak] { display: none !important; }
*/

/* Root CSS variables for 50's retro-futurism theme */
:root {
    /* Light Theme - Retro Console Aesthetic */
    --bg-body: #DED9C9;                    /* Creamy Beige - Bakelite console casing */
    --bg-card: #E9E6D7;                    /* Off-White/Cream - Activity list modules */
    --bg-card-hover: #F2EFDE;              /* Lighter cream for hover */
    --bg-slot-header: #7CA69C;             /* Muted Teal - Upper panel accents */
    --bg-navbar: #7CA69C;                  /* Muted Teal - Navigation bar */
    --border-color: #A8946D;               /* Brushed Brass/Gold - All metallic edges */
    --text-primary: #5E4E41;               /* Dark Bronze/Brown - All labels */
    --text-secondary: #8B7960;             /* Lighter bronze for secondary text */
    --text-navbar: #5E4E41;                /* Dark Bronze on teal navbar */
    --text-navbar-muted: rgba(94, 78, 65, 0.65);
    --text-navbar-hover: rgba(94, 78, 65, 0.9);
    --status-joined-bg: rgba(106, 143, 106, 0.15);  /* Muted green tint */
    
    /* Semantic color overrides for retro feel */
    --bs-primary: #7755BB;                 /* Deep Purple - Main button & gauge light */
    --bs-primary-rgb: 119, 85, 187;
    --bs-success: #6A8F6A;                 /* Muted Green - Accent/Status buttons */
    --bs-success-rgb: 106, 143, 106;
    --bs-danger: #B04F4F;                  /* Muted Red for consistency */
    --bs-danger-rgb: 176, 79, 79;
    --bs-warning: #A8946D;                 /* Brass/Gold for warnings */
    --bs-warning-rgb: 168, 148, 109;
    --bs-info: #7CA69C;                    /* Muted Teal */
    --bs-info-rgb: 124, 166, 156;
    --bs-secondary: #8B7960;               /* Light bronze */
    --bs-secondary-rgb: 139, 121, 96;
    
    /* Active button states */
    --btn-primary-active-bg: #6644AA;      /* Darker purple for pressed state */
    --btn-success-active-bg: #4F6C4F;      /* Darker green */
    --btn-danger-active-bg: #8A3C3C;       /* Darker red */
}

/* Dark mode - Glowing Retro-Futurism */
[data-bs-theme="dark"] {
    --bg-body: #2A2E33;                    /* Deep Charcoal - Dark Bakelite */
    --bg-body2: #2f363d;                    
    --bg-card: #2A2E33;                    /* Dark Charcoal - Panel background */
    --bg-card-hover: #343840;              /* Slightly lighter on hover */
    --bg-slot-header: #1F3A4D;             /* Midnight Teal - Slot headers */
    --bg-navbar: #1F3A4D;                  /* Midnight Teal - Navigation */
    --border-color: #6E5B4A;               /* Dark Bronze - Trim & bezels */
    --text-primary: #FFAA55;               /* Warm Amber - All glowing text */
    --text-secondary: #CC8844;             /* Dimmer amber for secondary */
    --text-navbar: #FFAA55;                /* Warm Amber navigation text */
    --text-navbar-muted: rgba(255, 170, 85, 0.65);
    --text-navbar-hover: rgba(255, 170, 85, 0.95);
    --status-joined-bg: rgba(77, 94, 77, 0.25);  /* Deep olive tint */
    
    /* Semantic colors for dark theme glow */
    --bs-primary: #9977DD;                 /* Mercury Vapor Purple glow */
    --bs-primary-rgb: 153, 119, 221;
    --bs-success: #6A8F6A;                 /* Muted Green - Accent/Status buttons */
    --bs-success-rgb: 106, 143, 106;
    --bs-danger: #FF6B4A;                  /* Brighter red-orange for visibility */
    --bs-danger-rgb: 255, 107, 74;
    --bs-warning: #FFAA55;                 /* Warm Amber */
    --bs-warning-rgb: 255, 170, 85;
    --bs-info: #1F3A4D;                    /* Midnight Teal */
    --bs-info-rgb: 31, 58, 77;
    --bs-secondary: #6E5B4A;               /* Dark Bronze */
    --bs-secondary-rgb: 110, 91, 74;
    
    /* Active button states */
    --btn-primary-active-bg: #7755BB;      /* Deeper purple for pressed state */
    --btn-success-active-bg: #3D4D3D;      /* Darker olive */
    --btn-danger-active-bg: #E65A39;       /* Darker red-orange */
}

/* Apply theme variables */
body, .sticky, .sticky::before {
    background-color: var(--bg-body);
    /* Note: background-image URL must be set inline with Django static tag */
    background-attachment: fixed;
    background-repeat: repeat;
}

/* Background rectangle that extends 1px above sticky date header */
.sticky::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: -1px;
    height: 10px;
    z-index: -1;
}
        
/* Make Bootstrap bg-light theme-aware */
.bg-light {
    background-color: var(--bg-slot-header) !important;
}

/* Override Bootstrap bg-info with theme-aware colors */
.bg-info {
    background-color: var(--bs-info) !important;
}

[data-bs-theme="dark"] .bg-info {
    color: #FAF8F3 !important; /* Off-white text for visibility on dark teal background */
}

[data-bs-theme="dark"] .text-info {
    color: #7CA69C !important; /* Off-white text for visibility on dark teal background */
}

/* Retro Card Styling - Bakelite Panel Aesthetic */
.card {
    background-color: var(--bg-card);
    border: 3px solid var(--border-color);
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

[data-bs-theme="dark"] .card {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4),
                inset 0 1px 0 rgba(255, 170, 85, 0.1);
}
 
/* Retro Navbar - Console Top Panel */
.navbar {
    background-color: var(--bg-navbar) !important;
    border-bottom: 3px solid var(--border-color);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

[data-bs-theme="dark"] .navbar {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4),
                inset 0 1px 0 rgba(255, 170, 85, 0.1),
                0 0 20px rgba(255, 170, 85, 0.05);
}

.navbar-brand,
.navbar .nav-link {
    color: var(--text-navbar) !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .navbar-brand,
[data-bs-theme="dark"] .navbar .nav-link {
    text-shadow: 0 0 8px rgba(255, 170, 85, 0.5),
                 0 1px 2px rgba(0, 0, 0, 0.5);
}

.navbar .nav-link {
    opacity: 0.85;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus {
    opacity: 1;
}

.navbar-toggler {
    border: 2px solid var(--border-color);
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(94, 78, 65, 0.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

[data-bs-theme="dark"] .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255, 170, 85, 0.8)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Retro Buttons - Console Buttons with Rim */
.btn {
    border-width: 2px;
    border-radius: 6px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    /* background-color: var(--bg-body); */
}

/* Primary Button - Main Action (Deep Purple) */
.btn-primary {
    background-color: var(--bs-primary);
    border-color: #5544AA;
    color: #FAF8F3;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: #8866CC;
    border-color: #5544AA;
    color: #FAF8F3;
}

[data-bs-theme="dark"] .btn-primary {
    background-color: var(--bs-primary);
    border-color: #7755BB;
    color: #FAF8F3;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

[data-bs-theme="dark"] .btn-primary:hover,
[data-bs-theme="dark"] .btn-primary:focus {
    background-color: #AA88EE;
    border-color: #7755BB;
    color: #FAF8F3;
}

/* Success Button - Positive Actions (Muted Green) */
.btn-success {
    background-color: var(--bs-success);
    border-color: var(--border-color);
    color: #ffffff;
}

.btn-success:hover,
.btn-success:focus {
    background-color: #577557;
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-success {
    background-color: var(--bs-success);
    border-color: var(--border-color);
    color: #DED9C9;
}

[data-bs-theme="dark"] .btn-success:hover,
[data-bs-theme="dark"] .btn-success:focus {
    background-color: #5A6E5A;
    border-color: var(--border-color);
    color: #DED9C9;
}

/* Danger Button - Destructive Actions */
.btn-danger {
    background-color: var(--bs-danger);
    border-color: var(--border-color);
    color: #ffffff;
}

.btn-danger:hover,
.btn-danger:focus {
    background-color: #9A4040;
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-danger {
    background-color: #FF6B4A;
    border-color: var(--border-color);
    color: #2A2E33;
}

[data-bs-theme="dark"] .btn-danger:hover,
[data-bs-theme="dark"] .btn-danger:focus {
    background-color: #FF7C5B;
    border-color: var(--border-color);
    color: #2A2E33;
}

/* Secondary Button - Alternative Actions */
.btn-secondary {
    background-color: var(--bs-secondary);
    border-color: var(--border-color);
    color: #ffffff;
}

.btn-secondary:hover,
.btn-secondary:focus {
    background-color: #756550;
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-secondary {
    background-color: var(--bs-secondary);
    border-color: var(--border-color);
    color: #DED9C9;
}

[data-bs-theme="dark"] .btn-secondary:hover,
[data-bs-theme="dark"] .btn-secondary:focus {
    background-color: #7A6854;
    border-color: var(--border-color);
    color: #DED9C9;
}

/* Warning Button */
.btn-warning {
    background-color: var(--bs-warning);
    border-color: var(--border-color);
    color: #5E4E41;
}

.btn-warning:hover,
.btn-warning:focus {
    background-color: #968058;
    border-color: var(--border-color);
    color: #5E4E41;
}

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

[data-bs-theme="dark"] .btn-warning:hover,
[data-bs-theme="dark"] .btn-warning:focus {
    background-color: #FFB566;
    border-color: var(--border-color);
    color: #2A2E33;
}

/* Info Button */
.btn-info {
    background-color: var(--bs-info);
    border-color: var(--border-color);
    color: #5E4E41;
}

.btn-info:hover,
.btn-info:focus {
    background-color: #699088;
    border-color: var(--border-color);
    color: #5E4E41;
}

[data-bs-theme="dark"] .btn-info {
    background-color: var(--bs-info);
    border-color: var(--border-color);
    color: #FFAA55;
}

[data-bs-theme="dark"] .btn-info:hover,
[data-bs-theme="dark"] .btn-info:focus {
    background-color: #2A4A5D;
    border-color: var(--border-color);
    color: #FFAA55;
}

/* Outline Buttons - Retro Style */
.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--border-color);
    background-color: transparent;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--bs-primary);
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--border-color);
}

[data-bs-theme="dark"] .btn-outline-primary:hover,
[data-bs-theme="dark"] .btn-outline-primary:focus {
    background-color: var(--bs-primary);
    border-color: #7755BB;
    color: #2A2E33;
}

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

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background-color: var(--bs-secondary);
    border-color: var(--border-color);
    color: #ffffff;
}

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

.btn-outline-danger:hover,
.btn-outline-danger:focus {
    background-color: var(--bs-danger);
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-outline-danger {
    color: #FF6B4A;
}

[data-bs-theme="dark"] .btn-outline-danger:hover,
[data-bs-theme="dark"] .btn-outline-danger:focus {
    background-color: #FF6B4A;
    border-color: var(--border-color);
    color: #2A2E33;
}

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

.btn-outline-success:hover,
.btn-outline-success:focus {
    background-color: var(--bs-success);
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-outline-success {
    color: #7A9E7A;
}

[data-bs-theme="dark"] .btn-outline-success:hover,
[data-bs-theme="dark"] .btn-outline-success:focus {
    background-color: var(--bs-success);
    border-color: var(--border-color);
    color: #DED9C9;
}

.btn-outline-warning {
    color: var(--bs-warning);
    border-color: var(--border-color);
    background-color: transparent;
}

.btn-outline-warning:hover,
.btn-outline-warning:focus {
    background-color: var(--bs-warning);
    border-color: var(--border-color);
    color: #5E4E41;
}

.btn-outline-info {
    color: var(--bs-success);
    border-color: var(--border-color);
    background-color: transparent;
}

.btn-outline-info:hover,
.btn-outline-info:focus {
    background-color: var(--bs-info);
    border-color: var(--border-color);
    color: #5E4E41;
}

/* Button hover and active states */
[data-bs-theme="dark"] .btn {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4);
    /* background-color: var(--bg-body); */
}

.btn:hover {
    /* transform: translateY(-1px); */ /* NEVER RE-ENABLE */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
}

[data-bs-theme="dark"] .btn:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
}

.btn:active {
    transform: translateY(1px);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

/* Active state backgrounds for each button type */
.btn-primary:active,
.btn-primary.active {
    background-color: var(--btn-primary-active-bg) !important;
    border-color: var(--border-color) !important;
}

.btn-success:active,
.btn-success.active {
    background-color: var(--btn-success-active-bg) !important;
    border-color: var(--border-color) !important;
}

.btn-danger:active,
.btn-danger.active {
    background-color: var(--btn-danger-active-bg) !important;
    border-color: var(--border-color) !important;
}

/* Override Bootstrap's default blue focus ring for all buttons */
.btn:focus,
.btn:focus-visible {
    outline: none;
    border-color: var(--border-color) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25) !important;
}

.btn:active:focus {
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}

.btn:disabled,
.btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

/* Retro Badges - Status Indicators */
.badge {
    border-radius: 4px;
    padding: 0.35em 0.65em;
    font-weight: 600;
    letter-spacing: 0.5px;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

[data-bs-theme="dark"] .badge {
    border-color: rgba(255, 170, 85, 0.2);
}

/* Dark mode specific adjustments */
[data-bs-theme="dark"] .alert {
    border: 2px solid var(--border-color);
}

.alert {
    border: 2px solid var(--border-color);
    border-radius: 6px;
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: var(--bg-card);
    border: 2px solid var(--border-color);
    color: var(--text-primary);
}

.form-control,
.form-select {
    border: 2px solid var(--border-color);
    border-radius: 6px;
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    background-color: var(--bg-card);
    color: var(--text-primary);
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(153, 119, 221, 0.25);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(119, 85, 187, 0.25);
}

/* Form switch/toggle styling - Retro Style */
.form-check-input {
    width: 1em;
    height: 1em;
    border: 1px solid transparent !important;
    border-radius: 2em;
    background-color: var(--bs-secondary);
    cursor: pointer;
}

.form-check-input:checked {
    background-color: var(--bs-primary);
    /* border-color: var(--border-color); */
}

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

[data-bs-theme="dark"] .form-check-input {
    background-color: var(--bs-secondary);
    /*border-color: var(--bs-primary);*/
}

[data-bs-theme="dark"] .form-check-input:checked {
    background-color: var(--bs-primary);
    /*border-color: var(--bs-primary);*/
}

[data-bs-theme="dark"] .form-check-input:focus {
    /*border-color: var(--bs-primary);*/
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Theme toggle button styling - Retro Switch */
.theme-toggle-btn {
    background: none;
    border: 2px solid var(--border-color);
    border-radius: 50%;
    color: var(--text-navbar);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 0.5rem;
    margin: 0;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease-in-out;
    width: 38px;
    height: 38px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .theme-toggle-btn {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4),
                0 0 8px rgba(255, 170, 85, 0.3);
}

.theme-toggle-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    transform: scale(1.1);
}

[data-bs-theme="dark"] .theme-toggle-btn:hover {
    background-color: rgba(255, 170, 85, 0.1);
}

/* Custom focus states for accessibility */
a:focus, button:focus, input:focus, select:focus, textarea:focus {
    outline: 3px solid #0d6efd;
    outline-offset: 2px;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Toast notification container */
.toast-container {
    position: fixed;
    top: 80px;
    right: 20px;
    z-index: 1090;
}

/* Breadcrumb styling */
.breadcrumb {
    background-color: transparent;
    padding: 0;
    margin-bottom: 0;
}

/* Breadcrumb in navbar */
.navbar .breadcrumb {
    align-items: center;
}

.navbar .breadcrumb-item {
    display: flex;
    align-items: center;
}

.navbar .breadcrumb-item a {
    color: var(--text-navbar);
    text-decoration: none;
    opacity: 0.85;
}

.navbar .breadcrumb-item a:hover {
    opacity: 1;
}

.navbar .breadcrumb-item.active {
    color: var(--text-navbar);
}

.navbar .breadcrumb-item + .breadcrumb-item::before {
    color: var(--text-navbar-muted);
}

/* Retro fieldset styling */
fieldset {
    border: 2px solid var(--border-color) !important;
    border-radius: 8px;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.05);
}

[data-bs-theme="dark"] fieldset {
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

legend {
    background-color: var(--bg-card);
    padding: 0.25rem 0.75rem !important;
    border: 2px solid var(--border-color);
    border-radius: 6px;
    font-weight: 600;
}
