/**
 * Frontend Styles
 * Scoped with high specificity to prevent theme conflicts
 */

/* Main wrapper - high specificity */
.woocommerce .cpaw-addons-wrapper,
.single-product .cpaw-addons-wrapper,
.product .cpaw-addons-wrapper {
	margin: 30px 0 !important;
	padding: 20px !important;
	background: #f9f9f9 !important;
	border: 1px solid #e5e5e5 !important;
	border-radius: 4px !important;
	box-sizing: border-box !important;
	clear: both !important;
}

.cpaw-addons-wrapper .cpaw-addon-group {
	margin-bottom: 30px !important;
}

.cpaw-addons-wrapper .cpaw-addon-group:last-child {
	margin-bottom: 0 !important;
}

.cpaw-addons-wrapper .cpaw-group-title {
	margin: 0 0 20px 0 !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: #333 !important;
	padding-bottom: 10px !important;
	border-bottom: 2px solid #ddd !important;
	line-height: 1.4 !important;
}

.cpaw-addons-wrapper .cpaw-addon-fields {
	display: flex !important;
	flex-direction: column !important;
	gap: 20px !important;
}

/* Field styles - scoped */
.cpaw-addons-wrapper .cpaw-field {
	margin-bottom: 20px !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.cpaw-addons-wrapper .cpaw-field label {
	display: block !important;
	margin-bottom: 8px !important;
	font-weight: 600 !important;
	font-size: 14px !important;
	color: #333 !important;
	line-height: 1.4 !important;
}

.cpaw-addons-wrapper .cpaw-field .required {
	color: #dc3232 !important;
	margin-left: 3px !important;
}

.cpaw-addons-wrapper .cpaw-input,
.cpaw-addons-wrapper .cpaw-field select,
.cpaw-addons-wrapper .cpaw-field textarea,
.cpaw-addons-wrapper input.cpaw-input,
.cpaw-addons-wrapper select.cpaw-input,
.cpaw-addons-wrapper textarea.cpaw-input {
	width: 100% !important;
	max-width: 100% !important;
	padding: 10px 12px !important;
	border: 1px solid #ddd !important;
	border-radius: 4px !important;
	font-size: 14px !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif !important;
	transition: border-color 0.3s ease !important;
	box-sizing: border-box !important;
	background: #fff !important;
	line-height: 1.5 !important;
}

.cpaw-addons-wrapper .cpaw-input:focus,
.cpaw-addons-wrapper .cpaw-field select:focus,
.cpaw-addons-wrapper .cpaw-field textarea:focus,
.cpaw-addons-wrapper input.cpaw-input:focus,
.cpaw-addons-wrapper select.cpaw-input:focus,
.cpaw-addons-wrapper textarea.cpaw-input:focus {
	outline: none !important;
	border-color: #2271b1 !important;
	box-shadow: 0 0 0 1px #2271b1 !important;
}

.cpaw-addons-wrapper .cpaw-help-text {
	display: block !important;
	margin-top: 5px !important;
	font-size: 13px !important;
	color: #666 !important;
	font-style: italic !important;
	line-height: 1.4 !important;
}

/* Radio options - scoped */
.cpaw-addons-wrapper .cpaw-radio-options {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
}

.cpaw-addons-wrapper .cpaw-radio-option {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	cursor: pointer !important;
}

.cpaw-addons-wrapper .cpaw-radio-option input[type="radio"] {
	margin: 0 !important;
	cursor: pointer !important;
}

.cpaw-addons-wrapper .cpaw-radio-option span {
	font-size: 14px !important;
	line-height: 1.4 !important;
}

/* Image radio options - scoped */
.cpaw-addons-wrapper .cpaw-image-radio-options {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important;
	gap: 15px !important;
	width: 100% !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-option {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	padding: 10px !important;
	border: 2px solid #ddd !important;
	border-radius: 4px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	background: #fff !important;
	box-sizing: border-box !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-option:hover {
	border-color: #2271b1 !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-option.selected {
	border-color: #2271b1 !important;
	background: #f0f6fc !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-option input[type="radio"] {
	display: none !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-image {
	width: 100% !important;
	margin-bottom: 8px !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-image img {
	width: 100% !important;
	height: auto !important;
	border-radius: 4px !important;
	display: block !important;
}

.cpaw-addons-wrapper .cpaw-image-radio-label {
	font-size: 13px !important;
	text-align: center !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
}

/* Image checkbox options - scoped */
.cpaw-addons-wrapper .cpaw-image-checkbox-options {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important;
	gap: 15px !important;
	width: 100% !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-option {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	padding: 10px !important;
	border: 2px solid #ddd !important;
	border-radius: 4px !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	background: #fff !important;
	box-sizing: border-box !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-option:hover {
	border-color: #2271b1 !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-option.selected {
	border-color: #2271b1 !important;
	background: #f0f6fc !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-option input[type="checkbox"] {
	display: none !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-image {
	width: 100% !important;
	margin-bottom: 8px !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-image img {
	width: 100% !important;
	height: auto !important;
	border-radius: 4px !important;
	display: block !important;
}

.cpaw-addons-wrapper .cpaw-image-checkbox-label {
	font-size: 13px !important;
	text-align: center !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
}

/* Color picker - scoped */
.cpaw-addons-wrapper .cpaw-color-picker,
.cpaw-addons-wrapper input[type="color"].cpaw-color-picker {
	width: 100px !important;
	height: 40px !important;
	padding: 2px !important;
	cursor: pointer !important;
	border: 1px solid #ddd !important;
	border-radius: 4px !important;
}

/* File upload - scoped */
.cpaw-addons-wrapper .cpaw-file-upload-wrapper {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	flex-wrap: wrap !important;
}

.cpaw-addons-wrapper .cpaw-file-upload-btn,
.cpaw-addons-wrapper button.cpaw-file-upload-btn {
	padding: 8px 16px !important;
	border: 1px solid #ddd !important;
	background: #f7f7f7 !important;
	cursor: pointer !important;
	border-radius: 4px !important;
	font-size: 14px !important;
}

.cpaw-addons-wrapper .cpaw-file-name {
	flex: 1 !important;
	min-width: 200px !important;
	font-size: 14px !important;
	color: #666 !important;
	line-height: 1.4 !important;
	display: inline-flex !important;
	align-items: center !important;
	vertical-align: middle !important;
}

.cpaw-addons-wrapper .cpaw-file-name img {
	max-width: 50px !important;
	height: auto !important;
	vertical-align: middle !important;
	margin-right: 5px !important;
	border: 1px solid #ddd !important;
	border-radius: 3px !important;
	padding: 2px !important;
	background: #fff !important;
}

.cpaw-addons-wrapper .cpaw-file-name .dashicons {
	font-size: 20px !important;
	width: 20px !important;
	height: 20px !important;
	vertical-align: middle !important;
	margin-right: 5px !important;
	color: #666 !important;
}

.cpaw-addons-wrapper .cpaw-file-remove,
.cpaw-addons-wrapper button.cpaw-file-remove {
	padding: 8px 16px !important;
	border: 1px solid #dc3232 !important;
	background: #fff !important;
	color: #dc3232 !important;
	cursor: pointer !important;
	border-radius: 4px !important;
	font-size: 14px !important;
}

/* Order addons display for customers - scoped */
.woocommerce-order-details .cpaw-order-addons-customer,
.woocommerce-view-order .cpaw-order-addons-customer,
.woocommerce-order .cpaw-order-addons-customer {
	margin-top: 15px !important;
	padding-top: 15px !important;
	border-top: 1px solid #e5e5e5 !important;
}

.cpaw-order-addons-customer .cpaw-order-addons-title {
	font-weight: 600 !important;
	margin-bottom: 8px !important;
	color: #333 !important;
	font-size: 14px !important;
	line-height: 1.4 !important;
}

.cpaw-order-addons-customer .cpaw-order-addons-list {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.cpaw-order-addons-customer .cpaw-order-addon-item {
	padding: 5px 0 !important;
	font-size: 14px !important;
	line-height: 1.6 !important;
}

.cpaw-order-addons-customer .cpaw-order-addon-item strong {
	margin-right: 5px !important;
	color: #666 !important;
	font-weight: 600 !important;
}

.cpaw-order-addons-customer .cpaw-order-addon-value {
	color: #333 !important;
}

.cpaw-order-addons-customer .cpaw-order-addon-value img {
	max-width: 60px !important;
	height: auto !important;
	border: 1px solid #ddd !important;
	border-radius: 4px !important;
	margin-top: 5px !important;
	display: block !important;
}

.cpaw-order-addons-customer .cpaw-order-addon-value a {
	color: #2271b1 !important;
	text-decoration: underline !important;
}

/* Cart and checkout image display */
.woocommerce-cart .cpaw-cart-image-value img,
.woocommerce-checkout .cpaw-cart-image-value img,
.woocommerce-order-details .cpaw-cart-image-value img,
.woocommerce-view-order .cpaw-cart-image-value img {
	max-width: 50px !important;
	height: auto !important;
	vertical-align: middle !important;
	margin-right: 5px !important;
	border: 1px solid #ddd !important;
	border-radius: 3px !important;
	padding: 2px !important;
	background: #fff !important;
}

.woocommerce-table__line-item .cpaw-cart-image-value,
.woocommerce-cart-item .cpaw-cart-image-value,
.woocommerce-checkout-review-order-table .cpaw-cart-image-value {
	display: inline-block !important;
	vertical-align: middle !important;
}

/* Responsive - scoped */
@media (max-width: 768px) {
	.cpaw-addons-wrapper .cpaw-image-radio-options,
	.cpaw-addons-wrapper .cpaw-image-checkbox-options {
		grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)) !important;
		gap: 10px !important;
	}

	.cpaw-addons-wrapper {
		padding: 15px !important;
		margin: 20px 0 !important;
	}
}
