/* ───────── Tokens (ported from demandnow-redesign) ───────── */
:root {
	--navy-950: #050E16;
	--navy-900: #08141D;
	--navy-800: #102434;
	--navy-700: #1A3A52;
	--navy-400: #5A7890;

	--green-700: #07744A;
	--green-600: #0A8F5E;
	--green-500: #11BC7A;
	--green-400: #2AE49C;
	--green-100: #E0F4EA;
	--green-50:  #F1FBF6;

	--ink-900: #0A1720;
	--ink-700: #2B3A45;
	--ink-500: #55636D;
	--ink-400: #7B8894;
	--ink-300: #B5BEC6;
	--ink-200: #D2CDC1;
	--ink-100: #E8E1D2;
	--ink-50:  #F3EBDB;
	--paper:   #F7F1E4;
	--paper-2: #EDE3D0;

	--white:   #FFFFFF;
	--red:     #D8453A;
	--amber:   #C77400;

	--font-display: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-sans:    "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-mono:    "Geist Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

	--shadow-sm: 0 1px 2px rgba(10,23,32,.06), 0 2px 6px rgba(10,23,32,.04);
	--shadow:    0 10px 28px -10px rgba(10,23,32,.14), 0 2px 6px rgba(10,23,32,.06);
	--shadow-lg: 0 30px 70px -20px rgba(10,23,32,.28), 0 8px 18px -8px rgba(10,23,32,.10);

	--container: 1080px;
	--ease: cubic-bezier(.2,.7,.2,1);

	color-scheme: light;
}

/* ───────── Reset ───────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--font-sans);
	color: var(--ink-900);
	background: var(--paper);
	line-height: 1.55;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--green-700); text-decoration: none; }
a:hover { color: var(--green-600); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
h1, h2, h3, h4 {
	margin: 0;
	font-family: var(--font-display);
	font-weight: 500;
	line-height: 1.08;
	letter-spacing: -0.025em;
	color: var(--ink-900);
}
p { margin: 0; }
em { font-style: normal; color: var(--green-600); font-weight: 500; }
.tabular, .audit-id, .audit-rate, .audit-cost, .hl-num,
.hl-status, .gauge-num, .head-to-head strong {
	font-variant-numeric: tabular-nums lining-nums;
}

:focus-visible {
	outline: 2px solid var(--green-500);
	outline-offset: 2px;
	border-radius: 4px;
}

.skip-link {
	position: absolute; top: -60px; left: 16px;
	background: var(--green-500); color: var(--navy-900);
	padding: 10px 16px; border-radius: 4px; font-weight: 600;
	z-index: 999;
}
.skip-link:focus { top: 16px; }

.muted { color: var(--ink-500); }
.error { color: var(--red); }
.err   { color: var(--red); }
[hidden] { display: none !important; }

.container {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 24px;
	width: 100%;
}

/* ───────── Site header ───────── */
.site-header {
	background: var(--navy-950);
	color: var(--paper);
	border-bottom: 1px solid rgba(255,255,255,.06);
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: blur(20px) saturate(1.2);
}
.site-header .nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding-top: 14px;
	padding-bottom: 14px;
}
.logo {
	display: inline-flex; align-items: baseline; gap: 8px;
	color: var(--paper);
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 18px;
	letter-spacing: -0.03em;
}
.logo:hover { color: var(--paper); text-decoration: none; }
.logo .amp { color: var(--green-400); font-weight: 500; }
.logo sup {
	font-family: var(--font-mono);
	font-size: 9px; font-weight: 500;
	letter-spacing: .18em;
	color: rgba(255,255,255,.5);
	text-transform: uppercase;
	vertical-align: top;
	margin-left: 4px;
	transform: translateY(2px);
	display: inline-block;
}
.site-nav {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-wrap: wrap;
}
.site-nav a, .site-nav form {
	margin: 0;
}
.site-nav a {
	padding: 8px 14px;
	border-radius: 4px;
	font-family: var(--font-sans);
	font-size: 13px;
	font-weight: 500;
	color: rgba(255,255,255,.78);
	transition: color .15s, background .15s;
}
.site-nav a:hover {
	color: var(--paper);
	background: rgba(255,255,255,.06);
	text-decoration: none;
}
.site-nav .nav-cta {
	margin-left: 6px;
}
.site-nav form button {
	background: transparent;
	border: 1px solid rgba(255,255,255,.18);
	color: rgba(255,255,255,.78);
	padding: 7px 14px;
	font-size: 13px;
	font-weight: 500;
	border-radius: 4px;
	font-family: var(--font-sans);
	cursor: pointer;
	transition: color .15s, background .15s, border-color .15s;
}
.site-nav form button:hover {
	color: var(--paper);
	background: rgba(255,255,255,.08);
	border-color: rgba(255,255,255,.32);
}

