
body {i
  background: #fff;
  /* color: #2f3138; OLD */
  color: #040919;
  font-family: Arial, sans-serif;
}

a {
  color: #f82249;
  transition: 0.5s;
}

a:hover,
a:active,
a:focus {
  color: #f8234a;
  outline: none;
  text-decoration: none;
}

p {
  padding: 0;
  margin: 0 0 30px 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: Arial, sans-serif;
  font-weight: 400;
  margin: 0 0 20px 0;
  padding: 0;
  color: #0e1b4d;
}

.main-page {
  margin-top: 70px;
}

.hide {
  visibility: visible;
}


/* Prelaoder */

#preloader {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999;
  width: 100%;
  height: 100%;
  overflow: visible;
  background: #fff url("../img/preloader.svg") no-repeat center center;
}

/* Back to top button */

.back-to-top {
  position: fixed;
  display: none;
  background: #f82249;
  color: #fff;
  width: 40px;
  height: 40px;
  text-align: center;
  border-radius: 50px;
  right: 15px;
  bottom: 15px;
  transition: background 0.5s ease-in-out;
}

.back-to-top i {
  font-size: 24px;
  padding-top: 6px;
}

.back-to-top:focus {
  background: #e0072f;
  color: #fff;
  outline: none;
}

.back-to-top:hover {
  background: #e0072f;
  color: #fff;
}

/* Sections Header
--------------------------------*/

.section-header {
  margin-bottom: 30px;
  position: relative;
  margin-top: 30px;
  padding-bottom: 20px;
}

.section-header::before {
  content: '';
  position: absolute;
  display: block;
  width: 60px;
  height: 5px;
  background: #f82249;
  bottom: 0;
  left: calc(50% - 25px);
}

.section-header h2 {
  font-size: 36px;
  text-transform: uppercase;
  text-align: center;
  font-weight: 700;
  margin-bottom: 10px;
}
.section-header h1 {
  font-size: 2.25rem;
  text-transform: uppercase;
  text-align: center;
  font-weight: 700;
  margin-bottom: 10px;
}

.section-header p {
  text-align: center;
  padding: 0;
  margin: 0;
  font-size: 18px;
  font-weight: 500;
  color: #9195a2;
}

.section-with-bg {
  background-color: #f6f7fd;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/

#header {
  height: 90px;
  padding: 25px 0;
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  transition: all 0.5s;
  z-index: 1000;
  background: transparent;
  max-width: 100vw;
}

#header.header-scrolled,
#header.header-fixed {
  background: rgba(6, 12, 34, 0.98);
  height: 80px;
  padding: 20px 0;
  transition: all 0.5s;
  z-index: 1000;
}

#header #logo h1 {
  font-size: 36px;
  margin: 0;
  padding: 6px 0;
  line-height: 1;
  font-family: Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
}
#header #logo {
  text-align: left; /* Default position untuk ukuran layar lebih besar */
  margin-left: 3%;
}

#header #logo h1 span {
  color: #f82249;
}

#header #logo h1 a,
#header #logo h1 a:hover {
  color: #fff;
}

#header #logo img {
  padding: 0;
  margin: 0;
   max-height: 65px;
   margin-top: -15px;
}
@media (max-width: 768px) {
  #header {
    justify-content: center; /* Center everything in the header */
    padding: 15px 0; /* Adjust padding for smaller screens if necessary */
  }

  #logo {
    flex: 0 1 auto; /* Allow logo to be centered and not grow or shrink */
    display: flex;
    justify-content: center; /* Center logo inside the logo container */
    align-items: center; /* Center logo vertically within the logo container */
    width: 100%; /* Ensure the logo container takes full width */
  }

  #logo img {
    display: block; /* Ensure the image behaves as a block element */
    margin: 0 auto; /* Center the image inside its container */
    max-height: 45px !important;

  }
}
@media (max-width: 991px) {
    #header #logo {
  flex: 5;
}
#logo {
    flex: 0 1 auto; /* Allow logo to be centered and not grow or shrink */
    display: flex;
    justify-content: center; /* Center logo inside the logo container */
    align-items: center; /* Center logo vertically within the logo container */
    width: 100%; /* Ensure the logo container takes full width */
  }
 #logo img {
    max-height: 55px !important;
    margin-left: 20% !important;
  }
}

#header2 {
  height: 90px;
  padding: 25px 0;
  position: fixed;
  left: 0;
  background: rgba(6, 12, 34, 0.98);
  top: 0;
  right: 0;
  transition: all 0.5s;
  z-index: 996;
  align-items: center;
}

#header2.header-scrolled,
#header2.header-fixed {
  background: rgba(6, 12, 34, 0.98);
  height: 80px;
  padding: 15px 0;
  transition: all 0.5s;
}

#header2 #logo2 h1 {
  font-size: 36px;
  margin: 0;
  padding: 6px 0;
  line-height: 1;
  font-family: Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
}
#header2 #logo2 {
  text-align: left; /* Default position untuk ukuran layar lebih besar */
  flex: 1;
  align-items: center;
  display: flex;
  margin-left: 3%;
}

#header2 #logo2 h1 span {
  color: #f82249;
}

#header2 #logo2 h1 a,
#header2 #logo2 h1 a:hover {
  color: #fff;
}

#header2 #logo2 img {
  padding: 0;
  margin: 0;
  max-height: 65px;
  margin-top: -5px;
}
@media (max-width: 991px) {
    #header2 #logo2 {
  flex: 5;
}
#logo2 {
    flex: 0 1 auto; /* Allow logo to be centered and not grow or shrink */
    display: flex;
    justify-content: center; /* Center logo inside the logo container */
    align-items: center; /* Center logo vertically within the logo container */
    width: 100%; /* Ensure the logo container takes full width */
  }
 #header2 #logo2 img {
    max-height: 55px;
    margin-left: 20% !important;
  }
}
@media (max-width: 768px) {
  #header2 {
    justify-content: center; /* Center everything in the header */
    padding: 15px 0; /* Adjust padding for smaller screens if necessary */
  }

  #logo2 {
    flex: 0 1 auto; /* Allow logo to be centered and not grow or shrink */
    display: flex;
    justify-content: center; /* Center logo inside the logo container */
    align-items: center; /* Center logo vertically within the logo container */
    width: 100%; /* Ensure the logo container takes full width */
  }

  #logo2 img {
    display: block; /* Ensure the image behaves as a block element */
    margin: 0 auto; /* Center the image inside its container */
    margin-top: -5px !important;
  }

}

@media (max-width: 500px){
  #header2 #logo2 img {
  padding: 0;
  margin: 0;
  max-height: 50px;
  margin-left: 25px !important;
}
  #header2 {
    height: 60px;
  }
    #header #logo img {
  padding: 0;
  margin: 0;
  max-height: 50px;
  margin-left: 30px !important;
  max-height: 45px !important;

}
  #header {
    height: 60px;
  }
}
/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/

/* Nav Menu Essentials */

.nav-menu,
.nav-menu * {
  margin: 0;
  padding: 0;
  list-style: none;
 justify-content: center; 
}

.nav-menu ul {
  position: absolute;
  display: none;
  top: 100%;
  left: 0;
  z-index: 99;
}

.nav-menu li {
  position: relative;
  white-space: nowrap;
}

.nav-menu > li {
  float: left;
}

.nav-menu li:hover > ul,
.nav-menu li.sfHover > ul {
  display: block;
}

.nav-menu ul ul {
  top: 0;
  left: 100%;
}

.nav-menu ul li {
  min-width: 180px;
}

/* Dropdown Style */
.dropdown {
    position: relative;
}

.dropdown .dropbtn {
    cursor: pointer;
}
.dropdown .dropbtn i {
    margin-left: 5px;
}
/* Dropdown content (tersembunyi secara default) */
.nav-menu .dropdown-content {
    display: none;
    position: absolute;
    background-color: #f9f9f9;
    min-width: 160px;
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.2);
    z-index: 1;
}

.nav-menu .dropdown-content li {
    padding: 2px 5px;
    text-align: left;
}

.nav-menu .dropdown-content li a {
    color: #060c22fa !important ;
    font-weight: bold;
    background-color: #f9f9f9 !important;
}

.dropdown:hover .dropdown-content li a:hover {
    color: #f82249 !important ;
    font-weight: bold;
    background-color: none;
}

/* Menampilkan dropdown ketika hover */
.dropdown:hover .dropdown-content {
    display: block;
}
.dropdown:active .dropdown-content {
    display: block;
}

/* Nav Menu Arrows */

.sf-arrows .sf-with-ul {
  padding-right: 30px;
}

.sf-arrows .sf-with-ul:after {
  content: "\f107";
  position: absolute;
  right: 15px;
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
}

.sf-arrows ul .sf-with-ul:after {
  content: "\f105";
}

/* Nav Meu Container */

#nav-menu-container {
    flex: 4; /* Allow menu to take up more space */
    text-align: center; /* Center the menu */
    align-items: center;
    justify-content: center;
    display: flex;
}

/* Nav Meu Styling */

.nav-menu a {
  padding: 8px;
  text-decoration: none;
  display: inline-block;
  color: rgba(202, 206, 221, 0.8);
  font-family: Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  outline: none;
   justify-content: center; 
}

.nav-menu .menu-active a,
.nav-menu a:hover {
  color: #fff;
}

.nav-menu > li {
  margin-left: 8px;
}

.nav-menu > li > a:before {
  content: "";
  position: absolute;
  width: 0;
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: #f82249;
  visibility: hidden;
  transition: all 0.3s ease-in-out 0s;
}

.nav-menu a:hover:before,
.nav-menu li:hover > a:before,
.nav-menu .menu-active > a:before {
  visibility: visible;
  width: 100%;
}

.nav-menu li.buy-tickets a {
  color: #fff;
  background: #f82249;
  padding: 7px 22px;
  border-radius: 50px;
  border: 2px solid #f82249;
  transition: all ease-in-out 0.3s;
  font-weight: 500;
  margin-left: 8px;
  margin-top: 2px;
  line-height: 1;
  font-size: 13px;
}

.nav-menu li.buy-tickets a:hover {
  background: none;
}

.nav-menu li.buy-tickets:hover a:before,
.nav-menu li.buy-tickets.menu-active a:before {
  visibility: hidden;
}

.nav-menu ul {
  margin: 4px 0 0 0;
  padding: 10px;
  box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
  background: #fff;
  border-radius: 3px;
}

.nav-menu ul li {
  transition: 0.3s;
}

.nav-menu ul li a {
  padding: 10px;
  color: #060c22;
  transition: 0.3s;
  display: block;
  font-size: 13px;
  text-transform: none;
  border-radius: 3px;
}

.nav-menu ul li:hover > a {
  background: #f82249;
  color: #fff;
}

.nav-menu ul ul {
  margin: 0;
}

/* HEADER ICON KERANJANG CART, LOGIN AND BAHASA */
.header-container {
    display: flex; /* Use flexbox for layout */
    align-items: center; /* Center items vertically */
    justify-content: space-between; /* Distribute space between items */
    padding: 10px 20px; /* Add padding around the header */
    background-color: #060c22fa; /* Set a background color */
}
.header-container-home {
    display: flex; /* Use flexbox for layout */
    align-items: center; /* Center items vertically */
    justify-content: space-between; /* Distribute space between items */
    padding: 10px 20px; /* Add padding around the header */
    background-color: transparent; /* Set a background color */
}

.header-icons {
    flex: 1; /* Allow icons to take up available space */
    display: flex; /* Use flexbox for icons */
    justify-content: center; /* Align icons to the right */
    align-items: center;
    gap: 10px;
}

.header-icons .icon {
    position: relative; /* Make the icon the reference point for the badge */
    margin-left: 5px; /* Add spacing between icons */
    color: #040919; /* Icon color */
    text-decoration: none; /* Remove underline from icons */
    width: 45px; /* Set width for the icon */
    height: 45px; /* Set height for the icon */
    border-radius: 50%; /* Make it circular */
    background-color: white; /* Background color */
    display: flex; /* Center the icon inside the container */
    align-items: center; /* Vertically center */
    justify-content: center; /* Horizontally center */
    border-color: white;
}

.header-icons .icon .badge {
    position: absolute; /* Position the badge relative to the icon */
    top: -5px; /* Adjust position to place it at the top-right of the icon */
    right: -5px; /* Adjust position to place it at the top-right of the icon */
    background-color: #f82249; /* Badge background color */
    color: white; /* Badge text color */
    width: 20px; /* Set badge size */
    height: 20px; /* Make it circular */
    border-radius: 50%; /* Make it a circle */
    display: flex; /* Center the text inside the badge */
    align-items: center; /* Vertically center text */
    justify-content: center; /* Horizontally center text */
    font-size: 12px; /* Adjust font size */
    font-weight: bold; /* Optional: Bold text */
    z-index: 1; /* Ensure badge stays on top */
}

.header-icons .icon:hover {
    color: #040919; /* Change color on hover */
}

/* Styling untuk dropdown dan avatar */
.user-dropdown {
    position: relative;
    display: inline-block;
}

.user-dropdown .dropdown-menu-profile {
    display: none;
    position: absolute;
    top: 55px; /* Sesuaikan agar dropdown dimulai 20px di bawah avatar */
    right: 10px; /* Posisi dropdown di pojok kanan */
    background-color: #fff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    z-index: 1000;
    width: 200px;
}
.dropdown-menu-profile-head {
    position: absolute;
    top: 0px;
    left: 0;
    width: 90%;
    min-height: 15px;
    background-color: transparent;
}
.dropdown-menu-profile-content{
    width: 100%;
    padding: 10px;
}

/* Styling untuk efek "leher botol" di pojok kiri bawah avatar */
.user-dropdown .dropdown-menu-rofile::before {
    content: '';
    position: absolute;
    top: -20px; /* Posisi elemen sebelum dropdown untuk membuat kepala botol */
    right: 10px; /* Posisikan di pojok kanan */
    width: 20px;
    height: 20px;
    background-color: #fff;
    transform: rotate(45deg); /* Membuat segitiga dengan sudut 45 derajat */
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); /* Sedikit bayangan untuk efek mendalam */
    z-index: 1000; /* Agar elemen berada di belakang dropdown */
}


.user-dropdown .dropdown-menu-profile a,
.user-dropdown .dropdown-menu-profile form button {
    display: block;
    padding: 8px 12px;
    text-decoration: none;
    color: #333;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    width: 100%;
}

.user-dropdown .dropdown-menu-profile form {
    margin: 0;
}
.icon-cart-mobile {
   position: relative; /* Make the icon the reference point for the badge */
    margin-left: 5px; /* Add spacing between icons */
    color: #040919; /* Icon color */
    text-decoration: none; /* Remove underline from icons */
    width: 20px; /* Set width for the icon */
    height: 20px; /* Set height for the icon */
    color: white;
    display: flex; /* Center the icon inside the container */
    align-items: center; /* Vertically center */
    justify-content: center; /* Horizontally center */
}
.icon-cart-mobile .badge {
    position: absolute; /* Position the badge relative to the icon */
    top: -8px; /* Adjust position to place it at the top-right of the icon */
    right: -5px; /* Adjust position to place it at the top-right of the icon */
    background-color: #f82249; /* Badge background color */
    color: white; /* Badge text color */
    width: 15px; /* Set badge size */
    height: 15px; /* Make it circular */
    border-radius: 50%; /* Make it a circle */
    display: flex; /* Center the text inside the badge */
    align-items: center; /* Vertically center text */
    justify-content: center; /* Horizontally center text */
    font-size: 12px; /* Adjust font size */
    font-weight: bold; /* Optional: Bold text */
    z-index: 1; /* Ensure badge stays on top */
}
.icon-search-mobile {
    position: relative; /* Make the icon the reference point for the badge */
    margin-left: 5px; /* Add spacing between icons */
    color: #040919; /* Icon color */
    text-decoration: none; /* Remove underline from icons */
    width: 20px; /* Set width for the icon */
    height: 20px; /* Set height for the icon */
    color: white;
    display: flex; /* Center the icon inside the container */
    align-items: center; /* Vertically center */
    justify-content: center; /* Horizontally center */
}
@media (max-width: 991px) {
    .header-icons {
    justify-content: center; /* Align icons to the right */
  }
  .header-icons .icon {
    margin-left: 0; /* Add spacing between icons */
    width: 50px; /* Set width for the icon */
    height: 45px; /* Set height for the icon */
  
}  
}
@media (max-width: 768px) {
  .user-dropdown, .icon-language, 
  .login-icon {
    display: none !important;
  }
}
@media (min-width: 501px) {
  .icon-cart-mobile {
    display: none !important;
  }
  .icon-search-mobile {
    display: none !important;
  }
}
@media (max-width: 500px) {
  .header-icons .icon {
    max-width: 30px;
    max-height: 30px;
    font-size: 0.8rem;
    margin-left: 0 ;
}
.icon-cart {
    display: none !important;
  }
  .icon-search {
    background-color: transparent !important;
    color: white !important;
  }
  .header-icons {
    gap: 0px;
  }
}

/* Mobile Nav Toggle */

#mobile-nav-toggle {
  position: fixed;
  /* right: 0; OLD */
  top: 0;
  z-index: 1001;
  margin: 15px 15px 0 0;
  border: 0;
  background: none;
  font-size: 24px;
  display: none;
  transition: all 0.4s;
  outline: none;
  cursor: pointer;
}

#mobile-nav-toggle i {
  color: #fff;
}

/* Mobile Nav Styling */

#mobile-nav {
  position: fixed;
  top: 0;
  padding-top: 40px;
  bottom: 0;
  z-index: 998;
  background: rgba(6, 12, 34, 0.9);
  left: -260px;
  width: 260px;
  overflow-y: auto;
  transition: 0.4s;
}

#mobile-nav ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

#mobile-nav ul li {
  position: relative;
}

#mobile-nav ul li a {
  color: #fff;
  font-size: 17px;
  overflow: hidden;
  padding: 10px 22px 10px 15px;
  position: relative;
  text-decoration: none;
  width: 100%;
  display: block;
  outline: none;
}

#mobile-nav ul li a:hover {
  color: #f82249;
}

#mobile-nav ul li li {
  padding-left: 30px;
}

#mobile-nav ul .menu-has-children i {
  position: absolute;
  right: 0;
  z-index: 99;
  padding: 15px;
  cursor: pointer;
  color: #fff;
}

#mobile-nav .dropdown-content {
    display: none; /* Dropdown tersembunyi secara default */
    position: absolute;
    background-color: #f9f9f9;
    min-width: 160px;
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.2);
    z-index: 1;
}

#mobile-nav .dropdown-content li {
    padding: 2px 5px;
    text-align: left;
}

#mobile-nav .dropdown-content li a {
    color: #333;
    font-weight: bold;
}

#mobile-nav .dropdown-content:active {
    display: block !important;
}

#mobile-nav ul .menu-has-children i.fa-chevron-up {
  color: #f82249;
}

#mobile-nav ul .menu-item-active {
  color: #f82249;
}

#mobile-body-overly {
  width: 100%;
  height: 100%;
  z-index: 997;
  top: 0;
  left: 0;
  position: fixed;
  background: rgba(6, 12, 34, 0.8);
  display: none;
}

/* Mobile Nav body classes */

body.mobile-nav-active {
  overflow: hidden;
}

body.mobile-nav-active #mobile-nav {
  left: 0;
}

body.mobile-nav-active #mobile-nav-toggle {
  color: #fff;
}

/*--------------------------------------------------------------
# Intro Section
--------------------------------------------------------------*/

#intro {
    position: relative;
    overflow: hidden;
    height: 100vh;
    width: 100vw;

}

.video-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 0;
    overflow: hidden;
}

#intro iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 110%;
    min-height: 113%;
    width: 100%; /* Adjust the width to zoom in */
    height: 100%; /* Adjust the height to zoom in */
    transform: translate(-50%, -50%);
    pointer-events: none; /* Prevent interaction with the video */
}

#intro:before {
    content: "";
    background: rgba(12, 12, 34, 0.5) !important; /* Semi-transparent overlay */
    position: absolute;
    bottom: 0;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1;
}

.intro-container {
    position: relative;
    z-index: 10; /* Ensure content is above the video */
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    text-align: center;
    padding: 0 15px;
    height: 100vh; /* Adjust to match the height of the intro section */
    color: white;
}
@media (max-width:991px) {
  #intro {
    max-height: 80vh !important;
  }
}
@media (max-width:500px) {
  #intro {
    height: 55vh !important;
  }
  .intro-container {
    height: 50vh;
  }
  .video-container {
    height: 60vh;
  }
 
  #intro h2 {
    font-size: 1.7rem !important;
  }
  #intro p {
    font-size: 0.8rem !important;
  }
  .welcome-buttons {
  margin-top: 5px !important;
}
.welcome-btn {
    padding: 8px 15px !important;
    border-radius: 15px;
}
.welcome-btn:hover{
    transform: scale(1.2);
}
}
.typed-text {
    color: #333; /* Color of the main text */
    display: inline; /* Ensure typed-text is inline */
}

/* Styles for the subtext */
.subtext {
    opacity: 0;
    transition: opacity 1s ease-in; /* Fade in effect */
    color: #666; /* Color of the subtext */
}

/* Make subtext visible when added class 'show' */
.subtext.show {
    opacity: 1;
}
.subtext.hide {
    opacity: 0;
}

.certificates {
    margin-top: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.certificates img {
    max-width: 130px; /* Adjust size as needed */
    height: auto;
    margin: 0 10px;
    max-height: 100px;
}
.endImage {
  display:none; 
  width:100vw; 
  height:100vh;
  object-fit: fill;
  object-position: center;
}
@media (min-width: 501px) and (max-width: 768px) {
  .endImage {
      object-fit: cover; /* Menghilangkan pengaturan fit agar bisa di-crop */
      object-position: center; /* Memusatkan gambar */
      width: 100vw; /* Buat gambar memenuhi lebar viewport */
      height: 100vh; /* Sesuaikan tinggi gambar agar memenuhi tinggi viewport */
  }
}
@media (max-width: 500px) {
    .certificates {
        display: none !important;
    }

    .certificates img {
        width: 50px; /* Adjust size as needed */
        margin: 0;
    }
    .endImage {
      object-fit: fill; /* Menghilangkan pengaturan fit agar bisa di-crop */
      object-position: center; /* Memusatkan gambar */
      width: 100vw; /* Buat gambar memenuhi lebar viewport */
      height: 60vh; /* Sesuaikan tinggi gambar agar memenuhi tinggi viewport */
  }
}
@media (min-width:401) and (max-width: 768px) {
    .certificates {
        margin-top: 30px;
    }

    .certificates img {
        width: 100px; /* Adjust size as needed */
        margin: 0;
    }
}
/* Tablet adjustments */
@media (max-width: 1024px) {
    #intro {
        height: 100vh;
    }
    #intro iframe {
        width: 177.78vh; /* 16:9 aspect ratio for height */
        height: 100vh;
    }
}

/* Mobile adjustments */
@media (min-width: 501px) and (max-width: 768px) {
    #intro {
        height: auto !important;
    }
    #intro iframe {
        width: 200%; /* Increase width for zoom effect on smaller screens */
        height: 200%; /* Increase height for zoom effect on smaller screens */
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
    .section-header {
      margin-top: 20px !important;
      margin-bottom: 25px !important;
      padding-bottom: 15px !important;
    }
    .section-header h2{
      font-size: 24px !important;
    }
    .section-header h1{
      font-size: 1.5rem !important;
    }
}
@media (max-width: 500px) {
    #intro iframe {
        min-width: 50%; /* Increase width for zoom effect on smaller screens */
        min-height: 50%; /* Increase height for zoom effect on smaller screens */
        width: 110vh;
        height: 110vw;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        margin-top: 10px;
    }

        .section-header {
      margin-top: 15px !important;
      margin-bottom: 20px !important;
      padding-bottom: 10px !important;
    }
    .section-header h2{
      font-size: 20px !important;
    }
    .section-header h1{
      font-size: 1.25rem !important;
    }
}

#intro h2 {
  color: #fff;
  font-family: Arial, sans-serif;
  font-size: 56px;
  font-weight: 600;
  text-transform: uppercase;
}

#intro h2 span {
  color: #f82249;
}
 #intro h1{
    font-size: 2rem;
    color: #fff;
  }
   #intro h3{
    font-size: 2rem;
    color: #fff;
  }

#intro p {
  color: #ebebeb;
  font-weight: 700;
  font-size: 20px;
}

