/* ==========================================================================
   SUPPLY CHAIN INTELLIGENCE PLATFORM — v2 (Refined)
   Design language: Clean Modern / Data Dashboard
   Typography: IBM Plex Mono (data) + IBM Plex Sans (body)
   All colours reference root vars from index.css
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ── Reset / page shell ─────────────────────────────────────── */
.sc2-page {
    padding: 28px 32px 50px;
    display: flex;
    flex-direction: column;
    gap: 0;
    font-family: 'IBM Plex Sans', 'Inter', sans-serif;
    color: var(--text-secondary);
    min-height: 100vh;
    background: transparent;
}

/* ── Page header ────────────────────────────────────────────── */
.sc2-header {
    padding: 24px 28px 22px;
    border-bottom: 1px solid var(--border-primary);
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg,
        rgba(15,23,42,0.0) 0%,
        rgba(251,191,36,0.04) 50%,
        rgba(15,23,42,0.0) 100%);
    border-radius: 16px 16px 0 0;
}

.sc2-header::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, var(--primary-gold), var(--primary-gold-dark));
    border-radius: 4px 0 0 4px;
}

.sc2-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 1;
    flex-wrap: wrap;
    gap: 16px;
}

.sc2-header-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.sc2-hex {
    font-size: 2.2rem;
    color: var(--primary-gold);
    line-height: 1;
    filter: drop-shadow(0 0 10px rgba(251,191,36,0.4));
    flex-shrink: 0;
}

.sc2-page-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.3px;
    margin: 0 0 4px;
    line-height: 1.2;
}

.sc2-page-sub {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin: 0;
    font-family: 'IBM Plex Sans', sans-serif;
    letter-spacing: 0.2px;
}

.sc2-header-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.sc2-live {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    color: #34d399;
    letter-spacing: 1px;
    text-transform: uppercase;
    background: rgba(52,211,153,0.08);
    border: 1px solid rgba(52,211,153,0.2);
    border-radius: 20px;
    padding: 6px 14px;
}

.sc2-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #34d399;
    box-shadow: 0 0 8px #34d399;
    animation: sc2-blink 2s ease-in-out infinite;
    display: inline-block;
}

@keyframes sc2-blink {
    0%,100% { opacity: 1; }
    50%      { opacity: 0.3; }
}

.sc2-ptag {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.72rem;
    color: var(--primary-gold);
    background: rgba(251,191,36,0.08);
    border: 1px solid var(--border-primary);
    border-radius: 8px;
    padding: 5px 12px;
    letter-spacing: 0.3px;
}

/* ── KPI strip ──────────────────────────────────────────────── */
.sc2-kpi-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-bottom: 1px solid var(--border-primary);
    background: rgba(15,23,42,0.3);
}

.sc2-kpi {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 20px 22px;
    border-right: 1px solid var(--border-primary);
    transition: background 0.25s ease;
    cursor: default;
}

.sc2-kpi:last-child { border-right: none; }

.sc2-kpi:hover {
    background: rgba(251,191,36,0.05);
}

.sc2-kpi-icon {
    font-size: 1.5rem;
    color: var(--text-muted);
    line-height: 1;
    width: 28px;
    text-align: center;
    flex-shrink: 0;
}

.sc2-kpi-value {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.5px;
    margin-bottom: 2px;
}

.sc2-kpi-label {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 2px;
}

.sc2-kpi-sub {
    font-size: 0.68rem;
    color: var(--text-muted);
    font-family: 'IBM Plex Sans', sans-serif;
}

/* ── Tab bar ─────────────────────────────────────────────────── */
.sc2-tabbar {
    display: flex;
    border-bottom: 1px solid var(--border-primary);
    background: rgba(15,23,42,0.5);
    overflow-x: auto;
    scrollbar-width: none;
    padding: 0 8px;
}

.sc2-tabbar::-webkit-scrollbar { display: none; }

.sc2-tab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 18px;
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text-secondary);
    letter-spacing: 0.2px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
    position: relative;
    border-radius: 8px 8px 0 0;
}

.sc2-tab span:first-child {
    font-size: 0.62rem;
    color: var(--text-muted);
    opacity: 0.6;
    margin-right: 2px;
    transition: color 0.2s ease;
}

.sc2-tab:hover {
    color: var(--text-primary);
    background: rgba(251,191,36,0.06);
}

.sc2-tab--active {
    color: var(--primary-gold) !important;
    border-bottom-color: var(--primary-gold) !important;
    background: rgba(251,191,36,0.08) !important;
}

.sc2-tab--active span:first-child {
    color: var(--primary-gold) !important;
    opacity: 1 !important;
}

/* ── Tab panels ─────────────────────────────────────────────── */
.sc2-panels { min-height: 550px; }

.sc2-panel {
    display: none;
    animation: sc2-fadein 0.3s ease;
}

.sc2-panel--active {
    display: block;
}

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

.sc2-tab-content {
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* ── Cards ──────────────────────────────────────────────────── */
.sc2-card {
    background: rgba(15,23,42,0.6);
    border: 1px solid var(--border-primary);
    border-radius: 14px;
    overflow: hidden;
    min-height: 0;
    min-width: 0;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.sc2-card:hover {
    border-color: var(--border-hover);
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

.sc2-card--full { width: 100%; }

.sc2-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-primary);
    background: rgba(15,23,42,0.4);
    flex-wrap: wrap;
}

.sc2-card-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: 0.3px;
    text-transform: uppercase;
}

