/* Modern Market UI/UX - 2025 Design System */
/* Mobile-First, Glassmorphism, Bento Box Layouts, Interactive Filters */

:root {
    --market-primary: #6baaff;
    --market-secondary: #9076ff;
    --market-accent: #53e5ff;
    --market-success: #10b981;
    --market-danger: #ef476f;
    --market-warning: #f59e0b;
    
    --market-bg-glass: rgba(255, 255, 255, 0.78);
    --market-bg-glass-dark: rgba(11, 18, 37, 0.82);
    --market-shadow: 0 18px 36px rgba(20, 38, 79, 0.12);
    --market-shadow-lg: 0 28px 64px rgba(10, 20, 43, 0.18);
    --market-shadow-hover: 0 34px 72px rgba(49, 104, 233, 0.16);
}

[data-theme="dark"] {
    --market-bg-glass: rgba(11, 18, 37, 0.78);
    --market-bg-glass-dark: rgba(15, 23, 42, 0.9);
}

html {
    background:
        radial-gradient(circle at 12% 10%, rgba(107, 170, 255, 0.12), transparent 22%),
        radial-gradient(circle at 84% 16%, rgba(83, 229, 255, 0.08), transparent 24%),
        radial-gradient(circle at 74% 78%, rgba(144, 118, 255, 0.08), transparent 26%),
        linear-gradient(180deg, var(--bg-primary) 0%, color-mix(in srgb, var(--bg-primary) 74%, var(--bg-secondary) 26%) 100%);
    background-color: var(--bg-primary);
}

.market-page {
    background:
        radial-gradient(circle at 12% 10%, rgba(107, 170, 255, 0.12), transparent 22%),
        radial-gradient(circle at 84% 16%, rgba(83, 229, 255, 0.08), transparent 24%),
        radial-gradient(circle at 74% 78%, rgba(144, 118, 255, 0.08), transparent 26%),
        linear-gradient(180deg, var(--bg-primary) 0%, color-mix(in srgb, var(--bg-primary) 74%, var(--bg-secondary) 26%) 100%);
}

/* Market App Header - Mobile Optimized */
.market-app-header {
    position: static !important;
    top: auto !important;
    z-index: 50;
    background: var(--bg-secondary);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border-color);
    padding: 16px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-sm);
}

/* Inner wrapper: align with TRINITY logo and main content on large screens */
.market-app-header-inner {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.market-header-title {
    font-size: 24px;
    font-weight: 700;
    margin: 0;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 12px;
}

.market-header-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
    margin: 4px 0 0 0;
}

.market-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

.market-data-age {
    font-size: 12px;
    color: var(--text-secondary);
    padding: 6px 12px;
    background: var(--bg-tertiary);
    border-radius: 20px;
    white-space: nowrap;
}

.market-refresh-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--bg-tertiary);
    border: none;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--transition);
    flex-shrink: 0;
}

.market-refresh-btn:hover {
    background: var(--bg-glass);
    transform: scale(1.05) rotate(90deg);
}

.market-refresh-btn.refreshing {
    animation: spin 1s linear infinite;
}

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

/* Hero Section */
.market-hero {
    padding: 40px 20px;
    text-align: center;
    background: linear-gradient(135deg, rgba(96, 165, 250, 0.1) 0%, rgba(63, 55, 201, 0.1) 100%);
    border-radius: var(--radius-xl);
    margin: 24px 20px;
}

.market-hero-title {
    font-size: clamp(28px, 5vw, 42px);
    font-weight: 800;
    margin-bottom: 12px;
    color: var(--text-primary);
}

.market-hero-description {
    font-size: clamp(14px, 2vw, 18px);
    color: var(--text-secondary);
    max-width: 600px;
    margin: 0 auto 24px;
}

/* Modern Filter Bar - Collapsible on Mobile */
.market-filters-modern {
    background: var(--market-bg-glass);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-color);
    border-radius: var(--glass-panel-radius);
    padding: 20px;
    margin: 24px 20px;
    box-shadow: var(--market-shadow);
}

.filter-header-mobile {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    cursor: pointer;
}

.filter-header-mobile h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.filter-toggle-icon {
    transition: transform 0.3s ease;
}

.filter-toggle-icon.active {
    transform: rotate(180deg);
}

.filter-grid-modern {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    transition: all 0.3s ease;
}

