/* ============================================================
   CycleSave — Admin Styles (Green Design System)
   All selectors scoped under .cyclesave-admin-wrap
   ============================================================ */

/* ----- CSS Custom Properties ----- */
.cyclesave-admin-wrap {
	--csave-primary: #50A659;
	--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: #0073AA;
	--csave-purple:        #0D7C66;   /* CycleSave primary teal */
	--csave-purple-dark:   #096B58;   /* CycleSave primary dark */
	--csave-purple-xdark:  #053D31; 
	--csave-blue-light: #EFF6FF;
	--csave-text: #1A1A2E;
	--csave-text-secondary: #6B7280;
	--csave-border: #E5E7EB;
	--csave-bg: #F9FAFB;
	--csave-radius: 10px;
	--csave-radius-sm: 6px;
	--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 rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06);

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

/* ----- Page Header ----- */
.cyclesave-admin-wrap .csave-admin-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 24px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-admin-header h1 {
	font-size: 24px;
	font-weight: 700;
	color: var(--csave-text);
	margin: 0;
	padding: 0;
}
.cyclesave-admin-wrap .csave-admin-header-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-admin-quick-actions .csave-admin-btn-svg svg {
	color: #fff!important;
}	
.cyclesave-admin-wrap .csave-admin-header .csave-admin-btn {
	margin-right: 290px;
}		