.sc2-card-sub {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-family: 'IBM Plex Sans', sans-serif;
    margin-left: 4px;
}

.sc2-badge {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.66rem;
    padding: 4px 10px;
    border-radius: 6px;
    background: rgba(251,191,36,0.1);
    color: var(--primary-gold);
    border: 1px solid rgba(251,191,36,0.2);
    letter-spacing: 0.4px;
    text-transform: uppercase;
    margin-left: auto;
    white-space: nowrap;
    font-weight: 500;
}

.sc2-badge--red {
    background: rgba(239,68,68,0.1);
    color: #f87171;
    border-color: rgba(239,68,68,0.2);
}

.sc2-badge--green {
    background: rgba(52,211,153,0.1);
    color: #34d399;
    border-color: rgba(52,211,153,0.2);
}

.sc2-badge--purple {
    background: rgba(167,139,250,0.1);
    color: #a78bfa;
    border-color: rgba(167,139,250,0.2);
}

.sc2-badge--blue {
    background: rgba(96,165,250,0.1);
    color: #60a5fa;
    border-color: rgba(96,165,250,0.2);
}

/* ── Two-column grid ────────────────────────────────────────── */
.sc2-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    min-height: 0;
    min-width: 0;
}

.sc2-two-col > * {
    min-height: 0;
    min-width: 0;
}

/* ── Map legend ─────────────────────────────────────────────── */
.sc2-map-legend {
    padding: 8px 20px 10px;
    font-size: 0.72rem;
    font-family: 'IBM Plex Sans', sans-serif;
    color: var(--text-muted);
    letter-spacing: 0.3px;
    border-bottom: 1px solid rgba(251,191,36,0.06);
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* ── Overview grid ──────────────────────────────────────────── */
.sc2-overview-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
    min-width: 0;
}

.sc2-insight-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.sc2-insight {
    background: rgba(15,23,42,0.55);
    border: 1px solid var(--border-primary);
    border-radius: 12px;
    padding: 20px 22px;
    transition: all 0.3s ease;
    cursor: default;
}

.sc2-insight:hover {
    border-color: rgba(251,191,36,0.4);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}

.sc2-insight-phase {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.64rem;
    font-weight: 600;
    color: var(--primary-gold);
    letter-spacing: 1.5px;
    margin-bottom: 8px;
    opacity: 0.85;
}

.sc2-insight-title {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 10px;
    line-height: 1.4;
}

.sc2-insight-body {
    font-size: 0.76rem;
    color: var(--text-muted);
    line-height: 1.65;
}

/* ── Prediction widget ──────────────────────────────────────── */
.sc2-card--predictor .sc2-predictor {
    display: grid;
    grid-template-columns: 1fr 260px;
    gap: 0;
    min-height: 380px;
}

.sc2-sliders-panel {
    padding: 20px 24px;
    border-right: 1px solid var(--border-primary);
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.sc2-predictor-hint {
    font-size: 0.74rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin-bottom: 8px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(251,191,36,0.08);
    font-family: 'IBM Plex Sans', sans-serif;
}

.sc2-slider-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.sc2-slider-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.sc2-slider-label {
    font-size: 0.74rem;
    color: var(--text-secondary);
    font-family: 'IBM Plex Sans', sans-serif;
}

.sc2-slider-cur {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.74rem;
    color: var(--primary-gold);
    font-weight: 600;
    min-width: 60px;
    text-align: right;
}

/* Dash slider overrides */
.sc2-slider .rc-slider-rail {
    background: rgba(251,191,36,0.15) !important;
    height: 4px !important;
    border-radius: 2px !important;
}
.sc2-slider .rc-slider-track {
    background: var(--primary-gold) !important;
    height: 4px !important;
    border-radius: 2px !important;
}
.sc2-slider .rc-slider-handle {
    border-color: var(--primary-gold) !important;
    background: var(--bg-dark) !important;
    width: 16px !important;
    height: 16px !important;
    margin-top: -6px !important;
    box-shadow: 0 2px 8px rgba(251,191,36,0.3) !important;
}
.sc2-slider .rc-slider-handle:hover,
.sc2-slider .rc-slider-handle:active {
    box-shadow: 0 0 12px rgba(251,191,36,0.6) !important;
    transform: scale(1.1);
}

/* Result panel */
.sc2-result-panel {
    padding: 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: linear-gradient(180deg, rgba(10,18,36,0.6) 0%, rgba(10,18,36,0.3) 100%);
    text-align: center;
}

.sc2-result-label {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--text-muted);
    letter-spacing: 2px;
    text-transform: uppercase;
}

.sc2-result-prob {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 3rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -2px;
    color: var(--primary-gold);
    transition: all 0.3s ease;
}

.sc2-result-verdict {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text-secondary);
    max-width: 200px;
    line-height: 1.4;
    transition: all 0.3s ease;
}

.sc2-result-bar-wrap {
    width: 100%;
    height: 10px;
    background: rgba(255,255,255,0.06);
    border-radius: 5px;
    overflow: hidden;
    margin: 6px 0;
    box-shadow: inset 0 1px 4px rgba(0,0,0,0.4);
}

.sc2-result-bar {
    height: 100%;
    border-radius: 5px;
    width: 0%;
    background: linear-gradient(90deg, var(--primary-gold), rgba(251,191,36,0.5));
    transition: width 0.5s ease, background 0.3s ease;
    box-shadow: 0 0 12px rgba(251,191,36,0.5);
}

