/**
 * AstroChat Booking Pro — front-end styles.
 *
 * All rules are scoped under .acbp-root so the plugin never bleeds into the
 * surrounding theme. Colours are driven by CSS custom properties; the active
 * palette is chosen by the [data-acbp-theme] attribute (auto|light|dark),
 * which is set inline by ACBP_Assets and/or toggled by acbp-frontend.js.
 */

/* ---------- Palette: dark (default / cosmic night) ---------- */
.acbp-root {
	--acbp-bg: #0f0a23;
	--acbp-surface: #1a1340;
	--acbp-surface-2: #241a52;
	--acbp-border: #322a63;
	--acbp-text: #ece9ff;
	--acbp-muted: #a39ed1;
	--acbp-primary: #7c5cff;
	--acbp-primary-600: #6a47f5;
	--acbp-accent: #ffc14d;
	--acbp-accent-600: #f5a623;
	--acbp-success: #3ddc97;
	--acbp-danger: #ff6b81;
	--acbp-online: #3ddc97;
	--acbp-offline: #6b6792;
	--acbp-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
	--acbp-radius: 16px;
	--acbp-radius-sm: 10px;
	--acbp-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	color: var(--acbp-text);
	font-family: var(--acbp-font);
	line-height: 1.55;
	box-sizing: border-box;
}

/* ---------- Palette: light ---------- */
.acbp-root[data-acbp-theme="light"] {
	--acbp-bg: #f5f3ff;
	--acbp-surface: #ffffff;
	--acbp-surface-2: #f1edff;
	--acbp-border: #e2dcf7;
	--acbp-text: #1c1640;
	--acbp-muted: #6b6592;
	--acbp-primary: #6a47f5;
	--acbp-primary-600: #5836d6;
	--acbp-accent: #e89a1c;
	--acbp-accent-600: #c97f0e;
	--acbp-success: #1aa472;
	--acbp-danger: #e23b53;
	--acbp-online: #1aa472;
	--acbp-offline: #b9b4d6;
	--acbp-shadow: 0 12px 32px rgba(80, 60, 160, 0.14);
}

/* honour OS preference when set to auto */
@media (prefers-color-scheme: light) {
	.acbp-root[data-acbp-theme="auto"] {
		--acbp-bg: #f5f3ff;
		--acbp-surface: #ffffff;
		--acbp-surface-2: #f1edff;
		--acbp-border: #e2dcf7;
		--acbp-text: #1c1640;
		--acbp-muted: #6b6592;
		--acbp-primary: #6a47f5;
		--acbp-primary-600: #5836d6;
		--acbp-accent: #e89a1c;
		--acbp-accent-600: #c97f0e;
		--acbp-success: #1aa472;
		--acbp-danger: #e23b53;
		--acbp-online: #1aa472;
		--acbp-offline: #b9b4d6;
		--acbp-shadow: 0 12px 32px rgba(80, 60, 160, 0.14);
	}
}

.acbp-root *,
.acbp-root *::before,
.acbp-root *::after {
	box-sizing: border-box;
}

/* ---------- Layout shell ---------- */
.acbp-root {
	background:
		radial-gradient(1200px 600px at 15% -10%, rgba(124, 92, 255, 0.18), transparent 60%),
		radial-gradient(900px 500px at 110% 10%, rgba(255, 193, 77, 0.10), transparent 55%),
		var(--acbp-bg);
	padding: 28px;
	border-radius: var(--acbp-radius);
}

.acbp-section-heading {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	margin: 0 0 18px;
	flex-wrap: wrap;
}

.acbp-section-heading h2 {
	margin: 0;
	font-size: 1.5rem;
	letter-spacing: 0.2px;
}

.acbp-count {
	color: var(--acbp-muted);
	font-size: 0.9rem;
}

