/**
 * REVDEN v3 Styles
 * Live Signal Tracking Focus
 * Mobile-First Design
 * No emojis, no purple - teal-based palette
 */

/* ============================================================================
   Dark Mode Extension Compatibility (Noir, Dark Reader)
   Signals to extensions that REVDEN already provides its own dark mode.
   - color-scheme: dark → browser-level signal
   - @media (prefers-color-scheme: dark) → Noir/Dark Reader detection heuristic
   ============================================================================ */

/* Light mode default */
:root {
    color-scheme: light;
}

/* Dark mode: class-based (REVDEN toggle) */
html.dark {
    color-scheme: dark;
}

/* Signal for Noir/Dark Reader: site responds to prefers-color-scheme */
@media (prefers-color-scheme: dark) {
    html.dark :root,
    html.dark {
        color-scheme: dark;
        background-color: #0F1923;
        color: #F8FAFC;
    }
}

@media (prefers-color-scheme: light) {
    :root {
        color-scheme: light;
    }
}

/* ============================================================================
   AdBlock Override - Force header container to be visible
   Some ad blockers hide elements with flex layouts
   ============================================================================ */

#header > div,
#header #header-container,
#header > div[class*="flex"] {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    min-height: 56px !important;
}

/* ============================================================================
   Typography System
   ============================================================================ */

/* Letter-spacing for brand elements */
.tracking-brand {
    letter-spacing: 0.05em;
}

/* ============================================================================
   Base Resets & Font Smoothing
   ============================================================================ */

*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    height: 100%;
    overflow: hidden;
}

body {
    margin: 0;
    padding: 0;
    height: 100%;
    overflow: hidden;
    /* Light mode defaults - blue-tinted to match CI */
    background-color: #E2E8F2;
    color: #0F172A;
}

/* App container fills viewport exactly */
#app {
    height: 100vh;
    overflow: hidden;
}

/* Dark mode body */
.dark body,
html.dark body {
    background-color: #152535;
    color: #F8FAFC;
}

/* Main content needs padding for bottom nav on all devices */
#main-content {
    padding-bottom: 1rem;
}

/* ============================================================================
   Scrollbar Styling
   ============================================================================ */

::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.3);
    border-radius: 9999px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(148, 163, 184, 0.6);
}

/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(148, 163, 184, 0.3) transparent;
}

/* Dark mode scrollbar */
.dark ::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.25);
}

.dark ::-webkit-scrollbar-thumb:hover {
    background: rgba(100, 116, 139, 0.5);
}

.dark * {
    scrollbar-color: rgba(100, 116, 139, 0.25) transparent;
}

/* Main content scrollbar - slightly wider with margin */
#main-content::-webkit-scrollbar {
    width: 10px;
}

#main-content::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.25);
    border: 2px solid transparent;
    background-clip: padding-box;
    border-radius: 9999px;
}

.dark #main-content::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.2);
    border: 2px solid transparent;
    background-clip: padding-box;
}

/* ============================================================================
   Unified Bottom Navigation (All Devices)
   ============================================================================ */

#bottom-nav {
    height: 4rem;
    background-color: #FFFFFF;
    border-top: 1px solid #E2E8F0;
}

.dark #bottom-nav {
    background-color: #1E3345;
    border-top-color: #2A4155;
}

.bottom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.25rem;
    color: #64748B;
    font-size: 0.625rem;
    font-weight: 500;
    transition: color 0.2s ease;
    position: relative;
    flex: 1 1 0;
    min-width: 0;
    background: none;
    border: none;
    cursor: pointer;
}

.bottom-nav-item svg {
    width: 1.25rem;
    height: 1.25rem;
    margin-bottom: 0.25rem;
    stroke-width: 2;
}

.bottom-nav-item span:not(.bottom-nav-badge) {
    font-size: 0.625rem;
    font-weight: 500;
}

.bottom-nav-item:hover {
    color: #94A3B8;
}

.bottom-nav-item.active {
    color: #14B8A6;
}

.bottom-nav-item:active {
    transform: scale(0.95);
}

.bottom-nav-badge {
    position: absolute;
    top: 0.25rem;
    left: 50%;
    margin-left: 0.25rem;
    min-width: 1rem;
    height: 1rem;
    padding: 0 0.25rem;
    font-size: 0.625rem;
    font-weight: 700;
    background-color: #EF4444;
    color: white;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
}

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

.card {
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 1rem;
    overflow: hidden;
    transition: all 0.2s ease;
}

.card:hover {
    border-color: #CBD5E1;
}

.dark .card {
    background-color: #1E3345;
    border-color: #2A4155;
}

.dark .card:hover {
    border-color: #3A5165;
}

/* Clickable Dashboard Cards */
.card-clickable {
    cursor: pointer;
    transition: all 0.2s ease;
}

.card-clickable:hover {
    border-color: #14B8A6;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(20, 184, 166, 0.15);
}

.card-clickable:active {
    transform: translateY(0);
}

/* ============================================================================
   Filter Chips
   ============================================================================ */

/* Asset Category Tabs */
.asset-filter-tab {
    display: inline-flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    color: #94A3B8;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: all 0.2s ease;
}

.asset-filter-tab:hover {
    color: #64748B;
}

.asset-filter-tab.active {
    color: #14B8A6;
    border-bottom-color: #14B8A6;
}

.dark .asset-filter-tab {
    color: #64748B;
}

.dark .asset-filter-tab:hover {
    color: #94A3B8;
}

.dark .asset-filter-tab.active {
    color: #14B8A6;
    border-bottom-color: #14B8A6;
}

/* Asset-specific tab active colors */
.asset-filter-tab[data-asset-filter="gold"].active {
    color: #C9A24D;
    border-bottom-color: #C9A24D;
}
.asset-filter-tab[data-asset-filter="indices"].active {
    color: #5A7FA6;
    border-bottom-color: #5A7FA6;
}
.asset-filter-tab[data-asset-filter="crypto"].active {
    color: #7A6FAE;
    border-bottom-color: #7A6FAE;
}
.dark .asset-filter-tab[data-asset-filter="gold"].active {
    color: #C9A24D;
    border-bottom-color: #C9A24D;
}
.dark .asset-filter-tab[data-asset-filter="indices"].active {
    color: #5A7FA6;
    border-bottom-color: #5A7FA6;
}
.dark .asset-filter-tab[data-asset-filter="crypto"].active {
    color: #7A6FAE;
    border-bottom-color: #7A6FAE;
}

