*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:Inter,sans-serif; background:#fff; color:#1a1a1a; overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; }
ul { list-style:none; }

/* ── NAVBAR ── */
#navbar { position:fixed; top:0; left:0; right:0; z-index:1000; height:80px; background:#fff; border-bottom:1px solid #f0f0f0; box-shadow:0 2px 20px rgba(0,0,0,0.06); transition:background 0.4s ease, box-shadow 0.4s ease, border-color 0.4s ease; }
#navbar.scrolled { box-shadow:0 4px 30px rgba(0,0,0,0.1); }

/* Transparent Navbar on Hero Page */
.hero-page #navbar { background:transparent; border-bottom:1px solid rgba(255,255,255,0.1); box-shadow:none; }
.hero-page #navbar .nav-menu > li > a { color:rgba(255,255,255,0.9); }
.hero-page #navbar .nav-menu > li > a:hover { color:#fff; background:rgba(255,255,255,0.1); }
.hero-page #navbar .nav-menu > li > a.active { color:#fda4af; }
.hero-page #navbar .hamburger span { background:#fff; }
.hero-page #navbar .nav-logo img { filter:brightness(10); }
.hero-page #navbar .dropdown { background:rgba(20,20,30,0.95); border-color:rgba(255,255,255,0.1); }
.hero-page #navbar .dropdown li a { color:rgba(255,255,255,0.7); }
.hero-page #navbar .dropdown li a:hover { background:rgba(255,255,255,0.1); color:#fff; }
.hero-page #navbar.scrolled { background:#fff; border-bottom:1px solid #f0f0f0; box-shadow:0 4px 30px rgba(0,0,0,0.1); }
.hero-page #navbar.scrolled .nav-menu > li > a { color:#333; }
.hero-page #navbar.scrolled .nav-menu > li > a:hover { color:#e11d48; background:#fff1f2; }
.hero-page #navbar.scrolled .nav-menu > li > a.active { color:#e11d48; }
.hero-page #navbar.scrolled .hamburger span { background:#333; }
.hero-page #navbar.scrolled .nav-logo img { filter:none; }
.hero-page #navbar.scrolled .dropdown { background:#fff; border-color:#f0f0f0; }
.hero-page #navbar.scrolled .dropdown li a { color:#444; }
.hero-page #navbar.scrolled .dropdown li a:hover { background:#fff1f2; color:#e11d48; }
.nav-container { max-width:1280px; margin:0 auto; padding:0 40px; height:100%; display:flex; align-items:center; justify-content:space-between; }
.nav-logo img { height:50px; object-fit:contain; transition:filter 0.4s ease; }
.nav-menu { display:flex; align-items:center; gap:4px; }
.nav-menu > li > a { padding:8px 16px; font-size:14px; font-weight:500; color:#333; border-radius:6px; transition:color 0.3s ease, background 0.3s ease; display:flex; align-items:center; gap:4px; }
.nav-menu > li > a:hover { color:#e11d48; background:#fff1f2; }
.nav-menu > li > a.active { color:#e11d48; }
.nav-career { background:#e11d48 !important; color:#fff !important; border-radius:6px; padding:8px 18px !important; font-weight:600 !important; }
.nav-career:hover { background:#be123c !important; color:#fff !important; }
.arrow { font-size:10px; }

/* DROPDOWN */
.has-dropdown { position:relative; }
.dropdown { position:absolute; top:calc(100% + 8px); left:0; background:#fff; border:1px solid #f0f0f0; border-radius:12px; box-shadow:0 10px 40px rgba(0,0,0,0.12); min-width:200px; padding:8px; opacity:0; visibility:hidden; transform:translateY(-8px); transition:all 0.25s; z-index:100; }
.has-dropdown:hover .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown li a { display:block; padding:10px 16px; font-size:13px; color:#444; border-radius:8px; transition:all 0.2s; }
.dropdown li a:hover { background:#fff1f2; color:#e11d48; }

/* HAMBURGER */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:#333; border-radius:2px; transition:all 0.3s; }
.hamburger.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* MOBILE MENU */
.mobile-menu { position:fixed; top:80px; left:0; right:0; z-index:999; background:#fff; border-bottom:1px solid #f0f0f0; box-shadow:0 10px 30px rgba(0,0,0,0.1); padding:16px 24px; display:flex; flex-direction:column; gap:4px; transform:translateY(-110%); visibility:hidden; transition:transform 0.3s ease, visibility 0.3s ease; }
.mobile-menu.open { transform:translateY(0); visibility:visible; }
.mobile-menu a { font-size:15px; color:#333; padding:12px 16px; border-radius:8px; font-weight:500; }
.mobile-menu a:hover { background:#fff1f2; color:#e11d48; }
.mobile-career { background:#e11d48 !important; color:#fff !important; text-align:center; margin-top:8px; font-weight:600 !important; }

/* PAGE WRAPPER */
.page-wrapper { padding-top:80px; }
.hero-page .page-wrapper { padding-top:0; }

/* PAGE HERO */
.page-hero { background:linear-gradient(135deg,#e11d48 0%,#9f1239 100%); padding:80px 40px; text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:""; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width=%2760%27 height=%2760%27 viewBox=%270 0 60 60%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cg fill=%27none%27 fill-rule=%27evenodd%27%3E%3Cg fill=%27%23ffffff%27 fill-opacity=%270.05%27%3E%3Cpath d=%27M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z%27/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.page-hero-content { position:relative; z-index:1; max-width:800px; margin:0 auto; }
.page-hero h1 { font-size:clamp(2rem,5vw,3.5rem); font-weight:900; color:#fff; letter-spacing:-1px; margin-bottom:16px; }
.page-hero p { font-size:1.1rem; color:rgba(255,255,255,0.85); line-height:1.7; }
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; margin-top:20px; font-size:13px; color:rgba(255,255,255,0.7); }
.breadcrumb a { color:rgba(255,255,255,0.7); transition:color 0.2s; }
.breadcrumb a:hover { color:#fff; }
.breadcrumb span { color:rgba(255,255,255,0.5); }

/* SECTIONS */
.section { padding:80px 40px; }
.section-alt { background:#fafafa; }
.section-red { background:linear-gradient(135deg,#e11d48,#9f1239); color:#fff; }
.container { max-width:1200px; margin:0 auto; }
.section-label { font-size:12px; letter-spacing:4px; text-transform:uppercase; color:#e11d48; margin-bottom:12px; font-weight:700; }
.section-label-white { color:rgba(255,255,255,0.8); }
.section-title { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; line-height:1.2; letter-spacing:-1px; color:#1a1a1a; margin-bottom:16px; }
.section-title-white { color:#fff; }
.section-sub { font-size:1rem; color:#666; line-height:1.7; max-width:600px; }
.section-sub-white { color:rgba(255,255,255,0.8); }
.section-header { margin-bottom:56px; }
.section-header.center { text-align:center; }
.section-header.center .section-sub { margin:0 auto; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:8px; font-size:14px; font-weight:600; transition:all 0.2s; cursor:pointer; border:none; font-family:Inter,sans-serif; }
.btn-red { background:#e11d48; color:#fff; }
.btn-red:hover { background:#be123c; transform:translateY(-1px); box-shadow:0 4px 15px rgba(225,29,72,0.3); }
.btn-outline { background:transparent; color:#e11d48; border:2px solid #e11d48; }
.btn-outline:hover { background:#e11d48; color:#fff; }
.btn-white { background:#fff; color:#e11d48; }
.btn-white:hover { background:#f9f9f9; transform:translateY(-1px); }
.btn-outline-white { background:transparent; color:#fff; border:2px solid rgba(255,255,255,0.6); padding:13px 28px; border-radius:8px; font-size:14px; font-weight:600; transition:all 0.2s; display:inline-flex; align-items:center; gap:8px; }
.btn-outline-white:hover { background:rgba(255,255,255,0.2); border-color:#fff; color:#fff; }

/* CARDS */
.card { background:#fff; border:1px solid #f0f0f0; border-radius:16px; overflow:hidden; transition:all 0.3s; box-shadow:0 2px 10px rgba(0,0,0,0.04); }
.card:hover { box-shadow:0 10px 40px rgba(0,0,0,0.1); transform:translateY(-4px); border-color:#fecdd3; }

/* STATS BAR */
.stats-bar { background:#e11d48; padding:40px; }
.stats-bar .container { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat-box { text-align:center; color:#fff; }
.stat-box .num { font-size:2.5rem; font-weight:900; line-height:1; }
.stat-box .label { font-size:12px; opacity:0.85; margin-top:6px; letter-spacing:1px; text-transform:uppercase; }

/* FOOTER */
footer { background:#1a1a1a; color:#fff; padding:60px 40px 0; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:1.5fr 2fr; gap:80px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.1); }
.footer-logo { height:50px; object-fit:contain; margin-bottom:16px; filter:brightness(10); }
.footer-brand p { font-size:14px; color:rgba(255,255,255,0.55); line-height:1.7; margin-bottom:24px; max-width:300px; }
.footer-wa { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:8px; background:linear-gradient(135deg,#25d366,#128c7e); font-size:13px; font-weight:600; color:#fff; transition:opacity 0.2s; }
.footer-wa:hover { opacity:0.85; }
.footer-links-wrap { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.footer-col h4 { font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:#fff; margin-bottom:20px; }
.footer-col a,.footer-col p { display:block; font-size:13px; color:rgba(255,255,255,0.5); margin-bottom:10px; transition:color 0.2s; }
.footer-col a:hover { color:#fda4af; }
.footer-bottom { padding:24px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.footer-bottom p { font-size:13px; color:rgba(255,255,255,0.4); }
.footer-bottom a { color:#fda4af; }

/* WA FLOAT */
#wa-float { position:fixed; bottom:28px; right:28px; z-index:500; width:54px; height:54px; border-radius:16px; background:linear-gradient(135deg,#25d366,#128c7e); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,0.4); transition:all 0.3s; animation:wa-pulse 3s ease-in-out infinite; }
#wa-float:hover { transform:translateY(-4px) scale(1.05); animation:none; }
#wa-float svg { width:28px; height:28px; fill:#fff; }
.wa-tooltip { position:absolute; right:64px; background:#1a1a1a; color:#fff; font-size:13px; font-weight:500; padding:8px 14px; border-radius:10px; white-space:nowrap; opacity:0; visibility:hidden; transition:all 0.3s; }
#wa-float:hover .wa-tooltip { opacity:1; visibility:visible; }
@keyframes wa-pulse { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4)} 50%{box-shadow:0 4px 30px rgba(37,211,102,0.7)} }

/* BACK TO TOP */
#back-to-top { position:fixed; bottom:92px; right:28px; z-index:500; width:44px; height:44px; border-radius:12px; background:#e11d48; color:#fff; font-size:20px; display:flex; align-items:center; justify-content:center; cursor:pointer; text-decoration:none; transition:all 0.3s; opacity:0; visibility:hidden; transform:translateY(10px); box-shadow:0 4px 15px rgba(225,29,72,0.3); }
#back-to-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
#back-to-top:hover { background:#be123c; transform:translateY(-3px); }

/* ANIMATIONS */
.fade-up { opacity:0; transform:translateY(24px); transition:opacity 0.6s ease,transform 0.6s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* BADGE */
.badge { display:inline-block; padding:4px 12px; border-radius:100px; font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase; }
.badge-red { background:#fff1f2; color:#e11d48; }
.badge-green { background:#f0fdf4; color:#16a34a; }
.badge-gray { background:#f5f5f5; color:#666; }

/* FORM */
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:13px; color:#444; margin-bottom:8px; font-weight:500; }
.form-group input,.form-group textarea,.form-group select { width:100%; padding:13px 16px; background:#fff; border:1.5px solid #e5e7eb; border-radius:10px; color:#1a1a1a; font-size:14px; outline:none; transition:border-color 0.3s; font-family:Inter,sans-serif; }
.form-group input:focus,.form-group textarea:focus,.form-group select:focus { border-color:#e11d48; box-shadow:0 0 0 3px rgba(225,29,72,0.08); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* PAGINATION */
.pagination { display:flex; gap:8px; justify-content:center; margin-top:48px; flex-wrap:wrap; }
.pagination a,.pagination span { width:40px; height:40px; display:flex; align-items:center; justify-content:center; border-radius:8px; font-size:14px; font-weight:500; border:1.5px solid #e5e7eb; color:#444; transition:all 0.2s; }
.pagination a:hover { border-color:#e11d48; color:#e11d48; }
.pagination .active { background:#e11d48; color:#fff; border-color:#e11d48; }

/* RESPONSIVE */
@media (max-width:1024px) { .nav-container { padding:0 24px; } .section { padding:60px 24px; } .stats-bar .container { grid-template-columns:repeat(2,1fr); } .footer-top { grid-template-columns:1fr; gap:40px; } footer { padding:40px 24px 0; } }
@media (max-width:768px) { .nav-menu,.nav-career { display:none; } .hamburger { display:flex; } .section { padding:48px 20px; } .form-row { grid-template-columns:1fr; } .footer-links-wrap { grid-template-columns:1fr 1fr; } .footer-bottom { flex-direction:column; } }
@media (max-width:480px) { .stats-bar .container { grid-template-columns:1fr 1fr; } .footer-links-wrap { grid-template-columns:1fr; } }
/* ── HERO SLIDER ── */
.hero-slider { position:relative; min-height:100vh; overflow:hidden; }
.hero-slides { position:absolute; inset:0; z-index:1; }
.hero-slide { position:absolute; inset:0; background-size:cover; background-position:center; background-repeat:no-repeat; opacity:0; transition:opacity 1.2s ease-in-out; }
.hero-slide.active { opacity:1; }
.hero-slide-overlay { position:absolute; inset:0; background:linear-gradient(135deg, rgba(10,10,10,0.72) 0%, rgba(30,0,10,0.55) 50%, rgba(225,29,72,0.25) 100%); }

/* Hero Slide — fallback gradient when no image */
.hero-slide { background-color:#1a1a2e; }
.hero-slide:nth-child(1) { background-color:#0f172a; }
.hero-slide:nth-child(2) { background-color:#1e1b2e; }
.hero-slide:nth-child(3) { background-color:#1a0a0a; }

.hero-slider-content { position:relative; z-index:5; max-width:1280px; margin:0 auto; padding:0 40px; min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding-top:120px; padding-bottom:120px; }
.hero-slide-texts { position:relative; }
.hero-slide-text { opacity:0; transform:translateY(30px); transition:opacity 0.8s ease, transform 0.8s ease; pointer-events:none; position:absolute; top:0; left:0; right:0; }
.hero-slide-text:first-child { position:relative; }
.hero-slide-text.active { opacity:1; transform:translateY(0); pointer-events:auto; }

.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(225,29,72,0.15); border:1px solid rgba(225,29,72,0.3); padding:8px 18px; border-radius:100px; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:#fda4af; margin-bottom:24px; font-weight:600; backdrop-filter:blur(10px); }
.badge-dot { width:6px; height:6px; background:#e11d48; border-radius:50%; box-shadow:0 0 8px #e11d48; animation:blink 2s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

.hero-slide-text h1 { font-size:clamp(2.5rem,5vw,4rem); font-weight:900; line-height:1.1; letter-spacing:-2px; color:#fff; margin-bottom:20px; }
.hero-slide-text h1 span { color:#fda4af; }
.hero-slide-text p { font-size:1.1rem; color:rgba(255,255,255,0.75); line-height:1.7; max-width:560px; margin-bottom:32px; }

.hero-btns { display:flex; gap:12px; flex-wrap:wrap; position:relative; z-index:5; }
.btn-outline-white-hero { background:transparent; color:#fff; border:2px solid rgba(255,255,255,0.5); padding:13px 28px; border-radius:8px; font-size:14px; font-weight:600; transition:all 0.2s; display:inline-flex; align-items:center; gap:8px; }
.btn-outline-white-hero:hover { background:rgba(255,255,255,0.15); border-color:#fff; color:#fff; }


/* Hero Slider Indicators */
.hero-slider-indicators { position:absolute; bottom:130px; left:40px; z-index:10; display:flex; gap:10px; }
.hero-indicator { width:40px; height:4px; border:none; border-radius:4px; background:rgba(255,255,255,0.3); cursor:pointer; transition:all 0.4s; padding:0; }
.hero-indicator.active { background:#e11d48; width:56px; }
.hero-indicator:hover { background:rgba(255,255,255,0.6); }

/* Hero Slider Arrows */
.hero-slider-arrow { position:absolute; top:50%; z-index:10; transform:translateY(-50%); width:48px; height:48px; border:2px solid rgba(255,255,255,0.25); border-radius:12px; background:rgba(0,0,0,0.2); backdrop-filter:blur(10px); color:#fff; font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.3s; }
.hero-slider-arrow:hover { background:rgba(225,29,72,0.6); border-color:rgba(225,29,72,0.8); }
.hero-arrow-prev { left:24px; }
.hero-arrow-next { right:24px; }

/* Hero Floating Cards */
.hero-floating-cards { position:absolute; bottom:20px; left:0; right:0; z-index:8; display:flex; gap:12px; justify-content:center; padding:0 40px; flex-wrap:wrap; }
.hero-floating-cards .hero-card { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); border-radius:14px; padding:14px 18px; display:flex; align-items:center; gap:12px; backdrop-filter:blur(16px); transition:all 0.3s; flex:0 1 auto; min-width:180px; }
.hero-floating-cards .hero-card:hover { background:rgba(255,255,255,0.15); border-color:rgba(255,255,255,0.25); transform:translateY(-3px); }
.hero-floating-cards .hc-icon { font-size:1.5rem; width:40px; height:40px; background:rgba(225,29,72,0.2); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.hero-floating-cards .hc-text strong { display:block; font-size:12px; font-weight:700; color:#fff; }
.hero-floating-cards .hc-text span { font-size:10px; color:rgba(255,255,255,0.55); }

/* ABOUT HOME */
.about-home-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-box { position:relative; height:380px; display:flex; align-items:center; justify-content:center; }
.aib-main { width:200px; height:200px; background:linear-gradient(135deg,#e11d48,#9f1239); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:5rem; box-shadow:0 20px 60px rgba(225,29,72,0.3); }
.aib-badge { position:absolute; background:#fff; border:1.5px solid #f0f0f0; border-radius:14px; padding:12px 18px; text-align:center; box-shadow:0 4px 20px rgba(0,0,0,0.08); }
.aib-badge strong { display:block; font-size:1.4rem; font-weight:900; color:#e11d48; }
.aib-badge span { font-size:11px; color:#888; }
.aib-1 { top:20px; right:20px; }
.aib-2 { bottom:40px; left:10px; }
.aib-3 { bottom:40px; right:10px; }
.about-points { display:flex; flex-direction:column; gap:12px; margin-top:24px; }
.ap-item { display:flex; align-items:center; gap:12px; font-size:14px; color:#444; }
.ap-icon { width:22px; height:22px; background:#e11d48; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; flex-shrink:0; }

/* SERVICES HOME */
.services-home-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.service-home-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:16px; padding:28px; transition:all 0.3s; display:block; position:relative; overflow:hidden; }
.service-home-card::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,#e11d48,#f43f5e); transform:scaleX(0); transition:transform 0.3s; }
.service-home-card:hover { border-color:#fecdd3; box-shadow:0 10px 40px rgba(225,29,72,0.1); transform:translateY(-4px); }
.service-home-card:hover::before { transform:scaleX(1); }
.shc-icon { font-size:2.2rem; width:56px; height:56px; background:#fff1f2; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.service-home-card h3 { font-size:15px; font-weight:700; color:#1a1a1a; margin-bottom:8px; }
.service-home-card p { font-size:13px; color:#666; line-height:1.6; margin-bottom:16px; }
.shc-arrow { font-size:16px; color:#e11d48; font-weight:700; transition:transform 0.2s; display:inline-block; }
.service-home-card:hover .shc-arrow { transform:translateX(4px); }

/* PROYEK GRID */
.proyek-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.proyek-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:16px; overflow:hidden; transition:all 0.3s; }
.proyek-card:hover { box-shadow:0 10px 40px rgba(0,0,0,0.1); transform:translateY(-4px); border-color:#fecdd3; }
.proyek-card-img { height:180px; position:relative; overflow:hidden; background:#f5f5f5; }
.proyek-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.proyek-card:hover .proyek-card-img img { transform:scale(1.05); }
.proyek-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; background:linear-gradient(135deg,#fff1f2,#fecdd3); }
.proyek-cat { position:absolute; top:12px; left:12px; background:#e11d48; color:#fff; font-size:11px; font-weight:600; padding:4px 10px; border-radius:6px; letter-spacing:1px; }
.proyek-card-body { padding:20px; }
.proyek-card-body h3 { font-size:15px; font-weight:700; color:#1a1a1a; margin-bottom:8px; line-height:1.4; }
.proyek-card-body p { font-size:13px; color:#666; line-height:1.5; margin-bottom:12px; }
.proyek-meta { display:flex; gap:16px; font-size:12px; color:#888; }

/* CLIENTS HOME */
.clients-home-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.client-home-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:14px; padding:28px 20px; display:flex; align-items:center; justify-content:center; min-height:110px; transition:all 0.3s; }
.client-home-card:hover { border-color:#fecdd3; box-shadow:0 6px 24px rgba(225,29,72,0.08); transform:translateY(-2px); }
.chc-logo { display:flex; flex-direction:column; align-items:center; gap:8px; width:100%; }
.chc-logo img { max-width:130px; max-height:55px; object-fit:contain; filter:grayscale(1); opacity:0.6; transition:all 0.3s; }
.client-home-card:hover .chc-logo img { filter:grayscale(0); opacity:1; }
.chc-logo span { font-size:11px; font-weight:600; color:#888; text-align:center; line-height:1.4; }

/* BERITA HOME */
.berita-home-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.berita-home-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:16px; overflow:hidden; transition:all 0.3s; display:block; }
.berita-home-card:hover { box-shadow:0 10px 40px rgba(0,0,0,0.1); transform:translateY(-4px); border-color:#fecdd3; }
.bhc-img { height:200px; position:relative; overflow:hidden; background:#f5f5f5; }
.bhc-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.berita-home-card:hover .bhc-img img { transform:scale(1.05); }
.bhc-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; background:linear-gradient(135deg,#fff1f2,#fecdd3); }
.bhc-cat { position:absolute; top:12px; left:12px; background:#e11d48; color:#fff; font-size:11px; font-weight:600; padding:4px 10px; border-radius:6px; }
.bhc-body { padding:20px; }
.bhc-date { font-size:12px; color:#aaa; margin-bottom:8px; }
.bhc-body h3 { font-size:15px; font-weight:700; color:#1a1a1a; margin-bottom:8px; line-height:1.4; }
.bhc-body p { font-size:13px; color:#666; line-height:1.5; margin-bottom:12px; }
.bhc-read { font-size:13px; color:#e11d48; font-weight:600; }

/* CTA BANNER */
.cta-banner { display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.cta-banner h2 { font-size:clamp(1.5rem,3vw,2.2rem); font-weight:800; color:#fff; margin-bottom:8px; }
.cta-banner p { color:rgba(255,255,255,0.8); font-size:1rem; }
.cta-btns { display:flex; gap:12px; flex-wrap:wrap; }

/* RESPONSIVE HOME */
@media (max-width:1024px) {
  .hero-slider-content { padding:0 24px; padding-top:100px; padding-bottom:50px; }
  .hero-floating-cards { padding:0 24px; gap:8px; }
  .hero-floating-cards .hero-card { min-width:150px; padding:10px 14px; }
  .hero-slider-indicators { left:24px; bottom:120px; }
  .hero-arrow-prev { left:12px; }
  .hero-arrow-next { right:12px; }
  .about-home-grid { grid-template-columns:1fr; gap:40px; }
  .services-home-grid { grid-template-columns:1fr 1fr; }
  .proyek-grid { grid-template-columns:1fr 1fr; }
  .clients-home-grid { grid-template-columns:1fr 1fr; }
  .berita-home-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .hero-slider { min-height:100vh; }
  .hero-slider-content { padding-top:100px; padding-bottom:140px; }
  .hero-slide-texts { min-height:240px; }
  .hero-slide-text h1 { font-size:clamp(1.8rem,6vw,2.5rem); }
  .hero-slider-arrow { width:36px; height:36px; font-size:14px; }
  .hero-arrow-prev { left:8px; }
  .hero-arrow-next { right:8px; }
  .hero-floating-cards { padding:0 16px; gap:6px; bottom:10px; }
  .hero-floating-cards .hero-card { min-width:130px; padding:8px 10px; border-radius:10px; }
  .hero-floating-cards .hc-icon { width:32px; height:32px; font-size:1.1rem; }
  .hero-floating-cards .hc-text strong { font-size:10px; }
  .hero-floating-cards .hc-text span { font-size:9px; }
  .hero-slider-indicators { left:16px; bottom:105px; }
}
@media (max-width:640px) {
  .hero-floating-cards { display:none; }
  .hero-slider-indicators { bottom:30px; left:50%; transform:translateX(-50%); }
  .hero-slider-arrow { display:none; }
  .hero-slider-content { padding-bottom:80px; }
  .services-home-grid { grid-template-columns:1fr; }
  .proyek-grid { grid-template-columns:1fr; }
  .clients-home-grid { grid-template-columns:1fr 1fr; }
  .berita-home-grid { grid-template-columns:1fr; }
  .cta-banner { flex-direction:column; text-align:center; }
  .cta-btns { justify-content:center; }
}
/* ── PAGES CSS ── */
.visi-misi-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.vm-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:20px; padding:40px; box-shadow:0 2px 12px rgba(0,0,0,0.04); }
.vm-icon { font-size:2.5rem; margin-bottom:16px; }
.vm-card h3 { font-size:1.3rem; font-weight:800; color:#1a1a1a; margin-bottom:16px; }
.vm-card p { font-size:14px; color:#555; line-height:1.7; }
.vm-card ul { padding-left:0; }
.vm-card ul li { font-size:14px; color:#555; line-height:1.7; padding:6px 0; padding-left:20px; position:relative; }
.vm-card ul li::before { content:"\2022"; color:#e11d48; position:absolute; left:0; font-weight:700; }
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.why-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:16px; padding:28px 20px; text-align:center; transition:all 0.3s; }
.why-card:hover { border-color:#fecdd3; box-shadow:0 8px 30px rgba(225,29,72,0.1); transform:translateY(-4px); }
.why-icon { font-size:2.2rem; width:60px; height:60px; background:#fff1f2; border-radius:16px; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.why-card h3 { font-size:15px; font-weight:700; color:#1a1a1a; margin-bottom:8px; }
.why-card p { font-size:13px; color:#666; line-height:1.6; }

/* LAYANAN */
.layanan-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.layanan-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:20px; padding:32px; transition:all 0.3s; position:relative; overflow:hidden; }
.layanan-card::after { content:""; position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg,#e11d48,#f43f5e); transform:scaleX(0); transition:transform 0.3s; }
.layanan-card:hover { border-color:#fecdd3; box-shadow:0 12px 40px rgba(225,29,72,0.1); transform:translateY(-4px); }
.layanan-card:hover::after { transform:scaleX(1); }
.lc-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.lc-icon { font-size:2rem; width:56px; height:56px; background:#fff1f2; border-radius:14px; display:flex; align-items:center; justify-content:center; }
.lc-num { font-size:3rem; font-weight:900; color:#f0f0f0; line-height:1; }
.layanan-card h3 { font-size:1.1rem; font-weight:700; color:#1a1a1a; margin-bottom:12px; }
.layanan-card p { font-size:14px; color:#666; line-height:1.6; margin-bottom:20px; }
.lc-tags { display:flex; flex-wrap:wrap; gap:8px; }
.lc-tags span { font-size:11px; padding:4px 10px; border-radius:100px; background:#fff1f2; color:#e11d48; font-weight:600; }

/* FILTER BAR */
.filter-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:40px; }
.filter-btn { padding:8px 20px; border-radius:100px; font-size:13px; font-weight:600; border:1.5px solid #e5e7eb; color:#555; transition:all 0.2s; cursor:pointer; }
.filter-btn:hover,.filter-btn.active { background:#e11d48; color:#fff; border-color:#e11d48; }

/* PROYEK KLIEN */
.proyek-klien { font-size:12px; color:#888; margin-top:8px; }

/* KONTAK */
.kontak-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; align-items:start; }
.kontak-items { margin-top:32px; display:flex; flex-direction:column; gap:20px; }
.kontak-item { display:flex; gap:16px; align-items:flex-start; }
.ki-icon { width:44px; height:44px; background:#fff1f2; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.ki-text strong { display:block; font-size:13px; font-weight:700; color:#1a1a1a; margin-bottom:4px; }
.ki-text a,.ki-text span { font-size:13px; color:#666; transition:color 0.2s; }
.ki-text a:hover { color:#e11d48; }
.kontak-map { margin-top:24px; border-radius:12px; overflow:hidden; border:1.5px solid #f0f0f0; }
.kontak-form-wrap { background:#fafafa; border:1.5px solid #f0f0f0; border-radius:20px; padding:40px; }
.success-msg { text-align:center; padding:40px 20px; }
.sm-icon { width:64px; height:64px; background:#dcfce7; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.8rem; color:#16a34a; margin:0 auto 16px; }
.success-msg h3 { font-size:1.3rem; font-weight:700; color:#1a1a1a; margin-bottom:8px; }
.success-msg p { font-size:14px; color:#666; }
.error-msg { background:#fff1f2; border:1px solid #fecdd3; color:#e11d48; padding:12px 16px; border-radius:8px; font-size:13px; margin-bottom:20px; }

/* FAQ */
.faq-wrap { max-width:800px; margin:0 auto; }
.faq-item { border:1.5px solid #f0f0f0; border-radius:12px; margin-bottom:12px; overflow:hidden; transition:border-color 0.3s; }
.faq-item.open { border-color:#fecdd3; }
.faq-q { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; cursor:pointer; font-size:15px; font-weight:600; color:#1a1a1a; gap:16px; }
.faq-q:hover { color:#e11d48; }
.faq-arrow { font-size:20px; color:#e11d48; flex-shrink:0; transition:transform 0.3s; font-weight:400; }
.faq-item.open .faq-arrow { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.3s ease; }
.faq-item.open .faq-a { max-height:300px; }
.faq-a p { padding:0 24px 20px; font-size:14px; color:#555; line-height:1.7; }

/* GALLERY */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery-item { border-radius:12px; overflow:hidden; position:relative; aspect-ratio:4/3; cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.7),transparent); display:flex; align-items:flex-end; padding:16px; opacity:0; transition:opacity 0.3s; }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay span { color:#fff; font-size:13px; font-weight:600; }

/* EMPTY STATE */
.empty-state { text-align:center; padding:80px 20px; }
.es-icon { font-size:4rem; margin-bottom:16px; }
.empty-state h3 { font-size:1.3rem; font-weight:700; color:#1a1a1a; margin-bottom:8px; }
.empty-state p { font-size:14px; color:#888; }

/* ARTIKEL */
.artikel-wrap { max-width:800px; margin:0 auto; }
.artikel-img { width:100%; height:400px; object-fit:cover; border-radius:16px; margin-bottom:32px; }
.artikel-content { font-size:15px; color:#333; line-height:1.8; }
.artikel-content p { margin-bottom:16px; }
.artikel-content h2,.artikel-content h3 { font-weight:700; color:#1a1a1a; margin:24px 0 12px; }
.artikel-back { margin-top:40px; padding-top:32px; border-top:1.5px solid #f0f0f0; }

/* KARIR */
.karir-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.karir-card { background:#fff; border:1.5px solid #f0f0f0; border-radius:16px; padding:28px; transition:all 0.3s; }
.karir-card:hover { border-color:#fecdd3; box-shadow:0 8px 30px rgba(225,29,72,0.08); }
.kc-header { margin-bottom:16px; }
.kc-header h3 { font-size:1.1rem; font-weight:700; color:#1a1a1a; margin-bottom:8px; }
.kc-meta { display:flex; gap:12px; align-items:center; flex-wrap:wrap; font-size:13px; color:#666; }
.karir-card p { font-size:14px; color:#555; line-height:1.6; }

/* RESPONSIVE PAGES */
@media (max-width:1024px) { .visi-misi-grid { grid-template-columns:1fr; } .why-grid { grid-template-columns:1fr 1fr; } .layanan-grid { grid-template-columns:1fr 1fr; } .kontak-grid { grid-template-columns:1fr; } .gallery-grid { grid-template-columns:1fr 1fr; } .karir-grid { grid-template-columns:1fr; } }
@media (max-width:640px) { .why-grid { grid-template-columns:1fr 1fr; } .layanan-grid { grid-template-columns:1fr; } .gallery-grid { grid-template-columns:1fr 1fr; } }