/* ============================================================
   Felda Haji Redesign — scoped under .felda-haji (no :root bleed)
   ============================================================ */
.felda-haji {
	--fh-orange: #E67E22;
	--fh-orange-deep: #C0620F;
	--fh-chocolate: #2A1810;
	--fh-chocolate-soft: #4A2E1D;
	--fh-cream: #FAF6F1;
	--fh-peach: #FCE8D4;
	--fh-peach-soft: #FFF4E6;
	--fh-line: #E8DECF;
	--fh-ink: #1A0F08;
	--fh-ink-muted: #7A6A5A;

	width: 100%;
	max-width: none;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	color: var(--fh-ink);
	line-height: 1.6;
	box-sizing: border-box;
}
.felda-haji *, .felda-haji *::before, .felda-haji *::after { box-sizing: border-box; }
.felda-haji section { max-width: 1440px; margin: 0 auto; padding: 60px 32px; }
.felda-haji h1, .felda-haji h2, .felda-haji h3 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; letter-spacing: -0.01em; margin: 0; }
.felda-haji p { margin: 0; }
.felda-haji em,
.felda-haji h1 em,
.felda-haji h2 em,
.felda-haji h3 em {
	font-family: 'Cormorant Garamond', Georgia, serif !important;
	font-style: italic !important;
	font-weight: 500;
	background: linear-gradient(293deg, var(--bde-brand-primary-color, #E67E22) 0%, var(--bde-headings-color, #2A1810) 100%) !important;
	-webkit-background-clip: text !important;
	background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	color: transparent !important;
}

/* ==================== SECTION 1 — C STATS ==================== */
.felda-haji .fh-c-stats { padding-top: 80px; padding-bottom: 80px; }
.felda-haji .fh-c-stats-head { text-align: center; max-width: 800px; margin: 0 auto 60px; }
.felda-haji .fh-c-eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-size: 12px; letter-spacing: .15em; text-transform: uppercase;
	color: var(--fh-orange-deep); font-weight: 600; margin-bottom: 16px;
}
.felda-haji .fh-c-line { width: 32px; height: 1px; background: var(--fh-orange); }
.felda-haji .fh-c-h2 { font-size: clamp(28px, 4vw, 44px); line-height: 1.2; }
.felda-haji .fh-c-stats-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.felda-haji .fh-c-stat {
	padding: 32px 24px; background: #fff; border-radius: 18px;
	border: 1px solid var(--fh-line); text-align: center;
	opacity: 0; transform: translateY(12px);
	transition: opacity .6s ease, transform .6s ease;
}
.felda-haji .fh-c-stat.is-in { opacity: 1; transform: translateY(0); }
.felda-haji .fh-c-stat-num {
	font-family: 'Cormorant Garamond', serif;
	font-size: 64px; line-height: 1; color: var(--fh-chocolate);
	display: flex; align-items: baseline; justify-content: center; gap: 4px;
}
.felda-haji .fh-c-stat-num > span:last-child { font-size: 20px; color: var(--fh-orange-deep); }
.felda-haji .fh-c-stat-lab { font-size: 14px; color: var(--fh-ink-muted); margin-top: 12px; line-height: 1.5; max-width: 260px; margin-left: auto; margin-right: auto; min-height: 42px; }
.felda-haji .fh-c-stat-ghost { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: #BAA898; margin-top: 10px; }

/* ==================== SECTION 2 — B JOURNEY / 5 FASA ==================== */
.felda-haji .fh-b-journey { padding: 80px 32px; max-width: 1376px; }
.felda-haji .fh-b-journey-top { display: grid; grid-template-columns: minmax(0,1fr) minmax(260px, 380px); gap: 56px; align-items: center; margin-bottom: 48px; }
.felda-haji .fh-b-sec-head { text-align: left; max-width: 720px; }
.felda-haji .fh-b-journey-top .fh-b-sec-head { margin-bottom: 0; }
.felda-haji .fh-b-ebook { margin: 0; position: relative; display: flex; align-items: center; gap: 20px; }
.felda-haji .fh-b-ebook img {
	display: block; width: 100%; height: auto; max-width: 140px; flex-shrink: 0;
	transform: rotate(-4deg); transition: transform .5s cubic-bezier(.22,.61,.36,1);
	filter: drop-shadow(0 24px 40px rgba(42,24,16,.28)) drop-shadow(0 8px 14px rgba(42,24,16,.14));
}
.felda-haji .fh-b-ebook:hover img { transform: rotate(-2deg) translateY(-4px) scale(1.02); }
.felda-haji .fh-b-ebook figcaption { display: flex; flex-direction: column; gap: 6px; text-align: left; }
.felda-haji .fh-b-ebook-tag { font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--fh-orange-deep); font-weight: 600; }
.felda-haji .fh-b-ebook-t { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 22px; line-height: 1.2; color: var(--fh-chocolate); font-weight: 500; }
@media (max-width: 900px) {
	.felda-haji .fh-b-journey-top { grid-template-columns: 1fr; gap: 32px; }
}
.felda-haji .fh-b-sec-head-split { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; max-width: none; }
.felda-haji .fh-b-eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-size: 12px; letter-spacing: .15em; text-transform: uppercase;
	color: var(--fh-orange-deep); font-weight: 600; margin-bottom: 14px;
}
.felda-haji .fh-b-dot { width: 6px; height: 6px; background: var(--fh-orange); border-radius: 50%; }
.felda-haji .fh-b-h2 { font-size: clamp(22px, 3vw, 36px); line-height: 1.2; margin-bottom: 16px; white-space: nowrap; }
@media (max-width: 680px) { .felda-haji .fh-b-h2 { white-space: normal; } }
.felda-haji .fh-b-sec-body { color: var(--fh-ink-muted); font-size: 15px; line-height: 1.65; }

