/* ============================================================
   CycleSave — Public/Frontend Styles
   Scoped under .cyclesave-wrap to avoid theme conflicts.
   Design system inspired by cyclesave.lovable.app
   ============================================================ */

/* --- CSS Custom Properties (scoped) --- */
.cyclesave-wrap {
	--csave-primary: #0D7C66;
	--csave-primary-dark: #096B58;
	--csave-primary-light: #e6f5f1;
	--csave-primary-50: #f0faf7;
	--csave-secondary: #F5F0E8;
	--csave-gold: #E5A530;
	--csave-gold-light: #FFF8E1;
	--csave-red: #DC3545;
	--csave-red-light: #FFF0F0;
	--csave-blue: #3B82F6;
	--csave-blue-light: #EFF6FF;
	--csave-text: #1A1A2E;
	--csave-text-secondary: #6B7280;
	--csave-text-muted: #9CA3AF;
	--csave-border: #E5E7EB;
	--csave-border-light: #F3F4F6;
	--csave-bg: #F9FAFB;
	--csave-white: #FFFFFF;
	--csave-radius: 10px;
	--csave-radius-sm: 6px;
	--csave-radius-lg: 14px;
	--csave-radius-full: 9999px;
	--csave-shadow: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
	--csave-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
	--csave-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);
	--csave-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--csave-transition: 0.2s ease;
}

/* --- Base --- */
.cyclesave-wrap {
	max-width: 1100px;
	margin: 0 auto;
	font-family: var(--csave-font);
	line-height: 1.6;
	color: var(--csave-text);
	-webkit-font-smoothing: antialiased;
}
.cyclesave-wrap *,
.cyclesave-wrap *::before,
.cyclesave-wrap *::after {
	box-sizing: border-box;
}
.cyclesave-wrap h2,
.cyclesave-wrap h3,
.cyclesave-wrap h4 {
	margin: 0 0 4px;
	color: var(--csave-text);
	font-weight: 600;
	line-height: 1.3;
}
.cyclesave-wrap h2 { font-size: 1.5rem; }
.cyclesave-wrap h3 { font-size: 1.125rem; }
.cyclesave-wrap h4 { font-size: 1rem; }
.cyclesave-wrap p { margin: 0 0 8px; }
.cyclesave-wrap a { color: var(--csave-primary); text-decoration: none; }
.cyclesave-wrap a:hover { color: var(--csave-primary-dark); }

/* --- Typography helpers --- */
.cyclesave-wrap .csave-text-muted { color: var(--csave-text-secondary); }
.cyclesave-wrap .csave-text-muted-light { color: rgba(255, 255, 255, 0.7); }
.cyclesave-wrap .csave-text-sm { font-size: 0.8125rem; }
.cyclesave-wrap .csave-text-xs { font-size: 0.75rem; color: var(--csave-text-secondary); }
.cyclesave-wrap .csave-link { font-size: 0.8125rem; font-weight: 500; color: var(--csave-primary); }
.cyclesave-wrap .csave-link:hover { text-decoration: underline; }

