/* ==============================================
   Trade Dashboards - Bootstrap 5.3 Dark Overrides
   GitHub Dark palette on top of Bootstrap dark mode
   ============================================== */

/* Custom CSS Variables - GitHub Dark palette */
:root,
[data-bs-theme="dark"] {
    --bg-primary: #0d1117;
    --bg-secondary: #161b22;
    --bg-tertiary: #21262d;
    --text-primary: #e6edf3;
    --text-secondary: #8b949e;
    --accent-green: #238636;
    --accent-green-light: #2ea043;
    --accent-blue: #58a6ff;
    --accent-red: #f85149;
    --accent-yellow: #d29922;
    --accent-purple: #a371f7;
    --accent-cyan: #56d4dd;
    --border-color: #30363d;
    --hover-bg: #1f2428;

    /* Override Bootstrap dark defaults to our darker palette */
    --bs-body-bg: #0d1117;
    --bs-body-color: #e6edf3;
    --bs-secondary-bg: #161b22;
    --bs-tertiary-bg: #21262d;
    --bs-border-color: #30363d;
    --bs-card-bg: #161b22;
    --bs-modal-bg: #161b22;
    --bs-emphasis-color: #e6edf3;
}

/* ---- Navbar ---- */
.td-navbar {
    background-color: var(--bg-secondary) !important;
}
.td-navbar .navbar-brand {
    color: var(--accent-blue);
}
.td-navbar .dropdown-menu {
    background-color: var(--bg-tertiary);
    border-color: var(--border-color);
}
.td-navbar .dropdown-item:hover,
.td-navbar .dropdown-item:focus {
    background-color: var(--hover-bg);
}
.td-navbar .dropdown-item.active {
    background-color: var(--accent-purple);
    color: #fff;
}

/* ---- Cards ---- */
.td-card {
    background-color: var(--bg-secondary);
    border-color: var(--border-color);
}

/* ---- Page title gradient ---- */
.page-title {
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 600;
}

/* ---- Controls bar ---- */
.controls-bar {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 24px;
}

/* ---- Stat display ---- */
.stat-value {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--accent-blue);
}
.stat-label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ---- PNL colors ---- */
.pnl-positive { color: var(--accent-green-light) !important; font-weight: 600; }
.pnl-negative { color: var(--accent-red) !important; font-weight: 600; }

/* ---- Sentiment colors ---- */
.sentiment-bullish { color: var(--accent-green-light); font-weight: 600; }
.sentiment-bearish { color: var(--accent-red); font-weight: 600; }
.sentiment-neutral { color: var(--text-secondary); font-weight: 600; }

/* ---- Source badges ---- */
.source-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 500;
    margin-right: 6px;
    margin-bottom: 4px;
}
.source-badge.reddit {
    background-color: rgba(255, 69, 0, 0.2);
    color: #ff6b35;
}
.source-badge.twitter {
    background-color: rgba(29, 161, 242, 0.2);
    color: #1da1f2;
}
.source-badge.stocktwits {
    background-color: rgba(0, 200, 200, 0.2);
    color: #00c8c8;
}
.source-badge.news {
    background-color: rgba(163, 113, 247, 0.2);
    color: var(--accent-purple);
}

/* ---- Post items ---- */
.post-item {
    padding: 16px;
    border-radius: 8px;
    margin-bottom: 12px;
    background-color: var(--bg-tertiary);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.post-item:hover {
    transform: translateX(4px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.post-title {
    display: block;
    color: var(--text-primary);
    text-decoration: none;
    font-size: 0.95rem;
    line-height: 1.5;
}
.post-title:hover { color: var(--accent-blue); }
.post-title.bullish {
    border-left: 3px solid var(--accent-green-light);
    padding-left: 10px;
}
.post-title.bearish {
    border-left: 3px solid var(--accent-red);
    padding-left: 10px;
}

/* ---- Post sentiment badges ---- */
.post-sentiment {
    display: inline-block;
    margin-top: 8px;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
}
.post-sentiment.bullish {
    background-color: rgba(46, 160, 67, 0.2);
    color: var(--accent-green-light);
}
.post-sentiment.bearish {
    background-color: rgba(248, 81, 73, 0.2);
    color: var(--accent-red);
}

/* ---- AI Sentiment badges ---- */
.ai-sentiment {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 10px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    background-color: rgba(163, 113, 247, 0.15);
    color: var(--accent-purple);
    border: 1px solid rgba(163, 113, 247, 0.3);
}
.ai-sentiment.bullish {
    background-color: rgba(46, 160, 67, 0.15);
    color: var(--accent-green-light);
    border-color: rgba(46, 160, 67, 0.3);
}
.ai-sentiment.bearish {
    background-color: rgba(248, 81, 73, 0.15);
    color: var(--accent-red);
    border-color: rgba(248, 81, 73, 0.3);
}

/* ---- Ticker tags ---- */
.ticker-tag {
    display: inline-block;
    padding: 4px 10px;
    background-color: rgba(88, 166, 255, 0.15);
    color: var(--accent-blue);
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.2s ease;
}
.ticker-tag:hover {
    background-color: rgba(88, 166, 255, 0.3);
}

/* ---- Event tags ---- */
.event-tag {
    display: inline-block;
    padding: 2px 8px;
    background-color: rgba(210, 153, 34, 0.2);
    color: var(--accent-yellow);
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 500;
    margin-right: 6px;
    text-transform: uppercase;
}

/* ---- Mention bar ---- */
.mention-bar {
    height: 8px;
    background: linear-gradient(90deg, var(--accent-green), var(--accent-blue));
    border-radius: 4px;
    min-width: 4px;
    transition: width 0.3s ease;
}

/* ---- Company name subtext ---- */
.company-name {
    display: block;
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: normal;
    margin-top: 2px;
}

/* ---- Subreddit badge ---- */
.subreddit-badge {
    display: inline-block;
    padding: 4px 10px;
    background-color: rgba(255, 69, 0, 0.15);
    color: #ff6b35;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 500;
}

/* ---- Loading overlay ---- */
.loading-overlay {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: rgba(13, 17, 23, 0.9);
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 20px;
    z-index: 1100;
}
.loading-overlay.active { display: flex; }

/* ---- Error banner ---- */
.error-banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    background-color: rgba(248, 81, 73, 0.1);
    border: 1px solid var(--accent-red);
    border-radius: 8px;
    margin-bottom: 20px;
    color: var(--accent-red);
}

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg-tertiary); }
::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-secondary); }

