/* ==========================================================================
   DeshipOS — Pricing widget
   Eyebrow + heading + 3-column pricing cards (featured plan highlighted).
   Depends on assets/css/base.css for design tokens.
   ========================================================================== */

.deshipos-pricing {
	--dpr-brand:        var(--dew-brand, #16A34A);
	--dpr-brand-strong: var(--dew-brand-strong, #15803D);
	--dpr-brand-soft:   var(--dew-brand-soft, rgba(22, 163, 74, .12));
	--dpr-text:         var(--dew-ink, #0F172A);
	--dpr-muted:        var(--dew-muted, #475569);
	--dpr-faint:        var(--dew-faint, #94A3B8);
	--dpr-border:       #BBF7D0;
	--dpr-bg:           #FFFFFF;
	--dpr-card-bg:      #FFFFFF;

	box-sizing: border-box;
	width: 100%;
	padding: 80px 20px;
	background: var(--dpr-bg);
}
.deshipos-pricing *,
.deshipos-pricing *::before,
.deshipos-pricing *::after { box-sizing: border-box; }

.deshipos-pricing__inner {
	max-width: 1200px;
	margin: 0 auto;
}

/* ----- Header ----- */
.deshipos-pricing__head {
	text-align: center;
	margin: 0 auto 48px;
	max-width: 760px;
}

.deshipos-pricing__eyebrow {
	display: inline-block;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--dpr-brand);
	margin-bottom: 12px;
}

.deshipos-pricing__heading {
	margin: 0;
	font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: var(--dew-tracking-tight);
	color: var(--dpr-text);
}

/* ----- Grid ----- */
.deshipos-pricing__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	align-items: stretch;
}

/* ----- Card ----- */
.deshipos-pricing__card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--dpr-card-bg);
	border: 1.5px solid var(--dpr-border);
	border-radius: 18px;
	padding: 36px 28px 32px;
	transition:
		transform var(--dew-dur-base, 220ms) var(--dew-ease-out, ease),
		box-shadow var(--dew-dur-base, 220ms) var(--dew-ease-out, ease),
		border-color var(--dew-dur-base, 220ms) var(--dew-ease-out, ease);
}

.deshipos-pricing__card:hover {
	transform: translateY(-3px);
	box-shadow: var(--dew-shadow-md, 0 4px 14px rgba(15, 23, 42, .08));
}

.deshipos-pricing__card--featured {
	border-color: var(--dpr-brand);
	border-width: 2px;
	box-shadow: 0 10px 30px -10px rgba(22, 163, 74, .25);
}

/* ----- Badge ----- */
.deshipos-pricing__badge {
	position: absolute;
	top: 24px;
	right: 24px;
	background: var(--dpr-brand);
	color: #FFFFFF;
	font-size: 12px;
	font-weight: 700;
	padding: 7px 16px;
	border-radius: 999px;
	letter-spacing: .01em;
	white-space: nowrap;
	box-shadow: 0 4px 12px -2px rgba(22, 163, 74, .35);
}

/* ----- Head (name + subtitle) ----- */
.deshipos-pricing__card-head {
	margin-bottom: 18px;
}

.deshipos-pricing__card--featured .deshipos-pricing__card-head {
	padding-right: 130px;
}

.deshipos-pricing__name {
	margin: 0 0 6px;
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--dpr-text);
	letter-spacing: var(--dew-tracking-snug);
}

.deshipos-pricing__subtitle {
	margin: 0;
	font-size: .9375rem;
	color: var(--dpr-muted);
	line-height: 1.5;
}

/* ----- Price ----- */
.deshipos-pricing__price-row {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 2px;
	margin: 6px 0 28px;
	color: var(--dpr-text);
}

.deshipos-pricing__currency {
	font-size: 1.875rem;
	font-weight: 800;
	line-height: 1;
}

.deshipos-pricing__price {
	font-size: 2.75rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -.02em;
}

.deshipos-pricing__price--custom {
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.1;
}

.deshipos-pricing__period {
	font-size: 1rem;
	font-weight: 500;
	color: var(--dpr-muted);
	margin-left: 4px;
}

/* ----- Features list ----- */
.deshipos-pricing__features {
	list-style: none;
	margin: 0 0 32px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
	flex: 1 1 auto;
}

