/* Old Man Footy Custom Styles */

/* Prevent flash of unstyled content during theme loading */
.theme-loading {
    visibility: hidden !important;
    transition: none !important;
}

.theme-loading * {
    transition: none !important;
}

.bi-2x {
  font-size: 2rem;
}

.bi-3x {
  font-size: 3rem;
}

.bi-4x {
  font-size: 4rem;
}

.bi-5x {
  font-size: 5rem;
}


/* Root Variables for Consistent Theming - Green/Gold Theme */
:root {
    --rugby-green: #006837;
    --rugby-gold: #FFD700;
    --rugby-dark-green: #004d27;
    --rugby-light-green: #e8f5e8;
    --rugby-link-green: #2E7D32;
    --rugby-link-green-hover: #1B5E20;
    --secondary: #dc3545;
    --success: #28a745;
    --wa-bgrning: #ffc107;
    --light: #f8f9fa;
    --dark: #343a40;
    --info: #bdf9c0;
    --shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --shadow-lg: 1rem 3rem rgba(0, 0, 0, 0.175);

    /* Light theme colors (default) */
    --theme-bg-primary: #f5f5f5;
    --theme-bg-secondary: #f8f9fa;
    --theme-bg-tertiary: #e9ecef;
    --theme-text-primary: #212529;
    --theme-text-secondary: #6c757d;
    --theme-text-muted: #6c757d;
    --theme-border-color: #dee2e6;
    --theme-card-bg: #ffffff;
    --theme-input-bg: #ffffff;
    --theme-dropdown-bg: #ffffff;

    /* Override ALL Bootstrap's nav-link CSS custom properties */
    --bs-nav-link-color: rgba(255, 255, 255, 0.9) !important;
    --bs-nav-link-hover-color: #FFD700 !important;
    --bs-nav-link-active-color: #FFD700 !important;
    --bs-nav-link-disabled-color: rgba(255, 255, 255, 0.5) !important;
    --bs-navbar-nav-link-padding-x: 0.5rem !important;
    --bs-navbar-color: rgba(255, 255, 255, 0.9) !important;
    --bs-navbar-hover-color: #FFD700 !important;
    --bs-navbar-disabled-color: rgba(255, 255, 255, 0.5) !important;
    --bs-navbar-active-color: #FFD700 !important;
    --bs-navbar-brand-color: white !important;
    --bs-navbar-brand-hover-color: #FFD700 !important;
    --bs-navbar-toggler-border-color: rgba(255, 255, 255, 0.1) !important;
    --bs-navbar-toggler-focus-width: 0.25rem !important;
    --bs-primary: #006837 !important;
    --bs-primary-rgb: 0, 104, 55 !important;
    --bs-link-color: #2E7D32 !important;
    --bs-link-hover-color: #1B5E20 !important;

    /* == STATES == */
    --nsw-bg: linear-gradient(135deg, #146CFD 0%, #9BCBEB 25%, #9BCBEB 75%, #146CFD 100%);
    --nsw-text: #001A33;
    --vic-bg: linear-gradient(135deg, #D9D9D6 0%, #003c71 25% ,#003c71 75%, #D9D9D6 100%);
    --vic-text: #ffffff;
    --qld-bg: linear-gradient(135deg, #FED200 0%, #73182c 25%, #73182c 75%, #FED200 100%);
    --qld-text: #ffffff;
    --wa-bg: linear-gradient(135deg, #000000 0%, #ffd100 25%, #ffd100 75%, #000000 100%);
    --wa-text: #000000;
    --sa-bg: linear-gradient(135deg, #ffa300 0%, #d50032 25%, #d50032 75%, #ffa300 100%);
    --sa-text: #ffffff;
    --tas-bg: linear-gradient(135deg, #fdde40 0%, #006648 25%, #006648 75%, #fdde40 100%);
    --tas-text: #ffffff ;
    /* == TERRITORIES == */
    --act-bg: linear-gradient(135deg, #002855 0%, #ffc72c 25%, #ffc72c 75%, #002855 100%);
    --act-text: #000000;
    --nt-bg: linear-gradient(135deg, #000000 0%, #C25E03 25%, #C25E03 75%, #000000 100%);
    --nt-text: #ffffff;
}

/* Dark theme variables */
[data-theme="dark"] {
    --theme-bg-primary: #1a1a1a;
    --theme-bg-secondary: #2d2d2d;
    --theme-bg-tertiary: #404040;
    --theme-text-primary: #ffffff;
    --theme-text-secondary: #cccccc;
    --theme-text-muted: #aaaaaa;
    --theme-border-color: #555555;
    --theme-card-bg: #2d2d2d;
    --theme-input-bg: #404040;
    --theme-dropdown-bg: #2d2d2d;

    /* Override Bootstrap dark theme properties */
    --bs-body-bg: #1a1a1a;
    --bs-body-color: #ffffff;
    --bs-link-color: #4CAF50;
    --bs-link-hover-color: #66BB6A;
}

/* Global Enhancements */
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    color: var(--theme-text-primary);
    background-color: var(--theme-bg-primary);
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Re-enable visibility and transitions after theme is applied */
body.theme-applied {
    visibility: visible !important;
}

body.theme-applied * {
    transition: all 0.3s ease;
}

/* Link Styling - Rugby Theme */
a {
    color: var(--rugby-link-green);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover,
a:focus {
    color: var(--rugby-link-green-hover);
    text-decoration: underline;
}

a:visited {
    color: var(--rugby-link-green);
}

/* Remove underlines from links that already have visual feedback */
.navbar a:hover,
.navbar a:focus,
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus,
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus,
.btn:hover,
.btn:focus,
a.btn:hover,
a.btn:focus,
.card:hover a,
.card a:hover,
.rugby-masters-card:hover a,
.rugby-masters-card a:hover,
.social-links a:hover,
.social-links a:focus,
a[class*="btn"]:hover,
a[class*="btn"]:focus,
.hero-btn:hover,
.hero-btn:focus,
.hero-logo:hover,
.footer a:hover,
.footer a:focus,
.breadcrumb-item a:hover,
.breadcrumb-item a:focus {
    text-decoration: none;
}

/* Header and Navigation */
.navbar-brand {
    font-weight: 700;
    color: white !important;
    transition: color 0.3s ease;
}

.navbar-brand:hover,
.navbar-brand:focus {
    color: var(--rugby-gold) !important;
}

.navbar-dark .navbar-nav .nav-link {
    font-weight: 500;
    color: rgba(255, 255, 255, 0.9) !important;
    transition: color 0.3s ease;
}

.navbar-dark .navbar-nav .nav-link:hover {
    color: var(--rugby-gold) !important;
}

/* More specific nav-link styling to override Bootstrap defaults */
.navbar-nav .nav-link,
.navbar-nav .nav-link:visited,
.navbar-nav .nav-link:focus {
    color: rgba(255, 255, 255, 0.9) !important;
}

.navbar-nav .nav-link:active,
.navbar-nav .nav-link:hover {
    color: var(--rugby-gold) !important;
}

/* Dropdown menu items */
.dropdown-menu .dropdown-item {
    color: #212529 !important;
    transition: all 0.3s ease;
}

.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
    background-color: var(--rugby-light-green) !important;
    color: var(--rugby-dark-green) !important;
}

/* Dark mode dropdown menu styling */
[data-theme="dark"] .dropdown-menu {
    background-color: var(--theme-dropdown-bg) !important;
    border-color: var(--theme-border-color) !important;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5) !important;
}

[data-theme="dark"] .dropdown-menu .dropdown-item {
    color: var(--theme-text-primary) !important;
    background-color: transparent !important;
}

[data-theme="dark"] .dropdown-menu .dropdown-item:hover,
[data-theme="dark"] .dropdown-menu .dropdown-item:focus {
    background-color: var(--theme-bg-secondary) !important;
    color: var(--rugby-gold) !important;
}

[data-theme="dark"] .dropdown-menu .dropdown-item:active {
    background-color: var(--rugby-green) !important;
    color: white !important;
}

[data-theme="dark"] .dropdown-divider {
    border-top-color: var(--theme-border-color) !important;
}

[data-theme="dark"] .dropdown-toggle::after {
    border-top-color: var(--theme-text-primary) !important;
}

/* Dark mode button overrides */
[data-theme="dark"] .btn-primary,
[data-theme="dark"] a.btn-primary,
[data-theme="dark"] .btn.btn-primary {
    background-color: var(--rugby-green) !important;
    border-color: var(--rugby-green) !important;
    color: white !important;
}

[data-theme="dark"] .btn-primary:hover,
[data-theme="dark"] .btn-primary:focus,
[data-theme="dark"] .btn-primary:active,
[data-theme="dark"] a.btn-primary:hover,
[data-theme="dark"] a.btn-primary:focus,
[data-theme="dark"] a.btn-primary:active {
    background-color: var(--rugby-dark-green) !important;
    border-color: var(--rugby-dark-green) !important;
    color: white !important;
}

/* Ensure text is always visible on primary buttons in dark mode */
[data-theme="dark"] .btn-primary *,
[data-theme="dark"] a.btn-primary *,
[data-theme="dark"] .btn.btn-primary * {
    color: white !important;
}

/* Info Section Enhancements */
.bg-info,
.card-header.bg-info {
    background-color: var(--info) !important;
    border-left-color: var(--rugby-light-green) !important;
    color: var(--rugby-dark-green) !important;
}

.bg-blue {
    background-color: blue !important;
    border-left-color: darkblue !important;
}

/* Ensure text color is applied with higher specificity */
.card .card-header.bg-info,
.card-header.bg-info h1,
.card-header.bg-info h2,
.card-header.bg-info h3,
.card-header.bg-info h4,
.card-header.bg-info h5,
.card-header.bg-info h6 {
    color: var(--rugby-dark-green) !important;
}


/* Button Enhancements */
.btn {
    border-radius: 0.375rem;
    font-weight: 500;
    transition: all 0.3s ease;
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow);
}

a.btn-primary,
.btn.btn-primary,
.btn-primary,
.btn-check:checked + .btn-outline-primary {
    background-color: var(--rugby-green);
    border-color: var(--rugby-green);
    color: white;
}

a.btn-primary:hover,
a.btn-primary:focus,
a.btn-primary:active,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--rugby-dark-green);
    border-color: var(--rugby-dark-green);
    color: white;
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25);
}

a.btn-secondary,
.btn.btn-secondary,
.btn-secondary,
.btn-check:checked + .btn-outline-secondary {
    background-color: var(--rugby-dark-green);
    border-color: var(--rugby-dark-green);
    color: white;
}

a.btn-primary:hover,
a.btn-primary:focus,
a.btn-primary:active,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--rugby-green);
    border-color: var(--rugby-green);
    color: white;
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25);
}

