﻿.poppins-thin {
   font-family: "Poppins", sans-serif;
   font-weight: 100;
   font-style: normal;
}

.poppins-extralight {
   font-family: "Poppins", sans-serif;
   font-weight: 200;
   font-style: normal;
}

.poppins-light {
   font-family: "Poppins", sans-serif;
   font-weight: 300;
   font-style: normal;
}



.poppins-regular {
   font-family: "Poppins", sans-serif;
   font-weight: 400;
   font-style: normal;
}

.poppins-medium {
   font-family: "Poppins", sans-serif;
   font-weight: 500;
   font-style: normal;
}

.poppins-semibold {
   font-family: "Poppins", sans-serif;
   font-weight: 400;
   font-style: normal;
}

.poppins-bold {
   font-family: "Poppins", sans-serif;
   font-weight: 700;
   font-style: normal;
}

.poppins-extrabold {
   font-family: "Poppins", sans-serif;
   font-weight: 800;
   font-style: normal;
}

.poppins-black {
   font-family: "Poppins", sans-serif;
   font-weight: 900;
   font-style: normal;
}

.poppins-thin-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 100;
   font-style: italic;
}

.poppins-extralight-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 200;
   font-style: italic;
}

.poppins-light-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 300;
   font-style: italic;
}

.poppins-regular-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 400;
   font-style: italic;
}

.poppins-medium-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 500;
   font-style: italic;
}

.poppins-semibold-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 600;
   font-style: italic;
}

.poppins-bold-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 700;
   font-style: italic;
}

.poppins-extrabold-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 800;
   font-style: italic;
}

.poppins-black-italic {
   font-family: "Poppins", sans-serif;
   font-weight: 900;
   font-style: italic;
}



#myBtn {
   display: none; /* Hidden by default */
   position: fixed; /* Fixed/sticky position */
   bottom: 20px; /* Place the button at the bottom of the page */
   right: 30px; /* Place the button 30px from the right */
   z-index: 99; /* Make sure it does not overlap */
   border: none; /* Remove borders */
   outline: none; /* Remove outline */
   background-color: #AEB135; /* Set a background color */
   color: white; /* Text color */
   cursor: pointer; /* Add a mouse pointer on hover */
   padding: 15px; /* Some padding */
   border-radius: 10px; /* Rounded corners */
   font-size: 18px; /* Increase font size */
}

   #myBtn:hover {
      background-color: #070d24; /* Add a dark-grey background on hover */
   }



.custom-caption {
   top: 10%;
   transform: translateY(-50%);
   bottom: initial;
   text-align: center;
}

   .custom-caption h1 {
      font-size: 60px;
      font-weight: 800;
   }

   .custom-caption p {
      font-size: 22px;
   }
/* HERO CAROUSEL */

.hero-slide {
   height: 100vh;
   position: relative;
   overflow: hidden;
}

.hero-img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   display: block;
}

.hero-slide2 {
   width: 100%;
   height: auto;
}

.hero-img2 {
   width: 100%;
   height: auto;
   display: block;
}

.banner-slide {
   position: relative;
   width: 100%;
   height: auto !important;
}
.banner-img {
   width: 100%;
   height: auto;
   display: block;
}

.banner-slide::before {
   content: "";
   position: absolute;
   inset: 0;
   background: linear-gradient( to right, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.4) 40%, rgba(0,0,0,0.15) 70%, transparent 100% );
   z-index: 1;
   pointer-events: none;
}

.banner-caption {
   position: absolute;
   top: 50%;
   left: 8%;
   transform: translateY(-50%);
   max-width: 600px;
   z-index: 2;
}
/* HERO BANNER */

.hero-banner {
   position: relative;
   width: 100%;
   max-height: 75vh;
   overflow: hidden;
}

.hero-banner-img {
   width: 100%;
   height: 75vh;
   object-fit: cover;
}

.hero-banner-content {
   position: absolute;
   top: 50%;
   left: 12%;
   transform: translateY(-50%);
   color: lightgray;
   text-align: left;
}

.hero-banner-content2 {
   position: absolute;
   top: 20%;
   left: 35%;
   transform: translateY(-50%);
   color: lightgray;
   text-align: left;
}

.hero-banner-content3 {
   position: absolute;
   top: 40%;
   left: 5%;
   transform: translateY(-50%);
   color: lightgray;
   text-align: left;
}
/* TEXT */