.deshipos-pricing__feature {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: .9375rem;
	color: var(--dpr-text);
	line-height: 1.45;
}

.deshipos-pricing__check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	border-radius: 999px;
	color: var(--dpr-brand);
	margin-top: 1px;
}

/* ----- Button ----- */
.deshipos-pricing__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 48px;
	padding: 12px 20px;
	font-size: .9375rem;
	font-weight: 700;
	letter-spacing: var(--dew-tracking-snug);
	border-radius: 10px;
	text-decoration: none;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition:
		background var(--dew-dur-fast, 120ms) var(--dew-ease-out, ease),
		color var(--dew-dur-fast, 120ms) var(--dew-ease-out, ease),
		border-color var(--dew-dur-fast, 120ms) var(--dew-ease-out, ease),
		transform var(--dew-dur-fast, 120ms) var(--dew-ease-out, ease),
		box-shadow var(--dew-dur-base, 220ms) var(--dew-ease-out, ease);
}

.deshipos-pricing__btn:active {
	transform: scale(.98);
}

.deshipos-pricing__btn--outline {
	background: transparent;
	color: var(--dpr-brand);
	border-color: var(--dpr-brand);
}
.deshipos-pricing__btn--outline:hover {
	background: var(--dpr-brand-soft);
}

.deshipos-pricing__btn--filled {
	background: var(--dpr-brand);
	color: #FFFFFF;
	border-color: var(--dpr-brand);
	box-shadow: 0 6px 16px -6px rgba(22, 163, 74, .55);
}
.deshipos-pricing__btn--filled:hover {
	background: var(--dpr-brand-strong);
	border-color: var(--dpr-brand-strong);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

/* Medium screens — keep 3 columns but tighter */
@media (max-width: 1100px) {
	.deshipos-pricing__card {
		padding: 32px 22px 28px;
	}
	.deshipos-pricing__price { font-size: 2.5rem; }
}

/* Tablet — 2 columns */
@media (max-width: 960px) {
	.deshipos-pricing {
		padding: 64px 18px;
	}
	.deshipos-pricing__head {
		margin-bottom: 36px;
	}
	.deshipos-pricing__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
	/* If there are 3 cards, the third one spans full width and stays centered */
	.deshipos-pricing__card:nth-child(3):last-child {
		grid-column: 1 / -1;
		max-width: 520px;
		margin: 0 auto;
		width: 100%;
	}
}

/* Mobile — 1 column */
@media (max-width: 640px) {
	.deshipos-pricing {
		padding: 48px 14px;
	}
	.deshipos-pricing__head {
		margin-bottom: 28px;
	}
	.deshipos-pricing__heading {
		font-size: clamp(1.375rem, 1.1rem + 1.2vw, 1.75rem);
	}
	.deshipos-pricing__grid {
		grid-template-columns: 1fr;
		gap: 18px;
	}
	.deshipos-pricing__card,
	.deshipos-pricing__card:nth-child(3):last-child {
		padding: 28px 22px 26px;
		max-width: 100%;
	}
	.deshipos-pricing__badge {
		right: 18px;
		top: 18px;
		font-size: 11px;
		padding: 5px 12px;
	}
	.deshipos-pricing__card--featured .deshipos-pricing__card-head {
		padding-right: 118px;
	}
	.deshipos-pricing__name { font-size: 1.25rem; }
	.deshipos-pricing__currency { font-size: 1.625rem; }
	.deshipos-pricing__price { font-size: 2.375rem; }
	.deshipos-pricing__price--custom { font-size: 1.75rem; }
	.deshipos-pricing__features { margin-bottom: 26px; gap: 12px; }
	.deshipos-pricing__feature { font-size: .9rem; }
	.deshipos-pricing__btn {
		min-height: 46px;
		font-size: .9rem;
	}
}

/* Very small phones */
@media (max-width: 360px) {
	.deshipos-pricing__card,
	.deshipos-pricing__card:nth-child(3):last-child {
		padding: 24px 18px 22px;
	}
	.deshipos-pricing__price { font-size: 2.125rem; }
	.deshipos-pricing__currency { font-size: 1.5rem; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.deshipos-pricing__card,
	.deshipos-pricing__btn {
		transition-duration: .01ms !important;
	}
	.deshipos-pricing__card:hover {
		transform: none;
	}
}