.sc2-result-insight {
    font-size: 0.7rem;
    color: var(--text-muted);
    font-family: 'IBM Plex Sans', sans-serif;
    max-width: 200px;
    text-align: center;
    line-height: 1.5;
    min-height: 28px;
}

.sc2-model-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 10px;
    width: 100%;
    border-top: 1px solid var(--border-primary);
    padding-top: 12px;
}

.sc2-model-tag {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.64rem;
    color: var(--text-muted);
    letter-spacing: 0.2px;
}

/* ── Forecast tab controls ──────────────────────────────────── */
.sc2-header-controls {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sc2-control-label {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.74rem;
    color: var(--text-muted);
}

/* Dropdown override */
.sc2-dropdown .Select-control {
    background: var(--bg-dark) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 8px !important;
    color: var(--text-primary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.76rem !important;
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
}

.sc2-dropdown .Select-value-label {
    color: var(--primary-gold) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
}

.sc2-dropdown .Select-menu-outer {
    background: rgba(15,23,42,0.98) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.3) !important;
}

.sc2-dropdown .Select-option {
    background: transparent !important;
    color: var(--text-secondary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.76rem !important;
    padding: 10px 14px !important;
}

.sc2-dropdown .Select-option:hover,
.sc2-dropdown .is-focused:not(.is-open) > .Select-control {
    background: rgba(251,191,36,0.1) !important;
    color: var(--primary-gold) !important;
}

.sc2-dropdown .Select-arrow {
    border-top-color: var(--text-muted) !important;
}

/* ── Callout box ─────────────────────────────────────────────── */
.sc2-callout {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: linear-gradient(135deg, rgba(251,191,36,0.06) 0%, rgba(251,191,36,0.02) 100%);
    border: 1px solid rgba(251,191,36,0.15);
    border-left: 4px solid var(--primary-gold);
    border-radius: 12px;
    padding: 18px 22px;
}

.sc2-callout-icon {
    font-size: 1.2rem;
    color: var(--primary-gold);
    flex-shrink: 0;
    margin-top: 2px;
}

.sc2-callout-text {
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.7;
}

.sc2-callout-text strong {
    color: var(--primary-gold);
    font-weight: 600;
}

/* ── Hub mini cards ──────────────────────────────────────────── */
.sc2-hub-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    padding: 18px 22px;
    border-top: 1px solid var(--border-primary);
}

.sc2-hub-mini {
    border: 1px solid var(--border-primary);
    border-radius: 10px;
    padding: 16px 18px;
    background: rgba(15,23,42,0.5);
    transition: all 0.25s ease;
}

.sc2-hub-mini:hover {
    transform: translateY(-3px);
    border-color: var(--primary-gold);
    box-shadow: 0 6px 16px rgba(0,0,0,0.2);
}

.sc2-hub-mini-id {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.sc2-hub-mini-city {
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 12px;
}

.sc2-hub-mini-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 6px;
}

.sc2-hub-mini-stat {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--text-primary);
}

.sc2-hub-mini-stat-label {
    font-size: 0.66rem;
    color: var(--text-muted);
    font-family: 'IBM Plex Sans', sans-serif;
}

/* ── Capacity table ──────────────────────────────────────────── */
.sc2-card--table .sc2-method-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8rem;
    font-family: 'IBM Plex Sans', sans-serif;
}

.sc2-method-table thead tr {
    border-bottom: 1px solid var(--border-primary);
}

.sc2-method-table th {
    padding: 12px 20px;
    text-align: left;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--primary-gold);
    letter-spacing: 1px;
    text-transform: uppercase;
    background: rgba(15,23,42,0.4);
}

.sc2-method-table td {
    padding: 12px 20px;
    color: var(--text-secondary);
    border-bottom: 1px solid rgba(251,191,36,0.06);
    line-height: 1.5;
}

.sc2-method-table td:first-child {
    color: var(--text-primary);
    font-weight: 500;
}

.sc2-method-table td:nth-child(2) {
    color: var(--primary-gold);
    font-weight: 500;
}

.sc2-method-table tr:last-child td {
    border-bottom: none;
}

.sc2-method-table tr:hover td {
    background: rgba(251,191,36,0.04);
}

/* ── Section title ───────────────────────────────────────────── */
.sc2-section-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--primary-gold);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-primary);
}

/* ── UI Grid Styles ──────────────────────────────────────────── */
.sc2-ui-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    padding: 8px;
}

.sc2-radio-group {
    display: flex;
    gap: 16px;
    margin-top: 8px;
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.82rem;
    color: var(--text-primary);
}

.sc2-radio-group input[type="radio"] {
    accent-color: var(--primary-gold);
    margin-right: 6px;
    cursor: pointer;
    width: 16px;
    height: 16px;
}

/* Custom Dropdown */
.sc2-model-dropdown .Select-control {
    background: rgba(15,23,42,0.8) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 8px !important;
    color: var(--text-primary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.82rem !important;
    height: 38px !important;
    padding: 0 14px !important;
}

.sc2-model-dropdown .Select-value-label {
    color: var(--primary-gold) !important;
}

.sc2-model-dropdown .Select-menu-outer {
    background: rgba(15,23,42,0.98) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 8px !important;
    z-index: 9999 !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.3) !important;
}

