/**
* Template Name: Impact
* Updated: Sep 17 2023 with Bootstrap v5.3.2
* Template URL: https://bootstrapmade.com/impact-bootstrap-business-website-template/
* Author: BootstrapMade.com
* License: https://bootstrapmade.com/license/
* 
* MODIFIED FOR UGKMB PORTAL
*/
document.addEventListener('DOMContentLoaded', () => {
  "use strict";

  /**
   * Preloader Logic (FIXED)
   * We hide the preloader on DOMContentLoaded, not window.load.
   * This makes the page appear much faster for the user.
   */
  const preloader = document.querySelector('#preloader');
  if (preloader) {
    // Hide preloader when the main document is ready, don't wait for all images/APIs
    preloader.remove();
  }

  /**
   * Sticky header on scroll
   */
  const selectHeader = document.querySelector('#header');
  if (selectHeader) {
    document.addEventListener('scroll', () => {
      window.scrollY > 100 ? selectHeader.classList.add('sticked') : selectHeader.classList.remove('sticked');
    });
  }

  /**
   * Mobile nav toggle
   */
  const mobileNavShow = document.querySelector('.mobile-nav-show');
  const mobileNavHide = document.querySelector('.mobile-nav-hide');

  document.querySelectorAll('.mobile-nav-toggle').forEach(el => {
    el.addEventListener('click', function(event) {
      event.preventDefault();
      mobileNavToogle();
    })
  });

  function mobileNavToogle() {
    document.querySelector('body').classList.toggle('mobile-nav-active');
    mobileNavShow.classList.toggle('d-none');
    mobileNavHide.classList.toggle('d-none');
  }

  /**
   * Hide mobile nav on same-page/hash links
   */
  document.querySelectorAll('#navbar a').forEach(navbarlink => {
    if (!navbarlink.hash) return;
    let section = document.querySelector(navbarlink.hash);
    if (!section) return;
    navbarlink.addEventListener('click', () => {
      if (document.querySelector('.mobile-nav-active')) {
        mobileNavToogle();
      }
    });
  });

  /**
   * Toggle mobile nav dropdowns
   */
  const navDropdowns = document.querySelectorAll('.navbar .dropdown > a');
  navDropdowns.forEach(el => {
    el.addEventListener('click', function(event) {
      if (document.querySelector('.mobile-nav-active')) {
        event.preventDefault();
        this.classList.toggle('active');
        this.nextElementSibling.classList.toggle('dropdown-active');
        let dropDownIndicator = this.querySelector('.dropdown-indicator');
        dropDownIndicator.classList.toggle('bi-chevron-up');
        dropDownIndicator.classList.toggle('bi-chevron-down');
      }
    })
  });

  /**
   * Scroll top button
   */
  const scrollTop = document.querySelector('.scroll-top');
  if (scrollTop) {
    const togglescrollTop = function() {
      window.scrollY > 100 ? scrollTop.classList.add('active') : scrollTop.classList.remove('active');
    }
    window.addEventListener('load', togglescrollTop);
    document.addEventListener('scroll', togglescrollTop);
    scrollTop.addEventListener('click', window.scrollTo({
      top: 0,
      behavior: 'smooth'
    }));
  }

  /**
   * Animation on scroll function and init
   */
  function aos_init() {
    AOS.init({
      duration: 1000,
      easing: 'ease-in-out',
      once: true,
      mirror: false
    });
  }
  // Initialize AOS on window load
  window.addEventListener('load', () => {
    aos_init();
  });

  /**
   * GLightbox
   */
  const glightbox = GLightbox({
    selector: '.glightbox'
  });

  /**
   * Testimonials slider
   */
  new Swiper('.testimonials-slider', {
    speed: 600,
    loop: true,
    autoplay: {
      delay: 5000,
      disableOnInteraction: false
    },
    slidesPerView: 'auto',
    pagination: {
      el: '.swiper-pagination',
      type: 'bullets',
      clickable: true
    },
    breakpoints: {
      320: {
        slidesPerView: 1,
        spaceBetween: 40
      },

      1200: {
        slidesPerView: 2,
        spaceBetween: 40
      }
    }
  });

  /**
   * Porfolio isotope and filter
   */
  let portfolionIsotope = document.querySelector('.portfolio-isotope');
  if (portfolionIsotope) {
    let portfolioFilter = portfolionIsotope.getAttribute('data-portfolio-filter') ? portfolionIsotope.getAttribute('data-portfolio-filter') : '*';
    let portfolioLayout = portfolionIsotope.getAttribute('data-portfolio-layout') ? portfolionIsotope.getAttribute('data-portfolio-layout') : 'masonry';
    let portfolioSort = portfolionIsotope.getAttribute('data-portfolio-sort') ? portfolionIsotope.getAttribute('data-portfolio-sort') : 'original-order';

    window.addEventListener('load', () => {
      let portfolioIsotope = new Isotope(document.querySelector('.portfolio-container'), {
        itemSelector: '.portfolio-item',
        layoutMode: portfolioLayout,
        filter: portfolioFilter,
        sortBy: portfolioSort
      });

      let menuFilters = document.querySelectorAll('.portfolio-isotope .portfolio-flters li');
      menuFilters.forEach(function(el) {
        el.addEventListener('click', function() {
          document.querySelector('.portfolio-isotope .portfolio-flters .filter-active').classList.remove('filter-active');
          this.classList.add('filter-active');
          portfolioIsotope.arrange({
            filter: this.getAttribute('data-filter')
          });
          portfolioIsotope.on('arrangeComplete', function() {
            AOS.refresh();
          });
        }, false);
      });
    });
  }

});
/* === TAMBAHKAN KODE INI DI BAGIAN AKHIR beranda/public/assets/css/style.css === */