.filter-group-modern {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.filter-label-modern {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.filter-select-modern,
.filter-input-modern {
    padding: 12px 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 14px;
    transition: var(--transition);
    font-family: inherit;
}

.filter-select-modern:focus,
.filter-input-modern:focus {
    outline: none;
    border-color: var(--market-primary);
    box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.1);
}

.filter-input-modern {
    width: 100%;
}

/* Active Filter Badges */
.active-filters-modern {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.filter-badge-modern {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--market-primary);
    color: white;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
}

.filter-badge-modern .remove-filter {
    cursor: pointer;
    opacity: 0.8;
    transition: opacity 0.2s;
}

.filter-badge-modern .remove-filter:hover {
    opacity: 1;
}

/* Market Grid - Bento Style */
.market-grid-modern {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
    padding: 20px;
    animation: fadeIn 0.4s ease-out;
}

@media (min-width: 768px) {
    .market-grid-modern {
        grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
        gap: 24px;
        padding: 24px;
    }
}

@media (min-width: 1200px) {
    .market-grid-modern {
        grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
    }
}

/* Stock Card - Modern Glassmorphism */
.stock-card-modern {
    background: var(--market-bg-glass);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 24px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    display: block;
    box-shadow: var(--market-shadow);
}

.stock-card-modern::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #60a5fa 0%, #3f37c9 50%, #4cc9f0 100%);
    opacity: 0;
    transition: var(--transition);
}

.stock-card-modern:hover {
    transform: translateY(-4px);
    box-shadow: var(--market-shadow-hover);
    border-color: var(--market-primary);
}

.stock-card-modern:hover::before {
    opacity: 1;
}

/* Stock Card Header */
.stock-card-header-modern {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-color);
}

