/* =========================================
   1. VARIABEL & RESET
   ========================================= */
:root {
  --navy-600: #1e3a8a;    /* Biru Navy Medium */
  --navy-700: #172554;    /* Biru Navy Gelap */
  --navy-800: #0f172a;    /* Navy Sangat Gelap */
  --orange-500: #f59e0b;  /* Oranye-Kuning (Aksen) */
  --muted: #6c757d;
  --light-bg: #f8fafc;
}

* { box-sizing: border-box; }

body { 
  font-family: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial; 
  background: var(--light-bg); 
  margin: 0; 
  color: var(--navy-800);
}

/* =========================================
   UTILITIES WARNA TEKS
   ========================================= */
.text-navy { color: var(--navy-700) !important; }
.text-orange { color: var(--orange-500) !important; }

/* =========================================
   2. HEADER & NAVBAR (NAVY THEME)
   ========================================= */
.navbar { background: var(--navy-700) !important; }
.navbar .navbar-brand, .navbar .nav-link { color: #fff !important; }
.navbar .nav-link:hover { 
  color: var(--orange-500) !important; 
  opacity: 1;
}

.header-top { 
  background: var(--navy-800); 
  color: #fff; 
  padding: 6px 0; 
  font-size: 0.95rem; 
}

.header-top .container { 
  display: flex; 
  justify-content: space-between; 
  align-items: center; 
}

/* Utilitas Header Abu-abu jika diperlukan */
.header-gray { background-color: #666; }
.header-gray .site-menu a { color: #fff !important; }

/* =========================================
   3. ANIMASI & LOGO
   ========================================= */
@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.15); }
  100% { transform: scale(1); }
}

.logo-anim {
  animation: pulse 2s infinite ease-in-out;
  cursor: pointer;
  transition: box-shadow 0.3s ease;
}

.logo-anim:hover {
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

/* =========================================
   HERO CAROUSEL (PENYESUAIAN LAPTOP/PC)
   ========================================= */
#heroCarousel .carousel-item {
  /* Kurangi dari 60vh menjadi 50vh (atau 45vh) agar tinggi gambar lebih proporsional di PC */
  height: 48vh; 
  min-height: 680px; /* Batas tinggi minimal agar di HP tetap bagus */
  position: relative;
}

#heroCarousel .hero-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Atur fokus gambar: 'center 20%' berarti fokus ditarik sedikit ke bagian atas gambar agar tidak kepotong */
  object-position: center 20%; 
  z-index: 1;
}

#heroCarousel .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(23,37,84,0.75), rgba(30,58,138,0.4));
  z-index: 2;
}

#heroCarousel .carousel-caption {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  /* Beri dorongan padding bawah agar tulisan/box sedikit naik ke atas */
  padding-bottom: 50px; 
}

#heroCarousel .text-start {
  text-align: left !important;
}

/* =========================================
   5. KOMPONEN (CARD, NEWS, STATS)
   ========================================= */
.card { 
  border: 0; 
  box-shadow: 0 6px 18px rgba(15,23,42,0.06); 
  background: #fff;
}

.news-list .card { display: flex; flex-direction: row; }
.news-list .card-img-left { width: 45%; object-fit: cover; }
.news-list .card-body { width: 55%; }

.list-ico .item { 
  flex: 0 0 23%; 
  background: #fff; 
  padding: 14px; 
  border-radius: 8px; 
  box-shadow: 0 6px 18px rgba(15,23,42,0.04); 
  text-align: center; 
}

.badge-orange { 
  background: var(--orange-500); 
  color: #fff; 
  padding: 6px 10px; 
  border-radius: 6px; 
}

.btn-extra-sm {
  padding: 0.15rem 0.4rem;
  font-size: 0.65rem;
  line-height: 1.2;
  border-radius: 0.2rem;
}

/* =========================================
   6. SOCIAL FLOATING
   ========================================= */
.social-floating {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 1000;
}