#intro .play-btn {
  width: 94px;
  height: 94px;
  background: radial-gradient(#f82249 50%, rgba(101, 111, 150, 0.15) 52%);
  border-radius: 50%;
  display: block;
  position: relative;
  overflow: hidden;
}

#intro .play-btn::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-40%) translateY(-50%);
  transform: translateX(-40%) translateY(-50%);
  width: 0;
  height: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid #fff;
  z-index: 100;
  transition: all 400ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

#intro .play-btn:before {
  content: '';
  position: absolute;
  width: 120px;
  height: 120px;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation: pulsate-btn 2s;
  animation: pulsate-btn 2s;
  -webkit-animation-direction: forwards;
  animation-direction: forwards;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-timing-function: steps;
  animation-timing-function: steps;
  opacity: 1;
  border-radius: 50%;
  border: 2px solid rgba(163, 163, 163, 0.4);
  top: -15%;
  left: -15%;
  background: rgba(198, 16, 0, 0);
}

#intro .play-btn:hover::after {
  border-left: 15px solid #f82249;
  -webkit-transform: scale(20);
  transform: scale(20);
}

#intro .play-btn:hover::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-40%) translateY(-50%);
  transform: translateX(-40%) translateY(-50%);
  width: 0;
  height: 0;
  border: none;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid #fff;
  z-index: 200;
  -webkit-animation: none;
  animation: none;
  border-radius: 0;
}

#intro .about-btn {
  font-family: Arial, sans-serif;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 12px 32px;
  border-radius: 50px;
  transition: 0.5s;
  line-height: 1;
  margin: 10px;
  color: #fff;
  -webkit-animation-delay: 0.8s;
  animation-delay: 0.8s;
  border: 2px solid #f82249;
}

#intro .about-btn:hover {
  background: #f82249;
  color: #fff;
}

@-webkit-keyframes pulsate-btn {
  0% {
    -webkit-transform: scale(0.6, 0.6);
    transform: scale(0.6, 0.6);
    opacity: 1;
  }

  100% {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    opacity: 0;
  }
}

@keyframes pulsate-btn {
  0% {
    -webkit-transform: scale(0.6, 0.6);
    transform: scale(0.6, 0.6);
    opacity: 1;
  }

  100% {
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    opacity: 0;
  }
}

/*--------------------------------------------------------------
# About Section
--------------------------------------------------------------*/

#about {
  background: url("../img/about-bg.jpg");
  background-size: cover;
  overflow: hidden;
  position: relative;
  color: #fff;
  padding: 60px 0 40px 0;
}

#about:before {
  content: "";
  background: rgba(13, 20, 41, 0.8);
  position: absolute;
  bottom: 0;
  top: 0;
  left: 0;
  right: 0;
}

#about h2 {
  font-size: 36px;
  font-weight: bold;
  margin-bottom: 10px;
  color: #fff;
}

#about h3 {
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 10px;
  color: #fff;
}

#about p {
  font-size: 14px;
  margin-bottom: 20px;
  color: #fff;
}

/*--------------------------------------------------------------
# Speakers Section
--------------------------------------------------------------*/

#about-us {
  padding: 10px 0 30px 0;
}

#about-us .about-us-item {
  position: relative;
  overflow: hidden;
  margin-bottom: 30px;
}

#about-us .about-us-item .details {
  background: rgba(6, 12, 34, 0.76);
  position: absolute;
  left: 0;
  bottom: -30px;
  right: 0;
  text-align: center;
  padding-top: 10px;
  transition: all 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

#about-us .about-us-item .details h3 {
  color: #fff;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 5px;
}

#about-us .about-us-item .details p {
  color: #fff;
  font-size: 15px;
  margin-bottom: 10px;
  font-style: italic;
}

#about-us .about-us-item .details .social {
  height: 30px;
}

#about-us .about-us-item .details a {
  color: #fff;
}

#about-us .about-us-item .details a:hover {
  color: #f82249;
}

#about-us .about-us-item:hover .details {
  bottom: 0;
}

#about-us-details {
  padding: 60px 0;
}

#about-us-details .details h2 {
  color: #112363;
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 10px;
}

#about-us-details .details .social {
  margin-bottom: 15px;
}

#about-us-details .details .social a {
  background: #e9edfb;
  color: #112363;
  line-height: 1;
  display: inline-block;
  text-align: center;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  padding-top: 9px;
}

#about-us-details .details .social a:hover {
  background: #f82249;
  color: #fff;
}

#about-us-details .details .social a i {
  font-size: 18px;
}

#about-us-details .details p {
  color: #112363;
  font-size: 15px;
  margin-bottom: 10px;
}





/*--------------------------------------------------------------
# Contact Section
--------------------------------------------------------------*/

#contact {
  
}

#contact .contact-info {
  margin-bottom: 20px;
  text-align: center;
}

#contact .contact-info i {
  font-size: 48px;
  display: inline-block;
  margin-bottom: 10px;
  color: #f82249;
}

#contact .contact-info address,
#contact .contact-info p {
  margin-bottom: 0;
  color: #112363;
}

#contact .contact-info h3 {
  font-size: 18px;
  margin-bottom: 15px;
  font-weight: bold;
  text-transform: uppercase;
  color: #112363;
}

#contact .contact-info a {
  color: #4869df;
}

#contact .contact-info a:hover {
  color: #f82249;
}

#contact .contact-address,
#contact .contact-phone,
#contact .contact-email {
  margin-bottom: 20px;
}

#contact .form #sendmessage {
  color: #f82249;
  border: 1px solid #f82249;
  display: none;
  text-align: center;
  padding: 15px;
  font-weight: 600;
  margin-bottom: 15px;
}

#contact .form #errormessage {
  color: red;
  display: none;
  border: 1px solid red;
  text-align: center;
  padding: 15px;
  font-weight: 600;
  margin-bottom: 15px;
}

#contact .form #sendmessage.show,
#contact .form #errormessage.show,
#contact .form .show {
  display: block;
}

#contact .form .validation {
  color: red;
  display: none;
  margin: 0 0 20px;
  font-weight: 400;
  font-size: 13px;
}

#contact .form input,
#contact .form textarea {
  padding: 10px 14px;
  border-radius: 0;
  box-shadow: none;
  font-size: 15px;
}

#contact .form button[type="submit"] {
  background: #f82249;
  border: 0;
  padding: 10px 40px;
  color: #fff;
  transition: 0.4s;
  border-radius: 50px;
  cursor: pointer;
}

#contact .form button[type="submit"]:hover {
  background: #e0072f;
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/

#footer {
 /* background: #101522; OLD */
  padding: 0 0 0 0;
  color: #eee;
  font-size: 14px;
  width: 100vw;
    margin: 0 !important;
}

#footer .footer-top {
  /* background: #040919; OLD */
  background: rgba(4, 9, 25, 0.4);
  padding: 60px 0 0px 0;
  margin-top: 30px;
}

#footer .footer-top .footer-info {
  margin-bottom: 30px;
}

#footer .footer-top .footer-info h3 {
  font-size: 26px;
  margin: 0 0 20px 0;
  padding: 2px 0 2px 0;
  line-height: 1;
  font-family: Arial, sans-serif;
  font-weight: 700;
  color: #fff;
}

#footer .footer-top .footer-info img {
  width: 80%;
  height: auto;
  margin-bottom: 10px;
}

#footer .footer-top .footer-info p {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 0;
  font-family: Arial, sans-serif;
  color: #fff;
}

#footer .footer-top .social-links a {
  font-size: 18px;
  display: inline-block;
  background: #222636;
  color: #eee;
  line-height: 1;
  padding: 8px 0;
  margin-right: 4px;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
  margin-top: 20px;
}

#footer .footer-top .social-links a:hover {
  background: #f82249;
  color: #fff;
}

#footer .footer-top h4 {
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  text-transform: uppercase;
  position: relative;
  padding-bottom: 12px;
  border-bottom: 2px solid #f82249;
}

#footer .footer-top .footer-links {
  margin-bottom: 30px;
}

#footer .footer-top .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

#footer .footer-top .footer-links ul i {
  padding-right: 5px;
  color: #f82249;
  font-size: 18px;
}

#footer .footer-top .footer-links ul li {
  border-bottom: 1px solid #262c44;
  padding: 10px 0;
}

#footer .footer-top .footer-links ul li:first-child {
  padding-top: 0;
}

#footer .footer-top .footer-links ul a {
  color: #eee;
}

#footer .footer-top .footer-links ul a:hover {
  color: #f82249;
}

#footer .footer-top .footer-contact {
  margin-bottom: 30px;
}

#footer .footer-top .footer-contact p {
  text-color: #ffffff;
  color: #FFF;
  margin-left: 0;
  padding-left: 0;
  line-height: 26px;
}
#footer .footer-top .footer-contact ul {
  padding-inline-start: 10px;
}
#footer .footer-top .footer-contact ul li {
  text-color: #ffffff;
  color: #FFF;
  line-height: 26px;
}
#footer .footer-top .footer-contact ul li a {
  color: #FFF;
}
#footer .footer-top .footer-newsletter {
  margin-bottom: 30px;
}

#footer .footer-top .footer-newsletter input[type="email"] {
  border: 0;
  padding: 6px 8px;
  width: 65%;
}

#footer .footer-top .footer-newsletter input[type="submit"] {
  background: #f82249;
  border: 0;
  width: 35%;
  padding: 6px 0;
  text-align: center;
  color: #fff;
  transition: 0.3s;
  cursor: pointer;
}

#footer .footer-top .footer-newsletter input[type="submit"]:hover {
  background: #e0072f;
}

#footer .copyright {
  text-align: center;
  padding-top: 30px;
  background-color: #060c22fa !important;
}

#footer .credits {
  text-align: center;
  font-size: 13px;
  color: #fff;
  padding-bottom: 10px;
  background-color: #060c22fa !important;
}
#footer .credits a {
  color: #fff;
}


/*--------------------------------------------------------------
# Responsive Media Queries
--------------------------------------------------------------*/

@media (min-width: 767px) {
  #subscribe input {
    min-width: 501px;
  }
}

@media (min-width: 768px) {
  #contact .contact-address,
  #contact .contact-phone,
  #contact .contact-email {
    padding: 20px 0;
  }

  #contact .contact-phone {
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
  }

}

@media (min-width: 991px) {
  #schedule .sub-heading {
    width: 75%;
  }
}

@media (min-width: 1024px) {
  #intro {
    background-attachment: fixed;
  }

  #about {
    background-attachment: fixed;
  }

  #subscribe {
    background-attachment: fixed;
  }
}

@media (max-width: 1199px) {
  #header .container {
    max-width: 100%;
  }

  .nav-menu a {
    padding: 8px 4px;
  }
}

@media (max-width: 991px) {
  #header {
    background: rgba(6, 12, 34, 0.98);
    height: 70px;
    padding: 15px 0;
    transition: all 0.5s;
  }

  #nav-menu-container {
    display: none;
  }

  #mobile-nav-toggle {
    display: inline;
    left: 15px;
    top: 5px;
  }

  #intro .intro-container {
    top: 70px;
  }

  #intro h2 {
    font-size: 34px;
  }

  #intro p {
    font-size: 16px;
  }

  #schedule .nav-tabs a {
    padding: 8px 60px;
  }


}

@media (max-width: 768px) {
  .back-to-top {
    bottom: 15px;
  }

  #faq #faq-list a {
    font-size: 18px;
  }

  #faq #faq-list i {
    top: 13px;
  }
   #intro h1{
    font-size: 1.5rem;
    color: #fff;
  }
  #intro h3{
    font-size: 1.5rem;
    color: #fff;
  }
}

@media (max-width: 767px) {
  #schedule .nav-tabs a {
    padding: 8px 50px;
  }
}

@media (max-width: 574px) {
  #venue .venue-info h3 {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  #schedule .nav-tabs a {
    padding: 8px 30px;
  }
}

@media (max-width: 460px) {
  #subscribe button {
    margin-top: 10px;
  }
  #intro h1{
    font-size: 1rem;
    color: #fff;
  }
  #intro h3{
    font-size: 1rem;
    color: #fff;
  }
}
  .whatsapp-icon {
    position: fixed;
    bottom: 15px;
    right: 15px;
    width: 60px;
    height: 60px;
  
    background-color: #25D366;
    color: white;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    text-decoration: none;
    font-size: 30px;
    transition: opacity 0.3s;

}

.whatsapp-options {
    position: fixed;
    bottom: 80px; /* Adjust position to appear above the icon */
    right: 5px;
    border-radius: 5px;
    z-index: 1001;
    padding: 5px;
    width: 200px; /* Adjust width as needed */
    color: #000;
    display: flex;
    gap: 10px;
    flex-direction: column;
}
.whatsapp-options i {
    font-size: 2rem;
    color: #25D366;
}
.whatsapp-option {
  border-radius: 10px;
    padding: 10px;
    display: flex;
    gap: 5px;
    align-items: center;
    background-color: white;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    cursor: pointer;

}
.whatsapp-option p {
    padding: 0 !important;
    margin-bottom: 0 !important;
    
}
.whatsapp-option:hover {
    background-color: #f0f0f0; /* Highlight on hover */
}

@media (max-width: 768px) {
  .whatsapp-options {
    bottom: 60px; /* Adjust position to appear above the icon */
    gap: 5px;
}
.whatsapp-options i {
    font-size: 1.5rem;
    color: #25D366;
}
.whatsapp-option p {
  font-size: 0.8rem;
    
}
}
.bottom-navbar {
  overflow: hidden;
  background-color: #060c22fa !important;
  position: fixed;
  bottom: 0;
  width: 100%;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  z-index: 999;
  max-width: 100vw;
}

.bottom-navbar a {
  flex: 1;
  color: #f2f2f2;
  text-align: center;
  padding: 10px 0;
  text-decoration: none;
  font-size: 17px;
  position: relative;
  overflow: visible;
}

.bottom-navbar a i {
  font-size: 24px;
  display: block;
  transition: transform 0.3s ease;
}

.bottom-navbar a:hover {
  background: #f1f1f1;
  color: black;
}

.bottom-navbar a:hover i {
  transform: scale(1.4); /* Zoom ikon 2 kali saat hover */
  z-index: 1; /* Pastikan ikon berada di atas elemen lain */
}
.bottom-navbar a.active {
  background-color: #ffffff;
  color: #060c22fa;

}
.bottom-navbar a i.active {
  color: #060c22fa;
}

.divider {
  width: 1px;
  background-color: #888;
  height: 40px;
}
@media  (max-width: 500px){
  .bottom-navbar a {
  font-size: 12px !important;
}
.bottom-navbar a i {
  font-size: 15px;
}
}
@media (min-width: 501px) and (max-width: 768px) {
.bottom-navbar a {
  font-size: 14px !important;
}
.bottom-navbar a i {
  font-size: 20px;
}
}
@media (max-width: 1024px) {
  .bottom-navbar {
    display: flex; /* Ensure it's visible on smaller devices */
  }
  .whatsapp-icon{
    display: none;
  }
}

@media (min-width: 1025px) {
  .bottom-navbar {
    display: none; /* Hide on desktop */
  }
}

#products {
    width: 100%;
    margin: 0 !important;
    padding: 20px;
    /* background: #0c22fa; OLD */

    position: relative;
}



.product {
    border: 1px solid #e0e5fa;
    background: #fff;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease-out;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    overflow: hidden;
}

.product-img {
    overflow: hidden;
    padding: 15px;
    margin-bottom: 15px;
}

.product-img img {
    width: 100%;
    height: auto;
    border-radius: 15px;
    transition: transform 0.3s ease-in-out;
}

.product:hover .hotel-img img {
    transform: scale(1.1);
}

h3 {
    font-weight: 600;
    font-size: 20px;
    margin-bottom: 5px;
    padding: 0 20px;
}

a {
    color: #152b79;
    text-decoration: none;
}

a:hover {
    color: #f82249;
}

.stars {
    padding: 0 20px;
    margin-bottom: 5px;
}

.stars i {
    color: #ffc31d;
}

p {
    padding: 0 20px;
    margin-bottom: 20px;
    color: #060c22;
    font-style: italic;
    font-size: 15px;
}

.swiper-button-next, .swiper-button-prev {
    color: #000;
}

.swiper-pagination-bullet-active {
    background: #04AA6D;
}

@media (max-width: 767px) {
    #products {
        padding: 10px;
    }

    .product {
        margin: 10px 0;
    }
}

/**baru**/


 #catalog {
width: 100vw;
}
.catalog-wrapper {
      display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px 20px;
    width: 100vw;
    margin: 0 !important;
}

.catalog-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 80%;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    background-color: #fff;
    transition: flex-direction 0.3s ease;
}

.catalog-image {
    width: 100%; /* Lebar tetap 50% */
    height: 100%; /* Tinggi mencakup seluruh card */
    object-fit: cover; /* Memastikan gambar memenuhi area */
    object-position: center; /* Memusatkan gambar */
}
.catalog-card img {
    width: 100%; /* Lebar tetap 50% */
    height: 100%; /* Tinggi mencakup seluruh card */
    object-fit: cover; /* Memastikan gambar memenuhi area */
    object-position: center; /* Memusatkan gambar */

}


.catalog-content {
    padding: 20px;
    text-align: center;
    color: #060c22;
}

.catalog-content h2 {
    font-size: 24px;
    margin-bottom: 20px;
    font-weight: bold;
}
.catalog-content p{
  text-indent: unset;
  padding: 0 !important;
}


.catalog-button {
    display: inline-flex;
    align-items: center;
    padding: 10px 20px;
    background-color: #060c22;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    text-decoration: none;
}

.catalog-button i {
    margin-right: 10px;
}

.catalog-button:hover {
    background-color: #f82249;
}

@media (min-width: 1024px) {
  .catalog-card {
        flex-direction: row;
        max-width: 90% ;
    }
    .catalog-image {
        width: 50%;
    }
    .catalog-card img {
        width: 50%;
    }

    .catalog-content {
        text-align: left;
        padding: 20px 40px;
    }
}
@media (min-width: 769px) and (max-width: 1023px){
    .catalog-card {
        flex-direction: row;
        max-width: 94%;
    }

    .catalog-image {
        width: 50%;
    }
    .catalog-card img {
        width: 50%;
    }

    .catalog-content {
        text-align: left;
        padding: 20px 40px;
    }
}

@media (max-width: 768px) {
    .catalog-card {
        flex-direction: column;
        max-width: 96%;
    }

    .catalog-content h2 {
        font-size: 20px;
    }
}

@media (max-width: 480px) {
    .catalog-content h2 {
        font-size: 18px;
    }

    .catalog-button {
        font-size: 14px;
        padding: 8px 16px;
    }
}

/**card product**/

    #product {
    display: flex;
    width: 100vw;
    margin: 0 !important;
    overflow: hidden;

    /* background-color: #060c22fa; OLD */
    /**background-color: rgba(2, 12, 34, 0.9);**/
    position: relative;
}

.slider-wrapper {
    display: flex;
    width: 100%;
    overflow: hidden;
    position: relative;
    justify-content: center !important;
}

/*.product-slider {
    display: flex;
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100%; 
    flex-direction: column; 
}*/

.product-container {
    display: flex;
    flex-wrap: nowrap; /* Ensure horizontal scrolling */
    transition: transform 0.5s ease-in-out;
    width: 100%;
    padding-bottom: 30px;
    margin-bottom: 30px;
}
.product-slider {
    display: flex;
    overflow: hidden;
    width: 100%;
}

/* Container for product cards */
/*.product-container {
    display: flex;
    align-items: stretch; 
    width: 100%;
}*/

.product-card {
    width: 100%; /* Make product-card take full width of swiper-slide */
    box-sizing: border-box;
    background-color: #ffffff;
    border-radius: 10px;
    box-shadow: 0 8px 10px rgba(0, 0, 0, 0.2);
    margin: 0; /* Remove margin */
    transition: transform 0.3s ease;
    display: flex;
    margin-right: 10px;
    flex-direction: column; /* Ensures content stretches to fill the card */
    height: 100%; /* Follows the height of the swiper-slide */
    z-index: 0;
    cursor: pointer;
}

.product-card img {
    width: 100%;
    border-radius: 10px 10px 0 0;
    aspect-ratio: 512 / 401;
}

.product-card-content {
    padding: 15px;
}

.product-card-title {
    font-size: 24px;
    margin-bottom: 15px;
    color: #060c22fa;
    font-weight: 700;
    text-align: center;
}

.color-options {
    display: flex;
    margin-bottom: 10px;
}

.color-options div {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 5px;
    cursor: pointer;
    border: 1px solid #cccccc;
}

.color-default { background-color: #060c22fa; }
.color-red { background-color: red; }
.color-green { background-color: green; }
.color-blue { background-color: blue; }

.description {
    font-size: 14px;
    color: #666666;
    margin-bottom: 10px;
    text-align: center;
}

.size-options {
    display: flex; /* Align children horizontally */
    gap: 10px;
    flex-direction: row;
    margin-bottom: 10px;
    justify-content: center; /* Centers items horizontally */
    align-items: center; /* Aligns items vertically if needed */
}

.size-box {
    background-color: #060c22fa; /* Blue background */
    color: #ffffff; /* White text color */
    padding: 5px 10px;
    border-radius: 20px; /* Rounded corners */
    cursor: pointer;
    font-size: 12px;
    text-align: center;
    box-sizing: border-box;
    border: none; /* Remove any default borders */
    display: inline-flex; /* Ensure text is centered properly */
    align-items: center; /* Center text vertically */
    justify-content: center; /* Center text horizontally */
}
.color-buttons {
  display: flex; /* Align children horizontally */
    gap: 10px;
    flex-direction: row;
    margin-bottom: 15px;
}
.color-options {
    padding: 5px 10px;
    border-radius: 15px;
    font-size: 0.9em;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative; /* Required for the shadow effect */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4), 0 8px 10px rgba(0, 0, 0, 0.2);
}

.color-box {
     background-color: white;
    color: #060c22fa;
    border: 2px solid #060c22fa;
}

.color-box:hover {
    background-color: #060c22fa; /* Change color on hover */
    color: white; /* Change text color on hover */
}

.navigation {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 10%; /* 10% for the navigation buttons */
    height: 100%;
    display: flex;
    padding-top: 80px;
    flex-direction: column; /* Stack buttons vertically */
    justify-content: center;
    align-items: center;
    gap: 10px; /* Space between buttons */
    right: 0;
    z-index: 1;
}

.navigation button {
    border: none;
    background-color: #f82249;
    color: white;
    width: 60px; /* Adjust width for buttons */
    height: 60px; /* Twice the height for vertical buttons */
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.3s;
    font-size: 24px;

}

.navigation button:hover {
    background-color: #060c22fa;
}
/* Button styles */
.product-buttons {
    display: flex;
    justify-content: center;
    gap: 10px;
}

.btn {
    padding: 10px 20px;
    border-radius: 20px;
    font-size: 0.9em;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4), 0 8px 10px rgba(0, 0, 0, 0.2);
}

.buy-btn {
    padding: 10px 40px !important;
    background-color: #f82249;
    color: white;
    border: none;
    width: 100%;
    font-weight: bold;
    text-transform: uppercase;
}
.buy-btn:hover {
  color: white;
}

.sample-btn {
    background-color: white;
    color: #f82249;
    border: 2px solid #f82249;
}

