/* ============================================================
   EQ Control – ISO 14001 Audit Readiness Questionnaire
   Brand palette extracted from qesm.fi
   ============================================================ */

:root {
	--eq-brand: rgba(223, 227, 43, 1);
	--eq-brand-light: color-mix(in srgb, var(--eq-brand) 70%, white);
	--eq-brand-dark: color-mix(in srgb, var(--eq-brand) 60%, black);
	--eq-navy: #1a2b3c;
	--eq-navy-deep: #0f1e2d;
	--eq-navy-mid: #233447;
	--eq-white: #ffffff;
	--eq-bg: #f4f6f8;
	--eq-card: #ffffff;
	--eq-text: #1e2b3a;
	--eq-text-muted: #6b7280;
	--eq-text-light: #9ca3af;
	--eq-border: #dde2e8;
	--eq-border-focus: #a8b200;
	--eq-success: #16a34a;
	--eq-success-bg: #f0fdf4;
	--eq-warning: #d97706;
	--eq-warning-bg: #fffbeb;
	--eq-danger: #dc2626;
	--eq-danger-bg: #fef2f2;
	--eq-radius: 6px;
	--eq-radius-lg: 10px;
	--eq-radius-xl: 16px;
	--eq-shadow: 0 1px 3px rgba(0, 0, 0, 0.07), 0 4px 18px rgba(0, 0, 0, 0.05);
	--eq-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
	--eq-trans: 0.17s ease;
	--eq-font:
		-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
		Arial, sans-serif;
	--eq-max: 780px;
}

/* ── Reset & base ─────────────────────────────────────────── */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

.eq-quiz-wrapper {
	font-family: var(--eq-font);
	color: var(--eq-text);
	background: var(--eq-bg);
	min-height: 100vh;
	-webkit-font-smoothing: antialiased;
}

/* ── Header ───────────────────────────────────────────────── */

.eq-quiz-header {
	background: var(--eq-navy-deep);
	padding: 18px 32px;
	display: flex;
	align-items: center;
}

.eq-logo {
	height: 36px;
	width: auto;
	display: block;
}

/* ── Container ────────────────────────────────────────────── */

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

/* ── Intro screen ─────────────────────────────────────────── */

.eq-intro {
	padding: 64px 0 80px;
}

.eq-intro-inner {
	background: var(--eq-card);
	border-radius: var(--eq-radius-xl);
	box-shadow: var(--eq-shadow);
	padding: 52px 56px;
	text-align: center;
}

.eq-intro-eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--eq-brand-dark);
	background: var(--eq-brand-light);
	border-radius: 100px;
	padding: 4px 14px;
	margin-bottom: 24px;
}

.eq-intro-title {
	font-size: clamp(22px, 3.5vw, 30px);
	font-weight: 700;
	line-height: 1.25;
	color: var(--eq-navy);
	margin-bottom: 20px;
}

.eq-intro-text {
	font-size: 16px;
	line-height: 1.7;
	color: var(--eq-text-muted);
	max-width: 540px;
	margin: 0 auto 32px;
}

.eq-intro-badges {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 40px;
}

.eq-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 500;
	color: var(--eq-text-muted);
	background: var(--eq-bg);
	border: 1px solid var(--eq-border);
	border-radius: 100px;
	padding: 5px 14px;
}

.eq-badge::before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--eq-brand);
	flex-shrink: 0;
}

/* ── Buttons ──────────────────────────────────────────────── */

.eq-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border: none;
	border-radius: var(--eq-radius);
	cursor: pointer;
	font-family: var(--eq-font);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	transition:
		background var(--eq-trans),
		box-shadow var(--eq-trans),
		transform var(--eq-trans);
	user-select: none;
	white-space: nowrap;
	float: none;
	margin: 0;
}

.eq-btn:focus-visible {
	outline: 3px solid var(--eq-brand);
	outline-offset: 3px;
}

.eq-btn:active {
	transform: translateY(1px);
}

.eq-btn-primary {
	background: var(--eq-brand);
	color: var(--eq-navy-deep);
	padding: 12px 28px;
	box-shadow: 0 2px 8px rgba(200, 212, 0, 0.3);
}

.eq-btn-primary:hover {
	background: var(--eq-brand-dark);
	box-shadow: 0 4px 14px rgba(200, 212, 0, 0.35);
}

.eq-btn-primary.eq-btn-large {
	font-size: 15px;
	padding: 15px 36px;
}

.eq-btn-ghost {
	background: transparent;
	color: var(--eq-text-muted);
	padding: 12px 20px;
	border: 1px solid var(--eq-border);
}