.sc2-model-dropdown .Select-option {
    background: transparent !important;
    color: var(--text-secondary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.82rem !important;
    padding: 10px 14px !important;
}

.sc2-model-dropdown .Select-option:hover {
    background: rgba(251,191,36,0.1) !important;
    color: var(--primary-gold) !important;
}

/* Custom Slider Overrides */
.sc2-custom-slider .rc-slider-rail {
    background: rgba(251,191,36,0.15) !important;
    height: 5px !important;
    border-radius: 3px !important;
}

.sc2-custom-slider .rc-slider-track {
    background: var(--primary-gold) !important;
    height: 5px !important;
    border-radius: 3px !important;
}

.sc2-custom-slider .rc-slider-handle {
    border-color: var(--primary-gold) !important;
    background: var(--bg-dark) !important;
    width: 18px !important;
    height: 18px !important;
    margin-top: -7px !important;
    box-shadow: 0 2px 8px rgba(251,191,36,0.3) !important;
    opacity: 1 !important;
}

.sc2-custom-slider .rc-slider-handle:hover,
.sc2-custom-slider .rc-slider-handle:active {
    box-shadow: 0 0 14px rgba(251,191,36,0.6) !important;
    transform: scale(1.15);
}

/* ── Input Group ─────────────────────────────────────────────── */
.sc2-input-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sc2-input-label {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.68rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
}

.sc2-model-number {
    background: rgba(15,23,42,0.8);
    border: 1px solid var(--border-primary);
    border-radius: 8px;
    color: var(--text-primary);
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 0.84rem;
    padding: 10px 14px;
    width: 100%;
    transition: all 0.2s ease;
}

.sc2-model-number:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 10px rgba(251,191,36,0.2);
}

/* ── Back Button ─────────────────────────────────────────────── */
.sc-back-btn {
    color: var(--primary-gold) !important;
    text-decoration: none !important;
    margin-bottom: 16px !important;
    display: inline-block !important;
    font-size: 0.82rem !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    background: transparent !important;
    border: none !important;
    padding: 8px 0 !important;
    cursor: pointer !important;
    text-align: left !important;
    transition: all 0.2s ease !important;
}

.sc-back-btn:hover {
    color: var(--primary-gold-hover) !important;
    transform: translateX(-3px);
}

/* ============================================================
   DYNAMIC PREDICTOR MATRIX STYLES
   ============================================================ */

.sc2-card {
    min-height: 0;
    min-width: 0;
    overflow: hidden;
}

.sc2-predictor-matrix {
    display: grid;
    grid-template-columns: 2fr 1fr;
    border-top: 1px solid var(--border-primary);
}

.sc2-inputs-panel {
    padding: 24px;
    border-right: 1px solid var(--border-primary);
    max-height: 450px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--primary-gold) rgba(15,23,42,0.5);
}

.sc2-input-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1200px) {
    .sc2-insight-row {
        grid-template-columns: repeat(2, 1fr);
    }
    .sc2-kpi-strip {
        grid-template-columns: repeat(2, 1fr);
    }
    .sc2-kpi:nth-child(2) { border-right: none; }
    .sc2-kpi:nth-child(3) { border-top: 1px solid var(--border-primary); }
    .sc2-kpi:nth-child(4) { border-top: 1px solid var(--border-primary); border-right: none; }
    .sc2-ui-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 960px) {
    .sc2-two-col {
        grid-template-columns: 1fr;
    }
    .sc2-card--predictor .sc2-predictor {
        grid-template-columns: 1fr;
    }
    .sc2-result-panel {
        border-top: 1px solid var(--border-primary);
        border-right: none;
    }
    .sc2-hub-cards {
        grid-template-columns: 1fr 1fr;
    }
    .sc2-predictor-matrix {
        grid-template-columns: 1fr;
    }
    .sc2-inputs-panel {
        border-right: none;
        border-bottom: 1px solid var(--border-primary);
        max-height: 320px;
    }
    .sc2-input-grid {
        grid-template-columns: 1fr;
    }
    .sc2-ui-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 768px) {
    .sc2-page {
        padding: 0 0 40px;
    }
    .sc2-header {
        padding: 20px;
        border-radius: 12px 12px 0 0;
    }
    .sc2-header-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }
    .sc2-header-right {
        width: 100%;
        justify-content: flex-start;
        padding-top: 10px;
        border-top: 1px solid var(--border-primary);
    }
    .sc2-page-title {
        font-size: 1.15rem;
    }
    .sc2-page-sub {
        display: none;
    }
    .sc2-tab-content {
        padding: 16px;
    }
    .sc2-insight-row {
        grid-template-columns: 1fr;
    }
    .sc2-kpi-strip {
        grid-template-columns: 1fr 1fr;
    }
    .sc2-kpi {
        padding: 16px;
    }
    .sc2-kpi-value {
        font-size: 1.3rem;
    }
    .sc2-kpi-label {
        font-size: 0.72rem;
    }
    .sc2-kpi-sub {
        display: none;
    }
    .sc2-tab {
        padding: 12px 14px;
        font-size: 0.72rem;
    }
    .sc2-tab span:first-child {
        display: none;
    }
    .sc2-result-prob {
        font-size: 2.2rem;
    }
    .sc2-hub-cards {
        grid-template-columns: 1fr;
    }
    .sc2-ui-grid {
        grid-template-columns: 1fr;
    }
    .sc2-input-group[style*="gridColumn"] {
        grid-column: 1 / span 1 !important;
    }
    .sc2-callout {
        flex-direction: column;
        gap: 12px;
        padding: 16px;
    }
    .sc2-callout-icon {
        font-size: 1.4rem;
    }
}

