/* OnRoute Courier Booking - Modern Forms Styling */

/* Imports */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=Rajdhani:wght@400;500;600;700&display=swap');

/* Reset/Root */
:root {
	--ocb-primary: #d63031;
	--ocb-primary-dark: #b33939;
	--ocb-secondary: #2D3748;
	--ocb-text: #1A202C;
	--ocb-text-muted: #718096;
	--ocb-bg-light: #F7FAFC;
	--ocb-border: #E2E8F0;
	--ocb-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	--ocb-radius: 12px;
}

/* Form Container */
.ocb-quote-form-container,
.ocb-booking-form-container,
.ocb-review-form-container,
.ocb-quote-summary-container {
	max-width: 850px !important;
	margin: 50px auto !important;
	padding: 50px !important;
	padding-left: max(50px, calc((100% - 850px) / 2)) !important;
	padding-right: max(50px, calc((100% - 850px) / 2)) !important;
	background: #ffffff !important;
	border-radius: var(--ocb-radius) !important;
	box-shadow: var(--ocb-shadow) !important;
	border: 1px solid var(--ocb-border) !important;
	font-family: 'Poppins', sans-serif !important;
}

/* Form Header */
.ocb-form-header {
	text-align: center !important;
	margin-bottom: 40px !important;
	position: relative !important;
}

.ocb-form-header h2 {
	margin: 0 0 10px 0 !important;
	color: var(--ocb-text) !important;
	font-size: 36px !important;
	font-weight: 800 !important;
	letter-spacing: -1px !important;
    font-family: 'Rajdhani', sans-serif !important;
    text-transform: uppercase !important;
}

.ocb-form-header p {
	margin: 0 !important;
	color: var(--ocb-text-muted) !important;
	font-size: 16px !important;
}

/* Form Sections */
.ocb-form-section {
	margin-bottom: 40px !important;
}

.ocb-form-section h3 {
	margin: 0 0 25px 0 !important;
	color: #ffffff !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	background: linear-gradient(135deg, var(--ocb-primary) 0%, var(--ocb-primary-dark) 100%) !important;
	padding: 16px 24px !important;
	border-radius: 10px !important;
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
    font-family: 'Rajdhani', sans-serif !important;
}

.ocb-form-section h3 i { font-size: 18px !important; }

/* Grid Layouts */
.ocb-form-row {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 24px !important;
}

.ocb-form-row.ocb-full {
	grid-template-columns: 1fr !important;
}

/* Form Groups */
.ocb-form-group {
	margin-bottom: 24px !important;
}

.ocb-form-group label {
	display: block !important;
	margin-bottom: 10px !important;
	color: #ffffff !important;
	font-weight: 600 !important;
	font-size: 13px !important;
	text-transform: uppercase !important;
	letter-spacing: 0.5px !important;
}

.ocb-form-group label .ocb-required {
	color: var(--ocb-primary) !important;
	margin-left: 4px !important;
}

/* Input Fields */
.ocb-form-group input:not([type="checkbox"]):not([type="radio"]),
.ocb-form-group textarea,
.ocb-form-group select {
	width: 100% !important;
	padding: 14px 18px !important;
	border: 2px solid #EDF2F7 !important;
	border-radius: 10px !important;
	font-size: 15px !important;
	font-family: inherit !important;
	background: #F8FAFC !important;
	color: var(--ocb-text) !important;
	transition: all 0.2s ease-in-out !important;
}

.ocb-form-group input:focus,
.ocb-form-group textarea:focus,
.ocb-form-group select:focus {
	outline: none !important;
	border-color: var(--ocb-primary) !important;
	background: #ffffff !important;
	box-shadow: 0 0 0 4px rgba(214, 48, 49, 0.08) !important;
}

/* Vehicle Grid (Special Case for selections) */
.ocb-vehicle-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
	gap: 20px !important;
	margin-top: 15px !important;
}

.ocb-vehicle-item {
	position: relative !important;
	border: 2px solid #EDF2F7 !important;
	border-radius: 12px !important;
	padding: 20px !important;
	cursor: pointer !important;
	transition: all 0.2s !important;
	background: #ffffff !important;
	text-align: center !important;
}