.social-floating a {
  background: #fff;
  color: #333;
  font-size: 22px;
  width: 45px;
  height: 45px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow: 0 3px 6px rgba(0,0,0,0.2);
  transition: all 0.3s ease;
}

.social-floating a:hover { transform: scale(1.1); }
.social-floating a.whatsapp { color: #25D366; }
.social-floating a.instagram { color: #E4405F; }
.social-floating a.facebook { color: #1877F2; }

/* =========================================
   7. GALERI & SLIDER
   ========================================= */
.galeri-img-wrapper { overflow: hidden; border-radius: 12px; }
.galeri-img-wrapper img { 
  width: 100%; 
  height: 220px; 
  object-fit: cover; 
  transition: 0.4s ease; 
}
.galeri-card:hover img { transform: scale(1.08); }

.swiper-pagination {
  position: relative !important;
  bottom: 0 !important;
  margin-top: 15px;
  text-align: center;
}

/* Tombol Navy Kustom */
.btn-navy {
  background-color: var(--navy-700);
  color: #ffffff;
  font-weight: 500;
  border-radius: 8px;
  padding: 8px 20px;
  border: none;
  transition: all 0.3s ease;
}

.btn-navy:hover {
  background-color: var(--orange-500);
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}

/* =========================================
   WIDGET KATEGORI (SIDEBAR)
   ========================================= */
.custom-list-group .list-group-item {
  color: #334155;
  font-weight: 500;
  border-color: #f8fafc;
  transition: all 0.3s ease;
  padding: 12px 20px;
}

/* Efek saat kursor diarahkan (hover) */
.custom-list-group .list-group-item:hover {
  background-color: #f1f5f9;
  color: var(--orange-500);
  padding-left: 25px; /* Teks bergeser sedikit ke kanan */
}

/* Efek saat kategori sedang aktif diklik */
.custom-list-group .list-group-item.active {
  background-color: var(--navy-700) !important;
  border-color: var(--navy-700) !important;
  color: #ffffff !important;
}

/* Ubah warna badge (angka) menjadi oranye saat kategorinya aktif */
.custom-list-group .list-group-item.active .badge-kategori {
  background-color: var(--orange-500) !important;
  color: #ffffff !important;
}

/* =========================================
   LIST LAYANAN YKAI KUSTOM
   ========================================= */
.layanan-item {
  background-color: #ffffff;
  border-radius: 12px;
  padding: 15px 15px 15px 12px;
  box-shadow: 0 4px 15px rgba(15, 23, 42, 0.04);
  border-left: 4px solid var(--orange-500);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.layanan-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(15, 23, 42, 0.08);
  border-left-color: var(--navy-700);
}

.layanan-number {
  background-color: #f1f5f9;
  color: var(--navy-700);
  font-size: 0.75rem;
  font-weight: 800;
  padding: 4px 8px;
  border-radius: 6px;
  transition: all 0.3s ease;
}

.layanan-item:hover .layanan-number {
  background-color: var(--navy-700);
  color: #ffffff;
}

.layanan-title {
  color: var(--navy-800);
  font-size: 0.95rem;
  line-height: 1.3;
}

.layanan-body {
  padding-left: 36px; /* Sejajar dengan teks judul, menghindari blok nomor */
  margin-top: 4px;
  line-height: 1.5;
}

/* =========================================
   HEADER JUDUL DENGAN BACKGROUND (SIDEBAR)
   ========================================= */
.title-bg-navy {
  background-color: rgba(30, 58, 138, 0.08); /* Biru Navy sangat tipis / transparan */
  color: var(--navy-800);
  font-weight: 700;
  font-size: 1.25rem;
  padding: 12px 15px; /* Memberi ruang (padding) agar background kotak terlihat */
  border-radius: 8px; /* Ujung kotak sedikit membulat */
  border-left: 5px solid var(--orange-500); /* Tetap pertahankan aksen garis oranye di kiri */
  margin-bottom: 20px;
  width: 100%; /* Memastikan selebar kolom (col-md-3) */
}


/* =========================================
   GALERI SLIDER BERJALAN (INFINITE MARQUEE)
   ========================================= */
.galeri-marquee-container {
  width: 100%;
  overflow: hidden; /* Menyembunyikan gambar yang keluar dari batas layar */
  position: relative;
  padding: 10px 0;
}

.galeri-marquee-track {
  display: flex;
  width: max-content;
  /* Atur angka 30s untuk mempercepat atau memperlambat jalannya gambar */
  animation: slideMarquee 30s linear infinite; 
}

/* Berhenti berjalan saat kursor mouse diarahkan ke gambar */
.galeri-marquee-track:hover {
  animation-play-state: paused;
}

.galeri-item {
  flex-shrink: 0;
  padding: 0 10px; /* Jarak antar gambar */
  /* Ukuran Default (Mobile): Menampilkan 2 gambar per baris */
  width: 48vw; 
}

/* Ukuran Desktop (Laptop/PC): Menampilkan 6 gambar per baris */
@media (min-width: 992px) {
  .galeri-item {
    /* Lebar sekitar 185px ideal untuk muat 6 gambar di container Bootstrap */
    width: 185px; 
  }
}

/* Animasi Pergerakan */
@keyframes slideMarquee {
  0% { transform: translateX(0); }
  /* Bergeser sejauh 50% dari total panjang track (karena datanya kita duplikasi 2 kali) */
  100% { transform: translateX(-50%); } 
}


/* =========================================
   PREMIUM BRANCH CARDS (KANTOR CABANG)
   ========================================= */
.premium-branch-card {
  border: 1px solid #cbd5e1; /* Warna Silver elegan untuk border */
  border-radius: 16px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  position: relative;
}

.premium-branch-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12);
  border-color: var(--navy-600); /* Border berubah navy saat disorot */
}

/* Wrapper Gambar */
.branch-img-wrapper {
  position: relative;
  width: 100%;
  height: 240px;
  overflow: hidden;
  border-bottom: 3px solid var(--orange-500); /* Aksen garis oranye pemisah gambar dan teks */
}

.branch-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.premium-branch-card:hover .branch-img {
  transform: scale(1.08); /* Efek zoom in lambat pada gambar */
}

/* Lencana (Badge) di atas gambar */
.branch-badge {
  position: absolute;
  top: 15px;
  right: 15px;
  background: rgba(15, 23, 42, 0.85); /* Navy transparan */
  color: #ffffff;
  padding: 6px 15px;
  border-radius: 30px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  backdrop-filter: blur(4px);
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}

/* Judul Cabang */
.branch-title {
  color: var(--navy-800);
  font-size: 1.35rem;
  line-height: 1.4;
}

/* Keterangan Editor */
.branch-desc {
  font-size: 0.95rem;
  line-height: 1.7;
}

.branch-desc p {
  margin-bottom: 0.5rem; /* Merapikan jarak paragraf bawaan WYSIWYG */
}

/* Footer Card */
.branch-footer-line {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, #e2e8f0 0%, transparent 100%); /* Gradien silver ke pudar */
}

.text-navy-light {
  color: var(--navy-600);
  opacity: 0.5;
  transition: opacity 0.3s ease;
}

.premium-branch-card:hover .text-navy-light {
  opacity: 1; /* Ikon map menyala saat disorot */
  color: var(--orange-500);
}

/* =========================================
   8. FOOTER & RESPONSIVE
   ========================================= */
footer { 
  background: var(--navy-700); 
  color: #e2e8f0; 
  padding: 30px 0; 
  margin-top: 40px; 
}

@media(max-width:768px){
  .news-list .card { flex-direction: column !important; }
  .news-list .card-img-left { width: 100% !important; height: auto !important; border-bottom: 1px solid #eee; }
  .news-list .card-body { width: 100% !important; }
  .list-ico .item { flex: 0 0 48%; }
  .site-section { padding-top: 30px; padding-bottom: 30px; }
}