html {
    scroll-behavior: smooth;
}

body
{
    background: #ffffff;
    font-family: "Caudex", serif;
    font-optical-sizing: auto;
    font-style: normal;
	  font-weight: 400;
	  position: relative;
    color: #658C58;
}

html,body {
	width: 100%;
	overflow-x: hidden;
}

h1, h2, h3, h4 {
	font-weight: bold;
    color: #658C58;
}

.heading {
	font-size: 60px;
}
.subheading {
	font-size: 14px;
	font-weight: bold;
	padding-bottom: 60px;
}

p {
	letter-spacing: 0px;
	line-height: 28px;
}

#about,
#planner, #contact {
	padding-top: 100px;
	padding-bottom: 100px;
}

#about .fa {
	font-size: 28px;
	min-width: 34px;
}

/* start navigation */
.custom-navbar {
    background: #ffffff;
    margin-bottom: 0;
}
.custom-navbar .navbar-brand  {
	color: #658C58;
	font-size: 40px;
}
.custom-navbar .navbar-brand .navbar-toggle {
    background: #55acee;
    padding: 4px 6px;
    font-size: 16px;
    color: #fff;
}
.custom-navbar .nav li a {
    text-decoration: none;
    color: #658C58;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 1px;
    padding-right: 20px;
    padding-left: 20px;
	  transition: all 0.3s ease-in-out;
    border-radius: 20px;
}
.custom-navbar .nav li a:hover {
    color: #FEEE91;
  	background: #658C58;
  	transition: all 0.3s ease-in-out;
    border-radius: 20px;
}
.custom-navbar .nav li.active > a {
    color: #FEEE91;
    background-color: #658C58;
    border-radius: 20px;
}
.custom-navbar .navbar-toggle {
    border: none;
    padding-top: 10px;
}
.custom-navbar .navbar-toggle .icon-bar {
    background: #658C58;
    border-color: transparent;
}
@media(min-width:768px){
    .custom-navbar {
            background: #ffffff;
            padding: 14px;
            border-bottom: 0;
            background: 0 0;
         }
    .custom-navbar.top-nav-collapse {
            padding: 14px;
            background: #fff;
            border-bottom: 1px solid #eeeeee;
        }
}

/* home section */
#home {
  background: url('../images/back2.jpg') center / cover no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100vh;
  text-align: center;
}
#home h3 {
  letter-spacing: 2px;
  color: #658C58;
}
#home h1 {
  font-weight: Bold;
  color: #658C58;
}
#home .btn {
  background: #658C58;
  border: 2px solid #658C58;
  color: #fff;
  font-weight: bold;
  padding: 12px 36px;
  margin-top: 40px;
  transition: all 0.4s ease-in-out;
  border-radius: 14px;
}

#home .btn:hover {
  color: #FEEE91;
}

/* about section */
#about {
    color: white;
    background: #658C58;
}

#about .container .row h1,
#about .container .row h2,
#about .container .row h3{
  color: white;
}
#about h3{
  margin-top: 20px;
}
#about .container .row {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#about .container .row .produk {
  margin-top: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}
.produk{
  padding-top: 50px;
}

.price-wrapper {
    display: flex;
    flex-direction: column;
    gap: 2px;
    align-items: center;
}
.price-old {
    font-size: 16px;
    color: #888;
    text-decoration: line-through;
}
.price-discount {
    font-size: 28px;
    font-weight: bold;
    color: #e63946;
}
.price-badge {
    margin-top: 10px;
    background: #e63946;
    color: white;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 14px;
    display: inline-block;
}



/* Pastikan selector langsung menggunakan ID */
#gam-und-dig {
    border-radius: 20px;
    background-image: url('../images/unddig.jpg'); /* path sudah benar */
    background-size: cover;       /* gambar menutupi div */
    background-position: center;  /* posisi gambar di tengah */
    background-repeat: no-repeat; /* jangan diulang */
    width: 100%;                  /* lebar div 100% dari parent */
    height: 400px;                /* tinggi div, jangan auto */
}
#gam-wed-plan {
    border-radius: 20px;
    background-image: url('../images/wedplan.jpg'); /* path sudah benar */
    background-size: cover;       /* gambar menutupi div */
    background-position: center;  /* posisi gambar di tengah */
    background-repeat: no-repeat; /* jangan diulang */
    width: 100%;                  /* lebar div 100% dari parent */
    height: 400px;                /* tinggi div, jangan auto */
}

