/* ==========================================================================
   DeshipOS — Retail solution widget
   Built to match the rest of the DeshipOS site (hero / features / how-it-works
   / cta-banner widgets): clean & light, flat soft-green icon tiles, solid-green
   buttons, gradient step badges, green-gradient CTA. Mobile-first.
   Depends on assets/css/base.css for design tokens.
   ========================================================================== */

.deshipos-retail {
	--dret-accent:   var(--dew-brand, #16A34A);
	--dret-accent-2: var(--dew-brand-strong, #15803D);
	--dret-accent-3: var(--dew-accent, #22C55E);
	--dret-soft:     var(--dew-brand-soft, rgba(22, 163, 74, .12));
	--dret-ink:      var(--dew-ink, #0F172A);
	--dret-text:     var(--dew-text, #1E293B);
	--dret-muted:    var(--dew-muted, #475569);
	--dret-border:   var(--dew-divider, #E2E8F0);
	--dret-bg:       var(--dew-bg, #FFFFFF);
	--dret-soft-bg:  #FAFBFC;

	box-sizing: border-box;
	width: 100%;
	padding: 56px 20px;
	color: var(--dret-text);
	background: var(--dret-bg);
}
.deshipos-retail *,
.deshipos-retail *::before,
.deshipos-retail *::after { box-sizing: border-box; }

.deshipos-retail__inner {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}

/* Shared eyebrow — soft-green pill (matches How It Works) */
.deshipos-retail__eyebrow {
	display: inline-block;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--dret-accent-2);
	background: var(--dret-soft);
	padding: 6px 14px;
	border-radius: 999px;
	margin-bottom: 18px;
}

/* Block heads */
.deshipos-retail__block { margin-top: 72px; }
.deshipos-retail__block-head {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 12px;
	max-width: 640px;
	margin: 0 auto 40px;
}
.deshipos-retail__block-head .deshipos-retail__eyebrow { margin-bottom: 0; }
.deshipos-retail__block-title {
	margin: 0;
	font-size: clamp(1.625rem, 3.5vw, 2.25rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: var(--dew-tracking-tight);
	color: var(--dret-ink);
}
.deshipos-retail__block-sub {
	margin: 0;
	font-size: 1.0625rem;
	line-height: 1.65;
	color: var(--dret-muted);
}

/* ==========================================================================
   Hero
   ========================================================================== */
.deshipos-retail__hero {
	display: flex;
	flex-direction: column;
	gap: 40px;
	align-items: flex-start;
}
.deshipos-retail__hero-text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	min-width: 0;
}
.deshipos-retail__heading {
	margin: 0 0 18px;
	font-size: clamp(2rem, 5.2vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: var(--dew-tracking-tight);
	color: var(--dret-ink);
}
.deshipos-retail__lead {
	margin: 0 0 28px;
	font-size: 1.0625rem;
	line-height: 1.6;
	color: var(--dret-muted);
	max-width: 560px;
}

/* Buttons — match Hero widget (radius 8px, solid green / bordered) */
.deshipos-retail__cta-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.deshipos-retail__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 13px 24px;
	border-radius: 8px;
	font-size: .9375rem;
	font-weight: 600;
	text-decoration: none;
	border: 1.5px solid transparent;
	cursor: pointer;
	white-space: nowrap;
	transition: transform var(--dew-dur-fast) var(--dew-ease-out),
	            background var(--dew-dur-fast) var(--dew-ease-out),
	            color var(--dew-dur-fast) var(--dew-ease-out),
	            box-shadow var(--dew-dur-fast) var(--dew-ease-out),
	            border-color var(--dew-dur-fast) var(--dew-ease-out);
}
.deshipos-retail__btn--primary {
	background: var(--dret-accent);
	border-color: var(--dret-accent);
	color: #fff;
	box-shadow: var(--dew-shadow-brand-sm);
}
.deshipos-retail__btn--primary:hover {
	background: var(--dret-accent-2);
	border-color: var(--dret-accent-2);
	transform: translateY(-1px);
	box-shadow: var(--dew-shadow-brand-md);
}
.deshipos-retail__btn--primary:hover svg { transform: translateX(3px); }
.deshipos-retail__btn svg { transition: transform var(--dew-dur-base) var(--dew-ease-out); }
.deshipos-retail__btn--ghost {
	background: transparent;
	border-color: var(--dret-border);
	color: var(--dret-ink);
}
.deshipos-retail__btn--ghost:hover { border-color: var(--dret-ink); transform: translateY(-1px); }

/* Hero media */
.deshipos-retail__hero-media {
	position: relative;
	width: 100%;
	min-width: 0;
}
.deshipos-retail__media-img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 15px;
	box-shadow: var(--dew-shadow-lg);
	border-radius: 10px !important;
}
/* Floating badge — clean white card (matches the site's flat card aesthetic) */
.deshipos-retail__badge {
	position: absolute;
	left: 16px;
	bottom: 16px;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 16px;
	background: var(--dret-bg);
	border: 1px solid var(--dret-border);
	border-radius: 14px;
	box-shadow: var(--dew-shadow-lg);
	max-width: 240px;
}
.deshipos-retail__badge-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px; height: 42px;
	flex: none;
	border-radius: 11px;
	background: var(--dret-soft);
	color: var(--dret-accent);
}
.deshipos-retail__badge-meta { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.deshipos-retail__badge-value { font-size: 1.25rem; font-weight: 800; color: var(--dret-ink); line-height: 1.1; }
.deshipos-retail__badge-label { font-size: .75rem; line-height: 1.3; color: var(--dret-muted); }

/* ==========================================================================
   Capabilities — match Features cards exactly
   ========================================================================== */
.deshipos-retail__features-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}
.deshipos-retail__card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
	padding: 24px;
	background: var(--dret-bg);
	border: 1px solid var(--dret-border);
	border-radius: 16px;
	transition: transform var(--dew-dur-base) var(--dew-ease-out),
	            box-shadow var(--dew-dur-base) var(--dew-ease-out),
	            border-color var(--dew-dur-base) var(--dew-ease-out);
}
.deshipos-retail__card:hover {
	transform: translateY(-3px);
	box-shadow: var(--dew-shadow-lg);
	border-color: var(--dret-accent);
}
.deshipos-retail__card-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 12px;
	background: var(--dret-soft);
	color: var(--dret-accent);
	flex: none;
	line-height: 1;
}
.deshipos-retail__card-icon svg { width: 22px; height: 22px; display: block; fill: var(--dret-accent); }
.deshipos-retail__card-icon svg path,
.deshipos-retail__card-icon svg g,
.deshipos-retail__card-icon svg circle,
.deshipos-retail__card-icon svg rect,
.deshipos-retail__card-icon svg polygon { fill: var(--dret-accent); }
.deshipos-retail__card-icon i { font-size: 22px; line-height: 1; color: var(--dret-accent); }
.deshipos-retail__card-title {
	margin: 0;
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--dret-ink);
	letter-spacing: var(--dew-tracking-snug);
}
.deshipos-retail__card-desc {
	margin: 0;
	font-size: .9375rem;
	line-height: 1.6;
	color: var(--dret-muted);
}

/* ==========================================================================
   How it works — match How It Works steps (gradient badges + dashed connector)
   ========================================================================== */
.deshipos-retail__steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
}
.deshipos-retail__step {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 12px;
}
.deshipos-retail__step-num {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--dret-accent) 0%, var(--dret-accent-2) 100%);
	color: #fff;
	font-size: 1.375rem;
	font-weight: 800;
	line-height: 1;
	box-shadow: var(--dew-shadow-md);
}
.deshipos-retail__step-num i { font-size: 1.5rem; color: #fff; }
.deshipos-retail__step-num svg { width: 26px; height: 26px; fill: #fff; }
.deshipos-retail__step-num svg path,
.deshipos-retail__step-num svg g,
.deshipos-retail__step-num svg circle,
.deshipos-retail__step-num svg rect,
.deshipos-retail__step-num svg polygon { fill: #fff; }
.deshipos-retail__step-title {
	margin: 0;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: var(--dew-tracking-snug);
	color: var(--dret-ink);
}
.deshipos-retail__step-desc {
	margin: 0;
	font-size: .9375rem;
	line-height: 1.6;
	color: var(--dret-muted);
}

/* ==========================================================================
   CTA banner — match CTA Banner widget (green gradient pill, pill buttons)
   ========================================================================== */
.deshipos-retail__cta {
	margin-top: 72px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	padding: 40px;
	border-radius: 16px;
	background: linear-gradient(115deg, #1BA950 0%, #17A24A 55%, #138C43 100%);
	color: #fff;
}
.deshipos-retail__cta-heading {
	margin: 0 0 10px;
	font-size: clamp(1.375rem, 1.1rem + 1.2vw, 2rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: var(--dew-tracking-tight);
	color: #fff;
}
.deshipos-retail__cta-text {
	margin: 0;
	font-size: clamp(.9375rem, .85rem + .25vw, 1.0625rem);
	line-height: 1.55;
	color: rgba(255, 255, 255, .9);
	max-width: 560px;
}
.deshipos-retail__btn--light {
	flex: none;
	min-height: 46px;
	border-radius: 999px;
	padding: 12px 26px;
	font-weight: 700;
	color: var(--dret-accent-2);
	background: #fff;
	box-shadow: 0 6px 18px -6px rgba(0, 0, 0, .35);
}
.deshipos-retail__btn--light:hover { transform: translateY(-1px); box-shadow: 0 10px 24px -8px rgba(0, 0, 0, .4); }
.deshipos-retail__btn--light:hover svg { transform: translateX(3px); }

/* ==========================================================================
   Scroll reveal
   ========================================================================== */
.deshipos-retail.js-reveal [data-reveal] {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity .6s var(--dew-ease-out), transform .6s var(--dew-ease-out);
	will-change: opacity, transform;
}
.deshipos-retail.js-reveal [data-reveal].is-in { opacity: 1; transform: none; }

/* ==========================================================================
   Responsive — mirror the site's breakpoints (600 / 960)
   ========================================================================== */
@media (min-width: 600px) {
	.deshipos-retail { padding: 64px 32px; }
	.deshipos-retail__features-grid { grid-template-columns: repeat(2, 1fr); }
	.deshipos-retail__steps { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
	.deshipos-retail { padding: 88px 40px; }
	.deshipos-retail__block { margin-top: 96px; }
	.deshipos-retail__cta { margin-top: 96px; }

	/* Hero: two columns (text left, image right) */
	.deshipos-retail__hero {
		flex-direction: row;
		align-items: center;
		gap: 64px;
	}
	.deshipos-retail__hero--rev { flex-direction: row-reverse; }
	.deshipos-retail__hero-text,
	.deshipos-retail__hero-media { flex: 1 1 0; }

	.deshipos-retail__features-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; }

	/* Steps: 4 across with a dashed connector behind the badges */
	.deshipos-retail__steps { grid-template-columns: repeat(4, 1fr); }
	.deshipos-retail__steps--connect .deshipos-retail__step:not(:last-child)::before {
		content: "";
		position: absolute;
		top: 29px;
		left: 50%;
		width: calc(100% + 32px);
		height: 0;
		border-top: 2px dashed var(--dret-border);
		z-index: 0;
	}
}

@media (max-width: 600px) {
	.deshipos-retail__cta { flex-direction: column; align-items: flex-start; gap: 22px; text-align: left; }
	.deshipos-retail__btn--light { width: 100%; }
	.deshipos-retail__cta-row .deshipos-retail__btn { flex: 1; }
}

@media (prefers-reduced-motion: reduce) {
	.deshipos-retail *,
	.deshipos-retail *::before,
	.deshipos-retail *::after { transition-duration: .01ms !important; }
	.deshipos-retail.js-reveal [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
	.deshipos-retail__btn:hover, .deshipos-retail__card:hover { transform: none !important; }
}
