/* Alpine.js cloak - hide elements until Alpine initializes */
[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: #89a67c;             /* Muted Teal - Upper panel accents */
    --bg-navbar: #89a67c;                  /* Muted Teal - Navigation bar */
    --bg-secondary: #C0A783;
    --text-secondary: #68420c;
    --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 */
    --bg-grey: #777;
    
    /* Semantic color overrides for retro feel */
    /* --bs-primary: #74c192;                  */
    --bs-primary: #7dac8f;                 
    --bs-primary-rgb: 116, 193, 146;   
    --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: 219, 190, 78;
    --bs-info: #679bcb;                    /* Muted Teal */
    --bs-info-rgb: 124, 166, 156;
    --bs-secondary: #68420c;               /* Light bronze */
    --bs-secondary-rgb: 104, 66, 12;
    /* --bs-secondary: #C0A783;               /* Light bronze */
    --bs-secondary-rgb: 192, 167, 131; */
 
    --bs-primary-text: #326c32;
    /* --bs-nav-link-hover-color: #95B195; */
    
    /* Active button states */
    --btn-primary-active-bg: #44aa5a;      /* Darker purple for pressed state */
    --btn-success-active-bg: #4F6C4F;      /* Darker green */
    --btn-danger-active-bg: #8A3C3C;       /* Darker red */
    
    /* Nav tabs active border - darker for light theme visibility */
    --bs-nav-tabs-link-active-border-color: #A8946D;  /* Brushed Brass - matches border-color */
}

[data-bs-theme="light"] {
    --bs-border-color: #4e594a;
    --bs-body-color: #333;
    /* --bs-table-color-state: #333; */
    --bs-emphasis-color: #333;
}
/* Dark mode - Glowing Retro-Futurism */
[data-bs-theme="dark"] {
    --bg-body: #2A2E33;                    /* Deep Charcoal - Dark Bakelite */
    --bg-body2: #2f363d;                    
    --bg-card: #2f363d;                    /* Dark Charcoal - Panel background */
    --bg-card-hover: #343840;              /* Slightly lighter on hover */
    --bg-slot-header: #0f240f;             /* Midnight Teal - Slot headers */
    /* --bg-navbar: #1F3A4D;                  Midnight Teal - Navigation */
    --bg-navbar: #17391a;                  /* Dark Spruce - 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);
    --text-grey: #AAAAAA;
    --status-joined-bg: rgba(77, 94, 77, 0.25);  /* Deep olive tint */
    
    /* Semantic colors for dark theme glow */
    --bs-primary: #6A8F6A;                 /* Mercury Vapor Purple glow, was 77dd81 */
    --bs-primary-rgb: 106, 143, 106;
    --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: #4c7296;                    /* Muted Teal */
    --bs-info-rgb: 31, 58, 77;
    --bs-secondary: #6E5B4A;               /* Dark Bronze */
    --bs-secondary-rgb: 110, 91, 74;
    
    --bs-primary-text: #95B195;

    /* Active button states */
    --btn-primary-active-bg: #6A8F6A;      /* Deeper purple for pressed state */
    --btn-success-active-bg: #3D4D3D;      /* Darker olive */
    --btn-danger-active-bg: #E65A39;       /* Darker red-orange */
    
    /* Nav tabs active border - matches dark theme border */
    --bs-nav-tabs-link-active-border-color: #6E5B4A;  /* Dark Bronze - matches border-color */
}

/* 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;
}

.bg-grey {
    background-color: var(--bg-grey) !important;
}

/* Status-joined styling for event/activity cards where user is participating */
.status-joined {
    background-color: var(--status-joined-bg);
    border-color: var(--bs-success) !important;
}

.text-grey {
    color: var(--text-grey) !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 */
}

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

.text-secondary {
    color: var(--text-secondary) !important;
}

/* 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);
}

/* Maintenance Mode Navbar - Under Construction Stripes */
.navbar.navbar-maintenance {
    background: repeating-linear-gradient(
        45deg,
        #000000,
        #000000 20px,
        #FFD700 20px,
        #FFD700 40px
    ) !important;
    border-bottom-color: #000000;
}

[data-bs-theme="dark"] .navbar.navbar-maintenance {
    background: repeating-linear-gradient(
        45deg,
        #1a1a1a,
        #1a1a1a 20px,
        #B8860B 20px,
        #B8860B 40px
    ) !important;
    border-bottom-color: #1a1a1a;
}

