/**
 * Chamber Fusion — Spoke Dashboard (scoped, theme-independent).
 *
 * Namespaced under .cf-spoke so the dashboard renders as a clean SaaS surface
 * on any theme. Brand colors fall back gracefully when the plugin's brand CSS
 * variables are absent.
 *
 * @since 1.45.0
 */

.cf-spoke {
	--cf-sp-accent: var( --cf-brand-primary, #2563eb );
	--cf-sp-accent-ink: var( --cf-brand-on-primary, #ffffff );
	--cf-sp-ink: #1e293b;
	--cf-sp-muted: #64748b;
	--cf-sp-line: #e2e8f0;
	--cf-sp-bg: #f8fafc;
	--cf-sp-ok: #16a34a;
	--cf-sp-radius: 14px;

	box-sizing: border-box;
	max-width: 820px;
	margin: 0 auto;
	padding: 16px;
	color: var( --cf-sp-ink );
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	line-height: 1.5;
}

.cf-spoke *,
.cf-spoke *::before,
.cf-spoke *::after {
	box-sizing: border-box;
}

.cf-spoke__card {
	background: #fff;
	border: 1px solid var( --cf-sp-line );
	border-radius: var( --cf-sp-radius );
	box-shadow: 0 10px 30px -12px rgba( 15, 23, 42, 0.18 );
	padding: 28px;
}

/* ── Header + switcher ──────────────────────────────────────────────── */
.cf-spoke__header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 18px;
}

.cf-spoke__eyebrow {
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var( --cf-sp-muted );
}

.cf-spoke__hubname {
	margin: 4px 0 0;
	font-size: 26px;
	font-weight: 800;
	line-height: 1.2;
}

.cf-spoke__switcher {
	display: flex;
	align-items: center;
	gap: 8px;
	background: var( --cf-sp-bg );
	border: 1px solid var( --cf-sp-line );
	border-radius: 10px;
	padding: 8px 10px;
}

.cf-spoke__switcher label {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var( --cf-sp-muted );
}

.cf-spoke__switcher select {
	border: 1px solid var( --cf-sp-line );
	border-radius: 8px;
	padding: 6px 8px;
	font-size: 14px;
	background: #fff;
	max-width: 220px;
}

/* ── Tabs ───────────────────────────────────────────────────────────── */
.cf-spoke__tabs {
	display: flex;
	gap: 4px;
	border-bottom: 2px solid var( --cf-sp-line );
	margin-bottom: 22px;
}

.cf-spoke__tab {
	padding: 12px 18px;
	font-size: 15px;
	font-weight: 600;
	color: var( --cf-sp-muted );
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: color 0.15s, border-color 0.15s;
}

.cf-spoke__tab:hover {
	color: var( --cf-sp-ink );
}

.cf-spoke__tab.cf-is-active {
	color: var( --cf-sp-accent );
	border-bottom-color: var( --cf-sp-accent );
}

/* ── Progress (gamification) ────────────────────────────────────────── */
.cf-spoke__progress {
	background: var( --cf-sp-bg );
	border: 1px solid var( --cf-sp-line );
	border-radius: 12px;
	padding: 16px 18px;
	margin-bottom: 24px;
}

.cf-spoke__progresshead {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 10px;
	font-size: 14px;
}

.cf-spoke__pct {
	font-size: 20px;
	font-weight: 800;
	color: var( --cf-sp-accent );
}

.cf-spoke__bar {
	height: 10px;
	border-radius: 999px;
	background: #e5e9f0;
	overflow: hidden;
}

.cf-spoke__barfill {
	display: block;
	height: 100%;
	border-radius: 999px;
	background: linear-gradient( 90deg, var( --cf-sp-accent ), #60a5fa );
	transition: width 0.4s ease;
}

.cf-spoke__nudge {
	margin: 10px 0 0;
	font-size: 13px;
	color: var( --cf-sp-muted );
}

.cf-spoke__nudge--done {
	color: var( --cf-sp-ok );
	font-weight: 600;
}

/* ── Reactive Profile-strength ring (v2.8.1) ────────────────────────── */
.cf-spoke__progress {
	display: flex;
	align-items: center;
	gap: 18px;
}

.cf-spoke__ringwrap {
	position: relative;
	width: 96px;
	height: 96px;
	flex: 0 0 auto;
}

.cf-spoke__ring {
	width: 96px;
	height: 96px;
	transform: rotate( -90deg ); /* Start the fill at 12 o'clock. */
}

.cf-spoke__ring-track {
	fill: none;
	stroke: #e5e9f0;
	stroke-width: 10;
}

.cf-spoke__ring-prog {
	fill: none;
	stroke: var( --cf-sp-accent );
	stroke-width: 10;
	stroke-linecap: round;
	stroke-dasharray: 326.726; /* 2·π·r, r=52 (kept in sync with the JS). */
	stroke-dashoffset: calc( 326.726px - ( 326.726px * var( --progress, 0 ) / 100 ) );
	transition: stroke-dashoffset 0.8s cubic-bezier( 0.4, 0, 0.2, 1 ), stroke 0.4s ease;
}

/* Verified state — ring + label turn "complete" green at 100%. */
.cf-spoke__ringwrap.is-complete .cf-spoke__ring-prog {
	stroke: var( --cf-sp-ok );
}

.cf-spoke__ringwrap .cf-spoke__pct {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	font-weight: 800;
	color: var( --cf-sp-accent );
	transition: color 0.4s ease;
}

.cf-spoke__ringwrap.is-complete .cf-spoke__pct {
	color: var( --cf-sp-ok );
}

.cf-spoke__progressmeta {
	min-width: 0;
}

.cf-spoke__progressmeta strong {
	display: block;
	font-size: 15px;
	margin-bottom: 4px;
}

/* Inline save toast injected by the JS controller. */
.cf-spoke__savemsg {
	margin: 0 0 14px;
	padding: 10px 14px;
	border: 1px solid #a7f3d0;
	border-radius: 10px;
	background: #ecfdf5;
	color: #166534;
	font-size: 13px;
	font-weight: 600;
	opacity: 0;
	max-height: 0;
	overflow: hidden;
	transition: opacity 0.25s ease, max-height 0.25s ease;
}

.cf-spoke__savemsg.is-show {
	opacity: 1;
	max-height: 80px;
}

.cf-spoke__savemsg--error {
	border-color: #fecaca;
	background: #fef2f2;
	color: #991b1b;
}

@media ( prefers-reduced-motion: reduce ) {
	.cf-spoke__ring-prog { transition: none; }
}

/* ── Forms ──────────────────────────────────────────────────────────── */
.cf-spoke__field {
	margin-bottom: 16px;
}

.cf-spoke__label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	margin-bottom: 6px;
}

.cf-spoke__req {
	color: #dc2626;
}

.cf-spoke__input {
	width: 100%;
	padding: 11px 13px;
	font-size: 15px;
	color: var( --cf-sp-ink );
	background: #fff;
	border: 1px solid var( --cf-sp-line );
	border-radius: 9px;
	transition: border-color 0.15s, box-shadow 0.15s;
}

.cf-spoke__input:focus {
	outline: none;
	border-color: var( --cf-sp-accent );
	box-shadow: 0 0 0 3px rgba( 37, 99, 235, 0.15 );
}

textarea.cf-spoke__input {
	resize: vertical;
	min-height: 96px;
}

.cf-spoke__hint {
	display: block;
	margin-top: 5px;
	font-size: 12px;
	color: var( --cf-sp-muted );
}

.cf-spoke__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

.cf-spoke__grid--3 {
	grid-template-columns: 2fr 1fr 1fr;
}

@media ( max-width: 520px ) {
	.cf-spoke__grid,
	.cf-spoke__grid--3 {
		grid-template-columns: 1fr;
	}
	.cf-spoke__header {
		align-items: flex-start;
	}
}

.cf-spoke__logo {
	margin-bottom: 8px;
}

.cf-spoke__logo img {
	border-radius: 10px;
	border: 1px solid var( --cf-sp-line );
	display: block;
}

.cf-spoke__file {
	display: block;
	font-size: 14px;
}

/* ── Summary (billing) + placeholders ───────────────────────────────── */
.cf-spoke__summary {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	margin-bottom: 18px;
}

.cf-spoke__summary > div {
	display: flex;
	justify-content: space-between;
	padding: 12px 14px;
	background: var( --cf-sp-bg );
	border-radius: 10px;
	font-size: 14px;
}

.cf-spoke__summary span {
	color: var( --cf-sp-muted );
}

.cf-spoke__placeholder {
	padding: 28px;
	text-align: center;
	color: var( --cf-sp-muted );
	background: var( --cf-sp-bg );
	border: 1px dashed var( --cf-sp-line );
	border-radius: 12px;
	font-size: 15px;
}

.cf-spoke__empty {
	text-align: center;
	padding: 20px;
}

/* ── Buttons + alerts ───────────────────────────────────────────────── */
.cf-spoke__actions {
	margin-top: 22px;
}

.cf-spoke__btn {
	display: inline-block;
	padding: 12px 24px;
	font-size: 15px;
	font-weight: 600;
	border-radius: 9px;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: filter 0.15s;
}

.cf-spoke__btn--primary {
	background: var( --cf-sp-accent );
	color: var( --cf-sp-accent-ink );
}

.cf-spoke__btn--primary:hover {
	filter: brightness( 0.94 );
	color: var( --cf-sp-accent-ink );
}

.cf-spoke__btn--ghost {
	background: #fff;
	border-color: var( --cf-sp-line );
	color: var( --cf-sp-ink );
}

.cf-spoke__alert {
	padding: 12px 14px;
	border-radius: 9px;
	font-size: 14px;
	margin-bottom: 18px;
}

.cf-spoke__alert.is-success {
	background: #f0fdf4;
	border: 1px solid #bbf7d0;
	color: #166534;
}

.cf-spoke__alert.is-error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}

