/* ═══════════════════════════════════════════════════════════════════
   Andy Soccer · Mobile UI — Premium Design
   Emerald accent · Frosted glass · Layered depth · Native feel
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --m-safe-top: env(safe-area-inset-top, 0px);
  --m-safe-bottom: env(safe-area-inset-bottom, 0px);
  --m-tab-h: 56px;
  --m-hdr-h: 50px;

  /* Brand palette */
  --m-primary: #0a8f5c;
  --m-primary-light: #10b981;
  --m-primary-dark: #065f3e;
  --m-primary-glow: rgba(16, 185, 129, 0.25);
  --m-primary-soft: rgba(16, 185, 129, 0.08);
  --m-primary-muted: rgba(16, 185, 129, 0.04);

  /* Neutrals */
  --m-bg: #f2f2f7;
  --m-card: #ffffff;
  --m-card-hover: #fafafa;
  --m-border: rgba(0, 0, 0, 0.06);
  --m-border-strong: rgba(0, 0, 0, 0.1);
  --m-text: #1a1a2e;
  --m-text-secondary: #6b7280;
  --m-text-tertiary: #9ca3af;
  --m-text-inverse: #ffffff;

  /* Semantic */
  --m-green: #047857;
  --m-green-soft: rgba(5, 150, 105, 0.1);
  --m-red: #ef4444;
  --m-red-soft: rgba(239, 68, 68, 0.08);
  --m-amber: #f59e0b;
  --m-amber-soft: rgba(245, 158, 11, 0.08);
  --m-blue: #3b82f6;
  --m-blue-soft: rgba(59, 130, 246, 0.08);

  /* Radius */
  --m-r-sm: 10px;
  --m-r-md: 14px;
  --m-r-lg: 20px;
  --m-r-xl: 24px;
  --m-r-full: 999px;

  /* Shadows */
  --m-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.04), 0 0 0 1px rgba(0, 0, 0, 0.02);
  --m-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.06), 0 0 0 1px rgba(0, 0, 0, 0.03);
  --m-shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.02);
  --m-shadow-glow: 0 4px 20px rgba(16, 185, 129, 0.2);
}

/* ── Desktop: hide mobile elements ── */
.hamburger, .mobile-nav-overlay, .mobile-nav-drawer, .mobile-tab-bar {
  display: none;
}

