/**
 * Walkr Client Portal Styles
 *
 * @package Walkr_Client_Portal
 * @since   1.0.0
 */

/* ==========================================================================
   CSS Variables - Paws & Play Theme
   ========================================================================== */

:root {
	/* Brand Colors */
	--walkr-primary: #EC4899;       /* Hot Pink */
	--walkr-primary-hover: #DB2777; /* Darker Pink */
	--walkr-primary-border: #BE185D; /* Even Darker Pink for 3D border */
	--walkr-primary-light: #FDF2F8; /* Pink tint for backgrounds */
	
	--walkr-secondary: #60A5FA;     /* Sky Blue */
	--walkr-secondary-bg: #DBEAFE;  /* Light Blue */
	
	--walkr-bg: #FEFCE8;            /* Soft Sunshine */
	--walkr-bg-light: #FFFBEB;      /* Lighter Yellow */
	
	--walkr-text: #1E293B;          /* Soft Slate */
	--walkr-text-light: #475569;
	--walkr-text-muted: #94a3b8;

	--walkr-border: #CBD5E1;
	--walkr-border-dark: #94a3b8;

	/* Semantic Colors */
	--walkr-success: #10B981;
	--walkr-success-bg: #D1FAE5;
	--walkr-warning: #F59E0B;
	--walkr-warning-bg: #FEF3C7;
	--walkr-info: #3B82F6;
	--walkr-info-bg: #DBEAFE;

	/* Shape Language */
	--walkr-radius: 3rem;           /* rounded-3xl */
	--walkr-radius-sm: 1.5rem;      /* rounded-xl */
	
	/* Fluid Typography Scale */
	--walkr-text-xs: clamp(0.7rem, 0.65rem + 0.25vw, 0.75rem);
	--walkr-text-sm: clamp(0.8rem, 0.75rem + 0.25vw, 0.875rem);
	--walkr-text-base: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
	--walkr-text-lg: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
	--walkr-text-xl: clamp(1.1rem, 1rem + 0.5vw, 1.25rem);
	--walkr-text-2xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
	--walkr-text-3xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);
	--walkr-text-4xl: clamp(1.75rem, 1.5rem + 1.25vw, 2.5rem);
	
	/* Shadows (None, using borders for depth) */
	--walkr-shadow: none;
	--walkr-shadow-md: none;
}

/* ==========================================================================
   Base Portal Styles
   ========================================================================== */

.walkr-portal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	min-height: 100vh;
	margin: 0;
	padding: clamp(15px, 3vw, 40px);
	font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: var(--walkr-text-base);
	line-height: 1.6;
	color: var(--walkr-text);
	background-color: var(--walkr-bg);
	box-sizing: border-box;
	overflow-y: auto;
	overflow-x: hidden;
	z-index: 9999;
	-webkit-overflow-scrolling: touch;
}

.walkr-portal-content {
	max-width: 1200px;
	margin: 0 auto;
}

/* Typography Overrides */
h1, h2, h3, h4, h5, h6 {
	font-weight: 900; /* Font-Black */
	letter-spacing: 0.025em; /* Tracking-Wide */
	color: var(--walkr-text);
	word-wrap: break-word;
	overflow-wrap: break-word;
}

/* ==========================================================================
   Header Styles
   ========================================================================== */

.walkr-portal-header {
	display: flex;
	flex-direction: column;
	gap: clamp(10px, 2vw, 15px);
	align-items: stretch;
	margin-bottom: clamp(20px, 4vw, 40px);
	padding-bottom: clamp(15px, 2vw, 20px);
	border-bottom: 4px solid var(--walkr-border);
}

@media (min-width: 600px) {
	.walkr-portal-header {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

.walkr-portal-title {
	font-size: var(--walkr-text-4xl);
	margin: 0;
	color: var(--walkr-primary);
	text-transform: uppercase;
	letter-spacing: 1px;
	text-align: center;
}

@media (min-width: 600px) {
	.walkr-portal-title {
		text-align: left;
	}
}

.walkr-portal-actions {
	display: flex;
	gap: 10px;
	justify-content: center;
}

@media (min-width: 600px) {
	.walkr-portal-actions {
		justify-content: flex-end;
	}
}
}

/* ==========================================================================
   Login Page Styles
   ========================================================================== */

.walkr-login-wrap {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100vw;
	height: 100vh;
	z-index: 2147483647; /* Max safe integer to cover everything */
	display: flex;
	flex-direction: column;
	background-color: var(--walkr-bg);
	overflow-y: auto; /* Allow scrolling */
	padding: 20px;
	box-sizing: border-box;
}

/* Background Shapes */
.walkr-login-background {
	position: fixed; /* Fixed background */
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	z-index: -1;
	pointer-events: none;
}

.walkr-shape {
	position: absolute;
	border-radius: 50%;
	opacity: 0.6;
}

.walkr-shape-1 {
	width: 300px;
	height: 300px;
	background-color: var(--walkr-secondary-bg);
	top: -50px;
	right: -50px;
	animation: walkr-float 6s ease-in-out infinite;
}

.walkr-shape-2 {
	width: 200px;
	height: 200px;
	background-color: #FCE7F3; /* Light Pink */
	bottom: 50px;
	left: -50px;
	animation: walkr-float 8s ease-in-out infinite reverse;
}

.walkr-shape-3 {
	width: 100px;
	height: 100px;
	background-color: #FEF3C7; /* Darker Yellow */
	top: 40%;
	left: 20%;
	animation: walkr-bounce 4s ease-in-out infinite;
}

@keyframes walkr-float {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(20px, -20px); }
}

@keyframes walkr-bounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-15px); }
}

.walkr-login-container {
	width: 100%;
	max-width: 450px;
	background: #ffffff;
	padding: 40px;
	border-radius: var(--walkr-radius);
	border: 4px solid var(--walkr-secondary); /* Sky Blue Border */
	position: relative;
	z-index: 1;
	margin: auto; /* Center vertically and horizontally in flex container */
	flex-shrink: 0; /* Prevent shrinking */
}

.walkr-login-header {
	text-align: center;
	margin-bottom: 30px;
}

.walkr-login-logo {
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
}

/* Login Form Inputs */
#walkr-login-form .login-username,
#walkr-login-form .login-password {
	margin-bottom: 20px;
}

#walkr-login-form label {
	display: block;
	margin-bottom: 8px;
	font-weight: 700;
	color: var(--walkr-text);
	font-size: 1rem;
}

#walkr-login-form input[type="text"],
#walkr-login-form input[type="password"] {
	width: 100%;
	padding: 15px 20px;
	border: 3px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	font-size: 1.1rem;
	background-color: #fff;
	transition: all 0.2s ease;
}

#walkr-login-form input[type="text"]:focus,
#walkr-login-form input[type="password"]:focus {
	border-color: var(--walkr-secondary);
	outline: none;
}

/* "Clicky" Pop-Art Button */
#walkr-login-form .login-submit {
	margin-top: 30px;
}

#walkr-login-form input[type="submit"] {
	display: block;
	width: 100%;
	padding: 15px;
	background-color: var(--walkr-primary);
	color: white;
	font-size: 1.2rem;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 1px;
	border: none;
	border-bottom: 6px solid var(--walkr-primary-border); /* 3D Effect */
	border-radius: var(--walkr-radius); /* Pill shape */
	cursor: pointer;
	transition: all 0.1s ease;
	margin-bottom: 10px;
}

#walkr-login-form input[type="submit"]:hover {
	background-color: var(--walkr-primary-hover);
	transform: translateY(-2px);
}

#walkr-login-form input[type="submit"]:active {
	transform: translateY(4px);
	border-bottom-width: 2px;
	margin-bottom: 14px; /* Compensate for border loss */
}

/* Links */
.walkr-login-links {
	text-align: center;
	margin-top: 20px;
}

.walkr-login-links a {
	color: var(--walkr-secondary);
	font-weight: 600;
	text-decoration: none;
}

.walkr-login-links a:hover {
	color: var(--walkr-primary);
	text-decoration: underline;
}

/* Notices */
.walkr-notice {
	padding: 15px;
	border-radius: var(--walkr-radius-sm);
	margin-bottom: 20px;
	font-weight: 600;
	text-align: center;
}

.walkr-notice-error {
	background-color: #FEE2E2;
	color: #991B1B;
	border: 2px solid #FCA5A5;
}

.walkr-notice-success {
	background-color: #D1FAE5;
	color: #065F46;
	border: 2px solid #6EE7B7;
}

/* Checkbox */
#walkr-login-form .login-remember label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: normal;
	cursor: pointer;
}

#walkr-login-form input[type="checkbox"] {
	width: 20px;
	height: 20px;
	border: 2px solid var(--walkr-border);
	border-radius: 6px;
	accent-color: var(--walkr-primary);
}

/* ==========================================================================
   Navigation / Tabs
   ========================================================================== */

.walkr-portal-nav {
	margin-bottom: 20px;
	position: relative;
	overflow: visible; /* Allow buttons to expand during hover */
	-webkit-overflow-scrolling: touch;
	padding: 10px 0 15px 0; /* Vertical padding for hover animation room */
	z-index: 10; /* Above other sections */
}

/* Scroll wrapper for horizontal scroll while allowing vertical overflow */
.walkr-portal-nav-scroll {
	overflow-x: auto;
	overflow-y: visible;
	padding-top: 8px;
	padding-bottom: 8px;
}

/* Scroll indicator gradient */
.walkr-portal-nav::after {
	content: '';
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: 40px;
	background: linear-gradient(to right, transparent, var(--walkr-bg));
	pointer-events: none;
	opacity: 1;
	z-index: 20; /* Ensure it stays on top */
}

@media (min-width: 768px) {
	.walkr-portal-nav::after {
		display: none;
	}
	
	.walkr-portal-nav {
		padding: 5px 0 10px 0;
	}
}

.walkr-tabs {
	display: flex;
	flex-wrap: nowrap;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 5px 50px 5px 0; /* Vertical padding + scroll indicator space */
	border-bottom: none;
	width: max-content;
	min-width: 100%;
	position: relative;
	z-index: 5;
}

@media (min-width: 768px) {
	.walkr-tabs {
		flex-wrap: wrap;
		width: auto;
		padding-right: 0;
	}
}

.walkr-tab {
	margin-bottom: 0;
	flex-shrink: 0;
	position: relative;
	z-index: 5;
}

.walkr-tab a {
	display: block;
	padding: 10px 18px;
	color: var(--walkr-text);
	text-decoration: none !important;
	background-color: #fff;
	border: 2px solid var(--walkr-secondary);
	border-radius: var(--walkr-radius);
	font-weight: 700;
	transition: all 0.2s ease;
	font-size: var(--walkr-text-sm);
	white-space: nowrap;
	position: relative;
	z-index: 5;
}

.walkr-tab a:hover {
	transform: translateY(-3px);
	border-color: var(--walkr-primary);
	color: var(--walkr-primary);
	text-decoration: none !important;
	z-index: 10; /* Bring to front during hover */
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.walkr-tab.active a {
	background-color: var(--walkr-primary);
	color: #fff;
	border-color: var(--walkr-primary-border);
	border-bottom-width: 5px;
	margin-bottom: -3px;
	z-index: 6;
}

/* ==========================================================================
   Sections
   ========================================================================== */

.walkr-section {
	margin-bottom: 30px;
	position: relative;
	z-index: 1; /* Below nav tabs */
}

.walkr-section h2 {
	margin: 0 0 20px;
	font-size: var(--walkr-text-xl);
	font-weight: 600;
	color: var(--walkr-text);
}

.walkr-section h3 {
	margin: 25px 0 15px;
	font-size: var(--walkr-text-lg);
	font-weight: 500;
	color: var(--walkr-text);
}

.walkr-section-actions {
	margin-bottom: 20px;
}

/* Tab Content Cards */
.walkr-tab-content {
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	padding: clamp(15px, 4vw, 25px);
	box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.walkr-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: clamp(10px, 2vw, 12px) clamp(18px, 4vw, 24px);
	font-size: var(--walkr-text-base);
	font-weight: 800;
	line-height: 1.2;
	text-decoration: none !important; /* Force no underline */
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border: none;
	border-radius: var(--walkr-radius);
	cursor: pointer;
	transition: all 0.1s ease;
	position: relative;
	min-height: 44px; /* Touch target */
	-webkit-tap-highlight-color: transparent;
}

.walkr-button:hover,
.walkr-button:focus,
.walkr-button:active {
	text-decoration: none !important;
	outline: none;
}

.walkr-button:focus-visible {
	outline: 3px solid var(--walkr-secondary);
	outline-offset: 2px;
}

.walkr-button-primary {
	background: var(--walkr-primary);
	color: #fff;
	border-bottom: 5px solid var(--walkr-primary-border);
}

.walkr-button-primary:hover {
	background: var(--walkr-primary-hover);
	color: #fff;
	transform: translateY(-2px);
}

.walkr-button-primary:active {
	transform: translateY(3px);
	border-bottom-width: 2px;
}

.walkr-button-secondary {
	background: #fff;
	color: var(--walkr-text);
	border: 2px solid var(--walkr-secondary);
	border-bottom: 5px solid var(--walkr-secondary);
}

.walkr-button-secondary:hover {
	background: var(--walkr-secondary-bg);
	color: var(--walkr-text);
	transform: translateY(-2px);
}

.walkr-button-secondary:active {
	transform: translateY(3px);
	border-bottom-width: 2px;
}

.walkr-button-small {
	padding: 8px 16px;
	font-size: var(--walkr-text-sm);
	border-bottom-width: 3px;
	min-height: 38px;
}

.walkr-button-danger {
	background: #EF4444;
	color: #fff;
	border-bottom: 5px solid #B91C1C;
}

.walkr-button-danger:hover {
	background: #DC2626;
	color: #fff;
	transform: translateY(-2px);
}

.walkr-button-danger:active {
	transform: translateY(3px);
	border-bottom-width: 2px;
}

/* ==========================================================================
   Cards
   ========================================================================== */

.walkr-cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 30px; /* Increased gap for cleaner look */
}

.walkr-card {
	background: #fff;
	border: 2px solid var(--walkr-secondary); /* Thinner border */
	border-radius: var(--walkr-radius);
	padding: 30px; /* Increased padding */
	box-shadow: none;
	transition: transform 0.2s ease;
}

.walkr-card:hover {
	transform: translateY(-5px);
	border-color: var(--walkr-primary); /* Highlight on hover */
}

.walkr-card h3 {
	margin: 0 0 20px;
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--walkr-text);
	text-transform: uppercase;
	letter-spacing: 1px;
}

.walkr-stat {
	font-size: 2rem;
	font-weight: 700;
	color: var(--walkr-text);
	margin: 0;
}

.walkr-stat .walkr-icon-check {
	color: var(--walkr-success);
	font-size: 1.5rem;
	vertical-align: middle;
}

.walkr-stat-credit {
	color: var(--walkr-success);
}

/* Card Variants */
.walkr-card-balance.walkr-card-warning {
	border-left: 4px solid var(--walkr-warning);
}

.walkr-card-balance.walkr-card-success {
	border-left: 4px solid var(--walkr-success);
}

.walkr-card-credit {
	border-left: 4px solid var(--walkr-info);
	background: linear-gradient(135deg, var(--walkr-bg) 0%, rgba(59, 130, 246, 0.05) 100%);
}

/* Badges */
.walkr-badge {
	display: inline-block;
	padding: 2px 8px;
	font-size: 0.75rem;
	font-weight: 600;
	border-radius: var(--walkr-radius-sm);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.walkr-badge-success {
	background: rgba(16, 185, 129, 0.1);
	color: var(--walkr-success);
}

.walkr-badge-info {
	background: rgba(59, 130, 246, 0.1);
	color: var(--walkr-info);
}

.walkr-badge-warning {
	background: rgba(245, 158, 11, 0.1);
	color: var(--walkr-warning);
}

/* Payment Status in Tables */
.walkr-paid {
	color: var(--walkr-success);
	font-weight: 600;
}

.walkr-pending {
	color: var(--walkr-warning);
}

.walkr-muted {
	color: var(--walkr-text-muted);
}

/* Stat Cards (Admin) */
.walkr-stat-cards {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
}

.walkr-stat-card {
	background: var(--walkr-bg);
	border: 1px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	padding: 15px 20px;
	text-align: center;
	min-width: 100px;
}

.walkr-stat-count {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--walkr-text);
}