a.btn-outline-primary,
.btn-outline-primary {
    color: var(--rugby-green);
    border-color: var(--rugby-green);
}

a.btn-outline-primary:hover,
a.btn-outline-primary:focus,
a.btn-outline-primary:active,
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active,
.btn-outline-primary:not(:disabled):not(.disabled):active,
.btn-outline-primary:not(:disabled):not(.disabled).active,
.show > .btn-outline-primary.dropdown-toggle {
    background-color: var(--rugby-green) !important;
    border-color: var(--rugby-green) !important;
    color: white !important;
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25) !important;
}

a.btn-outline-primary:focus,
.btn-outline-primary:focus {
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25) !important;
}

a.btn-outline-secondary,
.btn-outline-secondary {
    color: var(--rugby-dark-green);
    border-color: var(--rugby-dark-green);
}

a.btn-outline-secondary:hover,
a.btn-outline-secondary:focus,
a.btn-outline-secondary:active,
.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.btn-outline-secondary:active,
.btn-outline-secondary:not(:disabled):not(.disabled):active,
.btn-outline-secondary:not(:disabled):not(.disabled).active,
.show > .btn-outline-secondary.dropdown-toggle {
    background-color: var(--rugby-dark-green) !important;
    border-color: var(--rugby-dark-green) !important;
    color: white !important;
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25) !important;
}

a.btn-tertiary,
.btn-tertiary,
.btn-check:checked + .btn-outline-tertiary {
    background-color: var(--rugby-gold);
    border-color: var(--rugby-gold);
    color: var(--rugby-dark-green);
    font-weight: 600;
}

a.btn-tertiary:hover,
a.btn-tertiary:focus,
a.btn-tertiary:active,
.btn-tertiary:hover,
.btn-tertiary:focus,
.btn-tertiary:active {
    background-color: #e6c200;
    border-color: #e6c200;
    color: var(--rugby-dark-green);
    box-shadow: 0 0 0 0.2rem rgba(255, 215, 0, 0.25);
}

a.btn-outline-tertiary,
.btn-outline-tertiary {
    color: var(--rugby-gold);
    border-color: var(--rugby-gold);
}

a.btn-outline-tertiary:hover,
a.btn-outline-tertiary:focus,
a.btn-outline-tertiary:active,    
.btn-outline-tertiary:hover,
.btn-outline-tertiary:focus,
.btn-outline-tertiary:active {
    background-color: var(--rugby-gold);
    border-color: var(--rugby-gold);
    color: var(--rugby-dark-green) !important;
    box-shadow: 0 0 0 0.2rem rgba(255, 215, 0, 0.25);
}

a.btn-outline-danger,
.btn-outline-danger {
    color: red;
    border-color: red;
}

a.btn-outline-danger:hover,
.btn-outline-danger:hover,
a.btn-outline-danger:focus,
.btn-outline-danger:focus,
a.btn-outline-danger:active,
.btn-outline-danger:active {
    background-color: red;
    border-color: red;
    color: white;
    box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.25);
}

a.btn-group-sm,
.btn-group-sm .btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.875rem;
}