/* --- Notices --- */
.cyclesave-wrap .csave-notice {
	padding: 12px 16px;
	border-radius: var(--csave-radius-sm);
	margin-bottom: 16px;
	font-size: 0.875rem;
	line-height: 1.5;
}
.cyclesave-wrap .csave-notice-success { background: var(--csave-primary-light); border-left: 4px solid var(--csave-primary); color: #065F46; }
.cyclesave-wrap .csave-notice-error   { background: var(--csave-red-light); border-left: 4px solid var(--csave-red); color: #991B1B; }
.cyclesave-wrap .csave-notice-warning { background: var(--csave-gold-light); border-left: 4px solid var(--csave-gold); color: #92400E; }
.cyclesave-wrap .csave-notice-info    { background: var(--csave-blue-light); border-left: 4px solid var(--csave-blue); color: #1E40AF; }
/* Payment return notices (Stripe/Paystack/BankTransfer) — displayed after redirect */
.csave-notice.csave-payment-notice-auto  { display: block; padding: 16px 20px; border-radius: 8px; margin: 24px 0; font-size: 1rem; line-height: 1.6; font-weight: 500; max-width: 600px; margin-left: auto; margin-right: auto; }

/* --- Dashboard Header --- */
.cyclesave-wrap .csave-dash-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
}
.cyclesave-wrap .csave-dash-header-left {
	display: flex;
	align-items: center;
	gap: 16px;
}
.cyclesave-wrap .csave-dash-header-info h2 { margin: 0; }
.cyclesave-wrap .csave-dash-header-info p { margin: 4px 0 0; }

/* --- User avatar image (from get_avatar()) --- */
.cyclesave-wrap .csave-user-avatar {
	display: block;
	width: 52px;
	height: 52px;
	border-radius: var(--csave-radius-full);
	object-fit: cover;
	flex-shrink: 0;
}

/* --- Avatars --- */
.cyclesave-wrap .csave-avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--csave-radius-full);
	background: var(--csave-primary);
	color: var(--csave-white);
	font-weight: 600;
	text-transform: uppercase;
	flex-shrink: 0;
}
.cyclesave-wrap .csave-avatar-xs { width: 28px; height: 28px; font-size: 0.625rem; }
.cyclesave-wrap .csave-avatar-sm { width: 36px; height: 36px; font-size: 0.75rem; }
.cyclesave-wrap .csave-avatar-md { width: 42px; height: 42px; font-size: 0.875rem; }
.cyclesave-wrap .csave-avatar-lg { width: 52px; height: 52px; font-size: 1.125rem; }
.cyclesave-wrap .csave-avatar-more {
	background: var(--csave-border);
	color: var(--csave-text-secondary);
	font-size: 0.625rem;
}
.cyclesave-wrap .csave-avatar-stack {
	display: flex;
	gap: 0;
}
.cyclesave-wrap .csave-avatar-stack .csave-avatar {
	margin-left: -6px;
	border: 2px solid var(--csave-white);
}
.cyclesave-wrap .csave-avatar-stack .csave-avatar:first-child {
	margin-left: 0;
}

/* --- Dashboard Layout --- */
.cyclesave-wrap .csave-dash-body {
	display: flex;
	align-items: flex-start;
	gap: 24px;
}
.cyclesave-wrap .csave-dash-main {
	flex: 1;
	min-width: 0;
}

/* --- Sidebar Navigation --- */
.cyclesave-wrap .csave-tab-nav {
	display: flex;
	flex-direction: column;
	width: 200px;
	flex-shrink: 0;
	background: var(--csave-white);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 8px;
	gap: 2px;
	position: sticky;
	top: 20px;
}
.cyclesave-wrap .csave-tab-nav .csave-tab-link {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 10px 12px 10px 15px !important;
	font-size: 0.875rem !important;
	font-weight: 500;
	color: var(--csave-text-secondary);
	white-space: nowrap;
	border-radius: var(--csave-radius-sm);
	box-shadow: inset 3px 0 0 transparent;
	transition: color var(--csave-transition), background var(--csave-transition), box-shadow var(--csave-transition);
	text-decoration: none !important;
}
.cyclesave-wrap .csave-tab-nav .csave-tab-link:hover {
	color: var(--csave-text);
	background: var(--csave-bg);
	text-decoration: none !important;
}
.cyclesave-wrap .csave-tab-nav .csave-tab-link.csave-tab-active {
	color: var(--csave-primary);
	background: var(--csave-primary-light);
	box-shadow: inset 3px 0 0 var(--csave-primary);
	font-weight: 600;
}
.cyclesave-wrap .csave-tab-nav .csave-tab-link svg {
	display: block !important;
	flex-shrink: 0;
	opacity: 0.6;
}
.cyclesave-wrap .csave-tab-nav .csave-tab-link.csave-tab-active svg {
	opacity: 1;
}

/* --- Sidebar logout --- */
.cyclesave-wrap .csave-tab-nav-footer {
	border-top: 1px solid var(--csave-border);
	margin-top: 4px;
	padding-top: 4px;
}
.cyclesave-wrap .csave-tab-logout {
	color: var(--csave-text-secondary) !important;
}
.cyclesave-wrap .csave-tab-logout:hover {
	color: var(--csave-red) !important;
	background: var(--csave-red-light) !important;
}

/* --- Tab Content --- */
.cyclesave-wrap .csave-tab-content {
	animation: csFadeIn 0.25s ease;
}
@keyframes csFadeIn {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* --- Stat Cards Row --- */
.cyclesave-wrap .csave-stats-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin-bottom: 32px;
}
.cyclesave-wrap .csave-stat-card {
	background: var(--csave-white);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 20px;
	box-shadow: var(--csave-shadow);
	transition: box-shadow var(--csave-transition);
}
.cyclesave-wrap .csave-stat-card:hover {
	box-shadow: var(--csave-shadow-md);
}
.cyclesave-wrap .csave-stat-icon {
	width: 40px;
	height: 40px;
	border-radius: var(--csave-radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
}
.cyclesave-wrap .csave-stat-icon-green { background: var(--csave-primary-light); color: var(--csave-primary); }
.cyclesave-wrap .csave-stat-icon-teal  { background: #E0F2FE; color: #0284C7; }
.cyclesave-wrap .csave-stat-icon-gold  { background: var(--csave-gold-light); color: #B45309; }
.cyclesave-wrap .csave-stat-icon-blue  { background: var(--csave-blue-light); color: var(--csave-blue); }
.cyclesave-wrap .csave-stat-value {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--csave-text);
	line-height: 1.2;
}
.cyclesave-wrap .csave-stat-label {
	font-size: 0.75rem;
	color: var(--csave-text-secondary);
	margin-top: 2px;
}

/* --- Section --- */
.cyclesave-wrap .csave-section { margin-bottom: 32px; }
.cyclesave-wrap .csave-section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
}
.cyclesave-wrap .csave-section-header h3 {
	margin: 0;
	border: none;
	padding: 0;
}

/* --- Cards --- */
.cyclesave-wrap .csave-card {
	background: var(--csave-white);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	box-shadow: var(--csave-shadow);
	overflow: hidden;
}
.cyclesave-wrap .csave-card-body { padding: 20px; }
.cyclesave-wrap .csave-card-header {
	padding: 20px 24px;
	border-bottom: 1px solid var(--csave-border-light);
}
.cyclesave-wrap .csave-card-header h3 { margin-bottom: 4px; }
.cyclesave-wrap .csave-card-header p { margin: 0; }

/* --- Group Cards --- */
.cyclesave-wrap .csave-groups-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

@media (max-width: 1024px) {
	.cyclesave-wrap .csave-groups-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Sidebar layout: 2 columns is more readable in the narrower main pane */
.cyclesave-wrap .csave-dash-main .csave-groups-grid {
	grid-template-columns: repeat(2, 1fr);
}

/* 2-column variant for specific sections */
.cyclesave-wrap .csave-groups-grid-2col {
	grid-template-columns: repeat(2, 1fr);
}

@media (max-width: 1024px) {
	.cyclesave-wrap .csave-groups-grid-2col {
		grid-template-columns: repeat(1, 1fr);
	}
}

.cyclesave-wrap .csave-group-card {
	background: var(--csave-white);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	overflow: hidden;
	box-shadow: var(--csave-shadow);
	transition: box-shadow var(--csave-transition), transform var(--csave-transition);
}
.cyclesave-wrap .csave-group-card:hover {
	box-shadow: var(--csave-shadow-md);
	transform: translateY(-1px);
}
.cyclesave-wrap .csave-group-card-header {
	background: var(--csave-primary);
	color: var(--csave-white);
	padding: 16px 18px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.cyclesave-wrap .csave-group-card-header-open {
	background: linear-gradient(135deg, var(--csave-primary) 0%, #0A9B7D 100%);
}
.cyclesave-wrap .csave-group-card-header h3,
.cyclesave-wrap .csave-group-card-header h4 {
	margin: 0;
	color: var(--csave-white);
	font-size: 0.9375rem;
}
.cyclesave-wrap .csave-group-card-body { padding: 16px 18px; }
.cyclesave-wrap .csave-group-card-footer {
	padding: 14px 18px;
	border-top: 1px solid var(--csave-border-light);
	background: var(--csave-bg);
}

/* Group meta grid inside cards */
.cyclesave-wrap .csave-group-meta-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: var(--csave-border-light);
	border-radius: 8px;
	overflow: hidden;
}
.cyclesave-wrap .csave-group-meta-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: var(--csave-white);
}
.cyclesave-wrap .csave-meta-label {
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	color: var(--csave-text-secondary);
	font-weight: 500;
	line-height: 1.2;
}
.cyclesave-wrap .csave-meta-value {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--csave-text);
	line-height: 1.3;
}

/* --- Progress Bar --- */
.cyclesave-wrap .csave-progress-section { margin-top: 14px; }
.cyclesave-wrap .csave-progress-header {
	display: flex;
	justify-content: space-between;
	margin-bottom: 6px;
}
.cyclesave-wrap .csave-progress-bar {
	width: 100%;
	height: 6px;
	background: var(--csave-border);
	border-radius: var(--csave-radius-full);
	overflow: hidden;
}
.cyclesave-wrap .csave-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--csave-primary) 0%, #0A9B7D 100%);
	border-radius: var(--csave-radius-full);
	transition: width 0.5s ease;
	min-width: 4px;
}

