/**
 * Workflow GC Template Styles
 * Standardized page template components
 * 
 * @package Workflow_GC
 * @version 2.0.0
 * 
 * MOBILE-FIRST APPROACH
 * Base styles work on all screens
 * Tablet/desktop only ENHANCE (never override)
 */

/* ==========================================================================
   Global Icon Styles
   ========================================================================== */

.material-icons {
	color: var(--wfg-icon-color);  /* Clay Rose - STANDARD for all icons */
	vertical-align: middle;
}

/* ==========================================================================
   Page Wrapper & Container (Mobile-First)
   ========================================================================== */

/* Override WordPress theme's layout constraints */
.entry-content.is-layout-constrained .wfg-page-wrapper,
.wp-block-post-content.is-layout-constrained .wfg-page-wrapper {
	max-width: none !important;  /* Remove theme's max-width limit */
}

/* Reduce excessive top spacing from WordPress theme */
.wp-block-group.has-global-padding {
	padding-top: 20px !important;  /* Reduced from theme's 60px+ */
}

main.wp-block-group {
	margin-top: 20px !important;  /* Reduced from theme's 60px+ */
}

/* Mobile: Override WordPress's excessive padding */
@media (max-width: 767px) {
	/* Override WordPress's CSS variables for mobile - THIS IS THE KEY FIX */
	:root {
		--wp--style--root--padding-right: 5px !important;
		--wp--style--root--padding-left: 5px !important;
	}
	
	.wp-block-group.has-global-padding {
		padding-top: 10px !important;
		padding-bottom: 10px !important;
	}
	
	main.wp-block-group {
		margin-top: 10px !important;
	}
	
	.wp-block-post-title {
		margin-top: 10px !important;
		margin-bottom: 10px !important;
	}
}

/* Wrapper - no constraints, theme-safe */
.wfg-page-wrapper {
	width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	overflow-x: hidden;  /* Prevent horizontal scroll */
	word-wrap: break-word;  /* Wrap long words */
}

/* Container - mobile default (minimal padding to maximize space) */
.wfg-page-container {
	width: 100%;
	padding: 0;  /* Mobile: edge-to-edge */
	margin: 0 auto;  /* Auto margin for centering */
	box-sizing: border-box;
}

/* Mobile only: Add padding to show page boundaries */
@media (max-width: 767px) {
	/* Force WordPress entry-content to have less padding on mobile */
	.entry-content.has-global-padding {
		padding-left: 10px !important;
		padding-right: 10px !important;
	}
	
	/* Add 10px padding to wfg-page-container so white box has visible margins */
	.wfg-page-container {
		padding-left: 10px;
		padding-right: 10px;
	}
}

/* Content Container - white box (NO border) */
.wfg-content-container {
	background: #ffffff;
	border-radius: var(--wfg-radius-lg);
	padding: var(--wfg-space-md);  /* Smaller padding on mobile */
	margin-bottom: var(--wfg-space-md);
	box-sizing: border-box;
	overflow: hidden;  /* Prevent content overflow */
	word-wrap: break-word;  /* Wrap long text */
}

/* Button Container - plain white box (NO border) */
.wfg-button-container {
	background: #ffffff;
	border-radius: var(--wfg-radius-lg);
	padding: var(--wfg-space-md);  /* Smaller padding on mobile */
	box-sizing: border-box;
}

/* Tablet: minimal padding inside containers for maximum form space */
@media (min-width: 768px) {
	.wfg-content-container {
		padding: var(--wfg-space-xs);  /* Ultra-minimal - maximize form field width */
	}
	
	.wfg-button-container {
		padding: var(--wfg-space-md);
		margin-left: 0;   /* Full width - no margins */
		margin-right: 0;  /* Full width - no margins */
	}
}

/* Tablet: increased to accommodate 30px margins */
@media (min-width: 768px) {
	.wfg-page-container {
		max-width: 860px;
		padding: var(--wfg-space-xs);
	}
}

/* Desktop: increased to accommodate 30px margins */
@media (min-width: 1024px) {
	.wfg-page-container {
		max-width: 860px !important;
		padding: var(--wfg-space-xs);
	}
}

/* ==========================================================================
   Banner Component (Mobile-First)
   ========================================================================== */

