/* ==========================================================================
   Simple Upsell Pro – Premium Stylesheet
   US Market – Modern E-commerce Design
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Variables / Design Tokens
   -------------------------------------------------------------------------- */
:root {
	/* Brand Colors */
	--sup-navy: #0f172a;
	--sup-navy-soft: #1e293b;
	--sup-teal: #0ea5e9;
	--sup-teal-dark: #0284c7;
	--sup-orange: #f97316;
	--sup-orange-soft: #fff7ed;
	--sup-green: #16a34a;
	--sup-green-light: #f0fdf4;
	--sup-red: #dc2626;
	--sup-gold: #f59e0b;
	--sup-gold-light: #fffbeb;

	/* Neutral */
	--sup-white: #ffffff;
	--sup-gray-50: #f8fafc;
	--sup-gray-100: #f1f5f9;
	--sup-gray-200: #e2e8f0;
	--sup-gray-300: #cbd5e1;
	--sup-gray-400: #94a3b8;
	--sup-gray-600: #475569;
	--sup-gray-700: #334155;
	--sup-gray-900: #0f172a;

	/* Typography */
	--sup-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
	--sup-font-size: 14px;

	/* Spacing */
	--sup-radius: 12px;
	--sup-radius-sm: 8px;
	--sup-radius-lg: 16px;

	/* Shadows */
	--sup-shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);
	--sup-shadow: 0 4px 16px rgba(0, 0, 0, .10), 0 2px 6px rgba(0, 0, 0, .06);
	--sup-shadow-lg: 0 10px 40px rgba(0, 0, 0, .15);

	/* Transitions */
	--sup-transition: 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ==========================================================================
   UPSELL TIER WIDGET
   ========================================================================== */

.sup-upsell-widget {
	font-family: var(--sup-font);
	margin: 28px 0;
	background: linear-gradient(135deg, var(--sup-gold-light) 0%, #fff8f0 100%);
	border: 1.5px solid #fde68a;
	border-radius: var(--sup-radius-lg);
	padding: 24px;
	box-shadow: var(--sup-shadow);
	overflow: hidden;
	position: relative;
}

.sup-upsell-widget::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 140px;
	height: 140px;
	background: radial-gradient(circle, rgba(249, 115, 22, .10) 0%, transparent 70%);
	border-radius: 50%;
	transform: translate(40px, -40px);
	pointer-events: none;
}

/* Header */
.sup-upsell-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
}

.sup-upsell-icon {
	font-size: 22px;
	line-height: 1;
}

.sup-upsell-title {
	margin: 0 !important;
	font-size: 1.05rem !important;
	font-weight: 700 !important;
	color: var(--sup-navy) !important;
	letter-spacing: -0.01em;
}

/* Tier Rows */
.sup-upsell-tiers {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 20px;
}

.sup-tier-row {
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--sup-white);
	border: 1.5px solid var(--sup-gray-200);
	border-radius: var(--sup-radius);
	padding: 12px 16px;
	transition: all var(--sup-transition);
	position: relative;
}

.sup-tier-row:hover,
.sup-tier-row.is-active {
	border-color: var(--sup-orange);
	box-shadow: 0 0 0 3px rgba(249, 115, 22, .12);
	background: #fff9f5;
}

.sup-tier-row.is-active .sup-tier-badge {
	background: var(--sup-orange);
	color: var(--sup-white);
}

.sup-tier-row.is-unlocked {
	background: var(--sup-green-light);
	border-color: var(--sup-green);
}

.sup-tier-row.is-unlocked .sup-tier-badge {
	background: var(--sup-green);
	color: var(--sup-white);
}

.sup-tier-badge {
	background: var(--sup-gray-100);
	color: var(--sup-gray-700);
	padding: 5px 12px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 700;
	white-space: nowrap;
	transition: all var(--sup-transition);
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.sup-tier-qty {
	display: block;
}

.sup-tier-arrow {
	color: var(--sup-gray-400);
	font-size: 18px;
	flex-shrink: 0;
}

.sup-tier-save {
	flex: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 6px;
}

.sup-tier-pct {
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--sup-orange);
}