/* --- Status Badges --- */
.cyclesave-wrap .csave-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: var(--csave-radius-full);
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	white-space: nowrap;
}
.cyclesave-wrap .csave-badge-open      { background: rgba(255,255,255,0.2); color: var(--csave-white); }
.cyclesave-wrap .csave-badge-ordering  { background: var(--csave-gold-light); color: #92400E; }
.cyclesave-wrap .csave-badge-active    { background: var(--csave-primary-light); color: var(--csave-primary); }
.cyclesave-wrap .csave-badge-paused    { background: #F3F4F6; color: var(--csave-text-secondary); }
.cyclesave-wrap .csave-badge-completed { background: #F3F4F6; color: #374151; }

.cyclesave-wrap .csave-badge-status {
	display: inline-flex;
	align-items: center;
	padding: 3px 10px;
	border-radius: var(--csave-radius-full);
	font-size: 0.75rem;
	font-weight: 600;
	gap: 4px;
}
.cyclesave-wrap .csave-badge-status-success { background: var(--csave-primary-light); color: #065F46; }
.cyclesave-wrap .csave-badge-status-failed  { background: var(--csave-red-light); color: #991B1B; }
.cyclesave-wrap .csave-badge-status-pending { background: var(--csave-gold-light); color: #92400E; }

/* Paid badge */
.cyclesave-wrap .csave-paid-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 12px;
	border-radius: var(--csave-radius-full);
	font-size: 0.8125rem;
	font-weight: 600;
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}

/* --- Buttons --- */
.cyclesave-wrap .csave-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 20px;
	border-radius: var(--csave-radius-sm);
	border: 1px solid var(--csave-border);
	cursor: pointer;
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: all var(--csave-transition);
	background: var(--csave-white);
	color: var(--csave-text);
	font-family: var(--csave-font);
	line-height: 1.4;
}
.cyclesave-wrap .csave-button:hover {
	background: var(--csave-bg);
	text-decoration: none;
}
.cyclesave-wrap .csave-button-primary {
	background: var(--csave-primary);
	color: var(--csave-white);
	border-color: var(--csave-primary);
}
.cyclesave-wrap .csave-button-primary:hover {
	background: var(--csave-primary-dark);
	border-color: var(--csave-primary-dark);
	color: var(--csave-white);
}
.cyclesave-wrap .csave-button-sm {
	padding: 7px 14px;
	font-size: 0.8125rem;
}
.cyclesave-wrap .csave-button:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* Pay button */
.cyclesave-wrap .csave-pay-btn { width: auto; }

/* Extra-small button */
.cyclesave-wrap .csave-button-xs {
	padding: 4px 10px;
	font-size: 0.75rem;
	gap: 4px;
	border-radius: var(--csave-radius-sm);
}

/* Outline button variant */
.cyclesave-wrap .csave-button-outline {
	background: transparent;
	border: 1px solid var(--csave-border);
	color: var(--csave-text-secondary);
}
.cyclesave-wrap .csave-button-outline:hover {
	background: var(--csave-bg);
	border-color: var(--csave-primary);
	color: var(--csave-primary);
}

/* Reference code */
.cyclesave-wrap .csave-ref-code {
	display: inline-block;
	padding: 2px 8px;
	background: var(--csave-bg);
	border: 1px solid var(--csave-border-light);
	border-radius: 4px;
	font-family: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;
	font-size: 0.6875rem;
	color: var(--csave-text-secondary);
	letter-spacing: 0.3px;
	word-break: break-all;
	max-width: 140px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Action buttons container */
.cyclesave-wrap .csave-action-btns {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: nowrap;
}

/* Receipt download button hover */
.cyclesave-wrap .csave-download-receipt-btn:hover {
	color: var(--csave-primary);
	border-color: var(--csave-primary);
}

/* Table pay-btn override for inline usage */
.cyclesave-wrap .csave-table .csave-pay-btn {
	width: auto;
}

/* --- Tables --- */
.cyclesave-wrap .csave-table-wrap { overflow-x: auto; }
.cyclesave-wrap .csave-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.8125rem;
	margin-bottom: 16px;
}
.cyclesave-wrap .csave-table th {
	text-align: left;
	padding: 8px 10px;
	font-weight: 600;
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--csave-text-secondary);
	background: var(--csave-bg);
	border-bottom: 1px solid var(--csave-border);
	white-space: nowrap;
}
.cyclesave-wrap .csave-table td {
	padding: 8px 10px;
	border-bottom: 1px solid var(--csave-border-light);
	vertical-align: middle;
}
.cyclesave-wrap .csave-table tr:last-child td { border-bottom: none; }
.cyclesave-wrap .csave-table tr:hover td { background: var(--csave-primary-50); }
/* Truncate long cell content (e.g. gateway reference) */
.cyclesave-wrap .csave-ref-truncate {
	display: block;
	max-width: 130px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.cyclesave-wrap .csave-cell-group {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* --- Empty State --- */
.cyclesave-wrap .csave-empty-state {
	text-align: center;
	padding: 48px 24px;
	background: var(--csave-white);
	border: 1px dashed var(--csave-border);
	border-radius: var(--csave-radius);
}
.cyclesave-wrap .csave-empty-state h4 {
	margin: 16px 0 4px;
	color: var(--csave-text);
}
.cyclesave-wrap .csave-empty-state p {
	color: var(--csave-text-secondary);
	font-size: 0.875rem;
}

/* --- Group Detail Card (My Groups tab) --- */
.cyclesave-wrap .csave-group-detail-card {
	margin-bottom: 16px;
}
.cyclesave-wrap .csave-group-detail-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 18px 20px;
	border-bottom: 1px solid var(--csave-border-light);
}
.cyclesave-wrap .csave-group-detail-title {
	display: flex;
	align-items: center;
	gap: 12px;
}
.cyclesave-wrap .csave-group-detail-title h4 { margin: 0; }
.cyclesave-wrap .csave-group-detail-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1px;
	padding: 0;
	border-bottom: 1px solid var(--csave-border-light);
	background: var(--csave-border-light);
}
.cyclesave-wrap .csave-mini-stat {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 16px;
	background: var(--csave-white);
}
.cyclesave-wrap .csave-mini-stat-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	flex-shrink: 0;
}
.cyclesave-wrap .csave-mini-stat-icon-green  { background: #ecfdf5; color: #059669; }
.cyclesave-wrap .csave-mini-stat-icon-teal   { background: #f0fdfa; color: #0d9488; }
.cyclesave-wrap .csave-mini-stat-icon-blue   { background: #eff6ff; color: #2563eb; }
.cyclesave-wrap .csave-mini-stat-icon-gold   { background: #fffbeb; color: #d97706; }
.cyclesave-wrap .csave-mini-stat-icon-purple { background: #faf5ff; color: #7c3aed; }
.cyclesave-wrap .csave-mini-stat-icon-orange { background: #fff7ed; color: #ea580c; }
.cyclesave-wrap .csave-mini-stat-text {
	display: flex;
	flex-direction: column;
	gap: 1px;
	min-width: 0;
}
.cyclesave-wrap .csave-mini-stat-label {
	font-size: 0.6875rem;
	color: var(--csave-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.3px;
	line-height: 1.2;
}
.cyclesave-wrap .csave-mini-stat-value {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--csave-text);
	line-height: 1.3;
}
.cyclesave-wrap .csave-group-detail-round {
	padding: 14px 20px;
	border-bottom: 1px solid var(--csave-border-light);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cyclesave-wrap .csave-round-info {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cyclesave-wrap .csave-group-detail-members {
	padding: 14px 20px;
	display: flex;
	align-items: center;
	gap: 12px;
}

/* --- Forms --- */
.cyclesave-wrap .csave-form {
	padding: 0 24px 24px;
}
.cyclesave-wrap .csave-form-section {
	margin-bottom: 28px;
}
.cyclesave-wrap .csave-form-section h4 {
	margin-bottom: 16px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--csave-border-light);
	color: var(--csave-text);
	font-size: 0.9375rem;
}
.cyclesave-wrap .csave-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.cyclesave-wrap .csave-form-grid .csave-col-span-2 {
	grid-column: span 2;
}
.cyclesave-wrap .csave-form-group {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.cyclesave-wrap .csave-form-group label {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--csave-text);
	padding-top: 5px;
    padding-bottom: 5px;
}
.cyclesave-wrap .csave-input {
	padding: 9px 12px;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	font-size: 0.875rem;
	font-family: var(--csave-font);
	color: var(--csave-text);
	background: var(--csave-white);
	transition: border-color var(--csave-transition), box-shadow var(--csave-transition);
	width: 100%;
}
.cyclesave-wrap .csave-input:focus {
	outline: none;
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 3px rgba(13, 124, 102, 0.12);
}
.cyclesave-wrap .csave-input:disabled {
	background: var(--csave-bg);
	color: var(--csave-text-secondary);
	cursor: not-allowed;
}
.cyclesave-wrap .csave-form-hint {
	font-size: 0.75rem;
	color: var(--csave-text-muted);
}
.cyclesave-wrap .csave-form-actions {
	padding-top: 16px;
	border-top: 1px solid var(--csave-border-light);
}

/* Checkbox group */
.cyclesave-wrap .csave-checkbox-group {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.cyclesave-wrap .csave-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	padding: 12px 14px;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	transition: border-color var(--csave-transition), background var(--csave-transition);
}
.cyclesave-wrap .csave-checkbox-label:hover {
	border-color: var(--csave-primary);
	background: var(--csave-primary-50);
}
.cyclesave-wrap .csave-checkbox-label input[type="checkbox"] {
	margin-top: 2px;
	accent-color: var(--csave-primary);
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}
.cyclesave-wrap .csave-checkbox-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	font-size: 0.875rem;
}
.cyclesave-wrap .csave-checkbox-text strong {
	font-weight: 500;
}
.cyclesave-wrap .csave-checkbox-text .csave-text-muted {
	font-size: 0.75rem;
}

/* --- Stripe Checkout Card Element --- */
.cyclesave-wrap #cs-stripe-payment-element {
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 12px 14px;
	background: #fff;
	margin-bottom: 16px;
	transition: border-color 0.15s ease;
}
.cyclesave-wrap #cs-stripe-payment-element:hover {
	border-color: var(--csave-text-muted);
}
.cyclesave-wrap #cs-stripe-payment-element.StripeElement--focus {
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 1px var(--csave-primary);
}
.cyclesave-wrap #cs-stripe-payment-element.StripeElement--invalid {
	border-color: var(--csave-danger, #e53e3e);
}
.cyclesave-wrap #cs-checkout-stripe {
	margin-top: 8px;
}

/* --- Stripe Info --- */
.cyclesave-wrap .csave-stripe-info {
	padding: 16px 24px;
}
.cyclesave-wrap .csave-stripe-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--csave-primary-light);
	border-radius: var(--csave-radius-sm);
	color: var(--csave-primary);
	font-size: 0.8125rem;
	font-weight: 500;
}

/* --- Modal --- */
.cyclesave-wrap .csave-modal {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(4px);
}
.cyclesave-wrap .csave-modal.csave-modal--open {
	display: flex;
}
.cyclesave-wrap .csave-modal-content {
	background: var(--csave-white);
	border-radius: var(--csave-radius-lg);
	max-width: 480px;
	width: 100%;
	box-shadow: var(--csave-shadow-lg);
	overflow: hidden;
}
.cyclesave-wrap .csave-modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px 24px;
	border-bottom: 1px solid var(--csave-border-light);
}
.cyclesave-wrap .csave-modal-header h3 { margin: 0; }
.cyclesave-wrap .csave-modal-close-btn {
	background: none;
	border: none;
	cursor: pointer;
	color: var(--csave-text-secondary);
	padding: 4px;
	border-radius: var(--csave-radius-sm);
	transition: background var(--csave-transition);
}
.cyclesave-wrap .csave-modal-close-btn:hover {
	background: var(--csave-bg);
	color: #1A1A2E;
}
/* Stripe Payment Element */
.cyclesave-wrap #cs-payment-element {
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 12px 14px;
	background: #fff;
	margin-bottom: 16px;
	transition: border-color 0.15s ease;
	min-height: 60px;
}
.cyclesave-wrap #cs-payment-element:hover {
	border-color: var(--csave-text-muted);
}
.cyclesave-wrap #cs-payment-element.StripeElement--focus {
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 1px var(--csave-primary);
}
.cyclesave-wrap #cs-payment-element.StripeElement--invalid {
	border-color: var(--csave-danger, #e53e3e);
}
.cyclesave-wrap .csave-modal-actions {
	display: flex;
	gap: 8px;
	padding: 16px 24px;
	border-top: 1px solid var(--csave-border-light);
	justify-content: flex-end;
}

