/* ── Global Drawer ──────────────────────────────────────────────────── */

body.pb-drawer-open {
	overflow: hidden !important;
}

#pb-mc-drawer {
	position: fixed !important;
	top: 0 !important;
	right: 0 !important;
	width: 420px !important;
	max-width: 100vw !important;
	height: 100vh !important;
	background: #ffffff !important;
	z-index: 9999999 !important;
	display: flex !important;
	flex-direction: column !important;
	transform: translateX(100%) !important;
	transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
	box-shadow: -15px 0 60px rgba(0, 0, 0, 0.12) !important;
	visibility: hidden !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
}

#pb-mc-drawer.is-active {
	transform: translateX(0) !important;
	visibility: visible !important;
}

.pb-mc-overlay {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	height: 100% !important;
	background: rgba(15, 23, 42, 0.3) !important;
	backdrop-filter: blur(4px) !important;
	z-index: 9999998 !important;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.4s ease;
}

.pb-mc-overlay.is-active {
	opacity: 1 !important;
	visibility: visible !important;
}

/* ── Neutralize theme defaults (exclude our styled buttons) ────────── */

#pb-mc-drawer button:not(.pb-mc-btn),
#pb-mc-drawer a:not(.pb-mc-btn):not(.pb-mc-return-btn),
#pb-mc-drawer input {
	background: none !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	box-shadow: none !important;
	text-transform: none !important;
	color: inherit !important;
	line-height: inherit !important;
	cursor: pointer !important;
	text-decoration: none !important;
}

#pb-mc-drawer input { cursor: text !important; }

/* ── Header ────────────────────────────────────────────────────────── */

.pb-mc-header {
	padding: 20px 25px !important;
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	border-bottom: 1px solid #f1f5f9 !important;
	flex-shrink: 0 !important;
}

.pb-mc-header-title {
	font-size: 1.2rem !important;
	font-weight: 800 !important;
	color: #0f172a !important;
}

.pb-mc-close {
	width: 32px !important;
	height: 32px !important;
	background: #f1f5f9 !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: #475569 !important;
	transition: all 0.25s ease !important;
}

.pb-mc-close:hover {
	background: #0f172a !important;
	color: #ffffff !important;
	transform: rotate(90deg) !important;
}

/* ── Viewport ──────────────────────────────────────────────────────── */

.pb-mc-viewport {
	flex: 1 !important;
	overflow-y: auto !important;
	display: flex !important;
	flex-direction: column !important;
}

