/* =============================================================
   JT Process Steps Widget — by JT Digital Solution
   ============================================================= */

/* ---------- Wrapper ---------- */
.jt-ps-wrapper {
	position: relative;
	width: 100%;
	box-sizing: border-box;
}

/* ---------- Connector Line ---------- */
.jt-ps-connector-wrap {
	position: absolute;
	top: 44px; /* half of icon outer box */
	left: 10%;
	right: 10%;
	z-index: 0;
	pointer-events: none;
}
.jt-ps-connector {
	width: 100%;
	height: 2px;
	background: linear-gradient(to right, #f97316, #e84141);
	border-radius: 4px;
}

/* ---------- Grid ---------- */
.jt-ps-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 24px;
	position: relative;
	z-index: 1;
}

/* Tablet */
@media (max-width: 1024px) {
	.jt-ps-grid { grid-template-columns: repeat(3, 1fr); }
	.jt-ps-connector-wrap { display: none; }
}

/* Mobile */
@media (max-width: 767px) {
	.jt-ps-grid { grid-template-columns: 1fr; }
}

/* ---------- Vertical layout ---------- */
.jt-ps-layout-vertical .jt-ps-grid {
	grid-template-columns: 1fr;
}
.jt-ps-layout-vertical .jt-ps-item {
	flex-direction: row;
	text-align: left;
	gap: 20px;
}
.jt-ps-layout-vertical .jt-ps-connector-wrap { display: none; }

/* ---------- Item ---------- */
.jt-ps-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 16px;
	border-radius: 12px;
	cursor: default;
	text-decoration: none;
	color: inherit;
	transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
	will-change: transform;
}
a.jt-ps-item { cursor: pointer; }

/* ---------- Icon Outer Box ---------- */
.jt-ps-icon-outer {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 88px;
	height: 88px;
	border-radius: 16px;
	border: 2px solid rgba(220,53,69,0.2);
	background: #ffffff;
	box-shadow: 0 4px 12px rgba(0,0,0,0.06);
	transition: border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease;
	flex-shrink: 0;
}

/* ---------- Icon Inner Gradient Wrap ---------- */
.jt-ps-icon-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: linear-gradient(135deg, #e84141, #c0392b);
	box-shadow: 0 3px 8px rgba(232,65,65,0.35);
	transition: transform 0.35s ease, box-shadow 0.35s ease;
	overflow: hidden;
}
.jt-ps-icon-inner i,
.jt-ps-icon-inner svg {
	font-size: 20px;
	color: #ffffff;
	fill: #ffffff;
	transition: transform 0.35s ease, color 0.35s ease;
}