/* ============================================================
   Styles for other shortcodes (group-list, join, payout, ledger)
   ============================================================ */

/* Status inline */
.cyclesave-wrap .csave-status {
	display: inline-flex;
	align-items: center;
	padding: 3px 10px;
	border-radius: var(--csave-radius-full);
	font-size: 0.75rem;
	font-weight: 600;
}
.cyclesave-wrap .csave-status-success  { background: var(--csave-primary-light); color: #065F46; }
.cyclesave-wrap .csave-status-failed   { background: var(--csave-red-light); color: #991B1B; }
.cyclesave-wrap .csave-status-pending  { background: var(--csave-gold-light); color: #92400E; }
.cyclesave-wrap .csave-status-active   { background: var(--csave-blue-light); color: #1E40AF; }
.cyclesave-wrap .csave-status-upcoming { background: #F3F4F6; color: var(--csave-text-secondary); }

/* Joined / You badge */
.cyclesave-wrap .csave-joined-badge,
.cyclesave-wrap .csave-you-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 10px;
	border-radius: var(--csave-radius-full);
	font-size: 0.75rem;
	font-weight: 600;
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}

/* Compact table variant */
.cyclesave-wrap .csave-compact-table th,
.cyclesave-wrap .csave-compact-table td {
	padding: 7px 10px;
	font-size: 0.8125rem;
}
.cyclesave-wrap .csave-highlight-row td {
	background: var(--csave-primary-50) !important;
	font-weight: 600;
}

/* Dashboard header (legacy compat) */
.cyclesave-wrap .csave-dashboard-header { margin-bottom: 24px; }

/* Info rows (join page) */
.cyclesave-wrap .csave-info-row {
	display: flex;
	gap: 8px;
	padding: 8px 0;
	border-bottom: 1px solid var(--csave-border-light);
	font-size: 0.875rem;
}
.cyclesave-wrap .csave-info-row span {
	color: var(--csave-text-secondary);
	min-width: 180px;
}

/* Schedule intro */
.cyclesave-wrap .csave-schedule-intro {
	background: var(--csave-primary-light);
	padding: 14px 18px;
	border-radius: var(--csave-radius-sm);
	margin-bottom: 20px;
	font-size: 0.875rem;
	color: #065F46;
}
.cyclesave-wrap .csave-schedule-table-wrap { overflow-x: auto; }
.cyclesave-wrap .csave-audit-section { margin-top: 32px; }
.cyclesave-wrap .csave-muted { color: var(--csave-text-secondary); font-size: 0.875rem; }

/* Ledger stat cards */
.cyclesave-wrap .csave-ledger-stats { display: flex; gap: 16px; margin-bottom: 24px; }
.cyclesave-wrap .csave-ledger-stats .csave-stat-card {
	background: var(--csave-white);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 16px 24px;
	text-align: center;
}
.cyclesave-wrap .csave-stat-number {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--csave-primary);
}

/* Round section */
.cyclesave-wrap .csave-round-section { margin-bottom: 24px; }
.cyclesave-wrap .csave-round-header {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	background: var(--csave-bg);
	padding: 10px 14px;
	border-radius: var(--csave-radius-sm);
	margin-bottom: 8px;
	font-size: 0.875rem;
}
.cyclesave-wrap .csave-round-header h4 { margin: 0; }
.cyclesave-wrap .csave-round-progress { margin-left: auto; font-weight: 600; }

/* Join page */
.cyclesave-wrap .csave-join-details {
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 16px 20px;
	margin: 16px 0;
	background: var(--csave-white);
}
.cyclesave-wrap .csave-join-explainer { margin: 16px 0; }
.cyclesave-wrap .csave-join-explainer ol {
	padding-left: 20px;
	font-size: 0.875rem;
	color: var(--csave-text-secondary);
}
.cyclesave-wrap .csave-join-explainer li { margin-bottom: 6px; }
.cyclesave-wrap .csave-join-confirm {
	background: var(--csave-gold-light);
	border-left: 4px solid var(--csave-gold);
	padding: 12px 16px;
	border-radius: 0 var(--csave-radius-sm) var(--csave-radius-sm) 0;
	font-size: 0.875rem;
	margin-bottom: 16px;
}

/* Group join header */
.cyclesave-wrap .csave-group-join-header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

/* ============================================================
   Test Mode Banner (Stripe modal)
   ============================================================ */
.cyclesave-wrap .csave-test-mode-banner {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #FFF8E1;
	border: 1px solid #F59E0B;
	border-radius: var(--csave-radius-sm);
	padding: 8px 12px;
	margin-bottom: 14px;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #92400E;
	letter-spacing: 0.3px;
}
.cyclesave-wrap .csave-test-mode-banner::before {
	content: '⚠';
	font-size: 1rem;
}

/* ============================================================
   Bank Transfer Details (in-modal)
   ============================================================ */
.cyclesave-wrap .csave-bank-transfer-details {
	padding: 8px 0;
}
.cyclesave-wrap .csave-bank-transfer-icon {
	text-align: center;
	margin-bottom: 4px;
}
.cyclesave-wrap .csave-bank-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid var(--csave-border-light);
	font-size: 0.875rem;
}
.cyclesave-wrap .csave-bank-row:last-of-type {
	border-bottom: none;
}
.cyclesave-wrap .csave-bank-label {
	color: var(--csave-text-secondary);
	min-width: 120px;
}
.cyclesave-wrap .csave-bank-value {
	font-weight: 600;
	text-align: right;
	display: flex;
	align-items: center;
	gap: 6px;
}
.cyclesave-wrap .csave-bank-row-ref .csave-ref-code {
	font-size: 0.75rem;
}
.cyclesave-wrap .csave-copy-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	background: var(--csave-white);
	cursor: pointer;
	color: var(--csave-text-secondary);
	transition: all 0.15s;
}
.cyclesave-wrap .csave-copy-btn:hover {
	border-color: var(--csave-primary);
	color: var(--csave-primary);
	background: var(--csave-primary-light);
}
.cyclesave-wrap .csave-bank-notice {
	display: flex;
	gap: 8px;
	align-items: flex-start;
	margin-top: 16px;
	padding: 12px 14px;
	background: var(--csave-gold-light);
	border-left: 3px solid var(--csave-gold);
	border-radius: 0 var(--csave-radius-sm) var(--csave-radius-sm) 0;
	font-size: 0.8125rem;
	color: #92400E;
	line-height: 1.4;
}
.cyclesave-wrap .csave-bank-notice svg {
	flex-shrink: 0;
	margin-top: 1px;
}

/* ============================================================
   Payment Summary + Gateway Selection (Two-step Modal)
   ============================================================ */
.cyclesave-wrap .csave-payment-summary {
	padding: 20px 24px 0;
}
.cyclesave-wrap .csave-summary-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 10px 0;
	border-bottom: 1px solid var(--csave-border-light);
	font-size: 0.875rem;
}
.cyclesave-wrap .csave-summary-row:last-child {
	border-bottom: none;
}
.cyclesave-wrap .csave-summary-label {
	color: var(--csave-text-secondary);
}
.cyclesave-wrap .csave-summary-value {
	font-weight: 600;
	color: var(--csave-text);
}
.cyclesave-wrap .csave-summary-row-total {
	padding-top: 12px;
	margin-top: 4px;
	border-top: 2px solid var(--csave-border);
	border-bottom: none;
}
.cyclesave-wrap .csave-summary-amount {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--csave-primary);
}

