@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap');

:root {
    --themeht-primary-color: #502ee9;
    --themeht-text-color: #1a1a1a;
    --themeht-body-color: #444444;
    --themeht-white-color: #FFFFFF;
    --themeht-bg-dark-color: #030303;
    --themeht-bg-light-color: #FAFAFA;
    --themeht-border-light-color: #d5d7da;
    --themeht-rgba-color: rgba(255,255,255,0.9);
    --themeht-body-font-family: "Inter", sans-serif;
    --themeht-secondary-font-family: "Geist", sans-serif;
}

html {
  scroll-behavior: auto !important;
  -webkit-overflow-scrolling: auto !important; /* For Safari and iOS */
  overscroll-behavior: contain;
}

body {font-family: var(--themeht-body-font-family); font-weight: normal; font-style: normal; font-size: 15px; line-height: 1.5; color:var(--themeht-body-color); overflow-x: hidden;}
.page-wrapper{overflow-x: hidden;}

a { text-decoration: none; }
a:focus { text-decoration: none !important; }
a:focus, a:hover { color: var(--themeht-primary-color); text-decoration: none !important; }
a, button, input { outline: medium none !important; color: var(--themeht-primary-color); }

*::-moz-selection { background: var(--themeht-primary-color); color: var(--themeht-white-color); text-shadow: none; }
::-moz-selection { background: var(--themeht-primary-color); color: var(--themeht-white-color); text-shadow: none; }
::selection { background: var(--themeht-primary-color); color: var(--themeht-white-color); text-shadow: none; }


/* ------------------------
    Transition
------------------------*/
a,
i,
.btn,
.btn span,
button,
img,
span{
    -webkit-transition: all 0.5s ease-in-out 0s;
    -moz-transition: all 0.5s ease-in-out 0s;
    -ms-transition: all 0.5s ease-in-out 0s;
    -o-transition: all 0.5s ease-in-out 0s;
    transition: all 0.5s ease-in-out 0s;
}



/* ------------------------
    Box Shadow
------------------------*/
.box-shadow,
.scroll-top,
.tab .nav-tabs .nav-link {
    -webkit-box-shadow: 0px 25px 70px rgba(1, 33, 58, 0.07);
    -moz-box-shadow: 0px 25px 70px rgba(1, 33, 58, 0.07);
    box-shadow: 0px 25px 70px rgba(1, 33, 58, 0.07);
}

/* ------------------------
    Typography
------------------------*/
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a { color: inherit; }
h1, h2, h3, h4, h5, h6 { margin-top: 0; margin-bottom: 10px; font-family: var(--themeht-secondary-font-family); color: var(--themeht-text-color); font-weight: 400; font-style: normal; text-transform: none; /* change if you want capitalization */ }
h1 { font-size: 70px; line-height: 80px; font-weight: 400; }
h2 { font-size: 54px; line-height: 64px; position: relative; }
h3 { font-size: 28px; line-height: 34px; font-weight: 500; }
h4 { font-size: 24px; line-height: 30px; font-weight: 500; }
h5 { font-size: 20px; line-height: 26px; font-weight: 500; }
h6 { font-size: 18px; line-height: 24px; font-weight: 500; }
ul { margin: 0px; padding: 0px; }
u {text-decoration-style: wavy;}

