/*
Theme Name: SID Financial Theme
Theme URI: https://smartinvestorsdaily.com
Author: SmartInvestorsDaily
Author URI: https://smartinvestorsdaily.com
Description: MarketBeat-style financial content platform theme for SmartInvestorsDaily.com. Features programmatic ticker pages, market data calendars, research tools, and calculators.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 8.0
License: Proprietary
License URI: https://smartinvestorsdaily.com/license
Text Domain: sid-financial
Tags: finance, stocks, investing, programmatic-seo

This theme is designed to display financial data from external APIs
and MongoDB databases via GCP Cloud Functions.
*/

/* ==========================================================================
   CSS Custom Properties (Design Tokens)
   ========================================================================== */

:root {
    /* Primary Brand Colors - Deep Indigo/Purple */
    --sid-primary: #5b21b6;
    --sid-primary-dark: #4c1d95;
    --sid-primary-light: #7c3aed;

    /* Accent - Vibrant Orange/Coral for CTAs */
    --sid-accent: #f97316;
    --sid-accent-dark: #ea580c;
    --sid-accent-light: #fb923c;

    /* Secondary */
    --sid-secondary: #06b6d4;
    --sid-secondary-dark: #0891b2;

    /* Semantic */
    --sid-success: #10b981;
    --sid-danger: #ef4444;
    --sid-warning: #f59e0b;

    /* Dark Theme (header, footer, CTA sections) */
    --sid-dark: #1e1b4b;
    --sid-dark-lighter: #312e81;

    /* Text */
    --sid-text-primary: #1e1b4b;
    --sid-text-secondary: #4b5563;
    --sid-text-muted: #9ca3af;
    --sid-text-on-dark: #f8fafc;
    --sid-text-on-dark-muted: #c7d2fe;

    /* Backgrounds */
    --sid-bg-primary: #ffffff;
    --sid-bg-secondary: #f8fafc;
    --sid-bg-tertiary: #f1f5f9;

    /* Borders */
    --sid-border-color: #e2e8f0;
    --sid-border-radius: 6px;
    --sid-border-radius-lg: 10px;

    /* Shadows */
    --sid-shadow-sm: 0 1px 2px rgba(30, 27, 75, 0.05);
    --sid-shadow-md: 0 4px 6px -1px rgba(30, 27, 75, 0.1);
    --sid-shadow-lg: 0 10px 15px -3px rgba(30, 27, 75, 0.1);

    /* Spacing */
    --sid-spacing-xs: 4px;
    --sid-spacing-sm: 8px;
    --sid-spacing-md: 16px;
    --sid-spacing-lg: 24px;
    --sid-spacing-xl: 32px;
    --sid-spacing-2xl: 48px;

    /* Typography */
    --sid-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --sid-font-mono: 'JetBrains Mono', 'SF Mono', Monaco, monospace;

    /* Stock colors */
    --sid-stock-up: #10b981;
    --sid-stock-down: #ef4444;
    --sid-stock-neutral: #6b7280;

    /* Alias for up/down (used in templates) */
    --sid-up: #16a34a;
    --sid-down: #dc2626;
    --sid-up-rgb: 22, 163, 74;
    --sid-down-rgb: 220, 38, 38;

    /* Rating colors */
    --sid-rating-strong-buy: #059669;
    --sid-rating-buy: #10b981;
    --sid-rating-hold: #f59e0b;
    --sid-rating-sell: #f87171;
    --sid-rating-strong-sell: #ef4444;
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

* {
    box-sizing: border-box;
}

html, body {
    overflow-x: hidden;
    max-width: 100vw;
}

/* Prevent any element from causing horizontal overflow */
html {
    overflow-x: hidden;
}

body {
    overflow-x: hidden;
    width: 100%;
    position: relative;
}

/* Main content wrapper - prevent overflow */
.sid-main,
main,
#content,
.site-content {
    overflow-x: hidden;
    max-width: 100vw;
}

/* Container overflow handled below in Layout section */

/* All sections - prevent overflow */
section {
    overflow-x: hidden;
    max-width: 100vw;
}

/* Header must span full width regardless of content overflow */
.sid-header {
    width: 100%;
    max-width: 100vw;
}

.sid-ticker-tape {
    width: 100%;
    max-width: 100vw;
}

body {
    font-family: var(--sid-font-family);
    font-size: 14px;
    line-height: 1.5;
    color: var(--sid-text-primary);
    background-color: var(--sid-bg-secondary);
    margin: 0;
    padding: 0;
}

/* WordPress Admin Bar Fix - adjust sticky headers when logged in */
body.admin-bar .elementor-location-header,
body.admin-bar .elementor-sticky--active,
body.admin-bar [data-elementor-type="header"] {
    top: 32px !important;
}

@media screen and (max-width: 782px) {
    body.admin-bar .elementor-location-header,
    body.admin-bar .elementor-sticky--active,
    body.admin-bar [data-elementor-type="header"] {
        top: 46px !important;
    }
}

a {
    color: var(--sid-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* ==========================================================================
   Container
   ========================================================================== */

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

@media (max-width: 768px) {
    .container {
        padding: 0 16px;
    }
}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.sid-breadcrumbs {
    margin-bottom: var(--sid-spacing-lg);
    font-size: 13px;
}

.sid-breadcrumbs ol,
nav.sid-breadcrumbs ol {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    list-style: none !important;
    list-style-type: none !important;
    margin: 0;
    padding: 0;
}

.sid-breadcrumbs ol li,
nav.sid-breadcrumbs ol li {
    display: flex;
    align-items: center;
    list-style: none !important;
    list-style-type: none !important;
}

.sid-breadcrumbs ol li::marker {
    content: none;
    display: none;
}

.sid-breadcrumbs li:not(:last-child)::after {
    content: "/";
    margin-left: 8px;
    color: var(--sid-text-muted);
}

.sid-breadcrumbs a {
    color: var(--sid-text-secondary);
    text-decoration: none;
    transition: color 0.15s;
}

.sid-breadcrumbs a:hover {
    color: var(--sid-primary);
    text-decoration: none;
}

.sid-breadcrumbs li:last-child span {
    color: var(--sid-text-primary);
    font-weight: 500;
}

/* ==========================================================================
   Page Headers
   ========================================================================== */

.sid-page-header {
    margin-bottom: var(--sid-spacing-xl);
}

.sid-page-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--sid-text-primary);
    margin: 0 0 8px 0;
}

.sid-page-subtitle {
    font-size: 16px;
    color: var(--sid-text-secondary);
    margin: 0;
    line-height: 1.6;
}

/* ==========================================================================
   Main Content Area
   ========================================================================== */

.sid-main {
    padding: var(--sid-spacing-xl) 0;
    min-height: 60vh;
}

/* ==========================================================================
   Layout
   ========================================================================== */

.sid-container {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 0 var(--sid-spacing-md);
    box-sizing: border-box;
    overflow-x: hidden;
}

.sid-grid {
    display: grid;
    gap: var(--sid-spacing-lg);
}

.sid-grid--2-col {
    grid-template-columns: 1fr 300px;
}

.sid-grid--3-col {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 768px) {
    .sid-grid--2-col,
    .sid-grid--3-col {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Components - Cards
   ========================================================================== */

.sid-card {
    background: var(--sid-bg-primary);
    border: 1px solid var(--sid-border-color);
    border-radius: var(--sid-border-radius);
    padding: var(--sid-spacing-lg);
    box-shadow: var(--sid-shadow-sm);
}

.sid-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--sid-spacing-md);
    padding-bottom: var(--sid-spacing-md);
    border-bottom: 1px solid var(--sid-border-color);
}

.sid-card__title {
    font-size: 18px;
    font-weight: 600;
    margin: 0;
}

/* ==========================================================================
   Components - Stock Quote
   ========================================================================== */

.sid-quote {
    display: flex;
    align-items: baseline;
    gap: var(--sid-spacing-md);
}

.sid-quote__price {
    font-size: 32px;
    font-weight: 700;
    font-family: var(--sid-font-mono);
}

.sid-quote__change {
    font-size: 16px;
    font-weight: 500;
}

.sid-quote__change--up {
    color: var(--sid-stock-up);
}

.sid-quote__change--down {
    color: var(--sid-stock-down);
}

.sid-quote__change--neutral {
    color: var(--sid-stock-neutral);
}

/* ==========================================================================
   Components - Tables
   ========================================================================== */

.sid-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.sid-table th,
.sid-table td {
    padding: var(--sid-spacing-sm) var(--sid-spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--sid-border-color);
}

.sid-table th {
    font-weight: 600;
    color: var(--sid-text-secondary);
    background: var(--sid-bg-secondary);
}

.sid-table tbody tr:hover {
    background: var(--sid-bg-secondary);
}

.sid-table--striped tbody tr:nth-child(even) {
    background: var(--sid-bg-secondary);
}

/* Numeric columns */
.sid-table .num {
    text-align: right;
    font-family: var(--sid-font-mono);
}

/* ==========================================================================
   Components - Ratings
   ========================================================================== */

.sid-rating {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
}

.sid-rating--buy,
.sid-rating--strong-buy {
    background: rgba(13, 125, 13, 0.1);
    color: var(--sid-rating-buy);
}

.sid-rating--hold {
    background: rgba(251, 188, 4, 0.1);
    color: #996600;
}

.sid-rating--sell,
.sid-rating--strong-sell {
    background: rgba(217, 48, 37, 0.1);
    color: var(--sid-rating-sell);
}

/* ==========================================================================
   Components - Buttons
   ========================================================================== */

.sid-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--sid-spacing-sm) var(--sid-spacing-md);
    font-size: 14px;
    font-weight: 500;
    border-radius: var(--sid-border-radius);
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sid-btn--primary {
    background: var(--sid-primary);
    color: white;
}