.wfg-banner {
	background: var(--wfg-bg-banner);
	padding: var(--wfg-space-md);
	text-align: center;
	border-radius: var(--wfg-radius-md);
	margin-bottom: var(--wfg-space-lg);
	box-sizing: border-box;
}

.wfg-banner__title {
	font-size: var(--wfg-font-lg) !important;
	font-weight: var(--wfg-font-semibold) !important;
	color: var(--wfg-banner-title-color) !important;
	margin: 0 !important;
	line-height: var(--wfg-line-tight) !important;
}

.wfg-banner__subtitle {
	font-size: var(--wfg-font-sm);  /* 14px - readable */
	color: var(--wfg-banner-subtitle-color);
	margin: var(--wfg-space-sm) 0 0 0;
	line-height: var(--wfg-line-normal);
}

/* Tablet: larger text and margins to match form blocks */
@media (min-width: 768px) {
	.wfg-banner {
		padding: var(--wfg-space-lg) var(--wfg-space-xl);
		margin-top: 30px;
		margin-left: 30px;
		margin-right: 30px;
		margin-bottom: 30px;
	}

	.wfg-banner__title {
		font-size: var(--wfg-font-xl) !important; /* Force override h1 defaults */
	}

	.wfg-banner__subtitle {
		font-size: var(--wfg-font-sm); /* 14px - readable */
	}
}

/* ==========================================================================
   Card Component (Mobile-First)
   ========================================================================== */

.wfg-card {
	background: var(--wfg-bg-card);
	border: 2px solid #4a6953;  /* Dark Sage border - STANDARD */
	border-radius: var(--wfg-radius-lg);
	padding: 20px;  /* Mobile: 20px - matches white block standard */
	margin: 0 10px 20px 10px;  /* Mobile: 10px left/right margins - STANDARD */
	box-shadow: var(--wfg-shadow-sm);
	box-sizing: border-box;
	position: relative;
	overflow: hidden;  /* Prevent content overflow */
	word-wrap: break-word;  /* Wrap long text */
}

/* Desktop: 30px padding AND margins - EXACT SAME AS WHITE BLOCKS */
@media (min-width: 768px) {
	.wfg-card {
		padding: 30px;  /* Desktop: 30px - matches white block standard */
		margin: 0 30px 20px 30px;  /* Desktop: 30px left/right margins - STANDARD */
	}
}

/* Selectable card (with radio button) */
.wfg-card--selectable {
	cursor: pointer;
	transition: all 0.2s ease;
}

.wfg-card--selectable:hover {
	box-shadow: var(--wfg-shadow-md);
	transform: translateY(-2px);
}

/* Card radio button (hidden) */
.wfg-card__radio {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

/* Card label (clickable area) */
.wfg-card__label {
	display: block;
	cursor: pointer;
	position: relative;
}

/* Radio indicator (custom radio button) - aligned with title */
.wfg-card__radio-indicator {
	position: absolute;
	top: 0;  /* Align with card title, not card top */
	right: var(--wfg-space-md);
	width: 24px;
	height: 24px;
	border: 2px solid var(--wfg-border-color);
	border-radius: 50%;
	background: #fff;
	transition: all 0.2s ease;
}

.wfg-card__radio-indicator::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(0);
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--wfg-primary);
	transition: transform 0.2s ease;
}

/* Checked state - Highlight the whole card */
.wfg-card__radio:checked + .wfg-card__label .wfg-card__radio-indicator {
	border-color: var(--wfg-primary);
}

.wfg-card__radio:checked + .wfg-card__label .wfg-card__radio-indicator::after {
	transform: translate(-50%, -50%) scale(1);
}

/* Change entire card background when selected */
.wfg-card--selectable:has(.wfg-card__radio:checked) {
	background: #f0e2d5;  /* Calm Cream - Selected state */
	border-color: var(--wfg-primary);
}

/* Card content */
.wfg-card__content {
	padding-right: 40px; /* Space for radio button */
}

.wfg-card__title {
	font-size: 18px;
	font-weight: 600;
	color: var(--wfg-primary);
	margin: 0 0 var(--wfg-space-sm) 0;
}

.wfg-card__description {
	font-size: var(--wfg-font-base);  /* 16px - Industry standard for body text */
	color: var(--wfg-text-secondary);
	margin: 0 0 var(--wfg-space-md) 0;
	line-height: 1.5;
}

