/* ==========================================================================
   Design System Custom Properties — "The Luminous Administrator"
   Source of truth for all colours. Never use raw hex in markup.
   ========================================================================== */
:root {
    --eq-background:             #070d1f;
    --eq-surface:                #0c1326;
    --eq-surface-container:      #11192e;
    --eq-surface-container-high: #171f36;
    --eq-surface-highest:        #1c253e;
    --eq-primary:                #bd9dff;
    --eq-primary-dim:            #8a4cfc;
    --eq-primary-container:      #b28cff;
    --eq-secondary:              #34b5fa;
    --eq-secondary-container:    #006591;
    --eq-tertiary:               #ff97b2;
    --eq-on-surface:             #dfe4fe;
    --eq-on-surface-variant:     #a5aac2;
    --eq-outline:                #6f758b;
    --eq-outline-variant:        #41475b;
    --eq-on-primary-fixed:       #000000;
    --eq-secondary-dim:          #17a8ec;
    --eq-secondary-fixed-dim:    #81ccff;
    --eq-text-subtle:            #94a3b8;
    --eq-glass-bg:               rgba(28, 37, 62, 0.60);
    --eq-glass-border:           rgba(255, 255, 255, 0.10);
    --eq-ghost-border:           rgba(255, 255, 255, 0.15);
}

/* ==========================================================================
   Glass card — semi-transparent surface with backdrop blur and ghost border
   ========================================================================== */
.glass-card {
    background: var(--eq-glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--eq-glass-border);
    border-radius: 0.75rem;
}

/* Ethereal glow — purple ambient shadow for hero cards */
.ethereal-glow {
    box-shadow: 0 0 60px -15px rgba(189, 157, 255, 0.2);
}

/* ==========================================================================
   Auth card — standard sizing for unauthenticated page cards
   ========================================================================== */
.auth-card {
    padding: 2rem 2.5rem;
    width: 100%;
    max-width: 28rem;
}
.auth-card-centered {
    text-align: center;
}

/* ==========================================================================
   Typography utility classes
   ========================================================================== */
.card-heading {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    letter-spacing: -0.025em;
}

.card-subtitle {
    color: var(--eq-on-surface-variant);
    margin-top: 0.5rem;
    font-weight: 400;
    font-size: 0.875rem;
}

.text-muted {
    color: var(--eq-on-surface-variant);
    font-size: 0.875rem;
}

/* ==========================================================================
   Link styles
   ========================================================================== */
.link-secondary {
    color: var(--eq-secondary) !important;
    font-weight: 600;
    font-size: 0.875rem;
    text-decoration: none !important;
    transition: color 0.3s;
}
.link-secondary:hover {
    color: var(--eq-secondary-dim) !important;
    text-decoration: none !important;
}

/* Muted link — subtle grey, used for "Back to Login" etc. */
.link-muted {
    color: var(--eq-text-subtle) !important;
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    text-decoration: none !important;
    transition: color 0.3s;
}
.link-muted .mud-icon-root {
    transition: transform 0.3s;
}
.link-muted:hover {
    color: var(--eq-primary) !important;
    text-decoration: none !important;
}
.link-muted:hover .mud-icon-root {
    transform: translateX(-0.25rem);
}

/* Divider above footer links in cards */
.card-footer-divider {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/* ==========================================================================
   Icon accent — primary-coloured icons
   ========================================================================== */
.icon-primary {
    color: var(--eq-primary);
    margin-bottom: 1rem;
}

/* Icon badge — gradient square with centred icon (e.g. reset password header) */
.icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 4rem;
    height: 4rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, var(--eq-primary-dim), var(--eq-primary));
    box-shadow: 0 0 20px rgba(189, 157, 255, 0.4);
    margin-bottom: 2rem;
}
.icon-badge .mud-icon-root {
    color: var(--eq-on-primary-fixed);
    font-size: 2rem;
}

/* Layered icon — smaller icon centred over a larger one */
.icon-badge-layered {
    position: relative;
}
.icon-badge-layered .icon-badge-back.mud-icon-root {
    font-size: 2rem !important;
}
.icon-badge-layered .icon-badge-front.mud-icon-root {
    position: absolute;
    font-size: 0.9rem !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -40%);
    color: var(--eq-primary-container) !important;
}