/* ── Login state ────────────────────────────────────────────────────── */
.cf-spoke__title {
	margin: 0 0 16px;
	font-size: 22px;
	font-weight: 700;
}

.cf-spoke__login label {
	display: block;
	font-weight: 600;
	font-size: 14px;
	margin-bottom: 4px;
}

.cf-spoke__login input[type="text"],
.cf-spoke__login input[type="password"] {
	width: 100%;
	padding: 11px 13px;
	border: 1px solid var( --cf-sp-line );
	border-radius: 9px;
	margin-bottom: 14px;
	font-size: 15px;
}

.cf-spoke__login .button,
.cf-spoke__login input[type="submit"] {
	background: var( --cf-sp-accent );
	color: var( --cf-sp-accent-ink );
	border: none;
	padding: 11px 22px;
	border-radius: 9px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
}

/* ── Ticket Box (Tab 2) ─────────────────────────────────────────────── */
.cf-spoke__tickethead {
	margin: 6px 0 14px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var( --cf-sp-muted );
}

.cf-spoke__tickethead--past {
	margin-top: 26px;
	padding-top: 18px;
	border-top: 1px solid var( --cf-sp-line );
}

.cf-spoke__ticket {
	border: 1px solid var( --cf-sp-line );
	border-radius: 12px;
	padding: 18px;
	margin-bottom: 14px;
}

