/**
 * All Services Table - Base Styles (Rebuilt)
 * Neutral, WordPress-compliant base. Themes override via theme CSS only.
 */

/* Container */
.fashionpoint-all-services-container {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
	font-style: normal !important;
	line-height: 1.5 !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	color: #1f1f1f !important;
	background: #ffffff;
}

/* Neutralize theme global padding wrappers (e.g., alignfull + has-global-padding) */
.has-global-padding .fashionpoint-all-services-container,
.entry-content.has-global-padding .fashionpoint-all-services-container,
.alignfull .fashionpoint-all-services-container {
	margin-left: calc(-1 * var(--wp--style--root--padding-left, 0px)) !important;
	margin-right: calc(-1 * var(--wp--style--root--padding-right, 0px)) !important;
	width: calc(100% + var(--wp--style--root--padding-left, 0px) + var(--wp--style--root--padding-right, 0px)) !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* Scoped reset to neutralize theme/global styles */
.fashionpoint-all-services-container,
.fashionpoint-all-services-container * {
	box-sizing: border-box !important;
	font-family: inherit !important;
	font-style: inherit !important;
	line-height: inherit !important;
	letter-spacing: inherit !important;
	word-spacing: inherit !important;
	text-transform: inherit !important;
	text-decoration: inherit !important;
}

/* Neutralize CMSMasters / Elementor theme button overrides */
.fashionpoint-all-services-container button,
.fashionpoint-all-services-container button.fashionpoint-type-toggle-btn {
	font-family: inherit !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	font-style: normal !important;
	text-transform: inherit !important;
	text-decoration: none !important;
	letter-spacing: inherit !important;
	word-spacing: normal !important;
	line-height: inherit !important;
	text-shadow: none !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	padding: 0 !important;
	overflow: visible !important;
	position: relative !important;
	z-index: auto !important;
	transition: none !important;
}

/* Kill theme pseudo-elements injected on all <button> elements */
.fashionpoint-all-services-container button::before,
.fashionpoint-all-services-container button::after {
	content: none !important;
	display: none !important;
}

/* Neutralize CMSMasters / Elementor theme table overrides */
.fashionpoint-all-services-container table {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	border-spacing: 0 !important;
	border: none !important;
	background-color: transparent !important;
	overflow-wrap: normal !important;
	word-break: normal !important;
}

.fashionpoint-all-services-container table th,
.fashionpoint-all-services-container table td,
.fashionpoint-all-services-container table thead th,
.fashionpoint-all-services-container table thead td {
	font-family: inherit !important;
	font-weight: inherit !important;
	font-style: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	font-size: inherit !important;
	line-height: inherit !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	color: inherit !important;
	background-color: transparent !important;
	border: none !important;
	border-left-style: none !important;
	padding: 12px 16px !important;
}

/* Neutralize CMSMasters / Elementor theme input/select overrides */
.fashionpoint-all-services-container input,
.fashionpoint-all-services-container select,
.fashionpoint-all-services-container textarea {
	font-family: inherit !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	font-style: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	letter-spacing: normal !important;
	word-spacing: normal !important;
	line-height: inherit !important;
	color: inherit !important;
	border-radius: 6px !important;
	box-shadow: none !important;
	outline-offset: 0 !important;
	-webkit-appearance: none !important;
	appearance: none !important;
}

/* Neutralize CMSMasters / Elementor theme link overrides */
.fashionpoint-all-services-container a {
	color: inherit !important;
	text-decoration: none !important;
	box-shadow: none !important;
	border-bottom: none !important;
	background-image: none !important;
	transition: none !important;
}

/* Neutralize CMSMasters / Elementor theme list overrides */
.fashionpoint-all-services-container ul,
.fashionpoint-all-services-container ol {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.fashionpoint-all-services-container li {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.fashionpoint-all-services-container li::before,
.fashionpoint-all-services-container li::after {
	content: none !important;
	display: none !important;
}

/* Neutralize CMSMasters / Elementor theme SVG overrides */
.fashionpoint-all-services-container svg {
	max-width: none !important;
	height: auto;
	fill: currentColor;
	overflow: visible !important;
}

/* Neutralize CMSMasters / Elementor theme form overrides */
.fashionpoint-all-services-container form {
	margin: 0 !important;
	padding: 0 !important;
}

.fashionpoint-all-services-container label {
	font-family: inherit !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	color: inherit !important;
	margin: 0 !important;
}

/* Prevent outer themes from spacing content vertically (e.g., flex with space-between). */
.fashionpoint-all-services-container .fashionpoint-content-area {
	display: block;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	gap: 0;
}

.fashionpoint-all-services-container h1,
.fashionpoint-all-services-container h2,
.fashionpoint-all-services-container h3,
.fashionpoint-all-services-container h4,
.fashionpoint-all-services-container h5,
.fashionpoint-all-services-container h6 {
	margin: 0 !important;
	font-weight: 700 !important;
	font-family: inherit !important;
	font-style: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	letter-spacing: normal !important;
	line-height: 1.3 !important;
	color: inherit !important;
}

.fashionpoint-all-services-container p {
	margin: 0 0 10px 0 !important;
	font-family: inherit !important;
	font-size: inherit !important;
	line-height: inherit !important;
	color: inherit !important;
}

/* Table wrapper */
.fashionpoint-services-table-wrapper {
	width: 100%;
	max-width: none;
	margin: 0;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
}

/* View toggles (max specificity) */
body .fashionpoint-all-services-container .fashionpoint-desktop-view,
body .fashionpoint-all-services-container .fashionpoint-services-table-wrapper.fashionpoint-desktop-view {
	display: block !important;
}
body .fashionpoint-all-services-container .fashionpoint-mobile-view,
body .fashionpoint-all-services-container .fashionpoint-services-cards-wrapper.fashionpoint-mobile-view {
	display: none !important;
}

/* Table */
.fashionpoint-services-table {
	width: 100% !important;
	min-width: 900px;
	border-collapse: separate !important;
	border-spacing: 0 !important;
	table-layout: auto;
	border: 1px solid rgba(0, 0, 0, 0.08) !important;
	border-radius: 12px;
	overflow: hidden;
	background: #fff !important;
	color: inherit;
	margin: 0 !important;
}

.fashionpoint-services-table thead th {
	background: #f8fafc !important;
	font-weight: 700 !important;
	color: inherit !important;
	font-family: inherit !important;
	font-style: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	letter-spacing: normal !important;
	border: none !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.fashionpoint-services-table th,
.fashionpoint-services-table td {
	padding: 12px 16px !important;
	text-align: left !important;
	vertical-align: middle !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
	border-left: none !important;
	border-right: none !important;
	border-top: none !important;
}

.fashionpoint-services-table tbody tr:last-child td {
	border-bottom: none;
}

.fashionpoint-services-table tbody tr:hover {
	background: #f7f9fb;
}

/* Columns */
.fashionpoint-services-table th:nth-child(1),
.fashionpoint-services-table td:nth-child(1) { width: 45%; font-weight: 500; }
.fashionpoint-services-table th:nth-child(2),
.fashionpoint-services-table td:nth-child(2) { width: 15%; }
.fashionpoint-services-table th:nth-child(3),
.fashionpoint-services-table td:nth-child(3) { width: 15%; }
.fashionpoint-services-table th:nth-child(4),
.fashionpoint-services-table td:nth-child(4) { width: 8%; text-align: center; padding-left: 6px; padding-right: 6px; }
.fashionpoint-services-table th:nth-child(5),
.fashionpoint-services-table td:nth-child(5) { width: 15%; }

/* Category header */
.fashionpoint-category-header {
	display: flex;
	align-items: center;
	gap: 2px;
	padding: 0 0 16px 0;
	margin: 0 0 20px 0;
	border-bottom: 2px solid #e5e7eb;
	background: transparent;
}

.fashionpoint-category-header h2 {
	margin: 0;
	font-size: 22px;
	font-weight: 700;
	color: inherit;
}

.fashionpoint-category-name-container {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: center;
	text-align: center;
}

.fashionpoint-category-section,
.fashionpoint-category-section.collapsed,
.fashionpoint-category-section.expanded {
	display: block;
	width: 100%;
}

.fashionpoint-category-content {
	display: block;
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	max-height: none;
	opacity: 1;
	transition: max-height 0.35s ease, opacity 0.25s ease;
}

.fashionpoint-category-section.collapsed .fashionpoint-category-content {
	max-height: 0;
	opacity: 0;
	pointer-events: none;
}

/* Buttons */
.fashionpoint-booking-btn,
.fashionpoint-action-btn,
.fashionpoint-book-btn-mobile {
	padding: 10px 20px !important;
	border-radius: 6px !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	font-family: inherit !important;
	cursor: pointer !important;
	white-space: nowrap !important;
	border: none !important;
	transition: all 0.25s ease !important;
	background: var(--fp-primary, #d6ae47) !important;
	background-image: none !important;
	color: #fff !important;
	text-decoration: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1.5 !important;
}

.fashionpoint-booking-btn:hover,
.fashionpoint-action-btn:hover,
.fashionpoint-book-btn-mobile:hover {
	background: var(--fp-primary-dark, #c69a2e) !important;
}

/* Theme-specific button styles */
body .fashionpoint-booking-btn,
body .fashionpoint-action-btn,
body .fashionpoint-book-btn-mobile {
	background: var(--fp-primary, #d6ae47) !important;
	color: #fff !important;
}

body .fashionpoint-booking-btn:hover,
body .fashionpoint-action-btn:hover,
body .fashionpoint-book-btn-mobile:hover {
	background: var(--fp-primary-dark, #c69a2e) !important;
}

/* Badges */
.fashionpoint-location-badge,
.fashionpoint-promo-badge {
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 600;
	background: #111827 !important;
	color: #fff !important;
}

/* Location column */
.fp-location-cell {
	width: 8%;
	text-align: center !important;
	padding-left: 6px;
	padding-right: 6px;
}

.fp-location-cell .fp-location-list,
.fp-location-cell .fp-location-empty {
	display: inline-block;
	text-align: center;
	font-weight: 500;
	font-size: inherit;
	margin: 0 auto;
}

/* Price */

/* Price colors: current black, old gray strikethrough */
.fashionpoint-price-current,
.fashionpoint-current-price,
.fp-card-current-price,
.fashionpoint-price-eur,
.fashionpoint-price-bgn {
	color: #000 !important;
	font-weight: 500;
	font-size: inherit;
}

/* Reset price font weight inside custom tables to avoid theme overrides forcing bold */
body .fashionpoint-all-services-container .fashionpoint-services-table td:nth-child(2) .fashionpoint-price-wrapper,
body .fashionpoint-all-services-container .fashionpoint-services-table td:nth-child(2) .fashionpoint-current-price,
body .fashionpoint-all-services-container .fashionpoint-services-table td:nth-child(2) .fashionpoint-price-eur,
body .fashionpoint-all-services-container .fashionpoint-services-table td:nth-child(2) .fashionpoint-price-bgn {
	font-weight: 500 !important;
}

.fashionpoint-price-old {
	text-decoration: line-through;
	color: #6b7280 !important;
}

/* Search */
.fashionpoint-search-input {
	padding: 10px 16px !important;
	border-radius: 6px !important;
	width: 100% !important;
	font-size: 14px !important;
	border: 1px solid #e5e7eb !important;
	background: #fff !important;
	color: #1f1f1f !important;
	transition: border-color 0.2s ease !important;
}

.fashionpoint-search-input:focus {
	outline: none !important;
	border-color: #111827 !important;
	box-shadow: none !important;
}

/* Type toggle */
.fashionpoint-type-toggle button {
	padding: 10px 18px;
	border-radius: 6px;
	font-weight: 600;
	border: 1px solid #e5e7eb;
	background: #f9fafb;
	cursor: pointer;
	transition: all 0.2s ease;
}

.fashionpoint-type-toggle button.active {
	background: #111827;
	color: #fff;
	border-color: #111827;
}

/* Mobile cards (fallback) */
.fashionpoint-service-card {
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 8px;
	margin-bottom: 12px;
	background: #ffffff;
	width: 90%;
	transition: all 0.2s ease;
}

.fashionpoint-card-title {
	font-weight: 700;
	font-size: 16px;
}

/* =============================================
	TYPE TOGGLE
	============================================= */
.fashionpoint-type-toggle-wrapper {
	margin-bottom: 20px;
}

.fashionpoint-type-toggle {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
}

.fashionpoint-type-toggle-btn {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 16px !important;
	width: 160px !important;
	height: 160px !important;
	border-radius: 21px !important;
	font-weight: 700 !important;
	font-size: 16px !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	border: 2px solid #e5e7eb !important;
	background: #fff !important;
	color: #374151 !important;
	cursor: pointer !important;
	transition: all 0.25s ease !important;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04) !important;
	overflow: hidden !important;
	padding: 14px 18px !important;
	position: relative !important;
	z-index: 1 !important;
	background-image: none !important;
	text-shadow: none !important;
	text-decoration: none !important;
	font-style: normal !important;
	line-height: 1.5 !important;
}

.fashionpoint-type-toggle-btn:hover:not(.active) {
	border-color: #9ca3af !important;
	background: #fafafa !important;
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.07) !important;
	transform: translateY(-2px);
}

.fashionpoint-type-toggle-btn.active {
	background: #111827 !important;
	color: #fff !important;
	border-color: #111827 !important;
	box-shadow: 0 6px 16px rgba(17, 24, 39, 0.3) !important;
}

.fashionpoint-type-toggle-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
}

.fashionpoint-type-toggle-icon svg {
	width: 52px;
	height: 52px;
}

.fashionpoint-type-toggle-label {
	white-space: nowrap;
}

/* =============================================
	SEARCH & FILTER
	============================================= */
.fashionpoint-search-wrapper {
	max-width: 320px;
	margin: 0 auto 20px;
}

.fashionpoint-search-filter-row {
	display: flex;
	justify-content: center;
	gap: 12px;
	align-items: stretch;
}

.fashionpoint-search-container {
	position: relative;
	flex: 0 1 100%;
	min-width: 0;
}

.fashionpoint-search-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--fp-primary, #d4af37) !important;
	pointer-events: none;
}

.fashionpoint-search-input {
	padding-left: 42px !important;
	padding-right: 40px !important;
	border-radius: 10px;
}

.fashionpoint-search-clear {
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 4px;
	color: #9ca3af !important;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 4px;
	transition: color 0.15s ease;
}

.fashionpoint-search-clear:hover {
	color: #374151 !important;
}

.fashionpoint-search-btn-icon {
	display: inline-flex;
}

.fashionpoint-search-btn-icon--search {
	display: none;
}

.fashionpoint-location-filter-container {
	position: relative;
	min-width: 180px;
}

.fashionpoint-location-filter-icon {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	color: #9ca3af !important;
	pointer-events: none;
}

.fashionpoint-location-filter {
	width: 100% !important;
	padding: 10px 16px 10px 40px !important;
	border-radius: 6px !important;
	font-size: 14px !important;
	border: 1px solid #e5e7eb !important;
	background: #fff !important;
	color: #1f1f1f !important;
	appearance: none !important;
	-webkit-appearance: none !important;
	cursor: pointer !important;
}

.fashionpoint-location-filter:focus {
	outline: none !important;
	border-color: #111827 !important;
	box-shadow: none !important;
}

.fashionpoint-search-results-info {
	margin-top: 8px;
	font-size: 13px;
	color: #6b7280 !important;
}

/* =============================================
	CATEGORY HEADER COMPONENTS
	============================================= */
.fashionpoint-category-toggle {
	cursor: pointer;
}

.fashionpoint-category-toggle:hover {
	opacity: 0.85;
}

.fashionpoint-category-name-container {
	flex: 1;
	min-width: 0;
}

.fashionpoint-category-chevron-container {
	display: flex;
	align-items: center;
	margin-left: auto;
}

.fashionpoint-category-chevron {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #f3f4f6;
	transition: transform 0.25s ease, background 0.2s ease;
}

.fashionpoint-category-chevron svg {
	color: #6b7280 !important;
}

.fashionpoint-category-section.collapsed .fashionpoint-category-chevron {
	transform: rotate(-90deg);
}

.fashionpoint-category-promo-badge-container {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
}

/* Inline promo badge in cards - left aligned */
.fp-card-inline-promo {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

.fp-card-inline-promo .fashionpoint-category-promo-badge-container {
	justify-content: flex-start;
}

.fashionpoint-category-promo-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 10px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.03em;
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
	color: #fff !important;
}

.fashionpoint-category-promo-badge svg {
	color: #fff !important;
}

/* =============================================
	SERVICE CELL & TITLE
	============================================= */
.fashionpoint-service-cell-container {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.fashionpoint-service-title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 500;
}

/* =============================================
	PROMO BADGES
	============================================= */
.fashionpoint-promo-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.fashionpoint-promo-label {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
	color: #fff !important;
}

.fashionpoint-discount-badge {
	display: inline-block;
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	background: #fef2f2 !important;
	color: #dc2626 !important;
}

.fashionpoint-promo-star-badge {
	display: inline-block;
	padding: 1px 6px;
	border-radius: 3px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: #fef2f2 !important;
	color: #dc2626 !important;
}

.fashionpoint-promo-row {
	background: #fffbeb !important;
}

/* Reina-style promo badge (premium-black) */
.fashionpoint-reina-promo-badge-wrapper {
	margin-bottom: 2px;
}

.fashionpoint-reina-promo-badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: linear-gradient(135deg, #c9963a 0%, #b97b12 100%) !important;
	color: #fff !important;
}

/* =============================================
	DURATION
	============================================= */
.fashionpoint-duration-display {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	border-radius: 6px;
	font-size: 13px;
	color: #4b5563 !important;
	background: #f3f4f6 !important;
}

.fashionpoint-duration-display svg {
	flex-shrink: 0;
}

.fashionpoint-duration-icon {
	color: #6b7280 !important;
}

.fashionpoint-duration-inline {
	font-size: 13px;
	color: #6b7280 !important;
	margin-top: 2px;
}

.fashionpoint-no-duration {
	color: #d1d5db !important;
}

/* =============================================
	PRICE DISPLAY
	============================================= */
.fashionpoint-price-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.fashionpoint-old-price {
	font-size: 13px;
	color: #9ca3af !important;
	text-decoration: line-through;
}

.fashionpoint-current-price {
	font-weight: 700;
	font-size: 15px;
}

.fashionpoint-price-display {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.fashionpoint-price-promo-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.fashionpoint-price-wrapper {
	font-weight: 600;
}

.fashionpoint-price-eur,
.fashionpoint-price-bgn {
	white-space: nowrap;
}

.fashionpoint-price-promo {
	color: #dc2626 !important;
	font-weight: 700;
}

.fp-price-cell {
	text-align: center;
}

.text-align-left { text-align: left; }
.text-align-center { text-align: center; }

/* =============================================
	PACKAGE ITEMS LIST
	============================================= */
.fashionpoint-packages-section .fashionpoint-package-items,
.fashionpoint-all-services-container .fashionpoint-package-items {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.fashionpoint-packages-section .fashionpoint-package-item,
.fashionpoint-all-services-container .fashionpoint-package-item {
	padding-left: 0 !important;
}

.fashionpoint-packages-section .fashionpoint-package-item::before,
.fashionpoint-all-services-container .fashionpoint-package-item::before {
	content: none !important;
}

.fashionpoint-package-items-list {
	list-style: none;
	padding: 0;
	margin: 6px 0 0 0;
}

.fashionpoint-package-item {
	padding: 3px 0;
	font-size: 13px;
	color: #6b7280 !important;
	position: relative;
	padding-left: 0;
}

.fashionpoint-package-item::before {
	content: none;
}

.fashionpoint-package-item-name {
	color: inherit;
}

/* Mobile cards: keep package items visible and aligned */
.fashionpoint-services-cards-wrapper .fashionpoint-package-items-list {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin: 8px 0 0;
	padding: 0;
}

.fashionpoint-services-cards-wrapper .fashionpoint-package-item {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 0;
	color: inherit;
}

/* =============================================
	PRODUCT ACTIONS
	============================================= */
.fashionpoint-product-action {
	display: flex;
	justify-content: center;
}

.fashionpoint-product-action .fashionpoint-booking-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
}

.fashionpoint-product-unavailable {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 13px;
	color: #9ca3af;
	background: #f9fafb;
	border: 1px solid #e5e7eb;
}

/* =============================================
	FLEX UTILITIES
	============================================= */
.fp-flex-center {
	display: flex;
	justify-content: center;
	align-items: center;
}

/* Compact variant used by custom table shortcode */
.fp-custom-table-compact .fashionpoint-category-header {
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

.fp-custom-table-compact .fashionpoint-services-table-wrapper {
	margin: 0 !important;
	padding: 0 !important;
}

.fp-custom-table-compact .fashionpoint-services-table.compact th,
.fp-custom-table-compact .fashionpoint-services-table.compact td {
	padding: 10px 12px !important;
}

/* =============================================
	MOBILE CARDS
	============================================= */
.fp-card-promo-container {
	margin-bottom: 8px;
}

.fp-card-promo-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
	color: #fff;
}

.fp-card-title-container {
	margin-bottom: 6px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.fp-card-title-container .fp-card-inline-promo {
	align-self: flex-start;
	width: auto;
}

.fp-card-title {
	font-weight: 400;
	font-size: 16px;
	color: inherit;
}

.fp-card-duration {
	font-size: 13px;
	color: #6b7280;
	margin-bottom: 6px;
}

.fp-card-location {
	font-size: 13px;
	color: #6b7280;
	margin-bottom: 6px;
}

.fp-card-old-price-container {
	margin-bottom: 2px;
}

.fp-card-old-price {
	font-size: 13px;
	color: #9ca3af;
	text-decoration: line-through;
}

.fp-card-current-price {
	font-weight: 400;
	font-size: 16px;
	margin-bottom: 12px;
}

/* =============================================
	LOCATION MODAL OPTIONS
	============================================= */
.fashionpoint-location-option {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 14px 18px !important;
	border: 1px solid #e5e7eb !important;
	border-radius: 10px !important;
	background: #fff !important;
	color: #1f1f1f !important;
	cursor: pointer !important;
	transition: all 0.2s ease !important;
	margin-bottom: 10px !important;
	position: relative !important;
	overflow: hidden !important;
	text-decoration: none !important;
}

.fashionpoint-location-option::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 4px;
	background: #111827;
	border-radius: 0 2px 2px 0;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.fashionpoint-location-option:hover {
	border-color: #111827;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.fashionpoint-location-option:hover::before {
	opacity: 1;
}

.fashionpoint-location-option-name {
	font-weight: 600;
	font-size: 15px;
}

/* =============================================
	RESPONSIVE
	============================================= */
@media (max-width: 1200px) {
	.fashionpoint-all-services-container { padding: 0; }
}

@media (max-width: 768px) {
	.fashionpoint-all-services-container { padding: 0; }
	.fashionpoint-all-services-container .fashionpoint-services-table { min-width: 720px; }
	.fp-booking .fashionpoint-all-services-container .fashionpoint-services-table { min-width: 0; width: 100%; }
	body .fashionpoint-all-services-container .fashionpoint-desktop-view,
	body .fashionpoint-all-services-container .fashionpoint-services-table-wrapper.fashionpoint-desktop-view { display: none !important; }
	body .fashionpoint-all-services-container .fashionpoint-mobile-view,
	body .fashionpoint-all-services-container .fashionpoint-services-cards-wrapper.fashionpoint-mobile-view  { display: block !important; }

	.fashionpoint-search-filter-row {
		flex-direction: column;
	}

	.fashionpoint-location-filter-container {
		min-width: 100%;
	}

	.fashionpoint-type-toggle {
		width: 100%;
	}

	.fashionpoint-type-toggle-btn {
		flex: 1;
		justify-content: center;
		padding: 8px 12px;
		font-size: 14px;
	}

	.fashionpoint-type-toggle-icon {
		display: none;
	}
}

@media (max-width: 480px) {
	.fashionpoint-all-services-container { padding: 0; }

	.fashionpoint-service-card {
		padding: 6px;
		margin-bottom: 10px;
		width: 90%;
	}

	/* Keep icons visible on mobile (smaller size for fit) */
	.fashionpoint-type-toggle-icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 36px;
		height: 36px;
	}

	.fashionpoint-type-toggle-icon svg {
		width: 30px;
		height: 30px;
	}

	.fp-card-title {
		font-size: 15px;
	}

	.fp-card-current-price {
		font-size: 15px;
	}
}

/* Info / empty-state message */
.fashionpoint-info {
	text-align: center;
	padding: 40px 20px;
	color: #6b7280;
	font-size: 14px;
}

/* Modal base styles */
.fashionpoint-modal {
	position: fixed;
	inset: 0;
	align-items: center;
	justify-content: center;
	z-index: 9999;
	display: none;
}

.fashionpoint-modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	z-index: 9998;
}

.fashionpoint-modal-content {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #ffffff;
	border-radius: 18px;
	max-width: 520px;
	width: calc(100% - 32px);
	max-height: calc(100vh - 40px);
	box-shadow: 0 18px 45px rgba(0, 0, 0, 0.25);
	overflow: hidden;
	z-index: 9999;
}

.fashionpoint-modal-header {
	padding: 16px 24px;
	background: #f5f5f5;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.fashionpoint-modal-title {
	margin: 0;
	font-size: 18px;
	font-weight: 700;
}

.fashionpoint-modal-close {
	background: transparent !important;
	border: none !important;
	font-size: 20px !important;
	cursor: pointer !important;
	padding: 4px !important;
	color: #6b7280 !important;
	line-height: 1 !important;
}

.fashionpoint-modal-body {
	padding: 20px 24px 24px;
}