.sup-tier-example {
	font-size: 0.82rem;
	color: var(--sup-gray-600);
}

.sup-tier-crown {
	font-size: 12px;
	font-weight: 700;
	color: var(--sup-gold);
	background: var(--sup-gold-light);
	border: 1px solid #fde68a;
	border-radius: 20px;
	padding: 4px 10px;
	white-space: nowrap;
}

/* Progress Bar */
.sup-upsell-progress-wrap {
	margin-top: 4px;
}

.sup-upsell-progress-bar {
	background: var(--sup-gray-200);
	border-radius: 100px;
	height: 8px;
	overflow: hidden;
	margin-bottom: 8px;
}

.sup-upsell-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--sup-orange), var(--sup-gold));
	border-radius: 100px;
	transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.sup-upsell-progress-label {
	font-size: 12.5px;
	color: var(--sup-gray-600);
	margin: 0 !important;
	text-align: center;
	font-style: italic;
}

/* ==========================================================================
   FREQUENTLY BOUGHT TOGETHER – COMPACT WIDGET
   Compact design: fits neatly below Add to Cart without breaking layout
   ========================================================================== */

.sup-fbt {
	font-family: var(--sup-font);
	margin: 16px 0 0;
	padding: 14px 16px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	box-sizing: border-box;
	width: 100%;
	clear: both;
}

/* Section heading */
.sup-fbt-heading {
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: .07em !important;
	text-transform: uppercase !important;
	color: #94a3b8 !important;
	margin: 0 0 12px !important;
	padding: 0 !important;
	border: none !important;
	line-height: 1 !important;
}

/* --------------------------------------------------------------------------
   LAYOUT: products row + CTA — all in one compact row
   -------------------------------------------------------------------------- */
.sup-fbt-layout {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: nowrap;
}

/* Products strip — scrollable, no scrollbar visible */
.sup-fbt-products {
	display: flex;
	align-items: center;
	gap: 0;
	flex: 1 1 0;
	min-width: 0;
	flex-wrap: nowrap;
	overflow-x: auto;
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.sup-fbt-products::-webkit-scrollbar {
	display: none;
}

/* "+" separator */
.sup-fbt-sep {
	font-size: 14px;
	font-weight: 400;
	color: #cbd5e1;
	padding: 0 5px;
	flex-shrink: 0;
	line-height: 1;
}

/* --------------------------------------------------------------------------
   PRODUCT CARD — compact thumbnail
   -------------------------------------------------------------------------- */
.sup-fbt-card {
	flex: 0 0 auto;
	width: 64px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 5px;
}

/* Label wrapping the checkbox + image */
.sup-fbt-img-label {
	position: relative;
	display: block;
	cursor: pointer;
	width: 60px;
	height: 60px;
	border-radius: 6px;
	overflow: hidden;
	border: 2px solid #e2e8f0;
	transition: border-color .2s;
	flex-shrink: 0;
}

.sup-fbt-img-label:hover {
	border-color: #94a3b8;
}

/* Hidden native checkbox */
.sup-fbt-cb {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
	pointer-events: none;
}

/* Product image fills the label */
.sup-fbt-img {
	display: block;
	width: 100%;
	height: 100%;
}

.sup-fbt-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: opacity .2s;
}

/* Custom check overlay — top-left corner */
.sup-fbt-tick {
	position: absolute;
	top: 4px;
	left: 4px;
	width: 16px;
	height: 16px;
	background: #e2e8f0;
	border-radius: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
	transition: background .15s;
	box-shadow: 0 1px 2px rgba(0,0,0,.15);
}

.sup-fbt-tick svg {
	opacity: 0;
	transition: opacity .15s;
}

.sup-fbt-cb:checked ~ .sup-fbt-tick,
.sup-fbt-cb:disabled ~ .sup-fbt-tick {
	background: #0f172a;
}

.sup-fbt-cb:checked ~ .sup-fbt-tick svg,
.sup-fbt-cb:disabled ~ .sup-fbt-tick svg {
	opacity: 1;
}

.sup-fbt-cb:not(:checked):not(:disabled) ~ .sup-fbt-img img {
	opacity: .4;
	filter: grayscale(60%);
}