.walkr-stat-label {
	display: block;
	font-size: 0.8rem;
	color: var(--walkr-text-light);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.walkr-stat-pending .walkr-stat-count { color: var(--walkr-warning); }
.walkr-stat-confirmed .walkr-stat-count { color: var(--walkr-info); }
.walkr-stat-active .walkr-stat-count { color: var(--walkr-primary); }
.walkr-stat-success .walkr-stat-count { color: var(--walkr-success); }
.walkr-stat-info .walkr-stat-count { color: var(--walkr-info); }
.walkr-stat-muted .walkr-stat-count { color: var(--walkr-text-muted); }

/* ==========================================================================
   Tables
   ========================================================================== */

.walkr-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background: #fff;
	border: 2px solid var(--walkr-secondary); /* Thinner border */
	border-radius: var(--walkr-radius);
	overflow: hidden;
	margin-bottom: 20px;
}

.walkr-table th,
.walkr-table td {
	padding: 18px 25px; /* More breathing room */
	text-align: left;
	border-bottom: 1px solid var(--walkr-border); /* Thinner separator */
}

.walkr-table th {
	background: var(--walkr-secondary-bg);
	font-weight: 800;
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--walkr-text);
	border-bottom: 2px solid var(--walkr-secondary);
}

.walkr-table tbody tr:last-child td {
	border-bottom: none;
}

.walkr-table tbody tr:hover {
	background-color: var(--walkr-bg-light);
}

.walkr-row-warning {
	background: #fef3c7 !important;
}

.walkr-row-danger {
	background: #fee2e2 !important;
}