/* Tablet: larger titles */
@media (min-width: 768px) {
	.wfg-card__title {
		font-size: 20px;
	}
}

/* Card features list */
.wfg-card__features {
	list-style: none;
	padding: 0;
	margin: 0;
}

.wfg-card__features li {
	position: relative;
	padding-left: var(--wfg-space-lg);
	margin-bottom: var(--wfg-space-sm);
	font-size: var(--wfg-font-base);  /* 16px - Industry standard */
	color: var(--wfg-text-primary);
}

.wfg-card__features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 0;
	color: var(--wfg-accent1);
	font-weight: bold;
	font-size: 14px;
}

/* ==========================================================================
   Info Banner Component (Mobile-First)
   ========================================================================== */

.wfg-info-banner {
	display: flex;
	gap: var(--wfg-space-md);
	background: #b9b8a4;  /* Neutral Sand - STANDARD for all info boxes */
	padding: 16px;  /* Mobile: 16px padding */
	margin: 0 10px 20px 10px;  /* Mobile: 10px left/right margins - STANDARD */
	border-radius: var(--wfg-radius-md);
	box-sizing: border-box;
}

/* Desktop: more padding AND margins - MATCHES WHITE BLOCKS */
@media (min-width: 768px) {
	.wfg-info-banner {
		padding: 20px;  /* Desktop: 20px padding for info banners */
		margin: 0 30px 20px 30px;  /* Desktop: 30px left/right margins - STANDARD */
	}
}

.wfg-info-banner__icon {
	flex-shrink: 0;
	color: var(--wfg-icon-color);
	display: flex;
	align-items: center;
	font-size: 24px;
}

.wfg-info-banner__icon .material-icons {
	font-size: 24px;
}

.wfg-info-banner__content {
	flex: 1;
}

.wfg-info-banner__title {
	font-size: var(--wfg-font-md);
	font-weight: 600;
	color: #000000;  /* Black heading - STANDARD */
	margin: 0 0 var(--wfg-space-sm) 0;
}

.wfg-info-banner__text {
	font-size: var(--wfg-font-base);  /* 16px - Industry standard */
	color: #ffffff;  /* White body text */
	margin: 0;
	line-height: 1.6;
}

.wfg-info-banner__link {
	color: #ffffff;  /* White link */
	text-decoration: underline;
	font-weight: 500;
}

.wfg-info-banner__link:hover {
	opacity: 0.8;
}

/* ==========================================================================
   Form-Specific Components
   ========================================================================== */

/* Date of Birth dropdowns row - tuned widths for full visibility */
.wfg-dob-row {
	display: grid;
	grid-template-columns: 1.1fr 0.7fr 1.2fr; /* Month a bit wider than Day; Year widest */
	gap: var(--wfg-space-xs);
}

.wfg-dob-select {
	font-size: 14px;  /* Compact to fit values */
	min-height: var(--wfg-touch-target);
	padding-left: 8px;
	padding-right: 20px;  /* Space for dropdown arrow */
}

/* Ensure minimums for each select to avoid truncation */
.wfg-dob-row .wfg-dob-select:nth-child(1) { min-width: 84px; }  /* Month */
.wfg-dob-row .wfg-dob-select:nth-child(2) { min-width: 64px; }  /* Day */
.wfg-dob-row .wfg-dob-select:nth-child(3) { min-width: 100px; } /* Year */

@media (max-width: 767px) {
	.wfg-dob-row {
		grid-template-columns: 1fr;
		gap: var(--wfg-space-xs);
	}
	
	.wfg-dob-select {
		font-size: var(--wfg-font-base);
	}
}

/* 2-column form row */
.wfg-form-row {
	margin-bottom: var(--wfg-space-md);
}

.wfg-form-row--two-col {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--wfg-space-md);
}

@media (max-width: 767px) {
	.wfg-form-row--two-col {
		grid-template-columns: 1fr;
		gap: var(--wfg-space-sm);
	}
}

.wfg-form-row__col {
	min-width: 0;
}

/* Form help text */
.wfg-form-help {
	display: block;
	font-size: var(--wfg-font-sm);
	color: var(--wfg-text-secondary);
	margin-top: var(--wfg-space-xs);
	font-style: italic;
}

