:root {
  --primary: #4043ff;
  --secondary: #090e18;
  --white: #fff;
}

body {
  font-family: "Montserrat", sans-serif;
}

.btn {
  text-transform: capitalize;
  font-size: 0.875rem;
  font-weight: 600;
}

.btn-primary {
  background-color: var(--primary);
  border-color: var(--primary);
}

.btn-primary:hover {
  background-color: #0e1b26;
  border-color: #0e1b26;
}

.btn-primary:focus,
.btn-outline-primary:focus {
  box-shadow: 0 0 0 0.25rem rgba(14, 27, 38, 0.5);
}

.btn-outline-primary {
  color: var(--primary);
  border-color: var(--primary);
}

.btn-outline-primary:hover {
  background-color: var(--primary);
  color: var(--white);
  border-color: var(--primary);
}

.form-control {
  background-color: #f4f6f8;
  border: unset;
  height: 60px;
}

form .btn-primary {
  height: 100%;
  width: 170px;
  height: 60px;
}

.section-name {
  color: var(--primary);
  font-size: 0.875rem;
  letter-spacing: 8px;
  margin-bottom: 41px;
}

.section-title {
  color: var(--secondary);
  max-width: 500px;
  margin-bottom: 90px;
}

.bg-primary {
  background-color: var(--primary) !important;
}

.bg-secondary {
  background-color: var(--secondary) !important;
}

.text-primary {
  color: var(--primary) !important;
}

.text-secondary {
  color: var(--secondary) !important;
}

/* navbar */
.navbar {
  min-height: 80px;
}

.navbar .navbar-brand:hover {
  color: unset !important;
}

.navbar .navbar-brand img {
  width: 32px;
}

.navbar .nav-link {
  font-size: 0.875rem;
}

.navbar .navbar-toggler svg {
  width: 24px;
  color: var(--primary);
}

.navbar .dropdown-menu {
  background-color: #0e1b26;
  position: relative;
}

.navbar .dropdown-menu::before {
  content: "";
  background-color: #0e1b26;
  height: 16px;
  width: 16px;
  display: block;
  position: absolute;
  top: -11px;
  left: 16%;
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}

.navbar .dropdown-menu .dropdown-item {
  color: #bdc3ca;
}

.navbar .dropdown-menu .dropdown-item:hover {
  background-color: var(--primary);
  color: var(--white);
}

@media screen and (max-width: 768px) {
  .navbar .show-on-md {
    display: unset !important;
  }

  .navbar .dropdown-menu::before {
    left: 3%;
  }
}

/* Hero section */
.hero-section {
  min-height: 85vh;
}

.hero-section .display-5 {
  margin-bottom: 34px;
}

.hero-section .lead {
  color: #576078;
  margin-bottom: 59px;
}

.hero-section .btn-primary {
  min-width: 170px;
}

/* Shape between hero and featurs sections */
.hero-featurs-shape {
  min-height: 600px;
}

.hero-featurs-shape .colors-bg .features {
  background-color: #e4e7ea;
}

.hero-featurs-shape .shapes-bg {
  z-index: 1;
}

.hero-featurs-shape .shapes-bg .blue {
  left: 16%;
}

@media screen and (max-width: 992px) {
  .hero-featurs-shape .shapes-bg .blue {
    left: 2%;
  }
}

@media screen and (max-width: 530px) {
  .hero-featurs-shape .shapes-bg .blue {
    display: none;
  }
}

.hero-featurs-shape .shapes-bg .green {
  right: 13%;
}

@media screen and (max-width: 992px) {
  .hero-featurs-shape .shapes-bg .green {
    right: 2%;
  }
}

@media screen and (max-width: 530px) {
  .hero-featurs-shape .shapes-bg .green {
    display: none;
  }
}

.hero-featurs-shape .shapes-bg .dots {
  display: grid;
  grid-template-columns: repeat(3, 8px);
  grid-template-rows: repeat(3, 8px);
  gap: 6px;
}

