/* ═══════════════════════════════════════════════════════════════════════════
   1vsM — Member Kit Theme Overrides
   Maps member-kit CSS variables to the site's dark/gold color scheme.
   Loaded AFTER member.css + inline :root defaults so these always win.
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* Force dark scheme for native form controls */
    color-scheme: dark;

    /* Backgrounds — match site's nearly-black, not member-kit's navy */
    --member-bg:            #0A0A0A;   /* --bg-dark */
    --member-surface:       #111111;   /* between bg-dark and glass */
    --member-surface-hover: #1a1a1a;   /* subtle lift */

    /* Borders — match site's glass borders */
    --member-border:        rgba(255, 255, 255, 0.1);  /* --glass-border */

    /* Text */
    --member-text:          #F5F5F5;   /* --text-light */
    --member-text-muted:    #A0A0A0;   /* --text-muted */

    /* Accent — gold */
    --member-accent:        #D4AF37;   /* --primary */
    --member-accent-hover:  #F1D279;   /* --primary-light */
    --member-accent-text:   #050505;   /* --bg-darker (dark text on gold) */

    /* Typography */
    --member-font: 'Outfit', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --member-radius: 12px;
}

/* ── Fixed nav clearance ─────────────────────────────────────────────────── */

.member-page {
    padding-top: 100px;
}

