/*
 * Affiliate ecosystem layer:
 * - Related Amazon bundle + routine card
 * - Best-For positioning rail
 * - Sticky product CTA (mobile)
 * - Compare drawer (floating)
 */

/* ---------- Related Amazon bundle ---------- */
.cor-bundle {
	background:
		linear-gradient(180deg, var(--cor-paper) 0%, var(--cor-bg-warm) 100%);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius-lg);
	padding: clamp(24px, 4vw, 40px);
	margin: 2.5rem 0;
	box-shadow: var(--cor-elev-1, 0 1px 2px rgba(63,53,32,0.04), 0 4px 10px rgba(63,53,32,0.04));
	position: relative;
	overflow: hidden;
}
.cor-bundle::before {
	content: ''; position: absolute; top: 0; right: 0; width: 280px; height: 280px;
	background: radial-gradient(circle at 70% 30%, rgba(201,168,124,0.18), transparent 60%);
	pointer-events: none; z-index: 0;
}
.cor-bundle > * { position: relative; z-index: 1; }

.cor-bundle-head { margin-bottom: clamp(20px, 3vw, 32px); }
.cor-bundle-title { margin: 0 0 .35em; font-size: clamp(1.4rem, 1.5vw + .8rem, 1.85rem); }
.cor-bundle-sub { margin: 0; color: var(--cor-muted); max-width: 60ch; }
.cor-bundle-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.cor-bundle-pill {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 5px 12px; border-radius: 999px;
	background: rgba(255,255,255,0.65);
	border: 1px solid var(--cor-line);
	font-size: .76rem; font-weight: 500; color: var(--cor-ink-2);
	text-decoration: none;
}
.cor-bundle-link:hover { background: #fff; color: var(--cor-cta); border-color: var(--cor-cta); }

.cor-bundle-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 14px;
}
.cor-bundle-card {
	position: relative;
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius);
	padding: 18px 20px 14px;
	display: flex; flex-direction: column;
	transition:
		transform .35s var(--cor-ease, cubic-bezier(.2,.8,.2,1)),
		box-shadow .35s var(--cor-ease, cubic-bezier(.2,.8,.2,1)),
		border-color .25s ease;
	box-shadow: var(--cor-elev-1, 0 1px 2px rgba(63,53,32,0.04));
}
.cor-bundle-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--cor-elev-2, 0 8px 22px rgba(63,53,32,0.06));
	border-color: var(--cor-cream);
}
.cor-bundle-card.is-comparing {
	border-color: var(--cor-sage);
	background: linear-gradient(135deg, var(--cor-sage-l), var(--cor-paper));
}

.cor-bundle-badge {
	position: absolute; top: -10px; left: 14px;
	background: var(--cor-cta); color: #fff;
	font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	padding: 4px 10px; border-radius: 999px;
	box-shadow: 0 6px 14px rgba(232,81,28,0.25);
}