/* Registration Buttons */
a.btn-register,
.btn-register,
.registration-btn,
a[href*="/auth/register"],
button[type="submit"]:contains("Register"),
button[type="submit"]:contains("Complete Registration"),
.btn:contains("Register") {
    background: linear-gradient(45deg, var(--rugby-gold), #e6c200) !important;
    border: 2px solid var(--rugby-gold) !important;
    color: var(--rugby-dark-green) !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
}

a.btn-register:hover,
a.btn-register:focus,
a.btn-register:active,
.btn-register:hover,
.btn-register:focus,
.btn-register:active,
.registration-btn:hover,
.registration-btn:focus,
a[href*="/auth/register"]:hover,
a[href*="/auth/register"]:focus,
button[type="submit"]:contains("Register"):hover,
button[type="submit"]:contains("Register"):focus,
.btn:contains("Register"):hover,
.btn:contains("Register"):focus,
button[type="submit"]:contains("Complete Registration"):hover,
button[type="submit"]:contains("Complete Registration"):focus {
    background: linear-gradient(45deg, #e6c200, var(--rugby-gold)) !important;
    border-color: #e6c200 !important;
    color: var(--rugby-dark-green) !important;
    box-shadow: 0 4px 15px rgba(255, 215, 0, 0.3) !important;
    transform: translateY(-2px);
}

/* Card Enhancements */
.card {
    border: none;
    border-radius: 0.75rem;
    box-shadow: var(--shadow-sm);
    transition: all 0.3s ease;
    background-color: var(--theme-card-bg);
    border-color: var(--theme-border-color);
    color: var(--theme-text-primary);
}

.card:hover {
    box-shadow: var(--shadow);
    transform: translateY(-2px);
}

.card-header {
    border-radius: 0.75rem 0.75rem 0 0 !important;
    border-bottom: 2px solid var(--theme-border-color);
    font-weight: 600;
}

/* Dark Mode Card Glow Effects */
[data-theme="dark"] .card {
    box-shadow: 0 0 8px rgba(0, 104, 55, 0.3) !important;
    border: 1px solid rgba(0, 104, 55, 0.2) !important;
}

[data-theme="dark"] .card:hover {
    box-shadow: 0 0 16px rgba(0, 104, 55, 0.5) !important;
    transform: translateY(-2px);
}

[data-theme="dark"] .card.shadow,
[data-theme="dark"] .card.shadow-sm,
[data-theme="dark"] .card.shadow-lg {
    box-shadow: 0 0 12px rgba(0, 104, 55, 0.4) !important;
}

[data-theme="dark"] .card.shadow:hover,
[data-theme="dark"] .card.shadow-sm:hover,
[data-theme="dark"] .card.shadow-lg:hover {
    box-shadow: 0 0 20px rgba(0, 104, 55, 0.6) !important;
}

/* Special glow effects for different card types in dark mode */
[data-theme="dark"] .card.border-primary {
    box-shadow: 0 0 12px rgba(0, 104, 55, 0.4) !important;
    border-color: var(--rugby-green) !important;
}

[data-theme="dark"] .card.border-success {
    box-shadow: 0 0 12px rgba(0, 104, 55, 0.4) !important;
    border-color: var(--rugby-green) !important;
}

[data-theme="dark"] .card.border-info {
    box-shadow: 0 0 12px rgba(0, 104, 55, 0.4) !important;
    border-color: var(--rugby-green) !important;
}

[data-theme="dark"] .card.border-warning {
    box-shadow: 0 0 12px rgba(255, 215, 0, 0.3) !important;
    border-color: var(--rugby-gold) !important;
}

/* Rugby Masters Cards with enhanced glow */
[data-theme="dark"] .rugby-masters-card {
    box-shadow: 0 0 12px rgba(0, 104, 55, 0.4) !important;
}

[data-theme="dark"] .rugby-masters-card:hover {
    box-shadow: 0 0 20px rgba(0, 104, 55, 0.6) !important;
}

/* Dark mode bg-light styling */
[data-theme="dark"] .bg-light {
    background-color: var(--theme-bg-secondary) !important;
    color: var(--theme-text-primary) !important;
}

[data-theme="dark"] .card-body.bg-light {
    background-color: var(--theme-bg-secondary) !important;
    color: var(--theme-text-primary) !important;
}

/* Ensure proper text colors in dark mode bg-light sections */
[data-theme="dark"] .bg-light h1,
[data-theme="dark"] .bg-light h2,
[data-theme="dark"] .bg-light h3,
[data-theme="dark"] .bg-light h4,
[data-theme="dark"] .bg-light h5,
[data-theme="dark"] .bg-light h6,
[data-theme="dark"] .card-body.bg-light h1,
[data-theme="dark"] .card-body.bg-light h2,
[data-theme="dark"] .card-body.bg-light h3,
[data-theme="dark"] .card-body.bg-light h4,
[data-theme="dark"] .card-body.bg-light h5,
[data-theme="dark"] .card-body.bg-light h6 {
    color: var(--theme-text-primary) !important;
}

[data-theme="dark"] .bg-light p,
[data-theme="dark"] .bg-light .text-muted,
[data-theme="dark"] .card-body.bg-light p,
[data-theme="dark"] .card-body.bg-light .text-muted {
    color: var(--theme-text-secondary) !important;
}

/* Clickable Dashboard Stat Card Styling */
.clickable-card {
    cursor: pointer;
    transform: translateY(0);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    border-radius: 0.75rem !important;
}

.clickable-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transition: left 0.5s ease;
}

.clickable-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 104, 55, 0.3);
}

.clickable-card:hover::before {
    left: 100%;
}

.clickable-card:active {
    transform: translateY(0);
    box-shadow: 0 4px 15px rgba(0, 104, 55, 0.2);
}

.clickable-card .card-body *,
.clickable-card * {
    color: white !important;
}

.clickable-card:not(:where(a)) .card-body * {
    color: inherit !important;
}

/* Dashboard Stats Cards */
.dashboard-stats.row {
    display: flex;
    flex-wrap: wrap;
    margin-left: -15px;
    margin-right: -15px;
    gap: 0;
}

.dashboard-stats .col-md-4 {
    display: flex;
    flex-direction: column;
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 0 !important;
}

.dashboard-stats .col-md-4 > a {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    flex: 1;
}

.dashboard-stats .card {
    background: linear-gradient(135deg, var(--rugby-green) 0%, var(--rugby-dark-green) 100%);
    border: none;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.dashboard-stats .card:not(.clickable-card):hover,
.dashboard-stat-card:not(.clickable-card):hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(0, 104, 55, 0.2);
}

.dashboard-stats .card .card-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 1.25rem 1rem;
    min-height: 150px;
    flex: 1;
}

.dashboard-stats .card .card-body h1,
.dashboard-stats .card .card-body h3 {
    font-size: 2.25rem;
    margin-bottom: 0.5rem;
}

.dashboard-stats .card .card-body h5,
.dashboard-stats .card .card-body p {
    font-size: 1rem;
    margin-bottom: 0.5rem;
}

.dashboard-stats .card .card-body .text-white-50 {
    margin-top: auto;
    padding-top: 0.5rem;
    font-size: 0.8rem;
}


/* Dark Mode Card Styling */
[data-theme="dark"] .card,
[data-theme="dark"] .card-body {
    background-color: var(--theme-card-bg) !important;
    border-color: var(--theme-border-color) !important;
    color: var(--theme-text-primary) !important;
}

/* Old Man Footy Specific Enhancements */
.rugby-masters-hero {
    background: linear-gradient(135deg, var(--rugby-green) 0%, var(--rugby-dark-green) 100%);
    color: white;
    padding: 4rem 0;
    position: relative;
    overflow: hidden;
}

.rugby-masters-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" fill="none" stroke="rgba(255,215,0,0.1)" stroke-width="2"/></svg>') repeat;
    opacity: 0.3;
}