.filter-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: #64748B;
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 9999px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.filter-chip:hover {
    background-color: #F1F5F9;
    color: #0F172A;
}

.dark .filter-chip {
    color: #94A3B8;
    background-color: #1E3345;
    border-color: #2A4155;
}

.dark .filter-chip:hover {
    background-color: #2A4155;
    color: #F1F5F9;
}

.filter-chip.active {
    background-color: #14B8A6;
    border-color: #14B8A6;
    color: white;
}

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

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

.status-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 9999px;
    animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.status-badge-open {
    background-color: rgba(16, 185, 129, 0.15);
    color: #10B981;
}

.status-badge-open .status-dot {
    background-color: #10B981;
}

.status-badge-closed {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}

.status-badge-closed .status-dot {
    background-color: #EF4444;
}

/* Header Market Status Dot */
#market-status-dot {
    animation: pulse-dot 2s ease-in-out infinite;
}

#market-status-dot.open {
    background-color: #10B981;
}

#market-status-dot.closed {
    background-color: #64748B;
}

/* Market Regime Colors */
.regime-risk-on {
    color: #10B981;
}

.regime-risk-off {
    color: #EF4444;
}

.regime-mixed {
    color: #F59E0B;
}

.dark .regime-risk-on {
    color: #34D399;
}

.dark .regime-risk-off {
    color: #F87171;
}

.dark .regime-mixed {
    color: #FBBF24;
}

/* Session badges */
.session-badge {
    padding: 0.25rem 0.5rem;
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 0.375rem;
    text-transform: uppercase;
}

.session-badge-open {
    background-color: rgba(16, 185, 129, 0.15);
    color: #10B981;
}

.session-badge-caution {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.session-badge-closed {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}

/* ============================================================================
   Tier Badges
   ============================================================================ */

.tier-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 0.5rem;
}

.tier-free {
    background-color: #E2E8F0;
    color: #64748B;
}

.dark .tier-free {
    background-color: #2A4155;
    color: #94A3B8;
}

.tier-pro {
    background-color: rgba(20, 184, 166, 0.15);
    color: #14B8A6;
}

.tier-max {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.tier-vip {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.tier-admin {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}

/* Tier display (read-only, not clickable) */
.tier-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1rem 1.5rem;
    background-color: #F8FAFC;
    border: 2px solid #E2E8F0;
    border-radius: 0.875rem;
    opacity: 0.5;
}

.dark .tier-display {
    background-color: #152535;
    border-color: #2A4155;
}

.tier-display.active {
    border-color: #14B8A6;
    background-color: rgba(20, 184, 166, 0.05);
    opacity: 1;
}

/* Theme selection buttons */
.theme-select-btn {
    display: flex;
    align-items: center;
    padding: 0.75rem 1.25rem;
    background-color: #F8FAFC;
    border: 2px solid #E2E8F0;
    border-radius: 0.75rem;
    color: #64748B;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.theme-select-btn:hover {
    border-color: #CBD5E1;
    color: #0F172A;
}

.dark .theme-select-btn {
    background-color: #152535;
    border-color: #2A4155;
    color: #94A3B8;
}

.dark .theme-select-btn:hover {
    border-color: #3A5165;
    color: #F1F5F9;
}

.theme-select-btn.active,
.theme-select-btn.active:hover,
.dark .theme-select-btn.active,
.dark .theme-select-btn.active:hover {
    border-color: #14B8A6;
    color: #14B8A6;
}

/* ============================================================================
   Settings Page Styles
   ============================================================================ */

.settings-section {
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #E2E8F0;
}

.settings-section:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.dark .settings-section {
    border-bottom-color: #2A4155;
}

.settings-section-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: #475569;
    margin-bottom: 1rem;
}

.dark .settings-section-header {
    color: #CBD5E1;
}

.settings-section-header svg {
    color: #64748B;
}

.dark .settings-section-header svg {
    color: #94A3B8;
}

.settings-group {
    background-color: #F8FAFC;
    border-radius: 0.75rem;
    padding: 1rem;
}

.dark .settings-group {
    background-color: #152535;
}

.settings-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0;
}

.settings-row:first-child {
    padding-top: 0;
}

.settings-row:last-child {
    padding-bottom: 0;
}

.settings-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: #334155;
}

.dark .settings-label {
    color: #E2E8F0;
}

.settings-helper {
    display: block;
    font-size: 0.75rem;
    color: #64748B;
    margin-top: 0.125rem;
}

.dark .settings-helper {
    color: #94A3B8;
}

.settings-value {
    font-size: 0.875rem;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
    color: #475569;
}

.dark .settings-value {
    color: #CBD5E1;
}

.settings-input {
    background-color: #FFFFFF;
    border: 1px solid #CBD5E1;
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    width: 12rem;
    color: #0F172A;
    transition: all 0.2s ease;
}

.settings-input:focus {
    outline: none;
    border-color: #14B8A6;
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.1);
}

.settings-input::placeholder {
    color: #94A3B8;
}

.dark .settings-input {
    background-color: #1A2D3D;
    border-color: #2A4155;
    color: #F1F5F9;
}

.dark .settings-input:focus {
    border-color: #14B8A6;
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.15);
}

.dark .settings-input::placeholder {
    color: #64748B;
}

.settings-select {
    background-color: #FFFFFF;
    border: 1px solid #CBD5E1;
    border-radius: 0.5rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    min-width: 10rem;
    color: #0F172A;
    transition: all 0.2s ease;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748B'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.5rem center;
    background-size: 1.25rem;
    padding-right: 2.5rem;
}

.settings-select:focus {
    outline: none;
    border-color: #14B8A6;
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.1);
}

.dark .settings-select {
    background-color: #1A2D3D;
    border-color: #2A4155;
    color: #F1F5F9;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
}

.dark .settings-select:focus {
    border-color: #14B8A6;
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.15);
}

.settings-button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background-color: #14B8A6;
    color: #FFFFFF;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 0.5rem;
    border: none;
    cursor: pointer;
    transition: background-color 0.2s ease;
    text-decoration: none;
}