.ocb-vehicle-item:hover {
	border-color: var(--ocb-primary) !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 4px 12px rgba(0,0,0,0.05) !important;
}

.ocb-vehicle-item.active {
	border-color: var(--ocb-primary) !important;
	background: #FFF5F5 !important;
}

/* Service Options */
.ocb-service-options {
	display: grid !important;
	grid-template-columns: 1fr 1fr 1fr !important;
	gap: 15px !important;
}

/* Buttons */
.ocb-btn {
	padding: 16px 32px !important;
	border: none !important;
	border-radius: 12px !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 10px !important;
	text-decoration: none !important;
	font-family: 'Rajdhani', sans-serif !important;
	text-transform: uppercase !important;
}

.ocb-btn-primary {
	background: linear-gradient(135deg, var(--ocb-primary) 0%, var(--ocb-primary-dark) 100%) !important;
	color: #ffffff !important;
	box-shadow: 0 4px 15px rgba(198, 40, 40, 0.2) !important;
}

.ocb-btn-primary:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 8px 25px rgba(198, 40, 40, 0.3) !important;
}

.ocb-btn-secondary {
	background: #EDF2F7 !important;
	color: var(--ocb-secondary) !important;
}

.ocb-btn-secondary:hover {
	background: #E2E8F0 !important;
	transform: translateY(-1px) !important;
}

/* Form Actions */
.ocb-form-actions {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 20px !important;
	margin-top: 40px !important;
	padding-top: 30px !important;
	border-top: 2px solid #F7FAFC !important;
}

/* Postcode Badge Style */
.ocb-postcode-badge {
	background: #EDF2F7 !important;
	padding: 4px 10px !important;
	border-radius: 6px !important;
	font-family: 'Courier New', monospace !important;
	font-weight: 700 !important;
}

/* Responsive */
@media (max-width: 768px) {
	.ocb-quote-form-container,
	.ocb-booking-form-container,
	.ocb-review-form-container {
		padding: 30px 20px !important;
		margin: 20px 15px !important;
	}

	.ocb-form-row {
		grid-template-columns: 1fr !important;
	}

	.ocb-form-actions {
		flex-direction: column-reverse !important;
	}

	.ocb-btn {
		width: 100% !important;
	}
	
	.ocb-form-header h2 {
		font-size: 28px !important;
	}

	/* Responsive Review Header */
	.ocb-review-header-content {
		flex-direction: column !important;
		align-items: stretch !important;
	}

	.ocb-review-header h1 {
		font-size: 26px !important;
	}

	.ocb-btn-edit-details {
		width: 100% !important;
		justify-content: center !important;
	}

	.ocb-btn-text {
		display: inline !important;
	}
}

/* Quote Summary Card */
.ocb-quote-summary {
	background: #F8FAFC !important;
	border: 1px solid var(--ocb-border) !important;
	border-radius: 16px !important;
	padding: 30px !important;
	margin-bottom: 30px !important;
}

.ocb-price-display {
	text-align: center !important;
	margin: 25px 0 !important;
	padding: 25px !important;
	background: white !important;
	border-radius: 12px !important;
	border: 2px solid var(--ocb-primary) !important;
}

.ocb-price-label {
	font-size: 14px !important;
	color: var(--ocb-text-muted) !important;
	text-transform: uppercase !important;
	font-weight: 700 !important;
}

.ocb-price-amount {
	display: block !important;
	font-size: 48px !important;
	font-weight: 800 !important;
	color: var(--ocb-primary) !important;
	line-height: 1 !important;
}

/* Service Tabs */
.ocb-service-tabs {
	display: flex;
	gap: 10px;
	margin-bottom: 30px;
	border-bottom: 2px solid #e0e0e0;
}