/* Gateway Selection */
.cyclesave-wrap .csave-gateway-section {
	padding: 16px 24px 0;
}
.cyclesave-wrap .csave-gateway-title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--csave-text);
	margin: 0 0 12px;
	text-transform: uppercase;
	letter-spacing: 0.3px;
}
.cyclesave-wrap .csave-gateway-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.cyclesave-wrap .csave-gateway-option {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 1.5px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	cursor: pointer;
	transition: all var(--csave-transition);
	background: var(--csave-white);
}
.cyclesave-wrap .csave-gateway-option:hover {
	border-color: var(--csave-primary);
	background: var(--csave-primary-50);
}
.cyclesave-wrap .csave-gateway-option-selected {
	border-color: var(--csave-primary);
	background: var(--csave-primary-50);
	box-shadow: 0 0 0 1px var(--csave-primary);
}
.cyclesave-wrap .csave-gateway-option input[type="radio"] {
	display: none;
}
.cyclesave-wrap .csave-gateway-option-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--csave-radius-sm);
	background: var(--csave-bg);
	color: var(--csave-text-secondary);
	flex-shrink: 0;
}
.cyclesave-wrap .csave-gateway-option-selected .csave-gateway-option-icon {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-wrap .csave-gateway-option-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	flex: 1;
}
.cyclesave-wrap .csave-gateway-option-label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--csave-text);
}
.cyclesave-wrap .csave-gateway-option-default {
	font-size: 0.6875rem;
	color: var(--csave-primary);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.3px;
}
.cyclesave-wrap .csave-gateway-option-check {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: var(--csave-radius-full);
	color: transparent;
	flex-shrink: 0;
	transition: all var(--csave-transition);
}
.cyclesave-wrap .csave-gateway-option-selected .csave-gateway-option-check {
	color: var(--csave-primary);
	background: var(--csave-primary-light);
}