@media (max-width: 480px) {
    .sc2-page {
        padding: 0 0 30px;
    }
    .sc2-header {
        padding: 16px;
    }
    .sc2-hex {
        font-size: 1.8rem;
    }
    .sc2-page-title {
        font-size: 1rem;
    }
    .sc2-live {
        font-size: 0.62rem;
        padding: 4px 10px;
    }
    .sc2-ptag {
        font-size: 0.64rem;
        padding: 4px 8px;
    }
    .sc2-kpi-strip {
        grid-template-columns: 1fr;
    }
    .sc2-kpi {
        border-right: none !important;
        border-bottom: 1px solid var(--border-primary);
    }
    .sc2-kpi:nth-child(3) {
        border-top: none;
    }
    .sc2-kpi-value {
        font-size: 1.2rem;
    }
    .sc2-insight {
        padding: 16px;
    }
    .sc2-insight-title {
        font-size: 0.82rem;
    }
    .sc2-insight-body {
        font-size: 0.72rem;
    }
    .sc2-tabbar {
        padding: 0 4px;
    }
    .sc2-tab {
        padding: 10px 12px;
        font-size: 0.7rem;
    }
    .sc2-card-header {
        padding: 14px 16px;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    .sc2-badge {
        margin-left: 0;
        margin-top: 4px;
    }
    .sc2-result-prob {
        font-size: 2rem;
    }
    .sc2-method-table th,
    .sc2-method-table td {
        padding: 10px 12px;
        font-size: 0.72rem;
    }
}

/* ── Smooth transitions for all interactive elements ─────────────────────────────────────── */
.sc2-card,
.sc2-insight,
.sc2-hub-mini,
.sc2-tab,
.sc2-kpi,
.sc2-model-number,
.sc2-dropdown .Select-control,
.sc2-model-dropdown .Select-control {
    transition: all 0.25s ease;
}

.dash-dropdown {
    background: rgba(15, 23, 42, 0.95) !important;
}
.dash-dropdown-content {
    background: rgba(21, 31, 56, 0.95) !important;
}

.dash-dropdown-option {
    border-bottom: 1px solid var(--border-primary) !important;
}
.dash-dropdown-search-container{
    background: rgba(15, 23, 42, 0.95) !important;
    border: 2px solid var(--border-primary) !important;
}
/* ── Additional polish: subtle shadows and rounded corners ─────────────────────────────────────── */
.sc2-page {
    border-radius: 16px;
    background: rgba(15,23,42,0.4);
    border: 1px solid var(--border-primary);
}

@media (max-width: 768px) {
    .sc2-page {
        border-radius: 0;
        border: none;
    }
}

/* ============================================================
   MOBILE CHART RESPONSIVENESS - Demand Forecast & Hub Network
   ============================================================ */

/* Graph container fixes for mobile */
.sc2-panel .dash-graph {
    width: 100% !important;
    min-height: 280px !important;
}

.sc2-panel .dash-graph svg {
    max-width: 100% !important;
    height: auto !important;
}

/* Fix for Plotly charts on mobile */
.js-plotly-plot .plotly .main-svg {
    width: 100% !important;
    height: auto !important;
}

/* Ensure cards with graphs are fully responsive */
.sc2-card:has(.dash-graph) {
    width: 100%;
    overflow: hidden;
}

.sc2-card:has(.dash-graph) > div:first-child {
    flex-wrap: wrap;
}

/* Forecast chart specific fixes */
#sc2-panel-forecast .sc2-card {
    margin-bottom: 16px;
}

#sc2-panel-forecast .dash-graph {
    min-height: 320px !important;
    height: auto !important;
}

/* Hub network chart fixes */
#sc2-panel-hubs .sc2-two-col {
    gap: 16px;
}

#sc2-panel-hubs .sc2-card:first-child .dash-graph {
    min-height: 300px !important;
}

#sc2-panel-hubs .sc2-card:nth-child(2) .dash-graph {
    min-height: 280px !important;
}

/* Two-column layout for charts on mobile */
@media (max-width: 768px) {
    #sc2-panel-forecast .sc2-two-col,
    #sc2-panel-hubs .sc2-two-col {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    #sc2-panel-forecast .sc2-card,
    #sc2-panel-hubs .sc2-card {
        margin-bottom: 0;
    }

    #sc2-panel-forecast .dash-graph,
    #sc2-panel-hubs .dash-graph {
        min-height: 260px !important;
    }

    #sc2-panel-hubs .sc2-hub-cards {
        padding: 12px 16px;
    }

    #sc2-panel-hubs .sc2-hub-mini {
        padding: 12px 14px;
    }
}

@media (max-width: 480px) {
    #sc2-panel-forecast .dash-graph,
    #sc2-panel-hubs .dash-graph {
        min-height: 220px !important;
    }

    .sc2-card-header {
        padding: 12px 14px !important;
    }

    .sc2-card-title {
        font-size: 0.74rem !important;
    }

    .sc2-badge {
        font-size: 0.6rem !important;
        padding: 3px 8px !important;
    }
}

/* Force chart responsiveness in forecast tab */
@media (max-width: 960px) {
    #sc2-panel-forecast .sc2-tab-content {
        gap: 16px;
    }

    #sc2-panel-forecast .sc2-card {
        min-height: auto;
    }

    #sc2-panel-forecast .dash-graph {
        height: 300px !important;
        min-height: 300px !important;
    }
}