.walkr-amount {
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

/* ==========================================================================
   Status Badges
   ========================================================================== */

.walkr-status {
	display: inline-block;
	padding: 4px 10px;
	font-size: 0.8rem;
	font-weight: 500;
	border-radius: 20px;
	text-transform: capitalize;
}

.walkr-status-requested { background: #fef3c7; color: #92400e; }
.walkr-status-confirmed { background: #dbeafe; color: #1e40af; }
.walkr-status-on_the_way { background: #e0e7ff; color: #3730a3; }
.walkr-status-in_progress { background: #e0e7ff; color: #3730a3; }
.walkr-status-completed { background: #d1fae5; color: #065f46; }
.walkr-status-cancelled { background: #f3f4f6; color: #6b7280; }
.walkr-status-no_show { background: #fee2e2; color: #991b1b; }
.walkr-status-invoiced { background: #dbeafe; color: #1e40af; }
.walkr-status-paid { background: #d1fae5; color: #065f46; }
.walkr-status-partial { background: #fef3c7; color: #92400e; }
.walkr-status-draft { background: #f3f4f6; color: #6b7280; }
.walkr-status-sent { background: #dbeafe; color: #1e40af; }
.walkr-status-overdue { background: #fee2e2; color: #991b1b; }
.walkr-status-void { background: #f3f4f6; color: #6b7280; }

.walkr-overdue-badge {
	display: inline-block;
	padding: 2px 8px;
	background: var(--walkr-danger);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	border-radius: 10px;
}

/* ==========================================================================
   Forms
   ========================================================================== */

.walkr-form {
	max-width: 600px;
}

/* Forms inside modal should use full width */
.walkr-modal .walkr-form,
.walkr-form-modal-content .walkr-form {
	max-width: 100%;
}

.walkr-form-group {
	margin-bottom: 20px;
}

.walkr-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

@media (max-width: 600px) {
	.walkr-form-row {
		grid-template-columns: 1fr;
	}
}

.walkr-form label {
	display: block;
	margin-bottom: 6px;
	font-weight: 500;
	color: var(--walkr-text);
}

.walkr-form label .required {
	color: var(--walkr-danger);
}

.walkr-form input[type="text"],
.walkr-form input[type="email"],
.walkr-form input[type="number"],
.walkr-form input[type="datetime-local"],
.walkr-form input[type="date"],
.walkr-form input[type="time"],
.walkr-form select,
.walkr-form textarea {
	width: 100%;
	padding: 10px 12px;
	font-size: 1rem;
	border: 1px solid var(--walkr-border-dark);
	border-radius: var(--walkr-radius-sm);
	background: var(--walkr-bg);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.walkr-form input:focus,
.walkr-form select:focus,
.walkr-form textarea:focus {
	outline: none;
	border-color: var(--walkr-primary);
	box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
}

.walkr-form textarea {
	resize: vertical;
	min-height: 80px;
}

.walkr-help-text {
	margin: 5px 0 0;
	font-size: 0.85rem;
	color: var(--walkr-text-light);
}

.walkr-checkbox-group {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.walkr-checkbox-label {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}

.walkr-checkbox-label input[type="checkbox"] {
	width: 18px;
	height: 18px;
}

.walkr-pet-info {
	color: var(--walkr-text-light);
	font-size: 0.9em;
}

.walkr-form-actions {
	margin-top: 25px;
	padding-top: 20px;
	border-top: 1px solid var(--walkr-border);
}

/* ==========================================================================
   Messages & Notices
   ========================================================================== */

.walkr-notice {
	padding: 15px 20px;
	border-radius: var(--walkr-radius);
	margin-bottom: 20px;
}

.walkr-notice p {
	margin: 0;
}

.walkr-notice-info {
	background: #dbeafe;
	color: #1e40af;
	border: 1px solid #93c5fd;
}

.walkr-notice-success {
	background: #d1fae5;
	color: #065f46;
	border: 1px solid #6ee7b7;
}

.walkr-notice-warning {
	background: #fef3c7;
	color: #92400e;
	border: 1px solid #fcd34d;
}

.walkr-notice-error {
	background: #fee2e2;
	color: #991b1b;
	border: 1px solid #fca5a5;
}

.walkr-message {
	padding: 15px 20px;
	border-radius: var(--walkr-radius);
	margin-top: 20px;
}

.walkr-message-success {
	background: #d1fae5;
	color: #065f46;
}

.walkr-message-error {
	background: #fee2e2;
	color: #991b1b;
}

.walkr-empty {
	padding: 40px 20px;
	text-align: center;
	color: var(--walkr-text-light);
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius);
}

.walkr-empty-success {
	background: #d1fae5;
	color: #065f46;
}

/* ==========================================================================
   Pets
   ========================================================================== */

.walkr-pet-cards {
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

.walkr-pet-card {
	cursor: pointer;
	transition: box-shadow 0.2s ease;
}

.walkr-pet-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.walkr-pet-card.expanded {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.walkr-pet-card-header {
	display: flex;
	align-items: center;
	gap: 15px;
}

.walkr-pet-photo {
	width: 70px;
	height: 70px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	background: var(--walkr-bg);
}

.walkr-pet-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.walkr-pet-photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--walkr-primary-light) 0%, var(--walkr-primary) 100%);
}

.walkr-pet-icon {
	font-size: 32px;
}

.walkr-pet-header-info {
	flex: 1;
	min-width: 0;
}

.walkr-pet-header-info h3 {
	margin: 0 0 4px;
	font-size: 1.15rem;
	color: var(--walkr-text);
	text-transform: none;
	letter-spacing: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.walkr-pet-subtitle {
	margin: 0;
	font-size: 0.9rem;
	color: var(--walkr-text-light);
}

.walkr-pet-expand {
	width: 32px;
	height: 32px;
	border: none;
	background: transparent;
	cursor: pointer;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, transform 0.2s;
	flex-shrink: 0;
}

.walkr-pet-expand:hover {
	background: var(--walkr-bg);
}

.walkr-expand-icon {
	font-size: 12px;
	color: var(--walkr-text-light);
	transition: transform 0.3s ease;
}

.walkr-pet-card.expanded .walkr-expand-icon {
	transform: rotate(180deg);
}

.walkr-pet-card-details {
	margin-top: 15px;
	padding-top: 15px;
	border-top: 1px solid var(--walkr-border);
	animation: slideDown 0.3s ease;
}

@keyframes slideDown {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.walkr-pet-details {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 8px 15px;
	margin: 0 0 15px;
}

.walkr-pet-details dt {
	font-weight: 500;
	color: var(--walkr-text-light);
	font-size: 0.9rem;
}

.walkr-pet-details dd {
	margin: 0;
	font-size: 0.9rem;
}

.walkr-card-actions {
	display: flex;
	gap: 10px;
	padding-top: 15px;
	border-top: 1px solid var(--walkr-border);
}

/* ==========================================================================
   Visit Reports
   ========================================================================== */

.walkr-reports-list {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.walkr-report-card {
	background: var(--walkr-bg);
	border: 1px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	overflow: hidden;
}

.walkr-report-header {
	padding: 15px 20px;
	background: var(--walkr-bg-light);
	border-bottom: 1px solid var(--walkr-border);
}

.walkr-report-header h3 {
	margin: 0;
	font-size: 1rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.walkr-report-date {
	font-weight: 400;
	color: var(--walkr-text-light);
	font-size: 0.9em;
}

.walkr-report-details {
	padding: 15px 20px;
}

.walkr-report-checks {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	list-style: none;
	margin: 0 0 15px;
	padding: 0;
}

.walkr-report-checks li {
	padding: 5px 12px;
	border-radius: 20px;
	font-size: 0.85rem;
}

.walkr-report-checks .checked {
	background: #d1fae5;
	color: #065f46;
}

.walkr-report-checks .unchecked {
	background: #f3f4f6;
	color: #6b7280;
}

.walkr-report-mood {
	margin: 0 0 10px;
}

.walkr-report-notes {
	margin: 0;
	padding: 10px 15px;
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius-sm);
	color: var(--walkr-text);
}

/* ==========================================================================
   Login
   ========================================================================== */

.walkr-login-wrap {
	display: flex;
	justify-content: center;
	padding: 40px 20px;
}

.walkr-login-container {
	width: 100%;
	max-width: 400px;
	background: var(--walkr-bg);
	padding: 40px;
	border-radius: var(--walkr-radius);
	box-shadow: var(--walkr-shadow-md);
}

.walkr-login-title {
	margin: 0 0 30px;
	text-align: center;
	font-size: 1.5rem;
	font-weight: 600;
}

.walkr-login-container #walkr-login-form p {
	margin-bottom: 20px;
}

.walkr-login-container #walkr-login-form label {
	display: block;
	margin-bottom: 6px;
	font-weight: 500;
}

.walkr-login-container #walkr-login-form input[type="text"],
.walkr-login-container #walkr-login-form input[type="password"] {
	width: 100%;
	padding: 10px 12px;
	font-size: 1rem;
	border: 1px solid var(--walkr-border-dark);
	border-radius: var(--walkr-radius-sm);
}

.walkr-login-container #walkr-login-form input[type="submit"] {
	width: 100%;
	padding: 12px;
	font-size: 1rem;
	font-weight: 500;
	background: var(--walkr-primary);
	color: #fff;
	border: none;
	border-radius: var(--walkr-radius);
	cursor: pointer;
	transition: background 0.2s ease;
}

.walkr-login-container #walkr-login-form input[type="submit"]:hover {
	background: var(--walkr-primary-hover);
}

.walkr-login-links {
	margin-top: 20px;
	text-align: center;
}

.walkr-login-links a {
	color: var(--walkr-primary);
	text-decoration: none;
}

.walkr-login-links a:hover {
	text-decoration: underline;
}

/* ==========================================================================
   Misc
   ========================================================================== */

.walkr-icon-check {
	color: var(--walkr-success);
}

.walkr-paid {
	color: var(--walkr-success);
	font-weight: 500;
}

.walkr-pending {
	color: var(--walkr-warning);
}

.walkr-muted {
	color: var(--walkr-text-muted);
}

.walkr-disabled {
	color: var(--walkr-text-muted);
	pointer-events: none;
	cursor: not-allowed;
}

.walkr-form-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.walkr-form-links li {
	padding: 10px 0;
	border-bottom: 1px solid var(--walkr-border);
}

.walkr-form-links a {
	color: var(--walkr-primary);
	text-decoration: none;
}

.walkr-status-select {
	padding: 6px 10px;
	font-size: 0.85rem;
	border: 1px solid var(--walkr-border-dark);
	border-radius: var(--walkr-radius-sm);
	background: var(--walkr-bg);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 768px) {
	.walkr-portal {
		padding: 20px 15px;
	}

	.walkr-portal-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 15px;
	}

	.walkr-portal-title {
		font-size: 1.8rem;
	}

	.walkr-tabs {
		width: 100%;
		overflow-x: auto;
		flex-wrap: nowrap;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 10px;
	}

	.walkr-tab a {
		padding: 10px 15px;
		white-space: nowrap;
		font-size: 0.9rem;
	}

	.walkr-table {
		display: block;
		overflow-x: auto;
	}

	.walkr-cards {
		grid-template-columns: 1fr;
	}

	.walkr-button {
		padding: 10px 18px;
		font-size: 0.9rem;
	}
}

@media (max-width: 480px) {
	.walkr-portal {
		padding: 15px 10px;
	}

	.walkr-portal-title {
		font-size: 1.5rem;
	}

	.walkr-tab a {
		padding: 8px 12px;
		font-size: 0.85rem;
	}

	.walkr-card {
		padding: 20px;
	}

	.walkr-table th,
	.walkr-table td {
		padding: 12px 15px;
	}
}

/* ==========================================================================
   Calendar Styles (Refactored Mobile-First)
   ========================================================================== */

.walkr-calendar-instructions {
	color: var(--walkr-text-light);
	margin-bottom: 20px;
	font-size: 1rem;
}

.walkr-calendar-container {
	max-width: 100%;
	margin: 0 auto;
}

/* Custom Calendar - Mobile Base */
.walkr-calendar {
	background: #fff;
	border: 2px solid var(--walkr-secondary);
	border-radius: 1.2rem; /* Mobile radius */
	overflow: hidden;
	width: 100%;
	margin: 0 auto;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
    .walkr-calendar {
        border-radius: var(--walkr-radius); /* Larger desktop radius */
        max-width: 600px;
    }
}

.walkr-calendar-header {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	padding: 12px 15px;
	background: var(--walkr-secondary-bg);
	border-bottom: 2px solid var(--walkr-secondary);
	gap: 8px;
}

@media (min-width: 600px) {
    .walkr-calendar-header {
        padding: 15px 20px;
    }
}

.walkr-calendar-title {
	margin: 0;
	font-size: clamp(0.9rem, 3.5vw, 1.2rem);
	font-weight: 800;
	color: var(--walkr-text);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	flex: 1;
	text-align: center;
}

@media (min-width: 600px) {
    .walkr-calendar-title {
        font-size: 1.4rem;
    }
}

.walkr-calendar-nav {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: var(--walkr-primary);
	color: #fff;
	border: none;
	border-bottom: 3px solid var(--walkr-primary-border);
	border-radius: 50%;
	font-size: 1.1rem;
	font-weight: bold;
	cursor: pointer;
	transition: all 0.1s ease;
	text-decoration: none !important;
	flex-shrink: 0;
}

@media (min-width: 600px) {
    .walkr-calendar-nav {
		width: 44px;
		height: 44px;
        border-bottom-width: 4px;
        font-size: 1.5rem;
    }
}

.walkr-calendar-nav:hover {
	background: var(--walkr-primary-hover);
	transform: translateY(-2px);
	text-decoration: none !important;
}

.walkr-calendar-nav:active {
	transform: translateY(2px);
	border-bottom-width: 2px;
}

.walkr-calendar-nav span {
	text-decoration: none !important;
	line-height: 1;
}

.walkr-calendar-weekdays {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	background: var(--walkr-bg);
	border-bottom: 2px solid var(--walkr-border);
}

.walkr-calendar-weekdays > div {
	padding: 10px 2px;
	text-align: center;
	font-weight: 800;
	font-size: 0.7rem; /* Mobile size */
	color: var(--walkr-text);
	text-transform: uppercase;
	letter-spacing: 1px;
	text-decoration: none !important;
}

@media (min-width: 600px) {
    .walkr-calendar-weekdays > div {
        padding: 15px 5px;
        font-size: 0.85rem;
    }
}

.walkr-calendar-days {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 0;
}

.walkr-calendar-day {
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.9rem; /* Slightly smaller for mobile */
	font-weight: 600;
	color: var(--walkr-text);
	border: 1px solid var(--walkr-border);
	margin: -0.5px;
	cursor: pointer;
	transition: all 0.15s ease;
	text-decoration: none !important;
	background: #fff;
    min-height: 44px; /* Touch target */
}

@media (min-width: 600px) {
    .walkr-calendar-day {
        font-size: 1rem;
    }
}

.walkr-calendar-day:hover:not(.walkr-calendar-day-past):not(.walkr-calendar-day-unavailable):not(.walkr-calendar-day-other) {
	background: var(--walkr-secondary-bg);
	border-color: var(--walkr-secondary);
	z-index: 1;
}

.walkr-calendar-day-other {
	color: var(--walkr-text-muted);
	background: var(--walkr-bg-light);
	cursor: default;
}

.walkr-calendar-day-today {
	background: var(--walkr-secondary-bg) !important;
	font-weight: 800;
	color: var(--walkr-primary);
}

.walkr-calendar-day-past {
	color: var(--walkr-text-muted);
	background: var(--walkr-bg-light);
	cursor: not-allowed;
}

.walkr-calendar-day-unavailable {
	color: #ccc;
	background: #f5f5f5;
	cursor: not-allowed;
	position: relative;
}

.walkr-calendar-day-unavailable::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 20%;
	right: 20%;
	height: 2px;
	background: #ddd;
	transform: rotate(-45deg);
}

.walkr-calendar-day-selected {
	background: var(--walkr-primary) !important;
	color: #fff !important;
	border-color: var(--walkr-primary-border) !important;
	z-index: 2;
}

.walkr-calendar-day-in-range {
	background: rgba(236, 72, 153, 0.2) !important;
	border-color: var(--walkr-primary) !important;
}

/* Calendar Legend */
.walkr-calendar-legend {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 20px;
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
}

.walkr-legend-item {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 0.95rem;
	color: var(--walkr-text);
	font-weight: 500;
}

.walkr-legend-dot {
	width: 24px;
	height: 24px;
	border-radius: 8px;
	border: 2px solid;
	flex-shrink: 0;
}

.walkr-legend-available {
	background: #fff;
	border-color: var(--walkr-secondary);
}

.walkr-legend-selected {
	background: var(--walkr-primary);
	border-color: var(--walkr-primary-border);
}

.walkr-legend-unavailable {
	background: #f5f5f5;
	border-color: #ddd;
}

.walkr-calendar-hint {
	text-align: center;
	margin: 20px 0 0;
	color: var(--walkr-text-light);
	font-size: 0.95rem;
}

/* FullCalendar Overrides (Legacy - for backwards compatibility) */
.fc {
	font-family: inherit;
	--fc-border-color: var(--walkr-border);
	--fc-button-bg-color: var(--walkr-primary);
	--fc-button-border-color: var(--walkr-primary);
	--fc-button-hover-bg-color: var(--walkr-primary-hover);
	--fc-button-hover-border-color: var(--walkr-primary-hover);
	--fc-button-active-bg-color: var(--walkr-primary-hover);
	--fc-button-active-border-color: var(--walkr-primary-hover);
	--fc-today-bg-color: rgba(79, 70, 229, 0.1);
}

.fc-header-toolbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 20px;
}

.fc-toolbar-chunk {
	display: flex;
	align-items: center;
	gap: 5px;
}

.fc-toolbar-title {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 600;
}

.fc-button {
	padding: 8px 16px;
	font-size: 0.9rem;
	border-radius: var(--walkr-radius-sm);
	cursor: pointer;
	transition: background-color 0.15s, border-color 0.15s;
}

.fc-button-primary {
	background-color: var(--walkr-primary);
	border-color: var(--walkr-primary);
	color: #fff;
}

.fc-button-primary:hover {
	background-color: var(--walkr-primary-hover);
	border-color: var(--walkr-primary-hover);
}

.fc-button-primary:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.fc-icon {
	display: inline-block;
	width: 10px;
	height: 10px;
}

.fc-icon-chevron-left::before {
	content: "◀";
	font-size: 10px;
}

.fc-icon-chevron-right::before {
	content: "▶";
	font-size: 10px;
}

.fc-scrollgrid {
	width: 100%;
	border-collapse: collapse;
}

.fc-col-header-cell {
	padding: 10px;
	text-align: center;
	font-weight: 600;
	color: var(--walkr-text-light);
	background: var(--walkr-bg-light);
	border-bottom: 1px solid var(--walkr-border);
}

.fc-daygrid-day {
	border: 1px solid var(--walkr-border);
	cursor: pointer;
	transition: background-color 0.15s;
}

.fc-daygrid-day:hover:not(.fc-day-disabled) {
	background-color: var(--walkr-bg-light);
}

.fc-daygrid-day-frame {
	min-height: 80px;
	padding: 5px;
	position: relative;
}

.fc-daygrid-day-top {
	text-align: right;
}

.fc-daygrid-day-number {
	display: inline-block;
	padding: 5px 8px;
	font-size: 0.9rem;
	color: var(--walkr-text);
	text-decoration: none;
}

.fc-day-today {
	background-color: rgba(79, 70, 229, 0.08) !important;
}

.fc-day-today .fc-daygrid-day-number {
	background-color: var(--walkr-primary);
	color: #fff;
	border-radius: 50%;
	font-weight: 600;
}

.fc-day-other {
	background-color: var(--walkr-bg-light);
}

.fc-day-other .fc-daygrid-day-number {
	color: var(--walkr-text-muted);
}

.fc-day-disabled,
.walkr-unavailable {
	background-color: #f5f5f5 !important;
	cursor: not-allowed !important;
}

.fc-day-disabled .fc-daygrid-day-number,
.walkr-unavailable .fc-daygrid-day-number {
	color: #ccc;
	text-decoration: line-through;
}

.fc-day-selected {
	background-color: rgba(79, 70, 229, 0.2) !important;
}

.fc-day-selected .fc-daygrid-day-number {
	background-color: var(--walkr-primary);
	color: #fff;
	border-radius: 50%;
}

.fc-non-business {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: repeating-linear-gradient(
		45deg,
		transparent,
		transparent 5px,
		rgba(0, 0, 0, 0.03) 5px,
		rgba(0, 0, 0, 0.03) 10px
	);
	pointer-events: none;
}

/* ==========================================================================
   Booking Modal Styles (Refactored Mobile-First)
   ========================================================================== */

/* Modal Container - Mobile Base (Full Screen Bottom Sheet) */
.walkr-modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 99999 !important;
	display: none;
	align-items: stretch;
	justify-content: stretch;
	padding: 0 !important;
	margin: 0 !important;
	overscroll-behavior: contain;
}

@media (min-width: 768px) {
    .walkr-modal {
        align-items: center;
        justify-content: center;
        padding: 20px !important;
    }
}

#walkr-booking-modal {
	z-index: 100000 !important;
}

#walkr-pet-modal {
	z-index: 100001 !important;
}

.walkr-modal.active,
#walkr-booking-modal.active,
#walkr-pet-modal.active {
	display: flex !important;
}

.walkr-modal[style*="display: flex"],
#walkr-booking-modal[style*="display: flex"],
#walkr-pet-modal[style*="display: flex"] {
	display: flex !important;
}

.walkr-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(2px);
	z-index: 1;
}

/* Modal Content - Mobile Base (Full Screen - No Margins) */
.walkr-modal-content {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	width: 100% !important;
	height: 100% !important;
	min-width: 100% !important;
	min-height: 100% !important;
    max-width: none !important;
	max-height: none !important;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: #fff;
	border-radius: 0 !important;
	border: none !important;
	z-index: 2;
	margin: 0 !important;
	padding: 0 !important;
	box-shadow: none !important;
}

@media (min-width: 768px) {
    .walkr-modal-content {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		bottom: auto !important;
        width: 100% !important;
        max-width: 550px !important;
		min-width: auto !important;
        height: auto !important;
        min-height: auto !important;
        max-height: 90vh !important;
        border-radius: var(--walkr-radius) !important;
        border: 2px solid var(--walkr-secondary) !important;
        margin: auto !important;
		box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
    }
}

.walkr-modal-header {
	flex-shrink: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 16px;
	border-bottom: 1px solid var(--walkr-border);
    min-height: 50px;
	background: #fff;
	width: 100%; /* Ensure full width */
	box-sizing: border-box;
}

@media (min-width: 768px) {
    .walkr-modal-header {
        padding: 15px 20px;
		border-bottom: 2px solid var(--walkr-border);
    }
}

.walkr-modal-header h3 {
	margin: 0;
	font-size: 1.25rem; /* Mobile: Smaller heading */
	font-weight: 800;
	color: var(--walkr-primary);
}

@media (min-width: 600px) {
    .walkr-modal-header h3 {
        font-size: 1.5rem;
    }
}

.walkr-modal-close {
    display: inline-flex; /* Mobile: Ensure visibility */
    align-items: center;
    justify-content: center;
    min-width: 44px; /* Touch target */
    min-height: 44px;
	background: none;
	border: none;
	font-size: 2rem;
	color: var(--walkr-text-muted);
	cursor: pointer;
	padding: 0;
	line-height: 1;
	transition: color 0.15s;
}

.walkr-modal-close:hover {
	color: var(--walkr-primary);
}

.walkr-modal-body {
	padding: 0;
	overflow-y: auto;
	flex: 1;
    -webkit-overflow-scrolling: touch;
	width: 100%; /* Ensure full width */
	box-sizing: border-box;
}

/* Ensure booking form takes full width */
#walkr-booking-form {
	width: 100%;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	flex: 1;
}

@media (min-width: 768px) {
    .walkr-modal-body {
        padding: 0;
    }
}

#walkr-pet-form {
	padding: 15px;
	overflow-y: auto;
	flex: 1;
    -webkit-overflow-scrolling: touch;
}

@media (min-width: 600px) {
    #walkr-pet-form {
        padding: 25px;
    }
}

.walkr-modal-footer {
	display: flex;
    flex-direction: column; /* Stack buttons vertically */
	align-items: stretch; /* Full width buttons */
	gap: 10px;
	padding: 16px;
	border-top: 1px solid var(--walkr-border);
	background: #fff;
	flex-shrink: 0;
	width: 100%;
	box-sizing: border-box;
	/* Safe area for devices with home indicator */
	padding-bottom: max(16px, env(safe-area-inset-bottom));
}

.walkr-modal-footer .walkr-button {
	width: 100%;
	justify-content: center;
}

@media (min-width: 768px) {
    .walkr-modal-footer {
        flex-direction: row;
		justify-content: flex-end;
		align-items: center;
        padding: 20px 25px;
		border-top: 2px solid var(--walkr-border);
		padding-bottom: 20px;
    }
	
	.walkr-modal-footer .walkr-button {
		width: auto;
	}
}

body.walkr-modal-open {
	overflow: hidden;
}

/* ==========================================================================
   Modal Form Elements (Refactored Mobile-First)
   ========================================================================== */

.walkr-form-row {
	display: grid;
	grid-template-columns: 1fr; /* Mobile: Stacked */
	gap: 15px;
	margin-bottom: 15px;
}

@media (min-width: 600px) {
    .walkr-form-row {
        grid-template-columns: 1fr 1fr;
    }
}

.walkr-form-group {
	margin-bottom: 15px;
}

.walkr-form-row label,
.walkr-form-group label {
	display: block;
	margin-bottom: 8px; /* Slightly more space */
	font-weight: 500;
	color: var(--walkr-text);
	font-size: 1rem; /* Clear text size */
}

.walkr-form-row label .required,
.walkr-form-group label .required {
	color: var(--walkr-danger);
}

.walkr-form-row input,
.walkr-form-row select,
.walkr-form-row textarea,
.walkr-form-group input,
.walkr-form-group select,
.walkr-form-group textarea {
	width: 100%;
	padding: 10px 12px;
	font-size: 16px; /* Prevents auto-zoom on iOS */
	border: 2px solid var(--walkr-border);
	border-radius: 8px;
	background: #fff;
	transition: border-color 0.15s, box-shadow 0.15s;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	min-height: 44px;
}

/* Enhanced select styling */
.walkr-form-row select,
.walkr-form-group select {
	background-color: #fff;
	background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: right 10px center;
	background-size: 16px;
	padding-right: 36px;
	cursor: pointer;
	color: var(--walkr-text);
}

.walkr-form-row select:hover,
.walkr-form-group select:hover {
	border-color: var(--walkr-secondary);
}

.walkr-form-row input:focus,
.walkr-form-row select:focus,
.walkr-form-row textarea:focus,
.walkr-form-group input:focus,
.walkr-form-group select:focus,
.walkr-form-group textarea:focus {
	outline: none;
	border-color: var(--walkr-primary);
	box-shadow: 0 0 0 3px rgba(236, 72, 153, 0.1);
}

.walkr-form-row input[readonly] {
	background: var(--walkr-bg-light);
	cursor: default;
	color: var(--walkr-text-muted); /* Better contrast for readonly */
}

.walkr-time-row {
	display: grid;
	grid-template-columns: 1fr; /* Mobile Stack */
	gap: 15px;
}

@media (min-width: 600px) {
    .walkr-time-row {
        grid-template-columns: 1fr 1fr;
    }
}

.walkr-time-field {
	display: flex;
	flex-direction: column;
}

.walkr-time-field label {
	margin-bottom: 5px;
}

.walkr-checkbox-label {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	padding: 5px 0; /* Touch friendly vertical spacing */
}

.walkr-checkbox-label input[type="checkbox"] {
	width: 20px; /* Explicit size */
	height: 20px;
	margin: 0;
	min-height: 20px; /* Override previous rule */
	padding: 0;
}

.walkr-checkbox-label span {
	font-weight: normal;
	font-size: 1rem;
}

/* Pet Selection */
.walkr-pet-checkboxes {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.walkr-pet-checkbox {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	cursor: pointer;
	transition: background-color 0.15s, border-color 0.15s, box-shadow 0.15s;
	background: #fff;
}

.walkr-pet-checkbox:hover {
	background-color: var(--walkr-bg-light);
	border-color: var(--walkr-primary-light);
}

/* Checkbox input - visible and properly sized */
.walkr-pet-checkbox input[type="checkbox"] {
	width: 22px;
	height: 22px;
	margin: 0;
	cursor: pointer;
	accent-color: var(--walkr-primary);
	border: 2px solid var(--walkr-border);
	border-radius: 4px;
}

/* Highlight border when checked */
.walkr-pet-checkbox:has(input[type="checkbox"]:checked) {
	border-color: var(--walkr-primary);
	background-color: rgba(79, 70, 229, 0.05);
	box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
}

.walkr-pet-checkbox .pet-info {
	display: flex;
	flex-direction: column;
	padding-left: 8px;
}

.walkr-pet-checkbox .pet-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--walkr-primary-light) 0%, var(--walkr-primary) 100%);
}

.walkr-pet-checkbox .pet-avatar .pet-photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.walkr-pet-checkbox .pet-avatar .pet-photo-placeholder {
	font-size: 24px;
	color: #fff;
}