/* ==========================================================================
   Form layout
   ========================================================================== */
.form-fields {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* Label styling — uppercase, small, primary, above the field */
.field-label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    color: var(--eq-primary);
    font-family: 'Inter', sans-serif;
    padding-left: 0.25rem;
    margin-bottom: 0.5rem;
    display: block;
}
.field-label-secondary {
    color: var(--eq-secondary-fixed-dim);
}

/* Dark input field styling */
.dark-input .mud-input-outlined .mud-input-outlined-border {
    border-color: var(--eq-outline-variant) !important;
    transition: border-color 0.3s, box-shadow 0.3s;
}
.dark-input .mud-input-outlined:not(:focus-within):hover .mud-input-outlined-border {
    border-color: var(--eq-outline) !important;
}
.dark-input .mud-input-outlined:focus-within .mud-input-outlined-border {
    border-color: var(--eq-primary) !important;
    box-shadow: 0 0 0 2px rgba(189, 157, 255, 0.2);
}
.dark-input .mud-input.mud-input-outlined {
    background: rgba(0, 0, 0, 0.40);
    border-radius: 0.5rem;
}
.dark-input .mud-input-slot {
    padding-top: 0.875rem;
    padding-bottom: 0.875rem;
}
/* Adornment icon turns primary on focus */
.dark-input .mud-input-adornment-start .mud-icon-root,
.dark-input .mud-input-adornment-end .mud-icon-root {
    transition: color 0.3s;
}
.dark-input .mud-input-outlined:focus-within .mud-input-adornment-start .mud-icon-root,
.dark-input .mud-input-outlined:focus-within .mud-input-adornment-end .mud-icon-root {
    color: var(--eq-primary) !important;
}

/* ==========================================================================
   Primary gradient button
   ========================================================================== */
.gradient-button {
    background: linear-gradient(to right, var(--eq-primary-dim), var(--eq-primary)) !important;
    color: var(--eq-on-primary-fixed) !important;
    border-radius: 0.5rem !important;
    border: none !important;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.1em;
    font-size: 0.875rem;
    padding: 0.875rem 2rem;
    box-shadow: 0 10px 15px -3px rgba(138, 76, 252, 0.2) !important;
}
.gradient-button:hover {
    background: linear-gradient(to right, var(--eq-primary), var(--eq-primary-container)) !important;
}

/* Ghost border — specular highlight edge for glass elements */
.ghost-border {
    border: 1px solid var(--eq-ghost-border);
}

/* ==========================================================================
   Full-screen dark background for unauthenticated pages
   ========================================================================== */
.dark-fullscreen {
    min-height: 100vh;
    background-color: var(--eq-background);
    position: relative;
    overflow: hidden;
}

/* Background ethereal gradient blobs */
.dark-fullscreen::before,
.dark-fullscreen::after {
    content: '';
    position: absolute;
    width: 50%;
    height: 50%;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}
.dark-fullscreen::before {
    top: -10%;
    left: -10%;
    background: rgba(138, 76, 252, 0.20);
    filter: blur(120px);
}
.dark-fullscreen::after {
    bottom: -10%;
    right: -10%;
    background: rgba(0, 101, 145, 0.20);
    filter: blur(120px);
}

/* ==========================================================================
   Glassmorphism app bar for unauthenticated pages
   ========================================================================== */
.glass-appbar {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 50;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background: var(--eq-glass-bg) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid var(--eq-ghost-border);
    box-shadow: 0 8px 32px 0 rgba(138, 76, 252, 0.08);
}