.navbar.navbar-maintenance .navbar-brand,
.navbar.navbar-maintenance .nav-link {
    color: #ffffff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8),
                 -1px -1px 2px rgba(0, 0, 0, 0.8);
}

.navbar.navbar-maintenance .theme-toggle-btn {
    color: #ffffff;
    border-color: #ffffff;
    font-size: 1.05rem;
}

.navbar.navbar-maintenance .breadcrumb-item a,
.navbar.navbar-maintenance .breadcrumb-item.active,
.navbar.navbar-maintenance .breadcrumb-item + .breadcrumb-item::before {
    color: #ffffff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
}

.navbar.navbar-maintenance .navbar-toggler {
    border-color: #ffffff;
}

.navbar.navbar-maintenance .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, 255, 255, 0.9)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.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 i.bi {
    font-size: 1.2rem;
}


.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: #89a67c;
    color: #FAF8F3;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: #8bcca4;
    border-color: #36553e;
    color: #FAF8F3;
}

[data-bs-theme="dark"] .btn-primary {
    background-color: var(--bs-primary);
    border-color: #3D4D3D;
    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: #87AC87;
    border-color: #55bb7c;
    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;
}

.btn-navigation {
    background-color: color-mix(in srgb, var(--bg-slot-header), transparent 80%);
    /* background-color: var(--bg-slot-header); */
    /* border-color: var(--border-color); */
    color: #ffffff;
    width: 2rem;
    height: 2rem;
    z-index: 1060;
    /* opacity: 0.85; */
    font-size: 300%;
    /* background-color: red; */
    border: 0;
}

.btn-navigation:hover,
.btn-navigation:focus {
    background-color: color-mix(in srgb, var(--bg-slot-header), transparent 50%);
    border-color: var(--border-color);
    color: #ffffff;
}

[data-bs-theme="dark"] .btn-navigation {
    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-text);
    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-text);
    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: #4F6C4F;
    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;
    height: 2em;
    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-info);
    /* 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-info);
    /*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);
    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: 2rem;
    height: 2rem;
    /* 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;
}

/* Nav tabs - Retro styling */
.nav-tabs {
    border-bottom-color: var(--border-color);
}

.nav-tabs .nav-link.active {
    border-color: var(--border-color) var(--border-color) transparent;
    background-color: var(--bg-card);
}

.nav-tabs .nav-link {
    border-bottom: none;
}

.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus {
    border-color: var(--bs-nav-tabs-link-active-border-color) var(--bs-nav-tabs-link-active-border-color) transparent;
}


.text-primary, .nav-link {
	color: var(--bs-primary-text) !important;
}

/* Ongoing activity indicator - Pulsing red dot */
.ongoing-icon {
  display: inline-block;
  position: relative;
  width: 0.5em;
  height: 0.5em;
  /* background-color: --ring-color; */
  border-radius: 50%;
  margin-right: 0.3rem;
  margin-bottom: 0.05rem;
  /* vertical-align: middle; */
  animation: blink-pattern 2s infinite, pulse-ring 2s ease-out infinite;
  --ongoing-icon-color: white;
}

.slot-header .ongoing-icon {
    --ongoing-icon-color: var(--text-primary);
    /* background-color: var(--ongoing-icon-color) !important; */
    margin-bottom: 0.15rem !important;
}

.ongoing-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0.5em;
    height: 0.5em;
    background-color: transparent;
    border-radius: 50%;
    animation: pulse-ring 2s ease-out infinite;
    animation-delay: 0.67s;
}

.slot-header .ongoing-icon::before {
    /* background-color: var(--ongoing-icon-color) !important; */
    margin-bottom: 0.15rem !important;
}


@keyframes pulse-ring {
  0% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--ongoing-icon-color), transparent 30%);
  }
  33% {
    box-shadow: 0 0 0 0.5em rgba(255, 255, 255, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
  }
}

@keyframes blink-pattern {
  0%, 21%   { background-color: var(--ongoing-icon-color); }
  22%, 32%  { background-color: transparent;  }
  33%, 88%  { background-color: var(--ongoing-icon-color); }
  89%, 100%  { background-color: transparent;  } 
}



button, .clickable-element {
  /* Allows panning and pinch-zoom, but disables double-tap to zoom */
  touch-action: manipulation;
}