.ocb-service-tab {
	flex: 1;
	padding: 15px 10px;
	border: none;
	background: transparent;
	color: #666;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	border-bottom: 3px solid transparent;
	transition: all 0.3s ease;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ocb-service-tab:hover {
	color: #007cba;
	background: #f5f5f5;
}

.ocb-service-tab.ocb-service-active {
	color: #007cba;
	border-bottom-color: #007cba;
}

/* Vehicles Grid */
.ocb-vehicles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 20px;
	margin-bottom: 30px;
}

/* Vehicle Card */
.ocb-vehicle-card {
	background: white;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	padding: 20px;
	text-align: center;
	transition: all 0.3s ease;
	cursor: pointer;
}

.ocb-vehicle-card:hover {
	border-color: #007cba;
	box-shadow: 0 4px 12px rgba(0, 124, 186, 0.15);
	transform: translateY(-2px);
}

.ocb-vehicle-icon {
	font-size: 40px;
	margin-bottom: 10px;
}

.ocb-vehicle-card h4 {
	margin: 10px 0 5px 0;
	color: #333;
	font-size: 16px;
	font-weight: 600;
}

.ocb-vehicle-description {
	margin: 5px 0 8px 0;
	color: #666;
	font-size: 12px;
	font-weight: 500;
	font-style: italic;
}

.ocb-vehicle-desc {
	margin: 5px 0;
	color: #666;
	font-size: 13px;
	font-weight: normal;
}

.ocb-vehicle-weight {
	margin: 8px 0 15px 0;
	color: #999;
	font-size: 12px;
	font-weight: normal;
}

/* Vehicle Pricing */
.ocb-vehicle-pricing {
	margin: 15px 0;
	padding: 15px;
	background: #f9f9f9;
	border-radius: 6px;
	border-left: 3px solid #007cba;
}

.ocb-price-base {
	margin: 0;
	color: #666;
	font-size: 12px;
	font-weight: normal;
	text-decoration: line-through;
}

.ocb-price-vat {
	margin: 5px 0;
	color: #999;
	font-size: 12px;
	font-weight: normal;
}

.ocb-price-total {
	margin: 10px 0 0 0;
	color: #007cba;
	font-size: 20px;
	font-weight: 700;
}