/* Current product: accent border */
.sup-fbt-card--current .sup-fbt-img-label {
	border-color: #0f172a;
}

/* Product name + price below image */
.sup-fbt-card-info {
	width: 100%;
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.sup-fbt-name {
	font-size: 10px;
	font-weight: 500;
	color: #374151;
	text-decoration: none;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.3;
}

.sup-fbt-name:hover {
	color: #111827;
	text-decoration: underline;
}

.sup-fbt-price {
	font-size: 11px;
	font-weight: 700;
	color: #0f172a;
}

/* --------------------------------------------------------------------------
   CTA BOX — right side, compact
   -------------------------------------------------------------------------- */
.sup-fbt-cta {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 130px;
	max-width: 160px;
}

.sup-fbt-totals {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sup-fbt-totals-label {
	font-size: 10px;
	font-weight: 600;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: #9ca3af;
	line-height: 1;
}

.sup-fbt-totals-prices {
	display: flex;
	align-items: baseline;
	gap: 5px;
	flex-wrap: wrap;
}

.sup-fbt-price-was {
	font-size: 12px;
	color: #9ca3af;
	text-decoration: line-through;
}

.sup-fbt-price-now {
	font-size: 18px;
	font-weight: 800;
	color: #0f172a;
	letter-spacing: -.02em;
	line-height: 1;
}

.sup-fbt-save-badge {
	display: inline-block;
	background: #dcfce7;
	color: #15803d;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 20px;
	width: fit-content;
}

/* CTA Button */
.sup-fbt-atc-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	background: #0f172a;
	color: #fff !important;
	border: none;
	border-radius: 7px;
	padding: 9px 12px;
	font-family: var(--sup-font);
	font-size: 12px;
	font-weight: 700;
	cursor: pointer;
	transition: background .2s, transform .15s, box-shadow .2s;
	letter-spacing: .01em;
	width: 100%;
	white-space: nowrap;
	line-height: 1;
}

.sup-fbt-atc-btn:hover {
	background: #1e293b;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(15, 23, 42, .20);
}

.sup-fbt-atc-btn:active {
	transform: translateY(0);
	box-shadow: none;
}

.sup-fbt-atc-btn:disabled {
	opacity: .6;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* Spinner */
.sup-spin {
	width: 13px;
	height: 13px;
	animation: sup-spin-anim .9s linear infinite;
}

.sup-spin circle {
	stroke: #fff;
	stroke-linecap: round;
	animation: sup-dash-anim 1.5s ease-in-out infinite;
}

@keyframes sup-spin-anim {
	100% { transform: rotate(360deg); }
}

@keyframes sup-dash-anim {
	0%   { stroke-dasharray: 1, 150;  stroke-dashoffset: 0;    }
	50%  { stroke-dasharray: 90, 150; stroke-dashoffset: -35;  }
	100% { stroke-dasharray: 90, 150; stroke-dashoffset: -124; }
}

/* --------------------------------------------------------------------------
   RESPONSIVE — stack vertically on very narrow screens
   -------------------------------------------------------------------------- */
@media (max-width: 480px) {
	.sup-fbt-layout {
		flex-wrap: wrap;
	}

	.sup-fbt-cta {
		max-width: 100%;
		min-width: 0;
		width: 100%;
	}

	.sup-fbt-products {
		justify-content: flex-start;
	}
}








/* ==========================================================================
   ANNOUNCEMENT BAR
   ========================================================================== */

.sup-announcement-bar {
	background: linear-gradient(90deg, var(--sup-navy) 0%, var(--sup-navy-soft) 100%);
	color: var(--sup-white);
	text-align: center;
	padding: 11px 40px;
	font-weight: 600;
	font-size: 14px;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10000;
	box-shadow: 0 2px 12px rgba(0, 0, 0, .15);
}

.admin-bar .sup-announcement-bar {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .sup-announcement-bar {
		top: 46px;
	}
}

/* ==========================================================================
   SIDE CART
   ========================================================================== */

.sup-side-cart-wrapper {
	position: fixed;
	inset: 0;
	z-index: 9998;
	visibility: hidden;
	transition: visibility 0.3s;
}

.sup-side-cart-wrapper.active {
	visibility: visible;
}

.sup-side-cart-overlay {
	position: absolute;
	inset: 0;
	background: rgba(15, 23, 42, .5);
	backdrop-filter: blur(2px);
	opacity: 0;
	transition: opacity 0.3s;
}

.sup-side-cart-wrapper.active .sup-side-cart-overlay {
	opacity: 1;
}

.sup-side-cart-panel {
	position: absolute;
	top: 0;
	right: -420px;
	width: 380px;
	max-width: 95vw;
	height: 100%;
	background: var(--sup-white);
	box-shadow: -8px 0 40px rgba(0, 0, 0, .18);
	transition: right 0.35s cubic-bezier(0.16, 1, 0.3, 1);
	display: flex;
	flex-direction: column;
}

.sup-side-cart-wrapper.active .sup-side-cart-panel {
	right: 0;
}

.sup-side-cart-header {
	padding: 20px;
	border-bottom: 1px solid var(--sup-gray-100);
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--sup-navy);
	color: var(--sup-white);
}

.sup-side-cart-header h3 {
	margin: 0 !important;
	font-size: 1.1em !important;
	color: var(--sup-white) !important;
}

.sup-side-cart-close {
	background: rgba(255, 255, 255, .1);
	border: none;
	color: var(--sup-white);
	font-size: 20px;
	cursor: pointer;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--sup-transition);
}