.btn:hover {
    opacity: 0.8;
}
@media (max-width: 500px){
  .size-box {
    padding: 5px 5px;
    border-radius: 10px; /* Rounded corners */
    font-size: 10px;
  }
 .product-card {
        width: 85%; /* Make cards larger on mobile */
    }
    .product-slider {
        width: 100% !important;
    }
    .slider-wrapper {
        width: 100% !important;
        margin-bottom: 100px;
    }
    .product-card-content {
        padding: 10px !important;
    }
    .description {
        margin-bottom: 0px !important;
    }
    .navigation {
        top: auto;
        bottom: 5px !important;
        width: 100%;
        height: auto;
        flex-direction: row;
        justify-content: center; 
        gap: 10px;
        margin-top: 15px !important;
    }

    .navigation button {
        width: 50px;
        height: 50px;
    }

    .product-buttons {
        flex-direction: column; /* Stack buttons vertically */
        gap: 5px; /* Smaller gap between buttons */
    }

    .btn {
        padding: 8px 15px; /* Smaller padding for buttons */
        font-size: 0.8em; /* Smaller font size for text */
        width: 100%; /* Ensure buttons take full width of the container */
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4), 0 4px 6px rgba(0, 0, 0, 0.2); /* Adjust shadow for smaller buttons */
    }

    .buy-btn {
        padding: 8px 20px !important; /* Adjust padding for the buy button */
    }
}
@media  (min-width: 501px) and (max-width: 768px) {
      .product-card {
        width: 50%; /* Make cards larger on mobile */
    }
    .product-slider {
        width: 100% !important;
    }
    .slider-wrapper {
        width: 100% !important;
        margin-bottom: 160px;
    }
    .product-card-content {
        padding: 10px !important;
    }
    .description {
        margin-bottom: 0px !important;
    }
    .navigation {
        top: auto;
        bottom: 90px;
        width: 100%;
        height: auto;
        flex-direction: row;
        justify-content: center; 
        gap: 10px;
        margin-top: 15px !important;
    }

    .navigation button {
        width: 50px;
        height: 50px;
    }

    .product-buttons {
        flex-direction: column; /* Stack buttons vertically */
        gap: 5px; /* Smaller gap between buttons */
    }

    .btn {
        padding: 8px 15px; /* Smaller padding for buttons */
        font-size: 0.8em; /* Smaller font size for text */
        width: 100%; /* Ensure buttons take full width of the container */
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4), 0 4px 6px rgba(0, 0, 0, 0.2); /* Adjust shadow for smaller buttons */
    }

    .buy-btn {
        padding: 8px 20px !important; /* Adjust padding for the buy button */
    }
}
@media (min-width: 768px) and (max-width: 1024px){
    .product-card {
        width: 40%; /* Make cards larger on mobile */
    }
    .product-slider {
        width: 100% !important;
    }
    .slider-wrapper {
        width: 100% !important;
        margin-bottom: 160px;
    }
    .product-card-content {
        padding: 10px !important;
    }
    .description {
        margin-bottom: 0px !important;
    }
    .navigation {
        top: auto;
        bottom: 90px;
        width: 100%;
        height: auto;
        flex-direction: row;
        justify-content: center; 
        gap: 10px;
        margin-top: 15px !important;
    }

    .navigation button {
        width: 50px;
        height: 50px;
    }

    .product-buttons {
        flex-direction: column; /* Stack buttons vertically */
        gap: 5px; /* Smaller gap between buttons */
    }

    .btn {
        padding: 8px 15px; /* Smaller padding for buttons */
        font-size: 0.8em; /* Smaller font size for text */
        width: 100%; /* Ensure buttons take full width of the container */
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4), 0 4px 6px rgba(0, 0, 0, 0.2); /* Adjust shadow for smaller buttons */
    }

    .buy-btn {
        padding: 8px 10px !important; /* Adjust padding for the buy button */
    }
}

@media (min-width: 1024px) and (max-width: 1366px){
   .btn {
        padding: 8px 15px; /* Smaller padding for buttons */
        font-size: 0.8em; /* Smaller font size for text */
        width: 100%; /* Ensure buttons take full width of the container */
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4), 0 4px 6px rgba(0, 0, 0, 0.2); /* Adjust shadow for smaller buttons */
    }

    .buy-btn {
        padding: 8px 10px !important; /* Adjust padding for the buy button */
    }
}

/*FILTER KATEGORI */
.category-filter {
    margin-bottom: 30px;
    text-align: center;
}

.category-filter ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    gap: 10px;
    flex-wrap: wrap;
}

.category-filter li {
    background-color: #060c22fa;
    color: white;
    padding: 10px 20px;
    border-radius: 20px;
    border: 2px solid white;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.category-filter li:hover,
.category-filter li.active {
    background-color: #f82249;
    color: white;
}

@media (max-width: 399px) {
.category-filter li {
  padding: 5px 10px;
  font-size: 12px;
}
}

@media (min-width: 501px) and (max-width: 768px) {
  .category-filter li {
  padding: 8px 11px;
  font-size: 14px;
}
}
@media (min-width: 769px) and (max-width: 1366px) {
  .category-filter li {
  padding: 8px 12px;
  font-size: 14px;
}
}

/** LATEST PRODUK INDEX **/
#latest-product {
    display: flex;
    width: 100vw;
    margin: 0 !important;
    overflow: hidden;
    background-color: white; /* Background putih untuk section ini */
    position: relative;
}

.latest-product-container {
    display: flex;
    flex-wrap: nowrap; /* Ensure horizontal scrolling */
    transition: transform 0.5s ease-in-out;
    width: 100%;
    padding-bottom: 30px;
    margin-bottom: 30px;
}
.latest-product-slider {
    display: flex;
    overflow: hidden;
    width: 100%;
}
.slider-wrapper-latest {
    display: flex;
    width: 100%;
    overflow: hidden;
    position: relative;
}
.product-slider-latest {
    display: flex;
    overflow: hidden;
    width: 100%;
}


.latest-product-card {
    width: 100%; /* Make product-card take full width of swiper-slide */
    box-sizing: border-box;
    background-color: #ffffff;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
    display: flex;
    margin-right: 10px;
    flex-direction: column; /* Ensures content stretches to fill the card */
    height: 100%; /* Follows the height of the swiper-slide */
}

.latest-product-card img {
    width: 100%;
    height: auto;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    object-fit: cover; /* Cover mode to ensure the image fits within the card */
    height: auto; /* Fixed height to maintain consistency */
}

.latest-product-card-content {
    display: flex;
    flex-direction: column;
    margin: 15px;
    height: 100%;
    justify-content: flex-start;
}

.latest-product-card-title, .latest-description {
    min-height: 90px;
    margin: 0;
    font-size: 24px;
    margin-bottom: 15px;
    color: #060c22fa;
    font-weight: 700;
    padding: 10px 0;
    text-align: center; /* Center text */
}

.latest-description {
    font-size: 12px;
    color: #333;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* Limit text to 3 lines */
    -webkit-box-orient: vertical;
}

/* Ensure the .latest-product-container has padding at the bottom */
.latest-product-container {
    padding-bottom: 80px; /* Make space for navigation buttons */
}

/* Style for the navigation container */
.latest-product-navigation {
    position: relative;
    margin-top: 20px;
    bottom: 70px; /* Positioned 20px from the bottom of the .latest-product-slider */
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center; /* Center the navigation buttons */
    align-items: center;
    gap: 10px; /* Space between buttons */
    z-index: 10; /* Ensure it is on top of other content */
    width: 100%; /* Make sure navigation takes full width */
}

/* Style for each navigation button */
.latest-product-navigation button {
    border: 2px solid white;
    background-color: #060c22fa;
    color: white;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.3s;
    font-size: 24px; /* Adjust size of the icon */
}

/* Hover effect for buttons */
.latest-product-navigation button:hover {
    background-color: #f82249;
}

@media (max-width: 500px) {

/*    .latest-product-card {
        flex: 0 0 90%;
        width: 70%; 
        margin-right: 10px;
    }
*/
    .latest-product-navigation {
        width: 100%;
    }
    .latest-product-card img {
    max-height: 300px;
    }
    .latest-product-navigation button {
        width: 40px;
        height: 40px;
    }

.latest-product-card-title {
    font-size: 17px;
    margin-bottom: 0px;
    font-weight: 600;
    padding: 7px 0;
    min-height: 70px;
}
.product-price {
  font-size: 12px;
  margin-top: 7px;
  color: #040919 !important;
}
.product-color-info {
  font-size: 12px;
}

.color-bullet {
    width: 15px; /* Adjust the width as needed */
    height: 15px; /* Adjust the height as needed */
}
.rupiah-icon {
    width: 15px; /* Adjust the width as needed */
    height: 15px; /* Adjust the height as needed */
}
}

@media  (min-width: 501px) and (max-width: 768px) {

.latest-product-card-title {
    font-size: 19px;
    margin-bottom: 0px;
    color: #060c22fa;
    font-weight: 600;
    padding: 7px 0;
}
  .product-color-info {
  font-size: 12px;
}
.latest-product-card img {
    max-height: 270px;
  }

  .product-price {
  font-size: 13px;
  margin-top: 7px;
}
/*    .latest-product-card {
        flex: 0 0 70%;
        width: 70%; 
        margin-right: 10px;
    }*/

    .latest-product-navigation {
        width: 100%;
    }

    .latest-product-navigation button {
        width: 40px;
        height: 40px;
    }
    .color-bullet {
    width: 20px; /* Adjust the width as needed */
    height: 20px; /* Adjust the height as needed */
}
.rupiah-icon {
    width: 20px; /* Adjust the width as needed */
    height: 20px; /* Adjust the height as needed */
}
}
@media (min-width: 768px) and (max-width: 1024px) {
  .product-price {
  font-size: 13px;
  margin-top: 7px;
}
/*      .latest-product-card {
        flex: 0 0 50%;
        width: 70%; 
        margin-right: 10px;
    }*/

    .latest-product-navigation {
        width: 100%;
    }

    .latest-product-navigation button {
        width: 40px;
        height: 40px;
    }
}
.product-color-info {
  font-size: 14px;
    display: flex;
    align-items: center; /* Align items vertically centered */
}
.product-color-info-top {
  font-size: 14px;
    display: flex;
    align-items: center; /* Align items vertically centered */
}


.color-bullet {
    display: inline-block;
    width: 25px; /* Adjust the width as needed */
    height: 25px; /* Adjust the height as needed */
    border-radius: 50%;
    margin-right: 5px; /* Add some spacing between the bullet and the text */
}

.product-price {
  font-size: 14px;
  margin-top: 15px;
    display: flex;
    align-items: center; /* Aligns the icon and price text vertically */
    padding: 0 0 10px 0; /* Adds padding only to the bottom */
}

.rupiah-icon {
    width: 25px !important; /* Fixed width for the icon */
    height: 25px !important; /* Fixed height for the icon */
    margin-right: 5px; /* Adds space between the icon and the price text */
    display: inline-block; /* Ensures the span is displayed inline */
    background-image: url('../img/icon/rupiah2.png'); /* Set the path to your image */
    background-size: contain; /* Ensures the image scales to fit the span */
    background-repeat: no-repeat; /* Prevents the background image from repeating */
    background-position: center; /* Centers the image within the span */
}


/**MAPS TOKO**/
#store-section {
    background-color: #060c22fa; /* Background color with transparency */
    color: #ffffff;
    display: flex;
    flex-direction: column;
    min-height: 70vh;
    position: relative;
    width: 100vw;
    margin: 0 !important;
}

.global-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.global-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.card-toko {
    position: relative;
    margin: 20px auto;
  /* Adjust as needed */
    background: #ffffff;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 20px;
    border: 1px solid #ddd;
    z-index: 2;
}

.card-toko h1 {
    font-size: 24px;
    margin-bottom: 20px;
    color: #333;
    text-align: center;
}

.store-list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    width: 100%;
}

.store-content {
    display: flex;
    width: 100%;
    max-width: 30%; /* Set maximum width to allow 3 items per row */
    flex-basis: 30%; /* Adjust width for each store content */
    box-sizing: border-box;
    padding: 10px;
    flex-direction: column;
    border-bottom: 1px solid #ddd;
}

.store-sub-content {
  display: flex;
  width: 100%;
  flex-direction: row;
}
.store-image {
    width: 15%;
    display: flex;
    justify-content: center;
    top: 20px;
}

.store-image img {
    width: 40px;
    height: 40px;
}

.store-item {
    width: 85%;
    padding-left: 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.store-item:last-child {
    border-bottom: none;
}

.store-item h2 {
    font-size: 20px;
    margin-bottom: 5px;
    color: #333;
}
.store-item h3 {
    font-size: 20px;
    margin-bottom: 5px;
    color: #333;
    padding: 0 !important;
}
@media (max-width: 500px){
  .store-item h3 {
    font-size: 15px;
    margin-bottom: 5px;
    color: #333;
}
}
.store-item p {
    font-size: 1rem;
    color: #666;
    margin-bottom: 10px;
    text-transform: lowercase; /* Semua huruf kecil */
}

.store-item p::first-letter {
    font-size: 1rem; /* Jika ingin huruf pertama lebih besar, bisa diatur */
    text-transform: uppercase; /* Huruf pertama menjadi besar */
}

.links {
    display: flex;
    gap: 15px;
    justify-content: center;
    flex-wrap: wrap;
    padding-bottom: 20px;
    padding-right: 15px;
    padding-left: 15px;
}

.link {
    color: #007bff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 5px;
}

.link i {
    font-size: 1.5rem;
}

.link:hover {
    border: 2px solid #f82249;
    border-radius: 25px;
    padding: 5px;
    color: #f82249;
}

.divider {
    border-top: 1px solid #ddd;
    margin: 10px 5px;
}

@media (min-width: 769px) {
    .store-item {
        width: 100%; /* Adjust to fit 3 items per row with gaps */
    }
    .store-list {
      justify-content: space-between;
    }
}

@media (max-width: 768px) {
    .store-content {
        max-width: 100%; /* Full width on smaller screens */
        flex-basis: 100%;
    }
}
/*container baru 31-08-2024 */
.custom-container {
    width: 92% ; /* Container width is 95% of the viewport width */
   /* Optional: Max width for larger screens */
    margin: 0 auto; /* Centers the container */
    padding: 20px; /* Optional: Padding for spacing inside the container */
    box-sizing: border-box; /* Ensures padding doesn't affect width calculation */
}

/* Optional: Responsive adjustments */
@media (max-width: 768px) {
    .custom-container {
        width: 98%;
        padding: 10px;
        display: flex; /* Use flexbox */
        justify-content: center; /* Center content horizontally */
        align-items: center; /* Center content vertically if needed */
        flex-direction: column;
    }
}

/* KENAPA KAMI */
#why-us {
    padding: 60px 0;
    background-color: #f9f9f9;
    width: 100vw;
    margin: 0 !important;
}

#why-us .section-header {
    text-align: center;
    margin-bottom: 40px;
}

#why-us .section-header h2 {
    font-size: 28px;
    font-weight: 700;
    color: #112363;
    margin-bottom: 10px;
}

#why-us .section-header p {
    font-size: 16px;
    color: #555;
    margin-bottom: 0;
}

.why-us-content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.why-us-item {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 20px;
    margin: 10px;
    width: calc(50% - 20px);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.why-us-item img {
    width: 70px;
    height: auto;
    margin-right: 10px;
}

.why-us-info {
    flex: 1;
}

.why-us-info h3 {
    font-size: 22px;
    color: #112363;
    margin-bottom: 10px;
}

.why-us-info p {
    font-size: 16px;
    color: #666;
    margin: 0;
}

/* Responsive styling */
@media (max-width: 768px) {
    .why-us-item {
        width: 100%;
    }
}
@media (max-width: 500px) {
    .why-us-item {
      padding: 0px;
        flex-direction: column; /* Gambar berada di atas teks */
        align-items: center; /* Center align untuk konten */
        width: 100%; /* Lebar penuh pada layar kecil */
        margin: 10px 0; /* Margin diatur agar responsif */
    }

    .why-us-item img {
        margin-right: 0; /* Hapus margin-right untuk tata letak vertikal */
        margin-bottom: 15px; /* Tambah jarak antara gambar dan teks */
        width: 60px; /* Sesuaikan ukuran gambar */
    }

    .why-us-info h3 {
        font-size: 18px; /* Sesuaikan ukuran font untuk layar kecil */
    }
    .why-us-info p {
        font-size: 18px; /* Sesuaikan ukuran font untuk layar kecil */
        padding: 0px !important;
    }

}
@media (max-width: 480px) {
    .why-us-item {
        padding: 15px;
    }

    .why-us-item img {
        width: 60px;
        height: auto;
        margin-right: 15px;
    }

    .why-us-info h3 {
        font-size: 18px;
    }

    .why-us-info p {
        font-size: 12px;
    }
}

/* Rekomendasi Kain */
#recommendation-section {
    padding: 60px 0;
    background-color: #060c22fa;
    color: white;
    width: 100vw;
    margin: 0 !important;
}

.section-header-recommendation h2 {
    text-align: center;
    margin-bottom: 30px;
    color: white;
    font-size: 28px;
    font-weight: 700;
}

.recommendation-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: flex-start; /* Menyusun item secara horizontal dan di bagian atas */
    flex-wrap: nowrap; /* Menjaga agar item tidak membungkus ke baris berikutnya */
}

.category-list {
    width: 40%;
    margin-right: 30px;
}

.category-list h3 {
    color: white;
    font-size: 22px;
    font-weight: 600;
    padding: 0;
    margin-left: 0 !important;
    margin-bottom: 15px;
}
.category-list img {
  max-width: 40px;
  height: auto;
  margin-right: 15px;
}

.category-list ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.category-list li {
    display: flex;
    align-items: center;
    padding: 10px;
    cursor: pointer;
    color: white;
    font-weight: 600;
    border: 2px solid transparent;
    border-radius: 5px;
    transition: background-color 0.3s, color 0.3s, border-color 0.3s;
    max-width: 100vw;
}

.category-list li:hover{
  background-color: transparent;
    color: white;
    border-radius: 30px;
    border: 2px solid #f82249;
}
.category-list li.active {
    background-color: transparent;
    color: white;
    border-radius: 30px;
    border: 2px solid;
    border-color: #f82249; /* Ini adalah warna default sebelum animasi dimulai */
    animation: border-rgb-animation 2s linear infinite; /* Durasi animasi 2 detik, dan looping terus-menerus */
}

.slider-container {
    width: 50%;
    position: relative;
    overflow: hidden;
}

.image-slider {
    display: flex;
    gap: 20px;
    transition: transform 0.5s ease-in-out;
}
@media (max-width: 768px) {
    .slide {
        width: 100%;  /* Tampilkan hanya 1 item */
        display: none; /* Sembunyikan semua slide secara default */
    }

    .slide.active {
        display: block; /* Hanya tampilkan slide yang aktif */
    }
}

.slide {
    min-width: 100%;
    flex: 0 0 30%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.slide img {
    width: 100%;
    height: auto;
    max-width: 350px;
    margin: 0 auto;
    display: block;
}
.dummy {
    display: none; /* Sembunyikan elemen dummy pada awal */
}
.clothing-name {
    margin-top: 10px;
    text-align: center;
    color: white;
    font-size: 18px;
    font-weight: 500;
}



.recommended-fabric {
    width: 40%;
    text-align: left;
}

.recommended-fabric h3 {
    color: white;
    font-size: 22px;
    font-weight: 600;
    padding: 0;
    margin-left: 0 !important;
    margin-bottom: 15px;
}

.recommended-fabric ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap; /* Membungkus item jika diperlukan */
    gap: 10px; /* Jarak antar item */
}

.recommended-fabric li {
    margin-bottom: 0;
}

.fabric-button {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 2px solid white;
    border-radius: 25px;
    color: white;
    padding: 10px 20px;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s;
    text-align: center; /* Mengatur teks agar rata tengah */
    height: 100%; /* Pastikan tombol mengisi tinggi yang tersedia */
    min-height: 50px; /* Atur tinggi minimum tombol jika diperlukan */
}

.fabric-button:hover {
    background-color: white;
    color: #060c22fa; /* Sesuaikan warna teks dengan warna latar belakang */
}
.fabric-button i {
   margin-left: 8px;
}
/*.fabric-button::after {
    src: 'img/icon/arrow.png';
    margin-left: 10px;
    width: 10px; 
}*/
@media (max-width: 500px){
.fabric-button {
      padding: 5px 10px;
    font-size: 12px;
    min-height: 30px;
}
 .category-list img {
  max-width: 20px;
  height: auto;
}
    .recommendation-wrapper {
        flex-direction: column;
        align-items: center;
    }

    .category-list, .recommended-fabric {
        width: 100%;
        text-align: center;
        margin-bottom: 20px;
    }

    .slider-container {
        width: 100%;
    }

    .slide {
        flex: 0 0 70%; /* Perbesar ukuran slide pada perangkat yang lebih kecil */
    }

    .category-list {
        width: 100%; /* Mengatur lebar penuh untuk kategori list */
        order: 1; /* Menyusun kategori list di atas */
    }

    .slider-container {
        width: 100%; /* Mengatur lebar penuh untuk slider */
        order: 2; /* Menyusun slider di bawah kategori list */
    }

    .recommended-fabric {
        width: 100%; /* Mengatur lebar penuh untuk rekomendasi kain */
        order: 3; /* Menyusun rekomendasi kain di bawah slider */
    }

    .quote-container {
        width: 100%; /* Mengatur lebar penuh untuk kutipan */
        order: 4; /* Menyusun kutipan di bawah rekomendasi kain */
        margin-top: 20px;
    }
    .quote {
    font-size: 14px !important;
}

.looping-text {
    font-size: 18px ;
    font-weight: bold;
}
}
@media (min-width: 501px) and (max-width: 768px) {
  .category-list img {
  max-width: 20px;
  height: auto;
}
    .recommendation-wrapper {
        flex-direction: column;
        align-items: center;
    }

    .category-list, .recommended-fabric {
        width: 100%;
        text-align: center;
        margin-bottom: 20px;
    }

    .slider-container {
        width: 100%;
    }

    .slide {
        flex: 0 0 70%; /* Perbesar ukuran slide pada perangkat yang lebih kecil */
    }

    .category-list {
        width: 100%; /* Mengatur lebar penuh untuk kategori list */
        order: 1; /* Menyusun kategori list di atas */
    }

    .slider-container {
        width: 100%; /* Mengatur lebar penuh untuk slider */
        order: 2; /* Menyusun slider di bawah kategori list */
    }

    .recommended-fabric {
        width: 100%; /* Mengatur lebar penuh untuk rekomendasi kain */
        order: 3; /* Menyusun rekomendasi kain di bawah slider */
    }

    .quote-container {
        width: 100%; /* Mengatur lebar penuh untuk kutipan */
        order: 4; /* Menyusun kutipan di bawah rekomendasi kain */
        margin-top: 20px;
    }
        .quote {
    font-size: 15px;
}
.looping-text {
    font-size: 18px;
    font-weight: bold;
}
}
.icon-category {
    margin-right: 10px;
    font-size: 20px; /* Sesuaikan ukuran ikon sesuai kebutuhan */
}


.quote-container {
    text-align: center;
    margin-top: 20px;
}

.quote {
    font-size: 18px;
    font-style: italic;
    margin-bottom: 10px;
    color: white;
}

.looping-text {
    font-size: 24px;
    font-weight: bold;
}

.dynamic {
    color: #f82249;
    transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.fixed {
    color: white;
}

.hidden {
    opacity: 0;
    transform: translateY(-20px);
}
.hidden-display {
    display: none;
}
@keyframes border-rgb-animation {
    0% {
        border-color: red;
    }
    33% {
        border-color: green;
    }
    66% {
        border-color: blue;
    }
    100% {
        border-color: red;
    }
}

/* button ajakan belanja */
.welcome-buttons {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
}

.welcome-btn {
    padding: 15px 30px;
    border-radius: 25px;
    font-size: 0.9em;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative; /* Required for the shadow effect */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4), 0 8px 10px rgba(0, 0, 0, 0.2);
}

.welcome-btn:hover{
    padding: 10px 20px;
    border-radius: 20px;
    font-size: 0.9em;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative; /* Required for the shadow effect */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4), 0 8px 10px rgba(0, 0, 0, 0.2);
    transform: scale(1.5);
}


.yuk-btn {
    background-color: #060c22fa;
    color: #ffffff;
    border: 2px solid transparent;
    animation: border-white-animation 3s ease-out infinite;
}

@keyframes border-white-animation {
    0% {
        border-color: white;

    }
    50% {
        border-color: #060c22fa;
    }
    100% {
        border-color: white;
    }
}
.yuk-btn i {
    color: #ffffff;
    width: 25px;
    height: auto;
    margin-left: 10px;
}

/* FASILITAS PRODUKSI */
#production-facility {
    background-color: #ffffff;
    padding: 60px 0;
    color: white;
    width: 100vw;
    margin: 0 !important;
}

.container-facility {
    display: flex;
    flex-direction: column;
    margin-top: 30px;
    gap: 10px;
    background-size: contain; /* Sesuaikan ukuran gambar */
    background-repeat: no-repeat;
    background-image: url('../img/maps-ok.webp'); 
    height: auto; /* Pastikan tinggi menyesuaikan isi */
    aspect-ratio: 2147 / 1080; /* Ganti dengan aspek rasio gambar Anda */
}
.full-column {
  width: 100%;
}


.column-a {
    width: 25%;
}

