/* homepage.css - khusus elemen unik homepage (hero, metrics, wave) */
@import url('./design-tokens.css');
.home-hero{position:relative;min-height:640px;display:flex;align-items:center;padding:var(--space-10) 0 var(--space-8);background:linear-gradient(110deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 55%,#1092b8 100%);color:#fff;overflow:hidden;} 
.home-hero .bg-wave{position:absolute;inset:0;z-index:0;opacity:.35;} 
/* Grid hero diperhalus: kolom kedua untuk visual stack agar tidak menumpuk judul */
.home-hero .hero-inner{position:relative;z-index:1;display:grid;gap:var(--space-9);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:center;} 
/* Wrapper kolom kanan */
.hero-visual-stack{position:relative;display:flex;justify-content:center;padding:var(--space-4) 0;}
@media(min-width:1000px){.hero-visual-stack{justify-content:flex-end;}}
.hero-title-v2{margin:0 0 var(--space-5);font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.15;font-weight:700;} 
.hero-title-v2 .accent{color:#ffe173;} 
.hero-eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.65px;text-transform:uppercase;margin:0 0 var(--space-3);padding:6px 14px;border-radius:var(--radius-pill);background:rgba(255,255,255,.12);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);} 
.hero-sub{font-size:18px;line-height:1.55;margin:0 0 var(--space-6);max-width:560px;color:rgba(255,255,255,.92);} 
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;} 
/* Cluster kartu diubah menjadi relatif agar tidak overlap hero text */
.floating-cluster{position:relative;display:flex;flex-direction:column;gap:14px;}
.float-card{background:rgba(255,255,255,.9);color:var(--gray-800);border-radius:var(--radius-lg);padding:16px 20px;min-width:190px;box-shadow:var(--shadow-lg);backdrop-filter:blur(8px);animation:floatY 6s ease-in-out infinite;will-change:transform;} 
.float-card h5{margin:0 0 4px;font-size:15px;line-height:1.3;}
.float-card p{margin:0;font-size:13px;line-height:1.4;color:var(--gray-600);} 
.float-card:nth-child(2){animation-delay:1.2s;} .float-card:nth-child(3){animation-delay:2.4s;} 
@keyframes floatY{0%,100%{transform:translateY(-10px);}50%{transform:translateY(10px);} } 
.metrics-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-6);margin-top:var(--space-7);} .metric{display:flex;flex-direction:column;gap:4px;} .metric .value{font-size:clamp(1.4rem,2.2vw,2.1rem);font-weight:700;} .metric .label{font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:rgba(255,255,255,.75);} 
@media(max-width:680px){.hero-ctas{flex-direction:column;align-items:stretch;}.float-card{min-width:150px;padding:12px 14px;} .home-hero{padding:var(--space-9) 0 var(--space-7);} .hero-visual-stack{justify-content:flex-start;}}

/* =============== GLOBAL HOMEPAGE SECTIONS =============== */
.section-v2{padding:var(--space-9) 0;} .section-v2.header-tight{padding-top:var(--space-7);} 
.section-head{margin:0 0 var(--space-7);text-align:center;max-width:880px;margin-left:auto;margin-right:auto;}
.section-head h2{margin:0 0 var(--space-3);font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.2;font-weight:700;color:var(--gray-900);} 
.section-head p{margin:0;color:var(--gray-600);font-size:15px;line-height:1.55;}
.section-eyebrow{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.75px;padding:6px 12px;border-radius:var(--radius-pill);background:var(--gray-100);color:var(--gray-600);margin-bottom:var(--space-3);text-transform:uppercase;}