/* Emergency contact grouping */
.wfg-emergency-contact-group {
	padding: var(--wfg-space-md) 0;
	border-bottom: 1px solid var(--wfg-border-light);
	margin-bottom: var(--wfg-space-md);
}

.wfg-emergency-contact-group:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

/* ==========================================================================
   Actions Component (Mobile-First)
   ========================================================================== */

.wfg-actions {
	padding: var(--wfg-space-md);
	text-align: center;
	box-sizing: border-box;
}

/* Tablet: more padding */
@media (min-width: 768px) {
	.wfg-actions {
		padding: var(--wfg-space-lg);
	}
}

/* ==========================================================================
   Button Styles (Mobile-First)
   ========================================================================== */

.wfg-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--wfg-space-sm);
	padding: var(--wfg-space-sm) var(--wfg-space-lg);
	border: none;
	border-radius: var(--wfg-radius-md);
	font-size: var(--wfg-font-base);
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s ease;
	text-decoration: none;
	box-sizing: border-box;
	min-height: 44px;  /* Mobile touch target minimum */
}

.wfg-btn .material-icons {
	font-size: 20px;
}

.wfg-btn--primary {
	background: var(--wfg-primary);
	color: #fff;
}

.wfg-btn--primary:hover {
	background: var(--wfg-bg-hover);
	transform: translateY(-2px);
	box-shadow: var(--wfg-shadow-md);
}

.wfg-btn--secondary {
	background: var(--wfg-icon-color);  /* Clay Rose #c48c6e - STANDARD */
	color: #fff;
}

.wfg-btn--secondary:hover {
	background: #b37b5e;  /* Darker Clay Rose on hover */
	opacity: 1;
}

.wfg-btn--large {
	padding: var(--wfg-space-md) var(--wfg-space-xl);
	font-size: var(--wfg-font-md);
	min-width: 200px;
	justify-content: center;
}

/* Mobile: full width large buttons */
@media (max-width: 767px) {
	.wfg-btn--large {
		width: 100%;
		min-width: auto;
	}
}

.wfg-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* ==========================================================================
   Modal Component (Mobile-First)
   ========================================================================== */

.wfg-modal {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);  /* Perfect centering */
	z-index: 9999;
	width: 90%;
	max-width: 400px;
	box-sizing: border-box;
}

.wfg-modal__overlay {
	display: none;  /* No overlay, no blur */
}

.wfg-modal__container {
	position: relative;
	z-index: 1;
	width: 100%;
}

.wfg-modal__content {
	background: #fff;
	border: 2px solid #4a6953;  /* Dark Sage border */
	border-radius: var(--wfg-radius-lg);
	padding: var(--wfg-space-xl);
	box-shadow: var(--wfg-shadow-lg);
	box-sizing: border-box;
}

.wfg-modal__title {
	font-size: var(--wfg-font-xl);
	font-weight: 600;
	color: var(--wfg-text-primary);
	margin: 0 0 var(--wfg-space-md) 0;
	text-align: center;
}

.wfg-modal__text {
	font-size: var(--wfg-font-base);
	color: var(--wfg-text-secondary);
	margin: 0 0 var(--wfg-space-xl) 0;
	text-align: center;
	line-height: 1.6;
}

.wfg-modal__actions {
	display: flex;
	flex-direction: column;  /* ALWAYS vertical stack */
	gap: var(--wfg-space-md);
}



/* Hide WordPress auto-generated page titles on ALL V2 workflow pages */
.page-template-default .wp-block-post-title {
	display: none !important;
}

/* NUCLEAR: Client Portal specific - highest specificity */
body.page-id-215 h1.wp-block-post-title,
html body.page-id-215 h1.wp-block-post-title {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	width: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	left: -9999px !important;
	opacity: 0 !important;
}

/* Ensure WordPress wrappers don't interfere with V2 structure */
.page-id-215 .entry-content,
.page-id-215 .wp-block-post-content {
	padding: 0 !important;
	margin: 0 !important;
	max-width: 100% !important;
}