.eq-btn-ghost:hover {
	background: var(--eq-bg);
	color: var(--eq-text);
	border-color: #c0c8d0;
}

.eq-btn:disabled {
	opacity: 0.42;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* ── Quiz body ────────────────────────────────────────────── */

.eq-quiz-body {
	padding: 40px 0 72px;
}

/* ── Progress ─────────────────────────────────────────────── */

.eq-progress-wrap {
	margin-bottom: 28px;
}

.eq-progress-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 10px;
}

.eq-step-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--eq-navy);
	letter-spacing: 0.01em;
}

.eq-category-tag {
	font-size: 12px;
	font-weight: 500;
	color: var(--eq-brand-dark);
	background: var(--eq-brand-light);
	padding: 3px 10px;
	border-radius: 100px;
	letter-spacing: 0.02em;
}

.eq-progress-track {
	height: 5px;
	background: var(--eq-border);
	border-radius: 100px;
	overflow: hidden;
}

.eq-progress-fill {
	height: 100%;
	background: var(--eq-brand);
	border-radius: 100px;
	transition: width 0.35s ease;
}

/* Step dots */
.eq-step-dots {
	display: flex;
	gap: 6px;
	margin-top: 10px;
}

.eq-step-dot {
	flex: 1;
	height: 3px;
	border-radius: 100px;
	background: var(--eq-border);
	transition: background var(--eq-trans);
}

.eq-step-dot.done {
	background: var(--eq-brand);
}
.eq-step-dot.active {
	background: var(--eq-brand-dark);
}

/* ── Question cards ───────────────────────────────────────── */

.eq-questions {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin-bottom: 32px;
}

.eq-question-card {
	background: var(--eq-card);
	border-radius: var(--eq-radius-lg);
	box-shadow: var(--eq-shadow);
	padding: 22px 24px;
	border: 1.5px solid transparent;
	transition:
		border-color var(--eq-trans),
		box-shadow var(--eq-trans);
}

.eq-question-card.answered {
	border-color: var(--eq-brand);
	box-shadow:
		0 0 0 1px var(--eq-brand),
		var(--eq-shadow);
}

.eq-question-header {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 16px;
}

.eq-question-num {
	flex-shrink: 0;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: var(--eq-bg);
	color: var(--eq-text-muted);
	font-size: 12px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	transition:
		background var(--eq-trans),
		color var(--eq-trans);
}

.eq-question-card.answered .eq-question-num {
	background: var(--eq-brand);
	color: var(--eq-navy-deep);
}

.eq-question-text {
	font-size: 15px;
	font-weight: 500;
	line-height: 1.5;
	color: var(--eq-text);
	padding-top: 3px;
}

/* Answer options – radio inputs styled as checkbox pills */

