@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(100px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideOut {
    from {
        opacity: 1;
        transform: translateX(0);
    }
    to {
        opacity: 0;
        transform: translateX(100px);
    }
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}


/* Quick-Add Ticker Bar */
.quick-add-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
    align-items: center;
}
.quick-add-pill {
    display: inline-flex;
    align-items: center;
    background: var(--card-bg);
    color: var(--accent);
    border-radius: 999px;
    border: 1px solid var(--accent);
    font-size: 13px;
    font-weight: 600;
    padding: 2px 12px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border 0.15s;
    margin: 2px 2px;
    user-select: none;
}
.quick-add-pill:hover, .quick-add-pill:focus {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}


/* Floating Run Button for Mobile */
/* Smaller floating run button for mobile */
.floating-run-btn {
    display: none;
    position: fixed;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, #6366f1 60%, #10b981 100%);
    color: #fff;
    border: none;
    border-radius: 24px;
    box-shadow: 0 2px 12px rgba(99,102,241,0.13);
    padding: 8px 20px;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    cursor: pointer;
    z-index: 9999;
    transition: background 0.18s, box-shadow 0.18s, transform 0.18s;
    outline: none;
    min-height: 38px;
}
.floating-run-btn:active {
    transform: translateX(-50%) scale(0.97);
    box-shadow: 0 1px 4px rgba(99,102,241,0.10);
}
@media (max-width: 600px) {
    .floating-run-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        padding: 8px 20px;
        font-size: 1rem;
        min-height: 38px;
        border-radius: 24px;
    }
    #runBtn {
        display: none !important;
    }
}
.score-rating-badge, .score-rating {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 28px;
  padding: 6px 10px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.9rem;
  line-height: 1;
  text-align: center;
  margin-left: 8px;
  color: var(--rating-text, #111827);
  background: var(--rating-bg, rgba(0,0,0,0.03));
  letter-spacing: 0.02em;
  box-shadow: 0 1px 2px rgba(16,24,40,0.04);
  transition: background-color 180ms ease, color 180ms ease, transform 120ms ease;
}

/* Color-coded rating badges */
.score-rating.rating-A, .score-rating-badge.rating-A, .rating-A { background: rgba(16,185,129,0.15); color: #065f46; border: 1px solid rgba(16,185,129,0.2); }
.score-rating.rating-B, .score-rating-badge.rating-B, .rating-B { background: rgba(59,130,246,0.14); color: #1e40af; border: 1px solid rgba(59,130,246,0.18); }
.score-rating.rating-C, .score-rating-badge.rating-C, .rating-C { background: rgba(245,158,66,0.12); color: #7c2d12; border: 1px solid rgba(245,158,66,0.16); }
.score-rating.rating-D, .score-rating-badge.rating-D, .rating-D { background: rgba(251,191,36,0.12); color: #92400e; border: 1px solid rgba(251,191,36,0.16); }
.score-rating.rating-F, .score-rating-badge.rating-F, .rating-F { background: rgba(239,68,68,0.14); color: #7f1d1d; border: 1px solid rgba(239,68,68,0.18); }
.ticker-suggestion-item strong {
    color: #111 !important;
}
.ticker-suggestion-item span {
    color: #111 !important;
}

/* Shared "On this page" block styling */
.score-example {
  background: var(--card-bg, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 12px;
  padding: 16px 18px;
  margin: 16px 0 24px;
}

.score-example strong {
  display: block;
  margin: 0 0 8px 0;
  color: var(--text, #111827);
}

.score-example ul {
  margin: 0;
  padding-left: 18px;
  color: var(--subtext, #6b7280);
  line-height: 1.6;
}

.score-example li {
  margin-bottom: 8px;
}

.score-example a {
  color: var(--accent, #6366f1);
  text-decoration: none;
  font-weight: 600;
}

.score-example a:hover {
  text-decoration: underline;
}

/* Momentum block styling */
.momentum-block {
  display: flex;
  gap: 12px;
  margin: 10px 0 8px 0;
  align-items: center;
}
.momentum-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-size: 13px;
}
.momentum-item .momentum-label {
  color: var(--subtext);
  font-size: 11px;
}
.momentum-item .momentum-value {
  font-weight: 700;
  font-size: 13px;
}
.momentum-item.momentum-null .momentum-value { color: var(--subtext); font-weight:600; }

/* Sparkline styles */
.score-sparkline { width: 120px; height: 32px; display: block; margin-top: 6px; }
.sparkline-svg { display: block; width: 100%; height: 100%; }

/* Tooltip for sparkline */
.sparkline-tooltip {
  background: rgba(17,24,39,0.95);
  color: #fff;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 12px;
  pointer-events: none;
  white-space: pre-line;
  box-shadow: 0 6px 20px rgba(2,6,23,0.3);
  z-index: 99999;
}

/* Shared on-page navigation block */
.on-page-nav {
  background: var(--card-bg, #fff);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: 12px;
  padding: 18px 20px;
  margin: 18px 0 32px;
}

.on-page-nav h3 {
  margin: 0 0 10px 0;
  font-size: 1rem;
  color: var(--subtext, #6b7280);
  letter-spacing: 0.01em;
}

.on-page-nav ul {
  list-style: disc;
  padding-left: 18px;
  margin: 0;
}

.on-page-nav a {
  color: var(--accent, #6366f1);
  text-decoration: none;
  font-weight: 600;
}

.on-page-nav a:hover {
  text-decoration: underline;
}
/* Skeleton Loading Styles */
.skeleton {
    background: linear-gradient(90deg, #e5e7eb 25%, #f3f4f6 50%, #e5e7eb 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.2s infinite linear;
    border-radius: 8px;
    min-height: 1em;
    color: transparent !important;
}
@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
.skeleton-card { height: 80px; margin-bottom: 16px; }
.skeleton-chart { height: 300px; margin-bottom: 24px; }
.skeleton-score { height: 60px; margin-bottom: 12px; }
#themeToggle {
    position: static;
    float: right;
    margin-top: 10px;
    margin-bottom: 0;
    margin-right: 0;
    padding: 0;
    width: 40px;
    height: 40px;
    font-size: 1.7rem;
    background: transparent;
    color: var(--text);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, background 0.18s cubic-bezier(.4,1.2,.4,1);
    cursor: pointer;
    outline: none;
    flex-shrink: 0;
}

/* Ensure user menu button matches theme toggle */
#userMenuBtn {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
}

#userAvatar {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
}

/* How It Works Button in Header */
.header-btn {
    padding: 8px 16px;
    margin-right: 12px;
    background: transparent;
    color: var(--accent, #6366f1);
    border: 1px solid var(--accent, #6366f1);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
}

.header-btn:hover {
    background: var(--accent, #6366f1);
    color: #ffffff !important;
    transform: translateY(-2px);
}

#themeToggle .theme-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.18s cubic-bezier(.4,1.2,.4,1);
}
#themeToggle .theme-icon svg {
    width: 28px;
    height: 28px;
    display: block;
}
#themeToggle.theme-sun .theme-icon {
    /* Sun icon */
    background: none;
    mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><circle cx="12" cy="12" r="5" fill="black"/><g stroke="black" stroke-width="2"><line x1="12" y1="1" x2="12" y2="4"/><line x1="12" y1="20" x2="12" y2="23"/><line x1="4.22" y1="4.22" x2="5.64" y2="5.64"/><line x1="18.36" y1="18.36" x2="19.78" y2="19.78"/><line x1="1" y1="12" x2="4" y2="12"/><line x1="20" y1="12" x2="23" y2="12"/><line x1="4.22" y1="19.78" x2="5.64" y2="18.36"/><line x1="18.36" y1="5.64" x2="19.78" y2="4.22"/></g></svg>') center/contain no-repeat;
    background-color: var(--accent);
}
#themeToggle.theme-moon .theme-icon {
    /* Moon icon */
    background: none;
    mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M21 12.79A9 9 0 1111.21 3a7 7 0 109.79 9.79z" fill="black"/></svg>') center/contain no-repeat;
    background-color: var(--accent);
}
#themeToggle.theme-system .theme-icon {
    /* System icon (half moon/half sun) */
    background: none;
    mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><defs><linearGradient id="g"><stop offset="50%" stop-color="black"/><stop offset="50%" stop-color="white"/></linearGradient></defs><circle cx="12" cy="12" r="10" fill="url(%23g)"/></svg>') center/contain no-repeat;
    background-color: var(--accent);
}
.highlight {
    background: var(--highlight-bg, #ffe066);
    color: var(--highlight-text, #222);
    border-radius: 2px;
    padding: 0 1px;
}

/* Ticker Suggestions Dropdown - Theme Adaptive */
#tickerSuggestions {
  position: absolute;
  z-index: 1000;
  background: var(--card-bg, #fff);
  border: 1px solid var(--border, #ccc);
  color: var(--text, #222);
  display: none;
  max-height: 180px;
  overflow-y: auto;
  font-size: 14px;
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.08);
  border-radius: 8px;
  transition: background 0.2s, color 0.2s, border 0.2s;
}
.ticker-suggestion-item {
  padding: 6px 10px;
  cursor: pointer;
  background: transparent;
  color: var(--text) !important;
  border: none;
  transition: background 0.15s, color 0.15s;
}
.ticker-suggestion-item strong {
  color: var(--text) !important;
  font-weight: 700;
}
.ticker-suggestion-item span {
  color: var(--subtext) !important;
  margin-left: 8px;
}
.ticker-suggestion-name {
  color: var(--subtext) !important;
  margin-left: 8px;
}

/* Ensure highlighted fragments inside suggestion items are visible (override inline/inherited colors) */
.ticker-suggestion-item .highlight {
  color: var(--highlight-text) !important;
  background: var(--highlight-bg) !important;
  border-radius: 2px;
  padding: 0 2px;
}
.ticker-suggestion-item.active,
.ticker-suggestion-item:hover,
.ticker-suggestion-item:focus {
  background: var(--suggestion-hover, #f3f4f6);
  color: var(--accent) !important;
  outline: none;
}
/* Ad placeholder styling (non-intrusive skeletons) */
.ad-placeholder {
    display: block;
    margin: 18px 0;
    padding: 10px 0;
    min-height: 60px;
    width: 100%;
    box-sizing: border-box;
}
.adsense-wrapper { max-width: 100%; margin: 12px 0; }
.adsense-wrapper .ad-skeleton { background: linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%); height: 64px; border-radius: 8px; }
.ad-sidebar { margin-bottom: 16px; }

/* Mobile sticky bottom banner — visible only on small screens */
.ad-sticky-mobile { display: none; }
@media (max-width: 768px) {
  .ad-sticky-mobile { display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 9999; padding: 8px; background: rgba(255,255,255,0.96); box-shadow: 0 -6px 24px rgba(2,6,23,0.12); }
  .ad-sticky-mobile .ad-placeholder { margin: 0; min-height: 60px; }
}

/* Sticky sidebar ad for desktop */
@media (min-width: 769px) {
  .ad-sidebar { position: -webkit-sticky; position: sticky; top: 80px; }
}

/* Recovering pill visual — subtle pulse to indicate recovery in progress */
@keyframes recovering-pulse {
  0% { box-shadow: 0 0 0 0 rgba(59,130,246,0.0); }
  50% { box-shadow: 0 0 12px 4px rgba(59,130,246,0.06); }
  100% { box-shadow: 0 0 0 0 rgba(59,130,246,0.0); }
}
.pill-trend-recovering {
  position: relative;
  animation: recovering-pulse 1.8s ease-in-out infinite;
  border-radius: 999px;
}
.combined-status-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: 11px;
  border-radius: 999px;
  background: rgba(59,130,246,0.08);
  color: #1e3a8a;
  font-weight: 700;
}

/* Pill loading shimmer (small low-opacity breathing/skeleton) */
.pill-loading .trend-container { min-height: 16px; display: inline-block; vertical-align: middle; }
.pill-loading-shimmer {
  background: linear-gradient(90deg, rgba(255,255,255,0.04) 25%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.04) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: 6px;
  height: 12px;
  width: 44px;
  display: inline-block;
}

.pill-removing { opacity: 0; transform: scale(0.96); }

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Header batch indicator (small pulse dot/spinner) */
.batch-indicator {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-left: 8px;
  vertical-align: middle;
  border-radius: 999px;
  background: transparent;
  opacity: 0;
  transition: opacity 160ms ease, transform 200ms ease;
}
.batch-indicator.active {
  background: linear-gradient(90deg, var(--accent) 0%, #10b981 100%);
  box-shadow: 0 0 8px rgba(99,102,241,0.16);
  opacity: 1;
  transform: scale(1.05);
  animation: batch-pulse 1.6s infinite ease-in-out;
}
@keyframes batch-pulse {
  0% { box-shadow: 0 0 0 0 rgba(99,102,241,0.06); }
  50% { box-shadow: 0 0 8px 4px rgba(99,102,241,0.06); }
  100% { box-shadow: 0 0 0 0 rgba(99,102,241,0.06); }
}
/* Trend badge + compact pill styles */
.trend-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  border-radius: 8px;
  font-size: 11px;
  line-height: 1;
  color: #cbd5e1;
}
/* ensure trend-container transitions opacity when swapped */
.trend-container { transition: opacity 300ms ease; opacity: 1; }

/* visually-hidden helper for accessibility */
.visually-hidden {
  position: absolute !important;
  height: 1px; width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
  border: 0; padding: 0; margin: -1px;
}
.trend-badge .sparkline { display:inline-block; vertical-align:middle; }
.trend-badge--improving { color: #10b981; }
.trend-badge--improving svg { color: #10b981; stroke: currentColor; }
.trend-badge--decaying { color: #ef4444; }
.trend-badge--decaying svg { color: #ef4444; stroke: currentColor; }
.trend-badge--stable { color: #94a3b8; }

/* Compact pill: smaller height, minimal text */
.ticker-pill--compact { padding: 6px 8px; min-width: 72px; display:inline-flex; align-items:center; gap:8px; }
.ticker-pill--compact .trend-container { margin-left:6px; }
.ticker-pill--compact .trend-badge { padding: 2px 4px; border-radius:6px; font-size:10px; }

/* Liquid glass pill enhancement */
.liquid-glass-pill {
  backdrop-filter: blur(6px);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.03);
  box-shadow: inset 0 1px 1px rgba(255,255,255,0.03);
}

/* Clickable pill hover effect */
.ticker-pill:hover { transform: translateY(-2px); transition: transform 0.12s ease; }
.dark .score-ticker {
  color: #fff;
}
/* Scoreboard Title spacing matches score-section */
.score-section-title {
    max-width: 1200px;
    margin: 0 auto 0 auto;
    padding: 20px 0 0 0;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: var(--accent);
    text-align: left;
    background: linear-gradient(90deg, var(--card-bg) 60%, transparent 100%);
    border-left: 5px solid var(--accent);
    border-radius: 0 8px 8px 0;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    padding-left: 18px;
    transition: color 0.2s, background 0.2s, box-shadow 0.15s, transform 0.15s cubic-bezier(.4,1.2,.4,1);
    will-change: transform, box-shadow;
}
.score-section-title:hover {
    transform: translateY(-2px) scale(1.01);
    box-shadow: 0 6px 24px 0 rgba(99,102,241,0.10), 0 2px 8px rgba(0,0,0,0.08);
}
/* Role display (replaces inline-styled HTML in app.js) */
.role-info { display: grid; gap: 6px; font-size: 12px; }
.role-row { display: flex; justify-content: space-between; }
.role-label { color: var(--subtext); }
.role-value { color: var(--text); font-weight: 600; }
/* Portfolio Optimizer Styles */


:root {
    --bg: #f5f7fa;
    --card-bg: rgba(255,255,255,0.55);
    --border: rgba(255,255,255,0.35);
    --text: #1f2937;
    --subtext: #6b7280;
    --accent: #6366f1;
    --radius: 16px;
    --shadow: 0 8px 24px rgba(0,0,0,0.06);
    --transition: 0.25s ease;
    --primary-color: #007bff;
    --secondary-color: #6c757d;
    --success-color: #28a745;
    --warning-color: #ffc107;
    --danger-color: #dc3545;
    --font-family: 'Inter', sans-serif;
    --suggestion-hover: #f3f4f6;
    --highlight-bg: #ffe066;
    --highlight-text: #222;
    --driver-label-color: #222;
}



.dark {
    --bg: #0f0f11;
    --card-bg: rgba(30,30,30,0.55);
    --border: rgba(255,255,255,0.08);
    --text: #f3f4f6;
    --subtext: #9ca3af;
    --accent: #818cf8;
    --shadow: 0 8px 24px rgba(0,0,0,0.45);
    --suggestion-hover: #2d3340;
    --highlight-bg: #2b007c;
    --highlight-text: #000000 !important;
    --driver-label-color: #f3f4f6;
}

/* Force opaque suggestion dropdown in dark theme for better contrast */
.dark #tickerSuggestions {
  background: rgba(18,18,20,0.96) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: 0 8px 30px rgba(0,0,0,0.6) !important;
  color: var(--text) !important;
}

/* Slightly stronger background in light mode to avoid washed-out contrast */
.light #tickerSuggestions {
  background: rgba(255,255,255,0.98) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
}

.light {
    --bg: #f5f7fa;
    --card-bg: rgba(255,255,255,0.55);
    --border: rgba(255,255,255,0.35);
    --text: #1f2937;
    --subtext: #6b7280;
    --accent: #6366f1;
    --shadow: 0 8px 24px rgba(0,0,0,0.06);
    --driver-label-color: #222;
}


/* Improve visibility of ticker suggestion colors on dark theme */
.dark #tickerSuggestions .ticker-suggestion-item span {
  color: var(--subtext) !important; /* use theme subtext for muted name */
}
.dark #tickerSuggestions .ticker-suggestion-item strong {
  color: var(--text) !important; /* ensure ticker symbol is very visible */
}

/* Theme enforcement: ensure components use CSS variables for theme-aware colors */
html, body {
  background: var(--bg) !important;
  color: var(--text) !important;
}
/* Ensure main app container inherits theme colors */
#app, .app-root, main, #content {
  background: transparent;
  color: inherit;
}
/* Ticker suggestion override to respect theme */
.ticker-suggestion-item strong, .ticker-suggestion-item span {
  color: var(--text) !important;
}
/* Links and accents */
a, .link, .accent { color: var(--accent) !important; }

* {
    box-sizing: border-box;
}


body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-family);
    transition: background var(--transition), color var(--transition);
  margin: 0;
  padding: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Small inline-like buttons replaced with CSS classes */
.small-btn {
  margin-left: 8px;
  font-size: 13px;
  padding: 4px 12px;
  border-radius: 6px;
  border: 1px solid var(--border, #ccc);
  background: var(--card-bg, #f5f7fa);
  color: var(--text, #222);
  cursor: pointer;
}
.save-btn {
  border: 1px solid var(--border, #6366f1);
  background: var(--card-bg, #eef2ff);
  color: var(--accent, #6366f1);
}

.scoreboard-empty { padding: 16px; text-align: center; color: var(--subtext); }

main.page-main {
  flex: 1;
  width: 100%;
}

/* Pages that already use .page wrappers should also flex to keep footer pinned */
.page {
  flex: 1;
  width: 100%;
}

/* ============================
     SHARED UTILITY CLASSES
     ============================ */

/* Button Styles */
.btn {
    padding: 10px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
}

.btn-primary {
    background: linear-gradient(135deg, var(--accent), #818cf8);
    color: white;
}

.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(99,102,241,0.3);
}

.btn-secondary {
    background: transparent;
    color: var(--accent);
    border: 2px solid var(--accent);
}

.btn-secondary:hover {
    background: rgba(99,102,241,0.05);
}

.btn-danger {
    background: transparent;
    color: #ef4444;
    border: 1px solid #ef4444;
}

.btn-danger:hover {
    background: rgba(239,68,68,0.05);
}

.btn-small {
    padding: 6px 12px;
    font-size: 12px;
}

.btn-full {
    width: 100%;
}

/* Layout Utilities */
.flex {
    display: flex;
}

.flex-col {
    flex-direction: column;
}

.items-center {
    align-items: center;
}

.items-start {
    align-items: flex-start;
}

.justify-between {
    justify-content: space-between;
}

.justify-center {
    justify-content: center;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-1 {
    flex: 1;
}

/* Gap Utilities */
.gap-4 {
    gap: 4px;
}

.gap-6 {
    gap: 6px;
}

.gap-8 {
    gap: 8px;
}

.gap-12 {
    gap: 12px;
}

.gap-16 {
    gap: 16px;
}

/* Spacing Utilities */
.m-0 {
    margin: 0;
}

.mt-8 {
    margin-top: 8px;
}

.mt-12 {
    margin-top: 12px;
}

.mt-16 {
    margin-top: 16px;
}

.mt-24 {
    margin-top: 24px;
}

.mt-32 {
    margin-top: 32px;
}

.mt-40 {
    margin-top: 40px;
}

.mt-60 {
    margin-top: 60px;
}

.mb-8 {
    margin-bottom: 8px;
}

.mb-12 {
    margin-bottom: 12px;
}

.mb-16 {
    margin-bottom: 16px;
}

.mb-24 {
    margin-bottom: 24px;
}

.mb-32 {
    margin-bottom: 32px;
}

.p-8 {
    padding: 8px;
}

.p-12 {
    padding: 12px;
}

.p-16 {
    padding: 16px;
}

.p-24 {
    padding: 24px;
}

.p-32 {
    padding: 32px;
}

.p-40 {
    padding: 40px;
}

.px-12 {
    padding-left: 12px;
    padding-right: 12px;
}

.px-16 {
    padding-left: 16px;
    padding-right: 16px;
}

.py-12 {
    padding-top: 12px;
    padding-bottom: 12px;
}

.py-16 {
    padding-top: 16px;
    padding-bottom: 16px;
}

/* Text Utilities */
.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-sm {
    font-size: 0.875rem;
}

.text-xs {
    font-size: 0.75rem;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

/* Border Utilities */
.rounded-4 {
    border-radius: 4px;
}

.rounded-6 {
    border-radius: 6px;
}

.rounded-8 {
    border-radius: 8px;
}

.rounded-12 {
    border-radius: 12px;
}

.rounded-16 {
    border-radius: 16px;
}

/* Component Classes */
.info-box {
    background: rgba(99,102,241,0.08);
    border-radius: 6px;
    padding: 8px;
    border-left: 2px solid var(--accent);
    line-height: 1.3;
}

.highlight-box {
    background: linear-gradient(135deg, rgba(99,102,241,0.08) 0%, rgba(16,185,129,0.04) 100%);
    border-radius: 16px;
    padding: 40px;
}

.content-box {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 40px;
}

.modal-content {
    background: var(--card-bg);
    border-radius: 12px;
    padding: 32px;
    max-width: 500px;
    width: 90%;
    max-height: 70vh;
    overflow-y: auto;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.3);
}

.portfolio-item {
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
}

.ticker-badge {
    padding: 4px 8px;
    background: var(--accent);
    color: white;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    box-shadow: 0 1px 2px rgba(0,0,0,0.1);
}

.ticker-badge .ticker-price {
  margin-left: 8px;
  background: rgba(255,255,255,0.12);
  color: #fff;
  padding: 2px 6px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
}

/* Live price shown inside ticker pills */
.ticker-pill { display: inline-flex; align-items: center; gap: 8px; padding: 6px 10px; background: var(--card-bg); border-radius: 8px; border: 1px solid var(--border); }
.ticker-pill .ticker-live-price { background: transparent; color: var(--subtext); font-weight: 700; font-size: 12px; margin-left: 6px; }
.ticker-pill.ticker-pill--spy { opacity: 0.9; }

.empty-state {
    text-align: center;
    padding: 32px 16px;
    color: var(--subtext);
}

/* Input Styles */
.input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--input-bg, var(--card-bg));
    color: var(--text);
    font-size: 14px;
    box-sizing: border-box;
}

.input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.1);
}

/* Back Button */
.back-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    margin-bottom: 18px;
    background: rgba(99,102,241,0.08);
    color: var(--accent);
    border: 1px solid rgba(99,102,241,0.25);
    border-radius: 10px;
    font-weight: 650;
    cursor: pointer;
    text-decoration: none;
    position: sticky;
    top: 18px;
    z-index: 50;
    backdrop-filter: blur(8px);
    transition: all 0.2s ease;
}

.back-btn:hover {
    background: rgba(99,102,241,0.14);
    border-color: var(--accent);
    transform: translateY(-1px);
}

.score-ticker {
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    color: #222;
    margin-bottom: 2px;
}

.score-ticker .score-ticker-price {
  margin-left: 8px;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--accent, #6366f1);
  background: rgba(99,102,241,0.08);
  padding: 2px 6px;
  border-radius: 6px;
  margin-left: 10px;
}

.score-value {
    font-size: 1.1rem;
    font-weight: 700;
    margin-top: 2px;
    letter-spacing: 0.5px;
}

/* Rating badge */
/* Rating badge with icon */
.score-card span[style*='background:#222'] {
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    border: 1px solid #444;
    font-family: 'Montserrat', Arial, sans-serif;
    text-shadow: 0 1px 2px rgba(0,0,0,0.08);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Status badge */
/* Status badge with icon */
.score-card span[style*='background:#2ECC71'],
.score-card span[style*='background:#BDC3C7'],
.score-card span[style*='background:#E74C3C'] {
    box-shadow: 0 2px 8px rgba(0,0,0,0.10);
    border: 1px solid rgba(0,0,0,0.08);
    font-family: 'Montserrat', Arial, sans-serif;
    text-shadow: 0 1px 2px rgba(0,0,0,0.08);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Score bar */
.score-card div[style*='height:8px'] {
    margin-top: 2px;
    margin-bottom: 2px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.07);
    background: linear-gradient(90deg, #e74c3c 0%, #e67e22 40%, #f1c40f 60%, #2ecc71 80%, #27ae60 100%);
    border: 1px solid rgba(0,0,0,0.04);
}

.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border-color);
}

.brand h1 {
    margin: 0;
    font-size: 2.5rem;
    font-weight: 700;
}

.brand p {
    margin: 5px 0 0 0;
    color: var(--secondary-color);
    font-size: 1.1rem;
}

/* Premium Fintech Header */
.app-header {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 0 0 var(--radius) var(--radius);
  backdrop-filter: blur(12px);
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: var(--shadow);
  max-width: 1200px;
  margin: 0 auto;
  transition: box-shadow 0.15s ease-out, transform 0.15s cubic-bezier(.4,1.2,.4,1), background 0.2s;
}

.header-left .brand {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.5px;
  background: linear-gradient(120deg, #0ea5e9 0%, #6366f1 50%, #0ea5e9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: all 0.3s ease;
  cursor: pointer;
  user-select: none;
  text-decoration: none;
  display: flex;
  align-items: center;
  outline: none;
}

/* Remove default anchor styles for .brand */
.header-left .brand:link,
.header-left .brand:visited,
.header-left .brand:active,
.header-left .brand:focus {
  color: inherit;
  text-decoration: none;
  outline: none;
}

.header-left .brand:hover {
  transform: scale(1.05);
  filter: brightness(1.1);
}

.header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Theme toggle + avatar icons */
.header-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  transition: background 0.2s, transform 0.15s;
  padding: 0;
}

.header-icon:hover {
  background: rgba(99, 102, 241, 0.08);
  transform: scale(1.05);
}

.header-icon:active {
  transform: scale(0.95);
}

.header-icon .avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

/* Login button for guest */
.login-btn {
  padding: 8px 16px;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.25);
}

.login-btn:hover {
  background: linear-gradient(90deg, #5558e3, #7c3aed);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.35);
}

.login-btn:active {
  transform: translateY(0);
}

/* Mobile responsive header */
@media (max-width: 768px) {
  .app-header {
    padding: 12px 14px;
  }
  
  .header-left .brand {
    font-size: 18px;
  }
  
  .header-right {
    gap: 10px;
  }
  
  .header-icon {
    width: 36px;
    height: 36px;
  }
  
  .header-icon .avatar {
    width: 32px;
    height: 32px;
  }
  
  .login-btn {
    padding: 7px 14px;
    font-size: 13px;
  }
}


/* Unified .card style for all cards */
.card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 20px;
    box-shadow: var(--shadow);
    transition: box-shadow 0.15s ease-out, transform 0.15s cubic-bezier(.4,1.2,.4,1), background 0.2s;
    will-change: transform, box-shadow;
}

.card:hover {
    transform: translateY(-4px) scale(1.012);
    box-shadow: 0 8px 32px 0 rgba(99,102,241,0.13), 0 2px 8px rgba(0,0,0,0.10);
    z-index: 2;
}

/* Ripple/Pulse effect for Run Optimization button */
#runBtn {
    position: relative;
    overflow: hidden;
    outline: none;
    transition: box-shadow 0.15s, background 0.15s;
}
#runBtn:active::after, #floatingRunBtn:active::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: 48px;
    height: 48px;
    background: rgba(99,102,241,0.18);
    border-radius: 50%;
    transform: translate(-50%, -50%) scale(0);
    animation: ripple-optimized 0.32s cubic-bezier(.4,0,.2,1);
    pointer-events: none;
    z-index: 1;
}
@keyframes ripple-optimized {
    0% {
        opacity: 0.5;
        transform: translate(-50%, -50%) scale(0);
    }
    70% {
        opacity: 0.18;
        transform: translate(-50%, -50%) scale(3.5);
    }
    100% {
        opacity: 0;
        transform: translate(-50%, -50%) scale(5.5);
    }
}
#runBtn:focus {
    box-shadow: 0 0 0 3px rgba(99,102,241,0.18);
}

.card h3 {
    margin-top: 0;
    font-size: 1.5rem;
    font-weight: 600;
}

label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
}

input[type="text"],
input[type="range"] {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    background-color: var(--bg-color);
    color: var(--text-color);
    font-size: 1rem;
}

input[type="checkbox"] {
    margin-right: 8px;
}


#themeToggle, button {
    background: linear-gradient(90deg, var(--accent) 60%, var(--primary-color) 100%);
    color: #fff;
    border: none;
    padding: 10px 24px;
    border-radius: 24px;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: background 0.3s, color 0.2s, box-shadow 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    outline: none;
}

button:hover, #themeToggle:hover {
    background: linear-gradient(90deg, var(--primary-color) 60%, var(--accent) 100%);
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

#themeToggle {
    position: static;
    float: right;
    margin-top: 10px;
    margin-bottom: 0;
    margin-right: 0;
    padding: 0;
    width: 40px;
    height: 40px;
    font-size: 1.7rem;
    background: transparent;
    color: var(--text);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, background 0.2s;
}

button:hover {
    background-color: #0056b3;
}

#tickerContainer, .ticker-box {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
    margin-bottom: 18px;
    padding: 10px 12px;
    background: linear-gradient(90deg, var(--card-bg) 80%, transparent 100%);
    border-radius: 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    min-height: 48px;
    align-items: center;
}

.ticker-pill {
    background: var(--accent);
    color: #fff;
    border-radius: 16px;
    padding: 6px 16px 6px 12px;
    font-size: 1rem;
    font-weight: 600;
    margin: 0 2px 2px 0;
    display: flex;
    align-items: center;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
    transition: background 0.2s, color 0.2s;
}
.ticker-pill .remove-pill {
    margin-left: 8px;
    cursor: pointer;
    color: #fff;
    font-size: 1.1em;
    font-weight: bold;
    opacity: 0.7;
    transition: opacity 0.2s, color 0.2s;
}
.ticker-pill .remove-pill:hover {
    opacity: 1;
    color: #ffb4b4;
}

.ticker-row {
    display: flex;
    gap: 10px;
    align-items: center;
}

.ticker-input {
    flex: 1;
}

.grid {
    display: grid;
    gap: 20px;
    margin-bottom: 20px;
}

/* Mobile-specific compact styles for ticker pills and trend badges */
@media (max-width: 640px) {
  /* Make ticker container horizontally scrollable to save vertical space */
  #tickerContainer {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
  }

  .ticker-pill {
    flex: 0 0 auto;
    padding: 6px 8px;
    min-width: 64px;
    align-items: center;
    gap: 6px;
    background: var(--card-bg);
    color: #fff; /* improve contrast on colored pills */
  }

  /* Compact trend: show only icon and tiny percent, shrink sparkline */
  .trend-badge { padding: 2px 4px; border-radius: 8px; display:inline-flex; align-items:center; gap:6px; }
  .trend-badge .text-xs { display: none; }
  .trend-badge .trend-pct { font-size: 11px; font-weight:700; }
  .trend-badge .sparkline svg { width: 22px; height: 8px; }

  /* Increase remove hit target for touch */
  .ticker-pill .remove-pill { margin-left: 8px; padding: 8px; min-width: 44px; min-height: 44px; display:inline-flex; align-items:center; justify-content:center; border-radius:8px; }

  /* Sticky run button already present; ensure it overlays content and is accessible */
  .floating-run-btn { bottom: 12px; left: 50%; transform: translateX(-50%); box-shadow: 0 6px 18px rgba(0,0,0,0.18); }

  /* Bottom sheet / toast for mobile metric details */
  .bottom-sheet-overlay { position: fixed; left:0; right:0; top:0; bottom:0; background: rgba(0,0,0,0.35); z-index: 10000; display:flex; align-items:flex-end; }
  .bottom-sheet { background: var(--card-bg); color: var(--text); border-top-left-radius: 12px; border-top-right-radius:12px; padding: 14px 16px; box-shadow: 0 -6px 30px rgba(0,0,0,0.2); width: 100%; max-width: 720px; margin: 0 auto; }
  .bottom-sheet .bs-title { font-weight:700; margin-bottom:6px; }
  .bottom-sheet .bs-body { font-size: 14px; color: var(--subtext); }
}

.grid-2 {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.portfolio-grid {
        grid-template-columns: 1fr 1fr;
}

@media (max-width: 700px) {
    .portfolio-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Unified .metric-card style for all metric cards */
.metric-card {
    text-align: center;
    padding: 15px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    transition: box-shadow 0.15s ease-out, transform 0.15s cubic-bezier(.4,1.2,.4,1), background 0.2s;
    will-change: transform, box-shadow;
}
.metric-card:hover {
    transform: translateY(-4px) scale(1.012);
    box-shadow: 0 8px 32px 0 rgba(99,102,241,0.13), 0 2px 8px rgba(0,0,0,0.10);
    z-index: 2;
}

.metric-label {
    font-size: 0.9rem;
    color: var(--secondary-color);
    margin-bottom: 5px;
}

.metric-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.chart-box {
  height: 300px;
  width: 100%;
  max-width: 420px; /* limit width so side-by-side pies stay visually consistent */
  margin: 0 auto; /* center within card */
  display: block;
  text-align: center;
}

footer {
  margin-top: 48px;
  background: linear-gradient(180deg, rgba(99,102,241,0.06) 0%, rgba(99,102,241,0.0) 24%, var(--card-bg) 100%);
  border-top: 1px solid var(--border);
  padding: 38px 20px 28px;
  color: var(--subtext);
  font-size: 0.92rem;
}

footer .footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 24px;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 24px 32px;
  align-items: flex-start;
  max-width: 1200px;
  margin: 0 auto;
}

footer a {
  color: var(--accent);
  text-decoration: none;
  font-weight: 550;
}

footer a:hover {
  text-decoration: underline;
}

.footer-brand p {
  margin: 0 0 6px 0;
  color: var(--text);
}

.footer-col h4 {
  margin: 0 0 12px 0;
  color: var(--text);
  font-size: 1rem;
  letter-spacing: -0.01em;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}

.footer-bottom {
  padding-top: 8px;
  font-size: 0.86rem;
  color: var(--subtext);
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
  line-height: 1.5;
  word-break: break-word;
}

.footer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  align-items: center;
  font-size: 0.85rem;
}

@media (max-width: 640px) {
  footer {
    padding: 32px 16px 24px;
  }
  footer .footer-inner {
    max-width: 100%;
    grid-template-columns: 1fr;
  }
  .footer-brand,
  .footer-col {
    text-align: left;
  }
  .footer-grid {
    grid-template-columns: 1fr;
  }
  .footer-bottom {
    text-align: left;
    line-height: 1.5;
    max-width: 100%;
    margin: 0;
    padding-left: 0;
    padding-right: 0;
  }
}

@media (max-width: 768px) {
  footer {
    margin-top: 32px;
    width: 100%;
  }
  footer .footer-inner {
    width: 100%;
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 0;
  }
  .footer-grid {
    width: 100%;
    margin: 0;
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .footer-col h4 {
    font-size: 0.95rem;
  }
  .footer-col ul {
    gap: 6px;
  }
  .footer-bottom {
    font-size: 0.82rem;
  }
}

@media (max-width: 480px) {
  footer {
    padding: 24px 14px 20px;
  }
  footer .footer-inner {
    gap: 16px;
  }
  .footer-grid {
    gap: 16px;
  }
  .footer-col h4 {
    margin-bottom: 8px;
  }
  .footer-bottom {
    font-size: 0.8rem;
  }
}

/* ============================
     SCORE CARD (GLASSMORPHISM 2.0)
     ============================ */

.score-section {
    max-width: 1200px;
    margin: 0 auto 32px auto;
    padding: 24px 0 24px 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    border-bottom: 1px solid rgba(99,102,241,0.07);
    border-top: 1px solid rgba(99,102,241,0.07);
    background: linear-gradient(90deg, var(--card-bg) 80%, transparent 100%);
}

@media (min-width: 900px) {
    .score-section {
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }
}

/* Unified .score-card style for all cards */
.score-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 22px;
    margin: 12px 0;
    border-radius: var(--radius);
    background: var(--card-bg);
    backdrop-filter: blur(14px);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    transition: transform var(--transition), box-shadow var(--transition);
}

.score-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.12);
}

