/*!
 * Tobalt Self-Evaluation — public styles.
 * Civic Warmth palette: teal + amber + warm white.
 *
 * Author: Tobalt — https://tobalt.lt
 */

.tobalt-se {
	--se-primary: #0D4F5C;
	--se-primary-lt: #1A7A8A;
	--se-primary-soft: rgba(13, 79, 92, 0.12);
	--se-accent: #F5A623;
	--se-accent-lt: #FDE8B8;
	--se-bg: #FAF9F6;
	--se-surface: #FFFFFF;
	--se-text: #1A1A1A;
	--se-muted: #6B7280;
	--se-border: #E7E2D6;
	--se-success: #16A34A;
	--se-success-soft: rgba(22, 163, 74, 0.08);
	--se-danger: #DC2626;
	--se-danger-soft: rgba(220, 38, 38, 0.08);
	--se-radius: 12px;
	--se-radius-pill: 100px;
	--se-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	--se-shadow-lg: 0 8px 32px rgba(13, 79, 92, 0.1);
	--se-font-head: 'Instrument Serif', Georgia, serif;
	--se-font-body: 'DM Sans', system-ui, -apple-system, sans-serif;

	font-family: var(--se-font-body);
	color: var(--se-text);
	background: var(--se-bg);
	line-height: 1.55;
	max-width: 1100px;
	margin: 0 auto;
	padding: 32px 24px 64px;
}

.tobalt-se *,
.tobalt-se *::before,
.tobalt-se *::after {
	box-sizing: border-box;
}

/* Typography ---------------------------------------------------------- */
.tobalt-se__title {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: clamp(2rem, 4vw, 3.2rem);
	line-height: 1.05;
	margin: 0 0 16px;
	color: var(--se-primary);
}

.tobalt-se__h2 {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: clamp(1.4rem, 2.4vw, 2rem);
	margin: 48px 0 16px;
	color: var(--se-primary);
}

.tobalt-se__eyebrow {
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--se-primary-lt);
	margin: 0 0 12px;
}

.tobalt-se__lead {
	font-size: 1.1rem;
	color: var(--se-muted);
	max-width: 640px;
	margin: 0;
}

.tobalt-se__divider {
	display: inline-block;
	margin: 0 6px;
	color: var(--se-muted);
}

.tobalt-se__muted {
	color: var(--se-muted);
}

/* Hero ---------------------------------------------------------------- */
.tobalt-se__hero {
	margin-bottom: 40px;
}

.tobalt-se__shell {
	max-width: 560px;
	margin: 0 auto;
}

/* Forms --------------------------------------------------------------- */
.tobalt-se__form,
.tobalt-se__form-wizard {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.tobalt-se__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.tobalt-se__field label,
.tobalt-se__field > span {
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--se-primary);
}

.tobalt-se__field input,
.tobalt-se__field select,
.tobalt-se__field textarea {
	font: inherit;
	width: 100%;
	padding: 12px 14px;
	border: 1.5px solid var(--se-border);
	border-radius: 8px;
	background: var(--se-surface);
	color: var(--se-text);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.tobalt-se__field input:focus-visible,
.tobalt-se__field select:focus-visible,
.tobalt-se__field textarea:focus-visible {
	outline: none;
	border-color: var(--se-primary);
	box-shadow: 0 0 0 3px var(--se-primary-soft);
}

.tobalt-se__field--inline {
	margin-top: 12px;
}

.tobalt-se__field--inline span {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--se-muted);
}

.tobalt-se__fineprint {
	font-size: 0.85rem;
	color: var(--se-muted);
	margin: 0;
}

/* Buttons ------------------------------------------------------------- */
.tobalt-se__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 12px 24px;
	font: inherit;
	font-weight: 600;
	border-radius: var(--se-radius-pill);
	border: 2px solid var(--se-primary);
	background: transparent;
	color: var(--se-primary);
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, transform 0.1s ease;
	text-decoration: none;
}

.tobalt-se__btn:hover,
.tobalt-se__btn:focus-visible {
	background: var(--se-primary);
	color: #fff;
	outline: none;
}

