/* =====================================================================
 * scorecard.css — Operator Readiness Scorecard (AGCO + AGLC)
 *
 * Mirrors the tax-calculator visual system: glass cards on dark navy,
 * animated bars, gold accent, mono numerics. Light-mode parity throughout.
 *
 * Scope prefix: .ors-* (Operator Readiness Scorecard) — no global leaks.
 * Loaded only on template-tools-operator-readiness-scorecard.php.
 * ===================================================================== */

.ors {
	--ors-ink:        #0f172a;
	--ors-ink-soft:   #1e293b;
	--ors-muted:      #64748b;
	--ors-rule:       #e2e8f0;
	--ors-bg-soft:    #f8fafc;
	--ors-bg-card:    #ffffff;
	--ors-accent:     #b45309;       /* iGC brand gold */
	--ors-accent-dk:  #92400e;
	--ors-on-red:     #ef4444;       /* AGCO accent */
	--ors-on-red-soft:rgba(239, 68, 68, 0.12);
	--ors-aglc-amber: #f59e0b;       /* AGLC accent */
	--ors-aglc-amber-soft: rgba(245, 158, 11, 0.14);
	--ors-emerald:    #10b981;
	--ors-rose:       #f43f5e;
	--ors-blue:       #3b82f6;
	--ors-purple:     #a855f7;
}

/* Dark-mode (default) — inherit site dark theme vars where applicable */
html:not(.igc-light) .ors {
	--ors-ink:       rgba(255,255,255,0.92);
	--ors-ink-soft:  rgba(255,255,255,0.78);
	--ors-muted:     rgba(255,255,255,0.55);
	--ors-rule:      rgba(255,255,255,0.10);
	--ors-bg-soft:   rgba(255,255,255,0.025);
	--ors-bg-card:   rgba(255,255,255,0.035);
}

.ors-wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* ── Breadcrumbs ── */
.ors-crumbs {
	display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem;
	font-size: 0.78rem;
	color: var(--ors-muted);
	padding: 1.4rem 0 0.4rem;
}
.ors-crumbs a {
	color: var(--ors-muted);
	text-decoration: none;
	transition: color 0.12s ease;
}
.ors-crumbs a:hover { color: var(--ors-accent); }
.ors-crumbs span[aria-current] { color: var(--ors-ink); font-weight: 600; }

/* ── Hero ── */
.ors-hero { padding: 1rem 0 2.4rem; }
.ors-stamp {
	display: inline-flex; align-items: center; gap: 0.45rem;
	padding: 0.32rem 0.7rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 999px;
	font: 600 0.72rem/1 "DM Mono", monospace;
	letter-spacing: 0.03em;
	color: var(--ors-muted);
	margin-bottom: 1.3rem;
}
.ors-stamp__dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: var(--ors-emerald);
	animation: orsPulse 2s ease-in-out infinite;
}
@keyframes orsPulse { 0%,100%{opacity:1;} 50%{opacity:0.4;} }
.ors-hero__eyebrow {
	font: 600 0.7rem/1 "DM Mono", monospace;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ors-accent);
	margin-bottom: 0.5rem;
}
.ors-hero__h1 {
	font: 700 2.2rem/1.1 "DM Sans", system-ui, sans-serif;
	color: var(--ors-ink);
	letter-spacing: -0.02em;
	margin: 0 0 1rem;
}
.ors-hero__h1-sub {
	color: var(--ors-muted);
	font-weight: 600;
	font-size: 0.62em;
	letter-spacing: -0.01em;
}
.ors-hero__lede {
	font: 400 1.05rem/1.6 "DM Sans", sans-serif;
	color: var(--ors-ink-soft);
	max-width: 820px;
	margin: 0 0 1.7rem;
}

/* ── Jurisdiction pills ── */
.ors-jur-pills {
	display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
	margin-bottom: 1.4rem;
}
@media (max-width: 760px) { .ors-jur-pills { grid-template-columns: 1fr; } }
.ors-jur-pill {
	display: grid; grid-template-columns: auto 1fr; gap: 1rem;
	padding: 1rem 1.1rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 12px;
	border-left: 3px solid var(--ors-jpill-accent, var(--ors-accent));
}
.ors-jur-pill__flag {
	font-size: 2rem; line-height: 1;
}
.ors-jur-pill__title {
	font: 700 0.95rem/1.3 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin-bottom: 0.18rem;
}
.ors-jur-pill__sub {
	font-size: 0.82rem;
	color: var(--ors-ink-soft);
	line-height: 1.45;
	margin-bottom: 0.3rem;
}
.ors-jur-pill__since {
	font: 500 0.72rem/1.3 "DM Mono", monospace;
	color: var(--ors-muted);
}
.ors-jur-pill__since a { color: var(--ors-jpill-accent, var(--ors-accent)); text-decoration: none; }
.ors-jur-pill__since a:hover { text-decoration: underline; }

