*{margin:0;padding:0;box-sizing:border-box}
:root{
--bg:#FAF4EC;
--bg2:#F7F3EB;
--bg3:#F4EDE4;
--black:#111111;
--dark:#121212;
--white:#FFFFFF;
--gray-500:#888888;
--gray-600:#444444;
--gray-700:#333333;
--accent-coral:#FF4B1F;
--accent-green:#053B15;
--accent-pink:#FCB8FA;
--tag-pink:#F8E5F8;
--tag-cream:#F4EDE4;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--black);font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
.hfhg-container{max-width:1200px;margin:0 auto;padding:0 40px}

/* ===== HERO SECTION ===== */
.hfhg-hero{padding:120px 0;background:var(--bg2)}
.hfhg-hero .hfhg-container{display:flex;align-items:center;gap:60px;min-height:70vh}
.hfhg-hero-left{flex:1;max-width:480px}
.hfhg-hero-right{flex:1;display:flex;justify-content:center;perspective:800px}
.hfhg-hero h1{font-size:52px;font-weight:800;letter-spacing:-1.5px;line-height:1.08;color:var(--dark);margin-bottom:12px}
.hfhg-hero-subtitle{font-size:16px;color:var(--gray-600);line-height:1.7;margin-bottom:24px;max-width:420px}
.hfhg-hero-tags{display:flex;gap:8px;margin-top:20px;flex-wrap:wrap}
.hfhg-tag{display:inline-block;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500}
.hfhg-tag-dark{background:var(--black);color:var(--white)}
.hfhg-tag-pink{background:var(--tag-pink);color:var(--dark)}
.hfhg-tag-cream{background:var(--tag-cream);color:var(--dark)}

/* Stacked card effect */
.hfhg-card-stack{position:relative;width:380px;height:520px}
.hfhg-card-stack .hfhg-card-main{position:absolute;width:100%;height:100%;background:var(--dark);border-radius:32px;overflow:hidden;z-index:3;box-shadow:0 10px 30px rgba(0,0,0,.08);display:flex;flex-direction:column;justify-content:flex-end;padding:32px}
.hfhg-card-stack .hfhg-card-back-1{position:absolute;width:92%;height:100%;background:var(--gray-700);border-radius:32px;z-index:2;left:4%;top:12px;opacity:.6}
.hfhg-card-stack .hfhg-card-back-2{position:absolute;width:84%;height:100%;background:var(--gray-500);border-radius:32px;z-index:1;left:8%;top:24px;opacity:.3}
.hfhg-card-main .hfhg-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.hfhg-card-main .hfhg-stat-item{text-align:center}
.hfhg-card-main .hfhg-stat-num{font-size:28px;font-weight:800;color:var(--white)}
.hfhg-card-main .hfhg-stat-label{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px}
.hfhg-card-main .hfhg-chart-area{height:80px;display:flex;align-items:flex-end;gap:3px;padding:0 8px}
.hfhg-chart-bar{flex:1;border-radius:3px 3px 0 0;transition:height .8s cubic-bezier(.22,1,.36,1);background:var(--accent-coral)}
.hfhg-chart-bar:nth-child(even){background:rgba(255,255,255,.15)}
.hfhg-chart-bar:nth-child(3n){background:#FF6B35}

/* ===== ASSIGNMENT SECTION ===== */
.hfhg-assignment{padding:100px 0;background:var(--bg2)}
.hfhg-assignment-label{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:24px;display:flex;align-items:center;gap:8px}
.hfhg-assignment-label::before{content:'';width:20px;height:2px;background:var(--accent-coral);display:inline-block}
.hfhg-assignment h2{font-size:38px;font-weight:700;line-height:1.25;color:var(--dark);max-width:900px;margin-bottom:48px;letter-spacing:-.5px}

/* Horizontal scroll video cards */
.hfhg-video-scroll{display:flex;gap:20px;overflow-x:auto;padding-bottom:20px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.hfhg-video-scroll::-webkit-scrollbar{display:none}
.hfhg-video-card{flex:0 0 320px;height:568px;background:var(--black);border-radius:32px;overflow:hidden;scroll-snap-align:start;position:relative;display:flex;align-items:center;justify-content:center}
.hfhg-video-card .hfhg-placeholder{color:rgba(255,255,255,.2);font-size:14px;text-align:center;padding:40px}
.hfhg-video-card .hfhg-placeholder svg{display:block;margin:0 auto 12px;opacity:.3}
.hfhg-video-card .hfhg-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:var(--white)}
.hfhg-video-card .hfhg-overlay h4{font-size:15px;font-weight:600;margin-bottom:4px}
.hfhg-video-card .hfhg-overlay p{font-size:12px;opacity:.7}

/* ===== APPROACH SECTION ===== */
.hfhg-approach{padding:100px 0;background:var(--bg2)}
.hfhg-approach .hfhg-container{display:flex;align-items:center;gap:60px}
.hfhg-approach-image{flex:0 0 380px}
.hfhg-approach-image .hfhg-img-wrapper{border-radius:16px;overflow:hidden;background:var(--bg3);aspect-ratio:3/4;display:flex;align-items:center;justify-content:center}
.hfhg-approach-image .hfhg-img-wrapper svg{width:80px;height:80px;opacity:.15}
.hfhg-approach-content{flex:1}
.hfhg-approach-content .hfhg-label{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.hfhg-approach-content .hfhg-label::before{content:'';width:20px;height:2px;background:var(--accent-coral);display:inline-block}
.hfhg-approach-content h2{font-size:38px;font-weight:700;line-height:1.2;color:var(--dark);margin-bottom:20px;letter-spacing:-.5px}
.hfhg-approach-content p{font-size:15px;color:var(--gray-600);line-height:1.8;margin-bottom:16px}
.hfhg-approach-pillars{margin-top:28px;display:flex;flex-direction:column;gap:8px}
.hfhg-pillar-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--gray-600);line-height:1.6}
.hfhg-pillar-bullet{width:6px;height:6px;border-radius:50%;background:var(--accent-coral);flex-shrink:0;margin-top:8px}

/* ===== RESULTS SECTION ===== */
.hfhg-results{padding:100px 0;background:var(--bg2)}
.hfhg-results-header{text-align:left;margin-bottom:12px}
.hfhg-results-label{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:8px}
.hfhg-results h2{font-size:42px;font-weight:700;color:var(--dark);margin-bottom:8px;letter-spacing:-.5px}
.hfhg-results-sub{font-size:14px;color:var(--gray-500);margin-bottom:48px}

/* Result cards */
.hfhg-result-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.hfhg-result-card{border-radius:24px;overflow:hidden;position:relative;min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;padding:32px}
.hfhg-result-card.tall{min-height:500px}

/* Card styles */
.hfhg-rc-stat{background:var(--white);border:1px solid rgba(0,0,0,.06)}
.hfhg-rc-stat .hfhg-big-num{font-size:64px;font-weight:900;line-height:1;color:var(--dark);margin-bottom:8px;letter-spacing:-2px}
.hfhg-rc-stat .hfhg-big-label{font-size:16px;font-weight:600;color:var(--dark);margin-bottom:4px}
.hfhg-rc-stat .hfhg-big-sub{font-size:13px;color:var(--gray-500)}

.hfhg-rc-dark{background:var(--dark);color:var(--white)}
.hfhg-rc-dark .hfhg-big-num{color:var(--white)}
.hfhg-rc-dark .hfhg-big-label{color:rgba(255,255,255,.9)}
.hfhg-rc-dark .hfhg-big-sub{color:rgba(255,255,255,.5)}
.hfhg-rc-dark .hfhg-card-brand{position:absolute;top:24px;left:24px;display:flex;align-items:center;gap:8px}
.hfhg-rc-dark .hfhg-card-brand .dot{width:24px;height:24px;border-radius:6px;background:var(--accent-coral)}
.hfhg-rc-dark .hfhg-card-brand span{font-size:13px;font-weight:600;color:rgba(255,255,255,.6)}
.hfhg-rc-dark .hfhg-card-cta{display:inline-block;margin-top:16px;padding:8px 20px;background:var(--accent-coral);color:var(--white);border-radius:6px;font-size:12px;font-weight:600;text-decoration:none}

.hfhg-rc-coral{background:linear-gradient(135deg,#FF4B1F 0%,#FF6B35 100%);color:var(--white)}
.hfhg-rc-coral .hfhg-big-num{color:var(--white);font-size:56px}
.hfhg-rc-coral .hfhg-big-label{color:var(--white)}
.hfhg-rc-coral .hfhg-big-sub{color:rgba(255,255,255,.7)}

.hfhg-rc-green{background:var(--accent-green);color:var(--white)}
.hfhg-rc-green .hfhg-big-num{color:var(--white)}
.hfhg-rc-green .hfhg-big-label{color:rgba(255,255,255,.9)}
.hfhg-rc-green .hfhg-big-sub{color:rgba(255,255,255,.6)}

/* ===== BTS SECTION ===== */
.hfhg-bts{padding:100px 0;background:var(--bg2)}
.hfhg-bts h2{font-size:42px;font-weight:700;color:var(--dark);margin-bottom:8px;letter-spacing:-.5px}
.hfhg-bts-sub{font-size:14px;color:var(--gray-500);margin-bottom:40px}
.hfhg-bts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.hfhg-bts-card{background:var(--bg3);border-radius:16px;aspect-ratio:2/3;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hfhg-bts-card svg{width:40px;height:40px;opacity:.12}

/* ===== TESTIMONIAL ===== */
.hfhg-testimonial{padding:80px 0;background:var(--bg3)}
.hfhg-testimonial .hfhg-container{max-width:700px;text-align:center}
.hfhg-quote-icon{font-size:48px;color:var(--accent-coral);margin-bottom:16px;font-family:Georgia,serif}
.hfhg-quote-text{font-size:24px;font-weight:600;color:var(--dark);line-height:1.5;margin-bottom:24px;letter-spacing:-.3px}
.hfhg-quote-author{font-size:14px;font-weight:600;color:var(--dark)}
.hfhg-quote-role{font-size:13px;color:var(--gray-500)}

/* ===== CTA ===== */
.hfhg-cta{padding:100px 0;background:var(--bg2);text-align:center}
.hfhg-cta h2{font-size:42px;font-weight:700;color:var(--dark);margin-bottom:32px;letter-spacing:-.5px}
.hfhg-cta-buttons{display:flex;gap:16px;justify-content:center}
.hfhg-btn{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;border-radius:12px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;text-decoration:none;transition:all .25s ease}
.hfhg-btn-dark{background:var(--dark);color:var(--white)}
.hfhg-btn-dark:hover{background:var(--black);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.hfhg-btn-outline{background:transparent;color:var(--dark);border:1.5px solid rgba(0,0,0,.12)}
.hfhg-btn-outline:hover{border-color:var(--dark)}

/* ===== ANIMATIONS ===== */
.hfhg-fade-up{opacity:0;transform:translateY(30px);transition:all .7s cubic-bezier(.22,1,.36,1)}
.hfhg-fade-up.visible{opacity:1;transform:translateY(0)}
.hfhg-delay-1{transition-delay:.1s}
.hfhg-delay-2{transition-delay:.2s}
.hfhg-delay-3{transition-delay:.3s}
.hfhg-delay-4{transition-delay:.4s}

/* ===== RESPONSIVE ===== */
@media(max-width:992px){
.hfhg-hero .hfhg-container{flex-direction:column;gap:40px}
.hfhg-hero-left{max-width:100%}
.hfhg-card-stack{width:300px;height:420px}
.hfhg-approach .hfhg-container{flex-direction:column}
.hfhg-approach-image{flex:none;width:100%}
}
@media(max-width:768px){
.hfhg-hero h1{font-size:36px}
.hfhg-assignment h2,.hfhg-approach-content h2,.hfhg-results h2,.hfhg-bts h2,.hfhg-cta h2{font-size:30px}
.hfhg-video-card{flex:0 0 260px;height:462px}
.hfhg-result-row{grid-template-columns:1fr}
.hfhg-bts-grid{grid-template-columns:1fr 1fr}
.hfhg-card-stack{width:260px;height:380px}
.hfhg-card-main .hfhg-stat-num{font-size:22px}
.hfhg-rc-stat .hfhg-big-num,.hfhg-rc-coral .hfhg-big-num{font-size:44px}
}