/* ----- Buttons ----- */
.cyclesave-admin-wrap .csave-admin-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.4;
	cursor: pointer;
	border: 1px solid transparent;
	text-decoration: none;
	transition: all 0.15s ease;
	white-space: nowrap;
}
.cyclesave-admin-wrap .csave-admin-btn svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}
.cyclesave-admin-wrap .csave-admin-btn-primary {
	background: var(--csave-primary);
	color: #fff;
	border-color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-admin-btn-primary:hover,
.cyclesave-admin-wrap .csave-admin-btn-primary:focus {
	background: var(--csave-primary-dark);
	border-color: var(--csave-primary-dark);
	color: #fff;
}
.cyclesave-admin-wrap .csave-admin-btn-secondary {
	background: var(--csave-blue);
	color: #fff;
	border-color: var(--csave-blue);
	padding: 10px 18px;
}
.cyclesave-admin-wrap .csave-admin-btn-secondary:hover,
.cyclesave-admin-wrap .csave-admin-btn-secondary:focus {
	background: var(--csave-primary-dark);
	border-color: var(--csave-primary-dark);
	color: #fff;
}
.cyclesave-admin-wrap .csave-admin-btn-outline {
	background: #fff;
	color: var(--csave-primary);
	border-color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-admin-btn-outline:hover,
.cyclesave-admin-wrap .csave-admin-btn-outline:focus {
	background: var(--csave-primary-light);
	color: var(--csave-primary-dark);
}
.cyclesave-admin-wrap .csave-admin-btn-danger {
	background: var(--csave-red);
	color: #fff!important;
	border-color: var(--csave-red);
}
.cyclesave-admin-wrap .csave-admin-btn-danger:hover {
	background: #fff!important;
	color: #c82333!important;
}
.cyclesave-admin-wrap .csave-admin-btn-sm {
	padding: 5px 10px;
	font-size: 12px;
}

/* ----- Panel / Card ----- */
.cyclesave-admin-wrap .csave-admin-panel {
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	box-shadow: var(--csave-shadow);
	margin-bottom: 20px;
	overflow: hidden;
}
.cyclesave-admin-wrap .csave-admin-panel-header {
	padding: 16px 20px;
	border-bottom: 1px solid var(--csave-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}
.cyclesave-admin-wrap .csave-admin-panel-header h2,
.cyclesave-admin-wrap .csave-admin-panel-header h3 {
	margin: 0;
	font-size: 15px;
	font-weight: 700;
	color: var(--csave-text);
}
.cyclesave-admin-wrap .csave-admin-panel-body {
	padding: 20px;
}
.cyclesave-admin-wrap .csave-admin-panel-body svg {
	width: 20px;
	height: 20px;
	color: var(--csave-primary);
}
/* Override: chart containers must not be constrained to icon size */
.cyclesave-admin-wrap .csave-chart-wrap svg {
	width: unset;
	height: unset;
	color: unset;
}	

/* ----- Stats Row ----- */
.cyclesave-admin-wrap .csave-admin-stats-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	margin-bottom: 24px;
}
.cyclesave-admin-wrap .csave-admin-stat-card {
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 20px;
	box-shadow: var(--csave-shadow);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon svg {
	width: 24px;
	height: 24px;
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon.csave-icon-green {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon.csave-icon-blue {
	background: var(--csave-blue-light);
	color: var(--csave-blue);
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon.csave-icon-gold,
.cyclesave-admin-wrap .csave-admin-stat-card-icon.csave-icon-yellow {
	background: var(--csave-gold-light);
	color: var(--csave-gold);
}
.cyclesave-admin-wrap .csave-admin-stat-card-icon.csave-icon-red {
	background: var(--csave-red-light);
	color: var(--csave-red);
}
.cyclesave-admin-wrap .csave-admin-stat-card-value {
	font-size: 26px;
	font-weight: 700;
	color: var(--csave-text);
	line-height: 1.2;
	text-align: center;
}
.cyclesave-admin-wrap .csave-admin-stat-card-label {
	font-size: 13px;
	color: var(--csave-text-secondary);
	text-align: center;
	margin-top: 4px;
}

/* ----- Grid Layouts ----- */
.cyclesave-admin-wrap .csave-admin-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-bottom: 20px;
}
.cyclesave-admin-wrap .csave-admin-grid-2--start {
	align-items: start;
}
.cyclesave-admin-wrap .csave-admin-grid-3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

/* ----- Table ----- */
.cyclesave-admin-wrap .csave-admin-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}
.cyclesave-admin-wrap .csave-admin-table thead th {
	background: var(--csave-bg);
	padding: 10px 14px;
	text-align: left;
	font-weight: 600;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--csave-text-secondary);
	border-bottom: 2px solid var(--csave-border);
	white-space: nowrap;
}
.cyclesave-admin-wrap .csave-admin-table tbody td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--csave-border);
	vertical-align: middle;
	color: var(--csave-text);
}
.cyclesave-admin-wrap .csave-admin-table tbody tr:last-child td {
	border-bottom: none;
}
.cyclesave-admin-wrap .csave-admin-table tbody tr:hover {
	background: var(--csave-primary-50);
}
.cyclesave-admin-wrap .csave-admin-table .csave-text-secondary {
	color: var(--csave-text-secondary);
	font-size: 12px;
}
.cyclesave-admin-wrap .csave-admin-table .csave-amount {
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

/* ----- Badges ----- */
.cyclesave-admin-wrap .csave-admin-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 12px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	white-space: nowrap;
}
.cyclesave-admin-wrap .csave-admin-badge-success {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-admin-badge-warning {
	background: var(--csave-gold-light);
	color: #b8860b;
}
.cyclesave-admin-wrap .csave-admin-badge-danger {
	background: var(--csave-red-light);
	color: var(--csave-red);
}
.cyclesave-admin-wrap .csave-admin-badge-info {
	background: var(--csave-blue-light);
	color: var(--csave-blue);
}
.cyclesave-admin-wrap .csave-admin-badge-neutral {
	background: #f3f4f6;
	color: var(--csave-text-secondary);
}

/* ----- Status Mini Cards ----- */
.cyclesave-admin-wrap .csave-status-cards {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-status-mini-card {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	padding: 12px 16px;
	flex: 1;
	min-width: 100px;
}
.cyclesave-admin-wrap .csave-status-mini-card-count {
	font-size: 22px;
	font-weight: 700;
	color: var(--csave-text);
}
.cyclesave-admin-wrap .csave-status-mini-card-label {
	font-size: 12px;
	color: var(--csave-text-secondary);
	text-transform: capitalize;
}

/* ----- Quick Action Buttons ----- */
.cyclesave-admin-wrap .csave-quick-actions {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.cyclesave-admin-wrap .csave-quick-action-btn {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	text-decoration: none;
	color: var(--csave-text);
	font-size: 14px;
	font-weight: 600;
	transition: all 0.15s ease;
}
.cyclesave-admin-wrap .csave-quick-action-btn:hover {
	border-color: var(--csave-primary);
	background: var(--csave-primary-50);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-quick-action-btn svg {
	width: 20px;
	height: 20px;
	color: var(--csave-primary);
}

/* ----- Notices ----- */
.cyclesave-admin-wrap .csave-admin-notice {
	padding: 12px 16px;
	border-radius: var(--csave-radius-sm);
	margin-bottom: 16px;
	font-size: 13px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.cyclesave-admin-wrap .csave-admin-notice-success {
	background: var(--csave-primary-light);
	color: var(--csave-primary-dark);
	border: 1px solid #b8e6d9;
}
.cyclesave-admin-wrap .csave-admin-notice-error {
	background: var(--csave-red-light);
	color: var(--csave-red);
	border: 1px solid #f5c6cb;
}
.cyclesave-admin-wrap .csave-admin-notice-info {
	background: var(--csave-blue-light);
	color: var(--csave-blue);
	border: 1px solid #bfdbfe;
}

/* ----- Forms ----- */
.cyclesave-admin-wrap .csave-admin-form-group {
	margin-bottom: 16px;
}
.cyclesave-admin-wrap .csave-admin-label {
	display: block;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-text);
	margin-bottom: 6px;
}
.cyclesave-admin-wrap .csave-admin-input,
.cyclesave-admin-wrap .csave-admin-select,
.cyclesave-admin-wrap .csave-admin-textarea {
	width: 100%;
	padding: 8px 12px;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	color: var(--csave-text);
	background: #fff;
	transition: border-color 0.15s ease;
	box-sizing: border-box;
}
.cyclesave-admin-wrap .csave-admin-input:focus,
.cyclesave-admin-wrap .csave-admin-select:focus,
.cyclesave-admin-wrap .csave-admin-textarea:focus {
	outline: none;
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 2px rgba(13, 124, 102, 0.15);
}
.cyclesave-admin-wrap .csave-admin-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.cyclesave-admin-wrap .csave-admin-form-actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 20px;
}

/* ----- Filters Bar ----- */
.cyclesave-admin-wrap .csave-admin-filters {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-admin-filters .csave-admin-form-group {
	margin-bottom: 0;
	flex: 1;
	min-width: 150px;
}

/* ----- Modal ----- */
.cyclesave-admin-wrap .csave-admin-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: none;
	align-items: center;
	justify-content: center;
}
.cyclesave-admin-wrap .csave-admin-modal.csave-active {
	display: flex;
}
.cyclesave-admin-wrap .csave-admin-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
}
.cyclesave-admin-wrap .csave-admin-modal-content {
	position: relative;
	background: #fff;
	border-radius: var(--csave-radius);
	max-width: 560px;
	width: 90%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	z-index: 1;
}
.cyclesave-admin-wrap .csave-admin-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 24px;
	border-bottom: 1px solid var(--csave-border);
}
.cyclesave-admin-wrap .csave-admin-modal-header h2 {
	margin: 0;
	font-size: 17px;
	font-weight: 700;
}
.cyclesave-admin-wrap .csave-admin-modal-close {
	background: none;
	border: none;
	font-size: 24px;
	color: var(--csave-text-secondary);
	cursor: pointer;
	padding: 4px;
	line-height: 1;
}
.cyclesave-admin-wrap .csave-admin-modal-close:hover {
	color: var(--csave-text);
}
.cyclesave-admin-wrap .csave-admin-modal-body {
	padding: 24px;
}
.cyclesave-admin-wrap .csave-admin-modal-footer {
	padding: 16px 24px;
	border-top: 1px solid var(--csave-border);
	display: flex;
	justify-content: flex-end;
	gap: 10px;
}

/* ----- User Search Autocomplete ----- */
.cyclesave-admin-wrap .csave-user-search-wrap {
	position: relative;
}
.cyclesave-admin-wrap .csave-user-search-results {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: 0 0 var(--csave-radius-sm) var(--csave-radius-sm);
	box-shadow: var(--csave-shadow-md);
	max-height: 200px;
	overflow-y: auto;
	z-index: 10;
	display: none;
}
.cyclesave-admin-wrap .csave-user-result {
	padding: 8px 12px;
	cursor: pointer;
	font-size: 13px;
	border-bottom: 1px solid var(--csave-border);
}
.cyclesave-admin-wrap .csave-user-result:last-child {
	border-bottom: none;
}
.cyclesave-admin-wrap .csave-user-result:hover {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-no-results {
	padding: 10px 12px;
	color: var(--csave-text-secondary);
	font-size: 13px;
}

/* ----- Multi-Select User Chips ----- */
.cyclesave-admin-wrap .csave-selected-users {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	min-height: 0;
}
.cyclesave-admin-wrap .csave-selected-users:not(:empty) {
	padding: 4px 0 8px;
}
.cyclesave-admin-wrap .csave-user-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 8px 6px 12px;
	background: var(--csave-primary-light);
	border: 1px solid var(--csave-primary);
	border-radius: 20px;
	font-size: 12px;
	line-height: 1.3;
	color: var(--csave-primary);
	animation: cs-chip-in 0.15s ease;
}
@keyframes cs-chip-in {
	from { opacity: 0; transform: scale(0.9); }
	to   { opacity: 1; transform: scale(1); }
}
.cyclesave-admin-wrap .csave-user-chip-name {
	font-weight: 600;
}
.cyclesave-admin-wrap .csave-user-chip-email {
	color: var(--csave-text-secondary);
	font-size: 11px;
}
.cyclesave-admin-wrap .csave-user-chip-remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: var(--csave-primary);
	color: #fff;
	font-size: 14px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s ease, transform 0.1s ease;
	flex-shrink: 0;
}
.cyclesave-admin-wrap .csave-user-chip-remove:hover {
	background: var(--csave-red);
	transform: scale(1.1);
}

/* ----- Empty State ----- */
.cyclesave-admin-wrap .csave-admin-empty {
	text-align: center;
	padding: 40px 20px;
	color: var(--csave-text-secondary);
}
.cyclesave-admin-wrap .csave-admin-empty svg {
	width: 48px;
	height: 48px;
	margin-bottom: 12px;
	opacity: 0.4;
}
.cyclesave-admin-wrap .csave-admin-empty p {
	margin: 0;
	font-size: 14px;
}

/* ----- Backward Compatible: Legacy classes (group-detail, payouts, etc.) ----- */

/* Sortable payout order */
.cyclesave-admin-wrap .csave-sortable-list,
.csave-sortable-list {
	list-style: none;
	margin: 0;
	padding: 0;
	border: 1px solid var(--csave-border, #ddd);
	border-radius: var(--csave-radius-sm, 4px);
	max-width: 400px;
}
.cyclesave-admin-wrap .csave-sortable-item,
.csave-sortable-item {
	display: flex;
	align-items: center;
	padding: 10px 14px;
	border-bottom: 1px solid var(--csave-border, #eee);
	background: #fff;
	cursor: grab;
	transition: background 0.15s;
}
.csave-sortable-item:last-child { border-bottom: none; }
.csave-sortable-item:hover { background: var(--csave-primary-50, #f6f7f7); }
.csave-sortable-item.sortable-ghost { background: var(--csave-primary-light, #e8f0fe); opacity: 0.7; }
.csave-drag-handle {
	margin-right: 12px;
	color: #999;
	cursor: grab;
	font-size: 16px;
}

/* Legacy panel styles (for group-detail, payouts, reports) */
.cyclesave-admin .csave-panel-grid,
.cyclesave-admin-wrap .csave-panel-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-top: 20px;
}
.cyclesave-admin .csave-full-width,
.cyclesave-admin-wrap .csave-full-width {
	grid-column: 1 / -1;
}
.cyclesave-admin .csave-panel,
.cyclesave-admin-wrap .csave-panel {
	background: #fff;
	border: 1px solid var(--csave-border, #ccd0d4);
	border-radius: var(--csave-radius-sm, 4px);
	padding: 20px;
}
.cyclesave-admin .csave-panel h2,
.cyclesave-admin-wrap .csave-panel h2 {
	margin-top: 0;
	font-size: 1rem;
	border-bottom: 1px solid var(--csave-border, #eee);
	padding-bottom: 10px;
}

/* Status badges (legacy) */
.csave-status-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 12px;
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
}

/* Info table (legacy) */
.csave-info-table th { font-weight: 600; width: 150px; }
.csave-info-table td { color: #333; }
.csave-muted { color: #666; font-size: 13px; }

/* Payout cards (legacy) */
.csave-payout-card {
	display: flex;
	align-items: flex-start;
	gap: 24px;
	padding: 16px;
	background: #fff;
	border: 1px solid var(--csave-border, #ccd0d4);
	border-radius: var(--csave-radius-sm, 4px);
	margin-bottom: 16px;
}
.csave-payout-info { flex: 1; line-height: 1.8; }
.csave-payout-form { flex: 0 0 340px; }
.csave-payout-form label { display: block; font-size: 12px; font-weight: 600; margin-top: 10px; margin-bottom: 4px; }
.csave-payout-form input { width: 100%; }
.csave-payout-form .button { margin-top: 14px; }

/* Legacy stats grid (reports page) */
.csave-stats-grid {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin: 16px 0;
}
.csave-stat-card {
	background: #fff;
	border: 1px solid var(--csave-border, #ccd0d4);
	border-radius: var(--csave-radius-sm, 4px);
	padding: 16px 24px;
	text-align: center;
	min-width: 120px;
}
.csave-stat-number { font-size: 28px; font-weight: 700; color: var(--csave-primary, #1a73e8); }
.csave-stat-label  { font-size: 12px; color: #666; margin-top: 4px; }

/* Pro badge */
.cyclesave-pro-badge {
	display: inline-block;
	padding: 2px 8px;
	background: var(--csave-gold, #f0b429);
	color: #333;
	border-radius: 3px;
	font-size: 11px;
	font-weight: 700;
	vertical-align: middle;
	margin-left: 8px;
}
.cyclesave-pro-badge.csave-active { background: var(--csave-primary, #46b450); color: #fff; }

/* Pro upsell box */
.csave-pro-upsell {
	background: var(--csave-gold-light, #f9f9f9);
	border-left: 4px solid var(--csave-gold, #f0b429);
	padding: 14px 18px;
	border-radius: 0 4px 4px 0;
	margin: 14px 0;
}

/* Legacy modal */
.csave-modal {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.55);
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
}
.csave-modal.csave-active { display: flex; }
.csave-modal-content {
	background: #fff;
	border-radius: var(--csave-radius, 6px);
	padding: 28px 32px;
	max-width: 560px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 8px 40px rgba(0,0,0,.25);
}
.csave-modal-content h2 { margin-top: 0; }

/* Modal actions (payout order form buttons) */
.csave-modal-actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	flex-wrap: wrap;
	margin-top: 20px;
}

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

/* ----- Visibility Badge ----- */
.cyclesave-admin-wrap .csave-visibility-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 10px;
	font-size: 11px;
	font-weight: 600;
}
.cyclesave-admin-wrap .csave-visibility-public {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-visibility-private {
	background: var(--csave-gold-light);
	color: #b8860b;
}

/* ----- Toggle Switch ----- */
.cyclesave-admin-wrap .csave-toggle {
	display: flex;
	gap: 0;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	overflow: hidden;
}
.cyclesave-admin-wrap .csave-toggle-option {
	padding: 6px 14px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	background: #fff;
	border: none;
	color: var(--csave-text-secondary);
	transition: all 0.15s;
}
.cyclesave-admin-wrap .csave-toggle-option:not(:last-child) {
	border-right: 1px solid var(--csave-border);
}
.cyclesave-admin-wrap .csave-toggle-option.csave-active {
	background: var(--csave-primary);
	color: #fff;
}

/* ----- License Section ----- */
.cyclesave-admin-wrap .csave-license-status {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-weight: 600;
}
.cyclesave-admin-wrap .csave-license-active {
	background: var(--csave-primary-light);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-license-inactive {
	background: var(--csave-red-light);
	color: var(--csave-red);
}
.cyclesave-admin-wrap .csave-license-expired {
	background: var(--csave-gold-light);
	color: #b8860b;
}

/* ----- Tab Navigation ----- */
.cyclesave-admin-wrap .csave-admin-tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--csave-border);
	margin-bottom: 24px;
	overflow-x: auto;
}
.cyclesave-admin-wrap .csave-admin-tab {
	padding: 10px 20px;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-text-secondary);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	white-space: nowrap;
	transition: all 0.15s ease;
}
.cyclesave-admin-wrap .csave-admin-tab:hover {
	color: var(--csave-primary);
	background: var(--csave-primary-50);
}
.cyclesave-admin-wrap .csave-admin-tab-active {
	color: var(--csave-primary);
	border-bottom-color: var(--csave-primary);
}

/* ----- Textarea ----- */
.cyclesave-admin-wrap .csave-admin-textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-family: inherit;
	color: var(--csave-text);
	background: #fff;
	resize: vertical;
	transition: border-color 0.15s ease;
	box-sizing: border-box;
}
.cyclesave-admin-wrap .csave-admin-textarea:focus {
	outline: none;
	border-color: var(--csave-primary);
	box-shadow: 0 0 0 2px rgba(13, 124, 102, 0.15);
}

/* ----- Payout Timeline ----- */
.cyclesave-admin-wrap .csave-timeline {
	position: relative;
	padding-left: 60px;
}
.cyclesave-admin-wrap .csave-timeline::before {
	content: '';
	position: absolute;
	left: 28px;
	top: 0;
	bottom: 0;
	width: 2px;
	background: var(--csave-border);
}
.cyclesave-admin-wrap .csave-timeline-item {
	position: relative;
	margin-bottom: 16px;
}
.cyclesave-admin-wrap .csave-timeline-marker {
	position: absolute;
	left: -42px;
	top: 18px;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	font-weight: 700;
	z-index: 1;
	border: 2px solid #fff;
	box-shadow: var(--csave-shadow);
}
.cyclesave-admin-wrap .csave-timeline-marker-done {
	background: var(--csave-primary);
	color: #fff;
}
.cyclesave-admin-wrap .csave-timeline-marker-current {
	background: var(--csave-gold);
	color: #fff;
}
.cyclesave-admin-wrap .csave-timeline-marker-upcoming {
	background: #fff;
	color: var(--csave-text-secondary);
	border-color: var(--csave-border);
}
.cyclesave-admin-wrap .csave-timeline-card {
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	padding: 16px 20px;
	display: flex;
	align-items: center;
	gap: 14px;
}
.cyclesave-admin-wrap .csave-timeline-card-current {
	background: var(--csave-gold-light);
	border-color: var(--csave-gold);
}

/* ----- Member Cards ----- */
.cyclesave-admin-wrap .csave-member-card {
	background: #fff;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius);
	overflow: hidden;
	box-shadow: var(--csave-shadow);
}
.cyclesave-admin-wrap .csave-member-card-body {
	padding: 20px;
}
.cyclesave-admin-wrap .csave-member-card-header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

/* ----- Avatar ----- */
.cyclesave-admin-wrap .csave-avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: var(--csave-primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
	flex-shrink: 0;
	text-transform: uppercase;
}
.cyclesave-admin-wrap .csave-avatar-lg {
	width: 52px;
	height: 52px;
	font-size: 16px;
}

/* ----- Progress Bar ----- */
.cyclesave-admin-wrap .csave-progress-bar {
	width: 100%;
	height: 6px;
	background: var(--csave-border);
	border-radius: 3px;
	overflow: hidden;
}
.cyclesave-admin-wrap .csave-progress-bar-fill {
	height: 100%;
	border-radius: 3px;
	transition: width 0.3s ease;
}
.cyclesave-admin-wrap .csave-progress-bar-fill-green {
	background: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-progress-bar-fill-gold {
	background: var(--csave-gold);
}

/* ----- Contribution History ----- */
.cyclesave-admin-wrap .csave-member-history {
	display: none;
	border-top: 1px solid var(--csave-border);
	padding: 16px 20px;
	background: var(--csave-bg);
}
.cyclesave-admin-wrap .csave-member-history.csave-active {
	display: block;
}
.cyclesave-admin-wrap .csave-history-toggle {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--csave-primary);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	background: none;
	border: none;
	padding: 0;
}
.cyclesave-admin-wrap .csave-history-toggle:hover {
	text-decoration: underline;
}

/* ----- Stat Pills ----- */
.cyclesave-admin-wrap .csave-stat-pills {
	display: flex;
	gap: 12px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-stat-pill {
	flex: 1;
	min-width: 100px;
	padding: 14px 20px;
	border-radius: var(--csave-radius);
	text-align: center;
}
.cyclesave-admin-wrap .csave-stat-pill-green {
	background: var(--csave-primary-light);
}
.cyclesave-admin-wrap .csave-stat-pill-gold {
	background: var(--csave-gold-light);
}
.cyclesave-admin-wrap .csave-stat-pill-red {
	background: var(--csave-red-light);
}
.cyclesave-admin-wrap .csave-stat-pill-count {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
}
.cyclesave-admin-wrap .csave-stat-pill-label {
	font-size: 12px;
	color: var(--csave-text-secondary);
	margin-top: 2px;
}

/* ----- Filter Tabs ----- */
.cyclesave-admin-wrap .csave-filter-tabs {
	display: flex;
	gap: 0;
	border: 1px solid var(--csave-border);
	border-radius: var(--csave-radius-sm);
	overflow: hidden;
	margin-bottom: 16px;
}
.cyclesave-admin-wrap .csave-filter-tab {
	padding: 8px 18px;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	color: var(--csave-text-secondary);
	background: #fff;
	border-right: 1px solid var(--csave-border);
	transition: all 0.15s;
}
.cyclesave-admin-wrap .csave-filter-tab:last-child {
	border-right: none;
}
.cyclesave-admin-wrap .csave-filter-tab:hover {
	background: var(--csave-primary-50);
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-filter-tab-active {
	background: var(--csave-primary);
	color: #fff;
}
.cyclesave-admin-wrap .csave-filter-tab-active:hover {
	background: var(--csave-primary-dark);
	color: #fff;
}

/* ----- Group Selector ----- */
.cyclesave-admin-wrap .csave-group-selector {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 24px;
}
.cyclesave-admin-wrap .csave-group-selector .csave-admin-select {
	max-width: 400px;
}

/* ----- Responsive ----- */
@media (max-width: 1024px) {
	.cyclesave-admin-wrap .csave-admin-stats-row {
		grid-template-columns: repeat(2, 1fr);
	}
	.cyclesave-admin-wrap .csave-admin-grid-2 {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.cyclesave-admin-wrap .csave-admin-stats-row {
		grid-template-columns: 1fr;
	}
	.cyclesave-admin-wrap .csave-admin-header {
		flex-direction: column;
		align-items: flex-start;
	}
	.cyclesave-admin-wrap .csave-admin-filters {
		flex-direction: column;
	}
	.cyclesave-admin-wrap .csave-admin-form-row {
		grid-template-columns: 1fr;
	}
	.cyclesave-admin-wrap .csave-admin-table {
		font-size: 12px;
	}
	.cyclesave-admin-wrap .csave-admin-table thead th,
	.cyclesave-admin-wrap .csave-admin-table tbody td {
		padding: 8px 10px;
	}
	.cyclesave-admin-wrap .csave-admin-tab {
		padding: 8px 14px;
		font-size: 12px;
	}
	.cyclesave-admin-wrap .csave-stat-pills {
		flex-direction: column;
	}
	.cyclesave-admin-wrap .csave-timeline {
		padding-left: 48px;
	}
	.cyclesave-admin-wrap .csave-timeline::before {
		left: 20px;
	}
	.cyclesave-admin-wrap .csave-timeline-marker {
		left: -36px;
		width: 30px;
		height: 30px;
		font-size: 11px;
	}
	.cyclesave-admin-wrap .csave-timeline-card {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}
}

/* ============================================================
   Admin Layout — Sidebar
   ============================================================ */
.cyclesave-admin-wrap .csave-admin-layout {
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.cyclesave-admin-wrap .csave-admin-main {
	flex: 1;
	min-width: 0;
}

/* ----- Sidebar ----- */
.cyclesave-admin-wrap .csave-admin-sidebar {
	width: 260px;
	flex-shrink: 0;
	position: sticky;
	top: 40px;
}
.cyclesave-admin-wrap .csave-sidebar-panel {
	padding: 15px;
	margin-bottom: 12px;
	margin-right: 10px;
}
.cyclesave-admin-wrap .csave-sidebar-panel-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
	color: var(--csave-primary);
}
.cyclesave-admin-wrap .csave-sidebar-panel-header h3 {
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--csave-text);
}
.cyclesave-admin-wrap .csave-sidebar-text {
	font-size: 12px;
	color: var(--csave-text-secondary);
	margin: 0 0 10px 0;
	line-height: 1.5;
}
.cyclesave-admin-wrap .csave-sidebar-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-primary);
	text-decoration: none;
	transition: color 0.15s;
}
.cyclesave-admin-wrap .csave-sidebar-link:hover {
	color: var(--csave-primary-dark);
	text-decoration: underline;
}
.cyclesave-admin-wrap .csave-sidebar-version {
	display: flex;
	justify-content: space-between;
	font-size: 11px;
	color: var(--csave-text-secondary);
	padding: 8px 4px;
	border-top: 1px solid var(--csave-border);
	margin-top: 4px;
	margin-right: 10px;
}
.cyclesave-admin-wrap .button {
	width: 100%;
	text-align: center;
	gap: 6px;
	padding: 8px 16px;
	border-radius: var(--csave-radius-sm);
	font-size: 13px;
	font-weight: 600;
	line-height: 1.4;
	cursor: pointer;
	border: 1px solid transparent;
	text-decoration: none;
	transition: all 0.15s ease;
	white-space: nowrap;
}

/* Sidebar responsive — collapse below 1024px */
@media (max-width: 1024px) {
	.cyclesave-admin-wrap .csave-admin-layout {
		flex-direction: column;
	}
	.cyclesave-admin-wrap .csave-admin-sidebar {
		width: 100%;
		position: static;
		display: flex;
		flex-wrap: wrap;
		gap: 12px;
	}
	.cyclesave-admin-wrap .csave-sidebar-panel {
		flex: 1;
		min-width: 200px;
		margin-bottom: 0;
	}
	.cyclesave-admin-wrap .csave-sidebar-version {
		width: 100%;
	}
}

/* ============================================================
   Bulk Actions Bar
   ============================================================ */
.cyclesave-admin-wrap .csave-bulk-actions-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--csave-bg);
	border-bottom: 1px solid var(--csave-border);
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-bulk-actions-bar .csave-admin-select {
	min-width: 140px;
}
.cyclesave-admin-wrap .csave-per-page-wrap {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-left: auto;
	font-size: 13px;
	color: var(--csave-text-secondary);
}
.cyclesave-admin-wrap .csave-per-page-wrap .csave-admin-select {
	min-width: auto;
	width: 70px;
}
.cyclesave-admin-wrap .csave-admin-table th.csave-checkbox-col,
.cyclesave-admin-wrap .csave-admin-table td.csave-checkbox-col {
	width: 36px;
	text-align: center;
	padding: 8px 6px;
}
.cyclesave-admin-wrap .csave-admin-table .csave-bulk-check {
	width: 16px;
	height: 16px;
	cursor: pointer;
}

/* ── Member history toggle arrow ── */
.csave-history-arrow {
	display: inline-block;
	transition: transform 0.2s ease;
}
.csave-arrow-open {
	transform: rotate(180deg);
}
.csave-history-toggle:hover {
	opacity: 0.8;
}

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

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

/* Field hint text below inputs */
.cyclesave-admin-wrap .csave-field-hint {
	margin-top: 4px;
	color: var(--csave-text-secondary);
	font-size: 12px;
}

/* Inline label (flex row for checkbox + label text) */
.cyclesave-admin-wrap .csave-admin-label--inline {
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Flush panel body (removes default padding — used on table panels) */
.cyclesave-admin-wrap .csave-admin-panel-body.csave-panel-body--flush {
	padding: 0;
}

/* Notification section divider label */
.cyclesave-admin-wrap .csave-notification-section-header {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--csave-text-secondary, #6b7280);
	margin: 28px 0 12px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--csave-border, #e5e7eb);
}
.cyclesave-admin-wrap .csave-notification-section-header:first-of-type {
	margin-top: 0;
}

/* Collapsible sub-section panels */
.cyclesave-admin-wrap .csave-collapsible .csave-collapsible-toggle {
	cursor: pointer;
	user-select: none;
}
.cyclesave-admin-wrap .csave-collapsible .csave-chevron {
	margin-left: auto;
	flex-shrink: 0;
	transition: transform 0.2s ease;
	color: var(--csave-text-secondary, #6b7280);
}
.cyclesave-admin-wrap .csave-collapsible.csave-collapsed .csave-chevron {
	transform: rotate(-90deg);
}
.cyclesave-admin-wrap .csave-collapsible.csave-collapsed .csave-collapsible-body {
	display: none;
}

/* Bottom margin utility for notification section spacing */
.cyclesave-admin-wrap .csave-mb-32 {
	margin-bottom: 32px;
}

/* Pagination footer at bottom of list tables */
.cyclesave-admin-wrap .csave-pagination-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid var(--csave-border);
	padding: 12px 16px;
}
.cyclesave-admin-wrap .csave-pagination-footer .csave-pagination-info {
	font-size: 13px;
	color: #6b7280;
}
.cyclesave-admin-wrap .csave-pagination-footer .csave-pagination-buttons {
	display: flex;
	gap: 4px;
}
.cyclesave-admin-wrap .csave-pagination-footer .csave-page-current {
	pointer-events: none;
	background: #f3f4f6;
}

/* Small table-row avatar (36px green circle) */
.cyclesave-admin-wrap .csave-avatar-sm {
	width: 36px;
	height: 36px;
	min-width: 36px;
	border-radius: 50%;
	background: #16a34a;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 13px;
	flex-shrink: 0;
}

/* Inline code/reference pill */
.cyclesave-admin-wrap .csave-code-ref {
	font-size: 11px;
	background: #f3f4f6;
	padding: 2px 6px;
	border-radius: 4px;
	font-family: monospace;
}

/* Group-detail info grid label/value pair */
.cyclesave-admin-wrap .csave-detail-label {
	font-size: 12px;
	margin-bottom: 2px;
	color: var(--csave-text-secondary);
}
.cyclesave-admin-wrap .csave-detail-value {
	font-weight: 600;
	font-size: 15px;
}

/* Filter bar (flex space-between, used on contributions/payouts/payments) */
.cyclesave-admin-wrap .csave-filter-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}

/* Mode badges (TEST / LIVE pills in settings) */
.cyclesave-admin-wrap .csave-mode-badge--test {
	background: #F59E0B;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 2px 10px;
	border-radius: 9999px;
	letter-spacing: 0.5px;
}
.cyclesave-admin-wrap .csave-mode-badge--live {
	background: #10B981;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 2px 10px;
	border-radius: 9999px;
	letter-spacing: 0.5px;
}

/* Status info boxes (license, test-mode warning) */
.cyclesave-admin-wrap .csave-status-box {
	border-radius: var(--csave-radius-sm);
	padding: 12px 16px;
	margin-bottom: 16px;
}
.cyclesave-admin-wrap .csave-status-box--success {
	background: var(--csave-primary-light, #f0fdf4);
	border: 1px solid var(--csave-primary);
}
.cyclesave-admin-wrap .csave-status-box--error {
	background: #fef2f2;
	border: 1px solid #fca5a5;
}
.cyclesave-admin-wrap .csave-status-box--warning {
	background: #FFF8E1;
	border-left: 4px solid #F59E0B;
	border-radius: 0 var(--csave-radius-sm) var(--csave-radius-sm) 0;
}
.cyclesave-admin-wrap .csave-status-box-header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 4px;
}

/* Integrations tab — addon row */
.cyclesave-admin-wrap .csave-addon-row {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 20px;
	border-bottom: 1px solid var(--csave-border);
}
.cyclesave-admin-wrap .csave-addon-row:last-child {
	border-bottom: none;
}
.cyclesave-admin-wrap .csave-addon-row__icon {
	width: 40px;
	height: 40px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cyclesave-admin-wrap .csave-addon-row__body {
	flex: 1;
	min-width: 0;
}
.cyclesave-admin-wrap .csave-addon-row__name {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 2px;
}
.cyclesave-admin-wrap .csave-addon-row__name strong {
	font-size: 14px;
}
.cyclesave-admin-wrap .csave-addon-row__desc {
	margin: 0;
	color: var(--csave-text-secondary);
	font-size: 12px;
}
.cyclesave-admin-wrap .csave-addon-row__actions {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Email editor (rich-text toolbar + editable body) */
.cyclesave-admin-wrap .csave-editor-toolbar {
	display: flex;
	gap: 4px;
	padding: 8px;
	background: var(--csave-bg);
	border: 1px solid var(--csave-border);
	border-bottom: none;
	border-radius: var(--csave-radius-sm) var(--csave-radius-sm) 0 0;
}
.cyclesave-admin-wrap .csave-editor-toolbar__btn {
	padding: 4px 8px;
	border: 1px solid var(--csave-border);
	border-radius: 3px;
	background: #fff;
	cursor: pointer;
	font-size: 13px;
	line-height: 1.4;
}
.cyclesave-admin-wrap .csave-editor-toolbar__btn:hover {
	background: #f3f4f6;
}
.cyclesave-admin-wrap .csave-editor-toolbar__divider {
	width: 1px;
	background: var(--csave-border);
	margin: 0 4px;
	align-self: stretch;
}
.cyclesave-admin-wrap .csave-editor-body {
	min-height: 200px;
	max-height: 400px;
	overflow-y: auto;
	padding: 14px;
	border: 1px solid var(--csave-border);
	border-radius: 0 0 var(--csave-radius-sm) var(--csave-radius-sm);
	font-size: 13px;
	font-family: inherit;
	color: var(--csave-text);
	background: #fff;
	outline: none;
	line-height: 1.6;
	white-space: pre-wrap;
}

/* Group detail info grid */
.cyclesave-admin-wrap .csave-info-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px 24px;
}

/* Members list — member card sub-components */
.cyclesave-admin-wrap .csave-member-header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 14px;
}
.cyclesave-admin-wrap .csave-member-header__info {
	flex: 1;
	min-width: 0;
}
.cyclesave-admin-wrap .csave-member-name {
	font-weight: 600;
	font-size: 15px;
	color: #111827;
	margin-bottom: 2px;
}
.cyclesave-admin-wrap .csave-member-meta {
	font-size: 12px;
	color: #6b7280;
	line-height: 1.5;
}
.cyclesave-admin-wrap .csave-member-stats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}
.cyclesave-admin-wrap .csave-contributed-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 10px;
	padding: 8px;
	background: #f9fafb;
	border-radius: 6px;
}
.cyclesave-admin-wrap .csave-contributed-label {
	font-size: 12px;
	font-weight: 600;
	color: #374151;
}
.cyclesave-admin-wrap .csave-contributed-amount {
	font-size: 13px;
	font-weight: 700;
	color: #15803d;
}
.cyclesave-admin-wrap .csave-history-section {
	margin-top: 14px;
	border-top: 1px solid #e5e7eb;
	padding-top: 10px;
}
.cyclesave-admin-wrap .csave-history-toggle-btn {
	background: none;
	border: none;
	color: #15803d;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	padding: 4px 0;
	display: flex;
	align-items: center;
	gap: 4px;
}
.cyclesave-admin-wrap .csave-mini-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 12px;
}
.cyclesave-admin-wrap .csave-mini-table th {
	text-align: left;
	padding: 6px 8px;
	color: #6b7280;
	font-weight: 600;
	border-bottom: 1px solid #e5e7eb;
}
.cyclesave-admin-wrap .csave-mini-table td {
	padding: 6px 8px;
	color: #374151;
	border-bottom: 1px solid #f3f4f6;
}
.cyclesave-admin-wrap .csave-mini-table td.csave-td-right {
	text-align: right;
	font-weight: 500;
}
.cyclesave-admin-wrap .csave-mini-table td.csave-td-date {
	color: #6b7280;
}

/* Member tab navigation (inline button tabs) */
.cyclesave-admin-wrap .csave-member-tabs {
	display: flex;
	gap: 0;
	margin-top: 16px;
	border-bottom: 2px solid #e5e7eb;
}
.cyclesave-admin-wrap .csave-member-tab-btn {
	padding: 8px 20px;
	font-size: 13px;
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	cursor: pointer;
	transition: all 0.15s;
	color: #6b7280;
	font-weight: 400;
}
.cyclesave-admin-wrap .csave-member-tab-btn.csave-active {
	color: #15803d;
	font-weight: 600;
	border-bottom-color: #15803d;
}

/* Member status summary pills row */
.cyclesave-admin-wrap .csave-status-pills-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}
.cyclesave-admin-wrap .csave-status-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
}
.cyclesave-admin-wrap .csave-status-pill--active  { background: #dcfce7; color: #15803d; }
.cyclesave-admin-wrap .csave-status-pill--pending { background: #fef9c3; color: #a16207; }
.cyclesave-admin-wrap .csave-status-pill--removed { background: #fee2e2; color: #dc2626; }

/* Sidebar icon helpers */
.cyclesave-admin-wrap .csave-sidebar-icon-external {
	font-size: 14px;
	width: 14px;
	height: 14px;
}
.cyclesave-admin-wrap .csave-sidebar-panel--pro {
	border-left: 3px solid var(--csave-primary);
}
.cyclesave-admin-wrap .csave-sidebar-icon-primary {
	color: var(--csave-primary);
}

/* Group detail — back link, payout schedule section */
.cyclesave-admin-wrap .csave-back-link {
	text-decoration: none;
	font-size: 13px;
}
.cyclesave-admin-wrap .csave-payout-schedule-section {
	margin-top: 20px;
	border-top: 1px solid var(--csave-border);
	padding-top: 16px;
}
.cyclesave-admin-wrap .csave-schedule-heading {
	font-size: 13px;
	font-weight: 700;
	margin: 0 0 10px 0;
}
.cyclesave-admin-wrap .csave-schedule-list {
	margin: 0;
	padding-left: 20px;
	font-size: 13px;
}
.cyclesave-admin-wrap .csave-schedule-item {
	padding: 4px 0;
}
.cyclesave-admin-wrap .csave-text-sm {
	font-size: 12px;
}

/* List page shared helpers */
.cyclesave-admin-wrap .csave-table-user-cell {
	display: flex;
	align-items: center;
	gap: 10px;
}
/* WordPress-style hover row actions under member name */
.cyclesave-admin-wrap .csave-row-actions {
	visibility: hidden;
	padding-top: 3px;
	font-size: 12px;
	line-height: 1;
}
.cyclesave-admin-wrap tr:hover .csave-row-actions,
.cyclesave-admin-wrap tr:focus-within .csave-row-actions {
	visibility: visible;
}
.cyclesave-admin-wrap .csave-row-action-link {
	background: none;
	border: none;
	padding: 0;
	margin: 0;
	font: inherit;
	font-size: 12px;
	color: #2271b1;
	cursor: pointer;
	text-decoration: none;
}
.cyclesave-admin-wrap .csave-row-action-link:hover {
	color: #135e96;
	text-decoration: underline;
}
.cyclesave-admin-wrap .csave-row-action-link--danger {
	color: #b32d2e;
}
.cyclesave-admin-wrap .csave-row-action-link--danger:hover {
	color: #87171a;
}
.cyclesave-admin-wrap .csave-row-action-sep {
	color: #ccc;
	padding: 0 4px;
}
.cyclesave-admin-wrap .csave-action-buttons {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-form-inline {
	display: inline;
}
.cyclesave-admin-wrap .csave-admin-btn-danger-outline {
	color: #dc2626;
	border-color: #fecaca;
}
.cyclesave-admin-wrap .csave-td-nowrap {
	white-space: nowrap;
}
.cyclesave-admin-wrap .csave-text-danger {
	color: #dc2626;
}
.cyclesave-admin-wrap .csave-modal-info-row {
	background: var(--csave-primary-50, #f0fdf4);
	border-radius: var(--csave-radius-sm, 6px);
	padding: 12px 16px;
	margin-bottom: 20px;
	font-size: 13px;
}
.cyclesave-admin-wrap .csave-filter-form {
	display: flex;
	gap: 8px;
	align-items: center;
	margin: 0;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-filter-tab-group {
	display: flex;
	gap: 4px;
	flex-wrap: wrap;
}
.cyclesave-admin-wrap .csave-bulk-row {
	display: flex;
	align-items: center;
	gap: 8px;
}
.cyclesave-admin-wrap .csave-filter-select {
	min-width: 160px;
}
.cyclesave-admin-wrap .csave-filter-input {
	min-width: 180px;
}

/* Settings tab helpers */
.cyclesave-admin-wrap .csave-field-hint--sm { font-size: 13px; }
.cyclesave-admin-wrap .csave-field-hint--md { font-size: 14px; line-height: 1.6; }
.cyclesave-admin-wrap .csave-d-block { display: block; }
.cyclesave-admin-wrap .csave-mt-12 { margin-top: 12px; }
.cyclesave-admin-wrap .csave-mt-16 { margin-top: 16px; }
.cyclesave-admin-wrap .csave-mt-20 { margin-top: 20px; }
.cyclesave-admin-wrap .csave-mt-24 { margin-top: 24px; }
.cyclesave-admin-wrap .csave-font-semibold { font-weight: 600; }
.cyclesave-admin-wrap .csave-text-primary { color: var(--csave-primary); }
.cyclesave-admin-wrap .csave-text-red { color: var(--csave-red, #dc2626); }
.cyclesave-admin-wrap .csave-text-amber { color: #92400E; }
.cyclesave-admin-wrap .csave-icon-primary { color: var(--csave-primary); font-size: 18px; }
.cyclesave-admin-wrap .csave-icon-red { color: var(--csave-red, #dc2626); font-size: 18px; }
.cyclesave-admin-wrap .csave-button-row { display: flex; gap: 10px; }
.cyclesave-admin-wrap .csave-connected-indicator {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	font-weight: 600;
	color: #059669;
}
.cyclesave-admin-wrap .csave-settings-notice { margin: 0 0 16px; padding: 8px 14px; }
.cyclesave-admin-wrap .csave-code-block {
	display: block;
	padding: 6px 10px;
	background: var(--csave-bg-alt, #f6f7f7);
	border-radius: 4px;
	font-size: 13px;
	word-break: break-all;
}
.cyclesave-admin-wrap .csave-manual-keys-details { margin-top: 24px; }
.cyclesave-admin-wrap .csave-manual-keys-summary {
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-text-secondary);
	user-select: none;
	list-style: none;
	display: flex;
	align-items: center;
	gap: 6px;
}
.cyclesave-admin-wrap .csave-manual-keys-body {
	margin-top: 14px;
	padding: 16px;
	background: var(--csave-bg-alt, #f6f7f7);
	border-radius: 6px;
}
.cyclesave-admin-wrap .csave-keys-section-heading {
	margin: 0 0 10px;
	font-size: 12px;
	color: var(--csave-text-secondary);
	text-transform: uppercase;
	letter-spacing: .5px;
	display: flex;
	align-items: center;
	gap: 6px;
}
.cyclesave-admin-wrap .csave-mode-dot {
	display: inline-block;
	width: 7px;
	height: 7px;
	border-radius: 50%;
}
.cyclesave-admin-wrap .csave-mode-dot--live { background: #10B981; }
.cyclesave-admin-wrap .csave-mode-dot--test { background: #F59E0B; }
.cyclesave-admin-wrap .csave-col-toggle { width: 60px; }
.cyclesave-admin-wrap .csave-td-center { text-align: center; }
.cyclesave-admin-wrap .csave-unstyled-link { text-decoration: none; color: inherit; }
.cyclesave-admin-wrap .csave-modal-content--wide { max-width: 680px; }
.cyclesave-admin-wrap .csave-save-status { padding: 8px 12px; border-radius: var(--csave-radius-sm); font-size: 13px; margin-top: 8px; }
.cyclesave-admin-wrap .csave-addon-toggle-label { display: flex; align-items: center; gap: 6px; cursor: pointer; font-size: 13px; color: var(--csave-text-secondary); }
.cyclesave-admin-wrap .csave-addon-name-text { font-size: 14px; }
.cyclesave-admin-wrap .csave-rest-block { background: var(--csave-bg); border: 1px solid var(--csave-border); border-radius: var(--csave-radius-sm); padding: 10px 14px; }
.cyclesave-admin-wrap .csave-code-sm { font-size: 13px; }
.cyclesave-admin-wrap .csave-log-scroll { max-height: 400px; overflow-y: auto; }
.cyclesave-admin-wrap .csave-log-code { font-size: 12px; word-break: break-all; }
.cyclesave-admin-wrap .csave-input-license { max-width: 400px; font-family: monospace; letter-spacing: 0.5px; }
.cyclesave-admin-wrap .csave-select-md { max-width: 300px; }
.cyclesave-admin-wrap .csave-input-sm { max-width: 200px; }
.cyclesave-admin-wrap .csave-checkbox-lg { width: 18px; height: 18px; }

/* Members page helpers */
.cyclesave-admin-wrap .csave-filter-group-wide { min-width: 220px; flex: 1; }
.cyclesave-admin-wrap .csave-filter-group { min-width: 200px; flex: 1; }
.cyclesave-admin-wrap .csave-filter-submit { align-self: flex-end; }
.cyclesave-admin-wrap .csave-mb-0 { margin-bottom: 0; }
.cyclesave-admin-wrap .csave-mb-12 { margin-bottom: 12px; }
.cyclesave-admin-wrap .csave-progress-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 5px;
}
.cyclesave-admin-wrap .csave-progress-label { font-size: 12px; color: #6b7280; font-weight: 500; }
.cyclesave-admin-wrap .csave-progress-value { text-align: right; flex-shrink: 0; }
.cyclesave-admin-wrap .csave-progress-pct { font-size: 12px; font-weight: 600; color: #374151; }
.cyclesave-admin-wrap .csave-progress-track {
	width: 100%;
	height: 8px;
	background: #e5e7eb;
	border-radius: 999px;
	overflow: hidden;
}
.cyclesave-admin-wrap .csave-panel-icon { width: 16px; height: 16px; vertical-align: middle; margin-right: 4px; }
.cyclesave-admin-wrap .csave-admin-empty--lg { padding: 60px 20px; }
.cyclesave-admin-wrap .csave-empty-title { margin: 0 0 8px; font-size: 16px; color: #374151; }
.cyclesave-admin-wrap .csave-empty-desc { margin: 0; color: #6b7280; font-size: 14px; }
.cyclesave-admin-wrap .csave-mini-table-header { border-bottom: 1px solid #e5e7eb; }
.cyclesave-admin-wrap .csave-mini-table td.csave-td-date { color: #6b7280; }
.cyclesave-admin-wrap .csave-history-container { margin-top: 10px; }

/* ── Editor button format indicators ──────────────────────────────────────── */
.cyclesave-admin-wrap .csave-editor-btn--bold { font-weight: bold; }
.cyclesave-admin-wrap .csave-editor-btn--italic { font-style: italic; }
.cyclesave-admin-wrap .csave-editor-btn--underline { text-decoration: underline; }

/* ── Danger button variant ────────────────────────────────────────────────── */
.cyclesave-admin-wrap .csave-admin-btn-danger { color: #dc2626; border-color: #fecaca; }
.cyclesave-admin-wrap .csave-admin-btn-danger:hover { background: #fef2f2; border-color: #dc2626; }

/* ── Sub-tab Navigation ──────────────────────────────────────────────────── */
.cyclesave-admin-wrap .csave-admin-subtab-nav {
	display: flex;
	gap: 0;
	border-bottom: 1px solid var(--csave-border);
	margin-bottom: 20px;
}

.cyclesave-admin-wrap .csave-admin-subtab-link {
	display: inline-block;
	padding: 12px 20px;
	color: var(--csave-text-secondary);
	text-decoration: none;
	border-bottom: 3px solid transparent;
	font-weight: 500;
	font-size: 14px;
	transition: all 0.2s ease;
	margin-bottom: -1px;
}

.cyclesave-admin-wrap .csave-admin-subtab-link:hover {
	color: var(--csave-text);
	border-bottom-color: var(--csave-border);
}

.cyclesave-admin-wrap .csave-admin-subtab-link.csave-active {
	color: var(--csave-primary);
	border-bottom-color: var(--csave-primary);
}

/* Payout detail list in view modal */
.cyclesave-admin-wrap .csave-detail-list {
	margin: 0;
	padding: 0;
	list-style: none;
}
.cyclesave-admin-wrap .csave-detail-row {
	display: flex;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid var(--csave-border);
}
.cyclesave-admin-wrap .csave-detail-row:last-child {
	border-bottom: none;
}
.cyclesave-admin-wrap .csave-detail-row dt {
	flex: 0 0 160px;
	font-size: 13px;
	color: var(--csave-text-secondary);
	font-weight: 500;
}
.cyclesave-admin-wrap .csave-detail-row dd {
	margin: 0;
	font-size: 13px;
	font-weight: 600;
	color: var(--csave-text);
	word-break: break-all;
}

/* Action cell with multiple buttons */
.cyclesave-admin-wrap .csave-actions-cell {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

/* ----- Charts ----- */
.csave-admin-charts-section {
	display: flex;
	flex-direction: column;
	gap: var(--csave-gap, 1.5rem);
	margin-bottom: var(--csave-gap, 1.5rem);
}

.csave-chart-wrap {
	min-height: 280px;
}

/* Stat card as clickable link (e.g. pending withdrawals) */
a.csave-admin-stat-card {
	text-decoration: none;
	color: inherit;
	transition: box-shadow 0.15s ease, transform 0.15s ease;
}

a.csave-admin-stat-card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
	transform: translateY(-1px);
}