.settings-button:hover {
    background-color: #0D9488;
}

.settings-link {
    font-size: 0.875rem;
    color: #14B8A6;
    text-decoration: none;
    transition: color 0.2s ease;
}

.settings-link:hover {
    color: #0D9488;
}

.settings-footer-note {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    color: #64748B;
    margin-top: 0.75rem;
}

.settings-footer-note::before {
    content: "🔒";
    font-size: 0.625rem;
}

.dark .settings-footer-note {
    color: #94A3B8;
}

/* Plan Badges */
.tier-badge-pro {
    display: inline-flex;
    padding: 0.25rem 0.75rem;
    background-color: rgba(20, 184, 166, 0.15);
    color: #14B8A6;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 9999px;
}

.tier-badge-max {
    display: inline-flex;
    padding: 0.25rem 0.75rem;
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 9999px;
}

.tier-badge-free {
    display: inline-flex;
    padding: 0.25rem 0.75rem;
    background-color: rgba(100, 116, 139, 0.15);
    color: #64748B;
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 9999px;
}

.dark .tier-badge-free {
    color: #94A3B8;
}

/* ============================================================================
   Admin Performance Metrics
   ============================================================================ */

.perf-range-btn {
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 0.375rem;
    background-color: transparent;
    border: 1px solid #CBD5E1;
    color: #64748B;
    cursor: pointer;
    transition: all 0.15s ease;
}

.perf-range-btn:hover {
    border-color: #14B8A6;
    color: #14B8A6;
}

.perf-range-btn.active {
    background-color: #14B8A6;
    border-color: #14B8A6;
    color: #FFFFFF;
}

.dark .perf-range-btn {
    border-color: #2A4155;
    color: #94A3B8;
}

.dark .perf-range-btn:hover {
    border-color: #14B8A6;
    color: #14B8A6;
}

.dark .perf-range-btn.active {
    background-color: #14B8A6;
    border-color: #14B8A6;
    color: #FFFFFF;
}

.perf-stat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.75rem;
    background-color: #FFFFFF;
    border-radius: 0.5rem;
    border: 1px solid #E2E8F0;
}

.dark .perf-stat-card {
    background-color: #1A2D3D;
    border-color: #2A4155;
}

.perf-stat-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748B;
}

.dark .perf-stat-label {
    color: #94A3B8;
}

.perf-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    color: #0F172A;
}

.dark .perf-stat-value {
    color: #F1F5F9;
}

/* ============================================================================
   FAQ Modal
   ============================================================================ */

.faq-chevron {
    transition: transform 0.2s ease;
}

.faq-chevron.rotate-180 {
    transform: rotate(180deg);
}

.faq-answer {
    animation: faqSlideDown 0.2s ease;
}

@keyframes faqSlideDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ============================================================================
   Signal Cards (Watchlist)
   ============================================================================ */

.signal-card {
    position: relative;
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 1rem;
    padding: 0.875rem 1rem;
    transition: all 0.2s ease;
    cursor: pointer;
}

/* ============================================================================
   Final Signal Card Layout - 3 Rows
   ============================================================================ */

.signal-card-final {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* ROW 1 & ROW 2: Synchronized column widths */
.signal-row-1,
.signal-row-2 {
    display: flex;
    align-items: center;
}

/* Col 1: Symbol/Prices - flex grow */
.signal-row-1 .signal-col-1,
.signal-row-2 .signal-col-1 {
    flex: 1;
    display: flex;
    gap: 0.25rem;
}

.signal-row-1 .signal-col-1 {
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
}

.signal-row-2 .signal-col-1 {
    flex-direction: column;
}

/* Col 2: R/MFE/MAE - fixed width, centered */
.signal-row-1 .signal-col-2,
.signal-row-2 .signal-col-2 {
    width: 6rem;
    min-width: 6rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 0.5rem;
    border-left: 1px solid #E2E8F0;
    border-right: 1px solid #E2E8F0;
}

.dark .signal-row-1 .signal-col-2,
.dark .signal-row-2 .signal-col-2 {
    border-left-color: #2A4155;
    border-right-color: #2A4155;
}

.signal-row-2 .signal-col-2 {
    gap: 0.125rem;
}

/* Col 3: HOT+Star / Started+Last - fixed width */
.signal-row-1 .signal-col-3,
.signal-row-2 .signal-col-3 {
    width: 9rem;
    min-width: 9rem;
    padding-left: 0.75rem;
}

.signal-row-1 .signal-col-3 {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
}

.signal-row-2 .signal-col-3 {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* Timing rows: Label links, Wert rechts */
.signal-timing-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    width: 100%;
    gap: 0.5rem;
}

.signal-timing-row .signal-label {
    text-align: left;
}

.signal-timing-row .signal-value {
    white-space: nowrap;
}

.signal-r {
    font-size: 1rem;
    font-weight: 700;
}

.signal-data-row {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    height: 1.25rem;
}

.signal-label {
    font-size: 0.75rem;
    color: #64748B;
    min-width: 3rem;
}

.signal-value {
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 0.875rem;
    font-weight: 500;
    color: #334155;
}

.dark .signal-value {
    color: #CBD5E1;
}

.signal-mfe {
    font-size: 0.75rem;
    color: #64748B;
}

.signal-mae {
    font-size: 0.75rem;
    color: #64748B;
    opacity: 0.8;
}

/* ROW 3: Status + Confirmations | Confidence + TTL */
.signal-row-3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 0.5rem;
    border-top: 1px solid #E2E8F0;
}

.dark .signal-row-3 {
    border-top-color: #2A4155;
}

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

.signal-footer-right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.signal-confidence {
    font-size: 0.875rem;
    font-weight: 700;
    color: #1E293B;
}

.dark .signal-confidence {
    color: #F8FAFC;
}

.signal-ttl {
    font-size: 0.75rem;
    color: #64748B;
}


/*
 * Signal Footer Badge Base (CI Standard)
 * All badges in signal-footer-left MUST use this base for consistent sizing.
 * Sizing: font-size 0.625rem, padding 0.25rem 0.5rem, border-radius 0.25rem
 * Spacing: controlled by parent .signal-footer-left gap (0.5rem), no margin-left
 * Apply as: class="signal-footer-badge signal-direction-conflict" etc.
 */