.sid-btn--primary:hover {
    background: var(--sid-primary-dark);
}

.sid-btn--secondary {
    background: var(--sid-bg-secondary);
    color: var(--sid-text-primary);
    border: 1px solid var(--sid-border-color);
}

.sid-btn--secondary:hover {
    background: var(--sid-bg-tertiary);
}

.sid-btn--success {
    background: var(--sid-secondary);
    color: white;
}

/* ==========================================================================
   Components - Forms
   ========================================================================== */

.sid-input {
    width: 100%;
    padding: var(--sid-spacing-sm) var(--sid-spacing-md);
    font-size: 14px;
    border: 1px solid var(--sid-border-color);
    border-radius: var(--sid-border-radius);
    background: var(--sid-bg-primary);
}

.sid-input:focus {
    outline: none;
    border-color: var(--sid-primary);
    box-shadow: 0 0 0 2px rgba(26, 115, 232, 0.2);
}

.sid-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235f6368' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
}

/* ==========================================================================
   Components - Email Capture
   Note: Main styles are in partials/email-capture-form.php
   ========================================================================== */

/* ==========================================================================
   Components - Tabs (for ticker sub-pages)
   ========================================================================== */

.sid-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--sid-border-color);
    margin-bottom: var(--sid-spacing-lg);
    overflow-x: auto;
}