@media (max-width: 768px) {

  /* ═══════════════════════════════════════
     Global
     ═══════════════════════════════════════ */
  html {
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
    overscroll-behavior-y: none;
  }
  body {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'PingFang SC', 'Helvetica Neue', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    color: var(--m-text) !important;
    background: var(--m-bg) !important;
    background-image: none !important;
    padding-bottom: calc(var(--m-tab-h) + var(--m-safe-bottom) + 8px) !important;
    min-height: 100dvh;
    -webkit-font-smoothing: antialiased;
  }
  .public-shell { width: 100% !important; padding: 0 !important; margin: 0 !important; max-width: none !important; }

  /* ═══════════════════════════════════════
     Top Bar — Frosted Glass
     ═══════════════════════════════════════ */
  .public-hero { padding: 0 !important; position: sticky; top: 0; z-index: 100; }
  .public-hero .hero-copy { display: none !important; }

  .topbar {
    height: var(--m-hdr-h) !important; min-height: var(--m-hdr-h) !important;
    margin: 0 !important; padding: 0 16px !important;
    border: none !important; border-bottom: 0.5px solid rgba(0, 0, 0, 0.06) !important;
    border-radius: 0 !important;
    background: rgba(255, 255, 255, 0.72) !important;
    backdrop-filter: saturate(180%) blur(20px) !important;
    -webkit-backdrop-filter: saturate(180%) blur(20px) !important;
    box-shadow: 0 0.5px 0 rgba(0, 0, 0, 0.03) !important;
    display: flex !important; flex-wrap: nowrap !important;
    align-items: center !important; gap: 10px !important;
  }
  .brand { gap: 10px !important; min-width: 0; flex-shrink: 0; }
  .brand-mark {
    width: 32px !important; height: 32px !important;
    font-size: 14px !important; border-radius: 9px !important;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    color: var(--ux-text) !important; font-weight: 800 !important;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3) !important;
  }
  .brand strong { font-size: 17px !important; font-weight: 800 !important; letter-spacing: -0.03em; color: var(--m-text); }
  .brand small { display: none !important; }
  .topbar .nav-tabs { display: none !important; }
  .topbar .nav-user { display: none !important; }

  /* Hamburger */
  .hamburger {
    display: flex !important; width: 38px; height: 38px;
    padding: 0; margin-left: auto; border: none;
    border-radius: var(--m-r-sm); background: rgba(0, 0, 0, 0.04);
    cursor: pointer; flex-shrink: 0; position: relative;
    align-items: center; justify-content: center;
  }
  .hamburger:active { background: rgba(0, 0, 0, 0.08); }
  .hamburger span {
    display: block; width: 18px; height: 2px;
    border-radius: 1px; background: var(--m-text);
    position: absolute; left: 50%;
    transform: translateX(-50%);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                opacity 0.15s ease, top 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  }
  .hamburger span:nth-child(1) { top: 12px; }
  .hamburger span:nth-child(2) { top: 18px; }
  .hamburger span:nth-child(3) { top: 24px; }
  .hamburger.open span:nth-child(1) { top: 18px; transform: translateX(-50%) rotate(45deg); }
  .hamburger.open span:nth-child(2) { opacity: 0; transform: translateX(-50%) scaleX(0); }
  .hamburger.open span:nth-child(3) { top: 18px; transform: translateX(-50%) rotate(-45deg); }

  /* ═══════════════════════════════════════
     Drawer
     ═══════════════════════════════════════ */
  .mobile-nav-overlay {
    display: block !important; position: fixed; inset: 0; z-index: 200;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease;
    backdrop-filter: blur(4px);
  }
  .mobile-nav-overlay.open { opacity: 1; pointer-events: auto; }

  .mobile-nav-drawer {
    display: flex !important; flex-direction: column;
    position: fixed; top: 0; right: 0; bottom: 0;
    width: min(300px, 82vw); z-index: 210;
    background: #fff;
    box-shadow: -8px 0 40px rgba(0, 0, 0, 0.15);
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
    overflow-y: auto; overscroll-behavior: contain;
  }
  .mobile-nav-drawer.open { transform: translateX(0); }

  .mobile-nav-drawer-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: calc(var(--m-safe-top) + 20px) 20px 16px;
    border-bottom: 0.5px solid rgba(0, 0, 0, 0.06);
  }
  .mobile-nav-drawer-header strong { font-size: 20px; font-weight: 800; letter-spacing: -0.03em; }
  .mobile-nav-drawer-close {
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%; border: none;
    background: rgba(0, 0, 0, 0.06); cursor: pointer;
    color: var(--m-text-secondary); font-size: 14px;
    transition: background 0.15s;
  }
  .mobile-nav-drawer-close:active { background: rgba(0, 0, 0, 0.12); }
  .mobile-nav-drawer .nav-section-label {
    padding: 20px 20px 8px;
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--m-text-tertiary);
  }
  .mobile-nav-drawer a {
    display: flex; align-items: center; gap: 14px;
    padding: 13px 20px; font-size: 16px; font-weight: 500;
    color: var(--m-text); transition: all 0.15s;
    border-radius: 0; margin: 0;
  }
  .mobile-nav-drawer a:active { background: rgba(0, 0, 0, 0.03); }
  .mobile-nav-drawer a.active {
    color: var(--m-primary); font-weight: 600;
    background: var(--m-primary-muted);
  }
  .mobile-nav-drawer hr { margin: 8px 20px; border: none; border-top: 0.5px solid rgba(0, 0, 0, 0.06); }

  /* ═══════════════════════════════════════
     Tab Bar — Native iOS
     ═══════════════════════════════════════ */
  .mobile-tab-bar {
    display: flex !important;
    position: fixed; bottom: 0; left: 0; right: 0;
    height: calc(var(--m-tab-h) + var(--m-safe-bottom));
    padding-bottom: var(--m-safe-bottom);
    z-index: 100;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: saturate(200%) blur(24px);
    -webkit-backdrop-filter: saturate(200%) blur(24px);
    border-top: 0.5px solid rgba(0, 0, 0, 0.08);
  }
  .mobile-tab-bar a {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 3px;
    padding: 8px 0 4px;
    color: #86868b; font-size: 11px; font-weight: 500;
    text-decoration: none; user-select: none;
    transition: color 0.2s;
  }
  .mobile-tab-bar a svg {
    width: 24px; height: 24px; stroke-width: 1.7;
    transition: all 0.2s;
  }
  .mobile-tab-bar a.active { color: var(--m-primary); font-weight: 600; }
  .mobile-tab-bar a.active svg { stroke-width: 2.4; transform: scale(1.06); }

  /* ═══════════════════════════════════════
     App Main
     ═══════════════════════════════════════ */
  .app-main { padding: 0 !important; gap: 0 !important; }

  /* ═══════════════════════════════════════
     m-hero — Gradient Hero
     ═══════════════════════════════════════ */
  .m-hero {
    position: relative;
    padding: 32px 20px 28px;
    background: linear-gradient(165deg, #ecfdf5 0%, #f0fdf4 40%, #f8fafc 100%);
    overflow: hidden;
  }
  .m-hero::before {
    content: '';
    position: absolute; top: -40%; right: -20%;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
  }
  .m-hero::after {
    content: '';
    position: absolute; bottom: -30%; left: -10%;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.06) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
  }

  .m-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 12px; border-radius: var(--m-r-full);
    font-size: 12px; font-weight: 600;
    background: rgba(255, 255, 255, 0.8);
    color: var(--m-primary);
    border: 1px solid rgba(16, 185, 129, 0.2);
    backdrop-filter: blur(8px);
    position: relative;
  }
  .m-hero .m-badge,
  .m-header-meta .m-badge {
    margin-bottom: 16px;
  }
  .m-status-top .m-badge,
  .m-pred-top .m-badge {
    margin-bottom: 0;
  }
  .m-badge svg { width: 12px; height: 12px; stroke: var(--m-primary); }

  .m-hero h1 {
    font-size: 28px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.04em !important;
    margin: 0 0 10px;
    color: var(--m-text);
    position: relative;
  }
  .m-hero p {
    font-size: 15px;
    color: var(--m-text-secondary);
    line-height: 1.6;
    margin: 0 0 20px;
    position: relative;
  }
  .m-hero-actions {
    display: flex; gap: 10px;
    position: relative;
  }
  .m-hero-actions .m-btn { flex: 1; }

  /* ═══════════════════════════════════════
     Buttons
     ═══════════════════════════════════════ */
  .m-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 6px; height: 48px; padding: 0 20px;
    border-radius: var(--m-r-md);
    font-size: 15px; font-weight: 600;
    border: none; cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    text-decoration: none; position: relative; overflow: hidden;
  }
  .m-btn:active { transform: scale(0.97); }
  .m-btn-primary {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35), 0 1px 3px rgba(0, 0, 0, 0.1);
  }
  .m-btn-primary:active {
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.25);
  }
  .m-btn-ghost {
    background: rgba(255, 255, 255, 0.8);
    color: var(--m-text);
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: var(--m-shadow-sm);
    backdrop-filter: blur(8px);
  }
  .m-btn-ghost:active { background: rgba(0, 0, 0, 0.04); }
  .m-btn-block { width: 100%; }
  .m-btn-sm { height: 38px; font-size: 14px; padding: 0 16px; border-radius: var(--m-r-sm); }

  .m-btn-icon {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--m-r-sm);
    border: 1px solid var(--m-border, #dfe5ee);
    background: var(--m-card, #fff); cursor: pointer;
    font-size: 16px; transition: all 0.15s;
    color: var(--m-text-secondary, #536171);
  }
  .m-btn-icon:active { background: rgba(0, 0, 0, 0.08); transform: scale(0.95); }
  .m-btn-icon.active { background: var(--m-primary-soft); color: var(--m-primary); }

  .m-link {
    color: var(--m-primary); font-size: 14px; font-weight: 600;
    text-decoration: none; transition: opacity 0.15s;
  }
  .m-link:active { opacity: 0.6; }

  /* ═══════════════════════════════════════
     Status Card — Live Indicator
     ═══════════════════════════════════════ */
  .m-status-card {
    margin: 12px 16px 14px;
    padding: 16px 18px;
    background: var(--m-card);
    border-radius: var(--m-r-lg);
    box-shadow: var(--m-shadow-md);
    border: 1px solid rgba(0, 0, 0, 0.06);
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    overflow: hidden;
  }
  .m-status-card::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, #10b981 0%, #3b82f6 50%, #8b5cf6 100%);
    opacity: 0.8;
  }
  .m-status-card:active { transform: scale(0.98); box-shadow: var(--m-shadow-sm); }

  .m-status-top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
  }
  .m-status-tag {
    font-size: 12px; font-weight: 600;
    padding: 4px 10px; border-radius: var(--m-r-full);
    background: var(--m-bg); color: var(--m-text-secondary);
  }
  .m-status-tag.ready {
    background: var(--m-green-soft); color: var(--m-green);
  }
  .m-status-league {
    font-size: 12px; color: var(--m-text-tertiary);
    font-weight: 500; margin-bottom: 6px;
    text-transform: uppercase; letter-spacing: 0.04em;
  }
  .m-status-match h3 {
    font-size: 20px; font-weight: 800; margin: 0;
    letter-spacing: -0.02em;
  }
  .m-status-match h3 em {
    font-style: normal; color: var(--m-text-tertiary);
    font-weight: 400; font-size: 14px; margin: 0 6px;
  }
  .m-status-meta {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1px; margin-top: 14px;
    background: rgba(0, 0, 0, 0.04);
    border-radius: var(--m-r-sm);
    overflow: hidden;
  }
  .m-status-meta div {
    background: var(--m-card); text-align: center;
    padding: 10px 4px;
  }
  .m-status-meta span {
    font-size: 11px; color: var(--m-text-tertiary);
    display: block; font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.04em;
  }
  .m-status-meta strong { font-size: 13px; font-weight: 700; display: block; margin-top: 2px; }
  .m-status-empty p { font-size: 14px; color: var(--m-text-tertiary); margin: 0; line-height: 1.6; }

  /* ═══════════════════════════════════════
     Stats Row — Glassmorphism Pills
     ═══════════════════════════════════════ */
  .m-stats-row {
    display: flex; gap: 8px;
    padding: 0 16px; margin-bottom: 14px;
  }
  .m-stat-pill {
    flex: 1; text-align: center;
    padding: 14px 8px 12px;
    background: var(--m-card);
    border-radius: var(--m-r-md);
    box-shadow: var(--m-shadow-sm);
    border: 0.5px solid var(--m-border);
    position: relative;
  }
  .m-stat-pill strong {
    display: block; font-size: 22px;
    font-weight: 800; letter-spacing: -0.03em;
    line-height: 1;
  }
  .m-stat-pill span {
    font-size: 11px; color: var(--m-text-tertiary);
    font-weight: 500; text-transform: uppercase;
    letter-spacing: 0.06em; display: block; margin-top: 4px;
  }
  .m-stat-pill.good strong { color: var(--m-green); }
  .m-stat-pill.good::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--m-green); border-radius: var(--m-r-md) var(--m-r-md) 0 0;
  }
  .m-stat-pill.bad strong { color: var(--m-red); }
  .m-stat-pill.bad::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--m-red); border-radius: var(--m-r-md) var(--m-r-md) 0 0;
  }

  /* ═══════════════════════════════════════
     Section Layout
     ═══════════════════════════════════════ */
  .m-section { padding: 0 16px; margin-bottom: 4px; padding-bottom: 16px; }
  .m-section + .m-section { border-top: 0.5px solid rgba(0,0,0,0.04); padding-top: 16px; }
  .m-section-alt {
    padding: 20px 16px; margin-bottom: 20px;
    background: linear-gradient(180deg, rgba(16, 185, 129, 0.03) 0%, rgba(16, 185, 129, 0.01) 100%);
  }
  .m-section-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px; gap: 8px;
  }
  .m-section-head h2 {
    font-size: 14px !important; font-weight: 700 !important;
    letter-spacing: -0.01em; margin: 0;
    color: var(--m-text-secondary);
  }
  .m-section-desc {
    font-size: 12px; color: var(--m-text-tertiary);
    line-height: 1.5; margin-top: 2px;
  }

  /* ═══════════════════════════════════════
     List Items — Schedule
     ═══════════════════════════════════════ */
  .m-list-group {
    background: var(--m-card);
    border-radius: var(--m-r-md);
    overflow: hidden;
    box-shadow: var(--m-shadow-sm);
  }
  .m-list-item {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; padding: 14px 16px;
    background: var(--m-card);
    cursor: pointer; transition: all 0.15s;
    border-left: 3px solid transparent;
  }
  .m-list-group .m-list-item { border-radius: 0; }
  .m-list-item:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0; }
  .m-list-item:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md); }
  .m-list-item:only-child { border-radius: var(--m-r-md); }
  .m-list-item + .m-list-item { border-top: 0.5px solid var(--m-border); }
  .m-list-item:active { background: var(--m-card-hover); border-left-color: var(--m-primary); }
  .m-list-left { min-width: 0; flex: 1; }
  .m-list-primary {
    font-size: 15px; font-weight: 700;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    letter-spacing: -0.01em;
  }
  .m-list-secondary { font-size: 12px; color: var(--m-text-tertiary); margin-top: 3px; }
  .m-list-time {
    font-size: 12px; font-weight: 600; color: var(--m-text-secondary);
    white-space: nowrap; flex-shrink: 0;
    padding: 4px 10px; background: var(--m-bg);
    border-radius: var(--m-r-sm);
  }
  .m-vs {
    font-size: 12px; font-weight: 500;
    color: var(--m-text-tertiary); margin: 0 3px;
    padding: 1px 6px; background: rgba(0, 0, 0, 0.04);
    border-radius: 4px;
  }
  .m-section-cta { margin-top: 14px; }

  /* ═══════════════════════════════════════
     Result Cards
     ═══════════════════════════════════════ */
  .m-result-card {
    padding: 16px 18px;
    background: var(--m-card);
    cursor: pointer; transition: all 0.15s;
    border-left: 3px solid transparent;
  }
  .m-result-card:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0; }
  .m-result-card:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md); }
  .m-result-card:only-child { border-radius: var(--m-r-md); }
  .m-result-card + .m-result-card { border-top: 0.5px solid var(--m-border); }
  .m-result-card:active { background: var(--m-card-hover); }

  .m-result-top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px;
  }
  .m-league {
    font-size: 12px; font-weight: 600;
    color: var(--m-text-tertiary);
    text-transform: uppercase; letter-spacing: 0.05em;
    padding: 3px 8px; background: var(--m-bg);
    border-radius: 6px;
  }
  .m-time { font-size: 12px; color: var(--m-text-tertiary); }

  .m-result-card .m-result-teams,
  .m-pred-teams {
    font-size: 17px; font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
  }
  .m-result-score {
    font-size: 22px; font-weight: 800;
    margin: 0;
    letter-spacing: -0.02em;
    flex-shrink: 0;
  }

  .m-legs-row { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
  .m-leg-tag {
    padding: 5px 11px; border-radius: 8px;
    font-size: 12px; font-weight: 600;
    background: var(--m-bg); color: var(--m-text);
    border: 1px solid rgba(0, 0, 0, 0.04);
  }
  .m-leg-tag.win {
    color: var(--m-green); background: var(--m-green-soft);
    border-color: rgba(5, 150, 105, 0.15);
  }
  .m-leg-tag.lose {
    color: var(--m-red); background: var(--m-red-soft);
    border-color: rgba(239, 68, 68, 0.12);
  }

  .m-result-bottom {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 10px; padding-top: 10px;
    border-top: 0.5px solid var(--m-border);
  }
  .m-result-pnl { font-size: 15px; font-weight: 800; letter-spacing: -0.01em; flex-shrink: 0; }
  .m-result-pnl.positive { color: var(--m-green); }
  .m-result-pnl.negative { color: var(--m-red); }

  .m-result-icon {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 10px; font-weight: 800; font-size: 14px; flex-shrink: 0;
  }
  .m-result-icon.win { background: var(--m-green-soft); color: var(--m-green); }
  .m-result-icon.lose { background: var(--m-red-soft); color: var(--m-red); }
  .m-result-left { display: flex; align-items: center; gap: 14px; min-width: 0; flex: 1; }
  .m-result-meta { font-size: 12px; color: var(--m-text-tertiary); margin-top: 3px; }

  /* ═══════════════════════════════════════
     Prediction Cards — Expandable
     ═══════════════════════════════════════ */
  .m-pred-card {
    padding: 16px 18px;
    background: var(--m-card);
    cursor: pointer; transition: all 0.2s;
    border-left: 3px solid transparent;
  }
  .m-pred-card:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0; }
  .m-pred-card:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md); }
  .m-pred-card:only-child { border-radius: var(--m-r-md); }
  .m-pred-card + .m-pred-card { border-top: 0.5px solid var(--m-border); }
  .m-pred-card:active { background: var(--m-card-hover); }
  .m-pred-card.expanded { border-left-color: var(--m-primary); background: #fafbfc; }

  .m-pred-top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 8px;
  }
  .m-pred-teams { font-size: 17px; font-weight: 800; margin-bottom: 6px; letter-spacing: -0.02em; }
  .m-pred-teams .m-vs { font-size: 12px; color: var(--m-text-tertiary); font-weight: 500; }

  .m-pred-row {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    margin-top: 8px;
  }
  .m-choice {
    padding: 5px 12px; border-radius: var(--m-r-full);
    font-size: 13px; font-weight: 700;
    letter-spacing: -0.01em;
  }
  .m-choice.pick {
    background: var(--m-green-soft); color: var(--m-green);
    border: 1px solid rgba(5, 150, 105, 0.2);
  }
  .m-choice.wait {
    background: var(--m-amber-soft); color: #b45309;
    border: 1px solid rgba(245, 158, 11, 0.2);
  }

  .m-expand-hint {
    font-size: 12px; color: var(--m-primary);
    margin-top: 8px; font-weight: 500;
  }

  .m-card-detail {
    max-height: 0; overflow: hidden;
    transition: max-height 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: max-height;
    margin-top: 0;
  }
  .m-pred-card.expanded .m-card-detail {
    max-height: 700px; margin-top: 12px;
  }
  .m-pred-card.expanded .m-expand-hint { display: none; }

  .m-card-detail-link {
    padding-top: 12px;
    text-align: center;
    border-top: 0.5px solid var(--m-border);
  }
  .m-unlock + .m-card-detail-link { border-top: none; margin-top: 0; }

  .m-layers {
    background: var(--m-bg); border-radius: var(--m-r-sm);
    padding: 2px 0; margin-bottom: 12px;
  }
  .m-layer-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 12px; font-size: 13px;
    border-bottom: 0.5px solid rgba(0, 0, 0, 0.04);
  }
  .m-layer-row:last-child { border-bottom: none; }
  .m-layer-row span { color: var(--m-text-secondary); font-weight: 500; }
  .m-layer-row strong { font-size: 13px; }

  .m-logic, .m-exit {
    padding: 12px 0; border-top: 0.5px solid var(--m-border);
  }
  .m-logic span, .m-exit span {
    display: block; font-size: 12px; font-weight: 700;
    color: var(--m-text-tertiary); margin-bottom: 6px;
    text-transform: uppercase; letter-spacing: 0.08em;
  }
  .m-logic p, .m-exit p { font-size: 14px; color: var(--m-text-secondary); margin: 0; line-height: 1.6; }

  .m-unlock {
    padding: 14px 0; text-align: center;
    border-top: 0.5px solid var(--m-border);
  }
  .m-unlock p { font-size: 13px; color: var(--m-text-secondary); margin: 0 0 10px; }

  /* ═══════════════════════════════════════
     Page Header / KPI Grid
     ═══════════════════════════════════════ */
  .m-page-header {
    padding: 24px 20px 14px;
  }
  .m-page-header h1 {
    font-size: 28px !important; font-weight: 800 !important;
    letter-spacing: -0.04em; margin: 0;
  }
  .m-page-header p {
    font-size: 15px; color: var(--m-text-secondary);
    margin: 6px 0 0; line-height: 1.5;
  }
  .m-header-meta {
    display: flex; align-items: center; gap: 10px; margin-top: 10px;
  }
  .m-header-meta span:not(.m-badge) { font-size: 13px; color: var(--m-text-secondary); font-weight: 500; }

  .m-kpi-grid {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 8px; margin: 0 16px 16px;
  }
  .m-kpi {
    background: var(--m-card); padding: 16px 14px;
    text-align: center;
    border-radius: var(--m-r-md);
    box-shadow: var(--m-shadow-sm);
    border: 0.5px solid var(--m-border);
  }
  .m-kpi strong {
    display: block; font-size: 26px; font-weight: 800;
    letter-spacing: -0.03em; line-height: 1;
  }
  .m-kpi span {
    font-size: 11px; color: var(--m-text-tertiary);
    font-weight: 500; display: block; margin-top: 4px;
  }
  .m-kpi.good strong { color: var(--m-green); }
  .m-kpi.bad strong { color: var(--m-red); }

  /* ═══════════════════════════════════════
     Day Groups
     ═══════════════════════════════════════ */
  .m-day-group { margin-bottom: 20px; }
  .m-day-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 16px; margin-bottom: 10px;
  }
  .m-day-head h2 { font-size: 17px; font-weight: 700; margin: 0; letter-spacing: -0.02em; }
  .m-day-head span {
    font-size: 12px; color: var(--m-text-tertiary);
    padding: 3px 8px; background: var(--m-bg);
    border-radius: var(--m-r-full);
  }

  /* ═══════════════════════════════════════
     Steps — Timeline
     ═══════════════════════════════════════ */
  .m-steps { display: flex; flex-direction: column; gap: 0; }
  .m-step {
    display: flex; align-items: flex-start; gap: 14px;
    padding: 16px 0;
    position: relative;
  }
  .m-step:not(:last-child)::after {
    content: '';
    position: absolute; left: 15px; top: 44px; bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, rgba(16, 185, 129, 0.2), rgba(16, 185, 129, 0.05));
  }
  .m-step-num {
    width: 32px; height: 32px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%; font-size: 13px; font-weight: 800;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
    position: relative; z-index: 1;
  }
  .m-step strong { font-size: 15px; display: block; margin-bottom: 3px; font-weight: 700; }
  .m-step p { font-size: 13px; color: var(--m-text-secondary); margin: 0; line-height: 1.5; }

  /* ═══════════════════════════════════════
     Plan Cards
     ═══════════════════════════════════════ */
  .m-plan-card {
    display: flex; align-items: center; gap: 16px;
    padding: 18px 16px; margin-bottom: 10px;
    background: var(--m-card);
    border-radius: var(--m-r-lg);
    box-shadow: var(--m-shadow-sm);
    border: 1px solid rgba(0, 0, 0, 0.04);
    position: relative; transition: all 0.2s;
  }
  .m-plan-card.featured {
    border: 2px solid var(--m-primary);
    box-shadow: var(--m-shadow-glow);
  }
  .m-plan-badge {
    position: absolute; top: -10px; right: 14px;
    padding: 3px 10px; border-radius: var(--m-r-full);
    font-size: 12px; font-weight: 700;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
    letter-spacing: 0.02em;
  }
  .m-plan-info { flex: 1; min-width: 0; }
  .m-plan-name { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
  .m-plan-price {
    font-size: 26px; font-weight: 800;
    letter-spacing: -0.03em; margin: 2px 0;
    color: var(--m-text);
  }
  .m-plan-price small { font-size: 13px; font-weight: 500; color: var(--m-text-tertiary); }
  .m-plan-daily { font-size: 12px; color: var(--m-text-tertiary); }
  .m-plan-desc { font-size: 12px; color: var(--m-text-secondary); margin-top: 4px; line-height: 1.4; }

  /* ═══════════════════════════════════════
     Trial Card
     ═══════════════════════════════════════ */
  .m-trial-card {
    display: flex; align-items: center; gap: 16px;
    padding: 18px 16px;
    background: linear-gradient(135deg, #ecfdf5 0%, #f0fdf4 50%, #fff 100%);
    border-radius: var(--m-r-lg);
    box-shadow: var(--m-shadow-md);
    border: 1px solid rgba(16, 185, 129, 0.15);
  }
  .m-trial-info { flex: 1; }
  .m-trial-info strong { font-size: 16px; display: block; margin-bottom: 4px; font-weight: 700; }
  .m-trial-info p { font-size: 13px; color: var(--m-text-secondary); margin: 0; }
  .m-trial-price {
    font-size: 32px; font-weight: 800;
    color: var(--m-primary);
    letter-spacing: -0.04em;
    line-height: 1;
  }

  /* ═══════════════════════════════════════
     FAQ — Expandable
     ═══════════════════════════════════════ */
  .m-faq-list {
    background: var(--m-card);
    border-radius: var(--m-r-lg);
    overflow: hidden;
    box-shadow: var(--m-shadow-sm);
  }
  .m-faq { border-bottom: 0.5px solid var(--m-border); }
  .m-faq:last-child { border-bottom: none; }
  .m-faq summary {
    padding: 16px 18px; font-size: 15px; font-weight: 600;
    cursor: pointer; list-style: none;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.15s;
    color: var(--m-text);
  }
  .m-faq summary:active { background: rgba(0, 0, 0, 0.02); }
  .m-faq summary::-webkit-details-marker { display: none; }
  .m-faq summary::after {
    content: ''; display: inline-block;
    width: 8px; height: 8px;
    border-right: 2px solid var(--m-text-tertiary);
    border-bottom: 2px solid var(--m-text-tertiary);
    transform: rotate(-45deg);
    float: right; margin-top: 6px;
    transition: transform 0.25s ease;
  }
  .m-faq[open] summary::after { transform: rotate(45deg); margin-top: 2px; }
  .m-faq p {
    padding: 0 18px 16px; font-size: 14px;
    color: var(--m-text-secondary); margin: 0; line-height: 1.7;
  }

  /* ═══════════════════════════════════════
     CTA
     ═══════════════════════════════════════ */
  .m-cta {
    padding: 24px 20px; text-align: center;
    background: linear-gradient(165deg, #ecfdf5 0%, #f0fdf4 60%, #fff 100%);
    border-radius: var(--m-r-lg);
    margin: 0 16px 20px;
    box-shadow: var(--m-shadow-sm);
    border: 1px solid rgba(16, 185, 129, 0.1);
    position: relative; overflow: hidden;
  }
  .m-cta::before {
    content: ''; position: absolute;
    top: -60%; right: -20%; width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.08) 0%, transparent 70%);
    border-radius: 50%; pointer-events: none;
  }
  .m-cta strong { font-size: 18px; display: block; margin-bottom: 6px; font-weight: 800; letter-spacing: -0.02em; position: relative; }
  .m-cta p { font-size: 14px; color: var(--m-text-secondary); margin: 0 0 16px; position: relative; }

  /* ═══════════════════════════════════════
     Footer
     ═══════════════════════════════════════ */
  .m-footer {
    padding: 32px 20px; text-align: center;
    margin-top: 8px;
    background: var(--m-card);
    border-top: 0.5px solid var(--m-border);
  }
  .m-footer-brand strong {
    font-size: 18px; display: block;
    font-weight: 800; letter-spacing: -0.03em;
    color: var(--m-primary, #0f766e);
  }
  .m-footer-brand p { font-size: 12px; color: var(--m-text-tertiary); margin: 4px 0 16px; }
  .m-footer-links {
    display: flex; flex-wrap: wrap; justify-content: center; gap: 6px;
    margin-bottom: 16px;
  }
  .m-footer-links a {
    font-size: 13px; color: var(--m-text-secondary);
    text-decoration: none; padding: 5px 10px;
    border-radius: var(--m-r-sm);
    transition: all 0.15s;
  }
  .m-footer-links a:active { color: var(--m-primary); background: var(--m-primary-muted); }
  .m-footer-disclaimer { font-size: 11px; color: var(--m-text-tertiary); line-height: 1.6; }

  /* ═══════════════════════════════════════
     Detail Page
     ═══════════════════════════════════════ */
  .m-detail-header {
    padding: 12px 16px 14px;
    background: var(--m-bg);
  }
  .m-detail-nav {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 16px;
  }
  .m-detail-actions { display: flex; gap: 8px; }
  .m-detail-teams { text-align: center; }
  .m-detail-teams .m-league {
    display: inline-block; margin-bottom: 10px;
    padding: 4px 12px; background: rgba(0, 0, 0, 0.04);
    border-radius: var(--m-r-full);
    font-size: 12px; font-weight: 600;
    color: var(--m-text-tertiary); text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  .m-detail-teams h1 {
    font-size: 20px !important; font-weight: 700 !important;
    margin: 0; letter-spacing: -0.02em;
  }
  .m-detail-teams h1 em {
    font-style: normal; color: var(--m-text-tertiary);
    font-weight: 400; font-size: 15px; margin: 0 6px;
  }
  .m-detail-teams .m-time {
    display: block; font-size: 14px;
    color: var(--m-text-secondary); margin-top: 6px;
  }

  .m-detail-dir {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 8px; margin: 0 16px 16px;
  }
  .m-detail-dir > div {
    background: var(--m-card); padding: 14px 8px;
    text-align: center;
    border-radius: var(--m-r-md);
    box-shadow: var(--m-shadow-sm);
  }
  .m-detail-dir span {
    display: block; font-size: 11px;
    color: var(--m-text-tertiary); margin-bottom: 4px;
    font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .m-detail-dir strong { font-size: 18px; font-weight: 800; letter-spacing: -0.02em; }

  .m-leg-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 0; border-bottom: 0.5px solid var(--m-border);
  }
  .m-leg-item:last-child { border-bottom: none; }
  .m-leg-left { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
  .m-leg-market { font-size: 11px; color: var(--m-text-tertiary); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
  .m-leg-play { font-size: 16px; font-weight: 700; }
  .m-leg-odds { font-size: 14px; color: var(--m-text-secondary); }
  .m-leg-role {
    font-size: 11px; padding: 3px 8px; border-radius: var(--m-r-full);
    background: var(--m-primary-soft); color: var(--m-primary);
    font-weight: 700; letter-spacing: 0.04em;
  }
  .m-leg-outcome { font-size: 14px; font-weight: 700; }
  .m-leg-outcome.win { color: var(--m-green); }
  .m-leg-outcome.lose { color: var(--m-red); }

  .m-text-block {
    padding: 14px 16px;
    background: var(--m-bg);
    border-radius: var(--m-r-md);
    font-size: 14px; line-height: 1.7;
    color: var(--m-text-secondary);
  }
  .m-text-block p { margin: 0; }
  .m-text-block.m-warn {
    background: var(--m-amber-soft);
    border: 1px solid rgba(245, 158, 11, 0.2);
  }

  .m-unlock-card {
    margin: 0 16px 16px; padding: 24px 20px;
    background: linear-gradient(135deg, #ecfdf5 0%, #f0fdf4 100%);
    border-radius: var(--m-r-lg);
    text-align: center;
    box-shadow: var(--m-shadow-md);
    border: 1px solid rgba(16, 185, 129, 0.15);
  }
  .m-unlock-card strong { font-size: 18px; display: block; margin-bottom: 6px; font-weight: 800; }
  .m-unlock-card p { font-size: 14px; color: var(--m-text-secondary); margin: 0 0 14px; }

  .m-review-grid {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .m-review-item {
    background: var(--m-card); padding: 14px;
    text-align: center;
    border-radius: var(--m-r-md);
    box-shadow: var(--m-shadow-sm);
  }
  .m-review-item span {
    display: block; font-size: 11px;
    color: var(--m-text-tertiary); margin-bottom: 4px;
    font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .m-review-item strong { font-size: 16px; font-weight: 700; letter-spacing: -0.02em; }

  /* ═══════════════════════════════════════
     Detail Page — Metrics Dashboard
     ═══════════════════════════════════════ */
  .m-metric-row {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 0; margin: 0 16px 16px;
    background: var(--m-card);
    border-radius: var(--m-r-md);
    border: 0.5px solid var(--m-border);
    overflow: hidden;
  }
  .m-metric-card {
    padding: 12px 8px;
    text-align: center;
    border-right: 0.5px solid var(--m-border);
  }
  .m-metric-card:last-child { border-right: none; }
  .m-metric-card span {
    display: block; font-size: 11px;
    color: var(--m-text-tertiary); margin-bottom: 4px;
    font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .m-metric-card strong {
    font-size: 14px; font-weight: 700;
    letter-spacing: -0.02em;
    display: block; margin-bottom: 2px;
  }
  .m-metric-card p {
    font-size: 11px; color: var(--m-text-tertiary);
    margin: 0; line-height: 1.4;
  }

  /* ═══════════════════════════════════════
     Detail Page — Reasoning Flow (5-step)
     ═══════════════════════════════════════ */
  .m-reason-step {
    display: flex; gap: 12px;
    padding: 10px 0;
    position: relative;
  }
  .m-reason-step + .m-reason-step { border-top: 0.5px solid var(--m-border); }
  .m-reason-idx {
    width: 32px; height: 32px; flex-shrink: 0;
    display: grid; place-items: center;
    background: var(--m-primary-soft);
    color: var(--m-primary);
    border-radius: 50%;
    font-size: 12px; font-weight: 800;
    font-family: var(--m-mono, monospace);
  }
  .m-reason-body { flex: 1; min-width: 0; }
  .m-reason-top {
    display: flex; align-items: center; justify-content: space-between;
    gap: 8px; margin-bottom: 4px;
  }
  .m-reason-top strong { font-size: 14px; font-weight: 700; }
  .m-reason-top span {
    font-size: 11px; color: var(--m-text-tertiary);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    max-width: 120px; text-align: right;
  }
  .m-reason-body p {
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6; margin: 0;
  }

  /* ═══════════════════════════════════════
     Detail Page — Analysis Cards
     ═══════════════════════════════════════ */
  .m-analysis-card {
    background: var(--m-card);
    border-radius: var(--m-r-md);
    padding: 12px 14px;
    margin-bottom: 6px;
    box-shadow: none;
    border: 0.5px solid var(--m-border);
  }
  .m-analysis-card:last-child { margin-bottom: 0; }
  .m-analysis-card > span {
    font-size: 12px; font-weight: 700;
    color: var(--m-primary); text-transform: uppercase;
    letter-spacing: 0.08em; display: block; margin-bottom: 4px;
  }
  .m-analysis-card strong {
    font-size: 15px; font-weight: 700;
    display: block; margin-bottom: 6px;
  }
  .m-analysis-card p {
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6; margin: 0;
  }

  /* ═══════════════════════════════════════
     Detail Page — Evidence List
     ═══════════════════════════════════════ */
  .m-evidence-list {
    list-style: none; padding: 0; margin: 0;
  }
  .m-evidence-list li {
    padding: 10px 0;
    border-bottom: 0.5px solid var(--m-border);
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6;
  }
  .m-evidence-list li:last-child { border-bottom: none; }

  /* ═══════════════════════════════════════
     Detail Page — Risk Card
     ═══════════════════════════════════════ */
  .m-risk-list {
    list-style: none; padding: 0; margin: 0;
  }
  .m-risk-list li {
    padding: 10px 0;
    border-bottom: 0.5px solid var(--m-border);
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6;
  }
  .m-risk-list li:last-child { border-bottom: none; }

  /* ═══════════════════════════════════════
     Detail Page — Audit Note
     ═══════════════════════════════════════ */
  .m-audit-note {
    padding: 12px 16px;
    border-radius: var(--m-r-md);
    font-size: 13px; font-weight: 600;
    margin-bottom: 10px;
  }
  .m-audit-note-green {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid rgba(16, 185, 129, 0.2);
  }
  .m-audit-note-warn {
    background: var(--m-amber-soft);
    color: #92400e;
    border: 1px solid rgba(245, 158, 11, 0.2);
  }

  /* ═══════════════════════════════════════
     Detail Page — Positive Evidence
     ═══════════════════════════════════════ */
  .m-positive-list {
    list-style: none; padding: 0; margin: 0;
  }
  .m-positive-list li {
    padding: 8px 0;
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6;
    display: flex; align-items: flex-start; gap: 6px;
  }
  .m-positive-list li svg { flex-shrink: 0; margin-top: 3px; color: var(--m-green); }

  /* ═══════════════════════════════════════
     Detail Page — Insight Block (merged risk/evidence)
     ═══════════════════════════════════════ */
  .m-insight-block {
    background: var(--m-card);
    border-radius: var(--m-r-md);
    padding: 14px 16px;
    border: 0.5px solid var(--m-border);
    border-left: 3px solid var(--m-amber, #f59e0b);
  }
  .m-insight-block.m-insight-positive {
    border-left-color: var(--m-green);
  }
  .m-insight-item {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 6px 0;
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.5;
  }
  .m-insight-item + .m-insight-item {
    border-top: 0.5px solid var(--m-border);
  }
  .m-insight-item svg {
    flex-shrink: 0; margin-top: 2px;
    width: 14px; height: 14px;
  }
  .m-insight-item .insight-icon {
    flex-shrink: 0; margin-top: 1px;
    display: flex; align-items: center;
  }
  .m-insight-item .insight-icon.critical { color: var(--m-red, #ef4444); }
  .m-insight-item .insight-icon.info { color: var(--m-text-tertiary); }
  .m-insight-item .insight-icon.positive { color: var(--m-green); }

  /* Core logic accent */
  .m-text-block.m-core-logic {
    border-left: 2px solid rgba(0,0,0,0.08);
    background: none;
    font-size: 13px;
    padding: 10px 14px;
  }

  /* Audit note inside decision section */
  .m-decision-audit {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 14px;
    border-radius: var(--m-r-sm);
    font-size: 12px; font-weight: 600;
    margin-top: 12px;
  }
  .m-decision-audit svg { flex-shrink: 0; width: 14px; height: 14px; }
  .m-decision-audit-green {
    background: #ecfdf5; color: #065f46;
  }
  .m-decision-audit-warn {
    background: var(--m-amber-soft); color: #92400e;
  }

  /* ═══════════════════════════════════════
     Detail Page — Verdict Card (focal point)
     ═══════════════════════════════════════ */
  .m-verdict-card {
    margin: 0 12px 24px;
    padding: 32px 22px 26px;
    background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
    border-radius: 24px;
    box-shadow: 0 8px 40px rgba(16,185,129,0.18), 0 2px 8px rgba(0,0,0,0.06);
    position: relative;
    overflow: hidden;
  }
  .m-verdict-card::before {
    content: '';
    position: absolute; top: -40px; right: -40px;
    width: 160px; height: 160px;
    background: radial-gradient(circle, rgba(16,185,129,0.20) 0%, transparent 70%);
    border-radius: 50%;
  }
  .m-verdict-card::after {
    content: '';
    position: absolute; bottom: -20px; left: -20px;
    width: 80px; height: 80px;
    background: radial-gradient(circle, rgba(16,185,129,0.12) 0%, transparent 70%);
    border-radius: 50%;
  }
  .m-verdict-label {
    font-size: 12px; font-weight: 700;
    color: #065f46;
    letter-spacing: 0.02em;
    margin-bottom: 8px;
  }
  .m-verdict-choice {
    font-size: 30px; font-weight: 900;
    letter-spacing: -0.03em;
    color: #052e21;
    line-height: 1.12;
    margin-bottom: 18px;
    font-family: var(--font-display, var(--m-display, sans-serif));
  }
  .m-verdict-play {
    background: rgba(255,255,255,0.65);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-radius: 16px;
    padding: 16px 18px;
    display: flex; align-items: center;
    justify-content: space-between; gap: 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  }
  .m-verdict-play-left { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
  .m-verdict-market {
    font-size: 11px; color: #065f46;
    font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .m-verdict-play-name {
    font-size: 18px; font-weight: 800;
    color: #052e21; letter-spacing: -0.01em;
  }
  .m-verdict-odds {
    font-size: 24px; font-weight: 900;
    color: #052e21;
    background: rgba(255,255,255,0.45);
    padding: 4px 14px;
    border-radius: 10px;
    letter-spacing: -0.02em;
    flex-shrink: 0;
  }
  .m-verdict-role-badge {
    display: inline-block;
    font-size: 11px; padding: 2px 8px;
    border-radius: var(--m-r-full);
    background: rgba(16,185,129,0.18);
    color: #065f46; font-weight: 700;
    margin-top: 4px; letter-spacing: 0.02em;
  }
  .m-verdict-audit {
    display: flex; align-items: center; gap: 6px;
    padding: 8px 12px; border-radius: 10px;
    font-size: 12px; font-weight: 600;
    margin-top: 12px;
  }
  .m-verdict-audit svg { flex-shrink: 0; width: 13px; height: 13px; }
  .m-verdict-audit-green { background: rgba(255,255,255,0.55); color: #064e3b; }
  .m-verdict-audit-warn { background: rgba(245,158,11,0.12); color: #92400e; }

  /* Verdict card —观望/放弃 variant */
  .m-verdict-card.m-verdict-hold {
    background: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 40%, #e2e8f0 100%);
  }
  .m-verdict-card.m-verdict-hold .m-verdict-choice,
  .m-verdict-card.m-verdict-hold .m-verdict-play-name,
  .m-verdict-card.m-verdict-hold .m-verdict-odds,
  .m-verdict-card.m-verdict-hold .m-verdict-market { color: #475569; }

  /* ═══════════════════════════════════════
     Detail Page — Support Block (collapsible sections)
     ═══════════════════════════════════════ */
  .m-support-block {
    background: var(--m-card);
    border-radius: var(--m-r-md);
    overflow: hidden;
    border: 0.5px solid var(--m-border);
  }
  .m-support-block + .m-support-block { margin-top: 8px; }
  .m-support-block-head {
    display: flex; align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    font-size: 12px; font-weight: 600;
    color: var(--m-text-secondary);
  }
  .m-support-block-head .block-tag {
    font-size: 12px; font-weight: 600;
    color: var(--m-text-tertiary);
  }
  .m-support-block-body {
    padding: 0 14px 10px;
    font-size: 12px; color: var(--m-text-tertiary);
    line-height: 1.5;
  }

  /* ═══════════════════════════════════════
     Detail Page — Post-Match Review (enhanced)
     ═══════════════════════════════════════ */
  .m-review-note {
    padding: 12px 16px;
    background: var(--m-bg);
    border-radius: var(--m-r-md);
    margin-top: 10px;
  }
  .m-review-note span {
    font-size: 12px; font-weight: 700;
    color: var(--m-text-tertiary); text-transform: uppercase;
    letter-spacing: 0.06em; display: block; margin-bottom: 4px;
  }
  .m-review-note p {
    font-size: 13px; color: var(--m-text-secondary);
    line-height: 1.6; margin: 0;
  }

  /* ═══════════════════════════════════════
     Performance: ROI / Grade
     ═══════════════════════════════════════ */
  .m-roi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .m-roi-card {
    background: var(--m-card); border-radius: var(--m-r-lg);
    padding: 18px; text-align: center;
    box-shadow: var(--m-shadow-sm);
    border: 0.5px solid var(--m-border);
  }
  .m-roi-head { font-size: 13px; font-weight: 700; margin-bottom: 8px; color: var(--m-text-secondary); }
  .m-roi-rate {
    font-size: 32px; font-weight: 800;
    color: var(--m-primary);
    letter-spacing: -0.04em; line-height: 1;
  }
  .m-roi-detail { display: flex; justify-content: center; gap: 12px; margin-top: 10px; }
  .m-roi-detail span { font-size: 12px; color: var(--m-text-tertiary); }

  .m-grade-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 16px;
    background: var(--m-card);
  }
  .m-grade-row:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0; }
  .m-grade-row:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md); }
  .m-grade-row + .m-grade-row { border-top: 0.5px solid var(--m-border); }
  .m-grade-row span { font-size: 15px; font-weight: 600; }
  .m-grade-row small { display: block; font-size: 12px; color: var(--m-text-tertiary); font-weight: 400; }
  .m-grade-row strong { font-size: 15px; font-weight: 800; }

  /* ═══════════════════════════════════════
     Utility
     ═══════════════════════════════════════ */
  .m-empty, .m-empty-sm {
    padding: 32px 20px; text-align: center;
    color: var(--m-text-tertiary); font-size: 14px;
  }
  .m-empty-sm { padding: 16px; font-size: 13px; }

  .m-pagination {
    display: flex; align-items: center; justify-content: center;
    gap: 14px; padding: 20px 16px;
  }
  .m-pagination span { font-size: 13px; color: var(--m-text-secondary); font-weight: 600; }

  /* ── Legacy fallback (pricing, account, auth, skeleton) ── */
  ::-webkit-scrollbar { width: 0; height: 0; }
  .hide-mobile { display: none !important; }

  .cards-grid { display: flex !important; flex-direction: column !important; gap: 0 !important; padding: 0 16px !important; }
  .match-card {
    padding: 16px 18px !important; background: #fff !important;
    border: none !important; border-radius: 0 !important; box-shadow: none !important;
  }
  .match-card:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0 !important; }
  .match-card:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md) !important; }
  .match-card + .match-card { border-top: 0.5px solid var(--m-border) !important; }

  .modal-overlay { align-items: flex-end !important; padding: 0 !important; background: rgba(0, 0, 0, 0.3) !important; backdrop-filter: blur(2px) !important; }
  .modal-card {
    width: 100% !important; max-width: 100% !important; margin: 0 !important;
    padding: 24px 20px calc(24px + var(--m-safe-bottom)) !important;
    border-radius: var(--m-r-xl) var(--m-r-xl) 0 0 !important;
    max-height: 85vh; overflow-y: auto;
    animation: mSlideUp 0.4s cubic-bezier(0.32, 0.72, 0, 1);
  }
  @keyframes mSlideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
  .modal-card h2 { font-size: 20px !important; font-weight: 800 !important; text-align: center !important; letter-spacing: -0.02em; }
  .modal-actions { display: flex !important; flex-direction: column !important; gap: 10px !important; }
  .modal-actions button { width: 100% !important; height: 50px !important; font-size: 16px !important; font-weight: 700 !important; border-radius: var(--m-r-md) !important; }
  .modal-actions .ghost-button { background: #fff !important; color: var(--m-text, #1a1a2e) !important; border: 1.5px solid var(--m-border-strong, #cbd5e1) !important; box-shadow: none !important; }
  .modal-actions .primary-button { background: linear-gradient(135deg, var(--m-primary, #0a8f5c), var(--m-primary-dark, #065f3e)) !important; color: #fff !important; border: none !important; box-shadow: 0 4px 12px rgba(16, 127, 86, 0.2) !important; }

  .toast {
    top: 50% !important; left: 50% !important; right: auto !important; bottom: auto !important;
    transform: translate(-50%, -50%) !important;
    max-width: 280px; text-align: center;
    border-radius: var(--m-r-md); padding: 16px 22px;
    font-size: 15px; font-weight: 600;
    background: rgba(26, 26, 46, 0.9); color: #fff;
    backdrop-filter: blur(20px);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
  }

  .account-section { padding: 0 16px !important; }
  .account-card {
    padding: 16px 18px !important; background: var(--m-card) !important;
    border: none !important; border-radius: 0 !important; box-shadow: none !important;
  }
  .account-card:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0 !important; }
  .account-card:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md) !important; }
  .account-card + .account-card { border-top: 0.5px solid var(--m-border) !important; }

  .skeleton-card { padding: 20px 18px !important; background: #fff !important; border: none !important; border-radius: 0 !important; }
  .skeleton-card:first-child { border-radius: var(--m-r-md) var(--m-r-md) 0 0 !important; }
  .skeleton-card:last-child { border-radius: 0 0 var(--m-r-md) var(--m-r-md) !important; }
  .skeleton-card + .skeleton-card { border-top: 0.5px solid var(--m-border) !important; }
  .skeleton-line {
    height: 14px !important; border-radius: 7px !important;
    background: linear-gradient(90deg, #e8e8ed 25%, #d1d1d6 50%, #e8e8ed 75%) !important;
    background-size: 200% 100% !important;
    animation: mShimmer 1.5s ease-in-out infinite !important;
    margin-bottom: 12px !important;
  }
  @keyframes mShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

} /* end @media (max-width: 768px) */

@media (max-width: 380px) {
  .mobile-tab-bar a { font-size: 9px; }
  .mobile-tab-bar a svg { width: 22px; height: 22px; }
  .m-hero h1 { font-size: 24px !important; }
  .m-hero { padding: 24px 16px 20px; }
  .m-stat-pill strong { font-size: 19px; }
  .m-pred-teams, .m-result-card .m-result-teams { font-size: 15px; }
  .m-plan-price { font-size: 22px; }
  .m-detail-teams h1 { font-size: 20px !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   User Mobile v3 — compact decision product
   Landing becomes an operating surface: next match, today's board,
   transparent results, then plans. Keeps desktop untouched.
   ═══════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  :root {
    --m-tab-h: 62px;
    --m-hdr-h: 58px;
    --m-bg: #f6f8fb;
    --m-card: #ffffff;
    --m-card-hover: #f8fafc;
    --m-border: #dfe5ee;
    --m-border-strong: #cbd5e1;
    --m-text: #16202f;
    --m-text-secondary: #536171;
    --m-text-tertiary: #7b8794;
    --m-primary: #0f766e;
    --m-primary-light: #14b8a6;
    --m-primary-dark: #115e59;
    --m-primary-soft: rgba(15, 118, 110, 0.09);
    --m-primary-muted: rgba(15, 118, 110, 0.05);
    --m-blue: #2563eb;
    --m-blue-soft: rgba(37, 99, 235, 0.08);
    --m-amber: #d97706;
    --m-amber-soft: rgba(217, 119, 6, 0.09);
    --m-r-sm: 6px;
    --m-r-md: 8px;
    --m-r-lg: 8px;
    --m-r-xl: 10px;
    --m-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
    --m-shadow-md: 0 8px 22px rgba(15, 23, 42, 0.08);
    --m-shadow-lg: 0 18px 42px rgba(15, 23, 42, 0.11);
    --m-shadow-glow: 0 0 0 3px rgba(15, 118, 110, 0.10);
  }

  html {
    background: var(--m-bg);
    scroll-padding-top: calc(var(--m-safe-top) + var(--m-hdr-h) + 12px);
  }

  body {
    color: var(--m-text) !important;
    background: var(--m-bg) !important;
    font-size: 15px !important;
    line-height: 1.48 !important;
    letter-spacing: 0 !important;
    padding-bottom: calc(var(--m-tab-h) + var(--m-safe-bottom) + 14px) !important;
  }

  .public-shell {
    background: var(--m-bg);
  }

  .public-hero {
    position: sticky;
    top: 0;
    z-index: 100;
  }

  .topbar {
    height: calc(var(--m-hdr-h) + var(--m-safe-top)) !important;
    min-height: calc(var(--m-hdr-h) + var(--m-safe-top)) !important;
    padding: calc(var(--m-safe-top) + 8px) 12px 8px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    border-bottom: 1px solid rgba(203, 213, 225, 0.82) !important;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05) !important;
  }

  .brand {
    gap: 9px !important;
    max-width: calc(100vw - 76px);
  }

  .brand-mark {
    width: 34px !important;
    height: 34px !important;
    border-radius: 8px !important;
    background: #102033 !important;
    color: var(--ux-text) !important;
    box-shadow: none !important;
  }

  .brand strong {
    font-size: 16px !important;
    letter-spacing: 0 !important;
    color: var(--m-text) !important;
  }

  .hamburger {
    width: 40px !important;
    height: 40px !important;
    border: 1px solid var(--m-border) !important;
    background: #fff !important;
    border-radius: 8px !important;
  }

  .hamburger span {
    width: 18px;
    background: var(--m-text) !important;
  }

  .app-main {
    padding: 0 !important;
  }

  .m-hero {
    padding: 18px 14px 12px !important;
    background: var(--m-bg) !important;
    border-bottom: 1px solid var(--m-border);
  }

  .m-hero::before,
  .m-hero::after,
  .m-cta::before {
    display: none !important;
  }

  .m-hero .m-badge {
    margin-bottom: 10px;
  }

  .m-hero h1 {
    max-width: 11em;
    margin-bottom: 8px !important;
    color: var(--m-text) !important;
    font-size: 25px !important;
    line-height: 1.12 !important;
    letter-spacing: 0 !important;
  }

  .m-hero p {
    max-width: 34em;
    margin-bottom: 14px !important;
    color: var(--m-text-secondary) !important;
    font-size: 14px !important;
    line-height: 1.65 !important;
  }

  .m-hero-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8px !important;
  }

  .m-btn {
    min-height: 44px;
    height: auto !important;
    padding: 10px 13px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
  }

  .m-btn-primary {
    background: var(--m-primary, #0f766e) !important;
    color: #fff !important;
    box-shadow: 0 2px 8px rgba(15, 118, 110, 0.2) !important;
  }

  .m-btn-ghost {
    background: #fff !important;
    color: var(--m-text) !important;
    border: 1.5px solid var(--m-border-strong, #cbd5e1) !important;
    box-shadow: none !important;
  }

  .m-badge,
  .m-league,
  .m-status-tag,
  .m-choice,
  .m-leg-tag {
    border-radius: 999px !important;
    letter-spacing: 0 !important;
  }

  .m-badge {
    padding: 5px 10px !important;
    background: #fff !important;
    border: 1px solid var(--m-border) !important;
    color: var(--m-primary) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
  }

  .m-status-card {
    width: auto !important;
    margin: 10px 10px 12px !important;
    padding: 13px !important;
    background: var(--m-card) !important;
    border: 1px solid var(--m-border) !important;
    border-radius: 8px !important;
    box-shadow: var(--m-shadow-sm) !important;
  }

  .m-status-card::before {
    height: 2px !important;
    background: linear-gradient(90deg, var(--m-primary), var(--m-blue), var(--m-amber)) !important;
  }

  .m-status-top {
    gap: 8px !important;
    margin-bottom: 10px !important;
  }

  .m-status-tag {
    flex-shrink: 0;
    padding: 4px 9px !important;
    background: var(--m-amber-soft) !important;
    color: var(--m-amber) !important;
  }

  .m-status-tag.ready {
    background: var(--m-primary-soft) !important;
    color: var(--m-primary) !important;
  }

  .m-status-league,
  .m-time {
    text-transform: none !important;
    letter-spacing: 0 !important;
  }

  .m-status-match h3 {
    font-size: 18px !important;
    line-height: 1.28 !important;
    letter-spacing: 0 !important;
  }

  .m-status-meta {
    grid-template-columns: 1fr 1fr 0.72fr !important;
    gap: 6px !important;
    margin-top: 12px !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  .m-status-meta div {
    padding: 9px 8px !important;
    text-align: left !important;
    background: #f8fafc !important;
    border: 1px solid var(--m-border) !important;
    border-radius: 8px !important;
  }

  .m-status-meta span,
  .m-stat-pill span,
  .m-kpi span,
  .m-detail-dir span,
  .m-review-item span {
    text-transform: none !important;
    letter-spacing: 0 !important;
  }

  .m-status-meta strong {
    font-size: 12px !important;
    line-height: 1.25 !important;
  }

  .m-stats-row {
    width: auto !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px !important;
    padding: 0 10px !important;
    margin-bottom: 14px !important;
  }

  .m-stat-pill,
  .m-kpi,
  .m-roi-card,
  .m-review-item {
    padding: 12px 9px !important;
    border: 1px solid var(--m-border) !important;
    border-radius: 8px !important;
    background: #fff !important;
    box-shadow: var(--m-shadow-sm) !important;
  }

  .m-stat-pill strong {
    font-size: 19px !important;
  }

  .m-section {
    width: auto !important;
    padding: 0 10px !important;
    margin-bottom: 14px !important;
  }

  .m-section-alt {
    padding: 14px 10px !important;
    background: #eef6f5 !important;
    border-top: 1px solid #dbe9e7;
    border-bottom: 1px solid #dbe9e7;
  }

  .m-section-head {
    align-items: end !important;
    margin-bottom: 9px !important;
  }

  .m-section-head h2 {
    font-size: 17px !important;
    line-height: 1.2 !important;
    letter-spacing: 0 !important;
  }

  .m-link {
    color: var(--m-primary) !important;
    font-size: 13px !important;
    white-space: nowrap;
  }

  .m-list-group,
  .m-faq-list {
    border: 1px solid var(--m-border);
    border-radius: 8px !important;
    background: #fff;
    box-shadow: var(--m-shadow-sm) !important;
  }

  .m-list-item {
    padding: 12px !important;
    border-left: 0 !important;
  }

  .m-list-primary {
    font-size: 14px !important;
    white-space: normal !important;
    line-height: 1.35;
  }

  .m-list-secondary {
    font-size: 12px !important;
    line-height: 1.45;
  }

  .m-list-time {
    padding: 4px 8px !important;
    border: 1px solid var(--m-border);
    background: #f8fafc !important;
    border-radius: 6px !important;
  }

  .m-result-card,
  .m-pred-card {
    margin: 0 10px 8px !important;
    padding: 12px !important;
    border: 1px solid var(--m-border) !important;
    border-left: 3px solid transparent !important;
    border-radius: 8px !important;
    background: #fff !important;
    box-shadow: var(--m-shadow-sm) !important;
  }

  .m-result-card:first-child,
  .m-result-card:last-child,
  .m-result-card:only-child,
  .m-pred-card:first-child,
  .m-pred-card:last-child,
  .m-pred-card:only-child {
    border-radius: 8px !important;
  }

  .m-result-card + .m-result-card,
  .m-pred-card + .m-pred-card {
    border-top: 1px solid var(--m-border) !important;
  }

  .m-pred-card.expanded {
    border-left-color: var(--m-primary) !important;
    background: #fbfefd !important;
  }

  .m-result-top,
  .m-pred-top {
    margin-bottom: 8px !important;
  }

  .m-result-card .m-result-teams,
  .m-pred-teams {
    font-size: 16px !important;
    line-height: 1.32 !important;
    letter-spacing: 0 !important;
  }

  .m-pred-row {
    gap: 6px !important;
  }

  .m-choice {
    padding: 5px 10px !important;
    font-size: 12px !important;
  }

  .m-choice.pick {
    background: var(--m-primary-soft) !important;
    color: var(--m-primary-dark) !important;
  }

  .m-choice.wait {
    background: var(--m-amber-soft) !important;
    color: var(--m-amber) !important;
  }

  .m-legs-row {
    gap: 5px !important;
    margin-top: 7px !important;
  }

  .m-leg-tag {
    max-width: 100%;
    padding: 4px 8px !important;
    border: 1px solid var(--m-border) !important;
    background: #f8fafc !important;
    color: var(--m-text) !important;
    font-size: 12px !important;
    line-height: 1.35;
  }

  .m-expand-hint {
    color: var(--m-primary) !important;
    font-size: 12px !important;
    margin-top: 8px !important;
  }

  .m-layers {
    background: #f8fafc !important;
    border: 1px solid var(--m-border);
    border-radius: 8px !important;
  }

  .m-layer-row {
    padding: 9px 10px !important;
  }

  .m-layer-row strong {
    color: var(--m-text);
    text-align: right;
  }

  .m-page-header,
  .m-detail-header {
    padding: 16px 14px 12px !important;
    background: var(--m-bg) !important;
  }

  .m-page-header h1,
  .m-detail-teams h1 {
    font-size: 23px !important;
    line-height: 1.18 !important;
    letter-spacing: 0 !important;
  }

  .m-page-header p {
    font-size: 14px !important;
  }

  .m-header-meta {
    margin-top: 8px !important;
  }

  .m-kpi-grid {
    width: auto !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin: 0 10px 12px !important;
  }

  .m-kpi {
    padding: 10px 5px !important;
  }

  .m-kpi strong {
    font-size: 18px !important;
    letter-spacing: 0 !important;
  }

  .m-kpi span {
    font-size: 10px !important;
    line-height: 1.2;
  }

  .m-day-group {
    margin-bottom: 14px !important;
  }

  .m-day-head {
    padding: 0 10px !important;
    margin-bottom: 8px !important;
  }

  .m-day-head h2 {
    font-size: 15px !important;
  }

  .m-step {
    padding: 12px 0 !important;
  }

  .m-step-num {
    width: 28px !important;
    height: 28px !important;
    border-radius: 8px !important;
    background: #102033 !important;
    box-shadow: none !important;
  }

  .m-step:not(:last-child)::after {
    left: 13px !important;
    top: 38px !important;
    background: #cbd5e1 !important;
  }

  .m-plan-card,
  .m-trial-card,
  .m-cta,
  .m-unlock-card {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 13px !important;
    border: 1px solid var(--m-border) !important;
    border-radius: 8px !important;
    background: #fff !important;
    box-shadow: var(--m-shadow-sm) !important;
  }

  .m-plan-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 76px;
    align-items: center !important;
    gap: 10px !important;
  }

  .m-plan-info {
    min-width: 0;
  }

  .m-plan-card .m-btn {
    width: 76px;
    min-width: 76px;
    padding-left: 8px !important;
    padding-right: 8px !important;
    white-space: nowrap;
    writing-mode: horizontal-tb;
  }

  .m-plan-card.featured {
    border: 1px solid var(--m-primary) !important;
    box-shadow: var(--m-shadow-glow) !important;
  }

  .m-plan-badge {
    top: 10px !important;
    right: 10px !important;
    border-radius: 999px !important;
    background: var(--m-primary) !important;
    box-shadow: none !important;
  }

  .m-plan-price,
  .m-trial-price {
    color: var(--m-text) !important;
    font-size: 24px !important;
  }

  .m-trial-card {
    display: grid !important;
    grid-template-columns: 1fr auto;
    align-items: center !important;
    gap: 10px !important;
  }

  .m-trial-card .m-btn {
    grid-column: 1 / -1;
  }

  .m-faq summary {
    padding: 14px 13px !important;
    font-size: 14px !important;
  }

  .m-faq p {
    padding: 0 13px 14px !important;
  }

  .m-cta {
    width: auto !important;
    margin: 0 10px 14px !important;
    text-align: left !important;
  }

  .m-cta strong {
    font-size: 17px !important;
  }

  .m-footer {
    margin-top: 0 !important;
    padding: 24px 14px calc(24px + var(--m-safe-bottom)) !important;
    border-top: 1px solid var(--m-border) !important;
    background: #fff !important;
  }

  .m-footer-brand strong {
    color: var(--m-text) !important;
    background: none !important;
    -webkit-text-fill-color: currentColor !important;
  }

  .m-detail-dir {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    margin: 0 10px 12px !important;
  }

  .m-detail-dir > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 12px !important;
    text-align: left !important;
    border: 1px solid var(--m-border);
  }

  .m-detail-dir span {
    margin: 0 !important;
  }

  .m-detail-dir strong {
    font-size: 16px !important;
    text-align: right;
  }

  .m-text-block {
    padding: 12px !important;
    background: #fff !important;
    border: 1px solid var(--m-border);
    border-radius: 8px !important;
  }

  .m-text-block.m-warn {
    background: #fffaf0 !important;
    border-color: rgba(217, 119, 6, 0.24) !important;
  }

  .m-leg-item {
    align-items: flex-start !important;
    gap: 10px !important;
    padding: 12px 0 !important;
  }

  .m-leg-left {
    min-width: 0;
  }

  .m-leg-play {
    font-size: 15px !important;
  }

  .m-roi-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .m-roi-card {
    text-align: left !important;
  }

  .m-roi-rate {
    font-size: 28px !important;
    color: var(--m-primary) !important;
  }

  .m-roi-detail {
    justify-content: flex-start !important;
    flex-wrap: wrap;
  }

  .m-grade-row {
    margin: 0 10px;
    border: 1px solid var(--m-border);
    border-radius: 8px !important;
  }

  .m-grade-row + .m-grade-row {
    margin-top: 7px;
  }

  .mobile-tab-bar {
    left: 10px !important;
    right: 10px !important;
    bottom: calc(var(--m-safe-bottom) + 8px) !important;
    height: var(--m-tab-h) !important;
    padding: 0 !important;
    border: 1px solid rgba(203, 213, 225, 0.9) !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.16) !important;
    overflow: hidden;
  }

  .mobile-tab-bar a {
    min-width: 0;
    gap: 3px !important;
    padding: 7px 2px 6px !important;
    color: var(--m-text-tertiary) !important;
    font-size: 10px !important;
    line-height: 1 !important;
  }

  .mobile-tab-bar a svg {
    width: 20px !important;
    height: 20px !important;
  }

  .mobile-tab-bar a.active {
    color: var(--m-primary) !important;
    background: var(--m-primary-muted);
  }

  .mobile-nav-drawer {
    width: min(320px, 86vw) !important;
    background: #fff !important;
  }

  .mobile-nav-drawer-header {
    padding: calc(var(--m-safe-top) + 16px) 16px 12px !important;
  }

  .mobile-nav-drawer a {
    padding: 12px 16px !important;
    font-size: 15px !important;
  }

  .modal-card {
    border-radius: 12px 12px 0 0 !important;
  }

  .l-auth-shell,
  .account-section {
    padding: 0 10px !important;
  }

  .l-auth-form-title {
    font-size: 25px !important;
    letter-spacing: 0 !important;
  }

  .l-auth-input-wrap input,
  .l-auth-submit {
    border-radius: 8px !important;
  }

  .toast {
    border-radius: 8px !important;
  }
}

@media (max-width: 380px) {
  .m-hero {
    padding: 15px 10px 10px !important;
  }

  .m-hero h1 {
    font-size: 22px !important;
  }

  .m-hero-actions {
    grid-template-columns: 1fr !important;
  }

  .m-status-meta,
  .m-stats-row,
  .m-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .mobile-tab-bar {
    left: 8px !important;
    right: 8px !important;
  }
}

/* User Mobile v4: complete visual direction for the public app */
@media (max-width: 768px) {
  body:has(.ux-mobile) {
    background:
      linear-gradient(180deg, rgba(248,251,249,0.94) 0%, #ffffff 42%, #f8fafc 100%) !important;
  }

  body:has(.ux-mobile) .topbar {
    height: calc(56px + var(--m-safe-top)) !important;
    min-height: calc(56px + var(--m-safe-top)) !important;
    padding: calc(var(--m-safe-top) + 8px) 12px 8px !important;
    background: var(--background-80) !important;
    border-bottom: 1px solid var(--border-60) !important;
    box-shadow: var(--shadow-sm) !important;
  }

  body:has(.ux-mobile) .brand-mark {
    background: linear-gradient(135deg, var(--primary), var(--primary-90)) !important;
    border-radius: var(--r-sm) !important;
    box-shadow: 0 2px 8px var(--primary-20) !important;
  }

  body:has(.ux-mobile) .hamburger {
    border-radius: var(--r-sm) !important;
    background: var(--background-80) !important;
    border: 1px solid var(--border-60) !important;
  }

  .ux-mobile {
    --ux-ink: var(--foreground);
    --ux-text: var(--foreground);
    --ux-muted: var(--muted-foreground);
    --ux-faint: var(--muted-foreground-70);
    --ux-line: var(--border-60);
    --ux-card: var(--card-97);
    --ux-soft: var(--muted);
    --ux-primary: var(--primary);
    --ux-primary-soft: var(--primary-soft);
    --ux-primary-15: var(--primary-15);
    --ux-gold: var(--gold);
    --ux-gold-soft: var(--gold-soft);
    --ux-yellow: var(--yellow);
    --ux-yellow-soft: var(--yellow-soft);
    padding: 0 10px 18px;
    color: var(--ux-text);
    background: transparent;
  }

  .ux-mobile * {
    letter-spacing: 0;
  }

  .ux-hero,
  .ux-page-hero {
    margin: 10px 0;
    padding: 18px 14px;
    border: 1px solid var(--border-60);
    border-radius: 8px;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,251,249,0.94)),
      var(--card-97);
    color: var(--ux-text);
    box-shadow: var(--shadow-sm);
  }

  .ux-page-hero {
    background:
      linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,251,249,0.94));
    color: var(--ux-text);
  }

  .ux-eyebrow {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 9px;
    padding: 4px 9px;
    border-radius: 999px;
    background: var(--primary-soft);
    color: var(--primary);
    font-size: 11px;
    font-weight: 700;
  }

  .ux-page-hero .ux-eyebrow {
    color: var(--primary);
    background: var(--primary-soft);
  }

  .ux-hero h1,
  .ux-page-hero h1 {
    max-width: 12em;
    margin: 0;
    font-size: 27px;
    line-height: 1.12;
    font-weight: 850;
  }

  .ux-hero h1 {
    color: var(--ux-text) !important;
  }

  .ux-page-hero h1 {
    color: var(--ux-text) !important;
    font-size: 25px;
  }

  .ux-hero p,
  .ux-page-hero p {
    margin: 10px 0 0;
    color: var(--ux-muted);
    font-size: 14px;
    line-height: 1.58;
  }

  .ux-hero p {
    color: var(--ux-muted) !important;
  }

  .ux-page-hero p {
    color: var(--ux-muted) !important;
  }

  .ux-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 14px;
  }

  .ux-actions a,
  .ux-trial a,
  .ux-plan a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 9px 12px;
    border: 1px solid var(--border-60);
    border-radius: 7px;
    color: var(--ux-text);
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
  }

  .ux-actions a.primary {
    background: linear-gradient(135deg, var(--primary), var(--primary-90));
    border-color: var(--primary);
    color: #fff;
  }

  .ux-live-card,
  .ux-trial,
  .ux-risk,
  .ux-row-card,
  .ux-result-card,
  .ux-match-card,
  .ux-plan,
  .ux-footer {
    border: 1px solid var(--ux-line);
    border-radius: 8px;
    background: var(--ux-card);
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
  }

  .ux-live-card {
    padding: 13px;
    margin-bottom: 10px;
  }

  .ux-card-kicker,
  .ux-section-head,
  .ux-day-head,
  .ux-match-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .ux-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    width: fit-content;
    max-width: 100%;
    padding: 4px 8px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: 11px;
    line-height: 1.1;
    font-weight: 850;
    white-space: nowrap;
  }

  .ux-chip-dot {
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: currentColor;
    opacity: 0.8;
    flex-shrink: 0;
  }

  .ux-chip-waiting,
  .ux-chip-neutral {
    color: #667085;
    background: #f2f4f7;
    border-color: rgba(102, 112, 133, 0.16);
  }

  .ux-chip-soon {
    color: #b45309;
    background: rgba(245, 158, 11, 0.12);
    border-color: rgba(245, 158, 11, 0.22);
  }

  .ux-chip-ready,
  .ux-chip-positive {
    color: var(--primary);
    background: var(--primary-soft);
    border-color: var(--primary-20);
  }

  .ux-chip-settled,
  .ux-chip-info {
    color: #2563eb;
    background: rgba(59, 130, 246, 0.1);
    border-color: rgba(59, 130, 246, 0.18);
  }

  .ux-chip-negative,
  .ux-chip-risk {
    color: #dc2626;
    background: rgba(220, 38, 38, 0.08);
    border-color: rgba(220, 38, 38, 0.16);
  }

  .ux-chip-locked {
    color: #6b7280;
    background: rgba(107, 114, 128, 0.08);
    border-color: rgba(107, 114, 128, 0.18);
  }

  .ux-card-kicker > span:not(.ux-chip),
  .ux-row-card > div > span:not(.ux-chip),
  .ux-result-main > span:not(.ux-chip),
  .ux-match-top > span:not(.ux-chip),
  .ux-trial span:not(.ux-chip):not(.ux-chip-dot),
  .ux-plan span:not(.ux-chip):not(.ux-chip-dot) {
    color: var(--ux-faint);
    font-size: 11px;
    font-weight: 700;
  }

  .ux-live-teams {
    margin-top: 10px;
  }

  .ux-live-teams small {
    display: block;
    margin-bottom: 4px;
    color: var(--ux-muted);
    font-size: 12px;
  }

  .ux-live-teams h2,
  .ux-match-card h3 {
    margin: 0;
    color: var(--ux-text);
    font-size: 19px;
    line-height: 1.28;
    font-weight: 850;
  }

  .ux-live-teams em,
  .ux-row-card em,
  .ux-result-main em,
  .ux-match-card h3 em {
    margin: 0 5px;
    color: var(--ux-faint);
    font-style: normal;
    font-size: 12px;
    font-weight: 650;
  }

  .ux-live-grid,
  .ux-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    margin-top: 12px;
  }

  .ux-live-grid div,
  .ux-metrics div {
    min-width: 0;
    padding: 10px 8px;
    border: 1px solid var(--ux-line);
    border-radius: 7px;
    background: var(--ux-soft);
  }

  .ux-live-grid span,
  .ux-metrics span {
    display: block;
    color: var(--ux-faint);
    font-size: 11px;
    font-weight: 750;
  }

  .ux-live-grid strong,
  .ux-metrics strong {
    display: block;
    margin-top: 3px;
    color: var(--ux-text);
    font-size: 12px;
    line-height: 1.25;
    font-weight: 850;
  }

  .ux-metrics {
    margin: 0 0 12px;
  }

  .ux-metrics div {
    background: #fff;
  }

  .ux-metrics strong {
    font-size: 19px;
  }

  .ux-metrics .pos,
  .ux-result-side .pos {
    color: var(--primary);
  }

  .ux-metrics .neg,
  .ux-result-side .neg {
    color: #dc2626;
  }

  .ux-board-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .ux-board-metrics div {
    padding: 9px 5px;
    text-align: center;
  }

  .ux-board-metrics strong {
    font-size: 17px;
  }

  .ux-section {
    margin: 0 0 12px;
  }

  .ux-section-head,
  .ux-day-head {
    margin: 0 0 8px;
    padding: 0 2px;
  }

  .ux-section-head h2,
  .ux-day-head h2 {
    margin: 0;
    color: var(--ux-text);
    font-size: 17px;
    line-height: 1.2;
    font-weight: 850;
  }

  .ux-section-head a {
    color: var(--primary);
    font-size: 13px;
    font-weight: 800;
  }

  .ux-row-card,
  .ux-result-card,
  .ux-match-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px;
    margin-bottom: 7px;
  }

  .ux-live-card,
  .ux-row-card,
  .ux-result-card,
  .ux-match-card {
    position: relative;
    overflow: hidden;
  }

  .ux-row-card::before,
  .ux-result-card::before,
  .ux-match-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    bottom: 10px;
    width: 3px;
    border-radius: 0 999px 999px 0;
    background: transparent;
  }

  .ux-state-waiting::before,
  .ux-state-neutral::before {
    background: rgba(102, 112, 133, 0.22);
  }

  .ux-state-soon::before {
    background: rgba(245, 158, 11, 0.75);
  }

  .ux-state-ready::before,
  .ux-state-positive::before {
    background: var(--primary);
  }

  .ux-state-settled::before,
  .ux-state-info::before {
    background: #3b82f6;
  }

  .ux-state-negative::before,
  .ux-state-risk::before {
    background: #dc2626;
  }

  .ux-state-locked::before {
    background: rgba(16, 127, 86, 0.3);
  }

  .ux-row-card.is-next {
    border-color: rgba(16, 127, 86, 0.2);
    background:
      linear-gradient(90deg, rgba(16, 127, 86, 0.035), rgba(255, 255, 255, 0) 42%),
      var(--ux-card);
  }

  .ux-row-card div,
  .ux-result-main {
    min-width: 0;
  }

  .ux-row-card strong,
  .ux-result-main strong {
    display: block;
    margin-top: 3px;
    color: var(--ux-text);
    font-size: 14px;
    line-height: 1.28;
    font-weight: 850;
  }

  .ux-row-card p {
    margin: 4px 0 0;
    color: var(--ux-muted);
    font-size: 12px;
    line-height: 1.38;
  }

  .ux-row-side {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
    flex-shrink: 0;
  }

  .ux-row-card time {
    flex-shrink: 0;
    max-width: 96px;
    padding: 5px 8px;
    border-radius: 7px;
    background: var(--primary-soft);
    color: var(--primary);
    font-size: 12px;
    font-weight: 800;
    text-align: right;
  }

  .ux-result-side {
    flex-shrink: 0;
    text-align: right;
  }

  .ux-result-side b {
    display: block;
    color: var(--ux-text);
    font-size: 18px;
    line-height: 1;
  }

  .ux-result-side small {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    font-weight: 850;
  }

  .ux-result-side small.positive {
    color: var(--primary);
  }

  .ux-result-side small.negative {
    color: #dc2626;
  }

  .ux-result-side small.neutral {
    color: var(--ux-muted);
  }

  .ux-result-main .ux-chip {
    margin-top: 7px;
  }

  .ux-pick-line {
    display: flex;
    align-items: center;
    gap: 7px;
    flex-wrap: wrap;
    margin-top: 9px;
  }

  .ux-trial,
  .ux-risk {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 12px;
    padding: 13px;
  }

  .ux-trial strong,
  .ux-plan strong,
  .ux-risk strong {
    display: block;
    margin-top: 3px;
    color: var(--ux-text);
    font-size: 16px;
    line-height: 1.25;
    font-weight: 850;
  }

  .ux-trial p,
  .ux-plan p,
  .ux-risk p {
    margin: 5px 0 0;
    color: var(--ux-muted);
    font-size: 12px;
    line-height: 1.45;
  }

  .ux-trial a,
  .ux-plan a {
    min-width: 72px;
    border-color: var(--primary);
    background: linear-gradient(135deg, var(--primary), var(--primary-90));
    color: #fff;
    box-shadow: 0 2px 8px var(--primary-20);
  }

  .ux-plan-list {
    display: grid;
    gap: 7px;
  }

  .ux-plan {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 78px;
    gap: 10px;
    align-items: center;
    padding: 12px;
  }

  .ux-plan.featured {
    border-color: var(--primary-20);
    box-shadow: var(--shadow-glow);
  }

  .ux-risk {
    display: block;
    background: #fffbeb;
    border-color: var(--gold-20);
  }

  .ux-day {
    margin: 0 0 14px;
  }

  .ux-day-head span {
    padding: 4px 8px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--ux-line);
    color: var(--ux-muted);
    font-size: 12px;
    font-weight: 800;
  }

  .ux-match-card {
    display: block;
  }

  .ux-match-top {
    margin-bottom: 8px;
  }

  .ux-match-top time {
    color: var(--ux-muted);
    font-size: 12px;
    font-weight: 750;
  }

  .ux-pick-line {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 9px;
  }

  .ux-pick-line > span:not(.ux-chip):not(.ux-chip-dot) {
    color: var(--primary);
    background: var(--primary-soft);
  }

  .ux-leg-list {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 8px;
  }

  .ux-leg-list span {
    max-width: 100%;
    padding: 5px 8px;
    border: 1px solid var(--ux-line);
    border-radius: 999px;
    background: var(--ux-soft);
    color: var(--ux-text);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.3;
  }

  .ux-card-note {
    margin-top: 9px;
    padding-top: 9px;
    border-top: 1px solid var(--ux-line);
    color: var(--ux-muted);
    font-size: 12px;
    line-height: 1.5;
  }

  .ux-empty {
    padding: 18px 12px;
    border: 1px dashed #cbd5e1;
    border-radius: 8px;
    color: var(--ux-muted);
    background: rgba(255, 255, 255, 0.64);
    font-size: 13px;
    text-align: center;
  }

  .ux-footer {
    margin: 8px 10px 0;
    padding: 18px 14px calc(18px + var(--m-safe-bottom));
    text-align: center;
  }

  .ux-footer strong {
    color: var(--ux-text);
    font-size: 16px;
  }

  .ux-footer p {
    margin: 8px auto 12px;
    max-width: 32em;
    color: var(--ux-muted);
    font-size: 11px;
    line-height: 1.65;
  }

  .ux-footer div {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px 14px;
  }

  .ux-footer a {
    color: var(--ux-muted);
    font-size: 12px;
    font-weight: 700;
  }

  body:has(.ux-mobile) .mobile-tab-bar {
    left: 12px !important;
    right: 12px !important;
    bottom: calc(var(--m-safe-bottom) + 9px) !important;
    height: 62px !important;
    border-radius: 8px !important;
    border: 1px solid var(--border-60) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 12px 34px rgba(16, 24, 40, 0.14) !important;
  }

  body:has(.ux-mobile) .mobile-tab-bar a {
    font-size: 10px !important;
    color: #8a95a4 !important;
  }

  body:has(.ux-mobile) .mobile-tab-bar a.active {
    color: var(--primary) !important;
    background: transparent !important;
  }
}

@media (max-width: 380px) {
  .ux-mobile {
    padding-left: 8px;
    padding-right: 8px;
  }

  .ux-hero h1,
  .ux-page-hero h1 {
    font-size: 23px;
  }

  .ux-actions,
  .ux-live-grid,
  .ux-metrics,
  .ux-board-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ux-plan {
    grid-template-columns: 1fr;
  }

  .ux-plan a {
    width: 100%;
  }
}

/* ── Mobile drawer polish: align menu with product UI ── */
@media (max-width: 768px) {
  .mobile-nav-overlay {
    background: rgba(15, 23, 42, 0.28) !important;
    backdrop-filter: blur(10px) saturate(140%) !important;
    -webkit-backdrop-filter: blur(10px) saturate(140%) !important;
  }

  .mobile-nav-drawer {
    width: min(340px, 88vw) !important;
    padding: 0 !important;
    border-left: 1px solid rgba(15, 23, 42, 0.06) !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%) !important;
    box-shadow: -24px 0 70px rgba(15, 23, 42, 0.18) !important;
  }

  .mobile-nav-drawer-header {
    min-height: 92px !important;
    padding: calc(var(--m-safe-top) + 18px) 18px 14px !important;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06) !important;
  }

  .drawer-brand {
    display: flex;
    align-items: center;
    min-width: 0;
    gap: 11px;
  }

  .drawer-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border-radius: 8px;
    background: linear-gradient(135deg, #10b981, #047857);
    color: #fff;
    font-size: 15px;
    font-weight: 850;
    box-shadow: 0 8px 18px rgba(16, 185, 129, 0.22);
  }

  .drawer-brand strong {
    display: block;
    color: #111827;
    font-size: 17px;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: 0;
  }

  .drawer-brand small {
    display: block;
    margin-top: 3px;
    color: #8a94a3;
    font-size: 11px;
    font-weight: 650;
    letter-spacing: 0;
  }

  .mobile-nav-drawer-close {
    width: 38px !important;
    height: 38px !important;
    flex: 0 0 38px !important;
    border: 1px solid rgba(15, 23, 42, 0.06) !important;
    background: #f3f4f6 !important;
    color: #64748b !important;
    box-shadow: none !important;
  }

  .mobile-nav-drawer-close svg {
    width: 17px;
    height: 17px;
  }

  .drawer-body {
    display: grid;
    gap: 3px;
    padding: 16px 12px 8px;
  }

  .mobile-nav-drawer .nav-section-label {
    padding: 17px 10px 7px !important;
    color: #94a3b8 !important;
    font-size: 11px !important;
    font-weight: 750 !important;
    letter-spacing: 0.08em !important;
    line-height: 1 !important;
  }

  .mobile-nav-drawer .nav-section-label:first-child {
    padding-top: 4px !important;
  }

  .mobile-nav-drawer a {
    min-height: 48px !important;
    margin: 0 !important;
    padding: 0 11px !important;
    gap: 11px !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    color: #162033 !important;
    font-size: 15px !important;
    font-weight: 720 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
    text-decoration: none !important;
  }

  .mobile-nav-drawer a span:last-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-nav-drawer .drawer-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    border-radius: 8px;
    background: #f5f7f9;
    color: #64748b;
  }

  .mobile-nav-drawer .drawer-icon svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .mobile-nav-drawer a.active {
    border-color: rgba(16, 185, 129, 0.16) !important;
    background: rgba(16, 185, 129, 0.075) !important;
    color: #047857 !important;
    font-weight: 800 !important;
  }

  .mobile-nav-drawer a.active .drawer-icon {
    background: #0f8f60;
    color: #fff;
  }

  .mobile-nav-drawer a:active {
    background: rgba(15, 23, 42, 0.04) !important;
    transform: translateY(1px);
  }

  .mobile-nav-drawer hr {
    display: none !important;
  }

  .drawer-footer {
    margin-top: auto;
    padding: 10px 12px calc(var(--m-safe-bottom) + 14px);
    border-top: 1px solid rgba(15, 23, 42, 0.06);
  }

  .drawer-footer .drawer-logout {
    color: #dc2626 !important;
    font-weight: 760 !important;
  }

  .drawer-footer .drawer-logout .drawer-icon {
    background: rgba(220, 38, 38, 0.08);
    color: #dc2626;
  }

  .topbar .brand-mark.brand-logo {
    width: 34px !important;
    height: 34px !important;
    padding: 3px !important;
    overflow: hidden !important;
    border: 1px solid rgba(15, 23, 42, 0.07) !important;
    border-radius: 9px !important;
    background: #fff !important;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08) !important;
  }

  .topbar .brand-mark.brand-logo img,
  .drawer-brand-mark.drawer-logo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 6px;
  }

  .drawer-brand-mark.drawer-logo {
    width: 36px !important;
    height: 36px !important;
    flex: 0 0 36px !important;
    padding: 3px !important;
    overflow: hidden !important;
    border: 1px solid rgba(15, 23, 42, 0.07) !important;
    border-radius: 9px !important;
    background: #fff !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08) !important;
  }
}