.hero-featurs-shape .shapes-bg .dots__dot {
  background-color: #565f77;
}

.hero-featurs-shape .shapes-bg .dots.top {
  right: 19%;
  top: 9%;
}

@media screen and (max-width: 992px) {
  .hero-featurs-shape .shapes-bg .dots.top {
    right: 9%;
  }
}

.hero-featurs-shape .shapes-bg .dots.bottom {
  left: 34%;
  bottom: 7%;
}

@media screen and (max-width: 992px) {
  .hero-featurs-shape .shapes-bg .dots.bottom {
    left: 27%;
  }
}

.hero-featurs-shape .shapes-bg .dots.bottom .dots__dot {
  background-color: #bdc3ca;
}

.hero-featurs-shape .shapes-bg .browser {
  height: 470px;
  width: 770px;
  background-color: #f4f6f8;
  border-radius: 6px;
  z-index: 2;
}

.hero-featurs-shape .shapes-bg .browser .bar {
  background-color: #e4e7ea;
  height: 40px;
}

.hero-featurs-shape .shapes-bg .browser .bar .icons {
  gap: 3.33px;
  margin-left: 16px;
}

.hero-featurs-shape .shapes-bg .browser .bar .icons .icon {
  background-color: #bdc3ca;
  width: 10px;
  height: 10px;
}

.hero-featurs-shape .shapes-bg .browser .server {
  border-radius: 6px;
  right: 3%;
  bottom: 5%;
  top: 13%;
  left: 25%;
  gap: 5%;
}

@media screen and (max-width: 530px) {
  .hero-featurs-shape .shapes-bg .browser .server {
    left: 3%;
  }
}

.hero-featurs-shape .shapes-bg .browser .server .element {
  height: 54px;
  width: 92%;
  background-color: #e4e7ea;
  border-radius: 4px;
  padding: 0 18px;
}

@media screen and (max-width: 400px) {
  .hero-featurs-shape .shapes-bg .browser .server .element {
    padding: 0 4px;
  }
}

.hero-featurs-shape .shapes-bg .browser .server .element .profile .image {
  height: 24px;
  width: 24px;
  background-color: var(--white);
}

.hero-featurs-shape .shapes-bg .browser .server .element .profile .name-bio {
  gap: 4px;
}

.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element
  .profile
  .name-bio
  .name {
  background-color: #bdc3ca;
  width: 80px;
  height: 10px;
}

@media screen and (max-width: 400px) {
  .hero-featurs-shape
    .shapes-bg
    .browser
    .server
    .element
    .profile
    .name-bio
    .name {
    width: 50px;
  }
}

.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element
  .profile
  .name-bio
  .bio {
  background-color: #bdc3ca;
  width: 138px;
  height: 10px;
}

@media screen and (max-width: 400px) {
  .hero-featurs-shape
    .shapes-bg
    .browser
    .server
    .element
    .profile
    .name-bio
    .bio {
    width: 108px;
  }
}

.hero-featurs-shape .shapes-bg .browser .server .element .state {
  gap: 15px;
}

@media screen and (max-width: 300px) {
  .hero-featurs-shape .shapes-bg .browser .server .element .state {
    display: none !important;
  }
}

.hero-featurs-shape .shapes-bg .browser .server .element .state .off {
  background-color: #bdc3ca;
  width: 24px;
  height: 24px;
  border-radius: 4px;
}

.hero-featurs-shape .shapes-bg .browser .server .element .state .on {
  background-color: var(--primary);
  width: 24px;
  height: 24px;
  border-radius: 4px;
}

.hero-featurs-shape .shapes-bg .browser .server .element.element--active,
.hero-featurs-shape .shapes-bg .browser .server .element:hover {
  background-color: var(--white);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.18);
  transform: translateX(-10%);
}

@media screen and (max-width: 530px) {
  .hero-featurs-shape .shapes-bg .browser .server .element.element--active,
  .hero-featurs-shape .shapes-bg .browser .server .element:hover {
    transform: translateX(0);
  }
}