.signal-footer-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-radius: 0.25rem;
}

/* Risk Factor Indicator */
.signal-risk-indicator {
    display: inline-flex;
    align-items: center;
    color: #F59E0B;
    margin-left: 0.5rem;
}

.dark .signal-risk-indicator {
    color: #FBBF24;
}

/* Direction Conflict Indicator - signal cards (uses .signal-footer-badge base) */
.signal-direction-conflict {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
    cursor: help;
}

.dark .signal-direction-conflict {
    background-color: rgba(251, 191, 36, 0.15);
    color: #FBBF24;
}

/* Cluster Badge - correlation warning (uses .signal-footer-badge base) */
.signal-cluster-badge {
    background-color: rgba(139, 92, 246, 0.15);
    color: #8B5CF6;
    cursor: help;
}

.dark .signal-cluster-badge {
    background-color: rgba(167, 139, 250, 0.2);
    color: #A78BFA;
}

.signal-cluster-badge svg {
    width: 0.75rem;
    height: 0.75rem;
}

/* News Warning Badge on signal tiles */
.signal-news-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.125rem 0.375rem;
    margin-left: 0.5rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.025em;
    text-transform: uppercase;
    border-radius: 0.25rem;
    cursor: help;
}
.signal-news-badge svg { width: 0.75rem; height: 0.75rem; }

.signal-news-critical {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}
.dark .signal-news-critical {
    background-color: rgba(248, 113, 113, 0.2);
    color: #F87171;
}
.signal-news-critical-ahead {
    background-color: rgba(251, 146, 60, 0.15);
    color: #FB923C;
}
.dark .signal-news-critical-ahead {
    background-color: rgba(251, 146, 60, 0.2);
    color: #FDBA74;
}
.signal-news-high {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}
.dark .signal-news-high {
    background-color: rgba(251, 191, 36, 0.2);
    color: #FBBF24;
}

/* Symbol card inline indicator icons */
.symbol-news-icon,
.symbol-risk-icon {
    display: inline-flex;
    align-items: center;
    cursor: help;
    border-radius: 0.25rem;
    padding: 0.0625rem;
}
.symbol-news-icon.signal-news-critical { color: #EF4444; background-color: transparent; }
.dark .symbol-news-icon.signal-news-critical { color: #F87171; background-color: transparent; }
.symbol-news-icon.signal-news-critical-ahead { color: #FB923C; background-color: transparent; }
.dark .symbol-news-icon.signal-news-critical-ahead { color: #FDBA74; background-color: transparent; }
.symbol-news-icon.signal-news-high { color: #F59E0B; background-color: transparent; }
.dark .symbol-news-icon.signal-news-high { color: #FBBF24; background-color: transparent; }

/* Risk warning indicator (triangle) */
.symbol-risk-icon { color: #F59E0B; }
.dark .symbol-risk-icon { color: #FBBF24; }

/* News impact badge for CRITICAL */
.news-impact-critical {
    background-color: rgba(220, 38, 38, 0.25);
    color: #DC2626;
    font-weight: 800;
    border: 1px solid rgba(220, 38, 38, 0.4);
    animation: critical-pulse 2s ease-in-out infinite;
}
.dark .news-impact-critical {
    background-color: rgba(239, 68, 68, 0.3);
    color: #FCA5A5;
    border: 1px solid rgba(248, 113, 113, 0.5);
    text-shadow: 0 0 6px rgba(248, 113, 113, 0.4);
}
@keyframes critical-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0); }
    50% { box-shadow: 0 0 8px 2px rgba(239, 68, 68, 0.3); }
}

/* News warning cards in detail view */
.news-warning-card {
    padding: 0.5rem;
    background-color: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 0.375rem;
}
.dark .news-warning-card {
    background-color: #152535;
    border-color: #2A4155;
}

/* Symbol styling */
.signal-symbol {
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: #1E293B;
}

.dark .signal-symbol {
    color: #FFFFFF;
}

/* Direction badge */
.signal-direction {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.875rem;
    font-weight: 600;
}

/* Price rows */
.signal-price-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.signal-price-label {
    font-size: 0.75rem;
    color: #64748B;
    min-width: 3.5rem;
}

.signal-price-value {
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 0.875rem;
    font-weight: 500;
    color: #334155;
}

.dark .signal-price-value {
    color: #CBD5E1;
}

/* Metrics row (legacy, kept for compatibility) */
.signal-metrics {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.875rem;
}

.signal-metric {
    color: #64748B;
}

/* Status row */
.signal-status-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid #E2E8F0;
}

.dark .signal-status-row {
    border-top-color: #2A4155;
}

/* Legacy styles kept for compatibility */

.signal-card:hover {
    border-color: #CBD5E1;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.1);
}

.dark .signal-card {
    background-color: #1E3345;
    border-color: #2A4155;
}

.dark .signal-card:hover {
    border-color: #3A5165;
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.3);
}

.signal-card.hot {
    border-color: rgba(239, 68, 68, 0.3);
}

.signal-card.hot:hover {
    border-color: rgba(239, 68, 68, 0.5);
    box-shadow: 0 8px 24px -8px rgba(239, 68, 68, 0.15);
}

/* Favorite star button */
.favorite-btn {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    color: #64748B;
    transition: all 0.2s ease;
    z-index: 5;
}

.favorite-btn:hover {
    color: #F59E0B;
    transform: scale(1.1);
}

.favorite-btn.active {
    color: #F59E0B;
}

.favorite-btn.active svg {
    fill: #F59E0B;
}

/* Inline favorite button (for square cards) */
.favorite-btn-inline {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    color: #64748B;
    transition: all 0.2s ease;
    padding: 0.25rem;
    border-radius: 0.375rem;
}

.favorite-btn-inline:hover {
    color: #F59E0B;
    background: rgba(245, 158, 11, 0.1);
}

.favorite-btn-inline.active {
    color: #F59E0B;
}

.favorite-btn-inline.active svg {
    fill: #F59E0B;
}

/* Symbol card favorite button (smaller) */
.symbol-favorite-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem;
    border-radius: 0.25rem;
    color: #64748B;
    transition: all 0.15s ease;
    cursor: pointer;
    background: transparent;
    border: none;
}

.symbol-favorite-btn:hover {
    color: #F59E0B;
    background: rgba(245, 158, 11, 0.1);
}

.symbol-favorite-btn.active {
    color: #F59E0B;
}

.symbol-favorite-btn.active svg {
    fill: #F59E0B;
}

/* Invalidated signal (IX Power reversed) */
.signal-card.invalidated {
    opacity: 0.6;
    border-color: #EF4444;
    border-style: solid;
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.08) 0%, var(--color-surface-card) 100%);
}