/* ── Trust Signals: Risk Summary, Audit Notes, Coverage ── */

.m-risk-checks {
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--m-bg-secondary, #f8fafc);
  border-radius: var(--m-r-md, 8px);
}
.m-risk-checks-label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--m-text-secondary, #475569);
  margin-bottom: 6px;
}
.m-risk-flag {
  font-size: 13px;
  line-height: 1.5;
  padding: 4px 0;
  color: var(--m-text, #1e293b);
}
.m-risk-flag strong { font-weight: 600; }
.m-risk-flag p {
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--m-text-tertiary, #94a3b8);
}
.m-risk-stake {
  margin-top: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--m-text-secondary, #475569);
  padding: 4px 8px;
  background: rgba(59, 130, 246, 0.08);
  border-radius: 6px;
  display: inline-block;
}

.m-risk-positive {
  margin-top: 8px;
  padding: 10px 12px;
  background: rgba(16, 185, 129, 0.06);
  border-radius: var(--m-r-md, 8px);
}
.m-risk-positive-label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #047857;
  margin-bottom: 4px;
}
.m-risk-positive-item {
  font-size: 12px;
  color: var(--m-text-secondary, #475569);
  padding: 2px 0;
  line-height: 1.5;
}

.m-audit-note {
  margin-top: 8px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 600;
  color: #047857;
  background: rgba(16, 185, 129, 0.08);
  border-radius: var(--m-r-md, 8px);
  text-align: center;
}
.m-audit-note-warn {
  color: #d97706;
  background: rgba(245, 158, 11, 0.08);
}

/* Reconciliation Note */
.m-reconciliation {
  margin-top: 8px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 500;
  color: #6366f1;
  background: rgba(99, 102, 241, 0.06);
  border-radius: var(--m-r-md, 8px);
  border: 1px solid rgba(99, 102, 241, 0.2);
  line-height: 1.6;
}

/* Risk Teaser CTA for free users */
.m-risk-teaser-cta {
  margin-top: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary, #2563eb);
  text-align: center;
  padding: 4px 0;
}

/* Onboarding mobile adjustments */
.onboarding-card {
  padding: 24px 20px 20px;
  border-radius: 14px;
}
.onboarding-card h2 { font-size: 18px; }
.onboarding-body p { font-size: 13px; }

/* ── Module 5: Mobile Personality Grid ── */
.m-personality-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 0 16px 16px;
}
.m-personality-card {
  background: var(--card, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 10px;
  padding: 12px;
}
.m-personality-card strong {
  font-size: 13px;
  display: block;
  margin-bottom: 4px;
}
.m-personality-card p {
  font-size: 12px;
  color: var(--muted-foreground, #6b7280);
  line-height: 1.5;
  margin: 0;
}

/* ── Module 6: Mobile Week Calendar ── */
.m-week-calendar {
  margin: 0 12px 14px;
  background: var(--card, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 14px;
  padding: 14px 14px 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.m-week-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}
.m-week-header strong {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.2px;
}
.m-week-header span {
  font-size: 11px;
  color: var(--muted-foreground, #6b7280);
  font-weight: 500;
}
.m-week-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.m-week-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 8px 2px 6px;
  border-radius: 10px;
  border: 1px solid transparent;
}
.m-week-day.today {
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.07), rgba(37, 99, 235, 0.02));
  border-color: var(--primary, #2563eb);
}
.m-week-day-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted-foreground, #9ca3af);
  letter-spacing: 0.3px;
  line-height: 1;
}
.m-week-day.today .m-week-day-label {
  color: var(--primary, #2563eb);
}
.m-week-blocks {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  justify-content: center;
  align-items: center;
  min-height: 22px;
}
.m-week-block {
  width: 12px;
  height: 12px;
  border-radius: 3px;
}
.m-week-block.published {
  background: var(--primary, #2563eb);
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.25);
}
.m-week-block.waiting {
  background: var(--border, #d1d5db);
  opacity: 0.45;
}
.m-week-block.none {
  background: transparent;
  border: 1px dashed var(--border, #e5e7eb);
}
.m-week-overflow {
  font-size: 11px;
  color: var(--muted-foreground, #6b7280);
  font-weight: 600;
  font-family: var(--font-mono, monospace);
}
.m-week-count {
  font-size: 11px;
  color: var(--muted-foreground, #6b7280);
  font-weight: 600;
  font-family: var(--font-mono, monospace);
  line-height: 1;
}
.m-week-day.today .m-week-count {
  color: var(--primary, #2563eb);
  font-weight: 700;
}
.m-week-next {
  font-size: 12px;
  color: var(--muted-foreground, #6b7280);
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border, #e5e7eb);
  text-align: center;
  font-weight: 500;
}

/* ══════════════════════════════════════════════════════════════════
   AUTH PAGES — Mobile Refinement
   ══════════════════════════════════════════════════════════════════ */

/* Shell reset for mobile */
.l-auth-shell {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh !important;
  padding: 0 !important;
  grid-template-columns: none !important;
}

/* Left panel always hidden on mobile */
.l-auth-left { display: none !important; }

/* Right panel fills full width */
.l-auth-right {
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Compact hero for auth pages — matches pg-hero dark but tighter */
.l-auth-hero-compact {
  padding: calc(28px + env(safe-area-inset-top, 0px)) 24px 24px !important;
  border-radius: 0 !important;
  margin: 0 !important;
  flex-shrink: 0;
}
.l-auth-hero-compact h1 {
  font-size: 22px !important;
  margin-top: 6px !important;
  margin-bottom: 4px !important;
}
.l-auth-hero-compact p {
  font-size: 13px !important;
  margin: 0 !important;
}

/* Form area below the hero */
.l-auth-form-wrap {
  max-width: 100% !important;
  padding: 20px 24px 40px !important;
  margin: 0 !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

/* Highlight box (register page) */
.l-auth-highlight-box {
  padding: 12px 14px !important;
  border-radius: 10px !important;
  margin-bottom: 20px !important;
  font-size: 13px !important;
}
.l-auth-highlight-box strong {
  font-size: 13px !important;
}
.l-auth-highlight-box p {
  font-size: 12px !important;
  margin-top: 2px !important;
}

/* Input fields */
.l-auth-field {
  margin-bottom: 16px !important;
}
.l-auth-field label {
  font-size: 13px !important;
  font-weight: 600 !important;
  margin-bottom: 6px !important;
}
.l-auth-input-wrap {
  border-radius: 10px !important;
}
.l-auth-input-wrap input {
  height: 48px !important;
  font-size: 16px !important;
  padding: 0 14px !important;
  border-radius: 10px !important;
  border: 1.5px solid var(--border, #e2e8f0) !important;
  background: var(--background, #fff) !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
.l-auth-input-wrap input:focus {
  border-color: #0d6b4a !important;
  box-shadow: 0 0 0 3px rgba(13, 107, 74, 0.1) !important;
  outline: none !important;
}
.l-auth-input-wrap input::placeholder {
  color: var(--muted-foreground, #94a3b8) !important;
  font-size: 15px !important;
}

/* Password toggle */
.l-auth-pw-toggle {
  width: 40px !important;
  height: 40px !important;
}

/* Password requirements */
.l-auth-pw-reqs {
  gap: 8px !important;
  margin-top: 8px !important;
}
.l-auth-pw-req {
  font-size: 12px !important;
  padding: 3px 8px !important;
  border-radius: 6px !important;
}

/* Checkbox area */
.l-auth-checks {
  gap: 10px !important;
  margin: 16px 0 !important;
}
.l-auth-check {
  gap: 10px !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  background: #f8fafc !important;
  color: #475569 !important;
}
.l-auth-check input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
  accent-color: #0d6b4a !important;
}
.l-auth-check span {
  font-size: 12.5px !important;
  color: #475569 !important;
}
.l-auth-check a {
  color: #0d6b4a !important;
  font-weight: 600 !important;
}

/* Error message */
.l-auth-error {
  font-size: 13px !important;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  margin-bottom: 12px !important;
}

/* Submit button */
.l-auth-submit {
  height: 50px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border-radius: 10px !important;
  width: 100% !important;
  border: none !important;
  cursor: pointer !important;
  transition: opacity 0.15s !important;
  background: linear-gradient(135deg, #064e3b, #047857, #059669) !important;
  color: #fff !important;
  letter-spacing: 0.02em !important;
}
.l-auth-submit:active { opacity: 0.85; }
.l-auth-submit-hint {
  font-size: 12px !important;
  text-align: center !important;
  margin-top: 8px !important;
  color: var(--muted-foreground, #94a3b8) !important;
}

/* Switch link */
.l-auth-switch {
  font-size: 14px !important;
  text-align: center !important;
  margin-top: 24px !important;
  color: var(--muted-foreground, #64748b) !important;
}
.l-auth-link {
  font-weight: 600 !important;
  color: #0d6b4a !important;
}

/* ══════════════════════════════════════════════════════════════════
   ACCOUNT PAGE — Mobile Refinement
   ══════════════════════════════════════════════════════════════════ */

.l-acct-page {
  padding: 0 !important;
}

.l-acct-hero {
  padding: 24px 20px 20px !important;
  border-radius: 0 !important;
}
.l-acct-hero-inner {
  flex-direction: row !important;
  align-items: center !important;
  gap: 14px !important;
}
.l-acct-hero-left {
  flex: 1 !important;
  min-width: 0 !important;
}
.l-acct-avatar {
  width: 44px !important;
  height: 44px !important;
  font-size: 16px !important;
}
.l-acct-hero-tag {
  font-size: 11px !important;
}
.l-acct-hero-email {
  font-size: 18px !important;
  word-break: break-all !important;
  margin: 2px 0 6px !important;
}
.l-acct-hero-tags {
  flex-wrap: wrap !important;
  gap: 4px !important;
}
.l-acct-tag {
  font-size: 11px !important;
  padding: 2px 8px !important;
}

.l-acct-hero-right {
  flex-shrink: 0 !important;
}
.l-acct-upgrade-btn,
.l-acct-manage-btn {
  font-size: 13px !important;
  padding: 8px 14px !important;
  border-radius: 8px !important;
  white-space: nowrap !important;
}

/* Hide hero KPIs on mobile (redundant) */
.l-acct-hero-kpis { display: none !important; }

/* Dual column → single column on mobile */
.l-acct-dual {
  grid-template-columns: 1fr !important;
  gap: 12px !important;
  padding: 12px 16px !important;
}

.l-acct-details-card,
.l-acct-actions-card {
  border-radius: 12px !important;
  padding: 0 !important;
}
.l-acct-card-header {
  padding: 14px 16px 0 !important;
}
.l-acct-card-tag {
  font-size: 11px !important;
}
.l-acct-card-title {
  font-size: 16px !important;
}
.l-acct-card-body {
  padding: 8px 16px 16px !important;
}

/* Detail rows */
.l-acct-detail-row {
  padding: 10px 0 !important;
}
.l-acct-detail-icon {
  width: 32px !important;
  height: 32px !important;
}
.l-acct-detail-icon svg { width: 16px !important; height: 16px !important; }
.l-acct-detail-label {
  font-size: 12px !important;
}
.l-acct-detail-value p {
  font-size: 14px !important;
}
.l-acct-copy-btn {
  width: 28px !important;
  height: 28px !important;
}

/* Action rows */
.l-acct-action-row {
  padding: 12px 0 !important;
}
.l-acct-action-title {
  font-size: 14px !important;
}
.l-acct-action-desc {
  font-size: 12px !important;
}
.l-acct-action-row svg { width: 18px !important; height: 18px !important; }

/* Logout button */
.l-acct-logout-btn {
  width: 100% !important;
  padding: 12px !important;
  font-size: 14px !important;
  border-radius: 8px !important;
  margin-top: 8px !important;
}

/* Hide bottom cards on mobile (all info already above) */
.l-acct-bottom-row { display: none !important; }

/* Divider */
.l-acct-divider {
  margin: 8px 0 !important;
}

/* ══════════════════════════════════════════════════════════════════
   COMMON BUTTONS — Mobile Override
   ══════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

.primary-button,
a.primary-button {
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--m-r-md, 8px) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 12px 24px !important;
  min-height: 44px !important;
  box-shadow: 0 2px 8px rgba(15, 118, 110, 0.18) !important;
  letter-spacing: 0 !important;
}
.primary-button:active { transform: scale(0.97) !important; opacity: 0.9; }

.ghost-button,
a.ghost-button {
  background: #fff !important;
  color: var(--m-text, #16202f) !important;
  border: 1.5px solid var(--m-border-strong, #cbd5e1) !important;
  border-radius: var(--m-r-md, 8px) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  padding: 12px 22px !important;
  min-height: 44px !important;
  box-shadow: none !important;
  letter-spacing: 0 !important;
}
.ghost-button:active { background: var(--m-bg, #f6f8fb) !important; transform: scale(0.97); }

.badge-pill {
  display: inline-block !important;
  padding: 4px 12px !important;
  background: var(--m-primary-soft, rgba(15, 118, 110, 0.09)) !important;
  color: var(--m-primary, #0f766e) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
}

.back-link {
  color: var(--m-primary, #0f766e) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

/* ══════════════════════════════════════════════════════════════════
   STRATEGY PAGE — Mobile Override (l-strategy-*)
   ══════════════════════════════════════════════════════════════════ */

.l-strategy-hero {
  padding: 24px 16px 16px !important;
  text-align: left !important;
}
.l-strategy-hero h1 {
  font-size: 24px !important;
  font-weight: 800 !important;
  margin: 8px 0 6px !important;
  letter-spacing: -0.02em !important;
  color: var(--m-text, #16202f) !important;
}
.l-strategy-hero p {
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: var(--m-text-secondary, #536171) !important;
}

.l-strategy-gate-bar {
  margin: 0 16px 16px !important;
  padding: 12px 14px !important;
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-md, 8px) !important;
  flex-direction: column !important;
  gap: 8px !important;
  font-size: 12px !important;
  color: var(--m-text-secondary, #536171) !important;
}
.l-strategy-gate-item {
  font-size: 12px !important;
  display: block !important;
}
.l-strategy-gate-item strong {
  color: var(--m-text, #16202f) !important;
}

.l-strategy-section {
  padding: 0 16px !important;
  margin-bottom: 20px !important;
}
.l-strategy-section-head {
  margin-bottom: 12px !important;
}
.l-strategy-section-head h2 {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
}
.l-strategy-section-sub {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.5 !important;
}
.l-strategy-section-actions {
  margin-top: 8px !important;
}

.l-strategy-refresh-btn {
  background: var(--m-primary-soft, rgba(15, 118, 110, 0.09)) !important;
  color: var(--m-primary, #0f766e) !important;
  border: none !important;
  border-radius: var(--m-r-sm, 6px) !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer;
}

.l-strategy-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.l-strategy-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  padding: 18px 16px !important;
  box-shadow: var(--m-shadow-sm, 0 1px 2px rgba(15, 23, 42, 0.05)) !important;
}
.l-strategy-card:hover { transform: none !important; box-shadow: var(--m-shadow-sm) !important; }

.l-strategy-card-badge {
  display: inline-block !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
}
.l-strategy-card-badge.high {
  background: rgba(16, 185, 129, 0.1) !important;
  color: #047857 !important;
}
.l-strategy-card-badge.medium {
  background: var(--m-amber-soft, rgba(217, 119, 6, 0.09)) !important;
  color: #b45309 !important;
}

.l-strategy-card-icon {
  font-size: 28px !important;
  margin-bottom: 6px !important;
}
.l-strategy-card-name {
  font-size: 17px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 4px !important;
}
.l-strategy-card-desc {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.5 !important;
  margin-bottom: 10px !important;
}

.l-strategy-card-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 10px !important;
}
.l-strategy-filter-tag {
  display: inline-block !important;
  padding: 3px 8px !important;
  background: var(--m-bg, #f6f8fb) !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--m-text-secondary, #536171) !important;
}

.l-strategy-card-stats,
.l-strategy-card-bt-stats {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-bottom: 10px !important;
}
.l-strategy-stat {
  font-size: 12px !important;
  color: var(--m-text-secondary, #536171) !important;
}
.l-strategy-stat strong {
  color: var(--m-text, #16202f) !important;
  font-weight: 700 !important;
}
.l-strategy-stat.up strong { color: #047857 !important; }
.l-strategy-stat.down strong { color: #dc2626 !important; }

.l-strategy-card-footer {
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 0.5px solid var(--m-border, #dfe5ee) !important;
}

.l-strategy-sub-btn {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  padding: 12px 16px !important;
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--m-r-md, 8px) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.l-strategy-sub-btn-ghost {
  background: #fff !important;
  color: var(--m-text, #16202f) !important;
  border: 1.5px solid var(--m-border-strong, #cbd5e1) !important;
}
.l-strategy-card-subbed {
  font-size: 13px !important;
  color: #047857 !important;
  font-weight: 600 !important;
  text-align: center !important;
  display: block !important;
}

.l-strategy-empty {
  text-align: center !important;
  padding: 40px 16px !important;
  background: var(--m-card, #fff) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
}
.l-strategy-empty p {
  color: var(--m-text-secondary, #536171) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

.l-strategy-guide {
  margin: 0 16px 16px !important;
  padding: 16px !important;
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
}
.l-strategy-guide-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  margin-bottom: 12px !important;
}
.l-strategy-guide-badge {
  display: inline-block !important;
  padding: 3px 10px !important;
  background: var(--m-primary-soft) !important;
  color: var(--m-primary) !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  margin-bottom: 4px !important;
}
.l-strategy-guide-close {
  background: none !important;
  border: none !important;
  font-size: 18px !important;
  color: var(--m-text-tertiary, #7b8794) !important;
  cursor: pointer !important;
  padding: 4px !important;
}
.l-strategy-guide-steps {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.l-strategy-guide-step {
  display: flex !important;
  gap: 12px !important;
  padding: 10px !important;
  border-radius: var(--m-r-md, 8px) !important;
  background: var(--m-bg, #f6f8fb) !important;
}
.l-strategy-guide-step.active {
  background: var(--m-primary-soft, rgba(15, 118, 110, 0.09)) !important;
  border: 1px solid rgba(15, 118, 110, 0.2) !important;
}
.l-strategy-guide-step-num {
  width: 28px !important;
  height: 28px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 50% !important;
  background: var(--m-border, #dfe5ee) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  flex-shrink: 0 !important;
}
.l-strategy-guide-step.active .l-strategy-guide-step-num {
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
}
.l-strategy-guide-step.done .l-strategy-guide-step-num {
  background: #059669 !important;
  color: #fff !important;
}
.l-strategy-guide-step-content strong {
  font-size: 14px !important;
  font-weight: 700 !important;
  display: block !important;
  margin-bottom: 2px !important;
}
.l-strategy-guide-step-content p {
  font-size: 12px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}

/* ══════════════════════════════════════════════════════════════════
   PRICING PAGE — Mobile Override (l-pricing-*)
   ══════════════════════════════════════════════════════════════════ */

.l-pricing-hero {
  padding: 24px 16px 16px !important;
  text-align: center !important;
}
.l-pricing-hero h1 {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
}
.l-pricing-hero p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
}

.l-pricing-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  padding: 0 16px !important;
  max-width: 100% !important;
}

.l-pricing-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  padding: 24px 20px !important;
  text-align: center !important;
  box-shadow: var(--m-shadow-sm) !important;
}
.l-pricing-card:hover { transform: none !important; box-shadow: var(--m-shadow-sm) !important; }
.l-pricing-card.featured {
  border: 2px solid var(--m-primary, #0f766e) !important;
  box-shadow: 0 4px 16px rgba(15, 118, 110, 0.12) !important;
}

.l-pricing-card-name {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--m-text-secondary, #536171) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 8px !important;
}
.l-pricing-card-price {
  font-size: 36px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.03em !important;
}
.l-pricing-card-period {
  font-size: 13px !important;
  color: var(--m-text-tertiary, #7b8794) !important;
  margin-bottom: 16px !important;
}
.l-pricing-card-features {
  text-align: left !important;
  margin-bottom: 16px !important;
}
.l-pricing-card-features ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.l-pricing-card-features li {
  padding: 6px 0 !important;
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.5 !important;
  border-bottom: 0.5px solid var(--m-border, #dfe5ee) !important;
}
.l-pricing-card-features li:last-child { border-bottom: none !important; }

.l-pricing-card-btn {
  display: block !important;
  width: 100% !important;
  padding: 14px 16px !important;
  border-radius: var(--m-r-md, 8px) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-decoration: none !important;
  min-height: 44px !important;
}
.l-pricing-card-btn.primary {
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
  border: none !important;
}
.l-pricing-card-btn:not(.primary) {
  background: #fff !important;
  color: var(--m-text, #16202f) !important;
  border: 1.5px solid var(--m-border-strong, #cbd5e1) !important;
}

/* FAQ cards on pricing page */
.l-faq-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 0 16px !important;
  margin-top: 20px !important;
}
.l-faq-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-md, 8px) !important;
  padding: 16px !important;
}
.l-faq-card h4 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin-bottom: 6px !important;
}
.l-faq-card p {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ══════════════════════════════════════════════════════════════════
   LEGAL PAGES — Mobile Override (l-legal-*)
   ══════════════════════════════════════════════════════════════════ */

.l-legal-page {
  padding: 0 !important;
}
.l-legal-page .l-page-card {
  background: var(--m-card, #fff) !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
  padding: 24px 16px !important;
  margin: 0 !important;
}
.l-legal-page h1 {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 16px !important;
}
.l-legal-page h2 {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin: 20px 0 8px !important;
}
.l-legal-page h3 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin: 16px 0 6px !important;
}
.l-legal-page p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.7 !important;
  margin-bottom: 12px !important;
}
.l-legal-page ul, .l-legal-page ol {
  padding-left: 20px !important;
  margin-bottom: 12px !important;
}
.l-legal-page li {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.7 !important;
  margin-bottom: 4px !important;
}

/* ══════════════════════════════════════════════════════════════════
   LANDING PAGE DESKTOP — Mobile Override (l-landing-*, l-how-*)
   ══════════════════════════════════════════════════════════════════ */

.l-landing-hero {
  padding: 32px 16px 20px !important;
  text-align: center !important;
}
.l-landing-hero h1 {
  font-size: 26px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.03em !important;
  line-height: 1.15 !important;
}
.l-landing-hero p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
}

.l-how-section {
  padding: 20px 16px !important;
}
.l-how-section h2 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  text-align: center !important;
  margin-bottom: 16px !important;
}
.l-how-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
.l-how-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  padding: 20px 16px !important;
}
.l-how-card h3 {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin-bottom: 6px !important;
}
.l-how-card p, .l-how-card ol, .l-how-card li {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
}
.l-how-card-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--m-primary, #0f766e) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin-bottom: 6px !important;
  display: block !important;
}

/* ══════════════════════════════════════════════════════════════════
   NOTIFICATION / ORDER PAGES — Mobile Override
   ══════════════════════════════════════════════════════════════════ */

.l-notif-page, .l-orders-page {
  padding: 0 16px !important;
}
.l-notif-page h1, .l-orders-page h1 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  padding: 16px 0 12px !important;
}
.l-notif-item, .l-order-row {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-md, 8px) !important;
  padding: 14px 16px !important;
  margin-bottom: 8px !important;
}

/* ══════════════════════════════════════════════════════════════════
   METHOD PAGE — Mobile Override
   ══════════════════════════════════════════════════════════════════ */

.l-method-page {
  padding: 0 !important;
}
.l-method-page .l-page-card {
  background: var(--m-card, #fff) !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
  padding: 24px 16px !important;
  margin: 0 !important;
}
.l-method-page h1 {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  margin-bottom: 12px !important;
}
.l-method-page h2 {
  font-size: 17px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin: 20px 0 8px !important;
}
.l-method-page p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.7 !important;
}

/* ══════════════════════════════════════════════════════════════════
   GENERAL DESKTOP OVERRIDES — Mobile
   ══════════════════════════════════════════════════════════════════ */

/* Page header consistency */
.l-page-header {
  padding: 16px 16px 12px !important;
}
.l-page-header h1 {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
}
.l-page-header p {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
}

/* Generic page cards */
.l-page-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  padding: 20px 16px !important;
  box-shadow: var(--m-shadow-sm) !important;
  margin: 0 16px 12px !important;
}

/* Empty state */
.empty {
  text-align: center !important;
  padding: 48px 24px !important;
}
.empty p, .empty div {
  color: var(--m-text-secondary, #536171) !important;
  font-size: 14px !important;
}

/* Follow / copy buttons */
.follow-btn {
  background: var(--m-primary-soft, rgba(15, 118, 110, 0.09)) !important;
  color: var(--m-primary, #0f766e) !important;
  border: none !important;
  border-radius: var(--m-r-sm, 6px) !important;
  padding: 6px 12px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  cursor: pointer;
}
.follow-btn.active {
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
}
.copy-btn {
  background: var(--m-bg, #f6f8fb) !important;
  color: var(--m-text-secondary, #536171) !important;
  border: 1px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-sm, 6px) !important;
  padding: 6px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer;
}

/* Trust chip */
.trust-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 10px !important;
  background: var(--m-bg, #f6f8fb) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--m-text-secondary, #536171) !important;
}

/* Stats/metrics on performance page */
.l-stats-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 8px !important;
  padding: 0 16px !important;
  margin-bottom: 16px !important;
}
.l-stats-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-md, 8px) !important;
  padding: 14px 12px !important;
  text-align: center !important;
}
.l-stats-card span {
  font-size: 10px !important;
  color: var(--m-text-tertiary, #7b8794) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  display: block !important;
  margin-bottom: 4px !important;
}
.l-stats-card strong {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
}

/* Results table on mobile */
.l-results-table {
  width: 100% !important;
  font-size: 13px !important;
}
.l-results-table th {
  font-size: 10px !important;
  font-weight: 700 !important;
  color: var(--m-text-tertiary, #7b8794) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  padding: 8px 6px !important;
  border-bottom: 1px solid var(--m-border, #dfe5ee) !important;
}
.l-results-table td {
  padding: 10px 6px !important;
  font-size: 13px !important;
  color: var(--m-text, #16202f) !important;
  border-bottom: 0.5px solid var(--m-border, #dfe5ee) !important;
}

/* ══════════════════════════════════════════════════════════════════
   SECTION HEAD — Shared across pages
   ══════════════════════════════════════════════════════════════════ */

.section-head {
  padding: 16px 16px 12px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.section-head h1, .section-head h2 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
}
.section-head p {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  margin: 0 !important;
  line-height: 1.5 !important;
}

/* ══════════════════════════════════════════════════════════════════
   METHOD PAGE — Mobile Override (panel, method-*)
   ══════════════════════════════════════════════════════════════════ */

.panel {
  padding: 0 16px !important;
}
.method-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.method-item {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-md, 8px) !important;
  padding: 16px !important;
}
.method-item h3 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin-bottom: 6px !important;
}
.method-item p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}
.risk-statement {
  margin: 16px !important;
  padding: 16px !important;
  background: var(--m-amber-soft, rgba(217, 119, 6, 0.09)) !important;
  border: 1px solid rgba(245, 158, 11, 0.2) !important;
  border-radius: var(--m-r-md, 8px) !important;
}
.risk-statement h3 {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--m-text, #16202f) !important;
  margin-bottom: 6px !important;
}
.risk-statement p {
  font-size: 13px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ══════════════════════════════════════════════════════════════════
   PRICING PAGE — Fix header/section classes
   ══════════════════════════════════════════════════════════════════ */

.l-pricing-section {
  padding: 0 !important;
  margin-bottom: 20px !important;
}
.l-pricing-header {
  text-align: center !important;
  padding: 24px 16px 16px !important;
}
.l-pricing-header h2 {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  letter-spacing: -0.02em !important;
  margin: 8px 0 6px !important;
}
.l-pricing-header p {
  font-size: 14px !important;
  color: var(--m-text-secondary, #536171) !important;
  line-height: 1.6 !important;
}

/* ══════════════════════════════════════════════════════════════════
   CHECKOUT / SUBSCRIPTION PAGES — Mobile Override
   ══════════════════════════════════════════════════════════════════ */

.l-checkout-page, .l-sub-page {
  padding: 0 16px !important;
}
.l-checkout-page h1, .l-sub-page h1 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: var(--m-text, #16202f) !important;
  padding: 16px 0 12px !important;
}
.l-checkout-card, .l-sub-card {
  background: var(--m-card, #fff) !important;
  border: 0.5px solid var(--m-border, #dfe5ee) !important;
  border-radius: var(--m-r-lg, 10px) !important;
  padding: 20px 16px !important;
  margin-bottom: 12px !important;
}

/* ══════════════════════════════════════════════════════════════════
   STICKY CTA — Mobile Override
   ══════════════════════════════════════════════════════════════════ */

.sticky-cta {
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px)) !important;
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(12px) !important;
  border-top: 0.5px solid var(--m-border, #dfe5ee) !important;
  z-index: 50 !important;
}
.sticky-cta a, .sticky-cta button {
  display: block !important;
  width: 100% !important;
  padding: 14px !important;
  background: var(--m-primary, #0f766e) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--m-r-md, 8px) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  text-align: center !important;
  text-decoration: none !important;
}

/* ── SVG icon sizing (replace emoji) ── */
.m-personality-card strong svg { width: 16px; height: 16px; vertical-align: -2px; }
.m-section-head h2 svg { width: 16px; height: 16px; vertical-align: -2px; }
.m-risk-checks-label svg,
.m-risk-positive-label svg,
.m-audit-note svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-btn-icon svg { width: 16px; height: 16px; }
.m-week-next svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-reconciliation svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-risk-flag svg { width: 10px; height: 10px; }
.m-risk-teaser-cta svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-unlock p svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-grade-row svg { width: 14px; height: 14px; vertical-align: -1px; }
.m-positive-list li svg { width: 14px; height: 14px; vertical-align: -1px; }

} /* end @media (max-width: 768px) for common + page overrides */

/* ══════════════════════════════════════════════════════════
   VISUAL HIERARCHY — Focal Points for All Pages
   ══════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

/* ── 1. LANDING: Hero Focal Card ── */
.ux-hero {
  margin: 8px 12px 20px;
  padding: 32px 22px 26px;
  border: none;
  border-radius: 24px;
  background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
  box-shadow: 0 8px 40px rgba(16,185,129,0.18), 0 2px 8px rgba(0,0,0,0.06);
  position: relative;
  overflow: hidden;
}
.ux-hero::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.22) 0%, transparent 70%);
  pointer-events: none;
}
.ux-hero::after {
  content: '';
  position: absolute;
  bottom: -30px;
  left: -20px;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
  pointer-events: none;
}
.ux-hero .ux-eyebrow {
  background: rgba(255,255,255,0.5);
  color: #052e21;
  font-weight: 700;
  backdrop-filter: blur(6px);
}
.ux-hero h1 {
  color: #052e21 !important;
  font-size: 28px !important;
  line-height: 1.15 !important;
  max-width: 14em;
  position: relative;
}
.ux-hero p {
  color: #1a4731 !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  position: relative;
}
.ux-actions {
  margin-top: 18px;
  gap: 10px;
  position: relative;
}
.ux-actions a.primary {
  background: #052e21;
  border-color: #052e21;
  color: #bbf7d0;
  font-size: 15px;
  font-weight: 800;
  min-height: 46px;
  border-radius: 14px;
  box-shadow: 0 4px 14px rgba(5,46,33,0.3);
}
.ux-actions a:not(.primary) {
  background: rgba(255,255,255,0.55);
  border-color: rgba(255,255,255,0.6);
  backdrop-filter: blur(8px);
  color: #052e21;
  border-radius: 14px;
  min-height: 46px;
  font-weight: 700;
}

/* Landing: secondary sections de-emphasized */
.ux-landing .ux-live-card,
.ux-landing .ux-section,
.ux-landing .ux-trial,
.ux-landing .ux-risk {
  opacity: 0.92;
}
.ux-landing .ux-section-head h2 {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--m-text-secondary, #64748b) !important;
}
.ux-landing .ux-risk {
  background: transparent;
  border: 0.5px solid var(--m-border, #e2e8f0);
  font-size: 12px;
  padding: 12px 14px;
}
.ux-landing .ux-metrics {
  opacity: 0.88;
}

/* ── 2. TODAY: Match Cards as Focal ── */
.ux-today .ux-page-hero {
  margin: 6px 12px 10px;
  padding: 14px 16px;
  border: none;
  background: none;
  box-shadow: none;
}
.ux-today .ux-page-hero h1 {
  font-size: 22px !important;
  font-weight: 800 !important;
  color: var(--m-text-primary, #0f172a) !important;
}
.ux-today .ux-page-hero p {
  font-size: 13px !important;
  color: var(--m-text-tertiary, #94a3b8) !important;
  margin-top: 2px !important;
}
.ux-today .ux-page-hero .ux-eyebrow {
  font-size: 10px;
  padding: 3px 8px;
  margin-bottom: 4px;
}
.ux-today .ux-metrics {
  opacity: 0.85;
  margin-bottom: 10px;
}
/* Today match cards: elevate ones with predictions */
.ux-today .ux-match-card {
  margin: 0 12px 10px;
  border-radius: 16px;
  padding: 14px 16px;
  border: 0.5px solid var(--m-border, #e2e8f0);
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  transition: transform 0.15s;
}
.ux-today .ux-match-card:active {
  transform: scale(0.985);
}
.ux-today .ux-match-card.ux-state-ready,
.ux-today .ux-match-card.ux-state-positive {
  border-color: rgba(16,185,129,0.3);
  box-shadow: 0 4px 16px rgba(16,185,129,0.1), 0 1px 4px rgba(0,0,0,0.04);
  background: linear-gradient(180deg, rgba(236,253,245,0.5) 0%, #fff 50%);
}
.ux-today .ux-day-head {
  padding: 0 16px;
  margin: 12px 0 6px;
}
.ux-today .ux-day-head h2 {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--m-text-secondary, #64748b) !important;
}
.ux-today .ux-day-head span {
  font-size: 11px;
  color: var(--m-text-tertiary, #94a3b8);
}

/* ── 3. RESULTS: Stats Hero Banner ── */
.m-results-hero {
  margin: 8px 12px 16px;
  padding: 28px 20px 22px;
  border-radius: 24px;
  background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
  box-shadow: 0 8px 40px rgba(16,185,129,0.15), 0 2px 8px rgba(0,0,0,0.05);
  position: relative;
  overflow: hidden;
}
.m-results-hero::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -30px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.2) 0%, transparent 70%);
  pointer-events: none;
}
.m-results-hero h1 {
  font-size: 24px !important;
  font-weight: 900 !important;
  color: #052e21 !important;
  margin: 0 0 2px;
  position: relative;
}
.m-results-hero > p {
  font-size: 13px !important;
  color: #1a4731 !important;
  margin: 0 0 16px;
  position: relative;
}
.m-results-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 14px 0;
  position: relative;
}
.m-results-hero-stat {
  text-align: center;
  border-right: 1px solid rgba(0,0,0,0.06);
}
.m-results-hero-stat:last-child { border-right: none; }
.m-results-hero-stat strong {
  display: block;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1;
  color: #052e21;
}
.m-results-hero-stat span {
  display: block;
  font-size: 11px;
  color: #1a4731;
  margin-top: 4px;
  font-weight: 500;
}

/* ── Results: dual AH/OU cards ── */
.m-results-dual-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 12px;
  position: relative;
}
.m-results-type-card {
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 14px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  overflow: hidden;
}
.m-results-type-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
}
.m-results-type-ah::before {
  background: linear-gradient(90deg, #f59e0b, #14b8a6);
}
.m-results-type-ou::before {
  background: linear-gradient(90deg, #10b981, #3b82f6);
}
.m-results-type-head {
  display: flex;
  align-items: center;
  gap: 6px;
}
.m-results-type-icon {
  display: inline-flex;
  align-items: center;
  color: #1a4731;
}
.m-results-type-icon svg {
  width: 14px;
  height: 14px;
}
.m-results-type-label {
  font-size: 12px;
  font-weight: 700;
  color: #1a4731;
  letter-spacing: 0.3px;
}
.m-results-type-rate {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  font-family: ui-monospace, 'SF Mono', monospace;
}
.m-results-type-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding-top: 8px;
  border-top: 1px solid rgba(0,0,0,0.06);
}
.m-results-type-grid > div {
  text-align: center;
}
.m-results-type-grid strong {
  display: block;
  font-size: 14px;
  font-weight: 800;
  color: #052e21;
  line-height: 1.2;
}
.m-results-type-grid span {
  display: block;
  font-size: 9px;
  color: #1a4731;
  font-weight: 500;
  margin-top: 1px;
}
.m-results-type-foot {
  font-size: 10px;
  color: #1a4731;
  opacity: 0.7;
  font-weight: 500;
  text-align: center;
  padding-top: 4px;
}
.m-results-total-bar {
  text-align: center;
  font-size: 12px;
  color: #1a4731;
  font-weight: 600;
  opacity: 0.7;
  position: relative;
}
.m-results-total-bar strong {
  font-weight: 800;
}

/* Results list: compact, de-emphasized */
.m-result-card {
  margin: 0 12px;
  border-radius: 0;
  border-left: 0.5px solid var(--m-border, #e2e8f0);
  border-right: 0.5px solid var(--m-border, #e2e8f0);
}
.m-result-card:first-child {
  border-radius: 16px 16px 0 0;
  border-top: 0.5px solid var(--m-border, #e2e8f0);
}
.m-result-card:last-child {
  border-radius: 0 0 16px 16px;
  border-bottom: 0.5px solid var(--m-border, #e2e8f0);
  margin-bottom: 16px;
}
.m-result-card:only-child {
  border-radius: 16px;
  border: 0.5px solid var(--m-border, #e2e8f0);
}

/* ── 4. PERFORMANCE: KPI Dashboard Focal ── */
.m-perf-hero {
  margin: 8px 12px 20px;
  padding: 28px 18px 22px;
  border-radius: 24px;
  background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
  box-shadow: 0 8px 40px rgba(16,185,129,0.15), 0 2px 8px rgba(0,0,0,0.05);
  position: relative;
  overflow: hidden;
}
.m-perf-hero::before {
  content: '';
  position: absolute;
  top: -50px;
  right: -30px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.2) 0%, transparent 70%);
  pointer-events: none;
}
.m-perf-hero-header {
  position: relative;
  margin-bottom: 16px;
}
.m-perf-hero-header h1 {
  font-size: 22px !important;
  font-weight: 900 !important;
  color: #052e21 !important;
  margin: 0 0 2px;
}
.m-perf-hero-header p {
  font-size: 12px !important;
  color: #1a4731 !important;
  margin: 0;
}
.m-perf-hero .m-kpi-grid {
  margin: 0;
  gap: 0;
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(12px);
  border-radius: 16px;
  padding: 16px 0;
  position: relative;
  grid-template-columns: repeat(4, 1fr);
}
.m-perf-hero .m-kpi {
  background: none;
  border: none;
  box-shadow: none;
  border-right: 1px solid rgba(0,0,0,0.06);
  border-radius: 0;
  padding: 4px 8px;
}
.m-perf-hero .m-kpi:last-child { border-right: none; }
.m-perf-hero .m-kpi strong {
  font-size: 20px;
  font-weight: 900;
  color: #052e21;
}
.m-perf-hero .m-kpi.good strong { color: #047857; }
.m-perf-hero .m-kpi.bad strong { color: #dc2626; }
.m-perf-hero .m-kpi span {
  font-size: 10px;
  color: #1a4731;
  font-weight: 500;
}
/* Performance: secondary sections compact */
.m-perf-sections .m-section {
  padding: 0 14px;
  margin-bottom: 2px;
}
.m-perf-sections .m-section-head h2 {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--m-text-secondary, #64748b) !important;
}
.m-perf-sections .m-roi-card {
  border-radius: 14px;
}

/* ── 5. STRATEGIES: Focal Cards ── */
.l-strategy-hero {
  margin: 8px 12px 16px;
  padding: 24px 20px 20px;
  border-radius: 24px;
  background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
  box-shadow: 0 8px 40px rgba(16,185,129,0.15), 0 2px 8px rgba(0,0,0,0.05);
  position: relative;
  overflow: hidden;
}
.l-strategy-hero::before {
  content: '';
  position: absolute;
  top: -50px;
  right: -30px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.18) 0%, transparent 70%);
  pointer-events: none;
}
.l-strategy-hero h1 {
  color: #052e21 !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  position: relative;
}
.l-strategy-hero p {
  color: #1a4731 !important;
  font-size: 13px !important;
  position: relative;
}
.l-strategy-hero .badge-pill {
  background: rgba(255,255,255,0.5);
  color: #052e21;
  backdrop-filter: blur(6px);
  position: relative;
}
/* Strategy discover cards: elevated */
.l-strategy-card {
  border-radius: 18px !important;
  border: 0.5px solid var(--m-border, #e2e8f0) !important;
  box-shadow: 0 3px 12px rgba(0,0,0,0.05) !important;
  transition: transform 0.15s;
}
.l-strategy-card:active {
  transform: scale(0.985);
}
/* Strategy sections de-emphasized */
.l-strategy-section-head h2 {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--m-text-secondary, #64748b) !important;
}

/* ── 6. PRICING: Recommended Plan Focal ── */
.pricing-grid .plan-card.recommended {
  border-radius: 24px !important;
  background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%) !important;
  border: none !important;
  box-shadow: 0 8px 40px rgba(16,185,129,0.18), 0 2px 8px rgba(0,0,0,0.06) !important;
  position: relative;
  overflow: hidden;
  transform: scale(1.02);
}
.pricing-grid .plan-card.recommended::before {
  content: '';
  position: absolute;
  top: -40px;
  right: -25px;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(16,185,129,0.2) 0%, transparent 70%);
  pointer-events: none;
}
.pricing-grid .plan-card.recommended .plan-name {
  color: #052e21;
  font-weight: 900;
  position: relative;
}
.pricing-grid .plan-card.recommended .plan-price {
  color: #052e21;
  font-weight: 900;
  position: relative;
}
.pricing-grid .plan-card.recommended .plan-desc {
  color: #1a4731;
  position: relative;
}
.pricing-grid .plan-card.recommended .primary-button,
.pricing-grid .plan-card.recommended a.primary-button {
  background: #052e21 !important;
  color: #bbf7d0 !important;
  border: none !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 14px rgba(5,46,33,0.3);
  position: relative;
}
.pricing-grid .plan-card.recommended .plan-recommend-badge {
  background: rgba(255,255,255,0.6);
  color: #052e21;
  backdrop-filter: blur(6px);
  border-radius: 999px;
  font-weight: 700;
}
/* Non-recommended pricing cards: de-emphasize */
.pricing-grid .plan-card:not(.recommended) {
  opacity: 0.88;
  border-radius: 18px;
}
/* Pricing page header de-emphasize */
.membership-strip {
  opacity: 0.85;
}
.member-value-panel {
  opacity: 0.9;
}

} /* end @media (max-width: 768px) — visual hierarchy */

/* ══════════════════════════════════════════════════════════
   DESKTOP VISUAL HIERARCHY — Pricing + Strategies focal points
   ══════════════════════════════════════════════════════════ */

@media (min-width: 769px) {
  .pricing-grid .plan-card.recommended {
    border-radius: 24px !important;
    background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%) !important;
    border: none !important;
    box-shadow: 0 8px 40px rgba(16,185,129,0.18), 0 2px 8px rgba(0,0,0,0.06) !important;
    position: relative;
    overflow: hidden;
    transform: scale(1.03);
  }
  .pricing-grid .plan-card.recommended::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -30px;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.2) 0%, transparent 70%);
    pointer-events: none;
  }
  .pricing-grid .plan-card.recommended .plan-name {
    color: #052e21;
    font-weight: 900;
    position: relative;
  }
  .pricing-grid .plan-card.recommended .plan-price {
    color: #052e21;
    font-weight: 900;
    font-size: 36px;
    position: relative;
  }
  .pricing-grid .plan-card.recommended .plan-desc {
    color: #1a4731;
    position: relative;
  }
  .pricing-grid .plan-card.recommended .primary-button,
  .pricing-grid .plan-card.recommended a.primary-button {
    background: #052e21 !important;
    color: #bbf7d0 !important;
    border: none !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 14px rgba(5,46,33,0.3);
    position: relative;
  }
  .pricing-grid .plan-card.recommended .plan-recommend-badge {
    background: rgba(255,255,255,0.6);
    color: #052e21;
    backdrop-filter: blur(6px);
    border-radius: 999px;
    font-weight: 700;
  }
  .pricing-grid .plan-card:not(.recommended) {
    opacity: 0.88;
    border-radius: 18px;
  }
  /* Desktop strategies hero focal */
  .l-strategy-hero {
    border-radius: 24px;
    background: linear-gradient(155deg, #ecfdf5 0%, #bbf7d0 35%, #86efac 70%, #bbf7d0 100%);
    box-shadow: 0 8px 40px rgba(16,185,129,0.12), 0 2px 8px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
  }
  .l-strategy-hero::before {
    content: '';
    position: absolute;
    top: -60px;
    right: -40px;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.18) 0%, transparent 70%);
    pointer-events: none;
  }
  .l-strategy-hero h1 {
    color: #052e21 !important;
    position: relative;
  }
  .l-strategy-hero p {
    color: #1a4731 !important;
    position: relative;
  }
  .l-strategy-hero .badge-pill {
    background: rgba(255,255,255,0.5);
    color: #052e21;
    backdrop-filter: blur(6px);
    position: relative;
  }
} /* end @media (min-width: 769px) — desktop styles */

/* ═══════════════════════════════════════════════════════════
   Landing Page V2 — Conversion Funnel (Mobile)
   Hook → Proof → Urgency → Product → Trust → Convert
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  .lx-landing {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  /* ── 1. Hero ── */
  .lx-hero {
    padding: 32px 16px 28px;
    text-align: center;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
  }
  .lx-hero-tag {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    color: #047857;
    letter-spacing: 0.5px;
    background: rgba(16,185,129,0.1);
    padding: 4px 12px;
    border-radius: 999px;
    margin-bottom: 14px;
  }
  .lx-hero h1 {
    font-size: 28px !important;
    font-weight: 900 !important;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--foreground, #0f172a);
    margin: 0 0 10px;
  }
  .lx-hero-sub {
    font-size: 14px !important;
    color: var(--muted-foreground, #64748b);
    line-height: 1.5;
    margin: 0 0 20px;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }
  .lx-hero-num {
    margin: 20px 0 24px;
  }
  .lx-hero-num strong {
    display: block;
    font-size: 48px;
    font-weight: 900;
    font-family: ui-monospace, 'SF Mono', monospace;
    letter-spacing: -2px;
    line-height: 1;
  }
  .lx-hero-num strong.pos { color: #047857; }
  .lx-hero-num strong.neg { color: #dc2626; }
  .lx-hero-num span {
    display: block;
    font-size: 12px;
    color: var(--muted-foreground, #64748b);
    margin-top: 6px;
    font-weight: 600;
  }
  .lx-hero-cta {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
  }

  /* ── Buttons ── */
  .lx-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 48px;
    padding: 10px 20px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.15s;
  }
  .lx-btn svg { flex-shrink: 0; }
  .lx-btn-primary {
    background: #047857;
    color: #fff;
    box-shadow: 0 4px 16px rgba(4,120,87,0.25);
  }
  .lx-btn-primary:active { transform: scale(0.97); }
  .lx-btn-ghost {
    background: rgba(0,0,0,0.04);
    color: var(--foreground, #0f172a);
    border: 1px solid rgba(0,0,0,0.08);
  }
  .lx-btn-sm {
    min-height: 40px;
    padding: 8px 16px;
    font-size: 14px;
    border-radius: 10px;
  }

  /* ── 2. Proof ── */
  .lx-proof {
    margin: 0 12px 20px;
    padding: 20px 16px 16px;
    border-radius: 20px;
    background: linear-gradient(155deg, #ecfdf5, #d1fae5 60%, #a7f3d0);
    box-shadow: 0 8px 32px rgba(16,185,129,0.12);
    position: relative;
    overflow: hidden;
  }
  .lx-proof::before {
    content: '';
    position: absolute;
    top: -30px; right: -20px;
    width: 100px; height: 100px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15), transparent 70%);
  }
  .lx-proof-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 14px;
    position: relative;
  }
  .lx-proof-head strong {
    font-size: 16px;
    font-weight: 800;
    color: #052e21;
  }
  .lx-proof-head span {
    font-size: 11px;
    color: #1a4731;
    font-weight: 500;
  }
  .lx-proof-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    position: relative;
  }
  .lx-proof-card {
    background: rgba(255,255,255,0.6);
    backdrop-filter: blur(10px);
    border-radius: 14px;
    padding: 14px 12px;
    position: relative;
    overflow: hidden;
  }
  .lx-proof-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
  }
  .lx-proof-ah::before { background: linear-gradient(90deg, #f59e0b, #14b8a6); }
  .lx-proof-ou::before { background: linear-gradient(90deg, #10b981, #3b82f6); }
  .lx-proof-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 700;
    color: #1a4731;
    margin-bottom: 6px;
  }
  .lx-proof-label svg { width: 14px; height: 14px; }
  .lx-proof-rate {
    font-size: 30px;
    font-weight: 900;
    font-family: ui-monospace, 'SF Mono', monospace;
    letter-spacing: -1px;
    line-height: 1;
    color: #052e21;
    margin-bottom: 8px;
  }
  .lx-proof-rate.pos { color: #047857; }
  .lx-proof-rate.neg { color: #dc2626; }
  .lx-proof-detail {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    color: #1a4731;
    font-weight: 600;
    padding-top: 8px;
    border-top: 1px solid rgba(0,0,0,0.06);
  }
  .lx-proof-detail .pos { color: #047857; font-weight: 800; }
  .lx-proof-detail .neg { color: #dc2626; font-weight: 800; }
  .lx-proof-footer {
    text-align: center;
    margin-top: 14px;
    position: relative;
  }
  .lx-proof-footer a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 700;
    color: #047857;
    text-decoration: none;
  }
  .lx-proof-footer a svg { width: 14px; height: 14px; }

  /* ── 3. Urgency — Live Status ── */
  .lx-live {
    margin: 0 12px 20px;
    padding: 16px 14px;
    border-radius: 16px;
    background: var(--card, #fff);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    cursor: pointer;
  }
  .lx-live:active { transform: scale(0.99); }
  .lx-live-quiet { cursor: pointer; }
  .lx-live-quiet p {
    font-size: 13px;
    color: var(--muted-foreground, #64748b);
    margin: 8px 0 0;
  }
  .lx-live-top {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
  }
  .lx-live-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #10b981;
    box-shadow: 0 0 8px rgba(16,185,129,0.5);
    animation: lx-pulse 2s ease-in-out infinite;
  }
  @keyframes lx-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
  }
  .lx-live-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted-foreground, #64748b);
    letter-spacing: 0.3px;
    text-transform: uppercase;
  }
  .lx-live-status {
    margin-left: auto;
    font-size: 11px;
    font-weight: 700;
    color: #047857;
    background: rgba(16,185,129,0.1);
    padding: 2px 8px;
    border-radius: 6px;
  }
  .lx-live-league {
    font-size: 11px;
    color: var(--muted-foreground, #64748b);
    font-weight: 600;
  }
  .lx-live-match {
    margin-top: 8px;
  }
  .lx-live-teams {
    font-size: 17px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
    margin-top: 2px;
    letter-spacing: -0.2px;
  }
  .lx-live-teams em { font-style: normal; opacity: 0.4; margin: 0 4px; }
  .lx-live-meta {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(0,0,0,0.05);
  }
  .lx-live-meta > div { text-align: center; }
  .lx-live-meta span {
    display: block;
    font-size: 10px;
    color: var(--muted-foreground, #64748b);
    font-weight: 500;
  }
  .lx-live-meta strong {
    display: block;
    font-size: 14px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
    margin-top: 2px;
  }

  /* ── 4. Product ── */
  .lx-product {
    margin: 0 12px 20px;
    padding: 20px 16px;
    border-radius: 20px;
    background: var(--card, #fff);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 4px 20px rgba(0,0,0,0.04);
  }
  .lx-product-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 16px;
  }
  .lx-product-head strong {
    font-size: 16px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
  }
  .lx-product-head span {
    font-size: 11px;
    color: var(--muted-foreground, #64748b);
    font-weight: 600;
    background: rgba(16,185,129,0.08);
    padding: 2px 8px;
    border-radius: 6px;
  }
  .lx-sample-card {
    background: #f8fafc;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 18px;
  }
  .lx-sample-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
  }
  .lx-sample-league {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted-foreground, #64748b);
  }
  .lx-sample-hit {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 700;
    color: #047857;
    background: rgba(16,185,129,0.1);
    padding: 2px 8px;
    border-radius: 6px;
  }
  .lx-sample-hit svg { width: 12px; height: 12px; }
  .lx-sample-teams {
    font-size: 16px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
    margin-bottom: 4px;
  }
  .lx-sample-teams em { font-style: normal; opacity: 0.4; margin: 0 4px; }
  .lx-sample-score {
    font-size: 13px;
    color: var(--muted-foreground, #64748b);
    font-weight: 600;
    margin-bottom: 10px;
  }
  .lx-sample-legs { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
  .lx-sample-leg {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.04);
    border-radius: 10px;
  }
  .lx-sample-market {
    font-size: 10px;
    font-weight: 700;
    color: #047857;
    background: rgba(16,185,129,0.08);
    padding: 2px 6px;
    border-radius: 4px;
    flex-shrink: 0;
  }
  .lx-sample-play {
    font-size: 13px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
    flex: 1;
  }
  .lx-sample-ok {
    color: #047857;
    flex-shrink: 0;
  }
  .lx-sample-ok svg { width: 14px; height: 14px; }
  .lx-sample-pnl {
    text-align: center;
    font-size: 18px;
    font-weight: 900;
    font-family: ui-monospace, 'SF Mono', monospace;
    letter-spacing: -0.5px;
  }
  .lx-sample-pnl.pos { color: #047857; }
  .lx-sample-pnl.neg { color: #dc2626; }

  .lx-product-steps { display: flex; flex-direction: column; gap: 12px; }
  .lx-step {
    display: flex;
    gap: 12px;
    align-items: flex-start;
  }
  .lx-step-num {
    display: grid;
    place-items: center;
    width: 28px; height: 28px;
    border-radius: 8px;
    background: rgba(16,185,129,0.1);
    color: #047857;
    font-size: 13px;
    font-weight: 800;
    flex-shrink: 0;
  }
  .lx-step strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
  }
  .lx-step p {
    font-size: 12px;
    color: var(--muted-foreground, #64748b);
    margin: 2px 0 0;
    line-height: 1.4;
  }

  /* ── Recent Results ── */
  .lx-recent {
    margin: 0 12px 20px;
  }
  .lx-recent-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 4px;
    margin-bottom: 10px;
  }
  .lx-recent-head strong {
    font-size: 15px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
  }
  .lx-recent-head a {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    font-weight: 600;
    color: #047857;
    text-decoration: none;
  }
  .lx-recent-head a svg { width: 12px; height: 12px; }
  .lx-recent-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(0,0,0,0.04);
    cursor: pointer;
  }
  .lx-recent-item:active { background: rgba(0,0,0,0.02); }
  .lx-recent-teams {
    font-size: 14px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
  }
  .lx-recent-teams em { font-style: normal; opacity: 0.4; margin: 0 3px; }
  .lx-recent-right {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .lx-recent-score {
    font-size: 12px;
    color: var(--muted-foreground, #64748b);
    font-weight: 600;
  }
  .lx-recent-pnl {
    font-size: 14px;
    font-weight: 800;
    font-family: ui-monospace, 'SF Mono', monospace;
    min-width: 50px;
    text-align: right;
  }
  .lx-recent-pnl.pos { color: #047857; }
  .lx-recent-pnl.neg { color: #dc2626; }

  /* ── 5. Trust ── */
  .lx-trust {
    margin: 0 12px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .lx-trust-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 14px;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid rgba(0,0,0,0.04);
  }
  .lx-trust-item > svg {
    width: 20px; height: 20px;
    flex-shrink: 0;
    color: #047857;
    margin-top: 2px;
  }
  .lx-trust-item strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
  }
  .lx-trust-item p {
    font-size: 12px;
    color: var(--muted-foreground, #64748b);
    margin: 3px 0 0;
    line-height: 1.5;
  }

  /* ── 6. Convert ── */
  .lx-convert {
    margin: 0 12px 20px;
    padding: 20px 16px;
    border-radius: 20px;
    background: linear-gradient(180deg, #f0fdf4, #ecfdf5);
    border: 1px solid rgba(16,185,129,0.15);
  }
  .lx-convert-head {
    margin-bottom: 14px;
  }
  .lx-convert-head strong {
    font-size: 16px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
  }
  .lx-convert-trial {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    background: #fff;
    border-radius: 14px;
    border: 2px solid rgba(16,185,129,0.2);
    margin-bottom: 12px;
  }
  .lx-convert-trial-info span {
    font-size: 10px;
    font-weight: 700;
    color: #047857;
    letter-spacing: 0.3px;
    text-transform: uppercase;
  }
  .lx-convert-trial-info strong {
    display: block;
    font-size: 15px;
    font-weight: 800;
    color: var(--foreground, #0f172a);
    margin-top: 2px;
  }
  .lx-convert-trial-info p {
    font-size: 11px;
    color: var(--muted-foreground, #64748b);
    margin: 3px 0 0;
    line-height: 1.4;
  }
  .lx-convert-plan {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    background: rgba(255,255,255,0.7);
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,0.05);
    margin-bottom: 12px;
  }
  .lx-convert-plan strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
  }
  .lx-convert-plan span {
    font-size: 12px;
    color: var(--muted-foreground, #64748b);
    font-weight: 500;
  }
  .lx-convert-more {
    text-align: center;
  }
  .lx-convert-more a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: #047857;
    text-decoration: none;
  }
  .lx-convert-more a svg { width: 12px; height: 12px; }

  /* ── FAQ ── */
  .lx-faq {
    margin: 0 12px 20px;
  }
  .lx-faq-item {
    border-bottom: 1px solid rgba(0,0,0,0.06);
    padding: 14px 0;
  }
  .lx-faq-item summary {
    font-size: 14px;
    font-weight: 700;
    color: var(--foreground, #0f172a);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .lx-faq-item summary::after {
    content: '+';
    font-size: 18px;
    font-weight: 400;
    color: var(--muted-foreground, #64748b);
  }
  .lx-faq-item[open] summary::after { content: '−'; }
  .lx-faq-item p {
    font-size: 13px;
    color: var(--muted-foreground, #64748b);
    line-height: 1.6;
    margin: 8px 0 0;
  }

  /* ── Risk disclaimer ── */
  .lx-risk {
    margin: 0 12px 20px;
    padding: 14px;
    border-radius: 12px;
    background: #fef3c7;
    border: 1px solid rgba(245,158,11,0.2);
  }
  .lx-risk p {
    font-size: 11px;
    color: #92400e;
    line-height: 1.6;
    margin: 0;
    text-align: center;
  }
}

/* ═══════════════════════════════════════════════════════════
   Unified Mobile Design System — All Pages
   Consistent with Landing: emerald gradients · generous
   spacing · strong hierarchy · elevated cards
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ━━ Shared Gradient Hero ━━ */
  .pg-hero {
    margin: 0 0 20px;
    padding: 32px 20px 28px;
    border-radius: 0 0 28px 28px;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
    position: relative;
    overflow: hidden;
  }
  .pg-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
    pointer-events: none;
  }
  .pg-hero-eyebrow {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    color: #047857;
    letter-spacing: 0.5px;
    background: rgba(16,185,129,0.1);
    padding: 3px 10px;
    border-radius: 999px;
    margin-bottom: 12px;
    position: relative;
  }
  .pg-hero h1 {
    font-size: 24px;
    font-weight: 900;
    color: #0f172a;
    margin: 0 0 6px;
    letter-spacing: -0.5px;
    position: relative;
  }
  .pg-hero p {
    font-size: 13px;
    color: #64748b;
    margin: 0;
    line-height: 1.5;
    position: relative;
  }
  .pg-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin-top: 20px;
    background: rgba(255,255,255,0.65);
    backdrop-filter: blur(12px);
    border-radius: 16px;
    padding: 16px 0;
    position: relative;
  }
  .pg-hero-metric {
    text-align: center;
    border-right: 1px solid rgba(0,0,0,0.06);
  }
  .pg-hero-metric:last-child { border-right: none; }
  .pg-hero-metric strong {
    display: block;
    font-size: 28px;
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 1;
    color: #052e21;
  }
  .pg-hero-metric span {
    display: block;
    font-size: 10px;
    color: #64748b;
    margin-top: 5px;
    font-weight: 500;
  }

  /* ━━ Dark Hero Variant (Landing / Pricing / Strategies) ━━ */
  .pg-hero.dark {
    background: linear-gradient(135deg, #064e3b 0%, #047857 50%, #059669 100%);
    color: #fff;
  }
  .pg-hero.dark::before {
    background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%);
  }
  .pg-hero.dark h1 { color: #fff; }
  .pg-hero.dark p { color: rgba(255,255,255,0.85); }
  .pg-hero.dark .pg-hero-eyebrow {
    background: rgba(255,255,255,0.15);
    color: #bbf7d0;
  }
  .pg-hero.dark .pg-hero-metrics {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(12px);
  }
  .pg-hero.dark .pg-hero-metric strong { color: #bbf7d0; }
  .pg-hero.dark .pg-hero-metric span { color: rgba(255,255,255,0.6); }
  .pg-hero.dark .pg-hero-metric { border-color: rgba(255,255,255,0.1); }
  .pg-hero.dark .lx-hero-num strong.pos { color: #34d399; }
  .pg-hero.dark .lx-hero-num strong.neg { color: #fca5a5; }
  .pg-hero.dark .lx-hero-num span { color: rgba(255,255,255,0.6); }
  .pg-hero.dark .m-results-total-bar { color: rgba(255,255,255,0.6); opacity: 1; }
  .pg-hero.dark .m-results-type-card {
    background: rgba(255,255,255,0.12);
    border: 0.5px solid rgba(255,255,255,0.1);
  }
  .pg-hero.dark .m-results-type-label { color: rgba(255,255,255,0.8); }
  .pg-hero.dark .m-results-type-foot { color: rgba(255,255,255,0.5); }
  .pg-hero.dark .m-results-type-grid span { color: rgba(255,255,255,0.6); }
  .pg-hero.dark .m-results-type-grid strong { color: rgba(255,255,255,0.9); }
  .pg-hero.dark .m-results-type-icon { color: #bbf7d0; }
  .pg-hero.dark .m-results-type-grid { border-top-color: rgba(255,255,255,0.12); }

  /* Pricing chips on dark bg */
  .pg-hero.dark .pg-pricing-chip {
    color: #bbf7d0;
    background: rgba(255,255,255,0.12);
  }

  /* Landing proof section below hero */
  .pg-hero.dark + .lx-proof,
  .pg-hero.dark ~ .lx-proof {
    color: #0f172a;
  }

  /* Week calendar (below Today dark hero) — stays light, no changes needed */

  /* Account page elements on dark bg */
  .pg-hero.dark .l-acct-hero-email { color: #fff; }
  .pg-hero.dark .l-acct-hero-tag { color: rgba(255,255,255,0.6); }
  .pg-hero.dark .l-acct-tag {
    color: #bbf7d0;
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.1);
  }
  .pg-hero.dark .l-acct-tag-ok { color: #34d399; }
  .pg-hero.dark .l-acct-tag-warn { color: #fbbf24; }
  .pg-hero.dark .l-acct-hero-glow {
    background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%);
  }
  .pg-hero.dark .l-acct-upgrade-btn {
    color: #052e21 !important;
    background: #bbf7d0 !important;
  }
  .pg-hero.dark .l-acct-manage-btn {
    color: #bbf7d0 !important;
    background: rgba(255,255,255,0.1) !important;
  }

  /* ━━ Unified Hero Actions (buttons row) ━━ */
  .pg-hero-actions {
    display: flex;
    gap: 10px;
    margin-top: 20px;
    position: relative;
  }
  .pg-hero-actions .m-btn { flex: 1; }

  /* ━━ Unified Hero Stat Chip ━━ */
  .pg-hero-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    padding: 4px 12px;
    font-size: 12px;
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.1);
    border-radius: 20px;
    position: relative;
  }

  /* ━━ Shared Section ━━ */
  .pg-section {
    padding: 0 16px;
    margin-bottom: 24px;
  }
  .pg-section-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(0,0,0,0.04);
  }
  .pg-section-head strong {
    font-size: 15px;
    font-weight: 800;
    color: #0f172a;
  }
  .pg-section-head a,
  .pg-section-head span {
    font-size: 12px;
    color: #047857;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 2px;
    text-decoration: none;
  }
  .pg-section-head svg { width: 12px; height: 12px; }

  /* ━━ Shared Value Card ━━ */
  .pg-value-card {
    background: #fff;
    border-radius: 16px;
    padding: 18px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
    margin-bottom: 10px;
  }
  .pg-value-card p {
    font-size: 13px;
    color: #64748b;
    line-height: 1.6;
    margin: 0;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     TODAY PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .ux-today .ux-page-hero {
    margin: 0;
    padding: 28px 20px 24px;
    border-radius: 0 0 28px 28px;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.1), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.03), transparent 60%);
    position: relative;
    overflow: hidden;
  }
  .ux-today .ux-page-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.12) 0%, transparent 70%);
    pointer-events: none;
  }
  .ux-today .ux-page-hero h1 {
    font-size: 26px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
    letter-spacing: -0.5px;
    position: relative;
  }
  .ux-today .ux-page-hero p {
    font-size: 13px !important;
    color: #64748b !important;
    margin-top: 4px !important;
    position: relative;
  }
  .ux-today .ux-page-hero .ux-eyebrow {
    font-size: 10px;
    padding: 3px 10px;
    margin-bottom: 10px;
    background: rgba(16,185,129,0.1);
    color: #047857;
    position: relative;
  }
  .ux-today .ux-metrics {
    margin: 0 16px 16px;
    padding: 14px 0;
    background: rgba(255,255,255,0.65);
    backdrop-filter: blur(12px);
    border-radius: 16px;
    opacity: 1;
    border: 0.5px solid rgba(0,0,0,0.04);
  }
  .ux-today .ux-metrics div { padding: 2px 0; }
  .ux-today .ux-metrics strong {
    font-size: 24px !important;
    font-weight: 900 !important;
    letter-spacing: -0.03em;
    color: #052e21;
  }
  .ux-today .ux-metrics span {
    font-size: 10px;
    color: #64748b;
    font-weight: 500;
  }
  .ux-today .ux-day-head {
    padding: 0 20px;
    margin: 18px 0 10px;
  }
  .ux-today .ux-day-head h2 {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #94a3b8 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  .ux-today .ux-day-head span {
    font-size: 11px;
    color: #cbd5e1;
    font-weight: 600;
  }
  .ux-today .ux-match-card {
    margin: 0 16px 12px;
    border-radius: 18px;
    padding: 16px 18px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
    transition: transform 0.15s;
  }
  .ux-today .ux-match-card:active { transform: scale(0.985); }
  .ux-today .ux-match-card h2 {
    font-size: 17px !important;
    font-weight: 800 !important;
    letter-spacing: -0.3px;
  }
  .ux-today .ux-match-card.ux-state-ready,
  .ux-today .ux-match-card.ux-state-positive {
    border-color: rgba(16,185,129,0.25);
    box-shadow: 0 4px 18px rgba(16,185,129,0.08), 0 1px 4px rgba(0,0,0,0.03);
    background: linear-gradient(180deg, rgba(236,253,245,0.4) 0%, #fff 40%);
  }

  /* Week calendar */
  .m-week-calendar {
    margin: 0 16px 16px;
    padding: 14px 16px;
    background: #fff;
    border-radius: 16px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
  }
  .m-week-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
  }
  .m-week-header strong { font-size: 13px; font-weight: 700; color: #0f172a; }
  .m-week-header span { font-size: 11px; color: #94a3b8; }
  .m-week-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
  }
  .m-week-day {
    text-align: center;
    padding: 6px 2px;
    border-radius: 10px;
  }
  .m-week-day.today {
    background: rgba(16,185,129,0.08);
  }
  .m-week-day-label {
    font-size: 10px;
    font-weight: 700;
    color: #94a3b8;
    display: block;
    margin-bottom: 4px;
  }
  .m-week-day.today .m-week-day-label { color: #047857; }
  .m-week-blocks {
    display: flex;
    flex-direction: column;
    gap: 2px;
    align-items: center;
    min-height: 12px;
  }
  .m-week-block {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #e2e8f0;
  }
  .m-week-block.has-match { background: #10b981; }
  .m-week-block.has-prediction { background: #047857; }
  .m-week-block.none { background: transparent; }
  .m-week-count {
    font-size: 11px;
    font-weight: 800;
    color: #0f172a;
    display: block;
    margin-top: 4px;
  }
  .m-week-next {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(0,0,0,0.04);
    font-size: 12px;
    color: #64748b;
    display: flex;
    align-items: center;
    gap: 4px;
  }
  .m-week-next svg { width: 12px; height: 12px; color: #047857; }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     RESULTS PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .m-results-hero {
    margin: 0 0 20px;
    padding: 32px 20px 26px;
    border-radius: 0 0 28px 28px;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
    box-shadow: none;
    position: relative;
    overflow: hidden;
  }
  .m-results-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
    pointer-events: none;
  }
  .m-results-hero h1 {
    font-size: 26px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
    margin: 0 0 4px;
    letter-spacing: -0.5px;
    position: relative;
  }
  .m-results-hero > p {
    font-size: 13px !important;
    color: #64748b !important;
    margin: 0 0 20px;
    position: relative;
  }
  .m-results-dual-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 16px;
    position: relative;
  }
  .m-results-type-card {
    background: #fff;
    border-radius: 18px;
    padding: 16px 12px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
    text-align: center;
  }
  .m-results-type-head {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    margin-bottom: 8px;
  }
  .m-results-type-icon svg { width: 14px; height: 14px; color: #047857; }
  .m-results-type-label {
    font-size: 12px;
    font-weight: 700;
    color: #64748b;
  }
  .m-results-type-rate {
    font-size: 32px;
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 8px;
  }
  .m-results-type-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    padding-top: 8px;
    border-top: 1px solid rgba(0,0,0,0.04);
  }
  .m-results-type-grid strong {
    font-size: 14px;
    font-weight: 800;
    color: #0f172a;
    display: block;
  }
  .m-results-type-grid span {
    font-size: 9px;
    color: #94a3b8;
    display: block;
  }
  .m-results-type-foot {
    font-size: 10px;
    color: #94a3b8;
    margin-top: 8px;
  }
  .m-results-total-bar {
    text-align: center;
    font-size: 12px;
    color: #94a3b8;
    padding: 8px 0 0;
    position: relative;
  }
  .m-results-total-bar strong { color: #0f172a; font-weight: 800; }
  .m-result-card {
    margin: 0 16px 12px;
    padding: 16px 18px;
    background: #fff;
    border-radius: 18px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 10px rgba(0,0,0,0.04);
    cursor: pointer;
    transition: transform 0.15s;
  }
  .m-result-card:active { transform: scale(0.985); }
  .m-result-teams {
    font-size: 16px;
    font-weight: 800;
    color: #0f172a;
    letter-spacing: -0.2px;
  }
  .m-vs { font-style: normal; opacity: 0.3; margin: 0 4px; }
  .m-result-score {
    font-size: 22px;
    font-weight: 900;
    color: #0f172a;
    margin: 6px 0;
    letter-spacing: -0.03em;
  }
  .m-result-pnl {
    font-size: 16px;
    font-weight: 900;
    letter-spacing: -0.02em;
  }
  .m-result-pnl.positive { color: #047857; }
  .m-result-pnl.negative { color: #dc2626; }
  .m-legs-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 8px 0;
  }
  .m-leg-tag {
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #475569;
    font-weight: 600;
  }
  .m-leg-tag.win { background: rgba(5,150,105,0.08); color: #047857; }
  .m-leg-tag.lose { background: rgba(239,68,68,0.06); color: #dc2626; }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     PERFORMANCE PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .m-perf-hero {
    margin: 0 0 20px;
    padding: 32px 20px 26px;
    border-radius: 0 0 28px 28px;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
    box-shadow: none;
    position: relative;
    overflow: hidden;
  }
  .m-perf-hero::before {
    content: '';
    position: absolute;
    top: -50px; right: -30px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
    pointer-events: none;
  }
  .m-perf-hero-header { position: relative; margin-bottom: 18px; }
  .m-perf-hero-header h1 {
    font-size: 26px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
    margin: 0 0 4px;
    letter-spacing: -0.5px;
  }
  .m-perf-hero-header p {
    font-size: 12px !important;
    color: #64748b !important;
    margin: 0;
  }
  .m-perf-hero .m-kpi-grid {
    margin: 0;
    gap: 0;
    background: rgba(255,255,255,0.65);
    backdrop-filter: blur(12px);
    border-radius: 16px;
    padding: 16px 0;
    position: relative;
    grid-template-columns: repeat(4, 1fr);
    border: 0.5px solid rgba(0,0,0,0.04);
  }
  .m-perf-hero .m-kpi {
    background: none;
    border: none;
    box-shadow: none;
    border-right: 1px solid rgba(0,0,0,0.06);
    border-radius: 0;
    padding: 4px 8px;
  }
  .m-perf-hero .m-kpi:last-child { border-right: none; }
  .m-perf-hero .m-kpi strong {
    font-size: 22px;
    font-weight: 900;
    color: #052e21;
    letter-spacing: -0.03em;
  }
  .m-perf-hero .m-kpi span {
    font-size: 10px;
    color: #64748b;
    font-weight: 500;
  }
  .m-perf-sections {
    padding: 0;
  }
  .m-perf-sections .m-section {
    padding: 0 16px;
    margin-bottom: 20px;
  }
  .m-perf-sections .m-section-head h2 {
    font-size: 15px !important;
    font-weight: 800 !important;
    color: #0f172a !important;
    letter-spacing: -0.2px;
  }
  .m-perf-sections .m-roi-card {
    border-radius: 16px;
    padding: 18px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
  }
  .m-perf-sections .m-roi-rate {
    font-size: 32px;
    font-weight: 900;
    letter-spacing: -0.03em;
  }
  .m-perf-sections .m-grade-row {
    padding: 12px 16px;
    background: #fff;
    border-radius: 14px;
    border: 0.5px solid rgba(0,0,0,0.05);
    margin-bottom: 6px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .m-perf-sections .m-grade-row span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #0f172a;
  }
  .m-perf-sections .m-grade-row small {
    display: block;
    font-size: 10px;
    color: #94a3b8;
    font-weight: 400;
    margin-top: 2px;
  }
  .m-perf-sections .m-grade-row strong {
    font-size: 15px;
    font-weight: 800;
  }
  .m-personality-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 0 16px 8px;
  }
  .m-personality-card {
    background: #fff;
    border-radius: 14px;
    padding: 14px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 6px rgba(0,0,0,0.02);
  }
  .m-personality-card strong {
    font-size: 13px;
    font-weight: 800;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 4px;
  }
  .m-personality-card strong svg { width: 14px; height: 14px; color: #047857; }
  .m-personality-card p {
    font-size: 11px;
    color: #64748b;
    line-height: 1.5;
    margin: 6px 0 0;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     PRICING PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .pg-pricing-hero {
    margin: 0;
    padding: 36px 20px 32px;
    text-align: center;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
    position: relative;
    overflow: hidden;
  }
  .pg-pricing-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
    pointer-events: none;
  }
  .pg-pricing-hero h1 {
    font-size: 28px;
    font-weight: 900;
    color: #0f172a;
    margin: 0 0 8px;
    letter-spacing: -0.5px;
    position: relative;
  }
  .pg-pricing-hero p {
    font-size: 14px;
    color: #64748b;
    margin: 0 0 24px;
    line-height: 1.5;
    position: relative;
  }
  .pg-pricing-values {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    position: relative;
  }
  .pg-pricing-body {
    padding: 0 16px 4px;
  }
  .pg-pricing-body .pg-section {
    padding: 0;
  }
  .pg-pricing-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    color: #047857;
    background: rgba(16,185,129,0.08);
    padding: 5px 12px;
    border-radius: 999px;
  }
  .pg-pricing-chip svg { width: 12px; height: 12px; }
  .pg-plan-card {
    margin: 0 0 14px;
    background: #fff;
    border-radius: 20px;
    padding: 24px 20px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 4px 16px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
  }
  .pg-plan-card.featured {
    border-color: rgba(16,185,129,0.3);
    box-shadow: 0 4px 24px rgba(16,185,129,0.12), 0 2px 8px rgba(0,0,0,0.04);
    background: linear-gradient(180deg, rgba(236,253,245,0.3) 0%, #fff 40%);
  }
  .pg-plan-card.featured::before {
    content: '常用方案';
    position: absolute;
    top: 0; right: 20px;
    background: #047857;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 0 0 10px 10px;
    letter-spacing: 0.3px;
  }
  .pg-plan-name {
    font-size: 14px;
    font-weight: 700;
    color: #64748b;
    margin-bottom: 4px;
  }
  .pg-plan-price {
    font-size: 38px;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -0.03em;
    line-height: 1;
    margin-bottom: 4px;
  }
  .pg-plan-price span {
    font-size: 14px;
    font-weight: 600;
    color: #94a3b8;
  }
  .pg-plan-trial {
    font-size: 12px;
    color: #047857;
    font-weight: 600;
    margin-bottom: 8px;
  }
  .pg-plan-desc {
    font-size: 13px;
    color: #64748b;
    line-height: 1.5;
    margin-bottom: 16px;
  }
  .pg-plan-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 800;
    text-decoration: none;
    transition: transform 0.15s;
  }
  .pg-plan-btn:active { transform: scale(0.97); }
  .pg-plan-btn-primary {
    background: linear-gradient(135deg, #059669, #10b981);
    color: #fff;
    box-shadow: 0 4px 14px rgba(16,185,129,0.25);
  }
  .pg-plan-btn-ghost {
    background: #f8fafc;
    color: #0f172a;
    border: 1px solid rgba(0,0,0,0.08);
  }
  .pg-pricing-trust {
    margin: 24px 16px;
    padding: 18px;
    background: #fef3c7;
    border-radius: 14px;
    border: 1px solid rgba(245,158,11,0.2);
  }
  .pg-pricing-trust p {
    font-size: 12px;
    color: #92400e;
    line-height: 1.6;
    margin: 0;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     MATCH DETAIL PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .m-detail-header {
    padding: 16px 16px 0;
    margin-bottom: 16px;
  }
  .m-detail-teams h1 {
    font-size: 22px !important;
    font-weight: 900 !important;
    letter-spacing: -0.3px;
    color: #0f172a;
  }
  .m-detail-teams h1 em {
    font-style: normal;
    opacity: 0.3;
    margin: 0 6px;
  }
  .m-detail-dir {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin: 0 16px 16px;
    background: #fff;
    border-radius: 16px;
    padding: 14px 0;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
  }
  .m-detail-dir > div {
    text-align: center;
    border-right: 1px solid rgba(0,0,0,0.06);
  }
  .m-detail-dir > div:last-child { border-right: none; }
  .m-detail-dir span {
    display: block;
    font-size: 10px;
    color: #94a3b8;
    font-weight: 500;
    margin-bottom: 4px;
  }
  .m-detail-dir strong {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: #0f172a;
  }
  .m-verdict-card {
    margin: 0 16px 16px;
    padding: 20px;
    background: linear-gradient(135deg, #ecfdf5 0%, #f0fdf4 100%);
    border-radius: 20px;
    border: 1px solid rgba(16,185,129,0.2);
    box-shadow: 0 4px 16px rgba(16,185,129,0.08);
  }
  .m-verdict-label {
    font-size: 11px;
    font-weight: 700;
    color: #047857;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 6px;
  }
  .m-verdict-choice {
    font-size: 24px;
    font-weight: 900;
    color: #052e21;
    letter-spacing: -0.3px;
    margin-bottom: 12px;
  }
  .m-metric-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin: 0 16px 16px;
  }
  .m-metric-card {
    background: #fff;
    border-radius: 14px;
    padding: 14px 10px;
    text-align: center;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 6px rgba(0,0,0,0.02);
  }
  .m-metric-card span {
    font-size: 10px;
    color: #94a3b8;
    display: block;
    margin-bottom: 4px;
  }
  .m-metric-card strong {
    font-size: 15px;
    font-weight: 800;
    color: #0f172a;
    display: block;
  }
  .m-metric-card p {
    font-size: 9px;
    color: #cbd5e1;
    margin: 4px 0 0;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     PAGINATION
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  /* Results wrapper — isolate from #app grid */
  .m-results-wrap {
    display: block;
  }

  /* Pagination — three equal flex cells */
  .m-pag {
    display: flex;
    margin: 12px 16px 24px;
    background: #fff;
    border-radius: 14px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
    overflow: hidden;
  }
  .m-pag-cell {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
  }
  .m-pag-mid {
    font-size: 14px;
    font-weight: 800;
    color: #0f172a;
    border-left: 1px solid rgba(0,0,0,0.04);
    border-right: 1px solid rgba(0,0,0,0.04);
  }
  .m-pag-btn {
    background: none;
    border: none;
    padding: 0;
    font-size: 13px;
    font-weight: 700;
    color: #0f172a;
    cursor: pointer;
    line-height: 48px;
    white-space: nowrap;
  }
  .m-pag-btn:active { color: #047857; }
  .m-pag-btn:disabled { color: #cbd5e1; cursor: default; }
  .m-pag-btn svg {
    width: 12px;
    height: 12px;
    vertical-align: -1px;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     STRATEGIES PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .l-strategy-hero {
    margin: 0;
    padding: 32px 20px 28px;
    border-radius: 0 0 28px 28px;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.12), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.04), transparent 60%);
    box-shadow: none;
    position: relative;
    overflow: hidden;
  }
  .l-strategy-hero::before {
    content: '';
    position: absolute;
    top: -40px; right: -30px;
    width: 120px; height: 120px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,0.15) 0%, transparent 70%);
    pointer-events: none;
  }
  .l-strategy-hero h1 {
    font-size: 26px !important;
    font-weight: 900 !important;
    color: #0f172a !important;
    letter-spacing: -0.5px;
    position: relative;
  }
  .l-strategy-hero p {
    font-size: 13px !important;
    color: #64748b !important;
    position: relative;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     ACCOUNT PAGE
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
  .l-acct-page {
    padding-bottom: 20px;
  }
  .l-acct-hero {
    margin: 0;
    padding: 36px 20px 32px;
    text-align: center;
    background:
      radial-gradient(ellipse 80% 60% at 50% 0%, rgba(16,185,129,0.1), transparent),
      linear-gradient(180deg, rgba(5,46,33,0.03), transparent 60%);
    border-radius: 0 0 28px 28px;
    position: relative;
    overflow: hidden;
  }
  .l-acct-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, #059669, #10b981);
    color: #fff;
    font-size: 24px;
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
    box-shadow: 0 4px 16px rgba(16,185,129,0.2);
  }
  .l-acct-action-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    background: #fff;
    border-radius: 14px;
    border: 0.5px solid rgba(0,0,0,0.06);
    margin: 0 16px 8px;
    text-decoration: none;
    transition: transform 0.15s;
  }
  .l-acct-action-row:active { transform: scale(0.985); }
  .l-acct-action-title {
    font-size: 14px;
    font-weight: 700;
    color: #0f172a;
    margin: 0;
  }
  .l-acct-action-desc {
    font-size: 12px;
    color: #94a3b8;
    margin: 2px 0 0;
  }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     MARKET COLOR CODING
     AH = Emerald · OU = Indigo
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

  /* — Today page leg list — */
  .ux-leg-list span {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 8px;
    margin-right: 4px;
  }
  .ux-leg-ah {
    background: rgba(4,120,87,0.08);
    color: #047857;
  }
  .ux-leg-ou {
    background: rgba(37,99,235,0.08);
    color: #2563eb;
  }

  /* — Results page leg tags — */
  .m-leg-tag.m-leg-ah {
    background: rgba(4,120,87,0.08);
    color: #047857;
  }
  .m-leg-tag.m-leg-ou {
    background: rgba(37,99,235,0.08);
    color: #2563eb;
  }
  .m-leg-tag.m-leg-ah.win { background: rgba(4,120,87,0.15); }
  .m-leg-tag.m-leg-ou.win { background: rgba(37,99,235,0.15); }
  .m-leg-tag.m-leg-ah.lose { background: rgba(239,68,68,0.08); color: #dc2626; }
  .m-leg-tag.m-leg-ou.lose { background: rgba(239,68,68,0.08); color: #dc2626; }

  /* — Detail page leg rows — */
  .m-leg-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-top: 0.5px solid rgba(0,0,0,0.04);
  }
  .m-leg-item:first-child { border-top: none; }
  .m-leg-row-ah {
    border-left: 3px solid #10b981;
  }
  .m-leg-row-ou {
    border-left: 3px solid #3b82f6;
  }
  .m-mkt-ah {
    color: #047857 !important;
  }
  .m-mkt-ou {
    color: #2563eb !important;
  }
  .m-leg-market {
    font-size: 11px;
    font-weight: 700;
    display: block;
    letter-spacing: 0.3px;
  }
  .m-leg-play {
    font-size: 15px;
    font-weight: 800;
    color: #0f172a;
    display: block;
    margin-top: 2px;
  }
  .m-leg-odds {
    font-size: 13px;
    font-weight: 700;
    color: #64748b;
    margin-left: 6px;
  }
  .m-leg-outcome {
    font-size: 13px;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: 8px;
  }
  .m-leg-outcome.win {
    background: rgba(4,120,87,0.1);
    color: #047857;
  }
  .m-leg-outcome.lose {
    background: rgba(239,68,68,0.08);
    color: #dc2626;
  }
  .m-leg-role {
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    background: #047857;
    padding: 2px 8px;
    border-radius: 6px;
  }

  /* — Landing page sample legs — */
  .lx-sample-leg.lx-leg-ah .lx-sample-market { color: #047857; }
  .lx-sample-leg.lx-leg-ou .lx-sample-market { color: #2563eb; }
  .lx-sample-leg.lx-leg-ah { border-left: 3px solid #10b981; }
  .lx-sample-leg.lx-leg-ou { border-left: 3px solid #3b82f6; }

  /* — Results dual cards: market-specific header color — */
  .m-results-type-ah .m-results-type-icon svg { color: #047857; }
  .m-results-type-ou .m-results-type-icon svg { color: #2563eb; }
  .m-results-type-ah .m-results-type-rate { color: #047857; }
  .m-results-type-ou .m-results-type-rate { color: #2563eb; }

  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     INFORMATION HIERARCHY
     Important content ≠ regular text
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

  /* — Core Logic Card (THE most important content) — */
  .m-core-logic-card {
    margin: 0 16px 16px;
    padding: 18px 20px;
    background: linear-gradient(135deg, rgba(236,253,245,0.6) 0%, rgba(240,253,244,0.3) 100%);
    border-radius: 16px;
    border: 1px solid rgba(16,185,129,0.15);
    border-left: 4px solid #10b981;
    box-shadow: 0 2px 8px rgba(16,185,129,0.06);
    font-size: 14px;
    line-height: 1.75;
    color: #1a4731;
    position: relative;
  }
  .m-core-logic-card p {
    margin: 0 0 8px;
    font-size: 14px;
    color: #1a4731;
    line-height: 1.75;
  }
  .m-core-logic-card p:last-child { margin-bottom: 0; }

  /* Override the old weak .m-core-logic style */
  .m-text-block.m-core-logic {
    border-left: 4px solid #10b981;
    background: linear-gradient(135deg, rgba(236,253,245,0.6) 0%, rgba(240,253,244,0.3) 100%);
    border-radius: 14px;
    padding: 14px 16px;
    font-size: 14px;
    color: #1a4731;
    line-height: 1.75;
    border: 1px solid rgba(16,185,129,0.15);
    border-left: 4px solid #10b981;
  }

  /* — Exit Condition Card (Safety-critical, warning style) — */
  .m-exit-card {
    margin: 0 16px 16px;
    padding: 16px 18px;
    background: linear-gradient(135deg, rgba(254,243,199,0.5) 0%, rgba(254,249,195,0.3) 100%);
    border-radius: 16px;
    border: 1px solid rgba(245,158,11,0.2);
    border-left: 4px solid #f59e0b;
    box-shadow: 0 2px 8px rgba(245,158,11,0.06);
    display: flex;
    gap: 10px;
    align-items: flex-start;
  }
  .m-exit-card > svg:first-child {
    width: 18px;
    height: 18px;
    color: #d97706;
    flex-shrink: 0;
    margin-top: 2px;
  }
  .m-exit-card-body {
    flex: 1;
    font-size: 13px;
    color: #92400e;
    line-height: 1.65;
  }
  .m-exit-card-body p {
    margin: 0 0 6px;
    font-size: 13px;
    color: #92400e;
  }
  .m-exit-card-body p:last-child { margin-bottom: 0; }

  /* — Old m-logic / m-exit enhancement (backward compat) — */
  .m-logic {
    padding: 14px 16px;
    background: linear-gradient(135deg, rgba(236,253,245,0.5) 0%, transparent 100%);
    border-left: 3px solid #10b981;
    border-radius: 0 12px 12px 0;
    margin: 4px 0;
  }
  .m-logic span {
    color: #047857 !important;
    font-size: 11px !important;
  }
  .m-logic p {
    color: #1a4731 !important;
    font-size: 13px !important;
  }
  .m-exit {
    padding: 14px 16px;
    background: linear-gradient(135deg, rgba(254,243,199,0.4) 0%, transparent 100%);
    border-left: 3px solid #f59e0b;
    border-radius: 0 12px 12px 0;
    margin: 4px 0;
  }
  .m-exit span {
    color: #d97706 !important;
    font-size: 11px !important;
  }
  .m-exit p {
    color: #92400e !important;
    font-size: 13px !important;
  }

  /* — Section head icon sizing — */
  .m-section-head h2 svg {
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    margin-right: 4px;
    color: #047857;
  }

  /* — Insight items (enhanced differentiation) — */
  .m-insight-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 14px !important;
    border-top: 0.5px solid rgba(0,0,0,0.04) !important;
    font-size: 13px;
    line-height: 1.5;
    color: #334155;
  }
  .m-insight-item .insight-icon.critical {
    color: #dc2626 !important;
  }
  .m-insight-item .insight-icon.positive {
    color: #047857 !important;
  }
  .m-insight-item .insight-icon.info {
    color: #64748b !important;
  }

  /* — Support blocks (analysis zone) — */
  .m-support-block {
    background: #fff;
    border-radius: 16px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 6px rgba(0,0,0,0.02);
    overflow: hidden;
  }
  .m-support-block-head {
    padding: 12px 14px;
    font-size: 13px;
    font-weight: 800;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 6px;
    background: #fafbfc;
    border-bottom: 0.5px solid rgba(0,0,0,0.04);
  }
  .m-support-block-head svg {
    width: 14px;
    height: 14px;
    color: #047857;
  }
  .m-support-block-head .block-tag {
    margin-left: auto;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 6px;
    background: rgba(4,120,87,0.08);
    color: #047857;
  }
  .m-support-block-body {
    padding: 12px 14px;
    font-size: 13px;
    color: #475569;
    line-height: 1.5;
  }

  /* — Verdict card market accent — */
  .m-verdict-market {
    font-size: 11px;
    font-weight: 700;
    color: #047857;
    display: block;
    margin-bottom: 2px;
  }
  .m-verdict-play-name {
    font-size: 18px;
    font-weight: 900;
    color: #052e21;
    letter-spacing: -0.3px;
  }
  .m-verdict-odds {
    font-size: 20px;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -0.02em;
  }
  .m-verdict-role-badge {
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    background: #047857;
    padding: 2px 8px;
    border-radius: 6px;
    margin-left: 6px;
    vertical-align: 2px;
  }

  /* — PnL emphasis — */
  .m-result-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(0,0,0,0.04);
  }
  .m-link {
    font-size: 12px;
    color: #047857;
    font-weight: 600;
  }

  /* — Review grid (post-match) enhanced — */
  .m-review-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin: 0 16px 12px;
  }
  .m-review-item {
    background: #fff;
    padding: 14px 12px;
    text-align: center;
    border-radius: 14px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 6px rgba(0,0,0,0.02);
  }
  .m-review-item span {
    display: block;
    font-size: 10px;
    color: #94a3b8;
    font-weight: 500;
    margin-bottom: 4px;
  }
  .m-review-item strong {
    display: block;
    font-size: 18px;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -0.02em;
  }
  .m-review-item strong.good { color: #047857; }
  .m-review-item strong.bad { color: #dc2626; }
  .m-review-item strong.neutral { color: #64748b; }

  .m-review-note {
    margin: 0 16px 16px;
    padding: 14px 16px;
    background: #f8fafc;
    border-radius: 12px;
    border: 0.5px solid rgba(0,0,0,0.04);
  }
  .m-review-note span {
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
  }
  .m-review-note p {
    font-size: 13px;
    color: #475569;
    line-height: 1.6;
    margin: 0;
  }

  /* — Unlock card (premium CTA) — */
  .m-unlock-card {
    margin: 0 16px 16px;
    padding: 28px 20px;
    background: linear-gradient(135deg, #052e21 0%, #064e3b 100%);
    border-radius: 20px;
    text-align: center;
    box-shadow: 0 8px 30px rgba(5,46,33,0.2);
    border: none;
  }
  .m-unlock-card strong {
    font-size: 20px;
    font-weight: 900;
    color: #bbf7d0;
    display: block;
    margin-bottom: 8px;
    letter-spacing: -0.3px;
  }
  .m-unlock-card p {
    font-size: 13px;
    color: rgba(187,247,208,0.7);
    margin: 0 0 16px;
    line-height: 1.6;
  }
  /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
     懒人计划 · 策略自进化引擎 (Self-Evolving Strategy Engine)
     ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

  /* ── Hero override ── */
  .st-hero {
    background: linear-gradient(135deg, #064e3b 0%, #047857 50%, #059669 100%);
    padding: 28px 20px 20px;
    border-radius: 0 0 24px 24px;
    margin: 0 -16px 0;
    color: #fff;
  }
  .st-hero .pg-hero-badge {
    background: rgba(255,255,255,0.15);
    color: #bbf7d0;
  }
  .st-hero .pg-hero-title { color: #fff; }
  .st-hero .pg-hero-desc { color: rgba(255,255,255,0.85); }
  .st-hero-stat {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    padding: 4px 12px;
    font-size: 12px;
    color: rgba(255,255,255,0.7);
    background: rgba(255,255,255,0.1);
    border-radius: 20px;
  }

  /* ── Tab bar ── */
  .st-tabs {
    display: flex;
    margin: 0 16px 4px;
    background: #f1f5f9;
    border-radius: 12px;
    padding: 3px;
    position: sticky;
    top: 0;
    z-index: 20;
  }
  .st-tabs .mobile-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 0;
    font-size: 13px;
    font-weight: 600;
    color: #64748b;
    border-radius: 10px;
    text-decoration: none;
    transition: all 0.2s;
    cursor: pointer;
    position: relative;
  }
  .st-tabs .mobile-tab.active {
    background: #fff;
    color: #0f172a;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08);
  }
  .st-tab-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    background: #047857;
    border-radius: 10px;
    margin-left: 2px;
  }

  /* ── Strategy Card ── */
  .st-card {
    margin: 12px 16px 0;
    padding: 20px;
    background: #fff;
    border-radius: 18px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
  }
  .st-card.st-card-subbed {
    border-left: 3px solid #10b981;
    background: linear-gradient(135deg, #f0fdf4 0%, #fff 40%);
  }
  .st-card.st-card-decayed {
    opacity: 0.7;
    border-left: 3px solid #f59e0b;
    background: linear-gradient(135deg, #fffbeb 0%, #fff 40%);
  }
  .st-card.st-mkt-ah { border-top: 3px solid #059669; }
  .st-card.st-mkt-ou { border-top: 3px solid #2563eb; }

  .st-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 8px;
  }
  .st-card-name-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
  }
  .st-card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: #f0fdf4;
    border-radius: 10px;
    color: #047857;
    flex-shrink: 0;
  }
  .st-card-name {
    font-size: 17px;
    font-weight: 800;
    color: #0f172a;
    margin: 0;
    letter-spacing: -0.3px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  /* ── Evolution badge ── */
  .st-evo-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .st-evo-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
  }
  .st-mat-incubating { background: #fef3c7; color: #92400e; }
  .st-mat-incubating .st-evo-dot { background: #f59e0b; }
  .st-mat-promoted { background: #d1fae5; color: #065f46; }
  .st-mat-promoted .st-evo-dot { background: #10b981; }
  .st-mat-matured { background: #064e3b; color: #bbf7d0; }
  .st-mat-matured .st-evo-dot { background: #34d399; }
  .st-mat-decayed { background: #fee2e2; color: #991b1b; }
  .st-mat-decayed .st-evo-dot { background: #ef4444; }
  .st-mat-retired { background: #f1f5f9; color: #64748b; }
  .st-mat-retired .st-evo-dot { background: #94a3b8; }
  .st-evo-version {
    font-size: 10px;
    opacity: 0.7;
    margin-left: 2px;
  }

  /* ── Evolution row (trend + genome) ── */
  .st-card-evo-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
  }
  .st-trend {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
  }
  .st-trend-rising { color: #059669; }
  .st-trend-stable { color: #64748b; }
  .st-trend-declining { color: #dc2626; }

  /* ── Genome trail ── */
  .st-genome {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
  }
  .st-genome-node {
    padding: 2px 6px;
    border-radius: 6px;
    background: #f1f5f9;
    color: #64748b;
    font-weight: 600;
  }
  .st-genome-node.current {
    background: #064e3b;
    color: #bbf7d0;
  }
  .st-genome-sep {
    color: #cbd5e1;
    font-size: 10px;
  }

  /* ── Progress bar ── */
  .st-progress {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
  }
  .st-progress-bar {
    flex: 1;
    height: 5px;
    background: #e2e8f0;
    border-radius: 3px;
    overflow: hidden;
  }
  .st-progress-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.5s ease;
  }
  .st-progress-fill.st-mat-incubating { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
  .st-progress-fill.st-mat-promoted { background: linear-gradient(90deg, #10b981, #34d399); }
  .st-progress-fill.st-mat-matured { background: linear-gradient(90deg, #047857, #10b981); }
  .st-progress-label {
    font-size: 11px;
    color: #94a3b8;
    white-space: nowrap;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
  }

  /* ── Stats row ── */
  .st-stats {
    display: flex;
    gap: 0;
    margin: 0 -4px 12px;
  }
  .st-stat {
    flex: 1;
    text-align: center;
    padding: 8px 4px;
  }
  .st-stat strong {
    display: block;
    font-size: 20px;
    font-weight: 800;
    color: #0f172a;
    letter-spacing: -0.5px;
    line-height: 1.2;
  }
  .st-stat strong.up { color: #059669; }
  .st-stat strong.down { color: #dc2626; }
  .st-stat span {
    display: block;
    font-size: 11px;
    color: #94a3b8;
    margin-top: 2px;
    font-weight: 500;
  }

  /* ── Filter tags ── */
  .st-tags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 12px;
  }
  .st-tag {
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    background: #f0fdf4;
    color: #065f46;
    border-radius: 8px;
  }

  /* ── Decay / Incubating warnings ── */
  .st-decay-warning {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 12px;
    font-weight: 600;
    color: #991b1b;
    background: #fef2f2;
    border-radius: 10px;
    margin-bottom: 10px;
  }
  .st-incubating-note {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 12px;
    font-weight: 600;
    color: #92400e;
    background: #fef3c7;
    border-radius: 10px;
    margin-bottom: 10px;
  }

  /* ── CTA / Subscribe button ── */
  .st-card-footer {
    margin-top: 4px;
  }
  .st-sub-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 12px 0;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #047857, #059669);
    border: none;
    border-radius: 12px;
    cursor: pointer;
    text-decoration: none;
    transition: opacity 0.2s;
  }
  .st-sub-btn:active { opacity: 0.85; }
  .st-sub-btn.st-sub-ghost {
    background: #f1f5f9;
    color: #334155;
  }
  .st-cta-subbed {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px 0;
    font-size: 14px;
    font-weight: 700;
    color: #059669;
    background: #f0fdf4;
    border-radius: 12px;
    border: 1px solid #bbf7d0;
  }
  .st-cta-frozen {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px 0;
    font-size: 13px;
    font-weight: 600;
    color: #92400e;
    background: #fef3c7;
    border-radius: 12px;
  }

  /* ── Subscribe form (inline expand) ── */
  .st-sub-form {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #f1f5f9;
    animation: stSlideDown 0.2s ease;
  }
  @keyframes stSlideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .st-sub-input {
    width: 100%;
    padding: 12px 14px;
    font-size: 15px;
    border: 1.5px solid #e2e8f0;
    border-radius: 10px;
    outline: none;
    background: #f8fafc;
    margin-bottom: 10px;
    box-sizing: border-box;
    -webkit-appearance: none;
  }
  .st-sub-input:focus {
    border-color: #047857;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(4,120,87,0.1);
  }
  .st-sub-form-actions {
    display: flex;
    gap: 8px;
  }
  .st-sub-confirm {
    flex: 1;
    padding: 10px 0;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #047857, #059669);
    border: none;
    border-radius: 10px;
    cursor: pointer;
  }
  .st-sub-cancel {
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 600;
    color: #64748b;
    background: #f1f5f9;
    border: none;
    border-radius: 10px;
    cursor: pointer;
  }

  /* ── Subscriptions View ── */
  .st-subs-header {
    padding: 8px 16px 0;
  }
  .st-subs-header h2 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
    font-weight: 800;
    color: #0f172a;
    margin: 0;
  }
  .st-subs-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    background: #047857;
    border-radius: 12px;
  }

  .st-subs-list {
    padding: 8px 0 0;
  }
  .st-sub-card {
    margin: 8px 16px;
    padding: 16px;
    background: #fff;
    border-radius: 16px;
    border: 0.5px solid rgba(0,0,0,0.06);
    box-shadow: 0 2px 8px rgba(0,0,0,0.03);
  }
  .st-sub-card.disabled { opacity: 0.6; }
  .st-sub-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
  }
  .st-sub-card-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
  }
  .st-sub-card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: #f0fdf4;
    border-radius: 8px;
    color: #047857;
    flex-shrink: 0;
  }
  .st-sub-card-info h4 {
    font-size: 15px;
    font-weight: 700;
    color: #0f172a;
    margin: 0 0 2px;
  }
  .st-builtin-tag {
    font-size: 10px;
    color: #94a3b8;
    font-weight: 500;
  }
  .st-sub-card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #64748b;
  }
  .st-meta-email {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #059669;
    font-weight: 600;
  }
  .st-meta-no-email {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #f59e0b;
    font-weight: 600;
  }
  .st-sub-card-status {
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
  }
  .st-sub-card-status.active {
    background: #d1fae5;
    color: #065f46;
  }
  .st-sub-card-status.paused {
    background: #fef3c7;
    color: #92400e;
  }
  .st-sub-card-stats {
    display: flex;
    gap: 14px;
    font-size: 12px;
    color: #64748b;
    margin-bottom: 10px;
    flex-wrap: wrap;
  }
  .st-sub-card-stats span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
  }
  .st-sub-card-stats strong {
    font-weight: 700;
    color: #0f172a;
  }
  .st-sub-card-actions {
    display: flex;
    gap: 6px;
    padding-top: 10px;
    border-top: 1px solid #f1f5f9;
  }
  .st-action-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #475569;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    cursor: pointer;
    gap: 4px;
  }
  .st-action-btn:active { background: #e2e8f0; }
  .st-action-del { color: #dc2626; border-color: #fecaca; }

  /* ── Matched matches list ── */
  .st-matches-section {
    margin-top: 16px;
    padding: 0 16px;
  }
  .st-matches-section h2 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 800;
    color: #0f172a;
    margin: 0 0 8px;
  }
  .st-matches-list {
    background: #fff;
    border-radius: 14px;
    border: 0.5px solid rgba(0,0,0,0.06);
    overflow: hidden;
  }
  .st-match-row {
    padding: 12px 14px;
    border-bottom: 0.5px solid rgba(0,0,0,0.04);
    cursor: pointer;
  }
  .st-match-row:last-child { border-bottom: none; }
  .st-match-row:active { background: #f8fafc; }
  .st-match-time {
    font-size: 11px;
    color: #94a3b8;
    margin-bottom: 2px;
    font-weight: 600;
  }
  .st-match-teams {
    font-size: 14px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 2px;
  }
  .st-match-info {
    font-size: 12px;
    color: #64748b;
  }

  /* ── Disclaimer ── */
  .st-disclaimer {
    display: flex;
    gap: 10px;
    margin: 20px 16px 0;
    padding: 14px;
    background: #f8fafc;
    border-radius: 12px;
    border: 0.5px solid rgba(0,0,0,0.04);
    align-items: flex-start;
  }
  .st-disclaimer svg { flex-shrink: 0; margin-top: 2px; color: #94a3b8; }
  .st-disclaimer p {
    font-size: 12px;
    color: #64748b;
    line-height: 1.6;
    margin: 0;
  }

  /* ── Empty state ── */
  .st-empty {
    text-align: center;
    padding: 48px 24px;
    color: #94a3b8;
  }
  .st-empty p { margin: 0 0 4px; }

  /* ── Back to ranking button ── */
  .st-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 14px;
    padding: 10px 20px;
    font-size: 13px;
    font-weight: 700;
    color: #047857;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 10px;
    cursor: pointer;
  }

  .m-unlock-card .m-btn-primary {
    background: linear-gradient(135deg, #10b981, #34d399);
    color: #052e21;
    box-shadow: 0 4px 14px rgba(16,185,129,0.3);
  }

  /* — Today: core logic in card note — */
  .ux-card-note {
    margin-top: 10px;
    padding: 10px 14px;
    font-size: 13px;
    line-height: 1.6;
    color: #475569;
    background: #f8fafc;
    border-radius: 10px;
    border: 0.5px solid rgba(0,0,0,0.04);
  }
}
