
:root {
  --primary-color: #E84945;
  --primary-black-color: #141414;
}

/* Default CSS */
@media (min-width: 1450px) {
  .header-seven .container {
    max-width: 1550px;
  }
}
.border-top-1 {
  border-top: 1px solid var(--border-color);
}

.gradient-text {
  background: -webkit-gradient(linear, left top, right top, from(#FE7587), to(#ECB22E));
  background: linear-gradient(90deg, #FE7587 0%, #ECB22E 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
}

.theme-btn.style-one {
  padding: 13px 40px;
  font-weight: 700;
  font-size: 16px;
  color: var(--heading-color);
  background: -webkit-gradient(linear, left top, right top, from(#F28F32), to(#a73729 ));
  background: linear-gradient(90deg, #F28F32 0%, #a73729  100%);
}
.theme-btn.style-one:hover {
background: linear-gradient(90deg, #a73729 0%, #F28F32  100%);}
.sub-title {
  font: 600 16px var(--body-font);
}

@media (max-width: 767px) {
  .section-title h2 {
    font-size: 28px;
    line-height: 40px;
  }
}

/* Hero Section */
.hero-ca {
position: relative;
    padding: 125px 0 0px;
    background: #ffff;
    margin-bottom: 60px;
    z-index: 1;
    overflow: hidden;
}
.hero-ca .shape {
  position: absolute;
  z-index: -1;
}
.hero-ca .shape.shape-blur-one {
top: -30%;
  right: -30%;
}
.hero-ca .shape.shape-blur-one span {
  width: 710px;
  height: 710px;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#F9C5F0), to(#EDAD36));
 background: linear-gradient(180deg, #F9C5F0 0%, #EDAD36 100%);
  -webkit-filter: blur(600px);
          filter: blur(600px);
}
.hero-ca .shape.shape-blur-two {
  bottom: 20%;
  right: -30%;
}
.hero-ca .shape.shape-blur-two span {
  width: 535px;
  height: 535px;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#F1B678));
  background: linear-gradient(180deg, #FFF 0%, #F1B678 100%);
  -webkit-filter: blur(400px);
          filter: blur(400px);
}
.hero-ca .shape.element-one {
  top: 20%;
  left: 5%;
}
.hero-ca .shape.element-two {
  top: 19%;
  right: 10%;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .hero-ca .shape.element-two {
    text-align: right;
    top: 17%;
    right: 5%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .shape.element-two {
    text-align: right;
    top: 16%;
    right: 5%;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .shape.element-two {
    text-align: right;
    top: 18%;
    right: 10%;
  }
}
.hero-ca .shape.element-two span img {
  -webkit-animation-duration: 20s;
          animation-duration: 20s;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .hero-ca .shape.element-two span img {
    width: 65%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .shape.element-two span img {
    width: 55%;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .shape.element-two span img {
    width: 35%;
  }
}
.hero-ca .shape.element-three {
  top: 28%;
  left: 17%;
}
@media screen and (max-width: 991px) {
  .hero-ca .shape.element-three {
    top: 26%;
    left: 30%;
  }
}
.hero-ca .shape.element-three span img {
  -webkit-animation-duration: 15s;
          animation-duration: 15s;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .hero-ca .shape.element-three span img {
    width: 55%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .shape.element-three span img {
    width: 45%;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .shape.element-three span img {
    width: 25%;
  }
}
.hero-ca .shape.element-four {
  top: 50%;
  right: 5%;
}
.hero-ca .hero-content {
  max-width: 1100px;
  margin-bottom: 50px;
  padding-left: 130px;
  text-align: right;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .hero-content {
    padding-left: 70px;
    padding-right: 70px;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .hero-content {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 50px;
  }
}
.hero-ca .hero-content h1 {
  font-family: var(--heading-font);
  font-size: 200px;
  color: var(--white-color);
  line-height: 1;
  font-weight: 700;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .hero-content h1 {
    font-size: 150px;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .hero-content h1 {
    font-size: 100px;
  }
}
@media (max-width: 767px) {
  .hero-ca .hero-content h1 {
    font-size: 70px;
    line-height: 100px;
  }
}
.hero-ca .hero-content .hero-text {
  font-family: var(--heading-font);
  font-size: 65px;
  line-height: 1;
  color: var(--white-color);
  font-weight: 700;
  margin-top: 70px;
  text-align: center;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .hero-ca .hero-content .hero-text {
    font-size: 150px;
  }
}
@media screen and (max-width: 991px) {
  .hero-ca .hero-content .hero-text {
    font-size: 100px;
  }
}
@media (max-width: 767px) {
  .hero-ca .hero-content .hero-text {
    font-size: 70px;
    line-height: 100px;
  }
}
.hero-ca .hero-content-wrap {
  /* display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 900px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto 50px; */
  margin: 0 auto;
  width: fit-content;
  text-align: center;
}
@media (max-width: 767px) {
  .hero-ca .hero-content-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.hero-ca .hero-content-wrap .years-box {
  position: relative;
}
.hero-ca .hero-content-wrap .years-box .fill-text {
  color: #141414;
  font-size: 300px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1em;
  font-family: var(--heading-font);
  -webkit-text-stroke-width: 1px;
  stroke-width: 1px;
  background-color: transparent;
  -webkit-text-stroke-color: rgba(255, 255, 255, 0.1);
  stroke: rgba(255, 255, 255, 0.1);
}
@media screen and (max-width: 991px) {
  .hero-ca .hero-content-wrap .years-box .fill-text {
    font-size: 220px;
  }
}
.hero-ca .hero-content-wrap .years-box .gradient-text {
  position: absolute;
  right: 0;
  top: 50%;
  font: 600 24px var(--heading-font);
}
.hero-ca .hero-content-wrap .text-box {
  max-width: 600px;
  margin-bottom: 100px;
}
.hero-ca .hero-content-wrap .text-box p {
  margin-bottom: 30px;
  color: var(--white-color);
  font-size: 20px;
}
.hero-ca .hero-image {
  position: relative;
  margin-bottom: -140px;
  z-index: 1;
}
.hero-ca .hero-image img{
  border-radius: 50px;
  width: 700px;
}
.hero-ca .animated-big-text .headline-wrap.style-one {
  color:  rgba(255, 255, 255, 0.21);
}

/* Who We */
@media (min-width: 1200px) and (max-width: 1450px) {
  .who-we-ca .section-content-box h2 {
    font-size: 36px;
    line-height: 45px;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .who-we-ca .section-content-box h2 {
    font-size: 32px;
    line-height: 45px;
  }
}
@media (max-width: 767px) {
  .who-we-ca .section-content-box h2 {
    font-size: 28px;
    line-height: 40px;
  }
}
.who-we-ca .service-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.who-we-ca .service-list .Vistaaar-iconic-box.style-thirteen.flex-center .content {
  padding-top: 0;
}
.who-we-ca .service-list .Vistaaar-iconic-box.style-thirteen .content {
  padding-top: 100px;
}
@media screen and (max-width: 991px) {
  .who-we-ca .service-list ul {
    margin: 0 auto;
  }
}
.who-we-ca .service-list ul li:nth-child(2) {
  margin-top: -220px;
}
@media (max-width: 767px) {
  .who-we-ca .service-list ul li:nth-child(2) {
    margin-top: -100px;
  }
}
.who-we-ca .service-list ul li:nth-child(3) {
  margin-top: -220px;
}
@media (max-width: 767px) {
  .who-we-ca .service-list ul li:nth-child(3) {
    margin-top: -100px;
  }
}

/* Features Section */
.features-ca .Vistaaar-iconic-box.style-twelve {
  padding: 50px 30px 40px;
}
.features-ca .Vistaaar-iconic-box.style-twelve .content h4.title {
  margin-bottom: 15px;
}
.features-ca .Vistaaar-iconic-box.style-twelve .content p {
  font: 400 16px var(--body-font);
  color: var(--text-color);
  line-height: 30px;
}

/* Project Section */
.project-ca .container-fluid {
  padding-left: 100px;
  padding-right: 100px;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .project-ca .container-fluid {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media screen and (max-width: 991px) {
  .project-ca .container-fluid {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.project-ca .project-list .Turnr-project-item.style-four {
  margin-bottom: 150px;
}

.item_one {
  max-width: 735px;
}

.item_one_two {
  margin-left: auto;
}

/* Creative Promo */
.creative-promo {
  position: relative;
  z-index: 1;
}
.creative-promo .animated-big-text {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: -1;
}

/* Testimonial Section */
.testimonial-ca .testimonial-wrapper {
  position: relative;
  z-index: 1;
  min-height: 515px;
}
.testimonial-ca .testimonial-wrapper:after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(20, 20, 20, 0)), to(#141414));
  background: linear-gradient(180deg, rgba(20, 20, 20, 0) 0%, #141414 100%);
  z-index: -1;
}
.testimonial-ca .testimonial-slider-wrapper {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.testimonial-ca .testimonial-slider-wrapper .shape {
  position: absolute;
  z-index: -1;
}
.testimonial-ca .testimonial-slider-wrapper .shape.shape-blur-one {
  bottom: -40%;
  right: -10%;
}
.testimonial-ca .testimonial-slider-wrapper .shape.shape-blur-one span {
  width: 400px;
  height: 400px;
  border-radius: 400px;
  background: -webkit-gradient(linear, left top, left bottom, from(#EE54D5), to(#10424a));
  background: linear-gradient(180deg, #EE54D5 0%, #10424a 100%);
  -webkit-filter: blur(250px);
          filter: blur(250px);
}
.testimonial-ca .testimonial-slider-wrapper .shape.element-one {
  top: 20%;
  left: 5%;
}
.testimonial-ca .testimonial-slider-wrapper .shape.element-two {
  bottom: 35%;
  right: 7%;
}

/* Creative Agency */
.text-anm-three span {
  margin-right: 10px;
}

/* Creative Agency Footer */
.creative-agency-footer {
  background-color: #141414;
  position: relative;
  z-index: 1;
}
.creative-agency-footer .shape {
  position: absolute;
  z-index: -1;
}
.creative-agency-footer .shape.shape-blur-one {
  bottom: -40%;
  left: -10%;
}
.creative-agency-footer .shape.shape-blur-one span {
  width: 400px;
  height: 400px;
  border-radius: 400px;
  background: -webkit-gradient(linear, left top, left bottom, from(#EE54D5), to(#10424a));
  background: linear-gradient(180deg, #EE54D5 0%, #10424a 100%);
  -webkit-filter: blur(250px);
          filter: blur(250px);
}
.creative-agency-footer .shape.shape-blur-two {
  bottom: -40%;
  right: -10%;
}
.creative-agency-footer .shape.shape-blur-two span {
  width: 400px;
  height: 400px;
  border-radius: 400px;
  background: -webkit-gradient(linear, left top, left bottom, from(#EE54D5), to(#10424a));
  background: linear-gradient(180deg, #EE54D5 0%, #10424a 100%);
  -webkit-filter: blur(250px);
          filter: blur(250px);
}
.creative-agency-footer .shape.element-one {
  top: 10%;
  left: 10%;
}
@media (max-width: 767px) {
  .creative-agency-footer .shape.element-one {
    left: 5%;
    top: 5%;
  }
}
.creative-agency-footer .shape.element-two {
  top: 48%;
  right: 7%;
}
@media screen and (max-width: 991px) {
  .creative-agency-footer .shape.element-two {
    top: 70%;
  }
}
.creative-agency-footer .footer-top {
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.creative-agency-footer .footer-top .footer-content h2 {
  letter-spacing: -4.5px;
  font: 700 150px var(--heading-font);
  color: var(--white-color);
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .creative-agency-footer .footer-top .footer-content h2 {
    font-size: 130px;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .creative-agency-footer .footer-top .footer-content h2 {
    font-size: 80px;
  }
}
@media screen and (max-width: 991px) {
  .creative-agency-footer .footer-top .footer-content h2 {
    font-size: 50px;
  }
}
@media (max-width: 767px) {
  .creative-agency-footer .footer-top .footer-content h2 {
    font-size: 40px;
  }
}
.creative-agency-footer .footer-widget .footer-content h4.widget-title {
  color: var(--heading-color);
}
.creative-agency-footer .footer-widget .footer-content p {
  font-size: 16px;
  color: var(--heading-color);
  font-weight: 400;
  line-height: 30px;
  margin-bottom: 5px;
}
.creative-agency-footer .footer-widget .footer-content ul.social-link li a {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--heading-color);
}
.creative-agency-footer .footer-widget .footer-content ul.social-link li a:hover{
  background: #fff;
  color: #3b534b;
}



.creative-agency-footer .footer-widget .footer-content ul.social-link li a:hover {
  border-color: var(--heading-color);
}
.creative-agency-footer .footer-copyright {
  border-color: rgba(255, 255, 255, 0.07);
}
.creative-agency-footer .footer-copyright .copyright-text p {
  color: #ffffff;
}
.creative-agency-footer .footer-copyright .copyright-text p span {
  color: var(--heading-color);
}
.creative-agency-footer .footer-copyright .copyright-nav ul li a {
  color: #fff;
}
.footer-content .footer-links li a {
  color: #fff;
}
.creative-agency-footer .footer-copyright .copyright-nav ul li a:hover {
  color: var(--heading-color);
}

/* Page Banner */
.page-hero-ss {
position: relative;
  padding: 148px 0 35px;
  background: #ff831f4a;
  z-index: 1;
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .page-hero-ss {
    padding: 200px 0 140px;
  }
}
.page-hero-ss .shape {
  position: absolute;
  z-index: -1;
}
.page-hero-ss .shape.shape-blur-one {
  top: -30%;
  left: -30%;
}
.page-hero-ss .shape.shape-blur-one span {
  width: 710px;
  height: 710px;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#F4FDFF), to(#f7d6bb ));
background: linear-gradient(180deg, #F4FDFF 0%, #f7d6bb 100%);

  -webkit-filter: blur(600px);
          filter: blur(600px);
}
.page-hero-ss .shape.shape-blur-two {
  bottom: 20%;
  right: -30%;
}
.page-hero-ss .shape.shape-blur-two span {
  width: 535px;
  height: 535px;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, left bottom, from(#F4FDFF), to(#f7d6bb));
background: linear-gradient(180deg, #F4FDFF 0%, #f7d6bb 100%);
  -webkit-filter: blur(400px);
          filter: blur(400px);
}
.page-hero-ss .shape.element-one {
  top: 30%;
  left: 8%;
}
.page-hero-ss .shape.element-two {
  top: 35%;
  right: 10%;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .page-hero-ss .shape.element-two {
    text-align: right;
    top: 17%;
    right: 5%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .page-hero-ss .shape.element-two {
    text-align: right;
    top: 16%;
    right: 5%;
  }
}
@media screen and (max-width: 991px) {
  .page-hero-ss .shape.element-two {
    text-align: right;
    top: 18%;
    right: 10%;
  }
}
.page-hero-ss .shape.element-two span img {
  -webkit-animation-duration: 20s;
          animation-duration: 20s;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .page-hero-ss .shape.element-two span img {
    width: 65%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .page-hero-ss .shape.element-two span img {
    width: 55%;
  }
}
@media screen and (max-width: 991px) {
  .page-hero-ss .shape.element-two span img {
    width: 35%;
  }
}
.page-hero-ss .shape.element-three {
  bottom: 10%;
  left: 5%;
}
.page-hero-ss .shape.element-three span {
  max-width: 150px;
}
.page-hero-ss .shape.element-three span img {
  -webkit-animation-duration: 15s;
          animation-duration: 15s;
}
@media (min-width: 1200px) and (max-width: 1450px) {
  .page-hero-ss .shape.element-three span img {
    width: 55%;
  }
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .page-hero-ss .shape.element-three span img {
    width: 45%;
  }
}
@media screen and (max-width: 991px) {
  .page-hero-ss .shape.element-three span img {
    width: 25%;
  }
}
.page-hero-ss .shape.element-four {
  bottom: 8%;
  right: 15%;
}
.page-hero-ss .page-content {
  text-align: center;
}
.page-hero-ss .page-content h1 {
  color: var(--white-color);
  font-size: 65px;
  line-height: 1.1;
}

/* About Page */
.about-ca .Vistaaar-image-box .Vistaaar-image img {
  width: 100%;
}

/* Service Details Page */
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .service-details-wrapper .section-content-box h2 {
    font-size: 42px;
    line-height: 60px;
  }
}
@media screen and (max-width: 991px) {
  .service-details-wrapper .section-content-box h2 {
    font-size: 38px;
    line-height: 50px;
  }
}
@media (max-width: 767px) {
  .service-details-wrapper .section-content-box h2 {
    font-size: 28px;
    line-height: 40px;
  }
}
.service-details-wrapper .section-content-box p {
  margin-bottom: 35px;
}
.service-details-wrapper .Vistaaar-image-box img {
  width: 100%;
}

/* Project Details Page */
.project-details-ss .project-thumbnail .thumbnail {
  position: relative;
}
.project-details-ss .project-thumbnail .thumbnail img {
  border-radius: 7px;
  min-height: 550px;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .project-details-ss .project-thumbnail .thumbnail img {
    min-height: 500px;
  }
}
@media (max-width: 767px) {
  .project-details-ss .project-thumbnail .thumbnail img {
    min-height: 20px;
  }
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box {
  position: absolute;
  bottom: 30px;
  right: 30px;
  background-color: var(--primary-color);
  max-width: 400px;
  width: 100%;
  padding: 40px 50px;
  border-radius: 15px;
}
@media (max-width: 767px) {
  .project-details-ss .project-thumbnail .thumbnail .project-info-box {
    padding: 20px 30px;
    position: relative;
    bottom: 0;
    right: 0;
    margin-top: 40px;
  }
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box h4.title {
  letter-spacing: -0.48px;
  color: var(--white-color);
  margin-bottom: 20px;
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box ul li {
  display: block;
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box ul li:not(:last-child) {
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box ul li span {
  font: 500 16px var(--heading-font);
  color: var(--white-color);
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box ul li span.title {
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.36px;
}
.project-details-ss .project-thumbnail .thumbnail .project-info-box ul li span.info {
  float: right;
}
.project-details-ss .project-content .content h3.title {
  font-size: 52px;
  font-weight: 600;
  letter-spacing: -1.04px;
  margin-bottom: 33px;
}
@media screen and (min-width: 992px) and (max-width: 1200px) {
  .project-details-ss .project-content .content h3.title {
    font-size: 22px;
    margin-bottom: 25px;
    line-height: 40px;
  }
}
@media screen and (max-width: 991px) {
  .project-details-ss .project-content .content h3.title {
    font-size: 22px;
    margin-bottom: 15px;
    line-height: 40px;
  }
}
.project-details-ss .project-content .content p {
  margin-bottom: 40px;
}
.project-details-ss .project-content .content ul {
  margin-bottom: 60px;
}
@media (max-width: 767px) {
  .project-details-ss .project-content .content ul {
    margin-bottom: 30px;
  }
}
.project-details-ss .project-content .content h5 {
  margin-bottom: 10px;
}
.project-details-ss .project-content .content .block-image img {
  border-radius: 7px;
}

/* Primary Black Bg */
.primary-black-bg .sasfy-fancy-team-member {
  border-color: rgba(255, 255, 255, 0.1);
}
.primary-black-bg .sasfy-fancy-team-member .designation {
  color: rgba(255, 255, 255, 0.55);
}
.primary-black-bg .sasfy-fancy-team-member .name {
  color: var(--white-color);
}
.primary-black-bg .sasfy-fancy-team-member .social-links span {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.1);
}
.primary-black-bg .Vistaaar-testimonial-item.style-seven .testimonial-content p {
  color: var(--white-color);
}
.primary-black-bg .Vistaaar-testimonial-item.style-seven .testimonial-content .author-info h5 {
  color: var(--white-color);
}
.primary-black-bg .Vistaaar-testimonial-item.style-seven .testimonial-content .author-info span.position {
  color: var(--white-color);
}

       :root {
/* Card 1 – Dark Charcoal Brown (Neutral Base) */
--color-blue-light: rgb(43, 58, 78);
--color-blue-dark:  rgb(160, 196, 223);

/* Card 2 – Dark Burnt Orange (Brand-Linked) */
--color-orange-light: rgb(176, 80, 20);;
--color-orange-dark:  #F2A04C;

/* Card 3 – Dark Wine Red (Premium Accent) */
--color-purple-light: rgb(81, 48, 48);
--color-purple-dark:  #E06A5F;
                        --color-bg-light: #F8F9FA;
            --card-width-lg: 380px;
        }

        body {
            font-family: 'Inter', sans-serif;
            background-color: var(--color-bg-light);
            overflow-x: hidden;
            padding-bottom: 8rem;
        }

        /* --- Custom Curved Section and Background --- */
        .curved-section-wrapper {
            position: relative;
            padding: 0px 0 150px;
            overflow: visible; /* Allows cards to lift beyond bounds */
        }

        .curved-background {
position: absolute;
  bottom: 44px;
  left: 0;
  width: 100%;
  height: 300px;
  background-color: #fff;
border-top-left-radius: 55% 286px;
  border-top-right-radius: 50% 300px;
  z-index: 22;
        }

        /* New Container for Overlapping Cards */
        .cards-container {
            position: relative;
            /* Flex and margin auto used for mobile stacking */
            display: flex;
            flex-direction: column;
            align-items: center;
            /* Set max width for the desktop overlap effect */
            max-width: 1000px;
            margin: 0 auto;
            min-height: 500px;
            z-index: 10;
        }

        /* --- Card Styling --- */
        .feature-card {
            position: relative;
            z-index: 10;
            color: var(--color-blue-dark);
            border-radius: 30px;
            padding: 40px 30px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            min-height: 400px;
            width: 90%; /* Default width for mobile */
            max-width: var(--card-width-lg);
            cursor: pointer;
            margin-bottom: 2rem;
            /* Set initial transform for GSAP to target efficiently */
            transform: translate(0, 0) rotate(0deg);
            /* Remove CSS transition, GSAP handles transforms/colors */
            transition: none;
        }

        .card-content-block {
            border-radius: 20px;
            padding: 15px 20px;
            margin-top: 15px;
            color: var(--color-bg-light);
            font-size: 0.9rem;
            /* Ensure inner content also uses relative positioning */
            position: relative;
            z-index: 2;
        }

        /* --- Sweeping Overlay --- */
        .card-sweeper {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            border-radius: 100px;
            pointer-events: none;
            z-index: 1; /* Below the content (z-index: 2) but covers the card BG */
        }

        /* Initial Sweeper Colors (The target color after the swap) */
        .card-blue .card-sweeper {
            background-color: var(--color-blue-dark);
            opacity: 0.8;
        }
        .card-orange .card-sweeper {
            background-color: var(--color-orange-dark);
                opacity: 0.8;
        }
        .card-purple .card-sweeper {
            background-color: var(--color-purple-dark);
                opacity: 0.8;
        }

        /* Initial Colors (The state before hover) */
        .card-blue {
            background-color: var(--color-blue-light);
            color: var(--color-blue-dark);
        }
        .card-blue .card-content-block {
            background-color: var(--color-blue-dark);
        }
        .card-orange {
            background-color: var(--color-orange-light);
            color: var(--color-orange-dark);
        }
        .card-orange .card-content-block {
            background-color: var(--color-orange-dark);
        }
        .card-purple {
            background-color: var(--color-purple-light);
            color: var(--color-purple-dark);
        }
        .card-purple .card-content-block {
            background-color: var(--color-purple-dark);
        }


        /* Desktop Overlapping Positioning (min-width: 992px) */
        @media (min-width: 992px) {
            .cards-container {
                flex-direction: row;
                justify-content: center;
                align-items: flex-start;
                min-height: 550px;
            }

            .feature-card {
                position: absolute; /* Enable overlap */
                margin-bottom: 0;
                /* Apply initial translateX(-50%) to all cards in desktop view
                   to center their left edge at 50% and then shift back by half their width. */
                transform: translateX(-50%);
            }

            /* Card 1: Left - Tilted left, higher z-index, offset left */
            .cards-container .feature-card:nth-child(1) {
                /* Start left of center */
                left: calc(50% - 370px);
                top: 20px;
                z-index: 15;
                /* Combine centering translateX with rotation */
                transform: translateX(-50%) rotate(-5deg);
            }

            /* Card 2: Center - Base position, highest z-index, scaled up */
            .cards-container .feature-card:nth-child(2) {
                /* Position exactly at the center (50% left) */
                left: 50%;
                top: 0;
                z-index: 20;
                /* Combine centering translateX with scale */
                transform: translateX(-50%) scale(1.05);
            }

            /* Card 3: Right - Tilted right, middle z-index, offset right */
            .cards-container .feature-card:nth-child(3) {
                /* Start right of center */
                left: calc(50% + 370px);
                top: 20px;
                z-index: 15;
                /* Combine centering translateX with rotation */
                transform: translateX(-50%) rotate(5deg);
            }
        }


        .text-on-curve{
          position: absolute;
  z-index: 99999;
  left: 50%;
  transform: translateX(-50%);
  bottom: -67px;

        }

        .text-on-curve h2{
    font-size: 34px;
  line-height: 1.5;
        }

        /* MOBILE RESPONSIVE (below 992px) */
@media (max-width: 991px) {
    .cards-container {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        min-height: auto;
        margin: 0 auto;
        padding: 0 15px;
    }

    .feature-card {
        position: relative !important; /* remove absolute positioning from desktop */
        transform: none !important; /* remove rotations & scaling */
        width: 95% !important; /* almost full width */
        max-width: 380px; /* keep desktop card width limit */
        margin-bottom: 2rem;
    }

    .feature-card:nth-child(1),
    .feature-card:nth-child(2),
    .feature-card:nth-child(3) {
        left: auto !important;
        top: auto !important;
        z-index: auto !important;
        rotate: 0deg !important;
        scale: 1 !important;
    }

    /* Curved background adjustment */
    .curved-background {
        height: 200px;
        bottom: 20px;
        border-top-left-radius: 50% 200px;
        border-top-right-radius: 50% 200px;
    }

    /* Text on curve positioning */
    .text-on-curve {
        bottom: -50px;
        left: 50%;
        transform: translateX(-50%);
        text-align: center;
        padding: 0 10px;
    }

    .text-on-curve h2 {
        font-size: 20px;
        line-height: 1.4;
    }

    .text-on-curve h4 {
        font-size: 14px;
        line-height: 1.5;
        display: none;
    }

    /* Card inner content adjustments */
    .card-content-block {
        padding: 10px 15px;
        font-size: 0.85rem;
    }

    .card-title {
        font-size: 1.5rem;
    }
}

.blog-ca img{
    width: 100%;
    max-width: 100%;
    height: 330px;
    display: block;
    object-fit: cover;
    border-radius: 10px;
    border-radius: 20px;
}
.footer-bottom{
/* background: #883d0f; */
/* background: linear-gradient(90deg,rgb(153, 61, 45) 0%, rgb(200, 94, 45) 50%, rgb(153, 61, 45) 100%); */
border-top: 2px solid #b3b3b3;
background-color: #121212;
}

.section-content-box {
height: 350px;
}

/* Mobile Responsive Adjustments */
@media (max-width: 767px) {
    .blog-ca .row {
        flex-wrap: wrap;
    }

    .blog-ca .row > [class*="col-lg-"] {
        flex: 0 0 100%;
        max-width: 100%;
        text-align: center; /* optional: center text & images */
        margin-bottom: 20px;
    }

    /* Ensure images are responsive */
    .blog-ca img {
        width: 100%;
        height: auto;
        display: block;
        margin: 0 auto;
    }

    /* Optional: spacing for section content */
    .blog-ca .section-content-box {
        text-align: center;
        padding: 0 15px;
    }

    /* Fix alternating order */
    .blog-ca .row:nth-child(even) {
        flex-direction: column-reverse;
    }
}


:root {
    --sky-blue: #ffffff;
    --dark-text: #212529;
    --primary-color: #c45e1b;
}

body {
    margin: 0;
    font-family: 'Segoe UI', sans-serif;
}

/* Portfolio Section */
.portfolio-template {
    position: relative;
padding: 12rem 1rem 4rem;
    text-align: center;
    z-index: 1;
background: #fff;
}


.portfolio-template::before {
content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1300px;
  background-color: #883d0f;
  border-top-left-radius: 100% 60%;
  border-top-right-radius: 100% 60%;
  z-index: -1;
}






.portfolio-template h1 {
    font-size: 2.5rem;
    font-weight: 700;
    color: #fff;
}

.portfolio-template p.lead {
font-size: 1.15rem;
  color: #fff;
  max-width: 700px;
  margin: 0 auto 5rem auto;
}

/* Image Grid */
.image-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    grid-auto-rows: 200px; /* base row height */
    margin-top: 2rem;
}

/* Grid Items */

.grid-item {
    position: relative;
    overflow: hidden; /* clips child content to the border-radius */
    transition: transform 0.3s ease;
    border-radius: 30px; /* apply rounded corners to container */
    border: 1px solid #f2f2f2;
}
/* Alternate image sizes */
.grid-item.square { grid-row: span 1; }
.grid-item.vertical { grid-row: span 2; }

.grid-item img {
  width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Hover overlay */
.item-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
    background-color: #e27c30;
    transition: height 0.3s ease-out;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    border-top-left-radius: 50% 100%;
    border-top-right-radius: 50% 100%;
}

.grid-item:hover .item-overlay {
    height: 18%;
    opacity: 1;
    pointer-events: all;
}
.grid-item.square:hover .item-overlay {
  height: 44%;
  opacity: 1;
  pointer-events: all;
}

.overlay-content a {
    color: #fff;
}
.grid-item .btn-primary{
background: #fff;
  border-color: transparent;
  color: #000;
}
.grid-item .btn-primary:hover{
background: #fff;
}
/* Responsive */
@media (max-width: 991.98px) {
    .image-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767.98px) {
    .portfolio-template { padding: 4rem 1rem 3rem; }
    .portfolio-template h1 { font-size: 2rem; }
    .image-grid { grid-template-columns: repeat(2, 1fr); }

    .portfolio-template h1,.portfolio-template p.lead{
      color: #000;
    line-height: 37px;
    }
}


        :root {
            --bg-color: #3b5090;
            --card-radius: 32px;
            --primary-blue: #4c6fff;
            --text-dark: #1f2937;
            --text-muted: #6b7280;
            --input-border: #e5e7eb;
            --shadow-light: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
        }

        /* Main Card Container */
        .sign-in-card-container {
            background-color: white;
            max-width: 1200px; /* Increased max-width for a larger desktop feel */
            width: 100%;
            box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
            border-radius: var(--card-radius);
            overflow: hidden;
            display: flex;
            flex-direction: column; /* Stacked on mobile */
            height: auto;
            margin: 40px auto;
            margin: 40px auto;
        }

        @media (min-width: 1024px) {
            .sign-in-card-container {
                flex-direction: row; /* Side-by-side on desktop (lg) */
                height: 557px; /* Fixed height for desktop to match image aspect */
                height: 557px; /* Fixed height for desktop to match image aspect */
            }
        }

        /* Left Column: Login Form */
        .sign-in-login-panel {
            padding: 50px;
            width: 100%;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }

        @media (min-width: 1024px) {
            .sign-in-login-panel {
                width: 55%;
                padding: 64px;
            }
        }
        @media (min-width: 640px) {
            .sign-in-login-panel {
                padding: 48px;
            }
        }

        .sign-in-form-content {
            max-width: 400px;
            margin: 0 auto;
            width: 100%;
        }

        /* Header (Scoped for high specificity) */
        .sign-in-card-container .sign-in-header h1 {
            font-size: 30px;
            font-size: 30px;
            font-weight: 700;
            color: var(--text-dark);
        }
        .sign-in-card-container .sign-in-header p {
            color: var(--text-muted);
            margin-top: 4px;
        }

        /* Input Styles */
        .sign-in-input-group {
            margin-bottom: 20px;
            position: relative;
        }
        .sign-in-custom-input {
            width: 100%;
            padding: 12px 40px 12px 20px;
            border: 1px solid var(--input-border);
            border-radius: 12px;
            color: var(--text-dark);
            font-size: 0.9rem;
            box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
            transition: all 0.2s;
            outline: none;
        }
        .sign-in-custom-input::placeholder {
            color: #9ca3af;
        }
        .sign-in-custom-input:focus {
            border-color: var(--primary-blue);
            box-shadow: 0 0 0 3px rgba(76, 111, 255, 0.2);
        }
        .sign-in-input-icon {
            position: absolute;
            right: 12px;
            top: 50%;
            transform: translateY(-50%);
            color: #9ca3af;
        }

        /* Checkbox & Forgot Password */
        .sign-in-form-options {
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: 0.875rem;
            margin-top: -13px;
            float: right;
            margin-top: -13px;
            float: right;
        }
        .sign-in-form-options label {
            color: #4b5563;
        }

        /* Specific link class for 'Forgot Password?' */
        .sign-in-form-options .sign-in-forgot-link {
            color: var(--text-muted);
            text-decoration: none;
            transition: color 0.2s;
            font-size: 15px;
            font-size: 15px;
        }
        .sign-in-form-options .sign-in-forgot-link:hover {
            color: var(--primary-blue);
        }

        .sign-in-checkbox-group {
            display: flex;
            align-items: center;
        }
        .sign-in-checkbox-group input[type="checkbox"] {
            width: 16px;
            height: 16px;
            margin-right: 8px;
            accent-color: var(--primary-blue); /* Sets the checkbox color */
            border-radius: 4px;
            cursor: pointer;
        }

        /* Login Button */
        .sign-in-login-button {
            width: 100%;
            background: linear-gradient(90deg, #F28F32 0%, #a73729  100%);
            color: white;
            padding: 12px 0;
            border-radius: 12px;
            font-weight: 600;
            transition: background-color 0.3s;
            border: none;
            cursor: pointer;
            box-shadow: 0 5px 15px rgba(76, 111, 255, 0.3); /* Button shadow */
        }
        .sign-in-login-button:hover {
           background: linear-gradient(90deg, #a73729  0%, #F28F32 100%);
        }

        /* Separator */
        .sign-in-separator {
            display: flex;
            align-items: center;
            margin: 32px 0;
        }
        .sign-in-separator-line {
            flex-grow: 1;
            border-top: 1px solid #e5e7eb;
        }
        .sign-in-separator span {
            padding: 0 16px;
            color: #9ca3af;
            font-size: 0.875rem;
        }

        /* Social Buttons */
        .sign-in-social-buttons {
            display: flex;
            justify-content: center;
            gap: 16px;
        }
        .sign-in-social-button {
            width: 48px;
            height: 48px;
            background-color: white;
            border: 1px solid #d1d5db;
            border-radius: 50%;
            display: flex;
            justify-content: center;
            align-items: center;
            cursor: pointer;
            transition: background-color 0.2s, border-color 0.2s;
        }
        .sign-in-social-button:hover {
            background-color: #f9fafb;
            border-color: #9ca3af;
        }

        /* Graphic Panel (The Image Replica) */
        .sign-in-graphic-panel {
background-image: url(../images/login.jpg);
background-size: cover; /* Ensures the image covers the entire area */
    background-position: center; /* Centers the image within the container */
    background-repeat: no-repeat; /* Prevents the image from repeating */
    height: 100vh; /* Makes the panel's height equal to the viewport height */
    width: 100%;
        }

        @media (min-width: 1024px) {
            .sign-in-graphic-panel {
                display: block;
                width: 50%;
              height: 100%;
                border-radius: 0 var(--card-radius) var(--card-radius) 0;
            }
        }

        .sign-in-graphic-panel-content {
            position: absolute;
            inset: 0;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        /* Large circular glow effect */
        .sign-in-graphic-circle {
            width: 400px;
            height: 400px;
            background: radial-gradient(circle at 10% 50%, rgba(138, 114, 255, 0.7) 0%, rgba(76, 111, 255, 0.4) 40%, rgba(20, 0, 70, 0) 70%);
            border-radius: 50%;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
        }

        /* Secondary large shape effect (the bright edge) */
        .sign-in-graphic-shape {
            content: '';
            position: absolute;
            width: 150%;
            height: 150%;
            bottom: 0;
            right: 0;
            border-radius: 50%;
            background: rgba(255, 255, 255, 0.1);
            filter: blur(80px);
            opacity: 0.8;
            transform: translate(30%, 30%) rotate(45deg);
        }


        /* Message Box Styling (Modal) */
        #sign-in-message-box { /* Renamed ID */
            position: fixed;
            inset: 0;
            background-color: rgba(0, 0, 0, 0.5);
            display: none;
            justify-content: center;
            align-items: center;
            z-index: 100;
        }
        .sign-in-modal-content { /* Renamed class */
            background-color: white;
            padding: 24px;
            border-radius: 12px;
            box-shadow: var(--shadow-light);
            max-width: 380px;
            width: 100%;
            text-align: center;
        }
        .sign-in-modal-content h3 {
            font-size: 1.25rem;
            font-weight: 700;
            margin-bottom: 12px;
            color: var(--text-dark);
        }
        .sign-in-modal-content p {
            color: var(--text-muted);
            margin-bottom: 16px;
        }
        .sign-in-modal-content button {
            background-color: var(--primary-blue);
            color: white;
            padding: 8px 24px;
            border-radius: 8px;
            border: none;
            cursor: pointer;
            transition: background-color 0.2s;
        }
        .sign-in-modal-content button:hover {
            background-color: #3a5cda;
        }

        /* Specific disclaimer text and link styling */
        .sign-in-disclaimer-text {
            text-align: center;
            font-size: 0.75rem;
            color: #9ca3af;
            margin-top: 48px;
        }
        .sign-in-disclaimer-link {
            color: var(--primary-blue);
            text-decoration: underline;
        }


/* Sign-up */

.sign-up-card-container {
    background-color: white;
    max-width: 1200px;
    width: 100%;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1),
                0 10px 10px -5px rgba(0,0,0,0.04);
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    margin: 40px auto;
}

/* Desktop Layout */
@media (min-width: 1024px) {
    .sign-up-card-container {
        flex-direction: row;
        min-height: 600px; /* flexible height */
    }
}

/* LEFT PANEL */
.sign-up-login-panel {
    padding: 30px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (min-width: 1024px) {
    .sign-up-login-panel {
        width: 55%;
        padding: 40px;
    }
}

.sign-up-form-content {
    width: 100%;
    max-width: 520px;
}

/* HEADER SMALLER */
.sign-up-header h1 {
    font-size: 25px;
    font-weight: 700;
    margin-bottom: 4px;
    line-height: 1;
}

.sign-up-header p {
    font-size: 0.85rem;
    color: #6b7280;
}

/* INPUT */
.sign-up-input-group {
    margin-bottom: 12px; /* compact spacing */
}

.sign-up-custom-input {
    width: 100%;
    padding: 5px 14px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    font-size: 0.85rem;
}

.sign-up-custom-input:focus {
    border-color: #4c6fff;
    box-shadow: 0 0 0 2px rgba(76,111,255,0.2);
    outline: none;
}

/* PASSWORD TOGGLE */
.sign-up-password-toggle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 16px;
}

/* BUTTON */
.sign-up-login-button {
    width: 100%;
    background: linear-gradient(90deg, #F28F32 0%, #a73729 100%);
    color: white;
    padding: 10px 0;
    border-radius: 10px;
    border: none;
    font-weight: 600;
    font-size: 0.9rem;
    margin-top: 8px;
}

.sign-up-login-button:hover {
    background: linear-gradient(90deg, #a73729 0%, #F28F32 100%);
}

/* IMAGE PANEL */
.sign-up-graphic-panel {
    background-image: url(../images/login.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 250px;
}

@media (min-width: 1024px) {
    .sign-up-graphic-panel {
        width: 50%;
        height: auto;
    }
}
.sign-up-password-toggle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 18px;
    color: #6b7280;
}

.sign-up-password-toggle:hover {
    color: #000;
}

.sign-up-checkbox-group input{
  margin-top: 8px;
}
.sign-up-disclaimer-link{
  color: #007bff!important;
}

.sign-up-disclaimer-link:hover{
  color: #ba4d2b!important;
  text-decoration: underline;
}

.auth-bottom-text {
    margin-top: 15px;
    text-align: center;
    font-size: 14px;
    color: #666;
}

.auth-signup-link{
    color: #007bff;
    font-weight: 600;
    text-decoration: none;
}

.auth-signup-link:hover,.sign-in-forgot-link:hover {
    text-decoration: underline;
    color: #ba4d2b!important;
}


/* Divider */
.sign-in-divider {
    text-align: center;
    margin: 20px 0;
    position: relative;
}

.sign-in-divider span {
    background: #fff;
    padding: 0 15px;
    font-size: 13px;
    color: #888;
    position: relative;
    z-index: 1;
}

.sign-in-divider::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    background: #ddd;
    top: 50%;
    left: 0;
    z-index: 0;
}

/* Social Buttons Container */
.sign-in-social-buttons {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-bottom: 15px;
}

/* Common Button Style */
.social-login-btn {
    flex: 1;
    max-width: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 15px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 500;
    font-size: 14px;
    transition: 0.3s ease;
    border: 1px solid #d0d5dd;
    background: #f8fafc;
    color: #344054;
}

/* Icons */
.social-login-btn img {
    width: 20px;
    height: 20px;
}

/* Hover Effects */
.social-login-btn:hover {
    background: #eef2f6;
    transform: translateY(-2px);
}

/* Google specific */
.google-btn {
    border-color: #d0d5dd;
}

/* Facebook specific */
.facebook-btn {
    border-color: #d0d5dd;
}


/* Sign-up */

.sign-up-card-container {
    background-color: white;
    max-width: 1200px;
    width: 100%;
    box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1),
                0 10px 10px -5px rgba(0,0,0,0.04);
    border-radius: 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    margin: 40px auto;
}

/* Desktop Layout */
@media (min-width: 1024px) {
    .sign-up-card-container {
        flex-direction: row;
        min-height: 600px; /* flexible height */
    }
}

/* LEFT PANEL */
.sign-up-login-panel {
    padding: 30px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (min-width: 1024px) {
    .sign-up-login-panel {
        width: 55%;
        padding: 40px;
    }
}

.sign-up-form-content {
    width: 100%;
    max-width: 520px;
}

/* HEADER SMALLER */
.sign-up-header h1 {
    font-size: 25px;
    font-weight: 700;
    margin-bottom: 4px;
    line-height: 1;
}

.sign-up-header p {
    font-size: 0.85rem;
    color: #6b7280;
}

/* INPUT */
.sign-up-input-group {
    margin-bottom: 1px; /* compact spacing */
}

.sign-up-custom-input {
    width: 100%;
    padding: 5px 14px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    font-size: 0.85rem;
}

.sign-up-custom-input:focus {
    border-color: #4c6fff;
    box-shadow: 0 0 0 2px rgba(76,111,255,0.2);
    outline: none;
}

/* PASSWORD TOGGLE */
.sign-up-password-toggle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 16px;
}

/* BUTTON */
.sign-up-login-button {
    width: 100%;
    background: linear-gradient(90deg, #F28F32 0%, #a73729 100%);
    color: white;
    padding: 10px 0;
    border-radius: 10px;
    border: none;
    font-weight: 600;
    font-size: 0.9rem;
    margin-top: 8px;
}

.sign-up-login-button:hover {
    background: linear-gradient(90deg, #a73729 0%, #F28F32 100%);
}

/* IMAGE PANEL */
.sign-up-graphic-panel {
    background-image: url(../images/login.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 250px;
}

@media (min-width: 1024px) {
    .sign-up-graphic-panel {
        width: 50%;
        height: auto;
    }
}
.sign-up-password-toggle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    font-size: 18px;
    color: #6b7280;
}

.sign-up-password-toggle:hover {
    color: #000;
}

.sign-up-checkbox-group input{
  margin-top: 8px;
}
.sign-up-disclaimer-link{
  color: #007bff!important;
}

.sign-up-disclaimer-link:hover{
  color: #ba4d2b!important;
  text-decoration: underline;
}

.auth-bottom-text {
    margin-top: 15px;
    text-align: center;
    font-size: 14px;
    color: #666;
}

.auth-signup-link{
    color: #007bff;
    font-weight: 600;
    text-decoration: none;
}

.auth-signup-link:hover,.sign-in-forgot-link:hover {
    text-decoration: underline;
    color: #ba4d2b!important;
}


/* Divider */
.sign-in-divider {
    text-align: center;
    margin: 20px 0;
    position: relative;
}

.sign-in-divider span {
    background: #fff;
    padding: 0 15px;
    font-size: 13px;
    color: #888;
    position: relative;
    z-index: 1;
}

.sign-in-divider::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    background: #ddd;
    top: 50%;
    left: 0;
    z-index: 0;
}

/* Social Buttons Container */
.sign-in-social-buttons {
    display: flex;
    gap: 15px;
    justify-content: center;
    margin-bottom: 15px;
}

/* Common Button Style */
.social-login-btn {
    flex: 1;
    max-width: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px 15px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 500;
    font-size: 14px;
    transition: 0.3s ease;
    border: 1px solid #d0d5dd;
    background: #f8fafc;
    color: #344054;
}

/* Icons */
.social-login-btn img {
    width: 20px;
    height: 20px;
}

/* Hover Effects */
.social-login-btn:hover {
    background: #eef2f6;
    transform: translateY(-2px);
}

/* Google specific */
.google-btn {
    border-color: #d0d5dd;
}

/* Facebook specific */
.facebook-btn {
    border-color: #d0d5dd;
}


        /* pricing */


                .pricing-section {
            /* padding: 60px 0; */
             padding: 25px 0;
        }

        .section-title {
            margin-bottom: 20px;
        }

        /* Nav Tabs */
        .nav-tabs {
            justify-content: center;
            border: none;
            margin-bottom: 30px;
        }

        .nav-tabs .nav-link {
color: #000;
  font-weight: 600;
  background: transparent;
  border-bottom: 3px solid transparent;
  transition: 0.3s;
  font-size: 18px;
  border-top: var(--bs-nav-tabs-border-width) solid transparent!important;
   border-left: var(--bs-nav-tabs-border-width) solid transparent!important;
    border-right: var(--bs-nav-tabs-border-width) solid transparent!important;
        }

        .nav-tabs .nav-link.active {
            color: #e27c30;
            border-color: #e27c30;
            font-weight: 600;
        }
        #websites{
          position: relative;
        }
.tab-pane h6{
  font-size: 16px;
  margin-bottom: 2px;
  color: #141414;
}
 /* Custom Toggle Container (kept same placement) */
.toggle-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    position: absolute;
    right: 8px;
    top: -52px;
}



/* Sliding capsule */
.toggle-slider {
position: absolute;
  top: 2px;
  left: 2px;
  width: calc(50% - 5px);
  height: 34px;
  border-radius: 20px;
  background: #e27c30;
  transition: 0.3s ease-in-out;
  z-index: 1;
}

        /* Pricing Cards */

        .pricing-item {
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
            text-align: center;
            padding: 30px 25px;
            transition: all 0.3s ease;
            position: relative;
            height: 100%;
        }

        .pricing-item:hover {
            transform: translateY(-5px);
        }

        .pricing-header h4 {
            font-size: 25px;
            margin-bottom: 10px;
            color: #333;
        }

        .pricing-header h2 {
            font-size: 28px;
            color: #000;

        }

        .pricing-header .duration {


            color: #666;
            font-size: 16px;
            margin-top: 28px;
            margin-top: 11px;
            margin-left: 6px;
            font-weight: 700;
            font-size: 16px;
            margin-top: 28px;
            margin-top: 11px;
            margin-left: 6px;
            font-weight: 700;
        }

        .pricing-header p {
            font-size: 14px;
            color: #777;
            margin-bottom: 15px;
        }

        .pricing-body {
            height: 200px;
            /* adjust height as needed */
            overflow-y: auto;
            /* enables vertical scroll */
            overflow-x: hidden;
            scrollbar-width: thin;
            /* for Firefox */
            scrollbar-color: #b0b0b0 #f5f5f5;
            margin-top: 20px;
            margin-top: 20px;
            /* scrollbar thumb & track colors */
        }
        .pricing-body .check-list.style-one li:not(:last-child) {
  margin-bottom: 18px;
  line-height: 17px;}
        .pricing-body .check-list.style-one li:not(:last-child) {
  margin-bottom: 18px;
  line-height: 17px;}
        /* For Chrome, Edge, and Safari */
        .pricing-body::-webkit-scrollbar {
            width: 2px;
            /* thin scrollbar */
        }

        .pricing-body::-webkit-scrollbar-track {
            background: #f5f5f5;
            /* track color */
            border-radius: 10px;
        }

        .pricing-body::-webkit-scrollbar-thumb {
            background-color: #b0b0b0;
            /* scrollbar color */
            border-radius: 10px;
        }

        .pricing-body::-webkit-scrollbar-thumb:hover {
            background-color: #888;
            /* darker on hover */
        }

        .pricing-body ul {
            list-style: none;
            padding: 0;
            margin: 20px 0;
            text-align: left;
        }

        .pricing-body ul li {
            margin: 8px 0;
            font-size: 14px;
            display: flex;
            align-items: center;
        }

        .pricing-body ul i {
            color: #198754;
            margin-right: 10px;
        }

        .pricing-footer .theme-btn {
            background: #e27c30;
            color: #fff;
            border-radius: 25px;
            padding: 4px 28px;
            text-decoration: none;
            display: inline-block;
            transition: 0.3s;
            font-size: 14px;
            font-weight: 500;
        }
          .pricing-footer{
          margin-top: 51px;
          }
          .pricing-footer{
          margin-top: 51px;
          }
        .pricing-footer .theme-btn:hover {
            background: #a83829;
            color: #fff;
        }

        #pricingTabs {
            border-bottom: 1px solid #f2f2f2;
            justify-content: left;
        }

        .pricing-item.best-seller-plan {
            background: linear-gradient(90deg, #F28F32 0%, #a73729 100%);
            color: #fff;
        }



        .best-seller-plan .pricing-header h4,
        .best-seller-plan .pricing-header h2,
        .best-seller-plan .pricing-header .duration,
        .best-seller-plan .pricing-header p,
        .best-seller-plan .check-list.style-one li i {
            color: #fff;
        }

        .best-seller-plan .pricing-footer .theme-btn {
            background: #fff;
            color: #e27c30;

        }

        .best-seller-plan .pricing-footer .theme-btn:hover {
            background: #e27c30;
            color: #fff;
        }

        .best-seller {
            position: absolute;
            top: -12px;
            left: 50%;
            transform: translateX(-50%);
            background: #ebecec;
            color: #e27c30;
            font-size: 14px;
            padding: 0px 31px;
            border-radius: 20px;
            font-weight: 600;

        }

        .pricing-container {
            /* background-color: #fff; */
            padding: 18px;
            padding-bottom: 18px;
            border-radius: 20px;
            /* padding: 6px 20px 49px 20px; */
            padding: 6px 0px 49px 0px;
            /* border: 1px solid #eee; */
        }

        @media (max-width: 767px) {
            .pricing-header h2 {
                font-size: 24px;
            }

            .pricing-item {
                padding: 25px 20px;
            }
        }

.save-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #f7b500;
    color: #000;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 6px;
    margin-bottom: 10px;
}

.save-badge .old-small {
    text-decoration: line-through;
    font-weight: 500;
    opacity: 0.7;
}

/* Price Layout */
.price-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin-top: 10px;
}

.currency {
    font-size: 20px;
    font-weight: 600;
    margin-top: 8px;
    margin-right: 2px;
}

.main-price {
    font-size: 48px;
    font-weight: 700;
    line-height: 1;
}

  /* Save Row */
.save-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-bottom: 10px;
}

/* Yellow Save Badge */
.save-badge {
background: #d7d7d7;
  color: #000;
  font-size: 12px;
  font-weight: 600;
  padding: 1px 10px;
  border-radius: 24px;
}


/* Old Price */
.old-price {
font-size: 13px;
  color: #b9b9b9;
  text-decoration: line-through;
  font-weight: 500;
  margin-bottom: 8px;;
}

/* Price Layout */
.price-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin-top: 5px;
}

/* Raised ₹ */
.currency {
    font-size: 26px;
    font-weight: 700;
    margin-top: 10px;
    margin-right: 2px;
}

/* Big Price */
.main-price {
    font-size: 37px;
    font-weight: 700;
    line-height: 1;
    color: #000;

}
.best-seller-plan .main-price{
  color: #fff!important;
}

/* Term Text */
.term-text {
    font-size: 16px;
    font-weight: 500;
}

@media (max-width: 768px) {

    .main-price {
        font-size: 44px;
    }

    .currency {
        font-size: 20px;
        margin-top: 6px;
    }

    .duration {
        font-size: 16px;
        margin-top: 18px;
    }

    .term-text {
        font-size: 14px;
    }
}
.save-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #f7b500;
    color: #000;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 6px;
    margin-bottom: 10px;
}

.save-badge .old-small {
    text-decoration: line-through;
    font-weight: 500;
    opacity: 0.7;
}

/* Price Layout */
.price-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin-top: 10px;
}

.currency {
    font-size: 20px;
    font-weight: 600;
    margin-top: 8px;
    margin-right: 2px;
}

.main-price {
    font-size: 48px;
    font-weight: 700;
    line-height: 1;
}

  /* Save Row */
.save-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-bottom: 10px;
}

/* Yellow Save Badge */
.save-badge {
background: #d7d7d7;
  color: #000;
  font-size: 12px;
  font-weight: 600;
  padding: 1px 10px;
  border-radius: 24px;
}


/* Old Price */
.old-price {
font-size: 13px;
  color: #b9b9b9;
  text-decoration: line-through;
  font-weight: 500;
  margin-bottom: 8px;;
}

/* Price Layout */
.price-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin-top: 5px;
}

/* Raised ₹ */
.currency {
    font-size: 26px;
    font-weight: 700;
    margin-top: 10px;
    margin-right: 2px;
}

/* Big Price */
.main-price {
    font-size: 37px;
    font-weight: 700;
    line-height: 1;
    color: #000;

}
.best-seller-plan .main-price{
  color: #fff!important;
}

/* Term Text */
.term-text {
    font-size: 16px;
    font-weight: 500;
}

@media (max-width: 768px) {

    .main-price {
        font-size: 44px;
    }

    .currency {
        font-size: 20px;
        margin-top: 6px;
    }

    .duration {
        font-size: 16px;
        margin-top: 18px;
    }

    .term-text {
        font-size: 14px;
    }
}
/* multi-location business section */

        .section-header {
            color: #707070; /* --text-light */
            font-weight: 500;
            margin-bottom: 4rem;
        }

        /* --- Custom Icon Box Styling (Setup, Manage, Grow) --- */
        .icon-box {
            display: flex;
            align-items: center;
            height: 120px; /* Standardize height for alignment */
            position: relative;
        }

        .main-step-card {
            display: flex;
            align-items: center;
            gap: 15px;
            padding: 15px 25px;
            border-radius: 12px;
            background-color: #fff;
            box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
            width: 100%;
        }

        .main-icon-circle {
            width: 70px;
            height: 70px;
            border-radius: 50%;
            display: flex;
            justify-content: center;
            align-items: center;
            font-size: 28px;
        }

        .main-step-title {
            font-size: 1.2rem;
            font-weight: 600;
            color: #3c3c3c; /* --text-dark */
        }

        /* Color variants */
        .setup .main-icon-circle { background-color: #e0f4dd; color: #6bbd61; } /* --green-bg, --green-icon */
        .manage .main-icon-circle { background-color: #fef0e3; color: #f7b247; } /* --orange-bg, --orange-icon */
        .grow .main-icon-circle { background-color: #e6ebf5; color: #5e7fb0; } /* --blue-bg, --blue-icon */

        /* --- vistaar Main Block --- */
        .vistaar-block {
        padding: 20px;
          width: 150px;
          height: 150px;
          border-radius: 16px;
          background-color: #fff;
          box-shadow: 0 6px 15px rgba(0, 0, 0, 0.08);
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: center;
          text-align: center;
          position: relative;
          z-index: 10;
          bottom: 27px;
          right: 19px;
        }

        .vistaar-icon {
            font-size: 30px;
            color: #f7b247; /* --vistaar-pin-color */
            margin-bottom: 5px;
        }

        .vistaar-text {
            font-size: 1.2rem;
            font-weight: 700;
            color: #6c6c6c; /* --vistaar-text-color */
        }

        /* --- Feature List Styling --- */
        .feature-list {
            list-style: none;
            padding: 0;
            margin: 0;
        }

        .feature-item {
            display: flex;
            align-items: center;
            padding: 12px 15px;
            margin-bottom: 8px;
            border-radius: 8px;
            background-color: #fff;
            border: 1px solid #f1f1f1; /* --feature-border */
            font-size: 0.95rem;
            color: #6c6c6c; /* --feature-text */
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
            /* Added margin-left to create space for the vertical line and dot */
            position: relative;
        }

        .feature-icon {
            margin-right: 10px;
            font-size: 18px;
        }

        /* Feature Icon Colors based on row */
        .list-green .feature-icon { color: #6bbd61; } /* --green-icon */
        .list-orange .feature-icon { color: #f7b247; } /* --orange-icon */
        .list-blue .feature-icon { color: #5e7fb0; } /* --blue-icon */

        /* ==========================================================
           COMPLEX LINE DRAWING LOGIC (DESKTOP FIRST)
           ========================================================== */

        .flow-container {
            display: flex;
            justify-content: center;
            align-items: flex-start;
            gap: 5rem;
            position: relative;
            max-width: 1200px;
            margin: 0 auto;
        }

        .center-column {
            display: flex;
            flex-direction: column;
            align-items: center;
            padding-top: 0;
        }

        .steps-column {
            flex-grow: 1;
            display: flex;
            flex-direction: column;
            gap: 20px;
            padding-top: 50px;
        }

        .features-column {
            flex-grow: 1;
            padding-top: 50px;
            display: flex;
            flex-direction: column;
            gap: 70px; /* Space between feature lists */
        }

        .step-wrapper {
            position: relative;
            height: 120px;
            display: flex;
            align-items: center;
        }

        /* Line break dots (Default mobile/base - disabled) */
        .step-wrapper .line-dot {
            content: none;
        }


        /* Adjust layout to draw the main "Y" shape on desktop */
        @media (min-width: 992px) {
            .flow-container {
                display: grid;
                grid-template-columns: 1fr 1fr 1fr; /* Retain 3 columns */
                gap: 40px; /* Gap between columns */
                align-items: flex-start;
                padding: 50px 0;
            }

            .center-column {
                grid-column: 1 / 2;
                grid-row: 1 / 4;
                justify-content: center;
                align-items: center;
                height: 520px;
            }

            .steps-column {
                grid-column: 2 / 3;
                grid-row: 1 / 4;
                padding-top: 0;
                gap: 65px;
                position: relative;
            }

            .features-column {
                grid-column: 3 / 4;
                grid-row: 1 / 4;
                padding-top: 0;
                gap: 70px;
            }

            /* vistaar to Steps (Left Y-branch) */

            /* Vertical line stemming from vistaar for the "Y" - Centered in Col 1 */
            .center-column::before {
          content: '';
              position: absolute;
              left: 22.6%;
              transform: translate(-50%, -50%);
             top: 43%;
              height: 334px;
              width: 1px;
              border-left: 2px dashed #d1d1d1;
              z-index: 5;
            }

            /* Horizontal Lines from vistaar (Col 1) to Steps (Col 2) */
            .steps-column .step-wrapper::before {
                content: '';
                position: absolute;
                left: -140px;
                width: 140px;
                height: 1px;
                border-top: 2px dashed #d1d1d1;
                z-index: 5;
            }

            /* Dots on the line from vistaar */
            .steps-column .line-dot.dot-left {
                width: 10px;
                height: 10px;
                background-color: #d1d1d1;
                border-radius: 50%;
                position: absolute;
                left: -145px; /* Position dot on the line */
                z-index: 10;
                content: ''; /* Re-enable content */
            }

            /* --- NEW LOGIC: Steps (Col 2) to Features (Col 3) --- */

            /* Remove the old vertical line in the steps column gap */
            .steps-column::before {
                content: none;
            }

            /* Remove unused dot-right and horizontal line from steps */
            .step-wrapper::after,
            .step-wrapper .line-dot.dot-right {
                content: none;
            }

            /* 1. Add Vertical Spine to each Feature List Container (Feature list wrapper) */
            .feature-list-wrapper {
            position: relative;
                padding-left: 25px;
                margin-top: -61px;
            }
            .feature-list-wrapper::before {
                content: '';
                position: absolute;
                left: 0px;
                top: 40px;
                height: 61%;
                width: 1px;
                border-left: 2px dashed #d1d1d1;
                z-index: 5;
            }

            /* 2. Horizontal line from Step Card (Col 2) to Feature List Spine (Col 3) */
            /* We use step-wrapper::after here to link the center of the step card to the spine */
            .step-wrapper::after {
              content: '';
              position: absolute;
              right: -40px;
              width: 39px;
              height: 1px;
              border-top: 2px dashed #d1d1d1;
              z-index: 5;
            }

            /* 3. Horizontal lines from Spine to each Feature Item (LI) */
            .feature-item {
                margin-left: 0; /* Clear previous margin */
            }

            .feature-item::before {
                content: '';
                position: absolute;
                left: -25px; /* Connects from LI edge back to the spine at -20px */
                top: 50%;
                transform: translateY(-50%);
                width: 25px; /* Length to reach the vertical line */
                height: 1px;
                border-top: 2px dashed #d1d1d1;
                z-index: 5;
            }

            /* 4. Dot where horizontal and vertical lines meet */
            .feature-item::after {
                content: '';
                width: 10px;
                height: 10px;
                background-color: #d1d1d1;
                border-radius: 50%;
                position: absolute;
                left: -30px; /* 5px past the line start to center the dot */
                top: 50%;
                transform: translateY(-50%);
                z-index: 10;
            }

            /* Hide the lines used for mobile view */
            .mobile-lines {
                display: none;
            }
        }

        /* ==========================================================
           MOBILE/TABLET VIEW (Vertical Stacking and Lines)
           ========================================================== */
        @media (max-width: 991.98px) {
            .flow-container {
                display: block;
                padding: 20px;
            }

            .center-column, .steps-column, .features-column {
                padding-top: 0;
                align-items: stretch;
                margin-bottom: 20px;
            }

            .vistaar-block {
                margin: 20px auto 40px auto;
            }

            .step-wrapper {
                height: auto;
                margin-bottom: 30px;
                flex-direction: column;
                gap: 15px;
                padding-left: 30px; /* Add padding for vertical line */
            }

            .main-step-card {
                width: 100%;
                flex-shrink: 0;
            }

            .features-list-group {
                margin-bottom: 40px;
            }

            /* Ensure desktop line elements are removed in mobile view */
            .step-wrapper::before,
            .step-wrapper::after,
            .step-wrapper .line-dot {
                content: none !important;
            }

            /* Mobile Vertical Flow Lines (Left side of steps) */
            .steps-column {
                position: relative;
                padding-left: 15px;
            }

            .steps-column::before {
                content: '';
                position: absolute;
                left: 0;
                top: 0;
                height: 100%;
                width: 1px;
                border-left: 2px dashed #d1d1d1; /* --line-color */
            }

            /* Horizontal line from vertical line to step card */
            .step-wrapper .mobile-line-h {
                position: absolute;
                top: 50px; /* Aligns with the center of the step card */
                left: 0;
                width: 30px;
                height: 1px;
                border-top: 2px dashed #d1d1d1; /* --line-color */
                z-index: 5;
            }

            .step-wrapper .mobile-dot {
                width: 8px;
                height: 8px;
                background-color: #d1d1d1; /* --line-color */
                border-radius: 50%;
                position: absolute;
                top: 46px;
                left: -4px;
                z-index: 10;
            }

            /* Mobile Vertical Lines between step and features (already works for LI connections) */
            .feature-list-wrapper {
                position: relative;
                padding-left: 15px;
            }
            .feature-list-wrapper::before {
                content: '';
                position: absolute;
                left: 0;
                top: 0;
                height: 100%;
                width: 1px;
                border-left: 2px dashed #d1d1d1; /* --line-color */
            }

            .feature-list-wrapper .feature-item {
                position: relative;
                margin-left: 15px;
            }

            /* Horizontal line from features vertical line to feature item */
            .feature-item::before {
                content: '';
                position: absolute;
                left: -15px;
                top: 50%;
                transform: translateY(-50%);
                width: 15px;
                height: 1px;
                border-top: 2px dashed #d1d1d1; /* --line-color */
            }

            .feature-item::after {
                content: '';
                width: 8px;
                height: 8px;
                background-color: #d1d1d1; /* --line-color */
                border-radius: 50%;
                position: absolute;
                left: -19px;
                top: 50%;
                transform: translateY(-50%);
                z-index: 10;
            }
        }





        /* themes */

.website-theme-section-tabs {
      display: flex;
      gap: 25px;
      justify-content: flex-start;
      border-bottom: none;
      margin-bottom: 2rem;
    }

    .website-theme-section-tab {
      color: #cfd8dc;
      background: transparent;
      font-weight: 500;
      font-size: 0.9rem;
      cursor: pointer;
      border: none;
      border-bottom: 2px solid transparent;
      padding-bottom: 6px;
      transition: all 0.3s ease;
    }

    .website-theme-section-tab.active {
      color: #fff;
      border-bottom: 2px solid #e68131;
    }

    /* --- Section --- */
    .website-theme-section {
      padding: 80px 0;
      background: #883d0f;
    }

    .website-theme-section-content {
      display: none;
      transition: opacity 0.3s ease;
    }

    .website-theme-section-content.active {
      display: flex;
      opacity: 1;
    }

    .website-theme-section-text h6 {
      text-transform: uppercase;
      font-size: 0.9rem;
      color: #e68131;
      margin-bottom: 10px;
    }

    .website-theme-section-text h2 {
      font-weight: 700;
      font-size: 1.6rem;
      margin-bottom: 20px;
      text-transform: uppercase;
      line-height: 1.4;
      color: #fff;
    }

    .website-theme-section-text p {
      font-size: 0.95rem;
      line-height: 1.6;
      color: #bcd2d1;
      margin-bottom: 30px;
      max-width: 500px;
    }

    .website-theme-section-btn {
      border: 1px solid #fff;
      color: #ea8531;
      background-color: #fff;
      padding: 5px 25px;
      border-radius: 5px;
      transition: all 0.3s ease;
      font-weight: bold;
    }

    .website-theme-section-btn:hover {
background-color: #ea8531;
  color: #fff;
    }

    .website-theme-section-note {
      margin-top: 40px;
      font-size: 0.8rem;
      color: #aac8c7;
    }

    /* --- Image --- */
    .website-theme-section-images img {
height: 500px;
      border-radius: 8px;
    }

    /* Responsive */
    @media (max-width: 992px) {
      .website-theme-section-content {
        flex-direction: column;
        text-align: center;
      }
      .website-theme-section-text p {
        margin: 0 auto 30px;
      }
    }

    /* portfolio filter */

    :root {
  --grid-min-height: 700px; /* adjust this to match exact visual height you want so background curve remains stable */
}

/* ---- category card/accordion (unified box) ---- */
.category-wrapper {
  margin-bottom: 32px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid #e6e6e6;
  overflow: hidden; /* keeps it single card */
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}
.category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 18px;
}
.visible-categories {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.category {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  border-radius: 10px;
  padding: 8px 14px;
  border: 1px solid transparent;
  cursor: pointer;
  font-size: 14px;
  color: #555;
  border: 1px solid #f2f2f2;
}
.category.active { border-color: #f47b3c;; color: #be6332;; background: #f0f8ff; }
.category:hover { color: #f47b3c;; }

/* control button at right */
.toggle-btn {
  background: transparent;
  border: 0;
  padding: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: static;
}
.toggle-arrow { font-size: 16px; color: #666; transition: transform .3s ease; }
.toggle-btn[aria-expanded="true"] .toggle-arrow { transform: rotate(180deg); }

.hidden-categories {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s cubic-bezier(.2,.9,.3,1), padding .3s;
  padding: 0 18px;
  /* border-top: 1px solid rgba(0,0,0,0.03);  */
}
.hidden-categories.open {
  max-height: 220px;
  padding: 12px 18px 18px 18px;
}
.hidden-categories .category-list { display:flex; gap:12px; flex-wrap:wrap; }

.image-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 8px;
  min-height: var(--grid-min-height);
}
.grid-item { display: none; }
.grid-item img { width: 100%; display: block; border-radius: 10px; }

.item-overlay { position: relative; top:-73px; }

/* ---- pagination ---- */
.pagination { display:flex; align-items:center; justify-content:center; gap:12px; margin-top:28px; }
.page-btn {
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 999px;
  width: 38px;
  height: 38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.page-btn:disabled { opacity:.45; cursor:not-allowed; }

/* page number circles */
.page-numbers { display:flex; gap:8px; align-items:center; }
.page-number {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border: 1px solid #ddd;
  cursor: pointer;
  background: #fff;
}
.page-number.active { background: #e27c30; color: #fff; border-color:#fff; }

/* Responsive tweaks (optional) */
@media (max-width: 992px) {
  .image-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
  .visible-categories { gap:8px; }
  .image-grid { grid-template-columns: 1fr; }
}


/* Newsletter Section */
.newsletter-section {
  /* background: linear-gradient(135deg, #0f172a, #1e293b); */
  /* background: linear-gradient(135deg, #0a0e1a, #ba4d2b); */
  background: #ccc;
  color: #ffffff;
  border-radius: 20px;
  margin: 20px 20px;
}

/* Badge */
.newsletter-badge {
display: inline-block;
  padding: 6px 14px;
  font-size: 22px;
  font-weight: 600;
  color: #d56d2e;
  border-radius: 50px;
}

/* Title */
.newsletter-title {
  font-size: 36px;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
}

/* Text */
.newsletter-text {
  font-size: 16px;
  color: #fff;
  max-width: 600px;
  margin: 0 auto;
}

/* Form */
.newsletter-form .input-group {
  max-width: 520px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 50px;
  padding: 6px;
}

/* Input */
.newsletter-input {
  border: none;
  border-radius: 50px;
  padding-left: 20px;
  font-size: 15px;
}

.newsletter-input:focus {
  box-shadow: none;
}

/* Button */
.newsletter-btn {
background: linear-gradient(90deg, #F28F32 0%, #a73729 100%);
  color: #fff;
  font-weight: 600;
  border-radius: 50px;
  padding: 10px 26px;
  transition: all 0.3s ease;
}

.newsletter-btn:hover {
background: linear-gradient(90deg,#a73729 0%, #F28F32  100%);

  transform: translateY(-1px);
}

/* Note */
.newsletter-note {
  font-size: 13px;
  color: #94a3b8;
}

/* Responsive */
@media (max-width: 576px) {
  .newsletter-title {
    font-size: 28px;
  }
}

.terms-conditions h4{
  font-size: 18px;
}
.footer-social-widget{
  margin-top: 18px;
}
.copyright-text{
  text-align: center;
}


.website-type-switch {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 40px 0 20px;
    background: #f3f3f3;
    padding: 6px;
    border-radius: 12px;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

.type-tab {
    padding: 14px 30px;
    font-weight: 600;
    font-size: 18px;
    border-radius: 10px;
    cursor: pointer;
    transition: 0.3s ease;
    color: #333;
    background: transparent;
}

.type-tab.active {
    background: #ffffff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    color: #F28F32;
}

.type-tab:hover {
    color: #F28F32;
}







.website-type-switch {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 50px;
    background: #e9e9e9;
    padding: 0;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;
    border-radius: 15px 15px 0 0;
}
.type-tab {
    padding: 14px 30px;
    font-weight: 600;
    font-size: 22px;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    color: #333;
    background: transparent;
    white-space: nowrap; /* prevent wrapping */
}

.type-tab.active {
    background: #f8f9fa;
    color: #eb7012;
    border-radius: 15px 15px 0 0;
}

.type-tab:hover {
    color: #F28F32;
}

@media (max-width: 768px) {

    .website-type-switch {
        width: 90%;
        border-radius: 12px 12px 0 0;
    }

    .type-tab {
        flex: 1;               /* equal width */
        text-align: center;
        font-size: 16px;       /* reduce font */
        padding: 12px 10px;    /* reduce padding */
    }

}

.mobile-text {
    display: none;
}

@media (max-width: 768px) {
    .desktop-text {
        display: none;
    }
    .mobile-text {
        display: inline;
        font-size:21px;
    }
}

.template-image-wrap a{
  width: 100%;

}
.template-image-wrap{
height: 400px;
}







/* Profile Dropdown Container */


.profile-dropdown {
    position: relative;
    display: inline-block;
}

/* Toggle */
.nav-profile-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    text-decoration: none;
}

/* Profile Image */
.profile-img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

/* Name */
.profile-name {
    font-weight: 600;
    color: #333;
    display: flex;
    align-items: center;
    gap: 5px;
}

/* Arrow */
.arrow-down {
    border: solid #333;
    border-width: 0 2px 2px 0;
    display: inline-block;
    padding: 3px;
    transform: rotate(45deg);
    margin-top: -2px;
}

/* Dropdown Menu */
.profile-menu {
    position: absolute;
    top: 55px;
    right: 0;
    width: 220px;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 5px 25px rgba(0,0,0,0.08);
    padding: 10px 0;
    display: none;
    z-index: 999;
}
.profile-menu .dropdown-item {
border-bottom: 1px solid #f2f2f2;
}
/* Show Class */
.profile-menu.show {
    display: block;
}

/* Header */
.profile-header {
    padding: 12px 20px;
    border-bottom: 1px solid #eee;
}

.profile-header h6 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
}

/* Items */
.dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    text-decoration: none;
    color: #333;
    font-size: 14px;
    transition: 0.2s;
}

.dropdown-item:hover {
    background: #f5f5f5;
}

/* Responsive */
@media (max-width: 768px) {
    .profile-name {
        display: none;
    }
}


.sign-in-form-content {
    position: relative;
}

/* Desktop */
.sign-in-logo {
    position: absolute;
    top: 20px;
    left: 20px;
}

.sign-in-logo img {
    height: 40px;
}

/* Mobile */
@media (max-width: 768px) {
    .sign-up-login-panel{
      display: flex;
      flex-direction: column;
    }
    .sign-in-login-panel {
    padding: 20px;}

    .sign-in-logo {
        position: relative!important;
        top:10px;
        left: 0;
        width: 100%;
        text-align: center;
        margin: 0 0 15px 0;
    }

    .sign-in-logo img {
        height: 50px;
    }

    .sign-in-header {
        text-align: center;
    }
}