.cor-bundle-card-link { display: flex; flex-direction: column; gap: 6px; color: var(--cor-ink); flex: 1; }
.cor-bundle-card-link:hover .cor-bundle-card-title { color: var(--cor-cta); }
.cor-bundle-emoji {
	display: inline-flex; align-items: center; justify-content: center;
	width: 56px; height: 56px;
	background: var(--cor-cream-l);
	border-radius: 50%;
	font-size: 1.6rem;
	margin-bottom: 6px;
}
.cor-bundle-card-title { margin: 0; font-size: 1.05rem; line-height: 1.3; transition: color .2s; }
.cor-bundle-card-blurb { margin: 0; color: var(--cor-muted); font-size: .88rem; flex: 1; }
.cor-bundle-card-actions { display: flex; gap: 6px; align-items: center; margin-top: 12px; }
.cor-bundle-cta { flex: 1; justify-content: center; padding: 9px 12px; font-size: .82rem; }
.cor-bundle-compare {
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: 999px;
	padding: 8px 12px;
	font-size: .78rem; font-weight: 600; color: var(--cor-ink-2);
	display: inline-flex; align-items: center; gap: 5px;
	cursor: pointer;
	transition: background .15s, border-color .15s, color .15s;
}
.cor-bundle-compare:hover { border-color: var(--cor-sage); color: var(--cor-sage-d); }
.cor-bundle-compare.is-on { background: var(--cor-sage); color: #fff; border-color: var(--cor-sage); }

.cor-bundle-disclosure { font-size: .78rem; color: var(--cor-muted); margin: 16px 0 0; text-align: center; }

/* ---------- Routine "Frequently bought together" ---------- */
.cor-routine {
	margin-top: 24px;
	background: linear-gradient(135deg, var(--cor-cream-l), var(--cor-paper));
	border: 1px dashed var(--cor-cream);
	border-radius: var(--cor-radius);
	padding: clamp(20px, 3vw, 28px);
}
.cor-routine-head { margin-bottom: 16px; }
.cor-routine-head h3 { margin: 0 0 .25rem; font-size: 1.25rem; }
.cor-routine-sub { margin: 0; color: var(--cor-muted); font-size: .92rem; }
.cor-routine-row {
	display: flex; flex-wrap: wrap; gap: 8px; align-items: stretch;
	margin: 14px 0 18px;
}
.cor-routine-item {
	flex: 1 1 130px;
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius-sm);
	padding: 12px 14px 14px;
	display: flex; flex-direction: column; align-items: center; gap: 6px;
	color: var(--cor-ink); text-align: center;
	transition: transform .25s, border-color .2s, box-shadow .25s;
	font-size: .85rem; font-weight: 600;
}
.cor-routine-item:hover { transform: translateY(-2px); border-color: var(--cor-cream-d); color: var(--cor-ink); box-shadow: var(--cor-elev-1, 0 4px 10px rgba(0,0,0,0.05)); }
.cor-routine-emoji { font-size: 1.6rem; line-height: 1; }
.cor-routine-plus { display: flex; align-items: center; color: var(--cor-cream-d); font-weight: 700; font-family: var(--cor-serif); font-size: 1.4rem; }
@media (max-width: 540px) { .cor-routine-plus { display: none; } }
.cor-routine-cta { width: 100%; justify-content: center; }

