.wpbs-booking-shell {
	box-sizing: border-box;
	margin: 0;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
	padding: 1rem;
	width: 100vw;
}

.wpbs-booking-shell * {
	box-sizing: border-box;
}

.wpbs-booking-root {
	--wpbs-accent: #1f6b3f;
	--wpbs-accent-strong: #175534;
	--wpbs-accent-soft-bg: #eff5f0;
	--wpbs-accent-soft-hover: #dfece1;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(45, 140, 74, 0.14);
	--wpbs-accent-shadow: rgba(21, 63, 41, 0.25);
}

.wpbs-booking-root[data-theme='ocean'] {
	--wpbs-accent: #1c6ea4;
	--wpbs-accent-strong: #155680;
	--wpbs-accent-soft-bg: #eaf3fb;
	--wpbs-accent-soft-hover: #d7e8f8;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(28, 110, 164, 0.2);
	--wpbs-accent-shadow: rgba(18, 66, 98, 0.26);
}

.wpbs-booking-root[data-theme='sunset'] {
	--wpbs-accent: #c7642d;
	--wpbs-accent-strong: #a24f22;
	--wpbs-accent-soft-bg: #fbefe8;
	--wpbs-accent-soft-hover: #f5dfd0;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(199, 100, 45, 0.2);
	--wpbs-accent-shadow: rgba(120, 58, 22, 0.25);
}

.wpbs-booking-root[data-theme='mono'] {
	--wpbs-accent: #3b4752;
	--wpbs-accent-strong: #2f3942;
	--wpbs-accent-soft-bg: #eceff2;
	--wpbs-accent-soft-hover: #dde2e7;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(59, 71, 82, 0.2);
	--wpbs-accent-shadow: rgba(33, 39, 45, 0.24);
}

.wpbs-booking-root[data-theme='berry'] {
	--wpbs-accent: #a13b62;
	--wpbs-accent-strong: #7f2f4e;
	--wpbs-accent-soft-bg: #f8edf2;
	--wpbs-accent-soft-hover: #f1dce7;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(161, 59, 98, 0.2);
	--wpbs-accent-shadow: rgba(92, 31, 56, 0.24);
}

.wpbs-booking-root[data-theme='copper'] {
	--wpbs-accent: #9a5a2f;
	--wpbs-accent-strong: #7a4826;
	--wpbs-accent-soft-bg: #f8f0e8;
	--wpbs-accent-soft-hover: #efdfd0;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(154, 90, 47, 0.2);
	--wpbs-accent-shadow: rgba(89, 49, 24, 0.24);
}

.wpbs-booking-root[data-theme='teal'] {
	--wpbs-accent: #1f7e77;
	--wpbs-accent-strong: #19655f;
	--wpbs-accent-soft-bg: #e9f6f4;
	--wpbs-accent-soft-hover: #d6eeea;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(31, 126, 119, 0.2);
	--wpbs-accent-shadow: rgba(22, 77, 73, 0.24);
}

.wpbs-booking-root[data-theme='midnight'] {
	--wpbs-accent: #334b8d;
	--wpbs-accent-strong: #293c70;
	--wpbs-accent-soft-bg: #edf0fa;
	--wpbs-accent-soft-hover: #dce3f5;
	--wpbs-accent-contrast: #ffffff;
	--wpbs-accent-ring: rgba(51, 75, 141, 0.2);
	--wpbs-accent-shadow: rgba(31, 44, 84, 0.24);
}

h1.entry-title {
	display: none;
}

#site-header .site-navigation .menu > li > a,
#site-header .site-navigation-dropdown .menu > li > a {
	background: linear-gradient(180deg, #ffffff 0%, #f4faf6 100%);
	border: 1px solid #d6e3da;
	border-radius: 999px;
	color: #1f6b3f !important;
	font-weight: 600;
	padding: 0.48rem 0.9rem;
	transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

#site-header .site-navigation .menu,
#site-header .site-navigation-dropdown .menu {
	gap: 0.4rem;
}