.walkr-pet-checkbox .pet-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.walkr-pet-checkbox .pet-text strong {
	font-weight: 600;
	font-size: 1rem;
	color: var(--walkr-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.walkr-pet-checkbox .pet-text small {
	color: var(--walkr-text-light);
	font-size: 0.85rem;
}

/* Recurring Options */
.walkr-recurring-section {
	padding: 15px;
	margin-top: 15px;
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius-sm);
	border: 1px solid var(--walkr-border);
}

.walkr-day-checkboxes {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.walkr-day-checkboxes label {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 5px 10px;
	border: 1px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	cursor: pointer;
	font-weight: normal;
	transition: background-color 0.15s;
}

.walkr-day-checkboxes label:hover {
	background-color: var(--walkr-bg);
}

.walkr-day-checkboxes input[type="checkbox"] {
	width: auto;
	margin: 0;
}

/* Modal Messages */
#walkr-booking-message {
	margin: 20px;
	padding: 12px 15px;
	border-radius: var(--walkr-radius-sm);
}

.walkr-message-success {
	background-color: rgba(16, 185, 129, 0.1);
	color: var(--walkr-success);
	border: 1px solid var(--walkr-success);
}

.walkr-message-error {
	background-color: rgba(239, 68, 68, 0.1);
	color: var(--walkr-danger);
	border: 1px solid var(--walkr-danger);
}

/* Modal Buttons */
.walkr-btn {
	padding: 10px 20px;
	font-size: 0.95rem;
	font-weight: 500;
	border-radius: var(--walkr-radius-sm);
	cursor: pointer;
	transition: background-color 0.15s, border-color 0.15s;
	border: 1px solid transparent;
}

.walkr-btn-primary {
	background-color: var(--walkr-primary);
	color: #fff;
	border-color: var(--walkr-primary);
}

.walkr-btn-primary:hover {
	background-color: var(--walkr-primary-hover);
	border-color: var(--walkr-primary-hover);
}

.walkr-btn-primary:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.walkr-btn-secondary {
	background-color: var(--walkr-bg);
	color: var(--walkr-text);
	border-color: var(--walkr-border-dark);
}

.walkr-btn-secondary:hover {
	background-color: var(--walkr-bg-light);
}

/* ==========================================================================
   Forms List
   ========================================================================== */

.walkr-forms-list {
	display: flex;
	flex-direction: column;
	gap: 15px;
	margin-bottom: 30px;
}

.walkr-form-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 15px;
	padding: 20px;
	background: var(--walkr-bg);
	border: 1px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	box-shadow: var(--walkr-shadow);
}

.walkr-form-item.walkr-form-completed {
	border-left: 4px solid var(--walkr-success);
}

.walkr-form-item.walkr-form-pending {
	border-left: 4px solid var(--walkr-warning);
	background: linear-gradient(135deg, var(--walkr-bg) 0%, rgba(245, 158, 11, 0.03) 100%);
}

/* Highlight animation for forms required for booking */
.walkr-form-item.walkr-form-required-for-booking {
	border-left: 4px solid var(--walkr-primary);
	animation: walkr-pulse-highlight 2s ease-in-out infinite;
	position: relative;
}

.walkr-form-item.walkr-form-required-for-booking::before {
	content: "Required for your booking";
	position: absolute;
	top: -10px;
	left: 20px;
	background: var(--walkr-primary);
	color: white;
	font-size: 0.7rem;
	padding: 2px 10px;
	border-radius: 10px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

@keyframes walkr-pulse-highlight {
	0%, 100% {
		box-shadow: 0 0 0 0 rgba(236, 72, 153, 0.4);
		background: linear-gradient(135deg, var(--walkr-bg) 0%, rgba(236, 72, 153, 0.05) 100%);
	}
	50% {
		box-shadow: 0 0 0 8px rgba(236, 72, 153, 0);
		background: linear-gradient(135deg, var(--walkr-bg) 0%, rgba(236, 72, 153, 0.12) 100%);
	}
}

/* Banner for booking in progress */
.walkr-booking-forms-banner {
	background: linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);
	border: 2px solid #F59E0B;
	border-radius: var(--walkr-radius);
	padding: 15px 20px;
	margin-bottom: 20px;
}

.walkr-booking-forms-banner-content {
	display: flex;
	align-items: center;
	gap: 15px;
	flex-wrap: wrap;
}

.walkr-booking-forms-banner-icon {
	font-size: 2rem;
}

.walkr-booking-forms-banner-content > div {
	flex: 1;
	min-width: 200px;
}

.walkr-booking-forms-banner-content strong {
	display: block;
	color: #92400E;
	font-size: 1.1rem;
	margin-bottom: 4px;
}

.walkr-booking-forms-banner-content p {
	margin: 0;
	color: #78350F;
	font-size: 0.9rem;
}

.walkr-form-info h3 {
	margin: 0 0 5px;
	font-size: 1rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 10px;
}

.walkr-form-status {
	color: var(--walkr-success);
	font-size: 1.2rem;
}

.walkr-form-meta {
	margin: 0;
	font-size: 0.875rem;
	color: var(--walkr-text-light);
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.walkr-form-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.walkr-form-legend {
	padding: 15px;
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius);
	font-size: 0.875rem;
}

.walkr-form-legend p {
	margin: 0 0 5px;
}

.walkr-form-legend p:last-child {
	margin-bottom: 0;
}

.walkr-text-muted {
	color: var(--walkr-text-muted);
}

.walkr-section-description {
	margin: 0 0 20px;
	color: var(--walkr-text-light);
}

/* ==========================================================================
   Onboarding Alert
   ========================================================================== */

.walkr-onboarding-alert {
	padding: 20px;
	background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
	border: 1px solid #fed7aa;
	border-radius: var(--walkr-radius);
	margin-bottom: 30px;
}

.walkr-onboarding-alert.walkr-onboarding-blocked {
	background: linear-gradient(135deg, #fef2f2 0%, #fecaca 100%);
	border-color: #fca5a5;
}

.walkr-onboarding-alert.walkr-onboarding-blocked h3 {
	color: #991b1b;
}

.walkr-onboarding-alert.walkr-onboarding-blocked p,
.walkr-onboarding-alert.walkr-onboarding-blocked ul {
	color: #7f1d1d;
}

.walkr-onboarding-alert.walkr-onboarding-blocked a {
	color: #dc2626;
}

.walkr-onboarding-alert h3 {
	margin: 0 0 10px;
	color: #9a3412;
	font-size: 1.1rem;
}

.walkr-onboarding-alert p {
	margin: 0 0 15px;
	color: #7c2d12;
}

.walkr-onboarding-alert ul {
	list-style: disc;
	margin: 0;
	padding-left: 20px;
}

.walkr-onboarding-alert ul li {
	margin-bottom: 8px;
}

.walkr-onboarding-alert ul li a {
	color: #ea580c;
	text-decoration: underline;
}

.walkr-onboarding-alert ul li a:hover {
	color: #c2410c;
}

.walkr-onboarding-steps {
	list-style: none;
	padding: 0;
	margin: 0;
}

.walkr-onboarding-steps li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 0;
	border-bottom: 1px solid rgba(154, 52, 18, 0.1);
}

.walkr-onboarding-steps li:last-child {
	border-bottom: none;
}

.walkr-onboarding-steps .walkr-step-done {
	color: var(--walkr-success);
}

.walkr-onboarding-steps .walkr-step-pending {
	color: #9a3412;
}

/* ==========================================================================
   Form Modal Styles
   ========================================================================== */

.walkr-form-modal-content {
	max-width: 900px;
	width: 95%;
	max-height: 90vh;
	overflow-y: auto;
	margin: auto;
}

.walkr-form-modal-content .walkr-modal-body {
	padding: 0;
}

.walkr-form-loading {
	padding: 60px 20px;
	text-align: center;
	color: var(--walkr-text-light);
}

/* Form Message */
.walkr-form-message {
	padding: 15px 20px;
	margin: 0;
	border-bottom: 1px solid var(--walkr-border);
}

.walkr-form-message-success {
	background: #ecfdf5;
	color: #065f46;
	border-color: #a7f3d0;
}

.walkr-form-message-error {
	background: #fef2f2;
	color: #991b1b;
	border-color: #fecaca;
}

/* Form Sections */
.walkr-form-sections {
	padding: 0;
	width: 100%;
}

.walkr-form-section {
	padding: 25px 30px;
	border-bottom: 1px solid var(--walkr-border);
	width: 100%;
}

.walkr-form-section:last-of-type {
	border-bottom: none;
}

.walkr-form-section-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--walkr-text);
	margin: 0 0 8px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--walkr-primary);
	text-align: center;
}

.walkr-form-section-description {
	margin: 0 0 20px;
	color: var(--walkr-text-light);
	font-size: 0.9rem;
}

/* Form Fields */
.walkr-form-field {
	margin-bottom: 20px;
}

.walkr-form-field:last-child {
	margin-bottom: 0;
}

.walkr-form-field label {
	display: block;
	font-weight: 500;
	margin-bottom: 6px;
	color: var(--walkr-text);
}

.walkr-form-field input[type="text"],
.walkr-form-field input[type="email"],
.walkr-form-field input[type="tel"],
.walkr-form-field input[type="number"],
.walkr-form-field input[type="date"],
.walkr-form-field input[type="password"],
.walkr-form-field select,
.walkr-form-field textarea {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--walkr-border-dark);
	border-radius: var(--walkr-radius-sm);
	font-size: 15px;
	color: var(--walkr-text);
	background: var(--walkr-bg);
	transition: border-color 0.15s, box-shadow 0.15s;
}

/* Password field with toggle */
.walkr-password-field {
	position: relative;
	display: flex;
	align-items: center;
}

.walkr-password-field input[type="password"],
.walkr-password-field input[type="text"] {
	padding-right: 44px;
}

.walkr-toggle-password {
	position: absolute;
	right: 8px;
	background: none;
	border: none;
	padding: 4px 8px;
	cursor: pointer;
	color: var(--walkr-text-muted);
	transition: color 0.15s;
}

.walkr-toggle-password:hover {
	color: var(--walkr-primary);
}

.walkr-toggle-password .dashicons {
	font-size: 18px;
	width: 18px;
	height: 18px;
}

.walkr-encrypted-note {
	display: block;
	margin-top: 4px;
	font-size: 0.8rem;
	color: var(--walkr-text-muted);
	font-style: italic;
}

.walkr-encrypted-note::before {
	content: "🔒 ";
}

.walkr-form-field input:focus,
.walkr-form-field select:focus,
.walkr-form-field textarea:focus {
	outline: none;
	border-color: var(--walkr-primary);
	box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
}

.walkr-form-field textarea {
	resize: vertical;
	min-height: 80px;
}

.walkr-form-field select {
	cursor: pointer;
}

/* Required field indicator */
.walkr-required {
	color: var(--walkr-danger);
	font-weight: bold;
}

/* Shared field indicator */
.walkr-shared-indicator {
	margin-left: 5px;
	font-size: 0.9em;
	cursor: help;
	opacity: 0.7;
}

.walkr-shared-indicator:hover {
	opacity: 1;
}

.walkr-shared-field label {
	position: relative;
}

.walkr-shared-field input,
.walkr-shared-field select,
.walkr-shared-field textarea {
	border-color: var(--walkr-primary-light, #93c5fd);
}

.walkr-shared-field input:focus,
.walkr-shared-field select:focus,
.walkr-shared-field textarea:focus {
	border-color: var(--walkr-primary);
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Field error state */
.walkr-form-field-error input,
.walkr-form-field-error select,
.walkr-form-field-error textarea {
	border-color: var(--walkr-danger);
}

.walkr-form-field-error input:focus,
.walkr-form-field-error select:focus,
.walkr-form-field-error textarea:focus {
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.walkr-field-error {
	display: block;
	margin-top: 5px;
	font-size: 0.85rem;
	color: var(--walkr-danger);
}

.walkr-field-help {
	margin: 5px 0 0;
	font-size: 0.85rem;
	color: var(--walkr-text-muted);
}

/* Radio Buttons */
.walkr-radio-group {
	border: none;
	padding: 0;
	margin: 0;
}

.walkr-radio-group legend {
	font-weight: 500;
	margin-bottom: 10px;
	color: var(--walkr-text);
	padding: 0;
}

.walkr-radio-options {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
}

.walkr-radio-option {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-weight: normal;
	margin: 0;
}

.walkr-radio-option input[type="radio"] {
	width: 18px;
	height: 18px;
	margin: 0;
	cursor: pointer;
	accent-color: var(--walkr-primary);
}

.walkr-radio-option span {
	color: var(--walkr-text);
}

/* Checkboxes (Agreement/Consent) */
.walkr-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	cursor: pointer;
	font-weight: normal;
	margin: 0;
	padding: 15px;
	background: var(--walkr-bg-light);
	border: 1px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	transition: background-color 0.15s;
}

.walkr-checkbox-label:hover {
	background: var(--walkr-bg-dark);
}

.walkr-checkbox-label input[type="checkbox"] {
	width: 20px;
	height: 20px;
	margin: 2px 0 0;
	flex-shrink: 0;
	cursor: pointer;
	accent-color: var(--walkr-primary);
}

.walkr-checkbox-text {
	color: var(--walkr-text);
	font-size: 0.9rem;
	line-height: 1.5;
}

.walkr-form-field-checkbox {
	margin-bottom: 12px;
}

/* Agreement text display (no checkbox) */
.walkr-agreement-text {
	padding: 12px 16px;
	background: #fef3c7;
	border-left: 3px solid #f59e0b;
	border-radius: 4px;
	margin-bottom: 12px;
}

.walkr-agreement-text p {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.6;
	color: #78350f;
}

.walkr-form-field-agreement_text {
	margin-bottom: 12px;
}

/* Agreement section styling */
.walkr-form-section[data-section-id="agreement"] {
	background: #fffbeb;
}

.walkr-form-section[data-section-id="agreement"] .walkr-form-section-title {
	color: #92400e;
	border-bottom-color: #f59e0b;
}

/* Signature Section */
.walkr-form-signature {
	background: var(--walkr-bg-light);
}

.walkr-form-signature .walkr-form-section-title {
	border-bottom-color: var(--walkr-success);
}

.walkr-signature-date {
	margin: 0;
	color: var(--walkr-text-light);
}

/* Form Footer */
.walkr-form-footer {
	display: flex;
	gap: 12px;
	justify-content: flex-end;
	padding: 20px 30px;
	background: var(--walkr-bg-light);
	border-top: 1px solid var(--walkr-border);
}

.walkr-form-footer .walkr-button {
	min-width: 120px;
}

/* Conditional Fields */
.walkr-conditional-field {
	margin-left: 30px;
	padding-left: 15px;
	border-left: 3px solid var(--walkr-border-dark);
}

/* Responsive Modal - Mobile Full Screen (No Margins) */
@media (max-width: 767px) {
	.walkr-modal-content,
	.walkr-booking-wizard {
		position: absolute !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		min-width: 100% !important;
		min-height: 100% !important;
		border-radius: 0 !important;
		border: none !important;
		margin: 0 !important;
		padding: 0 !important;
		box-shadow: none !important;
	}

	.walkr-form-modal-content {
		position: absolute !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		width: 100% !important;
		height: 100% !important;
		max-height: none !important;
		border-radius: 0 !important;
	}

	.walkr-form-section {
		padding: 20px 15px;
	}

	.walkr-form-footer {
		padding: 15px;
		flex-direction: column;
	}

	.walkr-form-footer .walkr-button {
		width: 100%;
	}

	.walkr-radio-options {
		flex-direction: column;
		gap: 10px;
	}

	.walkr-conditional-field {
		margin-left: 15px;
		padding-left: 10px;
	}

	.walkr-time-row {
		grid-template-columns: 1fr;
	}

	.walkr-form-item {
		flex-direction: column;
		align-items: flex-start;
	}

	.walkr-form-actions {
		width: 100%;
	}

	.walkr-form-actions .walkr-button {
		flex: 1;
	}
}

/* ============================================
   ENHANCED BOOKING CALENDAR & WIZARD
   ============================================ */

/* Selection Mode Switcher */
.walkr-selection-mode {
	display: flex;
	justify-content: center;
	gap: 8px;
	padding: clamp(10px, 2vw, 15px) clamp(10px, 3vw, 20px);
	background: var(--walkr-bg-light);
	border-bottom: 2px solid var(--walkr-border);
	flex-wrap: wrap;
}

.walkr-mode-btn {
	padding: clamp(8px, 2vw, 10px) clamp(12px, 3vw, 20px);
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	cursor: pointer;
	transition: all 0.15s;
	font-size: var(--walkr-text-sm);
	font-weight: 500;
	color: var(--walkr-text);
	min-height: 44px; /* Touch target */
	flex: 1;
	text-align: center;
	max-width: 200px;
}

@media (min-width: 480px) {
	.walkr-mode-btn {
		flex: 0 1 auto;
	}
}

.walkr-mode-btn:hover {
	border-color: var(--walkr-secondary);
	background: var(--walkr-bg-light);
}

.walkr-mode-btn.active {
	border-color: var(--walkr-primary);
	background: var(--walkr-primary);
	color: #fff;
	border-bottom-width: 4px;
	font-weight: 600;
}

.walkr-mode-option {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	cursor: pointer;
	transition: all 0.15s;
	font-size: var(--walkr-text-sm);
}

.walkr-mode-option:hover {
	border-color: var(--walkr-secondary);
}

.walkr-mode-option input[type="radio"] {
	width: auto;
	margin: 0;
}

.walkr-mode-option input[type="radio"]:checked + span {
	color: var(--walkr-primary);
	font-weight: 600;
}

/* Selection Summary Bar */
.walkr-selection-summary {
	display: flex;
	flex-direction: column;
	gap: 15px;
	padding: clamp(15px, 3vw, 20px);
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
}

.walkr-selection-info {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	font-size: var(--walkr-text-base);
	color: var(--walkr-text);
}

.walkr-selection-info strong {
	color: var(--walkr-text-light);
	font-weight: 500;
}

#walkr-selected-count {
	font-weight: 700;
	color: var(--walkr-primary);
	font-size: var(--walkr-text-xl);
}

.walkr-clear-selection {
	background: none;
	border: none;
	color: var(--walkr-text-muted);
	cursor: pointer;
	font-size: 0.85rem;
	padding: 4px 8px;
	text-decoration: underline;
	transition: color 0.2s;
}

.walkr-clear-selection:hover {
	color: var(--walkr-danger);
	background: none;
}

.walkr-continue-booking {
	width: 100%;
	justify-content: center;
	padding: 12px;
	font-size: 1rem;
}

/* Range Start Indicator */
.walkr-calendar-day-range-start {
	background: var(--walkr-secondary) !important;
	color: #fff !important;
	animation: pulse 1s ease-in-out infinite;
}

@keyframes pulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.05); }
}