.score-left {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.score-ticker {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.5px;
}

.score-rating-badge {
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 700;
  color: inherit;
    width: fit-content;
}

/* ============================
     SCORE BAR
     ============================ */

.score-right {
    width: 160px;
}

.score-value {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 6px;
    text-align: right;
}

.score-bar {
    width: 100%;
    height: 8px;
    background: rgba(0,0,0,0.08);
    border-radius: 6px;
    overflow: hidden;
}

.score-bar-fill {
    height: 100%;
    border-radius: 6px;
    transition: width 0.6s ease, background 0.4s ease;
}
.remove-pill:hover {
    color: #1e1b4b;
}

/* Input row (input + Add button) */
.ticker-input-row {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}

/* Input field styling */
.ticker-input {
    flex: 1;
    padding: 10px;
    border-radius: 12px;
    border: 1px solid var(--border, #d1d5db);
    font-size: 14px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.ticker-input:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
    outline: none;
}

.footer {
    max-width: 1100px;
    margin: 8px auto 40px;
    color: var(--subtext);
    font-size: 13px;
    text-align: center;
    padding: 8px 12px;
}

/* Financial Health Score Cards */


.score-ticker {
    font-weight: 600;
    font-size: 14px;
}

.score-value {
    font-size: 16px;
    font-weight: 700;
}

/* Explainability Layer Styles */
.score-section {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 16px 16px;
    margin: 0 auto 32px auto;
    max-width: 1200px;
    padding: 24px 0 24px 0;
    align-items: stretch;
    border-bottom: 1px solid rgba(99,102,241,0.07);
    border-top: 1px solid rgba(99,102,241,0.07);
    background: linear-gradient(90deg, var(--card-bg) 80%, transparent 100%);
}

.explain-card {
  background: var(--card-bg);
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: auto;
  justify-content: flex-start;
  border: 1px solid var(--border);
  transition: box-shadow 0.2s, border 0.2s;
}

.explain-card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  border: 1px solid var(--accent);
}

.explain-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  margin-bottom: 8px;
}