.felda-haji .fh-b-timeline { position: relative; display: flex; align-items: center; justify-content: space-between; margin: 32px 0 40px; }
.felda-haji .fh-b-tl-track { position: absolute; inset: 16px 0 auto 0; height: 2px; background: var(--fh-line); z-index: 0; }
.felda-haji .fh-b-tl-fill { height: 100%; background: var(--fh-orange); transition: width .5s ease; }
.felda-haji .fh-b-tl-node {
	position: relative; z-index: 1; background: none; border: none; cursor: pointer;
	display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 0; flex: 1;
}
.felda-haji .fh-b-tl-dot {
	width: 14px; height: 14px; background: #fff; border: 2px solid var(--fh-line);
	border-radius: 50%; transition: background .3s, border-color .3s, transform .3s;
}
.felda-haji .fh-b-tl-node.is-active .fh-b-tl-dot { background: var(--fh-orange); border-color: var(--fh-orange); transform: scale(1.2); }
.felda-haji .fh-b-tl-node.is-done .fh-b-tl-dot { background: var(--fh-orange-deep); border-color: var(--fh-orange-deep); }
.felda-haji .fh-b-tl-num { font-size: 12px; color: var(--fh-ink-muted); letter-spacing: .05em; text-transform: uppercase; }
.felda-haji .fh-b-tl-node.is-active .fh-b-tl-num { color: var(--fh-orange-deep); font-weight: 600; }

.felda-haji .fh-b-phase-card {
	position: relative; background: #fff; border: 1px solid var(--fh-line);
	border-radius: 20px; padding: 32px; display: flex; align-items: center; gap: 24px;
	min-height: 140px;
}
.felda-haji .fh-b-phase-panel { display: flex; flex: 1; align-items: center; gap: 24px; }
.felda-haji .fh-b-phase-panel[hidden] { display: none; }
.felda-haji .fh-b-phase-card-left { flex-shrink: 0; }
.felda-haji .fh-b-phase-card-n {
	font-family: 'Cormorant Garamond', serif; font-size: 64px; line-height: 1;
	color: var(--fh-orange); font-weight: 500;
}
.felda-haji .fh-b-phase-card-meta { font-size: 12px; color: var(--fh-ink-muted); letter-spacing: .08em; text-transform: uppercase; margin-top: 8px; }
.felda-haji .fh-b-phase-card-body { flex: 1; }
.felda-haji .fh-b-phase-card-body h3 { font-size: 26px; color: var(--fh-chocolate); margin-bottom: 12px; }
.felda-haji .fh-b-phase-prog { display: flex; gap: 6px; }
.felda-haji .fh-b-phase-prog span { width: 24px; height: 3px; background: var(--fh-line); border-radius: 2px; }
.felda-haji .fh-b-phase-prog span.on { background: var(--fh-orange); }