/* Payment Form Body */
.cyclesave-wrap .csave-payment-form-body {
	padding: 20px 24px;
	min-height: 200px;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 768px) {
	.cyclesave-wrap .csave-stats-row {
		grid-template-columns: repeat(2, 1fr);
	}
	.cyclesave-wrap .csave-form-grid {
		grid-template-columns: 1fr;
	}
	.cyclesave-wrap .csave-group-detail-stats {
		grid-template-columns: repeat(2, 1fr);
	}
	.cyclesave-wrap .csave-dash-header-left {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}
}

@media (max-width: 600px) {
	.cyclesave-wrap .csave-stats-row {
		grid-template-columns: 1fr 1fr;
		gap: 10px;
	}
	.cyclesave-wrap .csave-groups-grid {
		grid-template-columns: 1fr;
	}
	.cyclesave-wrap .csave-dash-body {
		flex-direction: column;
	}
	.cyclesave-wrap .csave-tab-nav {
		width: 100%;
		flex-direction: row;
		flex-wrap: wrap;
		position: static;
		gap: 0;
	}
	.cyclesave-wrap .csave-tab-nav .csave-tab-link {
		padding: 8px 12px !important;
		font-size: 0.8125rem !important;
		border-bottom: 3px solid transparent;
		border-radius: 0;
		box-shadow: none;
	}
	.cyclesave-wrap .csave-tab-nav .csave-tab-link.csave-tab-active {
		border-bottom-color: var(--csave-primary);
		box-shadow: none;
	}
	.cyclesave-wrap .csave-tab-nav-footer {
		border-top: none;
		border-left: 1px solid var(--csave-border);
		margin-top: 0;
		margin-left: 4px;
		padding-top: 0;
		padding-left: 4px;
	}
	.cyclesave-wrap .csave-tab-link svg {
		display: none;
	}
	.cyclesave-wrap .csave-round-header {
		flex-direction: column;
		gap: 6px;
	}
	.cyclesave-wrap .csave-group-detail-stats {
		grid-template-columns: 1fr;
	}
	.cyclesave-wrap .csave-stat-card {
		padding: 14px;
	}
	.cyclesave-wrap .csave-stat-value {
		font-size: 1.25rem;
	}
	.cyclesave-wrap .csave-modal-content {
		margin: 16px;
	}
	.cyclesave-wrap .csave-ledger-stats {
		flex-direction: column;
	}
}

