/* =====================================================================
   Vote Amboy address lookup widget
   Reuses --va-* tokens from va-brand-style.css; loaded after va-brand.
   ===================================================================== */

.va-lookup {
	max-width: 720px;
	margin: 0 auto;
	padding: 0 var(--space-md, 16px);
	font-family: var(--va-font-serif, Georgia, serif);
	color: var(--va-charcoal, #1A1A1A);
}

.va-lookup__steps {
	list-style: none;
	margin: 0 0 var(--space-md, 16px);
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xs, 4px);
	counter-reset: va-lookup-step;
}
.va-lookup__step {
	display: flex;
	align-items: center;
	gap: var(--space-sm, 8px);
	padding: var(--space-sm, 8px) var(--space-sm-2, 12px); /* 8 / 12 step pill */
	background: var(--va-newsprint-deep, #EDE3CB);
	border-bottom: 3px solid var(--va-charcoal-soft, #3A3A3A);
	color: var(--va-charcoal-soft, #3A3A3A);
	font-family: var(--va-font-display, sans-serif);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: 0.04em;
	line-height: 1.25;
}
.va-lookup__step--current {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-bottom-color: var(--va-stamp, #C1272D);
	color: var(--va-ink, #0A2540);
	font-weight: 700;
}
.va-lookup__step-num {
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	border-radius: 999px;
	background: var(--va-stamp, #C1272D);
	color: var(--va-newsprint, #F4ECDB);
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	line-height: 1;
}
.va-lookup__step-text { line-height: 1.25; }
@media (max-width: 600px) {
	.va-lookup__steps { grid-template-columns: 1fr; }
	.va-lookup__step-text { font-size: 12px; }
}

.va-lookup__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm, 8px);
}

.va-lookup__label {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-size: var(--type-eyebrow, 13px);
	color: var(--va-ink, #0A2540);
	text-align: center;
}

.va-lookup__input {
	background: var(--va-newsprint-deep, #EDE3CB);
	border: 0;
	border-bottom: 2px solid var(--va-ink, #0A2540);
	border-radius: 0;
	padding: var(--space-sm-2, 12px) var(--space-md, 16px); /* 12 / 16 form input */
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 18px;
	color: var(--va-charcoal, #1A1A1A);
	width: 100%;
	max-width: 100%;
	transition: border-color 0.15s, background 0.15s;
}
.va-lookup__input::placeholder { color: var(--va-charcoal-soft, #3A3A3A); opacity: 0.7; }
.va-lookup__input:focus {
	outline: 0;
	background: var(--va-newsprint, #F4ECDB);
	border-bottom-color: var(--va-stamp, #C1272D);
	border-bottom-width: 3px;
}

.va-lookup__help {
	font-size: 13px;
	color: var(--va-charcoal-soft, #3A3A3A);
	margin: 0;
	text-align: center;
}

.va-lookup__submit {
	margin: var(--space-md, 16px) auto 0 !important;
	display: block !important;
	min-width: 220px;
}

.va-lookup__submit[aria-busy="true"] {
	opacity: 0.75;
	cursor: progress;
}

.va-lookup__status {
	min-height: 1.5em;
	text-align: center;
	font-style: italic;
	color: var(--va-charcoal-soft, #3A3A3A);
	margin-top: var(--space-md, 16px);
}

.va-lookup__result {
	margin-top: var(--space-lg, 24px);
}

/* ---------- Result card (uses .va-ward-card aesthetic) ---------- */

.va-lookup__card {
	background: var(--va-newsprint, #F4ECDB);
	border: 3px solid var(--va-ink, #0A2540);
	box-shadow: 6px 6px 0 0 var(--va-stamp, #C1272D); /* doctrine: rest-state card shadow = 6px */
	padding: var(--space-xl, 40px) var(--space-lg, 24px);
	text-align: center;
	outline: none;
}
.va-lookup__card:focus-visible {
	outline: 3px solid var(--va-brass, #B88A3E);
	outline-offset: 4px;
}

.va-lookup__eyebrow {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-size: var(--type-eyebrow, 13px);
	color: var(--va-stamp, #C1272D);
	margin: 0 0 var(--space-sm, 8px);
}

.va-lookup__heading {
	font-family: var(--va-font-serif, Georgia, serif);
	font-variation-settings: "opsz" 144, "SOFT" 0, "WONK" 1;
	font-weight: 900;
	font-size: clamp(28px, 4vw, 44px);
	line-height: 1.1;
	color: var(--va-ink, #0A2540);
	margin: 0 0 var(--space-lg, 24px);
}

.va-lookup__sub {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-size: 14px;
	color: var(--va-stamp, #C1272D);
	margin: var(--space-lg, 24px) 0 var(--space-sm, 8px);
}

.va-lookup__candidates {
	list-style: none;
	padding: 0;
	margin: 0 auto var(--space-lg, 24px);
	max-width: 520px;
	display: grid;
	gap: var(--space-sm, 8px);
}
.va-lookup__candidates li {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-left: 4px solid var(--va-stamp, #C1272D);
	padding: var(--space-md, 16px);
	text-align: left;
}
.va-lookup__cand-name {
	display: block;
	font-family: var(--va-font-serif, Georgia, serif);
	font-weight: 800;
	font-size: 22px;
	color: var(--va-ink, #0A2540);
	margin-bottom: var(--space-xs, 4px);
}
.va-lookup__cand-spell {
	display: block;
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 15px;
	color: var(--va-charcoal-soft, #3A3A3A);
}
.va-lookup__cand-spell strong {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 800;
	letter-spacing: 0.06em;
	color: var(--va-stamp, #C1272D);
	font-size: 16px;
}

.va-lookup__no-candidate {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-left: 4px solid var(--va-brass, #B88A3E);
	padding: var(--space-md, 16px);
	text-align: left;
	max-width: 520px;
	margin: 0 auto var(--space-lg, 24px);
	color: var(--va-charcoal, #1A1A1A);
}

/* ---------- How are you voting? method picker ---------- */

.va-lookup__methods {
	margin: var(--space-lg, 24px) auto 0;
	max-width: 720px;
	text-align: left;
}

.va-lookup__methods .va-lookup__sub {
	text-align: center;
	margin-bottom: var(--space-md, 16px);
}

.va-lookup__method-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md, 16px);
	margin-bottom: var(--space-md, 16px);
}

.va-lookup__method {
	background: var(--va-newsprint-deep, #EDE3CB);
	border: 3px solid var(--va-ink, #0A2540);
	box-shadow: 6px 6px 0 0 var(--va-stamp, #C1272D);
	color: var(--va-ink, #0A2540);
	padding: var(--space-md, 16px) var(--space-lg, 24px);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs, 4px);
	text-align: left;
	cursor: pointer;
	font-family: var(--va-font-serif, Georgia, serif);
	transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
	width: 100%;
	min-height: 132px;
}
.va-lookup__method:hover {
	transform: translate(-2px, -2px);
	box-shadow: 10px 10px 0 0 var(--va-stamp, #C1272D);
	background: var(--va-newsprint, #F4ECDB);
}
.va-lookup__method:focus-visible {
	outline: 3px solid var(--va-brass, #B88A3E);
	outline-offset: 4px;
}
.va-lookup__method.is-selected {
	background: var(--va-newsprint, #F4ECDB);
	border-top: 6px solid var(--va-stamp, #C1272D);
	box-shadow: 10px 10px 0 0 var(--va-stamp, #C1272D);
	transform: translate(-2px, -2px);
}

.va-lookup__method-eyebrow {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-size: 12px;
	color: var(--va-stamp, #C1272D);
}
.va-lookup__method-title {
	font-family: var(--va-font-serif, Georgia, serif);
	font-weight: 900;
	font-size: clamp(22px, 3vw, 28px);
	color: var(--va-ink, #0A2540);
	line-height: 1.1;
}
.va-lookup__method-desc {
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 15px;
	line-height: 1.4;
	color: var(--va-charcoal-soft, #3A3A3A);
}

.va-lookup__method-panel {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-left: 4px solid var(--va-stamp, #C1272D);
	padding: var(--space-md, 16px) var(--space-md, 16px) var(--space-md, 16px) var(--space-lg, 24px);
	margin-top: var(--space-md, 16px);
}
.va-lookup__method-panel[hidden] {
	display: none !important;
}

.va-lookup__method-steps {
	counter-reset: va-method-step;
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--space-sm, 8px);
}
.va-lookup__method-steps li {
	counter-increment: va-method-step;
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: var(--space-sm, 8px);
	align-items: start;
	background: var(--va-newsprint, #F4ECDB);
	border-left: 4px solid var(--va-stamp, #C1272D);
	padding: 12px 14px 12px 0; /* allow-raw-px: counter-cell layout asymmetric padding */
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 16px;
	line-height: 1.5;
	color: var(--va-charcoal, #1A1A1A);
}
.va-lookup__method-steps li::before {
	content: counter(va-method-step);
	font-family: var(--va-font-display, sans-serif);
	font-weight: 900;
	font-size: 24px;
	color: var(--va-stamp, #C1272D);
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--va-newsprint-deep, #EDE3CB);
	border-right: 2px solid var(--va-ink, #0A2540);
	min-height: 44px;
}

@media (min-width: 640px) {
	.va-lookup__method-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* ---------- Reminder block (Add to Calendar) ---------- */

.va-lookup__reminders {
	margin: var(--space-lg, 24px) auto 0;
	max-width: 720px;
	text-align: left;
}

.va-lookup__reminders-headsup {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-left: 4px solid var(--va-brass, #B88A3E);
	padding: var(--space-md, 16px);
	margin-bottom: var(--space-md, 16px);
}
.va-lookup__reminders-headsup-text {
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 15px;
	line-height: 1.5;
	color: var(--va-charcoal, #1A1A1A);
	margin: 0 0 var(--space-sm, 8px);
}
.va-lookup__reminders-portal {
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 14px;
	line-height: 1.5;
	color: var(--va-charcoal-soft, #3A3A3A);
	margin: 0;
}

.va-lookup__reminders .va-lookup__sub {
	text-align: center;
	margin-bottom: var(--space-md, 16px);
}

.va-lookup__reminders-fieldset {
	border: 0;
	margin: 0;
	padding: 0;
	min-width: 0;
}
.va-lookup__reminders-legend {
	float: none;
	width: 100%;
	padding: 0;
}

.va-lookup__reminders-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-sm, 8px);
	margin-bottom: var(--space-md, 16px);
}

.va-lookup__reminders-row {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm, 12px);
	background: var(--va-newsprint, #F4ECDB);
	border: 2px solid var(--va-ink, #0A2540);
	padding: var(--space-sm-2, 12px) var(--space-md, 16px);
	min-height: 56px;
	cursor: pointer;
	font-family: var(--va-font-serif, Georgia, serif);
}
.va-lookup__reminders-row input[type="checkbox"] {
	width: 20px;
	height: 20px;
	margin-top: 2px; /* allow-raw-px: optical baseline alignment with row title */
	accent-color: var(--va-stamp, #C1272D);
	flex-shrink: 0;
}
.va-lookup__reminders-text {
	display: flex;
	flex-direction: column;
	gap: 2px; /* allow-raw-px: tight stacked title + meta */
}
.va-lookup__reminders-row-title {
	font-weight: 800;
	color: var(--va-ink, #0A2540);
	font-size: 17px;
}
.va-lookup__reminders-row-when {
	color: var(--va-charcoal-soft, #3A3A3A);
	font-size: 14px;
	line-height: 1.35;
}

.va-lookup__reminders-actions {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-sm, 8px);
}
.va-lookup__reminders-ics,
.va-lookup__reminders-google {
	width: 100%;
	min-width: 0;
}
.va-lookup__reminders-ics:disabled,
.va-lookup__reminders-google:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	filter: grayscale(0.4);
}

.va-lookup__reminders-fallback {
	margin: var(--space-sm, 8px) 0 0;
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 14px;
	color: var(--va-stamp, #C1272D);
	text-align: center;
}

@media (min-width: 640px) {
	.va-lookup__reminders-actions {
		grid-template-columns: 1fr 1fr;
	}
}

/* ---------- Where to vote ---------- */

.va-lookup__where {
	margin-top: var(--space-lg, 24px);
}
.va-lookup__where-name {
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 22px;
	color: var(--va-ink, #0A2540);
	margin: 0 0 var(--space-xs, 4px);
}
.va-lookup__where-addr {
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 16px;
	color: var(--va-charcoal-soft, #3A3A3A);
	margin: 0 0 var(--space-md, 16px);
}
.va-lookup__directions {
	display: inline-block !important;
}

/* ---------- CTAs / try again ---------- */

.va-lookup__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md, 16px);
	justify-content: center;
	align-items: center;
	margin-top: var(--space-xl, 40px);
}
.va-lookup__try-again {
	background: transparent;
	border: 0;
	color: var(--va-charcoal-soft, #3A3A3A);
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 15px;
	text-decoration: underline;
	cursor: pointer;
	padding: var(--space-sm, 8px) var(--space-md, 16px);
}
.va-lookup__try-again:hover { color: var(--va-stamp, #C1272D); }
.va-lookup__try-again:focus-visible {
	outline: 3px solid var(--va-brass, #B88A3E);
	outline-offset: 4px;
	border-radius: 2px;
}

/* ---------- Errors / noscript ---------- */

.va-lookup__error {
	background: var(--va-newsprint-deep, #EDE3CB);
	border-left: 4px solid var(--va-stamp, #C1272D);
	padding: var(--space-md, 16px);
	text-align: left;
	max-width: 560px;
	margin: 0 auto;
	color: var(--va-ink, #0A2540);
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 16px;
	line-height: 1.5;
}

.va-lookup__noscript {
	background: var(--va-newsprint-deep, #EDE3CB);
	padding: var(--space-md, 16px);
	border-left: 4px solid var(--va-stamp, #C1272D);
	text-align: center;
	margin: var(--space-md, 16px) 0;
}

/* ---------- Ward + district picker (alt mode) ---------- */

.va-lookup__picker {
	margin-top: var(--space-lg, 24px);
	padding: var(--space-md, 16px);
	background: var(--va-newsprint-deep, #EDE3CB);
	border-top: 2px solid var(--va-ink, #0A2540);
	border-bottom: 2px solid var(--va-ink, #0A2540);
	text-align: center;
}

.va-lookup__picker-intro {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	font-size: 13px;
	color: var(--va-ink, #0A2540);
	margin: 0 0 var(--space-sm, 8px);
	text-align: center;
}

.va-lookup__picker-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-sm, 8px);
	margin: 0 auto var(--space-sm, 8px);
	max-width: 480px;
}

.va-lookup__picker-field {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs, 4px);
	text-align: left;
}

.va-lookup__picker-label {
	font-family: var(--va-font-display, sans-serif);
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	font-size: 12px;
	color: var(--va-ink, #0A2540);
}

.va-lookup__picker-select {
	background: var(--va-newsprint, #F4ECDB);
	border: 0;
	border-bottom: 2px solid var(--va-ink, #0A2540);
	border-radius: 0;
	padding: var(--space-sm-2, 12px) var(--space-sm-2, 12px); /* 12 / 12 select field — 14 was off-token */
	font-family: var(--va-font-serif, Georgia, serif);
	font-size: 16px;
	color: var(--va-charcoal, #1A1A1A);
	width: 100%;
	max-width: 100%;
	min-height: 44px;
	appearance: none;
	-webkit-appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--va-ink, #0A2540) 50%),
		linear-gradient(135deg, var(--va-ink, #0A2540) 50%, transparent 50%);
	background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}

.va-lookup__picker-select:focus {
	outline: 0;
	border-bottom-color: var(--va-stamp, #C1272D);
	border-bottom-width: 3px;
}

.va-lookup__picker-select:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.va-lookup__picker-submit {
	margin: var(--space-sm, 8px) auto 0 !important;
	display: inline-block !important;
	min-width: 220px;
}

.va-lookup__picker-submit[aria-busy="true"] {
	opacity: 0.75;
	cursor: progress;
}

@media (min-width: 640px) {
	.va-lookup__picker-grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* ---------- Mobile tweaks ---------- */

@media (max-width: 600px) {
	.va-lookup__card {
		padding: var(--space-lg, 24px) var(--space-md, 16px);
	}
	.va-lookup__heading { font-size: clamp(24px, 7vw, 32px); }
	.va-lookup__cand-name { font-size: 19px; }
	.va-lookup__rules { padding: var(--space-md, 16px); }
}