.explain-title {
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 1.05rem;
}

.driver-list li {
    margin-bottom: 4px;
    font-size: 1rem;
}

.driver-list-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
    font-size: 1.05rem;
}
.driver-list-item:last-child {
    margin-bottom: 0;
}
.driver-emoji {
    font-size: 1.2em;
    margin-right: 4px;
}
.driver-value {
    font-weight: 600;
    margin-right: 6px;
    min-width: 48px;
    display: inline-block;
}
.driver-label {
    color: var(--driver-label-color, #222);
}

/* Make explain-card info larger and more visually appealing */
.explain-header .ticker {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--accent);
  text-shadow: 0 1px 4px rgba(99,102,241,0.08);
}

.explain-header .rating {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  font-weight: 800;
  padding: 6px 16px;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10);
  gap: 0;
  min-width: 38px;
  letter-spacing: 1px;
}

.explain-header .rating::before {
  content: '\2605'; /* star icon */
  font-size: 1.2em;
  margin-right: 0;
  margin-left: 0;
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
}

.explain-header .rating span {
  display: inline-block;
  margin-left: 22px;
  margin-right: 0;
  font-size: 1.1em;
  font-weight: 900;
  text-align: center;
  width: 1.2em;
}

.explain-header .rating.rating-A::before { color: #16a34a; }
.explain-header .rating.rating-B::before { color: #4ade80; }
.explain-header .rating.rating-C::before { color: #facc15; }
.explain-header .rating.rating-D::before { color: #f97316; }
.explain-header .rating.rating-F::before { color: #dc2626; }

.score-row {
  margin-top: 8px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

.score-value {
  font-size: 2.1rem;
  font-weight: 800;
  color: var(--score-color, #222);
  letter-spacing: 1px;
  text-shadow: 0 1px 6px rgba(99,102,241,0.07);
  transition: color 0.2s;
}

.sector-badge {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 10px;
  background: rgba(99, 102, 241, 0.1);
  color: var(--accent);
  border-radius: 12px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.summary-block {
  margin: 12px 0;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.summary-text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text);
  font-weight: 400;
}

.insights-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 8px;
  margin: 4px 0;
}

.insight-item {
  padding: 10px 12px;
  background: var(--bg-subtle, #f3f4f6);
  border-radius: 6px;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-left: 3px solid #999;
}

.insight-label {
  font-size: 11px;
  color: var(--subtext, #6b7280);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.insight-value {
  font-size: 16px;
  font-weight: 700;
  color: var(--text, #1f2937);
}

.metric-context {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 2px 0;
}

.context-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  background: var(--bg-subtle, #f3f4f6);
  border-radius: 12px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text, #1f2937);
}

.data-quality-warning {
  padding: 10px 12px;
  background: #fef3c7;
  border-left: 3px solid #f59e0b;
  border-radius: 4px;
  font-size: 12px;
  color: #92400e;
  font-weight: 500;
}

/* Factor Breakdown Section */
.factor-breakdown {
  margin: 16px 0;
  padding: 12px;
  background: rgba(99, 102, 241, 0.05);
  border-radius: 6px;
  border: 1px solid rgba(99, 102, 241, 0.15);
}

.factor-breakdown-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.factor-bars {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.factor-bar-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.factor-name {
  min-width: 120px;
  font-size: 0.85em;
  font-weight: 600;
  color: var(--text-color);
}

.factor-bar-container {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
}

.factor-bar {
  height: 20px;
  border-radius: 3px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  position: relative;
  overflow: hidden;
  min-width: 2px;
}

.factor-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.15) 100%);
}

.factor-impact {
  min-width: 45px;
  font-size: 0.8em;
  font-weight: 700;
  color: var(--text-color);
  text-align: right;
}

.driver-metrics {
  font-size: 0.75rem;
  color: var(--subtext);
  margin-left: 24px;
  margin-top: 4px;
  font-style: italic;
}

.dark .score-value {
  --score-color: #f3f4f6;
}
.light .score-value {
  --score-color: #222;
}

.score-status {
  font-size: 1.1rem;
  font-weight: 700;
  margin-left: 12px;
  letter-spacing: 0.5px;
}

/* User menu dropdown styling */
.user-menu {
  position: absolute;
  right: 0;
  top: 48px;
  min-width: 280px;
  background: rgba(255, 255, 255, 0.98);
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 
    0 20px 60px rgba(0, 0, 0, 0.25),
    0 8px 24px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(255, 255, 255, 0.5) inset;
  overflow: hidden;
  z-index: 9999;
  animation: fadeIn 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.dark .user-menu {
  background: rgba(20, 20, 22, 0.98);
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 
    0 20px 60px rgba(0, 0, 0, 0.6),
    0 8px 24px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}

.user-menu__header {
  padding: 18px 16px;
  background: linear-gradient(
    135deg,
    rgba(59, 130, 246, 0.15),
    rgba(99, 102, 241, 0.12)
  );
  border-bottom: 1px solid var(--border);
}

.user-menu__name {
  font-weight: 600;
  font-size: 14px;
  color: var(--text);
}

.user-menu__email {
  font-size: 12px;
  color: var(--subtext);
  margin-top: 4px;
}

.user-menu__section {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--card-bg);
}

.user-menu__label {
  font-size: 12px;
  color: var(--subtext);
  margin-bottom: 6px;
}

.user-menu__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.user-menu__value {
  font-weight: 600;
  color: var(--text);
}

.user-menu__upgrade {
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 6px;
  background: var(--glass-bg);
  border: 1px solid var(--border);
  color: var(--subtext);
  opacity: 0.5;
  cursor: not-allowed;
}

.user-menu__limits {
  display: grid;
  gap: 6px;
  font-size: 12px;
}

.user-menu__limit-row {
  display: flex;
  justify-content: space-between;
  color: var(--subtext);
}

.user-menu__item {
  width: 100%;
  padding: 13px 16px;
  text-align: left;
  background: transparent;
  border: none;
  font-size: 14px;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  border-bottom: 1px solid var(--border);
  font-weight: 500;
}

.user-menu__item:hover {
  background: linear-gradient(90deg, rgba(59, 130, 246, 0.08), transparent);
  padding-left: 20px;
}

.user-menu__logout {
  color: #ef4444;
  border-bottom: none;
  font-weight: 600;
}

.user-menu__logout:hover {
  background: linear-gradient(90deg, rgba(239, 68, 68, 0.12), transparent);
  padding-left: 20px;
}

@keyframes fadeIn {
  from { 
    opacity: 0; 
    transform: translateY(-8px) scale(0.96);
  }
  to { 
    opacity: 1; 
    transform: translateY(0) scale(1);
  }
}

/* Mobile responsive styles */
@media (max-width: 768px) {
  /* Consistent sizing for theme toggle and user avatar */
  #themeToggle {
    width: 36px;
    height: 36px;
  }
  
  #userMenuBtn {
    width: 36px !important;
    height: 36px !important;
  }
  
  #userAvatar {
    width: 32px !important;
    height: 32px !important;
  }
  
  #themeToggle .theme-icon {
    width: 24px;
    height: 24px;
  }
  
  #themeToggle .theme-icon svg {
    width: 24px;
    height: 24px;
  }
  
  /* Smaller user name text */
  #userName {
    font-size: 13px !important;
  }
  
  /* Adjust user menu for mobile */
  .user-menu {
    min-width: 240px;
    right: -8px;
  }
  
  .user-menu__header {
    padding: 14px;
  }
  
  .user-menu__name {
    font-size: 13px;
  }
  
  .user-menu__email {
    font-size: 11px;
  }
  
  .user-menu__section {
    padding: 12px 14px;
  }
  
  .user-menu__item {
    padding: 11px 14px;
    font-size: 13px;
  }
  
  .user-menu__item:hover {
    padding-left: 18px;
  }
  
  .user-menu__logout:hover {
    padding-left: 18px;
  }
}

@media (max-width: 700px) {
  .portfolio-grid {
    grid-template-columns: 1fr !important;
  }
  .explain-header .ticker {
    font-size: 1.1rem;
  }
  .score-value {
    font-size: 1.4rem;
  }
  .explain-header .rating {
    font-size: 1rem;
    padding: 4px 10px;
    min-width: 30px;
  }
  .explain-header .rating span {
    margin-left: 18px;
    font-size: 1em;
  }
  .score-section {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 18px;
  }
}

/* ============================
   OPTIMIZED SCOREBOARD CARD
   ============================ */

.score-card-optimized {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 18px 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: transform 0.18s, box-shadow 0.18s;
    animation: fadeInUp 0.25s ease-out;
}

.score-card-optimized:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(99,102,241,0.12);
    border-color: var(--accent);
}