/* Select Vehicle Button */
.ocb-select-vehicle {
	width: 100%;
	padding: 10px 15px;
	background: #007cba;
	color: white;
	border: none;
	border-radius: 4px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s ease;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.ocb-select-vehicle:hover {
	background: #005a87;
	box-shadow: 0 2px 8px rgba(0, 90, 135, 0.3);
}

.ocb-select-vehicle:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* Responsive Design */
@media (max-width: 768px) {
	.ocb-quote-summary-container {
		padding: 30px 20px !important;
		margin: 20px auto !important;
	}

	.ocb-step-indicator {
		flex-direction: column;
		gap: 8px;
		font-size: 11px;
	}

	.ocb-step-arrow {
		display: none;
	}

	.ocb-step-item {
		width: 100%;
	}

	.ocb-vehicles-grid {
		grid-template-columns: 1fr;
		gap: 15px;
	}

	.ocb-service-tabs {
		flex-direction: column;
		gap: 0;
		border-bottom: none;
	}

	.ocb-service-tab {
		border-bottom: none;
		border-left: 3px solid transparent;
		padding-left: 15px;
		text-align: left;
	}

	.ocb-service-tab.ocb-service-active {
		border-bottom: none;
		border-left-color: #007cba;
	}

	.ocb-quote-info p {
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
	}

	.ocb-change-link {
		margin-left: 0;
	}
}

/* Address Selection Modal */
.ocb-modal {
	position: fixed;
	z-index: 9999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: center;
	justify-content: center;
}

.ocb-modal-content {
	background-color: #fff;
	border-radius: 8px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
	width: 90%;
	max-width: 600px;
	max-height: 80vh;
	overflow-y: auto;
}

.ocb-modal-header {
	padding: 20px;
	border-bottom: 1px solid #e0e0e0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ocb-modal-header h3 {
	margin: 0;
	font-size: 20px;
	color: #333;
}

.ocb-modal-close {
	background: none;
	border: none;
	font-size: 28px;
	cursor: pointer;
	color: #999;
	padding: 0;
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ocb-modal-close:hover {
	color: #333;
}

.ocb-modal-body {
	padding: 20px;
}

.ocb-address-item {
	padding: 12px;
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	margin-bottom: 10px;
	cursor: pointer;
	transition: all 0.3s ease;
}

.ocb-address-item:hover {
	background-color: #f0f0f0;
	border-color: #007cba;
}

.ocb-address-item input[type="radio"] {
	cursor: pointer;
}

.ocb-address-form {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid #e0e0e0;
}

.ocb-address-form textarea {
	width: 100%;
	padding: 10px;
	border: 1px solid #ddd;
	border-radius: 4px;
	font-family: inherit;
	font-size: 14px;
}

.ocb-modal-footer {
	padding: 20px;
	border-top: 1px solid #e0e0e0;
	display: flex;
	justify-content: flex-end;
	gap: 10px;
}

/* Postcode Container */
.ocb-postcode-container {
	display: flex;
	gap: 10px;
	align-items: center;
}

.ocb-postcode-display {
	flex: 1;
}

.ocb-btn-select-address {
	padding: 8px 16px;
	background-color: #C62828;
	color: white;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-size: 14px;
	transition: all 0.3s ease;
	white-space: nowrap;
	font-family: 'Rajdhani', sans-serif !important;
	text-transform: uppercase !important;
}

.ocb-btn-select-address:hover {
	background-color: #B71C1C;
	box-shadow: 0 4px 12px rgba(198, 40, 40, 0.3);
	transform: translateY(-2px);
}

/* Review & Book Header - Responsive Layout */
.ocb-review-header {
	margin-bottom: 35px !important;
}

.ocb-review-header-content {
	display: flex !important;
	align-items: flex-start !important;
	justify-content: space-between !important;
	gap: 20px !important;
	flex-wrap: wrap !important;
}

.ocb-review-header h1 {
	margin: 0 0 8px 0 !important;
	color: var(--ocb-text) !important;
	font-size: 32px !important;
	font-weight: 800 !important;
	font-family: 'Rajdhani', sans-serif !important;
	text-transform: uppercase !important;
}

.ocb-review-header p {
	margin: 0 !important;
	color: var(--ocb-text-muted) !important;
	font-size: 14px !important;
}

/* Edit Details Button */
.ocb-btn-edit-details {
	background: #ffffff !important;
	color: #000000 !important;
	border: 2px solid #d63031 !important;
	padding: 12px 20px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	border-radius: 8px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	white-space: nowrap !important;
	align-self: center !important;
}

.ocb-btn-edit-details:hover {
	background: #d63031 !important;
	color: #000000 !important;
	transform: translateY(-2px) !important;
	box-shadow: 0 4px 12px rgba(198, 40, 40, 0.3) !important;
}

.ocb-btn-edit-details:hover i {
	color: #000000 !important;
}

.ocb-btn-edit-details i {
	font-size: 16px !important;
	color: #d63031 !important;
}

/* Address Lookup Modal */
.ocb-address-modal {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	height: 100% !important;
	background: rgba(0, 0, 0, 0.6) !important;
	z-index: 9999 !important;
	overflow: auto !important;
	opacity: 1 !important;
	visibility: visible !important;
	transition: opacity 0.3s ease !important;
}

/* Address Selection Modal - Full Overlay with Centered Content */
#ocb-address-modal {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	z-index: 9999 !important;
	background: rgba(0, 0, 0, 0.5) !important;
	padding: 20px !important;
}

#ocb-address-modal.hidden {
	display: none !important;
}

.ocb-address-modal.hidden {
	display: none !important;
	opacity: 0 !important;
	visibility: hidden !important;
}

.ocb-address-modal-content {
	background: #ffffff !important;
	border-radius: 12px !important;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
	width: 100% !important;
	max-width: 650px !important;
	max-height: 80vh !important;
	display: flex !important;
	flex-direction: column !important;
	overflow: hidden !important;
	animation: slideUp 0.3s ease !important;
}