/* ---------- Filter bar ---------- */
.acbp-filters {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr auto;
	gap: 10px;
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	padding: 14px;
	margin-bottom: 22px;
	box-shadow: var(--acbp-shadow);
}

.acbp-filters input[type="search"],
.acbp-filters select {
	width: 100%;
	padding: 10px 12px;
	border-radius: var(--acbp-radius-sm);
	border: 1px solid var(--acbp-border);
	background: var(--acbp-surface-2);
	color: var(--acbp-text);
	font-size: 0.95rem;
}

.acbp-filter-toggle {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--acbp-muted);
	font-size: 0.9rem;
	white-space: nowrap;
}

/* ---------- Grid + cards ---------- */
.acbp-grid {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(var(--acbp-columns, 3), minmax(0, 1fr));
}

.acbp-card {
	position: relative;
	background: linear-gradient(180deg, var(--acbp-surface-2), var(--acbp-surface));
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	padding: 20px;
	box-shadow: var(--acbp-shadow);
	transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
	overflow: hidden;
}

.acbp-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: linear-gradient(90deg, var(--acbp-primary), var(--acbp-accent));
	opacity: 0.85;
}

.acbp-card:hover {
	transform: translateY(-4px);
	border-color: var(--acbp-primary);
}

.acbp-card-top {
	display: flex;
	gap: 14px;
	align-items: center;
}

.acbp-avatar {
	position: relative;
	width: 66px;
	height: 66px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--acbp-primary);
	flex: 0 0 auto;
}

.acbp-avatar-wrap {
	position: relative;
	flex: 0 0 auto;
}

.acbp-dot {
	position: absolute;
	right: 2px;
	bottom: 2px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 2px solid var(--acbp-surface);
	background: var(--acbp-offline);
}

.acbp-dot.is-online {
	background: var(--acbp-online);
	box-shadow: 0 0 0 4px rgba(61, 220, 151, 0.18);
}

.acbp-card-name {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 650;
}

.acbp-card-tagline {
	margin: 2px 0 0;
	color: var(--acbp-muted);
	font-size: 0.88rem;
}

.acbp-rating {
	color: var(--acbp-accent);
	font-size: 0.95rem;
	letter-spacing: 1px;
}

.acbp-rating small {
	color: var(--acbp-muted);
	letter-spacing: 0;
	margin-left: 4px;
}

.acbp-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 12px 0 0;
}

.acbp-badge {
	font-size: 0.72rem;
	font-weight: 600;
	padding: 3px 9px;
	border-radius: 999px;
	background: rgba(255, 193, 77, 0.14);
	color: var(--acbp-accent);
	border: 1px solid rgba(255, 193, 77, 0.35);
}

.acbp-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 12px 0 0;
}

.acbp-tag {
	font-size: 0.75rem;
	padding: 3px 9px;
	border-radius: 999px;
	background: var(--acbp-surface-2);
	color: var(--acbp-muted);
	border: 1px solid var(--acbp-border);
}

.acbp-card-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 16px;
	gap: 10px;
}

.acbp-price {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--acbp-text);
}

.acbp-price small {
	font-weight: 500;
	color: var(--acbp-muted);
}

.acbp-card-actions {
	display: flex;
	gap: 8px;
	margin-top: 16px;
}

/* ---------- Buttons ---------- */
.acbp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 11px 18px;
	border-radius: var(--acbp-radius-sm);
	border: 1px solid transparent;
	font-size: 0.95rem;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	transition: transform 0.12s ease, opacity 0.12s ease, background 0.12s ease;
	line-height: 1;
}

.acbp-btn:active {
	transform: translateY(1px);
}

.acbp-btn-primary {
	background: linear-gradient(135deg, var(--acbp-primary), var(--acbp-primary-600));
	color: #fff;
}

.acbp-btn-primary:hover {
	opacity: 0.92;
}

.acbp-btn-accent {
	background: linear-gradient(135deg, var(--acbp-accent), var(--acbp-accent-600));
	color: #2a1c00;
}