.column-a img {
    width: 100%;
    height: auto;
    border-radius: 10px; /* Opsional, jika ingin memberikan efek rounded */
}
.content-top {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
}
.content-bottom {
  margin-top: 40px;
  display: flex;
  flex-direction: row;
  align-items: baseline;
  justify-content: space-between;
}
.content-text {
  height: 150px;
}
.column-b {
    width: 24%;
    display: flex;
    flex-direction: column;
    text-align: center; /* Memusatkan teks */
    border-radius: 15px;
    border: 0.7px #999999 solid;
    padding: 20px 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    background-color: white;
    margin-left: 70px;
}
.column-c {
    width: 24%;
    display: flex;
    flex-direction: column;
    text-align: center; /* Memusatkan teks */
    border-radius: 15px;
    border: 0.7px #999999 solid;
    padding: 20px 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    background-color: white;
    margin-right: 50px;
}
.column-d {
    width: 25%;
    display: flex;
    flex-direction: column;
    text-align: center; /* Memusatkan teks */
}

.column-b h2 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 20px;
}

.column-b h3 {
  font-weight: 700;
  font-size: 1.5rem;
}
@media (max-width: 500px){
  .column-b h3 {
  font-size: 1rem !important;
}
.column-c h3 {
  font-size: 1rem !important;
}
.column-b p {
  font-size: 0.9rem !important;
}
.column-c p {
  font-size: 0.9rem !important;
}
}
.icons-grid {
    display: flex;
    gap: 0px;
    margin-bottom: 10px;
    justify-content: center; /* Memusatkan ikon secara horizontal */
    align-items: center; /* Memusatkan ikon secara vertikal */
}

.plastic-wrapper {
  display: flex;
  justify-items: center; /* Memusatkan ikon dalam grid */
  align-items: center;
}
.icon-item {
    text-align: center;
}

.icon-item img {
    width: 60px;
    height: auto;
}

.icon-item p {
    margin-top: 10px;
    font-size: 16px;
    font-weight: 700;
    padding: 0 8px !important;
}

.column-b p {
    font-size: 16px;
    line-height: 1.5;
    max-width: 800px;
}

@media (min-width: 1399px){
  .column-a, .column-b {
        width: 30%;
        text-align: center;
        margin-left: 18px;
    }
  .column-c {
        width: 30%;
        text-align: center;
        margin-right: 0px;
  }
  .container-facility {
    background-size: 90%; /* Perbesar ukuran gambar */
    background-repeat: no-repeat;
    background-position: center;
  }
  .content-top, .content-bottom {
    margin-top: 40px;
  }
}

@media (min-width: 1024px) and (max-width: 1399px) {
  .column-a, .column-b {
        width: 30%;
        text-align: center;
        margin-left: 0px;
    }
  .column-c {
        width: 30%;
        text-align: center;
        margin-right: 0px;
  }
  .container-facility {
    background-size: 90%; /* Perbesar ukuran gambar */
    background-repeat: no-repeat;
    background-position: center;
  }
  .content-top, .content-bottom {
    margin-top: 40px;
  }
}

@media (min-width: 901px) and (max-width: 1024px) {
  .column-a, .column-b {
        width: 35%;
        text-align: center;
        margin-left: 0px;
    }
  .column-c {
        width: 35%;
        text-align: center;
        margin-right: 0px;
  }
  .container-facility {
    background-size: 40%; /* Perbesar ukuran gambar */
    background-repeat: no-repeat;
    background-position: center;
  }
  .content-top, .content-bottom {
    margin-top: 50px;
  }
}

@media (min-width: 769px) and (max-width: 900px) {
  .column-a, .column-b {
        width: 40%;
        text-align: center;
        margin-left: 0px;
    }
  .column-c {
        width: 40%;
        text-align: center;
        margin-right: 0px;
  }
  .container-facility {
    background-size: 110%; /* Perbesar ukuran gambar */
    background-repeat: no-repeat;
    background-position: center;
    margin-top: 0 ;
  }
  .content-top {
    margin-top: 40px;
  }
  .content-bottom {
    margin-top: 120px;
  }
}
/* Responsive styling */
@media (max-width: 768px) {
    .column-a, .column-b {
        width: 100%;
        text-align: center;
        margin-left: 0px;
    }
  .column-c {
        width: 100%;
        text-align: center;
        margin-right: 0px;
  }
  .column-b, .column-c p {
    margin-bottom: 0px !important;
  }
  .column-b, .column-c h3 {
    font-size: 1.2rem;
  }
  .content-text {
    height: auto !important;
  }
  .container-facility {
    max-width: 100%;
    background-image: none; /* Hilangkan gambar latar */
    aspect-ratio: auto; /* Reset aspect ratio */
    height: auto;background-image: none;
  }
  .content-top {
    margin-top: 0px;
    flex-direction: column;
    gap: 15px;
  }
  .content-bottom {
    margin-top: 15px;
    flex-direction: column;
    gap: 15px;
  }
}

/* Swiper Container */
/* Swiper Container */
.swiper-container {
    flex: 0 0 93%; /* Takes 80% width */
    overflow: hidden;
}
.swiper-wrapper {
    display: flex; /* Flexbox is required for Swiper to properly align the slides */
    transition: transform 0.3s ease-in-out; /* Smooth transition between slides */
    width: 100%; /* Ensure the wrapper takes up the full width */
    height: auto !important;
/*    justify-content: center !important;*/
}
.swiper-slide {
    display: flex;
    flex-direction: column;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
    height: 100%;
    /* Ensure slides have space for margin if needed */
    box-sizing: border-box;
}


/* Optional: Navigation buttons */
.swiper-button-next, .swiper-button-prev {
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

/* Position navigation buttons on desktop */
@media (min-width: 768px) {
    .swiper-button-next {
        right: 10px;
    }
    .swiper-button-prev {
        left: 10px;
    }
}

/* Position navigation buttons on mobile */
@media (max-width: 767px) {
    .swiper-button-next, .swiper-button-prev {
        bottom: 10px;
        top: auto;
        left: auto;
        right: auto;
        transform: translateX(-50%);
    }
    
    .swiper-button-next {
        right: 50%;
    }
    .swiper-button-prev {
        left: 50%;
    }
    .swiper-container {
      flex: 0 0 100%;
    }
}
/* LATEST SLIDE SWIPER.JS */
.swiper-container-latest {
    /*flex: 0 0 100%; Takes 80% width */
    overflow: hidden;
    z-index: 1;
}

.swiper-wrapper-latest {
    display: flex; /* Flexbox is required for Swiper to properly align the slides */
    transition: transform 0.3s ease-in-out; /* Smooth transition between slides */
    width: 100%; /* Ensure the wrapper takes up the full width */
}

.swiper-slide-latest {
    display: flex;
    flex-direction: column;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
    box-sizing: border-box;
    /* Ensure slides have space for margin if needed */
    margin-right: 10px; /* Adjust spacing between slides */
    /* Optional: Adjust height to fit the container */
    height: auto;
}


.swiper-button-next-latest, .swiper-button-prev-latest {
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

/* Position navigation buttons on desktop */
@media (min-width: 768px) {
    .swiper-button-next-latest {
        right: 10px;
    }
    .swiper-button-prev-latest {
        left: 10px;
    }
}

/* Position navigation buttons on mobile */
@media (max-width: 767px) {
    .swiper-button-next-latest, .swiper-button-prev-latest {
        bottom: 10px;
        top: auto;
        left: auto;
        right: auto;
        transform: translateX(-50%);
    }
    
    .swiper-button-next-latest {
        right: 50%;
    }
    .swiper-button-prev-latest {
        left: 50%;
    }
}

@media (max-width: 768px) {
    .latest-product-card {
        width: 100%; /* Pastikan kartu produk menempati lebar penuh */
        box-sizing: border-box; /* Pastikan padding tidak menambah lebar */
    }

    .swiper-container-latest {
        padding: 10px; /* Beri padding untuk menghindari konten menyentuh tepi */
        width: 100%; /* Agar kontainer swiper mengikuti lebar layar */
    overflow: hidden; /* Mencegah elemen melebihi lebar kontainer */
    }
}

  /* Breadcrumb & Heading 07-09-2024 */
    #breadcrumb-section {
      margin-top: 80px;
        position: relative;
        color: #0e1b4d;
        text-align: center;
        padding: 20px 0;
        height: 18vh;
        width: 100vw;
    }

    #breadcrumb-section-artikel {
      margin-top: 80px;
        position: relative;
        color: #0e1b4d;
        text-align: center;
        padding: 20px 0;
        height: 13vh;
        width: 100vw;
    }

    #breadcrumb-section-shop {
      margin-top: 80px;
        position: relative;
        color: #0e1b4d;
        text-align: center;
        padding: 20px 0;
        height: 18vh;
        width: 100vw;
        background-size: 100%;
        background-repeat: no-repeat;
        background-position: center;
        background-image: url('../img/bg-ketebalan.webp');
    }

    .breadcrumb-text a {
        color: #0e1b4d;
        text-decoration: none;
        margin-right: 10px;
    }

    .breadcrumb-text span {
        font-weight: bold;
    }
    .breadcrumb-section h2 {
        font-size: 2rem;
        margin-top: 10px;
    }
    .breadcrumb-section-judul {
        font-size: 2rem;
        margin-top: 10px;
    }
    .breadcrumb-section-judul h1 {
        font-size: 2rem;
        font-weight: 700;
    }
    @media (min-width: 769px) and (max-width: 1024px){
       #breadcrumb-section {
          max-height: 13vh !important;
        }
    }
    @media (max-width: 768px) {
        #breadcrumb-section {
          max-height: 13vh !important;
        }
        #breadcrumb-section-artikel {
          max-height: 10vh !important;
        }
        #breadcrumb-section-shop {
          height: 15vh;
          margin-top: 70px;
          background-image: url('../img/bg-ketebalan-mini.webp');
        }
        .breadcrumb-section-judul h1 {
        font-size: 1.5rem;
        font-weight: 700;
        }
    }
    @media (max-width: 500px){
      #breadcrumb-section {
          max-height: 13vh !important;
        }
      .breadcrumb-section-judul h1 {
        font-size: 1.1rem;
        font-weight: 700;
        }
        #breadcrumb-section-shop {
          height: 15vh;
          margin-top: 60px;
          padding: 0 !important;
          background-image: url('../img/bg-ketebalan-mini.webp');
        }
    }
    /* Product Grid */
.product-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 20px;
    }
    .empty {
      display: block;
    }
    .product-grid.justify-content-center {
    width: max-content; /* Sesuaikan lebar grid dengan jumlah itemnya */
      place-content: center;
    }

    .product-card-detail {
      background-color: #ffffff;
      border-radius: 10px;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
      overflow: hidden;
      transition: transform 0.3s ease;
      box-sizing: border-box;
      width: 100%;
      position: relative; /* Allow absolute positioned elements to position within this container */
  }
  
    .product-card-detail img {
        width: 100%;
        height: auto;
        display: block;
    }
    .product-color-info-top {
    font-size: 1rem;
    font-weight: bold;
    position: absolute;
    top: 10px; /* Adjust to your preferred top position */
    left: 10px; /* Adjust to your preferred right position */
    background-color: rgba(255, 255, 255, 0.0); /* Optional background for readability */
    padding: 5px;
    border-radius: 5px;
    z-index: 10; /* Ensure this element appears above the image */
}
    @media (min-width: 769px) and (max-width: 1024px){
        .product-grid {
            grid-template-columns: repeat(4, 1fr);
        }
        .empty {
        display: none !important;
      }
    }
    @media (max-width: 768px){
      .product-color-info-top {
        font-size: 0.9rem;
      }
      .empty {
        display: none !important;
      }
    }
    @media (max-width: 500px){
      .product-color-info-top {
        font-size: 0.8rem;
      }
    }

    .product-card-content-category {
        padding: 15px;
        text-align: center;
        cursor: pointer;
    }
    .product-card-title-category {
        font-size: 1.5rem;
        margin-bottom: 10px;
    }

    @media (min-width: 769px) and (max-width: 1024px) {
        .product-grid {
            grid-template-columns: repeat(3, 1fr);
        }
    }

    @media (min-width: 501px) and (max-width: 768px) {
        .product-grid {
          grid-template-columns: repeat(2, 1fr);
            
        }
        .breadcrumb-section-judul {
          font-size: 1.5rem !important;
        }
        .breadcrumb-text a {
          font-size: 1rem !important;
        }
          .product-info-card {
              flex-direction: column;
          }

          .product-info-content {
              flex-direction: column;
          }

          .product-media {
              width: 100% !important;
              margin-bottom: 20px;
              order: -1; /* Ensure the image appears above the text */
          }

          .product-info-text {
            margin-top: 0;
              width: 100% !important;
          }

          .product-video iframe {
            height: 300px !important;
          }
          .expandable-header  {
            margin-right: 25px !important;
          }
          .expandable-header .expand-btn {
            margin-left: auto;
          }
          .product-info-img {
              width: 100%;
              height: 300px; /* Set a fixed height for mobile */
              max-height: 300px;
              object-fit: cover; /* Ensures the image is cropped to fit */
              object-position: center; /* Crop the image in the center */
          }
    }

    @media (max-width: 500px) {
              .product-grid {
            grid-template-columns: 1fr;
        }
        .breadcrumb-section-judul {
          font-size: 1.2rem !important;
        }
        .breadcrumb-text a {
            font-size: 0.9rem !important;
        }
        .breadcrumb-text span {
            font-size: 0.9rem !important;
        }
            .product-card-title-category {
        font-size: 1rem;
        margin-bottom: 10px;
        }
        #breadcrumb-section {
        margin-top: 50px;
        padding: 15px 0;
        }
        .product-info-card {
              flex-direction: column;
          }

          .product-info-content {
              flex-direction: column;
          }

          .product-media {
              width: 100% !important;
              margin-bottom: 20px;
              order: -1; /* Ensure the image appears above the text */
          }

          .product-info-text {
            margin-top: 0 !important;
              width: 100% !important;
          }

          .product-video iframe {
            height: 250px !important;
          }
          .expandable-header  {
            margin-right: 15px !important;
          }
          .expandable-header .expand-btn {
            margin-left: auto;
          }

          .expandable-header h2 {
            font-size: 1rem !important;
          }
          .product-info-img {
              width: 100%;
              height: 200px; /* Set a fixed height for mobile */
              max-height: 200px;
              object-fit: cover; /* Ensures the image is cropped to fit */
              object-position: center; /* Crop the image in the center */
          }

    }

    .view-product-btn {
        display: inline-block;
        padding: 10px 20px;
        background-color: #060c22fa;
        color: white;
        text-decoration: none;
        border-radius: 5px;
        transition: background-color 0.3s ease;
    }
    .view-product-btn:hover {
        background-color: #333;
    }

    /* Product Info Section */
   #product-info-section {
    margin-top: 50px;
}

.product-info-section {
    margin-top: 50px;
}

.product-info-card {
    background-color: #ffffff;
    border-radius: 10px;
    border: 0.5px solid rgba(0, 0, 0, 0.2);
    box-shadow: 0 8px 10px rgba(0, 0, 0, 0.4);
    padding: 0; /* Remove padding around the card */
    overflow: hidden; /* Ensure content does not overflow the card */
    display: flex;
    gap: 20px;
    flex-direction: row;
}
#faq {
    background-color: #f9f9f9;
    padding: 40px 20px;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    max-width: 100%;
    margin: 20px auto;
    font-family: 'Arial', sans-serif;
}
.faq-info-card {
    background-color: #ffffff;
    border-radius: 10px;
    border: 0.5px solid rgba(0, 0, 0, 0.2);
    box-shadow: 0 8px 10px rgba(0, 0, 0, 0.4);
    padding: 0; /* Remove padding around the card */
    overflow: hidden; /* Ensure content does not overflow the card */
    display: flex;
    gap: 20px;
    flex-direction: column;
}

.product-info-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 30px;
    width: 100%;
}

.product-info-text {
    margin-top: 20px;
    width: 50%;
}

.faq-info-text {
    width: 100%;
    justify-content: center;
}

.expandable-section {
    position: relative;
    margin-bottom: 20px;
}
.expandable-section p {
    display: none;
}

.expanded p {
    display: block;
}
.expandable-header {
    display: flex;
    align-items: center;
    gap: 10px; /* Adjust spacing as needed */
}

.expandable-header h2 {
    display: inline-flex;
    align-items: center;
    font-size: 1.25rem;
    padding: 0 20px;
    font-weight: 600;
}

.expandable-header .expand-btn {
    background: none;
    border: 2px solid #0e1b4d;
    color: #0e1b4d;
    cursor: pointer;
    font-size: 1.8rem;
    width: 2.6rem;
    height: 2.6rem;
    display: flex;
    font-weight: bold;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    text-align: center;
    padding: 0; /* Ensure no padding around the button */
}

.expandable-text {
    display: none; /* Hide text by default */
    margin-top: 10px;
}

.expandable-section.expanded .expandable-text {
    display: block; /* Show text if section is expanded */
}

.product-media {
    width: 50%;
    overflow: hidden;
}

.product-info-img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* Layout for mobile devices */
@media (max-width: 768px) {

}
@media (min-width: 768px) and (max-width: 900px){

}

.product-video {
    margin-top: 20px;
}

.product-video video {
    width: 100%;
    border-radius: 10px;
}


.product-video iframe {
    width: 100%;
    height: 600px; /* Atur tinggi sesuai kebutuhan */
    border: none; /* Hapus border default */
    border-radius: 10px; /* Opsional: Tambahkan border radius untuk mencocokkan dengan desain card */
}
/* ALIGMENT TEXT */
.text-left{
  text-align: left;
}
.text-center{
  text-align: center !important;
  align-items: center;
}
.text-right{
  text-align: right;
}

/*text COLOR */
.tc-main {
  color: #060c22fa;
}
.tc-white {
  color: white !important;
}

/* MARGIN */
.mtop-0{
  margin-top: 0 !important;
}
.mtop-10 {
  margin-top: 10px !important;
}
.mtop-15 {
  margin-top: 15px !important;
}
.mtop-20 {
  margin-top: 20px !important;
}
.mtop-30 {
  margin-top: 30px !important;
}
.mtop-40 {
  margin-top: 40px !important;
}

.mbottom-0{
  margin-bottom: 0 !important;
}
.mbottom-0{
  margin-bottom: 5px !important;
}
.mbottom-10{
  margin-bottom: 10px !important;
}
.mbottom-15{
  margin-bottom: 15px !important;
}
.mbottom-20{
  margin-bottom: 20px !important;
}
.mleft-0 {
  margin-left: 0 !important;
}

.mleft-10 {
  margin-left: 10px !important;
}

.mleft-15 {
  margin-left: 15px !important;
}

.mleft-20 {
  margin-left: 20px !important;
}

.mright-0 {
  margin-right: 0 !important;
}

.mright-10 {
  margin-right: 10px !important;
}

.mright-15 {
  margin-right: 15px !important;
}

.mright-20 {
  margin-right: 20px !important;
}
/* PADDING */
.pd-0{
  padding: 0 !important;
}
.pd-5{
  padding: 5px !important;
}
.pt-0 {
  padding-top: 0 !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.pt-15 {
  padding-top: 15px !important;
}

.pt-20 {
  padding-top: 20px !important;
}
.pt-30 {
  padding-top: 30px !important;
}
.pt-40 {
  padding-top: 40px !important;
}
.pt-90 {
  padding-top: 90px !important;
}
.pl-0 {
  padding-left: 0 !important;
}

.pl-10 {
  padding-left: 10px !important;
}

.pl-15 {
  padding-left: 15px !important;
}

.pl-20 {
  padding-left: 20px !important;
}

.pr-0 {
  padding-right: 0 !important;
}

.pr-10 {
  padding-right: 10px !important;
}

.pr-15 {
  padding-right: 15px !important;
}

.pr-20 {
  padding-right: 20px !important;
}

.pb-0 {
  padding-bottom: 0 !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.pb-15 {
  padding-bottom: 15px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

@media (max-width: 500px){
  .pt-40 {
  padding-top: 20px !important;
}
}
/* text color */
.main-red {
  color : #f82249;
}

/* font weight & text transform */
.w-500 {
  font-weight: 500;
}

.w-600 {
  font-weight: 600;
}

.w-700 {
  font-weight: 700;
}

.uppercase {
  text-transform: uppercase;
}
.font-05rem {
  font-size: 0.5rem !important;
}
.font-08rem {
  font-size: 0.8rem !important;
}
.font-1rem {
  font-size: 1rem !important;
}
.font-15rem {
  font-size: 1.5rem !important;
}
.font-2rem {
  font-size: 2rem !important;
}

/* DISPLAY */
.dblock {
  display: block !important;
}
.jcenter {
  justify-content: center;
}

/* BACKGROUND COLOR */
.bg_white {
  background-color: #ffffff !important;
}

/* BORDER COLOR */
.br_main {
  border-color: #060c22fa !important;
}

/* BULATAN WARNA DALAM KATEGORI LETEBALAN CARD */
.color-circle {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 5px;
    border: 1px solid #ccc;
}

.more-colors-btn {
    background: white;
    color: #007bff;
    border: none;
    cursor: pointer;
    padding: 8px 16px;
    font-size: 14px;
    border-radius: 30px; /* Mengatur border-radius */
    display: inline-flex;
    align-items: center;
    justify-content: center;
}


.border-gradient-purple {
    background: linear-gradient(white, white) padding-box,
              linear-gradient(to right, darkblue, darkorchid) border-box;
  border-radius: 50em;
  border: 2px solid transparent;
}
.more-colors-btn i {
    margin-left: 8px;
    font-size: 16px;
    color: #007bff;
}

/* Hover state */
.more-colors-btn:hover {
   background: linear-gradient(white, white) padding-box,
                linear-gradient(to right, rgb(255, 0, 0), rgb(0, 255, 0), rgb(0,191,255)) border-box; /* RGB gradient from red to green */
    border-radius: 50em; /* Large border-radius for rounded effect */
    border: 2px solid transparent; /* Transparent border to show the gradient */
    background-color: #f0f0f0;
}

.test-btn {
      background: white;
      border: 2px solid #007bff;
      color: #007bff;
      padding: 10px 20px;
      font-size: 16px;
      border-radius: 30px; /* Mengatur border-radius */
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background 0.3s, border-color 0.3s;
    }

    .test-btn:hover {
      background: #e0e0e0;
      border-color: #0056b3;
    }

    /*FILTER KATEGORI BG INVERSE */
.category-filter-inverse {
    margin-bottom: 30px;
    text-align: center;
}

.category-filter-inverse ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    gap: 10px;
    flex-wrap: wrap;
}

.category-filter-inverse li {
    background-color: #ffffff;
    color: #060c22fa;
    padding: 10px 20px;
    border-radius: 20px;
    border: 2px solid #060c22fa;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.category-filter-inverse li:hover,
.category-filter-inverse li.active {
    background-color: #f82249;
    color: white;
    border: 2px solid white;
}

@media (max-width: 399px) {
.category-filter-inverse li {
  padding: 5px 10px;
  font-size: 12px;
}
}

@media (min-width: 501px) and (max-width: 768px) {
  .category-filter-inverse li {
  padding: 8px 11px;
  font-size: 14px;
}
}
@media (min-width: 769px) and (max-width: 1366px) {
  .category-filter-inverse li {
  padding: 8px 12px;
  font-size: 14px;
}
}


/* KETEBALAN KAIN */

#etalase-kain {
    text-align: center;
  }

#etalase-kain .section-header {
    margin-bottom: 20px;
}

#etalase-kain h2 {
    margin: 20px 0;
    font-size: 24px;
}

/* Styling for the Pengertian section */
#etalase-kain .pengertian p {
    margin: 0;
}

/* Styling for the Kelebihan and Penggunaan sections */
#etalase-kain .kelebihan, 
#etalase-kain .penggunaan {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
}

#etalase-kain .kelebihan h2,
#etalase-kain .penggunaan h2 {
    width: 100%;
    margin-bottom: 10px;
    font-size: 20px;
    margin-top: 30px;
}

/* Styling for items in Kelebihan and Penggunaan sections */
#etalase-kain .kelebihan-wrap {
  display: flex;
  flex-wrap: wrap;
}
#etalase-kain .item {
    flex: 1 1 calc(25% - 20px); /* 4 items per row on desktop */
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 20px;
}
#etalase-kain h5 {
  font-size: 1rem;
  font-weight: bold;
}
#etalase-kain .item-kegunaan {
    flex: 1 1 auto; /* Pastikan item memiliki lebar otomatis */
    max-width: calc(25% - 20px); /* 4 items per row on desktop */
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 20px;
    flex-grow: 0; /* Pastikan item tidak tumbuh lebih dari yang diperlukan */
}

