/* ============================================================
   CycleSave — Onboarding Wizard Styles
   Scoped under .csave-onboarding-wrap
   ============================================================ */

/* ----- Hide admin notices on the onboarding page ----- */
.admin_page_cyclesave-onboarding .notice,
.admin_page_cyclesave-onboarding .notice-warning,
.admin_page_cyclesave-onboarding .notice-error,
.admin_page_cyclesave-onboarding .notice-success,
.admin_page_cyclesave-onboarding .notice-info,
.admin_page_cyclesave-onboarding .updated,
.admin_page_cyclesave-onboarding .update-nag,
.admin_page_cyclesave-onboarding .error {
	display: none !important;
}

/* ----- Wizard wrapper ----- */
.csave-onboarding-wrap {
	--csave-primary: #50A659;
	--csave-primary-dark: #096B58;
	--csave-primary-light: #e6f5f1;
	--csave-gold: #E5A530;
	--csave-blue: #0073AA;
	--csave-red: #DC3545;
	--csave-text: #1A1A2E;
	--csave-text-secondary: #6B7280;
	--csave-border: #E5E7EB;
	--csave-bg: #F9FAFB;
	--csave-radius: 10px;
	--csave-radius-sm: 6px;
	--csave-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06);

	background: var(--csave-bg);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--csave-text);
}

/* ----- Header ----- */
.csave-onboarding-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 32px;
	background: #fff;
	border-bottom: 1px solid var(--csave-border);
}

.csave-onboarding-logo {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 18px;
	font-weight: 700;
	color: var(--csave-text);
	text-decoration: none;
}

.csave-onboarding-logo-img {
	height: 28px;
	width: auto;
	display: block;
}

.csave-onboarding-skip {
	font-size: 13px;
	color: var(--csave-text-secondary);
	text-decoration: none;
}

.csave-onboarding-skip:hover {
	color: var(--csave-text);
	text-decoration: underline;
}

/* ----- Progress bar ----- */
.csave-onboarding-progress {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	padding: 24px 32px;
	background: #fff;
	border-bottom: 1px solid var(--csave-border);
}

.csave-ob-step {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 500;
	color: var(--csave-text-secondary);
}

.csave-ob-step-circle {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 2px solid var(--csave-border);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	font-weight: 600;
	flex-shrink: 0;
	transition: all 0.2s;
}

.csave-ob-step--active .csave-ob-step-circle {
	background: var(--csave-primary);
	border-color: var(--csave-primary);
	color: #fff;
}

.csave-ob-step--active {
	color: var(--csave-text);
	font-weight: 600;
}

.csave-ob-step--done .csave-ob-step-circle {
	background: var(--csave-primary);
	border-color: var(--csave-primary);
	color: #fff;
}

.csave-ob-step--done {
	color: var(--csave-primary-dark);
}

.csave-ob-step-line {
	flex: 1;
	max-width: 80px;
	height: 2px;
	background: var(--csave-border);
	margin: 0 8px;
}

/* ----- Body container ----- */
.csave-onboarding-body {
	max-width: 680px;
	margin: 40px auto;
	padding: 0 24px 80px;
}

/* ----- Card base (welcome, step-content) ----- */
.csave-ob-welcome,
.csave-ob-step-content,
.csave-ob-complete {
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 40px;
	box-shadow: var(--csave-shadow-md);
}

/* ----- Welcome step ----- */
.csave-ob-hero {
	text-align: center;
	margin-bottom: 36px;
}

.csave-ob-hero-icon {
	margin-bottom: 20px;
}

.csave-ob-hero h1 {
	font-size: 28px;
	font-weight: 700;
	color: var(--csave-text);
	margin: 0 0 12px;
	padding: 0;
}

.csave-ob-hero-text {
	font-size: 15px;
	color: var(--csave-text-secondary);
	line-height: 1.6;
	max-width: 480px;
	margin: 0 auto;
}

/* Feature cards grid */
.csave-ob-features {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 36px;
}

.csave-ob-feature-card {
	background: var(--csave-bg);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 20px;
}

.csave-ob-feature-icon {
	width: 40px;
	height: 40px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
}

.csave-ob-feature-icon--green {
	background: var(--csave-primary-light, #e6f5f1);
	color: var(--csave-primary);
}

.csave-ob-feature-icon--gold {
	background: #FFF8E1;
	color: var(--csave-gold);
}

.csave-ob-feature-icon--blue {
	background: #EFF6FF;
	color: var(--csave-blue);
}

.csave-ob-feature-card h3 {
	font-size: 14px;
	font-weight: 600;
	color: var(--csave-text);
	margin: 0 0 6px;
}

.csave-ob-feature-card p {
	font-size: 13px;
	color: var(--csave-text-secondary);
	line-height: 1.5;
	margin: 0;
}

/* ----- Step header ----- */
.csave-ob-step-header {
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--csave-border);
}

.csave-ob-step-header h2 {
	font-size: 22px;
	font-weight: 700;
	color: var(--csave-text);
	margin: 0 0 6px;
	padding: 0;
}

.csave-ob-step-header p {
	font-size: 14px;
	color: var(--csave-text-secondary);
	margin: 0;
}

/* ----- Two-column form row ----- */
.csave-ob-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

/* ----- Pages panel ----- */
.csave-ob-pages-panel {
	background: var(--csave-bg);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 18px 20px;
	margin-bottom: 28px;
}

.csave-ob-pages-panel-header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 14px;
}