/* Gradient text for branding */
.gradient-text {
    background: linear-gradient(135deg, var(--eq-primary-dim), var(--eq-primary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Branding text in app bar */
.appbar-brand {
    font-family: 'Manrope', sans-serif;
    font-weight: 800;
    font-size: 1.5rem;
    letter-spacing: -0.025em;
}

/* Main content area for unauthenticated pages */
.auth-main {
    position: relative;
    z-index: 10;
    display: flex;
    flex-grow: 1;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 6rem 1.5rem 3rem;
}

/* ==========================================================================
   Sidebar active nav item — vertical purple glow
   ========================================================================== */
.nav-active-glow {
    border-left: 2px solid var(--eq-primary);
    background: radial-gradient(ellipse at left, rgba(138, 76, 252, 0.15), transparent 70%);
}

/* ==========================================================================
   Setup page — first-time setup specific styles
   ========================================================================== */

/* Setup page container — wider than auth cards, left-aligned on large screens */
.setup-container {
    width: 100%;
    max-width: 42rem;
    text-align: left;
}

/* Badge/chip — pill with pulsing dot (INITIAL CONFIGURATION) */
.setup-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    background: rgba(0, 101, 145, 0.30);
    border: 1px solid rgba(52, 181, 250, 0.20);
}
.setup-badge-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background-color: var(--eq-secondary);
    animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}
.setup-badge-text {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--eq-secondary);
}

/* Gradient heading text — purple to blue */
.gradient-text-primary-secondary {
    background: linear-gradient(to right, var(--eq-primary), var(--eq-secondary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Two-column form grid (side-by-side fields) */
.form-fields-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}
@media (max-width: 768px) {
    .form-fields-grid { grid-template-columns: 1fr; }
}

/* Muted field label (grey, used on setup form) */
.field-label-muted {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--eq-outline);
    margin-left: 0.25rem;
    margin-bottom: 0.5rem;
    display: block;
}

/* Glass card internal glow decoration */
.glass-card-glow {
    position: relative;
    overflow: hidden;
}
.glass-card-glow::before {
    content: '';
    position: absolute;
    top: -6rem;
    right: -6rem;
    width: 12rem;
    height: 12rem;
    background: var(--eq-primary-dim);
    opacity: 0.10;
    filter: blur(48px);
    border-radius: 50%;
    pointer-events: none;
}

/* System note card — side panel */
.system-note {
    background: var(--eq-glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--eq-glass-border);
    border-left: 4px solid var(--eq-secondary);
    border-radius: 0.75rem;
    padding: 1rem;
    font-size: 0.75rem;
}
.system-note-heading {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--eq-secondary);
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.75rem;
}

/* Setup footer */
.setup-footer {
    margin-top: 3rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    opacity: 0.6;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}
.setup-footer a {
    color: var(--eq-on-surface);
    text-decoration: none;
    transition: color 0.3s;
}
.setup-footer a:hover {
    color: var(--eq-primary);
}

/* Terms checkbox link styling */
.terms-link {
    color: var(--eq-secondary) !important;
    text-decoration: none !important;
}
.terms-link:hover {
    text-decoration: underline !important;
}

/* ==========================================================================
   Portal Users — Summary Tiles
   ========================================================================== */
.summary-tile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    position: relative;
    overflow: hidden;
}
.summary-tile-label {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--eq-on-surface-variant);
    margin-bottom: 0.25rem;
}
.summary-tile-count {
    font-family: 'Manrope', sans-serif;
    font-size: 2rem;
    font-weight: 800;
    color: var(--eq-on-surface);
}
.summary-tile-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.summary-tile-icon-primary { background: rgba(189, 157, 255, 0.15); color: var(--eq-primary); }
.summary-tile-icon-secondary { background: rgba(52, 181, 250, 0.15); color: var(--eq-secondary); }
.summary-tile-icon-tertiary { background: rgba(255, 151, 178, 0.15); color: var(--eq-tertiary); }
.summary-tile-bg-icon {
    position: absolute;
    bottom: -0.5rem;
    right: -0.5rem;
    opacity: 0.05;
    font-size: 5rem !important;
    pointer-events: none;
}

/* ==========================================================================
   Portal Users — Role Badge Pills
   ========================================================================== */
.role-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
}
.role-badge-primary {
    background: rgba(189, 157, 255, 0.10);
    color: var(--eq-primary);
    border: 1px solid rgba(189, 157, 255, 0.20);
}
.role-badge-secondary {
    background: rgba(52, 181, 250, 0.10);
    color: var(--eq-secondary);
    border: 1px solid rgba(52, 181, 250, 0.20);
}
.role-badge-muted {
    background: var(--eq-surface-container-high);
    color: var(--eq-on-surface-variant);
    border: 1px solid rgba(111, 117, 139, 0.30);
}