/* ───────── Main + footer ───────── */
main.main {
	flex: 1 0 auto;
	padding: 56px 24px 80px;
	max-width: var(--container);
	margin: 0 auto;
	width: 100%;
}

.site-footer {
	margin-top: auto;
	border-top: 1px solid var(--paper-2);
	background: var(--ink-50);
	color: var(--ink-500);
	font-size: 13px;
}
.footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	padding-top: 22px;
	padding-bottom: 22px;
	flex-wrap: wrap;
}
.site-footer a { color: var(--ink-700); }
.site-footer a:hover { color: var(--green-600); }
.footer-legal { display: flex; gap: 20px; }

/* ───────── Page-level header ───────── */
main > header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 1rem;
	margin-bottom: 1.75rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--paper-2);
	flex-wrap: wrap;
}
main > header > h1 {
	font-size: clamp(28px, 3.4vw, 38px);
	letter-spacing: -0.03em;
}
main > header > p,
main > header > form { margin: 0; }
main > header > p > a,
main > header a {
	color: var(--ink-500);
	font-size: 14px;
	font-weight: 500;
}
main > header a:hover { color: var(--ink-900); text-decoration: none; }

/* Eyebrow / dateline (editorial) */
.eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--font-mono);
	font-size: 11px; font-weight: 500;
	letter-spacing: .22em; text-transform: uppercase;
	color: var(--green-700);
	margin-bottom: 14px;
}
.eyebrow::before {
	content: ""; width: 22px; height: 1px;
	background: currentColor; opacity: .6;
}