.csave-ob-pages-icon {
	width: 36px;
	height: 36px;
	background: var(--csave-primary-light, #e6f5f1);
	color: var(--csave-primary);
	border-radius: 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.csave-ob-pages-panel-header > div {
	flex: 1;
}

.csave-ob-pages-panel-header strong {
	font-size: 13px;
	font-weight: 600;
	display: block;
	margin-bottom: 2px;
}

.csave-ob-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 8px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 600;
	flex-shrink: 0;
}

.csave-ob-badge--green {
	background: var(--csave-primary-light, #e6f5f1);
	color: var(--csave-primary-dark);
}

/* ----- Payment gateway card ----- */
.csave-ob-gateway-card {
	border: 2px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 24px;
	margin-bottom: 20px;
	transition: border-color 0.15s;
}

.csave-ob-gateway-card--connected {
	border-color: var(--csave-primary);
	background: var(--csave-primary-light, #e6f5f1);
}

.csave-ob-gateway-card-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
}

.csave-ob-gateway-badge {
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	background: var(--csave-gold);
	color: #fff;
	padding: 3px 8px;
	border-radius: 20px;
}

.csave-ob-gateway-logo {
	margin-left: auto;
}

.csave-ob-gateway-desc {
	font-size: 13px;
	color: var(--csave-text-secondary);
	margin: 0 0 20px;
	line-height: 1.5;
}

.csave-ob-connected-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-primary-dark);
	background: #fff;
	border: 1px solid var(--csave-primary);
	border-radius: 20px;
	padding: 5px 14px;
	margin-bottom: 16px;
}

.csave-ob-inline-form {
	display: inline-block;
}

.csave-ob-alt-options {
	margin-top: 8px;
}

.csave-ob-alt-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--csave-text-secondary);
	margin: 0 0 12px;
}

.csave-ob-alt-row {
	display: flex;
	align-items: center;
	gap: 16px;
}

/* ----- Buttons ----- */
.csave-ob-btn-lg {
	padding: 12px 24px !important;
	font-size: 15px !important;
}

.csave-ob-btn-outline {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 18px;
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	border: 1px solid var(--csave-border);
	background: #fff;
	color: var(--csave-text);
	text-decoration: none;
	transition: all 0.15s;
}

.csave-ob-btn-outline:hover {
	border-color: var(--csave-primary);
	color: var(--csave-primary-dark);
	background: var(--csave-primary-light, #e6f5f1);
}

.csave-ob-link-btn {
	background: none;
	border: none;
	padding: 0;
	font-size: 13px;
	color: var(--csave-text-secondary);
	cursor: pointer;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.csave-ob-link-btn:hover {
	color: var(--csave-text);
}

/* ----- Actions row ----- */
.csave-ob-actions {
	margin-top: 32px;
	padding-top: 24px;
	border-top: 1px solid var(--csave-border);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
}

.csave-ob-actions--final {
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	border-top: none;
	padding-top: 0;
	margin-top: 28px;
	justify-content: center;
}

.csave-ob-step-count {
	font-size: 12px;
	color: var(--csave-text-secondary);
	margin: 0;
	text-align: center;
}

/* Welcome actions centred */
.csave-ob-welcome .csave-ob-actions {
	align-items: center;
	border-top: none;
	padding-top: 0;
}

/* ----- Complete step ----- */
.csave-ob-complete {
	text-align: center;
}

.csave-ob-complete-icon {
	margin-bottom: 20px;
}

.csave-ob-complete h2 {
	font-size: 26px;
	font-weight: 700;
	margin: 0 0 8px;
	padding: 0;
	color: var(--csave-text);
}

.csave-ob-complete-subtitle {
	font-size: 14px;
	color: var(--csave-text-secondary);
	margin: 0 0 28px;
}

.csave-ob-checklist {
	text-align: left;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	overflow: hidden;
	margin-bottom: 32px;
}

.csave-ob-check-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 13px 16px;
	font-size: 13px;
	border-bottom: 1px solid var(--csave-border);
}

.csave-ob-check-item:last-child {
	border-bottom: none;
}

.csave-ob-check-icon {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.csave-ob-check-item--done .csave-ob-check-icon {
	background: var(--csave-primary-light, #e6f5f1);
	color: var(--csave-primary);
}

.csave-ob-check-item--warn .csave-ob-check-icon {
	background: #FFF8E1;
	color: var(--csave-gold);
}

.csave-ob-check-link {
	margin-left: auto;
	font-size: 12px;
	font-weight: 600;
	color: var(--csave-blue);
	text-decoration: none;
	white-space: nowrap;
}

.csave-ob-check-link:hover {
	text-decoration: underline;
}

/* ----- Utilities used in partials ----- */
.csave-mb-0 { margin-bottom: 0 !important; }
.csave-mb-12 { margin-bottom: 12px !important; }
.csave-mb-20 { margin-bottom: 20px !important; }
.csave-mt-12 { margin-top: 12px !important; }
.csave-hidden { display: none !important; }

/* ----- Notice inside onboarding ----- */
.csave-onboarding-wrap .csave-admin-notice {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-weight: 500;
}

.csave-onboarding-wrap .csave-admin-notice-success {
	background: var(--csave-primary-light, #e6f5f1);
	color: var(--csave-primary-dark);
	border: 1px solid #b2dfc5;
}

.csave-onboarding-wrap .csave-admin-notice-error {
	background: #FFF0F0;
	color: #8B1A1A;
	border: 1px solid #f5c6c6;
}

/* ----- Responsive ----- */
@media (max-width: 640px) {
	.csave-ob-features {
		grid-template-columns: 1fr;
	}

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

	.csave-ob-welcome,
	.csave-ob-step-content,
	.csave-ob-complete {
		padding: 24px 20px;
	}

	.csave-ob-actions--final {
		flex-direction: column;
	}

	.csave-onboarding-progress {
		padding: 16px 20px;
	}

	.csave-ob-step-line {
		max-width: 40px;
	}
}