/* ==========================================================================
   Portal Users — Status Indicator
   ========================================================================== */
.status-dot {
    display: inline-block;
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
}
.status-dot-active {
    background-color: #34d399;
    box-shadow: 0 0 6px rgba(52, 211, 153, 0.5);
}
.status-dot-disabled {
    background-color: #64748b;
}
.status-dot-invited {
    background-color: #e2a832;
    box-shadow: 0 0 6px rgba(226, 168, 50, 0.5);
}
.status-text {
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}
.status-text-active { color: #34d399; }
.status-text-disabled { color: #64748b; }
.status-text-invited { color: #e2a832; }

/* ==========================================================================
   Quest Status Chips
   ========================================================================== */
.status-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}
.status-chip-active {
    background: rgba(34, 197, 94, 0.12);
    color: #22c55e;
}
.status-chip-draft {
    background: rgba(100, 116, 139, 0.12);
    color: #94a3b8;
}
.status-chip-scheduled {
    background: rgba(226, 168, 50, 0.12);
    color: #e2a832;
}
.status-chip-unpublished {
    background: rgba(239, 68, 68, 0.12);
    color: #ef4444;
}

/* ==========================================================================
   Portal Users — Avatar Initials Circle
   ========================================================================== */
.avatar-circle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--eq-on-primary-fixed);
    flex-shrink: 0;
}
.avatar-primary { background: linear-gradient(135deg, var(--eq-primary-dim), var(--eq-primary)); }
.avatar-secondary { background: linear-gradient(135deg, #006591, var(--eq-secondary)); }
.avatar-tertiary { background: linear-gradient(135deg, #b34d6d, var(--eq-tertiary)); }
.avatar-disabled { background: #334155; color: #94a3b8; }

/* ==========================================================================
   Portal Users — Data Grid Glass Styling
   ========================================================================== */
.grid-glass .mud-table {
    background: transparent !important;
}
.grid-glass .mud-table-head .mud-table-row {
    background: transparent !important;
}
.grid-glass .mud-table-head .mud-table-cell {
    color: var(--eq-on-surface-variant) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border-bottom-color: var(--eq-outline-variant) !important;
}
.grid-glass .mud-table-body .mud-table-row:hover {
    background: rgba(255, 255, 255, 0.02) !important;
}
.grid-glass .mud-table-body .mud-table-cell {
    border-bottom-color: rgba(255, 255, 255, 0.05) !important;
}
.grid-glass .mud-table-pagination {
    color: var(--eq-on-surface-variant) !important;
    border-top-color: var(--eq-outline-variant) !important;
}

/* ==========================================================================
   Invite Page — Role Description Cards
   ========================================================================== */
.role-card-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
@media (max-width: 768px) {
    .role-card-grid { grid-template-columns: 1fr; }
}
.role-card {
    padding: 1rem 1.25rem;
    border-radius: 0.75rem;
    background: var(--eq-surface-container);
    border: 1px solid var(--eq-outline-variant);
    transition: border-color 0.3s;
}
.role-card:hover {
    border-color: var(--eq-outline);
}
.role-card-selected {
    border-color: var(--eq-primary) !important;
    background: rgba(189, 157, 255, 0.05);
}
.role-card-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 0.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.75rem;
}
.role-card-title {
    font-size: 0.875rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}
.role-card-desc {
    font-size: 0.75rem;
    color: var(--eq-on-surface-variant);
    line-height: 1.5;
}

/* ==========================================================================
   Page action bar (filter + invite buttons row)
   ========================================================================== */
.page-action-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

/* Ghost/outline button variant */
.ghost-button {
    background: transparent !important;
    border: 1px solid var(--eq-ghost-border) !important;
    color: var(--eq-on-surface) !important;
    border-radius: 0.5rem !important;
    text-transform: none !important;
    font-weight: 500 !important;
}
.ghost-button:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: var(--eq-outline) !important;
}

/* ==========================================================================
   Authenticated Layout — App Bar
   ========================================================================== */
.eq-appbar.mud-appbar {
    background: rgba(12, 19, 38, 0.60) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 40px 40px -15px rgba(138, 76, 252, 0.08) !important;
    font-family: 'Manrope', sans-serif;
    padding-right: 1.5rem;
}
.eq-appbar-icon.mud-icon-button {
    color: var(--eq-on-surface-variant) !important;
}
.eq-appbar-icon.mud-icon-button:hover {
    background: rgba(255, 255, 255, 0.05) !important;
}
.eq-appbar-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    border: 2px solid rgba(138, 76, 252, 0.30);
    padding: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: 0.5rem;
    background: var(--eq-surface-container);
    color: var(--eq-on-surface-variant);
}
.eq-account-menu-button {
    appearance: none;
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    margin-left: 0.5rem;
    color: inherit;
}
.eq-account-menu-button:hover .eq-appbar-avatar,
.eq-account-menu-button:focus-visible .eq-appbar-avatar {
    color: var(--eq-primary);
    border-color: rgba(189, 157, 255, 0.55);
}
.eq-account-summary {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    line-height: 1.2;
    min-width: 0;
}
.eq-account-display-name {
    color: var(--eq-on-surface);
    font-size: 0.9rem;
    font-weight: 700;
    max-width: 12rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.eq-account-role {
    color: var(--eq-on-surface-variant);
    font-size: 0.75rem;
    font-weight: 500;
    max-width: 12rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
@media (max-width: 600px) {
    .eq-account-summary {
        display: none;
    }
}

/* ==========================================================================
   Profile Page
   ========================================================================== */
.profile-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 1rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}
.profile-header-copy {
    min-width: 0;
    flex: 1;
}

/* ==========================================================================
   Authenticated Layout — Drawer / Sidebar
   ========================================================================== */
.eq-drawer.mud-drawer {
    background: var(--eq-surface) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.05) !important;
}
.eq-drawer .mud-drawer-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

/* Brand block at top of drawer */
.eq-drawer-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.5rem 1.25rem 2.5rem;
}
.eq-drawer-logo {
    width: 2rem;
    height: 2rem;
    border-radius: 0.5rem;
    background: linear-gradient(135deg, var(--eq-primary-dim), var(--eq-primary));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--eq-on-primary-fixed);
    flex-shrink: 0;
}
.eq-drawer-brand-text {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    white-space: nowrap;
}
.eq-drawer-title {
    font-family: 'Manrope', sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.025em;
    line-height: 1.2;
}
.eq-drawer-subtitle {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--eq-outline);
    line-height: 1.4;
}
/* Hide brand text when drawer is collapsed to mini */
.mud-drawer--closed .eq-drawer-brand-text {
    display: none;
}