/* ---- DataTables dark overrides ---- */
div.dataTables_wrapper .dataTables_length select,
div.dataTables_wrapper .dataTables_filter input {
    background-color: var(--bg-tertiary);
    border-color: var(--border-color);
    color: var(--text-primary);
}
div.dataTables_wrapper .dataTables_info {
    color: var(--text-secondary);
}
table.dataTable {
    border-color: var(--border-color) !important;
}

/* ---- Hero card (PNL display, predictions) ---- */
.hero-card {
    background: linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary));
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 30px;
    text-align: center;
    margin-bottom: 24px;
}
.hero-value {
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.2;
}

/* ---- Chart wrapper ---- */
.chart-wrapper {
    position: relative;
    width: 100%;
}

/* ---- htmx indicators ---- */
.htmx-indicator {
    display: none;
}
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator {
    display: inline-block;
}

/* ---- Spin animation (refresh buttons) ---- */
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
.spin { animation: spin 1s linear infinite; }

/* ==============================================
   Mobile Responsive Overrides
   ============================================== */

/* ---- Tablet (< 768px) ---- */
@media (max-width: 767.98px) {
    /* Scale down hero card values */
    .hero-value {
        font-size: 2rem;
    }
    .hero-card {
        padding: 20px 16px;
    }

    /* Stat cards */
    .stat-value {
        font-size: 1.4rem;
    }

    /* Controls bar: stack and tighten */
    .controls-bar {
        padding: 14px;
        gap: 12px;
    }

    /* Page titles */
    .page-title {
        font-size: 1.4rem;
    }

    /* Tables: smaller font */
    .table {
        font-size: 0.8rem;
    }
    .table th, .table td {
        padding: 0.4rem 0.35rem;
        white-space: nowrap;
    }
}

/* ---- Phone (< 576px) ---- */
@media (max-width: 575.98px) {
    /* Shrink container padding */
    .container-fluid {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    /* Hero card */
    .hero-value {
        font-size: 1.6rem;
    }
    .hero-card {
        padding: 16px 12px;
        margin-bottom: 16px;
    }
    .hero-card .stat-value {
        font-size: 1.1rem;
    }

    /* Stat displays */
    .stat-value {
        font-size: 1.2rem;
    }
    .stat-label {
        font-size: 0.75rem;
    }

    /* Page title + subtitle */
    .page-title {
        font-size: 1.2rem;
    }

    /* Controls bar: full-width stack */
    .controls-bar {
        flex-direction: column;
        align-items: stretch !important;
        padding: 12px;
    }
    .controls-bar > .d-flex {
        justify-content: space-around;
    }

    /* Filter bars: full-width stack on phone */
    .filter-bar {
        gap: 0.5rem !important;
    }
    .filter-bar > div {
        flex: 1 1 calc(50% - 0.25rem);
        min-width: 0;
    }
    .filter-bar .form-select,
    .filter-bar .form-control {
        width: 100% !important;
    }

    /* Form controls: let them fill available space on mobile */
    .form-control,
    .form-select {
        min-width: 0 !important;
        max-width: 100%;
    }

    /* Card headers: stack on mobile */
    .card-header .d-flex.gap-2 {
        flex-wrap: wrap;
    }
    .card-header .d-flex.gap-2 .form-control,
    .card-header .d-flex.gap-2 .form-select {
        width: 100% !important;
        max-width: none;
    }

    /* Cards: tighter spacing */
    .card-body {
        padding: 0.75rem;
    }
    .td-card {
        margin-bottom: 16px;
    }

    /* Tables: even more compact */
    .table {
        font-size: 0.72rem;
    }
    .table th, .table td {
        padding: 0.3rem 0.25rem;
    }

    /* Post items */
    .post-item {
        padding: 12px;
        margin-bottom: 8px;
    }
    .post-title {
        font-size: 0.85rem;
    }

    /* Badges and tags */
    .source-badge {
        font-size: 0.65rem;
        padding: 3px 7px;
    }
    .ticker-tag {
        font-size: 0.7rem;
        padding: 3px 7px;
    }
    .event-tag {
        font-size: 0.6rem;
    }

    /* Navbar brand: shorter */
    .td-navbar .navbar-brand {
        font-size: 0.95rem;
    }

    /* Chart wrappers: reduce height on phone */
    .chart-wrapper {
        max-height: 250px;
    }
}
