    /* ============================================
       🚀 CRYPTO TRACKER - COMPLETE THEME
       ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');
    /* ============================================
       THEME VARIABLES
       ============================================ */

    /* Dark Mode (Default) */
    :root {
        --crypto-bg-primary: #0f0f1a;
        --crypto-bg-secondary: #1e1e2e;
        --crypto-bg-tertiary: #2a2a3e;
        --crypto-bg-elevated: #353550;
        --crypto-border: rgba(255, 255, 255, 0.08);
        --crypto-border-light: rgba(255, 255, 255, 0.12);
        --crypto-text-primary: #f4f4f5;
        --crypto-text-secondary: #a1a1aa;
        --crypto-text-muted: #6b7280;
        --crypto-primary: #6366f1;
        --crypto-primary-light: #818cf8;
        --crypto-green: #10b981;
        --crypto-green-light: #34d399;
        --crypto-red: #ef4444;
        --crypto-red-light: #f87171;
        --crypto-cyan: #06b6d4;
        --crypto-amber: #f59e0b;
        --crypto-purple: #8b5cf6;
        --crypto-pink: #ec4899;
        --crypto-gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
        --crypto-gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);
        --crypto-gradient-danger: linear-gradient(135deg, #ef4444 0%, #f87171 100%);
        --crypto-gradient-cyan: linear-gradient(135deg, #06b6d4 0%, #22d3ee 100%);
        --crypto-gradient-purple: linear-gradient(135deg, #8b5cf6 0%, #a78bfa 100%);
        --crypto-glow-primary: 0 0 20px rgba(99, 102, 241, 0.4);
        --crypto-glow-success: 0 0 20px rgba(16, 185, 129, 0.4);
        --crypto-glow-danger: 0 0 20px rgba(239, 68, 68, 0.4);
        --crypto-glow-cyan: 0 0 20px rgba(6, 182, 212, 0.4);

        /* Progress bar colors */
        --progress-bar-background: rgba(255, 255, 255, 0.1);

        /* Skeleton colors */
        --skeleton-base: rgba(255, 255, 255, 0.05);
        --skeleton-shine: rgba(255, 255, 255, 0.1);
    }

    /* Light Mode */
    [data-theme="light"] {
        --crypto-bg-primary: #ffffff;
        --crypto-bg-secondary: #f8f9fa;
        --crypto-bg-tertiary: #e9ecef;
        --crypto-bg-elevated: #ffffff;
        --crypto-border: #dee2e6;
        --crypto-border-light: #e9ecef;
        --crypto-text-primary: #212529;
        --crypto-text-secondary: #495057;
        --crypto-text-muted: #6c757d;
        --crypto-primary: #5b5fc7;
        --crypto-primary-light: #7c7fd8;
        --crypto-green: #00a887;
        --crypto-green-light: #00c9a0;
        --crypto-red: #dc3545;
        --crypto-red-light: #e85563;
        --crypto-cyan: #0099cc;
        --crypto-amber: #ff9800;
        --crypto-purple: #7c3aed;
        --crypto-pink: #db2777;
        --crypto-gradient-primary: linear-gradient(135deg, #5b5fc7 0%, #7c3aed 100%);
        --crypto-gradient-success: linear-gradient(135deg, #00a887 0%, #00c9a0 100%);
        --crypto-gradient-danger: linear-gradient(135deg, #dc3545 0%, #e85563 100%);
        --crypto-gradient-cyan: linear-gradient(135deg, #0099cc 0%, #00b8e6 100%);
        --crypto-gradient-purple: linear-gradient(135deg, #7c3aed 0%, #a78bfa 100%);
        --crypto-glow-primary: 0 0 20px rgba(91, 95, 199, 0.2);
        --crypto-glow-success: 0 0 20px rgba(0, 168, 135, 0.2);
        --crypto-glow-danger: 0 0 20px rgba(220, 53, 69, 0.2);
        --crypto-glow-cyan: 0 0 20px rgba(0, 153, 204, 0.2);

        /* Progress bar colors */
        --progress-bar-background: rgba(0, 0, 0, 0.1);

        /* Skeleton colors */
        --skeleton-base: rgba(0, 0, 0, 0.08);
        --skeleton-shine: rgba(0, 0, 0, 0.12);
    }

    /* ============================================
       THEME-SPECIFIC OVERRIDES
       ============================================ */

    /* Navbar */
    [data-theme="light"] .navbar {
        background: var(--crypto-bg-primary);
        border-bottom: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .navbar-item,
    [data-theme="light"] .navbar-link {
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .navbar-item:hover,
    [data-theme="light"] .navbar-link:hover {
        background-color: var(--crypto-bg-secondary);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .navbar-item.is-active {
        color: var(--crypto-primary);
    }

    [data-theme="light"] .navbar-dropdown {
        background-color: var(--crypto-bg-primary);
        border: 1px solid var(--crypto-border);
    }

    /* Hero Section */
    [data-theme="light"] .hero.is-dark {
        background: var(--crypto-gradient-primary) !important;
    }

    [data-theme="light"] .hero.is-dark .title,
    [data-theme="light"] .hero.is-dark .subtitle {
        color: #ffffff !important;
    }

    [data-theme="light"] .breadcrumb a {
        color: rgba(255, 255, 255, 0.9);
    }

    [data-theme="light"] .breadcrumb li.is-active a {
        color: rgba(255, 255, 255, 0.7);
    }

    /* Cards and Boxes */
    [data-theme="light"] .box,
    [data-theme="light"] .card {
        background: var(--crypto-bg-primary);
        border: 1px solid var(--crypto-border);
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    }

    [data-theme="light"] .card-header {
        background-color: var(--crypto-bg-secondary);
        border-bottom: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .card-footer {
        border-top: 1px solid var(--crypto-border);
    }

    /* Menu Sidebar */
    [data-theme="light"] .menu-list a {
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .menu-list a:hover {
        background-color: var(--crypto-bg-secondary);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .menu-list a.is-active {
        background-color: var(--crypto-primary);
        color: #ffffff;
    }

    [data-theme="light"] .menu-label {
        color: var(--crypto-text-muted);
    }

    /* Tables */
    [data-theme="light"] .table {
        background: var(--crypto-bg-primary);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .table thead th {
        color: var(--crypto-text-primary);
        border-bottom: 2px solid var(--crypto-border);
    }

    [data-theme="light"] .table tbody tr {
        border-bottom: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .table.is-hoverable tbody tr:hover {
        background-color: var(--crypto-bg-secondary);
    }

    /* Forms */
    [data-theme="light"] .input,
    [data-theme="light"] .textarea,
    [data-theme="light"] .select select {
        background: var(--crypto-bg-primary);
        color: var(--crypto-text-primary);
        border-color: var(--crypto-border);
    }

    [data-theme="light"] .input:focus,
    [data-theme="light"] .textarea:focus,
    [data-theme="light"] .select select:focus {
        border-color: var(--crypto-primary);
    }

    /* Panel */
    [data-theme="light"] .panel {
        border: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .panel-heading {
        background-color: var(--crypto-primary);
        color: #ffffff;
    }

    [data-theme="light"] .panel-block {
        border-top: 1px solid var(--crypto-border);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .panel-block:hover {
        background-color: var(--crypto-bg-secondary);
    }

    /* Progress Bars */
    .progress::-webkit-progress-bar {
        background-color: var(--progress-bar-background);
    }

    .progress::-moz-progress-bar {
        background-color: var(--progress-bar-background);
    }

    [data-theme="light"] .progress {
        background-color: var(--progress-bar-background);
    }

    /* Buttons - Fix for missing background colors */
    .button.is-success {
        background-color: var(--crypto-green);
        border-color: transparent;
        color: #fff;
    }

    .button.is-success:hover {
        background-color: var(--crypto-green-light);
    }

    .button.is-danger {
        background-color: var(--crypto-red);
        border-color: transparent;
        color: #fff;
    }

    .button.is-danger:hover {
        background-color: var(--crypto-red-light);
    }

    .button.is-info {
        background-color: var(--crypto-cyan);
        border-color: transparent;
        color: #fff;
    }

    .button.is-info:hover {
        background-color: #0bb3dd;
    }

    /* File upload button - keep white text on primary background */
    [data-theme="light"] .file.is-primary .file-cta {
        background-color: var(--crypto-primary);
        color: #ffffff;
    }

    [data-theme="light"] .file.is-primary:hover .file-cta {
        background-color: var(--crypto-primary-light);
        color: #ffffff;
    }

    /* Pro Features Tile - keep white text */
    [data-theme="light"] .tile.is-child.box[style*="crypto-gradient-purple"] .title,
    [data-theme="light"] .tile.is-child.box[style*="crypto-gradient-purple"] .subtitle {
        color: #ffffff !important;
    }

    /* Messages - Fix header text contrast */
    .message.is-success .message-header {
        background-color: var(--crypto-green);
        color: #ffffff;
    }

    .message.is-warning .message-header {
        background-color: var(--crypto-amber);
        color: #ffffff;
    }

    .message.is-danger .message-header {
        background-color: var(--crypto-red);
        color: #ffffff;
    }

    .message.is-info .message-header {
        background-color: var(--crypto-cyan);
        color: #ffffff;
    }

    [data-theme="light"] .message.is-success .message-header {
        background-color: var(--crypto-green);
        color: #ffffff;
    }

    [data-theme="light"] .message.is-warning .message-header {
        background-color: var(--crypto-amber);
        color: #ffffff;
    }

    [data-theme="light"] .message.is-danger .message-header {
        background-color: var(--crypto-red);
        color: #ffffff;
    }

    [data-theme="light"] .message.is-info .message-header {
        background-color: var(--crypto-cyan);
        color: #ffffff;
    }

    /* Skeleton Loading */
    .skeleton {
        background: var(--skeleton-base);
        position: relative;
        overflow: hidden;
    }

    .skeleton::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(
                90deg,
                transparent,
                var(--skeleton-shine),
                transparent
        );
        animation: skeleton-loading 1.5s infinite;
    }

    @keyframes skeleton-loading {
        0% {
            transform: translateX(-100%);
        }
        100% {
            transform: translateX(100%);
        }
    }

    .skeleton.is-circle {
        border-radius: 50%;
    }

    /* Dropdown */
    [data-theme="light"] .dropdown-menu {
        background-color: var(--crypto-bg-primary);
        border: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .dropdown-content {
        background-color: var(--crypto-bg-primary);
    }

    [data-theme="light"] .dropdown-item {
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .dropdown-item:hover {
        background-color: var(--crypto-bg-secondary);
    }

    [data-theme="light"] .dropdown-divider {
        background-color: var(--crypto-border);
    }

    /* Modal */
    [data-theme="light"] .modal-card {
        background-color: var(--crypto-bg-primary);
    }

    [data-theme="light"] .modal-card-head {
        background-color: var(--crypto-bg-secondary);
        border-bottom: 1px solid var(--crypto-border);
    }

    [data-theme="light"] .modal-card-body {
        background-color: var(--crypto-bg-primary);
    }

    [data-theme="light"] .modal-card-foot {
        background-color: var(--crypto-bg-secondary);
        border-top: 1px solid var(--crypto-border);
    }

    /* Footer */
    [data-theme="light"] .footer {
        background-color: var(--crypto-bg-secondary);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .footer a {
        color: var(--crypto-text-secondary);
    }

    [data-theme="light"] .footer a:hover {
        color: var(--crypto-primary);
    }

    /* Tabs */
    [data-theme="light"] .tabs.is-toggle li.is-active a {
        background-color: var(--crypto-primary);
        border-color: var(--crypto-primary);
        color: #ffffff;
    }

    [data-theme="light"] .tabs a {
        border-bottom-color: var(--crypto-border);
        color: var(--crypto-text-primary);
    }

    /* Notifications */
    [data-theme="light"] .notification {
        background-color: var(--crypto-bg-secondary);
    }

    /* Tags */
    [data-theme="light"] .tag:not(.is-primary):not(.is-success):not(.is-danger):not(.is-warning):not(.is-info):not(.is-dark) {
        background-color: var(--crypto-bg-tertiary);
        color: var(--crypto-text-primary);
    }

    /* Pagination */
    [data-theme="light"] .pagination-link,
    [data-theme="light"] .pagination-previous,
    [data-theme="light"] .pagination-next {
        border-color: var(--crypto-border);
        color: var(--crypto-text-primary);
    }

    [data-theme="light"] .pagination-link:hover,
    [data-theme="light"] .pagination-previous:hover,
    [data-theme="light"] .pagination-next:hover {
        border-color: var(--crypto-primary);
    }

    [data-theme="light"] .pagination-link.is-current {
        background-color: var(--crypto-primary);
        border-color: var(--crypto-primary);
        color: #ffffff;
    }





    * { box-sizing: border-box; }

html, body {
    background-color: var(--crypto-bg-primary) !important;
    color: var(--crypto-text-primary);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    min-height: 100vh;
}

::selection {
    background-color: rgba(99, 102, 241, 0.4);
    color: white;
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--crypto-bg-secondary); }
::-webkit-scrollbar-thumb { background: var(--crypto-bg-tertiary); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--crypto-bg-elevated); }

/* ============================================
   TYPOGRAPHY
   ============================================ */

.title, .subtitle, h1, h2, h3, h4, h5, h6 {
    color: var(--crypto-text-primary) !important;
    font-weight: 700;
}
.subtitle { color: var(--crypto-text-secondary) !important; }
p, .content p { color: var(--crypto-text-secondary); }
strong { color: var(--crypto-text-primary); }
a { color: var(--crypto-primary); }
a:hover { color: var(--crypto-primary-light); }
.has-text-grey, .has-text-grey-light { color: var(--crypto-text-secondary) !important; }
.has-text-grey-dark { color: var(--crypto-text-muted) !important; }
hr { background-color: var(--crypto-border); }
.label { color: var(--crypto-text-secondary) !important; font-weight: 500; }
.help { color: var(--crypto-text-muted); }

/* Font utilities */
.font-mono { font-family: 'JetBrains Mono', monospace !important; }
.has-text-gradient {
    background: var(--crypto-gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ============================================
   NAVBAR
   ============================================ */

.navbar {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--crypto-border);
    min-height: 4rem;
}
.navbar-brand .navbar-item { font-weight: 700; font-size: 1.25rem; }
.navbar-item, .navbar-link {
    color: var(--crypto-text-secondary);
    border-radius: 8px;
    transition: all 0.2s ease;
}
.navbar-item:hover, .navbar-link:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--crypto-text-primary);
}
.navbar-item.is-active {
    color: var(--crypto-primary) !important;
    background: rgba(99, 102, 241, 0.1) !important;
}
.navbar-link::after { border-color: var(--crypto-text-secondary); }
.navbar-dropdown {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.5);
    padding: 0.5rem;
}
.navbar-dropdown .navbar-item { border-radius: 8px; }
.navbar-dropdown a.navbar-item:hover { background: rgba(255, 255, 255, 0.05); }
.navbar-divider { background-color: var(--crypto-border); }
.navbar-burger span { background-color: var(--crypto-text-primary); }
.navbar-burger:hover { background: rgba(255, 255, 255, 0.05); }

/* Notification badge */
.navbar-item.has-badge { position: relative; }
.badge {
    position: absolute;
    top: 8px;
    right: 8px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 0.625rem;
    font-weight: 600;
    line-height: 18px;
    text-align: center;
    border-radius: 9999px;
    background: var(--crypto-red);
    color: white;
}

/* ============================================
   HERO
   ============================================ */

.hero {
    background: var(--crypto-bg-primary);
}
.hero.is-primary {
    background: var(--crypto-gradient-primary);
}
.hero.is-dark {
    background: linear-gradient(135deg, var(--crypto-bg-secondary) 0%, var(--crypto-bg-primary) 100%);
}
.hero.has-bg-pattern {
    background-image:
            radial-gradient(circle at 20% 50%, rgba(99, 102, 241, 0.15) 0%, transparent 50%),
            radial-gradient(circle at 80% 20%, rgba(6, 182, 212, 0.1) 0%, transparent 40%),
            radial-gradient(circle at 40% 80%, rgba(139, 92, 246, 0.1) 0%, transparent 40%);
}
.hero .title { color: white !important; }
.hero .subtitle { color: rgba(255, 255, 255, 0.8) !important; }

/* ============================================
   BUTTONS
   ============================================ */

.button {
    font-weight: 500;
    border-radius: 10px;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}
.button.is-primary {
    background: var(--crypto-gradient-primary);
    border: none;
    color: white;
}
.button.is-primary:hover:not([disabled]) {
    box-shadow: var(--crypto-glow-primary);
    transform: translateY(-1px);
}
.button.is-primary.is-outlined {
    background: transparent;
    border: 1px solid var(--crypto-primary);
    color: var(--crypto-primary);
}
.button.is-primary.is-outlined:hover {
    background: rgba(99, 102, 241, 0.1);
    color: var(--crypto-primary);
    box-shadow: none;
    transform: none;
}
.button.is-primary.is-light {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
}
.button.is-primary.is-light:hover {
    background: rgba(99, 102, 241, 0.25);
    box-shadow: none;
    transform: none;
}
.button.is-success {
    background: var(--crypto-gradient-success);
    border: none;
}
.button.is-success:hover:not([disabled]) {
    box-shadow: var(--crypto-glow-success);
    transform: translateY(-1px);
}
.button.is-success.is-light {
    background: rgba(16, 185, 129, 0.15);
    color: var(--crypto-green-light);
}
.button.is-danger {
    background: var(--crypto-gradient-danger);
    border: none;
}
.button.is-danger:hover:not([disabled]) {
    box-shadow: var(--crypto-glow-danger);
    transform: translateY(-1px);
}
.button.is-danger.is-light {
    background: rgba(239, 68, 68, 0.15);
    color: var(--crypto-red-light);
}
.button.is-info {
    background: var(--crypto-gradient-cyan);
    border: none;
}
.button.is-info:hover:not([disabled]) {
    box-shadow: var(--crypto-glow-cyan);
    transform: translateY(-1px);
}
.button.is-info.is-light {
    background: rgba(6, 182, 212, 0.15);
    color: #22d3ee;
}
.button.is-warning {
    background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
    border: none;
    color: #0f0f1a;
}
.button.is-warning.is-light {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}
.button.is-dark {
    background: var(--crypto-bg-tertiary);
    border: 1px solid var(--crypto-border);
    color: var(--crypto-text-primary);
}
.button.is-dark:hover {
    background: var(--crypto-bg-elevated);
    border-color: var(--crypto-border-light);
}
.button.is-light {
    background: rgba(255, 255, 255, 0.1);
    color: var(--crypto-text-primary);
}
.button.is-light:hover {
    background: rgba(255, 255, 255, 0.15);
}
.button.is-ghost {
    background: transparent;
    border: none;
    color: var(--crypto-text-secondary);
}
.button.is-ghost:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--crypto-text-primary);
}
.button.is-text {
    color: var(--crypto-text-secondary);
    text-decoration: none;
}
.button.is-text:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--crypto-text-primary);
}
.button.is-loading::after {
    border-color: transparent transparent rgba(255,255,255,0.7) rgba(255,255,255,0.7) !important;
}
.button[disabled] {
    opacity: 0.5;
    cursor: not-allowed;
}
.buttons.has-addons .button {
    border-radius: 0;
}
.buttons.has-addons .button:first-child {
    border-radius: 10px 0 0 10px;
}
.buttons.has-addons .button:last-child {
    border-radius: 0 10px 10px 0;
}

/* ============================================
   CARDS
   ============================================ */

.card {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 16px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    overflow: hidden;
}
.card:hover {
    border-color: var(--crypto-border-light);
    box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.4);
}
.card.is-glass {
    background: rgba(30, 30, 46, 0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
.card-header {
    background: transparent;
    border-bottom: 1px solid var(--crypto-border);
    box-shadow: none;
}
.card-header-title {
    color: var(--crypto-text-primary);
    font-weight: 600;
}
.card-header-icon { color: var(--crypto-text-muted); }
.card-content { padding: 1.5rem; }
.card-footer {
    background: transparent;
    border-top: 1px solid var(--crypto-border);
}
.card-footer-item {
    color: var(--crypto-text-secondary);
    border-right: 1px solid var(--crypto-border);
}
.card-footer-item:last-child { border-right: none; }
.card-footer-item:hover {
    background: rgba(255, 255, 255, 0.03);
    color: var(--crypto-text-primary);
}
.card-image { background: var(--crypto-bg-tertiary); }

/* ============================================
   BOX
   ============================================ */

.box {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 16px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
    color: var(--crypto-text-primary);
}

/* ============================================
   FORM ELEMENTS
   ============================================ */

.input, .textarea, .select select {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 10px;
    color: var(--crypto-text-primary);
    transition: all 0.2s ease;
}
.input::placeholder, .textarea::placeholder {
    color: var(--crypto-text-muted);
}
.input:hover, .textarea:hover, .select select:hover {
    border-color: var(--crypto-border-light);
}
.input:focus, .textarea:focus, .select select:focus,
.input.is-focused, .textarea.is-focused, .select select.is-focused {
    border-color: var(--crypto-primary);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}
.input.is-success, .textarea.is-success, .select.is-success select {
    border-color: var(--crypto-green);
}
.input.is-success:focus, .textarea.is-success:focus {
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.2);
}
.input.is-danger, .textarea.is-danger, .select.is-danger select {
    border-color: var(--crypto-red);
}
.input.is-danger:focus, .textarea.is-danger:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.2);
}
.input.is-info, .textarea.is-info, .select.is-info select {
    border-color: var(--crypto-cyan);
}
.select::after { border-color: var(--crypto-text-muted); }
.select:not(.is-multiple):not(.is-loading):hover::after {
    border-color: var(--crypto-text-secondary);
}

/* Checkbox & Radio */
.checkbox, .radio {
    color: var(--crypto-text-secondary);
}
.checkbox:hover, .radio:hover {
    color: var(--crypto-text-primary);
}
.checkbox input[type="checkbox"],
.radio input[type="radio"] {
    accent-color: var(--crypto-primary);
}

/* File input */
.file-cta {
    background: var(--crypto-bg-tertiary);
    border-color: var(--crypto-border);
    color: var(--crypto-text-primary);
}
.file-name {
    background: var(--crypto-bg-secondary);
    border-color: var(--crypto-border);
    color: var(--crypto-text-secondary);
}
.file:hover .file-cta {
    background: var(--crypto-bg-elevated);
}
.file.is-primary .file-cta {
    background: var(--crypto-gradient-primary);
    border: none;
}

/* Control icons */
.control.has-icons-left .icon,
.control.has-icons-right .icon {
    color: var(--crypto-text-muted);
}
.control.has-icons-left .input:focus ~ .icon,
.control.has-icons-right .input:focus ~ .icon {
    color: var(--crypto-text-secondary);
}

/* ============================================
   TABLES
   ============================================ */

.table {
    background: transparent;
    color: var(--crypto-text-primary);
}
.table th {
    color: var(--crypto-text-muted) !important;
    border-bottom: 1px solid var(--crypto-border) !important;
    font-weight: 500;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.table td {
    border-bottom: 1px solid var(--crypto-border) !important;
    vertical-align: middle;
}
.table tbody tr {
    transition: background 0.15s ease;
}
.table tbody tr:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}
.table.is-striped tbody tr:nth-child(even) {
    background: rgba(255, 255, 255, 0.02);
}
.table.is-striped tbody tr:nth-child(even):hover {
    background: rgba(255, 255, 255, 0.04) !important;
}
.table.is-bordered td, .table.is-bordered th {
    border: 1px solid var(--crypto-border) !important;
}
.table thead td, .table thead th {
    color: var(--crypto-text-muted);
    border-bottom-width: 1px;
}

/* ============================================
   TAGS
   ============================================ */

.tag {
    background: rgba(255, 255, 255, 0.1);
    color: var(--crypto-text-primary);
    border-radius: 9999px;
    font-weight: 500;
}
.tag.is-primary {
    background: rgba(99, 102, 241, 0.2);
    color: var(--crypto-primary-light);
}
.tag.is-success {
    background: rgba(16, 185, 129, 0.2);
    color: var(--crypto-green-light);
}
.tag.is-danger {
    background: rgba(239, 68, 68, 0.2);
    color: var(--crypto-red-light);
}
.tag.is-warning {
    background: rgba(245, 158, 11, 0.2);
    color: #fbbf24;
}
.tag.is-info {
    background: rgba(6, 182, 212, 0.2);
    color: #22d3ee;
}
.tag.is-dark {
    background: var(--crypto-bg-tertiary);
    color: var(--crypto-text-primary);
}
.tag.is-light {
    background: rgba(255, 255, 255, 0.1);
    color: var(--crypto-text-primary);
}
.tags.has-addons .tag { border-radius: 0; }
.tags.has-addons .tag:first-child { border-radius: 9999px 0 0 9999px; }
.tags.has-addons .tag:last-child { border-radius: 0 9999px 9999px 0; }
.tag .delete { background: rgba(255, 255, 255, 0.2); }
.tag .delete:hover { background: rgba(255, 255, 255, 0.3); }

/* ============================================
   TABS
   ============================================ */

.tabs {
    border-bottom-color: var(--crypto-border);
}
.tabs a {
    color: var(--crypto-text-secondary);
    border-bottom-color: transparent;
}
.tabs a:hover {
    color: var(--crypto-text-primary);
    border-bottom-color: var(--crypto-text-muted);
}
.tabs li.is-active a {
    color: var(--crypto-primary);
    border-bottom-color: var(--crypto-primary);
}
.tabs.is-boxed a {
    border-color: var(--crypto-border);
    border-radius: 8px 8px 0 0;
}
.tabs.is-boxed a:hover {
    background: rgba(255, 255, 255, 0.03);
    border-bottom-color: var(--crypto-border);
}
.tabs.is-boxed li.is-active a {
    background: var(--crypto-bg-secondary);
    border-color: var(--crypto-border);
    border-bottom-color: transparent;
}
.tabs.is-toggle a {
    border-color: var(--crypto-border);
    color: var(--crypto-text-secondary);
}
.tabs.is-toggle a:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: var(--crypto-border-light);
}
.tabs.is-toggle li.is-active a {
    background: var(--crypto-primary);
    border-color: var(--crypto-primary);
    color: white;
}
.tabs.is-toggle li:first-child a { border-radius: 10px 0 0 10px; }
.tabs.is-toggle li:last-child a { border-radius: 0 10px 10px 0; }

/* ============================================
   PAGINATION
   ============================================ */

.pagination-previous, .pagination-next, .pagination-link {
    background: var(--crypto-bg-secondary);
    border-color: var(--crypto-border);
    color: var(--crypto-text-secondary);
    border-radius: 8px;
}
.pagination-previous:hover, .pagination-next:hover, .pagination-link:hover {
    background: var(--crypto-bg-tertiary);
    border-color: var(--crypto-border-light);
    color: var(--crypto-text-primary);
}
.pagination-link.is-current {
    background: var(--crypto-gradient-primary);
    border-color: transparent;
    color: white;
}
.pagination-ellipsis {
    color: var(--crypto-text-muted);
}
.pagination-previous[disabled], .pagination-next[disabled] {
    background: var(--crypto-bg-tertiary);
    border-color: var(--crypto-border);
    color: var(--crypto-text-muted);
    opacity: 0.5;
}

/* ============================================
   PROGRESS
   ============================================ */

.progress {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 9999px;
}
.progress::-webkit-progress-bar {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 9999px;
}
.progress::-webkit-progress-value {
    background: var(--crypto-gradient-primary);
    border-radius: 9999px;
}
.progress::-moz-progress-bar {
    background: var(--crypto-gradient-primary);
    border-radius: 9999px;
}
.progress.is-primary::-webkit-progress-value { background: var(--crypto-gradient-primary); }
.progress.is-success::-webkit-progress-value { background: var(--crypto-gradient-success); }
.progress.is-danger::-webkit-progress-value { background: var(--crypto-gradient-danger); }
.progress.is-info::-webkit-progress-value { background: var(--crypto-gradient-cyan); }
.progress.is-warning::-webkit-progress-value { background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%); }

/* ============================================
   NOTIFICATIONS / MESSAGES
   ============================================ */

.notification {
    background: var(--crypto-bg-tertiary);
    border-radius: 12px;
    color: var(--crypto-text-primary);
}
.notification.is-primary {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
}
.notification.is-success {
    background: rgba(16, 185, 129, 0.15);
    color: var(--crypto-green-light);
}
.notification.is-danger {
    background: rgba(239, 68, 68, 0.15);
    color: var(--crypto-red-light);
}
.notification.is-warning {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}
.notification.is-info {
    background: rgba(6, 182, 212, 0.15);
    color: #22d3ee;
}
.notification .delete {
    background: rgba(255, 255, 255, 0.2);
}
.notification .delete:hover {
    background: rgba(255, 255, 255, 0.3);
}

.message {
    background: var(--crypto-bg-secondary);
    border-radius: 12px;
}
.message-header {
    background: var(--crypto-bg-tertiary);
    color: var(--crypto-text-primary);
    border-radius: 12px 12px 0 0;
}
.message-body {
    border: 1px solid var(--crypto-border);
    border-top: none;
    border-radius: 0 0 12px 12px;
    color: var(--crypto-text-secondary);
}
.message.is-primary .message-header { background: var(--crypto-primary); }
.message.is-primary .message-body { border-color: rgba(99, 102, 241, 0.3); }
.message.is-success .message-header { background: var(--crypto-green); }
.message.is-success .message-body { border-color: rgba(16, 185, 129, 0.3); }
.message.is-danger .message-header { background: var(--crypto-red); }
.message.is-danger .message-body { border-color: rgba(239, 68, 68, 0.3); }
.message.is-info .message-header { background: var(--crypto-cyan); }
.message.is-info .message-body { border-color: rgba(6, 182, 212, 0.3); }
.message.is-warning .message-header { background: var(--crypto-amber); color: #0f0f1a; }
.message.is-warning .message-body { border-color: rgba(245, 158, 11, 0.3); }

/* ============================================
   DROPDOWN
   ============================================ */

.dropdown-content {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.5);
    padding: 0.5rem;
}
.dropdown-item {
    color: var(--crypto-text-primary);
    border-radius: 8px;
    padding: 0.5rem 1rem;
}
a.dropdown-item:hover, button.dropdown-item:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--crypto-text-primary);
}
a.dropdown-item.is-active {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
}
.dropdown-divider {
    background-color: var(--crypto-border);
    margin: 0.5rem 0;
}

/* ============================================
   MODAL
   ============================================ */

.modal-background {
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(4px);
}
.modal-card {
    border-radius: 16px;
    overflow: hidden;
}
.modal-card-head {
    background: var(--crypto-bg-secondary);
    border-bottom: 1px solid var(--crypto-border);
}
.modal-card-title {
    color: var(--crypto-text-primary);
}
.modal-card-body {
    background: var(--crypto-bg-secondary);
    color: var(--crypto-text-secondary);
}
.modal-card-foot {
    background: var(--crypto-bg-secondary);
    border-top: 1px solid var(--crypto-border);
}
.modal-close {
    background: rgba(255, 255, 255, 0.2);
}
.modal-close:hover {
    background: rgba(255, 255, 255, 0.3);
}
.modal-card-head .delete {
    background: rgba(255, 255, 255, 0.1);
}
.modal-card-head .delete:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* ============================================
   MENU (Sidebar)
   ============================================ */

.menu-label {
    color: var(--crypto-text-muted);
    font-weight: 600;
    letter-spacing: 0.05em;
}
.menu-list a {
    color: var(--crypto-text-secondary);
    border-radius: 8px;
    transition: all 0.15s ease;
}
.menu-list a:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--crypto-text-primary);
}
.menu-list a.is-active {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
}
.menu-list li ul {
    border-left: 1px solid var(--crypto-border);
    margin: 0.5rem 0 0.5rem 1rem;
    padding-left: 0.75rem;
}

/* ============================================
   PANEL
   ============================================ */

.panel {
    background: var(--crypto-bg-secondary);
    border-radius: 16px;
    border: 1px solid var(--crypto-border);
    overflow: hidden;
}
.panel-heading {
    background: var(--crypto-bg-tertiary);
    color: var(--crypto-text-primary);
    border-bottom: 1px solid var(--crypto-border);
    border-radius: 0;
}
.panel-tabs a {
    color: var(--crypto-text-secondary);
    border-bottom-color: var(--crypto-border);
}
.panel-tabs a:hover {
    border-bottom-color: var(--crypto-text-secondary);
}
.panel-tabs a.is-active {
    color: var(--crypto-primary);
    border-bottom-color: var(--crypto-primary);
}
.panel-block {
    border-bottom: 1px solid var(--crypto-border);
    color: var(--crypto-text-primary);
}
.panel-block:last-child {
    border-bottom: none;
}
.panel-block:hover {
    background: rgba(255, 255, 255, 0.03);
}
.panel-block.is-active {
    background: rgba(99, 102, 241, 0.1);
    border-left: 3px solid var(--crypto-primary);
    color: var(--crypto-primary-light);
}
.panel-icon {
    color: var(--crypto-text-muted);
}
.panel.is-primary .panel-heading {
    background: var(--crypto-primary);
    color: white;
}

/* ============================================
   BREADCRUMB
   ============================================ */

.breadcrumb a {
    color: var(--crypto-text-secondary);
}
.breadcrumb a:hover {
    color: var(--crypto-primary);
}
.breadcrumb li.is-active a {
    color: var(--crypto-text-primary);
}
.breadcrumb li + li::before {
    color: var(--crypto-text-muted);
}

/* ============================================
   LEVEL
   ============================================ */

.level-item .title, .level-item .heading {
    color: var(--crypto-text-muted) !important;
}
.level-item .title {
    color: var(--crypto-text-primary) !important;
}

/* ============================================
   MEDIA OBJECT
   ============================================ */

.media + .media {
    border-top-color: var(--crypto-border);
}
.media-content .content {
    color: var(--crypto-text-secondary);
}

/* ============================================
   IMAGE / FIGURE
   ============================================ */

.image {
    background: var(--crypto-bg-tertiary);
    border-radius: 8px;
}
figure.image img {
    border-radius: 8px;
}

/* ============================================
   FOOTER
   ============================================ */

.footer {
    background: var(--crypto-bg-secondary);
    border-top: 1px solid var(--crypto-border);
    padding: 3rem 1.5rem;
}
.footer .content {
    color: var(--crypto-text-muted);
}
.footer a {
    color: var(--crypto-text-secondary);
}
.footer a:hover {
    color: var(--crypto-primary);
}

/* ============================================
   TILE
   ============================================ */

.tile.is-child.box {
    background: var(--crypto-bg-secondary);
}

/* ============================================
   CONTENT
   ============================================ */

.content h1, .content h2, .content h3, .content h4, .content h5, .content h6 {
    color: var(--crypto-text-primary);
}
.content blockquote {
    background: var(--crypto-bg-tertiary);
    border-left-color: var(--crypto-primary);
}
.content pre {
    background: var(--crypto-bg-tertiary);
}
.content code {
    background: var(--crypto-bg-tertiary);
    color: var(--crypto-red-light);
}
.content table th {
    color: var(--crypto-text-secondary);
}

/* ============================================
   CUSTOM CRYPTO COMPONENTS
   ============================================ */

/* Stat Box */
.stat-box {
    background: var(--crypto-bg-secondary);
    border: 1px solid var(--crypto-border);
    border-radius: 16px;
    padding: 1.25rem;
    transition: all 0.3s ease;
}
.stat-box:hover {
    border-color: var(--crypto-border-light);
}
.stat-box .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 1rem;
}
.stat-box .stat-icon.is-primary {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
}
.stat-box .stat-icon.is-success {
    background: rgba(16, 185, 129, 0.15);
    color: var(--crypto-green-light);
}
.stat-box .stat-icon.is-danger {
    background: rgba(239, 68, 68, 0.15);
    color: var(--crypto-red-light);
}
.stat-box .stat-icon.is-info {
    background: rgba(6, 182, 212, 0.15);
    color: #22d3ee;
}
.stat-box .stat-label {
    color: var(--crypto-text-muted);
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.25rem;
}
.stat-box .stat-value {
    color: var(--crypto-text-primary);
    font-size: 1.75rem;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    line-height: 1.2;
}
.stat-box .stat-change {
    font-size: 0.875rem;
    font-weight: 600;
    margin-top: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}
.stat-box.is-gradient {
    background: var(--crypto-gradient-primary);
    border: none;
}
.stat-box.is-gradient .stat-label {
    color: rgba(255, 255, 255, 0.7);
}
.stat-box.is-gradient .stat-value {
    color: white;
}
.stat-box.is-gradient .stat-change {
    color: rgba(255, 255, 255, 0.9);
}

/* Price indicators */
.price-positive { color: var(--crypto-green) !important; }
.price-negative { color: var(--crypto-red) !important; }
.price-neutral { color: var(--crypto-text-muted) !important; }

.price-change-pill {
    padding: 0.25rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}
.price-change-pill.is-positive {
    background: rgba(16, 185, 129, 0.15);
    color: var(--crypto-green-light);
}
.price-change-pill.is-negative {
    background: rgba(239, 68, 68, 0.15);
    color: var(--crypto-red-light);
}

/* Coin info display */
.coin-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}
.coin-info .coin-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: contain;
    background: var(--crypto-bg-tertiary);
}
.coin-info .coin-details .coin-name {
    font-weight: 600;
    color: var(--crypto-text-primary);
}
.coin-info .coin-details .coin-symbol {
    font-size: 0.75rem;
    color: var(--crypto-text-muted);
    text-transform: uppercase;
}