/* ---------- Phase Badge ---------- */
.jt-ps-badge {
	display: inline-flex;
	align-items: center;
	margin-top: 12px;
	padding: 3px 10px;
	border-radius: 50px;
	background: linear-gradient(135deg, #e84141, #c0392b);
	color: #ffffff;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	line-height: 1.4;
	transition: transform 0.35s ease, opacity 0.35s ease;
}

/* ---------- Title ---------- */
.jt-ps-title {
	margin-top: 12px;
	margin-bottom: 0;
	font-size: 14px;
	font-weight: 700;
	color: #1a1a2e;
	transition: color 0.35s ease, transform 0.35s ease;
	line-height: 1.4;
}

/* ---------- Description ---------- */
.jt-ps-desc {
	margin-top: 8px;
	margin-bottom: 0;
	font-size: 12px;
	line-height: 1.6;
	color: #6b7280;
	transition: color 0.35s ease, transform 0.35s ease;
}


/* =============================================================
   HOVER ANIMATIONS — Icon
   ============================================================= */

/* Float Up */
.jt-ps-hover-float .jt-ps-item:hover .jt-ps-icon-outer {
	transform: translateY(-6px);
	border-color: rgba(220,53,69,0.45);
	box-shadow: 0 12px 28px rgba(232,65,65,0.2);
}
.jt-ps-hover-float .jt-ps-item:hover .jt-ps-icon-inner {
	transform: scale(1.08);
	box-shadow: 0 6px 18px rgba(232,65,65,0.45);
}

/* Scale / Zoom */
.jt-ps-hover-scale .jt-ps-item:hover .jt-ps-icon-outer {
	transform: scale(1.1);
	border-color: rgba(220,53,69,0.45);
	box-shadow: 0 8px 24px rgba(232,65,65,0.25);
}
.jt-ps-hover-scale .jt-ps-item:hover .jt-ps-icon-inner {
	transform: scale(1.15);
}

/* Rotate */
@keyframes jt-ps-rotate-icon {
	from { transform: rotate(0deg); }
	to   { transform: rotate(360deg); }
}
.jt-ps-hover-rotate .jt-ps-item:hover .jt-ps-icon-inner {
	animation: jt-ps-rotate-icon 0.6s ease forwards;
}
.jt-ps-hover-rotate .jt-ps-item:hover .jt-ps-icon-outer {
	border-color: rgba(220,53,69,0.45);
	box-shadow: 0 8px 20px rgba(232,65,65,0.2);
}

/* Shake */
@keyframes jt-ps-shake {
	0%, 100% { transform: translateX(0); }
	15%       { transform: translateX(-5px) rotate(-4deg); }
	30%       { transform: translateX(5px) rotate(4deg); }
	45%       { transform: translateX(-4px) rotate(-3deg); }
	60%       { transform: translateX(4px) rotate(3deg); }
	75%       { transform: translateX(-2px) rotate(-2deg); }
	90%       { transform: translateX(2px) rotate(2deg); }
}
.jt-ps-hover-shake .jt-ps-item:hover .jt-ps-icon-inner {
	animation: jt-ps-shake 0.55s ease;
}

/* Bounce */
@keyframes jt-ps-bounce {
	0%,100% { transform: translateY(0); }
	25%      { transform: translateY(-10px); }
	50%      { transform: translateY(-5px); }
	75%      { transform: translateY(-8px); }
}
.jt-ps-hover-bounce .jt-ps-item:hover .jt-ps-icon-outer {
	animation: jt-ps-bounce 0.6s ease;
}

/* Pulse Glow */
@keyframes jt-ps-pulse-glow {
	0%,100% { box-shadow: 0 0 0 0 rgba(232,65,65,0.55); }
	50%     { box-shadow: 0 0 0 14px rgba(232,65,65,0); }
}
.jt-ps-hover-pulse .jt-ps-item:hover .jt-ps-icon-outer {
	animation: jt-ps-pulse-glow 0.9s ease infinite;
	border-color: rgba(220,53,69,0.55);
}
.jt-ps-hover-pulse .jt-ps-item:hover .jt-ps-icon-inner {
	transform: scale(1.05);
}

/* Flip */
@keyframes jt-ps-flip {
	0%   { transform: perspective(400px) rotateY(0); }
	50%  { transform: perspective(400px) rotateY(90deg); }
	100% { transform: perspective(400px) rotateY(0deg); }
}
.jt-ps-hover-flip .jt-ps-item:hover .jt-ps-icon-inner {
	animation: jt-ps-flip 0.6s ease;
}


/* =============================================================
   HOVER ANIMATIONS — Text
   ============================================================= */

/* Color Shift (title color changes via selectors) */
/* Slide Up */
.jt-ps-text-hover-slide_up .jt-ps-item:hover .jt-ps-title {
	transform: translateY(-3px);
}
.jt-ps-text-hover-slide_up .jt-ps-item:hover .jt-ps-desc {
	transform: translateY(-2px);
}

/* Underline Grow */
.jt-ps-text-hover-underline .jt-ps-title {
	position: relative;
	display: inline-block;
}
.jt-ps-text-hover-underline .jt-ps-title::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 50%;
	right: 50%;
	height: 2px;
	background: #e84141;
	transition: left 0.3s ease, right 0.3s ease;
	border-radius: 2px;
}
.jt-ps-text-hover-underline .jt-ps-item:hover .jt-ps-title::after {
	left: 0;
	right: 0;
}

/* Badge hover lift */
.jt-ps-item:hover .jt-ps-badge {
	transform: translateY(-1px);
}


/* =============================================================
   ENTRANCE ANIMATIONS
   ============================================================= */
.jt-ps-entrance {
	opacity: 0;
	transition-property: opacity, transform;
	transition-duration: 0.6s;
	transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
}
.jt-ps-entrance.jt-ps-visible {
	opacity: 1;
	transform: none !important;
}

/* Fade Up */
.jt-ps-wrapper[data-entrance="fade_up"] .jt-ps-entrance {
	transform: translateY(30px);
}
/* Fade In */
.jt-ps-wrapper[data-entrance="fade_in"] .jt-ps-entrance {
	transform: none;
}
/* Zoom In */
.jt-ps-wrapper[data-entrance="zoom_in"] .jt-ps-entrance {
	transform: scale(0.85);
}
/* Slide from Left */
.jt-ps-wrapper[data-entrance="slide_left"] .jt-ps-entrance {
	transform: translateX(-40px);
}
/* None — instantly visible */
.jt-ps-wrapper[data-entrance="none"] .jt-ps-entrance {
	opacity: 1;
	transform: none;
}


/* =============================================================
   Elementor Editor Overrides
   ============================================================= */
.elementor-editor-active .jt-ps-entrance {
	opacity: 1 !important;
	transform: none !important;
}