.hero-title {
   font-size: 50px;
   font-weight: 800;
   letter-spacing: 2px;
   text-shadow: 2px 2px 4px rgba(0,0,0,0.7), 0px 0px 10px rgba(0,0,0,0.8);
}


/* MOBILE */

@media (max-width: 768px) {

   .hero-banner-img {
      height: 35vh;
   }

   .hero-title {
      font-size: 36px;
   }

   .hero-banner-content {
      left: 20px;
      right: 20px;
   }
}
/* HERO TEXT */

.hero-caption {
   position: absolute;
   top: 25%;
   left: 12%;
   right: auto;
   bottom: auto;
   text-align: left;
   max-width: 1200px;
   z-index: 2;
}
.hero-caption2 {
   position: absolute;
   top: 12%;
   left: 12%;
   right: auto;
   bottom: auto;
   text-align: left;
   max-width: 800px;
   z-index: 2;
}
.hero-caption3 {
   position: absolute;
   top: 20%;
   left: 35%;
   right: auto;
   bottom: auto;
   text-align: left;
   max-width: 800px;
   z-index: 2;
 
}
.hero-title {
   font-size: 80px;
   font-weight: 800;
   letter-spacing: 2px;
}

.hero-title2 {
   font-size: 60px;
   font-weight: 800;
   letter-spacing: 2px;
}

.hero-title3 {
   font-size: 60px;
   font-weight: 800;
   letter-spacing: 2px;
   margin-top: 5px;
 
}

.hero-title4 {
   font-size: 60px;
   font-weight: 800;
   letter-spacing: 2px;
   margin-top: 5px;
   text-shadow: 2px 2px 4px rgba(0,0,0,0.7), 0px 0px 10px rgba(0,0,0,0.8);
}

.hero-subtitle {
   font-size: 22px;
   margin-top: 20px;
   margin-bottom: 30px;
}

/* BUTTONS */

.hero-buttons .btn {
   padding: 14px 30px;
   font-size: 18px;
}

/* MOBILE */

@media (max-width: 768px) {

   .hero-title {
      font-size: 38px;
   }

   .hero-subtitle {
      font-size: 18px;
   }
}
.hero-title {
   animation: fadeUp 1s ease forwards;
}

.hero-subtitle {
   animation: fadeUp 1.4s ease forwards;
}

.hero-buttons {
   animation: fadeUp 1.8s ease forwards;
}

@keyframes fadeUp {

   from {
      opacity: 0;
      transform: translateY(40px);
   }

   to {
      opacity: 1;
      transform: translateY(0);
   }
}
@media (max-width: 768px) {

   .hero-caption {
      top: 80px;
      left: 20px;
      right: 20px;
   }

   .hero-title {
      font-size: 36px;
   }
}

.montserrat {
   font-family: "Montserrat", sans-serif;
   font-optical-sizing: auto;

   font-style: normal;
}

.brand-word {
   height: 50px;
   vertical-align: middle;
     margin-bottom:10px
}

.btn-custom {
   background-color: red;
   color: white;
   font-size: 16px;
   padding: 5px 11px;
   border-radius: 0px;
   font-weight: 300;

}

   .btn-custom:hover {
      background-color: #2f353d;
      color: white;
   }

   .btn-custom i {
      margin-left: 8px;
      font-size: 14px;
   }

.select-wrapper {
   position: relative;
}

.custom-select {
   appearance: none;
   -webkit-appearance: none;
   -moz-appearance: none;
   width: 100%;
   padding-right: 40px; /* space for icon */
}

.select-icon {
   position: absolute;
   right: 15px;
   top: 50%;
   transform: translateY(-50%);
   pointer-events: none;
   color: #9cd34a;
   font-size: 16px;
}