.rugby-masters-card {
    background: linear-gradient(135deg, white 0%, #f8f9fa 100%);
    border: 2px solid var(--rugby-light-green);
    transition: all 0.3s ease;
}

.rugby-masters-card:hover {
    border-color: var(--rugby-green);
    box-shadow: 0 8px 25px rgba(0, 104, 55, 0.15);
}

[data-theme="dark"] .rugby-masters-card,
[data-theme="dark"] .rugby-masters-card .card-body,
[data-theme="dark"] .rugby-masters-card .card-title,
[data-theme="dark"] .rugby-masters-card .card-text,
[data-theme="dark"] .rugby-masters-card span:not(.badge) {
    background: var(--theme-card-bg) !important;
    color: var(--theme-text-primary) !important;
}

[data-theme="dark"] .rugby-masters-card {
    border: 2px solid var(--theme-border-color) !important;
}

[data-theme="dark"] .rugby-masters-card:hover {
    border-color: var(--rugby-green) !important;
    box-shadow: 0 8px 25px rgba(76, 175, 80, 0.15) !important;
}

[data-theme="dark"] .rugby-masters-card .text-muted a {
    color: var(--theme-text-secondary) !important;
}

[data-theme="dark"] .rugby-masters-card .text-muted a:hover {
    color: var(--theme-text-primary) !important;
}

[data-theme="dark"] .rugby-masters-card .bi-geo-alt,
[data-theme="dark"] .rugby-masters-card .bi-envelope,
[data-theme="dark"] .rugby-masters-card .bi-telephone,
[data-theme="dark"] .rugby-masters-card .bi-globe,
[data-theme="dark"] .col-md-6 .d-flex .bi-geo-alt,
[data-theme="dark"] .col-md-6 .d-flex .bi-trophy {
    color: white !important;
}

/* Dark Mode Text & Element Fixes */
[data-theme="dark"] .filter-section {
    background: var(--theme-bg-secondary) !important;
    border: 2px solid var(--theme-border-color) !important;
}

[data-theme="dark"] .stat-item-small .stat-label-small,
[data-theme="dark"] .text-muted,
[data-theme="dark"] .text-muted.small,
[data-theme="dark"] .form-text {
    color: var(--theme-text-muted) !important;
}

[data-theme="dark"] .col-md-6 h5,
[data-theme="dark"] .col-md-6 .d-flex span,
[data-theme="dark"] .col-md-6 span:not(.badge):not(.text-primary) {
    color: var(--theme-text-primary);
}

[data-theme="dark"] .social-links .btn {
    border-color: var(--theme-border-color) !important;
}

[data-theme="dark"] .social-links .btn:hover {
    background-color: var(--theme-bg-secondary) !important;
    border-color: var(--rugby-green) !important;
}

.community-gallery {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}

[data-theme="dark"] .community-gallery {
    background: linear-gradient(135deg, var(--theme-bg-secondary) 0%, var(--theme-bg-tertiary) 100%);
}

[data-theme="dark"] .py-4.bg-tertiary {
    background-color: var(--theme-bg-secondary) !important;
}

/* File Upload Areas */
.file-upload-area {
    border: 2px dashed #dee2e6;
    border-radius: 0.5rem;
    padding: 2rem 1rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background-color: #f8f9fa;
}

.file-upload-area:hover {
    border-color: var(--rugby-green);
    background-color: var(--rugby-light-green);
}

.file-upload-area.drag-over {
    border-color: var(--rugby-gold);
    background-color: #fffbf0;
    transform: scale(1.02);
}

.file-upload-area i {
    opacity: 0.6;
    transition: opacity 0.3s ease;
    color: var(--rugby-green);
}

.file-upload-area:hover i {
    opacity: 1;
}

.upload-text {
    margin: 0;
    color: #6c757d;
    font-weight: 500;
}

.file-upload-area.file-selected {
    border-color: var(--rugby-green);
    background-color: var(--rugby-light-green);
}

.file-upload-area.file-selected .upload-text {
    color: var(--rugby-green);
    font-weight: 600;
}

/* Logo Uploader Component */
.logo-preview-image {
    height: 150px;
    object-fit: contain;
    background: #f8f9fa;
}

.logo-uploader-no-logo {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Dark theme logo uploader styles */
[data-theme="dark"] .logo-preview-image {
    background: var(--theme-bg-tertiary);
}

/* Image Uploader Component Styles */
.image-upload-area {
    cursor: pointer;
    transition: border-color 0.3s ease;
}

.image-upload-area:hover {
    border-color: var(--bs-primary) !important;
    background-color: var(--bs-light) !important;
}

.image-upload-area.dragover {
    border-color: var(--bs-success) !important;
    background-color: var(--bs-success-bg-subtle) !important;
}

.image-thumbnail {
    background-color: var(--bs-light);
    position: relative;
}

.image-thumbnail img {
    transition: transform 0.2s ease;
}

.image-thumbnail:hover img {
    transform: scale(1.05);
}

.existing-image-item .badge {
    font-size: 0.65em;
}

/* Ensure existing images are properly aligned within upload areas */
.existing-images {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    width: 100% !important;
}

.existing-image-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    width: auto !important;
    margin: 0 auto !important;
}

/* Override Bootstrap inline classes specifically */
.existing-image-item.position-relative.d-inline-block {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
}

.existing-image-item .image-thumbnail {
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.existing-image-item .image-name {
    text-align: center !important;
    width: 100% !important;
    margin-top: 0.5rem !important;
}

.existing-image-item .badge {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    transform: translate(25%, -25%) !important;
}

/* Ultra-specific override for maximum compatibility */
.upload-equal-height .existing-images .existing-image-item.position-relative.d-inline-block {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    width: auto !important;
    margin: 0 auto !important;
    height: 100% !important;
}

.upload-equal-height .existing-images .existing-image-item .image-thumbnail {
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.upload-equal-height .existing-images .existing-image-item .image-name {
    text-align: center !important;
    margin-top: 0.5rem !important;
}

/* Override inline styles that prevent proper alignment */
.upload-equal-height .existing-images .existing-image-item .image-thumbnail[style*="200px"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 200px !important;
    height: 200px !important;
}

.upload-equal-height .existing-images .existing-image-item .image-thumbnail img[style*="100%"] {
    object-fit: contain !important;
    object-position: center !important;
    background-color: var(--theme-bg-secondary, #f8f9fa) !important;
}

/* Ensure consistent image container appearance for different aspect ratios */
.upload-equal-height .existing-images .existing-image-item .image-thumbnail {
    background-color: var(--theme-bg-secondary, #f8f9fa) !important;
    border: 1px solid var(--theme-border-color, #dee2e6) !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.selected-image-item {
    position: relative;
}

.selected-image-item .remove-image {
    position: absolute;
    top: 5px;
    right: 5px;
    background: rgba(220, 53, 69, 0.9);
    color: white;
    border: none;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.selected-image-item .remove-image:hover {
    background: rgba(220, 53, 69, 1);
}

.object-fit-cover {
    object-fit: cover;
}

.image-preview-container {
    overflow: hidden;
}

.image-preview-max-width {
    max-width: 100%;
}

.image-name {
    max-width: 120px;
}

/* Upload Area Styling */
.image-upload-area,
.document-upload-area {
    cursor: pointer;
    transition: border-color 0.3s ease, background-color 0.3s ease;
    background-color: #f8f9fa;
    min-height: 180px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.image-upload-area:hover,
.document-upload-area:hover {
    border-color: var(--rugby-green) !important;
    background-color: #e9ecef;
}

/* Equal height containers for upload areas */
.image-uploader,
.document-uploader {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.file-input-section {
    display: flex;
    flex-direction: column;
    min-height: 180px;
}

/* Ensure upload columns have equal heights */
.row:has(.image-uploader, .document-uploader),
.upload-equal-height {
    display: flex;
    flex-wrap: wrap;
}

.row:has(.image-uploader, .document-uploader) > [class*="col-"],
.upload-equal-height > [class*="col-"] {
    display: flex;
    flex-direction: column;
}

/* Form Enhancements */
.form-control,
.form-select {
    border-radius: 0.375rem;
    border: 2px solid var(--theme-border-color);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
    background-color: var(--theme-input-bg);
    color: var(--theme-text-primary);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--rugby-green);
    box-shadow: 0 0 0 0.2rem rgba(0, 104, 55, 0.25);
}

/* Dark mode form styling */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: var(--theme-input-bg);
    border-color: var(--theme-border-color);
    color: var(--theme-text-primary);
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] .form-select::placeholder {
    color: var(--theme-text-muted);
    opacity: 0.7;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: var(--theme-input-bg);
    border-color: var(--rugby-green);
    color: var(--theme-text-primary);
    box-shadow: 0 0 0 0.2rem rgba(76, 175, 80, 0.25);
}

/* Text Colors */
.text-primary {
    color: var(--rugby-green) !important;
}

.text-success {
    color: var(--rugby-gold) !important;
}

/* State Badge Colors - Australian States & Territories with Gradients */
.badge.state-nsw,
.badge[data-state="nsw"] {
    background: var(--nsw-bg) !important;
    color: var(--nsw-text) !important;
}

.badge.state-vic,
.badge[data-state="vic"] {
    background: var(--vic-bg) !important;
    color: var(--vic-text) !important;
}

.badge.state-qld,
.badge[data-state="qld"] {
    background: var(--qld-bg) !important;
    color: var(--qld-text) !important;
}

.badge.state-wa,
.badge[data-state="wa"] {
    background: var(--wa-bg) !important;
    color: var(--wa-text) !important;
}

.badge.state-sa,
.badge[data-state="sa"] {
    background: var(--sa-bg) !important;
    color: var(--sa-text) !important;
}

.badge.state-tas,
.badge[data-state="tas"] {
    background: var(--tas-bg) !important;
    color: var(--tas-text) !important;
}

.badge.state-act,
.badge[data-state="act"] {
    background: var(--act-bg) !important;
    color: var(--act-text) !important;
}

.badge.state-nt,
.badge[data-state="nt"] {
    background: var(--nt-bg) !important;
    color: var(--nt-text) !important;
}

.badge.state-act,
.badge.state-nsw,
.badge.state-nt,
.badge.state-qld,
.badge.state-sa,
.badge.state-tas,
.badge.state-vic,
.badge.state-wa,
.badge[data-state="act"],
.badge[data-state="nsw"],
.badge[data-state="nt"],
.badge[data-state="qld"], 
.badge[data-state="sa"],
.badge[data-state="tas"],
.badge[data-state="vic"],
.badge[data-state="wa"] {
    width: 3rem !important;
}

.badge {
    border-radius: 0 !important;
}

/* Shorts Color Badge Classes */
.badge-shorts-red {
    background-color: #dc3545 !important;
    color: white !important;
}

.badge-shorts-blue {
    background-color: #0d6efd !important;
    color: white !important;
}

.badge-shorts-green {
    background-color: #198754 !important;
    color: white !important;
}

.badge-shorts-yellow {
    background-color: #ffc107 !important;
    color: black !important;
}

.badge-shorts-unrestricted {
    background-color: #6c757d !important;
    color: white !important;
}

/* Icon utility classes */
.icon-large {
    font-size: 1.2em;
}

/* Hero Section Enhancements */
.hero-section,
.bg-primary {
    background: linear-gradient(135deg, var(--rugby-green) 0%, var(--rugby-dark-green) 100%) !important;
    color: white;
}

.bg-tertiary {
    background: linear-gradient(135deg, var(--rugby-gold) 0%, #e6c200 100%) !important;
}

.hero-section {
    padding: 4rem 0;
    margin-bottom: 2rem;
}

.hero-section h1 {
    font-weight: 700;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.hero-section .lead {
    font-size: 1.25rem;
    opacity: 0.9;
}

/* Enhanced Hero Banner */
.hero-banner {
    background: linear-gradient(180deg, var(--rugby-gold) 0%, var(--rugby-green) 100%) !important;
    position: relative;
    overflow: hidden;
    min-height: 400px;
    display: flex;
    align-items: center;
}

.hero-background-pattern {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image:
        radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.05) 0%, transparent 50%),
        radial-gradient(circle at 40% 80%, rgba(255, 255, 255, 0.08) 0%, transparent 50%);
    animation: float 6s ease-in-out infinite;
}

.hero-title {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--rugby-dark-green);
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
    margin-bottom: 1rem;
    animation: slideInFromTop 1s ease-out;
}

.hero-content {
    animation: slideInFromRight 1s ease-out 0.3s both;
}

.hero-description .lead {
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--rugby-dark-green);
    font-weight: 500;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
}

.logo-container {
    animation: slideInFromLeft 1s ease-out 0.1s both;
    padding-left: 1rem;
}

.hero-logo {
    max-height: 280px;
    filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.3));
    transition: transform 0.3s ease;
}

.hero-logo:hover {
    transform: scale(1.05) rotate(2deg);
}

/* Hero Action Buttons */
.hero-actions {
    animation: slideInFromBottom 1s ease-out 0.9s both;
}

.hero-btn {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 50px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.hero-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.hero-btn.btn-tertiary {
    background: linear-gradient(45deg, var(--rugby-gold), #f0c800);
    border: none;
    color: var(--rugby-dark-green);
}

.hero-btn.btn-tertiary:hover {
    background: linear-gradient(45deg, #f0c800, var(--rugby-gold));
    color: var(--rugby-dark-green);
}

.hero-btn.btn-outline-tertiary {
    background: rgba(255, 255, 255, 0.1);
    border: 2px solid var(--rugby-gold);
    color: var(--rugby-gold);
    backdrop-filter: blur(10px);
}

.hero-btn.btn-outline-tertiary:hover {
    background: var(--rugby-gold);
    border-color: var(--rugby-gold);
    color: var(--rugby-dark-green) !important;
}

/* Animation Keyframes */
@keyframes float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-10px); }
}

@keyframes slideInFromTop {
    from { opacity: 0; transform: translateY(-30px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideInFromRight {
    from { opacity: 0; transform: translateX(30px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes slideInFromLeft {
    from { opacity: 0; transform: translateX(-30px); }
    to { opacity: 1; transform: translateX(0); }
}

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

/* Statistics Runner */
.stats-runner {
    background: linear-gradient(135deg, #343a40 0%, #23272b 100%) !important;
    border-top: 3px solid var(--rugby-gold);
    animation: slideInFromBottom 1s ease-out 0.6s both;
}

.stat-item-small {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.5rem;
}

.stat-number-small {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--rugby-gold);
    line-height: 1;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
}

.stat-label-small {
    font-size: 0.75rem;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 0.25rem;
}

/* Social Media Links */
.social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.social-links a,
.social-links .btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 20px;
    padding: 6px 12px;
    font-size: 0.875rem;
    text-decoration: none;
    transition: all 0.2s ease;
}

.social-links a {
    margin-right: 12px;
    margin-bottom: 8px;
    /* background-color: rgba(255,255,255,0.8);
    border: 1px solid rgba(0,0,0,0.1); */
}

.social-links a:hover,
.social-links .btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    text-decoration: none;
}

.social-links a i,
.social-links .btn i {
    font-size: 1.1rem;
}

.card-body .social-links {
    margin-top: 8px;
}

.card-body .social-links .btn {
    font-size: 0.8rem;
    padding: 4px 8px;
}

/* Social Media Platform Colors */
.label-facebook {
    color: #1877f2;
}
.label-youtube {
    color: #ff0000;
}
.label-instagram {
    color: #cc0000;
}
.label-twitter-x {
    color: #000000;
}

.label-whatsapp {
    color: #25d366;
}

.btn-facebook:not(:disabled):not(.disabled) { background-color: #1877f2; border-color: #1877f2; color: white; }
.btn-facebook:hover, .btn-facebook:focus, .btn-facebook:active { background-color: #166fe5; border-color: #166fe5; color: white; box-shadow: 0 0 0 0.2rem rgba(24, 119, 242, 0.25); }
.btn-youtube, .btn-youtube:not(:disabled):not(.disabled) { background-color: #ff0000; border-color: #ff0000; color: white; }
.btn-youtube:hover, .btn-youtube:focus, .btn-youtube:active { background-color: #cc0000; border-color: #cc0000; color: white; box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.25); }
.btn-instagram:not(:disabled):not(.disabled) { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); border-color: #e6683c; color: white; }
.btn-instagram:hover, .btn-instagram:focus, .btn-instagram:active { background: linear-gradient(45deg, #d6821f 0%, #cc5a28 25%, #c22336 50%, #b81f52 75%, #a8146e 100%); border-color: #cc5a28; color: white; box-shadow: 0 0 0 0.2rem rgba(230, 104, 60, 0.25); }
.btn-twitter-x, .btn-twitter-x:not(:disabled):not(.disabled) { background-color: #000000; border-color: #000000; color: white; }
.btn-twitter-x:hover, .btn-twitter-x:focus, .btn-twitter-x:active { background-color: #333333; border-color: #333333; color: white; box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.25); }
.btn-twitter-x, .btn-twitter-x:not(:disabled):not(.disabled) { background-color: #000000; border-color: #000000; color: white; }


.btn-facebook i, .btn-youtube i, .btn-instagram i, .btn-twitter-x i {
    color: white;
}

/* Footer Enhancements */
.footer,
.bg-dark {
    background: linear-gradient(135deg, #343a40 0%, #23272b 100%) !important;
    color: white;
}

.footer {
    padding: 2rem 0;
    margin-top: 4rem;
}

.footer a {
    color: #adb5bd;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer a:hover {
    color: var(--rugby-gold);
}

/* Alert Enhancements */
.alert {
    border: none;
    border-radius: 0.5rem;
    font-weight: 500;
}

.alert-success { background-color: var(--rugby-light-green); color: var(--rugby-dark-green); border-left: 4px solid var(--rugby-green); }
.alert-info { background-color: #e8f5e8; color: #2e7d32; border-left: 4px solid var(--rugby-green); }
.alert-warning { background-color: #fff3cd; color: #856404; border-left: 4px solid var(--rugby-gold); }
.alert-danger { background-color: #f8d7da; color: #721c24; border-left: 4px solid #dc3545; }

/* Dark mode alert styling */
[data-theme="dark"] .alert-success { background-color: rgba(76, 175, 80, 0.2); color: #81c784; border-left-color: #4caf50; }
[data-theme="dark"] .alert-info { background-color: rgba(76, 175, 80, 0.15); color: #a5d6a7; border-left-color: var(--rugby-green); }
[data-theme="dark"] .alert-warning { background-color: rgba(255, 193, 7, 0.2); color: #ffc107; border-left-color: var(--rugby-gold); }
[data-theme="dark"] .alert-danger { background-color: rgba(244, 67, 54, 0.2); color: #ef5350; border-left-color: #f44336; }

/* Search and Filter Section */
.filter-section {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-radius: 0.75rem;
    padding: 1.5rem;
    margin-bottom: 2rem;
    border: 2px solid var(--rugby-light-green);
}

/* Loading Spinner */
.btn.loading::after {
    border-top: 2px solid var(--rugby-gold);
}

/* Image Carousel Styles */
.image-carousel-container {
    position: relative;
    max-width: 100%;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 0.5rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    background: white;
}

.image-carousel {
    position: relative;
    height: 400px;
    width: 100%;
    overflow: hidden;
}

.carousel-track-container {
    background: #f8f9fa;
    height: 100%;
    position: relative;
    overflow: hidden;
}

.carousel-track {
    padding: 0;
    margin: 0;
    list-style: none;
    position: relative;
    height: 100%;
}

.carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transition: opacity 600ms ease-in-out, visibility 600ms ease-in-out;
    will-change: opacity;
}

.carousel-slide.current-slide {
    opacity: 1;
    visibility: visible;
}

.carousel-images-group {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    height: 100%;
    padding: 1rem;
}

.carousel-image-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 0.5rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.carousel-image-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

.carousel-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.3s ease;
}

.carousel-image-wrapper:hover .carousel-image {
    transform: scale(1.05);
}

.carousel-image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.3) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
    display: flex;
    align-items: flex-end;
    padding: 1rem;
}

.carousel-image-wrapper:hover .carousel-image-overlay {
    opacity: 1;
}

.carousel-image-info {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.carousel-image-info .badge {
    font-size: 0.8rem;
    padding: 0.4rem 0.8rem;
    border-radius: 0.25rem;
    text-transform: capitalize;
}

.carousel-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 1rem;
    cursor: pointer;
    z-index: 2;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}

.carousel-button:hover {
    background: rgba(0, 0, 0, 0.8);
    transform: translateY(-50%) scale(1.1);
}

.carousel-button--left { left: 1rem; }
.carousel-button--right { right: 1rem; }

.carousel-button i {
    font-size: 1.2rem;
}

.carousel-nav {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.5rem;
    z-index: 2;
}

.carousel-indicator {
    border: none;
    border-radius: 50%;
    width: 12px;
    height: 12px;
    background: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    transition: all 0.3s ease;
}

.carousel-indicator.current-slide,
.carousel-indicator:hover {
    background: white;
    transform: scale(1.2);
}

.image-carousel.loading {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: loading 1.5s infinite;
}

@keyframes loading {
    from { background-position: 200% 0; }
    to { background-position: -200% 0; }
}

/* Responsive Carousel */
@media (max-width: 768px) {
    .image-carousel { height: 300px; }
    .carousel-images-group {
        grid-template-columns: 1fr;
        gap: 0.5rem;
        padding: 0.5rem;
    }
    .carousel-button { width: 40px; height: 40px; padding: 0.75rem; }
    .carousel-button--left { left: 0.5rem; }
    .carousel-button--right { right: 0.5rem; }
    .carousel-image-overlay { padding: 0.75rem; }
    .carousel-image-info .badge { font-size: 0.7rem; padding: 0.3rem 0.6rem; }
}

@media (max-width: 992px) and (min-width: 769px) {
    .carousel-images-group {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }
}

@media (max-width: 480px) {
    .image-carousel { height: 250px; }
    .carousel-button { width: 35px; height: 35px; }
    .carousel-button i { font-size: 1rem; }
}

/* Dark Mode Carousel Styling */
[data-theme="dark"] .carousel-images-group {
    background-color: var(--theme-bg-primary);
}

/* Email Subscription Section */
#subscribe,
.bg-tertiary {
    background-color: var(--theme-bg-secondary) !important;
}

[data-theme="dark"] #subscribe,
[data-theme="dark"] .bg-tertiary {
    background-color: var(--theme-bg-secondary) !important;
}

/* Dark Mode Text Improvements */
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3,
[data-theme="dark"] h4, [data-theme="dark"] h5, [data-theme="dark"] h6,
[data-theme="dark"] p, [data-theme="dark"] .lead,
[data-theme="dark"] #subscribe h2, [data-theme="dark"] #subscribe .h3,
[data-theme="dark"] #subscribe p,
[data-theme="dark"] section h2, [data-theme="dark"] section .h3,
[data-theme="dark"] section p {
    color: var(--theme-text-primary) !important;
}

/* Exceptions for elements that should not change color in dark mode */
[data-theme="dark"] .hero-title,
[data-theme="dark"] .hero-description .lead {
    color: var(--rugby-dark-green) !important;
}

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

/* Bootstrap Nav Tabs Dark Mode */
[data-theme="dark"] .nav-tabs {
    border-bottom-color: var(--theme-border-color) !important;
    background-color: transparent !important;
}

[data-theme="dark"] .nav-tabs .nav-link {
    color: var(--theme-text-secondary) !important;
    background-color: transparent !important;
    border-color: transparent !important;
}

[data-theme="dark"]  .file-upload-area {
    border: 2px dashed var(--theme-border-color);
    background-color: var(--theme-card-bg) !important;
}

[data-theme="dark"] .image-upload-area,
[data-theme="dark"] .document-upload-area {
    border-color: var(--theme-border-color) !important;
    background-color: var(--theme-card-bg) !important;
}

[data-theme="dark"] .image-upload-area:hover,
[data-theme="dark"] .document-upload-area:hover {
    border-color: var(--rugby-green) !important;
    background-color: var(--theme-bg-secondary) !important;
}

[data-theme="dark"] .nav-tabs .nav-link:hover,
[data-theme="dark"] .nav-tabs .nav-link:focus {
    color: var(--theme-text-primary) !important;
    background-color: transparent !important;
    border-color: var(--theme-border-color) !important;
    isolation: isolate;
}

[data-theme="dark"] .nav-tabs .nav-link.active,
[data-theme="dark"] .nav-tabs .nav-item.show .nav-link {
    color: var(--theme-text-primary) !important;
    background-color: transparent !important;
    border-color: var(--theme-border-color) var(--theme-border-color) var(--theme-card-bg) !important;
}

[data-theme="dark"] .tab-content,
[data-theme="dark"] .tab-pane {
    background-color: transparent !important;
    color: var(--theme-text-primary) !important;
}

/* Theme Toggle Button */
#themeToggle {
    transition: all 0.3s ease;
    border-radius: 50% !important;
    width: 38px !important;
    height: 38px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
    background-color: transparent !important;
    margin: 0 !important;
    align-self: center !important;
}

#themeToggle:hover {
    background-color: rgba(255, 255, 255, 0.2) !important;
    border-color: rgba(255, 255, 255, 0.6) !important;
    transform: scale(1.1);
}

#themeToggle:focus {
    background-color: rgba(255, 255, 255, 0.2) !important;
    border-color: var(--rugby-gold) !important;
    box-shadow: 0 0 0 2px rgba(255, 215, 0, 0.3) !important;
    outline: none !important;
}

#themeIcon {
    font-size: 1rem !important;
    transition: transform 0.3s ease;
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Custom Tooltip Styling - Primary Color with White Text and Fade Animation */
.tooltip {
    --bs-tooltip-bg: var(--bs-primary) !important;
    --bs-tooltip-color: #ffffff !important;
    /* Hide tooltip initially to prevent flash at bottom-left */
    opacity: 0 !important;
    /* Remove conflicting animations and transitions */
    animation: none !important;
    transition: opacity 0.15s ease-in-out 0.1s !important;
}

/* Show tooltip after Popper.js positioning is complete */
.tooltip.show {
    opacity: 1 !important;
}

.tooltip .tooltip-inner {
    background-color: var(--bs-primary) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
    /* Flexible width for longer tooltips */
    max-width: 300px !important;
    width: max-content !important;
    white-space: normal !important;
    word-wrap: break-word !important;
    line-height: 1.4 !important;
}

/* Tooltip Arrow Styling - All Directions */
.tooltip .tooltip-arrow::before {
    border-color: var(--bs-primary) transparent !important;
}

.tooltip.bs-tooltip-top .tooltip-arrow::before,
.tooltip.bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow::before {
    border-top-color: var(--bs-primary) !important;
}

.tooltip.bs-tooltip-end .tooltip-arrow::before,
.tooltip.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before {
    border-right-color: var(--bs-primary) !important;
}

.tooltip.bs-tooltip-bottom .tooltip-arrow::before,
.tooltip.bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow::before {
    border-bottom-color: var(--bs-primary) !important;
}

.tooltip.bs-tooltip-start .tooltip-arrow::before,
.tooltip.bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow::before {
    border-left-color: var(--bs-primary) !important;
}

/* Dark Theme Override - Keep Same Primary Color Styling */
[data-theme="dark"] .tooltip {
    --bs-tooltip-bg: var(--bs-primary) !important;
    --bs-tooltip-color: #ffffff !important;
}

[data-theme="dark"] .tooltip.show {
    opacity: 1 !important;
}

[data-theme="dark"] .tooltip .tooltip-inner {
    background-color: var(--bs-primary) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25) !important;
    /* Flexible width for longer tooltips */
    max-width: 300px !important;
    width: max-content !important;
    white-space: normal !important;
    word-wrap: break-word !important;
    line-height: 1.4 !important;
}

[data-theme="dark"] .tooltip .tooltip-arrow::before {
    border-color: var(--bs-primary) transparent !important;
}

[data-theme="dark"] .tooltip.bs-tooltip-top .tooltip-arrow::before,
[data-theme="dark"] .tooltip.bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow::before {
    border-top-color: var(--bs-primary) !important;
}

[data-theme="dark"] .tooltip.bs-tooltip-end .tooltip-arrow::before,
[data-theme="dark"] .tooltip.bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow::before {
    border-right-color: var(--bs-primary) !important;
}

[data-theme="dark"] .tooltip.bs-tooltip-bottom .tooltip-arrow::before,
[data-theme="dark"] .tooltip.bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow::before {
    border-bottom-color: var(--bs-primary) !important;
}

[data-theme="dark"] .tooltip.bs-tooltip-start .tooltip-arrow::before,
[data-theme="dark"] .tooltip.bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow::before {
    border-left-color: var(--bs-primary) !important;
}

/* Navbar Alignment */
.navbar-nav {
    align-items: center;
}

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

.navbar-nav .nav-item:has(#themeToggle) {
    justify-content: center !important;
    margin-right: 0.75rem !important;
}

/* Force white text for all dashboard stat card content */
.dashboard-stats .card .card-body,
.dashboard-stats .card .card-body *,
.dashboard-stats .card .card-body h1,
.dashboard-stats .card .card-body h2,
.dashboard-stats .card .card-body h3,
.dashboard-stats .card .card-body h4,
.dashboard-stats .card .card-body h5,
.dashboard-stats .card .card-body h6,
.dashboard-stats .card .card-body p,
.dashboard-stats .card .card-body span,
.dashboard-stats .card .card-body i,
.dashboard-stat-card .card-body,
.dashboard-stat-card .card-body *,
.dashboard-stat-card .card-body h1,
.dashboard-stat-card .card-body h2,
.dashboard-stat-card .card-body h3,
.dashboard-stat-card .card-body h4,
.dashboard-stat-card .card-body h5,
.dashboard-stat-card .card-body h6,
.dashboard-stat-card .card-body p,
.dashboard-stat-card .card-body span,
.dashboard-stat-card .card-body i {
    color: white !important;
}

/* Quick Start Checklist Styling */
#quickStartChecklist .list-group-item {
    background-color: var(--theme-card-bg);
    border-color: var(--theme-border-color);
    color: var(--theme-text-primary);
    transition: all 0.3s ease;
}

#quickStartChecklist .list-group-item:hover {
    background-color: var(--theme-bg-secondary);
}

#quickStartChecklist .list-group-item.checklist-completed {
    background-color: rgba(40, 167, 69, 0.1);
    border-left: 4px solid var(--rugby-green);
}

[data-theme="dark"] #quickStartChecklist .list-group-item.checklist-completed {
    background-color: rgba(76, 175, 80, 0.15);
    border-left: 4px solid var(--rugby-green);
}

/* Checklist checkbox styling */
.checklist-item {
    transform: scale(1.2);
    margin-right: 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.checklist-item:hover {
    transform: scale(1.3);
}

.checklist-item:checked {
    background-color: var(--rugby-green);
    border-color: var(--rugby-green);
    cursor: default;
}

.checklist-item:disabled {
    opacity: 0.8;
    cursor: default;
}

/* Checklist success animation */
@keyframes checklistSuccess {
    0% {
        transform: translate(-50%, -50%) scale(0);
        opacity: 0;
    }
    50% {
        transform: translate(-50%, -50%) scale(1.2);
        opacity: 1;
    }
    100% {
        transform: translate(-50%, -50%) scale(1);
        opacity: 0;
    }
}

/* Checklist label styling */
#quickStartChecklist .list-group-item label {
    cursor: pointer;
    margin-bottom: 0;
    transition: all 0.3s ease;
}

#quickStartChecklist .list-group-item label:hover {
    color: var(--rugby-green);
}

#quickStartChecklist .list-group-item.checklist-completed label {
    cursor: default;
}

/* Checklist action buttons */
#quickStartChecklist .btn-sm {
    transition: all 0.3s ease;
}

#quickStartChecklist .btn-sm:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 104, 55, 0.2);
}

/* Dark mode checklist styling */
[data-theme="dark"] #quickStartChecklist .list-group-item {
    background-color: var(--theme-card-bg);
    border-color: var(--theme-border-color);
    color: var(--theme-text-primary);
}

[data-theme="dark"] #quickStartChecklist .list-group-item:hover {
    background-color: var(--theme-bg-tertiary);
}

[data-theme="dark"] #quickStartChecklist .list-group-item label:hover {
    color: var(--rugby-gold);
}

[data-theme="dark"] .checklist-item:checked {
    background-color: var(--rugby-green);
    border-color: var(--rugby-green);
}

/* State Selector Dropdown Component */
.state-selector-container {
    position: relative;
    width: 100%;
}

.state-selector-dropdown {
    position: relative;
}

.state-selector-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-align: left;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    cursor: pointer;
    padding: 0.375rem 0.75rem;
    min-height: 38px;
}

.state-selector-toggle:hover {
    border-color: var(--bs-primary);
}

.state-selector-toggle[aria-expanded="true"] {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

.state-selector-toggle[aria-expanded="true"] .bi-chevron-down {
    transform: rotate(180deg);
}

.state-selector-toggle .bi-chevron-down {
    transition: transform 0.2s ease;
}

.state-selector-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1050;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.375rem;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    margin-top: 0.125rem;
    display: none;
    max-height: 300px;
    overflow-y: auto;
}

.state-selector-menu.show {
    display: block;
}

.state-selector-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-light);
}

.state-selector-header .btn-link {
    font-size: 0.875rem;
    text-decoration: none;
    color: var(--bs-primary);
}

.state-selector-header .btn-link:hover {
    color: var(--bs-primary);
    text-decoration: underline;
}

.state-options {
    padding: 0.25rem 0;
}

.state-option {
    display: flex;
    align-items: center;
    padding: 0.5rem 0.75rem;
    margin: 0;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.state-option:hover {
    background-color: var(--bs-light);
}

.state-option input[type="checkbox"] {
    margin-right: 0.5rem;
    cursor: pointer;
}

.state-badge {
    margin-right: 0.5rem;
    font-size: 0.75rem;
    padding: 0.25rem 0.4rem;
    border-radius: 0.25rem;
    font-weight: 600;
    min-width: 2.5rem;
    text-align: center;
}

.state-name {
    font-size: 0.875rem;
    color: var(--bs-body-color);
}

.selected-text {
    color: var(--bs-body-color);
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    flex: 1;
}

.selected-text.has-selection {
    color: var(--bs-body-color);
    font-weight: 500;
}

/* Dark mode support */
[data-bs-theme="dark"] .state-selector-toggle {
    background: var(--bs-dark);
    border-color: var(--bs-border-color-translucent);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .state-selector-menu {
    background: var(--bs-dark);
    border-color: var(--bs-border-color-translucent);
}

[data-bs-theme="dark"] .state-selector-header {
    background: var(--bs-gray-800);
    border-color: var(--bs-border-color-translucent);
}

[data-bs-theme="dark"] .state-option:hover {
    background-color: var(--bs-gray-800);
}

/* Responsive adjustments */
@media (max-width: 767.98px) {
    .state-selector-menu {
        position: fixed;
        top: auto !important;
        left: 1rem !important;
        right: 1rem !important;
        bottom: 1rem;
        max-height: 60vh;
        border-radius: 0.5rem;
    }
}

/* ==========================================================================
   Help Modal Styles
   ========================================================================== */

/* Help Modal Container */
#global-help-modal .modal-dialog {
    max-width: 700px;
    margin: 2rem auto;
}

/* Help Modal Content */
#global-help-modal .modal-content {
    border: none;
    border-radius: 1rem;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.2);
    overflow: hidden;
}

/* Help Modal Header */
#global-help-modal .modal-header {
    background: linear-gradient(135deg, var(--rugby-green) 0%, var(--rugby-dark-green) 100%);
    color: white;
    border-bottom: none;
    padding: 1.5rem 2rem;
    position: relative;
}