@media (max-width: 768px) {
  .produk {
    flex-direction: column;
    align-items: center;
  }
}

#sectionharga{
  min-height:100vh;
  padding:60px 8%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:linear-gradient(135deg,#f4f7f3,#ffffff);
  color:#333;
}

.headerharga{
  text-align:center;
  margin-bottom:50px;
}

.headerharga h1{
  color: #658C58;
  margin-bottom:10px;
}

.headerharga p{
  font-size:16px;
  color: #658C58;
  max-width:600px;
  margin:auto;
}

.harga{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:30px;
}

.card{
  background:#fff;
  border-radius:20px;
  padding:30px;
  box-shadow:0 15px 40px rgba(0,0,0,.08);
  transition:.4s ease;
  position:relative;
  overflow:hidden;
}

.card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:5px;
  background:#658C58;
}

.card:hover{
  transform:translateY(-10px);
  box-shadow:0 25px 60px rgba(0,0,0,.12);
}

.card h3{
  font-size:26px;
  color: #658C58;
  margin-bottom:15px;
}

.card ul{
  list-style:none;
  margin-bottom:20px;
}

.card ul li{
  font-size:14px;
  margin-bottom:8px;
  color:#555;
}

.card a{
    text-decoration: none;
}

.card a:hover{
    color:white;
}

.priceharga{
  font-size:22px;
  font-weight:600;
  margin-bottom:20px;
}

.priceharga span{
  font-size:14px;
  color:#999;
  text-decoration:line-through;
  margin-left:8px;
}

.btnprice{
  display:inline-block;
  text-decoration:none;
  padding:12px 28px;
  border-radius:50px;
  background: #658C58;
  color:#fff;
  font-size:14px;
  transition:.3s;
}

.btnprice:hover{
  background:#567a4c;
}

.footer-note{
  text-align:center;
  margin-top:50px;
  font-size:14px;
  color:#777;
}



#catalog {
  min-height: 100vh;
  padding: 60px 8%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #658C58;
  color: #333;
}

.headercatalog{
    padding-top: 30px;
  text-align:center;
  margin-bottom:50px;
}

.headercatalog h1{
  color: white;
  margin-bottom:12px;
}

.headercatalog p{
  max-width:650px;
  margin:auto;
  font-size:16px;
  color: white;
}

.containercatalog{
  display: grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:35px;
  padding: 20px;
}

.item{
  background:#fff;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 15px 40px rgba(0,0,0,.08);
  transition:.4s ease;
  text-decoration: none;
}

.item:hover{
  transform:translateY(-8px);
  box-shadow:0 25px 55px rgba(0,0,0,.12);
}

#catalog .thumb {
  height: 250px;
  overflow: hidden;
}

#catalog .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.item:hover img{
  transform:scale(1.08);
}

.content{
  padding:25px;
}

.content h3{
  font-family:'Playfair Display',serif;
  font-size:22px;
  color: #658C58;
  margin-bottom:10px;
}

.content p{
  font-size:14px;
  color:#555;
  line-height:1.6;
  margin-bottom:18px;
}

.tag{
  display:inline-block;
  padding:6px 16px;
  border-radius:50px;
  font-size:12px;
  background:rgba(101,140,88,.12);
  color: #658C58;
}

.footer-catalog{
  margin-top:60px;
  text-align:center;
  font-size:14px;
  color:white;
  padding-bottom: 30px;
}




.subheading{
  margin: 0px;
  padding: 2px;
}
.subheading-container{
  padding: 30px;
  min-height: 220px;
}

/* FILTER CSS */
.filter-wrapper {
    width: 100%;
    margin: 40px 0 24px 0;
    overflow: hidden;
    text-align: center;
}
.filter-wrapper li {
    display: inline-block;
    margin: 4px;
}
.filter-wrapper li a {
    color: #999999;
    font-size: 13px;
    font-weight: bold;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 8px 17px;
    display: block;
    text-decoration: none;
    transition: all 0.4s ease-in-out;
}
.filter-wrapper li .selected,
.filter-wrapper li a:focus,
.filter-wrapper li a:hover {
    background: #658C58;
    color: #ffffff;
    outline: none;
  }

