/* ==========================================================================
   DeshipOS — About widget (bento edition)
   A modern, asymmetric "bento" layout: a large story card beside an image +
   gradient highlight card, a row of floating stat cards, and value cards with
   gradient icon chips. Mobile-first. Depends on assets/css/base.css.
   ========================================================================== */

.deshipos-about {
	--dab-accent:    var(--dew-brand, #16A34A);
	--dab-accent-2:  var(--dew-brand-strong, #15803D);
	--dab-soft:      var(--dew-brand-soft, rgba(22, 163, 74, .12));
	--dab-soft:      color-mix(in srgb, var(--dab-accent) 12%, transparent);
	--dab-grad:      linear-gradient(135deg, var(--dab-accent) 0%, var(--dab-accent-2) 100%);
	--dab-ink:       var(--dew-ink, #0F172A);
	--dab-text:      var(--dew-text, #1E293B);
	--dab-muted:     var(--dew-muted, #475569);
	--dab-divider:   var(--dew-divider, #E2E8F0);
	--dab-surface:   var(--dew-surface, #F8FAFC);
	--dab-card-bg:   var(--dew-bg, #FFFFFF);
	--dab-radius:    24px;

	position: relative;
	box-sizing: border-box;
	width: 100%;
	padding: 56px 20px;
	background: transparent;
	color: var(--dab-text);
	overflow: hidden;
}
.deshipos-about *,
.deshipos-about *::before,
.deshipos-about *::after { box-sizing: border-box; }

/* Soft brand glows in the backdrop for depth. */
.deshipos-about::before,
.deshipos-about::after {
	content: "";
	position: absolute;
	width: 520px;
	height: 520px;
	border-radius: 50%;
	pointer-events: none;
	z-index: 0;
	filter: blur(8px);
}
.deshipos-about::before {
	top: -180px; right: -140px;
	background: radial-gradient(circle, var(--dab-soft), transparent 70%);
}
.deshipos-about::after {
	bottom: -200px; left: -160px;
	background: radial-gradient(circle, color-mix(in srgb, var(--dab-accent) 8%, transparent), transparent 70%);
}

.deshipos-about__inner {
	position: relative;
	z-index: 1;
	max-width: 1140px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.deshipos-about__eyebrow {
	display: inline-block;
	width: max-content;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--dab-accent-2);
	background: var(--dab-soft);
	padding: 6px 14px;
	border-radius: 999px;
}

/* ==========================================================================
   Intro — bento: story card + aside (image card + gradient highlight)
   ========================================================================== */
.deshipos-about__bento {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}

.deshipos-about__story {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 18px;
	padding: clamp(26px, 5vw, 44px);
	background: var(--dab-card-bg);
	border: 1px solid var(--dab-divider);
	border-radius: var(--dab-radius);
	box-shadow: var(--dew-shadow-sm);
}
.deshipos-about__heading {
	margin: 0;
	font-size: clamp(1.875rem, 4.5vw, 3rem);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: var(--dew-tracking-tight);
	color: var(--dab-ink);
}
.deshipos-about__lead {
	margin: 0;
	font-size: 1.1875rem;
	line-height: 1.6;
	font-weight: 500;
	color: var(--dab-text);
}
.deshipos-about__body {
	margin: 0;
	font-size: 1rem;
	line-height: 1.7;
	color: var(--dab-muted);
}
.deshipos-about__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 4px;
	padding: 13px 24px;
	border-radius: 999px;
	background: var(--dab-grad);
	color: #FFFFFF;
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	box-shadow: 0 8px 20px -6px color-mix(in srgb, var(--dab-accent) 55%, transparent);
	transition: transform var(--dew-dur-fast) var(--dew-ease-out),
	            box-shadow var(--dew-dur-base) var(--dew-ease-out);
}
.deshipos-about__cta:hover { transform: translateY(-2px); }
.deshipos-about__cta svg { transition: transform var(--dew-dur-base) var(--dew-ease-out); }
.deshipos-about__cta:hover svg { transform: translateX(4px); }

/* Aside column: image card on top, gradient highlight below. */
.deshipos-about__aside {
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-height: 0;
}
.deshipos-about__media {
	flex: 1 1 auto;
	min-height: 220px;
	border-radius: var(--dab-radius);
	overflow: hidden;
	border: 1px solid var(--dab-divider);
	box-shadow: var(--dew-shadow-sm);
}
.deshipos-about__media img {
	width: 100%;
	height: 100%;
	min-height: 220px;
	object-fit: cover;
	display: block;
}

/* Gradient highlight stat card. */
.deshipos-about__highlight {
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 4px;
	padding: 26px 28px;
	border-radius: var(--dab-radius);
	background: var(--dab-grad);
	color: #FFFFFF;
	box-shadow: 0 18px 40px -16px color-mix(in srgb, var(--dab-accent) 55%, transparent);
}
.deshipos-about__highlight::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(60% 80% at 90% 10%, rgba(255,255,255,.22), transparent 70%),
		radial-gradient(50% 70% at 0% 100%, rgba(255,255,255,.12), transparent 70%);
	pointer-events: none;
}
.deshipos-about__highlight-value {
	position: relative;
	font-size: clamp(2.25rem, 5vw, 3rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: var(--dew-tracking-tight);
}
.deshipos-about__highlight-label {
	position: relative;
	font-size: 1rem;
	font-weight: 600;
	opacity: .92;
}

/* ==========================================================================
   Stats — floating cards
   ========================================================================== */
.deshipos-about__stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}
.deshipos-about__stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 8px;
	padding: 26px 18px;
	background: var(--dab-card-bg);
	border: 1px solid var(--dab-divider);
	border-radius: 18px;
	box-shadow: var(--dew-shadow-sm);
	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-about__stat:hover {
	transform: translateY(-4px);
	box-shadow: var(--dew-shadow-lg);
	border-color: var(--dab-accent);
}
.deshipos-about__stat-value {
	font-size: clamp(1.875rem, 4vw, 2.5rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: var(--dew-tracking-tight);
	background: var(--dab-grad);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: var(--dab-accent-2);
}
.deshipos-about__stat-label {
	font-size: .9375rem;
	font-weight: 600;
	color: var(--dab-muted);
}

/* ==========================================================================
   Values
   ========================================================================== */
.deshipos-about__values-head {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 14px;
	max-width: 640px;
	margin: 12px auto 28px;
}
.deshipos-about__values-title {
	margin: 0;
	font-size: clamp(1.625rem, 3.5vw, 2.25rem);
	font-weight: 800;
	line-height: 1.18;
	letter-spacing: var(--dew-tracking-tight);
	color: var(--dab-ink);
}
.deshipos-about__values-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
}
.deshipos-about__value {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
	padding: 26px 24px;
	background: var(--dab-card-bg);
	border: 1px solid var(--dab-divider);
	border-radius: 18px;
	box-shadow: var(--dew-shadow-sm);
	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-about__value:hover {
	transform: translateY(-4px);
	box-shadow: var(--dew-shadow-lg);
	border-color: var(--dab-accent);
}
/* Gradient icon chip (always filled). */
.deshipos-about__value-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: var(--dab-grad);
	color: #FFFFFF;
	box-shadow: 0 8px 18px -8px color-mix(in srgb, var(--dab-accent) 60%, transparent);
	transition: transform var(--dew-dur-base) var(--dew-ease-out);
}
.deshipos-about__value:hover .deshipos-about__value-icon { transform: scale(1.08) rotate(-3deg); }

/* Uploaded-image variant — light chip, image shown as-is (no gradient/fill). */
.deshipos-about__value-icon--image {
	background: var(--dab-soft);
	box-shadow: none;
	overflow: hidden;
}
.deshipos-about__value-icon--image img {
	width: 64%;
	height: 64%;
	object-fit: contain;
	display: block;
}
.deshipos-about__value-icon i   { font-size: 22px; color: #FFFFFF; }
.deshipos-about__value-icon svg { width: 22px; height: 22px; fill: #FFFFFF; }
.deshipos-about__value-icon svg path,
.deshipos-about__value-icon svg g,
.deshipos-about__value-icon svg circle,
.deshipos-about__value-icon svg rect,
.deshipos-about__value-icon svg polygon { fill: #FFFFFF; }
.deshipos-about__value-title {
	margin: 0;
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: var(--dew-tracking-snug);
	color: var(--dab-ink);
}
.deshipos-about__value-desc {
	margin: 0;
	font-size: .9375rem;
	line-height: 1.6;
	color: var(--dab-muted);
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (min-width: 600px) {
	.deshipos-about__stats { grid-template-columns: repeat(4, 1fr); }
	.deshipos-about__values-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
	.deshipos-about { padding: 84px 40px; }
	.deshipos-about__inner { gap: 28px; }

	.deshipos-about__bento {
		grid-template-columns: 1.45fr 1fr;
		gap: 20px;
		align-items: stretch;
	}
	.deshipos-about__bento--solo { grid-template-columns: 1fr; }
	/* Image side on the left when chosen. */
	.deshipos-about__bento--rev .deshipos-about__aside { order: -1; }

	.deshipos-about__inner > .deshipos-about__stats { margin-top: 8px; }
	.deshipos-about__values-grid { grid-template-columns: repeat(4, 1fr); gap: 22px; }
	.deshipos-about__values-head { margin-top: 24px; }
}

/* ==========================================================================
   Scroll reveal — active only when JS adds `.js-reveal` (content visible
   without JS). Per-element transition-delay (inline) staggers the cards.
   ========================================================================== */
.deshipos-about.js-reveal [data-reveal] {
	opacity: 0;
	transform: translateY(22px);
	transition: opacity .65s var(--dew-ease-out), transform .65s var(--dew-ease-out);
	will-change: opacity, transform;
}
.deshipos-about.js-reveal [data-reveal].is-in {
	opacity: 1;
	transform: none;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.deshipos-about__cta,
	.deshipos-about__cta svg,
	.deshipos-about__stat,
	.deshipos-about__value,
	.deshipos-about__value-icon { transition-duration: .01ms !important; transform: none !important; }
	.deshipos-about.js-reveal [data-reveal] {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}