/* ============================================================
   Clickable Group Cards
   ============================================================ */
.cyclesave-wrap .csave-group-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}
.cyclesave-wrap .csave-group-card-link:hover,
.cyclesave-wrap .csave-group-card-link:focus {
	text-decoration: none;
	color: inherit;
}
.cyclesave-wrap .csave-group-card-clickable {
	transition: transform 0.15s ease, box-shadow 0.15s ease;
	cursor: pointer;
}
.cyclesave-wrap .csave-group-card-clickable:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

/* ============================================================
   Group Detail Page (inline in dashboard)
   ============================================================ */
.cyclesave-wrap .csave-group-detail-page {
	animation: csFadeIn 0.2s ease;
}
.cyclesave-wrap .csave-group-detail-back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	color: var(--csave-primary);
	text-decoration: none;
	font-weight: 600;
	margin-bottom: 16px;
}
.cyclesave-wrap .csave-group-detail-back:hover {
	text-decoration: underline;
}
.cyclesave-wrap .csave-group-detail-banner {
	background: var(--csave-primary);
	color: #fff;
	border-radius: var(--csave-radius);
	padding: 24px 28px;
	margin-bottom: 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 16px;
}
.cyclesave-wrap .csave-group-detail-banner h2 {
	margin: 0;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
}
.cyclesave-wrap .csave-group-detail-banner .csave-badge {
	background: rgba(255,255,255,0.2);
	color: #fff;
}
.cyclesave-wrap .csave-group-detail-banner-stats {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
}
.cyclesave-wrap .csave-group-detail-banner-stat {
	text-align: center;
}
.cyclesave-wrap .csave-group-detail-banner-stat-value {
	display: block;
	font-size: 20px;
	font-weight: 700;
}
.cyclesave-wrap .csave-group-detail-banner-stat-label {
	font-size: 12px;
	opacity: 0.85;
}