@keyframes slideUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.ocb-address-modal-header {
	padding: 20px 25px !important;
	border-bottom: 1px solid var(--ocb-border) !important;
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
}

.ocb-address-modal-header h3 {
	margin: 0 !important;
	font-size: 20px !important;
	font-weight: 600 !important;
	color: var(--ocb-text) !important;
	font-family: 'Rajdhani', sans-serif !important;
}

.ocb-address-modal-close {
	background: none !important;
	border: none !important;
	font-size: 28px !important;
	cursor: pointer !important;
	color: var(--ocb-text-muted) !important;
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 40px !important;
	height: 40px !important;
	border-radius: 4px !important;
	transition: all 0.2s ease !important;
}

.ocb-address-modal-close:hover {
	background-color: #f0f0f0 !important;
	color: var(--ocb-text) !important;
}

.ocb-address-modal-body {
	flex: 1 !important;
	overflow-y: auto !important;
	padding: 20px 25px !important;
	min-height: 150px !important;
}

.ocb-address-table {
	width: 100% !important;
	border-collapse: collapse !important;
}

.ocb-address-table thead {
	background-color: var(--ocb-bg-light) !important;
	border-bottom: 2px solid var(--ocb-border) !important;
}

.ocb-address-table th {
	padding: 12px !important;
	text-align: left !important;
	font-weight: 600 !important;
	color: var(--ocb-text) !important;
	font-size: 14px !important;
}

.ocb-address-table td {
	padding: 12px !important;
}

.ocb-address-row {
	border-bottom: 1px solid var(--ocb-border) !important;
	cursor: pointer !important;
	transition: background-color 0.2s ease !important;
}

.ocb-address-row:hover {
	background-color: #fafafa !important;
}

.ocb-address-row.ocb-address-row-selected {
	background-color: #fff3cd !important;
}

.ocb-address-col-select {
	width: 50px !important;
	text-align: center !important;
}

.ocb-address-col-select input[type="radio"] {
	cursor: pointer !important;
}

.ocb-address-col-address {
	padding: 12px !important;
}

.ocb-address-inline {
	font-size: 14px !important;
	color: #333 !important;
	line-height: 1.5 !important;
	display: block !important;
}

.ocb-address-link {
	color: var(--ocb-primary) !important;
	text-decoration: none !important;
	display: block !important;
	width: 100% !important;
}

.ocb-address-name {
	font-weight: 600 !important;
	color: #333 !important;
	font-size: 14px !important;
	margin-bottom: 6px !important;
	line-height: 1.3 !important;
}

.ocb-address-details {
	font-size: 13px !important;
	color: #666 !important;
	margin-bottom: 4px !important;
	line-height: 1.4 !important;
}

.ocb-address-postcode {
	font-size: 12px !important;
	color: #999 !important;
	font-weight: 500 !important;
	margin-top: 4px !important;
}

.ocb-address-link:hover {
	background-color: #f5f5f5 !important;
	border-radius: 3px !important;
}

.ocb-address-full {
	font-size: 13px !important;
	color: var(--ocb-text-muted) !important;
	line-height: 1.4 !important;
}

.ocb-address-pagination {
	margin-top: 15px !important;
	text-align: center !important;
	padding-top: 15px !important;
	border-top: 1px solid var(--ocb-border) !important;
}

.ocb-address-row:hover {
	background-color: #f9f9f9 !important;
}

.ocb-address-name {
	color: #333 !important;
	font-weight: 600 !important;
	font-size: 15px !important;
	margin-bottom: 2px !important;
}

.ocb-address-details {
	color: #666 !important;
	font-size: 13px !important;
	line-height: 1.4 !important;
	margin-top: 2px !important;
	word-wrap: break-word !important; /* Ensure long addresses wrap */
	white-space: normal !important;   /* Force wrapping */
}

.ocb-page-link {
	display: inline-block !important;
	padding: 8px 12px !important;
	margin: 0 4px !important;
	background-color: var(--ocb-bg-light) !important;
	border: 1px solid var(--ocb-border) !important;
	border-radius: 4px !important;
	color: var(--ocb-text) !important;
	text-decoration: none !important;
	cursor: pointer !important;
	transition: all 0.2s ease !important;
}