/* Hub tab grid fix */
@media (max-width: 960px) {
    #sc2-panel-hubs .sc2-two-col {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   INPUT FIELDS & DROPDOWN STYLING - AGGRESSIVE OVERRIDES
   ============================================================ */

/* OVERRIDE Dash's default white dropdown - use div:not for highest specificity */
div.Select-control,
div.Select-control:hover,
div.Select-control:focus,
div.Select-control.is-focused,
.Select-control,
.Select-control:hover,
.Select-control:focus,
.Select-control.is-focused,
.Select-control--is-focused {
    background: #0f172a !important;
    background-color: #0f172a !important;
    border: 1px solid rgba(251, 191, 36, 0.25) !important;
    border-color: rgba(251, 191, 36, 0.25) !important;
    border-radius: 5px !important;
    color: #fbbf24 !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 13px !important;
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 8px !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Value text in dropdown */
div.Select-value-label,
div.Select-value,
.Select-value-label,
.Select-value {
    color: #fbbf24 !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-weight: 500 !important;
}

/* Placeholder text */
div.Select-placeholder,
.Select-placeholder {
    color: #64748b !important;
    font-size: 12px !important;
}

/* Dropdown arrow */
div.Select-arrow,
.Select-arrow {
    border-top: 5px solid #64748b !important;
    width: 0 !important;
    height: 0 !important;
    border-left: 4px solid transparent !important;
    border-right: 4px solid transparent !important;
}

/* Dropdown menu */
div.Select-menu-outer,
.Select-menu-outer {
    background: #0a0f1a !important;
    background-color: #0a0f1a !important;
    border: 1px solid rgba(251, 191, 36, 0.25) !important;
    border-radius: 5px !important;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.6) !important;
    z-index: 999999 !important;
    max-height: 160px !important;
    overflow-y: auto !important;
}

/* Dropdown options */
div.Select-option,
.Select-option {
    background: transparent !important;
    color: #94a3b8 !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 12px !important;
    padding: 6px 10px !important;
    cursor: pointer !important;
}

div.Select-option:hover,
div.Select-option.is-hovered,
.Select-option:hover,
.Select-option.is-hovered {
    background: rgba(251, 191, 36, 0.2) !important;
    color: #fbbf24 !important;
}

div.Select-option.is-selected,
.Select-option.is-selected {
    background: rgba(251, 191, 36, 0.3) !important;
    color: #fbbf24 !important;
}

/* Search input inside dropdown - MAKE IT TINY */
div.Select-input,
.Select-input {
    height: 20px !important;
    min-height: 20px !important;
    padding: 0 !important;
    margin: 0 !important;
}

div.Select-input input,
.Select-input input {
    height: 20px !important;
    min-height: 20px !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 11px !important;
    color: #f8fafc !important;
    background: transparent !important;
    padding: 0 4px !important;
    margin: 0 !important;
}

div.Select-input input:focus,
.Select-input input:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* Hide search in single-select dropdowns where possible */
.Select--single .Select-input {
    display: none !important;
}

/* No results message */
div.Select-noresults,
.Select-noresults {
    color: #64748b !important;
    padding: 8px 10px !important;
    font-size: 11px !important;
}

/* Clear button */
div.Select-clear-zone,
.Select-clear-zone {
    width: 16px !important;
}

div.Select-clear,
.Select-clear {
    color: #64748b !important;
    font-size: 12px !important;
}

/* Scrollbar in dropdown */
.Select-menu-outer::-webkit-scrollbar {
    width: 5px !important;
}

.Select-menu-outer::-webkit-scrollbar-track {
    background: #0f172a !important;
}

.Select-menu-outer::-webkit-scrollbar-thumb {
    background: rgba(251, 191, 36, 0.5) !important;
    border-radius: 2px !important;
}

/* Ensure all cards have proper overflow handling */
.sc2-card {
    overflow-x: hidden !important;
}

/* Responsive chart containers */
.dash-graph {
    width: 100% !important;
    overflow: hidden !important;
}

.dash-graph > div {
    width: 100% !important;
}

/* Force proper scaling on Plotly charts */
.js-plotly-plot .plotly .main-svg {
    max-width: 100% !important;
}

/* Mobile dropdown - smaller */
@media (max-width: 768px) {
    div.Select-control,
    .Select-control {
        height: 32px !important;
        min-height: 32px !important;
        font-size: 14px !important;
    }

    div.Select-menu-outer,
    .Select-menu-outer {
        max-height: 150px !important;
    }

    div.Select-option,
    .Select-option {
        padding: 8px 10px !important;
        font-size: 13px !important;
    }
}

.sc2-page input:focus,
.sc2-page textarea:focus,
.sc2-page select:focus {
    border-color: var(--primary-gold) !important;
    box-shadow: 0 0 12px rgba(251,191,36,0.25) !important;
    outline: none !important;
}

.sc2-page input::placeholder,
.sc2-page textarea::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.7;
}