.acbp-btn-ghost {
	background: transparent;
	color: var(--acbp-text);
	border-color: var(--acbp-border);
}

.acbp-btn-ghost:hover {
	border-color: var(--acbp-primary);
}

.acbp-btn-block {
	width: 100%;
}

.acbp-btn[disabled] {
	opacity: 0.55;
	cursor: not-allowed;
}

.acbp-fav {
	background: transparent;
	border: 1px solid var(--acbp-border);
	color: var(--acbp-muted);
	border-radius: var(--acbp-radius-sm);
	width: 42px;
	cursor: pointer;
	font-size: 1.1rem;
}

.acbp-fav.is-active {
	color: var(--acbp-danger);
	border-color: var(--acbp-danger);
}

/* ---------- Pagination / load more ---------- */
.acbp-loadmore-wrap {
	display: flex;
	justify-content: center;
	margin-top: 26px;
}

.acbp-empty {
	text-align: center;
	color: var(--acbp-muted);
	padding: 40px 0;
}

/* ---------- Modal ---------- */
.acbp-modal {
	position: fixed;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(8, 5, 24, 0.72);
	backdrop-filter: blur(4px);
	z-index: 99999;
	padding: 20px;
}

.acbp-modal.is-open {
	display: flex;
}

.acbp-modal-card {
	width: 100%;
	max-width: 520px;
	max-height: 92vh;
	overflow-y: auto;
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	box-shadow: var(--acbp-shadow);
	padding: 26px;
	color: var(--acbp-text);
}

.acbp-modal-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 18px;
}

.acbp-modal-head h3 {
	margin: 0;
	font-size: 1.3rem;
}

.acbp-modal-close {
	background: none;
	border: none;
	color: var(--acbp-muted);
	font-size: 1.6rem;
	line-height: 1;
	cursor: pointer;
}

/* ---------- Forms ---------- */
.acbp-field {
	margin-bottom: 14px;
}

.acbp-field label {
	display: block;
	font-size: 0.85rem;
	font-weight: 600;
	margin-bottom: 6px;
	color: var(--acbp-muted);
}

.acbp-field input,
.acbp-field select,
.acbp-field textarea {
	width: 100%;
	padding: 11px 12px;
	border-radius: var(--acbp-radius-sm);
	border: 1px solid var(--acbp-border);
	background: var(--acbp-surface-2);
	color: var(--acbp-text);
	font-size: 0.95rem;
	font-family: inherit;
}

.acbp-field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.acbp-slots {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 6px;
}

.acbp-slot {
	padding: 8px 12px;
	border-radius: var(--acbp-radius-sm);
	border: 1px solid var(--acbp-border);
	background: var(--acbp-surface-2);
	color: var(--acbp-text);
	cursor: pointer;
	font-size: 0.88rem;
}

.acbp-slot.is-selected {
	background: var(--acbp-primary);
	border-color: var(--acbp-primary);
	color: #fff;
}

.acbp-feedback {
	font-size: 0.9rem;
	margin-top: 10px;
	min-height: 1.2em;
}

.acbp-feedback.is-error {
	color: var(--acbp-danger);
}

.acbp-feedback.is-success {
	color: var(--acbp-success);
}

/* ---------- Wallet ---------- */
.acbp-wallet-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.acbp-balance-card {
	background: linear-gradient(135deg, var(--acbp-primary), var(--acbp-primary-600));
	color: #fff;
	border-radius: var(--acbp-radius);
	padding: 26px;
	box-shadow: var(--acbp-shadow);
}

.acbp-balance-card .acbp-balance-amount {
	font-size: 2.4rem;
	font-weight: 800;
	margin: 6px 0 0;
}

.acbp-panel {
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	padding: 22px;
	box-shadow: var(--acbp-shadow);
}

.acbp-panel h3 {
	margin: 0 0 14px;
}