.ocb-page-link:hover {
	background-color: var(--ocb-primary) !important;
	color: white !important;
	border-color: var(--ocb-primary) !important;
}

.ocb-page-link.active {
	background-color: var(--ocb-primary) !important;
	color: white !important;
	border-color: var(--ocb-primary) !important;
}

.ocb-address-error {
	background-color: #f8d7da !important;
	color: #721c24 !important;
	padding: 15px !important;
	border-radius: 8px !important;
	border: 1px solid #f5c6cb !important;
	font-size: 14px !important;
	margin-bottom: 15px !important;
	display: none !important;
}

.ocb-address-error:not(.hidden):not([style*="display: none"]) {
	display: block !important;
}

.ocb-address-loading {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 40px 20px !important;
	color: var(--ocb-text-muted) !important;
	min-height: 200px !important;
}

.ocb-address-loading.hidden {
	display: none !important;
}

.ocb-spinner-small {
	width: 30px !important;
	height: 30px !important;
	border: 3px solid #e2e8f0 !important;
	border-top-color: var(--ocb-primary) !important;
	border-radius: 50% !important;
	animation: spin 0.8s linear infinite !important;
	margin-bottom: 15px !important;
}

@keyframes spin {
	to { transform: rotate(360deg); }
}

.ocb-address-list {
	display: block !important;
	width: 100% !important;
}

.ocb-address-table {
	width: 100% !important;
	border-collapse: collapse !important;
	margin: 0 !important;
}

.ocb-address-table thead {
	background: #f8f9fa !important;
	border-bottom: 2px solid #e2e8f0 !important;
}

.ocb-address-table thead th {
	padding: 12px !important;
	text-align: left !important;
	font-weight: 600 !important;
	color: var(--ocb-text) !important;
	font-size: 14px !important;
}

.ocb-address-col-select {
	width: 60px !important;
	text-align: center !important;
	padding: 12px !important;
}

.ocb-address-col-address {
	width: auto !important;
	padding: 15px !important;
	text-align: left !important;
}

.ocb-address-table tbody tr {
	border-bottom: 1px solid #e2e8f0 !important;
	transition: background 0.2s ease !important;
	display: table-row !important;
}

.ocb-address-row {
	cursor: pointer !important;
	display: table-row !important;
}

.ocb-address-row:hover {
	background: #f7fafc !important;
}

.ocb-address-row-selected {
	background: #fff9f7 !important;
}

.ocb-address-row td {
	display: table-cell !important;
	padding: 15px !important;
	vertical-align: middle !important;
	border-bottom: 1px solid #e2e8f0 !important;
}

.ocb-address-link {
	color: #0066cc !important;
	text-decoration: none !important;
	display: block !important;
	transition: color 0.2s ease !important;
}

.ocb-address-name {
	font-weight: 600 !important;
	color: #333 !important;
	font-size: 14px !important;
	margin-bottom: 6px !important;
	line-height: 1.3 !important;
}

.ocb-address-details {
	font-size: 13px !important;
	color: #666 !important;
	margin-bottom: 4px !important;
	line-height: 1.4 !important;
}

.ocb-address-postcode {
	font-size: 12px !important;
	color: #999 !important;
	font-weight: 500 !important;
	margin-top: 4px !important;
}

.ocb-address-link:hover {
	color: #0052a3 !important;
	text-decoration: underline !important;
}

.ocb-address-full {
	color: var(--ocb-text-muted) !important;
	font-size: 12px !important;
	margin-top: 3px !important;
}

.ocb-address-row input[type="radio"] {
	cursor: pointer !important;
	width: 18px !important;
	height: 18px !important;
	margin: 0 !important;
	vertical-align: middle !important;
}

.ocb-pagination {
	display: flex !important;
	justify-content: center !important;
	gap: 5px !important;
	padding: 15px 0 !important;
	flex-wrap: wrap !important;
}