/* ── Disclaimer ── */
.ors-disclaim {
	display: grid; grid-template-columns: auto 1fr; gap: 0.7rem;
	padding: 0.9rem 1.1rem;
	background: rgba(245, 158, 11, 0.08);
	border: 1px solid rgba(245, 158, 11, 0.30);
	border-radius: 10px;
	font-size: 0.85rem;
	color: var(--ors-ink-soft);
	line-height: 1.55;
}
.ors-disclaim__icon {
	font: 700 1.1rem/1 sans-serif;
	color: #d97706;
	width: 22px; height: 22px;
	display: inline-flex; align-items: center; justify-content: center;
	background: rgba(245, 158, 11, 0.18);
	border-radius: 50%;
}
.ors-disclaim strong { color: var(--ors-ink); font-weight: 700; }
.ors-disclaim--bottom {
	display: block;
	font-size: 0.78rem;
	color: var(--ors-muted);
	line-height: 1.6;
	padding: 1rem 1.2rem;
	background: var(--ors-bg-card);
	border-color: var(--ors-rule);
}
.ors-disclaim--bottom strong { color: var(--ors-ink); }

html.igc-light .ors-disclaim { background: #fffbeb; border-color: #fde68a; }
html.igc-light .ors-disclaim--bottom { background: #f8fafc; border-color: #e2e8f0; }

/* ── Stepper ── */
.ors-app { padding: 0 0 2.5rem; }
.ors-stepper {
	display: flex; gap: 0.4rem;
	margin: 1.6rem 0 1.4rem;
	padding: 0.35rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 12px;
	overflow-x: auto;
}
.ors-step {
	flex: 1 1 auto;
	display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
	padding: 0.6rem 0.9rem;
	border-radius: 8px;
	font: 600 0.82rem/1 "DM Sans", sans-serif;
	color: var(--ors-muted);
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
	white-space: nowrap;
}
.ors-step:hover { color: var(--ors-ink); background: var(--ors-bg-soft); }
.ors-step.is-active {
	background: linear-gradient(135deg, rgba(180, 83, 9, 0.16), rgba(245, 158, 11, 0.12));
	color: var(--ors-accent);
	border: 1px solid rgba(180, 83, 9, 0.30);
}
html:not(.igc-light) .ors-step.is-active {
	background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(180, 83, 9, 0.12));
	color: #fbbf24;
	border-color: rgba(245, 158, 11, 0.40);
}
.ors-step__num {
	display: inline-flex; align-items: center; justify-content: center;
	width: 20px; height: 20px; border-radius: 50%;
	background: var(--ors-bg-soft);
	font: 700 0.72rem/1 "DM Mono", monospace;
}
.ors-step.is-active .ors-step__num { background: rgba(255,255,255,0.20); color: inherit; }

/* ── App root + cards ── */
.ors-app-root { display: flex; flex-direction: column; gap: 1.4rem; }
.ors-card {
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 14px;
	padding: 1.5rem 1.6rem 1.6rem;
}
.ors-card__head {
	display: flex; align-items: baseline; justify-content: space-between;
	gap: 1rem; flex-wrap: wrap;
	margin-bottom: 1rem;
	padding-bottom: 0.9rem;
	border-bottom: 1px solid var(--ors-rule);
}
.ors-card__title {
	font: 700 1.2rem/1.25 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin: 0 0 0.2rem;
}
.ors-card__sub {
	font-size: 0.85rem;
	color: var(--ors-muted);
	margin: 0;
}
.ors-card__meta {
	font: 500 0.78rem/1.3 "DM Mono", monospace;
	color: var(--ors-muted);
}

/* ── Step 1: Profile form ── */
.ors-profile-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.1rem;
}
.ors-field { display: flex; flex-direction: column; gap: 0.5rem; }
.ors-field__lbl {
	font: 600 0.85rem/1.3 "DM Sans", sans-serif;
	color: var(--ors-ink);
}
.ors-field select {
	font: 500 0.92rem/1.3 "DM Sans", sans-serif;
	padding: 0.62rem 0.8rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
	color: var(--ors-ink);
	width: 100%;
	cursor: pointer;
}
.ors-field select:focus { outline: 2px solid var(--ors-accent); outline-offset: 1px; }
.ors-chip-row {
	display: flex; flex-wrap: wrap; gap: 0.4rem;
}
.ors-chip {
	display: inline-flex; align-items: center; gap: 0.35rem;
	padding: 0.38rem 0.7rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 999px;
	font: 600 0.8rem/1 "DM Sans", sans-serif;
	color: var(--ors-muted);
	cursor: pointer;
	transition: all 0.12s ease;
}
.ors-chip:hover { color: var(--ors-ink); border-color: var(--ors-muted); }
.ors-chip[aria-pressed="true"] {
	background: linear-gradient(135deg, rgba(180,83,9,0.18), rgba(245,158,11,0.10));
	border-color: rgba(180,83,9,0.45);
	color: var(--ors-accent);
}
html:not(.igc-light) .ors-chip[aria-pressed="true"] { color: #fbbf24; border-color: rgba(245,158,11,0.50); }

/* ── Step 2: Questions ── */
.ors-q-list { display: flex; flex-direction: column; gap: 1rem; margin-top: 0.4rem; }
.ors-q {
	padding: 1.1rem 1.2rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 10px;
}
.ors-q__top {
	display: flex; align-items: baseline; gap: 0.8rem; margin-bottom: 0.6rem;
}
.ors-q__num {
	font: 700 0.72rem/1 "DM Mono", monospace;
	color: var(--ors-muted);
	background: var(--ors-bg-soft);
	padding: 0.32rem 0.55rem;
	border-radius: 5px;
	min-width: 50px;
	text-align: center;
}
.ors-q__dim {
	font: 600 0.7rem/1 "DM Mono", monospace;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--ors-accent);
}
.ors-q__prompt {
	font: 500 0.98rem/1.5 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin: 0 0 0.5rem;
}
.ors-q__ctx {
	font-size: 0.82rem;
	color: var(--ors-muted);
	line-height: 1.55;
	margin: 0 0 0.85rem;
	padding-left: 0.8rem;
	border-left: 2px solid var(--ors-rule);
}
.ors-q__answer { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.ors-q__opt {
	flex: 1 1 calc(25% - 0.4rem);
	min-width: 110px;
	padding: 0.55rem 0.7rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
	font: 600 0.85rem/1.2 "DM Sans", sans-serif;
	color: var(--ors-ink-soft);
	cursor: pointer;
	transition: all 0.12s ease;
	text-align: center;
	display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
}
.ors-q__opt:hover { border-color: var(--ors-muted); }
.ors-q__opt[aria-pressed="true"][data-v="yes"]     { background: rgba(16,185,129,0.15);  border-color: rgba(16,185,129,0.45);  color: #047857; }
.ors-q__opt[aria-pressed="true"][data-v="partial"] { background: rgba(245,158,11,0.15);  border-color: rgba(245,158,11,0.45);  color: #92400e; }
.ors-q__opt[aria-pressed="true"][data-v="no"]      { background: rgba(244,63,94,0.15);   border-color: rgba(244,63,94,0.45);   color: #b91c1c; }
.ors-q__opt[aria-pressed="true"][data-v="na"]      { background: var(--ors-rule);        border-color: var(--ors-muted);       color: var(--ors-ink); }
html:not(.igc-light) .ors-q__opt[aria-pressed="true"][data-v="yes"]     { color: #6ee7b7; }
html:not(.igc-light) .ors-q__opt[aria-pressed="true"][data-v="partial"] { color: #fbbf24; }
html:not(.igc-light) .ors-q__opt[aria-pressed="true"][data-v="no"]      { color: #fda4af; }
.ors-q__details {
	margin-top: 0.7rem;
	font-size: 0.78rem;
	color: var(--ors-muted);
	display: flex; flex-wrap: wrap; gap: 0.4rem 0.9rem;
}
.ors-q__cite { display: inline-flex; align-items: center; gap: 0.3rem; }
.ors-q__cite strong { color: var(--ors-ink-soft); font-weight: 600; font-family: "DM Mono", monospace; font-size: 0.74rem; }
.ors-q__cite a { color: var(--ors-accent-dk); text-decoration: none; }
html:not(.igc-light) .ors-q__cite a { color: #fbbf24; }
.ors-q-actions {
	display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: space-between; align-items: center;
	margin-top: 1.2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ors-rule);
}
.ors-q-progress {
	font: 600 0.85rem/1 "DM Mono", monospace;
	color: var(--ors-muted);
}
.ors-q-progress strong { color: var(--ors-ink); }

/* ── Step 3: Results ── */
.ors-result-head {
	display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
	margin-bottom: 1.4rem;
}
@media (max-width: 760px) { .ors-result-head { grid-template-columns: 1fr; } }
.ors-bigscore {
	padding: 1.2rem 1.4rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 12px;
	border-top: 3px solid var(--ors-bigscore-accent, var(--ors-accent));
	display: grid; grid-template-columns: auto 1fr; gap: 1rem; align-items: center;
}
.ors-bigscore__flag { font-size: 2.3rem; }
.ors-bigscore__lbl {
	font: 600 0.7rem/1 "DM Mono", monospace;
	text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--ors-muted);
	margin-bottom: 0.3rem;
}
.ors-bigscore__name {
	font: 700 0.95rem/1.2 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin-bottom: 0.4rem;
}
.ors-bigscore__num {
	font: 700 2.4rem/1 "DM Sans", sans-serif;
	color: var(--ors-bigscore-accent, var(--ors-accent));
	letter-spacing: -0.02em;
	margin-bottom: 0.3rem;
}
.ors-bigscore__band {
	font: 600 0.72rem/1 "DM Mono", monospace;
	text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--ors-muted);
}
.ors-bigscore__band--green { color: #047857; }
.ors-bigscore__band--amber { color: #b45309; }
.ors-bigscore__band--red   { color: #b91c1c; }
html:not(.igc-light) .ors-bigscore__band--green { color: #6ee7b7; }
html:not(.igc-light) .ors-bigscore__band--amber { color: #fbbf24; }
html:not(.igc-light) .ors-bigscore__band--red   { color: #fda4af; }
.ors-bigscore__sub {
	margin-top: 0.4rem;
	font-size: 0.78rem;
	color: var(--ors-muted);
	line-height: 1.45;
}

/* Dimension bars */
.ors-dim-grid { display: grid; gap: 0.55rem; margin-top: 1rem; }
.ors-dim-row {
	display: grid;
	grid-template-columns: minmax(150px, 1fr) 2fr minmax(56px, auto);
	align-items: center; gap: 0.8rem;
	padding: 0.5rem 0.6rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
}
.ors-dim-row__lbl {
	font: 600 0.85rem/1.3 "DM Sans", sans-serif;
	color: var(--ors-ink);
	display: flex; align-items: center; gap: 0.4rem;
}
.ors-dim-bar { position: relative; height: 9px; background: var(--ors-rule); border-radius: 100px; overflow: hidden; }
.ors-dim-bar__fill {
	position: absolute; top: 0; left: 0; height: 100%;
	border-radius: 100px;
	transition: width 0.6s cubic-bezier(0.4, 0.0, 0.2, 1);
}
.ors-dim-bar__fill--green { background: linear-gradient(90deg, #10b981, #34d399); }
.ors-dim-bar__fill--amber { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.ors-dim-bar__fill--red   { background: linear-gradient(90deg, #f43f5e, #fb7185); }
.ors-dim-row__pct {
	font: 700 0.85rem/1 "DM Mono", monospace;
	text-align: right;
	color: var(--ors-ink);
}

/* Critical gaps + quick wins */
.ors-gap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1.4rem; }
@media (max-width: 880px) { .ors-gap-grid { grid-template-columns: 1fr; } }
.ors-gap-card {
	padding: 1rem 1.1rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 10px;
}
.ors-gap-card h3 {
	font: 700 0.95rem/1.25 "DM Sans", sans-serif;
	margin: 0 0 0.8rem;
	color: var(--ors-ink);
}
.ors-gap-list { display: flex; flex-direction: column; gap: 0.6rem; }
.ors-gap {
	padding: 0.65rem 0.8rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-left: 3px solid var(--ors-gap-accent, var(--ors-rose));
	border-radius: 6px;
}
.ors-gap--qw { --ors-gap-accent: var(--ors-emerald); }
.ors-gap__top {
	display: flex; align-items: baseline; gap: 0.6rem; flex-wrap: wrap;
	margin-bottom: 0.3rem;
}
.ors-gap__flag {
	font: 700 0.66rem/1 "DM Mono", monospace;
	text-transform: uppercase; letter-spacing: 0.05em;
	color: var(--ors-rose);
	background: rgba(244,63,94,0.10);
	padding: 0.18rem 0.42rem;
	border-radius: 4px;
}
.ors-gap--qw .ors-gap__flag { color: var(--ors-emerald); background: rgba(16,185,129,0.10); }
.ors-gap__title {
	font: 600 0.88rem/1.35 "DM Sans", sans-serif;
	color: var(--ors-ink);
}
.ors-gap__cite {
	font-size: 0.74rem;
	color: var(--ors-muted);
	line-height: 1.45;
	margin: 0.25rem 0 0;
}
.ors-gap__cite a { color: var(--ors-accent-dk); text-decoration: none; }
html:not(.igc-light) .ors-gap__cite a { color: #fbbf24; }
.ors-gap__cite strong { font-family: "DM Mono", monospace; font-size: 0.7rem; color: var(--ors-ink-soft); font-weight: 600; }
.ors-gap__effort {
	font-size: 0.73rem;
	color: var(--ors-muted);
	font-style: italic;
	margin: 0.3rem 0 0;
}

/* Cost-of-entry tile */
.ors-cost {
	margin-top: 1.4rem;
	padding: 1.1rem 1.3rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 12px;
}
.ors-cost h3 {
	font: 700 1rem/1.25 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin: 0 0 0.4rem;
}
.ors-cost__sub {
	font-size: 0.78rem;
	color: var(--ors-muted);
	margin: 0 0 0.9rem;
}
.ors-cost-grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem;
}
@media (max-width: 720px) { .ors-cost-grid { grid-template-columns: 1fr; } }
.ors-cost-card {
	padding: 0.85rem 1rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
	border-left: 3px solid var(--ors-cost-accent, var(--ors-accent));
}
.ors-cost-card__lbl {
	font: 600 0.7rem/1 "DM Mono", monospace;
	text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--ors-muted);
	margin-bottom: 0.35rem;
}
.ors-cost-card__val {
	font: 700 1.35rem/1.1 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin-bottom: 0.3rem;
}
.ors-cost-card__val--pending {
	color: var(--ors-muted);
	font-size: 1.05rem;
}
.ors-cost-card__note {
	font-size: 0.76rem;
	color: var(--ors-muted);
	line-height: 1.5;
}

/* ── Step 4: Deltas ── */
.ors-delta-list { display: flex; flex-direction: column; gap: 0.85rem; }
.ors-delta {
	padding: 1rem 1.1rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 10px;
}
.ors-delta__topic {
	font: 700 0.95rem/1.3 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin-bottom: 0.6rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--ors-rule);
}
.ors-delta__cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; }
@media (max-width: 720px) { .ors-delta__cmp { grid-template-columns: 1fr; } }
.ors-delta__col {
	padding: 0.65rem 0.8rem;
	background: var(--ors-bg-card);
	border-radius: 6px;
	border-left: 3px solid var(--ors-delta-accent, var(--ors-accent));
	font-size: 0.85rem;
	line-height: 1.5;
	color: var(--ors-ink-soft);
}
.ors-delta__col--agco { --ors-delta-accent: var(--ors-on-red); }
.ors-delta__col--aglc { --ors-delta-accent: var(--ors-aglc-amber); }
.ors-delta__col-head {
	font: 700 0.72rem/1 "DM Mono", monospace;
	text-transform: uppercase; letter-spacing: 0.08em;
	color: var(--ors-delta-accent);
	margin-bottom: 0.4rem;
}
.ors-delta__resolve {
	margin-top: 0.55rem;
	padding: 0.55rem 0.75rem;
	background: rgba(180,83,9,0.08);
	border-radius: 6px;
	font-size: 0.82rem;
	color: var(--ors-ink-soft);
	line-height: 1.5;
}
.ors-delta__resolve strong { color: var(--ors-accent-dk); font-weight: 700; }
html:not(.igc-light) .ors-delta__resolve strong { color: #fbbf24; }

/* ── Toolbar: share + reset + download ── */
.ors-toolbar {
	display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: flex-end; align-items: center;
	margin-top: 1.2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--ors-rule);
}
.ors-btn {
	display: inline-flex; align-items: center; gap: 0.45rem;
	padding: 0.55rem 0.95rem;
	background: var(--ors-bg-soft);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
	font: 600 0.82rem/1 "DM Sans", sans-serif;
	color: var(--ors-ink);
	cursor: pointer;
	transition: all 0.12s ease;
	text-decoration: none;
}
.ors-btn:hover { border-color: var(--ors-accent); color: var(--ors-accent); }
.ors-btn--primary {
	background: linear-gradient(135deg, var(--ors-accent), #d97706);
	border-color: var(--ors-accent);
	color: #fff;
}
.ors-btn--primary:hover { background: linear-gradient(135deg, var(--ors-accent-dk), var(--ors-accent)); color: #fff; }
.ors-btn--ghost { background: transparent; }
.ors-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Section + FAQ ── */
.ors-section { padding: 2rem 0; }
.ors-section--alt { background: linear-gradient(180deg, transparent 0%, var(--ors-bg-soft) 100%); }
.ors-section__title {
	font: 700 1.4rem/1.2 "DM Sans", sans-serif;
	color: var(--ors-ink);
	margin: 0 0 1.2rem;
}
.ors-faq {
	padding: 0.7rem 1rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 8px;
	margin-bottom: 0.5rem;
}
.ors-faq summary {
	font: 600 0.95rem/1.4 "DM Sans", sans-serif;
	color: var(--ors-ink);
	cursor: pointer;
	list-style: none;
	padding: 0.2rem 0;
	display: flex; align-items: center; gap: 0.5rem;
}
.ors-faq summary::-webkit-details-marker { display: none; }
.ors-faq summary::before {
	content: "+";
	font: 400 1.3rem/1 "DM Sans", sans-serif;
	color: var(--ors-accent);
	transition: transform 0.15s ease;
	display: inline-block;
	width: 18px;
}
.ors-faq[open] summary::before { content: "−"; }
.ors-faq p {
	margin: 0.6rem 0 0;
	padding: 0.6rem 0 0;
	border-top: 1px solid var(--ors-rule);
	font-size: 0.88rem;
	color: var(--ors-ink-soft);
	line-height: 1.6;
}

/* ── Related ── */
.ors-related-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1.3rem; margin-top: 1.4rem; }
@media (max-width: 760px) { .ors-related-grid { grid-template-columns: 1fr; } }
.ors-related {
	padding: 1.2rem 1.3rem;
	background: var(--ors-bg-card);
	border: 1px solid var(--ors-rule);
	border-radius: 12px;
}
.ors-related h3 {
	font: 700 1rem/1.25 "DM Sans", sans-serif;
	margin: 0 0 0.7rem;
	color: var(--ors-ink);
}
.ors-related ul { margin: 0; padding-left: 1.2rem; }
.ors-related li { margin-bottom: 0.3rem; }
.ors-related a { color: var(--ors-accent-dk); text-decoration: none; }
html:not(.igc-light) .ors-related a { color: #fbbf24; }
.ors-related a:hover { text-decoration: underline; }
.ors-related blockquote {
	font: 500 0.85rem/1.55 "DM Mono", monospace;
	color: var(--ors-ink-soft);
	background: var(--ors-bg-soft);
	border-left: 3px solid var(--ors-accent);
	padding: 0.7rem 0.85rem;
	border-radius: 0 6px 6px 0;
	margin: 0.5rem 0 0;
}

/* ── No-script fallback ── */
.ors-noscript {
	padding: 1.4rem 1.5rem;
	background: rgba(244,63,94,0.05);
	border: 1px solid rgba(244,63,94,0.20);
	border-radius: 10px;
}
.ors-noscript h2 { color: var(--ors-rose); margin-bottom: 0.5rem; }
.ors-noscript a { color: var(--ors-accent-dk); }

/* ── Hidden by default, JS toggles ── */
[data-ors-step] { display: none; }
[data-ors-step].is-current { display: block; }
