html {
  scroll-behavior: smooth;
}

body {
   font-family: "Playfair Display", serif;
  font-style: normal;
  margin: 0px;
  padding: 0px;
  font-size: 16px;
  font-size: 16px;
  color: #fff;
  overflow-x: hidden;
  background-color: #fff;
}


ul {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

p {
 font-family: "Space Grotesk", sans-serif;
  font-weight: 300;
  margin-bottom: 15px;
  font-size: 18px;
  line-height: 30px;
  color: #000;
}

img {
  max-width: 100%;
  border: 0;
  height: auto;
}

.clear {
  clear: both;
  float: none;
  width: 100%;
}

.clearfix::after {
  display: block;
  content: "";
  clear: both;
}

a {
  text-decoration: none !important;
  transition: all 0.2s ease-in;
  color: #1f1f1f;
 font-family: "Space Grotesk", sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
   font-family: "Playfair Display", serif;
}


a,
span {
  display: inline-block;
}

:focus {
  box-shadow: none !important;
  outline: none !important;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-SemiBold.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-SemiBoldItalic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-SemiBoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-Black.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-BlackItalic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-BlackItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-Bold.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-BoldItalic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-ExtraBold.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-ExtraBoldItalic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-ExtraBoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-Italic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-Medium.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-MediumItalic.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
     font-family: "Playfair Display", serif;
    src: url('../fonts/PlayfairDisplay-Regular.woff2') format('woff2'),
        url('../fonts/PlayfairDisplay-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Space Grotesk", sans-serif;
    src: url('../fonts/SpaceGrotesk-Regular.woff2') format('woff2'),
        url('../fonts/SpaceGrotesk-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
   font-family: "Space Grotesk", sans-serif;
    src: url('../fonts/SpaceGrotesk-SemiBold.woff2') format('woff2'),
        url('../fonts/SpaceGrotesk-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
   font-family: "Space Grotesk", sans-serif;
    src: url('../fonts/SpaceGrotesk-Bold.woff2') format('woff2'),
        url('../fonts/SpaceGrotesk-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Space Grotesk", sans-serif;
    src: url('../fonts/SpaceGrotesk-Light.woff2') format('woff2'),
        url('../fonts/SpaceGrotesk-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
  font-family: "Space Grotesk", sans-serif;
    src: url('../fonts/SpaceGrotesk-Medium.woff2') format('woff2'),
        url('../fonts/SpaceGrotesk-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}




@media (min-width: 1366px) {

  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl {
    max-width: 1250px;
  }
}

@media (min-width: 1440px) {

  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl {
    max-width: 1350px;
  }
}

@media (min-width: 1600px) {

  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl {
    max-width: 1500px;
  }
}






/*css start*/


/* HE
ADER STYLES*/



.page-header.is-sticky::after{
    height: auto;
}










.page-header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 999;
}

/* STICKY STYLES */
.page-header.is-sticky {
    position: fixed;
    box-shadow: 0 5px 16px rgba(0, 0, 0, 0.1);
    padding: 0px;
    backdrop-filter: blur(30px);
    animation: slideDown 0.5s ease-out;
    background: #000000c2;
    z-index: 9999;
    color: #000;
    transition: 0.7s ease-in-out;
}

.page-header.is-sticky .logo-box img {
    max-width: 60%;
}


@keyframes slideDown {
    from {
        transform: translateY(-100%);
    }

    to {
        transform: translateY(0);
    }
}


.nav-link:before {
    background-color: #d3af37;
    bottom: var(--bottom);
    content: "";
    height: 0.05em;
    left: 0;
    min-height: 1px;
    position: absolute;
    right: 0;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform .75s cubic-bezier(.19, 1, .22, 1);
    bottom: -2px;

}

.nav-link:hover:before {
    transform: scaleX(1);
    transform-origin: left;
}


.nav-link:hover:after {
    background-color: #c9a86a;
    transition: transform .75s cubic-bezier(.19, 1, .22, 1);
}

.navbar .nav-link:hover {
    color: #c9a86a;
}
/* 
.navpage-header.is-sticky .main-menulist {
    padding: 0px 15px 0px 15px;
}
 */

.main-menulist {
    padding: 10px 70px 15px 70px;
}
.inner-homesec2 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.navbar-expand-lg .navbar-collapse {
    justify-content: end;
}
.inner-homesec2 {
    height: 100%;
}
.top-nav-icon ul {
    display: flex;
    gap: 15px;
}

    .navbar-expand-lg {
        flex-wrap: nowrap;
        justify-content: flex-start;
        padding: 0;
    }
.btn-secondary {
    font-size: 18px;
    color: #fff !important;
    font-weight: 300;
    background-color: transparent;
    border-color: transparent;
    text-transform: capitalize;

}

.btn-secondary:hover {
    color: #9b7664;
    background-color: transparent;
    border-color: transparent;
}

.navbar .nav-link {
    font-size: 18px;
    color: #fff;
    font-weight: 300;
    text-transform: capitalize;
    position: relative;
    padding: 0 !important;
    margin: 0 26px !important;
    transition: 0.7s ease-in-out;
}



.hvr-underline-from-left:before {
    background: #fff;
}


.nav-item {
    padding: 0px 0px;
    display: flex;
    align-items: center;
}

.navbar-expand-lg .navbar-nav {
    flex-direction: row;
    align-items: center;
    justify-content: end;

}

.navbar .btn:hover {
    color: #252798;
}
.main-nav.scrolled .nav-logo {
  
    margin-top: -5px;
}
.dropdown-item:focus,
.dropdown-item:hover {

    background-color: transparent;
}

.btn-secondary:hover {
    color: #252798;
    background-color: transparent;
    border-color: transparent;
}

.btn-secondary:focus {
    color: #252798;
    background-color: transparent;
    border-color: transparent;
    box-shadow: none;
}


.sub-menu {
    /* padding: 10px; */
    background-color: #fff;
    color: #9b7664;
    border-radius: 5px;
}

.sub-menu li a {
    font-size: 16px;
    color: #252798;
    padding: 5px 10px;
    font-weight: 600;
}

.sub-menu li:hover {
    background-color: #252798;
    color: #fff;
}

.sub-menu li:hover a {
    color: #fff;
}

/* .top-space {
    height: 120px;
} */

.navbar-wrapper {
    display: flex;
    width: 100%;
    max-width: 100%;
    align-items: center;
    justify-content: space-between;
}
.main-navbar {   
    width: 100%;
}



/* end here  */












/* new css  */
   .main-nav.scrolled {
      position: fixed;
      top: 0;
      background: #121212cc;
      backdrop-filter: blur(10px);
      box-shadow: 0 2px 20px rgba(0,0,0,0.5);
    }
  .navbar-inner {
    width: 100%;
}
    /* ─── NAVBAR ──────────────────────────────── */
.main-nav {
    position: absolute;
    top: 30px;
    left: 0px;
    right: 0;
    z-index: 1000;
    padding: 0 0px 0 70px;
    transition: background 0.4s ease, top 0.4s ease, box-shadow 0.4s ease;
}
 

    .main-nav.scrolled .navbar-inner { border-bottom: none; }

    .nav-logo {
      
      font-size: 26px; font-weight: 700;
      color: #fff; text-decoration: none; letter-spacing: 1px;
    }
    .main-nav.scrolled .nav-logo img {
    width: 62%;
}

.main-nav.scrolled .nav-right {
    top: 1px;
    background-size: cover;
}

    .nav-logo span { color: var(--gold); }

  .nav-links {
    display: flex;
    align-items: center;
    list-style: none;
    justify-content: right;
}
 .nav-links > li {
    position: relative;
    margin: 2px 18px;
}
 .main-nav i.fas.fa-chevron-down {
    font-size: 13px;
    margin-left: -3px;
}
  .nav-links > li > a {
    display: block;
    color: rgba(255, 255, 255, 0.9);
    font-size: 21px;
    font-weight: 400;
    letter-spacing: 1.5px;
    text-decoration: none;
    padding: 0px;
    transition: color 0.3s;
}
    .nav-links > li > a:hover,
    .nav-links > li.active > a { color: var(--gold); }

  .nav-links > li .dropdown {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 180px;
    list-style: none;
    padding: 8px 0;
    background: #212527e8;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s ease;
    z-index: 999;
    backdrop-filter: blur(20px);
}
    .nav-links > li:hover .dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
    .nav-links > li .dropdown li a {
      display: block; color: rgba(255,255,255,0.8);
      font-size: 13px; padding: 9px 20px;
      text-decoration: none; letter-spacing: 0.5px; transition: all 0.2s;
    }
    .nav-links > li .dropdown li a:hover { color: var(--gold); padding-left: 26px; }

.nav-right {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: right;
    position: relative;
    padding: 20px 40px 20px 20px !important;
    background-image: url(../images/navrightshape.webp);
    border-radius: 0 0 0 20px;
    height: auto;
    top: -35px;
    width: auto;
    right: 0;
    background-repeat: no-repeat;
    background-size: 100%;
}


.nav-right::before{
 content: "";
        position: absolute;
        background-color: transparent;
        height: 40px;
        width: 20px;
        box-shadow: 0 -20px 0 0 var(--pbmit-xinterio-white-color);
        z-index: 0;
}

      .btn-consult:hover {
    color: #d3af37;
} 


  .btn-consult {
    color: #000;
    font-size: 22px;
    font-weight: 400;
    padding: 0px 24px;
    text-decoration: none;
    transition: all 0.3s;
}
   
    .hamburger {
      display: none; cursor: pointer;
      flex-direction: column; justify-content: center;
      gap: 6px; width: 36px; height: 36px;
      z-index: 1100;
    }
    .hamburger span {
      display: block; width: 24px; height: 2px;
      background: #fff; border-radius: 2px;
      transition: transform 0.4s cubic-bezier(0.77,0,0.18,1),
                  opacity 0.3s ease,
                  width 0.3s ease;
      transform-origin: center;
    }
    /* X animation when open */
    .hamburger.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
    .hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
    .hamburger.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

    /* ─── MOBILE MENU OVERLAY ─────────────────── */
    .mobile-menu {
      position: fixed;
      top: 0; right: 0;
      width: min(340px, 100vw);
      height: 100vh;
      background: #111;
      z-index: 1050;
      display: flex;
      flex-direction: column;
      padding: 100px 36px 40px;
      overflow-y: auto;
      /* slide in from right */
      transform: translateX(100%);
      transition: transform 0.5s cubic-bezier(0.77,0,0.18,1);
      /* box-shadow: -10px 0 40px rgba(0,0,0,0.6); */
    }
    .mobile-menu.open { transform: translateX(0); }

    /* Dim backdrop */
    .menu-backdrop {
      position: fixed; inset: 0;
      background: rgba(0,0,0,0.6);
      z-index: 1040;
      opacity: 0; visibility: hidden;
      transition: opacity 0.4s ease, visibility 0.4s ease;
    }
    .menu-backdrop.open { opacity: 1; visibility: visible; }

    /* Mobile nav items — staggered slide-in */
    .mobile-menu .m-nav { list-style: none; padding: 0; margin: 0; }
    .mobile-menu .m-nav > li {
      border-bottom: 1px solid rgba(255,255,255,0.07);
      opacity: 0;
      transform: translateX(30px);
      transition: opacity 0.4s ease, transform 0.4s ease;
    }
    /* Each item slides in with stagger when menu is open */
    .mobile-menu.open .m-nav > li:nth-child(1) { opacity:1; transform:translateX(0); transition-delay:0.15s; }
    .mobile-menu.open .m-nav > li:nth-child(2) { opacity:1; transform:translateX(0); transition-delay:0.22s; }
    .mobile-menu.open .m-nav > li:nth-child(3) { opacity:1; transform:translateX(0); transition-delay:0.29s; }
    .mobile-menu.open .m-nav > li:nth-child(4) { opacity:1; transform:translateX(0); transition-delay:0.36s; }
    .mobile-menu.open .m-nav > li:nth-child(5) { opacity:1; transform:translateX(0); transition-delay:0.43s; }
    .mobile-menu.open .m-nav > li:nth-child(6) { opacity:1; transform:translateX(0); transition-delay:0.50s; }

    .mobile-menu .m-nav > li > a {
      display: flex; justify-content: space-between; align-items: center;
      color: rgba(255,255,255,0.85);
      font-size: 15px; font-weight: 500;
      letter-spacing: 1.5px; text-transform: uppercase;
      text-decoration: none;
      padding: 16px 0;
      transition: color 0.25s;
    }
    .mobile-menu .m-nav > li > a:hover { color: var(--gold); }
    .mobile-menu .m-nav > li > a .m-arrow {
      font-size: 10px;
      transition: transform 0.3s ease;
    }
    .mobile-menu .m-nav > li.m-open > a .m-arrow { transform: rotate(180deg); }

    /* Mobile sub-dropdown */
    .mobile-menu .m-sub {
      list-style: none; padding: 0;
      max-height: 0; overflow: hidden;
      transition: max-height 0.4s cubic-bezier(0.77,0,0.18,1);
    }
    .mobile-menu .m-nav > li.m-open .m-sub { max-height: 300px; }
    .mobile-menu .m-sub li a {
      display: block;
      color: rgba(255,255,255,0.55);
      font-size: 13px; padding: 9px 0 9px 16px;
      text-decoration: none; letter-spacing: 0.5px;
      transition: color 0.2s, padding-left 0.2s;
      border-left: 1px solid rgba(255,255,255,0.1);
      margin-left: 4px;
    }
    .mobile-menu .m-sub li a:hover { color: var(--gold); padding-left: 22px; }

    /* Mobile Book Consult button */
    .mobile-menu .m-consult {
      display: inline-block;
      margin-top: 32px;
      background: var(--gold); color: #fff;
      font-size: 12px; font-weight: 500;
      letter-spacing: 2px; text-transform: uppercase;
      text-decoration: none; padding: 13px 28px;
      align-self: flex-start;
      opacity: 0; transform: translateY(20px);
      transition: opacity 0.4s 0.55s ease, transform 0.4s 0.55s ease;
    }
    .mobile-menu.open .m-consult { opacity: 1; transform: translateY(0); }
    .mobile-menu .m-consult:hover { background: #9a7a48; color: #fff; }

    /* Close button inside mobile menu */
    .m-close {
      position: absolute;
      top: 24px; right: 24px;
      background: none; border: 1px solid rgba(255,255,255,0.2);
      color: #fff; width: 40px; height: 40px;
      border-radius: 50%; font-size: 16px;
      cursor: pointer; display: flex;
      align-items: center; justify-content: center;
      transition: background 0.25s, border-color 0.25s, transform 0.3s;
    }
    .m-close:hover { background: var(--gold); border-color: var(--gold); transform: rotate(90deg); }

    /* ══════════════════════════════════════════════
       HERO SLIDER  —  vertical slide transition
       Current slide slides UP out,
       next slide slides UP in from below.
    ══════════════════════════════════════════════ */
   .hero-slider {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    background: #111;
    margin: 10px;
    border-radius: 30px;
}

    /* Track that holds all slides side-by-side vertically */
    .slides-track {
      position: absolute;
      inset: 0;
      /* slides stack via absolute positioning, handled by JS */
    }

    /* Individual slide */
    .slide {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      will-change: transform;
    }

    /* BG image layer */
    .slide-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center center;
      /* subtle Ken-Burns only on the ACTIVE slide – added via JS class */
      transition: transform 7s ease;
      transform: scale(1.06);
    }
    .slide.kb-active .slide-bg {
      transform: scale(1.0);
    }

    .slide-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(
        105deg,
        rgba(8,8,8,0.75) 0%,
        rgba(8,8,8,0.45) 55%,
        rgba(8,8,8,0.10) 100%
      );
    }

    /* Slide image via <img> tag inside .slide-bg */
    .slide-bg img {
      position: absolute;
      inset: 0; width: 100%; height: 100%;
      object-fit: cover; object-position: center;
      display: block;
    }

    /* Content */
#heroSlider .slide-content {
    position: absolute;
    top: 50%;
    left: 70px;
    transform: translateY(-50%);
    color: #fff;
    max-width: 100%;
    z-index: 5;
}

#heroSlider .slide-content p {
    font-size: 24px;
    font-family: "Space Grotesk", sans-serif;
    color: #fff;
    line-height: 35px;
    font-weight: 500;
}

    /* Text items: enter from top downward */
    .slide-tag,
    .slide-title,
    .slide-subtitle,
    .slide-btn {
 
    
      transition: none;
    }

    /* When slide gets class "text-in", animate each child with delay */
    .slide.text-in .slide-tag {
      animation: textDown 0.7s 0.25s ease both;
    }
    .slide.text-in .slide-title {
      animation: textDown 0.7s 0.45s ease both;
    }
    .slide.text-in .slide-subtitle {
      animation: textDown 0.65s 0.65s ease both;
    }
    .slide.text-in .slide-btn {
      animation: textDown 0.65s 0.85s ease both;
    }

    @keyframes textDown {
      from { opacity: 0; transform: translateY(-35px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* Keep final state */
    .slide.text-in .slide-tag,
    .slide.text-in .slide-title,
    .slide.text-in .slide-subtitle,
    .slide.text-in .slide-btn {
      animation-fill-mode: forwards;
    }

    .slide-tag {
      font-size: 13px; font-weight: 500;
      letter-spacing: 4px; text-transform: uppercase;
      color: var(--gold); margin-bottom: 16px;
      display: flex; align-items: center; gap: 12px;
    }
    .slide-tag::before {
      content: '';
      display: inline-block;
      width: 40px; height: 1px; background: var(--gold);
    }

 .slide-title {
    font-size: 72px;
    font-weight: 500;
    line-height: 1.07;
    margin-bottom: 22px;
    color: #fff;
       font-family: "Playfair Display", serif;
}
    .slide-title em { font-style: italic; color: var(--gold); }

    .slide-subtitle {
      font-size: 16px; font-weight: 300;
      color: rgba(255,255,255,0.78);
      line-height: 1.75; margin-bottom: 38px;
      max-width: 460px;
    }

.slide-btn a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #d3af37;
    color: #fff;
    font-size: 20px;
    font-weight: 500;
    text-decoration: none;
    border-radius: 60px;
    padding: 13px 77px 13px 28px;
    border: 1px solid transparent;
    transition: 0.7s ease-in-out;
}
.slide-btn div {
    top: 5px;
    background: #fff;
    width: 45px;
    height: 45px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    position: absolute;
    right: 8px;
    transition: 0.6s ease-in-out;
}
.slide-btn div img {
    width: 23px;
}
.slide-btn a:hover div img {
    filter: invert(1);
}
.slide-btn a:hover div{
    transform: translate3d(10px, 0, 0) rotateZ(45deg);
    background: #d3af37;
}

.slide-btn a:hover {
    color: #000;
    background: #fff;
    border: 1px solid #d3af37;
}
.slide-btn {
    width: fit-content;
    margin: 30px 0 0;
    position: relative;
}

    /* ─── DOTS – bottom-left, vertical ───────── */
.slider-dots {
    position: absolute;
    bottom: -10px;
    left: 67px;
    display: flex;
    flex-direction: column;
    transform: rotate(90deg);
    gap: 18px;
    z-index: 30;
}


.maindotsslide {
    background-image: url(../images/dotsshape.webp);
    background-size: cover;
    height: 52px;
    width: 147px;
    background-position: bottom;
    bottom: -1px;
    position: absolute;
    left: 177px;
    z-index: 9;
}


    .dot {
      width: 12px; height: 12px;
      border-radius: 50%;
      background: #d3af37;
      cursor: pointer;
      transition: background 0.35s, transform 0.35s;
      position: relative;
    }
    .dot.active { background: var(--gold); transform: scale(1.35); }
.dot::after {
    content: '';
    position: absolute;
    inset: -5px;
    border-radius: 50%;
    /* border: 1px solid #d3af37; */
    transition: border-color 0.35s;
}
.dot.active::after {
    border-color: #d3af37;
    content: '';
    position: absolute;
    inset: -5px;
    border-radius: 50%;
    border: 1px solid #d3af37;
    transition: border-color 0.35s;
    background: #d3af37;
    width: 13px;
    height: 13px;
    top: -3px;
    left: 0px;
}


    .dot.active::before {
    border: 1px solid #d3af37;
    width: 20px;
    height: 20px;
    content: '';
    position: absolute;
    border-radius: 50%;
    top: -6.6px;
    left: -3px;
}





    /* ─── SLIDE COUNTER ───────────────────────── */
    .slide-counter {
      position: absolute; right: 52px; bottom: 52px;
      z-index: 30; display: flex; align-items: center; gap: 6px;
      color: rgba(255,255,255,0.45); font-size: 13px; letter-spacing: 2px;
    }
    .slide-counter .cur {
      color: var(--gold); font-size: 24px;
      font-weight: 600;
    }


    /* ─── PROGRESS ────────────────────────────── */
    .slider-progress {
      position: absolute; bottom: 0; left: 0;
      height: 3px; background: var(--gold);
      z-index: 30; width: 0%;
    }

    /* ─── MOBILE ──────────────────────────────── */
    @media (max-width: 991px) {
      .main-nav { padding: 0 20px; }
      .nav-links, .btn-consult { display: none; }
      .hamburger { display: flex; }
      .slide-content { left: 6%; max-width: 90%; }
    }
    @media (max-width: 575px) {
      .slider-dots { left: 24px; bottom: 28px; }
      .slide-counter { right: 24px; bottom: 28px; }
      .scroll-hint { display: none; }
    }

/* for hero  */











    /* Paragraphs styled via parent (no class on <p>) */
.crafting-section .intro p {
    font-size: 18px;
    line-height: 1.7;
    margin-bottom: 10px;
    color: #000;
    font-weight: 400;
}
.crafting-section .titlesame {
    margin-bottom: 45px;
}
.crafting-section .feature p {
    font-size: 18px;
    line-height: 1.55;
    margin-bottom: 0;
    color: #000;
    font-weight: 400;
}
  
  

    /* Center sink image */
 .sink-image {
    width: 100%;
    height: auto;
    border-radius: 10px;
}
.feature:hover .icon-circle img {
    filter: invert(1);
}
    /* Feature item */
    .feature {
      display: flex;
      align-items: flex-start;
      gap: 18px;
      padding: 10px 6px;
      border-radius: 12px;
      cursor: pointer;
      transition: background 0.3s ease;
    }

    

   .feature .homesec2titlelist {
    font-size: 26px;
    margin: 0 0 6px;
    color: #000;
    font-weight: 500;
}

  .feature .icon-circle {
    flex-shrink: 0;
    width: 85px;
    height: 85px;
    border-radius: 50%;
    background: #f6f6f6;
    color: var(--text-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    transition: 0.7s ease

}

    /* First feature shown active by default (as in design) */
    .feature.is-active .icon-circle,
    .feature:hover .icon-circle {
      background: #d3af37;
      color: #fff;
      
    }
.titlesame {
    font-size: 55px;
    color: #000;
    font-weight: 500;
}





.services-section .titlesame {
    margin-bottom: 25px;
    text-align: center;
}
.cardtitlesec3home {
    font-size: 30px;
    font-family: "Space Grotesk", sans-serif;
    font-weight: 500;
}
.services-section {
    padding: 80px 0;
    background: #f6f6f6;
    margin: 0 10px 90px 0px;
    border-radius: 10px;
}
    .services-section .section-title {
      font-family: "Playfair Display", serif;
      font-weight: 600;
      color: var(--text-dark);
      text-align: center;
      font-size: clamp(1.8rem, 3.5vw, 2.75rem);
      margin-bottom: 50px;
    }

    /* Service card */
  .service-card {
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    height: 100%;
}
.services-section .g-5 {
    --bs-gutter-x: 6rem;
}
.service-card img {
    width: 100%;
    transition: transform 0.6s ease;
    height: 100%;
    object-fit: cover;
}

    .service-card:hover img {
      transform: scale(1.05);
    }

    /* Bottom dark gradient shadow behind text */
    .service-card::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 65%;
      background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.85) 0%,
        rgba(0, 0, 0, 0.55) 35%,
        rgba(0, 0, 0, 0) 100%
      );
      pointer-events: none;
    }

    .service-card .card-content {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 22px;
      padding: 0 20px;
      text-align: center;
      color: #fff;
      z-index: 2;
    }

    .service-card .card-content h3 {
      font-family: "Playfair Display", serif;
      font-weight: 600;
      font-size: 1.5rem;
      margin: 0 0 8px;
      color: #fff;
    }

    /* Paragraph styled via parent, no class on <p> */
.service-card .card-content p {
    font-size: 18px;
    line-height: 28px;
    margin: 0;
    color: #fff;
    font-weight: 400;
}


.crafting-section {
    padding: 130px 0;
}




.homesec4 {
    position: relative;
    background-image: url(../images/homesec4bgimg.jpg);
    height: 100vh;
    background-repeat: no-repeat;
    margin: 0 10px;
    clip-path: inset(0 0 0 0 round 20px);
}
.innerhomesec4 .titlesame {
    color: #fff;
    margin-bottom: 22px;
}
.innerhomesec4 {
    background: #212527d1;
    padding: 55px 40px;
    border-radius: 20px;
    max-width: 40%;
    bottom: 140px;
    position: absolute;
    left: 70px;
    backdrop-filter: blur(10px);
}


.innerhomesec4 p {
    color: #fff;
    font-weight: 400;
    font-size: 18px;
    line-height: 30px;
}




.footermain {
    margin: 0 10px 10px;
    background: #2f3437;
    padding: 70px 40px 0;
    border-radius: 20px;
}

.social-icons i:hover {
    color: #d3af37;
    border: 1px solid #fff;
}
.social-icons i {
    color: #fff;
    font-size: 20px;
    border: 1px solid #d3af37;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    text-align: center;
    display: flex;
    margin-right: 3px;
    align-items: center;
    justify-content: center;
    transition: 0.7s ease-in-out;
}

.social-icons {
    margin: 30px 0 0 0px;
}

.footerrequesttitle {
    font-size: 48px;
    font-weight: 500;
    color: #fff;
}
.innerulfooter ul li p {
    display: contents;
    color: #fff;
    font-size: 18px;
    font-weight: 300;
}
.innerulfooter ul li {
    font-size: 18px;
    margin-bottom: 5px;
    font-family: 'Space Grotesk';
    font-weight: 300;
}
.footertitle {
    font-size: 26px;
    color: #fff;
    margin-bottom: 15px;
}
.innerfooterright ul li a {
    font-size: 18px;
    color: #fff;
    margin-bottom: 0px;
    font-weight: 300;
}
.innerfooterright ul li a:hover {
    color: #d3af37;
}
.flex-request p {
    color: #fff;
    font-size: 18px;
    font-weight: 400;
    line-height: 28px;
    margin: 0;
}
.flex-request.btnnn {
    float: right;
}
.main-flexrequest {
  
    align-items: center;
    border-bottom: 1px solid #828587;
    padding-bottom: 50px;

}
.innerfooterright {
    margin-left: 50px;
}
.innerulfooter {
    margin: 50px 0 0;
}
.copyrightfoot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-image: url(../images/shapefootercopy.webp);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    margin-top: 90px;
    background-position: bottom;
    padding: 15px 60px;
    max-width: 1500px;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    top: 1px;
}
.copyrightfoot p {
    font-size: 18px;
    color: #2f3437;
    margin: 0;
}
.copyrightfoot p i {
    color: #f80000;
}
.copyrightfoot a {
    font-family: 'Space Grotesk';
    color: #2f3437;
}





.threeimageslidr {
    padding: 100px 0;
}

.threeimageslidr .swiper-container {
  position: relative;

}
.threeimageslidr .swiper-slide img {
    border-radius: 10px;
}
.threeimageslidr .swiper-container > .threeimageslidr .swiper-slide__content {
  position: absolute;
  top: 0;
}
.swiper-slide.swiper-slide-prev img {
    width: 70% !important;
}

.swiper-slide.swiper-slide-next img {
    width: 70% !important;
}

.threeimageslidr .swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 200ms linear;
  transform: scale(0.8);
}
.threeimageslidr .swiper-slide.swiper-slide-active {
  transform: scale(1);
}



.threeimageslidr .titlesame {
    text-align: center;
    margin-bottom: 40px;
}
.threeimageslidr .swiper-wrapper {
    align-items: center;
}
.threeimageslidr .swiper-button-prev {
    left: 25%;
    right: auto;
    width: 50px;
    height: 50px;
    border: 1px solid #d3af37;
    border-radius: 50%;
}

.threeimageslidr .swiper-button-next {
    left: 25%;
    right: auto;
    width: 50px;
    height: 50px;
    border: 1px solid #d3af37;
    border-radius: 50%;
}

.threeimageslidr .swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    content: 'prev';
    font-size: 20px;
    color: #d3af37;
}

.threeimageslidr .swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    content: 'next';
    font-size: 20px;
    color: #d3af37;
}