.dark-bg p{color: #c2c2c2}

ul { margin: 0px; padding: 0px; }
*::-moz-selection { background: var(--themeht-primary-color); color: #fff; text-shadow: none; }
::-moz-selection { background: var(--themeht-primary-color); color: #fff; text-shadow: none; }
::selection { background: var(--themeht-primary-color); color: #fff; text-shadow: none; }

section{padding: 120px 0; position: relative;}

.z-index-9{z-index: 9; position: relative;}

/* ------------------------
    Text color
------------------------*/
.text-theme{color:var(--themeht-primary-color);}
.text-white{color:var(--themeht-white-color);}
.text-black{color:#1c1d3e;}
.text-grey{color:#aaaaaa;}

.rounded {border-radius: 20px !important;}


/* ------------------------
    Background color
------------------------*/
.white-bg{background-color: var(--themeht-white-color) !important;}
.dark-bg{background-color: var(--themeht-bg-dark-color);}
.light-bg{background-color: var(--themeht-bg-light-color);}
.theme-bg{background-color: var(--themeht-primary-color);}
.transparent-bg{background-color: inherit !important;}
.grediant-bg{background-image: linear-gradient(180deg,#EBE5FF6B 0%,#EBE5FF1A 100%);}
.grediant-bg2{background: linear-gradient(115deg, var(--themeht-primary-color), var(--themeht-secondary-color));}
.grediant-bg3{background: linear-gradient(115deg, var(--themeht-primary2-color), var(--themeht-secondary2-color));}

.header { border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
#header-wrap { padding: 60px 100px 60px; }
.header-top { background: linear-gradient(-45deg, #ff2400, #e81d1d, #e8b71d, #e3e81d, #1de840, #1ddde8, #2b1de8, #dd00f3, #dd00f3); background-size: 400% 400%; animation: gradient 15s ease infinite; display: flex; align-items: center; justify-content: center; padding:7px 30px; }


@keyframes gradient {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}



.logo img { height: 60px; }
.navbar-nav { background-color: #F1EFEB14; padding: 0px 50px 0px 50px; border-radius: 8px 8px 8px 8px; }
.navbar-nav .nav-item { margin: 0px 28px 0px 28px; }
.navbar-nav .nav-link { color: var(--themeht-white-color); font-size: 16px; line-height: 70px; letter-spacing: 0.02em; font-weight: 500; padding: 0 !important; border-radius: 0; text-transform: capitalize; position: relative; }
.navbar-nav .nav-link:hover, .navbar-nav .nav-item .nav-link.active { color: var(--themeht-white-color); }
.navbar-nav .nav-link:before { position: absolute; content: ''; bottom: 0; right: 0; height: 2px; background-color: var(--themeht-white-color); width: 0; -webkit-transition: all .25s cubic-bezier(.645, .045, .355, 1); -khtml-transition: all .25s cubic-bezier(.645, .045, .355, 1); -moz-transition: all .25s cubic-bezier(.645, .045, .355, 1); -ms-transition: all .25s cubic-bezier(.645, .045, .355, 1); -o-transition: all .25s cubic-bezier(.645, .045, .355, 1); transition: all .25s cubic-bezier(.645, .045, .355, 1); }
.navbar-nav .nav-link:hover:before { left: 0; right: auto; width: 100%; }
.navbar-nav .nav-link:after { position: absolute; content: '/'; color: var(--four-color); top: 50% !important; transform: translatey(-50%); right: -30px !important; }
.navbar-nav li:last-child .nav-link:after { display: none; }
.ht-item-content { position: relative; padding-left: 31px; color: var(--themeht-white-color); }
.ht-item-content:before { content: ''; position: absolute; width: 24px; height: 24px; border-radius: 24px; border: 1px solid rgba(255, 255, 255, .15); top: 50%; transform: translatey(-50%); left: -9px; }
.ht-item-content:after { content: ''; position: absolute; width: 6px; height: 6px; background-color: #fff; border-radius: 6px; left: 0; top: 50%; transform: translatey(-50%); animation: dotColor 1.5s infinite ease-in-out; }
.ht-item-content label { font-size: 15px; line-height: 27px; font-weight: 600; }


/* ------------------------
    Button
------------------------*/
.btn { display: inline-flex; padding: 15px 30px; font-family: var(--themeht-secondary-font-family); font-weight: 500; font-size: 16px; line-height: 1.4; background: none; color: var(--themeht-text-color); overflow: hidden; border-radius: 6px; border: none; position: relative; z-index: 9; }
.btn.focus, .btn:focus { box-shadow: none; }
.btn:before { content: ''; position: absolute; top: 0; left: -200%; width: 200%; height: 100%; -webkit-transform: skewx(-20deg); -khtml-transform: skewx(-20deg); -moz-transform: skewx(-20deg); -ms-transform: skewx(-20deg); -o-transform: skewx(-20deg); transform: skewx(-20deg); background-image: linear-gradient(to right, transparent, rgba(255, 255, 255, .35), transparent); z-index: 1; }
.btn:hover:before { -webkit-animation: ht_btn_shine 1.8s ease; animation: ht_btn_shine 1.8s ease; -webkit-animation-delay: .1s; animation-delay: .1s; }
@keyframes ht_btn_shine {
    100% { left: 200% }
}
.btn.btn-theme { background: var(--themeht-primary-color); color: var(--themeht-white-color); }
.btn.btn-theme:hover { background: var(--themeht-bg-dark-color); color: var(--themeht-white-color); }
.btn.btn-dark { background: #02060b; color: var(--themeht-white-color); }
.btn.btn-dark:hover { background: var(--themeht-primary-color); }
.btn + .btn { margin-left: 10px; }


/* ------------------------
    Section Title
------------------------*/
.theme-title { margin-bottom: 40px;}
.theme-title h6 { line-height: 1; position: relative; display: inline-block; font-size: 14px; font-weight: 600; text-transform: uppercase; margin-bottom: 10px; }
.theme-title p { margin-top: 15px; margin-bottom: 0;}
.theme-title h2 { margin-bottom: 0;}
.theme-title h2 span {  margin-bottom: 0;background: linear-gradient(90deg, #ff0000, #ffff00, #ff00f3, #0033ff, #ff00c4, #ff0000);
    -webkit-text-fill-color: transparent;
    background-clip: text;
    -webkit-background-clip: text;
    animation: animate 10s linear infinite; background-size: 400%;}


@keyframes animate {
    0% {
      background-position: 0%;
    }
    100% {
      background-position: 400%;
    }
  }

.theme-title p { margin-bottom: 0; margin-top: 15px }
.text-white.theme-title h6 { background: linear-gradient(90deg, var(--themeht-white-color), var(--themeht-white-color), var(--themeht-white-color)); background-clip: border-box; -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.theme-title.text-white h6, .theme-title.text-white h2 { color: var(--themeht-white-color); }
.theme-title.text-white p { color: var(--themeht-white-color); }

.banner .btn.btn-theme:hover { background: var(--themeht-primary-color); }


/* ------------------------
    Demo
------------------------*/
.home-demo a { display: inline-block; }
.home-title a { display: inline-block; color: var(--themeht-text-color); text-transform: uppercase; font-weight: 700; }
.home-title a:hover { color: var(--themeht-primary-color); }
.home-demo .home-img { display: inline-block; position: relative; width: 100%; box-shadow: 0px 25px 70px rgba(1, 33, 58, 0.07); background: white; padding: 20px; border-radius: 15px; }
.mob-scroll { border-radius: 20px; display: inline-block; height: 500px; position: relative; width: 100%;}
.mob-scroll:hover .feature-mob-scroll { background-position: center 100% !important; }
.home-img .feature-mob-scroll {border: 1px solid var(--themeht-border-light-color); border-radius: 20px; background-position: center 0; background-repeat: no-repeat; background-size: cover; height: 100%; left: 0; position: absolute; top: 0; width: 100%; transition: all 9s ease-out 0s; -webkit-transition: all 9s ease-out 0s; -o-transition: all 9s ease-out 0s; -moz-transition: all 9s ease-out 0s; -ms-transition: all 9s ease-out 0s; }
.ht-home-footer { display: flex; flex-wrap: wrap; align-items: center; position: relative; column-gap: 37px; margin-top: 27px; margin-bottom: 0; }
.ht-item-title { font-size: 16px; font-weight: 500; text-transform: uppercase; flex: 1; color: var(--themeht-text-color); }
.ht-btn-area { display: flex; flex-wrap: wrap; align-items: center; position: relative; column-gap: 15px; }
.ht-item-btn a { display: flex; gap: 4px; background: var(--themeht-bg-dark-color); padding: 8px 15px 5px 15px; border-radius: 50px; box-shadow: var(--themeht-primary-color) 3px 3px 6px 0px inset, rgba(0, 0, 0, 0.5) -3px -3px 6px 1px inset; color: var(--themeht-white-color); font-size: 14px; font-weight: 500; text-transform: uppercase; z-index: 1; font-family: var(--themeht-secondary-font-family); }
.ht-item-btn .button-arrow-hover { position: relative; overflow: hidden; font-size: 0; line-height: 0; display: inline-block; text-align: end; }
.ht-item-btn .button-arrow-hover svg { display: inline-block; transition: transform .3s ease-out; max-width: 22px; max-height: 22px; transform: translatex(0) translatey(0) translatez(0); fill: var(--themeht-white-color) }
.ht-item-btn .button-arrow-hover svg:last-child { position: absolute; top: 0; left: 0; transform: translatex(-200%) translatey(200%) translatez(0); }
.ht-item-btn:hover .button-arrow-hover svg:first-child { transform: translatex(200%) translatey(-200%) translatez(0); }
.ht-item-btn:hover .button-arrow-hover svg:last-child { transform: translatex(0) translatey(0) translatez(0); }
.showcase { position: relative; overflow: hidden; }
.showcase::after { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 300px; /* Adjust fade height */ pointer-events: none;  /* Soft elliptical fade at bottom */ background: linear-gradient(to top, #030303, transparent);  /* The key: mask to create smooth fade edges like the screenshot */ -webkit-mask-image: linear-gradient(to top, #030303 0%, transparent 100%); mask-image: linear-gradient(to top, #030303 0%, transparent 100%); z-index: 9; }


/* ------------------------
 Marquee Text
------------------------*/
.marquee-wrap { width: 100%; position: relative; overflow: hidden; white-space: nowrap; }
.marquee-inner .home-img { display: inline-flex; align-items: center; white-space: nowrap; position: relative; }
.marquee-inner { display: inline-flex; animation: marquee 30s linear infinite; }
.marquee-wrap .home-img { margin: 0 15px; border-radius:10px; overflow:hidden; max-width: 500px; }
.marquee-wrap .home-title { display: none; }

@keyframes marquee {
    0% {
        transform: translateX(0%);
    }
    100% {
        transform: translateX(-50%);
    }
}


/* ------------------------
    Tab
------------------------*/
.tab .nav-tabs{border:none;}
.tab .nav-tabs .nav-link{font-family: var(--themeht-secondary-font-family); background: var(--themeht-white-color); border-radius: 10px; margin-right: 20px; font-size: 22px; font-weight: 500; text-transform: capitalize; color: var(--themeht-text-color); float: left; position: relative; display: inline-block; border:none; padding:15px 40px;}
.tab .nav-tabs .nav-link:last-child{margin-right: 0;}
.tab .nav-tabs .nav-link.active, .tab .nav-tabs .nav-link:hover, .tab .nav-tabs.active > a:focus, .tab .nav-tabs > a:hover{background: var(--themeht-primary-color); color: var(--themeht-white-color);}
.tab .tab-content{padding-top: 50px;}


/* ------------------------
    Featured Box
------------------------*/
.featured-item.style1 { display: flex; align-items: center; column-gap: 25px; }
.featured-item.style1 .featured-icon { width: 75px; height: 75px; display: flex; font-size: 16px; align-items: center; justify-content: center; background-color: #413A3A00; border-radius: 50%; border-style: solid; border-width: 1px 1px 1px 1px; border-color: #FFFFFF26; flex-shrink: 0; }
.featured-item.style1 .featured-icon img { width: 32px; }
.featured-item.style1 h6 { color: #c2c2c2 }
.featured-item.style2 { padding: 40px 30px; border-radius: 20px; border: 1px solid rgba(255, 255, 255, .15) }
.featured-item.style2 .featured-icon { margin-bottom: 20px; }
.featured-item.style2 .featured-icon { flex-shrink: 0; width: 80px; }
.featured-item.style2 h6 { font-size: 20px; color: var(--themeht-white-color); text-transform: uppercase; border-top: 1px solid rgba(255, 255, 255, .15); font-weight: 500; -webkit-transition: all .25s cubic-bezier(.645, .045, .355, 1); -khtml-transition: all .25s cubic-bezier(.645, .045, .355, 1); -moz-transition: all .25s cubic-bezier(.645, .045, .355, 1); -ms-transition: all .25s cubic-bezier(.645, .045, .355, 1); -o-transition: all .25s cubic-bezier(.645, .045, .355, 1); transition: all .25s cubic-bezier(.645, .045, .355, 1); margin-top: 24px; padding-top: 24px; margin-bottom: 24px; position: relative; }
.featured-item.style2 h6:after { content: ''; position: absolute; background-color: var(--themeht-white-color); width: 0; -webkit-transition: all .25s cubic-bezier(.645, .045, .355, 1); -khtml-transition: all .25s cubic-bezier(.645, .045, .355, 1); -moz-transition: all .25s cubic-bezier(.645, .045, .355, 1); -ms-transition: all .25s cubic-bezier(.645, .045, .355, 1); -o-transition: all .25s cubic-bezier(.645, .045, .355, 1); transition: all .25s cubic-bezier(.645, .045, .355, 1); height: 1px; top: 0; left: 0; }
.featured-item.style2:hover h6:after { width: 100%; }



.footer { padding: 100px 50px }
.footer h2 { font-weight: 500; font-size: clamp(48px, 11vw, 240px); line-height: clamp(56px, 14vw, 220px); letter-spacing: -0.05em; text-transform: uppercase; }
.footer h2 .btn-wrapper { position: relative; display: inline-block; }
.footer h2 .btn-wrapper .text { width: 175px; height: 175px; display: flex; align-items: center; border-radius: 500px; flex-direction: column; justify-content: center; color: var(--themeht-white-color); position: absolute; right: -69px; top: -87px; line-height: 1; z-index: 99; background: linear-gradient(-45deg, #e8b71d, #e3e81d, #1de840, #1ddde8, #2b1de8, #dd00f3, #dd00f3); background-size: 400% 400%; animation: gradient 15s ease infinite; }
.footer h2 .btn-wrapper .text .only { color: var(--themeht-white-color); font-size: 30px; font-weight: 500; line-height: 1; letter-spacing: -1.5px; }
.footer h2 .btn-wrapper .text strong { font-size: 60px; font-weight: 600; line-height: 1; letter-spacing: -3px; }
.footer h2 .btn-wrapper .btn { padding: 79px 140px; letter-spacing: -0.02em; transform: translateY(-20px); border-radius: 100px; }
.footer h2 .btn-wrapper .btn { background-color: var(--themeht-bg-dark-color); }


/* ------------------------
    Scroll to Top
------------------------*/
.scroll-top {position: fixed; bottom: 30px; right: 30px; z-index: 600; opacity: 0; visibility: hidden; -webkit-transition: all 0.8s ease-in-out; transition: all 0.8s ease-in-out; -webkit-transform: translate3d(0, 200%, 0); -ms-transform: translate3d(0, 200%, 0); transform: translate3d(0, 200%, 0);}
.scroll-top a, .scroll-top a:visited {display: block; height: 60px; width: 60px; line-height: 60px; text-align: center; -webkit-box-shadow: 0 0 15px 6px rgba(0,0,0,0.1); -moz-box-shadow: 0 0 15px 6px rgba(0,0,0,0.1); box-shadow: 0 0 15px 6px rgba(0,0,0,0.1); -webkit-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out;}
.scroll-top.scroll-visible {opacity: 1; visibility: visible; -webkit-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0);}

@media (max-width:992px) {
    .footer h2 .btn-wrapper .text { width: 135px; height: 135px; }
    .footer h2 .btn-wrapper .text .only { font-size: 20px; }
    .footer h2 .btn-wrapper .text strong { font-size: 50px; }
    .footer h2 .btn-wrapper .btn { padding: 59px 120px; transform: inherit; }
    #header-wrap { padding: 30px 30px 30px; }
    .navbar-toggler { background: var(--themeht-primary-color); height: 40px; width: 40px; padding: 3px; margin-right: 15px; color: var(--themeht-white-color) }
    .navbar-toggler:focus { box-shadow: none; }
    .navbar-collapse { max-height: 400px; background: #000; overflow: auto; border: medium none; left: 0; position: absolute; z-index: 999; top: 80px; width: 100%; }
    .navbar-nav .nav-item { margin: 0; }
    .navbar-nav { padding: 20px 30px; }
    .navbar-nav .nav-link { line-height: 40px; }
    .navbar-nav .nav-link:after { display: none; }
}
@media (max-width:767px) {
    h1 { font-size: 50px; line-height: 60px; }
    h2 { font-size: 44px; line-height: 54px; }
    .footer { padding: 80px 20px; }
    .footer h2 .btn-wrapper .btn { padding: 19px 30px; transform: inherit; }
    .footer h2 .btn-wrapper .text { width: 85px; height: 135px; top: -30px; right: -100px; }
    .container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl { --bs-gutter-x: 3.5rem; }
    .tab .nav-tabs .nav-link { font-size: 20px; padding: 12px 25px; }
    .ht-home-footer { display: block; }
    .ht-item-title { margin-bottom: 20px; }
    section { padding: 80px 0; }
}