/* Calendar Bottom Spacing */
.walkr-calendar-container {
	margin-bottom: clamp(20px, 4vw, 40px);
}

.walkr-calendar-hint {
	margin: clamp(15px, 3vw, 20px) 0 clamp(20px, 4vw, 30px) !important;
	padding: clamp(12px, 3vw, 16px);
	background: linear-gradient(135deg, var(--walkr-info-bg, #DBEAFE) 0%, #fff 100%);
	border: 2px solid var(--walkr-info, #3B82F6);
	border-radius: var(--walkr-radius-sm);
	font-size: var(--walkr-text-base);
	color: var(--walkr-text);
	line-height: 1.5;
	text-align: center;
}

/* ============================================
   BOOKING WIZARD MODAL
   ============================================ */

.walkr-booking-wizard {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	width: 100% !important;
	height: auto !important;
	min-height: 100dvh !important;
	max-width: none !important;
	max-height: none !important;
	min-width: 100% !important;
	box-sizing: border-box !important;
	border-radius: 0 !important;
	border: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

@media (min-width: 768px) {
	.walkr-booking-wizard {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		bottom: auto !important;
		max-width: 700px !important;
		width: 100% !important;
		min-width: auto !important;
		height: auto !important;
		min-height: auto !important;
		max-height: 90vh !important;
		border-radius: var(--walkr-radius) !important;
		border: 2px solid var(--walkr-secondary) !important;
		margin: auto !important;
	}
}

.walkr-wizard-progress {
	flex-shrink: 0;
	display: flex;
	justify-content: center; /* Center the steps */
	align-items: center;
	padding: 12px 16px;
	background: var(--walkr-bg-light);
	border-bottom: 1px solid var(--walkr-border);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	width: 100%;
	box-sizing: border-box;
	gap: 0; /* Steps handle their own spacing */
}

@media (min-width: 768px) {
	.walkr-wizard-progress {
		padding: 15px 25px;
		border-bottom: 2px solid var(--walkr-border);
	}
}

.walkr-wizard-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	flex: 1;
	min-width: 60px;
	position: relative;
}

@media (min-width: 768px) {
	.walkr-wizard-step {
		gap: 6px;
	}
}

/* Progress line connecting steps */
.walkr-wizard-step::after {
	content: '';
	position: absolute;
	top: 14px; /* Half of step-number height (28px/2 = 14px) */
	left: calc(50% + 16px); /* Half of step-number width + small gap */
	width: calc(100% - 32px); /* Full width minus step-number width */
	height: 2px;
	background: var(--walkr-border);
	z-index: 0;
}

@media (min-width: 768px) {
	.walkr-wizard-step::after {
		top: 18px; /* Half of larger step-number (36px/2 = 18px) */
		left: calc(50% + 20px);
		width: calc(100% - 40px);
		height: 3px;
	}
}

.walkr-wizard-step:last-child::after {
	display: none;
}

/* Completed step line color */
.walkr-wizard-step.completed::after {
	background: var(--walkr-success, #10b981);
}

.walkr-wizard-step .step-number {
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: 50%;
	font-weight: bold;
	font-size: 12px;
	color: var(--walkr-text-light);
	z-index: 1;
	transition: all 0.2s;
}

@media (min-width: 768px) {
	.walkr-wizard-step .step-number {
		width: 36px;
		height: 36px;
		border-width: 3px;
		font-size: var(--walkr-text-sm);
	}
}

.walkr-wizard-step .step-label {
	font-size: var(--walkr-text-xs);
	color: var(--walkr-text-light);
	font-weight: 500;
	text-align: center;
	word-wrap: break-word;
	max-width: 70px;
}

@media (min-width: 480px) {
	.walkr-wizard-step .step-label {
		font-size: var(--walkr-text-sm);
		max-width: none;
	}
}

.walkr-wizard-step.active .step-number {
	border-color: var(--walkr-primary);
	background: var(--walkr-primary);
	color: #fff;
	transform: none;
	box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.3);
}

.walkr-wizard-step.active .step-label {
	color: var(--walkr-primary);
	font-weight: 700;
}

.walkr-wizard-step.completed .step-number {
	border-color: var(--walkr-success, #10b981);
	background: var(--walkr-success, #10b981);
	color: #fff;
}

.walkr-wizard-step.completed .step-number::after {
	content: '✓';
}

.walkr-wizard-step.completed .step-label {
	color: var(--walkr-success, #10b981);
	font-weight: 600;
}

.walkr-wizard-step:not(.active):not(.completed) .step-number {
	background: #f1f5f9;
	border-color: #cbd5e1;
	color: #94a3b8;
}

.walkr-wizard-step:not(.active):not(.completed) .step-label {
	color: #94a3b8;
}

.walkr-wizard-panel {
	padding: 20px 16px; /* More vertical padding */
	width: 100%;
	box-sizing: border-box;
}

@media (min-width: 768px) {
	.walkr-wizard-panel {
		padding: 25px;
	}
}

.walkr-wizard-panel h4 {
	margin: 0 0 8px;
	font-size: var(--walkr-text-xl);
	color: var(--walkr-text);
}

/* Panel Header with Intro Text */
.walkr-panel-header {
	margin-bottom: 20px; /* More space after header */
	padding-bottom: 15px;
	border-bottom: 2px dashed var(--walkr-border);
}

@media (min-width: 480px) {
	.walkr-panel-header {
		margin-bottom: 15px;
		padding-bottom: 12px;
	}
}

.walkr-panel-intro {
	font-size: var(--walkr-text-base);
	color: var(--walkr-text-light);
	margin: 10px 0 0;
	line-height: 1.5;
}

/* Hint Boxes - Visual Prompts */
.walkr-hint-box {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 8px;
	margin-top: 12px;
	border: 2px solid;
}

.walkr-hint-box p {
	margin: 0;
	font-size: var(--walkr-text-sm);
	line-height: 1.4;
	color: var(--walkr-text);
}

.walkr-hint-box strong {
	color: inherit;
}

.walkr-hint-info {
	background: var(--walkr-info-bg, #DBEAFE);
	border-color: var(--walkr-info, #3B82F6);
}

.walkr-hint-success {
	background: var(--walkr-success-bg, #D1FAE5);
	border-color: var(--walkr-success, #10B981);
}

.walkr-hint-scroll {
	background: var(--walkr-warning-bg, #FEF3C7);
	border-color: var(--walkr-warning, #F59E0B);
	animation: walkr-pulse 2s ease-in-out infinite;
}

@keyframes walkr-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.7; }
}

/* Fieldset Styling */
.walkr-fieldset {
	border: none;
	padding: 0;
	margin: 0 0 20px;
}

.walkr-fieldset-legend {
	font-size: var(--walkr-text-base);
	font-weight: 600;
	color: var(--walkr-text);
	margin-bottom: 12px;
	display: block;
}

/* Optional Label */
.walkr-label-optional {
	font-weight: 400;
	color: var(--walkr-text-muted);
	font-size: 0.85em;
}

/* Recurring Inputs */
.walkr-recurring-inputs {
	display: flex;
	gap: 10px;
}

.walkr-recurring-inputs input[type="number"] {
	width: 80px;
	flex-shrink: 0;
}

.walkr-recurring-inputs select {
	flex: 1;
	min-width: 0;
}

.walkr-hint {
	font-size: var(--walkr-text-sm);
	color: var(--walkr-text-light);
	margin-top: 15px;
}

.walkr-subtext {
	font-size: var(--walkr-text-base);
	color: var(--walkr-text-light);
	margin-bottom: 20px;
}

/* Date Summary */
.walkr-dates-summary {
	background: var(--walkr-bg-light);
	padding: 20px;
	border-radius: var(--walkr-radius);
}

.walkr-date-ranges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 10px;
}

.walkr-date-chip {
	background: #fff;
	padding: 8px 14px;
	border-radius: var(--walkr-radius);
	border: 2px solid var(--walkr-border);
	font-size: 0.9rem;
}

.walkr-date-chip.walkr-date-range {
	background: var(--walkr-secondary-light, #dbeafe);
	border-color: var(--walkr-secondary);
}

.walkr-date-count {
	font-size: 0.9rem;
	color: var(--walkr-text-light);
	margin: 10px 0 0;
}

/* ==========================================================================
   Service Cards (Refactored Mobile-First)
   ========================================================================== */

.walkr-service-cards {
	display: grid;
	/* Flexible grid: Min 140px per card, fills available space */
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 15px;
}

.walkr-service-card {
	cursor: pointer;
	position: relative;
	-webkit-tap-highlight-color: transparent;
}

.walkr-service-card input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.walkr-service-card-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 15px; /* Mobile: Standard padding */
	min-height: 100px; /* Ensure substantial target area */
	background: #fff;
	border: 3px solid var(--walkr-border);
	border-radius: var(--walkr-radius);
	transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
	text-align: center;
	height: 100%; /* Equal height cards */
}

@media (min-width: 600px) {
	.walkr-service-card-content {
		padding: 20px 15px;
	}
}

/* Hover effects wrapped to prevent sticky hover on touch devices */
@media (hover: hover) {
	.walkr-service-card:hover .walkr-service-card-content {
		border-color: var(--walkr-secondary);
		transform: translateY(-2px);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	}
}

.walkr-service-card:active .walkr-service-card-content {
	transform: scale(0.98); /* Tactile feedback */
}

.walkr-service-card input:checked + .walkr-service-card-content {
	border-color: var(--walkr-primary);
	background: var(--walkr-primary-light, #fce7f3);
	box-shadow: 0 4px 12px rgba(236, 72, 153, 0.2);
}

.walkr-service-icon {
	font-size: 2rem;
}

.walkr-service-card strong {
	font-size: 1rem;
	color: var(--walkr-text);
	line-height: 1.3;
}

.walkr-service-card small {
	font-size: 0.8rem;
	color: var(--walkr-text-light);
}

/* Service Time Slots */
.walkr-service-times {
	margin-top: 25px;
	padding-top: 20px;
	border-top: 2px solid var(--walkr-border);
}

.walkr-service-times h5 {
	margin: 0 0 15px;
	font-size: 1rem;
	color: var(--walkr-text);
}

.walkr-service-time-row {
	display: flex;
	align-items: center;
	gap: 15px;
	padding: 12px 0;
	border-bottom: 1px solid var(--walkr-border);
}

.walkr-service-time-row:last-child {
	border-bottom: none;
}

.walkr-service-time-label {
	flex: 0 0 100px;
	font-weight: 500;
}

.walkr-service-time-inputs {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.walkr-time-slot-select {
	width: 100%;
	padding: 10px 12px;
	font-size: 0.95rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
	cursor: pointer;
}

.walkr-custom-time {
	display: flex;
	align-items: center;
	gap: 10px;
}

.walkr-custom-time input[type="time"] {
	flex: 1;
	padding: 8px 10px;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
}

.walkr-custom-time span {
	color: var(--walkr-text-light);
}

/* Booking Summary */
.walkr-booking-summary {
	background: var(--walkr-bg-light);
	padding: 20px;
	border-radius: var(--walkr-radius);
}

.walkr-summary-section {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.walkr-summary-item {
	font-size: 0.95rem;
	line-height: 1.5;
}

.walkr-summary-item strong {
	color: var(--walkr-text);
}

.walkr-summary-item ul {
	margin: 5px 0 0 20px;
	padding: 0;
}

.walkr-summary-item li {
	margin-bottom: 4px;
}

/* Invoice Section */
.walkr-invoice-section {
	margin-top: 25px;
	padding-top: 20px;
	border-top: 2px solid var(--walkr-border);
}

.walkr-invoice-section h4 {
	margin: 0 0 15px 0;
	font-size: 1.1rem;
	color: var(--walkr-text);
	display: flex;
	align-items: center;
	gap: 8px;
}

.walkr-invoice-section h4 i {
	color: var(--walkr-primary);
}

.walkr-invoice-table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	border-radius: 0;
	overflow: hidden;
	box-shadow: none;
	border: 1px solid var(--walkr-border);
}

.walkr-invoice-table th,
.walkr-invoice-table td {
	padding: 8px 6px;
	text-align: left;
	border-bottom: 1px solid var(--walkr-border);
	font-size: clamp(0.7rem, 2.5vw, 0.85rem);
	word-break: break-word;
}

@media (min-width: 480px) {
	.walkr-invoice-table th,
	.walkr-invoice-table td {
		padding: 10px 12px;
	}
}

.walkr-invoice-table th {
	background: var(--walkr-bg-light);
	font-weight: 600;
	color: var(--walkr-text);
	font-size: clamp(0.65rem, 2vw, 0.8rem);
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.walkr-invoice-table th:last-child,
.walkr-invoice-table td:last-child {
	text-align: right;
}

.walkr-invoice-table th:nth-child(2),
.walkr-invoice-table td:nth-child(2),
.walkr-invoice-table th:nth-child(3),
.walkr-invoice-table td:nth-child(3) {
	text-align: center;
}

.walkr-invoice-table tbody tr:hover {
	background: var(--walkr-bg-light);
}

.walkr-invoice-table tbody td {
	font-size: 0.95rem;
}

.walkr-invoice-table tfoot {
	background: var(--walkr-primary);
	color: #fff;
}

.walkr-invoice-table tfoot td {
	border-bottom: none;
	font-size: 1.05rem;
}

.walkr-invoice-total td {
	padding: 15px;
}

.walkr-invoice-note {
	margin: 12px 0 0 0;
	font-size: 0.85rem;
	color: var(--walkr-text-light);
}

/* Billing Option Selector */
.walkr-billing-option {
	margin: 15px 0;
	padding: 15px;
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius);
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.walkr-billing-option label {
	margin: 0;
	font-weight: 600;
}

.walkr-billing-select {
	flex: 1;
	min-width: 200px;
	max-width: 300px;
}

/* Dropdown Fix - Ensure text is not cut off */
select,
.walkr-form-group select,
.walkr-form-row select,
.walkr-time-slot-select {
	height: auto;
	min-height: 44px;
	padding: 10px 30px 10px 12px;
	line-height: 1.4;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
	background-position: right 10px center;
	background-repeat: no-repeat;
	background-size: 20px;
	overflow: visible;
}

select option,
.walkr-form-group select option,
.walkr-form-row select option {
	padding: 10px;
	line-height: 1.5;
}

/* Mobile Responsive for Wizard */
@media (max-width: 600px) {
	.walkr-selection-mode {
		gap: 8px;
	}
	
	.walkr-mode-option {
		padding: 6px 12px;
		font-size: 0.85rem;
	}
	
	.walkr-selection-summary {
		flex-direction: column;
		align-items: stretch;
	}
	
	.walkr-selection-info {
		justify-content: center;
	}
	
	.walkr-wizard-progress {
		padding: 15px 10px;
	}
	
	.walkr-wizard-step .step-label {
		font-size: 0.7rem;
	}
	
	.walkr-service-cards {
		grid-template-columns: 1fr;
	}
	
	.walkr-service-time-row {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.walkr-service-time-label {
		margin-bottom: 8px;
	}
	
	.walkr-custom-time {
		flex-direction: column;
		width: 100%;
	}
	
	.walkr-custom-time input[type="time"] {
		width: 100%;
	}
}
/* ============================================
   DESKTOP SIDE-BY-SIDE LAYOUT
   ============================================ */

.walkr-calendar-layout {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	align-items: flex-start;
	justify-content: center;
}

.walkr-calendar-left {
	flex: 0 1 auto;
	width: 100%;
	max-width: 750px;
	min-width: 320px;
}

.walkr-calendar-right {
	flex: 0 0 300px;
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: sticky;
	top: 20px;
}

/* Common Card Style for Side Bubbles */
.walkr-calendar-right .walkr-calendar-legend,
.walkr-calendar-right .walkr-selection-summary {
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	padding: 20px;
	box-shadow: 4px 4px 0 rgba(0,0,0,0.05);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.walkr-calendar-right .walkr-calendar-legend:hover,
.walkr-calendar-right .walkr-selection-summary:hover {
	transform: translateY(-2px);
	box-shadow: 6px 6px 0 rgba(0,0,0,0.05);
	border-color: var(--walkr-secondary);
}

/* Specific overrides */

.walkr-calendar-right .walkr-selection-summary {
	margin: 0;
	border-color: var(--walkr-primary); /* Highlight booking box */
}

.walkr-calendar-right .walkr-calendar-hint {
	text-align: center;
	margin: 5px 0 0;
	font-size: 0.85rem;
	color: var(--walkr-text-muted);
	font-style: italic;
}

.walkr-calendar-right .walkr-continue-booking {
	width: 100%;
	margin-top: 15px;

}

/* Mobile: Stack vertically */
@media (max-width: 850px) {
	.walkr-calendar-layout {
		flex-direction: column;
	}
	
	.walkr-calendar-left,
	.walkr-calendar-right {
		flex: 1 1 100%;
		width: 100%;
	}
	
	.walkr-calendar-right {
		position: static;
		flex-direction: column;
	}
}

/* ============================================
   SERVICE CONFIGURATION (Per-Day Assignment)
   ============================================ */

.walkr-service-config {
	margin-top: clamp(20px, 4vw, 25px);
	padding-top: clamp(15px, 3vw, 20px);
	border-top: 2px solid var(--walkr-border);
}

.walkr-service-config h5 {
	margin: 0 0 8px;
	font-size: var(--walkr-text-lg);
	color: var(--walkr-text);
}

.walkr-config-intro {
	margin: 0 0 clamp(15px, 3vw, 20px);
	font-size: var(--walkr-text-sm);
	color: var(--walkr-text-light);
}

.walkr-service-config-item {
	background: var(--walkr-bg-light);
	border-radius: var(--walkr-radius);
	padding: clamp(15px, 3vw, 20px);
	margin-bottom: 15px;
	border: 2px solid var(--walkr-border);
}

.walkr-service-config-item:last-child {
	margin-bottom: 0;
}

.walkr-service-config-header {
	margin-bottom: 15px;
}

.walkr-service-name {
	font-size: var(--walkr-text-lg);
	font-weight: 600;
	color: var(--walkr-primary);
}

/* Time Configuration Styles */
.walkr-times-per-day {
	width: 100%;
	max-width: 200px;
	padding: 12px 14px;
	font-size: 16px; /* Prevent iOS zoom */
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
	min-height: 44px;
}

.walkr-same-time-check {
	width: 20px;
	height: 20px;
}

.walkr-unified-times {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	margin-top: 10px;
}

.walkr-time-input-row {
	display: flex;
	flex-direction: column;
	gap: 5px;
	align-items: flex-start;
}

.walkr-slot-checkbox {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	padding: 5px 0;
}

.walkr-slot-checkbox input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--walkr-primary);
}

.walkr-time-input-row label {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--walkr-text-light);
}

.walkr-service-time {
	width: 130px;
	padding: 10px 12px;
	font-size: 0.95rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
}

.walkr-service-slot {
	min-width: 160px;
	padding: 10px 12px;
	font-size: 0.95rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
}

.walkr-per-day-times {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 10px;
}

.walkr-day-time-row {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 12px;
	background: #fff;
	border-radius: var(--walkr-radius-sm);
	border: 1px solid var(--walkr-border);
}

.walkr-day-label {
	font-size: 0.9rem;
	font-weight: 600;
	min-width: 80px;
	color: var(--walkr-text);
}

.walkr-day-times {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.walkr-day-times input[type="time"] {
	width: 100px;
	padding: 6px 8px;
	font-size: 0.85rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
}

.walkr-day-times select {
	min-width: 100px;
	padding: 6px 8px;
	font-size: 0.85rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
}

/* Summary Day Times */
.walkr-summary-day-times {
	font-size: 0.8rem;
	color: var(--walkr-text-light);
	margin-top: 5px;
	padding-left: 10px;
	border-left: 2px solid var(--walkr-secondary);
}

.walkr-summary-day-times div {
	padding: 2px 0;
}

.walkr-day-selection {
	margin-top: 15px;
	padding-top: 15px;
	border-top: 1px solid var(--walkr-border);
}

.walkr-day-selection > label {
	display: block;
	margin-bottom: 10px;
	font-weight: 500;
	font-size: 0.9rem;
}

.walkr-day-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.walkr-day-chip {
	cursor: pointer;
}

.walkr-day-chip input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}

.walkr-day-chip span {
	display: inline-block;
	padding: 6px 12px;
	background: #fff;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	font-size: 0.85rem;
	transition: all 0.15s;
}

.walkr-day-chip:hover span {
	border-color: var(--walkr-secondary);
}

.walkr-day-chip input:checked + span {
	background: var(--walkr-primary);
	border-color: var(--walkr-primary);
	color: #fff;
}

.walkr-walk-time {
	width: 150px;
	padding: 10px 12px;
	font-size: 0.95rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	background: #fff;
}

.walkr-field-hint {
	margin: 8px 0 0;
	font-size: 0.85rem;
	color: var(--walkr-text-light);
	font-style: italic;
}

/* Summary Service Items */
.walkr-summary-service {
	margin: 10px 0;
	padding: 10px 15px;
	background: #fff;
	border-radius: var(--walkr-radius-sm);
	border-left: 4px solid var(--walkr-primary);
}

.walkr-summary-service-name {
	display: block;
	font-weight: 600;
	color: var(--walkr-text);
	margin-bottom: 4px;
}

.walkr-summary-days {
	display: block;
	font-size: 0.85rem;
	color: var(--walkr-text-light);
}

.walkr-subtext {
	color: var(--walkr-text-light);
	font-size: 0.9rem;
	margin: 0 0 15px;
}

.walkr-hint {
	color: var(--walkr-text-light);
	font-size: 0.9rem;
	font-style: italic;
	margin-top: 10px;
}

@media (max-width: 600px) {
	.walkr-mode-btn {
		flex: 1;
		text-align: center;
		padding: 8px 12px;
		font-size: 0.85rem;
	}
	
	.walkr-service-time,
	.walkr-service-slot {
		width: 100%;
	}
	
	.walkr-unified-times {
		flex-direction: column;
	}
	
	.walkr-day-time-row {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.walkr-day-label {
		margin-bottom: 5px;
	}
	
	.walkr-day-times {
		width: 100%;
	}
	
	.walkr-day-times input[type="time"] {
		width: 100%;
	}
	
	.walkr-day-times select {
		width: 100%;
	}
}

/* ==========================================================================
   New Component Styles (Feeding, Pet Sitting, Scrollbar)
   ========================================================================== */

/* Pet Sitting Range Card */
.walkr-ps-range-card {
    background: #fff;
    border: 2px solid var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    padding: 15px;
    margin-bottom: 10px;
}

.walkr-ps-range-card .walkr-range-header {
    margin-bottom: 10px;
    color: var(--walkr-primary);
    font-size: 0.95rem;
}

/* Feeding Slot with Toggle */
.walkr-feeding-slot {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--walkr-bg-light);
    padding: 4px 8px;
    border-radius: var(--walkr-radius-sm);
    border: 1px solid var(--walkr-border);
}

.walkr-feeding-slot input[type="time"] {
    width: 90px !important;
    height: 32px;
    padding: 0 5px !important;
}

.walkr-feeding-slot input[type="time"]:disabled {
    background: #f1f5f9;
    color: #cbd5e1;
    border-color: #e2e8f0;
}

.walkr-slot-mini {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    user-select: none;
}

.walkr-slot-mini input[type="checkbox"] {
    width: 14px;
    height: 14px;
    accent-color: var(--walkr-primary);
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 5px;
}

::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 5px;
    border: 2px solid #f1f5f9;
}

::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}
}

/* ==========================================================================
   Inline Forms in Booking Wizard
   ========================================================================== */

.walkr-wizard-forms-panel {
    padding: 20px 0;
    display: flex;
    flex-direction: column;
    max-height: calc(80vh - 200px);
    overflow: hidden;
}

.walkr-inline-forms-header {
    flex-shrink: 0;
}

.walkr-inline-forms-header h4 {
    font-size: 1.25rem;
    margin: 0 0 8px 0;
    color: var(--walkr-text);
}

.walkr-inline-forms-header .walkr-subtext {
    margin: 0 0 20px 0;
    color: var(--walkr-text-light);
    font-size: 0.95rem;
}

.walkr-inline-forms-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.walkr-inline-form-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: var(--walkr-bg-light);
    border: 2px solid var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    transition: all 0.2s ease;
}

.walkr-inline-form-item.completed {
    background: #d1fae5;
    border-color: #10b981;
}

.walkr-inline-form-item.pending {
    background: #fef3c7;
    border-color: #f59e0b;
}

.walkr-inline-form-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.walkr-inline-form-status {
    font-size: 1.25rem;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}

.walkr-inline-form-item.completed .walkr-inline-form-status {
    background: #10b981;
    color: white;
}

.walkr-inline-form-item.pending .walkr-inline-form-status {
    background: #f59e0b;
    color: white;
}

.walkr-inline-form-label {
    font-weight: 600;
    font-size: 1rem;
    color: var(--walkr-text);
}

.walkr-inline-forms-complete {
    margin-top: 20px;
    padding: 20px;
    background: #d1fae5;
    border: 2px solid #10b981;
    border-radius: var(--walkr-radius-sm);
    text-align: center;
}

.walkr-inline-forms-complete .walkr-success-message {
    color: #065f46;
    font-weight: 600;
    font-size: 1.1rem;
    margin: 0 0 15px 0;
}

.walkr-inline-form-container {
    padding: 20px 0;
}

.walkr-inline-form-container .walkr-form-loading {
    text-align: center;
    padding: 40px;
    color: var(--walkr-text-muted);
}

.walkr-inline-form-container .walkr-form-sections {
    max-height: 50vh;
    overflow-y: auto;
    padding-right: 10px;
}

.walkr-inline-form-container .walkr-form-footer {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 2px solid var(--walkr-border);
}

/* Inline form content (the actual form element) */
#walkr-inline-form-content {
    display: flex;
    flex-direction: column;
    max-height: calc(80vh - 200px);
    overflow: hidden;
}

#walkr-inline-form-content .walkr-form-sections {
    flex: 1;
    overflow-y: auto;
    padding: 0 10px 20px 0;
    margin-bottom: 10px;
}

#walkr-inline-form-content .walkr-form-footer {
    flex-shrink: 0;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding-top: 15px;
    border-top: 2px solid var(--walkr-border);
    background: #fff;
}

/* Ensure form fields in inline forms use full width */
.walkr-inline-form-container .walkr-form-field {
    max-width: 100%;
    margin-bottom: 16px;
}

.walkr-inline-form-container .walkr-form-field input[type="text"],
.walkr-inline-form-container .walkr-form-field input[type="email"],
.walkr-inline-form-container .walkr-form-field input[type="tel"],
.walkr-inline-form-container .walkr-form-field input[type="number"],
.walkr-inline-form-container .walkr-form-field textarea,
.walkr-inline-form-container .walkr-form-field select {
    width: 100%;
    max-width: 100%;
}

/* ==========================================================================
   Session Restore Prompt
   ========================================================================== */

.walkr-session-restore {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background: white;
    border: 3px solid var(--walkr-primary);
    border-radius: var(--walkr-radius-sm);
    padding: 20px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    z-index: 10001;
    max-width: 320px;
    animation: slideInRight 0.3s ease-out;
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(100%);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.walkr-session-restore p {
    margin: 0 0 15px 0;
    font-weight: 600;
    color: var(--walkr-text);
}

.walkr-session-restore-actions {
    display: flex;
    gap: 10px;
}

.walkr-session-restore-actions button {
    flex: 1;
    padding: 10px 15px;
    border: 2px solid var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.walkr-session-restore-actions .walkr-restore-yes {
    background: var(--walkr-primary);
    color: white;
    border-color: var(--walkr-primary);
}

.walkr-session-restore-actions .walkr-restore-yes:hover {
    background: var(--walkr-primary-hover);
}

.walkr-session-restore-actions .walkr-restore-no {
    background: white;
    color: var(--walkr-text);
}

.walkr-session-restore-actions .walkr-restore-no:hover {
    background: var(--walkr-bg-light);
}

/* ==========================================================================
   Success Animation
   ========================================================================== */

.walkr-success-animation {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 40px;
    text-align: center;
    animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.walkr-success-icon {
    font-size: 80px;
    color: #10b981;
    margin-bottom: 20px;
    animation: bounceIn 0.6s ease-out;
}

@keyframes bounceIn {
    0% { transform: scale(0); opacity: 0; }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); opacity: 1; }
}

.walkr-success-animation h2 {
    color: var(--walkr-text);
    margin: 0 0 10px 0;
    font-size: 1.75rem;
}

.walkr-success-animation p {
    color: var(--walkr-text-light);
    margin: 0 0 30px 0;
    font-size: 1.1rem;
}

/* ==========================================================================
   Time Hint & Validation Messages
   ========================================================================== */

.walkr-time-hint {
    color: var(--walkr-text-muted);
    font-size: 0.85rem;
    margin: 0 0 15px 0;
    padding: 8px 12px;
    background: var(--walkr-bg-light);
    border-radius: var(--walkr-radius-sm);
    border-left: 3px solid var(--walkr-secondary);
}

.walkr-ps-validation-msg {
    color: #dc3545;
    font-size: 0.8rem;
    margin-top: 5px;
    padding: 4px 8px;
    background: #fee2e2;
    border-radius: 4px;
}

/* ==========================================================================
   Pet Sitting Type Selector
   ========================================================================== */

.walkr-petsitting-type {
    margin-bottom: 15px;
}

.walkr-petsitting-type label {
    display: block;
    margin-bottom: 8px;
    color: var(--walkr-text);
}

.walkr-petsitting-type-select {
    width: 100%;
    padding: 10px 12px;
    border: 2px solid var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    font-size: 0.95rem;
    background: white;
    color: var(--walkr-text);
    cursor: pointer;
    transition: border-color 0.2s ease;
}

.walkr-petsitting-type-select:focus {
    border-color: var(--walkr-primary);
    outline: none;
}

.walkr-petsitting-type-select:hover {
    border-color: var(--walkr-primary-hover);
}

/* ==========================================================================
   Confirmation Dialog Styles
   ========================================================================== */

.walkr-confirm-dialog {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10002;
    animation: fadeIn 0.2s ease-out;
}

.walkr-confirm-content {
    background: white;
    border-radius: var(--walkr-radius-sm);
    padding: 30px;
    max-width: 400px;
    width: 90%;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.walkr-confirm-content p {
    font-size: 1.1rem;
    margin: 0 0 25px 0;
    color: var(--walkr-text);
}

.walkr-confirm-actions {
    display: flex;
    gap: 15px;
    justify-content: center;
}

.walkr-confirm-actions button {
    padding: 12px 30px;
    border: 2px solid var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.walkr-confirm-yes {
    background: #dc3545;
    color: white;
    border-color: #dc3545;
}

.walkr-confirm-yes:hover {
    background: #c82333;
}

.walkr-confirm-no {
    background: white;
    color: var(--walkr-text);
}

.walkr-confirm-no:hover {
    background: var(--walkr-bg-light);
}

/* ==========================================================================
   Empty State Styles
   ========================================================================== */

.walkr-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    text-align: center;
    background: var(--walkr-bg-light);
    border: 2px dashed var(--walkr-border);
    border-radius: var(--walkr-radius-sm);
    margin: 20px 0;
}

.walkr-empty-icon {
    font-size: 48px;
    margin-bottom: 15px;
    opacity: 0.8;
}

.walkr-empty-state .walkr-empty {
    margin: 0 0 20px 0;
    color: var(--walkr-text-light);
    font-size: 1.1rem;
}

.walkr-empty-state .walkr-button {
    margin-top: 10px;
}

/* ==========================================================================
   Section Header with View All Link
   ========================================================================== */

.walkr-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    flex-wrap: wrap;
    gap: 10px;
}

.walkr-section-header h3 {
    margin: 0;
    font-size: 1.25rem;
}

.walkr-view-all-link {
    color: var(--walkr-primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    transition: color 0.2s ease;
}

.walkr-view-all-link:hover {
    color: var(--walkr-primary-hover);
    text-decoration: underline;
}

/* ==========================================================================
   Expandable Table Rows
   ========================================================================== */

.walkr-table-expandable .walkr-col-expand {
	width: 40px;
	padding: 10px;
	text-align: center;
}

.walkr-expand-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	background: var(--walkr-secondary-bg);
	border: 2px solid var(--walkr-secondary);
	border-radius: 50%;
	cursor: pointer;
	transition: transform 0.2s ease, background 0.2s ease;
}

.walkr-expand-toggle:hover {
	background: var(--walkr-secondary);
}

.walkr-expand-toggle:hover .walkr-expand-icon {
	color: #fff;
}

.walkr-expand-icon {
	font-size: 10px;
	color: var(--walkr-text);
	transition: transform 0.2s ease, color 0.2s ease;
}

.walkr-expand-toggle[aria-expanded="true"] .walkr-expand-icon {
	transform: rotate(90deg);
}

.walkr-booking-row {
	cursor: pointer;
}

.walkr-booking-row:hover td {
	background-color: var(--walkr-bg-light);
}

.walkr-booking-details {
	background: var(--walkr-bg-light);
}

.walkr-booking-details[hidden] {
	display: none;
}

.walkr-booking-details td {
	padding: 0;
	border-bottom: 2px solid var(--walkr-secondary);
}

.walkr-booking-details-content {
	padding: 20px 30px;
	animation: walkrSlideDown 0.2s ease;
}

@keyframes walkrSlideDown {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.walkr-details-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 15px;
	margin: 0;
}

.walkr-detail-item {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.walkr-detail-item dt {
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--walkr-text-light);
}

.walkr-detail-item dd {
	margin: 0;
	font-size: 1rem;
	color: var(--walkr-text);
}

.walkr-no-details {
	color: var(--walkr-text-muted);
	font-style: italic;
	margin: 0;
}

/* ==========================================================================
   Review & Confirm Modal
   ========================================================================== */

.walkr-review-modal-content {
	max-width: 700px;
	max-height: 90vh;
	overflow-y: auto;
}

.walkr-review-instructions {
	background: var(--walkr-secondary-bg);
	padding: 15px 20px;
	border-radius: var(--walkr-radius-sm);
	margin-bottom: 20px;
	border-left: 4px solid var(--walkr-primary);
}

.walkr-review-instructions p {
	margin: 0 0 8px 0;
}

.walkr-review-instructions p:last-child {
	margin-bottom: 0;
}

.walkr-review-data {
	margin-bottom: 25px;
}

.walkr-review-section {
	margin-bottom: 20px;
	padding-bottom: 15px;
	border-bottom: 1px solid var(--walkr-border);
}

.walkr-review-section:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

.walkr-review-section h4 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--walkr-primary);
	margin: 0 0 12px 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.walkr-review-fields {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 12px;
	margin: 0;
}

.walkr-review-field {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.walkr-review-field dt {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--walkr-text-light);
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.walkr-review-field dd {
	margin: 0;
	font-size: 0.95rem;
	color: var(--walkr-text);
}

.walkr-review-textarea {
	background: var(--walkr-bg-light);
	padding: 8px 12px;
	border-radius: 8px;
	font-size: 0.9rem;
	max-height: 100px;
	overflow-y: auto;
}

.walkr-review-confirm-section {
	background: #fff;
	padding: 20px;
	border-radius: var(--walkr-radius-sm);
	border: 2px solid var(--walkr-primary);
	margin-top: 20px;
}

.walkr-review-confirm-section label {
	display: block;
	font-weight: 700;
	margin-bottom: 10px;
	color: var(--walkr-text);
}

.walkr-review-confirm-section input {
	width: 100%;
	padding: 12px 16px;
	font-size: 1rem;
	border: 2px solid var(--walkr-border);
	border-radius: var(--walkr-radius-sm);
	transition: border-color 0.2s ease;
}

.walkr-review-confirm-section input:focus {
	outline: none;
	border-color: var(--walkr-primary);
}

.walkr-modal-footer {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	padding: 20px;
	border-top: 2px solid var(--walkr-border);
	background: var(--walkr-bg-light);
}

/* ==========================================================================
   Service History & Visit Reports
   ========================================================================== */

.walkr-history-row {
	cursor: pointer;
}

.walkr-history-row:hover td {
	background-color: var(--walkr-bg-light);
}

.walkr-report-complete {
	color: #059669;
	font-weight: 600;
}

.walkr-report-available {
	color: var(--walkr-primary);
	font-weight: 500;
}

.walkr-history-details {
	background: var(--walkr-bg-light);
}

.walkr-history-details[hidden] {
	display: none;
}

.walkr-history-details td {
	padding: 0;
	border-bottom: 2px solid var(--walkr-secondary);
}

.walkr-report-content {
	padding: 20px 30px;
	animation: walkrSlideDown 0.2s ease;
}

.walkr-report-content h4 {
	margin: 0 0 15px 0;
	font-size: 1rem;
	font-weight: 700;
	color: var(--walkr-primary);
}

.walkr-report-details {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.walkr-report-item {
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.walkr-report-item.walkr-report-notes {
	flex-direction: column;
	gap: 5px;
}

.walkr-report-label {
	font-weight: 600;
	color: var(--walkr-text-light);
	min-width: 60px;
}

.walkr-report-value {
	color: var(--walkr-text);
}

.walkr-report-notes p {
	margin: 0;
	background: #fff;
	padding: 10px 15px;
	border-radius: 8px;
	border: 1px solid var(--walkr-border);
}

.walkr-report-simple {
	color: var(--walkr-text-light);
	font-style: italic;
	margin: 0;
}

.walkr-report-photos {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.walkr-photo-gallery {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.walkr-photo-thumb {
	display: block;
	width: 100px;
	height: 100px;
	border-radius: 8px;
	overflow: hidden;
	border: 2px solid var(--walkr-border);
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.walkr-photo-thumb:hover {
	transform: scale(1.05);
	border-color: var(--walkr-primary);
}

.walkr-photo-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ==========================================================================
   Screen Reader Only (Accessibility)
   ========================================================================== */

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
/* ==========================================================================
   Mobile Improvements (Added via Chat)
   ========================================================================== */

/* Mobile Tabs Fix */
@media (max-width: 768px) {
	.walkr-portal {
		padding: 15px;
		height: 100vh; /* Ensure full viewport usage */
		box-sizing: border-box;
	}

	.walkr-portal-nav {
		width: 100%; /* Ensure container is full width */
		overflow-x: auto;
		overflow-y: hidden; /* Remove vertical scroll */
		-webkit-overflow-scrolling: touch;
		margin: 0 -15px 20px -15px; /* Bleed to edges */
		padding: 0 15px; /* Inner padding */
		mask-image: linear-gradient(90deg, rgba(0,0,0,1) 90%, rgba(0,0,0,0) 100%); /* Fade hint */
	}

	.walkr-tabs {
		display: flex; /* Ensure flex for horizontal layout */
		flex-wrap: nowrap !important; /* Prevent wrapping */
		white-space: nowrap; /* Keep text on one line */
		border-bottom: none; /* remove border */
		padding-bottom: 5px; /* Spacing for scrollbar */
		gap: 10px;
		width: max-content; /* Allow container to grow with content */
		scrollbar-width: none;  /* Firefox */
		-ms-overflow-style: none;  /* IE and Edge */
	}
	
	.walkr-tabs::-webkit-scrollbar {
		display: none; /* Hide scrollbar for cleaner look */
	}
	
	.walkr-tab {
		flex: 0 0 auto; /* Don't shrink */
		margin-bottom: 0;
	}

	.walkr-tab a {
		padding: 8px 15px;
		font-size: 0.9rem;
		border-width: 1px;
	}
}

/* Booking Wizard & General Mobile Improvements */
@media (max-width: 600px) {
	.walkr-portal-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 15px;
		margin-bottom: 20px;
		border-bottom-width: 2px;
	}

	.walkr-portal-title {
		font-size: 1.8rem;
		line-height: 1.2;
	}
	
	.walkr-portal-actions {
		width: 100%;
	}
	
	.walkr-portal-actions .walkr-button {
		width: 100%;
		text-align: center;
	}

	.walkr-section-book {
		padding-top: 0;
	}

	/* Walkr Modal / Wizard Mobile Styles */
	.walkr-modal-content {
		width: 95% !important;
		max-height: 90vh !important;
		padding: 20px !important;
	}

	.walkr-wizard-steps {
		margin-bottom: 20px !important;
		gap: 10px !important;
	}
	
	.walkr-wizard-step .step-number {
		width: 25px !important;
		height: 25px !important;
		font-size: 14px !important;
	}
	
	.walkr-wizard-step .step-label {
		font-size: 0.8rem !important;
		display: none; /* Hide labels on very small screens if needed, or keep smaller */
	}
	
	.walkr-wizard-step.active .step-label {
		display: inline-block; /* Show only active label to save space? Or just keep small */
	}

	/* Service Cards Grid on Mobile */
	.walkr-service-cards {
		grid-template-columns: 1fr !important; /* Stack vertically */
		gap: 10px !important;
	}
	
	.walkr-service-card {
		padding: 15px !important;
	}

	/* Confirm Booking Page Scaling */
	.walkr-booking-summary {
		padding: 15px !important;
		background: #f8fafc;
		border-radius: 8px;
	}
	
	.walkr-summary-section {
		margin-bottom: 15px;
		padding-bottom: 15px;
		border-bottom: 1px solid #efefef;
	}
	
	.walkr-summary-item {
		flex-direction: column; /* Stack label and value */
		align-items: flex-start !important;
		gap: 5px;
		margin-bottom: 15px !important;
	}
	
	.walkr-summary-item strong {
		min-width: auto !important;
		color: var(--walkr-text-light);
		font-size: 0.9rem;
	}
	
	.walkr-summary-service {
		background: #fff;
		padding: 10px;
		border: 1px solid #eee;
		border-radius: 6px;
		width: 100%;
		box-sizing: border-box;
		margin-top: 5px;
	}

	.walkr-modal-footer {
		flex-direction: column-reverse; /* Stack buttons, main action on top optionally, or just stack */
		gap: 10px;
	}
	
	.walkr-modal-footer button {
		width: 100%;
		margin: 0 !important;
	}
}

/* ==========================================================================
   Mobile Fixes V2 (Service Grid, Tables, Cards)
   ========================================================================== */

/* 1. Scale Service Buttons to fit without scrolling (2-column layout) */
@media (max-width: 600px) {
	.walkr-service-cards {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important; /* Force 2 columns */
		gap: 10px !important;
	}
	
	.walkr-service-card {
		padding: 10px !important;
		min-height: 80px; /* Consitent height */
		align-items: center;
		text-align: center;
		display: flex; /* Flex to center content */
		flex-direction: column;
		justify-content: center;
	}
	
	.walkr-service-card-content {
		display: flex;
		flex-direction: column;
		align-items: center;
		width: 100%;
	}
	
	.walkr-service-icon {
		font-size: 1.5rem !important;
		margin-bottom: 5px !important;
		margin-right: 0 !important;
	}
	
	.walkr-service-card strong {
		font-size: 0.85rem !important;
		margin-bottom: 2px;
	}
	
	.walkr-service-card small {
		font-size: 0.7rem !important;
		line-height: 1.1;
		opacity: 0.8;
	}
}

/* 2. Fix Confirm Page Table Scaling & Estimated Cost Table */
@media (max-width: 600px) {
	.walkr-invoice-table {
		width: 100%;
		table-layout: fixed; /* Force columns to respect width */
		font-size: 12px !important;
	}
	
	.walkr-invoice-table th, 
	.walkr-invoice-table td {
		padding: 4px 2px !important; /* Tighter padding */
		word-wrap: break-word;
	}
	
	/* Adjust column widths if needed */
	.walkr-invoice-table th:nth-child(1) { width: 40%; } /* Service */
	.walkr-invoice-table th:nth-child(2) { width: 15%; text-align: center; } /* Qty */
	.walkr-invoice-table th:nth-child(3) { width: 20%; text-align: right; } /* Rate */
	.walkr-invoice-table th:nth-child(4) { width: 25%; text-align: right; } /* Amount */
	
	.walkr-invoice-table td:nth-child(2) { text-align: center; }
	.walkr-invoice-table td:nth-child(3) { text-align: right; }
	.walkr-invoice-table td:nth-child(4) { text-align: right; }

	/* Booking Summary Box */
	.walkr-booking-summary {
		padding: 10px !important;
		overflow-x: hidden; /* Prevent horiz scroll on container */
	}
}

/* 3. Fix Booking Wizard Border / Full Screen on Mobile - REMOVED (Now handled by Mobile-First Base Styles) */

/* 4. Fix Tab Buttons Cut Off (Increase container spacing) */
@media (max-width: 768px) {
	.walkr-portal-nav {
		padding-top: 10px;    /* More space on top */
		padding-bottom: 15px; /* More space on bottom */
		margin-bottom: 15px;
	}
	
	.walkr-tabs {
		padding: 5px; /* Inner padding for focus rings/shadows */
	}
}

/* 5. Adjust Card Colors to Stand Out */
.walkr-card {
	/* Add a shadow to lift the card */
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	/* Ensure background is white */
	background-color: #ffffff;
	/* Slightly darken border */
	border-color: #93C5FD; /* A bit darker blue than sky-300 */
}

/* Enhancing the service selection cards as well */
.walkr-service-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	transition: all 0.2s ease;
}

.walkr-service-card input:checked + .walkr-service-card-content,
.walkr-service-card:has(input:checked) { /* Modern browsers */
	background-color: #EFF6FF; /* Blue-50 */
	border-color: #3B82F6; /* Blue-500 */
	box-shadow: 0 0 0 1px #3B82F6;
}
/* Fallback for older browsers if :has not supported */
.walkr-service-card input:checked {
    /* Style wrapper logic is mostly in JS or structure dependant, 
       but standard styling usually relies on parent selection or sibling.
       The existing CSS likely handles this, just enhancing colors. */
}

/* ==========================================================================
   COMPREHENSIVE MOBILE & TABLET STYLES (Added via Chat)
   Complete responsive overhaul for phones and tablets
   ========================================================================== */

/* ---------------------------------------------------------------------
   TABLET STYLES (768px - 1024px)
   --------------------------------------------------------------------- */
@media (min-width: 768px) and (max-width: 1024px) {
	.walkr-portal {
		padding: 25px 30px;
	}
	
	.walkr-portal-title {
		font-size: 2rem;
	}
	
	/* Calendar layout for tablets */
	.walkr-calendar-layout {
		flex-direction: column;
		gap: 20px;
	}
	
	.walkr-calendar-left,
	.walkr-calendar-right {
		width: 100%;
		flex: none;
	}
	
	.walkr-calendar-right {
		flex-direction: row;
		justify-content: space-between;
		gap: 20px;
	}
	
	.walkr-calendar-right > div {
		flex: 1;
		min-width: 0;
	}
	
	/* Cards grid for tablets */
	.walkr-cards {
		grid-template-columns: repeat(2, 1fr);
	}
	
	/* Tables stay readable on tablets */
	.walkr-table th,
	.walkr-table td {
		padding: 14px 18px;
	}
	
	/* Pet cards */
	.walkr-pet-cards {
		grid-template-columns: repeat(2, 1fr);
	}
	
	/* Modal size */
	.walkr-modal-content {
		max-width: 600px;
		width: 90%;
	}
	
	/* Form items */
	.walkr-form-item {
		flex-direction: row;
	}
}

/* ---------------------------------------------------------------------
   MOBILE LANDSCAPE (480px - 768px)
   --------------------------------------------------------------------- */
@media (min-width: 480px) and (max-width: 767px) {
	.walkr-portal {
		padding: 15px 20px;
	}
	
	.walkr-portal-header {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
		gap: 10px;
	}
	
	.walkr-portal-title {
		font-size: 1.6rem;
		flex: 1;
	}
	
	.walkr-portal-actions {
		flex: 0 0 auto;
	}
	
	/* Tabs horizontal scroll */
	.walkr-portal-nav {
		margin: 0 -20px 20px -20px;
		padding: 10px 20px;
	}
	
	/* 2-column grid for cards */
	.walkr-cards {
		grid-template-columns: repeat(2, 1fr);
		gap: 15px;
	}
	
	.walkr-card {
		padding: 20px;
	}
	
	/* Pet cards 2 columns */
	.walkr-pet-cards {
		grid-template-columns: repeat(2, 1fr);
		gap: 15px;
	}
}

/* ---------------------------------------------------------------------
   MOBILE PORTRAIT (up to 480px) - COMPREHENSIVE
   --------------------------------------------------------------------- */
@media (max-width: 480px) {
	/* Base Portal */
	.walkr-portal {
		padding: 12px;
		font-size: 15px;
	}
	
	/* Header */
	.walkr-portal-header {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
		margin-bottom: 15px;
		padding-bottom: 15px;
		border-bottom-width: 2px;
	}
	
	.walkr-portal-title {
		font-size: 1.4rem;
		text-align: center;
	}
	
	.walkr-portal-actions {
		width: 100%;
	}
	
	.walkr-portal-actions .walkr-button {
		width: 100%;
		text-align: center;
		justify-content: center;
	}
	
	/* Navigation Tabs - Improved */
	.walkr-portal-nav {
		margin: 0 -12px 15px -12px;
		padding: 8px 12px 12px;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
	}
	
	.walkr-tabs {
		display: flex;
		flex-wrap: nowrap;
		gap: 8px;
		padding: 3px;
		width: max-content;
	}
	
	.walkr-tab {
		flex: 0 0 auto;
	}
	
	.walkr-tab a {
		padding: 8px 14px;
		font-size: 0.82rem;
		border-width: 1px;
		border-radius: 1.5rem;
		white-space: nowrap;
	}
	
	.walkr-tab.active a {
		border-bottom-width: 3px;
	}
	
	/* Section Headers */
	.walkr-section {
		margin-bottom: 25px;
	}
	
	.walkr-section h2 {
		font-size: 1.1rem;
		margin-bottom: 15px;
	}
	
	.walkr-section h3 {
		font-size: 1rem;
	}
	
	/* Cards - Single Column */
	.walkr-cards {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	
	.walkr-card {
		padding: 18px;
		border-radius: 1.5rem;
	}
	
	.walkr-card h3 {
		font-size: 0.9rem;
		margin-bottom: 12px;
	}
	
	.walkr-stat {
		font-size: 1.6rem;
	}
	
	/* Tables - Responsive */
	.walkr-table {
		border-radius: 1rem;
		font-size: 0.85rem;
	}
	
	.walkr-table th,
	.walkr-table td {
		padding: 10px 8px;
	}
	
	.walkr-table th {
		font-size: 0.75rem;
		letter-spacing: 0.5px;
	}
	
	/* Hide less important columns on mobile */
	.walkr-table .walkr-col-notes,
	.walkr-table th:nth-child(5),
	.walkr-table td:nth-child(5) {
		display: none;
	}
	
	/* Expandable Table Rows */
	.walkr-col-expand {
		width: 30px;
		padding: 8px 4px !important;
	}
	
	.walkr-expand-toggle {
		width: 24px;
		height: 24px;
		font-size: 10px;
	}
	
	.walkr-booking-details-content,
	.walkr-report-content {
		padding: 12px;
	}
	
	.walkr-details-list {
		gap: 10px;
	}
	
	.walkr-detail-item dt {
		font-size: 0.8rem;
		margin-bottom: 2px;
	}
	
	.walkr-detail-item dd {
		font-size: 0.9rem;
	}
	
	/* Pet Cards */
	.walkr-pet-cards {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	
	.walkr-pet-card {
		padding: 15px;
	}
	
	.walkr-pet-photo {
		width: 55px;
		height: 55px;
	}
	
	.walkr-pet-header-info h3 {
		font-size: 1rem;
	}
	
	.walkr-pet-subtitle {
		font-size: 0.82rem;
	}
	
	.walkr-pet-card-details {
		padding-top: 12px;
		margin-top: 12px;
	}
	
	.walkr-pet-detail-row {
		font-size: 0.85rem;
		padding: 6px 0;
	}
	
	/* Forms List */
	.walkr-forms-list {
		gap: 12px;
	}
	
	.walkr-form-item {
		flex-direction: column;
		align-items: stretch;
		gap: 12px;
		padding: 15px;
	}
	
	.walkr-form-info {
		text-align: center;
	}
	
	.walkr-form-info h3 {
		justify-content: center;
	}
	
	.walkr-form-actions {
		width: 100%;
		display: flex;
		flex-direction: column;
		gap: 8px;
	}
	
	.walkr-form-actions .walkr-button {
		width: 100%;
		justify-content: center;
	}
	
	/* Booking Forms Banner */
	.walkr-booking-forms-banner {
		padding: 12px 15px;
	}
	
	.walkr-booking-forms-banner-content {
		flex-direction: column;
		text-align: center;
		gap: 10px;
	}
	
	.walkr-booking-forms-banner-icon {
		font-size: 1.5rem;
	}
	
	/* Empty States */
	.walkr-empty-state {
		padding: 30px 15px;
	}
	
	.walkr-empty-icon {
		font-size: 2.5rem;
	}
	
	.walkr-empty {
		padding: 25px 15px;
		font-size: 0.9rem;
	}
	
	/* Buttons */
	.walkr-button {
		padding: 10px 16px;
		font-size: 0.88rem;
		border-radius: 1.2rem;
	}
	
	.walkr-button-small {
		padding: 6px 12px;
		font-size: 0.8rem;
	}
	
	/* Calendar */
	.walkr-calendar {
		border-radius: 1.2rem;
		margin: 0 -5px;
	}
	
	.walkr-calendar-header {
		padding: 15px;
		flex-wrap: wrap;
		gap: 10px;
	}
	
	.walkr-calendar-title {
		font-size: 1.1rem;
		order: 2;
		width: 100%;
		text-align: center;
	}
	
	.walkr-calendar-nav {
		width: 38px;
		height: 38px;
		font-size: 1.2rem;
	}
	
	.walkr-calendar-nav:first-child {
		order: 1;
	}
	
	.walkr-calendar-nav:last-child {
		order: 3;
		margin-left: auto;
	}
	
	.walkr-calendar-weekdays > div {
		padding: 10px 2px;
		font-size: 0.7rem;
	}
	
	.walkr-calendar-day {
		padding: 8px 3px;
		min-height: 40px;
	}
	
	.walkr-calendar-day span {
		width: 28px;
		height: 28px;
		font-size: 0.8rem;
	}
	
	/* Calendar Layout */
	.walkr-calendar-layout {
		flex-direction: column;
		gap: 15px;
	}
	
	.walkr-calendar-left,
	.walkr-calendar-right {
		width: 100%;
	}
	
	.walkr-calendar-right {
		position: static;
		flex-direction: column;
		gap: 12px;
	}
	
	.walkr-calendar-legend,
	.walkr-selection-summary {
		padding: 15px;
	}
	
	.walkr-selection-summary h4 {
		font-size: 1rem;
	}
	
	/* Selection Mode Toggle */
	.walkr-selection-toggle {
		flex-direction: column;
		gap: 8px;
	}
	
	.walkr-selection-toggle button {
		width: 100%;
		padding: 10px;
		font-size: 0.85rem;
	}
	
	/* Invoice Table */
	.walkr-invoice-table {
		font-size: 11px;
	}
	
	.walkr-invoice-table th,
	.walkr-invoice-table td {
		padding: 6px 4px;
	}
	
	.walkr-invoice-section h4 {
		font-size: 1rem;
	}
	
	/* Invoices Page */
	.walkr-invoice-actions {
		flex-direction: column;
		gap: 8px;
	}
	
	.walkr-invoice-actions .walkr-button {
		width: 100%;
	}
}

/* ---------------------------------------------------------------------
   MODAL FULL-SCREEN ON MOBILE
   --------------------------------------------------------------------- */
@media (max-width: 767px) {
	/* Modal styles now handled by base styles (Mobile First) */
	
	/* Wizard Steps - equal distribution */
	.walkr-wizard-steps {
		padding: 10px 15px;
		gap: 0;
		overflow-x: visible;
		justify-content: space-between;
	}
	
	.walkr-wizard-step {
		flex-direction: column;
		gap: 3px;
		min-width: 0;
		flex: 1; /* Equal distribution */
	}
	
	.walkr-wizard-step .step-number {
		width: 28px;
		height: 28px;
		font-size: 12px;
	}
	
	.walkr-wizard-step .step-label {
		font-size: 0.65rem;
		text-align: center;
	}
	
	/* Wizard Panels - full width content */
	.walkr-wizard-panel {
		padding: 16px;
		width: 100%;
		box-sizing: border-box;
	}
	
	.walkr-wizard-panel h4 {
		font-size: 1.1rem;
		margin-bottom: 15px;
	}
	
	/* Service Cards in Wizard - 2 columns */
	.walkr-service-cards {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}
	
	.walkr-service-card-content {
		padding: 12px 8px;
		gap: 5px;
	}
	
	.walkr-service-icon {
		font-size: 1.4rem;
	}
	
	.walkr-service-card strong {
		font-size: 0.8rem;
	}
	
	.walkr-service-card small {
		font-size: 0.68rem;
		line-height: 1.2;
	}
	
	/* Service Configuration */
	.walkr-service-config {
		margin-top: 15px;
		padding-top: 15px;
	}
	
	.walkr-service-config-item {
		padding: 12px;
	}
	
	.walkr-service-name {
		font-size: 1rem;
	}
	
	.walkr-unified-times {
		flex-direction: column;
		gap: 12px;
	}
	
	.walkr-time-input-row {
		width: 100%;
	}
	
	.walkr-service-time,
	.walkr-service-slot,
	.walkr-times-per-day {
		width: 100%;
		max-width: 100%;
	}
	
	.walkr-per-day-times {
		gap: 8px;
	}
	
	.walkr-day-time-row {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
		padding: 10px;
	}
	
	.walkr-day-label {
		text-align: center;
		min-width: auto;
	}
	
	.walkr-day-times {
		flex-direction: column;
		gap: 8px;
	}
	
	.walkr-day-times input[type="time"] {
		width: 100%;
	}
	
	/* Pet Selection in Wizard */
	.walkr-pet-checkboxes {
		gap: 10px;
	}
	
	.walkr-pet-checkbox {
		padding: 10px;
	}
	
	.pet-avatar {
		width: 40px;
		height: 40px;
	}
	
	/* Booking Summary */
	.walkr-booking-summary {
		padding: 12px;
	}
	
	.walkr-summary-section {
		gap: 10px;
	}
	
	.walkr-summary-item {
		font-size: 0.88rem;
	}
	
	.walkr-summary-service {
		padding: 10px;
	}
	
	/* Invoice Preview in Summary */
	.walkr-invoice-section {
		margin-top: 15px;
		padding-top: 15px;
	}
	
	.walkr-invoice-table {
		width: 100%;
		table-layout: fixed;
	}
	
	.walkr-invoice-table th:first-child,
	.walkr-invoice-table td:first-child {
		width: 38%;
	}
	
	.walkr-invoice-table th:nth-child(2),
	.walkr-invoice-table td:nth-child(2) {
		width: 15%;
		text-align: center;
	}
	
	.walkr-invoice-table th:nth-child(3),
	.walkr-invoice-table td:nth-child(3) {
		width: 22%;
		text-align: right;
	}
	
	.walkr-invoice-table th:nth-child(4),
	.walkr-invoice-table td:nth-child(4) {
		width: 25%;
		text-align: right;
	}
	
	/* Date Chips */
	.walkr-dates-summary {
		padding: 12px;
	}
	
	.walkr-date-ranges {
		gap: 6px;
	}
	
	.walkr-date-chip {
		padding: 6px 10px;
		font-size: 0.8rem;
	}
	
	/* Form Fields */
	.walkr-form-group {
		margin-bottom: 15px;
	}
	
	.walkr-form-group label {
		font-size: 0.9rem;
		margin-bottom: 5px;
	}
	
	.walkr-form-group input,
	.walkr-form-group select,
	.walkr-form-group textarea {
		padding: 10px;
		font-size: 16px; /* Prevent iOS zoom */
	}
	
	/* Recurring Options */
	#walkr-recurring-options {
		padding: 12px;
		background: var(--walkr-bg-light);
		border-radius: 0.8rem;
	}
	
	/* Photo Gallery */
	.walkr-photo-gallery {
		grid-template-columns: repeat(3, 1fr);
		gap: 8px;
	}
	
	.walkr-photo-thumb {
		height: 70px;
	}
}

/* ---------------------------------------------------------------------
   TOUCH-FRIENDLY ENHANCEMENTS
   --------------------------------------------------------------------- */
@media (hover: none) and (pointer: coarse) {
	/* Larger touch targets */
	.walkr-button,
	.walkr-tab a,
	.walkr-calendar-nav,
	.walkr-expand-toggle,
	.walkr-pet-expand {
		min-height: 44px;
		min-width: 44px;
	}
	
	/* Remove hover effects that don't work on touch */
	.walkr-card:hover,
	.walkr-pet-card:hover,
	.walkr-service-card:hover .walkr-service-card-content {
		transform: none;
	}
	
	/* Better tap feedback */
	.walkr-button:active,
	.walkr-tab a:active,
	.walkr-calendar-day:active,
	.walkr-service-card:active .walkr-service-card-content {
		transform: scale(0.98);
		opacity: 0.9;
	}
}

/* ---------------------------------------------------------------------
   PRINT STYLES (for invoices)
   --------------------------------------------------------------------- */
@media print {
	.walkr-portal-nav,
	.walkr-portal-actions,
	.walkr-modal-footer button:not(.walkr-wizard-submit) {
		display: none !important;
	}
	
	.walkr-portal {
		position: static;
		padding: 0;
		background: white;
	}
	
	.walkr-card,
	.walkr-table {
		break-inside: avoid;
	}
}
