/* Taxi ABO — formulär, resultat, verifiering (taxigul / mörk, mobilvänlig) */

.taxi-abo-shell,
.taxi-abo-verify-wrap {
	box-sizing: border-box;
}

.taxi-abo-shell {
	margin-block-start: 1.75rem;
	max-width: 28rem;
	margin-inline: auto;
	text-align: left;
}

.text-card .taxi-abo-shell {
	max-width: 100%;
}

.taxi-abo-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.taxi-abo-field label {
	display: block;
	font-size: 0.58rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--accent, #f5d547);
	margin-block-end: 0.45rem;
	font-family: var(--font-mono, "DM Mono", monospace);
}

.taxi-abo-field input {
	width: 100%;
	max-width: 100%;
	padding: 0.75rem 0.9rem;
	border-radius: 0.5rem;
	border: 0.0625rem solid color-mix(in srgb, var(--accent, #f5d547) 35%, transparent);
	background: color-mix(in srgb, var(--bg, #0a0a0f) 88%, transparent);
	color: var(--fg, #e8e4d9);
	font-family: var(--font-mono, "DM Mono", monospace);
	font-size: clamp(0.8rem, 2.8vw, 0.9rem);
	min-height: 2.75rem;
	transition: border-color 0.2s, box-shadow 0.2s;
}

:root[data-theme="light"] .taxi-abo-field input {
	background: rgba(255, 255, 255, 0.92);
	color: var(--fg, #0b141a);
	border-color: color-mix(in srgb, var(--accent, #c9a227) 45%, transparent);
}

.taxi-abo-field input:focus {
	outline: none;
	border-color: var(--accent, #f5d547);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent, #f5d547) 22%, transparent);
}

.taxi-abo-field input::placeholder {
	color: color-mix(in srgb, var(--muted, #6a6a7e) 80%, transparent);
}

.taxi-abo-hint {
	font-size: clamp(0.66rem, 2.5vw, 0.72rem);
	line-height: 1.65;
	color: color-mix(in srgb, var(--fg, #e8e4d9) 58%, transparent);
	font-family: var(--font-mono, "DM Mono", monospace);
}

.taxi-abo-consent {
	margin-block-start: 0.15rem;
}

.taxi-abo-consent.taxi-abo-field label.taxi-abo-checkbox-label {
	text-transform: none;
	letter-spacing: normal;
	font-size: clamp(0.72rem, 2.5vw, 0.82rem);
	line-height: 1.55;
	color: color-mix(in srgb, var(--fg, #e8e4d9) 85%, transparent);
	margin-block-end: 0;
}

.taxi-abo-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	cursor: pointer;
	font-family: var(--font-mono, "DM Mono", monospace);
}

.taxi-abo-checkbox-label input[type="checkbox"] {
	width: 1.15rem;
	height: 1.15rem;
	min-height: 1.15rem;
	margin-top: 0.12rem;
	flex-shrink: 0;
	accent-color: var(--accent, #f5d547);
	cursor: pointer;
}

:root[data-theme="light"] .taxi-abo-consent.taxi-abo-field label.taxi-abo-checkbox-label {
	color: color-mix(in srgb, var(--fg, #0b141a) 88%, transparent);
}

.taxi-abo-submit {
	align-self: flex-start;
	margin-block-start: 0.35rem;
	padding: 0.7rem 1.35rem;
	min-height: 2.75rem;
	border: 0.0625rem solid var(--accent, #f5d547);
	background: color-mix(in srgb, var(--accent, #f5d547) 12%, transparent);
	color: var(--accent, #f5d547);
	font-family: var(--font-mono, "DM Mono", monospace);
	font-size: clamp(0.58rem, 2.2vw, 0.62rem);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	cursor: pointer;
	border-radius: 0.35rem;
	transition: background 0.2s, color 0.2s;
}

.taxi-abo-submit:hover:not(:disabled) {
	background: var(--accent, #f5d547);
	color: var(--bg, #0a0a0f);
}

.taxi-abo-submit:disabled {
	opacity: 0.55;
	cursor: wait;
}

.taxi-abo-form-error {
	font-size: 0.78rem;
	color: #ff8a80;
	margin: 0;
	font-family: var(--font-mono, "DM Mono", monospace);
}

.taxi-abo-result {
	margin-block-start: 1.25rem;
	padding-block-start: 1.25rem;
	border-top: 0.0625rem solid color-mix(in srgb, var(--accent, #f5d547) 25%, transparent);
}

.taxi-abo-result-title {
	font-size: 0.58rem;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--accent, #f5d547);
	margin-block-end: 0.75rem;
	font-family: var(--font-mono, "DM Mono", monospace);
}

.taxi-abo-code-box {
	display: inline-block;
	font-family: var(--font-display, "Bebas Neue", sans-serif);
	font-size: clamp(1.5rem, 6vw, 2.5rem);
	letter-spacing: 0.14em;
	color: var(--bg, #0a0a0f);
	background: var(--accent, #f5d547);
	padding: 0.5rem 1rem 0.35rem;
	border-radius: 0.5rem;
	line-height: 1;
	margin-block-end: 1.25rem;
	max-width: 100%;
	overflow-wrap: anywhere;
}

:root[data-theme="light"] .taxi-abo-code-box {
	color: #0b141a;
}

.taxi-abo-qr-block {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.65rem;
	margin-block-end: 1rem;
	width: 100%;
}

.taxi-abo-qr-block img {
	border-radius: 0.5rem;
	border: 0.0625rem solid color-mix(in srgb, var(--accent, #f5d547) 35%, transparent);
	background: #fff;
	padding: 0.5rem;
	max-width: min(100%, 22rem);
	width: 100%;
	height: auto;
}

.text-card.center .taxi-abo-qr-block {
	align-items: center;
}

.taxi-abo-dl {
	font-family: var(--font-mono, "DM Mono", monospace);
	font-size: 0.58rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--accent, #f5d547);
	text-decoration: none;
	border-bottom: 0.0625rem solid color-mix(in srgb, var(--accent, #f5d547) 45%, transparent);
	padding-bottom: 0.15rem;
}

.taxi-abo-dl:hover {
	color: var(--fg, #e8e4d9);
	border-color: var(--fg, #e8e4d9);
}

.taxi-abo-result-msg {
	font-size: 0.72rem;
	line-height: 1.65;
	color: color-mix(in srgb, var(--fg, #e8e4d9) 65%, transparent);
	font-family: var(--font-mono, "DM Mono", monospace);
	margin: 0;
}

/* Reveal animation (match theme .tag / .body-text) */
.taxi-abo-animate {
	opacity: 0;
	transform: translateY(0.625rem);
	transition: opacity 0.5s ease, transform 0.5s ease;
}

.taxi-abo-animate.visible {
	opacity: 1;
	transform: translateY(0);
}

.text-card.center .taxi-abo-shell {
	text-align: center;
}

.text-card.center .taxi-abo-form,
.text-card.center .taxi-abo-field,
.text-card.center .taxi-abo-submit {
	align-items: stretch;
}

.text-card.center .taxi-abo-submit {
	align-self: center;
}

/* ——— Verifieringssida: egna färger (syns även utan temats CSS-variabler) ——— */
.taxi-abo-verify-sheet {
	--abo-bg: #12141c;
	--abo-bg-elev: #1a1d28;
	--abo-fg: #f4f1ea;
	--abo-muted: #9aa3b5;
	--abo-accent: #f5d547;
	--abo-accent-dim: #c9a227;
	--abo-border: rgba(245, 213, 71, 0.35);
	--abo-input-bg: #0e1016;
	--abo-input-fg: #f4f1ea;

	max-width: min(32rem, 100%);
	width: 100%;
	margin-inline: auto;
	margin-block: 0 2rem;
	padding: clamp(1rem, 4vw, 1.75rem) clamp(0.85rem, 4vw, 1.5rem);
	box-sizing: border-box;
	background: var(--abo-bg);
	color: var(--abo-fg);
	border-radius: 1rem;
	border: 1px solid var(--abo-border);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
	font-family: "DM Mono", ui-monospace, monospace;
}

/* Teman med content-box på inputs gör width:100% + padding bredare än behållaren */
.taxi-abo-verify-sheet *,
.taxi-abo-verify-sheet *::before,
.taxi-abo-verify-sheet *::after {
	box-sizing: border-box;
}

.taxi-abo-verify-sheet .taxi-abo-form,
.taxi-abo-verify-sheet .taxi-abo-field {
	width: 100%;
	max-width: 100%;
	min-width: 0;
}

.taxi-abo-verify-sheet .taxi-abo-verify-intro {
	font-size: clamp(0.78rem, 2.8vw, 0.88rem);
	line-height: 1.75;
	color: var(--abo-muted);
	margin: 0 0 1.25rem;
	overflow-wrap: anywhere;
}

.taxi-abo-verify-sheet .taxi-abo-field label {
	color: var(--abo-accent);
}

.taxi-abo-verify-sheet .taxi-abo-field input {
	background: var(--abo-input-bg);
	color: var(--abo-input-fg);
	border-color: rgba(245, 213, 71, 0.45);
	width: 100%;
	max-width: 100%;
	min-width: 0;
}

.taxi-abo-verify-sheet .taxi-abo-field input:focus {
	border-color: var(--abo-accent);
	box-shadow: 0 0 0 3px rgba(245, 213, 71, 0.22);
}

.taxi-abo-verify-sheet .taxi-abo-field input::placeholder {
	color: #6b7287;
}

.taxi-abo-verify-sheet .taxi-abo-submit {
	border-color: var(--abo-accent);
	color: var(--abo-accent);
	background: rgba(245, 213, 71, 0.1);
	width: 100%;
	max-width: 100%;
	justify-content: center;
	align-self: stretch;
	text-align: center;
}

.taxi-abo-verify-sheet .taxi-abo-submit:hover:not(:disabled) {
	background: var(--abo-accent);
	color: #12141c;
}

.taxi-abo-verify-sheet .taxi-abo-form-error {
	color: #ff9e8e;
}

.taxi-abo-verify-feedback {
	font-size: clamp(0.75rem, 2.6vw, 0.82rem);
	line-height: 1.6;
	margin: 1rem 0 0;
	padding: 0.85rem 1rem;
	border-radius: 0.5rem;
	border: 1px solid transparent;
	max-width: 100%;
	min-width: 0;
	overflow-wrap: anywhere;
}

.taxi-abo-verify-sheet .taxi-abo-verify-feedback--ok {
	color: #1a1a12;
	background: linear-gradient(135deg, #f5d547 0%, #e8c73d 100%);
	border-color: rgba(0, 0, 0, 0.12);
	font-weight: 600;
}

.taxi-abo-verify-sheet .taxi-abo-verify-feedback--warn {
	color: #fff5ec;
	background: rgba(160, 72, 52, 0.45);
	border-color: rgba(255, 200, 140, 0.45);
}

.taxi-abo-verify-result {
	margin-block-start: 1.25rem;
	padding: 1.15rem 1.1rem;
	border-radius: 0.75rem;
	border: 1px solid var(--abo-border);
	background: var(--abo-bg-elev);
	color: var(--abo-fg);
}

.taxi-abo-verify-sheet .taxi-abo-verify-result-title {
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: clamp(1.5rem, 5vw, 2rem);
	letter-spacing: 0.08em;
	color: var(--abo-accent);
	margin: 0 0 1rem;
	font-weight: 400;
}

.taxi-abo-verify-dl {
	display: grid;
	grid-template-columns: minmax(0, 10rem) 1fr;
	gap: 0.5rem 1rem;
	margin: 0 0 1rem;
	font-size: 0.78rem;
}

.taxi-abo-verify-sheet .taxi-abo-verify-dl dt {
	margin: 0;
	color: var(--abo-muted);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-size: 0.58rem;
	align-self: center;
}

.taxi-abo-verify-sheet .taxi-abo-verify-dl dd {
	margin: 0;
	color: var(--abo-fg);
	font-size: clamp(0.82rem, 2.6vw, 0.95rem);
	letter-spacing: 0.03em;
	font-weight: 500;
	overflow-wrap: anywhere;
}

.taxi-abo-verify-sheet .taxi-abo-verify-label {
	margin: 0;
	font-size: 0.74rem;
	line-height: 1.65;
	color: var(--abo-muted);
}

body.page .taxi-abo-verify-wrap .taxi-abo-submit {
	margin-block-start: 0.25rem;
}

/* Honeypot */
.taxi-abo-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	pointer-events: none !important;
	overflow: hidden !important;
}

/* ——— Mobil ——— */
@media (max-width: 36rem) {
	.taxi-abo-shell {
		max-width: 100%;
		margin-inline: 0;
	}

	.taxi-abo-verify-dl {
		grid-template-columns: 1fr;
		gap: 0.25rem 0;
	}

	.taxi-abo-verify-sheet .taxi-abo-verify-dl dt {
		margin-top: 0.65rem;
	}

	.taxi-abo-verify-sheet .taxi-abo-verify-dl dt:first-child {
		margin-top: 0;
	}

	.taxi-abo-verify-sheet .taxi-abo-verify-dl dd {
		margin-bottom: 0.35rem;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	}

	.taxi-abo-verify-sheet .taxi-abo-verify-dl dd:last-of-type {
		border-bottom: none;
		margin-bottom: 0;
		padding-bottom: 0;
	}
}

@media (max-width: 22rem) {
	.taxi-abo-verify-sheet {
		padding: 0.85rem 0.65rem;
		border-radius: 0.65rem;
	}
}