/* =============== SERVICES / UNIFIED CARDS =============== */
.cards-grid{display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:stretch;}
.unified-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow .35s,transform .35s,border-color .35s;}
.unified-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--color-brand-primary);} 
.unified-card.featured{background:linear-gradient(145deg,#fff,#f4f9fb);} 
.icon-ring{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--color-brand-primary),var(--color-brand-secondary));color:#fff;font-size:22px;box-shadow:0 4px 14px -2px rgba(0,0,0,.15);} 
.unified-card h3{margin:4px 0 2px;font-size:18px;} .unified-card p{margin:0 0 4px;color:var(--gray-600);font-size:14px;line-height:1.5;}

/* =============== FEATURES SECTION =============== */
.features-v2{display:grid;gap:var(--space-7);grid-template-columns:repeat(auto-fit,minmax(340px,1fr));align-items:start;}
.feature-media-stack{position:relative;} .feature-media-stack img{border-radius:var(--radius-xl);box-shadow:var(--shadow-md);}
.feature-badge-float{position:absolute;bottom:16px;left:16px;background:#fff;color:var(--gray-800);padding:8px 14px;font-size:13px;font-weight:600;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);} 
.feature-points{display:grid;gap:18px;margin-top:var(--space-4);} 
.feature-point{display:flex;gap:14px;align-items:flex-start;padding:12px 14px;border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;transition:background .3s,border-color .3s,box-shadow .3s;} 
.feature-point i{font-size:20px;color:var(--color-brand-primary);margin-top:4px;} 
.feature-point h4{margin:0 0 4px;font-size:15px;} .feature-point p{margin:0;color:var(--gray-600);font-size:13px;line-height:1.45;} 
.feature-point:hover{background:linear-gradient(135deg,#ffffff,#f4f8fa);border-color:var(--color-brand-primary);box-shadow:var(--shadow-sm);} 

/* =============== PROJECTS =============== */
.projects-grid-v2{display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.project-card-v2{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .35s,transform .35s,border-color .35s;}
.project-card-v2:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-brand-primary);} 
.project-media{position:relative;aspect-ratio:16/10;overflow:hidden;} .project-media img{width:100%;height:100%;object-fit:cover;display:block;} 
.project-media .badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,var(--color-brand-primary),var(--color-brand-secondary));color:#fff;font-size:11px;} 
.project-body{padding:18px 20px;display:flex;flex-direction:column;gap:12px;} 
.project-body h3{margin:0;font-size:17px;line-height:1.3;} .project-body p{margin:0;color:var(--gray-600);font-size:14px;line-height:1.5;} 
.progress-wrap{display:flex;flex-direction:column;gap:4px;} .progress-bar-v2{background:var(--gray-100);height:8px;border-radius:6px;overflow:hidden;} .progress-fill{height:100%;background:linear-gradient(90deg,var(--color-brand-primary),var(--color-brand-secondary));width:0;transition:width 1.2s ease;} 

/* =============== TESTIMONIALS =============== */
.testi-grid{display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.testi-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:20px 22px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm);transition:box-shadow .35s,transform .35s,border-color .35s;}
.testi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--color-brand-primary);} 
.testi-head{display:flex;align-items:center;gap:14px;} .testi-head img{width:48px;height:48px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 3px #fff,0 0 0 4px var(--color-brand-primary);} .testi-head h4{margin:0;font-size:15px;} .testi-head span{font-size:12px;color:var(--gray-500);} 
.avatar-fallback{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;background:linear-gradient(135deg,var(--color-brand-primary),var(--color-brand-secondary));color:#fff;box-shadow:0 0 0 3px #fff,0 0 0 4px var(--color-brand-primary);} 
.img-fallback{object-fit:cover;filter:grayscale(.15);} 
.testi-body{font-size:13px;line-height:1.5;color:var(--gray-600);} 
.rating i{color:#ffb100;font-size:13px;} 

/* =============== NEWS & AGENDA =============== */
.tab-switch{display:inline-flex;background:var(--gray-100);padding:4px;border-radius:var(--radius-pill);gap:4px;margin-bottom:var(--space-5);} 
.tab-switch button{background:transparent;border:0;padding:8px 18px;font-weight:600;font-size:13px;border-radius:var(--radius-pill);color:var(--gray-600);transition:.3s;letter-spacing:.3px;} 
.tab-switch button.active{background:linear-gradient(135deg,var(--color-brand-primary),var(--color-brand-secondary));color:#fff;box-shadow:var(--shadow-sm);} 
.tab-panels{position:relative;} .tab-panel{display:none;} .tab-panel.active{display:block;} 
.news-grid-v2{display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.news-card-v2{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:box-shadow .35s,transform .35s,border-color .35s;} 
.news-card-v2 img{aspect-ratio:16/10;object-fit:cover;width:100%;}
.news-card-v2 img[onerror],.project-media img[onerror]{background:var(--gray-100);display:block;}
.news-card-v2 .nc-body{padding:16px 18px;display:flex;flex-direction:column;gap:10px;} 
.news-card-v2 h4{margin:0;font-size:16px;line-height:1.35;} .news-card-v2 h4 a{color:var(--gray-900);} .news-card-v2 h4 a:hover{color:var(--color-brand-primary);} 
.nc-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;font-weight:500;color:var(--gray-500);} .nc-meta i{margin-right:4px;color:var(--color-brand-primary);} 
.news-card-v2 p{margin:0;color:var(--gray-600);font-size:13px;line-height:1.5;} 
.news-card-v2:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--color-brand-primary);} 

/* =============== CTA BAND =============== */
.cta-band{background:linear-gradient(120deg,var(--color-brand-primary),var(--color-brand-secondary));color:#fff;padding:var(--space-9) 0;text-align:center;position:relative;overflow:hidden;}
.cta-band h2{margin:0 0 var(--space-4);font-size:clamp(1.6rem,3vw,2.2rem);} .cta-band p{margin:0 0 var(--space-6);max-width:620px;margin-left:auto;margin-right:auto;color:rgba(255,255,255,.9);} 
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}

/* Dark mode tweaks (scoped) */
:root[data-theme='dark'] .unified-card,:root[data-theme='dark'] .project-card-v2,:root[data-theme='dark'] .testi-card,:root[data-theme='dark'] .news-card-v2,:root[data-theme='dark'] .feature-point{background:#1f2529;border-color:#2c3338;}
:root[data-theme='dark'] .feature-point:hover{background:#232a32;}
:root[data-theme='dark'] .section-head h2{color:#fff;}
:root[data-theme='dark'] .section-eyebrow{background:#22292e;color:var(--gray-300);} 
:root[data-theme='dark'] .section-head p,:root[data-theme='dark'] .feature-point p,:root[data-theme='dark'] .testi-body{color:var(--gray-400);} 