.sid-tabs__tab {
    padding: var(--sid-spacing-md) var(--sid-spacing-lg);
    color: var(--sid-text-secondary);
    font-weight: 500;
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.2s ease;
}

.sid-tabs__tab:hover {
    color: var(--sid-text-primary);
    text-decoration: none;
}

.sid-tabs__tab--active {
    color: var(--sid-primary);
    border-bottom-color: var(--sid-primary);
}

/* ==========================================================================
   Components - Ticker Header
   ========================================================================== */

.sid-ticker-header {
    display: flex;
    gap: var(--sid-spacing-lg);
    align-items: flex-start;
    margin-bottom: var(--sid-spacing-lg);
}

.sid-ticker-header__logo {
    width: 64px;
    height: 64px;
    border-radius: var(--sid-border-radius);
    object-fit: contain;
    background: var(--sid-bg-secondary);
    padding: 8px;
}

.sid-ticker-header__info {
    flex: 1;
}

.sid-ticker-header__symbol {
    font-size: 14px;
    color: var(--sid-text-secondary);
    margin: 0 0 var(--sid-spacing-xs);
}

.sid-ticker-header__name {
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 var(--sid-spacing-sm);
}

.sid-ticker-header__meta {
    font-size: 13px;
    color: var(--sid-text-secondary);
}

/* ==========================================================================
   Calculator Styles
   ========================================================================== */

.sid-calculator {
    max-width: 800px;
}

.sid-calculator__form {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sid-spacing-md);
}

@media (max-width: 600px) {
    .sid-calculator__form {
        grid-template-columns: 1fr;
    }
}

.sid-calculator__group {
    display: flex;
    flex-direction: column;
    gap: var(--sid-spacing-xs);
}

.sid-calculator__label {
    font-size: 13px;
    font-weight: 500;
    color: var(--sid-text-secondary);
}

.sid-calculator__results {
    margin-top: var(--sid-spacing-xl);
    padding-top: var(--sid-spacing-xl);
    border-top: 1px solid var(--sid-border-color);
}

.sid-calculator__summary {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sid-spacing-md);
    margin-bottom: var(--sid-spacing-xl);
}

.sid-calculator__stat {
    text-align: center;
    padding: var(--sid-spacing-lg);
    background: var(--sid-bg-secondary);
    border-radius: var(--sid-border-radius);
}

.sid-calculator__stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--sid-primary);
    font-family: var(--sid-font-mono);
}

.sid-calculator__stat-label {
    font-size: 12px;
    color: var(--sid-text-secondary);
    margin-top: var(--sid-spacing-xs);
}

/* ==========================================================================
   Screener Styles
   ========================================================================== */

.sid-screener {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--sid-spacing-lg);
}

@media (max-width: 900px) {
    .sid-screener {
        grid-template-columns: 1fr;
    }
}

.sid-screener__filters {
    background: var(--sid-bg-primary);
    border: 1px solid var(--sid-border-color);
    border-radius: var(--sid-border-radius);
    padding: var(--sid-spacing-lg);
    height: fit-content;
}

.sid-screener__fieldset {
    border: none;
    padding: 0;
    margin: 0 0 var(--sid-spacing-lg);
}