.acbp-chip-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 12px;
}

.acbp-chip {
	padding: 8px 14px;
	border-radius: 999px;
	border: 1px solid var(--acbp-border);
	background: var(--acbp-surface-2);
	color: var(--acbp-text);
	cursor: pointer;
	font-weight: 600;
}

.acbp-chip.is-selected {
	background: var(--acbp-accent);
	border-color: var(--acbp-accent);
	color: #2a1c00;
}

.acbp-txn-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}

.acbp-txn-table th,
.acbp-txn-table td {
	text-align: left;
	padding: 10px 8px;
	border-bottom: 1px solid var(--acbp-border);
}

.acbp-txn-table th {
	color: var(--acbp-muted);
	font-weight: 600;
}

.acbp-amount-pos {
	color: var(--acbp-success);
}

.acbp-amount-neg {
	color: var(--acbp-danger);
}

.acbp-referral-code {
	font-family: monospace;
	font-size: 1.2rem;
	letter-spacing: 2px;
	background: var(--acbp-surface-2);
	border: 1px dashed var(--acbp-primary);
	border-radius: var(--acbp-radius-sm);
	padding: 10px 14px;
	display: inline-block;
}

/* ---------- Chat ---------- */
.acbp-chat {
	display: flex;
	flex-direction: column;
	height: min(78vh, 720px);
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	overflow: hidden;
	box-shadow: var(--acbp-shadow);
}

.acbp-chat-header {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	border-bottom: 1px solid var(--acbp-border);
	background: var(--acbp-surface-2);
}

.acbp-chat-header .acbp-avatar {
	width: 44px;
	height: 44px;
}

.acbp-chat-peer {
	flex: 1;
	min-width: 0;
}

.acbp-chat-peer h3 {
	margin: 0;
	font-size: 1rem;
}

.acbp-chat-status {
	font-size: 0.8rem;
	color: var(--acbp-muted);
}

.acbp-chat-meters {
	display: flex;
	gap: 16px;
	text-align: right;
}

.acbp-meter .acbp-meter-value {
	font-weight: 700;
	font-size: 1rem;
}