.tobalt-se__btn--primary {
	background: var(--se-primary);
	color: #fff;
}

.tobalt-se__btn--primary:hover,
.tobalt-se__btn--primary:focus-visible {
	background: var(--se-primary-lt);
}

.tobalt-se__btn--ghost {
	border-color: var(--se-border);
	color: var(--se-primary);
}

.tobalt-se__btn:active {
	transform: translateY(1px);
}

.tobalt-se__btn[disabled] {
	opacity: 0.5;
	pointer-events: none;
}

.tobalt-se__textlink {
	color: var(--se-muted);
	text-decoration: underline;
	font-size: 0.9rem;
}

/* Demo magic-link banner --------------------------------------------- */
.tobalt-se__demo-link {
	background: var(--se-accent-lt);
	border: 1.5px dashed var(--se-accent);
	border-radius: var(--se-radius);
	padding: 20px 24px;
	margin-bottom: 24px;
	text-align: center;
}

.tobalt-se__demo-link-eyebrow {
	font-size: 0.85rem;
	font-weight: 600;
	color: #6B4500;
	margin: 0 0 12px;
}

.tobalt-se__demo-link .tobalt-se__btn {
	background: var(--se-accent);
	border-color: var(--se-accent);
	color: #fff;
}

.tobalt-se__demo-link .tobalt-se__btn:hover,
.tobalt-se__demo-link .tobalt-se__btn:focus-visible {
	background: #d68b18;
	border-color: #d68b18;
}

.tobalt-se__demo-link-url {
	margin: 12px 0 0;
	word-break: break-all;
}

.tobalt-se__demo-link-url code {
	font-size: 0.75rem;
	color: #6B4500;
	background: rgba(255, 255, 255, 0.6);
	padding: 4px 8px;
	border-radius: 4px;
	display: inline-block;
}

/* Alerts -------------------------------------------------------------- */
.tobalt-se__alert {
	padding: 14px 16px;
	border-radius: 8px;
	margin-bottom: 24px;
	font-size: 0.95rem;
}

.tobalt-se__alert--warn {
	background: var(--se-accent-lt);
	color: #6B4500;
}

.tobalt-se__result {
	padding: 14px 16px;
	border-radius: 8px;
	margin-top: 16px;
	background: var(--se-success-soft);
	color: var(--se-success);
	font-weight: 600;
}

.tobalt-se__result.is-error {
	background: var(--se-danger-soft);
	color: var(--se-danger);
}

/* Wizard progress ----------------------------------------------------- */
.tobalt-se__wizard-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 24px;
	margin-bottom: 24px;
}

.tobalt-se__save-status {
	font-size: 0.85rem;
	color: var(--se-muted);
}

.tobalt-se__progress {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 8px;
	background: var(--se-surface);
	padding: 8px;
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow);
	margin-bottom: 32px;
	position: sticky;
	top: 12px;
	z-index: 10;
}

.tobalt-se__progress-seg {
	background: transparent;
	border: 0;
	padding: 12px 8px;
	border-radius: 8px;
	cursor: pointer;
	font: inherit;
	color: var(--se-muted);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	transition: background 0.15s, color 0.15s;
	text-align: center;
}

.tobalt-se__progress-seg:hover {
	background: var(--se-bg);
	color: var(--se-primary);
}

.tobalt-se__progress-seg.is-complete {
	color: var(--se-primary);
}

.tobalt-se__progress-seg.is-active {
	background: var(--se-primary);
	color: #fff;
}

.tobalt-se__progress-num {
	font-family: var(--se-font-head);
	font-size: 1.4rem;
}