.signal-card.invalidated:hover {
    opacity: 0.75;
    border-color: #EF4444;
}

.invalidation-banner {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    margin-bottom: 0.75rem;
    background-color: rgba(239, 68, 68, 0.15);
    border-radius: 0.375rem;
    color: #F87171;
    font-weight: 500;
}

.invalidation-banner svg {
    color: #EF4444;
}

/* Signal Status Tags */
.signal-status {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 600;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.signal-status-early {
    background-color: rgba(100, 116, 139, 0.2);
    color: #94A3B8;
}

.signal-status-building {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.signal-status-mature {
    background-color: rgba(16, 185, 129, 0.15);
    color: #10B981;
}

/* R-Value Display */
.r-value {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    padding: 0.25rem 0.5rem;
    border-radius: 0.375rem;
    font-size: 0.875rem;
}

.r-value-positive {
    background-color: rgba(16, 185, 129, 0.15);
    color: #10B981;
}

.r-value-negative {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}

.r-value-neutral {
    background-color: rgba(100, 116, 139, 0.15);
    color: #94A3B8;
}

/* D1 BID Badge (v3.0 - empirically validated momentum indicator) */
.d1-bid-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 700;
    background-color: rgba(34, 197, 94, 0.15);
    color: #22C55E;
    border-radius: 0.25rem;
    letter-spacing: 0.05em;
    font-family: 'Verdana', sans-serif;
}

/* Trading Conditions Badge (signal cards) - matches signal-status / d1-bid-badge sizing */
.signal-conditions-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 600;
    border-radius: 0.25rem;
    letter-spacing: 0.05em;
}

/* Hot Badge */
.hot-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 700;
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ============================================================================
   Symbol Cards (Grid)
   ============================================================================ */

.symbol-card {
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 0.75rem;
    padding: 0.875rem;
    transition: all 0.2s ease;
    cursor: pointer;
}

.symbol-card:hover {
    border-color: #CBD5E1;
    background-color: #F8FAFC;
}

.dark .symbol-card {
    background-color: #1E3345;
    border-color: #2A4155;
}

.dark .symbol-card:hover {
    border-color: #3A5165;
    background-color: #243850;
}

/* Locked symbol card (Guest/Free) */
.symbol-card-locked {
    opacity: 0.7;
}

.locked-badge {
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.15rem 0.4rem;
    border-radius: 0.25rem;
    background-color: rgba(100, 116, 139, 0.15);
    color: #94A3B8;
}

.dark .locked-badge {
    background-color: rgba(148, 163, 184, 0.1);
    color: #64748B;
}

/* ============================================================================
   Asset Class Symbol Name Colors
   ============================================================================ */

/* Forex: pure white (dark) / dark slate (light) — baseline */
.dark .symbol-card .font-bold {
    color: #FFFFFF;
}
.symbol-card .font-bold {
    color: #0F172A;
}

/* Gold: vivid warm gold */
.dark .signal-card.asset-gold .signal-symbol,
.dark .symbol-card.asset-gold .font-bold {
    color: #F5C842;
}
.signal-card.asset-gold .signal-symbol,
.symbol-card.asset-gold .font-bold {
    color: #A07D12;
}

/* Indices: bright electric blue */
.dark .signal-card.asset-indices .signal-symbol,
.dark .symbol-card.asset-indices .font-bold {
    color: #4A9EFF;
}
.signal-card.asset-indices .signal-symbol,
.symbol-card.asset-indices .font-bold {
    color: #1D6FBF;
}

/* Crypto: vivid violet */
.dark .signal-card.asset-crypto .signal-symbol,
.dark .symbol-card.asset-crypto .font-bold {
    color: #A78BFA;
}
.signal-card.asset-crypto .signal-symbol,
.symbol-card.asset-crypto .font-bold {
    color: #6D28D9;
}

