/* Shared Component & Global Layout System */

/* Global Drag Handle Utilities */
.pei-drag-handle,
.ui-sortable-handle {
	cursor: move !important;
}

/* Unified Component Notice Engine */
.pei-notice {
	padding: 10px 15px;
	margin-bottom: 15px;
	border-radius: 4px;
	font-weight: 500;
	display: none;
}

.pei-notice.pei-error {
	background: var(--pei-red-lighter);
	color: var(--pei-red-darker);
	border: 1px solid var(--pei-red);
}

.pei-notice.pei-success {
	background: var(--pei-green-lighter);
	color: var(--pei-green-darker);
	border: 1px solid var(--pei-green);
}

.pei-notice-spaced {
	margin-top: 10px;
}

.pei-notice-compact {
	margin-top: 10px;
	margin-bottom: 10px;
}

.pei-notice-visible {
	display: block;
}

/* Shared Badge Component */
.pei-badge {
	display: inline-block;
	padding: 3px 8px;
	border-radius: 12px;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.2;
}

.pei-display-badge {
	color: var(--pei-white);
}

.pei-low-stock-badge {
	background: var(--pei-red);
}

.pei-lead-time-badge {
	background: var(--pei-secondary-color);
}

.pei-orig-price-badge {
	background: var(--pei-accent-color);
	color: #fff;
}

.pei-specs-badge {
	background: #6f42c1;
	color: #fff;
}

/* Reusable Responsive Grid Utilities */
.pei-grid-2,
.pei-grid-4 {
	display: grid;
	gap: 10px;
}

.pei-grid-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pei-grid-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media screen and (max-width: 782px) {
	.pei-grid-2,
	.pei-grid-4 {
		grid-template-columns: 1fr;
	}
}

/* Global Select2 Layout Overrides */
.pei-select2-wrapper .select2-container,
.pei-admin-wrap .select2-container,
.pei-modal-overlay .select2-container {
	width: 100% !important;
}

/* Shared Modal Structural Styles */
.pei-modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--pei-black-transparent);
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	overflow: hidden;
	overscroll-behavior: contain;
	z-index: 99999;
	padding: 24px;
}

@media screen and (max-width: 782px) {
	.pei-modal-overlay {
		padding: 24px 12px;
	}
}

.pei-modal-content {
	background: var(--pei-white);
	width: 100%;
	max-width: 500px;
	max-height: calc(100vh - 48px);
	overflow: auto;
	border-radius: 4px;
	position: relative;
	box-sizing: border-box;
	padding: 20px;
}

.pei-modal-content-wide {
	max-width: 960px;
}

.pei-modal-header {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 16px;
}

.pei-modal-header h2 {
	margin: 0;
}

.pei-modal-header .pei-modal-close {
	position: static;
	top: auto;
	right: auto;
	font-size: 24px;
	line-height: 1;
	text-decoration: none;
	color: var(--pei-black-lighter-1);
	cursor: pointer;
	background: transparent;
	border: none;
}

.pei-modal-header .pei-modal-close:hover,
.pei-modal-header .pei-modal-close:focus {
	color: var(--pei-red);
}

/* Global Hide Utility */
.pei-is-hidden,
.is-hidden {
	display: none !important;
}

/* Global Text Status Utilities */
.pei-text-success {
	color: var(--pei-green-darker, #0f7518) !important;
}

.pei-text-error {
	color: var(--pei-red, #d72638) !important;
}

/* Copy Utility Button */
.pei-btn-copy-utility {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--pei-secondary-color) !important;
	text-decoration: none !important;
}

.pei-btn-copy-utility:hover,
.pei-btn-copy-utility:focus,
.pei-btn-copy-utility.is-copied {
	color: var(--pei-accent-color-darker-1) !important;
	text-decoration: none !important;
}

/* Shared list-item column action/drag utility layout */
.pei-column-action-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 44px;
	width: 44px;
	box-sizing: border-box;
	align-self: stretch;
	background: #f6f7f7;
	height: auto;
}

/* Consolidated Reusable Rotation Animation */
@keyframes pei-spin {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

/* Centralized Global Transitions & Keyframes */
@keyframes peiSlideUpFade {
	0% {
		opacity: 0;
		transform: translateY(30px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes peiBounceIn {
	0% {
		opacity: 0;
		transform: scale(0.3);
	}
	50% {
		opacity: 1;
		transform: scale(1.05);
	}
	70% {
		transform: scale(0.9);
	}
	100% {
		opacity: 1;
		transform: scale(1);
	}
}
