* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: #fafbfc; color: #1a1f29; }
header { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; border-bottom: 1px solid #e4e8ee; background: #ffffff; flex-wrap: wrap; gap: 10px; }
header h1 { margin: 0; font-size: 17px; font-weight: 600; letter-spacing: 0.2px; color: #1a1f29; }
nav { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
nav .spacer { flex: 1; min-width: 12px; }
button { background: #ffffff; color: #2d3748; border: 1px solid #d6dbe2; border-radius: 6px; padding: 6px 11px; font-size: 12px; cursor: pointer; }
button:hover { background: #f3f5f8; border-color: #b9c0cb; }
button.active { background: #1d6b3a; border-color: #1d6b3a; color: #ffffff; }
button.active:hover { background: #17592f; border-color: #17592f; }
#status { padding: 10px 20px; font-size: 12px; color: #6b7280; min-height: 18px; }
#status.error { color: #c53030; }

.filters { display: flex; gap: 6px; flex-wrap: wrap; padding: 10px 20px 4px; align-items: center; }
.filters .divider { width: 1px; height: 22px; background: #e4e8ee; margin: 0 6px; }

#offers-counts { padding: 6px 20px; font-size: 11px; color: #6b7280; }

main { padding: 4px 20px 60px; }

/* Offers cards */
.offer-card { background: #ffffff; border: 1px solid #e4e8ee; border-radius: 10px; padding: 12px 14px; margin-bottom: 8px; display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: start; box-shadow: 0 1px 2px rgba(15, 17, 21, 0.04); }
.offer-card .logo { width: 44px; height: 44px; object-fit: contain; border-radius: 6px; background: #ffffff; border: 1px solid #eef0f3; }
.offer-card .logo-fallback { width: 44px; height: 44px; border-radius: 6px; background: #eef0f3; display: flex; align-items: center; justify-content: center; color: #6b7280; font-size: 16px; font-weight: 600; }
.offer-card .meta-col { min-width: 0; }
.offer-card .merchant { font-weight: 600; font-size: 14px; color: #1a1f29; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.offer-card .reward { color: #196b3a; font-size: 13px; margin-top: 2px; font-weight: 500; }
.offer-card .sub { color: #6b7280; font-size: 11px; margin-top: 4px; line-height: 1.5; }
.offer-card .right-col { text-align: right; min-width: 90px; }
.offer-card .days { font-size: 16px; font-weight: 600; color: #4b5563; }
.offer-card .days.urgent { color: #c2570d; }
.offer-card .days.dying { color: #c53030; }
.offer-card .days-label { font-size: 10px; color: #9aa3b2; text-transform: uppercase; letter-spacing: 0.4px; margin-top: 2px; }

.pill { font-size: 10px; padding: 2px 7px; border-radius: 99px; background: #eef0f3; color: #4b5563; text-transform: uppercase; letter-spacing: 0.4px; font-weight: 500; }
.pill.amex { background: #006fcf; color: #ffffff; }
.pill.chase { background: #117aca; color: #ffffff; }
.pill.enrolled { background: #1d6b3a; color: #ffffff; }
.pill.available { background: #eef0f3; color: #4b5563; }
.pill.card { background: #f3e8d6; color: #855900; }

/* Captures (raw) */
.row { background: #ffffff; border: 1px solid #e4e8ee; border-radius: 8px; margin-bottom: 6px; }
.row summary { padding: 8px 12px; cursor: pointer; display: flex; gap: 10px; align-items: center; font-size: 12px; }
.row summary::-webkit-details-marker { display: none; }
.badge { font-size: 10px; padding: 2px 7px; border-radius: 99px; background: #eef0f3; color: #4b5563; text-transform: uppercase; letter-spacing: 0.4px; font-weight: 500; }
.badge.amex { background: #006fcf; color: #ffffff; }
.badge.chase { background: #117aca; color: #ffffff; }
.method { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; color: #6b7280; min-width: 36px; }
.status-ok { color: #196b3a; font-weight: 500; }
.status-bad { color: #c53030; font-weight: 500; }
.url { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px; color: #2d3748; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
.time { font-size: 11px; color: #9aa3b2; white-space: nowrap; }
pre { margin: 0; padding: 12px; font-size: 11px; line-height: 1.45; background: #f7f9fc; color: #2d3748; overflow: auto; max-height: 540px; border-top: 1px solid #e4e8ee; white-space: pre-wrap; }

.empty { color: #6b7280; padding: 24px 4px; font-size: 13px; }
.token-prompt { display: flex; gap: 8px; align-items: center; padding: 8px 12px; background: #ffffff; border: 1px solid #e4e8ee; border-radius: 8px; margin: 6px 0; }
.token-prompt input { flex: 1; padding: 6px 10px; background: #fafbfc; color: #1a1f29; border: 1px solid #d6dbe2; border-radius: 6px; font-size: 12px; }