/* MOBILE ONLY - Adult Dashboard (page-id-215) - Match reschedule page margins */
@media (max-width: 767px) {
	body.page-id-215 main.wp-block-group.has-global-padding,
	body.page-id-215 .wp-block-group.alignfull.has-global-padding,
	body.page-id-215 .entry-content.has-global-padding,
	body.page-id-215 .wp-block-post-content.has-global-padding {
		padding-left: 15px !important;
		padding-right: 15px !important;
	}
	
	/* Fix buttons overflowing containers - you were happy with this */
	body.page-id-215 .wfg-button,
	body.page-id-215 .wfg-btn {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box !important;
	}
	
	/* Stack booking session items vertically - you were happy with this */
	body.page-id-215 .booking-session-item {
		flex-direction: column !important;
		align-items: stretch !important;
	}
	
	body.page-id-215 .booking-session-item .wfg-button {
		width: 100% !important;
		text-align: center !important;
		margin-top: 10px !important;
	}
	
	/* Fix Agreements & Progress Tracking table - convert to cards */
	body.page-id-215 .wfg-agreements-table,
	body.page-id-215 .wfg-dashboard-table {
		display: block !important;
		border: none !important;
	}
	
	body.page-id-215 .wfg-agreements-table thead,
	body.page-id-215 .wfg-dashboard-table thead {
		display: none !important;
	}
	
	body.page-id-215 .wfg-agreements-table tbody,
	body.page-id-215 .wfg-dashboard-table tbody {
		display: block !important;
	}
	
	body.page-id-215 .wfg-agreements-table tr,
	body.page-id-215 .wfg-dashboard-table tr {
		display: block !important;
		margin-bottom: 15px !important;
		padding: 15px !important;
		border: 2px solid #4a6953 !important;
		border-radius: 10px !important;
		background: #fff !important;
	}
	
	body.page-id-215 .wfg-agreements-table td,
	body.page-id-215 .wfg-dashboard-table td {
		display: block !important;
		width: 100% !important;
		padding: 8px 0 !important;
		border: none !important;
		text-align: left !important;
	}
	
	/* Add labels before each field */
	body.page-id-215 .wfg-agreements-table td:nth-child(1):before {
		content: "Name: ";
		font-weight: 600;
		color: #4a6953;
		display: inline;
	}
	
	body.page-id-215 .wfg-agreements-table td:nth-child(2):before {
		content: "Status: ";
		font-weight: 600;
		color: #4a6953;
		display: block;
		margin-bottom: 5px;
	}
	
	body.page-id-215 .wfg-agreements-table td:nth-child(3):before {
		content: "Actions: ";
		font-weight: 600;
		color: #4a6953;
		display: block;
		margin-top: 10px;
		margin-bottom: 5px;
	}
	
	/* Make Download PDF button full width */
	body.page-id-215 .wfg-agreements-table .wfg-button,
	body.page-id-215 .wfg-dashboard-table .wfg-button {
		width: 100% !important;
		display: block !important;
		text-align: center !important;
	}
}

/* GLOBAL MOBILE - Menu spacing on right side (all pages) */
@media (max-width: 768px) {
	.wp-block-navigation__responsive-container .wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content {
		right: 15px !important;
		inset: 50px 15px auto auto !important;
	}
}

/* ==========================================================================
   Appointment Cart Page (Page ID 577) - Proper WordPress Integration
   ========================================================================== */

/* Ensure WordPress wrappers don't interfere with V2 structure */
.page-id-577 .entry-content,
.page-id-577 .wp-block-post-content {
	padding: 0 !important;
	margin: 0 !important;
	max-width: 100% !important;
}

/* MOBILE ONLY - Appointment Cart (page-id-577) - Match Adult Dashboard approach */
@media (max-width: 767px) {
	body.page-id-577 main.wp-block-group.has-global-padding,
	body.page-id-577 .wp-block-group.alignfull.has-global-padding,
	body.page-id-577 .entry-content.has-global-padding,
	body.page-id-577 .wp-block-post-content.has-global-padding {
		padding-left: 15px !important;
		padding-right: 15px !important;
	}
	
	/* Reduce internal padding on cart items */
	body.page-id-577 .appointment-item {
		padding: 20px 15px !important;
	}
	
	/* Reduce internal padding on form blocks */
	body.page-id-577 .wfg-form-block--white {
		padding: 12px !important;
	}
	
	/* Cart summary no side padding */
	body.page-id-577 .cart-summary {
		padding: 20px 0 !important;
	}
}