.tobalt-se__progress-label {
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* Wizard step --------------------------------------------------------- */
.tobalt-se__step {
	display: none;
	background: var(--se-surface);
	border-radius: var(--se-radius);
	padding: 32px;
	box-shadow: var(--se-shadow);
}

.tobalt-se__step.is-active {
	display: block;
}

.tobalt-se__step-head {
	border-bottom: 1px solid var(--se-border);
	padding-bottom: 16px;
	margin-bottom: 24px;
}

.tobalt-se__step-num {
	font-family: var(--se-font-head);
	font-size: 3rem;
	color: var(--se-accent);
	margin: 0;
	line-height: 1;
}

.tobalt-se__step-title {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	margin: 4px 0 0;
	color: var(--se-primary);
}

.tobalt-se__sub {
	margin: 32px 0;
}

.tobalt-se__sub-title {
	display: flex;
	align-items: baseline;
	gap: 12px;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--se-primary);
	margin: 0 0 16px;
	padding-bottom: 8px;
	border-bottom: 1px dashed var(--se-border);
}

.tobalt-se__sub-num {
	font-family: var(--se-font-head);
	font-size: 1.4rem;
	color: var(--se-accent);
}

.tobalt-se__crit-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.tobalt-se__crit {
	padding: 20px;
	background: var(--se-bg);
	border-radius: 8px;
	border-left: 3px solid var(--se-border);
	transition: border-left-color 0.2s ease;
}

.tobalt-se__crit:has(.tobalt-se__pill.is-selected) {
	border-left-color: var(--se-primary);
}

.tobalt-se__crit-label {
	font-size: 1.02rem;
	margin: 0 0 12px;
	color: var(--se-text);
}

.tobalt-se__hint {
	margin: 8px 0 16px;
	font-size: 0.9rem;
}

.tobalt-se__hint summary {
	cursor: pointer;
	color: var(--se-primary-lt);
	font-weight: 600;
	user-select: none;
}

.tobalt-se__hint summary::-webkit-details-marker {
	display: none;
}

.tobalt-se__hint summary::before {
	content: "▾ ";
	display: inline-block;
	transition: transform 0.15s;
}

.tobalt-se__hint[open] summary::before {
	transform: rotate(180deg);
}

.tobalt-se__hint p {
	margin: 8px 0 0;
	color: var(--se-muted);
	font-style: italic;
}

/* Pill scores --------------------------------------------------------- */
.tobalt-se__pills {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 12px 0;
}