.acbp-meter .acbp-meter-label {
	font-size: 0.7rem;
	color: var(--acbp-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.acbp-meter.is-low .acbp-meter-value {
	color: var(--acbp-danger);
}

.acbp-chat-body {
	flex: 1;
	overflow-y: auto;
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	background:
		radial-gradient(600px 300px at 90% 0%, rgba(124, 92, 255, 0.08), transparent 60%),
		var(--acbp-bg);
}

.acbp-msg {
	max-width: 76%;
	padding: 10px 14px;
	border-radius: 14px;
	font-size: 0.95rem;
	position: relative;
	word-wrap: break-word;
}

.acbp-msg-time {
	display: block;
	font-size: 0.68rem;
	opacity: 0.7;
	margin-top: 4px;
}

.acbp-msg.is-self {
	align-self: flex-end;
	background: linear-gradient(135deg, var(--acbp-primary), var(--acbp-primary-600));
	color: #fff;
	border-bottom-right-radius: 4px;
}

.acbp-msg.is-peer {
	align-self: flex-start;
	background: var(--acbp-surface-2);
	color: var(--acbp-text);
	border: 1px solid var(--acbp-border);
	border-bottom-left-radius: 4px;
}

.acbp-msg.is-system {
	align-self: center;
	background: transparent;
	color: var(--acbp-muted);
	font-size: 0.82rem;
	max-width: 90%;
	text-align: center;
}

.acbp-typing {
	align-self: flex-start;
	color: var(--acbp-muted);
	font-size: 0.85rem;
	font-style: italic;
	padding: 4px 8px;
	display: none;
}

.acbp-typing.is-active {
	display: block;
}

.acbp-chat-footer {
	border-top: 1px solid var(--acbp-border);
	padding: 12px;
	background: var(--acbp-surface-2);
}

.acbp-chat-inputbar {
	display: flex;
	gap: 8px;
	align-items: center;
}

.acbp-chat-inputbar input {
	flex: 1;
	padding: 12px 14px;
	border-radius: 999px;
	border: 1px solid var(--acbp-border);
	background: var(--acbp-surface);
	color: var(--acbp-text);
	font-size: 0.95rem;
}

.acbp-emoji-btn,
.acbp-send-btn {
	border: none;
	cursor: pointer;
	border-radius: 50%;
	width: 44px;
	height: 44px;
	font-size: 1.15rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.acbp-emoji-btn {
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	color: var(--acbp-text);
}

.acbp-send-btn {
	background: linear-gradient(135deg, var(--acbp-primary), var(--acbp-primary-600));
	color: #fff;
}

.acbp-emoji-tray {
	display: none;
	flex-wrap: wrap;
	gap: 4px;
	padding: 8px 0 2px;
}

.acbp-emoji-tray.is-open {
	display: flex;
}

.acbp-emoji-tray button {
	background: none;
	border: none;
	font-size: 1.3rem;
	cursor: pointer;
	padding: 4px;
	border-radius: 8px;
}

.acbp-emoji-tray button:hover {
	background: var(--acbp-surface);
}

.acbp-chat-toolbar {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	margin-top: 10px;
}

/* low-balance / disconnect overlay */
.acbp-chat-overlay {
	position: absolute;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	background: rgba(8, 5, 24, 0.82);
	backdrop-filter: blur(3px);
	padding: 20px;
	z-index: 5;
}

.acbp-chat-overlay.is-open {
	display: flex;
}

.acbp-overlay-card {
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius);
	padding: 28px;
	text-align: center;
	max-width: 380px;
	box-shadow: var(--acbp-shadow);
}

.acbp-overlay-card h3 {
	margin: 0 0 8px;
}

.acbp-overlay-card p {
	color: var(--acbp-muted);
	margin: 0 0 18px;
}

.acbp-chat-shell {
	position: relative;
}

/* toast */
.acbp-toast {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: var(--acbp-surface);
	color: var(--acbp-text);
	border: 1px solid var(--acbp-border);
	border-left: 4px solid var(--acbp-primary);
	padding: 12px 18px;
	border-radius: var(--acbp-radius-sm);
	box-shadow: var(--acbp-shadow);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease, transform 0.25s ease;
	z-index: 100000;
	max-width: 90vw;
}

.acbp-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

.acbp-toast.is-error {
	border-left-color: var(--acbp-danger);
}

.acbp-toast.is-success {
	border-left-color: var(--acbp-success);
}

/* ---------- Single astrologer ---------- */
.acbp-profile {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 26px;
}

.acbp-profile-side {
	text-align: center;
}

.acbp-profile-side .acbp-avatar {
	width: 140px;
	height: 140px;
}

.acbp-reviews-list {
	margin-top: 18px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.acbp-review {
	background: var(--acbp-surface);
	border: 1px solid var(--acbp-border);
	border-radius: var(--acbp-radius-sm);
	padding: 14px 16px;
}

.acbp-review-head {
	display: flex;
	justify-content: space-between;
	font-size: 0.85rem;
	color: var(--acbp-muted);
	margin-bottom: 6px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
	.acbp-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.acbp-filters {
		grid-template-columns: 1fr 1fr;
	}
	.acbp-wallet-grid {
		grid-template-columns: 1fr;
	}
	.acbp-profile {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {
	.acbp-root {
		padding: 16px;
	}
	.acbp-grid {
		grid-template-columns: 1fr;
	}
	.acbp-filters {
		grid-template-columns: 1fr;
	}
	.acbp-field-row {
		grid-template-columns: 1fr;
	}
	.acbp-chat {
		height: 80vh;
	}
	.acbp-msg {
		max-width: 86%;
	}
}
