@charset "UTF-8";
:root { --pegawe-orange: #ff8607; --pegawe-dark-orange: #eb5400; --pegawe-blue: #398c96; --black: #25352c; --black-light: #424242; font-size: 16px; }

@font-face { font-family: museo300; src: url(/static/fonts/Museo300-Regular-webfont.eot); src: url(/static/fonts/Museo300-Regular-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/Museo300-Regular-webfont.woff2) format("woff2"), url(/static/fonts/Museo300-Regular-webfont.woff) format("woff"), url(/static/fonts/Museo300-Regular-webfont.ttf) format("truetype"), url(/static/fonts/Museo300-Regular-webfont.svg#museo300) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: museo500; src: url(/static/fonts/Museo500-Regular-webfont.eot); src: url(/static/fonts/Museo500-Regular-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/Museo500-Regular-webfont.woff2) format("woff2"), url(/static/fonts/Museo500-Regular-webfont.woff) format("woff"), url(/static/fonts/Museo500-Regular-webfont.ttf) format("truetype"), url(/static/fonts/Museo500-Regular-webfont.svg#museo500) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: museo700; src: url(/static/fonts/Museo700-Regular-webfont.eot); src: url(/static/fonts/Museo700-Regular-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/Museo700-Regular-webfont.woff2) format("woff2"), url(/static/fonts/Museo700-Regular-webfont.woff) format("woff"), url(/static/fonts/Museo700-Regular-webfont.ttf) format("truetype"), url(/static/fonts/Museo700-Regular-webfont.svg#museo700) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: latoblack; src: url(/static/fonts/lato-black-webfont.eot); src: url(/static/fonts/lato-black-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/lato-black-webfont.woff2) format("woff2"), url(/static/fonts/lato-black-webfont.woff) format("woff"), url(/static/fonts/lato-black-webfont.ttf) format("truetype"), url(/static/fonts/lato-black-webfont.svg#latoblack) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: latomedium; src: url(/static/fonts/lato-medium-webfont.eot); src: url(/static/fonts/lato-medium-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/lato-medium-webfont.woff2) format("woff2"), url(/static/fonts/lato-medium-webfont.woff) format("woff"), url(/static/fonts/lato-medium-webfont.ttf) format("truetype"), url(/static/fonts/lato-medium-webfont.svg#latomedium) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: latoregular; src: url(/static/fonts/lato-regular-webfont.eot); src: url(/static/fonts/lato-regular-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/lato-regular-webfont.woff2) format("woff2"), url(/static/fonts/lato-regular-webfont.woff) format("woff"), url(/static/fonts/lato-regular-webfont.ttf) format("truetype"), url(/static/fonts/lato-regular-webfont.svg#latoregular) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: latobold; src: url(/static/fonts/lato-bold-webfont.eot); src: url(/static/fonts/lato-bold-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/lato-bold-webfont.woff2) format("woff2"), url(/static/fonts/lato-bold-webfont.woff) format("woff"), url(/static/fonts/lato-bold-webfont.ttf) format("truetype"), url(/static/fonts/lato-bold-webfont.svg#latobold) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: latoheavy; src: url(/static/fonts/lato-heavy-webfont.eot); src: url(/static/fonts/lato-heavy-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/lato-heavy-webfont.woff2) format("woff2"), url(/static/fonts/lato-heavy-webfont.woff) format("woff"), url(/static/fonts/lato-heavy-webfont.ttf) format("truetype"), url(/static/fonts/lato-heavy-webfont.svg#latoheavy) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: open_sansregular; src: url(/static/fonts/OpenSans-Regular-webfont.eot); src: url(/static/fonts/OpenSans-Regular-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/OpenSans-Regular-webfont.woff) format("woff"), url(/static/fonts/OpenSans-Regular-webfont.ttf) format("truetype"), url(/static/fonts/OpenSans-Regular-webfont.svg#open_sansregular) format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: open_sansbold; src: url(/static/fonts/OpenSans-Bold-webfont.eot); src: url(/static/fonts/OpenSans-Bold-webfont.eot?#iefix) format("embedded-opentype"), url(/static/fonts/OpenSans-Bold-webfont.woff) format("woff"), url(/static/fonts/OpenSans-Bold-webfont.ttf) format("truetype"), url(/static/fonts/OpenSans-Bold-webfont.svg#open_sansbold) format("svg"); font-weight: 400; font-style: normal; }

html { scroll-padding-top: 120px; }

* { margin: 0; padding: 0; box-sizing: border-box; }

body { font-family: "Museo", sans-serif; background-color: #fff; color: #333; }

h1, h2, h3, h4, h5, h6 { font-family: museo300; line-height: 140%; letter-spacing: 1.05px; }

.flex { display: flex; flex-wrap: wrap; }

.flex-row-reverse { flex-direction: row-reverse; }

.flex-column { flex-direction: column; }

.flex-column-reverse { flex-direction: column-reverse; }

.flex-just { justify-content: space-between; }

.flex-item-40 { width: calc(40% - 15px); }

.flex-item-50 { width: calc(50% - 15px); }

.flex-item-60 { width: calc(60% - 15px); }

.sticky { position: -webkit-sticky; /* Safari */ position: sticky; top: 0; }

.relative { position: relative; }

.bg-alihdaya { background: #076469; }

.bg-tosca { background-color: var(--tosca); }

.bg-white { background-color: #fff; }

.bg-abu-25 { background-color: rgba(0, 0, 0, 0.25); }

.size17px { font-size: 17px !important; }

.size20px { font-size: 20px !important; }

* { margin: 0; padding: 0; box-sizing: border-box; }

/* Mencegah overflow horizontal */
html, body { overflow-x: hidden; height: auto; }

body { overflow-y: hidden; padding-top: 100px; /* harus sama dengan tinggi navbar */ }

/* Pastikan semua elemen tidak keluar dari layar */
* { box-sizing: border-box; }

/* Untuk elemen kontainer yang mungkin melebar */
.container, .navbar { max-width: 100%; }

body { font-family: "Lato", sans-serif !important; }

h1, h2, h3, h4, h5, h6 { font-family: "Museo", sans-serif !important; }

p { font-family: "Lato", sans-serif !important; }

a { font-family: "Museo", sans-serif !important; }

span { font-family: "Lato", sans-serif !important; }

/* Navbar */
/* Navbar */
.navbar { background-color: #fff; border-bottom: 1px solid #eaeaea; padding: 15px 100px 24px 90px; height: 112px; position: fixed; width: 100%; top: 0px; z-index: 1000; }

.container { max-width: 1920px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }

.logo { height: 40px; display: flex; align-items: center; gap: 30px; }

.logo img { height: 48px; width: 179px; }

.nav-links { display: flex; align-items: center; gap: 32px; font-size: 16px; padding: 25px; margin-right: -20px; }

.nav-links a { color: #2a3233; text-decoration: none; font-weight: 300; transition: color 0.5s ease; }

.nav-links a:hover { color: #ff8607; }

.inline-cta-nav .cta-button { display: inline-block; margin-top: 0px; /* karena dia sejajar, gak perlu margin atas */ padding: 14px 24px 16px 24px; line-height: 100%; font-size: 16px; background-color: #028d96; width: 159px; height: 40px; color: white; text-decoration: none; border-radius: 10px; font-weight: 300; transition: background-color 0.3s ease; text-align: center; }

.inline-cta-nav .cta-button:hover { background-color: rgba(0, 112, 123, 0.963); }

.nav-links .inline-cta-nav a:hover { color: white; }

.nav-links a.active, .nav-links .dropdown-toggle.active, .mobile-menu a.active, .mobile-menu .dropdown-toggle.active { color: #ff8607; font-weight: bold; }

/* Container dropdown */
.dropdown { position: relative; display: inline-block; }

/* Buka dropdown jika ada class hover */
.dropdown.hover .dropdown-menu { display: block; opacity: 1; visibility: visible; }

/* Warna hover/aktif untuk menu utama */
/* Menu utama (dropdown toggle) aktif */
.dropdown1.active { color: #f1f5f9; /* Warna oranye untuk tulisan "Solusi" */ }

.dropdown1.active .icon { color: #f1f5f9; }

/* Warna hover/aktif untuk item submenu */
.dropdown-menu.custom-dropdown a:hover, .dropdown-menu.custom-dropdown a.active { background-color: #f1f5f9; }

/* Menu awalnya disembunyikan dengan transisi */
.dropdown-menu.custom-dropdown { opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.3s ease; position: absolute; top: 100%; right: 0; background-color: #fff; min-width: 250px; width: 322px; z-index: 999; padding: 0px; /* Hapus display:flex atau pastikan column */ display: block; }

.dropdown:hover .dropdown-menu.custom-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }

.dropdown-menu.custom-dropdown a { display: flex; align-items: center; gap: 14px; /* Ubah dari 10px ke 14px */ padding: 0px 50px; /* Ubah dari 5px 5px untuk ruang lebih */ padding-left: 10px; text-decoration: none; color: #2a3233; border-radius: 8px; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background-color 0.2s ease; width: 320px; height: 40px; }

.dropdown-menu.custom-dropdown a:hover { background-color: #f1f5f9; }

.dropdown-menu.custom-dropdown .icon { font-size: 16px; margin-top: -2px; color: #2a3233; min-width: 24px; /* Ubah dari 20px ke 24px untuk lebih stabil */ text-align: center; /* Tambahan agar ikon terlihat rapi */ }

.language-switcher { font-size: 16px; display: flex; gap: 16px; padding-left: 80px; }

.language-switcher a { text-decoration: none; color: #cbcbcb; font-weight: 300; margin: 0 2px; }

.language-switcher a.active { color: #ff8607; font-weight: 300; }

.language-switcher .active-lang { color: #ff8607; font-weight: 700; }

.language-switcher a:hover { color: #ff8607; font-weight: bold; }

.mobile-menu { display: none; }

.mobile-menu { margin-top: 100px; width: 100vw; max-height: calc(100vh - 100px); /* agar tetap di bawah navbar */ background-color: white; position: fixed; top: 0; left: 0; z-index: 9999; padding: 20px 60px; display: flex; flex-direction: column; gap: 16px; /* Scroll jika konten panjang */ overflow-y: auto; /* Transisi & efek hilang default */ opacity: 0; visibility: hidden; transform: translateY(-20px); transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s; }

.mobile-menu.show { opacity: 1; visibility: visible; transform: translateY(0); }

.mobile-menu.show a:hover { display: flex; }

.mobile-menu a { color: #2a3233; text-decoration: none; font-weight: 500; transition: color 0.5s ease; padding: 0px; font-size: 16px; }

.mobile-menu a:hover { color: #ff8607; }

.menu-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid #eaeaea; padding-bottom: 16px; }

.menu-header strong { font-size: 16px; font-weight: 600; font-family: "Museo", sans-serif !important; }

/* Dropdown Menu */
.mobile-menu .dropdown { position: relative; display: inline-block; }

/* Buka dropdown jika ada class hover */
.mobile-menu .dropdown.hover .dropdown-menu { display: block; opacity: 1; visibility: visible; }

/* Warna hover/aktif untuk menu utama */
/* Menu utama (dropdown toggle) aktif */
/* Warna hover/aktif untuk item submenu */
.dropdown-menu.custom-dropdown a:hover, .dropdown-menu.custom-dropdown a.active { background-color: #f1f5f9; }

/* Menu awalnya disembunyikan dengan transisi */
.mobile-menu .dropdown-menu.custom-dropdown { opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.3s ease; position: absolute; top: 100%; left: 0; background-color: #fff; border: 1px solid #ddd; border-radius: 12px; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08); min-width: 320px; width: 33%; z-index: 999; /* Hapus display:flex atau pastikan column */ display: block; }

.mobile-menu .dropdown:hover .dropdown-menu.custom-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }

.mobile-menu .dropdown-menu.custom-dropdown a { display: flex; align-items: center; gap: 14px; /* Ubah dari 10px ke 14px */ padding: 2px 63px; /* Ubah dari 5px 5px untuk ruang lebih */ padding-left: 10px; text-decoration: none; color: #2a3233; border-radius: 8px; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background-color 0.2s ease; width: 100%; }

.mobile-menu .dropdown-menu.custom-dropdown .icon { font-size: 16px; padding-top: -10px; color: #2a3233; min-width: 24px; /* Ubah dari 20px ke 24px untuk lebih stabil */ text-align: center; /* Tambahan agar ikon terlihat rapi */ }

.mobile-menu .dropdown-menu.custom-dropdown a:hover { background-color: #f1f5f9; }

.mobile-menu .inline-cta-nav .cta-button { display: block; width: 100%; margin-top: 2px; padding: 7px 18px; font-size: 16px; background-color: #028d96; color: white; text-decoration: none; border-radius: 10px; font-weight: 300; box-sizing: border-box; transition: background-color 0.3s ease, transform 0.3s ease; line-height: 1.5; text-align: center; }

.mobile-menu .inline-cta-nav .cta-button:hover { background-color: #00a3b1; text-align: center; }

/* Hamburger */
.hamburger-wrapper { display: flex; flex-direction: column; gap: 1px; padding: 1rem; cursor: pointer; z-index: 1001; position: relative; }

.hamburger { width: 30px; height: 20px; display: none; flex-direction: column; justify-content: space-between; cursor: pointer; z-index: 1001; }

.hamburger span { height: 3px; width: 25px; background: #333; border-radius: 2px; transition: 0.4s; }

.hamburger:hover span { background-color: orange; }

.hamburger.active span { background-color: orange; }

@media (max-width: 1280px) { .navbar { padding: 0px 40px; height: 110px; position: fixed; width: 100%; top: 0px; z-index: 1000; }
  .container { max-width: 1350px; margin: 0 auto; padding: 0px 55px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }
  .logo { height: 40px; display: flex; align-items: center; gap: 30px; }
  .logo img { height: 48px; width: 179px; }
  .language-switcher { font-size: 16px; font-weight: 400; }
  /* Container dropdown */
  .dropdown { position: relative; display: inline-block; }
  /* Responsif: Tambahkan hamburger menu */
  .hamburger { display: none; }
  .mobile-menu { display: none; } }

/* small dekstop view */
@media (max-width: 1233px) { .navbar { height: 100px; position: fixed; top: 0; z-index: 1000; }
  .container { padding: 24px 30px 24px 40px; flex-wrap: nowrap; }
  .nav-links { display: none; }
  .language-switcher { display: none; }
  .mobile-menu { display: flex; padding-left: 80px; padding-right: 87px; }
  .mobile-menu .language-switcher { display: flex; }
  /* Hamburger */
  .hamburger-wrapper { display: flex; flex-direction: column; gap: 4px; padding: 1rem; cursor: pointer; z-index: 1001; position: relative; }
  .hamburger { width: 30px; height: 20px; display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; z-index: 1001; }
  /* Mobile Menu */
  .dropdown-menu { display: none; transition: all 0.3s ease; }
  .dropdown-menu.show { display: block; }
  .mobile-menu .dropdown1.active { color: #ff8607; /* Warna oranye untuk tulisan "Solusi" */ }
  .mobile-menu .dropdown1.active .icon { background-color: #f1f5f9; }
  /* Warna hover/aktif untuk item submenu */
  .mobile-menu .dropdown-menu.custom-dropdown a.active, .mobile-menu .dropdown-menu.custom-dropdown a.hover { background-color: #f1f5f9; } }

/* Desktop hover support (optional) */
@media (max-width: 812px) { .navbar { padding: 0px 40px; height: 100px; position: fixed; top: 0; z-index: 1000; }
  .container { padding: 24px 0px 24px 10px; flex-wrap: nowrap; }
  .nav-links { display: none; }
  .mobile-menu { display: flex; margin-top: 90px; padding-left: 50px; padding-right: 58px; }
  .mobile-menu .language-switcher { display: flex; }
  /* Hamburger */
  .hamburger-wrapper { display: flex; flex-direction: column; gap: 4px; padding: 1rem; cursor: pointer; z-index: 1001; position: relative; }
  .hamburger { width: 30px; height: 20px; display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; z-index: 1001; }
  /* Mobile Menu */
  .dropdown-menu { display: none; transition: all 0.3s ease; }
  .dropdown-menu.show { display: block; } }

@media (max-width: 481px) { .navbar { padding: 25px 10px 16px 24px; position: fixed; z-index: 1000; height: 75px; }
  .logo img { height: 32px; width: 119px; }
  .container { padding: 10px 10px; flex-wrap: nowrap; margin-top: -25px; }
  .mobile-menu { margin-top: 65px; width: 100vw; height: 297px; position: fixed; top: 0; left: 0; z-index: 9999; padding: 20px 60px; padding-right: 35px; padding-left: 35px; display: flex; flex-direction: column; gap: 16px; /* Transisi & efek hilang default */ opacity: 0; visibility: hidden; transform: translateY(-20px); transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s; }
  .mobile-menu .language-switcher { display: flex; }
  .mobile-menu .dropdown-menu.custom-dropdown { opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.3s ease; position: absolute; top: 100%; left: 0; border-radius: 13px; min-width: 320px; width: 30%; z-index: 999; /* Hapus display:flex atau pastikan column */ display: block; }
  .mobile-menu .dropdown-menu.custom-dropdown a { display: flex; align-items: center; gap: 14px; /* Ubah dari 10px ke 14px */ padding: 2px 63px; /* Ubah dari 5px 5px untuk ruang lebih */ padding-left: 10px; text-decoration: none; border-radius: 8px; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background-color 0.2s ease; width: 100%; }
  .mobile-menu .dropdown-menu.custom-dropdown .icon { font-size: 14px; margin-top: -5px; min-width: 24px; /* Ubah dari 20px ke 24px untuk lebih stabil */ text-align: center; /* Tambahan agar ikon terlihat rapi */ }
  .hamburger-wrapper { display: flex; flex-direction: column; gap: 4px; padding: 1rem; cursor: pointer; z-index: 1001; position: relative; }
  .hamburger { width: 30px; height: 20px; display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; z-index: 1001; } }

@media (max-width: 375px) { .mobile-menu .dropdown-menu.custom-dropdown { opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.3s ease; position: absolute; top: 100%; left: 0; border-radius: 13px; min-width: 280px; width: 30%; z-index: 999; /* Hapus display:flex atau pastikan column */ display: block; }
  .mobile-menu .dropdown-menu.custom-dropdown a { display: flex; align-items: center; gap: 14px; /* Ubah dari 10px ke 14px */ padding: 2px 63px; /* Ubah dari 5px 5px untuk ruang lebih */ padding-left: 10px; text-decoration: none; border-radius: 8px; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: background-color 0.2s ease; width: 100%; }
  .mobile-menu .dropdown-menu.custom-dropdown .icon { font-size: 14px; margin-top: -5px; min-width: 24px; /* Ubah dari 20px ke 24px untuk lebih stabil */ text-align: center; /* Tambahan agar ikon terlihat rapi */ } }

.hero-section { position: relative; width: 100%; height: 630px; overflow: hidden; }

.hero-image-container { position: relative; width: 100%; height: 630px; }

.hero-image { width: 100%; height: 630px; display: block; object-fit: cover; }

.hero-text-box.overlay { position: absolute; top: 95px; right: 0; bottom: 0; background: rgba(255, 255, 255, 0.6); padding: 40px; border-radius: 16px 0 0 16px; box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1); backdrop-filter: blur(5px); /* Blur latar belakang */ max-width: 622px; width: 100%; gap: 24px; height: 402px; /* atau 402px kalau kamu butuh tinggi tetap */ }

.hero-text-box h1 { margin-top: 0px; font-size: 40px; font-weight: 600; color: #2a3233; margin-bottom: 16px; line-height: 1.4; }

.hero-text-box p { font-size: 16px; color: #2a3233; line-height: 1.4; margin-bottom: 24px; font-weight: 400; letter-spacing: 0%; }

.inline-cta .cta-button { background-color: #ff8607; color: white; width: 222px; height: 48px; padding-top: 16px; padding-bottom: 16px; line-height: 100%; gap: 12px; text-align: center; border-radius: 8px; font-size: 16px; font-weight: 700; text-decoration: none; transition: background-color 0.3s ease; display: inline-block; font-family: "Lato", sans-serif !important; }

.inline-cta .cta-button:hover { background-color: #e06c15; }

@media (max-width: 1440px) { .hero-image-container { position: relative; width: 100%; height: 600px; } }

@media (max-width: 1280px) { .hero-image-container { position: relative; width: 100%; height: 533px; }
  .hero-image { width: 100%; height: 533px; display: block; object-fit: cover; }
  .hero-text-box.overlay { position: absolute; top: 100px; right: 0; bottom: 0; max-width: 650px; width: 650px; padding: 24px 33px 24px 33px; border-radius: 16px 0 0 16px; gap: 24px; height: 330px; /* atau 402px kalau kamu butuh tinggi tetap */ }
  .hero-text-box h1 { margin-top: 0px; font-size: 36px; font-weight: 600; margin-bottom: 16px; line-height: 1.4; }
  .hero-text-box p { font-size: 16px; line-height: 1.4; margin-bottom: 20px; font-weight: 400; letter-spacing: 0%; }
  .inline-cta .cta-button { padding: 16px 22px 16px 22px; line-height: 100%; border-radius: 8px; font-size: 16px; font-weight: 700; text-decoration: none; transition: background-color 0.3s ease; display: inline-block; font-family: "Lato", sans-serif !important; } }

@media (max-width: 1024px) { .hero-image-container { position: relative; width: 100%; height: 426px; }
  .hero-image { width: 100%; height: 426px; display: block; object-fit: cover; }
  .hero-text-box.overlay { position: absolute; top: 88px; right: 0; bottom: 0; padding: 30px; border-radius: 16px 0 0 16px; backdrop-filter: blur(5px); /* Blur latar belakang */ width: 480px; gap: 24px; height: 335px; }
  .hero-text-box h1 { margin-top: 10px; font-size: 28px; font-weight: 600; margin-bottom: 10px; line-height: 1.4; }
  .hero-text-box p { font-size: 14px; line-height: 1.4; margin-bottom: 20px; font-weight: 400; letter-spacing: 0%; }
  .inline-cta .cta-button { padding: 16px 24px 16px 24px; line-height: 100%; width: 202px; height: 46px; border-radius: 8px; font-size: 14px; font-weight: 700; text-decoration: none; transition: background-color 0.3s ease; display: inline-block; font-family: "Lato", sans-serif !important; } }

@media (max-width: 812px) { .hero-image-container { position: relative; /* Pastikan container punya konteks positioning */ width: 100%; height: 480px; overflow: hidden; }
  .hero-image { width: 100%; height: 338px; object-fit: cover; display: block; }
  .hero-text-box.overlay { position: absolute; flex-wrap: nowrap; top: 110px; left: 0; right: 0; bottom: 0; transform: none; margin: 0 auto; width: 75%; height: 276px; padding: 24px 20px; box-shadow: none; backdrop-filter: blur(10px); /* Blur latar belakang */ border-radius: 20px 20px 0 0; text-align: center; }
  .hero-text-box h1 { font-size: 28px; margin-bottom: 12px; letter-spacing: 3%; }
  .hero-text-box p { font-size: 14px; margin-bottom: 16px; }
  .inline-cta .cta-button { margin-top: 15px; display: inline-block; padding-top: 16px; padding-bottom: 16px; line-height: 100%; width: 202px; height: 48px; font-size: 14px; text-decoration: none; border-radius: 8px; font-weight: 700; transition: background-color 0.3s ease; font-family: "Lato", sans-serif !important; } }

@media (max-width: 475px) { .hero-section { position: relative; width: 100%; height: 633px; overflow: hidden; margin-top: -35px; }
  .hero-image-container { width: 100%; height: 510px; position: relative; overflow: hidden; margin-top: -10; }
  .hero-image { width: 100%; height: 220px; display: block; object-fit: cover; }
  .hero-text-box.overlay { text-align: center; position: absolute; top: 220px; left: 0%; transform: translateX(-50%); /* Geser balik setengah lebar box agar benar-benar tengah */ margin: 0; padding: 36px 40px 36px 40px; border-radius: 0px; width: 100%; /* agar menyesuaikan lebar layar */ height: 340px; }
  .hero-text-box h1 { font-size: 20px; /* Ukuran dikecilkan */ line-height: 1.4; font-weight: 600; margin-top: 0px; }
  .hero-text-box p { margin-top: 10px; margin-left: 0px; margin-right: 0px; font-size: 13px; font-weight: 400; margin-bottom: 10px; line-height: 1.4; letter-spacing: 0px; }
  .inline-cta .cta-button { margin-top: 15px; display: inline-block; padding-top: 16px; padding-bottom: 16px; line-height: 100%; width: 202px; height: 48px; font-size: 14px; text-decoration: none; border-radius: 8px; font-weight: 700; transition: background-color 0.3s ease; font-family: "Lato", sans-serif !important; } }

.services-section { padding: 100px 50px; padding-left: 100px; padding-right: 120px; background-color: #fff; text-align: center; margin-top: -20px; }

.services-container { display: grid; grid-template-columns: repeat(3, 1fr); /* ✅ Tiga kolom di desktop */ gap: 32px; margin-bottom: 40px; max-width: 1920px; margin-inline: auto; transition: all 0.3s ease; }

.service-item { background-color: white; border: 1px solid rgba(0, 0, 0, 0.1); border-radius: 16px; padding: 24px; }

.service-item img { height: 80px; margin-bottom: 30px; margin-top: 15px; }

.service-item h3 { font-size: 18px; font-weight: 600; margin-bottom: 10px; color: #4a4a4a; line-height: 100%; }

.service-item p { margin-top: 15px; font-size: 15px; font-weight: 400; color: #4a4a4a; line-height: 140%; }

.service-buttons span { font-weight: 600; color: #4a4a4a; font-size: 18px; font-family: "Museo", sans-serif !important; }

.btn-orange:hover { background-color: #e06c15; color: white; }

.btn-outline:hover { background-color: rgba(0, 112, 123, 0.963); color: white; }

.service-buttons { margin-top: 50px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 24px; font-weight: bold; }

.service-buttons span { font-weight: 600; color: #4a4a4a; font-size: 18px; font-family: "Museo", sans-serif !important; }

.btn-outline { padding-top: 16px; padding-bottom: 16px; text-align: center; width: 301px; height: 48px; line-height: 1; background-color: #028d96; color: white; border-radius: 8px; text-decoration: none; font-size: 16px; font-weight: 700; font-family: "Lato", sans-serif !important; transition: background-color 0.3s ease; }

.btn-orange { padding-top: 16px; padding-bottom: 16px; text-align: center; width: 200px; height: 48px; line-height: 1; background-color: #ff8607; color: white; border-radius: 8px; text-decoration: none; font-size: 16px; font-weight: 700; font-family: "Lato", sans-serif !important; transition: background-color 0.3s ease; }

@media (max-width: 1440px) { .services-section { padding: 100px 50px; padding-left: 102px; padding-right: 120px; text-align: center; margin-top: -60px; } }

@media (max-width: 1280px) { .services-container { grid-template-columns: repeat(3, 1fr); margin-top: -130px; }
  .services-section { padding-left: 96px; padding-right: 100px; text-align: center; margin-top: -20px; } }

@media (max-width: 1024px) { .services-container { grid-template-columns: repeat(3, 1fr); margin-top: -225px; }
  .services-section { padding-left: 80px; padding-right: 90px; text-align: center; margin-top: -20px; }
  .service-buttons { margin-top: 50px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 16px; font-weight: bold; }
  .service-item img { height: 72px; margin-bottom: 15px; }
  .service-item h3 { font-size: 18px; font-weight: 600; margin-bottom: 10px; line-height: 100%; }
  .service-item p { margin-top: 15px; font-size: 13px; font-weight: 400; line-height: 140%; }
  .service-buttons span { font-weight: 600; font-size: 14px; font-family: "Museo", sans-serif !important; }
  .btn-outline { padding: 16px 24px 16px 24px; border-radius: 8px; text-decoration: none; font-size: 14px; font-weight: 700; font-family: "Lato", sans-serif !important; }
  .btn-orange { padding: 16px 24px 16px 24px; border-radius: 8px; text-decoration: none; font-size: 14px; font-weight: 700; font-family: "Lato", sans-serif !important; } }

@media (max-width: 812px) { .services-container { grid-template-columns: repeat(3, 1fr); margin-top: -260px; }
  .services-section { padding: 100px 50px; padding-left: 50px; padding-right: 61px; text-align: center; margin-top: -20px; }
  .services-container { display: grid; grid-template-columns: repeat(3, 1fr); /* ✅ Tiga kolom di desktop */ gap: 32px; margin-bottom: 40px; max-width: 1920px; margin-inline: auto; transition: all 0.3s ease; }
  .service-item img { height: 72px; margin-bottom: 15px; }
  .service-item h3 { font-size: 18px; font-weight: 600; margin-bottom: 10px; line-height: 100%; }
  .service-item p { margin-top: 15px; font-size: 13px; font-weight: 400; line-height: 140%; }
  .service-buttons span { font-weight: 600; font-size: 14px; font-family: "Museo", sans-serif !important; }
  .btn-outline { padding: 16px 24px 16px 24px; border-radius: 8px; text-decoration: none; font-size: 14px; font-weight: 700; font-family: "Lato", sans-serif !important; }
  .btn-orange { padding: 16px 24px 16px 24px; border-radius: 8px; text-decoration: none; font-size: 14px; font-weight: 700; font-family: "Lato", sans-serif !important; }
  .service-buttons { margin-top: 0px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 16px; font-weight: bold; } }

@media (max-width: 700px) { .services-section { margin-top: -10px; }
  .services-container { grid-template-columns: repeat(2, 1fr); }
  .service-buttons { display: none; } }

@media (max-width: 520px) { .services-section { margin-top: 60px; }
  .services-container { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; gap: 20px; padding-inline: 16px; overflow-y: hidden; }
  .service-item { flex: 0 0 80%; scroll-snap-align: start; min-width: 260px; max-width: 80%; border-radius: 10px; padding: 16px; }
  .service-buttons { display: none; } }

.happy-clients { padding: 5px 0; /* Hilangkan padding samping */ background-color: #fff; font-family: Arial, sans-serif; width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ margin-top: -30px; }

.happy-clients-container { display: flex; align-items: flex-start; gap: 60px; width: 100%; flex-wrap: wrap; }

.clients-image { flex: 1; min-width: 300px; }

.clients-image img { width: 110%; height: 423px; object-fit: cover; }

.clients-content { flex: 1; padding-left: 80px; margin-top: 15px; }

.clients-content h2 { margin-top: 38px; font-size: 30px; color: #4a4a4a; margin-bottom: 5px; font-weight: 600; }

.clients-content p { padding-left: 15px; font-size: 16px; margin-bottom: 25px; color: #4a4a4a; }

.clients-box { background-color: white; border-left: 1px solid rgba(0, 0, 0, 0.1); }

.clients-logos { display: grid; grid-template-columns: repeat(4, 1fr); /* <--- ubah di sini */ gap: 16px; align-items: center; width: 100%; padding-right: 110px; }

.clients-logos img { width: 100%; max-height: 60px; object-fit: contain; filter: grayscale(100%); transition: filter 0.3s ease; }

.clients-logos img:hover { filter: grayscale(0%); }

@media (max-width: 1440px) { .happy-clients { padding: 5px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .clients-image { flex: 1; min-width: 300px; }
  .clients-image img { width: 100%; height: 348px; object-fit: cover; }
  .clients-content { flex: 1; padding-left: 10px; }
  .clients-content h2 { margin-top: 5px; font-size: 30px; margin-bottom: 10px; font-weight: 600; }
  .clients-content p { margin-bottom: 25px; font-size: 16px; font-weight: 400; }
  .clients-logos { display: grid; grid-template-columns: repeat(4, 1fr); /* <--- ubah di sini */ gap: 16px; align-items: center; padding-right: 110px; } }

@media (max-width: 1280px) { .happy-clients { padding: 5px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .clients-image { flex: 1; min-width: 300px; }
  .clients-image img { width: 105%; height: 351px; object-fit: cover; }
  .clients-content { flex: 1; padding-left: 30px; }
  .clients-content h2 { margin-top: 15px; font-size: 28px; color: #4a4a4a; margin-bottom: 10px; font-weight: 600; }
  .clients-content p { font-size: 14px; font-weight: 400; margin-bottom: 25px; color: #4a4a4a; padding-right: 70px; }
  .clients-box { padding-right: 40px; }
  .clients-logos { display: grid; grid-template-columns: repeat(4, 1fr); /* <--- ubah di sini */ gap: 16px; align-items: center; padding-right: 60px; } }

@media (max-width: 1024px) { .happy-clients { padding: 5px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .clients-image { flex: 1; min-width: 300px; }
  .clients-image img { width: 90%; height: 245px; object-fit: cover; }
  .clients-content { flex: 1; padding-left: 10px; margin-left: -80px; margin-top: -17px; }
  .clients-content h2 { font-size: 20px; color: #4a4a4a; margin-bottom: 10px; font-weight: 600; }
  .clients-content p { font-size: 12px; font-weight: 400; margin-bottom: 15px; color: #4a4a4a; }
  .clients-logos { display: grid; grid-template-columns: repeat(4, 1fr); /* <--- ubah di sini */ gap: 16px; align-items: center; max-width: 600px; padding-right: 40px; } }

@media (max-width: 812px) { .happy-clients { padding: 0 20px; width: 100%; overflow-x: hidden; margin-top: -100px; box-sizing: border-box; }
  .happy-clients-container { display: flex; flex-direction: column; align-items: center; gap: 40px; width: 100%; }
  .clients-image { display: none; }
  .clients-content { width: 100%; max-width: 812px; text-align: center; background-color: #fff; padding: 20px; box-sizing: border-box; margin: 0 auto; }
  .clients-content h2 { margin-top: 30px; font-size: 20px; color: #4a4a4a; margin-bottom: 10px; font-weight: 600; }
  .clients-box { width: 115%; }
  .clients-box p { font-size: 12px; font-weight: 400; margin-bottom: 25px; color: #4a4a4a; text-align: center; }
  .clients-logos { display: grid; grid-template-columns: repeat(4, 1fr); /* Lebih responsif di mobile */ gap: 12px; align-items: center; max-width: 100%; margin: 0 auto; justify-content: center; }
  .clients-logos img { width: 100%; max-height: 60px; object-fit: contain; filter: grayscale(100%); transition: filter 0.3s ease; } }

@media (max-width: 500px) { .happy-clients { padding-left: 20px; padding-right: 20px; width: 100%; overflow-x: hidden; margin-top: -130px; box-sizing: border-box; }
  .happy-clients-container { display: flex; flex-direction: column; align-items: center; gap: 40px; width: 100%; }
  .clients-image { display: none; }
  .clients-content { width: 110%; text-align: center; background-color: #fff; box-sizing: border-box; margin: 0 auto; justify-content: center; padding-right: 15px; padding-left: 20px; }
  .clients-content h2 { margin-top: 30px; font-size: 20px; color: #4a4a4a; margin-bottom: 10px; font-weight: 600; padding-right: 40px; }
  .clients-box p { font-size: 12px; font-weight: 400; margin-bottom: 25px; color: #4a4a4a; text-align: center; padding-right: 70px; }
  .clients-logos { display: grid; grid-template-columns: repeat(2, 1fr); /* Lebih responsif di mobile */ gap: 12px; align-items: center; max-width: 100%; margin: 0 auto; justify-content: center; }
  .clients-logos img { width: 100%; max-height: 60px; object-fit: contain; filter: grayscale(100%); transition: filter 0.3s ease; } }

/* Container utama untuk membungkus slider agar sejajar dengan konten lain */
.testimonial-wrapper { margin-top: 50px; background-color: #f5f9f9; /* background membentang penuh */ width: 100%; padding: 2px 0; }

.testimonial-section, .service-flow { max-width: 1100px; margin: 60px auto; padding: 0 20px; text-align: center; }

.testimonial-section h2, .testimonial-section, .service-flow { max-width: 1920px !important; padding-left: 105px; padding-right: 120px; margin: 60px auto; text-align: center; }

.testimonial-section h2, .service-flow h2 { font-size: 24px; margin-bottom: 30px; font-weight: 700; }

/* WRAPPER BARU untuk tombol di luar */
.testimonial-slider-wrapper { display: flex; align-items: center; justify-content: center; position: relative; gap: 20px; /* jarak antara button dan slider */ width: 100%; }

/* SLIDER */
.testimonial-slider { overflow: hidden; /* tetap hidden agar tidak ada scroll */ width: 100%; }

/* Cards di dalam slider */
.testimonial-cards { display: flex; transition: transform 0.5s ease; gap: 20px; }

/* Masing-masing card */
.testimonial-card { background: #fff; border-radius: 10px; padding: 20px; flex: 0 0 31.6%; /* 3 kartu per baris */ box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05); text-align: left; position: relative; display: flex; flex-direction: column; box-sizing: border-box; }

.testimonial-card .quote-icon { position: absolute; bottom: 15px; right: 30px; width: 30px; opacity: 1; /* Biar tidak terlalu mencolok */ }

.testimonial-card p { font-size: 15px; margin-bottom: 15px; color: #333; }

/* User info di bawah testimonial */
.testimonial-user { display: flex; align-items: center; gap: 10px; margin-top: auto; /* Tambahan penting! */ }

.testimonial-user strong { font-family: "Museo", sans-serif !important; }

.user-info { display: flex; flex-direction: column; }

.user-info strong { font-size: 16px; font-weight: 600; color: #111827; font-family: "Museo", sans-serif !important; }

.user-title { font-size: 14px; font-weight: 300; color: #6b7280; margin-top: 2px; font-family: "Lato", sans-serif !important; }

.testimonial-user img { width: 40px; height: 40px; border-radius: 60%; object-fit: cover; }

/* Buttons di luar slider */
.nav-button { background: #f5f5f5; color: #fa6432; border: none; font-size: 24px; padding: 10px; border-radius: 50%; cursor: pointer; position: relative; /* tidak absolute lagi */ transform: none; }

/* Dots indikator */
.testimonial-dots { margin-top: 20px; }

.testimonial-dots .dot { width: 10px; height: 10px; margin: 0 4px; background-color: #ddd; border-radius: 50%; display: inline-block; }

.testimonial-dots .dot.active { background-color: #fa6432; }

@media (max-width: 1280px) { .testimonial-section h2, .testimonial-section, .service-flow { max-width: 1280px !important; padding-left: 100px; padding-right: 110px; margin: 60px auto; text-align: center; } }

@media (max-width: 1024px) { .testimonial-section h2, .testimonial-section, .service-flow { max-width: 1024px !important; padding-left: 90px; padding-right: 100px; margin: 60px auto; text-align: center; }
  .testimonial-card { flex: 0 0 50%; /* 2 kartu per baris di tablet */ height: 380px; } }

@media (max-width: 768px) { .testimonial-card { flex: 0 0 100%; /* 1 kartu di mobile */ height: 220px; }
  .testimonial-user img { display: none; }
  .testimonial-section h2, .testimonial-section, .service-flow { max-width: 1100px; padding: 0 40px; padding-left: 50px; padding-right: 63px; margin: 60px auto; text-align: center; } }

@media (max-width: 465px) { .testimonial-card { flex: 0 0 100%; /* 1 kartu di mobile */ height: 330px; }
  .testimonial-section h2, .testimonial-section, .service-flow { max-width: 1100px; padding: 0 40px; margin: 60px auto; text-align: center; }
  .testimonial-card .quote-icon { display: none; } }

@media (max-width: 465px) { .testimonial-card { flex: 0 0 100%; /* 1 kartu di mobile */ height: 390px; }
  .testimonial-section h2, .testimonial-section, .service-flow { max-width: 1100px; padding: 0 40px; margin: 60px auto; text-align: center; }
  .testimonial-card .quote-icon { display: none; }
  .testimonial-user img { display: none; } }

.service-flow { background-color: #fff; padding: 60px 20px; font-family: "Lato", sans-serif; text-align: center; }

.service-container { max-width: 1920px; margin: 0 auto; padding-right: 80px; padding-left: 80px; }

.service-flow h2 { font-size: 30px; font-weight: 600; line-height: 1; margin-bottom: 60px; color: #27272a; }

.steps-wrapper { overflow-y: hidden; position: relative; }

.steps { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; position: relative; gap: 30px; }

.step { flex: 1; min-width: 200px; max-width: 220px; position: relative; }

.step .icon { width: 80px; height: 80px; border: 1px solid rgba(194, 194, 194, 0.51); border-radius: 50%; padding: 20px; padding-top: 10px; padding-bottom: 10px; margin: 0 auto 20px; display: flex; align-items: center; justify-content: center; background-color: #fff; object-fit: contain; box-sizing: border-box; }

.step h3 { margin-top: 30px; font-size: 18px; font-weight: 400; margin-bottom: 8px; color: #18181b; line-height: 1; }

.step p { font-size: 15px; font-weight: 400; line-height: 1; color: #71717a; line-height: 1.4; }

/* Arrow Style */
.step .arrow { position: absolute; top: 45px; right: -145px; width: 55%; height: auto; padding-right: 10px; padding-left: 10px; }

.step:last-child .arrow { display: none; }

.mobile-service-slider { display: none; /* default: sembunyi */ }

@media (max-width: 1440px) { .step .arrow { right: -100px; width: 55%; } }

@media (max-width: 1280px) { .service-container { max-width: 1920px; margin: 0 auto; padding-right: 60px; padding-left: 70px; }
  .step .arrow { right: -8 0px; width: 55%; } }

@media (max-width: 1139px) { .service-container { max-width: 1920px; margin: 0 auto; padding-right: 70px; padding-left: 60px; }
  .step .arrow { right: -70px; width: 55%; }
  .step h3 { margin-top: 30px; font-size: 16px; font-weight: 400; margin-bottom: 8px; line-height: 1; }
  .step p { font-size: 14px; font-weight: 400; line-height: 1; line-height: 1.4; }
  .step { flex: 1; min-width: 180px; position: relative; } }

@media (max-width: 1029px) { .service-container { max-width: 1030px; margin: 0 auto; padding-right: 60px; padding-left: 50px; }
  .step .arrow { right: -60px; width: 55%; }
  .step h3 { font-size: 16px; }
  .step p { font-size: 14px; }
  .step { flex: 1; min-width: 130px; position: relative; } }

@media (max-width: 812px) { .service-container { max-width: 1019px; margin: 0 auto; padding-right: 20px; padding-left: 20px; }
  .service-flow h2 { font-size: 20px; }
  .step .arrow { right: -40px; width: 50%; }
  .step h3 { font-size: 14px; }
  .step p { font-size: 13px; }
  .steps { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; position: relative; gap: 10px; }
  .step img { width: 70px; height: 70px; }
  .step { flex: 1; min-width: 100px; position: relative; } }

@media (max-width: 600px) { .mobile-service-slider { display: block; padding: 40px 20px; background: #fff; text-align: center; overflow: hidden; height: 100; }
  .mobile-service-slider h2 { font-size: 22px; font-weight: 700; margin-bottom: 30px; }
  .mobile-slider { display: flex; transition: transform 0.5s ease-in-out; width: 100%; }
  .mobile-slide { min-width: 100%; box-sizing: border-box; padding: 20px; }
  .mobile-slide img { width: 70px; margin-bottom: 15px; }
  .mobile-slide h3 { font-size: 18px; margin-bottom: 10px; }
  .mobile-slide p { font-size: 14px; color: #555; }
  .service-flow { display: none; }
  .mobile-dots { display: flex; justify-content: center; margin-top: 15px; gap: 8px; }
  .mobile-dots .dot { width: 24px; height: 24px; border-radius: 50%; background-color: #fbe4d1; color: #f26522; font-size: 12px; font-weight: bold; display: flex; justify-content: center; align-items: center; transition: background-color 0.3s; }
  .mobile-dots .dot.active { background-color: #f26522; color: white; } }

.footer { background-color: #2e3737; color: #e0e0e0; padding: 40px 80px 20px; padding-left: 120px; padding-right: 120px; font-family: "Lato", sans-serif; }

.address-text { max-width: 700px; /* lebar ideal untuk dua baris */ line-height: 1.6; color: #fff; /* sesuaikan warna dengan tema */ font-size: 12px; }

.footer-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; margin-top: 10px; }

.footer-left, .footer-center, .footer-right { flex: 1; min-width: 300px; }

.footer-left strong { display: flex; align-items: center; gap: 10px; font-size: 16px; font-weight: 700; }

.footer-center { margin-left: 100px; }

.footer-left p, .footer-center p { margin: 5px 25px; margin-right: -190px; font-size: 15px; color: white; font-weight: 400; line-height: 1.4; }

.footer-center p { margin-left: 140px; }

.company-info { display: flex; align-items: center; /* agar vertikal sejajar */ gap: 8px; /* jarak antara ikon dan teks */ margin-bottom: 8px; }

.company-info strong { font-size: 16px; color: white; font-weight: 700; }

.icon1 { width: 16px; height: 16px; fill: #fff; /* atau warna lain sesuai desain */ gap: 10px; }

.icon-social { width: 30px; height: 20px; fill: #1f7d82; }

.social-icons { display: flex; gap: 12px; justify-content: flex-end; }

.social-circle { background-color: white; border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; transition: transform 0.2s ease; }

.social-circle:hover { transform: scale(1.1); }

hr { border: none; border-top: 2px solid #606464; margin: 30px 0 15px; }

.footer-bottom { margin-top: 35px; text-align: center; font-size: 16px; color: #bbb; }

@media (max-width: 880px) { .footer { padding: 40px 30px 20px; font-family: "Arial", sans-serif; }
  .address-text { max-width: 700px; /* lebar ideal untuk dua baris */ line-height: 1.6; font-size: 12px; }
  .footer-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; margin-top: 10px; }
  .footer-left, .footer-center, .footer-right { flex: 1; min-width: 300px; }
  .footer-left strong { display: flex; align-items: center; gap: 10px; font-size: 14px; }
  .footer-left p { padding-right: 300px; }
  .footer-center { margin-left: -100px; }
  .footer-right { padding-right: 20px; }
  .footer-left p, .footer-center p { margin: 5px 25px; margin-right: -190px; font-size: 12px; font-weight: 400; line-height: 1.4; }
  .footer-center p { margin-left: 140px; }
  .company-info { display: flex; align-items: center; /* agar vertikal sejajar */ gap: 8px; /* jarak antara ikon dan teks */ margin-bottom: 8px; }
  .company-info strong { font-size: 15px; font-weight: 700; }
  .icon1 { width: 16px; height: 16px; gap: 10px; }
  .icon-social { width: 30px; height: 20px; }
  .social-icons { display: flex; gap: 12px; justify-content: flex-end; }
  .social-circle { border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; transition: transform 0.2s ease; }
  .social-circle:hover { transform: scale(1.1); }
  hr { border: none; margin: 30px 0 15px; }
  .footer-bottom { margin-top: 35px; text-align: center; font-size: 13px; } }

@media (max-width: 579px) { .footer { padding: 40px 30px 20px; font-family: "Arial", sans-serif; }
  .address-text { max-width: 700px; /* lebar ideal untuk dua baris */ line-height: 1.6; font-size: 12px; }
  .footer-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; margin-top: 10px; }
  .footer-left, .footer-center, .footer-right { flex: 1; min-width: 300px; }
  .footer-left strong { display: flex; align-items: center; gap: 10px; font-size: 14px; }
  .footer-left p { padding-right: 350px; }
  .footer-center { margin-left: -200px; }
  .footer-right { padding-right: 20px; }
  .footer-left p, .footer-center p { margin: 5px 25px; margin-right: -190px; font-size: 12px; font-weight: 400; line-height: 1.4; }
  .footer-center p { margin-left: 140px; }
  .company-info { display: flex; align-items: center; /* agar vertikal sejajar */ gap: 8px; /* jarak antara ikon dan teks */ margin-bottom: 8px; }
  .company-info strong { font-size: 15px; font-weight: 700; }
  .icon1 { width: 16px; height: 16px; gap: 10px; }
  .icon-social { width: 30px; height: 20px; }
  .social-icons { display: flex; gap: 12px; justify-content: flex-end; }
  .social-circle { border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; transition: transform 0.2s ease; }
  .social-circle:hover { transform: scale(1.1); }
  hr { border: none; margin: 30px 0 15px; }
  .footer-bottom { margin-top: 35px; text-align: center; font-size: 13px; } }

@media (max-width: 480px) { .footer { padding: 40px 30px 20px; font-family: "Arial", sans-serif; }
  .address-text { max-width: 700px; /* lebar ideal untuk dua baris */ line-height: 1.6; font-size: 12px; }
  .footer-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; margin-top: 10px; }
  .footer-left, .footer-center, .footer-right { flex: 1; min-width: 300px; display: none; }
  .footer-left strong { display: flex; align-items: center; gap: 10px; font-size: 14px; }
  .footer-left p { padding-right: 350px; }
  .footer-center { margin-left: -200px; }
  .footer-right { padding-right: 20px; }
  .footer-left p, .footer-center p { margin: 5px 25px; margin-right: -190px; font-size: 12px; font-weight: 400; line-height: 1.4; }
  .footer-center p { margin-left: 140px; }
  .company-info { display: flex; align-items: center; /* agar vertikal sejajar */ gap: 8px; /* jarak antara ikon dan teks */ margin-bottom: 8px; }
  .company-info strong { font-size: 15px; font-weight: 700; }
  .icon1 { width: 16px; height: 16px; gap: 10px; }
  .icon-social { width: 30px; height: 20px; }
  .social-icons { display: flex; gap: 12px; justify-content: flex-end; }
  .social-circle { border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; transition: transform 0.2s ease; }
  .social-circle:hover { transform: scale(1.1); }
  hr { border: none; margin: 30px 0 15px; display: none; }
  .footer-bottom { margin-top: -10px; text-align: center; font-size: 14px; } }

/* Payroll */
.payroll-section { display: flex; height: 444px; }

.payroll-left { flex: 1; /* Lebih kecil dari kanan */ background-color: #f1f6f6; color: white; padding-top: 40px; padding-bottom: 40px; padding-left: 50px; padding-right: 40px; display: flex; flex-direction: column; justify-content: center; }

.payroll-left h2 { color: #2a3233; margin-left: 50px; margin-right: 30px; font-size: 32px; font-weight: 600; margin-bottom: 20px; line-height: 1.4; }

.payroll-left p { margin-left: 50px; margin-right: 30px; font-size: 16px; font-weight: 400; color: #2a3233; margin-bottom: 25px; line-height: 1.6; letter-spacing: 0px; }

.consult-btn { display: inline-block; align-self: flex-start; /* <<< Tambahan ini supaya tombol "ngepas" di kiri */ background-color: #ff8607; width: 222px; height: 48px; color: white; margin-left: 50px; padding-top: 16px; padding-bottom: 16px; text-align: center; line-height: 100%; font-size: 16px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; font-family: "Lato", sans-serif !important; }

.consult-btn:hover { background-color: #e06c15; /* warna sedikit lebih gelap saat hover */ color: white; }

.payroll-right { flex: 1.3; /* Lebih besar */ }

.payroll-right img { width: 100%; height: 444px; object-fit: cover; }

@media (max-width: 1440px) { .payroll-section { display: flex; height: 402px; }
  .payroll-left { flex: 1; /* Lebih kecil dari kanan */ padding-top: 40px; padding-bottom: 40px; padding-left: 50px; padding-right: 30px; display: flex; flex-direction: column; justify-content: center; }
  .payroll-left h2 { margin-left: 50px; margin-right: 30px; font-size: 32px; font-weight: 600; margin-bottom: 20px; line-height: 1.4; }
  .payroll-left p { margin-left: 50px; margin-right: 30px; font-size: 16px; font-weight: 400; margin-bottom: 25px; line-height: 1.6; letter-spacing: 0px; }
  .payroll-right img { width: 100%; height: 402px; object-fit: cover; } }

@media (max-width: 1280px) { .payroll-section { display: flex; height: 356px; }
  .payroll-left { flex: 1; /* Lebih kecil dari kanan */ padding-top: 40px; padding-bottom: 40px; padding-left: 45px; padding-right: 30px; display: flex; flex-direction: column; justify-content: center; }
  .payroll-left h2 { margin-left: 50px; margin-right: 30px; font-size: 30px; font-weight: 600; margin-bottom: 20px; line-height: 1.4; }
  .payroll-left p { margin-left: 50px; margin-right: 30px; font-size: 14px; font-weight: 400; margin-bottom: 25px; line-height: 1.4; letter-spacing: 0px; }
  .payroll-right img { width: 100%; height: 356px; object-fit: cover; } }

@media (max-width: 1024px) { .payroll-section { display: flex; height: 314px; }
  .payroll-left { flex: 1; /* Lebih kecil dari kanan */ padding-top: 40px; padding-bottom: 40px; padding-left: 30px; padding-right: 10px; display: flex; flex-direction: column; justify-content: center; }
  .payroll-left h2 { margin-left: 50px; margin-right: 30px; font-size: 24px; font-weight: 600; margin-bottom: 20px; line-height: 1.4; }
  .payroll-left p { margin-left: 50px; margin-right: 30px; font-size: 14px; font-weight: 400; margin-bottom: 25px; line-height: 1.4; letter-spacing: 0px; }
  .consult-btn { display: inline-block; align-self: flex-start; /* <<< Tambahan ini supaya tombol "ngepas" di kiri */ width: 200px; height: 46px; margin-left: 50px; padding-top: 16px; padding-bottom: 16px; text-align: center; line-height: 100%; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; font-family: "Lato", sans-serif !important; }
  .payroll-right img { width: 100%; height: 314px; object-fit: cover; }
  .payroll-right { flex: 1.2; /* Lebih besar */ } }

/* Responsive */
@media (max-width: 885px) { .payroll-section { flex-direction: column-reverse; align-items: center; /* opsional: biar tengah */ height: 628px; }
  .payroll-left, .payroll-right { width: 100%; }
  .payroll-right img { width: 100%; height: 366px; margin-top: -25px; flex: 1; }
  .payroll-left { justify-content: center; padding: 10px 10px; }
  .payroll-left h2, .payroll-left p, .consult-btn { text-align: center; }
  .payroll-left h2 { font-size: 20px; }
  .consult-btn { font-size: 14px; margin: 0 auto; } }

/* Responsive */
@media (max-width: 420px) { .payroll-section { flex-direction: column-reverse; align-items: center; /* opsional: biar tengah */ height: 470px; }
  .payroll-left, .payroll-right { width: 100%; max-width: 100%; }
  .payroll-right img { width: 100%; height: 224px; margin-top: -10px; }
  .payroll-left { justify-content: center; padding: 10px 10px; height: 330px; display: flex-start; }
  .payroll-left h2, .payroll-left p, .consult-btn { text-align: center; }
  .consult-btn { margin: 0 auto; } }

@media (max-width: 375px) { .payroll-section { flex-direction: column-reverse; align-items: center; /* opsional: biar tengah */ margin-top: -30px; }
  .payroll-left, .payroll-right { width: 100%; max-width: 100%; }
  .payroll-right img { width: 100%; height: 210px; }
  .payroll-left h2, .payroll-left p, .consult-btn { text-align: center; }
  .consult-btn { margin: 0 auto; } }

.payroll-features { text-align: center; padding: 20px; background-color: #ffffff; padding-left: 80px; padding-right: 100px; margin-top: 40px; }

.features-header h2 { font-size: 30px; font-weight: 600; line-height: 1.4; margin: 15px 0 50px; color: #2a3233; }

.features-list { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; padding-left: 20px; padding-right: 20px; }

.feature-item { background-color: #ffffff; text-align: center; /* Default mobile: 1 kolom */ flex: 0 0 100%; max-width: 100%; padding: 24px; border: 1px solid rgba(0, 0, 0, 0.1); border-radius: 16px; }

.feature-icon { width: 100%; height: 112px; margin: 0 auto 30px; overflow: hidden; display: flex; align-items: center; justify-content: center; }

.feature-icon img { width: 75%; height: 75%; object-fit: contain; }

.feature-item h3 { margin-top: -5px; font-size: 18px; font-weight: 600; margin-bottom: 12px; color: #4a4a4a; }

.feature-item p { font-size: 15px; line-height: 1.8; color: #4a4a4a; font-weight: 400; }

@media (max-width: 1280px) { .payroll-features { padding: 20px; padding-left: 75px; padding-right: 80px; }
  .features-header h2 { font-size: 28px; }
  .feature-item h3 { font-size: 16px; }
  .feature-item p { font-size: 13px; } }

@media (max-width: 1024px) { .payroll-features { padding: 20px; padding-left: 60px; padding-right: 70px; }
  .features-header h2 { font-size: 20px; }
  .feature-icon img { width: 60%; height: 60%; object-fit: contain; }
  .feature-item h3 { font-size: 14px; }
  .feature-item p { font-size: 12px; } }

@media (max-width: 812px) { .payroll-features { padding: 20px; padding-left: 30px; padding-right: 40px; }
  .features-header h2 { font-size: 20px; }
  .feature-icon img { width: 60%; height: 60%; object-fit: contain; }
  .feature-item h3 { font-size: 14px; }
  .feature-item p { font-size: 12px; } }

/* ✅ Responsif: mulai dari 376px ke atas jadi 3 kolom */
@media (min-width: 690px) { .feature-item { flex: 0 0 calc((100% - 48px) / 3); max-width: calc((100% - 48px) / 3); } }

.layanan-section { padding: 10px 20px; background-color: #fff; text-align: center; margin-top: 20px; }

.layanan-text h2 { font-size: 30px; font-weight: 600; margin-bottom: 10px; margin-left: -3px; color: #4a4a4a; }

.layanan-content { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; text-align: left; }

.layanan-text { flex: 0.85; min-width: 200px; padding: 0 50px; padding-left: 80px; margin-bottom: 10px; color: #4a4a4a; }

.layanan-list { background-color: white; border-left: 1px solid rgba(0, 0, 0, 0.1); width: 100%; gap: 24px; }

.layanan-item { margin-right: 50px; padding-left: 20px; padding-top: 10px; }

.layanan-item h3 { font-size: 18px; font-weight: 700; color: #4a4a4a; }

.layanan-item ul { padding-left: 1.5rem; margin-top: 0.5rem; margin-bottom: 1rem; list-style-type: disc; }

.layanan-item li { margin-bottom: 0.15rem; line-height: 1.4; font-size: 15px; font-weight: 400; color: #4a4a4a; font-family: "lato", sans-serif; }

.layanan-section { padding: 20px 0; /* Hilangkan padding samping */ background-color: #fff; width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }

.layanan-image { flex: 1.3; width: 100%; }

.layanan-image img { width: 100%; height: 588px; object-fit: cover; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }

.consult-btn1 { display: inline-block; height: 48px; width: 222px; background-color: #028d96; color: white; padding-top: 16px; padding-bottom: 16px; font-size: 16px; font-weight: 700; text-decoration: none; line-height: 100%; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; text-align: center; margin-left: 20px; font-family: "Lato", sans-serif !important; }

.consult-btn1:hover { background-color: rgba(0, 112, 123, 0.963); color: white; }

@media (max-width: 1440px) { .layanan-text { flex: 1; min-width: 200px; padding: 0 50px; margin-left: 90px; margin-bottom: 10px; }
  .layanan-image img { width: 110%; height: 588px; }
  .layanan-section { padding: 20px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ } }

@media (max-width: 1280px) { .layanan-text { flex: 1; min-width: 200px; padding: 0 50px; margin-left: 190px; }
  .layanan-section { padding: 20px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .layanan-text h2 { font-size: 28px; font-weight: 600; margin-top: 20px; margin-left: -3px; }
  .layanan-item h3 { font-size: 16px; font-weight: 700; }
  .layanan-item li { margin-bottom: 0.15rem; line-height: 1.4; font-size: 13px; font-weight: 400; }
  .layanan-image img { width: 130%; height: 536px; } }

@media (max-width: 1024px) { .layanan-text { flex: 1; min-width: 200px; padding: 0 50px; margin-left: 50px; }
  .layanan-section { padding: 20px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .layanan-text h2 { font-size: 20px; font-weight: 600; margin-top: 10px; margin-left: -3px; }
  .layanan-item h3 { font-size: 14px; font-weight: 700; }
  .layanan-item li { margin-bottom: 0.15rem; line-height: 1.4; font-size: 12px; font-weight: 400; }
  .layanan-image img { width: 112%; height: 450px; } }

@media (max-width: 812px) { .layanan-text { flex: 1; min-width: 300px; padding: 0 50px; margin-left: 5px; }
  .layanan-section { padding: 20px 0; /* Hilangkan padding samping */ width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .layanan-text h2 { font-size: 20px; font-weight: 600; margin-top: 15px; margin-left: -3px; }
  .layanan-item h3 { font-size: 14px; font-weight: 700; }
  .layanan-image img { margin-left: 50px; width: 98%; height: 250px; object-fit: cover; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }
  .consult-btn1 { font-size: 14px; } }

@media (max-width: 675px) { .layanan-text h2 { font-size: 20px; font-weight: 600; margin-top: 15px; margin-left: -3px; margin-bottom: 10px; }
  .layanan-content { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; text-align: left; }
  .layanan-text { flex: 1; min-width: 200px; padding: 0 40px; margin-left: 20px; }
  .layanan-list { width: 100%; gap: 24px; }
  .layanan-item { margin-bottom: 10px; margin-right: 50px; padding-left: 20px; }
  .layanan-item h3 { font-size: 14px; font-weight: 700; margin-bottom: 10px; margin-top: 10px; }
  .layanan-item p { font-size: 12px; font-weight: 400; line-height: 1.4; }
  .layanan-section { padding: 20px 0; /* Hilangkan padding samping */ font-family: Arial, sans-serif; width: 100vw; /* Agar menempel kiri kanan penuh */ overflow-x: hidden; /* Hindari scroll horizontal */ }
  .layanan-image { display: none; }
  .consult-btn1 { font-size: 14px; } }

.recruit-section { padding: 0 auto; background-color: #fff; }

.recruit-content { display: flex; align-items: stretch; justify-content: center; flex-wrap: wrap; }

.recruit-image { flex: 0.65; min-width: 300px; display: flex; }

.recruit-image img { width: 100%; height: 444px; object-fit: cover; }

.recruit-text { flex: 0.45; /* 40% untuk teks */ background-color: #f1f6f6; color: #2a3233; padding-top: 40px; padding-right: 120px; padding-bottom: 40px; padding-left: 80px; display: flex; flex-direction: column; justify-content: center; }

.recruit-text h2 { font-size: 32px; font-weight: 600; margin-bottom: 20px; line-height: 140%; }

.recruit-text p { font-size: 16px; font-weight: 400; margin-bottom: 30px; line-height: 140%; letter-spacing: 0px; }

.recruit-btn { width: 222px; height: 48px; padding-top: 16px; padding-bottom: 16px; line-height: 1; text-align: center; display: inline-block; align-self: flex-start; /* <<< Tambahan ini supaya tombol "ngepas" di kiri */ background-color: #ff8607; color: white; font-size: 16px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; margin-top: -5px; font-family: "Lato", sans-serif !important; }

.recruit-btn:hover { background-color: #e06c15; color: white; }

@media (max-width: 1280px) { .recruit-image { flex: 0.53; min-width: 300px; display: flex; }
  .recruit-image img { width: 100%; height: 334px; object-fit: cover; }
  .recruit-text { flex: 0.47; /* 40% untuk teks */ padding-top: 40px; padding-right: 120px; padding-bottom: 40px; padding-left: 80px; display: flex; flex-direction: column; justify-content: center; height: 334px; }
  .recruit-text h2 { font-size: 30px; font-weight: 600; margin-bottom: 20px; line-height: 140%; }
  .recruit-text p { font-size: 14px; font-weight: 400; margin-bottom: 30px; line-height: 140%; letter-spacing: 0px; } }

@media (max-width: 1024px) { .recruit-image { flex: 0.65; /* 60% untuk gambar */ min-width: 300px; display: flex; }
  .recruit-image img { width: 100%; height: 296px; object-fit: cover; }
  .recruit-text { flex: 0.45; /* 40% untuk teks */ padding: 40px 80px 40px 50px; display: flex; flex-direction: column; justify-content: center; height: 296px; }
  .recruit-text h2 { font-size: 20px; font-weight: 600; margin-bottom: 20px; line-height: 140%; }
  .recruit-text p { font-size: 14px; font-weight: 400; margin-bottom: 30px; line-height: 140%; letter-spacing: 0px; }
  .recruit-btn { font-size: 14px; } }

@media (max-width: 812px) { .recruit-content { display: flex; flex-direction: column; /* Gambar di atas, teks di bawah */ align-items: stretch; }
  .recruit-image { width: 100%; min-width: unset; /* Reset kalau sebelumnya ada */ display: flex; }
  .recruit-image img { width: 100%; height: 442px; /* Ubah supaya tinggi menyesuaikan */ object-fit: cover; }
  .recruit-text { text-align: center; width: 100%; padding: 30px 20px; padding-left: 60px; padding-right: 60px; display: flex; flex-direction: column; justify-content: center; height: auto; /* Lepas fix height agar fleksibel */ }
  .recruit-text h2 { font-size: 20px; font-weight: 600; margin-bottom: 20px; line-height: 140%; }
  .recruit-text p { font-size: 14px; font-weight: 400; margin-bottom: 30px; line-height: 140%; letter-spacing: 0px; }
  .recruit-btn { font-size: 14px; align-self: center; } }

@media (max-width: 450px) { .recruit-content { display: flex; flex-direction: column; /* Gambar di atas, teks di bawah */ align-items: stretch; }
  .recruit-image { width: 100%; min-width: unset; /* Reset kalau sebelumnya ada */ display: flex; margin-top: -30px; }
  .recruit-image img { width: 100%; height: 204px; /* Ubah supaya tinggi menyesuaikan */ object-fit: cover; }
  .recruit-text { text-align: center; width: 100%; padding: 30px 20px; padding-left: 40px; padding-right: 40px; display: flex; flex-direction: column; justify-content: center; height: auto; /* Lepas fix height agar fleksibel */ }
  .recruit-text h2 { font-size: 20px; font-weight: 600; margin-bottom: 20px; line-height: 140%; }
  .recruit-text p { font-size: 14px; font-weight: 400; margin-bottom: 30px; line-height: 140%; letter-spacing: 0px; }
  .recruit-btn { align-self: center; padding: 16px 24px; font-size: 14px; font-weight: 700; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; margin-top: -5px; } }

.layanan1-kami { padding: 50px 0px 20px 70px; padding-left: 100px; background-color: #fff; }

.layanan1-title { text-align: left; font-size: 30px; font-weight: 600; margin-top: 10px; color: #4a4a4a; }

.layanan1-content { display: flex; flex-wrap: nowrap; /* ubah jadi nowrap agar tidak turun ke bawah */ gap: 16px; /* beri jarak antar kolom */ justify-content: space-between; align-items: flex-start; }

.layanan1-list { padding-top: 10px; padding-right: 20px; padding-left: 20px; flex: 0.65; display: flex; flex-direction: column; flex-wrap: wrap; gap: 8px; background-color: white; border-left: 1px solid rgba(0, 0, 0, 0.1); }

.layanan1-image { flex: 0.35; display: flex; justify-content: flex-end; /* dorong gambar ke kanan */ align-items: flex-start; }

.layanan1-image img { width: 517px; height: 926px; margin-top: -40px; display: block; }

.layanan1-btn { display: block; /* atau flex */ width: 222px; height: 48px; padding-top: 16px; padding-bottom: 16px; line-height: 1; background-color: #028d96; color: white; font-size: 16px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; text-align: center; font-family: "Lato", sans-serif !important; }

.layanan1-btn:hover { background-color: #00a3b1; color: white; }

.layanan1-item h3 { font-size: 18px; font-weight: 700; margin-bottom: 8px; color: #4a4a4a; }

.layanan1-item p { font-size: 15px; font-weight: 400; line-height: 1.2; color: #4a4a4a; }

@media (max-width: 1280px) { .layanan1-kami { padding: 50px 0px 20px 70px; padding-left: 100px; }
  .layanan1-image img { width: 517px; height: 1130px; margin-top: -40px; display: block; } }

@media (max-width: 1024px) { .layanan1-kami { padding: 50px 0px 20px 70px; background-color: #fff; }
  .layanan1-title { text-align: left; font-size: 20px; font-weight: 600; margin-top: 10px; margin-left: 6px; }
  .layanan1-content { display: flex; flex-wrap: nowrap; /* ubah jadi nowrap agar tidak turun ke bawah */ gap: 16px; /* beri jarak antar kolom */ justify-content: space-between; align-items: flex-start; }
  .layanan1-list { padding-top: 10px; padding-right: 20px; padding-left: 20px; margin-right: -380px; flex: 0.65; display: flex; flex-direction: column; flex-wrap: wrap; gap: 5px; background-color: white; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); }
  .layanan1-image { display: none; }
  .layanan1-btn { display: block; /* atau flex */ width: fit-content; margin-left: -2px; /* auto kiri-kanan = center */ margin-top: 0px; /* auto kiri-kanan = center */ background-color: #028d96; color: white; padding: 13px 18px; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; text-align: left; }
  .layanan1-btn:hover { background-color: #00a3b1; color: white; }
  .layanan1-item h3 { font-size: 14px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; }
  .layanan1-item p { font-size: 12px; font-weight: 400; line-height: 1.2; color: #333; } }

@media (max-width: 1024px) { .layanan1-kami { padding: 50px 0px 20px 70px; background-color: #fff; }
  .layanan1-title { text-align: left; font-size: 20px; font-weight: 600; margin-top: 10px; margin-left: 6px; }
  .layanan1-content { display: flex; flex-wrap: nowrap; /* ubah jadi nowrap agar tidak turun ke bawah */ gap: 16px; /* beri jarak antar kolom */ justify-content: space-between; align-items: flex-start; }
  .layanan1-list { padding-top: 10px; padding-right: 30px; padding-left: 20px; margin-right: -300px; flex: 0.65; display: flex; flex-direction: column; flex-wrap: wrap; gap: 5px; background-color: white; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); }
  .layanan1-image { display: none; }
  .layanan1-btn { display: block; /* atau flex */ width: fit-content; margin-left: -2px; /* auto kiri-kanan = center */ margin-top: 0px; /* auto kiri-kanan = center */ background-color: #028d96; color: white; padding: 13px 18px; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; text-align: left; }
  .layanan1-btn:hover { background-color: #00a3b1; color: white; }
  .layanan1-item h3 { font-size: 14px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; }
  .layanan1-item p { font-size: 12px; font-weight: 400; line-height: 1.2; color: #333; } }

@media (max-width: 660px) { .layanan1-kami { padding: 50px 0px 20px 70px; background-color: #fff; }
  .layanan1-title { text-align: left; font-size: 20px; font-weight: 600; margin-top: 10px; margin-left: -25px; }
  .layanan1-content { display: flex; flex-wrap: nowrap; /* ubah jadi nowrap agar tidak turun ke bawah */ gap: 16px; /* beri jarak antar kolom */ justify-content: space-between; align-items: flex-start; }
  .layanan1-list { padding-top: 10px; padding-right: 30px; margin-left: -35px; margin-right: -300px; flex: 0.65; display: flex; flex-direction: column; flex-wrap: wrap; gap: 5px; background-color: white; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); }
  .layanan1-image { display: none; }
  .layanan1-btn { display: block; /* atau flex */ width: fit-content; margin-left: -2px; /* auto kiri-kanan = center */ margin-top: 0px; /* auto kiri-kanan = center */ background-color: #028d96; color: white; padding: 13px 18px; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; transition: background-color 0.3s; text-align: left; }
  .layanan1-btn:hover { background-color: #00a3b1; color: white; }
  .layanan1-item h3 { font-size: 14px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; }
  .layanan1-item p { font-size: 12px; font-weight: 400; line-height: 1.2; color: #333; } }

@media (max-width: 600px) { .layanan1-kami { padding: 30px 20px; background-color: #fff; }
  .layanan1-title { text-align: center; margin: 10px 0 20px; font-size: 20px; font-weight: 600; }
  .layanan1-content { display: flex; flex-direction: column; /* Stack vertical */ gap: 16px; align-items: center; padding: 0 16px; }
  .layanan1-list { width: 100%; margin: 0; padding: 20px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05); background-color: #fff; display: flex; flex-direction: column; gap: 10px; box-sizing: border-box; /* penting untuk padding tidak keluar batas */ }
  .layanan1-image { display: none; /* tetap disembunyikan di mobile */ }
  .layanan1-btn { margin: 20px auto 0 auto; display: block; background-color: #028d96; color: white; padding: 13px 18px; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 8px; white-space: nowrap; text-align: center; transition: background-color 0.3s; }
  .layanan1-btn:hover { background-color: #00a3b1; }
  .layanan1-item h3 { font-size: 14px; font-weight: 700; margin-bottom: 8px; line-height: 1.4; }
  .layanan1-item p { font-size: 12px; font-weight: 400; line-height: 1.4; color: #333; } }

.daftar-konten { display: flex; height: 751px; overflow: hidden; position: relative; }

.daftar-kiri { flex: 1; position: relative; z-index: 1; }

.daftar-kiri img { width: 60%; height: 100%; object-fit: cover; }

.daftar-kanan { flex: 1; display: flex; align-items: center; justify-content: flex-start; position: absolute; top: 0; right: 0; height: 100%; width: 45%; /* kanan form 55%, kiri 45% gambar */ z-index: 2; }

.daftar-formulir { background: #fff; padding: 30px; border-radius: 32px 0px 0px 32px; width: 100%; height: 100%; box-shadow: -10px 0 40px rgba(0, 0, 0, 0.1); display: flex; flex-direction: column; justify-content: center; }

.daftar-judul { text-align: center; color: #f57c00; font-size: 30px; font-weight: 600; margin-top: 0; }

.daftar-subjudul { text-align: center; font-size: 15px; font-weight: 500; margin: 5px 0 20px; color: #4a4a4a; }

form { display: flex; flex-direction: column; gap: 20px; }

.daftar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 0 40px; }

.daftar-grid textarea { grid-column: span 2; height: 96px; border-radius: 8px; border: 1px solid #f3f0e7; background-color: #f9f9f9; color: #8a949c; }

.daftar-grid input { height: 48px; border-radius: 8px; border: 1px solid #f3f0e7; background-color: #f9f9f9; color: #8a949c; font-family: "Lato", sans-serif !important; }

input, textarea { padding: 12px; border: 1px solid #eee; border-radius: 8px; background-color: #fafafa; font-size: 14px; }

/* === RESPONSIVE === */
/* Max Width 1280px */
@media (max-width: 1280px) { .daftar-konten { display: flex; height: 601px; overflow: hidden; position: relative; }
  .daftar-kiri { flex: 1; position: relative; z-index: 1; }
  .daftar-kiri img { width: 691px; height: 100%; object-fit: cover; }
  .daftar-kanan { flex: 1; display: flex; align-items: center; justify-content: flex-start; position: absolute; top: 0; right: 0; height: 100%; width: 636px; /* kanan form 55%, kiri 45% gambar */ z-index: 2; }
  .daftar-formulir { padding: 25px; border-radius: 32px 0px 0px 32px; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; }
  .daftar-judul { text-align: center; font-size: 28px; font-weight: 600; margin-top: 0; }
  .daftar-subjudul { text-align: center; font-size: 14px; font-weight: 500; margin: 5px 0 20px; }
  form { display: flex; flex-direction: column; gap: 20px; }
  .daftar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 0 40px; }
  .daftar-grid textarea { grid-column: span 2; }
  input, textarea { padding: 12px; border-radius: 8px; font-size: 14px; } }

/* Max Width 1024px */
@media (max-width: 1024px) { .daftar-konten { flex-direction: column; height: auto; position: relative; }
  .daftar-kiri { width: 100%; height: 300px; /* atau sesuai tinggi gambar yang kamu inginkan */ flex: none; }
  .daftar-kiri img { width: 100%; height: 400px; object-fit: cover; }
  .daftar-kanan { position: relative; width: 100%; flex: none; justify-content: center; }
  .daftar-formulir { padding: 25px; padding-left: 40px; padding-right: 50px; border-radius: 32px 32px 0px 0px; width: 100%; height: 680px; display: flex; flex-direction: column; justify-content: center; }
  .daftar-judul { text-align: center; font-size: 28px; font-weight: 600; margin-top: 0; }
  .daftar-subjudul { text-align: center; font-size: 14px; font-weight: 500; margin: 5px 0 20px; }
  form { display: flex; flex-direction: column; gap: 20px; }
  .daftar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 0 40px; }
  .daftar-grid textarea { grid-column: span 2; }
  input, textarea { padding: 12px; border-radius: 8px; font-size: 14px; } }

@media (max-width: 812px) { .daftar-konten { flex-direction: column; height: auto; position: relative; }
  .daftar-kiri { width: 100%; height: 300px; /* atau sesuai tinggi gambar yang kamu inginkan */ flex: none; }
  .daftar-kiri img { width: 100%; height: 447px; object-fit: cover; }
  .daftar-kanan { position: relative; width: 100%; flex: none; justify-content: center; }
  .daftar-formulir { padding: 25px; border-radius: 32px 32px 0px 0px; width: 100%; height: 640px; display: flex; flex-direction: column; justify-content: center; }
  .daftar-judul { text-align: center; font-size: 24px; font-weight: 600; margin-top: 0; }
  .daftar-subjudul { text-align: center; font-size: 14px; font-weight: 500; margin: 5px 0 20px; }
  form { display: flex; flex-direction: column; gap: 20px; }
  .daftar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 0 40px; }
  .daftar-grid textarea { grid-column: span 2; }
  input, textarea { padding: 12px; border-radius: 8px; font-size: 14px; } }

@media (max-width: 520px) { .daftar-konten { flex-direction: column; height: auto; position: relative; margin-top: -30px; }
  .daftar-kiri { width: 100%; height: 300px; /* atau sesuai tinggi gambar yang kamu inginkan */ flex: none; }
  .daftar-kiri img { width: 100%; height: 250px; object-fit: cover; }
  .daftar-kanan { position: relative; width: 100%; flex: none; justify-content: center; }
  .daftar-formulir { margin-top: -100px; padding: 25px; border-radius: 32px 32px 0px 0px; width: 100%; height: 640px; display: flex; flex-direction: column; justify-content: center; }
  .daftar-judul { text-align: center; font-size: 24px; font-weight: 600; margin-top: 0; }
  .daftar-subjudul { text-align: center; font-size: 14px; font-weight: 500; margin: 5px 0 20px; color: #333; }
  form { display: flex; flex-direction: column; gap: 20px; }
  .daftar-grid { display: grid; grid-template-columns: 1fr; gap: 16px; padding: 0 20px; }
  .daftar-grid textarea { grid-column: span 1; }
  input, textarea { padding: 12px; border-radius: 8px; font-size: 14px; } }

.maintenance { max-width: 1000px; margin-top: 100px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 30px; padding-left: 100px; }

.image-section .illustration { width: 300px; max-width: 100%; }

.text-section { max-width: 500px; text-align: left; }

.text-section h1 { color: #0595a9; font-size: 28px; margin-bottom: 10px; font-family: "Museo Sans", sans-serif; }

.text-section h2 { color: #333; font-weight: 600; font-size: 18px; margin-bottom: 15px; font-family: "Museo Sans", sans-serif; }

.text-section p { font-size: 16px; line-height: 1.6; font-family: "lato", sans-serif; }

.text-section a { color: #0595a9; text-decoration: none; }

.text-section a:hover { text-decoration: underline; }

.animate_delay_100 { transition-delay: 1000ms; }

.animate_delay_200 { transition-delay: 2000ms; }

.animate_delay_300 { transition-delay: 3000ms; }

.animate_delay_400 { transition-delay: 4000ms; }

.animate_delay_500 { transition-delay: 5000ms; }

.animate_from_left { transform: translateX(-2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; }

.animate_from_left.in_view { opacity: 1; /* scale: 1; */ transform: translateX(0); }

.animate_from_right { transform: translateX(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; }

.animate_from_right.in_view { opacity: 1; /* scale: 1; */ transform: translateX(0); }

.animate_from_top { transform: translateY(-200%); opacity: 0; scale: 0; transition: all 1s ease; }

.animate_from_top.in_view { opacity: 1; scale: 1; transform: translateY(0); }

.animate_from_bottom { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; }

.animate_from_bottom_100 { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; transition-delay: 200ms; }

.animate_from_bottom_200 { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; transition-delay: 400ms; }

.animate_from_bottom_300 { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all_400 1s ease; transition-delay: 600ms; }

.animate_from_bottom_400 { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; transition-delay: 1000ms; }

.animate_from_bottom_500 { transform: translateY(2rem); opacity: 0; /* scale: 0; */ transition: all 1s ease; transition-delay: 1200ms; }

.animate_from_bottom.in_view { opacity: 1; /* scale: 1; */ transform: translateY(0); }

.animate_from_bottom.in_view, .animate_from_bottom_100.in_view, .animate_from_bottom_200.in_view, .animate_from_bottom_300.in_view, .animate_from_bottom_400.in_view, .animate_from_bottom_500.in_view { opacity: 1; /* scale: 1; */ transform: translateY(0); }

.animate_from_bottom.in_view { opacity: 1; /* scale: 1; */ transform: translateY(0); }

.animate_from_center { opacity: 0; scale: 0; transition: all 1s ease; }

.animate_from_center.in_view { opacity: 1; scale: 1; }