/*
================================================================================
|     7. HEADER BARU & TOP BAR                                                 |
================================================================================
*/

.top-bar { 
    background-color: #343a40; /* Warna abu-abu gelap */
    padding: 0.5rem 0; 
    font-size: 0.85rem; 
}
.top-bar .container { 
    display: flex; 
    justify-content: flex-end; 
    align-items: center; 
}
.top-bar-menu .navbar-nav { 
    flex-direction: row; 
}
.top-bar-menu .nav-item { 
    margin-left: 1rem; 
}
.top-bar-menu .nav-link { 
    color: rgba(255, 255, 255, 0.75) !important; 
    padding: 0.25rem 0; 
    text-decoration: none; 
    transition: color 0.2s ease-in-out; 
}
.top-bar-menu .nav-link:hover, .top-bar-menu .nav-link.active { 
    color: #fff !important; 
}

@media (max-width: 991px) {
    .top-bar .container { justify-content: center; }
}


/* ===============================================
   STYLE BARU UNTUK FOOTER
   =============================================== */

.footer {
  /* Menggunakan variabel warna dari header untuk konsistensi */
  --footer-background-color: #1F1F1F; 
  --footer-text-color: rgba(255, 255, 255, 0.7);
  --footer-heading-color: #ffffff;
  --footer-link-hover-color: var(--ugkmb-secondary, #98fb98);

  font-size: 14px;
  padding: 80px 0;
  position: relative;
  color: var(--footer-text-color);
  background-color: var(--footer-background-color);
  background-size: cover;
  background-position: center;
  
  /* Menambahkan gambar latar belakang yang relevan dengan sedikit overlay gelap */
  /* Ganti URL gambar sesuai kebutuhan Anda */
  background-image: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.8)), url('https://images.unsplash.com/photo-1599233013441-0935395a1816?q=80&w=2070&auto=format&fit=crop');
}

.footer .footer-info .logo {
  line-height: 0;
  margin-bottom: 25px;
}

.footer .footer-info .logo span {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--footer-heading-color);
}

.footer .footer-links {
  margin-bottom: 30px;
}

.footer h4 {
  font-size: 16px;
  font-weight: bold;
  color: var(--footer-heading-color);
  position: relative;
  padding-bottom: 12px;
}

.footer .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer .footer-links ul i {
  padding-right: 2px;
  color: var(--footer-link-hover-color);
  font-size: 12px;
  line-height: 0;
}

.footer .footer-links ul li {
  padding: 10px 0;
  display: flex;
  align-items: center;
}

.footer .footer-links ul li:first-child {
  padding-top: 0;
}

.footer .footer-links ul a {
  color: var(--footer-text-color);
  transition: 0.3s;
  display: inline-block;
  line-height: 1;
  text-decoration: none;
}

.footer .footer-links ul a:hover {
  color: var(--footer-link-hover-color);
}

.footer .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 16px;
  color: rgba(255, 255, 255, 0.7);
  margin-right: 10px;
  transition: 0.3s;
}

.footer .social-links a:hover {
  color: #fff;
  border-color: var(--footer-link-hover-color);
  background: var(--footer-link-hover-color);
}

.footer .copyright {
  text-align: center;
  padding-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.footer .credits {
  padding-top: 4px;
  text-align: center;
  font-size: 13px;
}

.footer .credits a {
  color: var(--footer-link-hover-color);
  text-decoration: none;
  transition: 0.3s;
}

.footer .credits a:hover {
    color: #fff;
}
/* ===============================================
   STYLE UNTUK PRELOADER MODERN
   =============================================== */

#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  overflow: hidden;
  background: #fff; /* Latar belakang preloader, sesuaikan dengan tema Anda */
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s ease-out, visibility 0.5s ease-out;
}

/* Kelas ini ditambahkan oleh JS untuk memulai transisi fade-out */
#preloader.preloader-hidden {
  opacity: 0;
  visibility: hidden;
}

.preloader-logo {
  max-width: 150px; /* Ukuran logo di preloader */
  animation: preloader-pulse 1.5s ease-in-out infinite;
}

/* Animasi denyut untuk logo */
@keyframes preloader-pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.05);
    opacity: 0.7;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

/* Jika Anda menggunakan tema gelap, preloader juga bisa beradaptasi */
body.dark-theme #preloader {
    background: #121212;
}