#etalase-kain .icon {
    width: 60px; /* Adjust size as needed */
    height: auto;
    margin-bottom: 10px;
}

#etalase-kain .description {
    font-size: 14px;
}

/* Responsive design */
@media (max-width: 992px) { /* Tablet */
    #etalase-kain .item {
        flex: 1 1 calc(33.33% - 20px); /* 3 items per row */
    }
    #etalase-kain .item-kegunaan {
        max-width: calc(20% - 20px); /* 3 items per row */
    }
}

@media (max-width: 768px) { /* Mobile */
    #etalase-kain .item {
        flex: 1 1 calc(100% - 20px); /* 1 item per row */
    }
        #etalase-kain .item-kegunaan {
        max-width: calc(50% - 20px); /* 3 items per row */
    }
    #etalase-kain .icon {
    width: 40px; /* Adjust size as needed */
    height: auto;
    margin-bottom: 10px;
}
#etalase-kain h5 {
  font-size: 1rem !important;
  font-weight: bold;
}
}

/* SEARCH KOLOM DAN SHOW ITEM PER PAGE */
.products-section {
display: flex;
 flex-wrap: nowrap;
}
.header-options {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.search-box {
    display: flex;
    align-items: center;
}

.search-box input[type="text"] {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    margin-right: 10px;
}

.search-box button {
    padding: 10px 15px;
    background-color: #007bff;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.search-box button:hover {
    background-color: #0056b3;
}

.item-options select {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
}


/* Pagination */
.pagination-container {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 20px 0;
}

.pagination-btn {
    padding: 10px 20px;
    margin: 0 5px;
    border: 1px solid #ccc;
    border-radius: 5px;
    background-color: #f8f9fa;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s;
}

.pagination-btn:hover {
    background-color: #e2e6ea;
}

.pagination-numbers {
    display: flex;
}

.lihat-lainnya {
    display: none;
    text-align: center;
    margin: 20px 0;
}

.lihat-lainnya button {
    padding: 10px 20px;
    border: 1px solid #007bff;
    border-radius: 5px;
    background-color: #ffffff;
    color: #007bff;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s;
}

.lihat-lainnya button:hover {
    background-color: #007bff;
    color: #ffffff;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .pagination-container {
        flex-direction: column;
    }

    .pagination-btn {
        margin: 5px 0;
    }
}

@media (min-width: 501px) and (max-width: 768px) {

    .products-section {
        flex-direction: column;
    }
    .item-options,
    .pagination-container {
        display: none;
    }

    .lihat-lainnya {
        display: block;
    }
}

@media (max-width: 500px) {
   .products-section {
        flex-direction: column;
    }
    .search-box {
        flex-direction: column;
        align-items: stretch;
    }

    .search-box input[type="text"] {
        margin-bottom: 10px;
        margin-right: 0 !important;
    }
}

/* Pagination buttons */
.pagination-btn {
    background-color: #fff;
    border: 2px solid #ddd;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 5px;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s;
}

.pagination-btn:hover {
    background-color: #f0f0f0;
    border-color: #ccc;
}

.pagination-btn.prev .arrow {
    font-size: 18px;
}

.pagination-btn.next .arrow {
    font-size: 18px;
}

.pagination-btn.active {
    background-color: #ddd;
    border-color: #ccc;
}

.arrow {
    font-size: 16px;
}

/* Hide elements on smaller screens */
@media (max-width: 768px) {
    .item-options {
        display: none;
    }
    .pagination-container {
        display: none;
    }
    .lihat-lainnya {
        display: block;
    }
     .search-box {
        width: 100%; /* Make sure it takes the full width on smaller screens */
        justify-content: center;
        margin-top: 10px;
    }
}

/* PRODUK DETAIL */
/* General styles */
.product-detail-page {
    display: flex;
    flex-wrap: wrap;
}

.product-main {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.product-image-section-detail {
    width: 45%;
    padding-right: 20px;
    position: relative; /* Position relative to place navigation buttons */
}

.product-full-image-wrapper {
    position: relative; /* Position relative for absolute children */
}

.product-full-image img {
    width: 100%; /* Isi lebar kontainer */
    height: auto; /* Pertahankan aspek rasio */
    display: block;
    border-radius: 10px;
    transition: opacity 0.3s ease;
}

@media (max-width: 500px) {
    .product-full-image img {
        max-width: 100%;
        max-height: 250px;
        object-fit: contain; /* Hindari gambar terpotong */
    }
}
.slider-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: #fff;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 1;
    font-size: 24px;
    display: none; /* Initially hidden */
}

.slider-nav.prev {
    left: 10px;
}

.slider-nav.next {
    right: 10px;
}

.slider-nav.hidden {
    opacity: 0;
    pointer-events: none; /* Disable pointer events when hidden */
}

.product-full-image-wrapper:hover .slider-nav,
.product-full-image-wrapper:focus-within .slider-nav {
    display: block; /* Show buttons on hover or focus */
}

/* Thumbnail styles */
.product-image-thumbnails {
    display: flex;
    justify-content: center;
    margin-top: 10px;
}

.product-image-thumbnails img {
    width: 20%;
    max-width: 350px;
    height: auto;
    margin-right: 10px;
    cursor: pointer;
    border: 2px solid transparent;
    transition: border-color 0.3s ease;
}

.product-image-thumbnails img.active {
    border-color: #007bff; /* Border blue for active image */
}
.product-image-thumbnails img:hover {
    border-color: #007bff;
}

/* Product Info Section */
.product-info-section-detail {
    width: 55%;
    display: flex;
    flex-direction: column;
}

/* Product Name */
.product-name-detail {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 0;
}
.product-name-detail-top {
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 15px;
    display: none;
}
@media (max-width: 768px) {

    .product-main {
        flex-direction: column; /* Atur arah flex menjadi kolom vertikal */
    }
    
    .product-image-section-detail, .product-info-section-detail {
        width: 100%; /* Buat kedua elemen mengambil lebar penuh */
        padding-right: 0; /* Hapus padding untuk lebar penuh */
    }

    .product-image-section-detail {
        margin-bottom: 20px; /* Tambahkan sedikit jarak di bawah gambar */
    }
    .product-name-detail {
      font-size: 1.5rem;
    }
    .product-name-detail-top {
      display: none;
    }
}



/* Product Price */
/* Container for price detail and price cards */
.price-container {
  margin-top: 15px;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  flex-wrap: nowrap; /* Prevent wrapping by default */
}
/* Product price detail - occupies 30% of the width */
.product-price-detail {
  flex: 0 0 40%;
  font-size: 1.5rem;
  font-weight: bold;
  margin: 0;
  color: #040919 !important;
  justify-content: center;
  align-items: center;
}

.product-price-detail h5{
  font-size: 1.5rem;
  font-weight: bold;

}
.product-price-detail .unit {
    font-size: 1rem;
}

/* Price cards container - occupies 70% of the width */
.price-cards {
    display: flex;
    flex-wrap: nowrap; /* Pastikan kartu tetap berada dalam satu baris */
    gap: 10px; /* Jarak antar kartu */
    justify-content: flex-start; /* Mulai dari kiri */
    overflow-x: auto; /* Tambahkan scroll horizontal jika diperlukan */
}

/* Individual price card */
.price-card {
    flex: 0 0 auto; /* Pastikan kartu tidak mengecil */
    width: 120px; /* Lebar tetap untuk kartu */
    background-color: #ffffff;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.2);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Subtle shadow */
    height: auto; /* Sesuaikan tinggi dengan konten */
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center; /* Konten rata tengah */
}

/* Optional: ensure the content inside the card is centered */
.price-card p {
    margin: 0; /* Remove extra margin */
    padding: 2px 0; /* Adjust padding if needed */
}

@media (max-width: 768px) {
  .price-container {
        flex-direction: column; /* Atur harga dan kartu secara vertikal */
        align-items: flex-start;
        gap: 5px;
        min-height: 100px;
    }

    .price-cards {
      width: 100%;
        flex-wrap: nowrap; /* Pastikan kartu tetap berbaris dalam satu baris */
        overflow-x: auto; /* Aktifkan scroll horizontal jika diperlukan */
    }

    .product-price-detail {
        width: 100%; /* Penuh di atas price cards */
        min-height: 50px;
    }
}
}

/* Available Stores */
.store-section-product {
padding-top: 20px !important;
}
.store-section-content {
  display: flex;
}
.store-section-content-left {
  width: 40%;
}
.store-section-content-right {
  width: 60%;
}
.available-stores {
    display: flex;
    margin-top: 0 !important;
    flex-wrap: wrap;
    margin-bottom: 15px;
}

.store {
    display: flex;
    align-items: center;
    padding: 10px;
    border-radius: 25px;
    color: #060c22fa;
    border: 2.5px solid #060c22fa;
    background-color: #ffffff;
    margin-right: 10px;
    margin-bottom: 10px;
    cursor: pointer;

}
.store.active{
  color: #ffffff;
    border: 0;
    background-color:#060c22fa;
}
.store:hover {
    color: #ffffff;
    border: 0;
    background-color:#060c22fa;
}
.store .store-name {
    margin-right: 10px;
    font-size: 0.7rem;
    font-weight: 600;
}

.status-icon {
    display: inline-flex;
    margin-left: 8px;
    justify-content: center;
    align-items: center;
    width: 20px; /* Adjust size as needed */
    height: 20px; /* Adjust size as needed */
    border-radius: 50%; /* Makes the background circular */
    font-size: 12px; /* Adjust size as needed */
    color: white; /* Color of the icon */
    font-weight: bold; /* Makes the icon bold */
    text-align: center;
}
.status-icon img{
  width: 20px;
  height: auto;
}

.status-icon.available {
    background-color: green;
}

.status-icon.unavailable {
    background-color: red;
}

@media (max-width: 500px) {

  .store .store-name {
    margin-right: 10px;
    font-size: 0.6rem;
    font-weight: 600;
  }
  .status-icon {
    width: 15px; /* Adjust size as needed */
    height: 15px;
  }
  .store-section-content-left {
  width: 100%;
}
.store-section-content-right {
  width: 100%;
}
.store-section-content {
  flex-direction: column;
}
.check-stock-btn {
  padding: 0px !important;
  padding-bottom: 15px !important;
}
}

@media (min-width: 501px) and (max-width: 768px) {
  .store-section-content-left {
  width: 60%;
}
.store-section-content-right {
  width: 40%;
}
}
/* OPSI WARNA */
.fabric-color {
    margin-top: 0;
}

.fabric-color-content {
    display: flex;
    flex-wrap: wrap; /* Izinkan elemen melipat baris jika diperlukan */
    align-items: center;
    gap: 10px;
    width: 100%;
}

.color-options-detail {
    display: flex;
    flex-wrap: wrap; /* Warna akan dilipat jika diperlukan */
    gap: 10px;
    max-width: 100%;
    align-items: center;
}

/* Card untuk color-option-detail yang aktif */
.color-option-detail.active {
    width: auto; /* Lebar otomatis berdasarkan konten */
    height: auto; /* Tinggi otomatis berdasarkan konten */
    padding: 8px;
    border-radius: 10px;
    border-radius: 25px;
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 1; /* Pastikan card berada di atas bulatan warna lainnya */
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Keterangan warna pada color-option-detail aktif */
.color-option-detail.active::after {
    content: attr(data-name);
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin-left: 10px; /* Jarak dari bulatan warna */
}

/* Bulatan warna */
.color-option-detail {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: transparent;
  
    align-items: center;
    transition: transform 0.3s ease;
    position: relative;
    z-index: 0; /* Pastikan bulatan warna berada di bawah card */
}

.color-option-circle {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    cursor: pointer;
    position: relative;
    transition: transform 0.3s ease;
}

.tooltip-color {
    display: none; /* Tooltip disembunyikan secara default */
    position: absolute;
    bottom: 40px; /* Jarak tooltip dari lingkaran warna */
    left: 50%;
    transform: translateX(-50%);
    background-color: #333; /* Background tooltip */
    color: white; /* Warna teks tooltip */
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
    z-index: 10;
    white-space: nowrap;
    pointer-events: none;
}

.color-option-circle:hover .tooltip-color {
    display: block; /* Tampilkan tooltip saat hover */
}



/* Tombol untuk Pilih Warna Lainnya */
.more-colors-btn-detail {
    background: white;
    color: #060c22fa;
    cursor: pointer;
    padding: 8px 16px;
    font-size: 14px;
    border-radius: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    flex-shrink: 0;
    font-weight: 600;
    text-decoration: underline;
    border: 2px solid transparent;
    background-color: #ffffff;
    margin-top: 10px;
}

.more-colors-btn-detail i {
    margin-left: 8px;
    font-size: 1rem;
    text-decoration: none !important;
    color: #060c22fa;
}
.color-desc {
  text-transform: uppercase;
  font-size: 0.8rem;
    font-weight: 600;
}
.color-desc-sheet {
  text-transform: uppercase;
  font-size: 0.8rem;
    font-weight: 600;
}
/* Media query untuk layar lebih kecil (misal Android) */
@media (max-width: 1024px) {
    .fabric-color-content {
        flex-direction: column; /* Ubah menjadi kolom di layar kecil */
        align-items: flex-start;
    }

    .color-options-detail {
        width: 100%; /* Biarkan opsi warna mengambil seluruh lebar */
    }

    .more-colors-btn-detail {
        width: auto;
        margin-left: 0;
        margin-top: 10px;

    }
}

/* Untuk layar sempit di bawah 768px */
@media (max-width: 768px) {
    .fabric-color {
        flex-direction: column; /* Menempatkan elemen secara vertikal */
        align-items: flex-start; /* Menyelaraskan elemen di awal */
    }
}

@media (max-width: 500px) {
  .more-colors-btn-detail i {
    font-size: 0.8rem;
  }
  .more-colors-btn-detail {
    font-size: 0.8rem;
}

}

/* wrapping flex for thickness, width, gsm */
.detail-info-wrap {
  display: flex;
}
.color-box-note {
    display: inline-block;
    width: 15px;
    height: 15px;
    background-color: #040919;
    border: 1px solid #040919;
    border-radius: 10px;
}
.note-info {
    margin-top: 10px;
    font-size: 0.9rem;
    color: #333;
    padding-left: 0 !important;
}

/* Fabric Thickness */
.fabric-thickness {
    margin-bottom: 20px;
    border: 2px solid #040919;
    
}
.fabric-thickness-content {
  margin-left: 15px;
  margin-right: 15px;
  margin-bottom: 10px;
}

.fabric-thickness-tittle {
  margin-bottom: 10px;
  padding: 10px 10px;
  border-bottom: 1px solid #040919;
  border-right: 1px solid #fff;
  background-color: #040919;


}

.fabric-thickness-tittle h5 {
  text-align: center;
  font-size: 1rem;
  padding: 0 !important;
  margin: 0 !important;
  font-weight: 600;
  color: #fff;
}

.thickness-options {
    display: flex;
    justify-content: center;
}

.thickness-option {
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    color: #060c22fa;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 5px 10px;
    border-radius: 15px;
    margin-right: 10px;
    cursor: pointer;
}

.thickness-option.active {
    background-color: #060c22fa;
    color: white;
}

/* Fabric width */
.fabric-width {
    margin-bottom: 20px;
    border-width: 2px 1px 2px 1px; /* top right bottom left */
    border-style: solid;
    border-color: #040919;
    
}
.fabric-width-content {
  margin-left: 15px;
  margin-right: 15px;
  margin-bottom: 10px;
}

.fabric-width-tittle {
  margin-bottom: 10px;
  padding: 10px 10px;
  border-bottom: 1px solid #040919;
  border-right: 1px solid #fff;
  background-color: #040919;
}

.fabric-width-tittle h5 {
  text-align: center;
  font-size: 1rem;
  padding: 0 !important;
  margin: 0 !important;
  font-weight: 600;
  color: #fff;
}

.width-options {
    display: flex;
    justify-content: center;
}

.width-option {
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    color: #060c22fa;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 5px 10px;
    border-radius: 15px;
    margin-right: 10px;
    cursor: pointer;
}

.width-option.active {
    background-color: #060c22fa;
    color: white;
}

/* Fabric gsm */
.fabric-gsm {
    margin-bottom: 20px;
    border-width: 2px 2px 2px 1px; /* top right bottom left */
    border-style: solid;
    border-color: #040919;

}

.gsm-options {
    display: flex;
    flex-wrap: wrap;
    gap : 2px;
    justify-content: center;
}
.fabric-gsm-content {
  margin-left: 15px;
  margin-right: 15px;
  margin-bottom: 10px;
}
.fabric-gsm-tittle {
  margin-bottom: 10px;
  padding: 10px 10px;
  border-bottom: 1px solid #040919;
  background-color: #040919;
}
.fabric-gsm-tittle h5 {
  text-align: center;
  font-size: 1rem;
  padding: 0 !important;
  margin: 0 !important;
  font-weight: 600;
  color: #fff;
}
.gsm-option {
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    color: #060c22fa;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 5px 10px;
    border-radius: 15px;
    margin-right: 10px;
    cursor: pointer;

}

.gsm-option.active {
    background-color: #060c22fa;
    color: white;
}

@media (max-width: 768px) {
    .detail-info-wrap {
        display: flex;
        flex-wrap: wrap; /* Membungkus elemen agar turun ke bawah saat ruang terbatas */
    }

    .fabric-thickness, .fabric-width {
        flex: 1; /* Fabric-thickness dan fabric-width tetap dalam satu baris */
    }

    .fabric-gsm {
        flex: 100%; /* Fabric-gsm akan turun tepat di bawah fabric-thickness dan fabric-width */
    }

    .fabric-width-tittle {
      border-right: none;
    }
}

@media (max-width: 500px) {
    .detail-info-wrap {
        display: block;
    }

    .fabric-thickness, .fabric-width, .fabric-gsm {
        width: 100%;
    }
    .fabric-thickness-tittle, .fabric-width-tittle {
      border-right: none;

    }
}

/* Color Categories */
.color-category {
    margin-bottom: 20px;
    margin-top: 20px;
}

.category-buttons  {
    display: flex;
    flex-wrap: wrap; /* Memungkinkan tombol pindah ke baris baru */
    gap: 10px; /* Menambahkan jarak antar tombol */
}

.category-button {
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    color: #060c22fa;
    border-radius: 25px;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 10px 15px;
    cursor: pointer;
}

.category-button.active {
    background-color: #060c22fa;
    color: white;
}

/* Action Buttons */
.action-buttons {
    display: flex;
    flex-wrap: wrap;
}

.add-to-cart {
    background-color: #ffffff;
    color: #060c22fa;
    border: none;
    font-weight: 600;
    border-radius: 25px;
    border: 2.5px solid #060c22fa;
    padding: 10px 15px;
    margin-right: 10px;
    font-size: 1rem;
    cursor: pointer;
    transition: background-color 0.3s;
}
.buy-now {
    background-color: #f82249;
    color: white;
    border: none;
    font-weight: 600;
    border-radius: 25px;
    padding: 10px 15px;
    margin-right: 10px;
    font-size: 1rem;
    cursor: pointer;
    transition: background-color 0.3s;
}

.add-to-cart:hover, .buy-now:hover {
    background-color: #f82249;
    color: white;
    border: 2.5px solid #f82249;
    transform: scale(1.1); /* Zoom in slightly */
}

@media (min-width: 769px) and (max-width: 1200px){
   .product-image-section-detail {
        width: 35% ;
    }

    .product-info-section-detail {
        width: 65% ;
    }

}
@media (max-width: 768px) {
   .product-image-section {
        width: 100%;
    }

    .product-info-section {
        width: 100%;
    }


    .price-card {
      padding: 10px;
        width: 40%;
        margin-right: 0;
        margin-bottom: 10px;
    }
    .add-to-cart .buy-now{
      margin-top: 10px;
    }
    .action-buttons {
      gap: 15px;
    }

}
/* Responsive Styles */
@media (max-width: 500px) {
    .product-image-section {
        width: 100%;
    }

    .product-info-section {
        width: 100%;
    }


    .price-card {
        width: 100%;
        margin-right: 0;
        margin-bottom: 10px;
    }
    .thickness-option {
      font-size: 0.7rem;
    }
    .category-button {
      font-size: 0.7rem;
      padding: 5px 15px;
    }
}

@media (min-width: 769px) and (max-width: 1024px){
    .price-container {
        flex-wrap: wrap !important; /* Allow wrapping */
        gap: 0px;
    }

    /* Price detail takes full width */
    .product-price-detail {
        flex: 0 0 50% !important; /* Occupies full width */
       /* Add some space between the detail and cards */
    }

    /* Price cards will also take full width below the price detail */
    .price-cards {
        flex: 0 0 50% !important; /* Occupies full width */
    }
}

/* product info */

section.fabric-info {
   margin-top: 20px;
}
.section-header-info {
  margin-bottom: 10px;
  position: relative;
  padding-bottom: 10px;
  display: flex;
  justify-content: flex-start;
}

.section-header-info::before {
  content: '';
  position: absolute;
  display: block;
  width: 100%;
  height: 2px;
  background: #060c22fa;
  bottom: 0;
  left: 0;
}

.section-header-info h2 {
  font-size: 2rem;
  text-transform: uppercase;
  text-align: left;
  font-weight: 600;
  margin-bottom: 0px;
}

.section-header-white {
  margin-bottom: 10px;
  position: relative;
  padding-bottom: 10px;
  display: flex;
  justify-content: flex-start;
}

.section-header-white::before {
  content: '';
  position: absolute;
  display: block;
  width: 100%;
  height: 2px;
  background: #ffffff;
  bottom: 0;
  left: 0;
}

.section-header-white h2 {
  font-size: 2rem;
  text-transform: uppercase;
  text-align: left;
  font-weight: 600;
  margin-bottom: 0px;
}

.fabric-info-tab {
   display: flex;
    gap: 20px;
    margin: 15px auto;
}

.fabric-info-sub-tab {
    display: flex;
    gap: 20px;
    width: 70%;
}

.fabric-specs,
.fabric-description,
.fabric-parameters {
    background-color: #f9f9f9;
    border-radius: 10px;
    padding: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.fabric-specs .spec-title {
    width: 40%; /* Sesuaikan sesuai kebutuhan */
    font-weight: bold;
}

.fabric-description {
  width: 60%;
}
.fabric-parameters {
  width: 40%;
}
.fabric-specs .spec-value {
    flex: 1;
}
.fabric-specs ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.fabric-specs li {
    display: flex;
    justify-content: flex-start;
    margin-bottom: 10px;
}

.fabric-description h2 ,
.fabric-specs h2 ,
.fabric-parameters h2 {
    margin-bottom: 15px;
    font-size: 1.5rem;
    font-weight: 600;
}

.fabric-description p {
    text-indent: 30px; /* Indentasi awal paragraf */
    line-height: 1.6;
    padding: 0 !important;
}
.parameter {
    margin-bottom: 20px;
}

.parameter label {
    display: block;
    font-weight: bold;
    margin-bottom: 5px;
}

.range-bar {
    position: relative;
    width: 100%;
    height: 10px;
    background-color: #e0e0e0;
    border-radius: 5px;
    overflow: hidden;
}

/* Fill for Left and Right */
.range-left, .range-right {
    position: absolute;
    height: 100%;
    background-color: #f82249;
}

.range-left {
    left: 50%;
    transform: translateX(-100%); /* Fills to the left */
     border-right: 1px solid #ffffff;
}

.range-right {
    left: 50%; /* Starts from the center */
     border-left: 1px solid #ffffff;
}

/* Label above the bar */
.percentage-label {
    position: absolute;
    top: 20px;
    font-size: 12px;
    color: #f82249;
}

.range-labels {
    display: flex;
    justify-content: space-between;
    margin-top: 5px;
    z-index: 1;
    font-size: 12px;
}

.middle-labels {
  font-size: 12px;
  display: flex;
    justify-content: center;
    margin-top: 5px;
}

.range-labels span {
    font-size: 12px;
}

/* Desktop Layout */
.fabric-specs {
    flex: 1 1 30%;
}

.fabric-description {
    flex: 1 1 40%;
}

.fabric-parameters {
    flex: 1 1 30%;
}
.fabric-usable {
  display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    flex-direction: row;
}
.usable {
   flex: 1 1 auto; /* Pastikan item memiliki lebar otomatis */
    max-width: 90px; /* 4 items per row on desktop */
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex-grow: 0; /* Pastikan item tidak tumbuh lebih dari yang diperlukan */
}
.usable img {
  max-width: 60px;
}
@media (min-width: 769px) and (max-width: 1024px) {
      .fabric-info-tab {
        flex-direction: column;
    }
.fabric-info-sub-tab {
  flex-direction: row;
  gap: 20px;
  width: 100%;
}
  .fabric-description,
    .fabric-parameters {
        width: 50%;
        margin-bottom: 20px;
    }
}
/* Responsive Design */
@media (max-width: 768px) {
    .fabric-info-tab {
        flex-direction: column;
    }
.fabric-info-sub-tab {
  flex-direction: column;
  width: 100%;
  gap: 20px;
}
    .fabric-specs,
    .fabric-description,
    .fabric-parameters {
        width: 100%;
        margin-bottom: 20px;
    }

    .section-header-info h2 {
      font-size: 1.5rem ;

    }
    .section-header-info {
      width: 100%;
    }
     .section-header-white h2 {
      font-size: 1.5rem ;

    }
    .section-header-white {
      width: 100%;
    }
}
@media (max-width: 300px) {
  .section-header-info h2 {
      font-size: 1rem !important;

    }
    .section-header-white h2 {
      font-size: 1rem !important;

    }
}


/*tabel estimasi hasil jadi dari 1kg */
.estimation-section {
    padding: 0px;
    border-radius: 8px;
}
.card-section {
    border-radius: 10px;
    padding: 15px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}
.note {
    font-size: 14px;
    color: #060c22fa;
    padding: 0 !important;
    margin-top: 15px;
    font-weight: 500;
}

.calculator {
  display: flex;
  margin-top: 20px;
    margin-bottom: 20px;
    justify-content: flex-start;
    max-width: 100%;
}

.calculator input {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    margin-right: 10px;
}

.calculator button {
    padding: 10px 15px;
    background-color: #060c22fa;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

.calculator button:hover {
    background-color: #0056b3;
}

.result-table {
    width: 100%;
    border-collapse: collapse;
}
.result-table th {
  background-color: #060c22fa;
  color: white;
}
.result-table th, .result-table td {
    border: 1px solid #ccc;
    padding: 10px;
    text-align: center;
    font-weight: 600;
}

@media (max-width: 768px) {
  .result-table th, .result-table td{
  font-size: 0.8rem;
}
.calculator {
  justify-content: flex-start;
  font-size: 0.8rem;
}
}
@media (max-width: 300px){
    .result-table th, .result-table td{
  font-size: 0.5rem;
  padding: 5px;
}
.calculator {
  justify-content: flex-start;
  font-size: 0.5rem;
}
}

/* BOTTOM SHEET COLOR SEARCH */
.color-options-bottom-sheet {
    display: none; /* Initially hidden */
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.2);
    padding: 20px;
    z-index: 1000;
}

.bottom-sheet-header {
  margin-top: 50px; /* Add top margin to create space from the close button */
  margin-bottom: 10px; /* Maintain existing bottom margin */
}

#colorSearch {
  width: 100%;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  margin-bottom: 10px; /* Maintain existing bottom margin */
}

.color-options-detail-sheet {
    display: flex;
    flex-wrap: wrap; /* Membuat elemen warna bisa dilipat jika tidak muat */
    gap: 10px;
    max-width: 100%;
    align-items: center;
    max-height: 90vh; /* Batasi tinggi maksimal */
    overflow-y: auto; /* Aktifkan scroll vertikal jika konten melebihi tinggi */
}
/* Card untuk color-option-detail yang aktif */


/* Bulatan warna */
.color-option-detail-sheet {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: transparent;
    cursor: pointer;
    align-items: center;
    transition: transform 0.3s ease;
    position: relative;
     overflow-y: auto;
    z-index: 0; /* Pastikan bulatan warna berada di bawah card */
}

/* Gaya baru untuk color-option-detail */
.color-option-detail-sheet.new-style {
    width: auto; /* Lebar otomatis berdasarkan konten */
    height: auto; /* Tinggi otomatis berdasarkan konten */
    padding: 8px;
    border-radius: 25px;
    background-color: #ffffff;
    border: 2.5px solid #060c22fa;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Keterangan warna pada color-option-detail */
.color-option-detail-sheet.new-style::after {
    content: attr(data-name);
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin-left: 10px; /* Jarak dari bulatan warna */
}
.close-sheet-button {
  display: flex; /* Use flexbox to center the icon */
  justify-content: center; /* Center horizontally */
  align-items: center; /* Center vertically */
  position: absolute; /* Position it relative to the bottom sheet */
  right: 20px; /* Adjusted to place it on the right */
  top: 15px; /* Adjusted for vertical position */
  border-radius: 50%;
  background-color: #f82249;
  width: 30px; /* Diameter of the circle */
  height: 30px; /* Diameter of the circle */
  cursor: pointer; /* Change cursor to pointer on hover */
  margin-bottom: 30px;
}

.close-sheet-button i {
  color: white; /* Set icon color */
  font-size: 16px; /* Adjust icon size as needed */
}
@media (min-width: 768px) {
    .color-options-bottom-sheet {
        width: 50%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        height: 100%;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
    }
  }
  @media (max-width: 500px){
    .color-desc {
      font-size: 0.6rem;
    }
    .color-desc-sheet {
  font-size: 0.6rem;
}
    .color-option-circle {
      height: 20px;
      width: 20px;
    }
    .color-option-detail.active {
      padding: 5px;
    }
    .color-option-detail-sheet.new-style {
      padding: 5px;
    }
  }

/* LOADING PADA COLOR SAAT GANTI KATEGORI WARNA */
#loading {
    position: absolute; /* or fixed */
    top: 50%; /* Center vertically */
    left: 50%; /* Center horizontally */
    transform: translate(-50%, -50%);
    font-size: 18px;
    font-weight: bold;
}

/* BACKGROUND COLOR */
.bg_main {
  background-color: #040919;
}
.width_100 {
  width: 100vw !important;
}
.bg_image1 {
     /* Tentukan lokasi gambar */
    background-color: #040919;
    width: 100%;
}

/* BUTTON CIRCLE */
.btn-container {
   justify-content: center;
    bottom: 20px;
    display: flex;
    align-items: center;
    padding-bottom: 20px;
}

.circle-btn {
    background-color: white; /* Initial background */
    border: 2.5px ridge #040919; /* Red border */
    color: #040919; /* Red icon color */
    width: 50px; /* Initial width for circle */
    height: 50px; /* Height same as width for circle */
    border-radius: 50%; /* Make it a circle */
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    transition: all 0.3s ease; /* Smooth transition */
    font-size: 16px;
    cursor: pointer;
    overflow: hidden;

}

.circle-btn i {
    transition: all 0.3s ease;
    position: absolute;
    right: 50%; /* Start in the center */
    transform: translateX(50%); /* Keep the icon centered */
}

/* Hidden text */
.circle-btn .btn-text {
    position: absolute;
    left: 0;
    opacity: 0;
    transition: all 0.3s ease;
    color: #040919;
}

/* Hover state */
.circle-btn:hover {
    width: 150px; /* Expand button width on hover */
    border-radius: 30px; /* Make it an oval */
    justify-content: flex-start; /* Align items to the left */
    padding-left: 15px; /* Add padding to align text and icon properly */
}

.circle-btn:hover .btn-text {
    opacity: 1; /* Show text */
    left: 20px; /* Keep the text on the left */
}

.circle-btn:hover i {
    right: 15px; /* Move icon to the right end of the button */
    transform: translateX(0); /* Align icon naturally */
    color: #040919;
}

/* ADD CART PANEL */
.add-cart-bottom-sheet { 
    display: none; /* Initially hidden */
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.2);
    padding: 20px 30px;
    z-index: 1000;
    height: 100vh;
    overflow-y: auto;
    font-family: Arial, sans-serif;
}