.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element.element--active
  .profile
  .image,
.hero-featurs-shape .shapes-bg .browser .server .element:hover .profile .image {
  background-color: #576078;
}

.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element.element--active
  .profile
  .name-bio
  .name,
.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element:hover
  .profile
  .name-bio
  .name {
  background-color: #576078;
}

.hero-featurs-shape
  .shapes-bg
  .browser
  .server
  .element.element--active
  .state
  .on,
.hero-featurs-shape .shapes-bg .browser .server .element:hover .state .on {
  background-color: #3be4ce;
  width: 60px;
}

@media screen and (max-width: 400px) {
  .hero-featurs-shape
    .shapes-bg
    .browser
    .server
    .element.element--active
    .state
    .on,
  .hero-featurs-shape .shapes-bg .browser .server .element:hover .state .on {
    width: 24px;
  }
}

.hero-featurs-shape .shapes-bg .browser .user {
  right: 3%;
  bottom: 14%;
  top: 22%;
  gap: 5%;
  width: 25%;
}

@media screen and (max-width: 530px) {
  .hero-featurs-shape .shapes-bg .browser .user {
    display: none !important;
  }
}

.hero-featurs-shape .shapes-bg .browser .user .profile .image {
  background-color: #576078;
  height: 60px;
  width: 60px;
  margin-bottom: 20px;
}

.hero-featurs-shape .shapes-bg .browser .user .profile .name {
  background-color: #576078;
  border-radius: 10px;
  width: 80px;
  height: 10px;
  margin-bottom: 10px;
}

.hero-featurs-shape .shapes-bg .browser .user .profile .bio {
  background-color: #bdc3ca;
  border-radius: 10px;
  width: 47px;
  height: 10px;
  margin-top: -16px;
}

.hero-featurs-shape .shapes-bg .browser .user .taps {
  gap: 10px;
}

.hero-featurs-shape .shapes-bg .browser .user .taps .tab {
  height: 20px;
  width: 20px;
  background-color: #bdc3ca;
}

/* Featurs section */
.featurs-section {
  background-color: #e4e7ea;
  padding-top: 200px;
  padding-bottom: 200px;
}

.featurs-section .feature-cards .row {
  gap: 30px;
}

.featurs-section .feature-cards .feature-card {
  min-width: 370px;
  padding: 60px 30px;
  transition: all 0.15s ease-in-out;
}

@media screen and (max-width: 576px) {
  .featurs-section .feature-cards .feature-card {
    min-width: 100%;
  }
}

.featurs-section .feature-cards .card.feature-card:hover {
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  transform: translateY(-15px);
}

.featurs-section .feature-cards .feature-card .icon {
  height: 70px;
  width: 70px;
  border: 1px solid #bdc3ca;
  margin-bottom: 38px !important;
}

.featurs-section .feature-cards .feature-card:hover .icon {
  background-color: #3be4ce;
  border-color: #3be4ce;
}

.featurs-section .feature-cards .feature-card .icon svg {
  width: 30px;
  color: #576078;
}

.featurs-section .feature-cards .feature-card:hover .icon svg {
  width: 30px;
  color: #fff;
}

.featurs-section .feature-cards .feature-card .card-title {
  margin-bottom: 12px;
}

.featurs-section .feature-cards .feature-card .card-text {
  margin-bottom: 24px;
  color: #576078;
}

.featurs-section .feature-cards .feature-card:hover .btn-outline-primary {
  background-color: var(--primary);
  color: var(--white);
  border-color: var(--primary);
}

/* Descover new */
.descover-new {
  padding: 46px 0;
}

.descover-new .bg .shared-with-featurs {
  background-color: #e4e7ea;
}

.descover-new .frame {
  right: 11%;
  top: -2%;
}

.descover-new .content {
  min-height: 320px;
  width: 770px;
}

