/* =============================================================
   calculator.css — calculator spoke pages
   Loaded after composure.css. Uses Composure tokens throughout.
   ============================================================= */

.calc-page {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: clamp(32px, 5vw, 56px) var(--pad-x) clamp(40px, 5vw, 64px);
}

.calc-intro h1 {
	font-size: clamp(32px, 4.4vw, 52px);
	font-weight: 700; line-height: 1.05; letter-spacing: -0.025em;
	text-wrap: balance; margin: 0 0 14px;
}
.calc-intro .lead {
	font-size: clamp(15px, 1.4vw, 18px);
	color: var(--fg-2); max-width: 60ch;
	line-height: 1.55; margin: 0 0 32px;
}

/* main grid */
.calc-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	gap: clamp(24px, 3vw, 40px);
	align-items: start;
}
@media (max-width: 940px) {
	.calc-grid { grid-template-columns: 1fr; }
}

/* sliders panel */
.sliders-panel {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: clamp(20px, 2.5vw, 32px);
}
.sliders { display: flex; flex-direction: column; gap: 22px; }

.slider-row {
	display: grid;
	grid-template-rows: auto auto auto;
	gap: 6px;
}
.slider-head {
	display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
}
.slider-label {
	font-family: var(--display);
	font-size: 15px; font-weight: 600;
	color: var(--fg);
	letter-spacing: -0.01em;
}
.slider-value {
	font-family: var(--display);
	font-size: 18px; font-weight: 700;
	color: var(--accent);
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
}
.slider-hint {
	font-size: 12px; color: var(--fg-3);
}

/* custom range slider — Composure thumb */
.slider {
	-webkit-appearance: none; appearance: none;
	width: 100%; height: 22px;
	background: transparent; padding: 0; margin: 4px 0 0;
	cursor: pointer;
}
.slider:focus { outline: none; }

/* WebKit */
.slider::-webkit-slider-runnable-track {
	height: 4px;
	background: linear-gradient(to right,
		var(--accent) 0%, var(--accent) var(--fill, 0%),
		var(--line) var(--fill, 0%), var(--line) 100%);
	border-radius: 999px;
}
.slider::-webkit-slider-thumb {
	-webkit-appearance: none; appearance: none;
	width: 22px; height: 22px;
	background: var(--accent);
	border: 3px solid #fff;
	border-radius: 999px;
	box-shadow: 0 1px 3px rgba(21,33,46,.18);
	margin-top: -9px;
	transition: transform .15s var(--ease);
}
.slider::-webkit-slider-thumb:hover { transform: scale(1.08); }
.slider:focus-visible::-webkit-slider-thumb {
	outline: 3px solid var(--accent-soft);
	outline-offset: 1px;
}

/* Firefox */
.slider::-moz-range-track {
	height: 4px;
	background: var(--line);
	border-radius: 999px;
}
.slider::-moz-range-progress {
	height: 4px;
	background: var(--accent);
	border-radius: 999px;
}
.slider::-moz-range-thumb {
	width: 22px; height: 22px;
	background: var(--accent);
	border: 3px solid #fff;
	border-radius: 999px;
	box-shadow: 0 1px 3px rgba(21,33,46,.18);
	transition: transform .15s var(--ease);
}
.slider::-moz-range-thumb:hover { transform: scale(1.08); }
.slider:focus-visible::-moz-range-thumb {
	outline: 3px solid var(--accent-soft);
	outline-offset: 1px;
}

/* focus state on the focused slider — emphasize variant focus */
.slider-row[data-focus="true"] .slider-label::after {
	content: " · focus";
	color: var(--accent);
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-left: 4px;
}

/* totals strip under sliders */
.totals {
	display: flex; justify-content: space-between; align-items: baseline;
	gap: 12px; margin-top: 26px; padding-top: 18px;
	border-top: 1px dashed var(--line);
}
.totals .label { font-size: 12px; font-weight: 600; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--fg-3); }
.totals .value {
	font-family: var(--display); font-weight: 700;
	font-size: 22px; letter-spacing: -0.02em; color: var(--fg);
}

/* results panel */
.results-panel {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: clamp(20px, 2.5vw, 32px);
	position: sticky; top: 90px;
	box-shadow: var(--shadow-lift);
}
@media (max-width: 940px) {
	.results-panel { position: static; }
}