/* Nav menu styling */
.eq-nav-menu {
    flex: 1;
    padding: 0 0.5rem;
}
.eq-nav-menu .mud-nav-link {
    color: var(--eq-outline) !important;
    font-weight: 500;
    font-size: 0.875rem;
    border-radius: 0.5rem;
    margin-bottom: 0.125rem;
    transition: all 0.15s;
}
.eq-nav-menu .mud-nav-link:hover {
    color: var(--eq-on-surface-variant) !important;
    background: rgba(255, 255, 255, 0.05) !important;
}
.eq-nav-menu .mud-nav-link.active {
    color: var(--eq-primary) !important;
    background: linear-gradient(to right, rgba(138, 76, 252, 0.10), transparent) !important;
    border-left: 2px solid var(--eq-primary);
    box-shadow: -2px 0 15px rgba(138, 76, 252, 0.3);
    font-weight: 700;
}
.eq-nav-menu .mud-nav-link .mud-nav-link-icon {
    color: inherit !important;
}
/* NavGroup styling */
.eq-nav-menu .mud-nav-group .mud-nav-link {
    color: var(--eq-outline) !important;
}
.eq-nav-menu .mud-nav-group .mud-nav-link:hover {
    color: var(--eq-on-surface-variant) !important;
}
.eq-nav-menu .mud-collapse-wrapper .mud-nav-link {
    margin-left: 2.5rem !important;
    padding-left: 1rem !important;
}
.eq-nav-menu .mud-collapse-wrapper .mud-nav-link.active {
    color: var(--eq-primary) !important;
    font-weight: 700;
    background: linear-gradient(to right, rgba(138, 76, 252, 0.10), transparent) !important;
    border-left: 2px solid var(--eq-primary);
    box-shadow: -2px 0 15px rgba(138, 76, 252, 0.3);
}
/* NavGroup header — subtle purple tint when a child link is active */
.eq-nav-menu .mud-nav-group:has(.mud-nav-link.active) > .mud-nav-link {
    color: var(--eq-primary-container) !important;
}
.eq-nav-menu .mud-nav-group:has(.mud-nav-link.active) > .mud-nav-link .mud-nav-link-icon {
    color: var(--eq-primary-container) !important;
}