/* Skeleton loading */
.skeleton {
    background: linear-gradient(
            90deg,
            var(--crypto-bg-tertiary) 0%,
            var(--crypto-bg-elevated) 50%,
            var(--crypto-bg-tertiary) 100%
    );
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    border-radius: 8px;
}
.skeleton.is-circle { border-radius: 50%; }
@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Glass effect */
.is-glass {
    background: rgba(30, 30, 46, 0.6) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Glow effects */
.has-glow-primary { box-shadow: var(--crypto-glow-primary); }
.has-glow-success { box-shadow: var(--crypto-glow-success); }
.has-glow-danger { box-shadow: var(--crypto-glow-danger); }
.has-glow-cyan { box-shadow: var(--crypto-glow-cyan); }

/* Custom scrollbar hide */
.hide-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.hide-scrollbar::-webkit-scrollbar { display: none; }

/* Divider */
.divider {
    height: 1px;
    background: var(--crypto-border);
    margin: 1.5rem 0;
}

/* Avatar */
.avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--crypto-gradient-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: white;
}
.avatar.is-small { width: 32px; height: 32px; font-size: 0.75rem; }
.avatar.is-medium { width: 48px; height: 48px; }
.avatar.is-large { width: 64px; height: 64px; font-size: 1.25rem; }