.pb-mc-list {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* ── Product Item: Grid Layout ─────────────────────────────────────── */

.pb-mc-item {
	display: grid !important;
	grid-template-columns: 70px 1fr !important;
	grid-template-rows: auto auto !important;
	gap: 0 15px !important;
	padding: 18px 25px !important;
	border-bottom: 1px solid #f1f5f9 !important;
	position: relative !important;
	transition: all 0.3s ease !important;
	align-items: start !important;
}

/* Thumbnail: spans both rows */
.pb-mc-item-thumb {
	grid-column: 1 !important;
	grid-row: 1 / 3 !important;
	align-self: center !important;
}

.pb-mc-item-thumb img {
	width: 70px !important;
	height: 70px !important;
	border-radius: 10px !important;
	object-fit: cover !important;
	box-shadow: none !important;
	background: #f8fafc !important;
}

/* Content area: spans right column */
.pb-mc-item-content {
	grid-column: 2 !important;
	grid-row: 1 / 3 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: space-between !important;
	min-height: 70px !important; /* Match thumbnail height */
	padding-right: 30px !important;
}

/* Name: top-left */
.pb-mc-item-name {
	font-weight: 700 !important;
	font-size: 13px !important;
	color: #1e293b !important;
	line-height: 1.3 !important;
	text-decoration: none !important;
	display: block !important;
}

.pb-mc-item-name:hover { color: #3b82f6 !important; }

/* Qty Row: bottom-left */
.pb-mc-qty-row {
	margin-top: auto !important;
}

/* ── Qty: Modern Compact Pill ──────────────────────────────────────── */

.pb-mc-qty-control {
	display: inline-flex !important;
	align-items: center !important;
	background: #f1f5f9 !important;
	border-radius: 100px !important; /* Full pill shape */
	padding: 3px !important;
	height: 28px !important;
	gap: 0 !important;
}

.pb-mc-qty-btn {
	width: 22px !important;
	height: 22px !important;
	background: #ffffff !important;
	border-radius: 50% !important; /* Circular buttons */
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
	transition: all 0.15s ease !important;
	flex-shrink: 0 !important;
}

.pb-mc-qty-btn:hover {
	box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
}

.pb-mc-qty-btn:active { transform: scale(0.85) !important; }

.pb-mc-qty-btn svg {
	width: 7px !important;
	height: 7px !important;
	pointer-events: none !important;
}

.pb-mc-qty-btn.minus svg { stroke: #ef4444 !important; }
.pb-mc-qty-btn.plus svg { stroke: #10b981 !important; }

/* Fully reset input to behave like plain text */
.pb-mc-qty-input {
	appearance: none !important;
	-webkit-appearance: none !important;
	-moz-appearance: textfield !important;
	width: 28px !important;
	height: 22px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	background: transparent !important;
	text-align: center !important;
	font-weight: 800 !important;
	font-size: 12px !important;
	line-height: 22px !important;
	color: #0f172a !important;
	vertical-align: middle !important;
	display: block !important;
}

/* Hide number input spinners */
.pb-mc-qty-input::-webkit-outer-spin-button,
.pb-mc-qty-input::-webkit-inner-spin-button {
	-webkit-appearance: none !important;
	margin: 0 !important;
}

.pb-mc-qty-input.is-pending { color: #3b82f6 !important; }


/* ── Remove: top-right corner ──────────────────────────────────────── */

.pb-mc-remove {
	position: absolute !important;
	top: 18px !important;
	right: 25px !important;
	width: 18px !important;
	height: 18px !important;
	background: #f1f5f9 !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: #94a3b8 !important;
	font-size: 14px !important;
	line-height: 1 !important;
	transition: all 0.2s !important;
}

.pb-mc-remove:hover {
	background: #ef4444 !important;
	color: #ffffff !important;
}

/* ── Price: bottom-right corner ────────────────────────────────────── */

.pb-mc-item-price {
	position: absolute !important;
	bottom: 18px !important;
	right: 25px !important;
	font-weight: 800 !important;
	color: #0f172a !important;
	font-size: 13px !important;
}

/* ── Footer ────────────────────────────────────────────────────────── */

.pb-mc-footer {
	padding: 18px 25px !important;
	border-top: 1px solid #f1f5f9 !important;
	background: #ffffff !important;
	flex-shrink: 0 !important;
}

.pb-mc-subtotal {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-bottom: 15px !important;
	font-size: 0.95rem !important;
}

.pb-mc-subtotal span { color: #64748b !important; font-weight: 500 !important; }
.pb-mc-subtotal strong { 
	color: #0f172a !important; 
	font-weight: 900 !important; 
	font-size: 1.1rem !important;
	transition: opacity 0.2s ease !important;
}

/* Syncing state for faster feel */
.pb-mc-item.is-syncing {
	opacity: 0.7;
	animation: pbPulse 1.5s infinite ease-in-out;
}

@keyframes pbPulse {
	0% { opacity: 0.7; }
	50% { opacity: 0.5; }
	100% { opacity: 0.7; }
}

.pb-mc-actions {
	display: flex !important;
	flex-direction: row !important;
	gap: 10px !important;
}

/* ── Styled Buttons (NOT neutralized) ──────────────────────────────── */

#pb-mc-drawer .pb-mc-btn {
	flex: 1 !important;
	padding: 11px 10px !important;
	border-radius: 8px !important;
	font-weight: 700 !important;
	font-size: 12px !important;
	text-align: center !important;
	text-decoration: none !important;
	cursor: pointer !important;
	transition: all 0.25s ease !important;
	box-sizing: border-box !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	white-space: nowrap !important;
}

#pb-mc-drawer .pb-mc-btn:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 6px 20px rgba(0,0,0,0.1) !important;
}

#pb-mc-drawer .pb-btn-primary {
	background: #0f172a !important;
	color: #ffffff !important;
	border: none !important;
}

#pb-mc-drawer .pb-btn-secondary {
	background: #f8fafc !important;
	color: #1e293b !important;
	border: 1px solid #e2e8f0 !important;
}

/* ── Empty State ───────────────────────────────────────────────────── */

.pb-mc-empty-wrap {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 60px 30px !important;
}

.pb-mc-empty-text {
	color: #94a3b8 !important;
	font-size: 1rem !important;
	margin-bottom: 25px !important;
}

#pb-mc-drawer .pb-mc-return-btn {
	display: inline-block !important;
	background: #0f172a !important;
	color: #ffffff !important;
	padding: 14px 28px !important;
	border-radius: 10px !important;
	font-weight: 700 !important;
	text-decoration: none !important;
	border: none !important;
	transition: all 0.25s ease !important;
}

#pb-mc-drawer .pb-mc-return-btn:hover {
	transform: translateY(-2px) !important;
}