.tobalt-se__pill {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 1px solid var(--se-border);
	background: var(--se-surface);
	border-radius: 10px;
	cursor: pointer;
	font-weight: 500;
	color: var(--se-text);
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.tobalt-se__pill input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.tobalt-se__pill-check {
	flex: 0 0 22px;
	width: 22px;
	height: 22px;
	border: 1.5px solid var(--se-border);
	border-radius: 6px;
	background: var(--se-surface);
	position: relative;
	transition: border-color 0.15s ease, background 0.15s ease;
}

.tobalt-se__pill-label {
	font-size: 0.95rem;
	line-height: 1.4;
}

.tobalt-se__pill:hover {
	border-color: var(--se-primary-lt);
	background: var(--se-primary-soft);
}

.tobalt-se__pill:hover .tobalt-se__pill-check {
	border-color: var(--se-primary-lt);
}

.tobalt-se__pill input[type="radio"]:focus-visible + .tobalt-se__pill-check {
	outline: 2px solid var(--se-primary);
	outline-offset: 2px;
}

.tobalt-se__pill.is-selected {
	border-color: var(--se-primary);
	background: var(--se-primary-soft);
	color: var(--se-primary);
}

.tobalt-se__pill.is-selected .tobalt-se__pill-check {
	background: var(--se-primary);
	border-color: var(--se-primary);
}

.tobalt-se__pill.is-selected .tobalt-se__pill-check::after {
	content: "";
	position: absolute;
	left: 7px;
	top: 3px;
	width: 6px;
	height: 11px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.tobalt-se__crit-extras {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px dashed var(--se-border);
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.tobalt-se__crit-extras textarea {
	min-height: 56px;
}

.tobalt-se__step-nav {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	margin-top: 32px;
	padding-top: 24px;
	border-top: 1px solid var(--se-border);
}

.tobalt-se__step-nav button:only-child {
	margin-left: auto;
}

.tobalt-se__review-summary {
	color: var(--se-muted);
	font-size: 1.05rem;
}

.tobalt-se__review-meta {
	display: inline-flex;
	gap: 4px;
	background: var(--se-accent-lt);
	color: #6B4500;
	padding: 8px 16px;
	border-radius: var(--se-radius-pill);
	font-weight: 600;
	margin: 16px 0;
}

/* Score / gauge ------------------------------------------------------- */
.tobalt-se__score-block {
	display: flex;
	align-items: center;
	gap: 32px;
	margin-bottom: 32px;
	padding: 32px;
	background: var(--se-surface);
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow);
}

.tobalt-se__gauge {
	position: relative;
	flex-shrink: 0;
}

.tobalt-se__gauge svg {
	transform: rotate(-90deg);
}

.tobalt-se__gauge-track {
	fill: none;
	stroke: var(--se-border);
	stroke-width: 8;
}

.tobalt-se__gauge-fill {
	fill: none;
	stroke: var(--se-primary);
	stroke-width: 8;
	stroke-linecap: round;
	transition: stroke-dashoffset 1.6s cubic-bezier(0.5, 0, 0.2, 1);
}

.tobalt-se__gauge-fill--muted {
	stroke: var(--se-primary-lt);
	opacity: 0.45;
}

.tobalt-se__gauge-num {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--se-font-head);
	font-size: 3rem;
	color: var(--se-primary);
}

.tobalt-se__score-meta {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.tobalt-se__meta-line {
	margin: 0;
	color: var(--se-muted);
}

.tobalt-se__meta-line strong {
	color: var(--se-text);
	font-size: 1.15rem;
}

/* Section bars -------------------------------------------------------- */
.tobalt-se__section-bars {
	margin-top: 40px;
}

.tobalt-se__bar-row {
	display: grid;
	grid-template-columns: 1fr 2fr auto;
	align-items: center;
	gap: 16px;
	padding: 12px 0;
	border-bottom: 1px solid var(--se-border);
}

.tobalt-se__bar-label {
	display: flex;
	align-items: baseline;
	gap: 12px;
	color: var(--se-text);
}

.tobalt-se__bar-num {
	font-family: var(--se-font-head);
	font-size: 1.4rem;
	color: var(--se-accent);
}

.tobalt-se__bar {
	background: var(--se-border);
	height: 14px;
	border-radius: 100px;
	overflow: hidden;
}

.tobalt-se__bar-fill {
	height: 100%;
	width: 0;
	background: var(--se-primary);
	border-radius: inherit;
	transition: width 1.4s cubic-bezier(0.5, 0, 0.2, 1);
}

.tobalt-se__bar.is-visible .tobalt-se__bar-fill {
	width: var(--target-w);
}

.tobalt-se__bar-value {
	font-weight: 600;
	color: var(--se-primary);
	min-width: 56px;
	text-align: right;
}

/* Comparison banner --------------------------------------------------- */
.tobalt-se__compare-banner {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
	background: var(--se-surface);
	padding: 40px 32px;
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow-lg);
	margin-bottom: 40px;
}

.tobalt-se__compare-circle {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	position: relative;
}

.tobalt-se__compare-num {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: -130px;
	font-family: var(--se-font-head);
}

.tobalt-se__compare-num strong {
	font-size: 3rem;
	color: var(--se-primary);
}

.tobalt-se__compare-tag {
	font-family: var(--se-font-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--se-muted);
}

.tobalt-se__compare-circle--before .tobalt-se__compare-num strong {
	color: var(--se-primary-lt);
}

.tobalt-se__compare-delta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	background: var(--se-accent);
	color: #fff;
	padding: 18px 24px;
	border-radius: var(--se-radius);
	font-family: var(--se-font-head);
	min-width: 140px;
	text-align: center;
}

.tobalt-se__compare-delta--down {
	background: var(--se-danger);
}

.tobalt-se__compare-delta--flat {
	background: var(--se-muted);
}

.tobalt-se__delta-arrow {
	font-size: 1.2rem;
}

.tobalt-se__delta-num {
	font-size: 2rem;
	font-weight: 600;
	line-height: 1;
}

