/**
 * Surya Web - Complete Theme CSS (Indigo-Purple Theme)
 *
 * This file combines:
 * - Enterprise Theme CSS (component styles, color palettes, page headers, buttons)
 * - Site CSS (navbar, footer, layout, utilities)
 *
 * Theme: Indigo-Purple Gradient
 * Primary: #7c3aed (Violet)
 * Gradient: #6366f1 → #a855f7 (Indigo to Fuchsia)
 *
 * Usage: <link rel="stylesheet" href="~/css/surya-theme.css" />
 * Note: Requires variables.css to be loaded BEFORE this file
 */

/* ==========================================================================
   Color Variables
   ========================================================================== */

:root {
    /* =========================================================================
       ORGANIZED COLOR PALETTE - Distinct Visual Families
       ========================================================================= */

    /* ----- BLUE FAMILY (Cool Blues) ----- */
    --gradient-blue: linear-gradient(135deg, #3b82f6 0%, #2563eb 50%, #1d4ed8 100%);      /* Standard blue */
    --gradient-sky: linear-gradient(135deg, #0ea5e9 0%, #0284c7 50%, #0369a1 100%);       /* Lighter sky blue */
    --gradient-sapphire: linear-gradient(135deg, #1e40af 0%, #1e3a8a 50%, #172554 100%);  /* Deep royal blue */
    --gradient-navy: linear-gradient(135deg, #1e3a5f 0%, #0f2942 50%, #0a1929 100%);      /* Very dark blue */
    --gradient-ocean: linear-gradient(135deg, #0077b6 0%, #005f8a 50%, #03045e 100%);     /* Deep ocean blue */

    /* ----- PURPLE FAMILY (Purples & Violets) ----- */
    --gradient-purple: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);                 /* Standard purple */
    --gradient-violet: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 50%, #6d28d9 100%);    /* Lighter violet */
    --gradient-indigo: linear-gradient(135deg, #6366f1 0%, #4f46e5 50%, #4338ca 100%);    /* Blue-purple */
    --gradient-amethyst: linear-gradient(135deg, #9333ea 0%, #7e22ce 50%, #581c87 100%);  /* Rich purple */
    --gradient-grape: linear-gradient(135deg, #6b21a8 0%, #581c87 50%, #3b0764 100%);     /* Deep grape */

    /* ----- PINK FAMILY (Pinks & Magentas) ----- */
    --gradient-pink: linear-gradient(135deg, #ec4899 0%, #db2777 50%, #be185d 100%);      /* Standard pink */
    --gradient-fuchsia: linear-gradient(135deg, #d946ef 0%, #c026d3 50%, #a21caf 100%);   /* Bright magenta */
    --gradient-rose: linear-gradient(135deg, #f43f5e 0%, #e11d48 50%, #be123c 100%);      /* Pink-red */
    --gradient-blush: linear-gradient(135deg, #fda4af 0%, #fb7185 50%, #f43f5e 100%);     /* Soft pink */
    --gradient-coral: linear-gradient(135deg, #f97171 0%, #f472b6 50%, #e879f9 100%);     /* Pink to orchid */

    /* ----- RED FAMILY (Reds & Warm) ----- */
    --gradient-red: linear-gradient(135deg, #ef4444 0%, #dc2626 50%, #b91c1c 100%);       /* Standard red */
    --gradient-ruby: linear-gradient(135deg, #be123c 0%, #9f1239 50%, #881337 100%);      /* Deep ruby */
    --gradient-wine: linear-gradient(135deg, #831843 0%, #701a3d 50%, #500724 100%);      /* Burgundy wine */
    --gradient-crimson: linear-gradient(135deg, #dc2626 0%, #b91c1c 50%, #991b1b 100%);   /* Deep crimson */

    /* ----- ORANGE FAMILY (Oranges & Warm) ----- */
    --gradient-orange: linear-gradient(135deg, #f97316 0%, #ea580c 50%, #c2410c 100%);    /* Standard orange */
    --gradient-amber: linear-gradient(135deg, #f59e0b 0%, #d97706 50%, #b45309 100%);     /* Golden amber */
    --gradient-tangerine: linear-gradient(135deg, #fb923c 0%, #f97316 50%, #ea580c 100%); /* Bright tangerine */
    --gradient-peach: linear-gradient(135deg, #fdba74 0%, #fb923c 50%, #f97316 100%);     /* Soft peach */
    --gradient-bronze: linear-gradient(135deg, #b45309 0%, #92400e 50%, #78350f 100%);    /* Metallic bronze */

    /* ----- YELLOW FAMILY (Yellows & Gold) ----- */
    --gradient-yellow: linear-gradient(135deg, #f5c518 0%, #e6b800 50%, #d4a800 100%);    /* Standard yellow */
    --gradient-gold: linear-gradient(135deg, #fbbf24 0%, #f59e0b 50%, #d97706 100%);      /* Rich gold */
    --gradient-honey: linear-gradient(135deg, #fcd34d 0%, #fbbf24 50%, #f59e0b 100%);     /* Light honey */
    --gradient-mustard: linear-gradient(135deg, #ca8a04 0%, #a16207 50%, #854d0e 100%);   /* Deep mustard */

    /* ----- GREEN FAMILY (Greens) ----- */
    --gradient-green: linear-gradient(135deg, #059669 0%, #047857 50%, #065f46 100%);     /* Standard green */
    --gradient-emerald: linear-gradient(135deg, #10b981 0%, #059669 50%, #047857 100%);   /* Bright emerald */
    --gradient-lime: linear-gradient(135deg, #84cc16 0%, #65a30d 50%, #4d7c0f 100%);      /* Yellow-green */
    --gradient-forest: linear-gradient(135deg, #166534 0%, #14532d 50%, #052e16 100%);    /* Deep forest */
    --gradient-mint: linear-gradient(135deg, #34d399 0%, #10b981 50%, #059669 100%);      /* Fresh mint */
    --gradient-jade: linear-gradient(135deg, #0d9488 0%, #0f766e 50%, #115e59 100%);      /* Blue-green jade */

    /* ----- CYAN/TEAL FAMILY (Blue-Greens) ----- */
    --gradient-cyan: linear-gradient(135deg, #06b6d4 0%, #0891b2 50%, #0e7490 100%);      /* Standard cyan */
    --gradient-teal: linear-gradient(135deg, #14b8a6 0%, #0d9488 50%, #0f766e 100%);      /* Teal */
    --gradient-aqua: linear-gradient(135deg, #22d3ee 0%, #06b6d4 50%, #0891b2 100%);      /* Light aqua */
    --gradient-lagoon: linear-gradient(135deg, #0891b2 0%, #0e7490 50%, #155e75 100%);    /* Deep lagoon */

    /* ----- NEUTRAL FAMILY (Grays & Browns) ----- */
    --gradient-slate: linear-gradient(135deg, #64748b 0%, #475569 50%, #334155 100%);     /* Blue-gray */
    --gradient-steel: linear-gradient(135deg, #71717a 0%, #52525b 50%, #3f3f46 100%);     /* Neutral gray */
    --gradient-charcoal: linear-gradient(135deg, #3f3f46 0%, #27272a 50%, #18181b 100%); /* Dark charcoal */
    --gradient-coffee: linear-gradient(135deg, #78350f 0%, #5c2c0a 50%, #451a03 100%);    /* Rich coffee */

    /* ----- DUOTONE GRADIENTS (Multi-color combinations) ----- */
    --gradient-indigo-purple: linear-gradient(135deg, #667eea 0%, #764ba2 100%);          /* Indigo to purple */
    --gradient-berry: linear-gradient(135deg, #ec4899 0%, #d946ef 50%, #7c3aed 100%);     /* Hot Pink → Fuchsia → Purple */
    --gradient-tropical: linear-gradient(135deg, #06b6d4 0%, #84cc16 100%);               /* Cyan to lime */
    --gradient-flame: linear-gradient(135deg, #ef4444 0%, #f97316 100%);                  /* Red to orange */
    --gradient-mango: linear-gradient(135deg, #f97316 0%, #fbbf24 100%);                  /* Orange to yellow */
    --gradient-aurora: linear-gradient(135deg, #06b6d4 0%, #8b5cf6 50%, #ec4899 100%);    /* Cyan-purple-pink */
    --gradient-rainbow: linear-gradient(135deg, #ef4444 0%, #f59e0b 25%, #22c55e 50%, #3b82f6 75%, #8b5cf6 100%);

    /* NOTE: Primary color system is now defined in variables.css
       These are kept for backward compatibility with gradient references */

    /* Background Colors */
    --bg-card: var(--color-surface, #ffffff);
    --bg-muted: var(--color-surface-muted, #f8fafc);
    --bg-border: var(--color-border, #e5e7eb);

    /* Text Colors - reference variables.css */
    --text-primary: var(--color-text-primary, #1f2937);
    --text-secondary: var(--color-text-secondary, #6b7280);
    --text-muted: var(--color-text-muted, #9ca3af);
}

/* ==========================================================================
   Global Form Focus States - Indigo-Purple Theme
   ========================================================================== */

/* Standard form controls */
.form-control:focus,
.form-select:focus {
    border-color: var(--color-focus-border, #7c3aed);
    box-shadow: 0 0 0 3px var(--color-focus-ring, rgba(124, 58, 237, 0.4));
    outline: none;
}

/* Checkboxes and radios */
.form-check-input:focus {
    border-color: var(--color-focus-border, #7c3aed);
    box-shadow: 0 0 0 3px var(--color-focus-ring, rgba(124, 58, 237, 0.4));
}

.form-check-input:checked {
    background-color: var(--color-primary, #7c3aed);
    border-color: var(--color-primary, #7c3aed);
}

/* Buttons focus state */
.btn:focus,
.btn:focus-visible {
    box-shadow: 0 0 0 3px var(--color-focus-ring, rgba(124, 58, 237, 0.4));
}

/* Links focus state */
a:focus-visible {
    outline: 2px solid var(--color-focus-border, #7c3aed);
    outline-offset: 2px;
}

/* ==========================================================================
   Simple Background Colors (for cards)
   Organized by color family for easy selection
   ========================================================================== */

/* Blues */
.bg-blue { background: #3b82f6 !important; }
.bg-sky { background: #0ea5e9 !important; }
.bg-sapphire { background: #1e40af !important; }
.bg-navy { background: #1e3a5f !important; }
.bg-ocean { background: #0077b6 !important; }

/* Purples */
.bg-purple { background: #7c3aed !important; }
.bg-violet { background: #8b5cf6 !important; }
.bg-indigo { background: #6366f1 !important; }
.bg-amethyst { background: #9333ea !important; }
.bg-grape { background: #6b21a8 !important; }

/* Pinks */
.bg-pink { background: #ec4899 !important; }
.bg-fuchsia { background: #d946ef !important; }
.bg-rose { background: #f43f5e !important; }
.bg-blush { background: #fda4af !important; }
.bg-coral { background: #f97171 !important; }

/* Reds */
.bg-red { background: #ef4444 !important; }
.bg-ruby { background: #be123c !important; }
.bg-wine { background: #831843 !important; }
.bg-crimson { background: #dc2626 !important; }

/* Oranges */
.bg-orange { background: #f97316 !important; }
.bg-amber { background: #f59e0b !important; }
.bg-tangerine { background: #fb923c !important; }
.bg-peach { background: #fdba74 !important; }
.bg-bronze { background: #b45309 !important; }

/* Yellows */
.bg-yellow { background: #f5c518 !important; }
.bg-gold { background: #fbbf24 !important; }
.bg-honey { background: #fcd34d !important; }
.bg-mustard { background: #ca8a04 !important; }

/* Greens */
.bg-green { background: #059669 !important; }
.bg-emerald { background: #10b981 !important; }
.bg-lime { background: #84cc16 !important; }
.bg-forest { background: #166534 !important; }
.bg-mint { background: #34d399 !important; }
.bg-jade { background: #0d9488 !important; }

/* Cyans/Teals */
.bg-cyan { background: #06b6d4 !important; }
.bg-teal { background: #14b8a6 !important; }
.bg-aqua { background: #22d3ee !important; }
.bg-lagoon { background: #0891b2 !important; }

/* Neutrals */
.bg-slate { background: #64748b !important; }
.bg-steel { background: #71717a !important; }
.bg-charcoal { background: #3f3f46 !important; }
.bg-coffee { background: #78350f !important; }

/* Light Background Colors (for subtle cards - dark text) */
.bg-amber-light { background: var(--color-primary-light) !important; color: var(--color-primary-dark) !important; }
.bg-success-light { background: var(--color-success-light) !important; color: var(--color-success-dark) !important; }
.bg-danger-light { background: var(--color-danger-light) !important; color: var(--color-danger-dark) !important; }
.bg-info-light { background: var(--color-info-light) !important; color: var(--color-info-dark) !important; }
.bg-warning-light { background: var(--color-warning-light) !important; color: var(--color-warning-dark) !important; }
.bg-blush-light { background: #fce7f3 !important; color: #9d174d !important; }
.bg-sky-light { background: #e0f2fe !important; color: #0369a1 !important; }
.bg-mint-light { background: #d1fae5 !important; color: #047857 !important; }
.bg-violet-light { background: #ede9fe !important; color: #5b21b6 !important; }

/* ==========================================================================
   Text Colors (Theme)
   ========================================================================== */

.text-primary { color: var(--color-primary) !important; }
.text-primary-dark { color: var(--color-primary-dark) !important; }
.text-accent { color: var(--color-accent) !important; }
.text-indigo { color: #6366f1 !important; }
.text-violet { color: #7c3aed !important; }
.text-fuchsia { color: #a855f7 !important; }

/* ==========================================================================
   Dashboard Card - Light Variant (Option 4)
   Light background with colored icon/text
   ========================================================================== */

.dashboard-card-light {
    background: var(--color-primary-light) !important;
    border: 1px solid rgba(124, 58, 237, 0.15) !important;
}

.dashboard-card-light .card-icon {
    color: var(--color-primary);
}

.dashboard-card-light .card-link {
    color: var(--color-primary-dark);
    transition: color 0.2s ease;
}

.dashboard-card-light .card-link:hover {
    color: var(--color-primary);
}

/* ==========================================================================
   Gradient Backgrounds (for cards)
   ========================================================================== */

/* Blues */
.bg-gradient-blue { background: var(--gradient-blue) !important; }
.bg-gradient-sky { background: var(--gradient-sky) !important; }
.bg-gradient-sapphire { background: var(--gradient-sapphire) !important; }
.bg-gradient-navy { background: var(--gradient-navy) !important; }
.bg-gradient-ocean { background: var(--gradient-ocean) !important; }

/* Purples */
.bg-gradient-purple { background: var(--gradient-purple) !important; }
.bg-gradient-violet { background: var(--gradient-violet) !important; }
.bg-gradient-indigo { background: var(--gradient-indigo) !important; }
.bg-gradient-amethyst { background: var(--gradient-amethyst) !important; }
.bg-gradient-grape { background: var(--gradient-grape) !important; }

/* Pinks */
.bg-gradient-pink { background: var(--gradient-pink) !important; }
.bg-gradient-fuchsia { background: var(--gradient-fuchsia) !important; }
.bg-gradient-rose { background: var(--gradient-rose) !important; }
.bg-gradient-blush { background: var(--gradient-blush) !important; }
.bg-gradient-coral { background: var(--gradient-coral) !important; }

/* Reds */
.bg-gradient-red { background: var(--gradient-red) !important; }
.bg-gradient-ruby { background: var(--gradient-ruby) !important; }
.bg-gradient-wine { background: var(--gradient-wine) !important; }
.bg-gradient-crimson { background: var(--gradient-crimson) !important; }

/* Oranges */
.bg-gradient-orange { background: var(--gradient-orange) !important; }
.bg-gradient-amber { background: var(--gradient-amber) !important; }
.bg-gradient-tangerine { background: var(--gradient-tangerine) !important; }
.bg-gradient-peach { background: var(--gradient-peach) !important; }
.bg-gradient-bronze { background: var(--gradient-bronze) !important; }

/* Yellows */
.bg-gradient-yellow { background: var(--gradient-yellow) !important; }
.bg-gradient-gold { background: var(--gradient-gold) !important; }
.bg-gradient-honey { background: var(--gradient-honey) !important; }
.bg-gradient-mustard { background: var(--gradient-mustard) !important; }

/* Greens */
.bg-gradient-green { background: var(--gradient-green) !important; }
.bg-gradient-emerald { background: var(--gradient-emerald) !important; }
.bg-gradient-lime { background: var(--gradient-lime) !important; }
.bg-gradient-forest { background: var(--gradient-forest) !important; }
.bg-gradient-mint { background: var(--gradient-mint) !important; }
.bg-gradient-jade { background: var(--gradient-jade) !important; }

/* Cyans/Teals */
.bg-gradient-cyan { background: var(--gradient-cyan) !important; }
.bg-gradient-teal { background: var(--gradient-teal) !important; }
.bg-gradient-aqua { background: var(--gradient-aqua) !important; }
.bg-gradient-lagoon { background: var(--gradient-lagoon) !important; }

/* Neutrals */
.bg-gradient-slate { background: var(--gradient-slate) !important; }
.bg-gradient-steel { background: var(--gradient-steel) !important; }
.bg-gradient-charcoal { background: var(--gradient-charcoal) !important; }
.bg-gradient-coffee { background: var(--gradient-coffee) !important; }

/* Duotone/Multi-color */
.bg-gradient-indigo-purple { background: var(--gradient-indigo-purple) !important; }
.bg-gradient-berry { background: var(--gradient-berry) !important; }
.bg-gradient-tropical { background: var(--gradient-tropical) !important; }
.bg-gradient-flame { background: var(--gradient-flame) !important; }
.bg-gradient-mango { background: var(--gradient-mango) !important; }
.bg-gradient-aurora { background: var(--gradient-aurora) !important; }
.bg-gradient-rainbow { background: var(--gradient-rainbow) !important; }

/* ==========================================================================
   Page Header
   ========================================================================== */

.page-header {
    color: white;
    padding: 1.5rem 2rem;
    border-radius: 12px;
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

/* ----- BLUE FAMILY ----- */
.page-header.blue { background: var(--gradient-blue); box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3); }
.page-header.sky { background: var(--gradient-sky); box-shadow: 0 4px 15px rgba(14, 165, 233, 0.3); }
.page-header.sapphire { background: var(--gradient-sapphire); box-shadow: 0 4px 15px rgba(30, 64, 175, 0.3); }
.page-header.navy { background: var(--gradient-navy); box-shadow: 0 4px 15px rgba(30, 58, 95, 0.3); }
.page-header.ocean { background: var(--gradient-ocean); box-shadow: 0 4px 15px rgba(0, 119, 182, 0.3); }

/* ----- PURPLE FAMILY ----- */
.page-header.purple { background: var(--gradient-purple); box-shadow: 0 4px 15px rgba(124, 58, 237, 0.3); }
.page-header.violet { background: var(--gradient-violet); box-shadow: 0 4px 15px rgba(139, 92, 246, 0.3); }
.page-header.violet-light { background: #ede9fe; color: #5b21b6; box-shadow: 0 4px 15px rgba(124, 58, 237, 0.15); }
.page-header.indigo { background: var(--gradient-indigo); box-shadow: 0 4px 15px rgba(99, 102, 241, 0.3); }
.page-header.amethyst { background: var(--gradient-amethyst); box-shadow: 0 4px 15px rgba(147, 51, 234, 0.3); }
.page-header.grape { background: var(--gradient-grape); box-shadow: 0 4px 15px rgba(107, 33, 168, 0.3); }

/* ----- PINK FAMILY ----- */
.page-header.pink { background: var(--gradient-pink); box-shadow: 0 4px 15px rgba(236, 72, 153, 0.3); }
.page-header.fuchsia { background: var(--gradient-fuchsia); box-shadow: 0 4px 15px rgba(217, 70, 239, 0.3); }
.page-header.rose { background: var(--gradient-rose); box-shadow: 0 4px 15px rgba(244, 63, 94, 0.3); }
.page-header.blush { background: var(--gradient-blush); color: #1a1a1a; box-shadow: 0 4px 15px rgba(253, 164, 175, 0.3); }
.page-header.coral { background: var(--gradient-coral); box-shadow: 0 4px 15px rgba(249, 113, 113, 0.3); }

/* ----- RED FAMILY ----- */
.page-header.red { background: var(--gradient-red); box-shadow: 0 4px 15px rgba(239, 68, 68, 0.3); }
.page-header.ruby { background: var(--gradient-ruby); box-shadow: 0 4px 15px rgba(190, 18, 60, 0.3); }
.page-header.wine { background: var(--gradient-wine); box-shadow: 0 4px 15px rgba(131, 24, 67, 0.3); }
.page-header.crimson { background: var(--gradient-crimson); box-shadow: 0 4px 15px rgba(220, 38, 38, 0.3); }

/* ----- ORANGE FAMILY ----- */
.page-header.orange { background: var(--gradient-orange); box-shadow: 0 4px 15px rgba(249, 115, 22, 0.3); }
.page-header.amber { background: var(--gradient-amber); color: #1a1a1a; box-shadow: 0 4px 15px rgba(245, 158, 11, 0.3); }
.page-header.tangerine { background: var(--gradient-tangerine); box-shadow: 0 4px 15px rgba(251, 146, 60, 0.3); }
.page-header.peach { background: var(--gradient-peach); color: #1a1a1a; box-shadow: 0 4px 15px rgba(253, 186, 116, 0.3); }
.page-header.bronze { background: var(--gradient-bronze); box-shadow: 0 4px 15px rgba(180, 83, 9, 0.3); }

/* ----- YELLOW FAMILY ----- */
.page-header.yellow { background: var(--gradient-yellow); color: #1a1a1a; box-shadow: 0 4px 15px rgba(245, 197, 24, 0.3); }
.page-header.gold { background: var(--gradient-gold); color: #1a1a1a; box-shadow: 0 4px 15px rgba(251, 191, 36, 0.3); }
.page-header.honey { background: var(--gradient-honey); color: #1a1a1a; box-shadow: 0 4px 15px rgba(252, 211, 77, 0.3); }
.page-header.mustard { background: var(--gradient-mustard); box-shadow: 0 4px 15px rgba(202, 138, 4, 0.3); }

/* ----- GREEN FAMILY ----- */
.page-header.green { background: var(--gradient-green); box-shadow: 0 4px 15px rgba(5, 150, 105, 0.3); }
.page-header.emerald { background: var(--gradient-emerald); box-shadow: 0 4px 15px rgba(16, 185, 129, 0.3); }
.page-header.lime { background: var(--gradient-lime); color: #1a1a1a; box-shadow: 0 4px 15px rgba(132, 204, 22, 0.3); }
.page-header.forest { background: var(--gradient-forest); box-shadow: 0 4px 15px rgba(22, 101, 52, 0.3); }
.page-header.mint { background: var(--gradient-mint); color: #1a1a1a; box-shadow: 0 4px 15px rgba(52, 211, 153, 0.3); }
.page-header.jade { background: var(--gradient-jade); box-shadow: 0 4px 15px rgba(13, 148, 136, 0.3); }

/* ----- CYAN/TEAL FAMILY ----- */
.page-header.cyan { background: var(--gradient-cyan); box-shadow: 0 4px 15px rgba(6, 182, 212, 0.3); }
.page-header.teal { background: var(--gradient-teal); box-shadow: 0 4px 15px rgba(20, 184, 166, 0.3); }
.page-header.aqua { background: var(--gradient-aqua); color: #1a1a1a; box-shadow: 0 4px 15px rgba(34, 211, 238, 0.3); }
.page-header.lagoon { background: var(--gradient-lagoon); box-shadow: 0 4px 15px rgba(8, 145, 178, 0.3); }

/* ----- NEUTRAL FAMILY ----- */
.page-header.slate { background: var(--gradient-slate); box-shadow: 0 4px 15px rgba(100, 116, 139, 0.3); }
.page-header.steel { background: var(--gradient-steel); box-shadow: 0 4px 15px rgba(113, 113, 122, 0.3); }
.page-header.charcoal { background: var(--gradient-charcoal); box-shadow: 0 4px 15px rgba(63, 63, 70, 0.3); }
.page-header.coffee { background: var(--gradient-coffee); box-shadow: 0 4px 15px rgba(120, 53, 15, 0.3); }

/* ----- DUOTONE/MULTI-COLOR ----- */
.page-header.indigo-purple { background: var(--gradient-indigo-purple); box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3); }
.page-header.berry { background: var(--gradient-berry); box-shadow: 0 4px 15px rgba(124, 58, 237, 0.3); }
.page-header.tropical { background: var(--gradient-tropical); box-shadow: 0 4px 15px rgba(6, 182, 212, 0.3); }
.page-header.flame { background: var(--gradient-flame); box-shadow: 0 4px 15px rgba(239, 68, 68, 0.3); }
.page-header.mango { background: var(--gradient-mango); color: #1a1a1a; box-shadow: 0 4px 15px rgba(249, 115, 22, 0.3); }
.page-header.aurora { background: var(--gradient-aurora); box-shadow: 0 4px 15px rgba(139, 92, 246, 0.3); }

/* Dark text for light-colored headers */
.page-header.honey h1, .page-header.peach h1, .page-header.blush h1, .page-header.mint h1,
.page-header.aqua h1, .page-header.mango h1, .page-header.violet-light h1 { color: #5b21b6; }
.page-header.honey .subtitle, .page-header.peach .subtitle, .page-header.blush .subtitle, .page-header.mint .subtitle,
.page-header.aqua .subtitle, .page-header.mango .subtitle, .page-header.violet-light .subtitle { color: #7c3aed; opacity: 0.85; }

/* White page header - clean, minimal */
.page-header.white {
    background: #ffffff;
    color: var(--color-text-primary, #0f172a);
    border: 1px solid var(--color-border, #e2e8f0);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}
.page-header.white h1 { color: var(--color-text-primary, #0f172a); }
.page-header.white .subtitle { color: var(--color-text-secondary, #475569); opacity: 1; }

/* Surface page header - warm white background (Sunrise Amber palette) */
.page-header.surface {
    background: #fffbeb;
    color: var(--color-text-primary, #0f172a);
    border: 1px solid #fef3c7;
    box-shadow: 0 4px 15px rgba(245, 158, 11, 0.1);
}
.page-header.surface h1 { color: var(--color-text-primary, #0f172a); }
.page-header.surface .subtitle { color: var(--color-text-secondary, #475569); opacity: 1; }

.page-header h1 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.page-header.yellow h1 { color: #1a1a1a; }
.page-header.amber h1 { color: #1a1a1a; }
.page-header.lime h1 { color: #1a1a1a; }
.page-header .subtitle {
    opacity: 0.9;
    margin-top: 0.25rem;
    font-size: 0.9rem;
}

.page-header.yellow .subtitle { color: #1a1a1a; }
.page-header.amber .subtitle { color: #1a1a1a; }
.page-header.lime .subtitle { color: #1a1a1a; }

/* ==========================================================================
   Stats Cards
   ========================================================================== */

.stats-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.stat-card {
    background: #ffffff;
    border-radius: 10px;
    padding: 1.25rem;
    text-align: center;
    box-shadow: var(--shadow-md);
    transition: transform 0.2s, box-shadow 0.2s;
    border-left: 4px solid transparent;
}

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

.stat-card .stat-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
}

.stat-card .stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 0.25rem;
}

/* Stat Card Color Variants */
.stat-card.primary { border-left-color: var(--color-primary); }
.stat-card.primary .stat-value { color: var(--color-primary); }

.stat-card.success { border-left-color: var(--color-success); }
.stat-card.success .stat-value { color: var(--color-success); }

.stat-card.warning { border-left-color: var(--color-warning); }
.stat-card.warning .stat-value { color: var(--color-warning); }

.stat-card.danger { border-left-color: var(--color-danger); }
.stat-card.danger .stat-value { color: var(--color-danger); }

.stat-card.info { border-left-color: var(--color-info); }
.stat-card.info .stat-value { color: var(--color-info); }

.stat-card.secondary { border-left-color: var(--color-secondary); }
.stat-card.secondary .stat-value { color: var(--color-secondary); }

/* Additional stat card colors */
.stat-card.purple { border-left-color: #8b5cf6; }
.stat-card.purple .stat-value { color: #8b5cf6; }

.stat-card.cyan { border-left-color: #06b6d4; }
.stat-card.cyan .stat-value { color: #06b6d4; }

.stat-card.orange { border-left-color: #f97316; }
.stat-card.orange .stat-value { color: #f97316; }

.stat-card.pink { border-left-color: #ec4899; }
.stat-card.pink .stat-value { color: #ec4899; }

.stat-card.rose { border-left-color: #f43f5e; }
.stat-card.rose .stat-value { color: #f43f5e; }

.stat-card.indigo { border-left-color: #6366f1; }
.stat-card.indigo .stat-value { color: #6366f1; }

.stat-card.teal { border-left-color: #14b8a6; }
.stat-card.teal .stat-value { color: #14b8a6; }

.stat-card.amber { border-left-color: #f59e0b; }
.stat-card.amber .stat-value { color: #f59e0b; }

.stat-card.lime { border-left-color: #84cc16; }
.stat-card.lime .stat-value { color: #84cc16; }

.stat-card.slate { border-left-color: #64748b; }
.stat-card.slate .stat-value { color: #64748b; }

.stat-card.sky { border-left-color: #0ea5e9; }
.stat-card.sky .stat-value { color: #0ea5e9; }

.stat-card.violet { border-left-color: #8b5cf6; }
.stat-card.violet .stat-value { color: #8b5cf6; }

.stat-card.emerald { border-left-color: #10b981; }
.stat-card.emerald .stat-value { color: #10b981; }

.stat-card.fuchsia { border-left-color: #d946ef; }
.stat-card.fuchsia .stat-value { color: #d946ef; }

.stat-card.indigo-purple { border-left-color: #667eea; }
.stat-card.indigo-purple .stat-value { color: #667eea; }

/* ==========================================================================
   Filter Bar
   ========================================================================== */

.filter-bar {
    background: var(--bg-card);
    padding: 1.25rem;
    border-radius: 10px;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-md);
}

.filter-bar .form-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
}

/* ==========================================================================
   Data Table
   ========================================================================== */

.data-table-container {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    max-width: 100%;
    display: block;
}

.data-table,
.data-table-container .table.data-table,
.data-table-container > .table {
    margin: 0;
    font-size: 0.875rem;
    min-width: 800px !important; /* Prevents columns from shrinking too much, enables horizontal scroll */
    width: 100%;
}

.data-table thead th {
    background: var(--bg-muted);
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 2px solid var(--bg-border);
    padding: 0.875rem 1rem;
    white-space: nowrap;
}

.data-table tbody td {
    padding: 0.75rem 1rem;
    vertical-align: middle;
    border-bottom: 1px solid #f1f5f9;
}

.data-table tbody tr:hover {
    background: var(--bg-muted);
}

.data-table tbody tr:last-child td {
    border-bottom: none;
}

/* Sortable columns */
.data-table th.sortable {
    cursor: pointer;
    user-select: none;
}

.data-table th.sortable:hover {
    background: #e2e8f0;
}

.data-table th.sortable::after {
    content: ' \2195';
    opacity: 0.3;
}

.data-table th.sort-asc::after {
    content: ' \2191';
    opacity: 1;
}

.data-table th.sort-desc::after {
    content: ' \2193';
    opacity: 1;
}

/* ==========================================================================
   Status Badges
   ========================================================================== */

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.status-badge.active,
.status-badge.success,
.status-badge.completed {
    background: #d1fae5;
    color: #065f46;
}

.status-badge.inactive,
.status-badge.danger,
.status-badge.failed {
    background: #fee2e2;
    color: #991b1b;
}

.status-badge.pending,
.status-badge.warning {
    background: #fef3c7;
    color: #92400e;
}

.status-badge.running,
.status-badge.info,
.status-badge.primary {
    background: #dbeafe;
    color: #1e40af;
}

.status-badge.secondary,
.status-badge.default {
    background: #f3f4f6;
    color: #6b7280;
}

/* ==========================================================================
   Subscription Badges (Paid/Free)
   ========================================================================== */

.subscription-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.subscription-badge.paid {
    background: #ede9fe;
    color: #5b21b6;
}

.subscription-badge.free {
    background: #ecfdf5;
    color: #047857;
}

/* ==========================================================================
   Action Buttons
   ========================================================================== */

.action-buttons {
    display: flex;
    gap: 0.5rem;
}

.btn-action {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    border-radius: 6px;
    font-weight: 500;
    transition: all 0.15s;
}

.btn-action:hover {
    transform: translateY(-1px);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.pagination-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    background: var(--bg-muted);
    border-top: 1px solid var(--bg-border);
}

.pagination-info {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

/* ==========================================================================
   Empty State
   ========================================================================== */

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

.empty-state i {
    font-size: 3rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.empty-state h5 {
    color: var(--text-primary);
    margin-bottom: 0.5rem;
}

/* ==========================================================================
   User/Entity Info Cell
   ========================================================================== */

.entity-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.entity-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--gradient-blue);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 0.875rem;
    flex-shrink: 0;
}

.entity-avatar.green { background: var(--gradient-green); }
.entity-avatar.purple { background: var(--gradient-purple); }
.entity-avatar.cyan { background: var(--gradient-cyan); }

.entity-details .entity-name {
    font-weight: 600;
    color: var(--text-primary);
}

.entity-details .entity-subtitle {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* ==========================================================================
   ID Badge
   ========================================================================== */

.id-badge {
    font-family: 'Monaco', 'Menlo', 'Consolas', monospace;
    font-size: 0.7rem;
    color: var(--text-muted);
    background: #f3f4f6;
    padding: 0.125rem 0.375rem;
    border-radius: 4px;
}

/* ==========================================================================
   Loading Overlay - Full Page (used by Himalayan Jobs, etc.)
   ========================================================================== */

.loading-overlay-fullpage {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255,255,255,0.9);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s;
}

.loading-overlay-fullpage.show {
    opacity: 1;
    visibility: visible;
}

/* ==========================================================================
   Card Enhancements
   ========================================================================== */

.card-enhanced {
    background: var(--bg-card);
    border: none;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    transition: transform 0.2s, box-shadow 0.2s;
}

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

.card-enhanced .card-header {
    background: var(--bg-muted);
    border-bottom: 1px solid var(--bg-border);
    font-weight: 600;
    padding: 1rem 1.25rem;
}

/* ==========================================================================
   Page Header Buttons
   ========================================================================== */

.btn-header {
    background: white;
    font-weight: 600;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    border: 2px solid rgba(255,255,255,0.3);
    transition: all 0.15s;
    text-decoration: none;
}

.btn-header:hover {
    background: rgba(255,255,255,0.95);
    transform: translateY(-1px);
}

/* Color variants for header buttons */
.btn-header.blue { color: #2563eb; }
.btn-header.blue:hover { color: #1d4ed8; }

.btn-header.indigo { color: #4f46e5; }
.btn-header.indigo:hover { color: #4338ca; }

.btn-header.green { color: #059669; }
.btn-header.green:hover { color: #047857; }

.btn-header.purple { color: #7c3aed; }
.btn-header.purple:hover { color: #6d28d9; }

.btn-header.teal { color: #0d9488; }
.btn-header.teal:hover { color: #0f766e; }

.btn-header.orange { color: #ea580c; }
.btn-header.orange:hover { color: #c2410c; }

.btn-header.emerald { color: #059669; }
.btn-header.emerald:hover { color: #047857; }

.btn-header.amber { color: #d97706; }
.btn-header.amber:hover { color: #b45309; }

.btn-header.violet { color: #7c3aed; }
.btn-header.violet:hover { color: #6d28d9; }

.btn-header.fuchsia { color: #c026d3; }
.btn-header.fuchsia:hover { color: #a21caf; }

.btn-header.lime { color: #65a30d; }
.btn-header.lime:hover { color: #4d7c0f; }

.btn-header.indigo-purple { color: #667eea; }
.btn-header.indigo-purple:hover { color: #5a67d8; }

.btn-header.cyan { color: #0891b2; }
.btn-header.cyan:hover { color: #0e7490; }

.btn-header.rose { color: #e11d48; }
.btn-header.rose:hover { color: #be123c; }

.btn-header.pink { color: #db2777; }
.btn-header.pink:hover { color: #be185d; }

.btn-header.berry { color: #c026d3; }
.btn-header.berry:hover { color: #a21caf; }

.btn-header.slate { color: #475569; }
.btn-header.slate:hover { color: #334155; }

.btn-header.red { color: #dc2626; }
.btn-header.red:hover { color: #b91c1c; }

.btn-header.sky { color: #0284c7; }
.btn-header.sky:hover { color: #0369a1; }

.btn-header.white { color: var(--color-primary, #f59e0b); }
.btn-header.white:hover { color: var(--color-primary-hover, #d97706); }

/* Back Button - Right side of header */
.btn-back {
    display: inline-flex;
    align-items: center;
    background: rgba(255,255,255,0.15);
    color: white;
    font-weight: 500;
    font-size: 0.8rem;
    padding: 0.35rem 0.7rem;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.25);
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-back:hover {
    background: rgba(255,255,255,0.25);
    color: white;
    text-decoration: none;
}

.btn-back i {
    margin-right: 0.35rem;
    font-size: 0.75rem;
}

/* Dark text variants for light backgrounds */
.page-header.yellow .btn-back,
.page-header.amber .btn-back,
.page-header.lime .btn-back,
.page-header.white .btn-back,
.page-header.surface .btn-back,
.page-header.gold .btn-back,
.page-header.honey .btn-back,
.page-header.peach .btn-back,
.page-header.blush .btn-back,
.page-header.mint .btn-back,
.page-header.aqua .btn-back,
.page-header.mango .btn-back,
.page-header.violet-light .btn-back {
    background: rgba(0,0,0,0.08);
    color: #5b21b6;
    border-color: rgba(124,58,237,0.2);
}

.page-header.yellow .btn-back:hover,
.page-header.amber .btn-back:hover,
.page-header.lime .btn-back:hover,
.page-header.white .btn-back:hover,
.page-header.surface .btn-back:hover,
.page-header.gold .btn-back:hover,
.page-header.honey .btn-back:hover,
.page-header.peach .btn-back:hover,
.page-header.blush .btn-back:hover,
.page-header.mint .btn-back:hover,
.page-header.aqua .btn-back:hover,
.page-header.mango .btn-back:hover,
.page-header.violet-light .btn-back:hover {
    background: rgba(124,58,237,0.15);
    color: #5b21b6;
}

/* ==========================================================================
   Filter Bar Enhanced
   ========================================================================== */

.filter-bar .form-select,
.filter-bar .form-control {
    font-size: 0.875rem;
    border: 1px solid var(--bg-border);
    border-radius: 6px;
}

.filter-bar .filter-divider {
    border-top: 1px solid var(--bg-border);
    margin: 1rem 0;
}

/* Focus states - consistent across all filter bars */
.filter-bar .form-select:focus,
.filter-bar .form-control:focus {
    border-color: #6b7280;
    box-shadow: 0 0 0 3px rgba(107, 114, 128, 0.1);
}

/* Reset button - compact and elegant */
.btn-filter-reset {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border: 1px solid #e5e7eb;
    color: #6b7280;
    font-weight: 500;
    font-size: 0.8rem;
    background: #f9fafb;
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.btn-filter-reset:hover {
    background: #f3f4f6;
    border-color: #d1d5db;
    color: #374151;
}

.btn-filter-reset:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-filter-reset i {
    font-size: 0.75rem;
}

/* ==========================================================================
   User/Entity Display (Enhanced)
   ========================================================================== */

.user-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 0.875rem;
    flex-shrink: 0;
}

.user-details .user-name {
    font-weight: 600;
    color: var(--text-primary);
}

.user-details .user-email {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* ==========================================================================
   Data Display Badges
   ========================================================================== */

/* Currency badge */
.currency-badge {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    background: #f3f4f6;
    color: var(--text-primary);
}

/* Interval/time badge */
.interval-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    background: #dbeafe;
    color: #1e40af;
}

/* Price value */
.price-value {
    font-weight: 600;
    color: #059669;
}

/* Product info display */
.product-name {
    font-weight: 500;
    color: var(--text-primary);
}

.product-info {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

/* Date display */
.date-display {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* ==========================================================================
   Action Button Variants
   ========================================================================== */

.btn-action-edit {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    border-radius: 6px;
    font-weight: 500;
    background: transparent;
    text-decoration: none;
    transition: all 0.15s;
}

.btn-action-edit:hover {
    transform: translateY(-1px);
}

/* Color variants */
.btn-action-edit.blue {
    border: 1px solid #3b82f6;
    color: #3b82f6;
}
.btn-action-edit.blue:hover {
    background: #3b82f6;
    color: white;
}

.btn-action-edit.indigo {
    border: 1px solid #6366f1;
    color: #6366f1;
}
.btn-action-edit.indigo:hover {
    background: #6366f1;
    color: white;
}

.btn-action-edit.green {
    border: 1px solid #059669;
    color: #059669;
}
.btn-action-edit.green:hover {
    background: #059669;
    color: white;
}

.btn-action-edit.purple {
    border: 1px solid #7c3aed;
    color: #7c3aed;
}
.btn-action-edit.purple:hover {
    background: #7c3aed;
    color: white;
}

.btn-action-edit.teal {
    border: 1px solid #14b8a6;
    color: #14b8a6;
}
.btn-action-edit.teal:hover {
    background: #14b8a6;
    color: white;
}

.btn-action-edit.emerald {
    border: 1px solid #10b981;
    color: #10b981;
}
.btn-action-edit.emerald:hover {
    background: #10b981;
    color: white;
}

.btn-action-edit.amber {
    border: 1px solid #f59e0b;
    color: #d97706;
}
.btn-action-edit.amber:hover {
    background: #f59e0b;
    color: white;
}

.btn-action-edit.violet {
    border: 1px solid #8b5cf6;
    color: #7c3aed;
}
.btn-action-edit.violet:hover {
    background: #8b5cf6;
    color: white;
}

.btn-action-edit.fuchsia {
    border: 1px solid #d946ef;
    color: #c026d3;
}
.btn-action-edit.fuchsia:hover {
    background: #d946ef;
    color: white;
}

.btn-action-edit.orange {
    border: 1px solid #f97316;
    color: #ea580c;
}
.btn-action-edit.orange:hover {
    background: #f97316;
    color: white;
}

.btn-action-edit.lime {
    border: 1px solid #84cc16;
    color: #65a30d;
}
.btn-action-edit.lime:hover {
    background: #84cc16;
    color: white;
}

.btn-action-edit.indigo-purple {
    border: 1px solid #667eea;
    color: #667eea;
}
.btn-action-edit.indigo-purple:hover {
    background: #667eea;
    color: white;
}

.btn-action-edit.cyan {
    border: 1px solid #06b6d4;
    color: #0891b2;
}
.btn-action-edit.cyan:hover {
    background: #06b6d4;
    color: white;
}

.btn-action-edit.rose {
    border: 1px solid #f43f5e;
    color: #e11d48;
}
.btn-action-edit.rose:hover {
    background: #f43f5e;
    color: white;
}

.btn-action-edit.berry {
    border: 1px solid #d946ef;
    color: #c026d3;
}
.btn-action-edit.berry:hover {
    background: var(--gradient-berry);
    color: white;
}

/* ==========================================================================
   Table Row Delete Action Button
   ========================================================================== */

.btn-action-delete {
    display: inline-flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 6px;
    text-decoration: none;
    transition: all 0.15s ease;
    cursor: pointer;
    border: 1px solid #ef4444;
    color: #dc2626;
    background: transparent;
}

.btn-action-delete:hover {
    background: #ef4444;
    color: white;
    transform: translateY(-1px);
}

/* ==========================================================================
   Toolbar Buttons (Table Footer Actions)
   ========================================================================== */

.btn-toolbar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    transition: all 0.15s ease;
    text-decoration: none;
    gap: 0.375rem;
}

.btn-toolbar:hover {
    transform: translateY(-1px);
}

.btn-toolbar:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.btn-toolbar.primary {
    background: var(--gradient-brand, linear-gradient(135deg, #fbbf24 0%, #f59e0b 50%, #ea580c 100%));
    color: white;
    box-shadow: 0 2px 4px rgba(245, 158, 11, 0.3);
}

.btn-toolbar.primary:hover {
    box-shadow: 0 4px 8px rgba(245, 158, 11, 0.4);
}

.btn-toolbar.secondary {
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #e2e8f0;
}

.btn-toolbar.secondary:hover {
    background: #e2e8f0;
    color: #334155;
}

.btn-toolbar.danger {
    background: transparent;
    color: #dc2626;
    border: 1px solid #fecaca;
}

.btn-toolbar.danger:hover {
    background: #fef2f2;
    border-color: #fca5a5;
}

.btn-toolbar.success {
    background: var(--gradient-green);
    color: white;
    box-shadow: 0 2px 4px rgba(5, 150, 105, 0.3);
}

.btn-toolbar.success:hover {
    box-shadow: 0 4px 8px rgba(5, 150, 105, 0.4);
}

/* Small toolbar buttons */
.btn-toolbar.sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
}

/* ==========================================================================
   Form Buttons (Submit/Cancel)
   ========================================================================== */

.btn-form {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    transition: all 0.15s ease;
    text-decoration: none;
    gap: 0.5rem;
}

.btn-form:hover {
    transform: translateY(-1px);
}

.btn-form:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.btn-form.primary {
    background: var(--gradient-brand, linear-gradient(135deg, #6366f1 0%, #a855f7 100%));
    color: white;
    box-shadow: 0 2px 6px rgba(124, 58, 237, 0.35);
}

.btn-form.primary:hover {
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.45);
}

.btn-form.secondary {
    background: #f8fafc;
    color: #64748b;
    border: 1px solid #e2e8f0;
}

.btn-form.secondary:hover {
    background: #f1f5f9;
    color: #475569;
    border-color: #cbd5e1;
}

.btn-form.danger {
    background: var(--gradient-red);
    color: white;
    box-shadow: 0 2px 6px rgba(239, 68, 68, 0.35);
}

.btn-form.danger:hover {
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.45);
}

.btn-form.success {
    background: var(--gradient-green);
    color: white;
    box-shadow: 0 2px 6px rgba(5, 150, 105, 0.35);
}

.btn-form.success:hover {
    box-shadow: 0 4px 12px rgba(5, 150, 105, 0.45);
}

/* Large form button (for primary submit) */
.btn-form.lg {
    padding: 0.75rem 2rem;
    font-size: 1rem;
}

/* Form button color variants */
.btn-form.indigo {
    background: var(--gradient-indigo);
    color: white;
    box-shadow: 0 2px 6px rgba(99, 102, 241, 0.35);
}

.btn-form.indigo:hover {
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.45);
}

.btn-form.cyan {
    background: var(--gradient-cyan);
    color: white;
    box-shadow: 0 2px 6px rgba(6, 182, 212, 0.35);
}

.btn-form.cyan:hover {
    box-shadow: 0 4px 12px rgba(6, 182, 212, 0.45);
}

.btn-form.purple {
    background: var(--gradient-purple);
    color: white;
    box-shadow: 0 2px 6px rgba(124, 58, 237, 0.35);
}

.btn-form.purple:hover {
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.45);
}

.btn-form.indigo-purple {
    background: var(--gradient-indigo-purple);
    color: white;
    box-shadow: 0 2px 6px rgba(102, 126, 234, 0.35);
}

.btn-form.indigo-purple:hover {
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.45);
}

.btn-form.berry {
    background: var(--gradient-berry);
    color: white;
    box-shadow: 0 2px 6px rgba(217, 70, 239, 0.35);
}

.btn-form.berry:hover {
    box-shadow: 0 4px 12px rgba(217, 70, 239, 0.45);
}

.btn-form.sky {
    background: var(--gradient-sky);
    color: white;
    box-shadow: 0 2px 6px rgba(14, 165, 233, 0.35);
}

.btn-form.sky:hover {
    box-shadow: 0 4px 12px rgba(14, 165, 233, 0.45);
}

.btn-form.aurora {
    background: var(--gradient-aurora);
    color: white;
    box-shadow: 0 2px 6px rgba(139, 92, 246, 0.35);
}

.btn-form.aurora:hover {
    box-shadow: 0 4px 12px rgba(139, 92, 246, 0.45);
}

/* ==========================================================================
   Form Container & Sections (Create/Edit Pages)
   ========================================================================== */

.form-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 1rem;
}

.form-section {
    background: white;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 4px 12px rgba(0, 0, 0, 0.05);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.form-section-header {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid #e2e8f0;
}

.form-section-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: #1e293b;
    display: flex;
    align-items: center;
}

.form-section-title i {
    color: var(--color-primary, #7c3aed);
}

.form-section-subtitle {
    font-size: 0.875rem;
    color: #64748b;
    margin-top: 0.25rem;
}

/* Form Actions Footer */
.form-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem 0;
    border-top: 1px solid #e2e8f0;
    margin-top: 1rem;
}

/* Utility: Dashed border */
.border-dashed {
    border-style: dashed !important;
}

/* High-contrast form inputs (for tinted/colored backgrounds) */
.form-high-contrast .form-control,
.form-high-contrast .form-select {
    background-color: #ffffff;
    border: 2px solid #c4b5fd;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.form-high-contrast .form-control:focus,
.form-high-contrast .form-select:focus {
    border-color: var(--color-primary, #7c3aed);
    box-shadow: 0 0 0 3px var(--color-focus-ring, rgba(124, 58, 237, 0.25)), 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* ==========================================================================
   Modal Buttons
   ========================================================================== */

.btn-modal {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1.25rem;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    transition: all 0.15s ease;
    text-decoration: none;
    gap: 0.375rem;
}

.btn-modal:hover {
    transform: translateY(-1px);
}

.btn-modal.primary {
    background: var(--gradient-blue);
    color: white;
}

.btn-modal.primary:hover {
    box-shadow: 0 4px 8px rgba(59, 130, 246, 0.3);
}

.btn-modal.secondary {
    background: #f1f5f9;
    color: #64748b;
    border: 1px solid #e2e8f0;
}

.btn-modal.secondary:hover {
    background: #e2e8f0;
    color: #475569;
}

.btn-modal.danger {
    background: var(--gradient-red);
    color: white;
}

.btn-modal.danger:hover {
    box-shadow: 0 4px 8px rgba(239, 68, 68, 0.3);
}

.btn-modal.success {
    background: var(--gradient-green);
    color: white;
}

.btn-modal.success:hover {
    box-shadow: 0 4px 8px rgba(5, 150, 105, 0.3);
}

/* ==========================================================================
   Inline Remove Button (for table rows)
   ========================================================================== */

.btn-inline-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    padding: 0;
    font-size: 0.75rem;
    border-radius: 6px;
    border: 1px solid #fecaca;
    background: transparent;
    color: #ef4444;
    cursor: pointer;
    transition: all 0.15s ease;
}

.btn-inline-remove:hover {
    background: #fef2f2;
    border-color: #fca5a5;
    transform: scale(1.05);
}

.btn-inline-remove:active {
    transform: scale(0.95);
}

/* ==========================================================================
   Empty State Action Button
   ========================================================================== */

.btn-empty-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    transition: all 0.15s ease;
    text-decoration: none;
    gap: 0.5rem;
    background: var(--gradient-brand, linear-gradient(135deg, #fbbf24 0%, #f59e0b 50%, #ea580c 100%));
    color: white;
    box-shadow: 0 2px 6px rgba(245, 158, 11, 0.3);
    margin-top: 1rem;
}

.btn-empty-action:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
    color: white;
}

/* Empty state color variants */
.btn-empty-action.green {
    background: var(--gradient-green);
    box-shadow: 0 2px 6px rgba(5, 150, 105, 0.3);
}

.btn-empty-action.green:hover {
    box-shadow: 0 4px 12px rgba(5, 150, 105, 0.4);
}

.btn-empty-action.indigo {
    background: var(--gradient-indigo);
    box-shadow: 0 2px 6px rgba(99, 102, 241, 0.3);
}

.btn-empty-action.indigo:hover {
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
}

.btn-empty-action.cyan {
    background: var(--gradient-cyan);
    box-shadow: 0 2px 6px rgba(6, 182, 212, 0.3);
}

.btn-empty-action.cyan:hover {
    box-shadow: 0 4px 12px rgba(6, 182, 212, 0.4);
}

.btn-empty-action.purple {
    background: var(--gradient-purple);
    box-shadow: 0 2px 6px rgba(124, 58, 237, 0.3);
}

.btn-empty-action.purple:hover {
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.4);
}

.btn-empty-action.indigo-purple {
    background: var(--gradient-indigo-purple);
    box-shadow: 0 2px 6px rgba(102, 126, 234, 0.3);
}

.btn-empty-action.indigo-purple:hover {
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}

.btn-empty-action.berry {
    background: var(--gradient-berry);
    box-shadow: 0 2px 6px rgba(217, 70, 239, 0.3);
}

.btn-empty-action.berry:hover {
    box-shadow: 0 4px 12px rgba(217, 70, 239, 0.4);
}

/* ==========================================================================
   DataTables Plugin Overrides
   ========================================================================== */

.datatable-container {
    background: var(--bg-card);
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

/* Wrapper padding */
.datatable-container .dataTables_wrapper {
    padding: 0;
}

/* Length and filter controls */
.datatable-container .dataTables_length,
.datatable-container .dataTables_filter {
    padding: 1rem 1.25rem;
    margin: 0;
}

.datatable-container .dataTables_length label,
.datatable-container .dataTables_filter label {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.datatable-container .dataTables_length select,
.datatable-container .dataTables_filter input {
    border: 1px solid var(--bg-border);
    border-radius: 6px;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
}

/* Focus states with accent colors */
.datatable-container.accent-blue .dataTables_filter input:focus {
    border-color: #3b82f6;
    outline: none;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.datatable-container.accent-indigo .dataTables_filter input:focus {
    border-color: #6366f1;
    outline: none;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.datatable-container.accent-green .dataTables_filter input:focus {
    border-color: #059669;
    outline: none;
    box-shadow: 0 0 0 3px rgba(5, 150, 105, 0.1);
}

.datatable-container.accent-purple .dataTables_filter input:focus {
    border-color: #7c3aed;
    outline: none;
    box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}

/* Table styles */
.datatable-container table.dataTable {
    margin: 0 !important;
    width: 100% !important;
    border-collapse: collapse;
}

.datatable-container table.dataTable thead th {
    background: var(--bg-muted);
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 2px solid var(--bg-border) !important;
    padding: 0.875rem 1rem;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.datatable-container table.dataTable tbody td {
    padding: 0.75rem 1rem;
    vertical-align: middle;
    border-bottom: 1px solid #f1f5f9 !important;
    font-size: 0.875rem;
    color: var(--text-primary);
}

.datatable-container table.dataTable tbody tr:hover {
    background: var(--bg-muted) !important;
}

/* Info and pagination */
.datatable-container .dataTables_info {
    padding: 1rem 1.25rem;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.datatable-container .dataTables_paginate {
    padding: 1rem 1.25rem;
}

.datatable-container .dataTables_paginate .paginate_button {
    padding: 0.375rem 0.75rem;
    margin: 0 0.125rem;
    border-radius: 6px;
    border: 1px solid var(--bg-border) !important;
    background: white !important;
    color: var(--text-primary) !important;
    font-size: 0.875rem;
}

.datatable-container .dataTables_paginate .paginate_button:hover {
    background: #f3f4f6 !important;
    border-color: #d1d5db !important;
    color: #111827 !important;
}

.datatable-container .dataTables_paginate .paginate_button.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Pagination active state with accent colors */
.datatable-container.accent-blue .dataTables_paginate .paginate_button.current {
    background: #3b82f6 !important;
    border-color: #3b82f6 !important;
    color: white !important;
}

.datatable-container.accent-indigo .dataTables_paginate .paginate_button.current {
    background: #6366f1 !important;
    border-color: #6366f1 !important;
    color: white !important;
}

.datatable-container.accent-green .dataTables_paginate .paginate_button.current {
    background: #059669 !important;
    border-color: #059669 !important;
    color: white !important;
}

.datatable-container.accent-purple .dataTables_paginate .paginate_button.current {
    background: #7c3aed !important;
    border-color: #7c3aed !important;
    color: white !important;
}

.datatable-container.accent-teal .dataTables_paginate .paginate_button.current {
    background: #14b8a6 !important;
    border-color: #14b8a6 !important;
    color: white !important;
}

/* ==========================================================================
   Dashboard Cards
   ========================================================================== */

.dashboard-card {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 1.5rem;
    text-align: center;
    box-shadow: var(--shadow-md);
    transition: transform 0.2s, box-shadow 0.2s;
    border-top: 4px solid transparent;
    height: 100%;
}

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

.dashboard-card-icon {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
    font-size: 1.5rem;
    color: white;
}

.dashboard-card-title {
    margin: 0 0 0.25rem 0;
    font-weight: 600;
}

.dashboard-card-title a {
    text-decoration: none;
    color: var(--text-primary);
    transition: color 0.15s;
}

.dashboard-card-title a::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.dashboard-card {
    position: relative;
}

.dashboard-card-subtitle {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin: 0;
}

/* Dashboard card color variants */
.dashboard-card.blue { border-top-color: #3b82f6; }
.dashboard-card.blue .dashboard-card-icon { background: var(--gradient-blue); }
.dashboard-card.blue:hover .dashboard-card-title a { color: #3b82f6; }

.dashboard-card.green { border-top-color: #059669; }
.dashboard-card.green .dashboard-card-icon { background: var(--gradient-green); }
.dashboard-card.green:hover .dashboard-card-title a { color: #059669; }

.dashboard-card.emerald { border-top-color: #10b981; }
.dashboard-card.emerald .dashboard-card-icon { background: var(--gradient-emerald); }
.dashboard-card.emerald:hover .dashboard-card-title a { color: #10b981; }

.dashboard-card.indigo { border-top-color: #6366f1; }
.dashboard-card.indigo .dashboard-card-icon { background: var(--gradient-indigo); }
.dashboard-card.indigo:hover .dashboard-card-title a { color: #6366f1; }

.dashboard-card.purple { border-top-color: #7c3aed; }
.dashboard-card.purple .dashboard-card-icon { background: var(--gradient-purple); }
.dashboard-card.purple:hover .dashboard-card-title a { color: #7c3aed; }

.dashboard-card.violet { border-top-color: #8b5cf6; }
.dashboard-card.violet .dashboard-card-icon { background: var(--gradient-violet); }
.dashboard-card.violet:hover .dashboard-card-title a { color: #8b5cf6; }

.dashboard-card.cyan { border-top-color: #06b6d4; }
.dashboard-card.cyan .dashboard-card-icon { background: var(--gradient-cyan); }
.dashboard-card.cyan:hover .dashboard-card-title a { color: #06b6d4; }

.dashboard-card.teal { border-top-color: #14b8a6; }
.dashboard-card.teal .dashboard-card-icon { background: var(--gradient-teal); }
.dashboard-card.teal:hover .dashboard-card-title a { color: #14b8a6; }

.dashboard-card.orange { border-top-color: #f97316; }
.dashboard-card.orange .dashboard-card-icon { background: var(--gradient-orange); }
.dashboard-card.orange:hover .dashboard-card-title a { color: #f97316; }

.dashboard-card.pink { border-top-color: #ec4899; }
.dashboard-card.pink .dashboard-card-icon { background: var(--gradient-pink); }
.dashboard-card.pink:hover .dashboard-card-title a { color: #ec4899; }

.dashboard-card.rose { border-top-color: #f43f5e; }
.dashboard-card.rose .dashboard-card-icon { background: var(--gradient-rose); }
.dashboard-card.rose:hover .dashboard-card-title a { color: #f43f5e; }

.dashboard-card.slate { border-top-color: #64748b; }
.dashboard-card.slate .dashboard-card-icon { background: var(--gradient-slate); }
.dashboard-card.slate:hover .dashboard-card-title a { color: #64748b; }

.dashboard-card.amber { border-top-color: #f59e0b; }
.dashboard-card.amber .dashboard-card-icon { background: var(--gradient-amber); }
.dashboard-card.amber:hover .dashboard-card-title a { color: #f59e0b; }

.dashboard-card.sky { border-top-color: #0ea5e9; }
.dashboard-card.sky .dashboard-card-icon { background: var(--gradient-sky); }
.dashboard-card.sky:hover .dashboard-card-title a { color: #0ea5e9; }

/* ==========================================================================
   Filter Badges
   ========================================================================== */

.filter-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.625rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
}

.filter-badge.blue {
    background: #dbeafe;
    color: #1e40af;
}

.filter-badge.indigo {
    background: #e0e7ff;
    color: #3730a3;
}

.filter-badge.green {
    background: #d1fae5;
    color: #065f46;
}

.filter-badge.emerald {
    background: #d1fae5;
    color: #065f46;
}

.filter-badge.purple {
    background: #ede9fe;
    color: #5b21b6;
}

.filter-badge.teal {
    background: #ccfbf1;
    color: #115e59;
}

.filter-badge.amber {
    background: #fef3c7;
    color: #92400e;
}

.filter-badge.violet {
    background: #ede9fe;
    color: #5b21b6;
}

.filter-badge.fuchsia {
    background: #fae8ff;
    color: #86198f;
}

.filter-badge.orange {
    background: #ffedd5;
    color: #9a3412;
}

.filter-badge.lime {
    background: #ecfccb;
    color: #3f6212;
}

.filter-badge.indigo-purple {
    background: #e0e7ff;
    color: #4338ca;
}

.filter-badge.cyan {
    background: #cffafe;
    color: #0e7490;
}

/* ==========================================================================
   Product Cards
   ========================================================================== */

.product-card {
    background: var(--bg-card);
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
}

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

.product-card-header {
    padding: 1.25rem;
    border-bottom: 1px solid var(--bg-border);
    background: var(--bg-muted);
}

.product-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 0.5rem 0;
}

.product-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.product-meta-item {
    display: inline-flex;
    align-items: center;
    font-size: 0.7rem;
    color: var(--text-secondary);
    background: white;
    padding: 0.125rem 0.5rem;
    border-radius: 4px;
    border: 1px solid var(--bg-border);
}

.product-meta-item i {
    color: var(--text-muted);
}

.product-card-body {
    padding: 1.25rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.product-description {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin: 0 0 1rem 0;
    line-height: 1.5;
}

.product-pricing {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.price-tag {
    display: flex;
    align-items: baseline;
    gap: 0.25rem;
    background: #f0fdf4;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid #bbf7d0;
}

.price-amount {
    font-size: 1.25rem;
    font-weight: 700;
    color: #059669;
}

.price-interval {
    font-size: 0.75rem;
    color: #6b7280;
}

.product-features {
    margin-top: auto;
}

.features-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.5rem;
}

.features-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.features-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.8rem;
    color: var(--text-primary);
    padding: 0.25rem 0;
}

.features-list li i {
    color: #10b981;
    margin-top: 0.125rem;
    flex-shrink: 0;
}

.product-card-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--bg-border);
    background: var(--bg-muted);
}

/* ==========================================================================
   Loading & Spinner Styles
   ========================================================================== */

.search-loading {
    position: relative;
}

.search-loading::after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border: 2px solid #e5e7eb;
    border-top-color: var(--accent-primary, #0ea5e9);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

@keyframes spin {
    to { transform: translateY(-50%) rotate(360deg); }
}

.table-loading {
    opacity: 0.5;
    pointer-events: none;
}

/* Loading Overlay - Container Relative (for tables, panels) */
.loading-overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255,255,255,0.92);
    z-index: 10;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 0.75rem;
    border-radius: inherit;
    backdrop-filter: blur(2px);
}

.loading-overlay.show {
    display: flex;
}

.loading-overlay .spinner-border {
    width: 2.5rem;
    height: 2.5rem;
}

/* Make data-table-container position relative for overlay */
.data-table-container {
    position: relative;
}

/* ==========================================================================
   Common Utility Styles
   ========================================================================== */

.no-results {
    display: none;
    text-align: center;
    padding: 3rem;
    color: #6b7280;
}

.no-results.show {
    display: block;
}

.date-info {
    font-size: 0.85rem;
    color: #374151;
}

.date-info .date-label {
    font-size: 0.7rem;
    color: #9ca3af;
    text-transform: uppercase;
}

.tenant-badge {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #6b7280;
    background: #f9fafb;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
}

.user-id-badge {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #6b7280;
    background: #f3f4f6;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    word-break: break-all;
}

.ip-badge,
.ip-address {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #6b7280;
    background: #f3f4f6;
    padding: 0.2rem 0.4rem;
    border-radius: 4px;
}

.hash-badge {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.7rem;
    color: #6b7280;
    background: #f3f4f6;
    padding: 0.2rem 0.4rem;
    border-radius: 4px;
}

/* ==========================================================================
   Profile Type Badges (Access Profiles)
   ========================================================================== */

.profile-type-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 500;
}

.profile-type-badge.sthan { background: #e0f2fe; color: #0369a1; }
.profile-type-badge.bhartiya { background: #ffedd5; color: #c2410c; }
.profile-type-badge.surya { background: #fce7f3; color: #be185d; }
.profile-type-badge.periscopes { background: #dcfce7; color: #15803d; }
.profile-type-badge.default { background: #f3f4f6; color: #4b5563; }

.validity-badge {
    font-size: 0.7rem;
    padding: 0.2rem 0.5rem;
    border-radius: 4px;
    font-weight: 500;
}

.validity-badge.active { background: #dcfce7; color: #166534; }
.validity-badge.expired { background: #fee2e2; color: #991b1b; }
.validity-badge.future { background: #fef9c3; color: #854d0e; }

.profile-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #6b7280;
    background: #f3f4f6;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    word-break: break-all;
    max-width: 180px;
    display: inline-block;
}

.user-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
}

.user-info .email { font-weight: 500; color: #111827; }
.user-info .user-id { font-size: 0.75rem; color: #6b7280; }

.tenant-info {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.tenant-info .tenant-name { font-weight: 500; }
.tenant-info .tenant-label { font-size: 0.7rem; color: #6b7280; text-transform: uppercase; }

/* ==========================================================================
   API Badges (API Endpoints)
   ========================================================================== */

.api-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

.api-badge.periscopesapi { background: #dcfce7; color: #15803d; }
.api-badge.suryaapi { background: #fce7f3; color: #be185d; }
.api-badge.sthanapi { background: #e0f2fe; color: #0369a1; }
.api-badge.bharatapi { background: #ffedd5; color: #c2410c; }
.api-badge.himalayanapi { background: #f3e8ff; color: #7c3aed; }
.api-badge.netramapi { background: #fef9c3; color: #a16207; }
.api-badge.default { background: #f3f4f6; color: #4b5563; }

/* ==========================================================================
   API Endpoints Page - Enhanced Styles
   ========================================================================== */

/* Endpoint info cell */
.endpoint-info {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.endpoint-info .endpoint-name {
    font-weight: 600;
    color: #111827;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.endpoint-info .endpoint-name i {
    color: #0891b2;
    font-size: 0.85rem;
}

.endpoint-info .endpoint-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.endpoint-info .action-name {
    color: #6b7280;
    font-size: 0.8rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.endpoint-info .action-name::before {
    content: '→';
    color: #9ca3af;
}

/* Claim code styling */
.claim-code {
    display: inline-block;
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
    color: #0369a1;
    padding: 0.35rem 0.65rem;
    border-radius: 6px;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Fira Code', monospace;
    font-size: 0.8rem;
    font-weight: 500;
    border: 1px solid #bae6fd;
}

.claim-code:empty::before {
    content: '--';
    color: #9ca3af;
}

/* Category pill */
.category-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: linear-gradient(135deg, #ecfeff 0%, #cffafe 100%);
    color: #0e7490;
    padding: 0.3rem 0.7rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    border: 1px solid #a5f3fc;
}

.category-pill i {
    font-size: 0.65rem;
}

/* Filter bar enhancement */
.filter-bar {
    background: white;
    border-radius: 12px;
    padding: 1.25rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 1px 2px rgba(0,0,0,0.03);
    border: 1px solid #e5e7eb;
    position: relative;
}

.filter-bar::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, #0891b2, #06b6d4);
    border-radius: 12px 12px 0 0;
}

.filter-bar .form-label {
    font-weight: 600;
    font-size: 0.75rem;
    color: #374151;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.4rem;
}

.filter-bar .form-control,
.filter-bar .form-select {
    border: 1px solid #d1d5db;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.filter-bar .form-control:focus,
.filter-bar .form-select:focus {
    border-color: var(--color-focus-border);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.filter-bar .form-control::placeholder {
    color: var(--color-text-placeholder);
}

/* Live search indicator */
.search-loading .form-control,
.search-loading .form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 50 50'%3E%3Cpath fill='%230891b2' d='M25 5A20 20 0 1 0 25 45A20 20 0 1 0 25 5M25 10A15 15 0 1 1 25 40A15 15 0 1 1 25 10' opacity='.3'/%3E%3Cpath fill='%230891b2' d='M25 5A20 20 0 0 1 45 25L40 25A15 15 0 0 0 25 10Z'%3E%3CanimateTransform attributeName='transform' dur='0.8s' from='0 25 25' repeatCount='indefinite' to='360 25 25' type='rotate'/%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 1rem;
    padding-right: 2.5rem;
}

/* Results info styling */
.results-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background: #f9fafb;
    border-top: 1px solid #e5e7eb;
    font-size: 0.85rem;
    color: #6b7280;
}

.results-info .count {
    font-weight: 600;
    color: #111827;
}

/* ==========================================================================
   OS & Browser Badges (User Logins)
   ========================================================================== */

.os-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
}

.os-badge.windows { background: #dbeafe; color: #1d4ed8; }
.os-badge.linux { background: #fef3c7; color: #b45309; }
.os-badge.android { background: #dcfce7; color: #15803d; }
.os-badge.ios { background: #f3f4f6; color: #374151; }
.os-badge.macos { background: #f3f4f6; color: #374151; }
.os-badge.default { background: #f3f4f6; color: #6b7280; }

.browser-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
}

.browser-badge.chrome { background: #fef3c7; color: #b45309; }
.browser-badge.edge { background: #dbeafe; color: #1d4ed8; }
.browser-badge.firefox { background: #ffedd5; color: #c2410c; }
.browser-badge.safari { background: #e0f2fe; color: #0369a1; }
.browser-badge.opera { background: #fee2e2; color: #dc2626; }
.browser-badge.default { background: #f3f4f6; color: #6b7280; }

.device-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.device-info .device-type { font-weight: 500; color: #111827; }
.device-info .device-detail { font-size: 0.8rem; color: #6b7280; }

.login-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.login-info .email { font-weight: 500; color: #111827; }
.login-info .phone { font-size: 0.85rem; color: #6b7280; }
.login-info .session-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.7rem;
    color: #9ca3af;
    background: #f9fafb;
    padding: 0.15rem 0.4rem;
    border-radius: 3px;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ==========================================================================
   User Claims Styles
   ========================================================================== */

.claim-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.claim-info .claim-id { font-weight: 600; color: #111827; }
.claim-info .claim-value { font-size: 0.85rem; color: #6b7280; }

.claim-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
    background: #f0fdfa;
    color: #0d9488;
}

/* ==========================================================================
   User Roles Styles
   ========================================================================== */

.role-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.role-info .role-name { font-weight: 600; color: #111827; }
.role-info .role-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #9ca3af;
}

.role-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.85rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    background: #fff7ed;
    color: #c2410c;
}

/* ==========================================================================
   User Context Banner
   ========================================================================== */

.user-context-banner {
    border-radius: 8px;
    padding: 1rem 1.5rem;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.user-context-banner i { font-size: 1.5rem; }
.user-context-banner .user-context-info { flex: 1; }
.user-context-banner .user-context-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    font-weight: 600;
}

.user-context-banner .user-context-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.9rem;
}

/* Teal variant (User Claims) */
.user-context-banner.teal {
    background: linear-gradient(135deg, #f0fdfa 0%, #ccfbf1 100%);
    border: 1px solid #99f6e4;
}

.user-context-banner.teal i { color: #0d9488; }
.user-context-banner.teal .user-context-label { color: #0f766e; }
.user-context-banner.teal .user-context-id { color: #134e4a; }

/* Orange variant (User Roles) */
.user-context-banner.orange {
    background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
    border: 1px solid #fed7aa;
}

.user-context-banner.orange i { color: #ea580c; }
.user-context-banner.orange .user-context-label { color: #c2410c; }
.user-context-banner.orange .user-context-id { color: #9a3412; }

/* ==========================================================================
   Role Claims Card Styles
   ========================================================================== */

.role-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    margin-bottom: 1.5rem;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    transition: box-shadow 0.2s ease;
}

.role-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); }

/* ==========================================================================
   Form Page Wrapper (Create/Edit pages - gives contrast for white cards)
   ========================================================================== */
.form-page-wrapper {
    background: #f8f9fa;
    min-height: calc(100vh - 120px);
    margin: -1rem -0.75rem;
    padding: 2rem 0.75rem;
}

/* ==========================================================================
   Form Card Headers (Create/Edit pages)
   ========================================================================== */
.form-card-header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--bg-border);
}
.form-card-header h5 { margin-bottom: 0.25rem; font-weight: 600; }
.form-card-header small { color: var(--text-muted); }

.form-card-header.fuchsia {
    background: linear-gradient(135deg, #fdf4ff 0%, #fae8ff 100%);
    border-bottom-color: #f5d0fe;
}
.form-card-header.fuchsia h5 i { color: #a855f7; }

.form-card-header.violet {
    background: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%);
    border-bottom-color: #ddd6fe;
}
.form-card-header.violet h5 i { color: #7c3aed; }

.form-card-header.indigo {
    background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
    border-bottom-color: #c7d2fe;
}
.form-card-header.indigo h5 i { color: #6366f1; }

.role-card-header {
    background: linear-gradient(135deg, #fdf4ff 0%, #fae8ff 100%);
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #f5d0fe;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.role-card-title {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.role-card-title .role-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #d946ef 0%, #a855f7 100%);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.1rem;
}

.role-card-title .role-name { font-size: 1.1rem; font-weight: 600; color: #1f2937; }
.role-card-title .role-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #9ca3af;
}

.role-card-body { padding: 1.25rem 1.5rem; }

.role-card-footer {
    background: #fafafa;
    padding: 0.75rem 1.5rem;
    border-top: 1px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.claim-count { font-size: 0.85rem; color: #6b7280; }
.claim-count strong { color: #a855f7; }

.claims-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 0.75rem;
}

.claim-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0.85rem;
    background: #f9fafb;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
}

.claim-item.active { background: #fdf4ff; border-color: #f5d0fe; }

.claim-item .claim-status {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.claim-item .claim-status.active { background: #22c55e; }
.claim-item .claim-status.inactive { background: #d1d5db; }

.claim-item .claim-value {
    font-size: 0.85rem;
    color: #374151;
    flex: 1;
    word-break: break-word;
}

.claim-item.active .claim-value { color: #86198f; font-weight: 500; }

.no-claims {
    text-align: center;
    padding: 2rem;
    color: #9ca3af;
}

.no-claims i { font-size: 2rem; margin-bottom: 0.5rem; color: #d1d5db; }

/* ==========================================================================
   PDF Files Styles (PersonPdfs)
   ========================================================================== */

.file-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.file-info .file-name { font-weight: 600; color: #111827; word-break: break-all; }
.file-info .file-hash {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.7rem;
    color: #9ca3af;
}

.location-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.location-info .state-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.6rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    background: #fef2f2;
    color: #dc2626;
}

.location-info .ac-part { font-size: 0.8rem; color: #6b7280; }

.progress-cell { min-width: 120px; }

.progress-bar-container {
    background: #e5e7eb;
    border-radius: 4px;
    height: 6px;
    overflow: hidden;
    margin-top: 0.25rem;
}

.progress-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.progress-bar-fill.complete { background: #22c55e; }
.progress-bar-fill.partial { background: #f59e0b; }
.progress-bar-fill.none { background: #dc2626; }

.progress-text { font-size: 0.75rem; color: #6b7280; }

.pincode-badge {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.8rem;
    background: #fef3c7;
    color: #92400e;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
}

/* ==========================================================================
   Filter Card Styles (AppLogs, PersonPdfs)
   ========================================================================== */

.filter-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    margin-bottom: 1.5rem;
    border: 1px solid #e5e7eb;
    overflow: hidden;
}

.filter-card .filter-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: #374151;
    margin-bottom: 0.5rem;
}

.filter-card-header {
    background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #e2e8f0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.filter-card-header h5 { margin: 0; font-size: 0.95rem; font-weight: 600; color: #334155; }
.filter-card-header h5 i { color: #64748b; }
.filter-card-body { padding: 1.5rem; }
.filter-label { font-size: 0.8rem; font-weight: 600; color: #475569; margin-bottom: 0.4rem; }

/* ==========================================================================
   Log Level & Status Code Badges (AppLogs)
   ========================================================================== */

.log-level-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.6rem;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
}

.log-level-badge.info { background: #dbeafe; color: #1d4ed8; }
.log-level-badge.warning { background: #fef3c7; color: #92400e; }
.log-level-badge.error { background: #fee2e2; color: #dc2626; }
.log-level-badge.debug { background: #f3f4f6; color: #6b7280; }
.log-level-badge.fatal { background: #1f2937; color: #f9fafb; }

.status-code-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    font-family: 'SFMono-Regular', Consolas, monospace;
}

.status-code-badge.success { background: #dcfce7; color: #166534; }
.status-code-badge.client-error { background: #fef3c7; color: #92400e; }
.status-code-badge.server-error { background: #fee2e2; color: #dc2626; }
.status-code-badge.other { background: #f3f4f6; color: #6b7280; }

.log-user-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.log-user-info .user-email { font-size: 0.8rem; color: #374151; word-break: break-all; }
.log-user-info .user-id {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.65rem;
    color: #9ca3af;
}

.log-path {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.8rem;
    color: #374151;
    word-break: break-all;
}

.log-message { font-size: 0.8rem; color: #6b7280; margin-top: 0.25rem; }

.timestamp-info { font-size: 0.8rem; color: #374151; }
.timestamp-info .date { font-weight: 500; }
.timestamp-info .time {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.75rem;
    color: #6b7280;
}

.checkbox-group { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }
.checkbox-group .form-check { margin: 0; }
.checkbox-group .form-check-label { font-size: 0.8rem; color: #374151; }

.btn-search {
    background: linear-gradient(135deg, #475569 0%, #334155 100%);
    color: white;
    border: none;
    padding: 0.5rem 1.25rem;
    border-radius: 8px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.btn-search:hover {
    background: linear-gradient(135deg, #334155 0%, #1e293b 100%);
    color: white;
    transform: translateY(-1px);
}

/* Legacy alias - use btn-filter-reset for new code */
.btn-reset {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border: 1px solid #e5e7eb;
    color: #6b7280;
    font-weight: 500;
    font-size: 0.8rem;
    background: #f9fafb;
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    transition: all 0.15s ease;
    text-decoration: none;
}

.btn-reset:hover {
    background: #f3f4f6;
    border-color: #d1d5db;
    color: #374151;
    text-decoration: none;
}

.collapse-toggle {
    background: none;
    border: none;
    color: #64748b;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.collapse-toggle:hover { background: #e2e8f0; color: #334155; }

.results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background: #f8fafc;
    border-bottom: 1px solid #e5e7eb;
}

.results-header h5 { margin: 0; font-size: 0.95rem; font-weight: 600; color: #334155; }
.results-info { font-size: 0.8rem; color: #64748b; }

/* ==========================================================================
   Blog Card Styles (BlogPosts)
   ========================================================================== */

.blog-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    border: 1px solid #e5e7eb;
    overflow: hidden;
    transition: all 0.2s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.blog-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); transform: translateY(-2px); }
.blog-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }

.blog-card-footer {
    padding: 1rem 1.5rem;
    background: #fafafa;
    border-top: 1px solid #e5e7eb;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.category-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    background: linear-gradient(135deg, #fce7f3 0%, #fbcfe8 100%);
    color: #be185d;
    margin-bottom: 0.75rem;
}

.blog-title { font-size: 1.25rem; font-weight: 700; color: #111827; margin-bottom: 0.5rem; line-height: 1.3; }
.blog-title a { color: inherit; text-decoration: none; transition: color 0.2s ease; }
.blog-title a:hover { color: #be185d; }

.blog-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.8rem;
    color: #6b7280;
    margin-bottom: 1rem;
}

.blog-meta .author { display: flex; align-items: center; gap: 0.35rem; }
.blog-meta .author-name { color: #be185d; font-weight: 500; }
.blog-meta .date { display: flex; align-items: center; gap: 0.35rem; }
.blog-meta .separator { color: #d1d5db; }

.blog-excerpt { font-size: 0.9rem; color: #4b5563; line-height: 1.6; flex: 1; margin-bottom: 1rem; }

.read-more {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: #be185d;
    text-decoration: none;
    transition: all 0.2s ease;
}

.read-more:hover { color: #9d174d; gap: 0.5rem; }

.btn-blog-edit {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.85rem;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
    background: #fff1f2;
    color: #be185d;
    border: 1px solid #fecdd3;
    text-decoration: none;
    transition: all 0.2s ease;
}

.btn-blog-edit:hover { background: #fce7f3; color: #9d174d; }

.btn-blog-delete {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.85rem;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 500;
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-blog-delete:hover { background: #fee2e2; color: #b91c1c; }

.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
    gap: 1.5rem;
}

/* ==========================================================================
   Invitation Form Styles
   ========================================================================== */

.invite-container { max-width: 600px; margin: 0 auto; }

.invite-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    border: 1px solid #e5e7eb;
    overflow: hidden;
}

.invite-card-header {
    background: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 100%);
    padding: 2rem;
    text-align: center;
    border-bottom: 1px solid #fbcfe8;
}

.invite-card-header .icon-wrapper {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, #ec4899 0%, #db2777 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
    box-shadow: 0 4px 12px rgba(236, 72, 153, 0.3);
}

.invite-card-header .icon-wrapper i { font-size: 2rem; color: white; }
.invite-card-header h2 { font-size: 1.5rem; font-weight: 700; color: #1f2937; margin-bottom: 0.5rem; }
.invite-card-header p { font-size: 0.9rem; color: #6b7280; margin: 0; }

.invite-card-body { padding: 2rem; }

.invite-form .form-group { margin-bottom: 1.5rem; }
.invite-form .form-group:last-child { margin-bottom: 0; }

.invite-form .form-group label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: #374151;
    margin-bottom: 0.5rem;
}

.invite-form .form-group label i { color: #ec4899; margin-right: 0.5rem; }

.invite-form .form-group .form-control,
.invite-form .form-group .form-select {
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    border-radius: 8px;
    border: 1px solid #d1d5db;
    transition: all 0.2s ease;
}

.invite-form .form-group .form-control:focus,
.invite-form .form-group .form-select:focus {
    border-color: var(--color-focus-border);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.invite-form .form-group .form-control::placeholder { color: var(--color-text-placeholder); }

.btn-submit {
    background: linear-gradient(135deg, #ec4899 0%, #db2777 100%);
    color: white;
    border: none;
    padding: 0.875rem 2rem;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 10px;
    width: 100%;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.btn-submit:hover {
    background: linear-gradient(135deg, #db2777 0%, #be185d 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(236, 72, 153, 0.35);
}

.btn-submit:active { transform: translateY(0); }

.help-text { font-size: 0.8rem; color: #6b7280; margin-top: 0.5rem; }

.validation-error {
    color: #dc2626;
    font-size: 0.8rem;
    margin-top: 0.35rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.invite-info {
    background: #fdf2f8;
    border: 1px solid #fbcfe8;
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1.5rem;
}

.invite-info p {
    font-size: 0.85rem;
    color: #9d174d;
    margin: 0;
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.invite-info p i { color: #ec4899; margin-top: 0.15rem; }

/* ==========================================================================
   Delete Modal Styling
   ========================================================================== */

.modal-content.delete-modal { border-radius: 12px; border: none; }

.modal-content.delete-modal .modal-header {
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
    border-bottom: 1px solid #fecaca;
    border-radius: 12px 12px 0 0;
}

.modal-content.delete-modal .modal-title { color: #dc2626; font-weight: 600; }
.modal-content.delete-modal .modal-footer { border-top: 1px solid #e5e7eb; }

/* ==========================================================================
   Combobox / Autocomplete Dropdown
   ========================================================================== */

.combobox-wrapper {
    position: relative;
}

.combobox-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--bg-border);
    border-top: none;
    border-radius: 0 0 6px 6px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1050;
    display: none;
    box-shadow: var(--shadow-lg);
}

.combobox-dropdown.show {
    display: block;
}

.combobox-option {
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    font-size: 0.85rem;
    transition: background 0.1s;
}

.combobox-option:hover {
    background: var(--bg-muted);
}

.combobox-option.add-new {
    border-top: 1px solid var(--bg-border);
    color: var(--color-success);
    font-weight: 500;
}

.combobox-option .option-count {
    float: right;
    color: var(--text-muted);
    font-size: 0.75rem;
}

/* ==========================================================================
   Drag & Drop File Upload Area
   ========================================================================== */

.file-upload-area {
    border: 2px dashed var(--bg-border);
    border-radius: 12px;
    padding: 2rem;
    text-align: center;
    background: var(--bg-muted);
    transition: all 0.2s ease;
    cursor: pointer;
}

.file-upload-area:hover,
.file-upload-area.dragover {
    border-color: var(--color-primary);
    background: #f0f7ff;
}

.file-upload-area.dragover {
    transform: scale(1.01);
}

.file-upload-area h5 {
    margin: 0;
    color: var(--text-primary);
}

.file-upload-area .upload-icon {
    font-size: 3rem;
    color: var(--text-muted);
    margin-bottom: 1rem;
}

/* ==========================================================================
   Table Row States (for bulk operations)
   ========================================================================== */

.data-table tbody tr.row-valid {
    background: #f0fdf4;
}

.data-table tbody tr.row-valid:hover {
    background: #dcfce7;
}

.data-table tbody tr.row-duplicate {
    background: #fffbeb;
}

.data-table tbody tr.row-duplicate:hover {
    background: #fef3c7;
}

.data-table tbody tr.row-invalid {
    background: #fef2f2;
}

.data-table tbody tr.row-invalid:hover {
    background: #fee2e2;
}

/* Additional status badge variants */
.status-badge.valid {
    background: #d1fae5;
    color: #065f46;
}

.status-badge.duplicate {
    background: #fef3c7;
    color: #92400e;
}

.status-badge.invalid {
    background: #fee2e2;
    color: #991b1b;
}

/* ==========================================================================
   Monospace Preview (for generated values)
   ========================================================================== */

.mono-preview {
    font-family: 'Monaco', 'Menlo', 'Consolas', monospace;
    font-size: 0.75rem;
    color: var(--text-secondary);
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mono-preview.error {
    color: var(--color-danger);
    font-weight: 500;
}

/* ==========================================================================
   Result Item List (for bulk operation results)
   ========================================================================== */

.result-list {
    max-height: 400px;
    overflow-y: auto;
}

.result-item {
    display: flex;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid #f1f5f9;
    gap: 0.75rem;
}

.result-item:last-child {
    border-bottom: none;
}

.result-item.created .result-icon { color: var(--color-success); }
.result-item.skipped .result-icon { color: var(--color-warning); }
.result-item.error .result-icon { color: var(--color-danger); }

.result-item .result-name {
    font-weight: 500;
}

.result-item .result-message {
    font-size: 0.8rem;
    color: var(--text-muted);
}

/* ==========================================================================
   Format Help Box
   ========================================================================== */

.format-help {
    background: var(--bg-muted);
    border-radius: 8px;
    padding: 1rem;
    margin-top: 1rem;
}

.format-help h6 {
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.format-help code {
    display: block;
    background: var(--bg-card);
    padding: 0.5rem 0.75rem;
    border-radius: 4px;
    font-size: 0.8rem;
    margin: 0.5rem 0;
}

/* ==========================================================================
   Table Footer Actions
   ========================================================================== */

.table-footer {
    padding: 1rem 1.25rem;
    background: var(--bg-muted);
    border-top: 1px solid var(--bg-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.table-footer-left,
.table-footer-right {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

/* Tablet (iPad portrait and smaller laptops) */
@media (max-width: 992px) {
    .btn-text-full {
        display: none !important;
    }
}

/* Mobile (phones) */
@media (max-width: 576px) {
    .btn-text,
    .btn-text-full {
        display: none !important;
    }

    .btn-header,
    .btn-back {
        padding: 0.5rem 0.75rem;
    }

    .btn-header i,
    .btn-back i {
        margin-right: 0 !important;
        margin-left: 0 !important;
    }

    .page-header h1 {
        font-size: 1.1rem;
    }

    .page-header .subtitle {
        font-size: 0.75rem;
    }
}

@media (max-width: 768px) {
    .page-header {
        padding: 1rem 1.25rem;
    }

    .page-header h1 {
        font-size: 1.25rem;
    }

    .page-header .d-flex.gap-2 {
        gap: 0.5rem !important;
    }

    .stats-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .stat-card .stat-value {
        font-size: 1.5rem;
    }

    .filter-bar {
        padding: 1rem;
    }

    .data-table-container {
        border-radius: 8px;
    }

    .action-buttons {
        flex-direction: column;
    }

    .pagination-container {
        flex-direction: column;
        gap: 1rem;
    }

    .blog-grid {
        grid-template-columns: 1fr;
    }

    .claims-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   PHASE 3: Missing Button Styles
   ========================================================================== */

/* btn-action-edit.red variant */
.btn-action-edit.red {
    border: 1px solid var(--color-danger);
    color: var(--color-danger);
}
.btn-action-edit.red:hover {
    background: var(--color-danger);
    color: white;
}

/* Refresh Button (used in dashboard headers) */
.refresh-btn {
    background: rgba(var(--color-primary-rgb), 0.2);
    border: 1px solid rgba(var(--color-primary-rgb), 0.4);
    color: var(--color-primary);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-md);
    font-weight: 500;
    transition: all 0.15s ease;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}
.refresh-btn:hover {
    background: rgba(var(--color-primary-rgb), 0.3);
    color: var(--color-primary);
}

/* ==========================================================================
   PHASE 3: Indigo-Purple Button System

   Button Hierarchy (use appropriately):
   ┌─────────────┬──────────────┬─────────────────────────────────────────────┐
   │ Button      │ Color        │ Use For                                     │
   ├─────────────┼──────────────┼─────────────────────────────────────────────┤
   │ Primary     │ Violet       │ Main CTAs: Save, Submit, Confirm, Create    │
   │ Secondary   │ Gray         │ Cancel, Back, Close, Reset, Less important  │
   │ Accent      │ Fuchsia      │ Attention: Delete, Remove, Important warns  │
   │ Gradient    │ Indigo→Fuchsia│ Hero sections, Premium, Marketing CTAs     │
   └─────────────┴──────────────┴─────────────────────────────────────────────┘
   ========================================================================== */

/* -----------------------------------------------------------------------------
   PRIMARY BUTTON - Violet (Main CTAs)
   Use for: Save, Submit, Confirm, Create, Add
   ----------------------------------------------------------------------------- */
.btn-primary {
    background: #7c3aed !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-primary:hover,
.btn-primary:focus {
    background: #6d28d9 !important;
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.4) !important;
    color: white !important;
}
.btn-primary:active {
    background: #5b21b6 !important;
    transform: translateY(1px);
}
.btn-primary:disabled {
    background: #a78bfa !important;
    opacity: 0.6;
    cursor: not-allowed;
}

/* -----------------------------------------------------------------------------
   SECONDARY BUTTON - Gray (Less important actions)
   Use for: Cancel, Back, Close, Reset
   ----------------------------------------------------------------------------- */
.btn-secondary {
    background: #64748b !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-secondary:hover,
.btn-secondary:focus {
    background: #475569 !important;
    box-shadow: 0 4px 12px rgba(100, 116, 139, 0.3) !important;
    color: white !important;
}
.btn-secondary:active {
    background: #334155 !important;
    transform: translateY(1px);
}
.btn-secondary:disabled {
    background: #94a3b8 !important;
    opacity: 0.6;
    cursor: not-allowed;
}

/* -----------------------------------------------------------------------------
   ACCENT BUTTON - Fuchsia (Attention-grabbing)
   Use for: Delete, Remove, Important warnings, Destructive actions
   ----------------------------------------------------------------------------- */
.btn-accent {
    background: #a855f7 !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-accent:hover,
.btn-accent:focus {
    background: #9333ea !important;
    box-shadow: 0 4px 12px rgba(168, 85, 247, 0.4) !important;
    color: white !important;
}
.btn-accent:active {
    background: #7e22ce !important;
    transform: translateY(1px);
}
.btn-accent:disabled {
    background: #c084fc !important;
    opacity: 0.6;
    cursor: not-allowed;
}

/* -----------------------------------------------------------------------------
   GRADIENT BUTTON - Indigo to Fuchsia (Hero/Premium CTAs)
   Use for: Sign up, Purchase, Hero sections, Marketing CTAs
   ----------------------------------------------------------------------------- */
.btn-gradient {
    background: linear-gradient(135deg, #6366f1 0%, #7c3aed 50%, #a855f7 100%) !important;
    border: none !important;
    color: white !important;
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
    transition: all 0.2s ease;
}
.btn-gradient:hover,
.btn-gradient:focus {
    background: linear-gradient(135deg, #818cf8 0%, #8b5cf6 50%, #c084fc 100%) !important;
    box-shadow: 0 6px 20px rgba(124, 58, 237, 0.5) !important;
    color: white !important;
    transform: translateY(-1px);
}
.btn-gradient:active {
    background: linear-gradient(135deg, #4f46e5 0%, #6d28d9 50%, #9333ea 100%) !important;
    transform: translateY(1px);
}
.btn-gradient:disabled {
    background: linear-gradient(135deg, #a5b4fc 0%, #c4b5fd 100%) !important;
    opacity: 0.6;
    cursor: not-allowed;
}

/* -----------------------------------------------------------------------------
   OUTLINE VARIANTS
   ----------------------------------------------------------------------------- */

/* Outline Primary - Violet */
.btn-outline-primary {
    color: #7c3aed !important;
    border: 2px solid #7c3aed !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background: #7c3aed !important;
    color: white !important;
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.3) !important;
}

/* Outline Secondary - Gray */
.btn-outline-secondary {
    color: #64748b !important;
    border: 2px solid #64748b !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background: #64748b !important;
    color: white !important;
}

/* Outline Accent - Deep Orange */
.btn-outline-accent {
    color: #ea580c !important;
    border: 2px solid #ea580c !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-accent:hover,
.btn-outline-accent:focus {
    background: #ea580c !important;
    color: white !important;
    box-shadow: 0 4px 12px rgba(234, 88, 12, 0.3) !important;
}

/* -----------------------------------------------------------------------------
   SEMANTIC BUTTONS (Bootstrap compatibility)
   ----------------------------------------------------------------------------- */

/* Success Button - Green */
.btn-success {
    background: #059669 !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-success:hover,
.btn-success:focus {
    background: #047857 !important;
    box-shadow: 0 4px 12px rgba(5, 150, 105, 0.3) !important;
}

/* Danger Button - Red */
.btn-danger {
    background: #dc2626 !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-danger:hover,
.btn-danger:focus {
    background: #b91c1c !important;
    box-shadow: 0 4px 12px rgba(220, 38, 38, 0.3) !important;
}

/* Warning Button - Yellow (dark text) */
.btn-warning {
    background: #f59e0b !important;
    border: none !important;
    color: #1e293b !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-warning:hover,
.btn-warning:focus {
    background: #d97706 !important;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3) !important;
}

/* Info Button - Blue */
.btn-info {
    background: #0284c7 !important;
    border: none !important;
    color: white !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-info:hover,
.btn-info:focus {
    background: #0369a1 !important;
    box-shadow: 0 4px 12px rgba(2, 132, 199, 0.3) !important;
}

/* -----------------------------------------------------------------------------
   OUTLINE SEMANTIC BUTTONS
   ----------------------------------------------------------------------------- */

/* Outline Success */
.btn-outline-success {
    color: #059669 !important;
    border: 2px solid #059669 !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-success:hover,
.btn-outline-success:focus {
    background: #059669 !important;
    color: white !important;
}

/* Outline Danger */
.btn-outline-danger {
    color: #dc2626 !important;
    border: 2px solid #dc2626 !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-danger:hover,
.btn-outline-danger:focus {
    background: #dc2626 !important;
    color: white !important;
}

/* Outline Warning */
.btn-outline-warning {
    color: #d97706 !important;
    border: 2px solid #f59e0b !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-warning:hover,
.btn-outline-warning:focus {
    background: #f59e0b !important;
    color: #1e293b !important;
}

/* Outline Info */
.btn-outline-info {
    color: #0284c7 !important;
    border: 2px solid #0284c7 !important;
    background: transparent !important;
    font-weight: 500;
    transition: all 0.2s ease;
}
.btn-outline-info:hover,
.btn-outline-info:focus {
    background: #0284c7 !important;
    color: white !important;
}

/* ==========================================================================
   PHASE 4: Unified Form Focus States (Amber)
   All form inputs use consistent amber focus ring for brand consistency
   ========================================================================== */

/* Standard form controls */
.form-control:focus,
.form-select:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
input[type="datetime-local"]:focus,
textarea:focus {
    border-color: var(--color-focus-border) !important;
    box-shadow: 0 0 0 3px var(--color-focus-ring) !important;
    outline: none !important;
}

/* Checkboxes and radio buttons */
.form-check-input:focus {
    border-color: var(--color-focus-border) !important;
    box-shadow: 0 0 0 3px var(--color-focus-ring) !important;
    outline: none !important;
}

/* When checked, show amber ring */
.form-check-input:checked {
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
}

/* DataTables filter input */
.dataTables_filter input:focus,
.dataTables_length select:focus {
    border-color: var(--color-focus-border) !important;
    box-shadow: 0 0 0 3px var(--color-focus-ring) !important;
    outline: none !important;
}

/* Disabled form controls */
.form-control:disabled,
.form-control.disabled,
.form-select:disabled,
input:disabled,
textarea:disabled,
select:disabled {
    background-color: var(--color-surface-muted) !important;
    cursor: not-allowed !important;
    opacity: 0.7 !important;
}

/* Consistent border-radius for all form elements */
.form-control,
.form-select,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="date"],
textarea,
.btn {
    border-radius: var(--radius-md);
}

/* ==========================================================================
   PHASE 5: Badge Styles
   Consistent badge styling across the application
   ========================================================================== */

/* Base badge styles */
.badge {
    padding: 0.35em 0.65em;
    font-size: 0.75em;
    font-weight: 600;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    gap: 0.25em;
}

/* Success badge - green */
.badge-success,
.badge.bg-success-subtle {
    background: var(--color-success-light) !important;
    color: var(--color-success-dark) !important;
}

/* Warning badge - amber/yellow */
.badge-warning,
.badge.bg-warning-subtle {
    background: var(--color-warning-light) !important;
    color: var(--color-warning-dark) !important;
}

/* Danger badge - red */
.badge-danger,
.badge.bg-danger-subtle {
    background: var(--color-danger-light) !important;
    color: var(--color-danger-dark) !important;
}

/* Info badge - blue/cyan */
.badge-info,
.badge.bg-info-subtle {
    background: var(--color-info-light) !important;
    color: var(--color-info-dark) !important;
}

/* Secondary/muted badge */
.badge-secondary,
.badge.bg-secondary-subtle {
    background: var(--color-surface-muted) !important;
    color: var(--color-text-secondary) !important;
}

/* Primary badge - amber brand */
.badge-primary,
.badge.bg-primary-subtle {
    background: var(--color-primary-light) !important;
    color: var(--color-primary-dark) !important;
}

/* Active/Inactive status badges */
.badge-active {
    background: var(--color-success-light);
    color: var(--color-success-dark);
}

.badge-inactive {
    background: var(--color-surface-muted);
    color: var(--color-text-muted);
}

/* Authorized/Unauthorized badges */
.badge-authorized {
    background: var(--color-success-light);
    color: var(--color-success-dark);
}

.badge-unauthorized {
    background: var(--color-danger-light);
    color: var(--color-danger-dark);
}

/* Pending badge */
.badge-pending {
    background: var(--color-warning-light);
    color: var(--color-warning-dark);
}

/* Completed badge */
.badge-completed {
    background: var(--color-success-light);
    color: var(--color-success-dark);
}

/* Running/Processing badge */
.badge-running,
.badge-processing {
    background: var(--color-info-light);
    color: var(--color-info-dark);
}

/* Error/Failed badge */
.badge-error,
.badge-failed {
    background: var(--color-danger-light);
    color: var(--color-danger-dark);
}
/* Please see documentation at https://docs.microsoft.com/aspnet/core/client-side/bundling-and-minification
for details on configuring this project to bundle and minify static web assets. */

/* ============================================
   NAVBAR STYLES - Professional & Responsive
   ============================================ */

/* Navbar base styles */
.navbar {
    padding: 0.5rem 1rem;
}

.navbar-brand {
    white-space: nowrap;
    font-weight: 600;
    padding: 0.5rem 0;
}

.navbar-brand .fa-sun {
    color: var(--color-primary);
}

/* Nav links styling */
.navbar-nav .nav-link {
    padding: 0.5rem 0.75rem;
    font-weight: 500;
    font-size: 0.875rem;
    transition: opacity 0.15s ease;
}

.navbar-nav .nav-link:hover {
    opacity: 0.85;
}

/* Navbar toggler - visible on gradient background */
.navbar-toggler {
    border: 2px solid rgba(255, 255, 255, 0.5);
    padding: 0.25rem 0.5rem;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.25);
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Collapsed menu styles */
.navbar-collapse {
    flex-grow: 1;
}

/* Dropdown menu styling */
.navbar .dropdown-menu {
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    border-radius: 0.375rem;
    min-width: 180px;
    z-index: 1050;
}

.navbar .dropdown-item {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: #374151;
}

.navbar .dropdown-item:hover {
    background-color: #f3f4f6;
    color: #111827;
}

/* Dropdown on hover (desktop only) */
@media (min-width: 992px) {
    .navbar .nav-item.dropdown:hover > .dropdown-menu {
        display: block;
        margin-top: 0;
    }

    .navbar .nav-item.dropdown > .dropdown-toggle:active {
        pointer-events: none;
    }
}

/* Mobile responsive styles */
@media (max-width: 991.98px) {
    .navbar-collapse {
        background-image: var(--surya-navbar-gradient);
        margin: 0.5rem -1rem -0.5rem -1rem;
        padding: 1rem;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    .navbar-nav {
        padding: 0.5rem 0;
    }

    .navbar-nav .nav-link {
        padding: 0.75rem 0.5rem;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    .navbar-nav .nav-item:last-child .nav-link {
        border-bottom: none;
    }

    .navbar .dropdown-menu {
        background: rgba(255, 255, 255, 0.95);
        border: none;
        box-shadow: none;
        margin-left: 1rem;
    }
}

/* Desktop styles - medium screens (992px - 1399px) */
@media (min-width: 992px) and (max-width: 1399.98px) {
    .navbar-nav .nav-link {
        padding: 0.5rem 0.4rem;
        font-size: 0.8rem;
    }

    .navbar-brand {
        font-size: 0.9rem;
    }
}

/* Desktop styles - large screens (1400px+) */
@media (min-width: 1400px) {
    .navbar-nav .nav-link {
        padding: 0.5rem 0.875rem;
    }
}

/* Allow navbar to wrap to double row on desktop when needed */
@media (min-width: 992px) {
    .navbar-nav {
        flex-wrap: wrap;
    }
}

/* Provide sufficient contrast against white background */
a {
    color: #0366d6;
}

/*.btn-primary {
  color: #fff;
  background-color: #1b6ec2;
  border-color: #1861ac;
}*/

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.dropdown-menu.show {
    background-color: var(--color-surface);
}

/* Sticky footer styles
-------------------------------------------------- */
html {
    font-size: 14px;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

.border-top {
    border-top: 1px solid #e5e5e5;
}

.border-bottom {
    border-bottom: 1px solid #e5e5e5;
}

.box-shadow {
    box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
}

button.accept-policy {
    font-size: 1rem;
    line-height: inherit;
}

/* Sticky footer styles
-------------------------------------------------- */
html {
    position: relative;
    min-height: 100%;
}

body {
    /* Margin bottom by footer height */
    margin-bottom: 60px;
    background-color: var(--surya-body-bg);
}

.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    white-space: nowrap;
    line-height: 60px; /* Vertically center the text there */
    height: 60px;
    background-image: var(--surya-footer-gradient);
    color: #fff !important;
    font-weight: 400 !important;
}

    .footer .session-text {
        font-size: var(--font-size-xs);
        color: rgba(255, 255, 255, 0.7);
    }

    .footer a {
        color: rgba(255, 255, 255, 0.85);
    }

    .footer a:hover {
        color: #fff;
    }

.card {
    background-color: var(--surya-card-bg);
    border-color: var(--surya-card-border-color);
}

.flex-center {
    align-items: center;
    justify-content: center;
}

.flex-grow-1 {
    flex-grow: 1 !important;
}

.bg-card-gradient {
    background-image: var(--surya-card-gradient);
    background-position: center;
}

.bg-registration-card-gradient {
    background-image: var(--surya-registration-gradient);
    background-position: center;
}

.nav-bar-gradient {
    background-image: var(--surya-navbar-gradient);
    background-position: center;
}

.z-index-1 {
    z-index: 1;
}

.flex-between-center {
    justify-content: space-between;
    align-items: center;
}

.fs-error {
    font-size: 10rem;
}

.fw-semi-bold {
    font-weight: 600 !important;
}

.fw-black {
    font-weight: 900 !important;
}

.text-300 {
    color: var(--surya-error-code-300-grey) !important;
}

.text-800 {
    color: var(--surya-error-code-800-grey) !important;
}

.font-sans-serif {
    font-family: Sans-Serif;
}

.table {
    font-weight: 400 !important;
    color: var(--color-text-primary) !important;
}

.accordion-item {
    color: var(--color-text-primary) !important;
}

table > thead tr > th {
    /*text-align: center !important;*/
    vertical-align: middle;
}

table > tbody tr > td {
    vertical-align: middle;
}

input.disabled:hover {
    cursor: not-allowed
}

.collapsing {
    height: 0;
    overflow: hidden;
    transition: height 0.4s ease;
}

.endpoint-table-textbox {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

    .endpoint-table-textbox:hover {
        border-color: var(--color-border-hover);
    }

    .endpoint-table-textbox:focus {
        background-color: var(--color-surface);
        border-color: var(--color-focus-border);
        box-shadow: 0 0 0 3px var(--color-focus-ring);
        outline: none;
    }

.accordion-button:not(.collapsed) {
    background-color: #fff !important;
    box-shadow: unset !important;
}

.cursor-pointer {
    cursor: pointer;
}

.fs-small {
    font-size: small !important;
}

.fs-medium {
    font-size: medium !important;
}

.fs-xx-large {
    font-size: xx-large !important;
}

.ml--1-rem {
    margin-left: -1rem !important;
}

.color-gray-600 {
    color: var(--bs-gray-600) !important;
}

.fw-bold {
    font-weight: bolder !important;
}

/* ==========================================================================
   Login / Registration Pages
   ========================================================================== */

.login-container {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
}

.login-card {
    max-width: 900px;
    width: 100%;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    border: none;
}

.login-brand-panel {
    background: var(--surya-card-gradient);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 3rem 2rem;
    min-height: 100%;
}

.login-brand-icon {
    font-size: 4rem;
    color: rgba(255, 255, 255, 0.95);
    margin-bottom: 1rem;
}

.login-brand-title {
    font-family: sans-serif;
    font-size: 2.5rem;
    font-weight: 800;
    color: white;
    letter-spacing: 0.1em;
    text-decoration: none;
    margin-bottom: 1.5rem;
}

.login-brand-title:hover {
    color: white;
    text-decoration: none;
}

.login-brand-description {
    color: rgba(255, 255, 255, 0.85);
    text-align: center;
    font-size: 0.9375rem;
    line-height: 1.6;
    max-width: 280px;
}

.login-brand-cta {
    margin-top: 2.5rem;
    text-align: center;
}

.login-brand-cta p {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
}

.login-brand-cta a {
    color: white;
    font-weight: 600;
    text-decoration: none;
    padding: 0.5rem 1.5rem;
    border: 2px solid rgba(255, 255, 255, 0.5);
    border-radius: var(--radius-full);
    display: inline-block;
    transition: all 0.2s ease;
}

.login-brand-cta a:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: white;
    color: white;
}

.login-form-panel {
    padding: 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Option A: White form panel - clean workspace look */
.login-form-panel.bg-white {
    background: #ffffff;
}

/* Option B: Purple tint background with high-contrast inputs */
.login-form-panel.bg-tinted {
    background: var(--color-surface);
}

.login-form-title {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 0.5rem;
}

.login-form-subtitle {
    color: var(--color-text-muted);
    margin-bottom: 2rem;
    font-size: 0.9375rem;
}

.login-form .form-label {
    font-weight: 600;
    color: var(--color-text-secondary);
    font-size: 0.875rem;
    margin-bottom: 0.5rem;
}

.login-form .form-control,
.login-form .form-select {
    padding: 0.75rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    font-size: 0.9375rem;
    transition: all 0.2s ease;
    background-color: #ffffff;
}

.login-form .form-control:focus,
.login-form .form-select:focus {
    border-color: var(--color-focus-border);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.login-form .form-control::placeholder {
    color: var(--color-text-placeholder);
}

/* Option B: High-contrast inputs for tinted backgrounds */
.login-form.high-contrast .form-control,
.login-form.high-contrast .form-select {
    background-color: #ffffff;
    border: 2px solid #c4b5fd;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.login-form.high-contrast .form-control:focus,
.login-form.high-contrast .form-select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-focus-ring), 0 1px 3px rgba(0, 0, 0, 0.08);
}

.login-form .form-group {
    margin-bottom: 1.25rem;
}

.login-btn {
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
    font-weight: 600;
    border-radius: var(--radius-md);
    width: 100%;
    margin-top: 0.5rem;
    transition: all 0.2s ease;
}

.login-links {
    margin-top: 1.5rem;
    text-align: center;
}

.login-links a {
    color: var(--color-primary);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    transition: color 0.2s ease;
}

.login-links a:hover {
    color: var(--color-primary-hover);
    text-decoration: underline;
}

.login-links + .login-links {
    margin-top: 0.75rem;
}

.login-divider {
    display: flex;
    align-items: center;
    margin: 1rem 0;
    color: var(--color-text-muted);
    font-size: 0.8125rem;
}

.login-divider::before,
.login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

.login-divider span {
    padding: 0 1rem;
}

.alert-login {
    border-radius: var(--radius-md);
    margin-bottom: 1.5rem;
}

@media (max-width: 767.98px) {
    .login-brand-panel {
        padding: 2rem 1.5rem;
    }

    .login-form-panel {
        padding: 2rem 1.5rem;
    }

    .login-brand-icon {
        font-size: 3rem;
    }

    .login-brand-title {
        font-size: 2rem;
    }
}