/* Sparkline placeholder */
.sparkline {
    height: 40px;
    width: 120px;
    display: flex;
    align-items: flex-end;
    gap: 2px;
}
.sparkline-bar {
    flex: 1;
    background: var(--crypto-primary);
    border-radius: 2px 2px 0 0;
    opacity: 0.6;
}
.sparkline.is-positive .sparkline-bar { background: var(--crypto-green); }
.sparkline.is-negative .sparkline-bar { background: var(--crypto-red); }

/* Status dot */
.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}
.status-dot.is-online { background: var(--crypto-green); box-shadow: 0 0 8px var(--crypto-green); }
.status-dot.is-offline { background: var(--crypto-red); }
.status-dot.is-away { background: var(--crypto-amber); }

/* Quick filter pills */
.filter-pills {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.filter-pill {
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    background: var(--crypto-bg-tertiary);
    color: var(--crypto-text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}
.filter-pill:hover {
    background: var(--crypto-bg-elevated);
    color: var(--crypto-text-primary);
}
.filter-pill.is-active {
    background: rgba(99, 102, 241, 0.15);
    color: var(--crypto-primary-light);
    border-color: rgba(99, 102, 241, 0.3);
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.animate-fade-in {
    animation: fadeIn 0.3s ease-out;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
.animate-pulse {
    animation: pulse 2s ease-in-out infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
.animate-spin {
    animation: spin 1s linear infinite;
}