.tobalt-se__delta-label {
	font-family: var(--se-font-body);
	font-size: 0.8rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* Section compare ----------------------------------------------------- */
.tobalt-se__sec-row {
	display: grid;
	grid-template-columns: 1.2fr 2fr auto;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid var(--se-border);
	align-items: center;
}

.tobalt-se__sec-label {
	display: flex;
	align-items: baseline;
	gap: 12px;
}

.tobalt-se__sec-bars {
	display: flex;
	flex-direction: column;
	gap: 6px;
	position: relative;
}

.tobalt-se__bar--before .tobalt-se__bar-fill {
	background: var(--se-primary-lt);
	opacity: 0.45;
}

.tobalt-se__bar-tag {
	display: block;
	font-size: 0.75rem;
	color: var(--se-muted);
	margin-top: 2px;
}

.tobalt-se__sec-delta {
	font-family: var(--se-font-head);
	font-size: 1.6rem;
	min-width: 60px;
	text-align: right;
}

.tobalt-se__sec-delta--up {
	color: var(--se-success);
}

.tobalt-se__sec-delta--down {
	color: var(--se-danger);
}

.tobalt-se__sec-delta--flat {
	color: var(--se-muted);
}

/* Diff table ---------------------------------------------------------- */
.tobalt-se__crit-detail-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 48px;
}

.tobalt-se__filter {
	display: flex;
	gap: 8px;
}

.tobalt-se__filter-btn {
	padding: 8px 16px;
	font: inherit;
	font-size: 0.9rem;
	border-radius: var(--se-radius-pill);
	border: 1.5px solid var(--se-border);
	background: var(--se-surface);
	color: var(--se-muted);
	cursor: pointer;
	transition: all 0.15s ease;
}

.tobalt-se__filter-btn:hover {
	color: var(--se-primary);
	border-color: var(--se-primary);
}

.tobalt-se__filter-btn.is-active {
	background: var(--se-primary);
	color: #fff;
	border-color: var(--se-primary);
}

.tobalt-se__table-wrap {
	overflow-x: auto;
	background: var(--se-surface);
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow);
	margin-top: 16px;
}

.tobalt-se__table {
	width: 100%;
	border-collapse: collapse;
}

.tobalt-se__table th,
.tobalt-se__table td {
	padding: 12px 16px;
	border-bottom: 1px solid var(--se-border);
	text-align: left;
	vertical-align: top;
}

.tobalt-se__table th {
	background: var(--se-bg);
	font-weight: 600;
	color: var(--se-primary);
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.tobalt-se__table td code {
	font-size: 0.8rem;
	color: var(--se-muted);
	display: block;
	margin-bottom: 4px;
}

.tobalt-se__diff-row--improved {
	background: var(--se-success-soft);
}

.tobalt-se__diff-row--declined {
	background: var(--se-danger-soft);
}

.tobalt-se__diff-row--unchanged {
	color: var(--se-muted);
}

.tobalt-se__diff-row.is-hidden {
	display: none;
}

/* Offers -------------------------------------------------------------- */
.tobalt-se__offers {
	margin-top: 48px;
}

.tobalt-se__offer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 16px;
}

.tobalt-se__offer-card {
	background: var(--se-surface);
	padding: 24px;
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow);
	display: flex;
	flex-direction: column;
	gap: 12px;
	border-top: 4px solid var(--se-accent);
}

.tobalt-se__offer-card h3 {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: 1.4rem;
	margin: 0;
	color: var(--se-primary);
}

.tobalt-se__offer-desc {
	color: var(--se-muted);
	flex: 1;
}

.tobalt-se__offer-card .tobalt-se__btn {
	align-self: flex-start;
}

/* CTA banner ---------------------------------------------------------- */
.tobalt-se__cta-banner {
	margin-top: 48px;
	padding: 24px 32px;
	background: var(--se-primary);
	color: #fff;
	border-radius: var(--se-radius);
	text-align: center;
}

.tobalt-se__cta-banner strong {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: 1.5rem;
	display: block;
	margin-bottom: 8px;
}

/* Action plan compare ------------------------------------------------- */
.tobalt-se__action-compare {
	margin-top: 48px;
}

.tobalt-se__two-col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	margin-top: 16px;
}

