/* /Components/CharacterForm.razor.rz.scp.css */
/* CharacterForm styles simplified to use global theme tokens.
   Rely on `--text-primary`, `--card-bg`, `--input-bg`, `--accent-success`,
   and `--accent-danger` which are defined in the site-level CSS. This
   removes duplicated light/dark rules and prefers tokens so `data-theme`
   or `prefers-color-scheme` can control appearance globally. */

.player-name-input[b-8e4hpogg9n] {
  background-color: var(--input-bg, #f8f9fa);
  color: var(--text-primary, #212529);
  caret-color: var(--text-primary, #212529);
}
.player-name-input[b-8e4hpogg9n]::placeholder {
  color: var(--text-secondary, rgba(0,0,0,0.6));
}

.spec-card[b-8e4hpogg9n] {
  transition: all 0.2s ease;
  cursor: pointer;
  background-color: var(--card-bg, #ffffff);
  color: var(--text-primary, #212529);
  box-shadow: 0 4px 8px var(--shadow-color, rgba(0,0,0,0.1));
}
.spec-card:hover[b-8e4hpogg9n] { transform: translateY(-2px); box-shadow: 0 6px 18px var(--shadow-color, rgba(0,0,0,0.12)); }
.spec-card.selected[b-8e4hpogg9n] { transform: translateY(-1px); box-shadow: 0 4px 10px var(--shadow-color-strong, rgba(0,0,0,0.15)); }

/* Use theme tokens for selected/border accents. Keep fallbacks for safety. */
.spec-main.selected[b-8e4hpogg9n] {
  border-color: var(--accent-success, #198754) !important;
}
.spec-alt.selected[b-8e4hpogg9n] {
  border-color: var(--btn-info-bg, #0dcaf0) !important;
}
.midnight-card[b-8e4hpogg9n] {
  background-color: var(--card-bg, #ffffff);
}
.midnight-card.selected[b-8e4hpogg9n] {
  border-color: var(--badge-on-accent, #9333ea) !important;
}
.midnight-card img[b-8e4hpogg9n] { filter: none; }

/* Ensure focus/outline is visible in both themes */
.player-name-input:focus[b-8e4hpogg9n] {
  outline: 2px solid rgba(13,110,253,0.25);
  outline-offset: 1px;
}

/* Labels and helper text follow global tokens */
.card-body .form-label[b-8e4hpogg9n] { color: var(--text-primary, #212529); }
.card-body .form-label .text-danger[b-8e4hpogg9n] { color: var(--accent-danger, #dc3545); }
.card-body .form-text[b-8e4hpogg9n] { color: var(--text-secondary, #6c757d); }

/* /Components/GuildStatsCard.razor.rz.scp.css */
/* GuildStatsCard scoped styles with dark-mode support */
.collapsible-header:hover[b-8eeajaig4n] {
    background-color: rgba(255, 255, 255, 0.03) !important;
}

.bg-gradient-info[b-8eeajaig4n] {
    background: linear-gradient(135deg, #17a2b8 0%, #138496 100%) !important;
}

.bg-gradient-success[b-8eeajaig4n] {
    background: linear-gradient(135deg, #28a745 0%, #1e7e34 100%) !important;
}

.bg-gradient-secondary[b-8eeajaig4n] {
    background: linear-gradient(135deg, #6c757d 0%, #545b62 100%) !important;
}

.bg-gradient-primary[b-8eeajaig4n] {
    background: linear-gradient(135deg, #007bff 0%, #0056b3 100%) !important;
}

.card[b-8eeajaig4n] {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.card:hover[b-8eeajaig4n] {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
}

.badge-sm[b-8eeajaig4n] {
    font-size: 0.7rem;
    padding: 0.25rem 0.5rem;
}

.class-icon-container[b-8eeajaig4n] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.5) 100%);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    transition: all 0.2s ease;
}

.class-icon-container:hover[b-8eeajaig4n] {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.chart-container[b-8eeajaig4n] {
    position: relative;
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}

.chart-container canvas[b-8eeajaig4n] {
    width: 100% !important;
    height: auto !important;
    max-height: 600px;
}

.midnight-icon-container[b-8eeajaig4n] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.9);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
    transition: all 0.2s ease;
}

.midnight-icon-container:hover[b-8eeajaig4n] {
    transform: scale(1.1);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

/* Per-class cards */
.class-card[b-8eeajaig4n] {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}
.class-card.empty[b-8eeajaig4n] {
    background: linear-gradient(135deg, #ffe5e5 0%, #ffcccc 100%);
}
.class-name[b-8eeajaig4n] { color: #212529; }
.badge-midnight[b-8eeajaig4n] { background-color: #9333ea; color: #fff; }

@media (prefers-color-scheme: dark) {
    .collapsible-header:hover[b-8eeajaig4n] { background-color: rgba(255,255,255,0.03) !important; }
    .class-card[b-8eeajaig4n] { background: linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.03)); }
    .class-card.empty[b-8eeajaig4n] { background: linear-gradient(135deg, rgba(255,0,0,0.04), rgba(255,0,0,0.02)); }
    .class-name[b-8eeajaig4n] { color: #e9eef8; }
    .class-icon-container[b-8eeajaig4n] { background: linear-gradient(135deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.02) 100%); box-shadow: 0 2px 8px rgba(0,0,0,0.6); }
    .badge-midnight[b-8eeajaig4n] { background-color: #b27bff; }
    .badge.bg-success[b-8eeajaig4n] { background-color: #2eb04b !important; }
    .badge.bg-info[b-8eeajaig4n] { background-color: #3fc7eb !important; color: #000 !important; }
}
/* /Components/InteractiveMapComponent.razor.rz.scp.css */
/* Theme-aware styles for InteractiveMapComponent - use tokens so light/dark adapt automatically */
.filter-panel[b-t4hdmiov4n] {
  background-color: var(--app-surface);
  border: 1px solid var(--app-border);
  border-radius: 8px;
  padding: 15px;
  margin-bottom: 20px;
  color: var(--app-text);
}

.filter-heading[b-t4hdmiov4n] {
  margin-bottom: 0;
  color: var(--app-text);
}

.pref-1[b-t4hdmiov4n] {
  color: var(--pref-1, #28a745);
  font-weight: bold;
}
.pref-2[b-t4hdmiov4n] {
  color: var(--pref-2, #ffc107);
  font-weight: bold;
}
.pref-3[b-t4hdmiov4n] {
  color: var(--pref-3, #dc3545);
  font-weight: bold;
}
.available-label[b-t4hdmiov4n] {
  color: var(--app-muted);
  font-weight: bold;
}
.show-houses-label[b-t4hdmiov4n] {
  color: var(--app-text);
  font-weight: bold;
}

/* Slightly muted text for supporting copy */
.filter-panel .text-muted[b-t4hdmiov4n] {
  color: var(--app-muted);
}

/* Map hint / small text in the component */
.map-hint[b-t4hdmiov4n] {
  color: var(--app-muted);
}

/* Keep a fallback for older browsers that don't support tokens */
@supports not (color: var(--app-text)) {
  .filter-panel[b-t4hdmiov4n] { background-color: #e9ecef; border-color: #dee2e6; color: #495057; }
  .filter-panel .text-muted[b-t4hdmiov4n], .map-hint[b-t4hdmiov4n] { color: #6c757d; }
  .pref-1[b-t4hdmiov4n] { color: #28a745; }
  .pref-2[b-t4hdmiov4n] { color: #ffc107; }
  .pref-3[b-t4hdmiov4n] { color: #dc3545; }
  .available-label[b-t4hdmiov4n] { color: #6c757d; }
  .show-houses-label[b-t4hdmiov4n] { color: #343a40; }
}
/* /Components/RoleDistributionCard.razor.rz.scp.css */
/* RoleDistributionCard styles with dark-mode support */
.role-card[b-zkhepfmrqq] {
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.role-card .card-body[b-zkhepfmrqq] { padding-top: 1rem; padding-bottom: 1rem; }

.role-card-tank[b-zkhepfmrqq] {
  background: linear-gradient(135deg, #0069d9 0%, #004b9e 100%);
}
.role-card-healer[b-zkhepfmrqq] {
  background: linear-gradient(135deg, #28a745 0%, #1e7e34 100%);
}
.role-card-dps[b-zkhepfmrqq] {
  background: linear-gradient(135deg, #dc3545 0%, #a71d2a 100%);
}

.role-card .opacity-75[b-zkhepfmrqq] { opacity: 0.85; }

@media (prefers-color-scheme: dark) {
  .role-card-tank[b-zkhepfmrqq] { background: linear-gradient(135deg, #0b5ed7 0%, #063b8a 100%); }
  .role-card-healer[b-zkhepfmrqq] { background: linear-gradient(135deg, #2eb04b 0%, #16692a 100%); }
  .role-card-dps[b-zkhepfmrqq] { background: linear-gradient(135deg, #ff6b6b 0%, #9a1b22 100%); }

  .role-card .opacity-75[b-zkhepfmrqq] { opacity: 0.85; color: rgba(255,255,255,0.85); }
}
/* /Components/SpecializationChips.razor.rz.scp.css */
/* Theme-aware styles for SpecializationChips */
.spec-chips[b-w1dgd02igk] { display:flex; flex-wrap:wrap; gap:0.5rem; align-items:flex-start; }
.spec-pill[b-w1dgd02igk] { display:inline-flex; align-items:stretch; font-size:0.75rem; max-width:100%; }
.spec-pill-small[b-w1dgd02igk] { font-size:0.72rem; }

/* Accent area (color usually supplied by component-specific classes or inline styles) */
.spec-accent[b-w1dgd02igk] { display:inline-flex; align-items:center; justify-content:center; width:1.6rem; padding:0.25rem; border-radius:0.35rem 0 0 0.35rem; color: var(--badge-on-accent, #fff); }
.spec-pill .spec-accent[b-w1dgd02igk] { width:1.1rem; padding:0.18rem; border-radius:0.25rem 0 0 0.25rem; }

/* Content surface uses the theme surface token so it adapts to light/dark */
.spec-content[b-w1dgd02igk] { display:inline-flex; align-items:center; gap:0.45rem; padding:0.22rem 0.6rem; border-radius:0 0.35rem 0.35rem 0; background: var(--app-surface); color: var(--app-text); box-shadow: 0 0 0 1px rgba(0,0,0,0.03) inset; max-width:22rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.spec-content-child[b-w1dgd02igk] { background: var(--app-surface); }
.spec-title[b-w1dgd02igk] { font-weight:600; }

/* Ensure spec-title follows theme: black in light mode, white in dark mode */
html[data-theme="light"] .spec-title[b-w1dgd02igk] { color: #000 !important; }
html[data-theme="dark"] .spec-title[b-w1dgd02igk] { color: #fff !important; }
.spec-options[b-w1dgd02igk] { color: var(--app-muted); font-size:0.72rem; margin-left:0.25rem; }
.more-toggle[b-w1dgd02igk] { cursor:pointer; font-size:0.75rem; margin-left:0.4rem; color: var(--link-color); }
.spec-toggle-btn[b-w1dgd02igk] { background:transparent; border:0; }
.spec-node[b-w1dgd02igk] { display:flex; flex-direction:column; align-items:flex-start; }
.spec-angle-icon[b-w1dgd02igk] { font-size:0.7rem; color: var(--badge-on-accent, #fff); }
.spec-badge[b-w1dgd02igk] { font-size:0.65rem; background: var(--app-border); color: var(--app-text); }

/* Ensure stronger contrast in dark mode via theme tokens (no separate media query needed) */
html[data-theme="dark"] .spec-content[b-w1dgd02igk], html[data-theme="dark"] .spec-content-child[b-w1dgd02igk] {
  background: var(--app-surface) !important;
  color: var(--app-text) !important;
  box-shadow: none;
  border-color: var(--app-border);
}

html[data-theme="dark"] .spec-options[b-w1dgd02igk] { color: var(--app-muted); }
html[data-theme="dark"] .more-toggle[b-w1dgd02igk] { color: var(--link-color); }

/* Fallback for older browsers without CSS variable support */
@supports not (color: var(--app-text)) {
  .spec-content[b-w1dgd02igk] { background:#fff; color:#212529; }
  .spec-content-child[b-w1dgd02igk] { background:#f8f9fa; }
  .spec-options[b-w1dgd02igk] { color:#6c757d; }
  .more-toggle[b-w1dgd02igk] { color: #0071c1; }
  .spec-angle-icon[b-w1dgd02igk], .spec-accent[b-w1dgd02igk] { color:#fff; }
  .spec-badge[b-w1dgd02igk] { background-color: rgba(0,0,0,0.03); color: #212529; }
}

/* Chevron color overrides to match spec-title in light/dark themes */
html[data-theme="light"] .spec-content i.fas.fa-chevron-up[b-w1dgd02igk],
html[data-theme="light"] .spec-content i.fas.fa-chevron-down[b-w1dgd02igk],
html[data-theme="light"] .spec-content-child i.fas.fa-chevron-up[b-w1dgd02igk],
html[data-theme="light"] .spec-content-child i.fas.fa-chevron-down[b-w1dgd02igk] {
  color: #000 !important;
}

html[data-theme="dark"] .spec-content i.fas.fa-chevron-up[b-w1dgd02igk],
html[data-theme="dark"] .spec-content i.fas.fa-chevron-down[b-w1dgd02igk],
html[data-theme="dark"] .spec-content-child i.fas.fa-chevron-up[b-w1dgd02igk],
html[data-theme="dark"] .spec-content-child i.fas.fa-chevron-down[b-w1dgd02igk] {
  color: #fff !important;
}

/* /Components/SpecializationSelector.razor.rz.scp.css */


.spec-card[b-tjzpnfjmrl] {
  background: transparent;
  border: 1px solid #dee2e6;
  padding: 0.5rem 0.75rem;
  margin-top: 0.75rem;
  text-align: center;
  border-radius: 0.375rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.spec-card:hover[b-tjzpnfjmrl] { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.spec-card.selected[b-tjzpnfjmrl] { border-color: #0d6efd; background: rgba(13,110,253,0.06); box-shadow: 0 4px 12px rgba(13,110,253,0.06); }

/* Dark mode via class (for explicit toggle) */
.dark-mode .spec-selector[b-tjzpnfjmrl] { background-color: rgba(255,255,255,0.02); border-color: rgba(255,255,255,0.06); }
.dark-mode .spec-heading[b-tjzpnfjmrl] { color: #9fc3ff; }
.dark-mode .spec-subtitle[b-tjzpnfjmrl] { color: rgba(255,255,255,0.65); }

.dark-mode .spec-card[b-tjzpnfjmrl] { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06); }
.dark-mode .spec-card:hover[b-tjzpnfjmrl] { box-shadow: 0 8px 28px rgba(0,0,0,0.7); }
.dark-mode .spec-card.selected[b-tjzpnfjmrl] { background: rgba(13,110,253,0.08); border-color: rgba(159,195,255,0.25); box-shadow: 0 4px 12px rgba(0,0,0,0.6); }

.dark-mode .selected-summary[b-tjzpnfjmrl] { background: rgba(255,255,255,0.02); border: 1px solid rgba(46,176,75,0.2); }
.dark-mode .selected-heading[b-tjzpnfjmrl] { color: #2eb04b; }
.dark-mode .selected-badge[b-tjzpnfjmrl] { background-color: #2b9cff !important; color: #000 !important; }
.dark-mode .selected-info[b-tjzpnfjmrl] { color: rgba(255,255,255,0.65); }

.dark-mode .empty-summary[b-tjzpnfjmrl] { border-color: rgba(255,255,255,0.06); color: rgba(255,255,255,0.65); }
.dark-mode .error-message[b-tjzpnfjmrl] { background: rgba(220,53,69,0.06); border: 1px solid rgba(220,53,69,0.18); color: #ffb3b3; }

.dark-mode .spec-selector .bg-primary[b-tjzpnfjmrl] { background-color: #2b9cff !important; color: #000 !important; }
.dark-mode .spec-selector .bg-success[b-tjzpnfjmrl] { background-color: #2eb04b !important; color: #000 !important; }
.dark-mode .spec-selector .bg-danger[b-tjzpnfjmrl] { background-color: #ff6b6b !important; color: #000 !important; }
.dark-mode .spec-selector .bg-secondary[b-tjzpnfjmrl] { background-color: rgba(255,255,255,0.06) !important; color: #e9eef8 !important; }

/* Ensure nested spec-content from SpecializationChips is dark */
.dark-mode .spec-selector .spec-content[b-tjzpnfjmrl],
.dark-mode .spec-selector .spec-content-child[b-tjzpnfjmrl],
.dark-mode .spec-selector .spec-pill[b-tjzpnfjmrl],
.dark-mode .spec-selector .spec-chip[b-tjzpnfjmrl],
.dark-mode .spec-selector .spec-badge[b-tjzpnfjmrl],
.dark-mode .spec-selector .spec-card .spec-content[b-tjzpnfjmrl] { 
  background: rgba(255,255,255,0.02) !important;
  color: #e9eef8 !important;
  box-shadow: none !important;
  border-color: rgba(255,255,255,0.04) !important;
}

/* Override bootstrap outline primary buttons inside selector */
.dark-mode .spec-selector .btn-outline-primary[b-tjzpnfjmrl] {
  color: #9fc3ff;
  border-color: rgba(159,195,255,0.25);
  background-color: transparent;
}
.dark-mode .spec-selector .btn-outline-primary:hover[b-tjzpnfjmrl] {
  background-color: rgba(159,195,255,0.04);
}

/* Light mode via class (explicit toggle) - emphasize black borders */
.light-mode .spec-selector[b-tjzpnfjmrl] { border-color: #000; }
.light-mode .spec-card[b-tjzpnfjmrl] { border-color: #000; }
.light-mode .spec-card.selected[b-tjzpnfjmrl] { border-color: #000; }
.light-mode .selected-summary[b-tjzpnfjmrl] { border: 1px solid #000; }
.light-mode .empty-summary[b-tjzpnfjmrl] { border: 1px solid #000; }
.light-mode .error-message[b-tjzpnfjmrl] { border: 1px solid #000; }
.light-mode .spec-selector .spec-content[b-tjzpnfjmrl],
.light-mode .spec-selector .spec-content-child[b-tjzpnfjmrl],
.light-mode .spec-selector .spec-pill[b-tjzpnfjmrl],
.light-mode .spec-selector .spec-chip[b-tjzpnfjmrl],
.light-mode .spec-selector .spec-badge[b-tjzpnfjmrl],
.light-mode .spec-selector .spec-card .spec-content[b-tjzpnfjmrl] { 
  border-color: #000 !important;
}
/* /Layout/MainLayout.razor.rz.scp.css */
.page[b-w3o2uu2ph4] {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.sidebar[b-w3o2uu2ph4] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
}

main[b-w3o2uu2ph4] {
    flex: 1;
    margin-top: 4rem; /* Account for the fixed top navigation */
}

.content[b-w3o2uu2ph4] {
    padding: 1rem;
}

/* Mobile responsive adjustments */
@media (max-width: 1199.98px) {
    main[b-w3o2uu2ph4] {
        margin-top: 3.5rem; /* Adjust for smaller mobile navbar */
    }
    
    .content[b-w3o2uu2ph4] {
        padding: 0.75rem;
    }
}

@media (max-width: 575.98px) {
    main[b-w3o2uu2ph4] {
        margin-top: 3rem; /* Adjust for smallest mobile navbar */
    }
    
    .content[b-w3o2uu2ph4] {
        padding: 0.5rem;
    }
}
/* /Layout/NavMenu.razor.rz.scp.css */
.top-row[b-foozdniw8u] {
    height: 4rem;
    background: linear-gradient(135deg, #2d5016 0%, #4a7c59 50%, #1a3a0f 100%);
    border-bottom: 1px solid rgba(139, 195, 74, 0.2);
    box-shadow: 0 2px 20px rgba(45, 80, 22, 0.3);
    backdrop-filter: blur(10px);
}

[data-theme="dark"] .top-row[b-foozdniw8u] {
    background: linear-gradient(135deg, #1a2f0d 0%, #2d4a35 50%, #0d1a08 100%);
    border-bottom: 1px solid rgba(139, 195, 74, 0.15);
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.5);
}

.container-fluid[b-foozdniw8u] {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 3rem;
    padding: 0 2rem;
}

.navbar-brand[b-foozdniw8u] {
    font-size: 1.5rem;
    font-weight: 700;
    color: #e8f5e8 !important;
    text-decoration: none;
    margin-right: 0;
    letter-spacing: -0.025em;
    transition: all 0.3s ease;
    text-shadow: 0 1px 3px rgba(45, 80, 22, 0.5);
}

.navbar-brand:hover[b-foozdniw8u] {
    color: #c8e6c9 !important;
    transform: translateY(-1px);
    text-shadow: 0 2px 8px rgba(139, 195, 74, 0.4);
}

.navbar-nav[b-foozdniw8u] {
    display: flex;
    flex-direction: row;
    gap: 1.5rem;
    margin-left: 0;
}

.nav-link[b-foozdniw8u] {
    color: rgba(232, 245, 232, 0.9) !important;
    text-decoration: none;
    padding: 0.75rem 1.25rem;
    border-radius: 8px;
    font-weight: 500;
    font-size: 0.95rem;
    transition: all 0.3s ease;
    position: relative;
    backdrop-filter: blur(5px);
    border: 1px solid rgba(139, 195, 74, 0.15);
    background: rgba(74, 124, 89, 0.1);
}

.nav-item button[b-foozdniw8u]{
    margin: 0;
    padding: 0.5rem 0;
}

.nav-link:hover[b-foozdniw8u] {
    color: #e8f5e8 !important;
    background: rgba(139, 195, 74, 0.2);
    border-color: rgba(139, 195, 74, 0.4);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(45, 80, 22, 0.25);
}

.nav-link.active[b-foozdniw8u] {
    color: #e8f5e8 !important;
    background: rgba(139, 195, 74, 0.3);
    border-color: rgba(139, 195, 74, 0.5);
    font-weight: 600;
    box-shadow: 0 4px 15px rgba(45, 80, 22, 0.3);
}

.nav-link.active[b-foozdniw8u]::before {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(139, 195, 74, 0.8), transparent);
    border-radius: 1px;
}

/* Mobile hamburger button */
.navbar-toggler[b-foozdniw8u] {
    border: none;
    background: none;
    padding: 0.5rem;
    border-radius: 6px;
    transition: all 0.3s ease;
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.navbar-toggler:hover[b-foozdniw8u] {
    background: rgba(139, 195, 74, 0.2);
    transform: scale(1.05);
}

.navbar-toggler:focus[b-foozdniw8u] {
    box-shadow: 0 0 0 2px rgba(139, 195, 74, 0.3);
    outline: none;
}

.navbar-toggler-icon[b-foozdniw8u] {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28232, 245, 232, 0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
}

/* Mobile navigation menu */
.mobile-nav[b-foozdniw8u] {
    position: fixed;
    top: 4rem;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    transition: all 0.3s ease;
}

.mobile-nav-backdrop[b-foozdniw8u] {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
    z-index: 1001;
}

.mobile-nav-content[b-foozdniw8u] {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, #2d5016 0%, #4a7c59 50%, #1a3a0f 100%);
    border-top: 1px solid rgba(139, 195, 74, 0.2);
    box-shadow: 0 8px 32px rgba(45, 80, 22, 0.4);
    backdrop-filter: blur(10px);
    z-index: 1002;
    max-height: calc(100vh - 4rem);
    overflow-y: auto;
    padding: 1rem 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

[data-theme="dark"] .mobile-nav-content[b-foozdniw8u] {
    background: linear-gradient(135deg, #1a2f0d 0%, #2d4a35 50%, #0d1a08 100%);
    border-top: 1px solid rgba(139, 195, 74, 0.15);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
}

.mobile-nav.collapse[b-foozdniw8u] {
    display: none;
}



.mobile-nav-link[b-foozdniw8u] {
    color: rgba(232, 245, 232, 0.9) !important;
    text-decoration: none !important;
    padding: 1rem 2rem;
    font-weight: 500;
    font-size: 1rem;
    transition: all 0.3s ease;
    border-bottom: 1px solid rgba(139, 195, 74, 0.1);
    display: flex;
    align-items: center;
    background: transparent;
}

/* Ensure NavLink component overrides Bootstrap defaults */
.mobile-nav-content a.mobile-nav-link[b-foozdniw8u] {
    color: rgba(232, 245, 232, 0.9) !important;
}

.mobile-nav-content a.mobile-nav-link:visited[b-foozdniw8u] {
    color: rgba(232, 245, 232, 0.9) !important;
}

.mobile-nav-content a.mobile-nav-link:link[b-foozdniw8u] {
    color: rgba(232, 245, 232, 0.9) !important;
}

.mobile-nav-link:hover[b-foozdniw8u],
.mobile-nav-content a.mobile-nav-link:hover[b-foozdniw8u] {
    color: #e8f5e8 !important;
    background: rgba(139, 195, 74, 0.15);
    border-left: 4px solid rgba(139, 195, 74, 0.6);
    padding-left: calc(2rem - 4px);
    transform: translateX(4px);
}

.mobile-nav-link.active[b-foozdniw8u],
.mobile-nav-content a.mobile-nav-link.active[b-foozdniw8u] {
    color: #e8f5e8 !important;
    background: rgba(139, 195, 74, 0.25);
    border-left: 4px solid rgba(139, 195, 74, 0.8);
    padding-left: calc(2rem - 4px);
    font-weight: 600;
}

.mobile-nav-link:last-child[b-foozdniw8u] {
    border-bottom: none;
}

/* Container adjustments */
.container-fluid[b-foozdniw8u] {
    justify-content: space-between;
    position: relative;
}

/* Responsive design */
@media (max-width: 1199.98px) {
    .top-row[b-foozdniw8u] {
        height: 3.5rem;
        position: relative;
    }
    
    .container-fluid[b-foozdniw8u] {
        gap: 1rem;
        padding: 0 1rem;
    }
    
    .navbar-brand[b-foozdniw8u] {
        font-size: 1.25rem;
    }
    
    /* Hide desktop nav on mobile/tablet */
    .navbar-nav[b-foozdniw8u] {
        display: none !important;
    }
    
    /* Show mobile nav elements */
    .navbar-toggler[b-foozdniw8u] {
        display: flex !important;
    }
    
    .mobile-nav[b-foozdniw8u] {
        display: block;
        top: 3.5rem;
    }
    
    .mobile-nav-content[b-foozdniw8u] {
        max-height: calc(100vh - 3.5rem);
    }
}

@media (min-width: 1200px) {
    /* Hide mobile elements on desktop */
    .navbar-toggler[b-foozdniw8u] {
        display: none !important;
    }
    
    .mobile-nav[b-foozdniw8u] {
        display: none !important;
    }
    
    /* Show desktop nav */
    .navbar-nav[b-foozdniw8u] {
        display: flex !important;
    }
}

/* Small mobile devices */
@media (max-width: 575.98px) {
    .top-row[b-foozdniw8u] {
        height: 3rem;
    }
    
    .navbar-brand[b-foozdniw8u] {
        font-size: 1.1rem;
    }
    
    .container-fluid[b-foozdniw8u] {
        padding: 0 0.75rem;
    }
    
    .mobile-nav[b-foozdniw8u] {
        top: 3rem;
    }
    
    .mobile-nav-content[b-foozdniw8u] {
        max-height: calc(100vh - 3rem);
    }
    
    .mobile-nav-link[b-foozdniw8u] {
        padding: 0.875rem 1.5rem;
        font-size: 0.95rem;
    }
}

/* /Pages/ProfessionsPage.razor.rz.scp.css */
.spec-bg[b-i2vdops0ma] {
  background-color: #fff;
}

html[data-theme="dark"] .spec-bg[b-i2vdops0ma] {
  background-color: #000;
}