/* Detail panel title colors (matching signal card colors) */
.dark .detail-title-gold { color: #F5C842; }
.detail-title-gold { color: #A07D12; }
.dark .detail-title-indices { color: #4A9EFF; }
.detail-title-indices { color: #1D6FBF; }
.dark .detail-title-crypto { color: #A78BFA; }
.detail-title-crypto { color: #6D28D9; }

.symbol-card:active {
    transform: scale(0.98);
}

/* Direction indicators */
.direction-bullish {
    color: #10B981;
}

.direction-bearish {
    color: #EF4444;
}

.direction-neutral {
    color: #64748B;
}

.direction-shifting {
    color: #F59E0B;
}

/* Alignment badges */
.alignment-badge {
    font-size: 0.6875rem;
    font-weight: 500;
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
}

.alignment-aligned {
    background-color: rgba(16, 185, 129, 0.1);
    color: #10B981;
}

.alignment-mixed {
    background-color: rgba(100, 116, 139, 0.1);
    color: #94A3B8;
}

/* Status dot */
.symbol-status-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 9999px;
}

.symbol-status-extreme {
    background-color: #EF4444;
    box-shadow: 0 0 8px rgba(239, 68, 68, 0.5);
}

.symbol-status-active {
    background-color: #10B981;
}

.symbol-status-normal {
    background-color: #64748B;
}

/* ============================================================================
   News Event Cards
   ============================================================================ */

.news-card {
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 0.75rem;
    padding: 1rem;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.dark .news-card {
    background-color: #1E3345;
    border-color: #2A4155;
}

.news-impact-badge {
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 700;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    flex-shrink: 0;
    min-width: 3.5rem;
    text-align: center;
}

.news-impact-high {
    background-color: rgba(239, 68, 68, 0.15);
    color: #EF4444;
}

.news-impact-medium {
    background-color: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.news-impact-low {
    background-color: rgba(100, 116, 139, 0.15);
    color: #64748B;
}

.news-currency {
    font-weight: 700;
    color: #0F172A;
}

.dark .news-currency {
    color: #FFFFFF;
}

.news-time {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.75rem;
    color: #64748B;
}

.news-countdown {
    font-size: 0.75rem;
    color: #F59E0B;
    font-weight: 500;
}

/* ============================================================================
   AI Insights
   ============================================================================ */

.ai-opportunity-card {
    background-color: #F8FAFC;
    border: 1px solid #E2E8F0;
    border-radius: 0.75rem;
    padding: 1rem;
    transition: all 0.2s ease;
}

.ai-opportunity-card:hover {
    border-color: #CBD5E1;
}

.dark .ai-opportunity-card {
    background-color: #152535;
    border-color: #2A4155;
}

.dark .ai-opportunity-card:hover {
    border-color: #3A5165;
}

.ai-warning-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 500;
    background-color: rgba(245, 158, 11, 0.1);
    color: #F59E0B;
    border-radius: 0.5rem;
}

.ai-avoid-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    background-color: rgba(239, 68, 68, 0.1);
    color: #EF4444;
    border-radius: 0.375rem;
}

/* Pause Status Banner (Execution Window / News Events) */
.pause-status-banner {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    background: linear-gradient(to right, rgba(245, 158, 11, 0.1), rgba(245, 158, 11, 0.05));
    border: 1px solid rgba(245, 158, 11, 0.3);
    border-radius: 0.75rem;
    margin-bottom: 1rem;
}

.pause-status-banner .pause-icon {
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.pause-status-banner.pause-status-news {
    background: linear-gradient(to right, rgba(239, 68, 68, 0.1), rgba(239, 68, 68, 0.05));
    border-color: rgba(239, 68, 68, 0.3);
}

.dark .pause-status-banner {
    background: linear-gradient(to right, rgba(245, 158, 11, 0.15), rgba(245, 158, 11, 0.05));
    border-color: rgba(245, 158, 11, 0.4);
}

.dark .pause-status-banner.pause-status-news {
    background: linear-gradient(to right, rgba(239, 68, 68, 0.15), rgba(239, 68, 68, 0.05));
    border-color: rgba(239, 68, 68, 0.4);
}

/* ============================================================================
   Detail Panel / Modal
   ============================================================================ */

#detail-sidebar.open {
    transform: translateX(0);
}

#detail-modal.open #detail-modal-panel {
    transform: translateY(0);
}

/* ============================================================================
   Animations
   ============================================================================ */

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideRight {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}

.animate-fade-in {
    animation: fadeIn 0.3s ease-out;
}

.animate-slide-up {
    animation: slideUp 0.3s ease-out;
}

/* Power bar animation */
.power-bar-fill {
    animation: powerBarGrow 0.6s ease-out forwards;
    transform-origin: left center;
}

@keyframes powerBarGrow {
    from {
        transform: scaleX(0);
        opacity: 0.5;
    }
    to {
        transform: scaleX(1);
        opacity: 1;
    }
}

/* Skeleton loading */
.skeleton {
    background: linear-gradient(
        90deg,
        #E2E8F0 0%,
        #F1F5F9 50%,
        #E2E8F0 100%
    );
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 0.375rem;
}

.dark .skeleton {
    background: linear-gradient(
        90deg,
        #1E3345 0%,
        #2A4155 50%,
        #1E3345 100%
    );
    background-size: 200% 100%;
}

@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Toast notifications */
.toast {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 0.75rem;
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.15);
    animation: slideUp 0.3s ease-out;
    max-width: 360px;
}

.dark .toast {
    background-color: #1E3345;
    border-color: #2A4155;
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.4);
}

.toast-success {
    border-color: rgba(16, 185, 129, 0.3);
}

.toast-error {
    border-color: rgba(239, 68, 68, 0.3);
}

.toast-warning {
    border-color: rgba(245, 158, 11, 0.3);
}

/* ============================================================================
   Tooltips (JS-based, position: fixed to avoid overflow clipping)
   ============================================================================ */

[data-tooltip],
[data-tooltip-below] {
    cursor: help;
}

/* Disable old CSS pseudo-element tooltips (clipped by overflow containers) */
[data-tooltip]::after,
[data-tooltip]::before,
[data-tooltip-below]::after,
[data-tooltip-below]::before {
    display: none !important;
}

/* Global tooltip element (appended to body, position: fixed) */
.global-tooltip {
    position: fixed;
    z-index: 99999;
    padding: 0.5rem 0.75rem;
    background-color: #0F172A;
    border: 1px solid #E2E8F0;
    border-radius: 0.5rem;
    color: #F8FAFC;
    font-size: 0.75rem;
    font-weight: 400;
    max-width: 250px;
    text-align: center;
    line-height: 1.4;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
}

.global-tooltip.visible {
    opacity: 1;
}

.dark .global-tooltip {
    background-color: #152535;
    border-color: #2A4155;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* ============================================================================
   Glossary Term Highlighting
   ============================================================================ */

.glossary-term {
    border-bottom: 1px dotted rgba(100, 116, 139, 0.5);
    cursor: help;
    transition: border-color 0.2s ease;
}

.glossary-term:hover {
    border-bottom-color: #3ABAB4;
}

.dark .glossary-term {
    border-bottom-color: rgba(148, 163, 184, 0.4);
}

.dark .glossary-term:hover {
    border-bottom-color: #3ABAB4;
}

/* ============================================================================
   Last Confirm Time Colors
   ============================================================================ */

.last-confirm-fresh {
    color: #10B981 !important;
}

.last-confirm-aging {
    color: #F59E0B !important;
}

.last-confirm-stale {
    color: #EF4444 !important;
}

/* AI Analysis Age Colors (<1h green, 1-4h orange, >4h red) */
.analysis-fresh {
    color: #10B981 !important;
}

.analysis-aging {
    color: #F59E0B !important;
}

.analysis-stale {
    color: #EF4444 !important;
}

/* ============================================================================
   Filter Chip Variants
   ============================================================================ */

.filter-chip-warning {
    border-color: rgba(239, 68, 68, 0.3);
    color: #F87171;
}

.filter-chip-warning:hover {
    background-color: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.5);
}

.filter-chip-warning.active {
    background-color: #EF4444;
    border-color: #EF4444;
    color: white;
}

/* ============================================================================
   Browser Notification Toast
   ============================================================================ */

.notification-toast {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    background-color: #FFFFFF;
    border: 1px solid #E2E8F0;
    border-radius: 0.75rem;
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.15);
    animation: slideUp 0.3s ease-out;
    max-width: 360px;
}

.dark .notification-toast {
    background-color: #1E3345;
    border-color: #2A4155;
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.4);
}