.tobalt-se__two-col h3 {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: 1.2rem;
	color: var(--se-primary);
	margin: 0 0 12px;
}

.tobalt-se__action-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.tobalt-se__action-list li {
	padding: 12px;
	background: var(--se-surface);
	border-radius: 8px;
	border-left: 3px solid var(--se-border);
	font-size: 0.95rem;
}

.tobalt-se__action-list li.is-new {
	border-left-color: var(--se-accent);
	background: var(--se-accent-lt);
}

.tobalt-se__action-list code {
	font-size: 0.8rem;
	color: var(--se-muted);
	display: inline-block;
	margin-right: 8px;
}

.tobalt-se__badge {
	display: inline-block;
	background: var(--se-accent);
	color: #fff;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-right: 8px;
}

/* Dashboard ----------------------------------------------------------- */
.tobalt-se__round-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	margin: 32px 0;
}

.tobalt-se__round-card {
	background: var(--se-surface);
	padding: 32px;
	border-radius: var(--se-radius);
	box-shadow: var(--se-shadow);
	display: flex;
	flex-direction: column;
	gap: 16px;
	border-top: 4px solid var(--se-border);
}

.tobalt-se__round-card.is-done {
	border-top-color: var(--se-success);
}

.tobalt-se__round-card.is-locked {
	opacity: 0.65;
}

.tobalt-se__round-card header {
	display: flex;
	align-items: baseline;
	gap: 16px;
}

.tobalt-se__round-card h2 {
	font-family: var(--se-font-head);
	font-weight: 400;
	font-size: 1.6rem;
	color: var(--se-primary);
	margin: 0;
}

.tobalt-se__round-meta {
	display: flex;
	align-items: baseline;
	gap: 12px;
}

.tobalt-se__round-meta strong {
	font-family: var(--se-font-head);
	font-size: 2rem;
	color: var(--se-primary);
}

.tobalt-se__round-meta span {
	color: var(--se-muted);
	font-size: 0.9rem;
}

.tobalt-se__dash-footer {
	margin-top: 32px;
	padding-top: 16px;
	border-top: 1px solid var(--se-border);
	text-align: center;
}

.tobalt-se__print-bar {
	margin-top: 32px;
	text-align: right;
}

/* Print styles -------------------------------------------------------- */
@media print {
	.tobalt-se__no-print,
	.tobalt-se__progress,
	.tobalt-se__step-nav,
	.tobalt-se__filter,
	.tobalt-se__cta-banner,
	.tobalt-se__print-bar {
		display: none !important;
	}
	.tobalt-se {
		max-width: 100%;
		padding: 0;
	}
	.tobalt-se__step {
		display: block !important;
		box-shadow: none;
		page-break-after: always;
	}
	.tobalt-se__hint {
		display: block !important;
	}
	.tobalt-se__hint[open],
	.tobalt-se__hint:not([open]) p {
		display: block !important;
	}
}

/* Responsive ---------------------------------------------------------- */
@media (max-width: 768px) {
	.tobalt-se {
		padding: 24px 16px 48px;
	}
	.tobalt-se__progress {
		grid-template-columns: 1fr;
		position: static;
	}
	.tobalt-se__progress-seg {
		flex-direction: row;
		justify-content: flex-start;
		gap: 12px;
	}
	.tobalt-se__progress-label {
		text-align: left;
		text-transform: none;
		letter-spacing: 0;
		font-size: 0.95rem;
		font-weight: 500;
	}
	.tobalt-se__pill {
		min-width: 100%;
	}
	.tobalt-se__compare-banner {
		grid-template-columns: 1fr;
	}
	.tobalt-se__compare-num {
		margin-top: -150px;
	}
	.tobalt-se__bar-row,
	.tobalt-se__sec-row {
		grid-template-columns: 1fr;
	}
	.tobalt-se__round-grid,
	.tobalt-se__two-col {
		grid-template-columns: 1fr;
	}
	.tobalt-se__step {
		padding: 20px;
	}
	.tobalt-se__score-block {
		flex-direction: column;
		text-align: center;
	}
}