.stock-symbol-modern {
    font-size: 28px;
    font-weight: 800;
    color: var(--text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.stock-price-modern {
    text-align: right;
}

.price-value-modern {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    display: block;
}

.price-change-modern {
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
}

.price-change-modern.positive {
    color: var(--market-success);
}

.price-change-modern.negative {
    color: var(--market-danger);
}

.price-change-modern.neutral {
    color: var(--text-secondary);
}

/* Signal Badge */
.signal-badge-modern {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 12px;
}

.signal-badge-modern.buy {
    background: rgba(16, 185, 129, 0.2);
    color: var(--market-success);
}

.signal-badge-modern.sell {
    background: rgba(239, 68, 68, 0.2);
    color: var(--market-danger);
}

.signal-badge-modern.hold {
    background: rgba(59, 130, 246, 0.2);
    color: #3b82f6;
}

.signal-badge-modern.neutral {
    background: rgba(107, 114, 128, 0.2);
    color: #6b7280;
}

/* Stock Metrics Grid */
.stock-metrics-modern {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-top: 20px;
}

.metric-item-modern {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.metric-label-modern {
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.metric-value-modern {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
}

.metric-value-modern.highlight {
    color: var(--primary);
}

/* Stage Badge */
.stage-badge-modern {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: var(--radius-md);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.stage-badge-modern.stage-1 {
    background: rgba(255, 193, 7, 0.2);
    color: #f59e0b;
    border: 1px solid rgba(255, 193, 7, 0.3);
}

.stage-badge-modern.stage-2 {
    background: rgba(16, 185, 129, 0.2);
    color: var(--market-success);
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.stage-badge-modern.stage-3 {
    background: rgba(255, 152, 0, 0.2);
    color: #f97316;
    border: 1px solid rgba(255, 152, 0, 0.3);
}

.stage-badge-modern.stage-4 {
    background: rgba(239, 68, 68, 0.2);
    color: var(--market-danger);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

/* Confidence Meter */
.confidence-meter-modern {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.confidence-label-modern {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.confidence-text-modern {
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 600;
}

.confidence-value-modern {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
}

.confidence-bar-modern {
    height: 8px;
    background: var(--bg-tertiary);
    border-radius: 4px;
    overflow: hidden;
    position: relative;
}

.confidence-fill-modern {
    height: 100%;
    background: linear-gradient(90deg, #ef4444 0%, #f59e0b 50%, #10b981 100%);
    border-radius: 4px;
    transition: width 0.5s ease;
}

/* Loading State */
.market-loading-modern {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 20px;
    gap: 24px;
}

.market-loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--border-color);
    border-top-color: var(--market-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.market-loading-text {
    font-size: 16px;
    color: var(--text-secondary);
    font-weight: 500;
}

/* Empty State */
.market-empty-modern {
    text-align: center;
    padding: 80px 20px;
}

.market-empty-icon {
    font-size: 64px;
    color: var(--text-light);
    margin-bottom: 24px;
}

.market-empty-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.market-empty-description {
    font-size: 16px;
    color: var(--text-secondary);
    max-width: 400px;
    margin: 0 auto;
}

/* Error State */
.market-error-modern {
    text-align: center;
    padding: 80px 20px;
}

.market-error-icon {
    font-size: 64px;
    color: var(--market-danger);
    margin-bottom: 24px;
}

.market-error-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.market-error-description {
    font-size: 16px;
    color: var(--text-secondary);
    margin-bottom: 24px;
}

/* Pagination Modern */
.pagination-modern {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    padding: 24px 20px;
    flex-wrap: wrap;
}

.pagination-btn-modern {
    min-width: 44px;
    height: 44px;
    padding: 0 16px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.pagination-btn-modern:hover:not(:disabled) {
    background: var(--bg-glass);
    border-color: var(--market-primary);
    transform: translateY(-2px);
}

.pagination-btn-modern.active {
    background: var(--market-primary);
    color: white;
    border-color: var(--market-primary);
}

.pagination-btn-modern:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pagination-info-modern {
    font-size: 14px;
    color: var(--text-secondary);
    padding: 0 16px;
}

/* Trending explainer: compact control in market hero, full content in modal */
.status-hero-modern .trending-toggle-modern {
    margin-top: 18px;
    width: auto;
    max-width: 100%;
    align-self: flex-start;
    background: linear-gradient(135deg, var(--market-primary), #667eea);
    border: none;
    padding: 8px 14px;
    color: white;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.01em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: var(--radius-md);
    box-shadow: 0 2px 8px rgba(96, 165, 250, 0.25);
    transition: var(--transition);
}

.status-hero-modern .trending-toggle-modern:hover {
    background: linear-gradient(135deg, #667eea, var(--market-primary));
    box-shadow: 0 4px 14px rgba(102, 126, 234, 0.35);
    transform: translateY(-1px);
}

.status-hero-modern .trending-toggle-modern i {
    font-size: 14px;
    opacity: 0.95;
}

.status-hero-modern .trending-toggle-modern:focus {
    outline: 2px solid var(--market-primary);
    outline-offset: 2px;
}

.status-hero-modern .trending-toggle-modern:focus:not(:focus-visible) {
    outline: none;
}

/* Mostly full-screen trending explainer modal */
.trending-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 10040;
    background: rgba(15, 23, 42, 0.58);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: max(12px, env(safe-area-inset-top, 0px))
        max(12px, env(safe-area-inset-right, 0px))
        max(12px, env(safe-area-inset-bottom, 0px))
        max(12px, env(safe-area-inset-left, 0px));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s ease, visibility 0.2s ease;
}

.trending-modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.trending-modal-panel {
    width: min(1200px, calc(100vw - 20px));
    height: min(calc(100vh - 24px), 960px);
    max-height: calc(100vh - 24px);
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.35);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: translateY(12px) scale(0.985);
    transition: transform 0.22s ease;
}

.trending-modal-overlay.is-open .trending-modal-panel {
    transform: translateY(0) scale(1);
}

.trending-modal-header {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px 16px;
    border-bottom: 1px solid var(--border-color);
    background: linear-gradient(
        180deg,
        rgba(var(--primary-rgb), 0.08),
        transparent
    );
}

.trending-modal-title {
    margin: 0;
    font-size: clamp(18px, 2.6vw, 22px);
    font-weight: 800;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    line-height: 1.25;
    padding-right: 8px;
}

.trending-modal-close {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    font-size: 18px;
    transition: var(--transition);
}

.trending-modal-close:hover {
    background: var(--bg-glass);
    border-color: var(--market-primary);
    color: var(--market-primary);
}

.trending-modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px 22px 24px;
    -webkit-overflow-scrolling: touch;
}

.trending-modal-footnote {
    margin-top: 24px;
    padding: 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: linear-gradient(
        135deg,
        rgba(96, 165, 250, 0.06),
        rgba(103, 126, 234, 0.06)
    );
    border: 1px solid rgba(96, 165, 250, 0.22);
    border-radius: var(--radius-md);
}

.trending-modal-footnote i {
    color: var(--market-primary);
    margin-top: 2px;
    font-size: 18px;
    flex-shrink: 0;
}

.trending-modal-footnote p {
    margin: 0;
    color: var(--text-primary);
    line-height: 1.55;
    font-size: 15px;
}

.trending-grid-modern {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

@media (min-width: 768px) {
    .trending-grid-modern {
        grid-template-columns: 1fr 1fr;
    }
}

.trending-scoring-modern,
.trending-factors-modern {
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    padding: 20px;
}

.trending-scoring-modern h4,
.trending-factors-modern h4 {
    color: var(--market-primary);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 18px;
}

.score-item-modern {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: var(--bg-secondary);
    border-radius: var(--radius-md);
    margin-bottom: 8px;
    border-left: 4px solid var(--market-primary);
}

.score-factor-modern {
    font-weight: 500;
    color: var(--text-primary);
}

.score-points-modern {
    font-weight: 700;
    color: var(--market-primary);
}

.factor-item-modern {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: var(--radius-md);
    margin-bottom: 12px;
}

.factor-icon-modern {
    color: var(--market-primary);
    font-size: 20px;
    margin-top: 2px;
}

.factor-content-modern strong {
    display: block;
    color: var(--text-primary);
    font-weight: 600;
    margin-bottom: 4px;
}

.factor-content-modern span {
    color: var(--text-secondary);
    font-size: 14px;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .filter-grid-modern {
        grid-template-columns: 1fr;
    }
    
    .market-grid-modern {
        grid-template-columns: 1fr;
        padding: 16px;
    }
    
    .stock-metrics-modern {
        grid-template-columns: 1fr;
    }
    
    .trending-grid-modern {
        grid-template-columns: 1fr;
    }
    
    .filter-header-mobile {
        display: flex;
    }
    
    .filter-grid-modern.collapsed {
        display: none;
    }
}

@media (min-width: 769px) {
    .filter-header-mobile {
        display: none;
    }
    
    .filter-grid-modern {
        display: grid !important;
    }
}

/* Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 1000px;
    }
}

/* View Details Link */
.view-details-link-modern {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--market-primary);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
    transition: var(--transition);
    pointer-events: none;
}

.stock-card-modern:hover .view-details-link-modern {
    gap: 12px;
    color: var(--market-secondary);
}

.view-details-link-modern i {
    transition: transform 0.2s;
}

.stock-card-modern:hover .view-details-link-modern i {
    transform: translateX(4px);
}

/* -------------------------------------------------------------------------- */
/* /market: match portfolio horizontal bounds (.portfolio-main-container) */
/* -------------------------------------------------------------------------- */
/* Screener hero: same treatment as /status (.status-* in status.css) */
.portfolio-main-container .status-hero-modern,
.market-hero-shell .status-hero-modern {
    margin: 0 0 24px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.market-hero-shell {
    position: relative;
    overflow: hidden;
    margin: 0 0 24px;
    padding: 24px 18px 4px;
}

.market-hero-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 14% 18%, rgba(107, 170, 255, 0.12), transparent 22%),
        radial-gradient(circle at 84% 14%, rgba(83, 229, 255, 0.08), transparent 20%),
        linear-gradient(180deg, rgba(8, 17, 31, 0.04) 0%, rgba(8, 17, 31, 0) 100%);
    pointer-events: none;
}

/* Centered shell + dismiss (aligns with .portfolio-main-container max-width) */
.market-hero-content {
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
}

.market-hero-grid {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.9fr);
    gap: 24px;
    align-items: stretch;
}

.market-hero-copy,
.market-hero-panel-card {
    border: none;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
    border-radius: var(--glass-panel-radius);
}

.market-hero-copy {
    padding: clamp(28px, 4vw, 40px);
}

.market-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.market-hero-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 14px;
    text-decoration: none;
    font-weight: 700;
    transition: var(--transition-fast);
}

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

.market-hero-btn-primary {
    background: var(--gradient-primary);
    color: #fff;
    box-shadow: 0 18px 34px rgba(49, 104, 233, 0.24);
}

.market-hero-btn-secondary {
    background: color-mix(in srgb, var(--bg-tertiary) 82%, transparent);
    border: 1px solid color-mix(in srgb, var(--border-color) 80%, transparent);
    color: var(--text-primary);
}

.market-hero-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.market-hero-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bg-tertiary) 78%, transparent);
    border: 1px solid color-mix(in srgb, var(--border-color) 72%, transparent);
    color: var(--text-primary);
    font-size: var(--iris-list-hero-pill-size, 17px);
    font-weight: 600;
}

.market-hero-pill i {
    color: var(--market-accent);
}

.market-hero-panel {
    min-width: 0;
}

.market-hero-panel-card {
    padding: 28px;
    height: 100%;
}

.market-hero-panel-label {
    margin: 0 0 18px 0;
    font-size: var(--iris-list-hero-panel-label-size, 16px);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.market-hero-panel-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.market-hero-panel-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.market-hero-panel-item > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--bg-tertiary) 84%, transparent);
    color: var(--market-primary);
    font-size: var(--iris-list-hero-panel-step-size, 15px);
    font-weight: 700;
}

.market-hero-panel-item h3 {
    margin: 0 0 6px 0;
    font-size: var(--iris-list-hero-panel-heading-size, 20px);
    font-weight: 700;
    color: var(--text-primary);
}

.market-hero-panel-item p {
    margin: 0;
    font-size: var(--iris-list-hero-panel-body-size, 18px);
    line-height: var(--iris-list-hero-panel-body-line-height, 1.6);
    color: var(--text-secondary);
}

@media (max-width: 639px) {
    .portfolio-main-container .status-hero-modern,
    .market-hero-shell .status-hero-modern {
        margin-bottom: 16px;
    }

    .market-hero-shell {
        padding: 16px 18px 0;
    }

    .market-hero-grid {
        grid-template-columns: minmax(0, 1fr);
        gap: 14px;
    }

    .market-hero-copy,
    .market-hero-panel-card,
    .portfolio-main-container .market-filters-modern {
        padding: 18px 16px;
    }

    .market-hero-actions {
        flex-direction: column;
    }

    .market-hero-btn {
        width: 100%;
    }

    .market-hero-pills {
        flex-direction: column;
    }

    .market-hero-pill {
        width: 100%;
        justify-content: center;
    }
}

.portfolio-main-container .market-filters-modern {
    margin: 20px 0 24px;
    border-radius: var(--glass-panel-radius);
    padding: clamp(18px, 3vw, 28px);
    background: color-mix(in srgb, var(--bg-secondary) 80%, transparent);
    border: 1px solid color-mix(in srgb, var(--border-color) 82%, transparent);
    box-shadow: var(--market-shadow);
}

.portfolio-main-container .market-grid-modern {
    padding: 0 0 20px;
}

.market-filters-modern .filter-header-mobile h3 {
    font-family: "Outfit", var(--font-sans);
    letter-spacing: -0.01em;
}

.filter-select-modern,
.filter-input-modern {
    background: color-mix(in srgb, var(--bg-primary) 88%, transparent);
    border-color: color-mix(in srgb, var(--border-color) 82%, transparent);
}

.filter-select-modern:focus,
.filter-input-modern:focus {
    border-color: var(--market-primary);
    box-shadow: 0 0 0 4px rgba(107, 170, 255, 0.08);
}

.stock-card-modern {
    background: color-mix(in srgb, var(--bg-secondary) 82%, transparent);
    border-color: color-mix(in srgb, var(--border-color) 82%, transparent);
    box-shadow: var(--market-shadow);
}

.stock-card-modern:hover {
    box-shadow: var(--market-shadow-hover);
}

.trending-modal-panel {
    background: color-mix(in srgb, var(--bg-primary) 94%, transparent);
}

@media (min-width: 768px) {
    .portfolio-main-container .market-grid-modern {
        padding: 0 0 24px;
    }
}

.portfolio-main-container .market-loading-modern,
.portfolio-main-container .market-empty-modern,
.portfolio-main-container .market-error-modern {
    padding-left: 0;
    padding-right: 0;
}

.portfolio-main-container .pagination-modern {
    padding-left: 0;
    padding-right: 0;
}

#market-list-header-container {
    position: sticky;
    top: 0;
    z-index: 101;
    background: color-mix(in srgb, var(--bg-secondary) 88%, transparent);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: none;
    box-shadow: none;
    padding: 0;
}

#market-list-header-container .watchlist-app-header-inner {
    min-height: 50px;
    height: 50px;
    gap: 16px;
}