.product-name {
    font-size: 1.3rem !important;
    font-weight: bold;
    margin-bottom: 10px;
    margin-top: 20px;
}
.type-fabric-name {
    font-size: 1.2rem;
    font-weight: bold;
    font-weight: 600;
    margin-bottom: 10px;
}


.store-dropdown {
    margin-bottom: 20px;
    position: relative;
    font-family: Arial, sans-serif;
    width: 100%;
}

.store-dropdown label {
    display: block;
    font-weight: bold;
    margin-bottom: 10px;
    color: #333;
}

.custom-select-cart {
    position: relative;
    display: inline-block;
    width: 100%;
    background-color: #f7f7f7;
    border: 2px solid #060c22fa;
    border-radius: 8px;
    cursor: pointer;
}

.select-trigger {
    padding: 10px;
    font-size: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.select-trigger .arrow {
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #060c22fa;
}

.store-options {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: #fff;
    border: 2px solid #060c22fa;
    border-radius: 8px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 1000;
}

.store-option {
    padding: 10px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.store-option:hover {
    background-color: #060c22fa;
    color: white;
}

.store-option.active {
    background-color: #060c22fa;
    color: white;
}

.custom-select-cart.open .store-options {
    display: block;
}

.check-stock-btn {
    background: white;
    color: #060c22fa;
    cursor: pointer;
    padding: 8px 16px;
    font-size: 14px;
    border-radius: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    flex-shrink: 0;
    font-weight: 600;
    text-decoration: underline;
    border: 2px solid transparent;
    background-color: #ffffff;
    margin-top: 10px;
}

.check-stock-btn i {
    margin-left: 8px;
    font-size: 1rem;
    text-decoration: none !important;
    color: #060c22fa;
}

/* BOTTOM SHEET STOK*/
.stock-bottom-sheet {
    display: none; /* Initially hidden */
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.2);
    padding: 20px;
    z-index: 1000;
    max-height: 97vh;
}

.stock-header {
  margin-top: 50px; /* Add top margin to create space from the close button */
  margin-bottom: 10px; /* Maintain existing bottom margin */
}

.stocks-detail-sheet {
    display: flex;
    flex-wrap: wrap; /* Membuat elemen warna bisa dilipat jika tidak muat */
    gap: 10px;
    margin-top: 20px;
    max-width: 100%;
    align-items: center;
    flex-direction: row;
    max-height: 80vh; /* Batasi tinggi maksimal */
    overflow-y: auto; /* Aktifkan scroll vertikal jika konten melebihi tinggi */
    padding-right: 10px;
    overflow-x: hidden;
    box-sizing: border-box;
    padding-bottom: 50px;
}
.stock-card {
  width: 100%;
  padding:0 15px;
  border-radius: 15px;
  border: 2px solid rgba(0, 0, 0, 0.4);
  box-shadow: 0 4px 5px rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
}
.stock-card-tittle {
  margin-top: 10px;
  border-bottom: 2px solid box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.4);
}
.stock-card-tittle h5 {
  font-size: 1.2rem;
  font-weight: 600;
  color: #060c22fa;
}
.stock-card-content {
  margin-top: 10px;
  display: flex;
  
}
.stock-body  {
  width: 50%;
}
.stock-rib {
  width: 50%;
}

/* Card untuk color-option-detail yang aktif */


.close-stocks-sheet-button {
  display: flex; /* Use flexbox to center the icon */
  justify-content: center; /* Center horizontally */
  align-items: center; /* Center vertically */
  position: absolute; /* Position it relative to the bottom sheet */
  right: 20px; /* Adjusted to place it on the right */
  top: 15px; /* Adjusted for vertical position */
  border-radius: 50%;
  background-color: #f82249;
  width: 30px; /* Diameter of the circle */
  height: 30px; /* Diameter of the circle */
  cursor: pointer; /* Change cursor to pointer on hover */
  margin-bottom: 30px;
}

.close-stocks-sheet-button i {
  color: white; /* Set icon color */
  font-size: 16px; /* Adjust icon size as needed */
}
@media (min-width: 768px) {
    .stock-bottom-sheet {
        width: 50%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        height: 100%;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
    }
  }

/* CART */
.section-cart {
    margin-bottom: 20px;
}
.sub-section-cart-left {
  width: 30%;
  display: flex;
  flex-direction: column;
}
.sub-section-cart-right {
  width: 70%;
  padding: 0px 20px;
  display: flex;
  flex-direction: column;
}
.section-cart h2 {
    font-size: 18px;
    font-weight: bold;
    display: flex;
    align-items: center;
}

/* Layout harga per kg di atas section */
.price-section {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.price-box {
    text-align: center;
    width: 45%;
}

.price-box h3 {
    font-size: 16px;
    margin-bottom: 5px;
}

.price-box .price {
    font-size: 18px;
    font-weight: bold;
}

.info-button {
    background: #ddd;
    border: none;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    margin-left: 10px;
    cursor: pointer;
    position: relative;
}

.info-button:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    top: -5px;
    left: 25px;
    background-color: rgba(0, 0, 0, 0.7);
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 12px;
}

.stock-info {
    margin: 5px 0;
    font-size: 0.9rem;
}

.input-amount {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

.unit-selection {
    display: flex;
    align-items: center;
    gap: 15px; /* Jarak antar radio button */
}

.unit-selection input[type="radio"] {
    display: none; /* Sembunyikan radio button asli */
}

.unit-selection label {
    position: relative;
    padding-left: 30px;
    font-size: 1rem; /* Ukuran teks label */
    cursor: pointer;
    user-select: none;

}

.unit-selection label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px; /* Ukuran radio button */
    height: 20px;
    border-radius: 50%;
    border: 2px solid #060c22fa; /* Warna border radio button */
    background-color: #fff; /* Warna background radio button */
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.1);
}

.unit-selection input[type="radio"]:checked + label::before {
    background-color: #fff; /* Warna radio button ketika terpilih */
    border-color: #060c22fa;
}

.unit-selection input[type="radio"]:checked + label::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 8px; /* Ukuran titik di tengah radio button */
    height: 8px;
    border-radius: 50%;
    background-color: #060c22fa; /* Warna titik tengah */
}

.unit-selection input[type="radio"]:hover + label::before {
    border-color: #060c22fa; /* Warna border saat hover */
}


.input-amount input {
    width: 85%;
    padding: 5px;
    margin-right: 5px;
    border-radius: 8px;
    border-color: rgba(0, 0, 0, 0.4) ;
}

.unit-label {
    width: 15%;
    font-size: 1.2rem;
    color: #555;
    text-align: right;
}


.note {
    font-size: 0.9rem;
    margin-top: 5px;
    color: rgba(0, 0, 0, 0.8);
}

.estimate-option {
    margin: 10px 0;
    font-size: 0.9rem;
    color: rgba(0, 0, 0, 0.8);
}

/* Layout subtotal dan total */
.subtotal {
    display: flex;
    justify-content: space-between;
  
}

.subtotal, .total p {
    font-size: 1rem;
}

.subtotal strong {
    font-size: 1rem;
    font-weight: bold;
}

/* Tombol masukkan ke keranjang */
.add-to-cart-detail {
    background-color: #040919;
    color: #fff;
    padding: 10px 20px;
    border: none;
    border-radius: 5px;
    width: 100%;
    cursor: pointer;
    font-size: 16px;
}

.add-to-cart-detail:hover {
    background-color: #218838;
}

.price-cart-detail-box {
  padding: 15px 10px;
  border: 2px solid rgba(0, 0, 0, 0.4);
  border-radius: 15px;
  width: 100%;
  margin-bottom: 15px;
  box-shadow: 0 2 5px rgba(0, 0, 0, 0.1);
}
.total {
    position: relative;
    padding-top: 10px; /* Jarak antara garis dan konten */
    margin-top: 5px; /* Tambahkan margin agar terlihat lebih baik */
    border-top: 1px dashed rgba(0, 0, 0, 0.7);
}

/* Media query untuk layar lebih besar dari 768px */
@media (min-width: 769px) {
    .add-cart-bottom-sheet {
        width: 40%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        max-height: 100vh;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
    }
    .section-cart {
        display: flex;
        justify-content: space-between;
    }

    .stock-info {
        width: 100%;
    }

    .unit-selection, .input-amount {
        width: 100%;
    }

    .subtotal, .total {
        justify-content: space-between;
        align-items: center;
        display: flex;
    }

    /* Harga per kg untuk body dan rib */
    .price-section {
        justify-content: space-between;
    }

    .price-box {
        width: 45%;
    }

    .price-box h3, .price-box .price {
        text-align: center;
    }

    /* Subtotal dan total align kiri dan kanan */
    .subtotal p, .total p {
        width: 50%;
    }

    .subtotal span, .total span {
        text-align: right;
        display: inline-block;
        width: 50%;
    }
}

@media (max-width: 768px) {
    .add-cart-bottom-sheet {
        width: 70%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        max-height: 100vh;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
    }
    .section-cart {
        display: flex;
        justify-content: space-between;
    }

    .stock-info {
        width: 100%;
    }

    .unit-selection, .input-amount {
        width: 100%;
    }

    .subtotal, .total {
        justify-content: space-between;
        align-items: center;
        display: flex;
    }

    /* Harga per kg untuk body dan rib */
    .price-section {
        justify-content: space-between;
    }

    .price-box {
        width: 45%;
    }

    .price-box h3, .price-box .price {
        text-align: center;
    }

    /* Subtotal dan total align kiri dan kanan */
    .subtotal p, .total p {
        width: 50%;
    }

    .subtotal span, .total span {
        text-align: right;
        display: inline-block;
        width: 50%;
    }
}
@media (max-width: 500px) {
     .add-cart-bottom-sheet {
        width: 90%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        max-height: 100vh;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
    }
}
@media (max-width: 500px) {
     .add-cart-bottom-sheet {
        width: 100%; /* Adjust width for larger screens */
        right: 0; /* Position from the right */
        left: auto;
        max-height: 90vh;
        top: 0; /* Align to top for desktop */
        bottom: auto; /* Reset bottom for desktop */
        border-radius: 10px 0 0 10px; /* Rounded left corners */
        padding: 20px 10px;
    }
    .type-fabric-name {
      font-size: 1rem;
    }
    .price {
      font-size: 0.9rem;
    }
    .stock-info {
      font-size: 0.8rem;
    }

    .unit-selection label {
      font-size: 0.9rem;
    }
    .sub-section-cart-right {
      margin-left: 10px;
    }
    .total p {
      margin-bottom: 0 !important;
    }
}

/*UNDER DEVELOPMENT */
.underdev {
  display: flex;
  margin-top: 90px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.animation-dev img {
    min-width: 200px;
    max-width: 100%;
    height: auto; /* Menjaga aspek rasio gambar */
}

.message-dev {
    margin-top: 20px;
    font-size: 18px; /* Ukuran font untuk pesan */
    color: #333; /* Warna teks */
    text-align: center;
  font-weight: 600;
}

/* HALAMAN CART */
.cart-section {
  height: 100%;
}
.cart-wrapper {
  display: flex;
  flex-direction: row;
  height: auto;
  gap: 25px;
  overflow: visible; /* Pastikan overflow parent tidak menghalangi sticky */
}
.cart-content {
  display: flex;
  width: 35%;
}
.store-group {
    margin-bottom: 30px;
    border-bottom: 10px solid #ddd;
}

.store-products {
    display: flex;
    flex-direction: column;
}
.cart-items {
  width: 75%;
  overflow-y: visible; /* Scroll hanya di bagian cart-items */
  height: 100%; /* Mengisi penuh tinggi yang tersedia */
  padding-right: 15px; /* Ruang untuk scrollbar */
  box-sizing: border-box;
}

.cart-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
    border-bottom: 1.5px dashed #ddd;
}

.cart-item img {
    width: 40px;
    height: 40px;
    object-fit: cover;
    margin-left: 10px;
    align-items: center;
}

.cart-item-details {
    flex: 1;
    padding-left: 5px;
}

.remove-item {
    background-color: #f82249;
    color: white;
    border: none;
    padding: 10px;
    border-radius: 8px;
    cursor: pointer;
}