.sid-screener__legend {
    font-weight: 600;
    font-size: 14px;
    margin-bottom: var(--sid-spacing-sm);
    color: var(--sid-text-primary);
}

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

.text-up { color: var(--sid-stock-up); }
.text-down { color: var(--sid-stock-down); }
.text-muted { color: var(--sid-text-muted); }
.text-center { text-align: center; }
.text-right { text-align: right; }
.font-mono { font-family: var(--sid-font-mono); }
.font-bold { font-weight: 700; }

.mt-0 { margin-top: 0; }
.mt-sm { margin-top: var(--sid-spacing-sm); }
.mt-md { margin-top: var(--sid-spacing-md); }
.mt-lg { margin-top: var(--sid-spacing-lg); }
.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--sid-spacing-sm); }
.mb-md { margin-bottom: var(--sid-spacing-md); }
.mb-lg { margin-bottom: var(--sid-spacing-lg); }

.hidden { display: none; }
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* ==========================================================================
   Layout - Main Content
   ========================================================================== */

.sid-main {
    padding-bottom: var(--sid-spacing-2xl);
    min-height: calc(100vh - 400px);
}

/* ==========================================================================
   Sidebar Widgets
   ========================================================================== */

.sid-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--sid-spacing-lg);
}

.sid-sidebar .sid-card {
    padding: var(--sid-spacing-lg);
}

.sid-sidebar .sid-card__title {
    font-size: 16px;
    font-weight: 600;
    color: var(--sid-text-primary);
    margin: 0;
    padding-bottom: var(--sid-spacing-sm);
    border-bottom: 1px solid var(--sid-border-color);
    margin-bottom: var(--sid-spacing-md);
}

/* Definition Lists (Key Terms, Glossaries) */
.sid-definitions {
    margin: 0;
    padding: 0;
}

.sid-definitions dt {
    font-weight: 600;
    font-size: 14px;
    color: var(--sid-text-primary);
    margin-top: var(--sid-spacing-md);
}

.sid-definitions dt:first-child {
    margin-top: 0;
}

.sid-definitions dd {
    margin: var(--sid-spacing-xs) 0 0 0;
    font-size: 13px;
    color: var(--sid-text-secondary);
    line-height: 1.5;
}

/* Quick Links List (Related Links) */
.sid-quick-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sid-quick-links li {
    padding: var(--sid-spacing-sm) 0;
    border-bottom: 1px solid var(--sid-border-color);
}

.sid-quick-links li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.sid-quick-links li:first-child {
    padding-top: 0;
}

.sid-quick-links a {
    display: flex;
    align-items: center;
    color: var(--sid-primary);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: color 0.15s;
}

.sid-quick-links a:hover {
    color: var(--sid-primary-dark);
    text-decoration: none;
}

.sid-quick-links a::before {
    content: "•";
    margin-right: var(--sid-spacing-sm);
    color: var(--sid-primary);
}

/* Stats Display in Sidebar */
.sid-stat {
    display: flex;
    flex-direction: column;
    gap: var(--sid-spacing-xs);
}

.sid-stat__label {
    font-size: 12px;
    color: var(--sid-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sid-stat__value {
    font-size: 16px;
    font-weight: 600;
    color: var(--sid-text-primary);
    font-family: var(--sid-font-mono);
}

/* Stats Grid */
.sid-stats-grid {
    display: grid;
    gap: var(--sid-spacing-md);
}

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

.sid-stats-grid--3col {
    grid-template-columns: repeat(3, 1fr);
}

/* Page Title */
.sid-page-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--sid-text-primary);
    margin: 0 0 var(--sid-spacing-lg);
}

/* Text utilities */
.text-sm {
    font-size: 13px;
}

/* Highlight List (for upcoming events, featured items) */
.sid-highlight-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sid-highlight-list li {
    border-bottom: 1px solid var(--sid-border-color);
}

.sid-highlight-list li:last-child {
    border-bottom: none;
}

.sid-highlight-list a {
    display: flex;
    justify-content: space-between;
    padding: var(--sid-spacing-sm) 0;
    color: var(--sid-text-primary);
    text-decoration: none;
    transition: color 0.15s;
}

.sid-highlight-list a:hover {
    text-decoration: none;
}

.sid-highlight-list a:hover strong {
    color: var(--sid-primary);
}

.sid-highlight-list span {
    color: var(--sid-text-muted);
    font-size: 13px;
}

/* Badge Component */
.sid-badge {
    display: inline-block;
    background: var(--sid-bg-secondary);
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
    color: var(--sid-text-secondary);
}

/* Page Header */
.sid-page-header {
    margin-bottom: var(--sid-spacing-xl);
}

.sid-page-subtitle {
    color: var(--sid-text-secondary);
    font-size: 16px;
    margin: var(--sid-spacing-sm) 0 0;
}
