/* ==========================================================
   Catfishnumr — Unified Design System
   Loaded last; overrides all other plugin styles.
   ========================================================== */

/* ── Tokens ─────────────────────────────────────────────── */
:root {
  --cf-bg:           #f8fafc;
  --cf-surface:      #ffffff;
  --cf-surface2:     #f0f4f8;
  --cf-border:       rgba(0,0,0,0.03);
  --cf-border-accent:#0e9488;
  --cf-text:         #0d1520;
  --cf-muted:        #8a9aaa;
  --cf-dim:          #5a6a7a;
  --cf-accent:       #0e9488;
  --cf-accent-light: rgba(14,148,136,0.10);
  --cf-green:        #16a34a;
  --cf-green-light:  rgba(22,163,74,0.10);
  --cf-red:          #dc2626;
  --cf-red-light:    rgba(220,38,38,0.08);
  --cf-yellow:       #d97706;
  --cf-yellow-light: rgba(217,119,6,0.10);
  --cf-blue:         #2563d4;
  --cf-shadow:       none;
  --cf-shadow-md:    none;
  --cf-radius:       12px;
  --cf-radius-sm:    8px;
  --cf-font:         'Space Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --cf-mono:         'JetBrains Mono', 'Courier New', monospace;
  --cf-gradient-neutral: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
  --cf-gradient-accent:  linear-gradient(135deg, #0e9488 0%, #0b7d73 100%);
  --cf-gradient-accent-deep: linear-gradient(135deg, #0b7d73 0%, #0a6f66 100%);
}

/* ── Base wrappers ──────────────────────────────────────── */
.catfishnumr-lookup-wrapper,
.catfishnumr-email-search-wrapper {
  font-family: var(--cf-font);
  color: var(--cf-text);
}

.is-hidden {
  display: none !important;
}

.is-clickable {
  cursor: pointer;
}

.cn-btn-full {
  width: 100%;
}

.catfish-credits-link {
  text-decoration: none;
  color: inherit;
  display: inline-block;
}

.catfish-coins-icon {
  margin-right: 4px;
}

/* ── Card ────────────────────────────────────────────────── */
.cn-card {
  background: var(--cf-surface);
  border: none;
  border-radius: var(--cf-radius);
  box-shadow: var(--cf-shadow);
  padding: 28px;
  font-family: var(--cf-font);
}

/* ── Tabs ────────────────────────────────────────────────── */
.catfishnumr-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--cf-border);
  padding-bottom: 0;
  flex-wrap: wrap;
}

.catfishnumr-tabs .tab-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  border: none;
  background: transparent;
  color: var(--cf-muted);
  font-family: var(--cf-font);
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--cf-radius-sm) var(--cf-radius-sm) 0 0;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
  position: relative;
  margin-bottom: -1px;
}

.catfishnumr-tabs .tab-button:hover {
  background: var(--cf-surface2);
  color: var(--cf-text);
}

.catfishnumr-tabs .tab-button.active {
  background: var(--cf-surface);
  color: var(--cf-accent);
  font-weight: 600;
  border: none;
}

/* ── Input group ─────────────────────────────────────────── */
.cn-input-group {
  display: flex;
  gap: 10px;
  align-items: stretch;
  flex-wrap: wrap;
}

.cn-input-group input[type="tel"],
.cn-input-group input[type="email"],
.cn-input-group input[type="text"],
.cn-input-group input[type="search"] {
  flex: 1;
  min-width: 0;
  padding: 11px 16px;
  border: none;
  border-radius: var(--cf-radius-sm);
  font-family: var(--cf-font);
  font-size: 15px;
  color: var(--cf-text);
  background: var(--cf-surface);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}

.cn-input-group input:focus {
  border-color: transparent;
  box-shadow: none;
}

/* ── Buttons ─────────────────────────────────────────────── */
.cn-input-group button,
.cn-input-group button[type="submit"],
#cn-btn,
.cn-btn,
.cn-post-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 11px 22px;
  background: var(--cf-accent);
  color: #fff;
  border: none;
  border-radius: var(--cf-radius-sm);
  font-family: var(--cf-font);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, box-shadow 0.15s, transform 0.15s;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.cn-input-group button:hover,
#cn-btn:hover,
.cn-btn:hover,
.cn-post-btn:hover {
  background: #0b7d73;
  box-shadow: none;
  transform: none;
}