/* NAV BASE */
.navbar .nav-link {
   position: relative;
   padding: 8px 16px;
   margin: 0 5px;
   color: #fff;
   transition: all 0.3s ease;
}

   /* Animated border */
   .navbar .nav-link::before,
   .navbar .nav-link::after {
      content: "";
      position: absolute;
      inset: 0;
      border: 2px solid transparent;
      transition: 0.4s ease;
   }

   /* Top-left */
   .navbar .nav-link::before {
      border-top-color: #AEB135;
      border-left-color: #AEB135;
      transform: scale(0);
      transform-origin: top left;
   }

   /* Bottom-right */
   .navbar .nav-link::after {
      border-bottom-color: #AEB135;
      border-right-color: #AEB135;
      transform: scale(0);
      transform-origin: bottom right;
   }

   /* Hover */
   .navbar .nav-link:hover::before,
   .navbar .nav-link:hover::after {
      transform: scale(1);
   }

   .navbar .nav-link:hover {
      color: #AEB135;
   }
   /* ACTIVE state */
   .navbar .nav-link.active::before,
   .navbar .nav-link.active::after {
      transform: scale(1);
   }

   /* Keep text WHITE when active */
   .navbar .nav-link.active {
      color: #fff !important;
   }

      /* Optional: subtle brand glow (VERY NICE TOUCH) */
      .navbar .nav-link.active::before,
      .navbar .nav-link.active::after {
         box-shadow: 0 0 4px rgba(174, 177, 53, 0.6);
      }

/* Remove default Bootstrap arrow */
.dropdown-toggle::after {
   display: none !important;
}

/* Custom icon */
.dropdown-icon {
   font-size: 0.8rem;
   transition: transform 0.3s ease;
}

/* Rotate when open */
.nav-item.dropdown.show .dropdown-icon {
   transform: rotate(180deg);
}

/* Optional: slight hover animation */
.navbar .nav-link:hover .dropdown-icon {
   transform: translateY(2px);
}

html {
   scroll-behavior: smooth;
}

.custom-title {
   font-size: 60px;
   font-weight: 800;
   letter-spacing: 2px;
   margin-top: 10%;

}

.hero-billboard {
   background: radial-gradient(circle at 70% 40%, #3a424a 0%, #1f252b 60%, #14181c 100%);
   padding: 120px 0;
   position: relative;
   overflow: hidden;
   height:600px!important;
}

/* 🔥 Glow effect */
.hero-glow {
   position: absolute;
   width: 500px;
   height: 500px;
   background: radial-gradient(circle, rgba(174,177,53,0.25) 0%, transparent 70%);
   top: 10%;
   left: 5%;
   filter: blur(80px);
   z-index: 0;
}

/* TEXT */
.hero-content {
   position: relative;
   z-index: 2;
}

.hero-title {
   display: flex;
   flex-direction: column;
   line-height: 0.9;
}

   .hero-title .primary {
      font-size: clamp(50px, 7vw, 110px);
      font-weight: 900;
      color: #c4c84a; /* slightly brighter */
      letter-spacing: 3px;
      /* ✨ softer glow */
      text-shadow: none;
   }

   .hero-title .secondary {
      font-size: clamp(40px, 6vw, 80px);
      font-weight: 700;
      color: #ffffff;
      margin-top: -10px;
      opacity: 1;
   }

/* SUBTEXT */
.hero-sub {
   margin-top: 20px;
   color: #ccc;
   font-size: 18px;
   max-width: 500px;
}

/* BUTTON */
.hero-btn {
   margin-top: 30px;
   padding: 14px 30px;
   font-weight: 600;
}

/* IMAGE - FLOATING EFFECT */
.hero-image img {
   transform: translateY(0px);
   animation: 4s ease-in-out;
   filter: drop-shadow(0 20px 40px rgba(0,0,0,0.6)) drop-shadow(0 0 20px rgba(174,177,53,0.25));
   margin-top: -120px; /* 👈 moves whole image block up */
}



/* FLOAT ANIMATION */
@keyframes float {
   0% {
      transform: translateY(0px);
   }

   50% {
      transform: translateY(-12px);
   }

   100% {
      transform: translateY(0px);
   }
}

.hero-billboard::after {
   content: "";
   position: absolute;
   width: 300px;
   height: 4px;
   background: #AEB135;
   bottom: 40px;
   left: 10%;
   transform: rotate(-15deg);
   opacity: 0.6;
}
.hero-billboard::before {
   content: "";
   position: absolute;
   inset: 0;
   background: linear-gradient( to right, rgba(20,24,28,0.9) 0%, rgba(20,24,28,0.6) 30%, transparent 60% );
   z-index: 1;
}

.hero-wave {
   position: absolute;
   bottom: 0;
   left: 0;
   width: 110%;
   height: 260px;
   background: url('/Images/assets/gold-wave.png') no-repeat left bottom;
   background-size: contain;
   opacity: 0.9; /* IMPORTANT */
   z-index: 1;
   pointer-events: none;
}




.hero-content::after {
   content: "";
   display: block;
   width: 100px;
   height: 3px;
   background: #AEB135;
   margin-top: 25px;
   opacity: 0.6;
}

.carousel-caption .primary {
   color: #fff; /* white first line */
   animation: fadeUp 0.8s ease forwards;
}

.carousel-caption .secondary {
   color: #AEB135; /* brand highlight */
   animation: fadeUp 1.2s ease forwards;
}

.carousel-caption .hero-btn {
   animation: fadeUp 1.6s ease forwards;
}

.carousel-item .hero-title,
.carousel-item .hero-sub,
.carousel-item .hero-btn {
   opacity: 0;
   transform: translateY(40px);
   transition: all 0.8s ease;
}

/* Active slide animation */
.carousel-item.active .hero-title {
   opacity: 1;
   transform: translateY(0);
   transition-delay: 0.2s;
}

.carousel-item.active .hero-sub {
   opacity: 1;
   transform: translateY(0);
   transition-delay: 0.4s;
}

.carousel-item.active .hero-btn {
   opacity: 1;
   transform: translateY(0);
   transition-delay: 0.6s;
}


.hero-slide::before {
   content: "";
   position: absolute;
   inset: 0;
   background: linear-gradient( to right, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.5) 35%, rgba(0,0,0,0.2) 65%, transparent 100% );
   z-index: 1;
   pointer-events: none;

}