.sup-side-cart-close:hover {
	background: rgba(255, 255, 255, .2);
}

.sup-side-cart-body {
	flex: 1;
	overflow-y: auto;
	padding: 20px;
}

.sup-cart-items {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.sup-cart-item {
	display: flex;
	gap: 14px;
	padding-bottom: 14px;
	margin-bottom: 14px;
	border-bottom: 1px solid var(--sup-gray-100);
	position: relative;
}

.sup-item-thumb img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: var(--sup-radius-sm);
}

.sup-item-name {
	font-weight: 600;
	font-size: 13px;
	display: block;
	margin-bottom: 4px;
}

.sup-qty-controls {
	display: flex;
	align-items: center;
	border: 1px solid var(--sup-gray-200);
	border-radius: var(--sup-radius-sm);
	overflow: hidden;
	margin-top: 8px;
	width: fit-content;
}

.sup-qty-btn {
	background: var(--sup-gray-100);
	border: none;
	width: 26px;
	height: 26px;
	cursor: pointer;
	font-size: 14px;
	transition: background var(--sup-transition);
}

.sup-qty-btn:hover {
	background: var(--sup-gray-200);
}

.sup-qty-controls input {
	width: 32px;
	text-align: center;
	border: none;
	font-size: 13px;
	background: transparent;
}

.sup-item-remove {
	position: absolute;
	top: 0;
	right: 0;
	color: var(--sup-gray-400);
	text-decoration: none;
	font-size: 18px;
	line-height: 1;
	transition: color var(--sup-transition);
}

.sup-item-remove:hover {
	color: var(--sup-red);
}

.sup-cart-summary {
	padding-top: 16px;
	border-top: 2px solid var(--sup-gray-200);
}

.sup-subtotal {
	display: flex;
	justify-content: space-between;
	font-size: 1.05em;
	font-weight: 700;
	margin-bottom: 16px;
}

.sup-cart-summary .button.checkout {
	width: 100%;
	text-align: center;
	padding: 14px;
	background: linear-gradient(135deg, var(--sup-teal), var(--sup-teal-dark));
	color: white !important;
	border-radius: var(--sup-radius-sm);
	font-weight: 700;
	font-size: 15px;
	transition: all var(--sup-transition);
}

.sup-cart-summary .button.checkout:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(14, 165, 233, .3);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 480px) {
	.sup-fbt-footer {
		flex-direction: column;
		align-items: stretch;
	}

	.sup-fbt-add-btn {
		width: 100%;
		justify-content: center;
	}

	.sup-fbt-thumb {
		width: 70px;
		height: 70px;
	}

	.sup-upsell-widget {
		padding: 18px;
	}

	.sup-tier-example {
		display: none;
	}
}