.results-head {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
	text-transform: uppercase; color: var(--fg-3); margin-bottom: 14px;
}
.rc-live { display: inline-flex; align-items: center; gap: 7px; color: var(--accent); }
.rc-live .dot {
	width: 7px; height: 7px; border-radius: 999px; background: var(--accent);
	animation: pulse 1.6s ease-in-out infinite;
}

/* winner */
.winner {
	position: relative;
	background: var(--win-soft);
	border: 1px solid color-mix(in oklab, var(--win) 30%, transparent);
	border-radius: 12px;
	padding: 18px 18px 16px;
	margin-bottom: 14px;
}
@media (prefers-reduced-motion: no-preference) {
	.winner { animation: rise .5s var(--ease) both; }
}
@keyframes rise { from{transform:translateY(8px);} to{transform:translateY(0);} }
.winner .tag {
	position: absolute; top: -10px; left: 16px;
	background: var(--win); color: #fff;
	font-size: 10px; font-weight: 600; letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 4px 11px; border-radius: 999px;
}
.winner .row {
	display: flex; justify-content: space-between; align-items: flex-end; gap: 16px;
}
.winner .name {
	font-family: var(--display); font-weight: 700;
	font-size: 19px; letter-spacing: -0.02em; line-height: 1.15;
}
.winner .issuer { font-size: 12.5px; color: var(--fg-3); margin-top: 3px; }
.winner .val {
	font-family: var(--display); font-weight: 700;
	font-size: clamp(28px, 3.4vw, 36px); letter-spacing: -0.03em;
	color: var(--win); line-height: 1;
	font-variant-numeric: tabular-nums;
}
.winner .per {
	font-size: 12px; color: var(--fg-3); text-align: right; margin-top: 4px;
	font-variant-numeric: tabular-nums;
}
.winner .breakdown {
	margin-top: 14px; padding-top: 12px;
	border-top: 1px dashed color-mix(in oklab, var(--win) 28%, transparent);
	font-size: 12.5px; color: var(--fg-2); line-height: 1.55;
}
.winner .breakdown b { color: var(--win); font-weight: 700; }

/* ranked rows */
.ranked { display: flex; flex-direction: column; gap: 7px; }
.rrow {
	display: flex; justify-content: space-between; align-items: center;
	padding: 12px 16px;
	border: 1px solid var(--line-2);
	border-radius: 10px;
	background: var(--surface);
}
.rrow .name { font-weight: 600; font-size: 14.5px; line-height: 1.25; }
.rrow .issuer { font-size: 12px; color: var(--fg-3); margin-top: 2px; }
.rrow .val { font-weight: 600; font-size: 15px; font-variant-numeric: tabular-nums; }
.rrow .per { font-size: 11.5px; color: var(--fg-3); text-align: right;
	font-variant-numeric: tabular-nums; }
.rrow .right { text-align: right; }

.results-foot {
	display: flex; justify-content: space-between; align-items: center;
	border-top: 1px dashed var(--line);
	margin-top: 14px; padding-top: 12px;
	font-size: 11.5px; color: var(--fg-3);
}
.results-foot a { color: var(--accent); text-decoration: none; font-weight: 600; }
.results-foot a:hover { text-decoration: underline; }

/* related calculators strip */
.related-strip { background: var(--surface);
	border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.related-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
@media (max-width: 900px) { .related-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .related-grid { grid-template-columns: 1fr; } }
.rel-card {
	display: flex; flex-direction: column;
	background: var(--bg); border: 1px solid var(--line);
	border-radius: 12px; padding: 16px 18px;
	text-decoration: none; color: inherit;
	transition: border-color .2s, transform var(--ease) .2s;
}
.rel-card:hover { border-color: var(--accent-line); transform: translateY(-2px); }
.rel-card .ctag {
	display: inline-flex; align-self: flex-start; align-items: center;
	font-size: 10px; font-weight: 600; letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--accent); background: var(--accent-soft);
	border-radius: 999px; padding: 3px 9px; margin-bottom: 12px;
}
.rel-card h3 { font-size: 16px; font-weight: 700; letter-spacing: -0.01em;
	line-height: 1.2; margin: 0; }
.rel-card p { font-size: 13px; color: var(--fg-2); margin: 6px 0 0; line-height: 1.5; }

/* FAQ block */
.faq dl { margin: 0; }
.faq dt {
	font-family: var(--display); font-weight: 700;
	font-size: 16px; color: var(--fg);
	margin: 22px 0 6px;
}
.faq dt:first-child { margin-top: 0; }
.faq dd { font-size: 14px; color: var(--fg-2); margin: 0; line-height: 1.55; }