/* Dash Dropdown - Target all Select components anywhere in page */
.Select-control {
    background: rgba(15,23,42,0.95) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 6px !important;
    color: var(--text-primary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.8rem !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 10px !important;
    transition: all 0.2s ease !important;
    box-shadow: none !important;
}

.Select-control:hover {
    border-color: var(--border-hover) !important;
}

.Select-control.is-focused,
.Select-control:focus,
.Select-control--is-focused {
    border-color: var(--primary-gold) !important;
    box-shadow: 0 0 8px rgba(251,191,36,0.3) !important;
    outline: none !important;
}

/* Selected value text */
.Select-value-label,
.Select-value {
    color: var(--primary-gold) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-weight: 500 !important;
    font-size: 0.78rem !important;
}

.Select-placeholder {
    color: var(--text-muted) !important;
    font-size: 0.76rem !important;
}

/* Dropdown arrow */
.Select-arrow {
    border-top-color: var(--text-muted) !important;
    width: 0 !important;
    height: 0 !important;
    border-left: 4px solid transparent !important;
    border-right: 4px solid transparent !important;
    border-top: 5px solid var(--text-muted) !important;
    margin-top: -2px !important;
}

.Select-arrow-zone {
    padding: 0 8px !important;
    width: 24px !important;
}

/* Dropdown menu container */
.Select-menu-outer {
    background: rgba(10,15,30,0.98) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: 6px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
    z-index: 99999 !important;
    max-height: 200px !important;
    overflow-y: auto !important;
    margin-top: 4px !important;
}

.Select-menu {
    max-height: 180px !important;
}

/* Dropdown options */
.Select-option {
    background: transparent !important;
    color: var(--text-secondary) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.76rem !important;
    padding: 8px 12px !important;
    border-bottom: 1px solid rgba(251,191,36,0.05) !important;
    transition: all 0.15s ease !important;
    cursor: pointer !important;
}

.Select-option:last-child {
    border-bottom: none !important;
}

.Select-option:hover,
.Select-option.is-hovered {
    background: rgba(251,191,36,0.15) !important;
    color: var(--primary-gold) !important;
}

.Select-option.is-selected {
    background: rgba(251,191,36,0.25) !important;
    color: var(--primary-gold) !important;
    font-weight: 500 !important;
}

/* Search input inside dropdown - CRITICAL FIX */
.Select-input {
    height: 26px !important;
    min-height: 26px !important;
    padding: 0 !important;
    margin: 0 !important;
}

.Select-input input {
    height: 26px !important;
    min-height: 26px !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.76rem !important;
    color: var(--text-primary) !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

.Select-input input:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* Fix search bar height and appearance */
.Select--single > .Select-control .Select-input {
    height: 28px !important;
}

.Select-input > input {
    padding: 0 !important;
    font-size: 0.74rem !important;
}

/* No results message */
.Select-noresults {
    color: var(--text-muted) !important;
    padding: 10px 12px !important;
    font-size: 0.76rem !important;
    font-style: italic !important;
}

/* Clear indicator (x button) */
.Select-clear-zone {
    width: 20px !important;
}

.Select-clear {
    color: var(--text-muted) !important;
    font-size: 14px !important;
}

.Select-clear:hover {
    color: var(--primary-gold) !important;
}

/* Dropdown with search - keep it compact */
.Select--searchable > .Select-control {
    height: 32px !important;
}

.sc2-page .Select-option:hover,
.sc2-page .Select-option.is-hovered {
    background: rgba(251,191,36,0.12) !important;
    color: var(--primary-gold) !important;
}

.sc2-page .Select-option.is-selected {
    background: rgba(251,191,36,0.2) !important;
    color: var(--primary-gold) !important;
    font-weight: 500 !important;
}

/* No options message */
.sc2-page .Select-noresults {
    color: var(--text-muted) !important;
    padding: 12px 14px !important;
    font-size: 0.8rem !important;
}

/* Input number specific styling */
.sc2-page input[type="number"] {
    -moz-appearance: textfield !important;
}

.sc2-page input[type="number"]::-webkit-outer-spin-button,
.sc2-page input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* Slider labels in dropdown context */
.sc2-page .rc-slider {
    padding: 8px 0 !important;
}

.sc2-page .rc-slider-rail {
    background: rgba(251,191,36,0.15) !important;
    height: 5px !important;
}

.sc2-page .rc-slider-track {
    background: var(--primary-gold) !important;
    height: 5px !important;
}

.sc2-page .rc-slider-handle {
    border-color: var(--primary-gold) !important;
    background: var(--bg-dark) !important;
    width: 18px !important;
    height: 18px !important;
}

.sc2-page .rc-slider-handle:hover,
.sc2-page .rc-slider-handle:active {
    box-shadow: 0 0 14px rgba(251,191,36,0.6) !important;
}

/* Radio buttons */
.sc2-page input[type="radio"] {
    accent-color: var(--primary-gold) !important;
    width: 16px !important;
    height: 16px !important;
    cursor: pointer !important;
}

/* Label styling to match theme */
.sc2-page label {
    color: var(--text-muted) !important;
    font-family: 'IBM Plex Sans', sans-serif !important;
    font-size: 0.72rem !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* Scrollbar styling for dropdown menus */
.sc2-page .Select-menu-outer::-webkit-scrollbar {
    width: 6px !important;
}

.sc2-page .Select-menu-outer::-webkit-scrollbar-track {
    background: rgba(15,23,42,0.5) !important;
    border-radius: 3px !important;
}

.sc2-page .Select-menu-outer::-webkit-scrollbar-thumb {
    background: var(--primary-gold) !important;
    border-radius: 3px !important;
}

/* Ensure all cards have proper overflow handling */
.sc2-card {
    overflow-x: hidden !important;
}

/* Responsive chart containers */
.dash-graph {
    width: 100% !important;
    overflow: hidden !important;
}

.dash-graph > div {
    width: 100% !important;
}

/* Force proper scaling on Plotly charts */
.js-plotly-plot .plotly .main-svg {
    max-width: 100% !important;
}

/* Mobile-specific dropdown fixes */
@media (max-width: 768px) {
    .Select-control {
        height: 36px !important;
        min-height: 36px !important;
        font-size: 0.84rem !important;
    }

    .Select-menu-outer {
        max-height: 180px !important;
    }

    .Select-option {
        padding: 10px 12px !important;
        font-size: 0.82rem !important;
    }

    .sc2-page input,
    .sc2-page textarea {
        font-size: 0.9rem !important;
        padding: 12px 14px !important;
    }
}

/* ============================================================
   CHART LEGEND & LABEL FIXES FOR MOBILE
   ============================================================ */

/* Make Plotly legends more compact */
.js-plotly-plot .plotly .legend {
    max-width: 100% !important;
    width: auto !important;
}

.js-plotly-plot .plotly .legend .legenditem {
    white-space: normal !important;
    font-size: 10px !important;
}

/* Legend items should wrap instead of expanding */
.js-plotly-plot .plotly .legend .legend-group {
    max-width: 100% !important;
}

/* On mobile, force legend to show below chart */
@media (max-width: 768px) {
    .js-plotly-plot .plotly .legend {
        orientation: horizontal !important;
        max-height: none !important;
        padding: 8px !important;
    }

    .js-plotly-plot .plotly .legend .legendlayer {
        max-width: 100% !important;
    }

    .js-plotly-plot .plotly .legend .legendgroup {
        display: inline-block !important;
        margin: 2px 8px 2px 0 !important;
    }
}

/* Fix tilted x-axis labels on mobile - make them horizontal */
@media (max-width: 768px) {
    .js-plotly-plot .plotly .xaxis .tick text,
    .js-plotly-plot .plotly .yaxis .tick text {
        transform: none !important;
        writing-mode: horizontal-tb !important;
        font-size: 9px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    /* Specifically for hub distance chart - reduce label spacing */
    #sc2-panel-hubs .js-plotly-plot .plotly .xaxis .tick text {
        font-size: 8px !important;
        max-width: 60px !important;
    }
}

/* Fix bar chart labels that may be rotated */
@media (max-width: 600px) {
    .js-plotly-plot .plotly .cartesian .tick text {
        transform: rotate(0deg) !important;
    }

    /* Remove 45 degree rotation from any text */
    .js-plotly-plot .plotly text[transform*="rotate"] {
        transform: none !important;
    }
}

/* Reduce chart margins on mobile */
@media (max-width: 768px) {
    .js-plotly-plot .plotly .main-svg {
        margin: 0 !important;
        padding: 0 !important;
    }

    .js-plotly-plot .plotly .modebar {
        display: none !important;
    }
}

/* Make sure graphs don't overflow container */
.dash-graph {
    overflow: hidden !important;
    max-width: 100% !important;
}

.dash-graph svg {
    max-width: 100% !important;
    overflow: hidden !important;
}

/* Fix x-axis label collision on smaller screens */
@media (max-width: 480px) {
    .js-plotly-plot .plotly .xaxis .tick:nth-child(n+3) text {
        display: none !important;
    }
}

/* ============================================================
   ADDITIONAL MOBILE CHART FIXES
   ============================================================ */

/* Force horizontal legend on all charts in specific panels */
#sc2-panel-forecast .js-plotly-plot .plotly .legend,
#sc2-panel-hubs .js-plotly-plot .plotly .legend {
    orientation: horizontal !important;
    max-width: 100% !important;
    width: 100% !important;
    padding: 4px !important;
}

#sc2-panel-forecast .js-plotly-plot .plotly .legend .legendlayer,
#sc2-panel-hubs .js-plotly-plot .plotly .legend .legendlayer {
    width: 100% !important;
}

#sc2-panel-forecast .js-plotly-plot .plotly .legend .legenditem,
#sc2-panel-hubs .js-plotly-plot .plotly .legend .legenditem {
    font-size: 9px !important;
    margin-right: 6px !important;
}

