/*
 * Dynamic Jewellery Pricing - Frontend Styles
 */

/* ── Weight Selector ─────────────────────────────────────────────────────── */
.djp-weight-selector {
	margin: 15px 0;
	padding: 15px;
	background: #f0f4ff;
	border: 1px solid #b3c6ff;
	border-radius: 6px;
}

.djp-weight-selector label {
	display: block;
	font-weight: 600;
	color: #333;
	margin-bottom: 8px;
	font-size: 0.95em;
}

.djp-weight-selector #djp-weight-display {
	font-weight: 400;
	color: #7f54b3;
}

.djp-weight-controls {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.djp-weight-preset {
	min-width: 140px;
	padding: 6px 10px;
	border: 1px solid #ccc;
	border-radius: 4px;
	background: #fff;
	font-size: 0.9em;
	cursor: pointer;
}

.djp-weight-input {
	width: 90px;
	padding: 6px 10px;
	border: 2px solid #7f54b3;
	border-radius: 4px;
	font-size: 1em;
	font-weight: 600;
	text-align: center;
	color: #7f54b3;
}

.djp-weight-input:focus {
	outline: none;
	border-color: #5a3a8a;
	box-shadow: 0 0 0 3px rgba( 127, 84, 179, 0.15 );
}

.djp-weight-unit {
	font-weight: 600;
	color: #555;
	font-size: 0.95em;
}

.djp-weight-hint {
	margin: 8px 0 0;
	font-size: 0.82em;
	color: #666;
	line-height: 1.5;
}

/* Price loading state. */
.djp-price-loading {
	opacity: 0.5;
	transition: opacity 0.15s ease;
}

/* ── Price Breakdown ─────────────────────────────────────────────────────── */
.djp-price-breakdown {
	background: #f9f9f9;
	border: 1px solid #e1e1e1;
	padding: 15px;
	margin: 20px 0;
	border-radius: 4px;
}

.djp-price-breakdown h4 {
	margin-top: 0;
	border-bottom: 1px solid #ddd;
	padding-bottom: 10px;
}

.djp-price-breakdown table {
	width: 100%;
}

.djp-price-breakdown td {
	padding: 5px 0;
	border-bottom: 1px solid #eee;
}

.djp-price-breakdown td:first-child {
	font-weight: bold;
}

.djp-price-breakdown .djp-final-price {
	font-size: 1.2em;
	font-weight: bold;
	color: #7f54b3;
}

.djp-metal-table {
	overflow-x: auto;
}

.djp-metal-table table {
	width: 100%;
}

.djp-calculator {
	background: #f9f9f9;
	border: 1px solid #e1e1e1;
	padding: 20px;
	border-radius: 4px;
}

.djp-calculator .form-table th {
	width: 150px;
}

#djp-calculator-result {
	margin-top: 20px;
	padding: 15px;
	background: #fff;
	border: 1px solid #ddd;
}

.djp-loading {
	display: inline-block;
	width: 20px;
	height: 20px;
	border: 2px solid #ccc;
	border-top-color: #333;
	border-radius: 50%;
	animation: djp-spin 1s linear infinite;
}

@keyframes djp-spin {
	to {
		transform: rotate(360deg);
	}
}

.djp-order-item-meta {
	margin-top: 10px;
	padding: 10px;
	background: #f9f9f9;
	border: 1px solid #e1e1e1;
	font-size: 0.9em;
}

/* Cart item inline breakdown. */
.djp-cart-item-breakdown {
	margin-top: 4px;
	padding: 4px 8px;
	background: #f0f0f0;
	border-left: 3px solid #7f54b3;
	font-size: 0.85em;
	color: #555;
}

.djp-cart-item-breakdown small {
	display: block;
	line-height: 1.6;
}

/* Cart breakdown shortcode block. */
.djp-cart-breakdown {
	background: #f9f9f9;
	border: 1px solid #e1e1e1;
	padding: 20px;
	border-radius: 4px;
	margin: 20px 0;
}

.djp-cart-breakdown h4 {
	margin-top: 0;
	border-bottom: 2px solid #7f54b3;
	padding-bottom: 10px;
	color: #7f54b3;
}

.djp-cart-item-breakdown-block {
	background: #fff;
	border: 1px solid #e1e1e1;
	border-radius: 4px;
	padding: 15px;
	margin-bottom: 15px;
}

.djp-cart-item-breakdown-block h5 {
	margin: 0 0 10px;
	padding-bottom: 8px;
	border-bottom: 1px solid #eee;
	font-size: 1em;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.djp-cart-item-qty {
	background: #7f54b3;
	color: #fff;
	padding: 2px 8px;
	border-radius: 10px;
	font-size: 0.85em;
}

.djp-breakdown-table {
	width: 100%;
	border-collapse: collapse;
}

.djp-breakdown-table td {
	padding: 5px 0;
	border-bottom: 1px solid #f0f0f0;
}

.djp-breakdown-table td:first-child {
	font-weight: 600;
	width: 45%;
	color: #333;
}

.djp-breakdown-table td:last-child {
	text-align: right;
	color: #555;
}

.djp-breakdown-table .djp-breakdown-line-total td {
	font-weight: bold;
	color: #7f54b3;
	border-top: 2px solid #7f54b3;
	border-bottom: none;
	padding-top: 10px;
}

.djp-cart-totals-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 0;
	margin-top: 10px;
	border-top: 2px solid #7f54b3;
	font-size: 1.1em;
	color: #7f54b3;
}

.djp-no-items {
	color: #888;
	font-style: italic;
}

.djp-error {
	color: #c00;
}

@media (max-width: 768px) {
	.djp-price-breakdown table,
	.djp-calculator .form-table,
	.djp-breakdown-table {
		font-size: 0.9em;
	}

	.djp-cart-item-breakdown-block {
		padding: 10px;
	}

	.djp-breakdown-table td:first-child {
		width: 40%;
	}
}