#global-help-modal .modal-header::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 0;
    right: 0;
    height: 20px;
    background: linear-gradient(135deg, var(--rugby-green) 0%, var(--rugby-dark-green) 100%);
    clip-path: polygon(0 0, 100% 0, 95% 100%, 5% 100%);
}

#global-help-modal .modal-title {
    font-weight: 600;
    font-size: 1.5rem;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

#global-help-modal .modal-title::before {
    content: "💡";
    font-size: 1.8rem;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

#global-help-modal .btn-close {
    background: rgba(255, 255, 255, 0.95);
    border-radius: 50%;
    width: 2.75rem;
    height: 2.75rem;
    opacity: 1;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    filter: none;
    border: none;
    position: relative;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    backdrop-filter: blur(10px);
}

#global-help-modal .btn-close:hover {
    background: rgba(255, 255, 255, 1);
    transform: scale(1.05) rotate(90deg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
}

#global-help-modal .btn-close:active {
    transform: scale(0.95);
    transition: all 0.1s ease;
}

#global-help-modal .btn-close::before,
#global-help-modal .btn-close::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 2px;
    background: var(--rugby-dark-green);
    border-radius: 1px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#global-help-modal .btn-close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

#global-help-modal .btn-close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

#global-help-modal .btn-close:hover::before,
#global-help-modal .btn-close:hover::after {
    background: var(--rugby-green);
    width: 20px;
}