.eq-answer-group {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.eq-answer-option {
	position: relative;
}

.eq-answer-option input[type="radio"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.eq-answer-option label {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	cursor: pointer;
	font-size: 13px;
	font-weight: 500;
	color: var(--eq-text-muted);
	background: var(--eq-bg);
	border: 1.5px solid var(--eq-border);
	border-radius: 100px;
	padding: 7px 18px;
	transition:
		background var(--eq-trans),
		border-color var(--eq-trans),
		color var(--eq-trans);
	user-select: none;
}

.eq-answer-option label::before {
	content: "";
	width: 14px;
	height: 14px;
	border-radius: 3px;
	border: 1.5px solid var(--eq-border);
	background: var(--eq-white);
	flex-shrink: 0;
	transition:
		border-color var(--eq-trans),
		background var(--eq-trans);
}

.eq-answer-option input[type="radio"]:checked + label {
	color: var(--eq-navy-deep);
	background: var(--eq-brand-light);
	border-color: var(--eq-brand);
	font-weight: 600;
}

.eq-answer-option input[type="radio"]:checked + label::before {
	background: var(--eq-brand);
	border-color: var(--eq-brand-dark);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 8' fill='none'%3E%3Cpath d='M1 4l3 3 5-6' stroke='%230f1e2d' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-size: 10px 8px;
	background-repeat: no-repeat;
	background-position: center;
}

.eq-answer-option input[type="radio"]:focus-visible + label {
	outline: 3px solid var(--eq-brand);
	outline-offset: 2px;
}

.eq-answer-option label:hover {
	border-color: var(--eq-brand-dark);
	color: var(--eq-text);
}

/* ── Navigation ───────────────────────────────────────────── */

.eq-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.eq-nav-hint {
	text-align: center;
	font-size: 12px;
	color: var(--eq-text-light);
	margin-top: 12px;
	min-height: 18px;
}

/* ── Results screen ───────────────────────────────────────── */

.eq-results {
	padding: 40px 0 80px;
}

/* Score card */

.eq-score-card {
	background: var(--eq-card);
	border-radius: var(--eq-radius-xl);
	box-shadow: var(--eq-shadow);
	padding: 48px 40px;
	text-align: center;
	margin-bottom: 24px;
}

.eq-score-visual {
	display: flex;
	justify-content: center;
	margin-bottom: 32px;
}

.eq-score-ring-wrap {
	position: relative;
	width: 140px;
	height: 140px;
}

.eq-score-ring-wrap svg {
	transform: rotate(-90deg);
}

.eq-score-ring-bg {
	stroke: var(--eq-border);
	fill: none;
	stroke-width: 10;
}

.eq-score-ring-fill {
	fill: none;
	stroke-width: 10;
	stroke-linecap: round;
	transition:
		stroke-dashoffset 1.1s ease,
		stroke 0.4s ease;
}

.eq-score-ring-text {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.eq-score-number {
	font-size: 38px;
	font-weight: 800;
	color: var(--eq-navy);
	line-height: 1;
}

.eq-score-denom {
	font-size: 14px;
	font-weight: 500;
	color: var(--eq-text-muted);
	margin-top: 2px;
}

.eq-score-level-badge {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 100px;
	padding: 5px 16px;
	margin-bottom: 16px;
}

.eq-score-level-badge.high {
	background: var(--eq-danger-bg);
	color: var(--eq-danger);
}
.eq-score-level-badge.medium {
	background: var(--eq-warning-bg);
	color: var(--eq-warning);
}
.eq-score-level-badge.good {
	background: var(--eq-success-bg);
	color: var(--eq-success);
}

.eq-score-title {
	font-size: 22px;
	font-weight: 700;
	color: var(--eq-navy);
	margin-bottom: 12px;
	line-height: 1.3;
}

.eq-score-desc {
	font-size: 15px;
	line-height: 1.65;
	color: var(--eq-text-muted);
	max-width: 520px;
	margin: 0 auto;
}

/* ── Category breakdown ───────────────────────────────────── */

.eq-breakdown {
	background: var(--eq-card);
	border-radius: var(--eq-radius-xl);
	box-shadow: var(--eq-shadow);
	padding: 32px 36px;
	margin-bottom: 24px;
}

.eq-breakdown-title {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--eq-text-muted);
	margin-bottom: 22px;
}

.eq-breakdown-rows {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.eq-breakdown-row {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 16px;
}

.eq-breakdown-label {
	font-size: 14px;
	font-weight: 500;
	color: var(--eq-text);
	margin-bottom: 6px;
}

.eq-breakdown-bar-track {
	height: 6px;
	background: var(--eq-border);
	border-radius: 100px;
	overflow: hidden;
}

.eq-breakdown-bar-fill {
	height: 100%;
	border-radius: 100px;
	transition: width 0.6s ease;
}

.eq-breakdown-score {
	font-size: 13px;
	font-weight: 700;
	color: var(--eq-navy);
	white-space: nowrap;
}

/* ── contact-us box ──────────────────────────────────────────────── */

.eq-contact-us-box {
	background: var(--eq-navy);
	border-radius: var(--eq-radius-xl);
	padding: 40px 48px;
	text-align: center;
	margin-bottom: 24px;
}

.eq-contact-us-title {
	font-size: 20px;
	font-weight: 700;
	color: var(--eq-white);
	margin-bottom: 12px;
	line-height: 1.3;
}

.eq-contact-us-text {
	font-size: 15px;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.72);
	max-width: 480px;
	margin: 0 auto 28px;
}

.eq-contact-us-btn {
	background: var(--eq-brand);
	color: var(--eq-navy-deep);
	padding: 14px 34px;
	font-size: 15px;
	font-weight: 700;
	border-radius: var(--eq-radius);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition:
		background var(--eq-trans),
		box-shadow var(--eq-trans);
	box-shadow: 0 2px 10px rgba(200, 212, 0, 0.3);
}

.eq-contact-us-btn:hover {
	background: var(--eq-brand-dark);
	box-shadow: 0 4px 18px rgba(200, 212, 0, 0.4);
}

/* ── Lead form ────────────────────────────────────────────── */

.eq-lead-wrap {
	background: var(--eq-card);
	border-radius: var(--eq-radius-xl);
	box-shadow: var(--eq-shadow);
	padding: 40px 48px;
}

.eq-lead-heading {
	font-size: 19px;
	font-weight: 700;
	color: var(--eq-navy);
	margin-bottom: 8px;
}

.eq-lead-sub {
	font-size: 14px;
	color: var(--eq-text-muted);
	line-height: 1.6;
	margin-bottom: 28px;
}

.eq-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 16px;
}

.eq-form-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.eq-form-group label {
	font-size: 13px;
	font-weight: 600;
	color: var(--eq-white);
	letter-spacing: 0.01em;
	width: fit-content;
}

.eq-form-group input[type="text"],
.eq-form-group input[type="email"],
.eq-form-group input[type="tel"] {
	font-family: var(--eq-font);
	font-size: 14px;
	color: var(--eq-text);
	background: var(--eq-bg);
	border: 1.5px solid var(--eq-border);
	border-radius: var(--eq-radius);
	padding: 10px 14px;
	width: 100%;
	transition:
		border-color var(--eq-trans),
		box-shadow var(--eq-trans);
	outline: none;
}

.eq-form-group input:focus {
	border-color: var(--eq-brand-dark);
	box-shadow: 0 0 0 3px rgba(200, 212, 0, 0.18);
	background: var(--eq-white);
}

.eq-form-group input.eq-invalid {
	border-color: var(--eq-danger);
}

.eq-form-group--full {
	grid-column: 1 / -1;
}

/* Honeypot field — visually hidden but rendered, so naive bots
   auto-fill it and trip the server-side check. Off-screen rather
   than display:none so bots that skip hidden inputs still fill it. */
.eq-hp-field {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Consent */

.eq-consent-label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	font-size: 13px;
	color: var(--eq-text-muted);
	line-height: 1.55;
}

.eq-consent-label input[type="checkbox"] {
	flex-shrink: 0;
	margin-top: 2px;
	width: 16px;
	height: 16px;
	accent-color: var(--eq-brand-dark);
	cursor: pointer;
}

.eq-consent-label .consent-text {
	text-align: left;
}

.eq-consent-label .consent-text a {
	color: var(--eq-brand);
	text-decoration: underline;
}

.eq-consent-label .consent-text a:hover {
	color: var(--eq-navy);
}

/* Form footer */

.eq-form-footer {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	margin-top: 28px;
	flex-wrap: wrap;
}

.eq-form-privacy-note {
	font-size: 12px;
	color: var(--eq-text-light);
	line-height: 1.5;
	display: flex;
	align-items: center;
	gap: 5px;
}

.eq-form-msg {
	margin-top: 16px;
	font-size: 14px;
	font-weight: 500;
	padding: 12px 16px;
	border-radius: var(--eq-radius);
	border-left: 3px solid transparent;
}

.eq-form-msg.success {
	background: var(--eq-success-bg);
	border-color: var(--eq-success);
	color: var(--eq-success);
}

.eq-form-msg.error {
	background: var(--eq-danger-bg);
	border-color: var(--eq-danger);
	color: var(--eq-danger);
}

/* ── Utilities ────────────────────────────────────────────── */

[hidden] {
	display: none !important;
}

/* ── Responsive ───────────────────────────────────────────── */

@media (max-width: 640px) {
	.eq-quiz-header {
		padding: 14px 20px;
	}
	.eq-logo {
		height: 28px;
	}
	.eq-container {
		padding: 0 16px;
	}

	.eq-intro {
		padding: 32px 0 48px;
	}
	.eq-intro-inner {
		padding: 32px 24px;
	}

	.eq-quiz-body {
		padding: 24px 0 56px;
	}

	.eq-question-card {
		padding: 18px 18px;
	}
	.eq-question-text {
		font-size: 14px;
	}

	.eq-answer-group {
		gap: 8px;
	}
	.eq-answer-option label {
		font-size: 12px;
		padding: 6px 14px;
	}

	.eq-score-card {
		padding: 32px 24px;
	}
	.eq-breakdown {
		padding: 24px 20px;
	}
	.eq-contact-us-box {
		padding: 32px 24px;
	}
	.eq-lead-wrap {
		padding: 28px 20px;
	}

	.eq-form-row {
		grid-template-columns: 1fr;
	}

	.eq-form-footer {
		flex-direction: column;
		align-items: flex-start;
	}

	.eq-nav {
		flex-direction: column-reverse;
	}
	.eq-btn-ghost,
	.eq-btn-primary {
		width: 100%;
		justify-content: center;
	}

	.eq-results {
		padding: 24px 0 56px;
	}

	.eq-score-ring-wrap {
		width: 120px;
		height: 120px;
	}
	.eq-score-number {
		font-size: 30px;
	}
}

@media (max-width: 400px) {
	.eq-intro-badges {
		flex-direction: column;
		align-items: center;
	}
}