/* ---------- Best-For positioning rail ---------- */
.cor-bf-rail .cor-bf-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
}
.cor-bf-card {
	position: relative;
	background: var(--cor-paper);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius);
	padding: 36px 22px 22px;
	display: flex; flex-direction: column; gap: 12px;
	transition: transform .35s var(--cor-ease, cubic-bezier(.2,.8,.2,1)), box-shadow .35s, border-color .2s;
	box-shadow: var(--cor-elev-1, 0 1px 2px rgba(63,53,32,0.04), 0 4px 10px rgba(63,53,32,0.04));
}
.cor-bf-card:hover { transform: translateY(-3px); box-shadow: var(--cor-elev-2, 0 8px 22px rgba(63,53,32,0.06)); border-color: var(--cor-cream); }
.cor-bf-label {
	position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
	background: var(--cor-sage-d); color: #fff;
	font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	padding: 6px 14px; border-radius: 999px;
	box-shadow: 0 6px 14px rgba(63,93,61,0.25);
	white-space: nowrap;
}
.cor-bf-card--organic .cor-bf-label { background: var(--cor-sage-d); }
.cor-bf-card--hair    .cor-bf-label { background: #6B4F2F; }
.cor-bf-card--budget  .cor-bf-label { background: #2A4659; }
.cor-bf-card--cold    .cor-bf-label { background: #1F4259; }
.cor-bf-card--cooking .cor-bf-label { background: var(--cor-cta-d); }
.cor-bf-card--skin    .cor-bf-label { background: #8C5B2A; }

.cor-bf-media {
	background: var(--cor-bg-warm);
	border-radius: var(--cor-radius-sm);
	aspect-ratio: 1;
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
}
.cor-bf-media img { width: 100%; height: 100%; object-fit: contain; padding: 8px; }
.cor-bf-placeholder { display: block; width: 100%; height: 100%; background: linear-gradient(135deg, var(--cor-cream-l), var(--cor-bg-warm)); }
.cor-bf-body { display: flex; flex-direction: column; gap: 4px; }
.cor-bf-brand { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--cor-cream-d); margin: 0; font-weight: 600; }
.cor-bf-name { margin: 0; font-size: 1.05rem; line-height: 1.3; }
.cor-bf-name a { color: var(--cor-ink); }
.cor-bf-name a:hover { color: var(--cor-cta); }
.cor-bf-price { font-family: var(--cor-serif); font-size: 1.1rem; font-weight: 600; color: var(--cor-ink); margin: 4px 0 0; }
.cor-bf-cta { justify-content: center; margin-top: auto; }
.cor-bf-disclosure { font-size: .78rem; color: var(--cor-muted); text-align: center; margin: 18px 0 0; }

/* ---------- Inline mid-content product card ---------- */
.cor-inline-product {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 18px;
	align-items: center;
	background:
		linear-gradient(135deg, var(--cor-paper) 0%, var(--cor-cream-l) 100%);
	border: 1px solid var(--cor-cream);
	border-left: 4px solid var(--cor-cta);
	border-radius: var(--cor-radius);
	padding: 18px 22px;
	margin: 1.8em 0;
	position: relative;
	box-shadow: var(--cor-elev-1, 0 1px 2px rgba(63,53,32,0.04), 0 4px 10px rgba(63,53,32,0.04));
}
.cor-inline-product-badge {
	position: absolute; top: -10px; left: 16px;
	background: var(--cor-cta); color: #fff;
	font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
	padding: 4px 10px; border-radius: 999px;
	box-shadow: 0 6px 14px rgba(232,81,28,0.25);
}
.cor-inline-product-icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 56px; height: 56px;
	background: var(--cor-paper);
	border-radius: 50%;
	font-size: 1.6rem;
	border: 1px solid rgba(0,0,0,0.04);
}
.cor-inline-product-body { min-width: 0; }
.cor-inline-product-body .cor-eyebrow { margin-bottom: .35rem; font-size: .72rem; }
.cor-inline-product-title {
	margin: 0 0 .2rem;
	font-size: 1.1rem;
	font-family: var(--cor-serif);
	line-height: 1.25;
}
.cor-inline-product-blurb {
	margin: 0;
	color: var(--cor-ink-2);
	font-size: .92rem;
}
.cor-inline-product-cta-wrap {
	display: flex; flex-direction: column; gap: 6px; align-items: stretch;
	flex: 0 0 auto;
}
.cor-inline-product-cta { white-space: nowrap; }
.cor-inline-product-cta-wrap .cor-bundle-compare {
	font-size: .72rem; padding: 6px 10px;
	justify-content: center;
}

@media (max-width: 600px) {
	.cor-inline-product { grid-template-columns: 56px 1fr; padding: 22px 18px 16px; }
	.cor-inline-product-cta-wrap { grid-column: 1 / -1; flex-direction: row; }
	.cor-inline-product-cta { flex: 1; justify-content: center; }
}

/* ---------- Sticky product CTA (mobile) ---------- */
.cor-sticky-product {
	position: fixed; left: 0; right: 0; bottom: 0;
	background: rgba(255, 253, 249, 0.96);
	backdrop-filter: blur(14px) saturate(140%);
	-webkit-backdrop-filter: blur(14px) saturate(140%);
	border-top: 1px solid var(--cor-line);
	box-shadow: 0 -10px 30px rgba(28,24,18,0.10);
	transform: translateY(110%);
	transition: transform .35s var(--cor-ease, cubic-bezier(.2,.8,.2,1));
	z-index: 65;
	padding: 10px 0;
}
.cor-sticky-product.is-visible { transform: translateY(0); }
.cor-sticky-product-inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cor-sticky-product-meta { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.cor-sticky-product-thumb { width: 44px; height: 44px; border-radius: 8px; object-fit: cover; flex: 0 0 auto; }
.cor-sticky-product-text { display: flex; flex-direction: column; min-width: 0; }
.cor-sticky-product-title { margin: 0; font-size: .9rem; font-weight: 600; color: var(--cor-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cor-sticky-product-price { margin: 0; font-size: .82rem; color: var(--cor-cream-d); font-weight: 600; }
.cor-sticky-product-cta { white-space: nowrap; flex: 0 0 auto; }
@media (min-width: 880px) { .cor-sticky-product { display: none; } }
/* Hide the generic sticky CTA on product pages (the product-specific one replaces it). */
.cor-single-product .cor-sticky-cta { display: none !important; }

/* ---------- Compare drawer ---------- */
.cor-compare-drawer {
	position: fixed; right: 16px; bottom: 16px;
	z-index: 70;
	font-family: var(--cor-sans);
}
.cor-compare-drawer-toggle {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--cor-ink); color: #fff;
	border: 0; border-radius: 999px;
	padding: 12px 18px;
	cursor: pointer;
	box-shadow: 0 12px 28px rgba(28,24,18,0.20), 0 4px 8px rgba(28,24,18,0.12);
	font-weight: 600; font-size: .85rem;
	transition: transform .2s, background .2s;
}
.cor-compare-drawer-toggle:hover { background: var(--cor-sage-d); transform: translateY(-2px); }
.cor-compare-drawer-count {
	background: var(--cor-cta); color: #fff;
	font-size: .72rem; font-weight: 700;
	padding: 2px 8px; border-radius: 999px; min-width: 22px; text-align: center;
}
.cor-compare-drawer-panel {
	position: absolute; right: 0; bottom: calc(100% + 10px);
	width: clamp(280px, 88vw, 360px);
	background: rgba(255, 253, 249, 0.97);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid var(--cor-line);
	border-radius: var(--cor-radius);
	box-shadow: 0 24px 48px rgba(28,24,18,0.14);
	padding: 16px 18px;
	opacity: 0; transform: translateY(8px); pointer-events: none;
	transition: opacity .25s var(--cor-ease, cubic-bezier(.2,.8,.2,1)), transform .25s var(--cor-ease, cubic-bezier(.2,.8,.2,1));
}
.cor-compare-drawer.is-open .cor-compare-drawer-panel {
	opacity: 1; transform: translateY(0); pointer-events: auto;
}
.cor-compare-drawer-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.cor-compare-drawer-head strong { font-size: .9rem; }
.cor-compare-drawer-close { background: transparent; border: 0; font-size: 1.4rem; line-height: 1; color: var(--cor-muted); cursor: pointer; padding: 0 4px; }
.cor-compare-drawer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; max-height: 240px; overflow-y: auto; }
.cor-compare-drawer-list li {
	display: flex; justify-content: space-between; align-items: center; gap: 8px;
	background: var(--cor-paper); border: 1px solid var(--cor-line); border-radius: 8px;
	padding: 8px 10px; font-size: .85rem;
}
.cor-compare-drawer-list a { color: var(--cor-ink); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cor-compare-drawer-list a:hover { color: var(--cor-cta); }
.cor-compare-drawer-list button {
	background: transparent; border: 0; color: var(--cor-muted);
	font-size: 1.1rem; cursor: pointer; padding: 0 4px; line-height: 1;
}
.cor-compare-drawer-list button:hover { color: var(--cor-cta); }
.cor-compare-drawer-foot { display: flex; gap: 8px; align-items: center; justify-content: space-between; margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--cor-line); }

/* When sticky product CTA is up on mobile, lift the compare drawer above it. */
@media (max-width: 880px) {
	.cor-compare-drawer { bottom: 80px; right: 12px; }
}