/* Flip overlay for right-aligned slide */
.carousel-item:nth-child(2)::before {
   background: linear-gradient( to left, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.4) 40%, rgba(0,0,0,0.2) 70%, transparent 100% );

}

.hero-caption {
   top:35%;
   transform: translateY(-50%);
   max-width: 900px; /* 👈 FIX */
   z-index: 2;
}

   .hero-caption.left {
      left: 10%;
   }

   .hero-caption.right {
      right: 10%;
      left: auto;
   }

   .hero-caption.center {
      left: 50%;
      transform: translate(-50%, -50%);
      text-align: center;
   }

.gallery-container {
   padding: 60px 5%;

}

.gallery-grid {
   column-count: 4;
   column-gap: 15px;
}

.gallery-item {
   break-inside: avoid;
   margin-bottom: 15px;
   border-radius: 10px;
   overflow: hidden;
   cursor: pointer;
   background: #2a3138;
   padding: 5px;
   box-shadow: 0 10px 25px rgba(0,0,0,0.3);
}

   .gallery-item img {
      width: 100%;
      height: auto;
      display: block;
      transition: transform 0.4s ease;
   }

   .gallery-item:hover img {
      transform: scale(1.05);
   }

.lightbox {
   display: none;
   position: fixed;
   inset: 0;
   background: rgba(0,0,0,0.95);
   justify-content: center;
   align-items: center;
   z-index: 9999;
}

   .lightbox img {
      max-width: 90%;
      max-height: 85%;
      border-radius: 10px;
      transition: 0.3s;
   }

   /* Controls */
   .lightbox .close {
      position: absolute;
      top: 20px;
      right: 30px;
      font-size: 40px;
      color: white;
      cursor: pointer;
   }

   .lightbox .prev,
   .lightbox .next {
      position: absolute;
      top: 50%;
      font-size: 40px;
      color: white;
      cursor: pointer;
      padding: 10px;
      transform: translateY(-50%);
   }

.prev {
   left: 20px;
}

.next {
   right: 20px;
}

@media (max-width: 1200px) {
   .gallery-grid {
      column-count: 3;
   }
}

@media (max-width: 768px) {
   .gallery-grid {
      column-count: 2;
   }
}

@media (max-width: 480px) {
   .gallery-grid {
      column-count: 1;
   }
}

.section-heading-left {
   color: #4C555E;
   border-left: 4px solid #AEB135;
   padding-left: 10px;
}

.quote-highlight {
   background: radial-gradient(circle at 70% 40%, #3a424a 0%, #1f252b 60%, #14181c 100%);
   border-left: 10px solid #AEB135;
   border-radius: 15px;
   box-shadow: 0 10px 30px rgba(0,0,0,0.05);
   position: relative;
}

   .quote-highlight h5 {
      color: white;
      letter-spacing: 1px;
   }

.text-accent {
   color: #AEB135;
}