/* Homepage-specific styles, extracted from the inline <style> block in
   index.html (Perf Sprint 2). Loads after styles.css + hub.css so the cascade
   order is preserved. */
/* ── HERO CTA BUTTONS ── */
    .hero-cta-group {
      display: flex;
      gap: 1rem;
      flex-wrap: wrap;
      margin-top: 2rem;
      align-items: flex-start;
    }
    .hero-cta-primary {
      display: inline-block;
      background: linear-gradient(135deg, #00C2B3 0%, #00CFA8 45%, #00D68F 100%);
      color: #fff;
      font-family: 'Inter', system-ui, sans-serif;
      font-size: 16px;
      font-weight: 700;
      border-radius: 999px;
      padding: 14px 32px;
      text-decoration: none;
      white-space: nowrap;
      width: fit-content;
      max-width: 100%;
      letter-spacing: .01em;
      box-shadow: 0 2px 18px rgba(0,194,179,.28);
      border: none;
      cursor: pointer;
      transition: filter .15s;
    }
    .hero-cta-primary:hover { filter: brightness(1.08); color: #fff; }
    .hero-cta-secondary {
      display: inline-block;
      background: transparent;
      color: #e0e0e0;
      font-family: 'Inter', system-ui, sans-serif;
      font-size: 16px;
      font-weight: 600;
      border-radius: 999px;
      padding: 14px 32px;
      text-decoration: none;
      white-space: nowrap;
      width: fit-content;
      max-width: 100%;
      letter-spacing: .01em;
      border: 1.5px solid rgba(255,255,255,.18);
      cursor: pointer;
      transition: border-color .2s, color .2s;
    }
    .hero-cta-secondary:hover { border-color: #00C2B3; color: #00C2B3; }

    /* ── HERO TWO-COLUMN LAYOUT ── */
    .hero-split {
      display: block;
      max-width: 720px;
      width: 100%;
    }
    .hero-left { }
    .hero-right {
      display: flex;
      justify-content: flex-end;
      align-items: flex-start;
    }

    /* Scorecard preview card */
    .scorecard-preview {
      background: var(--clr-bg-2);
      border: 1px solid var(--clr-border);
      border-radius: 16px;
      padding: 1.75rem;
      width: 100%;
      box-shadow: 0 8px 40px rgba(0,0,0,.35);
    }
    .scorecard-preview-header {
      display: flex;
      align-items: center;
      gap: .6rem;
      margin-bottom: 1.25rem;
    }
    .scorecard-preview-icon {
      width: 36px; height: 36px;
      border-radius: 10px;
      background: linear-gradient(135deg, #00C2B3 0%, #00D68F 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
      flex-shrink: 0;
    }
    .scorecard-preview-title {
      font-family: var(--font-display);
      font-size: .95rem;
      font-weight: 700;
      color: var(--clr-text);
    }
    .scorecard-preview-subtitle {
      font-size: .72rem;
      color: var(--clr-text-3);
    }
    .scorecard-gauge {
      display: flex;
      justify-content: center;
      margin-bottom: 1.25rem;
    }
    .scorecard-gauge svg { width: 140px; height: 80px; }
    .scorecard-categories {
      display: flex;
      flex-direction: column;
      gap: .55rem;
      margin-bottom: 1.25rem;
    }
    .scorecard-cat {
      display: flex;
      align-items: center;
      gap: .6rem;
      font-size: .78rem;
      color: var(--clr-text-2);
    }
    .scorecard-cat-icon {
      font-size: .85rem;
      width: 20px;
      text-align: center;
      flex-shrink: 0;
    }
    .scorecard-cat-bar {
      flex: 1;
      height: 6px;
      background: rgba(255,255,255,.06);
      border-radius: 3px;
      overflow: hidden;
    }
    .scorecard-cat-fill {
      height: 100%;
      border-radius: 3px;
      transition: width .6s ease;
    }
    .scorecard-preview-cta {
      display: block;
      text-align: center;
      font-size: .82rem;
      font-weight: 600;
      color: #00C2B3;
      text-decoration: none;
      padding: .6rem 0 0;
      transition: color .15s;
    }
    .scorecard-preview-cta:hover { color: #00D68F; }

    /* Stats bar below hero split */
    .hero-stats-row {
      margin: 2.25rem auto 2.25rem;
    }

    @media (max-width: 768px) {
      .hero-split {
        grid-template-columns: 1fr;
        gap: 1.5rem;
      }
      .hero-right { justify-content: center; }
      .scorecard-preview {
        max-width: 280px;
        margin: 0 auto;
        padding: 1.1rem;
        border-radius: 12px;
      }
      .scorecard-preview-header { margin-bottom: .75rem; gap: .4rem; }
      .scorecard-preview-icon { width: 28px; height: 28px; font-size: 14px; border-radius: 8px; }
      .scorecard-preview-title { font-size: .82rem; }
      .scorecard-preview-subtitle { font-size: .65rem; }
      .scorecard-gauge { margin-bottom: .75rem; }
      .scorecard-gauge svg { width: 100px; height: 58px; }
      .scorecard-categories { gap: .4rem; margin-bottom: .75rem; }
      .scorecard-cat { font-size: .7rem; gap: .4rem; }
      .scorecard-cat-icon { font-size: .75rem; width: 16px; }
      .scorecard-cat-bar { height: 5px; }
      .scorecard-preview-cta { font-size: .75rem; padding: .4rem 0 0; }
      .hero-cta-group { justify-content: flex-start; align-items: flex-start; }
      .hero-cta-primary {
        white-space: normal;
        text-align: center;
        width: 100%;
        box-sizing: border-box;
        padding: 14px 20px;
        font-size: 15px;
      }
    }

    /* ── NAV OVERRIDES: Remove Compare, clean link styles ── */
    .nav-compare-hide { display: none !important; }
    .nav-dropdown-trigger {
      border: none !important;
      background: transparent !important;
      box-shadow: none !important;
      outline: none !important;
    }
    .nav-dropdown-trigger:hover, .nav-dropdown-trigger:focus {
      border: none !important;
      box-shadow: none !important;
      outline: none !important;
      background: transparent !important;
    }

    /* ── CLICKABLE STATS BAR ── */
    .hero-stats-new {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      background: var(--clr-bg-2);
      border: 1px solid var(--clr-border);
      border-radius: 13px;
      overflow: hidden;
      max-width: 100%;
      margin-left: auto;
      margin-right: auto;
    }
    .stat-link-new {
      flex: 1;
      min-width: 80px;
      padding: 12px 8px;
      text-align: center;
      border-right: 1px solid var(--clr-border);
      text-decoration: none;
      display: block;
      position: relative;
      transition: background .18s;
      cursor: pointer;
    }
    .stat-link-new:last-child { border-right: none; }
    .stat-link-new:hover { background: rgba(0,194,179,.07); }
    .stat-link-new:hover .stat-num-new { color: #00D68F; }
    .stat-link-new:hover .stat-label-new { color: var(--clr-text-2); }
    .stat-link-new:hover .stat-arrow-new { opacity: 1; transform: translateY(0); }
    .stat-num-new {
      font-family: 'DM Mono', 'Courier New', monospace;
      font-size: 1.2rem;
      font-weight: 500;
      color: #00C2B3;
      line-height: 1;
      display: block;
      transition: color .18s;
    }
    .stat-label-new {
      font-size: 9px;
      color: var(--clr-text-3);
      margin-top: 3px;
      letter-spacing: .03em;
      display: block;
      transition: color .18s;
    }
    .stat-arrow-new {
      position: absolute;
      left: 50%;
      bottom: 8px;
      transform: translate(-50%, 3px);
      font-size: 9px;
      color: #00C2B3;
      opacity: 0;
      transition: opacity .18s, transform .18s;
      font-weight: 700;
      white-space: nowrap;
      pointer-events: none;
    }
    /* Tooltip */
    .stat-link-new::after {
      content: attr(data-tip);
      position: absolute;
      bottom: calc(100% + 8px);
      left: 50%;
      transform: translateX(-50%);
      background: #111C2E;
      border: 1px solid rgba(0,194,179,.25);
      color: var(--clr-text-2);
      font-size: 11px;
      font-weight: 600;
      white-space: nowrap;
      padding: 6px 12px;
      border-radius: 8px;
      opacity: 0;
      pointer-events: none;
      transition: opacity .18s;
      box-shadow: 0 8px 24px rgba(0,0,0,.5);
      z-index: 20;
    }
    .stat-link-new::before {
      content: '';
      position: absolute;
      bottom: calc(100% + 3px);
      left: 50%;
      transform: translateX(-50%);
      border: 5px solid transparent;
      border-top-color: #111C2E;
      opacity: 0;
      pointer-events: none;
      transition: opacity .18s;
      z-index: 20;
    }
    .stat-link-new:hover::after,
    .stat-link-new:hover::before { opacity: 1; }

    /* ── PERSONA ENGINE SECTION ── */
    .engine-section {
      max-width: 820px;
      margin: 0 auto;
      padding: 1rem 1.5rem 0;
    }
    .engine-intro {
      margin-bottom: 1.75rem;
      text-align: center;
    }
    .engine-eyebrow {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: #00C2B3;
      margin-bottom: .65rem;
      display: block;
    }
    .engine-headline {
      font-family: 'Sora', 'Inter', sans-serif;
      font-size: 1.45rem;
      font-weight: 800;
      color: var(--clr-text);
      line-height: 1.3;
      margin: 0 0 .5rem;
    }
    .engine-sub {
      font-size: 1.05rem;
      color: var(--clr-text-2);
      line-height: 1.7;
      max-width: 540px;
      margin: 0 auto;
      font-weight: 500;
    }
    .engine-sub-advisor {
      color: #00C2B3;
      font-weight: 600;
      text-decoration: none;
      cursor: pointer;
    }
    .engine-sub-advisor:hover {
      text-decoration: underline;
      color: #00D68F;
    }
    .engine-card {
      background: var(--clr-bg-2);
      border: 1.5px solid var(--clr-border-2);
      border-radius: 20px;
      overflow: hidden;
      box-shadow: 0 8px 48px rgba(0,0,0,.5);
    }
    .engine-top-bar {
      padding: 18px 22px 16px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      border-bottom: 1px solid var(--clr-border);
    }
    .engine-top-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--clr-text-3);
      margin-bottom: 5px;
    }
    .engine-top-title {
      font-size: .95rem;
      font-weight: 700;
      color: var(--clr-text);
      line-height: 1.35;
    }

    /* Beacon advisor chip */
    .advisor-chip {
      display: flex;
      align-items: center;
      gap: 10px;
      background: var(--clr-surface);
      border: 1.5px solid rgba(0,194,179,.28);
      border-radius: 13px;
      padding: 10px 15px;
      flex-shrink: 0;
      cursor: pointer;
      transition: all .2s;
      position: relative;
      user-select: none;
      font: inherit;
      color: inherit;
      text-align: left;
    }
    .advisor-chip:hover, .advisor-chip.open {
      border-color: #00C2B3;
      background: #051a18;
      transform: translateY(-1px);
    }
    .beacon-wrap {
      position: absolute;
      top: -5px;
      right: -5px;
      width: 14px;
      height: 14px;
    }
    .beacon-dot {
      position: absolute;
      inset: 0;
      border-radius: 50%;
      background: #00C2B3;
      border: 2.5px solid var(--clr-bg-2);
      animation: beaconPop 2.8s ease-in-out infinite;
    }
    .beacon-ring {
      position: absolute;
      inset: 0;
      border-radius: 50%;
      background: rgba(0,194,179,.55);
      animation: beaconRing 2.8s ease-in-out infinite;
    }
    .beacon-ring-2 {
      position: absolute;
      inset: 0;
      border-radius: 50%;
      background: rgba(0,194,179,.3);
      animation: beaconRing 2.8s ease-in-out infinite .55s;
    }
    @keyframes beaconPop {
      0%, 100% { transform: scale(1); }
      50% { transform: scale(1.2); }
    }
    @keyframes beaconRing {
      0% { transform: scale(1); opacity: .85; }
      100% { transform: scale(3.2); opacity: 0; }
    }
    .advisor-av {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      background: linear-gradient(135deg, #00C2B3, #00D68F);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 13px;
      font-weight: 800;
      color: #041a12;
      flex-shrink: 0;
    }
    .advisor-name { font-size: 12.5px; font-weight: 700; color: var(--clr-text); line-height: 1.2; }
    .advisor-status {
      font-size: 10.5px;
      color: #00C2B3;
      display: flex;
      align-items: center;
      gap: 4px;
      margin-top: 2px;
    }
    .advisor-status-dot {
      width: 5px;
      height: 5px;
      background: #00C2B3;
      border-radius: 50%;
      animation: statusPulse 2.2s ease-in-out infinite;
    }
    @keyframes statusPulse {
      0%, 100% { opacity: 1; }
      50% { opacity: .2; }
    }
    .advisor-cta-hint { font-size: 10px; color: var(--clr-text-3); margin-top: 2px; }

    /* Persona button grid */
    .persona-btn-grid {
      padding: 18px 22px 20px;
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    /* CCR-213: ensure the HTML `hidden` attribute actually hides the panel.
       Without this, .persona-btn-grid's display:flex overrides UA hidden=display:none. */
    .persona-btn-grid[hidden] { display: none; }
    /* CCR-213: viewport swap between College (desktop) and Senior (mobile)
       in the primary grid; inverse in More Options. Buttons are duplicated
       in the DOM and CSS-toggled per breakpoint. */
    .persona-mobile-only { display: none; }
    @media (max-width: 600px) {
      .persona-desktop-only { display: none; }
      .persona-mobile-only  { display: inline-flex; }
    }
    /* M-4: secondary panel uses tighter top padding so it visually attaches
       to the expander toggle when open. */
    .persona-btn-grid--secondary {
      padding: 4px 22px 18px;
      animation: persona-more-slide .18s ease-out;
    }
    @keyframes persona-more-slide {
      from { opacity: 0; transform: translateY(-4px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .persona-more-toggle {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      margin: 0 22px 14px;
      padding: 6px 12px;
      background: transparent;
      border: 1px dashed rgba(255,255,255,.16);
      border-radius: 99px;
      font-size: 12px;
      font-weight: 700;
      color: var(--clr-text-3, #94A3B8);
      cursor: pointer;
      transition: color .15s, border-color .15s;
      font-family: inherit;
      -webkit-appearance: none;
    }
    .persona-more-toggle:hover {
      color: var(--clr-text);
      border-color: rgba(0,194,179,.35);
    }
    .persona-more-chevron {
      display: inline-block;
      transition: transform .18s;
      font-size: 14px;
      line-height: 1;
    }
    .persona-more-toggle[aria-expanded="true"] .persona-more-chevron {
      transform: rotate(90deg);
    }
    .persona-more-toggle[aria-expanded="true"] .persona-more-label::after {
      content: " (close)";
      color: var(--clr-text-3, #64748B);
      font-weight: 500;
    }
    .persona-btn {
      background: var(--clr-surface);
      border: 1.5px solid rgba(255,255,255,.09);
      border-radius: 99px;
      padding: 9px 18px;
      font-size: 13px;
      font-weight: 700;
      color: #C8D3E8;
      cursor: pointer;
      transition: all .18s;
      white-space: nowrap;
      display: flex;
      align-items: center;
      gap: 7px;
      font-family: inherit;
      -webkit-appearance: none;
      outline: none;
      box-shadow: none;
      text-decoration: none;
    }
    .persona-btn:hover {
      background: rgba(0,194,179,.07);
      border-color: rgba(0,194,179,.45);
      color: #00C2B3;
    }
    .persona-btn.selected {
      background: rgba(0,194,179,.09);
      border-color: #00C2B3;
      color: #00C2B3;
    }
    .persona-btn:visited { color: #C8D3E8; }
    .persona-btn.selected:visited { color: #00C2B3; }

    /* Topic panel */
    .topic-panel {
      display: none;
      padding: 0 22px 20px;
      animation: engineFadeUp .3s ease-out;
    }
    .topic-panel.visible { display: block; }
    @keyframes engineFadeUp {
      from { opacity: 0; transform: translateY(6px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .topic-step-header {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 14px;
      padding: 10px 14px;
      background: rgba(0,194,179,0.07);
      border: 1px solid rgba(0,194,179,0.18);
      border-radius: 10px;
    }
    .topic-step-badge {
      flex-shrink: 0;
      background: #00C2B3;
      color: #041a12;
      font-size: 10px;
      font-weight: 800;
      letter-spacing: .08em;
      text-transform: uppercase;
      padding: 3px 9px;
      border-radius: 99px;
    }
    .topic-panel-label {
      font-size: 13.5px;
      font-weight: 700;
      color: var(--clr-text);
    }
    .topic-chip-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
      margin-bottom: 14px;
    }
    .topic-chip {
      background: var(--clr-surface);
      border: 1.5px solid var(--clr-border-2);
      border-radius: 99px;
      padding: 7px 15px;
      font-size: 12px;
      font-weight: 600;
      color: var(--clr-text-2);
      cursor: pointer;
      transition: all .15s;
      white-space: nowrap;
    }
    .topic-chip:hover {
      border-color: rgba(0,194,179,.35);
      color: #00C2B3;
      background: rgba(0,194,179,.07);
    }
    .topic-chip.selected {
      border-color: #00C2B3;
      color: #00C2B3;
      background: rgba(0,194,179,.09);
    }

    /* Show results CTA */
    .engine-cta-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      width: 100%;
      background: rgba(255,255,255,0.07);
      color: var(--clr-text-3);
      font-family: 'Inter', system-ui, sans-serif;
      font-size: 13.5px;
      font-weight: 700;
      border-radius: 12px;
      padding: 13px;
      text-decoration: none;
      cursor: not-allowed;
      box-shadow: none;
      border: 1px solid rgba(255,255,255,0.08);
      pointer-events: none;
      transition: background .2s, color .2s, box-shadow .2s, border-color .2s;
    }
    .engine-cta-btn.ready {
      background: linear-gradient(135deg, #00C2B3 0%, #00CFA8 45%, #00D68F 100%);
      color: #041a12;
      cursor: pointer;
      box-shadow: 0 2px 18px rgba(0,194,179,.18);
      border-color: transparent;
      pointer-events: auto;
    }
    .engine-cta-btn.ready:hover { filter: brightness(1.07); color: #041a12; }

    /* Results panel */
    .results-panel {
      display: none;
      padding: 0 22px 22px;
      animation: engineFadeUp .3s ease-out;
    }
    .results-panel.visible { display: block; }
    .result-card {
      background: var(--clr-surface);
      border: 1.5px solid var(--clr-border);
      border-radius: 13px;
      padding: 15px;
      margin-bottom: 9px;
      position: relative;
    }
    .result-badge {
      position: absolute;
      top: 12px;
      right: 12px;
      font-size: 9.5px;
      font-weight: 800;
      letter-spacing: .06em;
      text-transform: uppercase;
      padding: 3px 9px;
      border-radius: 99px;
    }
    .badge-teal { background: rgba(0,194,179,.14); color: #00C2B3; }
    .badge-blue { background: rgba(79,142,247,.14); color: #4F8EF7; }
    .badge-red { background: rgba(248,113,113,.14); color: #F87171; }
    .badge-green { background: rgba(0,214,143,.18); color: #00D68F; font-size: .8rem; }
    .result-hub-card { border: 2px solid rgba(0,214,143,.4) !important; background: rgba(0,214,143,.04) !important; }
    .result-hub-card:hover { border-color: rgba(0,214,143,.7) !important; box-shadow: 0 4px 20px rgba(0,214,143,.15); }
    .result-hub-card .result-name { color: #00D68F; }
    .result-name { font-size: .95rem; font-weight: 700; color: var(--clr-text); margin-bottom: 4px; padding-right: 80px; }
    .result-desc { font-size: .8rem; color: var(--clr-text-2); line-height: 1.65; margin-bottom: 10px; }
    .result-btns { display: flex; gap: 6px; flex-wrap: wrap; }
    .result-btn-amazon {
      display: inline-block;
      background: linear-gradient(135deg, #00C2B3, #00D68F);
      color: #041a12;
      font-size: 11.5px;
      font-weight: 800;
      padding: 7px 13px;
      border-radius: 8px;
      text-decoration: none;
    }
    .result-btn-read {
      background: rgba(79,142,247,.12);
      color: #4F8EF7;
      border: 1.5px solid rgba(79,142,247,.25);
      font-size: 11.5px;
      font-weight: 700;
      padding: 7px 13px;
      border-radius: 8px;
      text-decoration: none;
      display: inline-block;
    }
    .result-btn-guide {
      background: rgba(0,194,179,.1);
      color: #00C2B3;
      border: 1.5px solid rgba(0,194,179,.22);
      font-size: 11.5px;
      font-weight: 700;
      padding: 7px 13px;
      border-radius: 8px;
      text-decoration: none;
      display: inline-block;
    }
    .result-aff-note { font-size: 9.5px; color: var(--clr-text-3); margin-top: 6px; font-style: italic; }
    .result-insight {
      background: rgba(79,142,247,.06);
      border: 1.5px solid rgba(79,142,247,.15);
      border-radius: 12px;
      padding: 12px 15px;
      display: flex;
      gap: 10px;
      align-items: flex-start;
      margin-top: 4px;
    }
    .result-insight-icon { font-size: 16px; flex-shrink: 0; }
    .result-insight-text { font-size: .8rem; color: var(--clr-text-2); line-height: 1.65; }
    .result-insight-text a { color: #00C2B3; font-weight: 600; text-decoration: none; }

    /* Chat panel */
    .chat-panel {
      max-height: 0;
      overflow: hidden;
      transition: max-height .45s cubic-bezier(.4, 0, .2, 1);
    }
    .chat-panel.open {
      max-height: 600px;
      border-top: 1px solid var(--clr-border);
    }
    .chat-inner { padding: 18px 22px 20px; background: #0a1420; display: flex; flex-direction: column; max-height: 580px; }
    .chat-messages { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; min-height: 76px; max-height: 400px; overflow-y: auto; scroll-behavior: smooth; }
    .chat-messages::-webkit-scrollbar { width: 5px; }
    .chat-messages::-webkit-scrollbar-track { background: transparent; }
    .chat-messages::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 3px; }
    .chat-messages::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.25); }
    .chat-msg-row { display: flex; gap: 9px; align-items: flex-start; }
    .chat-msg-row.user-row { justify-content: flex-end; }
    .chat-msg-av {
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: linear-gradient(135deg, #00C2B3, #00D68F);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 11px;
      font-weight: 800;
      color: #041a12;
      flex-shrink: 0;
      margin-top: 2px;
    }
    .chat-bubble {
      background: var(--clr-bg-2);
      border: 1px solid var(--clr-border);
      border-radius: 4px 13px 13px 13px;
      padding: 10px 14px;
      font-size: 13px;
      color: #C8D3E8;
      line-height: 1.65;
      max-width: 88%;
    }
    .chat-bubble.user-bubble {
      background: var(--clr-surface);
      border-color: rgba(0,194,179,.2);
      border-radius: 13px 4px 13px 13px;
    }
    .chat-bubble strong { color: var(--clr-text); }
    .chat-bubble em { color: #00C2B3; font-style: normal; }
    .chat-bubble p { margin: 0 0 6px; }
    .chat-bubble p:last-of-type { margin-bottom: 0; }
    .chat-bubble ul { margin: 4px 0 6px; padding-left: 16px; }
    .chat-bubble li { margin-bottom: 3px; }
    .chat-bubble a { color: #4F8EF7; text-decoration: none; border-bottom: 1px solid rgba(79,142,247,.3); }
    .chat-bubble a:hover { border-bottom-color: #4F8EF7; }
    .chat-bubble .chat-dig-deeper { display: block; margin-top: 6px; font-size: 12px; color: rgba(200,211,232,.7); }
    .chat-share-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 10px; padding-top: 9px; border-top: 1px solid rgba(255,255,255,.10); }
    .chat-share-label { font-size: 10.5px; font-weight: 600; color: rgba(200,211,232,.55); letter-spacing: .3px; text-transform: uppercase; margin-right: 2px; }
    .chat-share-btn {
      display: inline-flex; align-items: center; gap: 4px;
      background: rgba(79,142,247,.08); border: 1px solid rgba(79,142,247,.2);
      border-radius: 5px; padding: 4px 10px; font-size: 10.5px; font-weight: 600;
      color: rgba(200,211,232,.75); cursor: pointer; font-family: inherit;
      transition: all .15s; line-height: 1.4;
    }
    .chat-share-btn:hover { background: rgba(79,142,247,.18); color: #fff; border-color: rgba(79,142,247,.4); }
    .chat-share-btn svg { flex-shrink: 0; }
    .chat-share-btn.chat-copied { color: #00C2B3; border-color: rgba(0,194,179,.3); background: rgba(0,194,179,.1); }
    .chat-progress-bar { display: flex; align-items: center; gap: 8px; margin-top: 8px; padding: 8px 10px; background: rgba(0,194,179,.06); border: 1px solid rgba(0,194,179,.12); border-radius: 8px; cursor: pointer; transition: background .15s; }
    .chat-progress-bar:hover { background: rgba(0,194,179,.1); }
    .chat-progress-label { font-size: 10.5px; font-weight: 600; color: rgba(200,211,232,.7); flex: 1; }
    .chat-progress-meter { width: 60px; height: 5px; background: rgba(255,255,255,.08); border-radius: 3px; overflow: hidden; }
    .chat-progress-fill { height: 100%; background: #00C2B3; border-radius: 3px; transition: width .3s; }
    .chat-progress-pct { font-size: 10px; font-weight: 700; color: #00C2B3; min-width: 28px; text-align: right; }
    .chat-checklist { display: none; margin-top: 6px; padding: 8px 0; }
    .chat-checklist.open { display: block; }
    .chat-check-item { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 11.5px; color: rgba(200,211,232,.75); }
    .chat-check-item input[type="checkbox"] { accent-color: #00C2B3; }
    .chat-check-item.checked label { text-decoration: line-through; color: rgba(200,211,232,.4); }
    .chat-comparison-card { margin-top: 10px; border: 1px solid rgba(79,142,247,.15); border-radius: 10px; overflow: hidden; }
    .chat-comparison-header { background: rgba(79,142,247,.06); padding: 6px 12px; font-size: 10px; font-weight: 700; color: rgba(200,211,232,.6); text-transform: uppercase; letter-spacing: .4px; }
    .chat-comparison-grid { display: flex; gap: 0; }
    .chat-comparison-item { flex: 1; padding: 10px 12px; border-right: 1px solid rgba(255,255,255,.06); }
    .chat-comparison-item:last-child { border-right: none; }
    .chat-comparison-name { font-size: 12px; font-weight: 700; color: #e0e7f0; margin-bottom: 4px; }
    .chat-comparison-name a { color: #4F8EF7; text-decoration: none; }
    .chat-comparison-name a:hover { text-decoration: underline; }
    .chat-comparison-price { font-size: 11px; color: #00C2B3; font-weight: 600; margin-bottom: 3px; }
    .chat-comparison-note { font-size: 10.5px; color: rgba(200,211,232,.55); line-height: 1.4; }
    .chat-starters { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
    .chat-starter-chip {
      display: inline-block; padding: 6px 12px; font-size: 11.5px; font-weight: 500;
      background: rgba(79,142,247,.08); border: 1px solid rgba(79,142,247,.2);
      border-radius: 16px; color: rgba(200,211,232,.85); cursor: pointer;
      transition: all .15s;
    }
    .chat-starter-chip:hover { background: rgba(79,142,247,.18); color: #fff; border-color: rgba(79,142,247,.4); }
    .chat-feedback-bar { display: flex; align-items: center; gap: 6px; margin-top: 6px; }
    .chat-feedback-label { font-size: 10px; color: rgba(200,211,232,.4); font-weight: 500; }
    .chat-feedback-btn {
      background: none; border: 1px solid rgba(255,255,255,.08); border-radius: 5px;
      padding: 3px 8px; cursor: pointer; font-size: 13px; line-height: 1;
      color: rgba(200,211,232,.5); transition: all .15s;
    }
    .chat-feedback-btn:hover { background: rgba(255,255,255,.06); color: rgba(200,211,232,.9); border-color: rgba(255,255,255,.15); }
    .chat-feedback-btn.fb-selected-up { color: #00C2B3; border-color: rgba(0,194,179,.3); background: rgba(0,194,179,.08); }
    .chat-feedback-btn.fb-selected-down { color: #ff5252; border-color: rgba(255,82,82,.3); background: rgba(255,82,82,.08); }
    .chat-stop-btn {
      width: 42px; height: 42px;
      background: linear-gradient(135deg, #ff5252, #ff1744);
      border: none; border-radius: 11px; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; transition: filter .15s;
      -webkit-appearance: none; outline: none;
      animation: chatStopPulse 1.5s ease-in-out infinite;
    }
    .chat-stop-btn:hover { filter: brightness(1.15); }
    @keyframes chatStopPulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(255,23,68,.4); }
      50% { box-shadow: 0 0 0 6px rgba(255,23,68,0); }
    }
    .chat-mic-btn {
      width: 42px; height: 42px; background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.12); border-radius: 11px; cursor: pointer;
      display: flex; align-items: center; justify-content: center; flex-shrink: 0;
      color: rgba(200,211,232,.6); transition: all .15s; -webkit-appearance: none; outline: none;
    }
    .chat-mic-btn:hover { background: rgba(255,255,255,.1); color: rgba(200,211,232,.9); }
    .chat-mic-btn.mic-active { background: rgba(255,23,68,.15); border-color: rgba(255,23,68,.4); color: #ff5252; animation: chatStopPulse 1.5s ease-in-out infinite; }
    .chat-input-wrap { flex: 1; position: relative; }
    .chat-input-wrap .chat-input-field { width: 100%; box-sizing: border-box; padding-right: 32px; }
    .chat-history-toggle {
      position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
      background: none; border: none; color: rgba(200,211,232,.4); cursor: pointer;
      padding: 4px; line-height: 0; transition: color .15s;
    }
    .chat-history-toggle:hover { color: rgba(200,211,232,.8); }
    .chat-history-dropdown {
      display: none; position: absolute; bottom: calc(100% + 6px);
      left: 0; right: 0; background: #0d1b2a;
      border: 1px solid rgba(255,255,255,.12); border-radius: 10px;
      box-shadow: 0 8px 24px rgba(0,0,0,.5); max-height: 160px;
      overflow-y: auto; z-index: 10;
    }
    .chat-history-label {
      font-size: 9px; color: rgba(255,255,255,.35); text-transform: uppercase;
      letter-spacing: .5px; font-weight: 600; padding: 8px 12px 4px;
    }
    .chat-history-item {
      padding: 7px 12px; font-size: 12px; color: #C8D3E8;
      cursor: pointer; white-space: nowrap; overflow: hidden;
      text-overflow: ellipsis; transition: background .12s;
    }
    .chat-history-item:hover { background: rgba(0,194,179,.1); color: #00C2B3; }
    .chat-typing { display: none; gap: 9px; align-items: center; }
    .chat-typing-dots {
      background: var(--clr-bg-2);
      border: 1px solid var(--clr-border);
      border-radius: 4px 13px 13px 13px;
      padding: 10px 14px;
      display: flex;
      gap: 4px;
    }
    .chat-typing-dot {
      width: 6px;
      height: 6px;
      background: #00C2B3;
      border-radius: 50%;
      animation: typingDot 1.2s ease-in-out infinite;
    }
    .chat-typing-dot:nth-child(2) { animation-delay: .2s; }
    .chat-typing-dot:nth-child(3) { animation-delay: .4s; }
    @keyframes typingDot {
      0%, 80%, 100% { opacity: .2; transform: scale(.75); }
      40% { opacity: 1; transform: scale(1); }
    }
    .chat-input-row { display: flex; gap: 8px; align-items: center; }
    .chat-input-field {
      flex: 1;
      background: var(--clr-bg-2);
      border: 1.5px solid rgba(255,255,255,.1);
      border-radius: 11px;
      padding: 11px 14px;
      color: var(--clr-text);
      font-size: 13px;
      font-family: inherit;
      outline: none;
      transition: border-color .15s;
    }
    .chat-input-field:focus { border-color: #00C2B3; }
    .chat-input-field::placeholder { color: var(--clr-text-3); }
    .chat-send-btn {
      width: 42px;
      height: 42px;
      background: linear-gradient(135deg, #00C2B3, #00D68F);
      border: none;
      border-radius: 11px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      transition: filter .15s;
      -webkit-appearance: none;
      outline: none;
    }
    .chat-send-btn:hover { filter: brightness(1.1); }
    .chat-disclaimer { font-size: 9px; color: var(--clr-text-3); text-align: center; margin-top: 8px; line-height: 1.55; }
    .sa-preamble-bubble { font-style: italic; opacity: .7; }
    .chat-suggestion-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
    .chat-suggestion-chip {
      background: rgba(0,194,179,.1);
      border: 1px solid rgba(0,194,179,.25);
      border-radius: 99px;
      padding: 5px 12px;
      font-size: 11.5px;
      color: #00C2B3;
      cursor: pointer;
      font-weight: 600;
      transition: background .15s;
      font-family: inherit;
      line-height: 1.2;
      -webkit-appearance: none;
      appearance: none;
    }
    .chat-suggestion-chip:hover { background: rgba(0,194,179,.2); }
    .chat-suggestion-chip:focus-visible {
      outline: 2px solid rgba(0,194,179,.6);
      outline-offset: 2px;
    }
    .chat-resource-links {
      display: flex;
      flex-wrap: wrap;
      gap: 5px;
      margin-top: 10px;
      padding-top: 8px;
      border-top: 1px solid rgba(255,255,255,.06);
    }
    .chat-resource-label {
      font-size: 10px;
      color: var(--clr-text-3);
      width: 100%;
      margin-bottom: 2px;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      font-weight: 600;
    }
    .chat-resource-link {
      font-size: 11px;
      color: #4F8EF7;
      text-decoration: none;
      background: rgba(79,142,247,.08);
      border: 1px solid rgba(79,142,247,.2);
      border-radius: 6px;
      padding: 4px 10px;
      transition: all .15s;
      font-weight: 500;
    }
    .chat-resource-link:hover {
      background: rgba(79,142,247,.18);
      border-color: rgba(79,142,247,.4);
      text-decoration: none;
    }

    /* ── PERSONA HUB STRIP ── */
    .hub-strip-section {
      max-width: 820px;
      margin: 0 auto;
      padding: 2.5rem 1.5rem 0;
    }
    .hub-strip-label {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: .07em;
      text-transform: uppercase;
      color: #00C2B3;
      margin-bottom: 1rem;
    }
    .hub-strip-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 10px;
    }
    .hub-strip-link {
      display: flex;
      align-items: center;
      gap: 7px;
      background: linear-gradient(135deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.015) 100%);
      border: 1.5px solid var(--clr-border-2);
      border-radius: 10px;
      padding: 10px 12px;
      font-size: 12px;
      font-weight: 700;
      color: var(--clr-text);
      cursor: pointer;
      transition: border-color .18s, box-shadow .18s, color .18s, background .18s;
      text-decoration: none;
      white-space: normal;
      word-break: break-word;
    }
    .hub-strip-link:hover {
      border-color: rgba(0,194,179,.45);
      color: #00C2B3;
      background: linear-gradient(135deg, rgba(0,194,179,.07) 0%, rgba(0,194,179,.02) 100%);
      box-shadow: 0 0 18px rgba(0,194,179,.1);
    }

    /* ── GEMS SECTION ── */
    .gems-section {
      max-width: 820px;
      margin: 0 auto;
      padding: 1.5rem 1.5rem 2.25rem;
    }
    .gems-eyebrow {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: .11em;
      text-transform: uppercase;
      color: #00C2B3;
      margin-bottom: 7px;
    }
    .gems-title {
      font-family: 'Sora', 'Inter', sans-serif;
      font-size: 1.15rem;
      font-weight: 800;
      color: var(--clr-text);
      margin-bottom: 5px;
    }
    .gems-sub { font-size: 12.5px; color: var(--clr-text-3); margin-bottom: .75rem; line-height: 1.6; }
    .gems-all-link {
      display: inline-flex;
      align-items: center;
      gap: .35rem;
      font-size: 12.5px;
      font-weight: 700;
      color: #00C2B3;
      text-decoration: none;
      margin-bottom: 1.25rem;
      transition: color .15s;
    }
    .gems-all-link:hover { color: #00D68F; }
    .gems-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
    }
    .gem-card {
      background: var(--clr-bg-2);
      border: 1.5px solid var(--clr-border);
      border-radius: 13px;
      padding: 14px;
      cursor: pointer;
      transition: all .17s;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
    .gem-card:hover { border-color: rgba(0,194,179,.28); background: #0a1a17; transform: translateY(-2px); }
    .gem-card.open { border-color: #00C2B3; background: #051a14; }

    /* ── EDITORIAL PROOF BLOCK (M-3) ── */
    .ep-section {
      padding: 2.5rem 0 1rem;
      border-top: 1px solid var(--clr-border, rgba(255,255,255,0.08));
    }
    .ep-inner {
      max-width: 1080px;
      margin: 0 auto;
      padding: 0 1.25rem;
    }
    .ep-eyebrow {
      font-size: .72rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--clr-teal, #00D68F);
      margin: 0 0 .4rem;
    }
    .ep-headline {
      font-family: 'Sora', sans-serif;
      font-size: 1.4rem;
      font-weight: 800;
      margin: 0 0 1.4rem;
      color: var(--clr-text);
      max-width: 720px;
      line-height: 1.3;
    }
    .ep-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 0.9rem;
    }
    @media (max-width: 760px) {
      .ep-grid { grid-template-columns: 1fr; }
    }
    .ep-card {
      display: block;
      background: var(--clr-surface);
      border: 1px solid var(--clr-border);
      border-radius: 12px;
      padding: 1.2rem 1.3rem;
      text-decoration: none;
      color: inherit;
      transition: border-color .15s, transform .15s;
    }
    .ep-card:hover { border-color: var(--clr-teal, #00D68F); transform: translateY(-2px); }
    .ep-card-num {
      display: block;
      font-family: 'Sora', sans-serif;
      font-size: .82rem;
      font-weight: 700;
      color: var(--clr-text-3, #64748B);
      letter-spacing: .08em;
      margin-bottom: .55rem;
    }
    .ep-card-title {
      display: block;
      font-family: 'Sora', sans-serif;
      font-size: 1rem;
      font-weight: 700;
      margin: 0 0 .45rem;
      color: var(--clr-text);
      line-height: 1.35;
    }
    .ep-card-desc {
      display: block;
      font-size: .86rem;
      color: var(--clr-text-2);
      line-height: 1.6;
      margin: 0 0 .65rem;
    }
    .ep-card-cta {
      display: inline-block;
      font-size: .82rem;
      color: var(--clr-blue);
      font-weight: 600;
    }
    .ep-corrections-line {
      font-size: .82rem;
      color: var(--clr-text-3, #64748B);
      margin: 1.1rem 0 0;
      text-align: center;
    }
    .ep-corrections-line a { color: var(--clr-blue); }

    /* M-3: priority-1 "start here" card — visually elevated above siblings */
    .gem-card--elevated {
      grid-column: 1 / -1;
      background: linear-gradient(135deg, rgba(0,194,179,.06), rgba(79,142,247,.04));
      border: 2px solid rgba(0,194,179,.4);
      box-shadow: 0 4px 14px rgba(0,194,179,.08);
      padding: 18px 20px;
    }
    .gem-card--elevated .gem-title { font-size: 1.12rem; }
    .gem-card--elevated .gem-desc { font-size: .92rem; }
    @media (max-width: 760px) {
      .gem-card--elevated { padding: 16px; }
    }
    .gem-tag {
      font-size: 9px;
      font-weight: 800;
      letter-spacing: .07em;
      text-transform: uppercase;
      padding: 2px 8px;
      border-radius: 99px;
      width: fit-content;
    }
    .gem-tag-alert { background: rgba(248,113,113,.15); color: #F87171; }
    .gem-tag-guide { background: rgba(79,142,247,.15); color: #4F8EF7; }
    .gem-tag-free { background: rgba(0,194,179,.15); color: #00C2B3; }
    .gem-tag-law { background: rgba(167,139,250,.15); color: #A78BFA; }
    .gem-tag-money { background: rgba(245,158,11,.15); color: #F59E0B; }
    .gem-title { font-size: 12px; font-weight: 700; color: var(--clr-text); line-height: 1.35; }
    .gem-desc { font-size: 10.5px; color: var(--clr-text-3); line-height: 1.5; flex: 1; }
    .gem-arrow { font-size: 10.5px; color: #00C2B3; font-weight: 600; text-decoration: none; display: inline-block; }
    .gem-arrow:hover { color: #00D68F; text-decoration: underline; }
    .gem-expand {
      display: none;
      background: var(--clr-bg-2);
      border: 1.5px solid rgba(0,194,179,.25);
      border-radius: 13px;
      padding: 16px 18px;
      margin-top: 8px;
      animation: engineFadeUp .25s ease-out;
      grid-column: 1 / -1;
    }
    .gem-expand.visible { display: block; }
    .gem-expand-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; }
    .gem-expand-title { font-size: .95rem; font-weight: 700; color: var(--clr-text); line-height: 1.4; max-width: 90%; }
    .gem-expand-close { background: none; border: none; color: var(--clr-text-3); cursor: pointer; font-size: 18px; line-height: 1; -webkit-appearance: none; }
    .gem-expand-desc { font-size: .83rem; color: var(--clr-text-2); line-height: 1.7; margin-bottom: 13px; }
    .gem-expand-btns { display: flex; gap: 7px; flex-wrap: wrap; }

    /* Responsive */
    @media (max-width: 600px) {
      .gems-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .hero-stats-new {
        border-radius: 10px;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
      }
      .hero-stats-row { margin: 1.85rem auto 2rem; }
      .stat-link-new { min-width: 0; padding: 9px 5px; }
      .stat-num-new { font-size: 1rem; }
      .stat-label-new { font-size: 10px; line-height: 1.35; }
      .stat-arrow-new { display: none; }
      .engine-top-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
      .advisor-chip { width: 100%; }
    }
    @media (max-width: 400px) {
      .gems-grid { grid-template-columns: 1fr; }
    }