.notification-toast-new-signal {
    border-color: rgba(16, 185, 129, 0.3);
    border-left: 3px solid #10B981;
}

.notification-toast-invalidated {
    border-color: rgba(239, 68, 68, 0.3);
    border-left: 3px solid #EF4444;
}

/* ============================================================================
   Expired Badge
   ============================================================================ */

.expired-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 700;
    background-color: rgba(100, 116, 139, 0.2);
    color: #94A3B8;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ============================================================================
   Utility Classes
   ============================================================================ */

.text-muted {
    color: #64748B;
}

.font-mono {
    font-family: 'JetBrains Mono', monospace;
}

/* Hide scrollbar but keep functionality */
.hide-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.hide-scrollbar::-webkit-scrollbar {
    display: none;
}

/* ============================================================================
   Pro Content Blur / Feature Gates
   ============================================================================ */

/* Blurred content for non-tier users (FOMO: visible but unreadable) */
.pro-content-blur {
    filter: blur(6px);
    user-select: none;
    pointer-events: none;
    opacity: 0.85;
}

/* Full section blur for FOMO effect - content looks real but unreadable */
/* Used when pricing modal opens over Pro sections */
.pro-blur-overlay {
    filter: blur(5px);
    user-select: none;
    pointer-events: none;
    opacity: 0.9;
    transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Overlay for locked content - semi-transparent so blurred content shows through */
.pro-content-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.45);
    border-radius: inherit;
    z-index: 10;
}

.dark .pro-content-overlay {
    background: rgba(21, 37, 53, 0.45);
}

/* Beta badge for experimental features */
.beta-badge {
    display: inline-flex;
    padding: 0.125rem 0.5rem;
    font-size: 0.625rem;
    font-weight: 700;
    font-family: Arial, sans-serif;
    background-color: rgba(139, 92, 246, 0.15);
    color: #A78BFA;
    border-radius: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Ensure parent has relative positioning for overlay */
.signal-card.relative,
.relative {
    position: relative;
}

/* Placeholder card for pro-only sections */
.pro-placeholder {
    min-height: 200px;
}

/* Upgrade button glow effect */
.upgrade-btn {
    box-shadow: 0 0 0 0 rgba(20, 184, 166, 0.4);
    transition: all 0.3s ease;
}

.upgrade-btn:hover {
    box-shadow: 0 0 20px 0 rgba(20, 184, 166, 0.3);
    transform: translateY(-1px);
}

/* =========================================
   Pricing Modal Styles
   ========================================= */

#pricing-modal {
    animation: fadeIn 0.2s ease;
}

/* Equal height pricing cards */
#pricing-modal .grid {
    align-items: stretch;
}

#pricing-modal .grid > div {
    display: flex;
    flex-direction: column;
}

#pricing-modal .grid > div > ul {
    flex-grow: 1;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* Crown icon gradient animation */
.crown-icon-animated {
    animation: crownShimmer 2s infinite;
}

@keyframes crownShimmer {
    0%, 100% {
        filter: brightness(1);
    }
    50% {
        filter: brightness(1.2);
    }
}

/* Pricing card hover effect */
#pricing-card-pro,
#pricing-card-max {
    transition: transform 0.2s ease;
    will-change: transform;
    isolation: isolate;
}
#pricing-card-pro:hover,
#pricing-card-max:hover {
    transform: translateY(-2px);
}

/* Popular badge pulse */
#pricing-modal .bg-primary-500 {
    animation: badgePulse 2s infinite;
}

@keyframes badgePulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(20, 184, 166, 0.4);
    }
    50% {
        box-shadow: 0 0 10px 2px rgba(20, 184, 166, 0.2);
    }
}

/* Savings banner shine effect */
#pricing-savings-banner {
    position: relative;
    overflow: hidden;
}

#pricing-savings-banner::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    animation: shine 4s ease-in-out 2;
}

@keyframes shine {
    0% {
        left: -100%;
    }
    50%, 100% {
        left: 100%;
    }
}

/* Auth modal backdrop animation */
#auth-modal-backdrop {
    transition: opacity 0.3s ease;
}

/* Form input focus states */
#auth-modal input:focus {
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.2);
}

/* Loading spinner for auth buttons */
.auth-loading {
    position: relative;
    color: transparent !important;
}

.auth-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: white;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ============================================================================
   Detail Panel - Section Styles (v3.1)
   ============================================================================ */

/* Risk/Warning Color Classes */
.text-impact-high {
    color: #EF4444;
}

.text-impact-medium {
    color: #F59E0B;
}

.text-bullish {
    color: #10B981;
}

.text-bearish {
    color: #EF4444;
}

/* R Value Colors */
.r-value-positive {
    color: #10B981;
}

.r-value-negative {
    color: #EF4444;
}

/* Direction Colors */
.direction-bullish {
    color: #10B981;
}

.direction-bearish {
    color: #EF4444;
}

.direction-neutral {
    color: #94A3B8;
}