/* Header */
.score-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.score-left {
    flex: 1;
}

.score-ticker {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.score-sector {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--subtext);
    opacity: 0.85;
}

/* Score + Rating */
.score-right {
    text-align: right;
    flex-shrink: 0;
}

.score-value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--text);
    line-height: 1;
    margin-bottom: 6px;
}

.score-rating { /* keep compatibility - visual handled above */ }

/* Rating Colors (fallback for compact badges) */
.rating-A { background: #16a34a; color: #fff; }
.rating-B { background: #3b82f6; color: #fff; }
.rating-C { background: #facc15; color: #222; }
.rating-D { background: #f97316; color: #fff; }
.rating-F { background: #dc2626; color: #fff; }

/* Summary */
.score-summary {
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--text);
}

/* Insights Grid */
.score-insights {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 8px;
}

.score-insight-item {
    background: rgba(99,102,241,0.08);
    padding: 10px;
    border-radius: 8px;
    border-left: 3px solid var(--accent);
    transition: background 0.2s;
}

.score-insight-item:hover {
    background: rgba(99,102,241,0.12);
}

.score-insight-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--subtext);
    opacity: 0.75;
    margin-bottom: 4px;
}

.score-insight-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
}

.score-insight-explain {
    font-size: 13px;
    line-height: 1.4;
    color: var(--subtext);
    margin-top: 6px;
    opacity: 0.9;
}

/* Context Badges */
.score-context {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.context-badge-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.context-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: rgba(99,102,241,0.08);
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  width: fit-content;
}

.sector-icon { margin-right: 8px; font-size: 1.05rem; vertical-align: middle; }

.context-label { display: inline-block; }

/* Traffic-light severity indicator for context badges */
.context-light { width: 10px; height: 10px; border-radius: 50%; display: inline-block; margin-right: 8px; border: 1px solid rgba(0,0,0,0.06); }
.context-light.good { background: #10b981; box-shadow: 0 0 6px rgba(16,185,129,0.12); }
.context-light.neutral { background: #f59e0b; box-shadow: 0 0 6px rgba(245,158,11,0.12); }
.context-light.bad { background: #ef4444; box-shadow: 0 0 6px rgba(239,68,68,0.12); }

.context-badge-explain {
    font-size: 13px;
    line-height: 1.4;
    color: var(--subtext);
    padding-left: 2px;
    opacity: 0.9;
}

/* Factor Bars */
.score-factors {
    margin-top: 4px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.factor-item {
    display: grid;
    grid-template-columns: 120px 1fr 40px;
    align-items: center;
    gap: 10px;
}

/* .factor-bar-container {
    width: 100%;
    background: rgba(0,0,0,0.1);
    height: 8px;
    border-radius: 6px;
    overflow: hidden;
} */

.factor-bar-container {
    width: 100%;
    background: rgba(0,0,0,0.1);
    height: 8px;
    border-radius: 6px;
    overflow: hidden;
}


/* .factor-bar {
    height: 100%;
    border-radius: 6px;
    transition: width 0.4s ease;
} */
.factor-bar {
    height: 100%;
    border-radius: 6px;
    transition: width 0.4s ease;
    flex: 0 0 auto !important; /* prevent stretching */
    overflow: visible !important; /* prevent clipping */
}

/* Drivers */
.score-drivers {
    margin-top: 6px;
}

.drivers-title {
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 8px;
    color: var(--text);
}

.drivers-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.driver-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
}

.driver-emoji {
    font-size: 1rem;
    flex-shrink: 0;
}

.driver-value {
    font-weight: 700;
    min-width: 45px;
    color: var(--text);
}

.data-quality-warning {
    padding: 10px 12px;
    background: #fef3c7;
    border-left: 3px solid #f59e0b;
    border-radius: 4px;
    font-size: 12px;
    color: #92400e;
    font-weight: 500;
}

/* Mobile Adjustments for Scoreboard */
@media (max-width: 600px) {
    .score-card-optimized {
        padding: 16px 14px;
    }
    
    .score-insights {
        grid-template-columns: 1fr;
    }
    
    .score-insight-explain,
    .context-badge-explain {
        font-size: 12px;
    }
}
/* ============================
   AD SECTION STYLES (Premium Feel)
   ============================ */

.ad-section {
    width: 100%;
    margin: 48px 0 40px 0;
    padding: 0 20px;
    display: flex;
    justify-content: center;
}

.ad-placeholder {
    width: 100%;
    background: var(--card-bg);
    border: 2px dashed var(--border);
    border-radius: var(--radius);
    padding: 60px 40px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 120px;
    transition: all 0.3s ease;
    color: var(--subtext);
    font-size: 0.9rem;
    box-sizing: border-box;
}

.ad-placeholder:hover {
    background: rgba(99,102,241,0.04);
    border-color: var(--accent);
    box-shadow: 0 4px 12px rgba(99,102,241,0.08);
}

/* Support text */
.ad-support-text {
    font-size: 0.8rem;
    color: var(--subtext);
    text-align: center;
    margin: 16px 0;
    opacity: 0.75;
    font-weight: 500;
}

/* Bottom banner ad style */
.ad-banner {
    background: linear-gradient(135deg, rgba(99,102,241,0.08) 0%, rgba(16,185,129,0.04) 100%);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 20px 24px;
    margin: 32px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.ad-banner-content {
    flex: 1;
}

.ad-banner-title {
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--text);
    font-size: 0.95rem;
}

.ad-banner-text {
    font-size: 0.9rem;
    color: var(--subtext);
    line-height: 1.5;
}

.ad-banner-close {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.4rem;
    color: var(--subtext);
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, transform 0.2s;
    flex-shrink: 0;
}

.ad-banner-close:hover {
    color: var(--text);
    transform: scale(1.2);
}

@media (max-width: 600px) {
    .ad-section {
        margin: 32px auto 24px auto;
    }
    
    .ad-placeholder {
        padding: 40px 20px;
        min-height: 100px;
    }
    
    .ad-banner {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .ad-banner-close {
        align-self: flex-end;
    }
}

/* Premium sign-in CTA */
.ad-remove-cta {
    background: linear-gradient(90deg, var(--accent) 0%, #818cf8 100%);
    color: white;
    padding: 16px 24px;
    border-radius: 12px;
    border: none;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.95rem;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(99,102,241,0.3);
    white-space: nowrap;
}

.ad-remove-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(99,102,241,0.4);
}

.ad-remove-cta:active {
    transform: translateY(0);
}

/* Beginner-friendly scoreboard styles */
.score-card-optimized{background:var(--card-bg,#fff);border:1px solid var(--border,#e5e7eb);padding:12px;border-radius:8px;box-shadow:0 1px 0 rgba(16,24,40,0.03);margin-bottom:10px}
.top-decision{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.top-left .score-ticker{font-weight:700;font-size:14px}
.top-left .score-sector{font-size:12px;color:var(--subtext,#6b7280)}
.top-right{display:flex;flex-direction:column;align-items:flex-end}
.score-hero-number{display:flex;align-items:baseline;gap:8px}
.score-value{font-size:28px;font-weight:700;color:var(--accent,#0b69ff)}
.score-rating{background:var(--muted-bg,#f3f4f6);padding:4px 8px;border-radius:12px;font-size:12px}
.score-status{font-size:12px;color:var(--subtext,#6b7280)}
.one-line-takeaway{font-size:13px;color:var(--text,#374151);margin:8px 0}
.chips-section{display:flex;gap:12px;margin-bottom:8px}
.chips-col{flex:1}
.chips-title{font-size:12px;color:var(--subtext,#6b7280);margin-bottom:6px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{background:rgba(15,23,42,0.04);padding:6px 8px;border-radius:999px;font-size:12px}
.chip.positive{background:rgba(16,185,129,0.12);color:#065f46}
.chip.negative{background:rgba(239,68,68,0.08);color:#7f1d1d}
.factor-section.compact{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.factor-item{display:flex;justify-content:space-between;align-items:center;gap:12px}
.factor-label{font-size:12px;color:var(--subtext,#6b7280)}
.factor-bar{flex:1;height:8px;background:var(--muted-bg,#f3f4f6);border-radius:6px;margin:0 8px;position:relative;overflow:hidden}
.factor-fill{height:100%;background:linear-gradient(90deg,#06b6d4,#0ea5ff);border-radius:6px}
.factor-pct{width:40px;text-align:right;font-size:12px;color:var(--text,#374151)}
.badges-row{display:flex;gap:8px;margin:8px 0}
.badge{font-size:12px;padding:6px 8px;border-radius:6px;background:var(--muted-bg,#f3f4f6);color:var(--text,#374151)}
.impact-summary{margin:8px 0}
.impact-title{font-size:12px;color:var(--subtext,#6b7280);margin-bottom:6px}
.impact-list{margin:0;padding:0 0 0 18px;font-size:13px;color:var(--text,#374151)}
.impact-list li{margin:2px 0}
.recommendation{margin-top:8px;padding:8px;border-radius:6px;background:linear-gradient(180deg,rgba(6,182,212,0.04),transparent);font-size:13px}
.details-toggle{background:none;border:0;color:var(--accent,#0b69ff);cursor:pointer;padding:6px}

/* Allocation modal styles */
.alloc-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.65); display:flex; align-items:center; justify-content:center; z-index:10050; backdrop-filter: blur(4px); }
.alloc-modal { background:var(--card-bg); color:var(--text); width:720px; max-width:94%; border-radius:10px; box-shadow:0 8px 30px rgba(0,0,0,0.25); overflow:hidden; }
.alloc-modal-header { padding:18px 20px; border-bottom:1px solid rgba(0,0,0,0.06); }
.alloc-modal-header h3 { margin:0 0 6px 0; }
.alloc-modal-sub { color:var(--subtext); font-size:0.95rem; }
.alloc-modal-body { padding:16px 20px; max-height:60vh; overflow:auto; }
.alloc-field { margin-bottom:12px; }
.alloc-label { font-weight:600; margin-bottom:6px; }
.alloc-input { width:200px; padding:12px; border:1px solid rgba(0,0,0,0.08); border-radius:8px; font-size:1rem; font-weight:600; }
.alloc-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 6px 18px rgba(99,102,241,0.14); }
.alloc-input-wrap { display:flex; align-items:center; gap:8px; }
.alloc-currency { position:static; margin-left:0; margin-right:6px; font-weight:700; color:var(--subtext); pointer-events:none; }
.alloc-tip { color:var(--subtext); font-size:0.9rem; margin-top:6px; }
.alloc-result { display:flex; gap:18px; align-items:flex-start; margin-top:12px; }
.alloc-table { width:320px; border-collapse:collapse; background:transparent; }
.alloc-table th, .alloc-table td { text-align:left; padding:8px 6px; border-bottom:1px solid rgba(0,0,0,0.04); }
.alloc-table thead th { color:var(--subtext); font-weight:600; }
.alloc-table tfoot td { border-top:2px solid rgba(0,0,0,0.06); }
.alloc-bar-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.alloc-bar-label { width:70px; font-size:0.95rem; }
.alloc-bar-container { flex:1; background:rgba(0,0,0,0.06); height:12px; border-radius:6px; overflow:hidden; }
.alloc-bar { height:100%; background:var(--accent); }
.alloc-bar-pct { width:48px; text-align:right; font-weight:600; }
.alloc-explain { margin-top:14px; color:var(--subtext); font-size:0.95rem; }
.alloc-modal-footer { padding:12px 18px; display:flex; justify-content:flex-end; gap:10px; border-top:1px solid rgba(0,0,0,0.06); }
.allocate-btn { margin-top:10px; }

/* Light-theme tweaks: make allocation modal pop on light backgrounds */
.light .alloc-modal-overlay { background: rgba(0,0,0,0.58); }
.light .alloc-modal { background: #ffffff; border: 1px solid rgba(15,23,42,0.06); box-shadow: 0 14px 40px rgba(15,23,42,0.18); }
.light .alloc-modal-header { border-bottom-color: rgba(15,23,42,0.06); }
.light .alloc-table th, .light .alloc-table td { border-color: rgba(15,23,42,0.04); }

/* Mobile / small viewport tweaks for allocation modal */
@media (max-width: 600px) {
  .alloc-modal-overlay { align-items:flex-end; padding:12px; }
  .alloc-modal { width:100%; max-width:100%; border-radius:12px 12px 8px 8px; margin:0; max-height:calc(100vh - 40px); display:flex; flex-direction:column; }
  .alloc-modal-header { padding:14px 16px; }
  .alloc-modal-body { padding:12px 16px; max-height:calc(100vh - 160px); overflow:auto; }
  .alloc-input { width:100%; }
  .alloc-input-wrap { flex-direction:column; align-items:stretch; }
  .alloc-currency { margin-left:0; margin-bottom:6px; }
  .alloc-result { flex-direction:column; gap:12px; align-items:stretch; }
  .alloc-table { width:100%; }
  .alloc-table th, .alloc-table td { padding:10px 8px; }
  .alloc-bar-row { align-items:center; gap:10px; }
  .alloc-bar-label { width:auto; min-width:70px; }
  .alloc-bar-container { height:14px; }
  .alloc-bar-pct { width:56px; }
  .alloc-modal-footer { padding:12px 16px; justify-content:space-between; }
  .alloc-modal-footer .btn { width:48%; display:inline-flex; justify-content:center; align-items:center; }
}

/* Theme-aware semantic trend colors and liquid-glass pill styling */
:root {
  --trend-imp: #059669; /* Light default */
  --trend-dec: #e11d48;
  --trend-stable: #64748b;
}
@media (prefers-color-scheme: dark) {
  :root {
    --trend-imp: #34d399;
    --trend-dec: #fb7185;
    --trend-stable: #94a3b8;
  }
}

.ticker-pill {
  position: relative;
  overflow: visible;
  color: var(--text);
  transition: transform 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}
.ticker-pill::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 8px;
  pointer-events: none;
  z-index: 0;
}

/* Dark glass look */
@media (prefers-color-scheme: dark) {
  .ticker-pill { background: rgba(30,41,59,0.5); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,0.04); }
  .ticker-pill::before { background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.00)); }
}
/* Light glass look */
@media (prefers-color-scheme: light) {
  .ticker-pill { background: rgba(255,255,255,0.8); backdrop-filter: blur(14px); border: none; box-shadow: 0 10px 15px -3px rgba(0,0,0,0.08); }
  .ticker-pill::before { background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.2)); }
}

/* pill spark background container */
.pill-spark-bg { position: absolute; left: 6px; top: 50%; transform: translateY(-50%); width: 60px; height: 20px; z-index: 0; pointer-events: none; opacity: 0.95; }
.ticker-pill > span.pill-spark-bg + * { z-index: 1; }

/* Theme-adaptive tweaks for ticker pills to improve contrast and layout */
.ticker-pill {
  /* ensure sparkline doesn't overlap text */
  padding-left: 76px;
  min-height: 40px;
  align-items: center;
}

.ticker-pill .pill-spark-bg svg { width: 60px; height: 20px; display: block; }
.ticker-pill .pill-spark-bg svg polyline { vector-effect: non-scaling-stroke; stroke-linecap: round; stroke-linejoin: round; }

.ticker-pill .remove-pill {
  color: var(--subtext);
  background: transparent;
  border: none;
  padding: 6px;
  border-radius: 8px;
}
.ticker-pill .remove-pill:hover { background: rgba(0,0,0,0.04); color: var(--text); }

.ticker-pill .trend-badge { color: inherit; }
.ticker-pill .trend-badge .trend-pct { color: inherit; }

/* Make combined status badge subtly visible in both themes */
.combined-status-badge {
  margin-left: 8px;
  font-size: 11px;
  padding: 4px 6px;
  border-radius: 6px;
  align-self: center;
  color: var(--subtext);
  background: rgba(0,0,0,0.04);
  border: 1px solid transparent;
}

@media (prefers-color-scheme: dark) {
  .ticker-pill .remove-pill:hover { background: rgba(255,255,255,0.02); }
  .combined-status-badge { background: rgba(255,255,255,0.03); color: var(--subtext); }
}

@media (prefers-color-scheme: light) {
  .ticker-pill .remove-pill:hover { background: rgba(0,0,0,0.03); }
  .combined-status-badge { background: rgba(0,0,0,0.03); color: var(--subtext); }
}

/* Mobile adjustments: reduce left padding when space is tight */
@media (max-width: 640px) {
  .ticker-pill { padding-left: 56px; min-height: 36px; }
  .pill-spark-bg { left: 4px; width: 48px; }
  .ticker-pill .pill-spark-bg svg { width: 48px; height: 16px; }
}

/* Trend-based pill hover/interaction */
.pill-trend-improving:hover { transform: scale(1.02); border-color: var(--trend-imp); box-shadow: 0 6px 18px rgba(52,211,153,0.08); }
.pill-trend-decaying:hover { transform: scale(1.02); border-color: var(--trend-dec); box-shadow: 0 6px 18px rgba(251,113,133,0.08); }
.pill-trend-stable:hover { transform: scale(1.02); border-color: var(--trend-stable); box-shadow: 0 6px 18px rgba(148,163,184,0.06); }

/* subtle glow for dark theme to give liquid glass etched glow */
@media (prefers-color-scheme: dark) {
  .pill-trend-improving { box-shadow: 0 6px 20px rgba(52,211,153,0.06), 0 0 10px rgba(52,211,153,0.03) inset; border: 1px solid rgba(255,255,255,0.06); }
  .pill-trend-decaying { box-shadow: 0 6px 20px rgba(251,113,133,0.06), 0 0 10px rgba(251,113,133,0.03) inset; border: 1px solid rgba(255,255,255,0.06); }
  .pill-trend-stable { box-shadow: 0 6px 20px rgba(148,163,184,0.05); border: 1px solid rgba(255,255,255,0.06); }
  /* gradient fill peek for improving trend */
  .pill-trend-improving .pill-spark-bg svg polyline { stroke: var(--trend-imp); opacity: 1; }
  .pill-trend-decaying .pill-spark-bg svg polyline { stroke: var(--trend-dec); opacity: 1; }
}

/* light theme: use stronger saturated accents and shadows */
@media (prefers-color-scheme: light) {
  .pill-trend-improving { box-shadow: 0 6px 18px rgba(5,150,105,0.08); }
  .pill-trend-decaying { box-shadow: 0 6px 18px rgba(225,29,72,0.08); }
  .pill-trend-stable { box-shadow: 0 6px 18px rgba(100,116,139,0.06); }
}

/* Make ticker pill match add button accent on light theme for consistency */
@media (prefers-color-scheme: light) {
  .ticker-pill {
    background: var(--accent);
    color: #ffffff;
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 8px 20px rgba(2,6,23,0.06);
  }
  .ticker-pill .remove-pill { color: rgba(255,255,255,0.9); }
  .ticker-pill .trend-badge { color: rgba(255,255,255,0.95); }
  .ticker-pill .pill-spark-bg svg polyline { stroke: rgba(255,255,255,0.9); }
  .combined-status-badge { background: rgba(255,255,255,0.06); color: rgba(17,24,39,0.9); border: 1px solid rgba(0,0,0,0.04); }
}

/* hide metric label on very small phones to prioritize icon-only */
@media (max-width: 420px) {
  .trend-metric { display: none; }
  .trend-pct { font-size: 10px; }
}

/* trend badge simplified chevron + pct */
.trend-badge { display:inline-flex; align-items:center; gap:6px; z-index:2; }
.trend-badge .trend-pct { font-weight:700; font-size:11px; }
.trend-badge .text-xs { display:none; }
.trend-badge .sparkline { display:none; }
.trend-badge .font-bold { font-size: 12px; }

.trend-badge--improving { color: var(--trend-imp); }
.trend-badge--decaying { color: var(--trend-dec); }
.trend-badge--stable { color: var(--trend-stable); }

/* demo badge and combined status badge styling */
.pill-demo { opacity: 0.85; }
.pill-demo .demo-badge { margin-left:6px; background:rgba(255,255,255,0.06); color:var(--subtext); padding:2px 6px; border-radius:6px; font-size:10px; margin-left:8px; }
.combined-status-badge { margin-left:8px; font-size:11px; padding:4px 6px; border-radius:6px; background:rgba(0,0,0,0.06); color:var(--subtext); align-self:center; }

/* Improve visibility specifically for dark/night themes and high-contrast needs */
@media (prefers-color-scheme: dark) {
  /* make pill background slightly brighter and text stronger for legibility */
  .ticker-pill {
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    color: #e6eef8; /* light, high-contrast text */
    font-weight: 700;
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 6px 18px rgba(2,6,23,0.45);
  }

  /* ensure remove button remains visible but subtle */
  .ticker-pill .remove-pill { color: rgba(230,238,248,0.9); }

  /* stronger, yet soft, accent backgrounds for trend states so text sits on a legible surface */
  .pill-trend-improving { background: linear-gradient(180deg, rgba(52,211,153,0.06), rgba(52,211,153,0.02)); }
  .pill-trend-decaying { background: linear-gradient(180deg, rgba(251,113,133,0.06), rgba(251,113,133,0.02)); }
  .pill-trend-stable { background: linear-gradient(180deg, rgba(148,163,184,0.04), rgba(148,163,184,0.02)); }

  /* make sparkline strokes and icons clearer */
  .pill-spark-bg svg polyline { stroke-width: 1.6; opacity: 0.98; }

  /* make combined status badge slightly more prominent */
  .combined-status-badge { background: rgba(255,255,255,0.03); color: #dbeafe; border: 1px solid rgba(255,255,255,0.04); }
}

/* Optional: support an explicit "night" class on body for users who toggle a stronger dark theme */
body.theme-night .ticker-pill {
  background: rgba(10,14,20,0.7);
  color: #f3f7fb;
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 10px 22px rgba(2,6,23,0.6);
}
body.theme-night .combined-status-badge { background: rgba(255,255,255,0.02); color: #cfe8ff; }

/* Undo toast */
.undo-toast-container {
  position: fixed;
  left: 50%;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 78px); /* offset above quick-add row, respect device safe-area */
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 99999;
  width: auto;
  max-width: 920px;
}

/* High-specificity override: ensure ticker pills use accent background on light theme.
   Adds support for body.light / body.theme-light and a utility class `.force-accent`.
   Uses !important to defeat other broad cascade rules that may set translucent white backgrounds. */
body.light .ticker-pill,
body.theme-light .ticker-pill,
.light .ticker-pill,
.ticker-pill.force-accent {
  background: var(--accent) !important;
  color: #ffffff !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 8px 20px rgba(2,6,23,0.06) !important;
}
.ticker-pill.force-accent .pill-spark-bg svg polyline,
body.light .ticker-pill .pill-spark-bg svg polyline,
body.theme-light .ticker-pill .pill-spark-bg svg polyline { stroke: rgba(255,255,255,0.95) !important; }

.undo-toast {
  background: rgba(255,255,255,0.04);
  color: var(--text, #e6eef8);
  border-radius: 12px;
  padding: 10px 14px;
  box-shadow: 0 10px 30px rgba(2,6,23,0.35);
  display: inline-flex;
  gap: 12px;
  align-items: center;
  font-weight: 600;
  font-size: 13px;
  animation: toast-slide-up 260ms cubic-bezier(.22,.9,.35,1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.06);
}
.undo-toast .undo-btn {
  background: transparent;
  border: 0;
  color: var(--accent, #6366f1);
  font-weight: 700;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 8px;
}
.undo-toast .undo-btn:active { transform: scale(0.98); }

/* progress bar that shrinks left-to-right over the toast life */
.undo-progress {
  position: relative;
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
  overflow: hidden;
  margin-top: 6px;
}
.undo-progress-bar {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 100%;
  background: linear-gradient(90deg, rgba(99,102,241,0.9), rgba(16,185,129,0.9));
  transform-origin: left center;
  animation-name: undo-progress-shrink;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}

@keyframes undo-progress-shrink {
  from { transform: scaleX(1); }
  to { transform: scaleX(0); }
}

@keyframes toast-slide-up {
  from { transform: translateX(-50%) translateY(12px); opacity: 0; }
  to { transform: translateX(-50%) translateY(0); opacity: 1; }
}

/* Mobile tweaks: wider toast, larger bottom offset to account for nav bars and keyboard */
@media (max-width: 600px) {
  .undo-toast-container {
    width: 90%;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 80px);
    left: 50%;
    transform: translateX(-50%);
  }
  .undo-toast {
    width: 100%;
    max-width: none;
    padding: 12px 14px;
    border-radius: 12px;
    font-size: 15px;
  }
}

/* When an input is focused (mobile keyboard), push the toast further up */
.undo-toast-container.input-focused {
  bottom: calc(env(safe-area-inset-bottom, 0px) + 120px) !important;
}

/* Ad placeholder skeleton + slot styling (used by adsense-loader.js) */
.ad-section { margin: 32px 0; display:flex; justify-content:center; }
.adsense-wrapper { width:100%; max-width:728px; }
.ad-skeleton {
    background: linear-gradient(90deg, rgba(0,0,0,0.03) 25%, rgba(0,0,0,0.06) 37%, rgba(0,0,0,0.03) 63%);
    background-size: 400% 100%;
    animation: shimmer 1.6s linear infinite;
    border-radius: 8px;
    padding: 14px;
    text-align: center;
    color: rgba(0,0,0,0.6);
    font-size: 0.95rem;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
.adsense-slot { display: none; }
.adsense-slot[aria-hidden="false"] { display: block; }
.adsense-slot iframe { width: 100%; height: auto; border: 0; }

/* Show a skeleton for legacy placeholders when loader is disabled */
.ad-placeholder {
  width:100%;
  max-width:728px;
  margin: 0 auto;
  padding: 14px;
  border-radius: 8px;
  text-align: center;
  font-size: 0.95rem;
  color: rgba(0,0,0,0.6);
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  background: linear-gradient(90deg, rgba(0,0,0,0.03) 25%, rgba(0,0,0,0.06) 37%, rgba(0,0,0,0.03) 63%);
  background-size: 400% 100%;
  animation: shimmer 1.6s linear infinite;
}

/* Education page canonical styling (matches financial-health-score.html) */
main.page-main .article-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 60px 20px;
}

main.page-main .back-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  margin-bottom: 18px;
  background: rgba(99,102,241,0.08);
  color: var(--accent);
  border: 1px solid rgba(99,102,241,0.25);
  border-radius: 10px;
  font-weight: 650;
  cursor: pointer;
  text-decoration: none;
  position: sticky;
  top: 18px;
  z-index: 50;
  backdrop-filter: blur(8px);
  transition: all 0.2s ease;
}

main.page-main h1 {
  font-size: 2.5rem;
  font-weight: 700;
  margin: 0 0 16px 0;
  line-height: 1.2;
  background: linear-gradient(120deg, #0ea5e9 0%, #6366f1 50%, #0ea5e9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

main.page-main .article-intro {
  color: var(--subtext);
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 32px;
}

main.page-main h2 {
  font-size: 1.8rem;
  font-weight: 700;
  margin: 40px 0 20px 0;
  color: var(--text);
}

main.page-main h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 28px 0 12px 0;
  color: var(--text);
}

main.page-main p {
  font-size: 1rem;
  line-height: 1.8;
  margin: 0 0 16px 0;
  color: var(--text);
}

main.page-main ul, main.page-main ol {
  margin: 16px 0;
  padding-left: 24px;
}

main.page-main li { margin-bottom: 12px; line-height: 1.6; }

main.page-main .concept-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  margin: 20px 0;
}


/* Education Home button: match article back button styling and behavior */
nav[aria-label="Education navigation"] > a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  margin-bottom: 18px;
  background: rgba(99,102,241,0.08);
  color: var(--accent, #6366f1);
  border: 1px solid rgba(99,102,241,0.25);
  border-radius: 10px;
  font-weight: 650;
  text-decoration: none;
  position: sticky;
  top: 18px;
  z-index: 50;
  backdrop-filter: blur(8px);
  transition: all 0.2s ease;
}

nav[aria-label="Education navigation"] > a:hover,
nav[aria-label="Education navigation"] > a:focus {
  background: rgba(99,102,241,0.14);
  border-color: var(--accent, #6366f1);
  transform: translateY(-1px);
  outline: none;
}

nav[aria-label="Education navigation"] > a:focus-visible {
  box-shadow: 0 0 0 4px rgba(99,102,241,0.08);
  border-color: var(--accent, #6366f1);
}