/* Dashboard Section - Simple section dividers inside main white container */
.wfg-dashboard-section {
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px solid var(--wfg-color-neutral-sand);
}

.wfg-dashboard-section:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.wfg-dashboard-section h2 {
	margin-bottom: 15px;
}

/* Additional specificity to hide Client Portal title */
.page-id-215.page-template-default .wp-block-post-title,
main .page-id-215 .wp-block-post-title {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
}

/* ==========================================================================
   Client Info Grid (Two-column layout for T&C client info cards)
   Design Standard: White background, Dark Sage labels, Clay Rose age badge
   ========================================================================== */

.wfg-client-info-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.wfg-client-info-label {
	font-weight: 600;
	color: #4a6953;  /* Dark Sage - STANDARD for labels */
	margin-bottom: 4px;
	font-size: 16px;  /* Body text - STANDARD */
}

.wfg-client-info-value {
	color: #333;  /* Standard text color */
	font-size: 16px;  /* Body text - STANDARD */
}

.wfg-client-info-value--with-badge {
	display: flex;
	align-items: center;
	gap: 8px;
}

.wfg-age-badge {
	background: #c48c6e;  /* Clay Rose - STANDARD */
	color: white;
	padding: 2px 12px;
	border-radius: 4px;
	font-size: 14px;
	font-weight: 600;
	white-space: nowrap;
}

/* Mobile: Stack columns */
@media (max-width: 768px) {
	.wfg-client-info-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}

/* ==========================================================================
   WooCommerce Checkout - Mobile Appointment Display
   ========================================================================== */

/* Mobile-only: Fix WooCommerce checkout table spacing */
@media (max-width: 767px) {
	/* CRITICAL: Remove WordPress theme's global padding on checkout pages */
	.woocommerce-checkout main.wp-block-group.has-global-padding,
	.woocommerce-checkout .wp-block-group.alignfull.has-global-padding,
	.woocommerce-checkout .entry-content.has-global-padding,
	.woocommerce-checkout .wp-block-post-content.has-global-padding {
		padding-left: 10px !important;
		padding-right: 10px !important;
	}
	
	/* Make "Your Order" container wider by reducing its padding */
	.woocommerce-checkout-review-order {
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
	
	/* Add proper padding to checkout table cells */
	.woocommerce-checkout-review-order-table th,
	.woocommerce-checkout-review-order-table td {
		padding-left: 12px;
		padding-right: 12px;
	}
	
	/* Reduce font size for prices to fit better */
	.woocommerce-checkout-review-order-table .product-total {
		font-size: 14px;
	}
	
	/* Hide table headers - we'll add labels with ::before */
	.wfg-sessions-table thead {
		display: none;
	}
	
	/* Convert table to blocks */
	.wfg-sessions-table,
	.wfg-sessions-table tbody,
	.wfg-sessions-table tr,
	.wfg-sessions-table td {
		display: block;
		width: 100%;
	}
	
	/* Reset table row styling */
	.wfg-sessions-table tr {
		margin-bottom: 8px;
		padding: 8px 0;
		border-bottom: 1px solid #e0e0e0;
	}
	
	.wfg-sessions-table tr:last-child {
		border-bottom: none;
	}
	
	/* Each cell: label on top, value below */
	.wfg-sessions-table td {
		padding: 6px 0;
		border: none;
		text-align: left;
		font-size: 13px;
	}
	
	/* Add labels */
	.wfg-sessions-table td::before {
		content: attr(data-label);
		display: block;
		font-weight: 600;
		color: #4a6953;
		font-size: 11px;
		text-transform: uppercase;
		margin-bottom: 2px;
	}
	
	.wfg-sessions-table td:nth-child(1)::before {
		content: "Date";
	}
	
	.wfg-sessions-table td:nth-child(2)::before {
		content: "Time";
	}
	
	.wfg-sessions-table td:nth-child(3)::before {
		content: "Session Type";
	}
	
	/* Client header - smaller font */
	.wfg-checkout-appointment-card > div:first-child {
		font-size: 13px;
	}
	
	.wfg-checkout-appointment-card > div:first-child strong {
		font-size: 12px;
	}
}

/* Cache bust: 1762448628 */