/* ==========================================================================
   SMART SUGGESTION STRIP
   ========================================================================== */

.sup-suggestion-strip {
	font-family: var(--sup-font);
	margin: 24px 0;
	border-radius: var(--sup-radius-lg);
	border: 1.5px solid #fde68a;
	background: linear-gradient(135deg, #fffbeb 0%, #fff9f0 100%);
	overflow: hidden;
	box-shadow: var(--sup-shadow);
	position: relative;
}

.sup-suggestion-strip::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--sup-orange), var(--sup-gold), var(--sup-orange));
	background-size: 200%;
	animation: sup-shimmer 2.5s linear infinite;
}

@keyframes sup-shimmer {
	0% {
		background-position: 200% center;
	}

	100% {
		background-position: -200% center;
	}
}

/* Eyebrow */
.sup-suggestion-eyebrow {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	background: rgba(249, 115, 22, 0.06);
	border-bottom: 1px solid #fde68a;
	font-size: 12.5px;
	font-weight: 700;
	color: #92400e;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.sup-suggestion-spark {
	font-size: 16px;
}

.sup-suggestion-deal-badge {
	margin-left: auto;
	background: var(--sup-orange);
	color: var(--sup-white);
	font-size: 11px;
	padding: 3px 10px;
	border-radius: 20px;
}

/* Body */
.sup-suggestion-body {
	padding: 18px 20px;
}

.sup-suggestion-headline {
	font-size: 15px;
	font-weight: 700;
	color: var(--sup-navy);
	margin: 0 0 4px 0 !important;
}

.sup-suggestion-sub {
	font-size: 12px;
	color: var(--sup-gray-600);
	margin: 0 0 16px 0 !important;
}

/* Suggestion products row */
.sup-suggestion-products {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.sup-suggestion-product {
	display: flex;
	align-items: center;
	gap: 12px;
	background: var(--sup-white);
	border: 1px solid var(--sup-gray-200);
	border-radius: var(--sup-radius-sm);
	padding: 10px 14px;
	transition: all var(--sup-transition);
}

.sup-suggestion-product:hover {
	border-color: var(--sup-orange);
	box-shadow: 0 0 0 3px rgba(249, 115, 22, .1);
}

.sup-suggestion-thumb {
	flex-shrink: 0;
	width: 52px;
	height: 52px;
	overflow: hidden;
	border-radius: 6px;
	display: block;
}

.sup-suggestion-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--sup-transition);
}

.sup-suggestion-product:hover .sup-suggestion-thumb img {
	transform: scale(1.07);
}

.sup-suggestion-info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.sup-suggestion-name {
	font-size: 13px;
	font-weight: 600;
	color: var(--sup-navy);
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: color var(--sup-transition);
}

.sup-suggestion-name:hover {
	color: var(--sup-teal);
}

.sup-suggestion-price {
	font-size: 13px;
	font-weight: 700;
	color: var(--sup-gray-600);
}

/* Add to cart button (per-product) */
.sup-suggestion-add-btn {
	flex-shrink: 0;
	background: var(--sup-orange);
	color: var(--sup-white) !important;
	border: none;
	border-radius: var(--sup-radius-sm);
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: all var(--sup-transition);
	white-space: nowrap;
}

.sup-suggestion-add-btn:hover {
	background: #ea6f04;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(249, 115, 22, .35);
}

.sup-suggestion-add-btn:active {
	transform: translateY(0);
}

.sup-suggestion-add-btn.is-added {
	background: var(--sup-green);
}

/* Footer strip */
.sup-suggestion-footer {
	padding: 10px 20px;
	background: rgba(249, 115, 22, 0.06);
	border-top: 1px solid #fde68a;
	font-size: 12.5px;
	color: #92400e;
	display: flex;
	align-items: center;
	gap: 6px;
}

.sup-suggestion-footer strong {
	color: var(--sup-orange);
}

/* Responsive */
@media (max-width: 480px) {
	.sup-suggestion-product {
		flex-wrap: wrap;
	}

	.sup-suggestion-add-btn {
		width: 100%;
		text-align: center;
	}
}