/* Sub-tab Navigation */
.cyclesave-wrap .csave-group-sub-nav {
	display: flex;
	gap: 0;
	margin-bottom: 20px;
	border-bottom: 2px solid var(--csave-border);
}
.cyclesave-wrap .csave-group-sub-tab {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	font-size: 14px;
	font-weight: 500;
	color: var(--csave-text-muted);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	transition: all 0.15s;
}
.cyclesave-wrap .csave-group-sub-tab:hover {
	color: var(--csave-primary);
	text-decoration: none;
}
.cyclesave-wrap .csave-group-sub-tab-active {
	color: var(--csave-primary);
	font-weight: 600;
	border-bottom-color: var(--csave-primary);
}
@keyframes csFadeIn {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   Utility Classes — extracted from inline styles
   ========================================================================== */

/* Hidden utility (toggled by JS) */
.csave-hidden { display: none; }

/* JS-injected state text (loading, error) */
.cyclesave-wrap .csave-loading-text {
	text-align: center;
	color: #6B7280;
	padding: 12px 0;
}
.cyclesave-wrap .csave-error-text {
	text-align: center;
	color: #991B1B;
	padding: 12px 0;
}
.cyclesave-wrap .csave-bank-subtitle {
	text-align: center;
	color: #6B7280;
	font-size: 13px;
	margin-bottom: 16px;
}

/* Dashboard / checkout helpers */
.cyclesave-wrap .csave-mb-16 { margin-bottom: 16px; }
.cyclesave-wrap .csave-mb-20 { margin-bottom: 20px; }
.cyclesave-wrap .csave-mt-20 { margin-top: 20px; }
.cyclesave-wrap .csave-mt-24 { margin-top: 24px; }
.cyclesave-wrap .csave-section-title { margin-top: 28px; }
.cyclesave-wrap .csave-member-row {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 12px;
	background: var(--csave-bg);
	border-radius: var(--csave-radius-sm);
}
.cyclesave-wrap .csave-badge-xs { font-size: 10px; padding: 1px 6px; }

/* Checkout form helpers */
.cyclesave-wrap .csave-fieldset-clean {
	border: none;
	margin: 0 0 16px;
	padding: 0;
}
.cyclesave-wrap .csave-legend-clean {
	font-weight: 600;
	font-size: 15px;
	margin-bottom: 12px;
	padding: 0;
}
.cyclesave-wrap .csave-form-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.cyclesave-wrap .csave-form-grid-2--mt {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	margin-top: 10px;
}
.cyclesave-wrap .csave-form-group--mt { margin-top: 10px; }

/* ============================================================
   Payment Success Page — Receipt
   ============================================================ */
.cyclesave-wrap .csave-success-receipt {
	max-width: 520px;
	margin: 24px auto;
	background: #fff;
	border: 1px solid var(--csave-border-light, #E5E7EB);
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.cyclesave-wrap .csave-success-icon {
	text-align: center;
	padding: 28px 24px 8px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-letterhead {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 16px 28px 12px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-brand {
	display: flex;
	flex-direction: column;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-brand-name {
	font-size: 1.125rem;
	color: var(--csave-text, #1A1A2E);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-brand-tagline {
	font-size: 0.75rem;
	color: var(--csave-text-secondary, #6B7280);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-stamp {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 2px;
	color: var(--csave-primary, #0D7C66);
	border: 2px solid var(--csave-primary, #0D7C66);
	padding: 4px 12px;
	border-radius: 4px;
	text-transform: uppercase;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-meta-row {
	display: flex;
	justify-content: space-between;
	padding: 0 28px 16px;
	gap: 16px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-meta-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-meta-label {
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--csave-text-secondary, #6B7280);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-meta-value {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--csave-text, #1A1A2E);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-divider {
	height: 1px;
	background: var(--csave-border-light, #E5E7EB);
	margin: 0 28px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-section {
	padding: 16px 28px;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-section-title {
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--csave-text-secondary, #6B7280);
	margin-bottom: 8px;
	font-weight: 600;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-billed-name {
	font-weight: 600;
	font-size: 0.875rem;
	color: var(--csave-text, #1A1A2E);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-billed-email {
	font-size: 0.8125rem;
	color: var(--csave-text-secondary, #6B7280);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-table {
	width: 100%;
	border-collapse: collapse;
	table-layout: fixed;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-table td {
	padding: 10px 28px;
	font-size: 0.875rem;
	border-bottom: 1px solid var(--csave-border-light, #F3F4F6);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-table tr:last-child td {
	border-bottom: none;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-table-label {
	width: 45%;
	color: var(--csave-text-secondary, #6B7280);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-table-value {
	width: 55%;
	text-align: left;
	font-weight: 600;
	color: var(--csave-text, #1A1A2E);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-total-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 28px;
	font-size: 1.125rem;
	font-weight: 700;
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-total-label {
	color: var(--csave-text, #1A1A2E);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-total-amount {
	color: var(--csave-primary, #0D7C66);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-footer-note {
	padding: 20px 28px;
	background: var(--csave-bg, #F9FAFB);
	border-top: 1px solid var(--csave-border-light, #E5E7EB);
	text-align: center;
	font-size: 0.8125rem;
	color: var(--csave-text-secondary, #6B7280);
}
.cyclesave-wrap .csave-success-receipt .csave-receipt-powered {
	margin-top: 6px;
	font-size: 0.6875rem;
	opacity: 0.7;
}
.cyclesave-wrap .csave-success-actions {
	display: flex;
	justify-content: center;
	gap: 12px;
	margin: 20px auto 0;
	max-width: 520px;
}
@media print {
	/* Hide everything except the receipt */
	body * {
		visibility: hidden !important;
	}
	.cyclesave-wrap,
	.cyclesave-wrap * {
		visibility: visible !important;
	}
	.cyclesave-wrap {
		position: absolute !important;
		left: 0 !important;
		top: 0 !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
	}
	.cyclesave-wrap .csave-success-receipt {
		max-width: 100% !important;
		margin: 0 auto !important;
		box-shadow: none !important;
		border: none !important;
	}
	.cyclesave-wrap .csave-success-actions,
	.cyclesave-wrap .csave-notice {
		display: none !important;
		visibility: hidden !important;
	}
}

/* --- Checkout Page Layout --- */
.cyclesave-wrap .csave-back-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--csave-primary, #0d9488);
	text-decoration: none;
	padding: 6px 12px;
	border-radius: 6px;
	transition: background 0.15s, color 0.15s;
}
.cyclesave-wrap .csave-back-link:hover {
	background: rgba(13, 148, 136, 0.08);
	color: var(--csave-primary-dark, #0f766e);
}
.cyclesave-wrap .csave-checkout-grid {
	display: flex;
	flex-direction: column;
	gap: 20px;
	max-width: 560px;
	margin: 24px auto 0;
}
.cyclesave-wrap .csave-checkout-details {
	margin-top: 16px;
}
.cyclesave-wrap .csave-checkout-summary {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--csave-border-light);
}
.cyclesave-wrap .csave-button-full {
	width: 100%;
	display: block;
	margin-top: 16px;
}
.cyclesave-wrap .csave-checkout-security {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 14px;
}

/* Payout position picker */
.cyclesave-wrap .csave-position-picker {
	margin-top: 20px;
	margin-bottom: 20px;
}
.cyclesave-wrap .csave-position-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}
.cyclesave-wrap .csave-position-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	width: 64px;
	padding: 10px 6px;
	border: 2px solid var(--csave-border, #e2e8f0);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
}
.cyclesave-wrap .csave-position-item input[type="radio"] {
	display: none;
}
.cyclesave-wrap .csave-position-item:not(.csave-position-taken):hover {
	border-color: var(--csave-primary, #4f46e5);
	background: var(--csave-primary-light, #eef2ff);
}
.cyclesave-wrap .csave-position-item:has(input:checked) {
	border-color: var(--csave-primary, #4f46e5);
	background: var(--csave-primary-light, #eef2ff);
}
.cyclesave-wrap .csave-position-number {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
}
.cyclesave-wrap .csave-position-label {
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--csave-text-muted, #64748b);
}
.cyclesave-wrap .csave-position-taken {
	opacity: 0.4;
	cursor: not-allowed;
	background: var(--csave-bg-muted, #f8fafc);
}

/* Fix Stripe element ID prefix (was cs-, is now csave-) */
.cyclesave-wrap #csave-stripe-payment-element {
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 12px 14px;
	background: #fff;
	margin-bottom: 16px;
	transition: border-color 0.15s ease;
}
.cyclesave-wrap #csave-stripe-payment-element:hover {
	border-color: var(--csave-text-muted);
}
.cyclesave-wrap #csave-stripe-payment-element.StripeElement--focus {
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 1px var(--csave-primary);
}
.cyclesave-wrap #csave-stripe-payment-element.StripeElement--invalid {
	border-color: var(--csave-danger, #e53e3e);
}
.cyclesave-wrap #csave-checkout-stripe {
	margin-top: 8px;
}

/* --- Gateway accordion on checkout page --- */
.cyclesave-wrap .csave-gateway-option-wrap {
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	margin-bottom: 8px;
	overflow: hidden;
}
.cyclesave-wrap .csave-gateway-option-wrap + .csave-gateway-option-wrap {
	margin-top: -1px; /* collapse borders between options */
}
.cyclesave-wrap .csave-gateway-form {
	border-top: 1px solid var(--csave-border-light);
	padding: 16px;
}

/* --- Bank transfer details panel --- */
.cyclesave-wrap .csave-bank-transfer-details {
	background: var(--csave-primary-50);
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 14px 16px;
	margin-bottom: 16px;
}
.cyclesave-wrap .csave-bank-transfer-details .csave-info-row {
	border-bottom: 1px solid var(--csave-border-light);
}
.cyclesave-wrap .csave-bank-transfer-details .csave-info-row:last-of-type {
	border-bottom: none;
}