/* ISOTOPE BOX CSS */
.iso-box-section {
    width: 100%;
}
.iso-box-wrapper {
    width: 100%;
    padding: 0;
    clear: both;
    position: relative;
}
.iso-box {
    position: relative;
    min-height: 50px;
    float: left;
    overflow: hidden;
    margin-bottom: 20px;
}
.iso-box > a {
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.iso-box > a {
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.fluid-img {
  width: 100%;
  display: block;
}

/* team section */
#team {
  text-align: center;
}
#team h3 {
  color: #202020;
  line-height: 4px;
}
#team .team-des {
  padding-top: 20px;
  padding-bottom: 40px;
}

/* contact section */
#contact {
  background: #f9f9f9;
  text-align: center;
}
#contact .fa {
  font-size: 40px;
}

.contact-info-box h3 { font-size: 16px; }

#rowfooter{
  margin-top: 60px;
}

#rowfooter a {
  text-decoration: none;
}

#rowfooter i {
  font-size: 36px;
  color: #658C58;
}

@media (max-width: 550px) {
  #rowfooter{
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
  }
  #rowfooter i {
      font-size: 32px;
  }
  #rowfooter h3{
      display: flex;
      font-size: 18px;
      justify-content: center;
      align-items: center;
      text-align: center;
  }
}

/* footer section */
footer {
  background: url('../images/back2.jpg') no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center;
  text-align: center;
  padding-top: 80px;
  padding-bottom: 80px;
}
.social-icon {
  padding: 0;
  text-align: center;
  vertical-align: middle;
}
.social-icon li {
  list-style: none;
  display: inline-block;
  padding: 0;
}
.social-icon li a {
  border-radius: 50%;
  color: #303030;
  font-size: 32px;
  width: 80px;
  height: 80px;
  line-height: 80px;
  text-align: center;
  text-decoration: none;
  transition: all 0.4s ease-in-out;
  margin-top: 20px;
  margin-right: 10px;
}
.social-icon li a:hover {
  background: #658C58;
}

@media (max-width: 450px) {
  .social-icon li a {
      width: 40px;
      height: 40px;
  }
}

/* copyright section */
#copyright {
  background: #404040;
  color: #ffffff;
  padding-top: 20px;
  padding-bottom: 20px;
}
#copyright p {
  padding-top: 20px;
}
#copyright a {
	color: #fff;
}
#copyright a:hover {
	color: #658C58;
	text-decoration: none;
	transition: all 0.4s ease-in-out;
}
#copyright .fa {
  background: #383838;
  color: #ffffff;
  font-size: 18px;
  width: 60px;
  height: 60px;
  line-height: 60px;
  text-align: center;
  text-decoration: none;
  outline: none;
  transition: all 0.4s ease-in-out;
}
#copyright .fa:hover {
  background: #658C58;
  color: #000;
}

@media screen and (min-width: 992px) {
  @-moz-document url-prefix() {
    #harga .col-lg-4,
    #harga .col-md-4 {
      width: 33.333%;
    }
  }    
}

@media ( max-width: 980px ) {
  .custom-navbar .navbar-brand {
    font-size: 24px;
  }
  #about img {
    padding-top: 40px;
  }
  #contact form {
    padding-top: 30px;
  }
}

@media screen and (max-width: 767px) {
  .contact-info-box { margin-bottom: 20px; }
  .contact-info-box:last-child { margin-bottom: 0; }
}

@media (max-width: 450px) {
  .heading {
    font-size: 40px;
  }
  #about .col-md-4 .fa {
    margin-top: 32px;
  }
  #contact h3 {
    font-size: 16px;
    padding-bottom: 40px;
  }
}

#catalog .container .row h1 {
    color: white;
}

.iframe-wrapper {
  width: clamp(200px, 20vw, 375px); 375px;      /* simulasi layar mobile */
  height: clamp(352px, 10vw, 660px); 667px;     /* tinggi layar */
  overflow: hidden;
}

.iframe-wrapper iframe {
  width: 50%;
  height: 50%;
  border: none;
}


/* Reset tampilan link untuk card katalog */
#catalog a.item,
#catalog a.item:link,
#catalog a.item:visited,
#catalog a.item:hover,
#catalog a.item:active,
#catalog a.item:focus,
#catalog a.item:focus-within {
  text-decoration: none;
  color: inherit;
  outline: none;
}

/* Pastikan child element juga tidak mewarisi garis */
#catalog a.item * {
  text-decoration: none;
}

/* Hover tetap kelihatan interaktif */
#catalog a.item:hover {
  cursor: pointer;
  text-decoration: none;
}