#market-list-header-container .watchlist-header-title {
    font-family: var(--portfolio-font-display);
    font-size: 20px;
    font-weight: 700;
}

/* Market screener equity cards: keep 3 metric tiles per row at every viewport. */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-metrics-modern.equity-card-metrics-market {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

/*
 * Stock analysis featured (not signal-generation execution layout): use a 6-column
 * grid so signal|stage|strength still fill one row (span 2 each), while sector and
 * industry vibe tiles span half the card each (2 per row) instead of two-thirds + gap.
 */
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout) {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .metric-item-modern.allocation-metric-badge-cell.allocation-metric-badge-cell-signal,
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .metric-item-modern.allocation-metric-badge-cell.allocation-metric-badge-cell-stage,
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .metric-item-modern.allocation-metric-badge-cell.allocation-metric-badge-cell-strength {
    grid-column: span 2;
}

#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .metric-item-modern.market-allocation-vibe-badge[data-allocation-vibe="sector"],
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .metric-item-modern.market-allocation-vibe-badge[data-allocation-vibe="industry"] {
    grid-column: span 3;
}

#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market:not(.allocation-featured-execution-layout)
    > .allocation-stage-probability-modern {
    grid-column: 1 / -1;
}

/* Badge tiles (signal / stage / strength): default grid stretch makes every
   cell in the row match the tallest; keep each tile only as tall as its content. */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .allocation-metrics-modern.equity-card-metrics-market
    .metric-item-modern.allocation-metric-badge-cell {
    align-self: start;
}

/*
 * Equity-card sparklines: review.css defines grid-column + 72px inner/canvas, but any page
 * that omits review.css used to place the sparkline in a single column and stretch it to the
 * row height. Keep full-width + fixed chart height here as well.
 */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .allocation-metrics-modern.equity-card-metrics-market
    > .review-allocation-sparkline-wrap {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 100%;
    align-self: start;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .allocation-metrics-modern.equity-card-metrics-market
    > .review-allocation-sparkline-wrap
    .review-allocation-sparkline-inner {
    height: 72px;
    min-height: 72px;
    box-sizing: border-box;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .allocation-metrics-modern.equity-card-metrics-market
    > .review-allocation-sparkline-wrap
    .review-allocation-sparkline-canvas {
    height: 72px;
    box-sizing: border-box;
}

/* Signal-generation featured previews: sparkline spans all columns; metrics follow in 3×2 rows (signal & strength start row 2). */
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market.allocation-featured-execution-layout
    > .review-allocation-sparkline-wrap {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 100%;
}

#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market.allocation-featured-execution-layout
    > .review-allocation-sparkline-wrap
    .review-allocation-sparkline-inner,
#stock-analysis-featured-cards
    .allocation-metrics-modern.equity-card-metrics-market.allocation-featured-execution-layout
    > .review-allocation-sparkline-wrap
    .review-allocation-sparkline-canvas {
    height: 84px;
    min-height: 84px;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-stage-prob-grid-modern {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Match portfolio allocations tab: metric info hover should not lift the whole card */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-card-modern:has(.allocation-metric-info-trigger:hover):hover {
    transform: none;
    box-shadow: var(--shadow-md);
    border-color: var(--border-color);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-card-modern:has(.allocation-metric-info-trigger:hover):hover::before {
    opacity: 0;
}

/* Market cards: sector/industry vibe badges (Artemis hot-pick style) */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 82px;
    text-align: center;
    padding: 12px 10px;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge .vibe-entity-label-modern {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    font-size: 12px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-metric-classification-cell .metric-label-modern {
    width: 100%;
    text-align: center;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-metric-classification-cell .metric-value-modern {
    width: 100%;
    text-align: center;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .equity-card-metrics-market
    .metric-item-modern.allocation-metric-classification-cell:not(.market-allocation-vibe-badge) {
    border: 1px solid rgba(116, 150, 220, 0.2);
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

:root:not([data-theme="dark"])
    :is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .equity-card-metrics-market
    .metric-item-modern.allocation-metric-classification-cell:not(.market-allocation-vibe-badge) {
    background: rgba(255, 255, 255, 0.72);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-show-more-btn {
    height: 40px;
    padding-top: 0;
    padding-bottom: 0;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .equity-card-market .allocation-card-header-row-modern {
    align-items: flex-start;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .equity-card-market .allocation-card-header-modern {
    gap: 0;
}

/* Sector / industry vibe tiles: same glass + rgba palette as Signal / Stage / Strength above */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge.signal-metric-badge-modern {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(107, 114, 128, 0.5);
    background: rgba(107, 114, 128, 0.3);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge.signal-metric-badge-modern.positive {
    background: rgba(34, 197, 94, 0.32);
    border-color: rgba(22, 163, 74, 0.55);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge.signal-metric-badge-modern.negative {
    background: rgba(239, 68, 68, 0.3);
    border-color: rgba(239, 68, 68, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge.signal-metric-badge-modern.warning {
    background: rgba(245, 158, 11, 0.3);
    border-color: rgba(245, 158, 11, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .market-allocation-vibe-badge.signal-metric-badge-modern.neutral {
    background: rgba(107, 114, 128, 0.3);
    border-color: rgba(107, 114, 128, 0.5);
}

/*
 * Signal / Stage / Strength metric tiles on market cards: same green–amber–red glass
 * as symbol page .stage-metric-badge-modern (symbol.css). Market does not load
 * symbol.css, so these rules are duplicated here under
 * :is(#market-analysis-grid-modern, #stock-analysis-featured-cards).
 */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell.signal-metric-badge-modern,
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell.stage-metric-badge-modern {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.15);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-stage.stage-metric-badge-modern.stage-1-bg {
    background: rgba(107, 114, 128, 0.3);
    border-color: rgba(107, 114, 128, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-stage.stage-metric-badge-modern.stage-2-bg {
    background: rgba(34, 197, 94, 0.32);
    border-color: rgba(22, 163, 74, 0.55);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-stage.stage-metric-badge-modern.stage-3-bg {
    background: rgba(245, 158, 11, 0.3);
    border-color: rgba(245, 158, 11, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-stage.stage-metric-badge-modern.stage-4-bg {
    background: rgba(239, 68, 68, 0.3);
    border-color: rgba(239, 68, 68, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-signal.signal-metric-badge-modern.signal-buy {
    background: rgba(34, 197, 94, 0.32);
    border-color: rgba(22, 163, 74, 0.55);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-signal.signal-metric-badge-modern.signal-sell {
    background: rgba(239, 68, 68, 0.3);
    border-color: rgba(239, 68, 68, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-signal.signal-metric-badge-modern.signal-hold,
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-signal.signal-metric-badge-modern.signal-neutral {
    background: rgba(107, 114, 128, 0.3);
    border-color: rgba(107, 114, 128, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .metric-item-modern.allocation-metric-badge-cell-strength.stage-metric-badge-modern.sata-badge-modern.sata-positive {
    background: rgba(34, 197, 94, 0.32);
    border-color: rgba(22, 163, 74, 0.55);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .metric-item-modern.allocation-metric-badge-cell-strength.stage-metric-badge-modern.sata-badge-modern.sata-negative {
    background: rgba(239, 68, 68, 0.3);
    border-color: rgba(239, 68, 68, 0.5);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .metric-item-modern.allocation-metric-badge-cell-strength.stage-metric-badge-modern.sata-badge-modern.sata-moderate {
    background: rgba(245, 158, 11, 0.3);
    border-color: rgba(245, 158, 11, 0.5);
}

/* Signal value: match Stage / Strength typography (global badge-cell-signal uses a larger clamp) */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .metric-item-modern.allocation-metric-badge-cell-signal .metric-value-modern {
    font-size: clamp(20px, 5cqw, 30px);
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .vibe-badge-headline-modern {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    width: 100%;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .vibe-badge-vibe-text {
    font-size: clamp(11px, 2.5vw, 13px);
    font-weight: 600;
    line-height: 1.25;
    color: var(--text-primary);
    max-width: 100%;
    text-align: center;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .vibe-badge-category-text {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

/*
 * Company blurb: mirror artemis-modern.css
 * (#tab-artemis-modern #artemis-recommendations .artemis-yf-profile-panel.rec-v2-panel)
 * — full card width (grid-column in review.css), inner panel contrasts glass card + metric tiles.
 */
:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-market-yf-profile.rec-v2-panel {
    margin: 0;
    margin-top: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    cursor: pointer;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-market-yf-profile .rec-v2-panel-head {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    flex: 0 0 auto;
    font-size: calc(11px + 4pt);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-market-yf-profile .artemis-yf-profile-description {
    margin: 0;
    width: 100%;
    min-width: 0;
    font-size: 13px;
    line-height: 1.5;
    color: var(--text-primary);
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards)
    .allocation-market-yf-profile.artemis-yf-profile-panel--expanded
    .artemis-yf-profile-description {
    display: block;
    -webkit-line-clamp: unset;
    line-clamp: unset;
    overflow: visible;
}

:is(#market-analysis-grid-modern, #stock-analysis-featured-cards) .allocation-market-yf-profile .artemis-yf-profile-more {
    align-self: flex-start;
    margin-top: 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--primary, var(--accent-color));
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
}

/* Sort sync: keep native select for API/query string but hide from layout (popover + toolbar replace it). */
.market-filters-modern .filter-group-modern.market-sort-select-sync-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.market-filters-toolbar-modern {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid var(--border-color);
}

/* Market data grid (same pattern as allocationspositions table mode) */
#market-analysis-grid-modern.market-analysis-table-mode {
    display: block;
    width: 100%;
}

#market-analysis-grid-modern.market-analysis-table-mode .trinity-dg-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

#market-analysis-grid-modern.market-analysis-table-mode tr.market-grid-row-modern {
    cursor: pointer;
}

#market-analysis-grid-modern.market-analysis-table-mode .allocations-grid-info-cell {
    display: flex;
    flex-direction: column;
    gap: 3px;
    line-height: 1.25;
    max-width: 16rem;
}

#market-analysis-grid-modern.market-analysis-table-mode .allocations-grid-info-line {
    word-break: break-word;
}

#market-analysis-grid-modern.market-analysis-table-mode .allocations-grid-info-industry {
    font-size: 11px;
    font-weight: 500;
    color: var(--text-secondary);
}

#market-analysis-grid-modern.market-analysis-table-mode .allocations-grid-symbol-sub {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    margin-top: 2px;
}

/* -------------------------------------------------------------------------- */
/* /portfolio/stock-analysis — hero reuse + centered symbol hub               */
/* -------------------------------------------------------------------------- */

.stock-analysis-main {
    padding-top: 8px;
    padding-bottom: clamp(48px, 8vw, 96px);
}

.stock-analysis-search-hub {
    max-width: 720px;
    margin: 40px auto;
    text-align: center;
}

.stock-analysis-eyebrow {
    margin: 0 0 14px;
    font-size: 15px;
    font-weight: 600;
    color: var(--text-secondary);
    letter-spacing: 0.02em;
}

.stock-analysis-page #stock-analysis-symbol-search {
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}

.stock-analysis-page #stock-analysis-symbol-search .symbol-search-input {
    width: 100%;
    box-sizing: border-box;
    min-height: 52px;
    padding: 10px 16px 10px 44px;
    border-radius: 999px;
    font-size: 16px;
    border: 1px solid color-mix(in srgb, var(--border-color) 88%, transparent);
    box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
}

.stock-analysis-page #stock-analysis-symbol-search .symbol-search-input:focus {
    width: 100%;
    border-color: var(--primary);
    box-shadow:
        0 8px 28px rgba(15, 23, 42, 0.06),
        0 0 0 3px rgba(var(--primary-rgb), 0.18);
}

.stock-analysis-page #stock-analysis-symbol-search .symbol-search-icon {
    left: 18px;
    font-size: 15px;
}

.stock-analysis-suggestions-label {
    margin: 32px 0 14px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.stock-analysis-suggestions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.stock-analysis-suggestions li {
    margin: 0;
}

.stock-analysis-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 4.25rem;
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-decoration: none;
    color: var(--text-primary);
    background: color-mix(in srgb, var(--bg-tertiary) 78%, transparent);
    border: 1px solid color-mix(in srgb, var(--border-color) 72%, transparent);
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.stock-analysis-chip:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--market-primary) 45%, var(--border-color));
    box-shadow: 0 10px 26px rgba(49, 104, 233, 0.12);
}

@media (max-width: 480px) {
    .stock-analysis-suggestions {
        gap: 8px;
    }

    .stock-analysis-chip {
        min-width: 3.75rem;
        padding: 9px 14px;
        font-size: 14px;
    }
}

/* Stock analysis: reuse Market equity cards (AAPL / MSFT / NVDA) */
.stock-analysis-featured-section {
    margin-top: clamp(28px, 5vw, 48px);
    padding-bottom: 8px;
}

.stock-analysis-featured-label {
    margin-top: 0;
}

/* Featured strip: spinner spans full grid until three cards replace it */
.stock-analysis-main #stock-analysis-featured-cards .stock-analysis-featured-loading {
    grid-column: 1 / -1;
    padding-top: clamp(36px, 6vw, 56px);
    padding-bottom: clamp(36px, 6vw, 56px);
}

/* Card strip: full width of .portfolio-main-container (1400px), same as hero / market body */
.stock-analysis-main #stock-analysis-featured-cards.market-grid-modern {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-top: 12px;
    grid-template-columns: 1fr;
    gap: 20px;
}

@media (min-width: 640px) {
    .stock-analysis-main #stock-analysis-featured-cards.market-grid-modern {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 24px;
    }
}

/* Metric grid + glass tiles: shared with market screener via :is(...) above */

#stock-analysis-featured-cards .allocation-card-modern:has(.allocation-metric-info-trigger:hover):hover {
    transform: none;
    box-shadow: var(--market-shadow);
}

#stock-analysis-featured-cards .allocation-card-modern:has(.allocation-metric-info-trigger:hover):hover::before {
    opacity: 0;
}
