* { box-sizing: border-box; }
body { font: 16px/1.5 system-ui, -apple-system, sans-serif; margin: 0; background: #f6f7f9; color: #1a1f24; }
header { background: #0f4c3a; color: #fff; padding: 24px; }
header h1 { margin: 0; }
.tagline { opacity: .8; margin: 4px 0 0; }
main { max-width: 780px; margin: 24px auto; padding: 0 16px; display: grid; gap: 24px; }
section { background: #fff; padding: 20px; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
section h2 { margin-top: 0; font-size: 18px; color: #0f4c3a; }
.drop-zone { display: block; border: 2px dashed #bcd; border-radius: 8px; padding: 32px; text-align: center; cursor: pointer; color: #567; }
.drop-zone.drag { border-color: #0f4c3a; background: #f0f7f4; }
button { background: #0f4c3a; color: #fff; border: 0; padding: 10px 18px; border-radius: 6px; font-weight: 600; cursor: pointer; font-size: 14px; }
button:hover { background: #0c3b2d; }
button:disabled { opacity: .6; cursor: not-allowed; }
pre { background: #0f1419; color: #d0d7de; padding: 16px; border-radius: 6px; overflow: auto; max-height: 360px; font-size: 12px; }
.dim { color: #6b7480; font-size: 13px; margin: 4px 0 10px; }
input[type="text"] { padding: 8px; border: 1px solid #cdd6db; border-radius: 4px; font-size: 14px; margin-right: 8px; }
code { background: #eef2f4; padding: 1px 6px; border-radius: 3px; font-size: 13px; }
#dev-section { background: #fffbe6; border: 1px dashed #e3c97d; }
.quote-card { border: 1px solid #dce4e9; border-radius: 8px; padding: 16px; background: #fbfdfc; }
.quote-header { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; }
.quote-header h3 { margin: 0; color: #0f4c3a; font-size: 20px; }
.quote-header p { margin: 2px 0 0; color: #6b7480; font-size: 14px; }
.mock-tag { color: #c9700c; font-style: normal; font-weight: 600; background: #fff4e1; padding: 1px 6px; border-radius: 3px; font-size: 11px; }
.coverage-table { width: 100%; border-collapse: collapse; margin-bottom: 12px; }
.coverage-table td { padding: 6px 8px; border-bottom: 1px solid #eef2f4; font-size: 14px; }
.coverage-table td:first-child { color: #6b7480; }
.coverage-table td:last-child { text-align: right; font-weight: 600; }
.bridge-link { display: inline-block; padding: 8px 14px; background: #0f4c3a; color: #fff; border-radius: 4px; text-decoration: none; font-weight: 600; font-size: 14px; }
.bridge-link:hover { background: #0c3b2d; }
.error { color: #c53030; padding: 12px; background: #fef2f2; border-radius: 6px; }
form { display: grid; gap: 10px; max-width: 360px; }
form label { display: grid; gap: 4px; font-size: 14px; color: #455560; }
form input, form select { padding: 8px; border: 1px solid #cdd6db; border-radius: 4px; font-size: 14px; }
form button { margin-top: 8px; justify-self: start; }

/* Umbrella comparison section — appears when driver does the two-pass scrape */
.umbrella-comparison { margin: 14px 0 16px; padding: 14px; background: #f0f7f3; border: 1px solid #c8ddd0; border-radius: 6px; }
.umbrella-comparison h4 { margin: 0 0 10px; color: #0f4c3a; font-size: 15px; }
.umbrella-comparison .summary-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 10px; }
.umbrella-comparison .summary-grid > div { display: flex; flex-direction: column; background: #fff; padding: 8px 10px; border-radius: 4px; border: 1px solid #e0ebe5; }
.umbrella-comparison .summary-grid .label { color: #6b7480; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.umbrella-comparison .summary-grid .value { font-size: 16px; font-weight: 600; color: #0f4c3a; }
.umbrella-comparison .summary-grid .value.strong { color: #0c3b2d; font-size: 18px; }
.umbrella-pitch { background: #fff9e0; border-left: 3px solid #f0c040; padding: 8px 12px; margin: 8px 0 12px; font-size: 13px; color: #514016; border-radius: 0 4px 4px 0; }
.tier-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.tier-table th { text-align: left; padding: 6px 8px; color: #6b7480; font-weight: 600; font-size: 11px; text-transform: uppercase; border-bottom: 1px solid #dce4e9; }
.tier-table th.num, .tier-table td.num { text-align: right; }
.tier-table td { padding: 5px 8px; border-bottom: 1px solid #eef2f4; }
.tier-table td.num { font-variant-numeric: tabular-nums; font-weight: 500; }
.tier-table td.discount { color: #0f7a5a; font-weight: 600; }

/* 4-state scenario comparison grid */
.scenario-4cell .scenario-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.scenario-4cell .grid-cell { display: flex; flex-direction: column; background: #fff; padding: 10px 12px; border-radius: 5px; border: 1px solid #dce4e9; }
.scenario-4cell .grid-cell.best { border: 2px solid #0f7a5a; background: #eaf6ef; position: relative; }
.scenario-4cell .grid-cell.best::after { content: "⭐ BEST"; position: absolute; top: 4px; right: 8px; font-size: 10px; color: #0f7a5a; font-weight: 700; letter-spacing: .04em; }
.scenario-4cell .grid-cell.disabled { opacity: 0.5; background: #f3f4f5; }
.scenario-4cell .cell-label { font-size: 11px; color: #6b7480; text-transform: uppercase; letter-spacing: .04em; }
.scenario-4cell .cell-value { font-size: 18px; font-weight: 700; color: #0c3b2d; margin-top: 2px; }
.scenario-4cell .cell-sub { font-size: 11px; color: #6b7480; margin-top: 2px; font-variant-numeric: tabular-nums; }
.umbrella-note { font-size: 12px; color: #567; margin: 4px 0 10px; font-style: italic; }