@media screen and (max-width: 800px) {
  .descover-new .content {
    width: 100%;
  }
}

.descover-new .content .section-title {
  max-width: 500px;
  margin-bottom: 35px;
}

.descover-new .content form .btn-primary {
  border-color: var(--secondary);
}

@media screen and (max-width: 768px) {
  .descover-new .content form .btn-primary {
    width: 100%;
  }
}

.descover-new .content form .btn-primary:hover {
  background-color: var(--white) !important;
  border-color: var(--white) !important;
  color: var(--secondary) !important;
}

.descover-new .content form .form-control {
  background-color: rgb(9, 14, 24, 0.2);
}

.descover-new .content form .form-control::placeholder {
  color: #bdc3ca;
}

/* Reviews section */
.reviews {
  padding: 154px 0;
}

.reviews .review {
  background-color: #222730;
  padding: 34px 30px;
  width: 370px;
  transition: all 0.15s ease-in-out;
}

@media screen and (max-width: 576px) {
  .reviews .review {
    width: 100%;
  }
}

.reviews .review:hover {
  background-color: var(--white);
  transform: translateY(-15px);
}

.reviews .carousel-item {
  padding-bottom: 100px;
  padding-top: 24px;
}

.reviews .carousel-item .row {
  gap: 30px;
}

.reviews .rate {
  margin-bottom: 41px;
}

.reviews .review .rate svg {
  color: #576078;
  width: 16px;
  margin-right: 9px;
}

.reviews .review:hover .rate svg {
  color: var(--primary);
}

.reviews .rate .number {
  color: #576078;
  font-size: 0.875rem;
}

.reviews .review:hover .rate .number {
  color: var(--primary);
}

.reviews .comment {
  margin-bottom: 24px;
}

.reviews .review:hover .comment {
  color: #576078 !important;
}

.reviews .profile .image {
  width: 60px;
  height: 60px;
  margin-right: 15px;
}

.reviews .profile .image img {
  object-fit: cover;
}

.reviews .profile .name-work .name {
  font-size: 0.875rem;
  margin-bottom: 2px;
}

.reviews .review:hover .profile .name-work .name {
  color: var(--secondary) !important;
}

.reviews .profile .name-work .work {
  color: #576078;
  font-size: 0.875rem;
}

.reviews .carousel-indicators [data-bs-target] {
  height: 10px;
  width: 10px;
  border-radius: 50%;
  margin-right: 5px;
  margin-left: 5px;
  background-color: transparent;
  border: 2px solid #555e76;
  box-sizing: border-box;
  opacity: unset;
}

.reviews .carousel-indicators .active {
  background-color: #3be4ce;
  border: unset;
}

/* Pricing section */
.pricing {
  padding: 150px 0;
}

@media screen and (max-width: 480px) {
  .pricing {
    overflow: hidden;
  }
}

.pricing .container-xxl {
  min-height: 1000px;
}

.pricing .nav {
  background-color: #e4e7ea;
  width: 270px;
  height: 60px;
  border-radius: 4px;
  margin-bottom: 90px;
}

.pricing .nav-pills .nav-link {
  height: 50px;
  width: 127px;
  color: #576078;
  font-size: 0.875rem;
}

.pricing .nav-pills .nav-link.active {
  background-color: var(--primary);
  color: var(--white);
  box-shadow: 0 0.125rem 0.25rem rgb(0, 0, 0, 0.08);
}

.pricing .tab-pane .row {
  gap: 30px;
}

.pricing .card {
  width: 370px;
  transition: all 0.15s ease-in-out;
  z-index: 3;
}

@media screen and (max-width: 480px) {
  .pricing .card {
    overflow: hidden;
  }
}

@media screen and (max-width: 890px) {
  .pricing .card {
    overflow: hidden;
  }
}

@media screen and (max-width: 769px) {
  .pricing .card {
    overflow: unset;
  }
}

@media screen and (max-width: 400px) {
  .pricing .card {
    width: 100%;
  }
}