/* ── Removal Animation ─────────────────────────────────────────────── */

.pb-mc-item.is-removing {
	opacity: 0 !important;
	transform: translateX(40px) !important;
	max-height: 0 !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	overflow: hidden !important;
}

/* ── Cart Icon Button (Shortcode) ──────────────────────────────────── */

.pb-cart-icon-btn {
	position: relative !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 44px !important;
	height: 44px !important;
	background: transparent !important;
	border: none !important;
	border-radius: 50% !important;
	cursor: pointer !important;
	padding: 0 !important;
	margin: 0 !important;
	color: currentColor !important;
	transition: background 0.2s ease, transform 0.2s ease !important;
	box-shadow: none !important;
}

.pb-cart-icon-btn:hover {
	background: rgba(0, 0, 0, 0.06) !important;
	transform: scale(1.05) !important;
}

.pb-cart-icon-wrap {
	position: relative !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.pb-cart-svg {
	display: block !important;
	stroke: currentColor !important;
}

.pb-cart-custom-img {
	width: 22px !important;
	height: 22px !important;
	object-fit: contain !important;
}

/* Badge counter */
.pb-cart-count {
	position: absolute !important;
	top: -8px !important;
	right: -8px !important;
	min-width: 18px !important;
	height: 18px !important;
	padding: 0 5px !important;
	background: #ef4444 !important;
	color: #ffffff !important;
	border-radius: 100px !important;
	font-size: 10px !important;
	font-weight: 800 !important;
	line-height: 18px !important;
	text-align: center !important;
	display: none !important; /* Hidden by default */
	box-shadow: 0 2px 6px rgba(239, 68, 68, 0.4) !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
	transform: scale(0) !important;
	transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

/* Visible state — triggered by PHP class */
.pb-cart-count.is-visible {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transform: scale(1) !important;
}

/* ── Floating Cart Icon ───────────────────────────────────────────── */

.pb-floating-cart-wrap {
	position: fixed !important;
	bottom: var(--pb-float-bottom, 30px) !important;
	right: var(--pb-float-right, 30px) !important;
	z-index: 9999 !important;
}

.pb-floating-cart {
	width: 60px !important;
	height: 60px !important;
	background: #ffffff !important;
	color: #0f172a !important;
	border-radius: 50% !important;
	box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.2), 0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	cursor: pointer !important;
	transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
	border: none !important;
	padding: 0 !important;
}

.pb-floating-cart:hover {
	transform: translateY(-5px) scale(1.05) !important;
	background: #f8fafc !important;
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.2), 0 10px 10px -5px rgba(0, 0, 0, 0.1) !important;
}

.pb-floating-cart .pb-cart-svg {
	width: 26px !important;
	height: 26px !important;
}

.pb-floating-cart .pb-cart-count {
	top: -10px !important;
	right: -10px !important;
	width: 20px !important;
	height: 20px !important;
	line-height: 20px !important;
	font-size: 10px !important;
}

/* Mobile adjustments */
@media (max-width: 768px) {
	.pb-floating-cart-wrap {
		bottom: 20px !important;
		right: 20px !important;
	}
	
	.pb-floating-cart {
		width: 54px !important;
		height: 54px !important;
	}
}