.cf-spoke__ticket.is-past {
	opacity: 0.7;
	background: var( --cf-sp-bg );
}

.cf-spoke__ticketmain {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}

.cf-spoke__ticketinfo {
	flex: 1 1 240px;
	min-width: 0;
}

.cf-spoke__tickettitle {
	margin: 6px 0 2px;
	font-size: 18px;
	font-weight: 700;
}

.cf-spoke__ticketdate {
	margin: 0;
	color: var( --cf-sp-muted );
	font-size: 14px;
}

.cf-spoke__ticketlabel {
	margin: 4px 0 0;
	font-size: 13px;
	color: var( --cf-sp-ink );
	font-weight: 600;
}

.cf-spoke__ticketstatus {
	display: inline-block;
	padding: 3px 9px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: #e2e8f0;
	color: #475569;
}

.cf-spoke__ticketstatus.cf-st-confirmed,
.cf-spoke__ticketstatus.cf-st-checked_in {
	background: #dcfce7;
	color: #166534;
}

.cf-spoke__ticketstatus.cf-st-pending_payment {
	background: #fef9c3;
	color: #854d0e;
}

.cf-spoke__ticketstatus.cf-st-cancelled {
	background: #fee2e2;
	color: #991b1b;
}

.cf-spoke__qrwrap {
	flex: 0 0 auto;
	text-align: center;
	background: #fff;
	padding: 10px;
	border: 1px solid var( --cf-sp-line );
	border-radius: 10px;
}

.cf-spoke__qrwrap .cf-qr {
	display: inline-block;
	line-height: 0;
}

.cf-spoke__qrwrap .cf-qr img,
.cf-spoke__qrwrap .cf-qr canvas {
	display: block;
}

.cf-spoke__qrhash {
	display: block;
	margin-top: 6px;
	font-size: 10px;
	letter-spacing: 1px;
	color: var( --cf-sp-muted );
	word-break: break-all;
	max-width: 140px;
}

/* Group management */
.cf-spoke__guests {
	margin-top: 14px;
	border-top: 1px dashed var( --cf-sp-line );
	padding-top: 12px;
}

