/* Product box — high-converting affiliate component */

.cor-product-box {
	position: relative;
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius);
	padding: 0;
	overflow: hidden;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.cor-product-box:hover { border-color: var(--cor-line-2); box-shadow: var(--cor-shadow); }

.cor-pb-badge {
	position: absolute; top: 14px; left: -8px;
	background: var(--cor-cta); color: #fff;
	font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	padding: 6px 12px 6px 16px; border-radius: 4px 4px 4px 0;
	box-shadow: 0 4px 10px rgba(232,81,28,.25);
	z-index: 2;
}
.cor-pb-badge::after { content: ''; position: absolute; left: 0; top: 100%; border: 4px solid transparent; border-top-color: var(--cor-cta-d); border-right-color: var(--cor-cta-d); }

.cor-pb-grid { display: grid; grid-template-columns: 220px 1fr; gap: 24px; padding: 22px; align-items: start; }
.cor-pb-default .cor-pb-grid, .cor-pb-compact .cor-pb-grid { grid-template-columns: 160px 1fr; padding: 18px; }
.cor-pb-featured .cor-pb-grid { grid-template-columns: 280px 1fr; padding: 28px; gap: 32px; }

@media (max-width: 600px) {
	.cor-pb-grid, .cor-pb-default .cor-pb-grid, .cor-pb-compact .cor-pb-grid, .cor-pb-featured .cor-pb-grid {
		grid-template-columns: 1fr; gap: 16px;
	}
	.cor-pb-media { max-width: 220px; margin: 0 auto; }
}

.cor-pb-media { background: var(--cor-bg-warm); border-radius: var(--cor-radius-sm); aspect-ratio: 1/1; overflow: hidden; }
.cor-pb-media img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.cor-pb-placeholder { display: block; width: 100%; height: 100%; background: linear-gradient(135deg, var(--cor-cream-l), var(--cor-bg-warm)); }

.cor-pb-body { display: flex; flex-direction: column; gap: 8px; }
.cor-pb-brand { font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; color: var(--cor-cream-d); margin: 0; font-weight: 600; }
.cor-pb-title { font-size: 1.3rem; margin: 0; line-height: 1.25; }
.cor-pb-title a { color: var(--cor-ink); }
.cor-pb-title a:hover { color: var(--cor-cta); }
.cor-pb-rating { margin: 2px 0 6px; }
.cor-pb-best-for { font-size: .9rem; color: var(--cor-ink-2); margin: 0; }
.cor-pb-pros, .cor-pb-cons { list-style: none; padding: 0; margin: 6px 0 0; display: grid; gap: 4px; font-size: .9rem; }
.cor-pb-pros li::before { content: "✓ "; color: var(--cor-sage); font-weight: 700; }
.cor-pb-cons li::before { content: "× "; color: var(--cor-cta-d); font-weight: 700; }
.cor-pb-cta-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 12px; }
.cor-pb-price { font-family: var(--cor-serif); font-size: 1.4rem; font-weight: 600; color: var(--cor-ink); }
.cor-pb-cta { padding: 13px 22px; }
.cor-pb-disclosure { font-size: .72rem; color: var(--cor-muted); margin: 6px 0 0; }

/* Featured variant */
.cor-pb-featured { background: linear-gradient(135deg, var(--cor-paper), var(--cor-cream-l)); border-color: var(--cor-cream); }
.cor-pb-featured .cor-pb-title { font-size: 1.6rem; }
.cor-pb-featured .cor-pb-cta { padding: 16px 28px; font-size: 1rem; }

/* Compact (used in side-by-side grids) */
.cor-pb-compact .cor-pb-title { font-size: 1.1rem; }
.cor-pb-compact .cor-pb-pros, .cor-pb-compact .cor-pb-cons { font-size: .85rem; }