.cart-summary {
  width: 25%;
  height: auto;
  text-align: left;
  margin-top: 20px;
  border: 1px solid #ddd;
  border-radius: 15px;
  padding: 15px;
  max-height: 50vh;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

.summary-title {
  font-size: 1.5rem;
  font-weight: 600;
  padding-bottom: 20px;
  border-bottom: 1px solid #ddd;
  text-align: center;
}
.cart-summary-wrapper {
  display: flex;
  flex-direction: column;
}
.summary-item, .summary-total {
    display: flex;
    justify-content: space-between; /* Mengatur item kiri dan kanan berjauhan */
    margin: 15px 0px;
}

.item-left {
    font-weight: bold;
}

.item-right {
    text-align: right;
    font-weight: bolder;
}

.btn-shipping {
    background-color: #060c22fa;
    color: white;
    margin-top: 0px;
    padding: 10px 20px;
    text-decoration: none;
    display: inline-block;
    border-radius: 10px;
    width: 100%;
    cursor: pointer;
}

.cart-item-details {
    margin-bottom: 10px; /* Memberikan jarak bawah */
    display: flex;
    flex-direction: row;
    align-items: center;
    
}
.cart-product-name {
  width: 90%;
  height: auto;
  font-weight: 600;
}
.cart-qty-price {
 width: 100%;
 display: flex;
  flex-direction: row;
padding-bottom: 10px;
}
.cart-wrapper-qty {
   width: 60%;
  display: flex;
    flex-direction: column;
}
.cart-action-btn {
  width: 10%;
  padding: 0 15px;
}
.cart-type {
  width: 20%;
   padding: 0 15px;
}
.cart-qty {
  width: 20%;
   padding: 0 15px;
}
.cart-price {
  width: 30%;
   padding: 0 15px;
}
.cart-subtotal {
  width: 30%;
   padding: 0 15px;
}

.cart-item-head {
    display: flex;
    justify-content: space-between;
    margin-bottom: 15px;
    align-items: center; /* Vertically aligns content */
    height: 40px;
    flex-direction: row;
    padding-left: 40px;
    flex: 1;
    border-bottom: 1px solid #ddd;
}

.cart-name-head {
    width: calc(25% + 40px);
    height: auto;
    font-weight: 600;
    padding-left:40px;
}

.cart-wrapper-qty-head {
    width: 60%;
    display: flex;
    flex-direction: row;
    align-items: center; /* Vertically centers the text inside */
    margin-left: 15px;
}

.cart-qty-price-head {
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center; /* Vertically centers the text inside */
}

.cart-action-btn-head {
    width: 10%;
    display: flex;
    align-items: center; /* Vertically centers the text inside */
    padding: 0 15px;
    font-weight: 600;
}

.cart-type-head,
.cart-qty-head {
    display: flex;
    align-items: center; /* Vertically centers the text inside */
    padding: 0 15px;
    width: 20%;
    font-weight: 600;
}
.cart-price-head,
.cart-subtotal-head {
    display: flex;
    align-items: center; /* Vertically centers the text inside */
    padding: 0 15px;
    width: 30%;
    font-weight: 600;
}
.img-cart {
  height: 100%;
  align-items: center;
  width: 10%;
  margin-right: 10px;
}
.remove-dekstop {
    display: block;
  }
  .remove-phone {
    display: none;
  }
.cart-qty-price-head-mobile {
  display: none;
  width: 100%;
  flex-direction: row;
  align-items: center;
}

@media (max-width: 1200px) {
  .cart-product-name {
    width: 90%;
  }
  .cart-name-head {
    width: calc(25% + 40px);
  }
  .cart-wrapper-qty-head,
  .cart-wrapper-qty {
    width: 65%;
    margin-left: 0px;
  }

  .cart-action-btn, 
  .cart-action-btn-head  {
    width: 10%;
    padding: 0 10px;
  }
  .cart-type,
  .cart-type-head,
  .cart-qty,
  .cart-qty-head {
    width: 20%;
    padding: 0 10px;
  }

  .cart-price,
  .cart-price-head {
    width: 32.5%;
    padding: 0 10px;
  }
  .cart-subtotal,
  .cart-subtotal-head {
    width: 32.5%;
     padding: 0 10px;
  }
  .remove-dekstop {
    display: block;
  }
  .remove-phone {
    display: none;
  }
  .cart-summary {
    max-height: 52vh;
  }
}

@media (min-width: 1000px){
      .cart-summary {
    position: sticky;
    top: 100px; /* Sticky 100px dari atas saat di layar >= 1024px */
    margin-top: 10px;
  }

}
@media (min-width: 769px) and (max-width: 1200px){
   .summary-title{
      padding-bottom: 5px;
      font-size: 1rem;
    }
    .summary-item,
    .summary-total {
      margin: 5px 0px;
    }
  .cart-summary {
    position: sticky;
    top: 100px; /* Sticky 100px dari atas saat di layar >= 1024px */
    margin-top: 10px;

  }
}
@media (max-width: 768px) {
  .cart-wrapper {
    flex-direction: column;
    height: auto;
    width: 100%;
  }

  .cart-items {
    width: 100%;
    height: auto; /* Menyisakan ruang untuk cart-summary */
    overflow-y: visible; /* Scroll hanya di bagian cart-items */
  }
.cart-item-details {
  width: 100%;
  flex-direction: column;
  gap: 10px;
}
.cart-item-head {
  display: none;
}
.img-cart {
  height: 100%;
  align-items: center;
  width: 10%;
  margin-right: 10px;
}
  .cart-summary {
    width: 100%;
    opacity: 1;
    position: fixed; /* Posisi tetap di bawah layar */
    bottom: 0; /* Jarak dari bawah */
    left: 0; /* Jarak dari kiri */
    padding: 5px 10px; /* Ruang di dalam elemen */
    border-radius: 10px 10px 0 0;
    margin: 0; /* Menghilangkan margin */
    box-shadow: none; /* Menghilangkan bayangan */
    z-index: 1000; /* Agar elemen berada di atas elemen lain */
    background-color: white; 
  }
  .btn-shipping {
    margin-top: 15px;
  }
  .cart-summary-wrapper{
    flex-direction: row; 
    justify-content: space-between;
  }
  .summary-item .item-left,
    .summary-total .item-left {
        display: none; /* Sembunyikan item-left */
    }
    .summary-title{
      padding-bottom: 5px;
    }
    .summary-item,
    .summary-total {
      margin: 5px 0px;
    }
  .note-cart {
    display: none;
  }
  .cart-product-name,
  .cart-wrapper-qty-head,
  .cart-wrapper-qty {
    width: 100%;
  }
  .cart-content {
    flex-direction: row;
    width: 100%;
  }
  .remove-item {
  display: inline-flex; /* Agar ikon dan teks berada dalam satu baris */
  align-items: center;  /* Vertikal align ikon dengan teks */
  gap: 5px;  /* Memberikan jarak antara ikon dan teks */
  padding: 5px 10px;
  font-size: 0.9rem;
  font-weight: bold;
}

.remove-item i {
  margin-right: 5px; /* Memberikan sedikit jarak antara ikon dan teks */
  font-size: 0.9rem;
}
  .remove-dekstop {
    display: none;
  }
  .cart-action-btn {
    width: 100%;
    display: flex; /* Menyusun elemen di dalam secara fleksibel */
    justify-content: center; /* Pusatkan secara horizontal */
    align-items: center; /* Pusatkan secara vertikal */
    gap: 10px; /* Jika ada beberapa tombol, beri jarak antar tombol */
}
.cart-qty-price-head-mobile {
  display: flex;
}
}

@media (max-width: 500px){
  .cart-items {
    padding-right: 0;
  }
  .store-group h5{
    font-size: 1rem;
  }
  .cart-qty-price-head,
  .cart-qty-price{
    font-size: 0.8rem;
  }
  .cart-product-name {
    font-size: 0.9rem;
  }
  .cart-type,
  .cart-type-head,
  .cart-qty,
  .cart-qty-head {
    width: 20%;
    padding: 0 5px;
  }

  .cart-price,
  .cart-price-head {
    width: 32.5%;
    padding: 0 5px;
  }
  .cart-subtotal,
  .cart-subtotal-head {
    width: 32.5%;
     padding: 0 5px;
  }
  .cart-item {
    border: 1px solid #ddd;
    border-radius: 10px;
    padding: 5px;
  }
  .summary-total,
  .summary-item,
  .summary-title {
    font-size: 0.9rem;
  }
  .btn-shipping {
    margin-top: 10px;
    padding: 5px 20px;
    width: 100%;
    color: white;
    background-color: #f82249;
    border: transparent;
  }
  .note-cart {
    display: none;
  }
    .remove-item {
  font-size: 0.8rem;
}

.remove-item i {
  margin-right: 5px; /* Memberikan sedikit jarak antara ikon dan teks */
  font-size: 0.8rem;
}
.alert-warning {
  font-size: 0.8rem;
}
.cart-summary {
  background-color: #040919;
  border-color: transparent;
}
.summary-title,
.summary-total,
.summary-item {
  color: white;
}

}

/* Gaya dasar untuk timeline */
.order-timeline-card {
  border: 1px solid #ddd;
  border-radius: 20px;

}
.order-timeline-card h3 {
  text-align: center;
  margin-top: 15px;
}
.order-timeline {
    display: flex;
    justify-content: flex-start;
    position: relative;
    padding: 10px 0;
    margin: 10px 0;
}

.timeline-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    flex-grow: 1;
}
.timeline-step p {
  margin-top: 15px;
}

.timeline-step::before {
    content: '';
    position: absolute;
    top: 50%;  /* Garis berada di tengah vertikal bulatan */
    left: 50%;  /* Garis mulai dari tengah bulatan */
    width: 100%;
    height: 3px;
    background-color: #ddd;
    z-index: -1;
    transform: translateX(-50%); /* Memindahkan garis ke tengah */
}

.timeline-step:first-child::before {
    left: 75%; /* Garis hanya mulai dari tengah bulatan pertama */
    width: 50%; /* Garis memanjang setengah untuk langkah pertama */
}

.timeline-step:last-child::before {
    left: 0; /* Garis berakhir di tengah bulatan terakhir */
    width: 120%; /* Garis memanjang setengah untuk langkah terakhir */
}

.step-icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid #ddd;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 10px;
    position: relative;
    background-color: white;
    z-index: 1;
}

/* Selesai */
.completed .step-icon {
    background-color: white;
    border: 3px solid #6bbf59; /* Hijau */
    color: #6bbf59;
}

.completed .step-icon i {
    font-family: FontAwesome;
    color: #6bbf59;
}

/* Aktif */
.active .step-icon {
    border: 3px solid #3498db; /* Border biru */
    background-color: white;  /* Background putih */
    position: relative;
}

.active .step-icon::after {
    content: '';
    width: 15px;
    height: 15px;
    background-color: #3498db;  /* Bulatan biru kecil */
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.active p {
    font-weight: bold;
    color: #3498db; /* Warna teks biru */
}

/* Belum berjalan */
.timeline-step:not(.completed):not(.active) .step-icon {
    border: 1px solid #ddd;
}

/* Responsif untuk mobile */
@media (max-width: 768px) {
    .order-timeline {
        flex-direction: column;
    }

    .timeline-step::before {
        display: none;
    }

    .timeline-step {
        flex-direction: row;
        justify-content: flex-start;
        margin-bottom: 20px;
    }

    .step-icon {
        margin-right: 15px;
        margin-bottom: 0;
    }
}

/* POP-UP KONFIRMASI */
.popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Latar belakang semi-transparan */
    display: flex;
    align-items: center; /* Vertikal di tengah */
    justify-content: center; /* Horizontal di tengah */
    z-index: 1000; /* Pastikan pop-up di atas elemen lainnya */
}

.popup {
    background-color: white;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    text-align: center;
}

.popup h3 {
    margin-bottom: 10px;
}

.popup-buttons {
    margin-top: 20px;
}

.popup-buttons button {
    margin: 0 10px;
    padding: 10px 15px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.popup-buttons button:hover {
    background-color: #f0f0f0; /* Warna latar belakang saat hover */
}

/* LOGIN */
.auth-container {
    display: flex;
    gap: 30px;
    padding: 20px;
    background-color: #fff;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
}

.form-container {
    width: 300px;
    padding: 20px;
    border-radius: 8px;
}

.form-title {
    color: #060c22fa;
    text-align: center;
    margin-bottom: 20px;
    font-size: 24px;
}

.input-group {
    margin-bottom: 15px;
}

.input-group label {
    display: block;
    font-size: 14px;
    color: #060c22fa;
    margin-bottom: 5px;
}

.input-group input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 16px;
    background-color: #f9f9f9;
}

.auth-btn {
    width: 100%;
    padding: 10px;
    background-color: #f82249;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    margin-top: 10px;
}

.auth-btn:hover {
    background-color: #d71f3f;
}

.oauth-container {
    text-align: center;
    margin-top: 15px;
}

.oauth-btn {
    background-color: #4285f4;
    color: white;
    border: none;
    padding: 10px 15px;
    border-radius: 5px;
    font-size: 14px;
    cursor: pointer;
}

.oauth-btn:hover {
    background-color: #357ae8;
}

/* Responsive Design */
@media (max-width: 768px) {
    .auth-container {
        flex-direction: column;
    }
}

/* WARNING MESSAGE */
.warning-message {
    opacity: 1; /* Atur opacity */
    margin-bottom: 10px; /* Jarak antara warning dan elemen di bawahnya */
    text-align: center; /* Pusatkan teks */
}
.warning-messages {
    margin-bottom: 15px; /* Margin bawah */
}

.alert {
    position: relative; /* Posisi relatif untuk tombol close */
    background-color: #fff3cd; /* Warna latar belakang untuk alert */
    border: 1px solid #ffeeba; /* Border untuk alert */
    border-radius: 5px; /* Sudut melengkung */
    padding: 15px; /* Padding */
    margin-bottom: 10px; /* Margin bawah untuk setiap alert */
   
}

.close-button {
    position: absolute; /* Posisi absolut untuk tombol close */
    top: 5px;
    right: 10px;
    background: none; /* Tidak ada latar belakang */
    border: none; /* Tidak ada border */
    font-size: 20px; /* Ukuran font */
    color: #856404; /* Warna untuk tombol close */
    cursor: pointer; /* Ubah kursor menjadi pointer */
}

.close-button:hover {
    color: #b58a00; /* Warna saat hover */
}

/* LOGIN FORM */
/* Container Style */
.login-form {
    width: 100%;
    max-width: 400px;
    margin: 10px auto;
    padding: 15px;
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    font-family: Arial, sans-serif;
}

/* Form Group Style */
.login-section {
  padding-top: 100px;
  background-size: cover; /* Atur gambar agar mengisi seluruh elemen */
  background-position: center; /* Tempatkan gambar di tengah */
  background-repeat: no-repeat; /* Jangan ulang gambar */
  height: 100%; /* Atur tinggi elemen agar penuh layar */
  width: 100%; /* Atur lebar elemen agar penuh lebar */
  background-image: url('{{ asset('img/bg_white.png') }}');
  
}
.login-form-title {
  margin-bottom: 20px;
  font-size: 1.5rem;
  font-weight: bold;

}
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    font-weight: 600;
    color: #040919;
    margin-bottom: 8px;
}

.form-group input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
    box-sizing: border-box;
    font-size: 16px;
    transition: border-color 0.3s ease;
}

.form-group input:focus {
    border-color: #f82249;
    outline: none;
}

/* Button Style */
.login-btn {
    width: 100%;
    padding: 12px;
    background-color: #f82249;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.login-btn:hover {
    background-color: #d71d3f;
}

/* Add Some Spacing and Alignment */
.login-form {
    text-align: left;
}

.login-btn:focus {
    outline: none;
}
.ask-register{
  margin-top: 20px;
}
.ask-register a {
 text-decoration: underline;
 color: blue;
 font-weight: bold;
}

@media (max-width: 768px) {
    .login-form {
        margin: 20px;
        padding: 15px;
    }
}

.register-section {
  padding-top: 40px;
    display: flex;
    align-items: center; /* Mengatur agar konten di tengah secara vertikal */
    justify-content: center; /* Mengatur agar konten di tengah secara horizontal */
    height: 100vh; /* Mengatur tinggi elemen agar penuh layar */
    background-size: cover; /* Gambar mengisi elemen */
    background-position: center; /* Gambar berada di tengah */
    background-image: url('{{ asset('img/bg_white.png') }}');
    
}
.register-wrapper {
  display: flex;
    align-items: center; /* Mengatur agar konten di tengah secara vertikal */
    justify-content: center; 
}
.register-row {
  display: flex;
  flex-direction: row;
  gap: 15px;
}
.register-column-left {
  width: 50%;
}
.register-column-right {
  width: 50%;
}
.register-card {
    margin-top: 50px;
    background: rgba(255, 255, 255, 0.8); /* Memberikan latar belakang putih transparan */
    padding: 20px; /* Memberikan padding di dalam kartu */
    border-radius: 10px; /* Mengatur sudut melengkung */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Memberikan bayangan untuk efek depth */
    width: auto;
    max-width: 90%; /* Mengatur lebar kartu agar responsif */
}

.is-invalid {
    border-color: red; /* Atur warna border untuk kolom input yang error */
}

.invalid-feedback {
    color: red; /* Atur warna pesan error */
    font-size: 0.875em; /* Ukuran font untuk pesan error */
}
.btn-wrapper {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
}
/* Button Style */
.register-btn {
    width: 50%;
    justify-content: center;
    padding: 12px;
    background-color: #f82249;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.register-btn:hover {
    background-color: #d71d3f;
}
@media (max-width: 500px){
  .register-row {
  flex-direction: column;
  gap:0;
}
.register-card {
  max-width: 85%;
  margin: 15px;
}
.register-column-left {
  width: 100%;
}
.register-column-right {
  width: 100%;
}
.register-section {
  height: auto;
  margin-top: 30px;
}
.register-btn {
  width: 80%;
}
}

.indented-text {
  text-indent: 30px; /* Atur jumlah indentasi sesuai kebutuhan */
  padding-left: 0 !important;
}

/* CERTIFICATE */

.certificate-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  width: 100%;
  justify-content: center;
}
.certificate-wrapper img {
  width: 15%;
  height: auto;
}

/* STORE DETAIL */
.detail-store-section {
  margin-top: 90px;
}

/*CAREER */

.social-links-big {
  display: flex;
  gap: 15px;
  width: 100%;
  align-items: center;
  justify-content: center;
}

.social-links-big a {
  display: flex; /* Menggunakan flexbox untuk penyusunan */
  max-width: 300px;
  height: auto;
  gap: 10px;
  padding: 10px 15px;
  border-radius: 20px;
  background-color: #060c22fa;
  align-items: center; /* Vertikal center */
  justify-content: center; /* Horizontal center */
  text-decoration: none; /* Menghapus garis bawah pada tautan */
  color: white;
}
.social-links-big i {
  color: white;

}

/* ICON LANGUAGE HEADER */
.icon-language {
    all: unset; /* Menghapus semua style default dari button */
    position: relative; /* Untuk positioning dropdown */
    cursor: pointer; /* Menunjukkan bisa diklik */
    color: white;
    background-color: transparent;
}

.custom-dropdown {
    display: none; /* Sembunyikan dropdown secara default */
    position: absolute; /* Mengatur posisi dropdown */
    background-color: #ffffff; /* Warna latar dropdown */
    border: 1px solid #ccc; /* Batas dropdown */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); /* Bayangan */
    z-index: 1000; /* Pastikan dropdown di atas elemen lain */
    margin-top: 5px; /* Jarak antara dropdown dan tautan */
}

.custom-dropdown-item {
    display: block; /* Buat item menjadi block */
    padding: 10px 15px; /* Ruang dalam item */
    color: #060c22fa; /* Warna teks */
    text-decoration: none; /* Menghapus garis bawah */
}

.custom-dropdown-item:hover {
    background-color: #f0f0f0; /* Warna latar saat hover */
}

/* ICON BAHASA DAN PROFILE PD HP */
/* Hide dropdown by default */
.language-option .dropdown-language {
    
    position: absolute;
    background-color: white;
    list-style-type: none;
    padding: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    border-radius: 5px;

}

/* Show dropdown on hover or click (for mobile) */
.language-option:hover .dropdown-language,
.language-option.active .dropdown-language {
    display: block;
}
@media (min-width: 769px) {
    .language-option {
        display: none;
    }
}
/* Mobile-specific styles */
@media (max-width: 768px) {
    .language-option {
        position: relative; /* Menjadikan .language-option sebagai referensi posisi */
    }

    .dropdown-language {
        position: absolute;
        top: 100%; /* Posisi tepat di bawah language-option */
        left: 0; /* Mepet ke kiri icon language-option */
        width: auto; /* Sesuaikan lebar */
        z-index: 1000; /* Pastikan dropdown muncul di atas elemen lain */
    }
    .dropdown-language {
        background-color: #f8f9fa; /* Warna latar dropdown */
        color: #000; /* Warna teks */
        padding: 10px;
        border: 1px solid #ddd; /* Tambahkan border agar dropdown terlihat */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Bayangan untuk efek dropdown */
    }

    .dropdown-language a {
        color: #000 !important; /* Warna teks pada link dropdown */
        display: block; /* Setiap link dalam dropdown pada satu baris */
        padding: 5px 10px; /* Tambahkan padding */
    }

    .dropdown-language a:hover {
        background-color: #e9ecef; /* Warna latar saat hover */
        color: #000; /* Warna teks saat hover */
    }
}

.icon-login .dropdown-menu-profile-mobile {
    display: none;
    position: absolute;
    background-color: white;
    list-style-type: none;
    padding: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border-radius: 5px;
    z-index: 1000; /* Pastikan dropdown muncul di atas elemen lainnya */
}

/* Show dropdown on hover or click (for mobile) */
.icon-login.active .dropdown-menu-profile-mobile {
    display: block; /* Memastikan dropdown muncul saat active */
}

@media (min-width: 769px) {
    .icon-login {
        display: none;
    }
    .login-icon-mobile {
      display: none;
    }
}

/* Mobile-specific styles */
@media (max-width: 768px) {
    .icon-login {
        display: block;
        position: relative;
    }
    .login-icon-mobile {
      display: block;
    }
    .dropdown-menu-profile-mobile {
        left: 15px;
        width: 200px;

    }
    .dropdown-menu-profile-mobile a {
        display: block !important; /* Pastikan link tampil */
        color: #000 !important;
    }
}

/* MAKLOON */

.makloon-section {

}

.makloon-images {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.image_mk1 {
  display: block;
  max-width: 300px;
  margin-right: -20px;
  z-index: 1;
  border-radius: 20px;
  margin-top: 20px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
.image_mk2 {
  display: block;
  max-width: 100%;
  z-index: 2;
  border-radius: 20px;
}
.image_mk3  {
  display: block;
  max-width: 300px;
  margin-left: -20px;
  z-index: 1;
  border-radius: 20px;
  margin-top: 20px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.makloon-title h5 {
  margin-top: 20px;
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  color: #060c22fa;
}

.makloon-desc p {
  text-align: center;
  font-size: 1rem;
  margin-left: 0 !important;

}

.makloon-btn {
  padding: 10px 15px;
  text-align: center;
  font-weight: bold;
  background: #060c22fa;
  border: 2px solid #060c22fa;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  border-radius: 25px;
  justify-content: center;
  align-items: center;

  color: white;
}
.makloon-btn:hover {
  background-color: #f82249;
  border: 3px solid #f82249;
  color: white;
}
.makloon-wrapper {
  width: 100%;
  display: flex;
  flex-direction: row;
}
.makloon-left {
  width: 50%;
  height: auto;
  padding: 20px;
  align-items: center;
}
.makloon-right {
  padding: 20px;
  padding-top: 0 !important;
  width: 50%;
  display: flex;
  flex-direction: column; /* ensures vertical stacking */
  align-items: center; /* centers items horizontally */
  justify-content: center; /* centers items vertically */
  margin: 0 auto; /* centers the whole block within its container */
}
@media (max-width: 768px) {
  .makloon-wrapper {
    flex-direction: column;

  }
  .image_mk2 {
    max-width: 100%;
  }
  .makloon-left, .makloon-right {
    width: 100%;
    padding-top: 0 !important;
  }
}

/* Cookie */
.cookie-popup {
    position: fixed;
    bottom: 20px;
    left: 20px;
    width: 500px;
    padding: 15px;
    background-color: #060c22fa; /* Warna utama website Anda */
    color: #ffffff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    border-radius: 8px;
    font-family: Arial, sans-serif;
    z-index: 1000;
    max-width: 100vw;
}

.cookie-popup p {
    margin: 0;
    padding: 0;
    font-size: 14px;
}
.cookie-text {
  color: white;
}
.cookie-link {
    color: #f82249; /* Warna sekunder */
    text-decoration: underline;
    font-weight: bold;
}

.cookie-link:hover {
    text-decoration: none;
}

.cookie-btn {
    background-color: #f82249;
    color: white;
    border: none;
    padding: 8px 20px;
    font-size: 14px;
    cursor: pointer;
    border-radius: 10px;
    margin-top: 10px;
}

.cookie-btn:hover {
    background-color: #e61a3f;
}

.hidden {
    display: none;
}

@media (max-width:768px) {
  .cookie-popup {
    width: 90vw;
    max-width: 90vw !important;
    bottom: 70px;
    left: 10px;
  }


}

/* PROFILE */
.profile-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 100px;
}

.profile-header {
    text-align: center;
    width: 100%;
    justify-content: center;
    align-items: center;
    display: flex;
    flex-direction: column;
}

.profile-img {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 20px;
    border: 2px solid #ddd;
}

.profile-info {
    text-align: center;
    font-size: 18px;
}

.address-section {
    margin-top: 40px;
    text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    border-top: 2px solid #ddd;
    padding-top: 20px;
}

.address-header {
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 10px;
}

.address-content {
    font-size: 16px;
    line-height: 1.5;
}

.default-profile-img {
    background-color: #f0f0f0;
    color: #666;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    font-size: 36px;
    margin-bottom: 20px;
    border: 2px solid #ddd;
}
.logout-profile-btn {
   padding: 10px 15px;
  text-align: center;
  font-weight: bold;
  background: #060c22fa;
  border: 2px solid #060c22fa;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  border-radius: 25px;
  justify-content: center;
  align-items: center;
  color: white;
}
.logout-profile-btn:hover {
  background-color: #f82249;
  border: 3px solid #f82249;
  color: white;
}
@media (max-width: 768px){
  .profile-header h1 {
      font-size: 1.5rem;
  }
}
.disable-btn {
  background-color: #ddd;

}
.disable-btn:hover {
  background-color: #ddd;
  
}
.captcha-wrapper {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
  margin-bottom: 15px;
}
.g-recaptcha {
  
}

/* ABOUT US NEW */
#about-section {
}
.cert-wrapper {
  display: flex;
  width: 100%;

  justify-content: center;
  flex-direction: row;
  flex-wrap: wrap;
}
.cert-image {
  width: 9%;
}

.about-wrapper {
  margin: 20px 10px;
  display: flex;
  flex-direction: row;
  width: 100%;
  background: linear-gradient(to right, #ffffff 0%, #ffffff 5%, #add8e6 10%, #0a4969 20%, #060c22fa 50%, #060c22fa 100%);
  border-radius: 20px;
}
.about-image {
  width: 50%;
  padding: 20px;
  display: flex;
  justify-content: center; /* Menyelaraskan gambar di tengah secara horizontal */
  align-items: center; /* Menyelaraskan gambar di tengah secara vertikal */
}
.about-image img{
  aspect-ratio: 1602 / 816;
  max-width: 100%;
  border-radius: 10px;
}
.about-text {
  width: 50%;
  padding: 20px;
   display: flex;
  justify-content: center; /* Menyelaraskan gambar di tengah secara horizontal */
  flex-direction: column;
}
.about-text p {
  color: white;
}
.about-full-text {
  width: 100%;
  display: flex;
}
.about-judul {
  width: 100%;
  padding-top: 30px;
  font-weight: bold;
}
.about-judul h4 {
  text-transform: uppercase;
  font-weight: bold;
}
.non-indent-text {
  text-indent: 0px; /* Atur jumlah indentasi sesuai kebutuhan */
  padding-left: 20px !important;
}
.about-right {
  width: 50%;
}
.about-left {
  width: 50%;
}
.text-0 {
  text-indent: 0px; /* Atur jumlah indentasi sesuai kebutuhan */
  padding-left: 0 !important;
  text-align: left !important;
}

@media (max-width: 768px) {
  .about-wrapper {
    flex-direction: column;
    background: linear-gradient(to bottom, #ffffff 0%, #ffffff 3%, #add8e6 7%, #0a4969 10%, #060c22fa 40%, #060c22fa 100%);
  }
  .about-image {
    
    width: 100%;
    padding: 10px !important;
  }
  .about-image img {
    aspect-ratio: 880 / 816;
  }
  .about-text {
    width: 100%;
  }
  .cert-image {
  width: 15%;
}
.about-judul h4 {
  text-transform: uppercase;
  font-size: 1.1rem;
}
.about-right {
  width: 100%;
}
.about-left {
  width: 100%;
}
.about-full-text {
  flex-direction: column;
}
}

/* Media query untuk ukuran layar maksimum 400px */
@media (max-width: 500px) {
    .indented-text, .text-0, .non-indent-text {
        font-size: 0.9rem !important; /* Ukuran font yang lebih kecil */
        text-align: left;
    }
    .about-judul {
      padding-top: 20px;
    }
}
/* SHIMMERING IMAGE */
.shimmer {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0.1) 100%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* SERACH BUTTON HEADER */
/* BOTTOM SHEET SEARCH */
.search-bottom-sheet {
    display: none; /* Initially hidden */
    position: fixed;
    bottom: 0;
    right: 0;
    height: 98vh;
    background-color: #fff;
    box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.2);
    padding: 20px;
    z-index: 1000;
    max-height: 98vh;
    width: 35%;
}

.close-search-sheet-button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    right: 20px;
    top: 15px;
    border-radius: 50%;
    background-color: #f82249;
    width: 30px;
    height: 30px;
    cursor: pointer;
}

.close-search-sheet-button i {
    color: white;
    font-size: 16px;
}

#searchInput {
    width: 100%;
    padding: 10px;
    margin-top: 10px;
    border-radius: 5px;
    border: 1px solid #ccc;
}