.felda-haji .fh-b-phase-card-right { display: flex; gap: 8px; flex-shrink: 0; }
.felda-haji .fh-b-icon-btn {
	width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--fh-line);
	background: #fff; display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer; transition: background .2s, border-color .2s, color .2s;
	color: var(--fh-chocolate);
}
.felda-haji .fh-b-icon-btn:hover { border-color: var(--fh-orange); color: var(--fh-orange-deep); }
.felda-haji .fh-b-icon-btn-primary { background: var(--fh-orange); border-color: var(--fh-orange); color: #fff; }
.felda-haji .fh-b-icon-btn-primary:hover { background: var(--fh-orange-deep); border-color: var(--fh-orange-deep); color: #fff; }
.felda-haji .fh-b-icon-btn[data-fh-phase-prev] svg { transform: rotate(180deg); }
.felda-haji .fh-b-icon-btn[data-fh-car-prev] svg { transform: rotate(180deg); }

/* ==================== SECTION 3 — A KEMBARA (dark) ==================== */
.felda-haji .fh-a-kembara { background: var(--fh-chocolate); border-radius: 32px; padding: 80px 48px; margin: 40px auto; max-width: 1376px; color: #FDE2C2; }
.felda-haji .fh-a-kembara-inner { display: grid; grid-template-columns: 360px 1fr; gap: 48px; align-items: start; }
.felda-haji .fh-a-kembara-head { position: sticky; top: 24px; }
.felda-haji .fh-a-eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	font-size: 12px; letter-spacing: .15em; text-transform: uppercase;
	color: var(--fh-orange); font-weight: 600; margin-bottom: 14px;
}
.felda-haji .fh-a-dot { width: 6px; height: 6px; background: var(--fh-orange); border-radius: 50%; }
.felda-haji .fh-a-eyebrow-onDark { color: #FDE2C2; }
.felda-haji .fh-a-eyebrow-onDark .fh-a-dot { background: var(--fh-orange); }
.felda-haji .fh-a-h2 { font-size: clamp(28px, 4vw, 48px); line-height: 1.15; color: var(--fh-chocolate); }
.felda-haji .fh-a-h2-onDark { color: #FDE2C2; }
.felda-haji .fh-a-h2-em { font-style: italic; color: var(--fh-orange); display: block; }
.felda-haji .fh-a-h2-onDark .fh-a-h2-em,
.felda-haji .fh-a-kembara em,
.felda-haji .fh-a-kembara h1 em,
.felda-haji .fh-a-kembara h2 em,
.felda-haji .fh-a-kembara h3 em {
	background: linear-gradient(293deg, #FDE2C2 0%, #FFB86B 100%) !important;
	-webkit-background-clip: text !important;
	background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	color: transparent !important;
}
.felda-haji .fh-a-sec-body { font-size: 15px; color: var(--fh-ink-muted); margin-top: 16px; line-height: 1.65; }
.felda-haji .fh-a-sec-body-onDark { color: rgba(253,226,194,.7); }
.felda-haji .fh-a-pillars { display: grid; gap: 24px; }
.felda-haji .fh-a-pillar {
	background: rgba(253,226,194,.05); border: 1px solid rgba(253,226,194,.1);
	border-radius: 20px; padding: 32px;
}
.felda-haji .fh-a-pillar-num {
	font-family: 'Cormorant Garamond', serif; font-size: 48px;
	color: var(--fh-orange); line-height: 1; margin-bottom: 12px; font-weight: 400;
}
.felda-haji .fh-a-pillar-t { font-family: 'Cormorant Garamond', serif; font-size: 26px; line-height: 1.2; color: #FDE2C2; margin-bottom: 12px; font-weight: 500; }
.felda-haji .fh-a-pillar-b { font-size: 14px; line-height: 1.7; color: rgba(253,226,194,.7); }
.felda-haji .fh-a-pillar-line { width: 40px; height: 2px; background: var(--fh-orange); margin-top: 20px; border-radius: 2px; }

/* ==================== SECTION 4 — B KENAPA CAROUSEL ==================== */
.felda-haji .fh-b-kenapa { padding: 80px 32px; max-width: 1376px; }
.felda-haji .fh-b-kenapa .fh-b-sec-head-split { margin-bottom: 40px; align-items: end; }
.felda-haji .fh-b-kenapa-intro p { color: var(--fh-ink-muted); font-size: 15px; line-height: 1.65; margin-bottom: 20px; }
.felda-haji .fh-b-carousel-ctrl { display: inline-flex; align-items: center; gap: 12px; }
.felda-haji .fh-b-carousel-count { font-size: 13px; color: var(--fh-ink-muted); min-width: 60px; text-align: center; }
.felda-haji .fh-b-carousel-count em { font-style: normal; color: var(--fh-chocolate); font-weight: 600; }

.felda-haji .fh-b-carousel { overflow: hidden; position: relative; }
.felda-haji .fh-b-carousel-track {
	display: grid; grid-auto-flow: column;
	grid-auto-columns: calc((100% - 48px) / 3);
	gap: 24px;
	transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.felda-haji .fh-b-card {
	background: #fff; border: 1px solid var(--fh-line); border-radius: 18px;
	padding: 28px; display: flex; flex-direction: column; gap: 14px;
}
.felda-haji .fh-b-card-top { display: flex; align-items: center; justify-content: space-between; }
.felda-haji .fh-b-card-icon {
	width: 48px; height: 48px; border-radius: 12px;
	background: var(--fh-peach-soft); display: grid; place-items: center;
}
.felda-haji .fh-b-card-n { font-family: 'Cormorant Garamond', serif; font-size: 28px; color: var(--fh-ink-muted); }
.felda-haji .fh-b-card-tag { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--fh-orange-deep); font-weight: 600; }
.felda-haji .fh-b-card-t { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--fh-chocolate); line-height: 1.25; font-weight: 500; }
.felda-haji .fh-b-card-b { font-size: 13px; color: var(--fh-ink-muted); line-height: 1.65; }

.felda-haji .fh-b-catbar { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--fh-line); }
.felda-haji .fh-b-catchip {
	display: inline-flex; align-items: center; gap: 8px;
	background: #fff; border: 1px solid var(--fh-line); border-radius: 999px;
	padding: 8px 14px; font-size: 13px; color: var(--fh-chocolate);
}
.felda-haji .fh-b-catchip em { font-style: normal; color: var(--fh-ink-muted); font-size: 11px; }

/* ==================== SECTION 5 — C FINAL CTA ==================== */
.felda-haji .fh-c-final-wrap { padding: 60px 32px 100px; }
.felda-haji .fh-c-final {
	background: linear-gradient(135deg, var(--fh-chocolate) 0%, var(--fh-chocolate-soft) 100%);
	color: #FDE2C2; border-radius: 32px; padding: 56px 48px;
	display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
	max-width: 1200px; margin: 0 auto;
}
.felda-haji .fh-c-final-t { font-family: 'Cormorant Garamond', serif; font-size: clamp(24px, 3.5vw, 36px); line-height: 1.25; font-weight: 500; margin-bottom: 12px; color: #FDE2C2; }
.felda-haji .fh-c-final-t,
.felda-haji .fh-c-final-t * { color: #FDE2C2 !important; -webkit-text-fill-color: #FDE2C2 !important; }
.felda-haji .fh-c-final-t em {
	font-family: 'Cormorant Garamond', Georgia, serif !important;
	font-style: italic !important;
	background: linear-gradient(293deg, #FFB86B 0%, #FDE2C2 100%) !important;
	-webkit-background-clip: text !important;
	background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	color: transparent !important;
}
.felda-haji .fh-c-final-b { color: rgba(253,226,194,.75); font-size: 15px; line-height: 1.65; }
.felda-haji .fh-c-final-ctas { display: flex; gap: 12px; flex-shrink: 0; flex-wrap: wrap; }
.felda-haji .fh-c-btn {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 14px 24px; border-radius: 999px; font-size: 14px; font-weight: 600;
	text-decoration: none; transition: background .2s, transform .2s, color .2s;
	font-family: inherit; border: 1px solid transparent; cursor: pointer;
	line-height: 1;
}
.felda-haji .fh-c-btn-primary { background: var(--fh-orange); color: #fff; }
.felda-haji .fh-c-btn-primary:hover { background: var(--fh-orange-deep); transform: translateY(-1px); color: #fff; }
.felda-haji .fh-c-btn-outline { background: transparent; color: #FDE2C2; border-color: rgba(253,226,194,.3); }
.felda-haji .fh-c-btn-outline:hover { background: rgba(253,226,194,.1); color: #FDE2C2; }

/* ==================== RESPONSIVE ==================== */
@media (max-width: 1024px) {
	.felda-haji .fh-a-kembara-inner { grid-template-columns: 1fr; }
	.felda-haji .fh-a-kembara-head { position: static; }
	.felda-haji .fh-b-carousel-track { grid-auto-columns: calc((100% - 24px) / 2); }
	.felda-haji .fh-b-sec-head-split { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 768px) {
	.felda-haji section { padding: 48px 20px; }
	.felda-haji .fh-c-stats-row { grid-template-columns: 1fr; gap: 16px; }
	.felda-haji .fh-b-phase-card { flex-direction: column; align-items: flex-start; padding: 24px; }
	.felda-haji .fh-b-phase-panel { flex-direction: column; align-items: flex-start; }
	.felda-haji .fh-b-phase-card-right { align-self: flex-end; }
	.felda-haji .fh-b-carousel-track { grid-auto-columns: 100%; }
	.felda-haji .fh-a-kembara { padding: 48px 24px; border-radius: 20px; }
	.felda-haji .fh-c-final { grid-template-columns: 1fr; padding: 40px 28px; }
	.felda-haji .fh-b-tl-num { font-size: 10px; }
}