/* Hub chart specific - make x-axis labels readable */
#sc2-panel-hubs .js-plotly-plot .plotly .xaxis .tick text {
    font-size: 10px !important;
    white-space: normal !important;
    text-anchor: middle !important;
    transform: none !important;
    max-width: 100% !important;
    line-height: 1.2 !important;
    padding: 2px !important;
}

/* Hub chart bar labels - ensure they fit */
#sc2-panel-hubs .js-plotly-plot .plotly .bar text {
    font-size: 9px !important;
    text-anchor: middle !important;
}

/* Forecast chart x-axis - show fewer ticks on mobile */
@media (max-width: 600px) {
    #sc2-panel-forecast .js-plotly-plot .plotly .xaxis .tick text,
    #sc2-panel-hubs .js-plotly-plot .plotly .xaxis .tick text {
        font-size: 9px !important;
        transform: none !important;
    }

    #sc2-panel-forecast .js-plotly-plot .plotly .xaxis .tick:nth-child(odd) text,
    #sc2-panel-hubs .js-plotly-plot .plotly .xaxis .tick:nth-child(odd) text {
        display: none !important;
    }
}

/* Force chart SVG to respect container */
#sc2-panel-forecast .dash-graph svg,
#sc2-panel-hubs .dash-graph svg {
    max-width: 100% !important;
    width: 100% !important;
}

/* Hide annotations on very small screens if needed */
@media (max-width: 400px) {
    #sc2-panel-forecast .js-plotly-plot .plotly .annotation {
        display: none !important;
    }
}

/* Fix Plotly text elements that might be rotated */
.js-plotly-plot .plotly .gtitle,
.js-plotly-plot .plotly .xtitle,
.js-plotly-plot .plotly .ytitle {
    font-size: 10px !important;
}