.cn-input-group button:disabled,
#cn-btn:disabled,
.cn-btn:disabled {
  background: var(--cf-muted);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* ── Lookup form ─────────────────────────────────────────── */
.lookup-form {
  background: transparent;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
  margin-bottom: 0;
}

/* ── Search type selector ────────────────────────────────── */
.catfish-search-type-selector {
  margin-top: 14px;
}

.search-type-toggle {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.search-type-option {
  flex: 1;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-sm);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  background: var(--cf-surface2);
  position: relative;
}

.search-type-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.search-type-option:hover {
  border-color: var(--cf-accent);
  background: var(--cf-surface);
}

.search-type-option.search-type-active,
.search-type-option:has(input:checked) {
  border-color: var(--cf-accent);
  background: var(--cf-accent-light);
}

.stt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.search-type-label {
  font-family: var(--cf-font);
  font-size: 14px;
  font-weight: 600;
  color: var(--cf-text);
}

.search-type-cost {
  font-family: var(--cf-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--cf-accent);
  background: var(--cf-accent-light);
  border: 1px solid rgba(14,148,136,0.20);
  padding: 2px 8px;
  border-radius: 10px;
  letter-spacing: 0.04em;
}

.search-type-desc {
  font-family: var(--cf-font);
  font-size: 12px;
  color: var(--cf-dim);
  line-height: 1.5;
}

/* ── Message / alert ─────────────────────────────────────── */
#cn-msg,
.cn-post-msg,
.cn-message {
  font-family: var(--cf-font);
  font-size: 13.5px;
  padding: 10px 14px;
  border-radius: var(--cf-radius-sm);
  margin-top: 12px;
  border: 1px solid transparent;
}

.cn-message-error,
#cn-msg[style*="color: red"],
#cn-msg[style*="color:#dc"] {
  background: var(--cf-red-light);
  border-color: rgba(220,38,38,0.20);
  color: var(--cf-red);
}

.cn-message-success {
  background: var(--cf-green-light);
  border-color: rgba(22,163,74,0.20);
  color: #15803d;
}

.cn-message-info {
  background: var(--cf-accent-light);
  border-color: rgba(14,148,136,0.20);
  color: #0b7d73;
}

/* ── Credits display ─────────────────────────────────────── */
.catfishnumr-credits-display {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  border-radius: 40px;
  box-shadow: var(--cf-shadow);
  font-family: var(--cf-font);
}

.credits-label {
  font-size: 13px;
  color: var(--cf-dim);
  font-weight: 500;
}

.credits-count {
  font-family: var(--cf-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--cf-accent);
  line-height: 1;
}

.credits-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--cf-font);
  font-size: 13px;
  font-weight: 600;
  color: var(--cf-accent);
  background: var(--cf-accent-light);
  border: 1px solid rgba(14,148,136,0.20);
  padding: 4px 12px;
  border-radius: 20px;
}

.buy-credits-btn,
.catfish-btn--primary,
.catfish-use-coupon-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  background: var(--cf-accent);
  color: #fff;
  border: none;
  border-radius: var(--cf-radius-sm);
  font-family: var(--cf-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, box-shadow 0.15s;
  letter-spacing: 0.02em;
}

.buy-credits-btn:hover,
.catfish-btn--primary:hover,
.catfish-use-coupon-btn:hover {
  background: #0b7d73;
  color: #fff;
  box-shadow: 0 4px 12px rgba(14,148,136,0.25);
  text-decoration: none;
}

.catfish-btn--secondary,
.catfish-view-history-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  background: transparent;
  color: var(--cf-dim);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-sm);
  font-family: var(--cf-font);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.15s, color 0.15s;
}

.catfish-btn--secondary:hover,
.catfish-view-history-link:hover {
  border-color: var(--cf-accent);
  color: var(--cf-accent);
  text-decoration: none;
}

/* ── Coupon cards ────────────────────────────────────────── */
.catfish-coupon-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.catfish-coupon-card {
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius);
  box-shadow: var(--cf-shadow);
  overflow: hidden;
  transition: box-shadow 0.2s, transform 0.2s;
  font-family: var(--cf-font);
}

.catfish-coupon-card:hover {
  box-shadow: var(--cf-shadow-md);
  transform: translateY(-2px);
}