/* Help Modal Body */
#global-help-modal .modal-body {
    padding: 2rem;
    background: var(--theme-card-bg);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--theme-text-primary);
}

/* Help Content Typography */
#global-help-modal .modal-body h1,
#global-help-modal .modal-body h2,
#global-help-modal .modal-body h3,
#global-help-modal .modal-body h4,
#global-help-modal .modal-body h5,
#global-help-modal .modal-body h6 {
    color: var(--rugby-dark-green);
    margin-top: 1.5rem;
    margin-bottom: 1rem;
    font-weight: 600;
}

#global-help-modal .modal-body h2 {
    font-size: 1.4rem;
    border-bottom: 2px solid var(--rugby-gold);
    padding-bottom: 0.5rem;
}

#global-help-modal .modal-body h3 {
    font-size: 1.25rem;
    color: var(--rugby-green);
}

#global-help-modal .modal-body p {
    margin-bottom: 1.25rem;
    color: var(--theme-text-primary);
}

#global-help-modal .modal-body ul,
#global-help-modal .modal-body ol {
    margin-bottom: 1.25rem;
    padding-left: 1.75rem;
}

#global-help-modal .modal-body li {
    margin-bottom: 0.5rem;
    color: var(--theme-text-primary);
}

#global-help-modal .modal-body li::marker {
    color: var(--rugby-green);
}