/* Signal Status Badges */
.signal-status {
    display: inline-flex;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.signal-status-early {
    background: rgba(245, 158, 11, 0.15);
    color: #F59E0B;
}

.signal-status-building {
    background: rgba(59, 130, 246, 0.15);
    color: #3B82F6;
}

.signal-status-mature {
    background: rgba(16, 185, 129, 0.15);
    color: #10B981;
}

/* Alignment Badges */
.alignment-badge {
    font-weight: 500;
    text-transform: capitalize;
}

.alignment-aligned {
    color: #10B981;
}

.alignment-mixed {
    color: #F59E0B;
}

.alignment-divergent {
    color: #EF4444;
}

.alignment-unknown {
    color: #94A3B8;
}

/* Counter-pressure Warning Box */
.counter-pressure-warning {
    margin-top: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.counter-pressure-warning span {
    font-size: 0.75rem;
    color: #F59E0B;
}

/* Risk Factor Tags */
.risk-factor-tag {
    display: inline-flex;
    padding: 0.125rem 0.5rem;
    font-size: 0.6875rem;
    font-weight: 500;
    background-color: #F1F5F9;
    color: #64748B;
    border-radius: 0.25rem;
}

.dark .risk-factor-tag {
    background-color: #2A4155;
    color: #94A3B8;
}

/* Detail Section Dividers */
.detail-section {
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.1);
}

.detail-section:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

/* Detail Section Headers */
.detail-section-header {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748B;
    margin-bottom: 0.75rem;
}

.dark .detail-section-header {
    color: #94A3B8;
}

/* Detail Subsection Headers */
.detail-subsection-header {
    font-size: 0.625rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #94A3B8;
    margin-top: 0.75rem;
    margin-bottom: 0.5rem;
}

/* Detail Row */
.detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.25rem 0;
}

.detail-label {
    font-size: 0.75rem;
    color: #64748B;
}

.dark .detail-label {
    color: #94A3B8;
}

.detail-value {
    font-size: 0.875rem;
    color: #334155;
    font-weight: 500;
}

.dark .detail-value {
    color: #E2E8F0;
}

/* ============================================================================
   Pricing Modal View Transitions
   ============================================================================ */

#pricing-cards-view,
#pricing-auth-view {
    transition: opacity 0.2s ease-in-out;
}

#pricing-cards-view.hidden,
#pricing-auth-view.hidden {
    display: none;
}

/* Smooth form field focus states for inline auth */
#pricing-auth-view input:focus {
    box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.1);
}

/* Loading spinner animation enhancement */
@keyframes pricing-spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

#pricing-auth-submit-btn .animate-spin,
#subscribe-monthly-btn .animate-spin,
#subscribe-yearly-btn .animate-spin {
    animation: pricing-spin 1s linear infinite;
}

/* Auth error message styling */
#pricing-auth-error {
    animation: shake 0.3s ease-in-out;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

/* ============================================================================
   Forecast State Colors (BETA)
   ============================================================================ */

.forecast-trending   { color: #10B981; }
.forecast-compressed { color: #3B82F6; }
.forecast-choppy     { color: #EF4444; }
.forecast-neutral    { color: #64748B; }

/* D1 badge: always in Row3 footer (consistent desktop + mobile) */
.d1-badge-desktop {
    display: none !important;
}
.d1-badge-mobile {
    display: inline-flex;
}

/* ============================================================================
   Mobile Optimizations (< 640px / sm breakpoint)
   Targets: Watchlist header, Symbols filter badges, Signal cards
   Desktop layout remains completely unchanged.
   ============================================================================ */

@media (max-width: 639px) {

    /* --- Sticky Headers: tighter padding --- */
    #section-watchlist > .sticky,
    #section-symbols .sticky {
        padding-top: 0.625rem;
        padding-bottom: 0.5rem;
    }

    /* --- Title rows: compact icon + hide subtitle --- */
    #section-watchlist .w-10.h-10,
    #section-forecast .w-10.h-10 {
        width: 1.75rem;
        height: 1.75rem;
        min-width: 1.75rem;
    }
    #section-watchlist .w-10.h-10 svg,
    #section-forecast .w-10.h-10 svg {
        width: 0.875rem;
        height: 0.875rem;
    }
    #section-watchlist h2,
    #section-forecast h2 {
        font-size: 1rem;
    }
    /* Hide subtitle on Watchlist + Weather mobile */
    #section-watchlist h2 + p,
    #section-forecast h2 + p {
        display: none;
    }

    /* --- Asset filter tabs: smaller on mobile --- */
    .asset-filter-tab {
        padding: 0.25rem 0.5rem;
        font-size: 0.6875rem;
    }

    /* --- Filter chips: compact on mobile --- */
    .filter-chip {
        padding: 0.25rem 0.625rem;
        font-size: 0.6875rem;
    }
    /* Hide icons inside filter chips on mobile (Symbols page) */
    .filter-chip svg {
        display: none;
    }
    .filter-chip svg + span {
        margin-left: 0;
    }

    /* --- Sort dropdown: compact --- */
    #section-watchlist .flex.items-center.gap-2.ml-auto {
        margin-left: 0;
    }
    /* Hide "Sort:" label on mobile */
    #section-watchlist .flex.items-center.gap-2.ml-auto > span[data-i18n="filter.sort"] {
        display: none;
    }
    #watchlist-sort {
        font-size: 0.6875rem;
        padding: 0.25rem 0.5rem;
    }

    /* --- Filter + Sort row: tighter gap --- */
    #section-watchlist .flex.flex-wrap.items-center.gap-4 {
        gap: 0.5rem;
    }

    /* --- Signal cards: tighter spacing --- */
    #watchlist-grid {
        gap: 0.5rem;
    }
    #watchlist-grid > .card {
        padding: 0.625rem;
    }

    /* Signal card columns: narrower on mobile */
    .signal-row-1 .signal-col-2,
    .signal-row-2 .signal-col-2 {
        width: 4.5rem;
        min-width: 4.5rem;
        padding: 0 0.25rem;
    }
    .signal-row-1 .signal-col-3,
    .signal-row-2 .signal-col-3 {
        width: 6.5rem;
        min-width: 6.5rem;
        padding-left: 0.5rem;
    }

    /* D1 badge: already in footer globally, no mobile override needed */

    /* --- Weather pills: compact on mobile --- */
    .weather-pill {
        gap: 0.25rem;
        padding: 0.375rem 0.625rem;
        border-radius: 0.5rem;
    }
    .weather-pill > span:first-child {
        width: 0.875rem;
        height: 0.875rem;
    }
    .weather-pill > span:nth-child(2) {
        font-size: 0.875rem;
    }
    .weather-pill > span:last-child {
        font-size: 0.6875rem;
    }

    /* --- Search bar: allow full compression --- */
    #symbol-search {
        min-width: 0 !important;
    }
    .min-w-\[200px\] {
        min-width: 0 !important;
    }

}