/* ───────── Forms ───────── */
input, select, textarea {
	font: inherit;
	font-family: var(--font-sans);
	padding: 12px 14px;
	border-radius: 4px;
	border: 1px solid var(--ink-200);
	background: var(--white);
	color: var(--ink-900);
	transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus {
	outline: none;
	border-color: var(--green-500);
	box-shadow: 0 0 0 3px rgba(17,188,122,.15);
}
input::placeholder { color: var(--ink-400); }
input[name="url"] { width: 100%; }
input[type="number"] { width: 7rem; }

.field {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	margin: 0 0 1.1rem;
}
.field label {
	font-size: 13px;
	font-weight: 500;
	color: var(--ink-700);
	letter-spacing: -0.005em;
}
.field small { font-size: 12px; color: var(--ink-500); }

.actions {
	margin: 1.5rem 0 0;
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}
.actions a {
	color: var(--ink-500);
	font-size: 14px;
	font-weight: 500;
}
.actions a:hover { color: var(--green-600); text-decoration: none; }

form.filters {
	display: flex;
	gap: 1rem;
	align-items: center;
	margin: 1rem 0 1.5rem;
	font-size: 14px;
	color: var(--ink-500);
}
form.filters select { font: inherit; padding: 6px 10px; font-size: 14px; }

/* ───────── Buttons ───────── */
button {
	font: inherit;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 14px;
	padding: 10px 18px;
	border-radius: 4px;
	border: 1px solid var(--ink-200);
	background: var(--white);
	color: var(--ink-900);
	cursor: pointer;
	transition: transform .15s var(--ease), box-shadow .15s var(--ease),
	            background .15s, border-color .15s, color .15s;
	letter-spacing: 0;
}
button:hover {
	background: var(--paper-2);
	border-color: var(--ink-300);
}
button:active { transform: translateY(0.5px); }

button[type="submit"] {
	background: var(--navy-950);
	color: var(--paper);
	border-color: var(--navy-950);
	padding: 12px 22px;
	font-weight: 600;
	box-shadow: 0 6px 16px -6px rgba(5,14,22,.4);
}
button[type="submit"]:hover {
	background: var(--green-600);
	border-color: var(--green-600);
	color: var(--paper);
	box-shadow: 0 14px 34px -8px rgba(10,143,94,.45);
	transform: translateY(-1px);
}

.cancel-form { margin: 1.25rem 0; }
.cancel-form button[type="submit"] {
	background: transparent;
	color: var(--red);
	border-color: rgba(216,69,58,.4);
	box-shadow: none;
	padding: 8px 16px;
	font-weight: 500;
}
.cancel-form button[type="submit"]:hover {
	background: var(--red);
	color: var(--white);
	border-color: var(--red);
	box-shadow: 0 8px 20px -8px rgba(216,69,58,.5);
}

/* ───────── Status pills ───────── */
.status-pill {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-family: var(--font-mono);
	font-weight: 500;
	letter-spacing: .12em;
	text-transform: uppercase;
	border: 1px solid var(--ink-200);
	background: var(--paper-2);
	color: var(--ink-700);
	line-height: 1.5;
}
.status-pending   { background: var(--ink-100); color: var(--ink-700); border-color: var(--ink-200); }
.status-running   { background: rgba(199,116,0,.12); color: var(--amber); border-color: rgba(199,116,0,.35); }
.status-completed { background: var(--green-100); color: var(--green-700); border-color: rgba(17,188,122,.35); }
.status-failed    { background: rgba(216,69,58,.12); color: var(--red); border-color: rgba(216,69,58,.35); }

/* ───────── Spend line ───────── */
.spend-line {
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .04em;
	margin: -0.5rem 0 1.75rem;
	color: var(--ink-500);
}

/* ───────── Audits list ───────── */
ul.audits {
	list-style: none;
	padding: 0;
	margin: 0.75rem 0 1.5rem;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(5rem, auto) minmax(6rem, auto) minmax(3rem, auto);
	border-top: 1px solid var(--paper-2);
}
ul.audits a { color: inherit; text-decoration: none; }
ul.audits a:hover .audit-url { color: var(--green-700); text-decoration: underline; text-underline-offset: 3px; }

li.audit-row {
	display: contents;
}
li.audit-row > * {
	padding: 0.7rem 0.6rem;
	border-bottom: 1px solid var(--paper-2);
	align-self: center;
}
li.audit-row > *:first-child { padding-left: 0; }
li.audit-row > *:last-child  { padding-right: 0; }
.audit-link { display: flex; gap: 0.6rem; min-width: 0; align-items: baseline; }
.audit-id { color: var(--ink-400); font-variant-numeric: tabular-nums; min-width: 1.75rem; font-family: var(--font-mono); font-size: 13px; }
.audit-url { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
.audit-status { white-space: nowrap; }
.audit-brand, .audit-rate, .audit-cost {
	font-size: 13px;
	text-align: right;
	color: var(--ink-500);
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

ul.audits + p > a,
h2 + ul.audits + p a {
	color: var(--ink-500);
	font-size: 14px;
}

nav.pager {
	display: flex;
	gap: 1.25rem;
	align-items: center;
	margin-top: 1.5rem;
	font-size: 14px;
}
nav.pager a { color: var(--green-700); font-weight: 500; }
nav.pager .muted { color: var(--ink-400); }

/* ───────── Audit detail page ───────── */
p.audit-summary {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1.5rem;
	flex-wrap: wrap;
}
p.audit-summary a { word-break: break-all; color: var(--ink-900); font-weight: 500; }
p.audit-summary a:hover { color: var(--green-700); }

/* Section base */
section.extraction,
section.psi,
section.highlights,
section.summary,
section.rankings {
	margin-top: 2.5rem;
	padding-top: 1.75rem;
	border-top: 1px solid var(--paper-2);
}
section.extraction h2,
section.psi h2,
section.highlights h2,
section.summary h2,
section.rankings h2 {
	font-size: 22px;
	letter-spacing: -0.025em;
	margin-bottom: 0.85rem;
}

/* Extraction */
.extraction dl {
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: 0.55rem 1.25rem;
	margin: 0;
	font-size: 14px;
}
.extraction dt { color: var(--ink-500); font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; align-self: center; }
.extraction dd { margin: 0; color: var(--ink-900); font-weight: 500; }
ul.keywords {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
ul.keywords li {
	padding: 4px 12px;
	border: 1px solid var(--paper-2);
	border-radius: 999px;
	font-size: 13px;
	background: var(--ink-50);
	color: var(--ink-700);
}
.extraction .cost { margin-top: 0.85rem; font-size: 13px; }

/* ───────── Live-log panel (hero-panel inspired) ───────── */
.live-log-wrap {
	margin: 1.5rem 0 1rem;
	background: var(--navy-950);
	border-radius: 6px;
	overflow: hidden;
	box-shadow: var(--shadow-lg);
	border: 1px solid rgba(255,255,255,.04);
	color: var(--paper);
}
.live-log-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 18px;
	font-family: var(--font-mono);
	font-size: 10px;
	color: rgba(255,255,255,.55);
	letter-spacing: .22em;
	text-transform: uppercase;
	border-bottom: 1px solid rgba(255,255,255,.08);
	background: rgba(255,255,255,.02);
}
.live-log-tag {
	display: inline-flex; align-items: center; gap: 8px;
	color: var(--green-400);
	font-weight: 500;
}
.live-log-tag::before {
	content: ""; width: 6px; height: 6px; border-radius: 50%;
	background: var(--green-400);
	box-shadow: 0 0 0 4px rgba(42,228,156,.22);
	animation: log-pulse 1.6s var(--ease) infinite;
}
.live-log-static .live-log-tag::before { animation: none; box-shadow: none; }
@keyframes log-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(42,228,156,.5); }
	50%      { box-shadow: 0 0 0 8px rgba(42,228,156,0); }
}

ul#log {
	list-style: none;
	padding: 16px 18px;
	margin: 0;
	font-family: var(--font-mono);
	font-size: 12.5px;
	max-height: 360px;
	overflow-y: auto;
	color: rgba(255,255,255,.78);
	line-height: 1.7;
}
ul#log:empty::before {
	content: "Waiting for the worker to pick up your audit…";
	color: rgba(255,255,255,.35);
	font-style: italic;
}
.log-line { padding: 0; }
.log-line .ts {
	color: rgba(255,255,255,.35);
	margin-right: 0.65rem;
	font-size: 11px;
}
.log-line .level {
	display: inline-block;
	min-width: 4.5rem;
	margin-right: 0.65rem;
	color: rgba(255,255,255,.45);
	text-transform: uppercase;
	font-size: 10px;
	letter-spacing: .12em;
}
.log-stage .level { color: var(--green-400); }
.log-error .level { color: #ff8b80; }
.log-error           { color: #ffb1a8; }

/* ───────── PSI gauges ───────── */
.psi-gauges {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	gap: 1.25rem;
	margin: 1rem 0 0;
}
.gauge {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	flex: 0 0 auto;
}
.gauge-svg { width: 84px; height: 84px; }
.gauge-bg { stroke: currentColor; opacity: 0.15; }
.gauge-fg { stroke: currentColor; }
.gauge-num { font-size: 11px; font-weight: 600; fill: currentColor; }
.gauge-label { font-size: 13px; color: var(--ink-500); font-family: var(--font-mono); letter-spacing: .04em; text-transform: uppercase; font-size: 11px; }
.gauge-good { color: var(--green-600); }
.gauge-ok   { color: var(--amber); }
.gauge-poor { color: var(--red); }
.gauge-na   { color: var(--ink-400); }

/* ───────── Highlights ───────── */
.hl-bad { color: var(--red); font-weight: 600; }
.hl-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 0.6rem;
	margin: 1rem 0;
}
.hl-stat {
	border: 1px solid var(--paper-2);
	border-radius: 4px;
	padding: 0.7rem 0.85rem;
	text-align: center;
	background: var(--white);
}
.hl-stat.hl-bad  { border-color: rgba(216,69,58,.4); background: rgba(216,69,58,.06); color: var(--red); }
.hl-stat.hl-ok   { opacity: 0.7; }
.hl-num { font-size: 1.6rem; font-weight: 600; font-variant-numeric: tabular-nums; font-family: var(--font-display); letter-spacing: -0.02em; }
.hl-label { font-size: 11px; color: var(--ink-500); margin-top: 4px; font-family: var(--font-mono); letter-spacing: .04em; text-transform: uppercase; }
.hl-stat.hl-bad .hl-label { color: rgba(216,69,58,.85); }
.hl-schema { margin: 0.5rem 0 0.75rem; font-size: 14px; }
.hl-tag {
	display: inline-block;
	padding: 2px 10px;
	border: 1px solid var(--paper-2);
	border-radius: 999px;
	font-size: 12px;
	background: var(--ink-50);
	color: var(--ink-700);
}
.hl-details { margin-top: 1rem; font-size: 14px; }
.hl-details summary { cursor: pointer; color: var(--ink-500); padding: 4px 0; }
.hl-details summary:hover { color: var(--ink-900); }
.hl-table { border-collapse: collapse; width: 100%; margin-top: 0.75rem; background: var(--white); border-radius: 4px; overflow: hidden; }
.hl-table th, .hl-table td { padding: 0.45rem 0.6rem; border-bottom: 1px solid var(--paper-2); text-align: left; vertical-align: top; font-size: 13px; }
.hl-table th { font-size: 10px; text-transform: uppercase; color: var(--ink-500); font-family: var(--font-mono); letter-spacing: .12em; background: var(--ink-50); }
.hl-url { max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hl-url a { color: var(--ink-900); }
.hl-url a:hover { color: var(--green-700); }
.hl-title { max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hl-schematypes { font-family: var(--font-mono); font-size: 11px; color: var(--ink-500); }
.hl-status { font-variant-numeric: tabular-nums; padding: 1px 6px; border-radius: 3px; font-size: 11px; font-family: var(--font-mono); font-weight: 500; }
.hl-status-2xx { color: var(--green-700); background: var(--green-100); }
.hl-status-3xx { color: var(--amber);     background: rgba(199,116,0,.12); }
.hl-status-4xx { color: var(--red);       background: rgba(216,69,58,.12); }
.hl-status-5xx { color: var(--red);       background: rgba(216,69,58,.12); }
.hl-status-err { color: var(--red);       background: rgba(216,69,58,.12); }
.hl-flag { display: inline-block; margin-left: 0.5rem; padding: 1px 6px; font-size: 10px; border: 1px solid rgba(216,69,58,.4); color: var(--red); border-radius: 3px; font-family: var(--font-mono); letter-spacing: .04em; text-transform: uppercase; }

/* ───────── Summary (engine cards) ───────── */
.summary-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 0.85rem;
}
.engine-card {
	border: 1px solid var(--paper-2);
	border-radius: 6px;
	padding: 1rem 1.15rem;
	background: var(--white);
	box-shadow: var(--shadow-sm);
}
.engine-card h3 {
	margin: 0 0 0.6rem;
	font-size: 11px;
	font-family: var(--font-mono);
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--ink-500);
}
.engine-card dl {
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: 0.35rem 0.85rem;
	margin: 0;
	font-size: 14px;
}
.engine-card dt { color: var(--ink-500); }
.engine-card dd { margin: 0; }
.engine-card dd strong { font-weight: 600; font-family: var(--font-display); font-size: 16px; letter-spacing: -0.02em; }
.engine-card dd.err { color: var(--red); }
.head-to-head {
	margin-top: 0.85rem;
	font-size: 13px;
	color: var(--ink-500);
}
.head-to-head strong { color: var(--ink-900); font-weight: 600; }

/* ───────── Rankings table ───────── */
table.ranks {
	border-collapse: collapse;
	width: 100%;
	margin-top: 0.75rem;
	background: var(--white);
	border: 1px solid var(--paper-2);
	border-radius: 6px;
	overflow: hidden;
}
table.ranks th, table.ranks td {
	padding: 0.55rem 0.7rem;
	border-bottom: 1px solid var(--paper-2);
	text-align: left;
}
table.ranks tr:last-child td { border-bottom: none; }
table.ranks th {
	font-size: 10px;
	text-transform: uppercase;
	color: var(--ink-500);
	font-family: var(--font-mono);
	letter-spacing: .12em;
	font-weight: 500;
	background: var(--ink-50);
}
table.ranks td.kw { font-weight: 500; }
table.ranks td.cell.hit  { color: var(--green-700); font-weight: 500; }
table.ranks td.cell.err  { color: var(--red); }
table.ranks td.cell.miss { color: var(--ink-400); }
table.ranks td.toggle { width: 1.5rem; padding-right: 0; }

.expand-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 0.95rem;
	color: var(--ink-400);
	transition: transform 0.15s, color .15s;
}
.expand-btn:hover { color: var(--ink-900); background: none; }
.expand-btn[aria-expanded="true"] { transform: rotate(90deg); color: var(--green-700); }