.catfish-coupon-card__header {
  padding: 14px 18px;
  background: var(--cf-surface2);
  border-bottom: 1px solid var(--cf-border);
}

.catfish-coupon-badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
}

.catfish-coupon-badge--available {
  background: var(--cf-green-light);
  color: var(--cf-green);
  border: 1px solid rgba(22,163,74,0.25);
}

.catfish-coupon-badge--used {
  background: rgba(138,154,170,0.12);
  color: var(--cf-muted);
  border: 1px solid var(--cf-border);
}

.catfish-coupon-badge--expired {
  background: var(--cf-red-light);
  color: var(--cf-red);
  border: 1px solid rgba(220,38,38,0.20);
}

.catfish-coupon-card__body {
  padding: 16px 18px;
}

.catfish-coupon-code-block {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--cf-surface2);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius-sm);
  padding: 10px 14px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: border-color 0.15s;
}

.catfish-coupon-code-block:hover {
  border-color: var(--cf-accent);
}

.catfish-coupon-code-value {
  font-family: var(--cf-mono);
  font-size: 13px;
  color: var(--cf-text);
  letter-spacing: 0.05em;
  background: none;
  padding: 0;
  flex: 1;
}

.catfish-coupon-meta {
  margin-bottom: 12px;
}

.catfish-coupon-meta__item {
  font-size: 13px;
  color: var(--cf-dim);
}

.catfish-coupon-meta__label {
  font-weight: 600;
  color: var(--cf-text);
  margin-right: 4px;
}

.catfish-coupon-meta__muted {
  color: var(--cf-muted);
}

.catfish-coupon-details {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.catfish-coupon-details__row {
  display: flex;
  gap: 8px;
  font-size: 12.5px;
}

.catfish-coupon-details__row dt {
  color: var(--cf-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 10px;
  min-width: 90px;
  padding-top: 2px;
}

.catfish-coupon-details__row dd {
  color: var(--cf-text);
  font-family: var(--cf-mono);
  font-size: 12px;
  margin: 0;
}

.catfish-coupon-card__footer {
  padding: 14px 18px;
  border-top: 1px solid var(--cf-border);
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.catfish-coupon-section-title {
  font-family: var(--cf-font);
  font-size: 16px;
  font-weight: 700;
  color: var(--cf-text);
  margin: 0 0 16px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.catfish-coupon-count {
  font-size: 12px;
  font-weight: 600;
  color: var(--cf-muted);
  background: var(--cf-surface2);
  border: 1px solid var(--cf-border);
  padding: 2px 8px;
  border-radius: 10px;
}

.catfish-coupon-cards-section {
  margin-bottom: 28px;
}

/* ── No results ──────────────────────────────────────────── */
.catfish-no-results,
.no-results {
  text-align: center;
  padding: 40px 24px;
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius);
  color: var(--cf-muted);
  font-family: var(--cf-font);
  font-size: 15px;
}

/* ── Redirect notes ──────────────────────────────────────── */
.email-redirect-note,
.phone-redirect-note {
  margin-top: 10px;
}

.email-redirect-note p,
.phone-redirect-note p {
  font-size: 12px;
  color: var(--cf-muted);
  margin: 0;
  text-align: center;
}

/* ── Coupon input form ───────────────────────────────────── */
.cn-coupon-input-form .cn-card h2 {
  font-family: var(--cf-font);
  font-size: 20px;
  font-weight: 700;
  color: var(--cf-text);
  margin: 0 0 8px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.cn-coupon-input-form .cn-card h2 i {
  color: var(--cf-accent);
}

.cn-coupon-input-form .cn-card p {
  font-size: 14px;
  color: var(--cf-dim);
  margin: 0 0 20px 0;
}

/* ── PDF button wrapper (injected by pdf-download.js) ────── */
.catfish-pdf-btn-wrapper {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}

.catfish-pdf-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  color: var(--cf-dim);
  border-radius: var(--cf-radius-sm);
  font-family: var(--cf-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.catfish-pdf-btn:hover {
  border-color: var(--cf-accent);
  color: var(--cf-accent);
  background: var(--cf-accent-light);
  box-shadow: none;
  transform: none;
}

/* ── Lookup stats cards (dashboard quick view) ───────────── */
.catfishnumr-lookup-stats-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.lookup-stats-card {
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius);
  box-shadow: var(--cf-shadow);
  overflow: hidden;
  font-family: var(--cf-font);
}

.lookup-stats-card .card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  background: var(--cf-surface2);
  border-bottom: 1px solid var(--cf-border);
}

.lookup-stats-card .card-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--cf-accent-light);
  border: 1px solid rgba(14,148,136,0.20);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cf-accent);
  font-size: 16px;
  flex-shrink: 0;
}

