/* ================================================
   Product Pathway Widget — frontend.css
   ================================================ */

.ppw-wrapper {
	position: relative;
	box-sizing: border-box;
}

/* ---- Header ---- */
.ppw-header {
	margin-bottom: 32px;
}

.ppw-heading {
	margin: 0 0 16px;
}

.ppw-body {
	margin: 0;
	line-height: 1.6;
}

/* ---- Filters ---- */
.ppw-filters {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 48px;
}

.ppw-filter {
	background: transparent;
	border: 2px solid transparent;
	cursor: pointer;
	padding: 10px 24px;
	border-radius: 30px;
	font-weight: 600;
	font-size: 15px;
	color: var(--ppw-filter-inactive-color, #003B46);
	transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
	white-space: nowrap;
}

.ppw-filter:hover {
	border-color: var(--ppw-filter-active-bg, #003B46);
}

.ppw-filter.ppw-active {
	background: var(--ppw-filter-active-bg, #003B46);
	color: var(--ppw-filter-active-color, #ffffff);
	border-color: var(--ppw-filter-active-bg, #003B46);
}

.ppw-filter-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--ppw-arrow-size, 32px);
	height: var(--ppw-arrow-size, 32px);
	border-radius: 50%;
	background: var(--ppw-arrow-bg, #B1FF6A);
	color: var(--ppw-arrow-color, #003B46);
	flex-shrink: 0;
}

.ppw-filter-arrow svg {
	width: 55%;
	height: 55%;
	stroke: currentColor;
	fill: none;
}

/* ---- Panels ---- */
.ppw-panels {
	position: relative;
}

.ppw-panel {
	display: none;
}

.ppw-panel.ppw-active {
	display: block;
}

/* ---- Cascade fade-in animation ---- */
@keyframes ppwFadeUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Left column elements */
.ppw-panel.ppw-active .ppw-image-wrap,
.ppw-panel.ppw-active .ppw-content-heading,
.ppw-panel.ppw-active .ppw-content-body,
.ppw-panel.ppw-active .ppw-button,
.ppw-panel.ppw-active .ppw-card {
	opacity: 0;
	animation: ppwFadeUp 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.ppw-panel.ppw-active .ppw-image-wrap      { animation-delay: 0s; }
.ppw-panel.ppw-active .ppw-content-heading  { animation-delay: 0.08s; }
.ppw-panel.ppw-active .ppw-content-body     { animation-delay: 0.16s; }
.ppw-panel.ppw-active .ppw-button           { animation-delay: 0.24s; }

/* Right column cards cascade */
.ppw-panel.ppw-active .ppw-card:nth-child(1) { animation-delay: 0.1s; }
.ppw-panel.ppw-active .ppw-card:nth-child(2) { animation-delay: 0.2s; }
.ppw-panel.ppw-active .ppw-card:nth-child(3) { animation-delay: 0.3s; }
.ppw-panel.ppw-active .ppw-card:nth-child(4) { animation-delay: 0.4s; }
.ppw-panel.ppw-active .ppw-card:nth-child(5) { animation-delay: 0.5s; }

/* ---- Content two-column ---- */
.ppw-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ppw-column-gap, 48px);
	align-items: start;
}

/* ---- Left column ---- */
.ppw-content-left {
	display: flex;
	flex-direction: column;
	position: sticky;
	top: var(--ppw-sticky-offset, 140px);
	align-self: start;
}

.ppw-image-wrap {
	margin-bottom: 28px;
	border-radius: var(--ppw-image-radius, 12px);
	overflow: hidden;
}

.ppw-image-wrap img {
	display: block;
	width: 100%;
	height: auto;
	max-height: var(--ppw-image-height, 260px);
	object-fit: cover;
}

.ppw-content-heading {
	margin: 0 0 16px;
	color: var(--ppw-content-heading-color, #003B46);
}

.ppw-content-body {
	margin: 0 0 24px;
	color: var(--ppw-content-body-color, #4a5568);
	line-height: 1.7;
}

.ppw-content-body p:last-child {
	margin-bottom: 0;
}

/* ---- Button ---- */
.ppw-button {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: var(--ppw-btn-padding, 14px 28px);
	background: var(--ppw-btn-bg, #B1FF6A);
	color: var(--ppw-btn-color, #003B46);
	border: 2px solid var(--ppw-btn-border-color, #BEFF6B);
	border-radius: var(--ppw-btn-radius, 8px);
	text-decoration: none;
	font-family: inherit;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
	margin-top: 8px;
	align-self: flex-start;
}

.ppw-button:hover {
	background: var(--ppw-btn-hover-bg, #9de85a);
	color: var(--ppw-btn-hover-color, #003B46);
	border-color: var(--ppw-btn-hover-border-color, #024B50);
}

.ppw-button-arrow {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	fill: none;
	stroke-width: 2.5;
	stroke-linecap: round;
	stroke-linejoin: round;
}

/* ---- Right column / Cards ---- */
.ppw-content-right {
	display: flex;
	flex-direction: column;
	gap: var(--ppw-card-gap, 16px);
}

.ppw-card {
	background: var(--ppw-card-bg, #E8EDE4);
	border-radius: var(--ppw-card-radius, 16px);
	padding: var(--ppw-card-padding, 24px 28px);
}

.ppw-card-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 12px;
}

.ppw-card-title {
	margin: 0;
	font-weight: 700;
	color: var(--ppw-card-title-color, #003B46);
}

.ppw-card-title a {
	color: inherit;
	text-decoration: none;
}

.ppw-card-title a:hover {
	text-decoration: underline;
}

.ppw-card-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--ppw-card-icon-size, 44px);
	height: var(--ppw-card-icon-size, 44px);
	border-radius: 50%;
	background: var(--ppw-card-icon-bg, #B1FF6A);
	color: var(--ppw-card-icon-color, #003B46);
	flex-shrink: 0;
}

.ppw-card-icon i,
.ppw-card-icon svg {
	font-size: calc(var(--ppw-card-icon-size, 44px) * 0.45);
	width: calc(var(--ppw-card-icon-size, 44px) * 0.45);
	height: calc(var(--ppw-card-icon-size, 44px) * 0.45);
}

/* ---- Card list ---- */
.ppw-card-list {
	list-style: none;
	padding: 0;
	margin: 14px 0 0;
}

.ppw-card-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 5px 0;
	color: var(--ppw-list-color, #003B46);
}

.ppw-wrapper a {
	text-decoration: none;
}

.ppw-card-list li a {
	color: var(--ppw-list-link-color, #003B46);
}

.ppw-card-list li a:hover {
	text-decoration: underline;
	color: var(--ppw-list-link-hover-color, #003B46);
}

.ppw-list-icon {
	color: var(--ppw-list-icon-color, #BEFF6B);
	flex-shrink: 0;
	display: inline-flex;
	line-height: 1;
}

.ppw-list-icon i,
.ppw-list-icon svg {
	font-size: var(--ppw-list-icon-size, 16px);
	width: var(--ppw-list-icon-size, 16px);
	height: var(--ppw-list-icon-size, 16px);
	fill: currentColor;
}

/* ---- Mobile ---- */
@media (max-width: 767px) {
	.ppw-content {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.ppw-content-left {
		position: static;
	}

	.ppw-filters {
		gap: 8px;
	}

	.ppw-filter-arrow {
		display: none;
	}

	.ppw-filter {
		padding: 8px 18px;
		font-size: 13px;
	}
}