.threeimageslidr .swiper-button-next {
    right: 25%;
    left: auto;
}
























.testi-section {
    width: 100%;
    padding: 0px 0px 100px;
    background: #fff;
}

.testi-outer {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 1280px;
    margin: 0 auto;
}
.testi-card {
    width: 100%;
    border: 1.5px solid #d4b96a;
    border-radius: 330px;
    padding: 20px 60px 36px;
    position: relative;
    text-align: center;
    background: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
  .testi-section .titlesame {
    text-align: center;
    margin-bottom: 80px;
}
.avatar-wrap {
    position: absolute;
    top: -42px;
    left: 50%;
    transform: translateX(-50%);
    width: 94px;
    height: 94px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #d3af37;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
    overflow: hidden;
}
  .avatar-wrap svg { width: 36px; height: 36px; fill: #fff; opacity: 0.85; }
  .testi-section .slide-contents { display: none; width: 100%; flex-direction: column; align-items: center; }
  .testi-section .slide-contents.active { display: flex; animation: fadeSlide 0.45s ease; }
  @keyframes fadeSlide {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0); }
  }
.testi-text {
    font-size: 18px;
    color: #000;
    line-height: 1.75;
    max-width: 820px;
    margin: 70px auto 80px;
    font-family: 'Space Grotesk';
}
.avatar-wrap img {
    border-radius: 50%;
}
.testi-divider {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    position: relative;
}
.testi-divider::after {
    content: '';
    position: absolute;
    top: 23px;
    background: #9c9fa0;
    height: 1px;
    width: 63%;
}
.divider-line {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.diamond {
    width: 17px;
    height: 17px;
    background: #9c9fa0;
    transform: rotate(45deg);
    display: inline-block;
    flex-shrink: 0;
}

.rating-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    border: 1.5px solid #9ea4a1;
    border-radius: 60px;
    padding: 4px 24px;
    font-size: 15px;
    background: #fff;
    z-index: 9;
    color: #3a3f42;
    font-family: 'Space Grotesk';
    white-space: nowrap;
    margin: 0 12px;
    font-weight: 500;
}
  .rating-badge .star {
    color: #d3af37;
    font-size: 25px;
}
.reviewer {
    color: #000;
    font-size: 19px;
    font-family: 'Space Grotesk';
    margin: 10px 0 0;
}
  .arrow-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 60px; height: 60px;
    border-radius: 50%;
    border: 1.5px solid #d4b96a;
    background: #fff;
    color: #c49a2a;
    font-size: 50px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s;
    z-index: 5;
    user-select: none;
        align-items: flex-end;
    box-shadow: 0 1px 6px rgba(0,0,0,0.07);
  }
  .arrow-btn:hover { background: #fef8e6; transform: translateY(-50%) scale(1.08); }
  .arrow-btn:active { transform: translateY(-50%) scale(0.95); }
.arrow-left {
    left: -88px;
}
  .arrow-right { right: -88px; }



  





/* fixed new css  */
.socailiconfixed {
    position: fixed;
    right: 40px;
    top: 50%;
    z-index: 9;
    display: grid;
}
.socailiconfixed i:hover {
    color: #fff;
    background: #000;
}
.socailiconfixed i {
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    font-size: 22px;
    margin-bottom: 10px;
    transition: 0.7s ease-in-out;
    border-radius: 50%;
    box-shadow: 0 5px 16px rgb(102 101 101 / 23%);
    border: 1px solid #dddcdc;
}
.flex-herobannerbottom {
    margin: 30px 12px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: fixed;
    left: 0;
    top: inherit;
    z-index: 9;
    width: 98%;
    bottom: 100px;
}
.giveusnewbtn {
    font-size: 24px;
    font-weight: 600;
    background: #d3af37;
    transition: 0.7s ease-in-out;
    color: #fff;
    padding: 12px 34px;
    border-radius: 60px;
}
.giveusnewbtn:hover {
    background: #000;
    color: #fff;
}
.giveusnewbtn img {
    filter: invert(1);
}
.addresfoot a {
    color: #fff;
    font-size: 18px;
    line-height: 30px;
}
.addresfoot {
    margin: 30px 0 0;
}
/* end heere  */





/* innerpages css about  */
li.breadcrumb-item a {
    font-size: 16px;
    color: #3a3f42;
    font-family: 'Space Grotesk';
    font-weight: 500;
}
.breadcrumb-item.active {
    color: #d3af37;
    font-family: 'Space Grotesk';
    font-weight: 500;
    font-size: 17px;
}
.breadcrumb {
    margin: 15px 0 0 40px;
}
.innerbannetext {
    position: absolute;
    bottom: 165px;
    left: 40px;
    z-index: 9;
    width: fit-content;
}
.innerbannertitle {
    font-size: 72px;
    color: #fff;
    margin-bottom: 0;
    width: fit-content;
}
.innerpages-banner {
    margin: 10px;
    position: relative;
}

.innerpages-banner::after {
    content: '';
    position: absolute;
    top: 0;
    background-image: url(../images/innerbannershadow.png);
    height: 100%;
    left: 0;
    right: 0;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    border-radius: 18px;
}

.innerpages-banner img {
    border-radius: 18px;
    width: 100%;
}

.inner-abotsec2right img {
    width: 100%;
    border-radius: 10px;
}   
.inner-abotsec2left {
    padding-left: 26%;
}
.abttitlesame{
    font-size: 48px;
    color: #000;
    font-weight: 500;
}

.inner-aboutsec1 p {
    font-size: 18px;
    color: #000;
    font-weight: 400;
}
.inner-aboutsec1 .abttitlesame {
    margin-bottom: 20px;
}
.imgoneabtsec1 img {
    border-radius: 10px;
}
.aboutsec1 {
    padding: 70px 0;
}
.inner-aboutsec1 {
    position: relative;
}
.imgtwoabtsec1 img {
    border-radius: 10px;
}
.imgtwoabtsec1 {
    position: absolute;
    top: 18%;
    right: 30px;
    z-index: 99;
}

.aboutsec2 {
    padding: 40px 0 90px;
}


/* .flexnavmenu {
    background: #000000c2;
    padding: 10px 20px;
    width: fit-content;
    border-radius: 60px;
    margin-left: auto;
    backdrop-filter: blur(10px);
} */
/* end here  */















/* ----------media-query------------ */

@media (max-width: 1600px) {
.nav-right {top: -35px;padding: 12px 40px 22px 20px !important;}
.navbar-inner .align-items-center { align-items: baseline !important;}
.nav-links > li > a {font-size: 20px;}
.slide-title { font-size: 68px;}
#heroSlider .slide-content p {font-size: 22px;}
.slide-btn a {font-size: 19px; padding: 12px 77px 12px 28px;}
.titlesame { font-size: 51px;}
.innerhomesec4 { bottom: 100px;}
.footerrequesttitle {font-size: 44px;font-weight: 500; color: #fff;}
.footermain { padding: 70px 30px 0;}
.copyrightfoot { max-width: 1400px;}





}

body,html{overflow-x: hidden;}

@media (max-width: 1440px) {
.nav-right {top: -22px; padding: 12px 40px 22px 20px !important;}
.btn-consult { font-size: 18px;}
.navbar-inner .align-items-center {align-items: normal !important;}
.main-nav { top: 30px; padding: 0 0px 0 50px;}
.nav-links > li > a { font-size: 18px;}
.nav-links > li {margin: 2px 15px;}
.main-nav.scrolled .navbar-inner .align-items-center {align-items: center !important;}
.slide-title {font-size: 63px;margin-bottom: 20px;}
.crafting-section {padding: 120px 0 90px;}
.titlesame { font-size: 48px;}
p {font-size: 17px !important; line-height: 29px !important;}
.crafting-section .titlesame { margin-bottom: 25px;}
.slide-btn a {font-size: 18px;padding: 10px 62px 10px 21px;}
.slide-btn div {top: 4px;width: 40px;height: 40px;}
.feature .homesec2titlelist { font-size: 24px;}
.innerhomesec4 { bottom: 100px; max-width: 45%;}
.threeimageslidr {padding: 80px 0;}
.threeimageslidr .swiper-button-prev {left: 23%;}
.threeimageslidr .swiper-button-next {right: 23%;left: auto;}
.footerrequesttitle { font-size: 41px;}
.innerfooterright ul li a { font-size: 17px;}
 .copyrightfoot { max-width: 1220px;}
.testi-outer { max-width: 1140px;}
.testi-section {

    padding: 0px 0px 80px;
}
    .innerfooterright .slide-btn a {
        font-size: 17px;
        padding: 10px 62px 10px 21px;
    }


}


@media (max-width: 1366px) {

.slide-title {font-size: 56px; margin-bottom: 16px;}
.titlesame { font-size: 45px;}
.crafting-section {padding: 110px 0 70px;}
.services-section { padding: 70px 0;    margin: 0 10px 80px 0px;}
    .innerhomesec4 {
        bottom: 60px;
        max-width: 50%;
        padding: 45px 30px;
    }
    .threeimageslidr {
        padding: 70px 0;
    }
  .testi-text {
    margin: 60px auto 60px;
}
    .testi-outer {
        max-width: 1050px;
    }
.main-flexrequest {

    padding-bottom: 40px;
}
.innerfooterright ul {
    padding: 40px 0 0;
}
    .copyrightfoot {
        max-width: 1170px;
        margin-top: 60px;
    }
    .footerrequesttitle {
        font-size: 38px;
    }
        .innerfooterright .slide-btn a {
        font-size: 17px;
        padding: 10px 55px 10px 19px;
    }
        .footermain {
        padding: 60px 30px 0;
    }
}




  @media (max-width: 700px) {
    .testi-card { padding: 20px 24px 32px; border-radius: 36px; }
  .arrow-left {
    left: -88px;
}
    .arrow-right {  left: -88px; }
    .testi-outer { padding: 0 36px; }
    .testi-title { font-size: 22px; }
  }
    @media (max-width: 991.98px) {
      .crafting-section { padding: 50px 0; }
      .sink-image { margin: 30px 0; }

.services-section { padding: 50px 0; }
      .service-card { height: 280px; }


    }







    @media (max-width: 575.98px) {
      .service-card { height: 240px; }
      .service-card .card-content h3 { font-size: 1.25rem; }
    }