/* Stub nav items — yellow/amber for pages that don't exist yet */
.eq-nav-stub .mud-nav-link {
    color: #e2a832 !important;
}
.eq-nav-stub .mud-nav-link .mud-nav-link-icon,
.eq-nav-stub .mud-nav-link .mud-nav-link-text,
.eq-nav-stub .mud-nav-link .mud-icon-root,
.eq-nav-stub .mud-nav-link svg {
    color: #e2a832 !important;
    fill: #e2a832 !important;
}
.eq-nav-stub .mud-nav-link:hover {
    color: #f0c050 !important;
}
.eq-nav-stub .mud-nav-link:hover .mud-nav-link-icon,
.eq-nav-stub .mud-nav-link:hover .mud-nav-link-text,
.eq-nav-stub .mud-nav-link:hover .mud-icon-root,
.eq-nav-stub .mud-nav-link:hover svg {
    color: #f0c050 !important;
    fill: #f0c050 !important;
}

/* Nav footer area */
.eq-nav-footer {
    margin-top: auto;
    padding: 0 0.75rem 1rem;
}
.eq-nav-quest-button {
    padding: 0.5rem;
}
.eq-nav-quest-button .gradient-button {
    border-radius: 0.75rem !important;
    padding: 0.75rem 1rem;
    text-transform: none;
    font-weight: 700;
}
.eq-nav-footer-links .mud-nav-link {
    font-size: 0.75rem !important;
    color: var(--eq-outline) !important;
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}
.eq-nav-footer-links .mud-nav-link.active {
    background: transparent !important;
}
.eq-nav-footer-links .mud-nav-link:hover {
    color: var(--eq-on-surface-variant) !important;
}

/* ==========================================================================
   Authenticated Layout — Main Content
   ========================================================================== */
.eq-main-content.mud-main-content {
    padding: 2rem;
    padding-top: calc(var(--mud-appbar-height) + 2rem);
    max-width: 80rem;
    position: relative;
    overflow: hidden;
}

/* Background ethereal gradient blobs — matches login/unauthenticated pages */
.eq-main-content.mud-main-content::before,
.eq-main-content.mud-main-content::after {
    content: '';
    position: fixed;
    width: 50%;
    height: 50%;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}
.eq-main-content.mud-main-content::before {
    top: -10%;
    left: -10%;
    background: rgba(138, 76, 252, 0.20);
    filter: blur(120px);
}
.eq-main-content.mud-main-content::after {
    bottom: -10%;
    right: -10%;
    background: rgba(0, 101, 145, 0.20);
    filter: blur(120px);
}

/* ==========================================================================
   Dialogs — glass-style modal
   ========================================================================== */
.eq-dialog.mud-dialog {
    background: var(--eq-surface-container) !important;
    border: 1px solid var(--eq-glass-border);
    border-radius: 1rem !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5) !important;
    max-width: 28rem;
}
.eq-dialog .mud-dialog-title {
    display: none;
}
.eq-dialog .mud-dialog-content {
    padding: 1.5rem 2rem 2rem !important;
    overflow-y: visible;
}
.eq-dialog .mud-dialog-actions {
    display: none;
}
.eq-dialog.eq-dialog-wide.mud-dialog {
    max-width: 36rem !important;
    width: 36rem !important;
}