/* Help Content Code and Pre-formatted Text */
#global-help-modal .modal-body code {
    background: rgba(var(--rugby-green), 0.1);
    color: var(--rugby-dark-green);
    padding: 0.25rem 0.5rem;
    border-radius: 0.375rem;
    font-size: 0.9rem;
    border: 1px solid rgba(var(--rugby-green), 0.2);
}

#global-help-modal .modal-body pre {
    background: var(--theme-bg-tertiary);
    border: 1px solid var(--theme-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    overflow-x: auto;
    font-size: 0.875rem;
}

/* Help Content Links */
#global-help-modal .modal-body a {
    color: var(--rugby-link-green);
    text-decoration: none;
    font-weight: 500;
    border-bottom: 1px solid transparent;
    transition: all 0.3s ease;
}

#global-help-modal .modal-body a:hover {
    color: var(--rugby-link-green-hover);
    border-bottom-color: var(--rugby-gold);
    text-decoration: none;
}

/* Help Content Blockquotes */
#global-help-modal .modal-body blockquote {
    border-left: 4px solid var(--rugby-gold);
    background: rgba(var(--rugby-gold), 0.1);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    border-radius: 0 0.5rem 0.5rem 0;
    font-style: italic;
}

/* Help Content Tables */
#global-help-modal .modal-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.5rem 0;
    background: var(--theme-card-bg);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