.ocb-page-link {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 32px !important;
	height: 32px !important;
	padding: 0 8px !important;
	border: 1px solid #e2e8f0 !important;
	border-radius: 4px !important;
	background: #ffffff !important;
	color: var(--ocb-text) !important;
	text-decoration: none !important;
	font-size: 14px !important;
	cursor: pointer !important;
	transition: all 0.2s ease !important;
}

.ocb-page-link:hover {
	background: var(--ocb-primary) !important;
	border-color: var(--ocb-primary) !important;
	color: #ffffff !important;
}

.ocb-page-link.active {
	background: var(--ocb-primary) !important;
	color: #ffffff !important;
	border-color: var(--ocb-primary) !important;
}

.ocb-address-items {
	display: none !important;
}

.ocb-address-item-label {
	font-weight: 600 !important;
	color: var(--ocb-text) !important;
	margin-bottom: 4px !important;
	font-size: 14px !important;
}

.ocb-address-item-full {
	font-size: 13px !important;
	color: var(--ocb-text-muted) !important;
	word-break: break-word !important;
	line-height: 1.4 !important;
}

.ocb-address-error {
	background: #ffebee !important;
	color: #d32f2f !important;
	padding: 15px !important;
	border-radius: 6px !important;
	border: 1px solid #ffcdd2 !important;
	font-size: 14px !important;
	text-align: center !important;
}

.ocb-address-modal-footer {
	padding: 15px 20px !important;
	border-top: 1px solid #e2e8f0 !important;
	display: flex !important;
	gap: 12px !important;
	justify-content: flex-end !important;
	align-items: center !important;
}

.ocb-address-modal-footer .ocb-btn {
	padding: 8px 16px !important;
	font-size: 13px !important;
	min-height: 36px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
}

/* Mobile Responsive - Address Modal */
@media (max-width: 768px) {
	.ocb-address-modal-content {
		margin: 50px auto !important;
		width: 95% !important;
	}

	.ocb-address-modal-body {
		max-height: 60vh !important;
	}

	.ocb-address-item {
		padding: 12px !important;
		margin-bottom: 8px !important;
	}

	.ocb-address-item-label {
		font-size: 13px !important;
	}

	.ocb-address-item-full {
		font-size: 12px !important;
	}

	.ocb-address-modal-footer {
		flex-direction: column !important;
	}

	.ocb-address-modal-footer .ocb-btn {
		width: 100% !important;
	}
}

@media (max-width: 480px) {
	.ocb-address-modal-content {
		margin: 20px auto !important;
		width: 98% !important;
		border-radius: 8px !important;
	}

	.ocb-address-modal-header {
		padding: 15px !important;
	}

	.ocb-address-modal-header h3 {
		font-size: 16px !important;
	}

	.ocb-address-modal-body {
		padding: 15px !important;
		max-height: 50vh !important;
	}

	.ocb-address-item {
		padding: 10px !important;
		gap: 8px !important;
	}

	.ocb-address-modal-footer {
		padding: 15px !important;
		gap: 8px !important;
	}
}

/* Print Styles */
@media print {
	.ocb-btn,
	.ocb-form-actions,
	.ocb-modal,
	.ocb-btn-select-address {
		display: none;
	}

	.ocb-quote-form-container,
	.ocb-booking-form-container,
	.ocb-quote-summary-container {
		box-shadow: none;
		border: 1px solid #ddd;
	}
}
/* Address Lookup - Field Highlight Effect */
.ocb-field-updated {
	animation: ocb-field-highlight 2s ease-out;
	box-shadow: 0 0 20px rgba(214, 48, 49, 0.3) !important;
}

@keyframes ocb-field-highlight {
	0% {
		background-color: #fff3cd !important;
		box-shadow: 0 0 30px rgba(214, 48, 49, 0.5) !important;
	}
	50% {
		background-color: #fff8e7 !important;
		box-shadow: 0 0 20px rgba(214, 48, 49, 0.3) !important;
	}
	100% {
		background-color: transparent !important;
		box-shadow: none !important;
	}
}