.lookup-stats-card .card-title h3 {
  margin: 0 0 2px 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--cf-text);
}

.lookup-stats-card .card-count {
  font-size: 12px;
  color: var(--cf-muted);
  margin: 0;
}

.lookup-stats-card .card-items {
  padding: 8px 0;
}

.lookup-stats-card .card-item {
  padding: 10px 18px;
  border-bottom: 1px solid var(--cf-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 0.15s;
}

.lookup-stats-card .card-item:last-child {
  border-bottom: none;
}

.lookup-stats-card .card-item:hover,
.lookup-stats-card .clickable-item:hover {
  background: var(--cf-surface2);
}

.lookup-stats-card .item-value {
  font-family: var(--cf-mono);
  font-size: 13px;
  color: var(--cf-text);
}

.lookup-stats-card .card-item-empty {
  padding: 20px 18px;
  text-align: center;
}

.lookup-stats-card .empty-message {
  font-size: 13px;
  color: var(--cf-muted);
}

.lookup-stats-card .card-footer {
  padding: 12px 18px;
  border-top: 1px solid var(--cf-border);
}

.show-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--cf-accent);
  text-decoration: none;
  transition: gap 0.15s;
}

.show-more-btn:hover {
  gap: 8px;
  text-decoration: none;
  color: var(--cf-accent);
}

/* ── Results animation container ─────────────────────────── */
#results-animation-container {
  background: var(--cf-surface);
  border: 1px solid var(--cf-border);
  border-radius: var(--cf-radius);
  padding: 40px 24px;
  text-align: center;
  font-family: var(--cf-font);
}

/* ── Post lookup card ─────────────────────────────────────── */
.cn-post-error-box {
  background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
  color: #991b1b;
  padding: 2rem;
  border-radius: 1rem;
  margin: 0;
  text-align: center;
  border: 1px solid #fecaca;
  font-size: 1.1rem;
  line-height: 1.6;
}

.cn-post-error-icon {
  font-size: 2rem;
  margin-bottom: 1rem;
  display: block;
}

.cn-post-header {
  text-align: center;
  margin-bottom: 20px;
}

.cn-post-title {
  color: var(--cf-text);
  margin: 0 0 10px 0;
  font-size: 1.4rem;
}

.cn-post-title-icon {
  color: var(--cf-blue);
  margin-right: 8px;
}

.cn-post-subtitle {
  margin-bottom: 15px;
  padding: 10px;
  background: var(--cf-surface2);
  border-radius: 6px;
  font-size: 14px;
  color: var(--cf-dim);
}

.catfish-results-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catfish-result-card {
  width: 160px;
  border: 1px solid #eee;
  border-radius: 8px;
  overflow: hidden;
  background: var(--cf-surface);
}

.catfish-result-card-img {
  width: 100%;
  height: 120px;
  object-fit: cover;
}

.catfish-result-info {
  padding: 8px;
}

.catfish-result-confidence {
  font-size: 12px;
  color: var(--cf-dim);
}

.catfish-result-link {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: #0a58ca;
  word-break: break-all;
}