#global-help-modal .modal-body th,
#global-help-modal .modal-body td {
    padding: 0.875rem;
    text-align: left;
    border-bottom: 1px solid var(--theme-border-color);
}

#global-help-modal .modal-body th {
    background: var(--rugby-green);
    color: white;
    font-weight: 600;
}

#global-help-modal .modal-body tr:last-child td {
    border-bottom: none;
}

#global-help-modal .modal-body tr:hover {
    background: var(--theme-bg-secondary);
}

/* Help Modal Responsive Design */
@media (max-width: 768px) {
    #global-help-modal .modal-dialog {
        margin: 1rem;
        max-width: none;
    }
    
    #global-help-modal .modal-header {
        padding: 1.25rem 1.5rem;
    }
    
    #global-help-modal .modal-title {
        font-size: 1.25rem;
    }
    
    #global-help-modal .modal-body {
        padding: 1.5rem;
        font-size: 0.95rem;
    }
}

/* Help Modal Animation */
#global-help-modal.fade .modal-dialog {
    transition: transform 0.4s ease-out, opacity 0.4s ease-out;
    transform: translate(0, -50px) scale(0.95);
}

#global-help-modal.show .modal-dialog {
    transform: none;
}

/* Dark Theme Support for Help Modal */
[data-theme="dark"] #global-help-modal .modal-body {
    background: var(--theme-card-bg);
    color: var(--theme-text-primary);
}

[data-theme="dark"] #global-help-modal .modal-body code {
    background: rgba(255, 215, 0, 0.15);
    color: var(--rugby-gold);
    border-color: rgba(255, 215, 0, 0.3);
}

[data-theme="dark"] #global-help-modal .modal-body blockquote {
    background: rgba(255, 215, 0, 0.1);
}

[data-theme="dark"] #global-help-modal .modal-body th {
    background: var(--rugby-dark-green);
}

/* File Input Hidden Utility */
.file-input-hidden {
    display: none !important;
}