tr.rank-detail td {
	background: var(--ink-50);
	padding: 0.85rem 1rem 1rem 1.5rem;
}
tr.rank-detail dl.detail {
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: 0.5rem 1.25rem;
	margin: 0;
	font-size: 13px;
}
tr.rank-detail dt { color: var(--ink-500); font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
tr.rank-detail dd { margin: 0; }
tr.rank-detail .top10 { font-family: var(--font-mono); font-size: 12px; color: var(--ink-700); }
tr.rank-detail .context { margin: 0.4rem 0 0; font-size: 13px; color: var(--ink-500); }
tr.rank-detail .err { color: var(--red); }

/* ───────── Tokens page ───────── */
table.tokens { font-size: 13px; margin-top: 1rem; }
table.tokens td { vertical-align: top; }
table.tokens th:nth-child(2),
table.tokens td:nth-child(2) { white-space: nowrap; }
table.tokens th:nth-child(3),
table.tokens td:nth-child(3),
table.tokens th:nth-child(4),
table.tokens td:nth-child(4) { white-space: nowrap; width: 1%; }
code.token-url {
	font-family: var(--font-mono);
	font-size: 12px;
	word-break: break-all;
	background: var(--ink-50);
	padding: 3px 6px;
	border-radius: 3px;
	color: var(--ink-700);
}

/* ───────── Login ───────── */
body.login main.main {
	max-width: 380px;
	padding-top: 80px;
}
.login-card {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	background: var(--white);
	border: 1px solid var(--paper-2);
	border-radius: 6px;
	padding: 32px 28px 28px;
	box-shadow: var(--shadow);
}
.login-card h1 {
	text-align: center;
	margin-bottom: 1rem;
	font-size: 24px;
}
.login-card .actions { display: flex; }
.login-card .actions button { width: 100%; }

/* ───────── Public lead page (start.html) ───────── */
body.public-start main.main { max-width: 720px; }
body.public-start main > header { border-bottom: none; padding-bottom: 0.5rem; margin-bottom: 0.75rem; }
body.public-start main > header > h1 {
	font-size: clamp(34px, 4.6vw, 48px);
	letter-spacing: -0.035em;
	max-width: 18ch;
}
.public-card {
	background: var(--white);
	border: 1px solid var(--paper-2);
	border-radius: 8px;
	padding: 32px 32px 28px;
	box-shadow: var(--shadow);
	margin-top: 1.5rem;
}
.public-trust {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--paper-2);
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 1rem;
	font-size: 13px;
	color: var(--ink-500);
}
.public-trust b {
	display: block;
	color: var(--ink-900);
	font-weight: 600;
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: .04em;
	margin-bottom: 4px;
}

/* ───────── Responsive ───────── */
@media (max-width: 720px) {
	main.main { padding: 32px 20px 60px; }
	.site-header .nav { padding-top: 12px; padding-bottom: 12px; gap: 12px; flex-wrap: wrap; }
	.site-nav { gap: 2px; }
	.site-nav a { padding: 6px 10px; font-size: 12px; }
	.footer-inner { flex-direction: column; align-items: flex-start; }
	ul.audits {
		grid-template-columns: minmax(0, 1fr) auto;
	}
	li.audit-row > .audit-brand,
	li.audit-row > .audit-rate,
	li.audit-row > .audit-cost { display: none; }
	.public-card { padding: 24px 20px; }
}