/* ── Legacy harmonization layer ───────────────────────────── */
.cn-email-link {
  color: var(--cf-green, #16a34a) !important;
  border: 1px solid rgba(22,163,74,0.2) !important;
  background: var(--cf-green-light, rgba(22,163,74,0.1)) !important;
}

.cn-email-link:hover {
  background: var(--cf-green, #16a34a) !important;
  border-color: var(--cf-green, #16a34a) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(22,163,74,0.3) !important;
}

.catfish-credits-badge {
  background: linear-gradient(135deg, var(--cf-yellow, #d97706) 0%, #b45309 100%);
  box-shadow: 0 4px 16px rgba(217,119,6,0.28);
}

.lookup-results {
  background: var(--cf-surface, #fff);
  box-shadow: var(--cf-shadow-md, 0 4px 16px rgba(0,0,0,0.1));
}

.lookup-results h3 {
  color: var(--cf-text, #0d1520);
}

.result-item {
  border-bottom: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.result-item strong {
  color: var(--cf-dim, #5a6a7a);
}

.lookup-error {
  background: var(--cf-red-light, rgba(220,38,38,0.08));
  border: 1px solid rgba(220,38,38,0.2);
}

.lookup-error h3 {
  color: var(--cf-red, #dc2626);
}

.lookup-error p {
  color: #991b1b;
}

.lookup-error .button {
  background: linear-gradient(135deg, var(--cf-accent, #0e9488) 0%, #0b7d73 100%);
}

.lookup-error .button:hover {
  background: linear-gradient(135deg, #0b7d73 0%, #0a6f66 100%);
}

.osint-features-preview {
  background: linear-gradient(135deg, var(--cf-bg, #f8fafc) 0%, var(--cf-surface2, #f0f4f8) 100%);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.osint-features-preview h4 {
  color: var(--cf-text, #0d1520);
}

.feature-item {
  background: var(--cf-surface, #fff);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  box-shadow: var(--cf-shadow, 0 1px 4px rgba(0,0,0,0.06));
}

.feature-item:hover {
  box-shadow: var(--cf-shadow-md, 0 4px 16px rgba(0,0,0,0.1));
}

.feature-item i {
  color: var(--cf-accent, #0e9488);
}

.feature-item span {
  color: var(--cf-dim, #5a6a7a);
}

#phone {
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  background: var(--cf-surface, #fff);
}

#phone:focus {
  border-color: var(--cf-accent, #0e9488);
  box-shadow: 0 0 0 2px var(--cf-accent-light, rgba(14,148,136,0.12));
}

#cn-btn,
.cn-input-group button[type="submit"] {
  background: linear-gradient(135deg, var(--cf-accent, #0e9488) 0%, #0b7d73 100%);
  box-shadow: 0 4px 16px rgba(14,148,136,0.3);
}

#cn-btn:hover,
.cn-input-group button[type="submit"]:hover {
  opacity: 0.9;
}

.cn-face-select-dialog {
  background: var(--cf-surface, #fff);
  box-shadow: var(--cf-shadow-md, 0 8px 24px rgba(0,0,0,0.16));
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.cn-face-select-close {
  background: var(--cf-surface2, #f0f4f8);
  color: var(--cf-dim, #5a6a7a);
}

.cn-face-select-close:hover {
  background: color-mix(in srgb, var(--cf-surface2, #f0f4f8) 85%, black 8%);
  color: var(--cf-text, #0d1520);
}

.cn-face-select-title {
  color: var(--cf-text, #0d1520);
}

.cn-face-select-sub {
  color: var(--cf-muted, #8a9aaa);
}

.cn-face-select-card {
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  background: var(--cf-bg, #f8fafc);
}

.cn-face-select-card:hover {
  border-color: var(--cf-accent, #0e9488);
  box-shadow: 0 4px 14px rgba(14,148,136,0.18);
}

.cn-face-select-card-meta {
  color: var(--cf-dim, #5a6a7a);
}

.cn-face-select-cancel {
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  background: var(--cf-surface, #fff);
  color: var(--cf-dim, #5a6a7a);
}

.cn-face-select-cancel:hover {
  background: var(--cf-surface2, #f0f4f8);
}

.cn-loading-container {
  background: linear-gradient(135deg, color-mix(in srgb, var(--cf-surface, #fff) 88%, transparent) 0%, color-mix(in srgb, var(--cf-surface2, #f0f4f8) 82%, transparent) 100%);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.cn-wrap .cn-map-section,
.cn-map-section {
  background: color-mix(in srgb, var(--cf-surface2, #f0f4f8) 88%, transparent);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.cn-pill {
  background: color-mix(in srgb, var(--cf-surface, #fff) 90%, transparent);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
}

.cn-pill b {
  color: var(--cf-text, #0d1520);
}

.cn-pill span {
  color: var(--cf-dim, #5a6a7a);
}

.cn-phase-dot {
  background: var(--cf-accent, #0e9488);
}

.cn-phase-text .big {
  color: var(--cf-text, #0d1520);
}

.cn-phase-text .small {
  color: var(--cf-muted, #8a9aaa);
}

.upgrade-section {
  background: var(--cf-surface, #fff);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  border-radius: var(--cf-radius, 12px);
  box-shadow: var(--cf-shadow, 0 1px 4px rgba(0,0,0,0.06));
}

.package-option {
  background: var(--cf-surface, #fff);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  border-radius: var(--cf-radius-sm, 8px);
}

.package-option:hover {
  border-color: var(--cf-accent, #0e9488);
  box-shadow: var(--cf-shadow-md, 0 4px 16px rgba(0,0,0,0.1));
}

.package-option.premium-highlight {
  border-color: rgba(14,148,136,0.35);
  background: color-mix(in srgb, var(--cf-accent-light, rgba(14,148,136,0.1)) 45%, var(--cf-surface, #fff));
}

.package-option h4 {
  color: var(--cf-text, #0d1520);
}

.package-button {
  background: linear-gradient(135deg, var(--cf-accent, #0e9488) 0%, #0b7d73 100%);
  color: #fff;
  border: 1px solid transparent;
}

.package-button:hover {
  background: linear-gradient(135deg, #0b7d73 0%, #0a6f66 100%);
  color: #fff;
}

.cn-proof {
  background: var(--cf-surface2, #f0f4f8);
  border: 1px solid var(--cf-border, rgba(0,0,0,0.08));
  color: var(--cf-dim, #5a6a7a);
}

.cn-plan-sub {
  color: var(--cf-muted, #8a9aaa);
}

.cn-sticky-cta {
  background: linear-gradient(135deg, var(--cf-accent, #0e9488) 0%, #0b7d73 100%);
  border: 1px solid rgba(255,255,255,0.18);
}

.cn-sticky-cta .left {
  color: rgba(255,255,255,0.92);
}

.cn-sticky-cta a {
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.24);
  color: #fff;
}

.cn-sticky-cta a:hover {
  background: rgba(255,255,255,0.2);
  color: #fff;
}

.catfishnumr-dashboard-wrapper,
.catfishnumr-history-wrapper {
  color: var(--cf-text, #0d1520);
  font-family: var(--cf-font);
}

/* ── Flat UI preference ───────────────────────────────────── */
.lookup-results,
.catfishnumr-history-email-form,
.catfishnumr-history-items,
.upgrade-section,
.package-option,
.feature-item,
.catfish-coupon-card,
.lookup-stats-card {
  border: none !important;
  box-shadow: none !important;
}

.cn-input-group,
.tab-button,
.history-type-btn,
.history-dashboard-btn,
.history-back-btn,
.cn-face-select-dialog,
.cn-face-select-card {
  box-shadow: none !important;
}

.cn-input-group:focus-within,
#phone:focus,
.history-email-input-group input[type="email"]:focus {
  box-shadow: none !important;
  border-color: transparent !important;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 600px) {
  .cn-card {
    padding: 20px 16px;
  }

  .catfishnumr-tabs .tab-button {
    padding: 8px 12px;
    font-size: 13px;
  }

  .cn-input-group {
    flex-direction: column;
  }

  .cn-input-group button,
  #cn-btn {
    width: 100%;
    justify-content: center;
  }

  .search-type-toggle {
    flex-direction: column;
  }

  .search-type-option {
    min-width: 0;
  }

  .catfish-coupon-cards-grid {
    grid-template-columns: 1fr;
  }

  .catfishnumr-lookup-stats-cards {
    grid-template-columns: 1fr;
  }
}

/* ── Shared primary CTA (dashboard + history) ─────────────── */
.find-coupon-btn,
.history-dashboard-btn {
  background: var(--cf-accent);
  color: #fff;
  border-color: var(--cf-accent);
}

.find-coupon-btn:hover,
.history-dashboard-btn:hover {
  background: #0b7d73;
  border-color: #0b7d73;
  color: #fff;
  box-shadow: 0 4px 12px rgba(14, 148, 136, 0.25);
  text-decoration: none;
}

.find-coupon-btn:hover {
  transform: translateY(-1px);
}

.history-dashboard-btn:hover {
  transform: translateY(-2px);
}

.cn-btn-primary {
  background: var(--cf-accent);
  color: #fff;
  border: 1px solid var(--cf-accent);
  border-radius: var(--cf-radius-sm);
  transition: all 0.15s ease;
}

.cn-btn-primary:hover {
  background: #0b7d73;
  border-color: #0b7d73;
  color: #fff;
  box-shadow: 0 4px 12px rgba(14, 148, 136, 0.25);
  transform: translateY(-1px);
  text-decoration: none;
}
