  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── CUSTOM SCROLLBAR ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.25); border-radius: 100px; }
::-webkit-scrollbar-thumb:hover { background: rgba(201,168,76,0.45); }

  :focus-visible {
    outline: 2px solid var(--gold);
    outline-offset: 3px;
  }

  :root {
    --bg: #080c18;
    --surface: #0f1623;
    --surface2: #151e2e;
    --border: #1e2d42;
    --border2: #253347;
    --gold: #c9a84c;
    --gold-light: #e2c074;
    --gold-dim: rgba(201,168,76,0.15);
    --blue: #3b82f6;
    --blue-dim: rgba(59,130,246,0.15);
    --green: #22c55e;
    --yellow: #f59e0b;
    --red: #ef4444;
    --purple: #8b5cf6;
    --text: #e2e8f0;
    --text2: #94a3b8;
    --text3: #64748b;
    --radius: 10px;
  }

  html { scroll-behavior: smooth; }

  body {
    background: var(--bg);
    background-image: radial-gradient(rgba(201,168,76,0.035) 1px, transparent 1px);
    background-size: 26px 26px;
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    min-height: 100vh;
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  /* ── PAYPAL MODAL ── */
  .modal-overlay {
    position: fixed; inset: 0;
    background: rgba(8,12,24,0.96);
    backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    z-index: 1000;
    padding: 20px;
    transition: opacity 0.3s;
  }
  .modal-overlay.hidden { opacity: 0; pointer-events: none; }

  .modal {
    background: var(--surface);
    border: 1px solid var(--border);
    border-top-color: rgba(201,168,76,0.25);
    border-radius: 14px;
    padding: 40px;
    max-width: 440px;
    width: 100%;
    box-shadow: 0 25px 80px rgba(0,0,0,0.6);
    position: relative;
    animation: modalIn 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  }
  @keyframes modalIn {
    from { opacity: 0; transform: scale(0.94) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
  }
  .modal-close-btn {
    position: absolute; top: 14px; right: 14px;
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--surface2); border: 1px solid var(--border2);
    color: var(--text3); font-size: 18px; line-height: 1;
    cursor: pointer; display: flex; align-items: center; justify-content: center;
    transition: color 0.2s, background 0.2s, border-color 0.2s;
    padding: 0;
  }
  .modal-close-btn:hover { color: var(--text); background: var(--border); border-color: var(--text3); }

  .modal-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(0,112,186,0.15);
    border: 1px solid rgba(0,112,186,0.3);
    border-radius: 100px;
    padding: 6px 14px;
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.08em; text-transform: uppercase;
    color: #60a5fa;
    margin-bottom: 20px;
  }

  .modal h2 {
    font-family: Georgia, serif;
    font-size: 22px; font-weight: 700;
    color: var(--text); margin-bottom: 12px; line-height: 1.3;
  }

  .modal p {
    color: var(--text2); font-size: 14px;
    line-height: 1.6; margin-bottom: 16px;
  }

  .modal-steps {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 16px 18px;
    margin-bottom: 24px;
  }

  .modal-step {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    font-size: 13px; color: var(--text2); line-height: 1.5;
  }
  .modal-step:last-child { border-bottom: none; padding-bottom: 0; }
  .modal-step:first-child { padding-top: 0; }

  .step-num {
    width: 24px; height: 24px; border-radius: 50%;
    background: linear-gradient(135deg, rgba(201,168,76,0.22), rgba(201,168,76,0.08));
    border: 1px solid rgba(201,168,76,0.4);
    color: var(--gold); font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 1px;
    box-shadow: 0 0 8px rgba(201,168,76,0.1);
  }

  .btn-primary {
    width: 100%;
    background: linear-gradient(135deg, #c9a84c 0%, #e2c074 50%, #c9a84c 100%);
    color: #0a0c14; border: none; border-radius: 8px;
    padding: 14px 20px; font-size: 15px; font-weight: 700;
    cursor: pointer; letter-spacing: 0.02em;
    transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    position: relative; overflow: hidden;
  }
  .btn-primary::after {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 55%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
    animation: btnShimmer 2.8s 1.2s ease-in-out infinite;
  }
  @keyframes btnShimmer {
    0% { left: -100%; }
    50%, 100% { left: 160%; }
  }
  .btn-primary:hover { opacity: 0.92; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(201,168,76,0.25); }
  .btn-primary:active { transform: translateY(0); }

  .btn-ghost {
    width: 100%; background: transparent;
    border: 1px solid var(--border2); border-radius: 8px;
    padding: 11px 20px; font-size: 14px; font-weight: 600;
    color: var(--text2); cursor: pointer; margin-top: 10px;
    transition: border-color 0.2s, color 0.2s;
  }
  .btn-ghost:hover { border-color: var(--text3); color: var(--text); }

  /* ── PAGE LAYOUT ── */
  .page { display: none; min-height: 100vh; }
  .page.active { display: block; animation: fadeIn 0.5s ease; }

  @keyframes fadeIn {
    from { opacity: 0; transform: translateY(22px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .container {
    max-width: 760px;
    margin: 0 auto;
    padding: 40px 20px 80px;
  }

  /* ── HEADER ── */
  .site-header {
    text-align: center;
    padding: 48px 20px 0;
    margin-bottom: 32px;
    position: relative;
  }
  .site-header::before {
    content: '';
    position: absolute;
    top: -60px; left: 50%; transform: translateX(-50%);
    width: 700px; height: 360px;
    background: radial-gradient(ellipse at 50% 40%,
      rgba(201,168,76,0.07) 0%,
      rgba(59,130,246,0.04) 45%,
      transparent 70%);
    pointer-events: none;
    z-index: 0;
  }
  .site-header > * { position: relative; z-index: 1; }

  .site-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--gold-dim);
    border: 1px solid rgba(201,168,76,0.3);
    border-radius: 100px;
    padding: 6px 16px;
    font-size: 11px; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 20px;
  }

  .site-title {
    font-family: Georgia, serif;
    font-size: clamp(32px, 6vw, 64px);
    font-weight: 700; color: var(--text);
    line-height: 1.15; margin-bottom: 14px;
    letter-spacing: -0.02em;
  }
  .site-title span {
    color: transparent;
    background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 50%, var(--gold) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    position: relative;
    display: inline-block;
  }
  .site-title span::after {
    content: '';
    position: absolute;
    left: 0; bottom: -2px;
    height: 2px; width: 100%;
    background: linear-gradient(90deg, var(--gold), var(--gold-light), transparent);
    transform: scaleX(0);
    transform-origin: left;
    animation: underlineSlide 0.9s 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  }
  @keyframes underlineSlide { to { transform: scaleX(1); } }

  .site-sub {
    color: var(--text2); font-size: 16px;
    line-height: 1.6; max-width: 520px;
    margin: 0 auto 32px;
  }

  .trust-row {
    display: flex; align-items: center; justify-content: center;
    gap: 24px; flex-wrap: wrap; margin-bottom: 0;
  }

  .trust-item {
    display: flex; align-items: center; gap: 6px;
    font-size: 12px; color: var(--text2); font-weight: 500;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 5px 12px;
    transition: border-color 0.2s, color 0.2s;
  }
  .trust-item:hover { border-color: var(--border2); color: var(--text); }
  .trust-item svg { color: var(--green); }

  /* ── STATS ROW ── */
  .stats-strip {
    display: flex; align-items: stretch;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--surface);
    margin-bottom: 28px;
    overflow: hidden;
  }

  .stat-item {
    flex: 1;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    padding: 22px 16px;
    border-right: 1px solid var(--border);
    position: relative;
  }
  .stat-item::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, var(--gold), transparent);
    opacity: 0.5;
  }
  .stat-item:last-child { border-right: none; }

  .stat-num {
    font-size: 30px; font-weight: 900;
    color: var(--gold); line-height: 1;
    letter-spacing: -1px;
    margin-bottom: 6px;
  }

  .stat-desc {
    font-size: 11px; color: var(--text2);
    line-height: 1.4; max-width: 110px;
  }

  @media (max-width: 640px) {
    .stats-strip {
      display: grid;
      grid-template-columns: 1fr 1fr;
    }
    .stat-item { border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .stat-item:nth-child(2n) { border-right: none; }
    .stat-item:nth-last-child(-n+2) { border-bottom: none; }
  }

  /* ── FORM CARD ── */
  .form-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-top-color: rgba(201,168,76,0.3);
    border-radius: 14px;
    padding: 36px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 0 1px rgba(201,168,76,0.05);
  }
  .form-card h3 {
    font-family: Georgia, serif;
    font-size: 20px; font-weight: 700; margin-bottom: 6px;
  }
  .form-card .form-sub {
    color: var(--text2); font-size: 13px; margin-bottom: 28px;
  }
  .form-divider { height: 1px; background: var(--border); margin: 20px 0; }

  .field { margin-bottom: 16px; }
  .field label {
    display: block; font-size: 12px; font-weight: 600;
    letter-spacing: 0.05em; text-transform: uppercase;
    color: var(--text2); margin-bottom: 6px;
  }
  .field input, .field select {
    width: 100%;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 8px; padding: 12px 14px;
    color: var(--text); font-size: 14px; outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    appearance: none;
  }
  .field input:focus, .field select:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(201,168,76,0.12), 0 0 14px rgba(201,168,76,0.07);
  }
  .field input::placeholder { color: var(--text3); }
  .select-wrap { position: relative; }
  .select-wrap svg {
    position: absolute; right: 12px; top: 50%;
    transform: translateY(-50%);
    pointer-events: none; color: var(--text3);
  }
  .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

  .error-msg {
    background: rgba(239,68,68,0.1);
    border: 1px solid rgba(239,68,68,0.3);
    border-radius: 8px; padding: 12px 14px;
    font-size: 13px; color: #fca5a5;
    margin-top: 12px; display: none;
  }
  .error-msg.show { display: block; }

  /* ── AUDIT PROGRESS ── */
  .audit-header {
    text-align: center; padding: 60px 20px 40px;
  }
  .audit-header h2 {
    font-family: Georgia, serif;
    font-size: clamp(22px, 4vw, 32px); margin-bottom: 10px;
    transition: opacity 0.4s ease;
  }
  .audit-header p { color: var(--text2); font-size: 15px; transition: opacity 0.4s ease; }

  .ai-analysis-panel {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px auto 0;
    padding: 16px 22px;
    background: rgba(201,168,76,0.07);
    border: 1px solid rgba(201,168,76,0.28);
    border-radius: 10px;
    max-width: 420px;
    color: var(--gold);
    font-size: 0.9rem;
    line-height: 1.5;
    animation: aiPanelGlow 2s ease-in-out infinite;
  }
  @keyframes aiPanelGlow {
    0%, 100% { border-color: rgba(201,168,76,0.28); box-shadow: 0 0 0 0 transparent; }
    50% { border-color: rgba(201,168,76,0.5); box-shadow: 0 0 18px rgba(201,168,76,0.08); }
  }
  .ai-spark-ring {
    width: 22px; height: 22px;
    border: 2px solid var(--gold);
    border-top-color: transparent;
    border-radius: 50%;
    flex-shrink: 0;
    animation: aiSpin 0.9s linear infinite;
    position: relative;
  }
  .ai-spark-ring::before {
    content: '';
    position: absolute;
    inset: -5px;
    border: 1px solid rgba(201,168,76,0.2);
    border-radius: 50%;
    animation: ringPulse 1.6s ease-in-out infinite;
  }
  @keyframes ringPulse {
    0%, 100% { transform: scale(1); opacity: 0.6; }
    50% { transform: scale(1.35); opacity: 0; }
  }
  @keyframes aiSpin { to { transform: rotate(360deg); } }

  .audit-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px; padding: 32px;
    max-width: 600px; margin: 0 auto;
  }

  .progress-bar-wrap {
    height: 6px; background: var(--border);
    border-radius: 999px; margin-bottom: 32px; overflow: hidden;
  }
  .progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--gold), #a78bfa, var(--blue));
    border-radius: 999px; width: 0%;
    transition: width 0.6s ease;
    position: relative; overflow: hidden;
  }
  .progress-bar-fill::after {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 60%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    animation: barShimmer 1.6s ease-in-out infinite;
  }
  @keyframes barShimmer {
    0% { left: -60%; }
    100% { left: 160%; }
  }

  .check-list { list-style: none; display: flex; flex-direction: column; gap: 4px; }
  .check-item {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 16px; border-radius: 8px;
    font-size: 14px; color: var(--text3);
    transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    opacity: 0; transform: translateX(-12px);
    border-left: 2px solid transparent;
  }
  .check-item.visible { opacity: 1; transform: translateX(0); }
  .check-item.running {
    color: var(--text2); background: var(--surface2);
    border-left-color: rgba(201,168,76,0.45);
  }
  .check-item.done { color: var(--text); }
  .check-item.done.found { border-left-color: rgba(34,197,94,0.45); }
  .check-item.done.weak { border-left-color: rgba(245,158,11,0.45); }
  .check-item.done.not_found { border-left-color: rgba(239,68,68,0.45); }

  .check-icon {
    width: 26px; height: 26px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; font-size: 13px;
  }
  .check-icon.spinning {
    border: 2px solid var(--border2);
    border-top-color: var(--blue);
    animation: spin 0.8s linear infinite;
  }
  @keyframes spin { to { transform: rotate(360deg); } }
  .check-icon.found { background: rgba(34,197,94,0.15); font-size: 14px; }
  .check-icon.weak { background: rgba(245,158,11,0.15); font-size: 14px; }
  .check-icon.not_found { background: rgba(239,68,68,0.15); font-size: 14px; }
  .check-label { flex: 1; font-weight: 500; }
  .check-status { font-size: 12px; font-weight: 600; }
  .check-status.found { color: var(--green); }
  .check-status.weak { color: var(--yellow); }
  .check-status.not_found { color: var(--red); }
  .audit-footer-note {
    text-align: center; margin-top: 24px;
    font-size: 12px; color: var(--text3);
  }

  /* ── RESULTS HEADER ── */
  .results-header {
    text-align: center; padding: 48px 20px 0; margin-bottom: 36px;
  }
  .results-header h2 {
    font-family: Georgia, serif;
    font-size: clamp(22px, 4vw, 34px);
    margin-bottom: 10px; line-height: 1.3;
  }
  .results-header p { color: var(--text2); font-size: 15px; }

  /* ── SCORE CIRCLES ── */
  .scores-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 16px; margin-bottom: 28px;
  }
  .score-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; padding: 24px 16px 20px; text-align: center;
  }
  .score-card.main {
    border-color: rgba(201,168,76,0.4);
    background: linear-gradient(160deg, #0f1623 0%, #131c2a 100%);
    box-shadow: 0 0 40px rgba(201,168,76,0.08);
  }
  .score-circle-wrap {
    position: relative; width: 88px; height: 88px; margin: 0 auto 12px;
  }
  .score-circle-wrap svg { width: 100%; height: 100%; transform: rotate(-90deg); }
  .score-circle-bg { fill: none; stroke: var(--border2); stroke-width: 8; }
  .score-circle-fill {
    fill: none; stroke-width: 8; stroke-linecap: round;
    stroke-dasharray: 220; stroke-dashoffset: 220;
    transition: stroke-dashoffset 1.4s cubic-bezier(0.25, 1, 0.5, 1);
  }
  .score-circle-fill.gold { stroke: var(--gold); filter: drop-shadow(0 0 6px rgba(201,168,76,0.45)); }
  .score-circle-fill.blue { stroke: var(--blue); filter: drop-shadow(0 0 6px rgba(59,130,246,0.4)); }
  .score-circle-fill.green { stroke: var(--green); filter: drop-shadow(0 0 6px rgba(34,197,94,0.4)); }
  .score-circle-fill.red { stroke: var(--red); filter: drop-shadow(0 0 6px rgba(239,68,68,0.4)); }
  .score-number {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    flex-direction: column; gap: 0;
    font-size: 24px; font-weight: 800; color: var(--text);
    line-height: 1;
  }
  .score-unit {
    font-size: 10px; font-weight: 500;
    color: var(--text3); letter-spacing: 0.02em; margin-top: 2px;
  }
  .score-card.main .score-number { font-size: 26px; color: var(--gold); }
  .score-label { font-size: 12px; font-weight: 600; color: var(--text2); letter-spacing: 0.04em; }

  /* ── SUMMARY CARD ── */
  .summary-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; padding: 28px; margin-bottom: 24px;
  }
  .summary-card h4 {
    font-family: Georgia, serif; font-size: 16px; font-weight: 700;
    margin-bottom: 12px; color: var(--text);
  }
  .summary-text { color: var(--text2); font-size: 14px; line-height: 1.7; }

  /* ── AI SAMPLE RESPONSE CARD ── */
  .ai-sample-card {
    background: #070b14;
    border: 1px solid var(--border);
    border-radius: 12px; margin-bottom: 24px; overflow: hidden;
  }
  .ai-titlebar {
    background: var(--surface2);
    border-bottom: 1px solid var(--border);
    padding: 10px 16px;
    display: flex; align-items: center; gap: 7px;
  }
  .dot { width: 10px; height: 10px; border-radius: 50%; }
  .dot-r { background: #ef4444; }
  .dot-y { background: #f59e0b; }
  .dot-g { background: #22c55e; }
  .ai-titlebar-label {
    font-size: 12px; color: var(--text3);
    margin-left: 6px; font-family: 'SF Mono', 'Fira Code', monospace;
  }
  .ai-sample-body { padding: 20px; }
  .ai-row { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
  .ai-row:last-of-type { margin-bottom: 0; }
  .ai-avatar {
    width: 30px; height: 30px; border-radius: 7px;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; font-weight: 800; flex-shrink: 0; color: white;
  }
  .ai-avatar.user { background: #7c3aed; }
  .ai-avatar.bot { background: linear-gradient(135deg, #06b6d4, #3b82f6); font-size: 10px; }
  .ai-bubble {
    border-radius: 10px; padding: 11px 14px;
    font-size: 13px; line-height: 1.6; flex: 1;
  }
  .ai-bubble.user {
    background: rgba(124,58,237,0.12);
    border: 1px solid rgba(124,58,237,0.2);
    color: var(--text); font-style: italic;
  }
  .ai-bubble.bot {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text2);
  }
  .ai-absent-badge {
    display: flex; align-items: center; gap: 8px;
    background: rgba(239,68,68,0.08);
    border: 1px solid rgba(239,68,68,0.2);
    border-radius: 8px; padding: 10px 14px;
    font-size: 12px; color: #fca5a5; margin-top: 14px;
  }
  .ai-present-badge {
    display: flex; align-items: center; gap: 8px;
    background: rgba(34,197,94,0.08);
    border: 1px solid rgba(34,197,94,0.2);
    border-radius: 8px; padding: 10px 14px;
    font-size: 12px; color: #86efac; margin-top: 14px;
  }

  /* ── FINDINGS CARD ── */
  .findings-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; padding: 28px; margin-bottom: 24px;
  }
  .findings-card h4 {
    font-family: Georgia, serif; font-size: 16px; font-weight: 700;
    margin-bottom: 20px;
    display: flex; align-items: center; gap: 10px;
  }
  .findings-card h4::after {
    content: ''; flex: 1; height: 1px; background: var(--border);
  }
  .finding-item {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 10px 14px 0; border-bottom: 1px solid var(--border);
    border-radius: 6px;
    transition: background 0.2s, padding-left 0.2s;
    cursor: default;
  }
  .finding-item:hover { background: rgba(201,168,76,0.03); padding-left: 8px; }
  .finding-item:last-child { border-bottom: none; padding-bottom: 0; }
  .finding-item:first-child { padding-top: 0; }
  .finding-num {
    width: 24px; height: 24px; border-radius: 50%;
    background: var(--gold-dim); border: 1px solid rgba(201,168,76,0.3);
    color: var(--gold); font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 1px;
    transition: transform 0.2s;
  }
  .finding-item:hover .finding-num { transform: scale(1.1); }
  .finding-num.severity-critical { background: rgba(239,68,68,0.12); border-color: rgba(239,68,68,0.3); color: var(--red); }
  .finding-num.severity-warning { background: rgba(245,158,11,0.12); border-color: rgba(245,158,11,0.3); color: var(--yellow); }
  .finding-num.severity-info { background: rgba(59,130,246,0.12); border-color: rgba(59,130,246,0.3); color: var(--blue); }
  .finding-text { font-size: 14px; line-height: 1.6; color: var(--text2); }

  /* ── BENCHMARK CARD ── */
  .benchmark-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; padding: 28px; margin-bottom: 28px;
  }
  .benchmark-card h4 {
    font-family: Georgia, serif; font-size: 16px; font-weight: 700;
    margin-bottom: 20px; color: var(--text);
    display: flex; align-items: center; gap: 10px;
  }
  .benchmark-card h4::after {
    content: ''; flex: 1; height: 1px; background: var(--border);
  }
  .benchmark-row {
    display: grid; grid-template-columns: 160px 1fr 44px;
    align-items: center; gap: 14px; margin-bottom: 16px;
  }
  .benchmark-row:last-child { margin-bottom: 0; }
  .bench-label { font-size: 13px; color: var(--text2); }
  .bench-track {
    height: 8px; background: var(--border2);
    border-radius: 100px; overflow: hidden;
  }
  .bench-fill {
    height: 100%; border-radius: 100px; width: 0%;
    transition: width 1.4s cubic-bezier(0.25, 1, 0.5, 1);
  }
  .bench-fill.yours { background: var(--gold); }
  .bench-fill.avg { background: var(--blue); }
  .bench-fill.top { background: var(--green); }
  .bench-value { font-size: 13px; font-weight: 700; color: var(--text); text-align: right; }

  /* ── PRICING ── */
  .pricing-header {
    text-align: center; margin-bottom: 32px; padding: 16px 0 0;
  }
  .pricing-header h3 {
    font-family: Georgia, serif;
    font-size: clamp(20px, 3.5vw, 28px); margin-bottom: 8px;
  }
  .pricing-header p { color: var(--text2); font-size: 14px; }

  .urgency-line {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(239,68,68,0.1);
    border: 1px solid rgba(239,68,68,0.3);
    border-radius: 100px; padding: 6px 16px;
    font-size: 12px; font-weight: 600; color: #fca5a5; margin-top: 14px;
  }
  .urgency-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #ef4444; animation: pulse 1.5s ease infinite;
  }
  @keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.8); }
  }

  .pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px; margin-bottom: 40px;
  }

  .pricing-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 14px; padding: 28px 24px;
    display: flex; flex-direction: column;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
    position: relative;
  }
  .pricing-card:hover {
    border-color: var(--border2);
    transform: translateY(-4px);
    box-shadow: 0 16px 50px rgba(0,0,0,0.4);
  }
  .pricing-card.featured {
    border-color: rgba(201,168,76,0.5);
    background: linear-gradient(160deg, #0f1623 0%, #131c28 100%);
    box-shadow: 0 0 50px rgba(201,168,76,0.1);
    animation: featuredGlow 3s ease-in-out infinite;
  }
  .pricing-card.featured::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--gold), var(--gold-light), var(--gold), transparent);
    border-radius: 14px 14px 0 0;
  }
  @keyframes featuredGlow {
    0%, 100% { box-shadow: 0 0 50px rgba(201,168,76,0.1); border-color: rgba(201,168,76,0.5); }
    50% { box-shadow: 0 0 70px rgba(201,168,76,0.18), 0 0 25px rgba(201,168,76,0.08); border-color: rgba(201,168,76,0.75); }
  }
  .pricing-card.featured:hover { border-color: var(--gold); }

  .featured-badge {
    position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    color: #0a0c14; font-size: 10px; font-weight: 800;
    letter-spacing: 0.1em; text-transform: uppercase;
    padding: 4px 14px; border-radius: 100px; white-space: nowrap;
  }

  .pricing-tier {
    font-size: 11px; font-weight: 700; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--text2); margin-bottom: 8px;
  }
  .pricing-name {
    font-family: Georgia, serif; font-size: 18px;
    font-weight: 700; margin-bottom: 6px; line-height: 1.3;
  }
  .pricing-tagline { font-size: 12px; color: var(--text3); margin-bottom: 20px; line-height: 1.5; }
  .pricing-price { margin-bottom: 20px; }
  .pricing-amount { font-size: 32px; font-weight: 800; color: var(--text); line-height: 1; }
  .pricing-card.featured .pricing-amount { color: var(--gold); }
  .pricing-per { font-size: 13px; color: var(--text3); margin-left: 2px; }

  .pricing-features {
    list-style: none; margin-bottom: 24px;
    flex: 1; display: flex; flex-direction: column; gap: 10px;
  }
  .pricing-features li {
    display: flex; align-items: flex-start; gap: 9px;
    font-size: 13px; color: var(--text2); line-height: 1.5;
  }
  .pricing-features li svg { flex-shrink: 0; color: var(--green); margin-top: 1px; }

  /* ── CHECKOUT BUTTON ── */
  .btn-checkout {
    width: 100%;
    background: linear-gradient(135deg, #c9a84c 0%, #e2c074 50%, #c9a84c 100%);
    color: #0a0c14; border: none; border-radius: 8px;
    padding: 13px 20px; font-size: 14px; font-weight: 700;
    cursor: pointer; letter-spacing: 0.02em;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: opacity 0.2s, transform 0.15s;
    margin-bottom: 6px;
  }
  .btn-checkout:hover { opacity: 0.9; transform: translateY(-1px); }
  .btn-checkout:active { transform: translateY(0); }
  .checkout-note { font-size: 11px; color: var(--text3); text-align: center; }

  /* ── CHECKOUT MODAL FIELDS ── */
  .checkout-field { margin-bottom: 14px; }
  .checkout-field label {
    display: block; font-size: 12px; font-weight: 600;
    letter-spacing: 0.05em; text-transform: uppercase;
    color: var(--text2); margin-bottom: 6px;
  }
  .checkout-field input {
    width: 100%; background: var(--surface2);
    border: 1px solid var(--border); border-radius: 8px;
    padding: 11px 14px; color: var(--text); font-size: 14px; outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
  }
  .checkout-field input:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(201,168,76,0.12);
  }
  .checkout-field input::placeholder { color: var(--text3); }

  /* ── FOOTER ── */
  .footer-note {
    text-align: center; padding: 20px;
    font-size: 12px; color: var(--text3);
    border-top: 1px solid var(--border);
  }

  /* ── COMPETITOR LEADERBOARD ── */
  .leaderboard-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    margin-bottom: 16px;
  }
  .leaderboard-card h4 {
    font-family: Georgia, serif;
    font-size: 16px; font-weight: 700;
    color: var(--text); margin-bottom: 4px;
  }
  .leaderboard-card h4::after {
    content: ''; display: block;
    width: 32px; height: 2px;
    background: var(--red);
    margin-top: 8px; margin-bottom: 14px;
  }
  .leaderboard-subtitle {
    font-size: 13px; color: var(--text2);
    margin-bottom: 18px;
  }
  .leaderboard-row {
    display: grid;
    grid-template-columns: 28px 1fr 80px 44px;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
  }
  .leaderboard-row:last-child { border-bottom: none; padding-bottom: 0; }
  .lb-rank {
    font-size: 12px; font-weight: 700;
    color: var(--text3); text-align: center;
  }
  .lb-name { font-size: 14px; color: var(--text); font-weight: 500; }
  .lb-bar-wrap {
    background: var(--surface2);
    border-radius: 4px; height: 6px; overflow: hidden;
  }
  .lb-bar { height: 100%; border-radius: 4px; transition: width 0.8s ease; }
  .lb-bar.competitor { background: var(--blue); }
  .lb-bar.you { background: var(--red); }
  .lb-score { font-size: 13px; font-weight: 700; text-align: right; }
  .lb-score.competitor { color: var(--blue); }
  .lb-score.you { color: var(--red); }
  .lb-you-label {
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    color: var(--red); text-transform: uppercase;
  }

  /* ── REVENUE ESTIMATOR ── */
  .revenue-card {
    background: linear-gradient(135deg, #1a0c0c 0%, #0f1623 100%);
    border: 1px solid rgba(239,68,68,0.3);
    border-radius: var(--radius);
    padding: 28px 24px;
    margin-bottom: 16px;
  }
  .revenue-card h4 {
    font-family: Georgia, serif;
    font-size: 16px; font-weight: 700;
    color: var(--red); margin-bottom: 4px;
  }
  .revenue-card h4::after {
    content: ''; display: block;
    width: 32px; height: 2px;
    background: var(--red);
    margin-top: 8px; margin-bottom: 16px;
  }
  .revenue-desc {
    font-size: 14px; color: var(--text2);
    line-height: 1.6; margin-bottom: 20px;
  }
  .revenue-amounts {
    display: flex; gap: 24px; align-items: flex-end;
    flex-wrap: wrap; margin-bottom: 12px;
  }
  .revenue-amount-block { display: flex; flex-direction: column; gap: 4px; }
  .revenue-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.08em; }
  .revenue-dollars {
    font-family: Georgia, serif;
    font-size: 30px; font-weight: 700;
    color: var(--gold-light); line-height: 1;
  }
  .revenue-note { font-size: 12px; color: var(--text3); line-height: 1.5; }

  /* ── RESPONSIVE ── */
  @media (max-width: 600px) {
    .form-card, .audit-card { padding: 24px 20px; }
    .field-row { grid-template-columns: 1fr; }
    .scores-grid { grid-template-columns: 1fr 1fr; }
    .pricing-grid { grid-template-columns: 1fr; }
    .modal { padding: 28px 24px; }
    .benchmark-row { grid-template-columns: 120px 1fr 36px; }
  }
  @media (max-width: 380px) {
    .scores-grid { grid-template-columns: 1fr; }
    .benchmark-row { grid-template-columns: 1fr; }
  }

  /* ── SCORE METHODOLOGY NOTE ── */
  .methodology-note {
    font-size: 11px; color: var(--text3);
    text-align: center; margin-top: -20px; margin-bottom: 24px;
    line-height: 1.5; padding: 0 12px;
  }

  /* ── SEO & GBP SIGNAL TILES ── */
  .signals-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; padding: 24px; margin-bottom: 24px;
  }
  .signals-card h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700;
    margin-bottom: 18px; color: var(--text);
    display: flex; align-items: center; gap: 10px;
  }
  .signals-card h4::after { content: ''; flex: 1; height: 1px; background: var(--border); }
  .signals-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 12px;
  }
  .signal-tile {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-left: 3px solid var(--border2);
    border-radius: 8px; padding: 20px 16px;
    transition: border-left-color 0.3s;
  }
  .signal-tile:has(.signal-badge.good) { border-left-color: rgba(34,197,94,0.5); }
  .signal-tile:has(.signal-badge.weak) { border-left-color: rgba(245,158,11,0.5); }
  .signal-tile:has(.signal-badge.bad) { border-left-color: rgba(239,68,68,0.5); }
  .signal-tile-label {
    font-size: 10px; font-weight: 700; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--text3); margin-bottom: 8px;
  }
  .live-dot {
    color: #22c55e; font-size: 8px; vertical-align: middle;
    margin-right: 3px; opacity: 0.9;
  }
  .signal-tile-value {
    font-size: 20px; font-weight: 800; color: var(--text); line-height: 1;
    margin-bottom: 6px;
  }
  .signal-badge {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 11px; font-weight: 600;
    padding: 3px 9px; border-radius: 100px;
  }
  .signal-badge.good {
    background: rgba(34,197,94,0.12);
    border: 1px solid rgba(34,197,94,0.25);
    color: #86efac;
  }
  .signal-badge.weak {
    background: rgba(245,158,11,0.12);
    border: 1px solid rgba(245,158,11,0.25);
    color: #fcd34d;
  }
  .signal-badge.bad {
    background: rgba(239,68,68,0.12);
    border: 1px solid rgba(239,68,68,0.25);
    color: #fca5a5;
  }

  /* ── COMPETITIVE TABLE ── */
  .competitor-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; margin-bottom: 24px; overflow: hidden;
  }
  .competitor-card-header {
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--border);
  }
  .competitor-card-header h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700; color: var(--text);
    margin-bottom: 4px;
  }
  .competitor-card-header p { font-size: 12px; color: var(--text3); }
  .comp-table { width: 100%; border-collapse: collapse; }
  .comp-table th {
    font-size: 10px; font-weight: 700; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--text3);
    padding: 10px 16px; text-align: left;
    border-bottom: 1px solid var(--border);
    background: var(--surface2);
  }
  .comp-table th:not(:first-child) { text-align: right; }
  .comp-table td {
    font-size: 13px; color: var(--text2);
    padding: 12px 16px; border-bottom: 1px solid var(--border);
    vertical-align: middle;
  }
  .comp-table td:not(:first-child) { text-align: right; }
  .comp-table tr:last-child td { border-bottom: none; }
  .comp-table tr.you-row td {
    color: var(--text); font-weight: 600;
    background: rgba(201,168,76,0.04);
  }
  .comp-table tr.you-row td:first-child {
    color: var(--gold);
    border-left: 3px solid rgba(201,168,76,0.6);
  }
  .comp-name { font-weight: 600; color: var(--text); }
  .comp-score {
    display: inline-flex; align-items: center; justify-content: center;
    width: 34px; height: 24px;
    border-radius: 5px; font-size: 12px; font-weight: 700;
    background: rgba(59,130,246,0.15); color: var(--blue);
  }
  .comp-score.you-score { background: rgba(239,68,68,0.15); color: var(--red); }
  .comp-table-note {
    font-size: 11px; color: var(--text3);
    padding: 12px 16px; border-top: 1px solid var(--border);
    background: var(--surface2); line-height: 1.5;
  }
  .competitor-card { overflow-x: auto; }

  @media (max-width: 700px) {
    .comp-table th:nth-child(3),
    .comp-table td:nth-child(3),
    .comp-table th:nth-child(4),
    .comp-table td:nth-child(4),
    .comp-table th:nth-child(5),
    .comp-table td:nth-child(5) { display: none; }
  }

  /* ── AI VISIBILITY METHODOLOGY CARD ── */
  .methodology-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px; margin-bottom: 24px; overflow: hidden;
  }
  .methodology-toggle {
    width: 100%; background: none; border: none; cursor: pointer;
    padding: 18px 24px;
    display: flex; align-items: center; justify-content: space-between;
    text-align: left;
  }
  .methodology-toggle-left {
    display: flex; align-items: center; gap: 12px;
  }
  .methodology-icon {
    width: 32px; height: 32px; border-radius: 8px;
    background: var(--blue-dim);
    border: 1px solid rgba(59,130,246,0.2);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; color: var(--blue);
  }
  .methodology-title {
    font-family: Georgia, serif; font-size: 14px; font-weight: 700;
    color: var(--text);
  }
  .methodology-subtitle { font-size: 12px; color: var(--text3); margin-top: 2px; }
  .methodology-chevron {
    color: var(--text3); transition: transform 0.25s;
    flex-shrink: 0;
  }
  .methodology-chevron.open { transform: rotate(180deg); }
  .methodology-body {
    padding: 0 24px;
    max-height: 0; overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s;
  }
  .methodology-body.open {
    max-height: 600px;
    overflow-y: auto;
    padding: 0 24px 20px;
  }
  .methodology-body p {
    font-size: 13px; color: var(--text2); line-height: 1.7;
    border-top: 1px solid var(--border);
    padding-top: 16px;
  }

  /* ── REVENUE MODEL ── */
  .revenue-model-card {
    background: var(--surface);
    border: 1px solid rgba(201,168,76,0.25);
    border-radius: 12px; margin-bottom: 16px; overflow: hidden;
  }
  .revenue-model-header {
    padding: 20px 24px 0;
    display: flex; align-items: flex-start; justify-content: space-between;
    flex-wrap: wrap; gap: 12px;
  }
  .revenue-model-header h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700; color: var(--text);
  }
  .revenue-model-header p { font-size: 12px; color: var(--text3); margin-top: 4px; }
  .revenue-scenario-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--gold-dim);
    border: 1px solid rgba(201,168,76,0.25);
    border-radius: 100px; padding: 4px 12px;
    font-size: 11px; font-weight: 600;
    color: var(--gold); white-space: nowrap; flex-shrink: 0;
  }
  .revenue-math {
    padding: 20px 24px;
    display: flex; flex-direction: column; gap: 0;
  }
  .math-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 0;
    border-bottom: 1px solid var(--border);
    gap: 16px;
  }
  .math-row:last-of-type { border-bottom: none; }
  .math-label { font-size: 13px; color: var(--text2); flex: 1; }
  .math-label em { font-style: normal; font-size: 11px; color: var(--text3); display: block; margin-top: 1px; }
  .math-value { font-size: 14px; font-weight: 700; color: var(--text); white-space: nowrap; }
  .math-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
    margin: 10px 0;
  }
  .math-row.total .math-label { color: var(--text); font-weight: 600; }
  .math-row.total .math-value { font-size: 17px; color: var(--red); }
  .math-row.total:last-of-type .math-value { font-size: 22px; font-weight: 900; color: var(--red); }
  .revenue-note {
    font-size: 11px; color: var(--text3);
    padding: 0 24px 18px; line-height: 1.5;
  }

  /* ── OPPORTUNITY NOTE ── */
  .opportunity-card {
    background: var(--surface);
    border: 1px solid rgba(201,168,76,0.3);
    border-left: 3px solid var(--gold);
    border-radius: 12px; padding: 20px 24px;
    margin-bottom: 28px;
  }
  .opportunity-card h4 {
    font-family: Georgia, serif; font-size: 14px; font-weight: 700;
    color: var(--gold-light); margin-bottom: 10px;
  }
  .opportunity-card p { font-size: 13px; color: var(--text2); line-height: 1.7; }

  /* ── URL AUTO-FILL ── */
  .url-input-wrap { position: relative; }
  .url-input-wrap input { width: 100%; }
  .url-spinner {
    display: none;
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    width: 16px; height: 16px;
    border: 2px solid var(--border2);
    border-top-color: var(--gold);
    border-radius: 50%;
    animation: spin 0.7s linear infinite;
    pointer-events: none;
  }
  .url-spinner.active { display: block; }
  @keyframes spin { to { transform: translateY(-50%) rotate(360deg); } }
  .autofill-badge {
    display: none;
    margin-top: 6px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--gold);
    opacity: 0;
    transition: opacity 0.4s;
  }
  .autofill-badge.show { display: block; opacity: 1; }
  .autofill-badge.fade { opacity: 0; }

  /* ── FORM REDESIGN ── */
  .url-hero {
    background: linear-gradient(135deg, rgba(201,168,76,0.08) 0%, rgba(201,168,76,0.03) 100%);
    border: 1px solid rgba(201,168,76,0.25);
    border-radius: 12px;
    padding: 18px 20px 16px;
    margin-bottom: 18px;
  }
  .url-hero-label {
    font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
  }
  .url-hero .field { margin-bottom: 0; }
  .url-hero .field label { color: var(--text2); }

  .or-divider {
    display: flex; align-items: center; gap: 12px;
    margin: 18px 0;
  }
  .or-divider::before, .or-divider::after {
    content: ''; flex: 1; height: 1px; background: var(--border);
  }
  .or-divider span {
    font-size: 10px; color: var(--text3); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em; white-space: nowrap;
  }

  /* ── AUTOCOMPLETE DROPDOWN ── */
  .ac-wrap { position: relative; }
  .ac-dropdown {
    position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 200;
    background: var(--surface2); border: 1px solid var(--border2);
    border-radius: 10px; overflow: hidden;
    box-shadow: 0 16px 50px rgba(0,0,0,0.55);
    display: none;
  }
  .ac-dropdown.open { display: block; }
  .ac-item {
    padding: 11px 14px; cursor: pointer;
    border-bottom: 1px solid var(--border);
    display: flex; flex-direction: column; gap: 2px;
    transition: background 0.1s;
  }
  .ac-item:last-child { border-bottom: none; }
  .ac-item:hover, .ac-item.ac-active { background: rgba(201,168,76,0.1); }
  .ac-item-name { font-size: 13px; font-weight: 600; color: var(--text); }
  .ac-item-addr { font-size: 11px; color: var(--text3); }
  .ac-item-hint { font-size: 10px; color: var(--gold); font-weight: 600; letter-spacing: 0.05em; margin-top: 2px; }
  .ac-loading, .ac-empty {
    padding: 14px; text-align: center; color: var(--text3); font-size: 12px;
  }

  .field input.autofilled {
    border-color: var(--green) !important;
    background: rgba(34,197,94,0.05) !important;
  }

  /* ── DATA SOURCE LEGEND ── */
  .data-legend {
    display: flex; align-items: center; gap: 14px;
    flex-wrap: wrap; margin-top: 14px;
    padding-top: 12px; border-top: 1px solid var(--border);
  }
  .legend-item {
    display: flex; align-items: center; gap: 5px;
    font-size: 11px; color: var(--text3);
  }
  .legend-dot-live { color: var(--green); }

  /* ── API FALLBACK BANNER ── */
  .audit-error-banner {
    background: rgba(245,158,11,0.08);
    border: 1px solid rgba(245,158,11,0.25);
    border-radius: 10px; padding: 14px 18px;
    margin-bottom: 24px; font-size: 13px;
    color: #fcd34d; line-height: 1.5;
    display: none; align-items: flex-start; gap: 12px;
  }
  .audit-error-banner.show { display: flex; }
  .audit-error-banner svg { flex-shrink: 0; color: #f59e0b; margin-top: 1px; }

  /* ── GBP PROFILE CHECKLIST ── */
  .gbp-checklist-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; padding: 24px; margin-bottom: 24px;
  }
  .gbp-checklist-card h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700;
    margin-bottom: 16px; color: var(--text);
    display: flex; align-items: center; gap: 10px;
  }
  .gbp-checklist-card h4::after { content: ''; flex: 1; height: 1px; background: var(--border); }
  .gbp-checklist-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 10px;
  }
  .gbp-check-item {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 10px 14px; background: var(--surface2);
    border: 1px solid var(--border); border-radius: 8px;
  }
  .gbp-check-icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
  .gbp-check-info { display: flex; flex-direction: column; gap: 2px; }
  .gbp-check-key { font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text3); }
  .gbp-check-val { font-size: 13px; color: var(--text); }

  /* ── LOCAL PACK DETAIL ── */
  .pack-detail-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; margin-bottom: 24px; overflow: hidden;
  }
  .pack-detail-header {
    padding: 18px 24px 14px; border-bottom: 1px solid var(--border);
  }
  .pack-detail-header h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700;
    color: var(--text); margin-bottom: 3px;
  }
  .pack-detail-header p { font-size: 12px; color: var(--text3); }
  .pack-firm-list { list-style: none; }
  .pack-firm-item {
    display: flex; align-items: center; gap: 14px;
    padding: 11px 24px; border-bottom: 1px solid var(--border);
  }
  .pack-firm-item:last-child { border-bottom: none; }
  .pack-firm-item.you-pack { background: rgba(239,68,68,0.05); }
  .pack-rank-num {
    width: 26px; height: 26px; border-radius: 50%;
    background: var(--surface2); border: 1px solid var(--border2);
    font-size: 12px; font-weight: 700; color: var(--text3);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .pack-rank-num.top3 { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.3); color: var(--gold); }
  .pack-firm-name { flex: 1; font-size: 13px; font-weight: 600; color: var(--text); }
  .pack-you-tag { font-size: 10px; font-weight: 700; color: var(--red); margin-left: 6px; text-transform: uppercase; }
  .pack-firm-meta { font-size: 12px; color: var(--text3); white-space: nowrap; }

  /* ── GOOGLE ORGANIC RESULTS ── */
  .search-results-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; margin-bottom: 24px; overflow: hidden;
  }
  .search-results-header {
    padding: 18px 24px 14px; border-bottom: 1px solid var(--border);
  }
  .search-results-header h4 {
    font-family: Georgia, serif; font-size: 15px; font-weight: 700;
    color: var(--text); margin-bottom: 3px;
  }
  .search-results-header p { font-size: 12px; color: var(--text3); }
  .search-result-item {
    padding: 12px 24px; border-bottom: 1px solid var(--border);
  }
  .search-result-item:last-child { border-bottom: none; }
  .search-result-item.firm-result { background: rgba(34,197,94,0.04); }
  .search-result-num {
    font-size: 10px; font-weight: 700; letter-spacing: 0.06em;
    color: var(--text3); text-transform: uppercase; margin-bottom: 3px;
    display: flex; align-items: center; gap: 6px;
  }
  .firm-hit-tag {
    background: rgba(34,197,94,0.15); border: 1px solid rgba(34,197,94,0.3);
    color: #86efac; padding: 1px 8px; border-radius: 100px;
    font-size: 10px; font-weight: 700;
  }
  .search-result-title { font-size: 13px; font-weight: 600; color: #60a5fa; margin-bottom: 3px; }
  .search-result-domain { font-size: 11px; color: var(--text3); margin-bottom: 4px; }
  .search-result-snippet { font-size: 12px; color: var(--text2); line-height: 1.5; }
  .search-show-more {
    padding: 12px 24px; text-align: center;
    border-top: 1px solid var(--border); background: var(--surface2);
  }
  .search-show-more button {
    background: none; border: none; color: var(--text3);
    font-size: 12px; cursor: pointer; text-decoration: underline; padding: 0;
  }
  .search-show-more button:hover { color: var(--text2); }

  /* ── PERPLEXITY FIRMS MENTIONED ── */
  .perp-mentioned {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: 8px; padding: 12px 14px; margin-top: 14px;
  }
  .perp-mentioned-title {
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--text3); margin-bottom: 8px;
  }
  .perp-firm-tags { display: flex; flex-wrap: wrap; gap: 6px; }
  .perp-firm-tag {
    background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.2);
    border-radius: 100px; padding: 3px 10px; font-size: 12px; color: var(--blue);
  }

  @media (max-width: 600px) {
    .gbp-checklist-grid { grid-template-columns: 1fr 1fr; }
    .pack-firm-item { padding: 10px 16px; }
    .search-result-item { padding: 10px 16px; }
  }
  @media (max-width: 400px) {
    .gbp-checklist-grid { grid-template-columns: 1fr; }
  }

  /* ── MINI BAR CHARTS (Competitive Table) ── */
  .mini-bar-cell {
    display: flex; align-items: center;
    gap: 7px; justify-content: flex-end;
  }
  .mini-bar-track {
    width: 44px; height: 5px;
    background: var(--border2);
    border-radius: 100px; overflow: hidden; flex-shrink: 0;
  }
  .mini-bar-fill {
    height: 100%; border-radius: 100px;
    transition: width 1.2s cubic-bezier(0.25, 1, 0.5, 1);
  }
  .mini-bar-fill.da-bar { background: var(--blue); }
  .mini-bar-fill.traffic-bar { background: var(--green); }
  .mini-bar-fill.you-da-bar { background: var(--gold); }
  .mini-bar-fill.you-traffic-bar { background: var(--gold); }

  /* ── AUTOFILLED FIELDS ── */
  .field input.autofilled {
    border-color: var(--green) !important;
    border-left-width: 3px !important;
    background: rgba(34,197,94,0.05) !important;
    padding-left: 11px !important;
    box-shadow: 0 0 0 1px rgba(34,197,94,0.1) !important;
  }