/* Dashboard: site nav visible at top, sidebar at left */
.member-dashboard.has-site-nav .member-dashboard-sidebar {
    position: fixed !important;
    left: 0;
    top: var(--nav-height, 72px);
    height: calc(100vh - var(--nav-height, 72px));
    width: 260px;
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.member-dashboard.has-site-nav .member-dashboard-main {
    margin-left: 260px !important;
}

.member-dashboard.has-site-nav.vdash-sidebar-collapsed .member-dashboard-main {
    margin-left: 56px !important;
}

/* Full-width content — remove 900px cap */
.member-dashboard-content {
    max-width: none;
}

/* ── User Details in Sidebar ─────────────────────────────────────────────── */

.member-dashboard-user-details {
    margin-top: 0.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.user-detail-line {
    font-size: 0.7rem;
    color: var(--member-text-muted);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.user-detail-id {
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 0.65rem;
    color: var(--member-text-faint, #555);
}

.user-detail-role {
    font-size: 0.6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--member-text-muted);
}

.user-detail-role--admin {
    background: rgba(212, 175, 55, 0.15);
    color: var(--member-accent);
}

.user-detail-role--sales_rep {
    background: rgba(96, 165, 250, 0.15);
    color: var(--member-info);
}

/* Hide details when sidebar is collapsed */
.vdash-sidebar-collapsed .member-dashboard-user-details {
    display: none;
}

/* ── Login card polish ───────────────────────────────────────────────────── */
/* Match the glassmorphic card style used on the rest of the site */

.member-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border-radius: 20px;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.member-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

/* Gold sign-in button */
.member-button,
.member-form button[type="submit"] {
    background: #D4AF37;
    color: #050505;
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 50px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.member-button:hover,
.member-form button[type="submit"]:hover {
    background: #F1D279;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(212, 175, 55, 0.25);
}

/* Form inputs — dark glassmorphic style */
.member-input,
.member-form-group input {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    color: #F5F5F5;
    font-family: 'Inter', sans-serif;
}

.member-input:focus,
.member-form-group input:focus {
    border-color: #D4AF37;
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.15);
}

/* Links — gold on hover */
.member-link,
.member-card a {
    color: #A0A0A0;
    transition: color 0.3s;
}

.member-link:hover,
.member-card a:hover {
    color: #D4AF37;
}

/* ── Dashboard sidebar polish ────────────────────────────────────────────── */
/* !important needed to override member-kit dashboard.php inline <style> block */

.member-dashboard-sidebar {
    background: #050505 !important;
    border-right-color: rgba(255, 255, 255, 0.07) !important;
    /* No overflow-y: hidden — flex layout pins user card, nav scrolls independently */
}

/* Nav scrolls independently — user card + logout stay pinned at bottom */
.member-dashboard-nav {
    overflow-y: auto;
    flex: 1;
    min-height: 0;
}

.member-dashboard-user {
    flex-shrink: 0;
}

.member-dashboard-nav-item.active {
    background: rgba(212, 175, 55, 0.1) !important;
    color: #D4AF37 !important;
    border-left: 3px solid #D4AF37;
}

.member-dashboard-nav-item:hover:not(.active) {
    background: rgba(255, 255, 255, 0.03) !important;
    color: #E8E8E8 !important;
}

.member-dashboard-logo {
    background: rgba(212, 175, 55, 0.12) !important;
    border-radius: 12px !important;
}

.member-dashboard-user-avatar {
    background: linear-gradient(135deg, #D4AF37, #A08520) !important;
    color: #050505 !important;
}

.member-dashboard-main {
    background: #0A0A0A !important;
}

.member-dashboard {
    background: #0A0A0A !important;
    font-family: 'Outfit', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

/* ── Sign Up CTA — gold accent ──────────────────────────────────────── */

.member-signup-cta {
    background: rgba(212, 175, 55, 0.08);
    border-color: rgba(212, 175, 55, 0.2);
}

.member-signup-cta__link {
    color: #D4AF37;
}

.member-signup-cta__link:hover {
    color: #F1D279;
}

/* ── Sidebar nav group headers — gold override ─────────────────────────── */

.member-dashboard-nav-group {
    color: rgba(212, 175, 55, 0.5);
    font-family: 'Outfit', sans-serif;
}

/* Dashboard tab headings */
.member-dashboard-main h2 {
    font-family: 'Outfit', sans-serif;
}

/* ── Tab Notification Badges ─────────────────────────────────────────────── */

.member-dashboard-nav-item {
    position: relative;
}

.tab-badge {
    position: absolute;
    top: 6px;
    right: 8px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: #ef4444;
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    animation: badgePulse 2s ease-in-out infinite;
}

@keyframes badgePulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

/* ── Empty State ────────────────────────────────────────────────────────── */

.empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--member-text-muted);
}

.empty-state h3 {
    color: var(--member-text);
    margin-bottom: 0.5rem;
    font-size: 1.1rem;
}

.empty-state p {
    margin-bottom: 0.75rem;
    font-size: 0.9rem;
}

.empty-state .empty-cta {
    display: inline-block;
    margin-top: 0.75rem;
    padding: 0.5rem 1.25rem;
    border: 1px solid var(--member-accent);
    color: var(--member-accent);
    border-radius: var(--member-radius);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    transition: all 0.2s;
}

.empty-state .empty-cta:hover {
    background: rgba(212, 175, 55, 0.1);
}

/* ── Global Search ──────────────────────────────────────────────────────── */

.global-search-wrapper {
    position: relative;
    max-width: 400px;
    margin: 0 0 1.5rem auto;
    padding: 0 2rem;
}

.global-search-icon {
    position: absolute;
    left: 2.75rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.85rem;
    pointer-events: none;
    z-index: 1;
}

.global-search-input {
    width: 100%;
    padding: 0.6rem 0.75rem 0.6rem 2.25rem;
    background: var(--member-surface);
    border: 1px solid var(--member-border);
    border-radius: var(--member-radius);
    color: var(--member-text);
    font-size: 0.85rem;
    font-family: inherit;
    transition: border-color 0.2s;
}

.global-search-input:focus {
    outline: none;
    border-color: var(--member-accent);
    box-shadow: 0 0 0 2px rgba(212, 175, 55, 0.1);
}

.global-search-input::placeholder {
    color: var(--member-text-muted);
}

.global-search-dropdown {
    position: absolute;
    top: 100%;
    left: 2rem;
    right: 2rem;
    background: var(--member-surface);
    border: 1px solid var(--member-border);
    border-radius: var(--member-radius);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
    z-index: 100;
    max-height: 400px;
    overflow-y: auto;
    margin-top: 4px;
}

.global-search-group-header {
    padding: 0.5rem 0.75rem 0.25rem;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--member-accent);
}

.global-search-result {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background 0.1s;
}

.global-search-result:hover,
.global-search-result.highlighted {
    background: rgba(212, 175, 55, 0.08);
}

.global-search-result-icon {
    font-size: 0.85rem;
    flex-shrink: 0;
}

.global-search-result-body {
    flex: 1;
    min-width: 0;
}

.global-search-result-label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--member-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.global-search-result-secondary {
    font-size: 0.75rem;
    color: var(--member-text-muted);
}

.global-search-result-tab {
    font-size: 0.65rem;
    color: var(--member-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    flex-shrink: 0;
}

.global-search-empty {
    padding: 1rem;
    text-align: center;
    color: var(--member-text-muted);
    font-size: 0.85rem;
}

/* ── Keyboard Shortcuts ─────────────────────────────────────────────────── */

.keyboard-highlight {
    outline: 2px solid var(--member-accent) !important;
    outline-offset: -2px;
    background: rgba(212, 175, 55, 0.06) !important;
}

.keyboard-help-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.keyboard-help-modal {
    background: var(--member-surface);
    border: 1px solid var(--member-border);
    border-radius: var(--member-radius);
    padding: 2rem;
    max-width: 400px;
    width: 90%;
}

.keyboard-help-modal h3 {
    color: var(--member-accent);
    font-size: 1rem;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.keyboard-help-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.keyboard-help-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.keyboard-help-row kbd {
    display: inline-block;
    min-width: 60px;
    padding: 0.25rem 0.5rem;
    background: var(--member-bg);
    border: 1px solid var(--member-border);
    border-radius: 4px;
    font-family: monospace;
    font-size: 0.8rem;
    color: var(--member-accent);
    text-align: center;
}

.keyboard-help-row span {
    color: var(--member-text-muted);
    font-size: 0.85rem;
}

.keyboard-help-close {
    margin-top: 1.5rem;
    width: 100%;
    padding: 0.5rem;
    border: 1px solid var(--member-border);
    border-radius: var(--member-radius);
    background: transparent;
    color: var(--member-text-muted);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
}

.keyboard-help-close:hover {
    border-color: var(--member-accent);
    color: var(--member-accent);
}

/* ── Last Updated Timestamp ─────────────────────────────────────────────── */

.last-updated-badge {
    font-size: 0.75rem;
    color: var(--member-text-muted);
    font-weight: 400;
    margin-left: 0.75rem;
}

/* ── View Toggle (reusable) ─────────────────────────────────────────────── */

.view-toggle {
    display: inline-flex;
    border: 1px solid var(--member-border);
    border-radius: var(--member-radius);
    overflow: hidden;
}

.view-toggle-btn {
    padding: 0.5rem 1rem;
    border: none;
    background: transparent;
    color: var(--member-text-muted);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.view-toggle-btn.active {
    background: var(--member-accent);
    color: var(--member-accent-text);
}

.view-toggle-btn:hover:not(.active) {
    background: var(--member-surface-hover);
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
    .tab-badge,
    .member-card,
    .member-button,
    .member-form button[type="submit"],
    .member-link,
    .member-card a,
    .member-dashboard.has-site-nav .member-dashboard-sidebar,
    .empty-state .empty-cta,
    .global-search-input,
    .global-search-result,
    .keyboard-help-close,
    .view-toggle-btn {
        animation: none !important;
        transition-duration: 0.01ms !important;
    }
}