.search-detail-sheet {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
    max-width: 100%;
    max-height: 80vh;
    overflow-y: auto;
    padding-bottom: 50px;
}
.search-title {
  margin: 30px 0;
  font-weight: 700;
}
.product-card-search {
    width: 100%;
    display: flex;
    padding: 0 15px;
    border-radius: 15px;
    border: 2px solid rgba(0, 0, 0, 0.4);
    box-shadow: 0 4px 5px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    text-align: center;
    flex-direction: row;
    cursor: pointer;
}
.product-search-img {
  width: 20%;
  padding: 10px;
}
.product-search-name {
    width: 80%;
    display: flex; /* Enable Flexbox on this container */
    justify-content: left; /* Center text horizontally */
    align-items: center; /* Center text vertically */
}

@media (min-width: 1025px) and (max-width: 1200px){
  .search-bottom-sheet {
    width: 40%;
  }
}

@media (min-width: 769px) and (max-width: 1024px){
  .search-bottom-sheet {
    width: 50%;
  }
  .product-search-img {
    width: 15%;
  }
}

@media (min-width: 501px) and (max-width: 768px){
  .search-bottom-sheet {
    width: 70%;
  }
  .product-search-img {
    width: 15%;
  }
}
@media (max-width: 500px){
  .search-bottom-sheet {
    width: 100%;
    top: 70px;
  }
  .product-search-img {
    width: 20%;
  }
  .search-title {
  margin: 20px 0;
  }
}

/* DISPLAY BLOCK */
.display-block {
  display: block !important;
}
.product-colors {
  display: flex;
  flex-direction: column;
}

.warning-checkout {
    color: #d9534f;
    background-color: #f8d7da;
    padding: 10px;
    border: 1px solid #f5c6cb;
    border-radius: 5px;
    margin-top: 10px;
    padding-top: 30px;
    font-size: 14px;
    position: absolute;
    top: 90px;
    right: 20px;
    width: 30%;
}
.close-warning-checkout {
    background-color: transparent;
    border: none;
    color: #d9534f;
    font-weight: bold;
    position: absolute;
    top: 5px;
    right: 10px;
    cursor: pointer;
}

.skeleton-price {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.skeleton-line {
    background-color: #e0e0e0;
    border-radius: 4px;
    animation: skeleton-loading 1.2s infinite ease-in-out;
}

@keyframes skeleton-loading {
    0% {
        background-color: #e0e0e0;
    }
    50% {
        background-color: #f0f0f0;
    }
    100% {
        background-color: #e0e0e0;
    }
}


#kamus {
  padding-top: 90px;
   scroll-padding-top: 90px; /* Mengatur jarak 90px untuk scroll dalam section ini */
}
#kamus .istilah-item {
    scroll-margin-top: 100px; /* Menambahkan jarak 90px ke atas saat digulir */
}
.search-bar {
  margin: 20px 0;
  }
  .search-utama {
    display: none;
  }
  .search-side {
    display: block;
  }
.search-bar input[type="text"] {
  padding: 10px 5px;
  width: 73%;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.search-bar button {
  padding: 10px 0;
  border: none;
  background-color: #f82249;
  color: white;
  width: 25%;
  border-radius: 4px;
  cursor: pointer;
}
.kamus-container {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 0 3%;
}

/* Styling Daftar Isi */
.kolom-kanan {
    width: 25%;
    padding: 10px;
    margin-top: 30px;
}
.daftar-isi {
  border: 1px solid #ddd;
  padding: 15px;
  border-radius: 15px;
}
.daftar-isi h2 {
    font-size: 18px;
    margin-bottom: 15px;
    font-weight: bold;
}

.daftar-isi ul {
    list-style-type: none;
    padding: 0;
}

.daftar-isi ul li {
    margin: 5px 0;
}

.daftar-isi ul li a {
    text-decoration: none;
    color: #007bff;
    font-weight: bold;
}

.daftar-isi ul li a:hover {
    text-decoration: underline;
}

/* Styling Konten Utama */
.konten-utama {
    width: 75%;
    padding: 20px;
}

.konten-utama .section-header h1 {
    font-size: 24px;
    color: #333;
}

.istilah-item {
    margin-bottom: 10px;
     transition: padding-top 0.3s ease-in-out; /* Menambahkan efek transisi */
}

.istilah-item h2 {
            font-size: 1.5rem;
            color: #040919;
        }
.konten-utama h2 {
  font-size: 1.5rem;
            color: #040919;
}
.istilah-item p {
    font-size: 1rem;
    color: #666;
}
.floating-card {
  position: fixed; /* Tetap di tempat saat scrolling */
  bottom: 20px; /* Jarak 20px dari bawah */
  left: 50%; /* Posisikan di tengah secara horizontal */
  transform: translateX(-50%); /* Geser ke kiri sebesar setengah lebar elemen untuk memastikan center */
  width: 70%; /* Lebar elemen */
  justify-content: center; /* Untuk konten internal (opsional) */
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5); /* Efek bayangan */
  background-color: #fff; /* Pastikan elemen memiliki latar belakang */
  border-radius: 20px;
  z-index: 1000; /* Pastikan elemen berada di atas konten lain */
  padding: 10px;
  background-color: #040919;
}
.floating-card h2 {
  font-size: 1.5rem;
  font-weight: bold;
  color: white;
  text-align: center;
  margin: 0 !important;
}
.content-floating-card {
  display: flex; /* Aktifkan Flexbox */
  flex-direction: column; /* Atur konten ke kolom */
  justify-content: center; /* Pusatkan secara vertikal */
  align-items: center; /* Pusatkan secara horizontal */
  width: 100%;
  padding: 5px 20px;
  text-align: center; /* Tambahan untuk teks di tengah */
}
.close-card-floating {
  position: absolute; /* Posisi relatif terhadap floating card */
  top: 10px; /* Jarak dari atas */
  right: 15px; /* Jarak dari kanan */
  cursor: pointer; /* Tunjukkan bahwa elemen bisa diklik */
  font-size: 20px; /* Ukuran font ikon */
  color: #fff; /* Warna ikon */
}
.btn-floating-card {
  max-width: 30%;
  margin-top: 15px;
  word-wrap: break-word; /* Membungkus kata yang panjang */
  overflow-wrap: break-word; /* Dukungan tambahan untuk membungkus teks */
  white-space: normal; /* Memungkinkan teks untuk membungkus */
}
.close-card-floating:hover {
  color: red; /* Ubah warna saat hover */
}
@media (min-width: 768px) and (max-width: 1024px){
  .floating-card {
    width: 80%;
    bottom: 80px;
  }
  .floating-card h2 {
    font-size: 1.3rem;
  }
  .btn-floating-card {
      max-width: 35%;
    }

}
@media (min-width: 501px) and (max-width: 768px){
    .floating-card {
      width: 80%;
      bottom: 70px;
  }
  .floating-card h2 {
    font-size: 1.2rem;
  }
  .btn-floating-card {
  max-width: 60%;
  margin-top: 10px;
}
  .istilah-item h2 {
    font-size: 1.2rem;
    font-weight: bold;
  }
  .konten-utama h2 {
  font-size: 1.2rem;
  font-weight: bold;
}
  .istilah-item p {
    font-size: 0.9rem;
  }
  .kamus-container {
        flex-direction: column;
    }

    .kolom-kanan, .konten-utama {
        width: 100%;
        padding: 10px;
    }
    .search-utama {
    display: block;
    width: 100%;
  }
  .search-bar {
  margin: 15px 0;
  }
  .search-side {
    display: none;
  }
.search-bar input[type="text"] {
  padding: 8px 5px;
  width: 72%;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.search-bar button {
  padding: 8px 0;
  border: none;
  background-color: #f82249;
  color: white;
  width: 20%;
  border-radius: 4px;
  cursor: pointer;
}
}
@media (max-width: 500px){
  #kamus {
    padding-top: 60px;
  }
  #kamus h1 {
    font-size: 1.1rem !important;
  }
  .floating-card {
      width: 95%;
      bottom: 80px;
  }
  .floating-card h2 {
    font-size: 0.8rem;
  }
  .content-floating-card{
    padding: 5px 10px;
  }
  .btn-floating-card {
  max-width: 100%;
  font-size: 0.9rem;
  margin-top: 8px;
  font-display: auto;
}
  .floating-card a {
    font-size: 0.7rem;
  }
  .istilah-item h2 {
    font-size: 1rem;
    font-weight: bold;
  }
  .konten-utama h2 {
  font-size: 0.9rem;
}
  .istilah-item p {
    font-size: 0.8rem;
  }
  .kamus-container {
        flex-direction: column;
    }

    .kolom-kanan, .konten-utama {
        width: 100%;
        padding: 0px;
    }
   .search-utama {
    display: block;
    width: 100%;
  }
  .search-bar {
  margin: 10px 0;
  }
  .search-side {
    display: none;
  }
.search-bar input[type="text"] {
  padding: 8px 5px;
  width: 72%;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.search-bar button {
  padding: 8px 0;
  border: none;
  background-color: #f82249;
  color: white;
  width: 20%;
  border-radius: 4px;
  cursor: pointer;
}
.close-card-floating {
  font-size: 1rem;
  top: 5px;
  right: 10px;
}
}
@media (max-width: 250px) {
.btn-floating-card {
  max-width: 100%;
  font-size: 0.7rem;
  margin-top: 8px;
}
}
.flex-main-image {
  display: flex;
  justify-content: center;
}
.thumbnail-image{
  width: 80%;
  height: auto;
  aspect-ratio: 1436 / 819;
  object-fit: fill;
  object-position: center;
  padding: 20px;
  justify-content: center;
}
.link-store-contact {
  color: blue;
}
.link-store-contact i {
  margin-right: 5px;
  margin-left: 5px;
}
  .daftar-container {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin: 20px 0;
  }


  .daftar-produk {
    flex: 1 1 calc(33% - 20px);
    background: #f9f9f9;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 15px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  }

  .daftar-produk h2 {
    font-size: 1.2rem;
    color: #040919;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-weight: bold;
  }

  .daftar-produk ul {
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .daftar-produk ul li {
    margin-bottom: 8px;
    font-size: 0.95rem;
    line-height: 1.5;
    color: #040919;
    position: relative;
    padding-left: 20px;
  }

  .daftar-produk ul li::before {
    content: "\2022"; /* Bullet point */
    position: absolute;
    left: 0;
    color: #f82249; /* Highlight color */
    font-size: 1.2rem;
    line-height: 1;
  }

  @media (max-width: 768px) {
    .daftar-produk {
      flex: 1 1 100%;
    }
    .thumbnail-image {
      padding: 10px;
      width: 96%;
    }
  }
  
@media (min-width: 769px) and (max-width: 1024px) {
    .daftar-produk {
      flex: 1 1 calc(50% - 20px);
    }
    .thumbnail-image {
      padding: 10px;
      width: 96%;
    }
  }

  .video-section {
    background-color: #f9f9f9;
    padding: 40px 20px;
    text-align: center;
}

.video-section p {
    font-size: 1rem;
    color: #333;
    margin-bottom: 20px;
}

.video-container-supplier {
        position: relative;
        width: 100%;
        height: 0;
        padding-bottom: 56.25%; /* 16:9 aspect ratio */
        background-color: #000;
        overflow: hidden;
        border: 5px solid #f82249;
        border-radius: 25px;
    }

  .video-container-supplier iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
  }

.video-container-supplier video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 3px solid #f82249;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

 .video-placeholder-supplier {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-size: cover;
        background-position: center;
        cursor: pointer;
        display: flex;
        justify-content: center; /* Center horizontally */
        align-items: center;    /* Center vertically */
        text-align: center;
    }

    .video-thumbnail-supplier {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .play-button-red {
      width: auto;
        border: none;
        cursor: pointer;
        position: absolute;
        background-color: transparent;
    }
    .play-button-red i {
        color: #f82249;
        font-size: 3rem;
    }

@media (max-width: 500px) {
  .play-button-red i {
        color: #f82249;
        font-size: 2rem;
    }
    .video-container-supplier {
      border-radius: 15px;
    }
    .daftar-produk h2 {
    font-size: 1rem;
  }
}

@media (max-width: 767px) {
    #slider-dekstop {
        display: none !important;
    }
}

#colortable {
  max-width: 100vw;
}
.table-warna {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 16px;
    text-align: left;
}

.table-warna th, 
.table-warna td {
    border: 1px solid #ddd;
    padding: 12px;
}

.table-warna th {
    background-color: #e6edf6;
    color: #333;
    text-align: center;
    font-weight: bold;
     position: sticky; /* Membuat header sticky */
    top: 90px; /* Menempel di bagian atas tabel */
    z-index: 2; /* Menjaga agar header tetap di atas konten tabel */
}

.table-warna tr:nth-child(even) {
    background-color: #f3f4f6;
}

.table-warna tr:hover {
    background-color: #f1f1f1;
}

.color-preview {
    display: inline-block;
    width: 30px;
    height: 30px;
  
    border: 1px solid #ccc;
    margin-right: 10px;
    vertical-align: middle;
    
    -webkit-mask-image: url('/img/icon/kaos.svg');
    mask-image: url('/img/icon/kaos.svg');
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
}
.justify-center{
  justify-content: center;
}
.sub-category-link {
    display: inline-block;
    color: blue; /* Teks putih */
    border-radius: 50%; /* Membuat bulatan */
    width: 30px; /* Lebar bulatan */
    height: 30px; /* Tinggi bulatan */
    line-height: 30px; /* Vertikal align teks */
    text-align: center; /* Horizontal align teks */
    margin-right: 5px; /* Jarak antar bulatan */
    text-decoration: none; /* Hilangkan garis bawah */
    font-size: 12px; /* Ukuran teks */
    font-weight: bold;
}

.sub-category-link:hover {
    background-color: #333; /* Warna saat hover */
}

@media (max-width: 768px) {
  .table-warna {
    font-size: 0.8rem;
    max-width: 98vw;
  }
  .table-warna th, 
.table-warna td {
    font-size: 0.8rem;
    padding: 3px;
}

.table-warna th {
    background-color: #f4f4f4;
    color: #333;
    font-weight: bold;
     position: sticky; /* Membuat header sticky */
    top: 90px; /* Menempel di bagian atas tabel */
    z-index: 2; /* Menjaga agar header tetap di atas konten tabel */
}
}
@media (max-width: 500px) {
  .table-warna {
    font-size: 0.7rem;
    max-width: 98vw;
  }
  .table-warna th, 
.table-warna td {
    font-size: 0.7rem;
    padding: 3px;
}
.search-color {
    width: 100% !important;
    font-size: 0.8rem;

}
.table-warna th {
  text-align: center;
    background-color: #f4f4f4;
    color: #333;
    font-weight: bold;
     position: sticky; /* Membuat header sticky */
    top: 70px; /* Menempel di bagian atas tabel */
    z-index: 2; /* Menjaga agar header tetap di atas konten tabel */
}
}
.table-responsive {
    overflow-x: auto; /* Mengaktifkan scroll horizontal */
    -webkit-overflow-scrolling: touch; /* Memperhalus scrolling di perangkat sentuh */
}
.search-color {
  position: relative;
    display: flex;
    align-items: center;
    width: 30%;
    margin-bottom: 20px;
    margin-top: 20px;
}
.search-input {
    position: relative;
    width: 100%;
    padding: 10px 40px 10px 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 16px;
}

.search-icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: #aaa;
    cursor: pointer;
}

/* UPGRADE TOKO */
.store-list-new {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
    margin: 20px;
}
.store-list-new h2 {
    text-align: center;
}

.store-card {
    background: #ffffff;
    border: 1px solid #ddd;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s, box-shadow 0.3s;
}

.store-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
}


.store-content-new {
    padding: 15px;
}

.store-title {
    font-size: 18px;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
}

.store-title a {
    text-decoration: none;
    color: inherit;
}

.store-title a:hover {
    color: #f82249;
}

.store-address {
    font-size: 14px;
    color: #666;
    margin-bottom: 10px;
}

.map-container {
    margin: 15px 0;
    border: 1px solid #ddd;
    border-radius: 5px;
    overflow: hidden;
}

.store-links-new {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 10px;
    justify-content: center;
}

.store-link-new {
    display: inline-block;
    padding: 8px 12px;
    font-size: 14px;
    color: #ffffff;
    background-color: #e6212a;
    border-radius: 5px;
    text-decoration: none;
    transition: background-color 0.3s;
}

.store-link-new:hover {
    background-color: #c51d25;
    color: white;
}

.store-detail {
    margin-top: 10px;
    text-align: center;
}

.store-detail-button {
    display: inline-block;
    padding: 10px 15px;
    font-size: 14px;
    color: #ffffff;
    background-color: #060c22fa;
    border-radius: 5px;
    text-decoration: none;
    transition: background-color 0.3s;
}

.store-detail-button:hover {
    background-color: #444b6a;
}

/* DISPLAY COLUMN 50-50*/
.flex-column-custom {
  width: 100%;
  display: flex;
  gap: 20px;
  flex-direction: row;
}

.left-column {
  width: 50%;
}
.right-column {
  width: 50%;
}
.card-display {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.3);
  padding: 15px;
}
.card-display h2 {
  font-weight: bold;
}
@media (max-width: 768px) {
  .flex-column-custom {
    flex-direction: column;
  }
  .left-column {
  width: 100%;
}
.right-column {
  width: 100%;
}
.card-display h2{
      font-size: 1.5rem !important;

}
}
@media (max-width: 500px){
  .pt-90 {
    padding-top: 70px !important;
  }
  .card-display h2{
      font-size: 1.2rem !important;
  }
}

#artikel {
  padding-top: ;
}

.container-artikel {
    display: flex;
    flex-direction: row;
    gap: 20px;
}

.content-artikel {
    flex: 3;
    margin-right: 20px;
    font-family: 'Inter', sans-serif;
    color: #23272A;
}
.content-artikel p {
    color: #4A4A4A;
    font-style: normal;
    font-family: 'Inter', sans-serif;
}
.content-artikel a {
    color: #2C3E50;
}
.content-artikel h2, h3, h4, h5 {
    color: #1A1A1A;
    font-family: 'Lato', sans-serif;
}
.content-artikel ul li {
    color: #4A4A4A;
    font-style: normal;
    font-family: 'Inter', sans-serif;
}

.content-artikel table {
  margin-left: 20px;
  margin-bottom: 20px;
}

.content-artikel h2 {
  font-size: 1.5rem !important;
  font-weight: 700;
}

.content-artikel h3 {
  font-size: 1.3rem !important;
  font-weight: 700;
}

.sidebar-artikel {
    flex: 1;
}

@media (max-width: 768px) {
    .container-artikel {
        flex-direction: column;
    }
    .content-artikel {
        margin-right: 0;
    }
    .content-artikel h2 {
      font-size: 1.25rem !important;
    }
    .content-artikel h3 {
      font-size: 1.1rem !important;
    }
}

.no-transform {
    text-transform: none !important;
}
.h-20 {
  margin-top: -20px;
}
.btn-artikel {
  max-width: 80%;
  font-weight: bold;
}

.option-nonaktif {
  color: #999999 !important ;
  border-color: 1px solid #999999 !important;
}

.banner-pelopor {
  margin-top: 30px;
  margin-bottom: 30px;
}

.banner-pelopor img {
  width: 100%;
  aspect-ratio: 2288 / 800;
}
.max-500 {
  max-width: 500px;
}
@media (max-width: 500px){
  .banner-pelopor {
  margin-top: 20px;
  margin-bottom: 20px;
}
.max-500 {
  max-width: 360px;
}
}

.custom-form-altra {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.form-group-altra label {
    font-weight: bold;
}

.form-group-altra input,
.form-group-altra select {
    padding: 0.5rem;
    width: 100%;
    border-radius: 5px;
    border: 1px solid #ccc;
}

.btn-submit-altra {
    background-color: #a0031c;
    color: white;
    border: none;
    padding: 0.7rem;
    cursor: pointer;
    border-radius: 5px;
    font-weight: bold;
}

.result-box-altra {
    padding: 1rem;
    background: #f2f2f2;
    border-radius: 8px;
}


.hasil-box {
  padding-top: 0 !important;
    padding: 20px;
    background: #f9f9f9;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.hasil-box h2 {
    text-align: center;
    margin-bottom: 20px;
    font-size: 1.4rem;
    font-weight: bold;
}

.hasil-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    flex-direction: row;
}

.hasil-kiri,
.hasil-kanan {
    flex: 1 1 300px;
}

.hasil-kiri p,
.hasil-kanan p {
    margin-bottom: 10px;
    font-size: 16px;
}

.hasil-kiri span,
.hasil-kanan span {
    font-weight: bold;
    color: #333;
    display: inline-block;
    min-width: 160px;
}

.merah {
    color: #a0031c;
    font-weight: bold;
}

/* Responsive */
@media (max-width: 768px) {
    .hasil-grid {
        flex-direction: column;
    }
    .hasil-kiri,
    .hasil-kanan {
        flex: 1 1 0;
    }
    .hasil-box h2 {
      font-size: 1.4rem;
    }
}

.warna-detail-card {
  
}

/* Section wrapper */
#cerita-altra {
    padding: 5px 20px;
    background: #fafafa;
}

/* Container */
.cerita-altra-container {
    max-width: 1200px;
    margin: 0 auto;
}

/* Header */
.cerita-altra-section-header {
    text-align: center;
    margin-bottom: 40px;
}

.cerita-altra-section-header h2 {
    font-size: 2rem;
    font-weight: 700;
    color: #222;
    margin-bottom: 10px;
}

.cerita-altra-section-header p {
    color: #555;
    font-size: 1rem;
}

/* Grid layout */
.cerita-altra-grid {
    display: grid;
    gap: 25px;
}

/* HP default: 1 kolom */
.cerita-altra-grid {
    grid-template-columns: 1fr;
}

/* Tablet: 2 kolom */
@media (min-width: 768px) {
    .cerita-altra-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* PC: 3 kolom */
@media (min-width: 1024px) {
    .cerita-altra-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Card */
.cerita-altra-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.cerita-altra-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.12);
}

/* Video wrapper */
.cerita-altra-video {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9; /* menjaga proporsi */
    overflow: hidden;
    border-radius: 12px;
    background: #000; /* biar pas loading gak putih */
}
.cerita-altra-video img {
    width: 100%;
    height: 100%;
    object-fit: cover;  /* potong proporsi kalau perlu */
    display: block;
}

.cerita-altra-video iframe,
.cerita-altra-video img,
.cerita-altra-video blockquote {
    width: 100%;
    height: 100%;
    object-fit: cover; /* isi penuh tapi potong pinggir sedikit */
    display: block;
    border: 0;
}

/* Info */
.cerita-altra-info {
    padding: 15px 20px;
}

.cerita-altra-info h3 {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: #112363;
    text-align: center;
}

.cerita-altra-info p {
    font-size: 0.95rem;
    color: #555;
    line-height: 1.4;
    text-align: center;
}