.cf-spoke__guests summary {
	cursor: pointer;
	font-weight: 600;
	font-size: 14px;
	color: var( --cf-sp-accent );
}

.cf-spoke__guestrow {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	margin-top: 10px;
}

@media ( max-width: 520px ) {
	.cf-spoke__guestrow {
		grid-template-columns: 1fr;
	}
}

.cf-spoke__guests .cf-spoke__btn {
	margin-top: 12px;
}

/* ── Financial Ledger (Tab 3) ───────────────────────────────────────── */
.cf-spoke__billhead {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 18px;
}

.cf-spoke__billhead .cf-spoke__summary {
	flex: 1 1 320px;
	margin-bottom: 0;
}

.cf-spoke__managebill {
	flex: 0 0 auto;
}

.cf-spoke__ledgerwrap {
	overflow-x: auto;
	border: 1px solid var( --cf-sp-line );
	border-radius: 12px;
}

.cf-spoke__ledger {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.cf-spoke__ledger thead th {
	text-align: left;
	padding: 12px 14px;
	background: var( --cf-sp-bg );
	color: var( --cf-sp-muted );
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border-bottom: 1px solid var( --cf-sp-line );
}

.cf-spoke__ledger td {
	padding: 12px 14px;
	border-bottom: 1px solid #f0f0f1;
	vertical-align: middle;
}

.cf-spoke__ledger tbody tr:last-child td {
	border-bottom: none;
}

.cf-spoke__ledger .cf-num {
	text-align: right;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.cf-spoke__ledger .cf-act {
	text-align: right;
	white-space: nowrap;
}

.cf-spoke__badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
	background: #e2e8f0;
	color: #475569;
}

.cf-spoke__badge.cf-st-paid {
	background: #dcfce7;
	color: #166534;
}

.cf-spoke__badge.cf-st-pending {
	background: #fef9c3;
	color: #854d0e;
}

.cf-spoke__badge.cf-st-failed {
	background: #fee2e2;
	color: #991b1b;
}

.cf-spoke__btn--sm {
	padding: 7px 14px;
	font-size: 13px;
}

.cf-spoke__receipt {
	font-size: 13px;
	font-weight: 600;
	color: var( --cf-sp-accent );
	text-decoration: none;
}

.cf-spoke__muted {
	color: #b6bcc6;
}

/* Stack the ledger into cards on narrow screens. */
@media ( max-width: 600px ) {
	.cf-spoke__ledger thead {
		display: none;
	}
	.cf-spoke__ledger,
	.cf-spoke__ledger tbody,
	.cf-spoke__ledger tr,
	.cf-spoke__ledger td {
		display: block;
		width: 100%;
	}
	.cf-spoke__ledger tr {
		padding: 8px 0;
		border-bottom: 1px solid var( --cf-sp-line );
	}
	.cf-spoke__ledger td {
		display: flex;
		justify-content: space-between;
		gap: 12px;
		border: none;
		padding: 6px 14px;
		text-align: right;
	}
	.cf-spoke__ledger td::before {
		content: attr( data-label );
		font-weight: 700;
		color: var( --cf-sp-muted );
		text-transform: uppercase;
		font-size: 11px;
		letter-spacing: 0.04em;
	}
	.cf-spoke__ledger .cf-num,
	.cf-spoke__ledger .cf-act {
		text-align: right;
	}
}

/* Cancellation */
.cf-spoke__cancel {
	margin-top: 14px;
}

.cf-spoke__cancelbtn {
	background: none;
	border: none;
	padding: 0;
	color: #b91c1c;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: underline;
}

.cf-spoke__cancelnote {
	font-size: 13px;
	color: var( --cf-sp-muted );
	font-style: italic;
}

/* v2.5.2 — cf_ticket card (Tickets tab repointed off CF_Registrations). */
.cf-spoke__ticket { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.cf-spoke__ticket-main { min-width: 0; }
.cf-spoke__ticket-title { margin: 0 0 4px; font-size: 16px; font-weight: 700; }
.cf-spoke__ticket-when { margin: 0 0 2px; font-size: 13px; color: var( --cf-sp-muted, #64748b ); }
.cf-spoke__ticket-id { margin: 0; font-size: 12px; color: var( --cf-sp-muted, #64748b ); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.cf-spoke__ticket-status { flex: 0 0 auto; padding: 5px 12px; border-radius: 999px; font-size: 12px; font-weight: 800; background: rgba( 22, 163, 74, .12 ); color: #16a34a; border: 1px solid #16a34a; }