.pricing .card .card-header {
  height: 103px;
  background-color: #e4e7ea;
  font-size: 0.875rem;
  border-radius: 14px 14px 0 0;
}

.pricing .card:hover .card-header {
  background-color: #3538d1;
  color: var(--white) !important;
}

.pricing .card .card-header .price {
  font-size: 2.25rem;
}

.pricing .card .card-body {
  padding-top: 30px;
  padding-bottom: 30px;
  border: 2px solid #e4e7ea;
  border-radius: 0 0 14px 14px;
}

.pricing .card:hover .card-body {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  border-radius: 0;
}

.pricing .card .card-body .card-title {
  font-size: 1.125rem;
  margin: 35px 0;
}

.pricing .card:hover .card-body .card-title {
  color: var(--white) !important;
}

.pricing .card .card-body .list-group .list-group-item {
  background-color: unset;
  border: unset;
  font-size: 0.875rem;
  gap: 18px;
  color: #576078;
  padding: 0;
}

.pricing .card:hover .card-body .list-group .list-group-item {
  color: var(--white);
}

.pricing .card .card-body .list-group .list-group-item svg {
  width: 14px;
  color: #3be4ce;
}

.pricing .card .card-body .list-group .list-group-item.off-package svg {
  color: var(--secondary);
}

.pricing .card .card-body.buttons-body {
  display: none;
  gap: 15px;
  border-radius: 0 0 14px 14px;
}

.pricing .card:hover .card-body.buttons-body {
  display: flex;
}

.pricing .card .card-body .btn-primary {
  height: 40px;
  width: 117px;
  border-color: var(--secondary);
}

.pricing .card .card-body .card-link {
  font-size: 0.875rem;
  font-weight: 600;
}

.pricing .dots {
  display: grid;
  grid-template-columns: repeat(5, 10px);
  grid-template-rows: repeat(5, 10px);
  gap: 10px;
  z-index: -1;
}

.pricing .dots.left-card {
  left: -13%;
  bottom: -5%;
}

.pricing .dots.right-card {
  right: -13%;
  top: 46px;
  opacity: 0.4;
}

.pricing .dots .dots__dot {
  background-color: #576078;
}

/* Subscribe section */
.subscribe {
  padding: 0 16px;
}

.subscribe .bg .with-footer {
  background-color: #f4f6f8;
}

.subscribe .container-xxl {
  border-radius: 14px;
  padding: 112px 60px;
}

@media screen and (max-width: 480px) {
  .subscribe .container-xxl {
    padding-left: 8px;
    padding-right: 8px;
  }
}

.subscribe .container-xxl .section-title {
  margin-bottom: 0;
  max-width: unset;
}

@media screen and (max-width: 1200px) {
  .subscribe .container-xxl .section-title {
    margin-bottom: 64px;
  }
}

.subscribe input,
.subscribe input:focus {
  background-color: #21262f;
  color: var(--white);
}

.subscribe form {
  gap: 32px;
}

/* footer */
footer {
  background-color: #f4f6f8;
  padding: 150px 0 !important;
}

footer .container-xxl {
  gap: 32px;
}

@media screen and (max-width: 711px) {
  footer .container-xxl {
    justify-content: center !important;
  }
}

footer .links {
  gap: 32px;
}

@media screen and (max-width: 365px) {
  footer .links {
    gap: 24px;
  }
}

@media screen and (max-width: 300px) {
  footer .links {
    gap: 16px;
  }
}

footer .social-links {
  gap: 10px;
}

footer .social-links .nav-item {
  width: 20px;
  height: 20px;
  background-color: #bdc3ca;
  padding: 4px;
  border-radius: 50%;
}

footer .social-links .nav-item:hover {
  background-color: var(--primary);
}

footer .social-links a {
  padding: 0;
}

footer .social-links a svg {
  width: 100%;
  height: 100%;
  fill: #f4f6f8;
}