#site-header .site-navigation .menu > li > a:hover,
#site-header .site-navigation .menu > li.current-menu-item > a,
#site-header .site-navigation .menu > li.current_page_item > a,
#site-header .site-navigation-dropdown .menu > li > a:hover,
#site-header .site-navigation-dropdown .menu > li.current-menu-item > a,
#site-header .site-navigation-dropdown .menu > li.current_page_item > a {
	background: linear-gradient(180deg, #2a8f4b 0%, #1f6b3f 100%);
	border-color: #1f6b3f;
	box-shadow: 0 8px 18px rgba(20, 48, 33, 0.16);
	color: #ffffff !important;
}

#site-header .site-branding.show-title {
	display: none !important;
}

#site-header .header-inner {
	padding-left: 0 !important;
}

#site-header .site-navigation.show {
	margin-left: 0 !important;
}

.wpbs-booking-app {
	background: linear-gradient(180deg, #f5f7f5 0%, #ffffff 35%);
	border: 1px solid #e5e8e5;
	border-radius: 16px;
	min-height: calc(100vh - 2rem);
	padding: 1.25rem;
}

.wpbs-eyebrow {
	color: #3d5a4a;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.4rem;
	text-transform: uppercase;
}

.wpbs-title {
	color: #122117;
	font-size: clamp(1.6rem, 2.4vw, 2.2rem);
	margin: 0;
}

.wpbs-subtitle {
	color: #3d4b42;
	margin: 0.6rem 0 0;
	max-width: 60ch;
}

.wpbs-header {
	align-items: flex-start;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
}

.wpbs-header-main {
	flex: 1 1 auto;
	min-width: 0;
}

.wpbs-brand-logo-wrap {
	margin: 0 0 0.55rem;
}

.wpbs-brand-logo {
	border: 1px solid #d9e5dc;
	border-radius: 16px;
	display: block;
	height: 84px;
	object-fit: cover;
	width: 84px;
}

.wpbs-logo-manager {
	background: #ffffff;
	border: 1px solid #dce7df;
	border-radius: 14px;
	margin-bottom: 0.9rem;
	padding: 0.9rem;
}

.wpbs-logo-manager--inline {
	flex: 0 0 260px;
	margin-bottom: 0;
}

.wpbs-logo-manager--compact {
	background: transparent;
	border: 0;
	padding: 0;
}

.wpbs-logo-toggle {
	border-radius: 999px;
	font-size: 0.84rem;
	font-weight: 700;
	margin-top: 0;
	padding: 0.45rem 0.75rem;
}

.wpbs-logo-manager__panel {
	background: #ffffff;
	border: 1px solid #dce7df;
	border-radius: 12px;
	box-shadow: 0 8px 18px rgba(20, 48, 33, 0.08);
	margin-top: 0.45rem;
	padding: 0.7rem;
}

.wpbs-logo-manager__preview {
	border: 1px solid #d9e5dc;
	border-radius: 12px;
	display: block;
	height: 84px;
	object-fit: cover;
	width: 84px;
}

.wpbs-logo-manager__form {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.wpbs-logo-manager__form .wpbs-input[type='file'] {
	flex: 1 1 100%;
}

.wpbs-logo-manager__form .wpbs-card__note {
	margin-right: 0.4rem;
}

.wpbs-logo-manager__form .wpbs-button {
	margin-left: 0.3rem;
}

@media ( max-width: 900px ) {
	.wpbs-header {
		flex-direction: column;
	}

	.wpbs-logo-manager--inline {
		flex: 1 1 auto;
		width: 100%;
	}
}

.wpbs-grid {
	display: grid;
	gap: 1rem;
	margin-top: 1.2rem;
}

.wpbs-panel {
	background: #ffffff;
	border: 1px solid #e6e9e6;
	border-radius: 12px;
	padding: 1rem;
}

.wpbs-panel h3 {
	font-size: 1.05rem;
	margin: 0 0 0.9rem;
}

.wpbs-panel--quick-add {
	background: linear-gradient(180deg, #ffffff 0%, #f8fbf8 100%);
	border-radius: 18px;
	box-shadow: 0 10px 24px rgba(20, 48, 33, 0.06);
	margin-top: 1rem;
	padding: 1.15rem;
}

.wpbs-panel--quick-add .wpbs-input {
	border-radius: 14px;
	padding: 0.72rem 0.9rem;
}

.wpbs-panel--quick-add textarea.wpbs-input {
	border-radius: 14px;
	min-height: 96px;
	resize: vertical;
}

.wpbs-panel--quick-add .wpbs-button {
	border-radius: 999px;
	padding-left: 1.2rem;
	padding-right: 1.2rem;
}

.wpbs-cards {
	display: grid;
	gap: 0.7rem;
}

.wpbs-card {
	background: #f9fbfa;
	border: 1px solid #dbe4dd;
	border-radius: 12px;
	cursor: pointer;
	padding: 0.85rem;
	text-align: left;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.wpbs-card:hover {
	border-color: #7aa588;
	transform: translateY(-1px);
}

.wpbs-card.is-selected {
	border-color: #2d8c4a;
	box-shadow: 0 0 0 2px rgba(45, 140, 74, 0.16);
}

.wpbs-card__category {
	color: #5a6e61;
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	margin-bottom: 0.3rem;
	text-transform: uppercase;
}

.wpbs-card__title {
	color: #16231b;
	font-size: 1rem;
	margin: 0;
}

.wpbs-card__meta,
.wpbs-card__note {
	color: #405248;
	font-size: 0.9rem;
	margin: 0.35rem 0 0;
}

.wpbs-label {
	color: #27352d;
	display: block;
	font-size: 0.85rem;
	font-weight: 600;
	margin: 0.4rem 0 0.3rem;
}

.wpbs-input {
	border: 1px solid #ccd7d0;
	border-radius: 8px;
	font-size: 0.95rem;
	margin-bottom: 0.4rem;
	padding: 0.65rem 0.75rem;
	width: 100%;
}

.wpbs-booking-app .wpbs-search-input {
	background: linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%) !important;
	border: 1px solid #c9d9cf !important;
	border-radius: 999px !important;
	box-shadow: 0 8px 22px rgba(20, 48, 33, 0.07) !important;
	font-size: 0.96rem;
	margin-bottom: 0.2rem;
	padding: 0.75rem 1rem !important;
	transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.wpbs-booking-app .wpbs-search-input:focus {
	border-color: #2d8c4a !important;
	box-shadow: 0 0 0 3px rgba(45, 140, 74, 0.14), 0 10px 22px rgba(20, 48, 33, 0.09) !important;
	outline: none;
}

.wpbs-summary {
	background: #f8fbf8;
	border: 1px solid #e1e8e2;
	border-radius: 10px;
	margin-top: 0.9rem;
	padding: 0.9rem;
}

.wpbs-summary h4 {
	margin: 0 0 0.65rem;
}

.wpbs-summary p {
	margin: 0.35rem 0;
}

.wpbs-button {
	background: #1f6b3f;
	border: 0;
	border-radius: 9px;
	color: #ffffff;
	cursor: pointer;
	font-weight: 700;
	margin-top: 0.7rem;
	padding: 0.7rem 1rem;
}

.wpbs-button,
.wpbs-button:visited,
.wpbs-button:hover,
.wpbs-button:focus {
	color: #ffffff;
	text-decoration: none;
}

.wpbs-button:hover {
	background: #175534;
}

.wpbs-button--secondary {
	background: #eff5f0;
	color: #1f6b3f;
	margin-top: 0;
}

.wpbs-button--secondary,
.wpbs-button--secondary:visited,
.wpbs-button--secondary:hover,
.wpbs-button--secondary:focus {
	color: #1f6b3f;
}

.wpbs-button--secondary:hover {
	background: #dfece1;
}

.wpbs-button--danger {
	background: #8d2020;
}

.wpbs-button--danger:hover {
	background: #731818;
}

.wpbs-auth-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	margin-top: 0.9rem;
}

.wpbs-auth-actions .wpbs-button {
	display: inline-flex;
	margin-top: 0;
}

.wpbs-panel--week {
	margin-top: 1rem;
}

.wpbs-week-head {
	align-items: flex-end;
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	justify-content: space-between;
	margin-bottom: 0.6rem;
}

.wpbs-week-head h3 {
	margin: 0;
}

.wpbs-week-nav {
	display: flex;
	gap: 0.5rem;
}

.wpbs-week-grid {
	display: grid;
	gap: 0.65rem;
	margin-top: 0.7rem;
}

.wpbs-week-col {
	background: #f8fbf8;
	border: 1px solid #e2e9e3;
	border-radius: 12px;
	padding: 0.65rem;
}

.wpbs-week-col h4 {
	margin: 0 0 0.45rem;
}

.wpbs-week-list {
	display: grid;
	gap: 0.35rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.wpbs-week-list li {
	padding: 0;
}

.wpbs-week-item-btn {
	background: #ffffff;
	border: 1px solid #e2e8e3;
	border-radius: 9px;
	cursor: default;
	display: block;
	padding: 0.45rem 0.55rem;
	text-align: left;
	width: 100%;
}

.wpbs-week-item-btn.is-manageable {
	cursor: pointer;
}

.wpbs-week-item-btn.is-manageable:hover {
	border-color: #7da68c;
	box-shadow: 0 0 0 2px rgba(45, 140, 74, 0.1);
}

.wpbs-week-time {
	font-weight: 700;
}

.wpbs-week-meta {
	color: #486055;
	display: block;
	font-size: 0.86rem;
}

.wpbs-week-manage {
	color: #1f6b3f;
	display: block;
	font-size: 0.74rem;
	font-weight: 700;
	margin-top: 0.3rem;
	text-transform: uppercase;
}

.wpbs-manage-panel {
	border-top: 1px solid #e0e8e2;
	margin-top: 0.9rem;
	padding-top: 0.9rem;
}

.wpbs-manage-panel__head {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

.wpbs-manage-close {
	background: #eff5f0;
	border: 1px solid #d2ddd5;
	border-radius: 8px;
	cursor: pointer;
	font-size: 0.8rem;
	font-weight: 600;
	padding: 0.35rem 0.55rem;
}

.wpbs-manage-close:disabled {
	cursor: default;
	opacity: 0.6;
}

.wpbs-manage-backdrop {
	background: rgba(22, 31, 25, 0.46);
	inset: 0;
	position: fixed;
	z-index: 90;
}

.wpbs-manage-panel.is-open {
	background: #ffffff;
	border: 1px solid #dbe5dd;
	border-radius: 14px;
	box-shadow: 0 16px 38px rgba(20, 34, 24, 0.26);
	left: 50%;
	margin: 0;
	max-height: calc(100vh - 48px);
	max-width: 620px;
	overflow-y: auto;
	padding: 1rem;
	position: fixed;
	top: 24px;
	transform: translateX(-50%);
	width: calc(100% - 32px);
	z-index: 91;
}

.wpbs-manage-actions {
	display: flex;
	gap: 0.55rem;
	margin-top: 0.5rem;
}

.wpbs-submit-msg {
	border-radius: 8px;
	font-size: 0.9rem;
	margin: 0.5rem 0 0;
	padding: 0.55rem 0.7rem;
}

.wpbs-submit-msg.is-success {
	background: #ecf9f0;
	border: 1px solid #9fd5ae;
	color: #1f6b3f;
}

.wpbs-submit-msg.is-error {
	background: #fff2f2;
	border: 1px solid #f0b3b3;
	color: #8d2020;
}

.wpbs-week-calendar {
	background: linear-gradient(180deg, #f6faf7 0%, #ffffff 40%);
	border: 1px solid #e2eae3;
	border-radius: 18px;
	margin: 1.5rem 0;
	padding: 1rem;
}

.wpbs-week-calendar__header h3 {
	margin: 0;
}

.wpbs-week-calendar__header p {
	color: #52655a;
	margin: 0.35rem 0 0.9rem;
}

.wpbs-week-calendar__nav {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.7rem;
}

.wpbs-week-calendar__btn {
	background: #eff5f0;
	border-radius: 999px;
	color: #1f6b3f;
	display: inline-block;
	font-size: 0.85rem;
	font-weight: 600;
	padding: 0.45rem 0.8rem;
	text-decoration: none;
}

.wpbs-week-calendar__btn:hover {
	background: #dfece1;
}

.wpbs-week-calendar--timeline {
	overflow-x: auto;
}

.wpbs-timeline {
	display: grid;
	gap: 0.7rem;
	grid-template-columns: 68px minmax(980px, 1fr);
}

.wpbs-time-axis {
	display: grid;
	grid-template-rows: repeat(var(--wpbs-marker-count, 11), 64px);
	padding-top: 2rem;
}

.wpbs-time-axis__hour {
	color: #5a6d61;
	font-size: 0.78rem;
	padding-right: 0.3rem;
	text-align: right;
}

.wpbs-days-grid {
	display: grid;
	gap: 0.65rem;
	grid-template-columns: repeat(7, minmax(130px, 1fr));
}

.wpbs-day-col h4 {
	margin: 0 0 0.45rem;
}

.wpbs-day-track {
	--wpbs-hour-height: 64px;
	background:
		repeating-linear-gradient(
			to bottom,
			#eef4ef 0,
			#eef4ef 1px,
			transparent 1px,
			transparent var(--wpbs-hour-height)
		),
		#ffffff;
	border: 1px solid #dce6de;
	border-radius: 14px;
	height: calc(var(--wpbs-hour-count) * var(--wpbs-hour-height));
	position: relative;
}

.wpbs-day-track__empty {
	color: #6a7d70;
	font-size: 0.85rem;
	left: 50%;
	margin: 0;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
}

.wpbs-slot-card {
	background: linear-gradient(180deg, #2a8f4b 0%, #1f6b3f 100%);
	border: 0;
	border-radius: 10px;
	box-shadow: 0 5px 14px rgba(21, 63, 41, 0.25);
	color: #ffffff;
	cursor: default;
	font: inherit;
	left: 6px;
	margin: 0;
	outline: none;
	padding: 0.38rem 0.45rem;
	position: absolute;
	right: 6px;
	text-align: left;
}

.wpbs-slot-card.is-manageable {
	cursor: pointer;
}

.wpbs-slot-card.is-manageable:hover,
.wpbs-slot-card.is-manageable:focus-visible {
	box-shadow: 0 0 0 2px rgba(213, 242, 221, 0.95), 0 8px 18px rgba(21, 63, 41, 0.28);
}

.wpbs-slot-card__time {
	font-size: 0.74rem;
	font-weight: 700;
}

.wpbs-slot-card__plus {
	background: rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	display: inline-block;
	font-size: 0.74rem;
	font-weight: 800;
	margin-left: 0.35rem;
	padding: 0 0.32rem;
}

.wpbs-slot-card__staff {
	display: block;
	font-size: 0.82rem;
	line-height: 1.2;
}

.wpbs-slot-card__service,
.wpbs-slot-card__customer {
	display: block;
	font-size: 0.72rem;
	opacity: 0.96;
}

.wpbs-manage-hour-list {
	margin-bottom: 0.55rem;
}

.wpbs-manage-hour-items {
	display: grid;
	gap: 0.35rem;
}

.wpbs-manage-hour-item {
	background: #f7faf8;
	border: 1px solid #dfe8e1;
	border-radius: 8px;
	cursor: pointer;
	font-size: 0.82rem;
	padding: 0.4rem 0.55rem;
	text-align: left;
}

.wpbs-manage-hour-item.is-active {
	border-color: #7aa38a;
	box-shadow: 0 0 0 2px rgba(45, 140, 74, 0.12);
}

.wpbs-week-calendar__grid {
	display: grid;
	gap: 0.8rem;
}

.wpbs-week-day {
	background: #ffffff;
	border: 1px solid #e2e8e3;
	border-radius: 14px;
	padding: 0.8rem;
}

.wpbs-week-day h4 {
	margin: 0 0 0.5rem;
}

.wpbs-week-day__empty {
	color: #65776c;
	font-size: 0.9rem;
	margin: 0;
}

.wpbs-week-day__list {
	display: grid;
	gap: 0.45rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.wpbs-week-day__list li {
	background: #f8fbf8;
	border-radius: 10px;
	padding: 0.55rem 0.65rem;
}

.wpbs-week-day__time {
	font-weight: 700;
	margin-right: 0.4rem;
}

.wpbs-week-day__staff {
	color: #1f6b3f;
	font-weight: 600;
	margin-right: 0.4rem;
}

.wpbs-week-day__service,
.wpbs-week-day__customer {
	color: #3d4f45;
	display: block;
	font-size: 0.88rem;
}

.wpbs-account-shell {
	margin: 1.8rem auto;
	max-width: 860px;
}

.wpbs-account-card {
	background: linear-gradient(180deg, #ffffff 0%, #f8fbf8 100%);
	border: 1px solid #dce7df;
	border-radius: 24px;
	box-shadow: 0 14px 34px rgba(20, 48, 33, 0.08);
	padding: 1.25rem;
}

.wpbs-account-head h2 {
	color: #122117;
	margin: 0 0 0.3rem;
}

.wpbs-account-head p {
	color: #41554a;
	margin: 0 0 0.9rem;
}

.wpbs-account-notice {
	border-radius: 14px;
	margin: 0.8rem 0 1rem;
	padding: 0.7rem 0.9rem;
}

.wpbs-account-notice.is-success {
	background: #ecf8f0;
	border: 1px solid #b9dec5;
	color: #195436;
}

.wpbs-account-notice.is-error {
	background: #fdeeee;
	border: 1px solid #efc0c0;
	color: #7e1f1f;
}

.wpbs-account-notice p {
	margin: 0;
}

.wpbs-account-layout {
	display: grid;
	gap: 1rem;
	grid-template-columns: 220px 1fr;
}

.wpbs-account-avatar-card {
	background: #f7fbf8;
	border: 1px solid #dce7df;
	border-radius: 20px;
	padding: 0.9rem;
}

.wpbs-account-avatar-wrap {
	display: flex;
	justify-content: center;
	margin-bottom: 0.7rem;
}

.wpbs-account-avatar {
	border: 2px solid #d1e0d6;
	border-radius: 999px;
	height: 130px;
	object-fit: cover;
	width: 130px;
}

.wpbs-account-avatar--placeholder {
	align-items: center;
	background: linear-gradient(180deg, #eef6f0 0%, #dbeade 100%);
	color: #1f6b3f;
	display: flex;
	font-size: 2rem;
	font-weight: 700;
	justify-content: center;
}

.wpbs-account-file {
	border-radius: 14px;
}

.wpbs-account-fields .wpbs-input {
	border-radius: 14px;
	margin-bottom: 0.55rem;
	padding: 0.7rem 0.85rem;
}

.wpbs-account-grid {
	display: grid;
	gap: 0.8rem;
	grid-template-columns: 1fr 1fr;
}

.wpbs-account-actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 0.6rem;
}

.wpbs-account-save {
	border-radius: 999px;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.wpbs-booking-root .wpbs-card.is-selected {
	border-color: var(--wpbs-accent);
	box-shadow: 0 0 0 2px var(--wpbs-accent-ring);
}

.wpbs-booking-root .wpbs-button {
	background: var(--wpbs-accent);
	color: var(--wpbs-accent-contrast);
}

.wpbs-booking-root .wpbs-button:hover {
	background: var(--wpbs-accent-strong);
}

.wpbs-booking-root .wpbs-button,
.wpbs-booking-root .wpbs-button:visited,
.wpbs-booking-root .wpbs-button:hover,
.wpbs-booking-root .wpbs-button:focus {
	color: var(--wpbs-accent-contrast);
}

.wpbs-booking-root .wpbs-button--secondary {
	background: var(--wpbs-accent-soft-bg);
	color: var(--wpbs-accent);
}

.wpbs-booking-root .wpbs-button--secondary:hover {
	background: var(--wpbs-accent-soft-hover);
}

.wpbs-booking-root .wpbs-button--secondary,
.wpbs-booking-root .wpbs-button--secondary:visited,
.wpbs-booking-root .wpbs-button--secondary:hover,
.wpbs-booking-root .wpbs-button--secondary:focus {
	color: var(--wpbs-accent);
}

.wpbs-booking-root .wpbs-booking-app .wpbs-search-input:focus {
	border-color: var(--wpbs-accent) !important;
	box-shadow: 0 0 0 3px var(--wpbs-accent-ring), 0 10px 22px rgba(20, 48, 33, 0.09) !important;
}

.wpbs-booking-root .wpbs-week-manage,
.wpbs-booking-root .wpbs-week-day__staff,
.wpbs-booking-root .wpbs-slot-card__plus {
	color: var(--wpbs-accent);
}

.wpbs-booking-root .wpbs-week-calendar__btn {
	background: var(--wpbs-accent-soft-bg);
	color: var(--wpbs-accent);
}

.wpbs-booking-root .wpbs-week-calendar__btn:hover {
	background: var(--wpbs-accent-soft-hover);
}

.wpbs-booking-root .wpbs-slot-card {
	background: linear-gradient(180deg, var(--wpbs-accent) 0%, var(--wpbs-accent-strong) 100%);
	box-shadow: 0 5px 14px var(--wpbs-accent-shadow);
}

@media ( min-width: 1024px ) {
	.wpbs-booking-shell {
		padding-left: 2.5rem;
		padding-right: 2.5rem;
	}

	.wpbs-grid {
		grid-template-columns: 1fr 1fr 0.85fr;
	}

	.wpbs-week-calendar__grid {
		grid-template-columns: repeat(7, minmax(0, 1fr));
	}

	.wpbs-week-grid {
		grid-template-columns: repeat(7, minmax(0, 1fr));
	}
}

@media ( max-width: 800px ) {
	.wpbs-booking-shell {
		padding: 0.55rem;
	}

	.wpbs-booking-app {
		border-radius: 12px;
		min-height: auto;
		padding: 0.85rem;
	}

	.wpbs-week-head {
		align-items: stretch;
		flex-direction: column;
		gap: 0.5rem;
	}

	.wpbs-week-nav {
		display: grid;
		gap: 0.45rem;
		grid-template-columns: 1fr 1fr;
		width: 100%;
	}

	.wpbs-week-nav .wpbs-button,
	.wpbs-week-nav .wpbs-week-calendar__btn {
		margin-top: 0;
		text-align: center;
		width: 100%;
	}

	.wpbs-booking-app .wpbs-search-input {
		width: 100%;
	}

	.wpbs-week-calendar {
		border-radius: 14px;
		padding: 0.75rem;
	}

	.wpbs-timeline {
		grid-template-columns: 52px minmax(760px, 1fr);
	}

	.wpbs-manage-panel.is-open {
		border-radius: 12px;
		top: 10px;
		width: calc(100% - 12px);
	}

	.wpbs-manage-actions {
		flex-direction: column;
	}

	.wpbs-manage-actions .wpbs-button {
		margin-top: 0;
		width: 100%;
	}

	.wpbs-logo-manager__form .wpbs-card__note {
		margin-right: 0;
	}

	.wpbs-logo-manager__form .wpbs-button {
		margin-left: 0;
		width: 100%;
	}

	#site-header .site-navigation .menu {
		flex-wrap: wrap;
	}

	.wpbs-account-layout {
		grid-template-columns: 1fr;
	}

	.wpbs-account-grid {
		grid-template-columns: 1fr;
	}

	.wpbs-account-actions {
		justify-content: stretch;
	}
}

:root {
	--wpbs-global-accent: #1f6b3f;
	--wpbs-global-accent-strong: #175534;
	--wpbs-global-accent-soft-bg: #eff5f0;
	--wpbs-global-accent-soft-hover: #dfece1;
	--wpbs-global-accent-ring: rgba(45, 140, 74, 0.14);
	--wpbs-global-accent-shadow: rgba(21, 63, 41, 0.25);
}

body.wpbs-theme-ocean {
	--wpbs-global-accent: #1c6ea4;
	--wpbs-global-accent-strong: #155680;
	--wpbs-global-accent-soft-bg: #eaf3fb;
	--wpbs-global-accent-soft-hover: #d7e8f8;
	--wpbs-global-accent-ring: rgba(28, 110, 164, 0.2);
	--wpbs-global-accent-shadow: rgba(18, 66, 98, 0.26);
}

body.wpbs-theme-sunset {
	--wpbs-global-accent: #c7642d;
	--wpbs-global-accent-strong: #a24f22;
	--wpbs-global-accent-soft-bg: #fbefe8;
	--wpbs-global-accent-soft-hover: #f5dfd0;
	--wpbs-global-accent-ring: rgba(199, 100, 45, 0.2);
	--wpbs-global-accent-shadow: rgba(120, 58, 22, 0.25);
}

body.wpbs-theme-mono {
	--wpbs-global-accent: #3b4752;
	--wpbs-global-accent-strong: #2f3942;
	--wpbs-global-accent-soft-bg: #eceff2;
	--wpbs-global-accent-soft-hover: #dde2e7;
	--wpbs-global-accent-ring: rgba(59, 71, 82, 0.2);
	--wpbs-global-accent-shadow: rgba(33, 39, 45, 0.24);
}

body.wpbs-theme-berry {
	--wpbs-global-accent: #a13b62;
	--wpbs-global-accent-strong: #7f2f4e;
	--wpbs-global-accent-soft-bg: #f8edf2;
	--wpbs-global-accent-soft-hover: #f1dce7;
	--wpbs-global-accent-ring: rgba(161, 59, 98, 0.2);
	--wpbs-global-accent-shadow: rgba(92, 31, 56, 0.24);
}

body.wpbs-theme-copper {
	--wpbs-global-accent: #9a5a2f;
	--wpbs-global-accent-strong: #7a4826;
	--wpbs-global-accent-soft-bg: #f8f0e8;
	--wpbs-global-accent-soft-hover: #efdfd0;
	--wpbs-global-accent-ring: rgba(154, 90, 47, 0.2);
	--wpbs-global-accent-shadow: rgba(89, 49, 24, 0.24);
}

body.wpbs-theme-teal {
	--wpbs-global-accent: #1f7e77;
	--wpbs-global-accent-strong: #19655f;
	--wpbs-global-accent-soft-bg: #e9f6f4;
	--wpbs-global-accent-soft-hover: #d6eeea;
	--wpbs-global-accent-ring: rgba(31, 126, 119, 0.2);
	--wpbs-global-accent-shadow: rgba(22, 77, 73, 0.24);
}

body.wpbs-theme-midnight {
	--wpbs-global-accent: #334b8d;
	--wpbs-global-accent-strong: #293c70;
	--wpbs-global-accent-soft-bg: #edf0fa;
	--wpbs-global-accent-soft-hover: #dce3f5;
	--wpbs-global-accent-ring: rgba(51, 75, 141, 0.2);
	--wpbs-global-accent-shadow: rgba(31, 44, 84, 0.24);
}

.wpbs-booking-root {
	--wpbs-accent: var(--wpbs-global-accent);
	--wpbs-accent-strong: var(--wpbs-global-accent-strong);
	--wpbs-accent-soft-bg: var(--wpbs-global-accent-soft-bg);
	--wpbs-accent-soft-hover: var(--wpbs-global-accent-soft-hover);
	--wpbs-accent-ring: var(--wpbs-global-accent-ring);
	--wpbs-accent-shadow: var(--wpbs-global-accent-shadow);
}

#site-header .site-navigation .menu > li > a,
#site-header .site-navigation-dropdown .menu > li > a {
	color: var(--wpbs-global-accent) !important;
}

#site-header .site-navigation .menu > li > a:hover,
#site-header .site-navigation .menu > li.current-menu-item > a,
#site-header .site-navigation .menu > li.current_page_item > a,
#site-header .site-navigation-dropdown .menu > li > a:hover,
#site-header .site-navigation-dropdown .menu > li.current-menu-item > a,
#site-header .site-navigation-dropdown .menu > li.current_page_item > a {
	background: linear-gradient(180deg, var(--wpbs-global-accent) 0%, var(--wpbs-global-accent-strong) 100%);
	border-color: var(--wpbs-global-accent-strong);
	box-shadow: 0 8px 18px var(--wpbs-global-accent-shadow);
}

.wpbs-booking-root .wpbs-card:hover {
	border-color: var(--wpbs-accent);
	box-shadow: 0 0 0 2px var(--wpbs-accent-ring);
}

.wpbs-booking-root .wpbs-week-item-btn.is-manageable:hover,
.wpbs-booking-root .wpbs-manage-hour-item.is-active,
.wpbs-booking-root .wpbs-slot-card.is-manageable:hover,
.wpbs-booking-root .wpbs-slot-card.is-manageable:focus-visible {
	border-color: var(--wpbs-accent);
	box-shadow: 0 0 0 2px var(--wpbs-accent-ring);
}
