.back_home_hiro {
  background: #fff;
  background-image: url(../img/home/pattern.svg);
  background-repeat: no-repeat;
  background-position: bottom;
  background-size: auto;
}

.home_oping_tit_hiro {
  color: #818692;
  text-align: center;
  font-size: 24px;
  font-style: normal;
  font-weight: 500;
  line-height: 36px;
}
.home_oping_min_tit_hiro {
  color: #191e24;
  text-align: center;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  background: linear-gradient(251deg, #191e24 35.67%, #298dff 74.92%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.home_oping_min_tit_hiro b {
  text-align: center;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  line-height: 85px;
}

.btn_blue_hiro {
  border-radius: 8px;
  border: 1px solid #7ebaff;
  background: #298dff;
  display: flex;
  height: 48px;
  padding: 0px 16px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  color: #fff;
  text-align: center;

  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px;
  text-decoration: none;
}

.btn_gry_hiro {
  border-radius: 8px;
  border: 1px solid #d4e5ff;
  background: linear-gradient(180deg, #eef6ff 0%, #e2efff 100%);
  display: flex;
  height: 48px;
  padding: 0px 16px;
  justify-content: center;
  align-items: center;
  gap: 8px;

  color: #298dff;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px;
  text-decoration: none;
}
.itme_hiro {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
.itme_hiro p {
  color: #3b4554;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 26px;
}

.home_st_price {
  color: #818692;
  text-align: right;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
}
.home_st_price_st {
  color: #191e24;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 26px; /* 162.5% */
}
.home_st_price_st b {
  color: #191e24;
  font-size: 32px;
  font-style: normal;
  font-weight: 700;
  line-height: 40px;
  text-transform: capitalize;
}
.home_st_price_st_month {
  color: #3b4554;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
}
.prices_info_hiro {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
}
.txt_home_tit_h {
  color: #fff;
  text-align: center;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 40px;
  letter-spacing: -0.56px;
}
.st_section_2 {
  border-radius: 24px;
  background: #0d0f12;
  padding: 72px;
}
.txt_home_tit_p {
  color: #dcdfe5;
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px;
}
.card_hosts_infos {
  border-radius: 24px;
  border: 4px solid #252932;
  background: linear-gradient(
    93deg,
    #0d0f12 6.56%,
    #21262c 41.13%,
    #0f1114 92.66%
  );
}
.card_hosts_infos_tit {
  color: #fff;
  text-align: right;
  font-feature-settings: "salt" on;
  font-size: 21px;
  font-style: normal;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: -0.42px;
  text-transform: capitalize;
}
.card_hosts_infos_items {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.card_hosts_infos_items p {
  padding-top: 8px;
  color: #dcdfe5;
  text-align: right;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
.pad-24 {
  padding: 32px;
  padding-bottom: 0;
}
.step_mb {
  display: none;
}

/* Container for the icon and the tooltip */
.tooltip-container {
  position: relative;
  display: inline-block;
  /* Or 'block', depending on your layout */
  cursor: pointer;
}

/* The element that contains the icon and text */
.itme_hiro {
  display: flex;
  align-items: center;
  gap: 8px;
  /* Adds some space between the text and the icon */
}

/* The tooltip itself */
.tooltip-text {
  visibility: hidden;
  width: 280px;
  padding: 10px;
  position: absolute;
  z-index: 1;
  top: 150%;
  /* Position the tooltip above the icon */
  left: 50%;
  margin-left: -140px;
  /* Use half of the width to center the tooltip */
  opacity: 0;
  transition: opacity 0.3s;

  color: #fff;
  text-align: center;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: 20px;
  border-radius: 6px;
  border: 1px solid #45464f;
  background: #0a0c0f;
}

/* The little arrow pointing down */
.tooltip-text::after {
  content: "";
  position: absolute;
  bottom: 100%;
  /* At the bottom of the tooltip */
  left: 50%;
  margin-left: -8px;
  border-width: 8px;
  border-style: solid;
  border-color: transparent transparent #212121 transparent;
}

/* Show the tooltip when hovering over the container */
.tooltip-container:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}

@media only screen and (max-width: 768px) {
  .step_ds {
    display: none;
  }
  .step_mb {
    display: block;
  }
  .itme_hiro {
    display: none;
  }
  .home_oping_tit_hiro {
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
  }
  .home_oping_min_tit_hiro {
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
  }
  .st_section_2 {
    padding: 72px 12px;
  }
  .pd_0_mb {
    padding: 0;
  }
  .pad-24 {
    padding: 32px 12px;
  }
}

/* =================== */
/* =================== */
/* oping */
/* home */
/* =================== */
/* =================== */

.back__dark {
  background: #111418;
}
.btn_blue {
  border-radius: 9px;
  background: #298dff;
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  height: 48px;
  line-height: 26px;

  display: flex;
  padding: 0px 23px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  text-decoration: none;
  border: none;
}
.btn_gry {
  border-radius: 9px;
  background: #29313d;
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px;
  height: 48px;

  display: flex;
  padding: 8px 23px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  text-decoration: none;
  border: none;
}

.home_oping_tit {
  color: #fff;
  text-align: center;
  font-family: Dana;
  font-size: 44px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.home_oping_min_tit {
  color: #babfc9;
  text-align: center;
  font-size: 24px;
  font-style: normal;
  font-weight: 500;
  line-height: 36px; /* 150% */
}
.home_mid_txt {
  color: #fff;
  text-align: right;
  font-size: 32px;
  font-style: normal;
  font-weight: 500;
  line-height: 48px;
  letter-spacing: 0.9px;
}
.d-ruby {
  display: ruby;
}
.tit_light_mid {
  color: #191e24;
  text-align: center;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 40px;
  letter-spacing: -0.56px;
}
.txt_light_mid {
  color: #3b4554;
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px; /* 155.556% */
}

/* crd__home */
.crd__home {
  border-radius: 16px;
  background: #f7f7f8;
  height: 100%;
}
.img_crd__home img {
  width: 100%;
}

.crd__home_body {
  padding: 24px 32px;
}
.tit_crd__home {
  color: #191e24;
  text-align: right;
  font-size: 21px;
  font-style: normal;
  font-weight: 600;
  line-height: 30px;
  text-transform: capitalize;
}
.txt_crd__home {
  color: #3b4554;
  text-align: right;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
}

/* card_home_plan */
.card_home_plan {
  border-radius: 14px;
  border: 1px solid #f0f2f4;
  background: #fff;
  padding: 24px;
  position: relative;
  height: 100%;
}
.icon_card_home_plan {
}
.tit_card_home_plan {
  color: #191e24;
  text-align: right;
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 28px;
}
.dec_card_home_plan {
  color: #3b4554;
  text-align: right;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
}
.mutetxt_card_home_plan {
  color: #818692;
  text-align: right;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
}
.price_card_home_plan {
  color: #191e24;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 40px;
  text-transform: capitalize;
}
.pricetxt_card_home_plan {
  color: #191e24;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 26px;
}
.pricetxt_card_home_plan span {
  color: #3b4554;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
}

.pin_card_home_plan {
}
.pin_tl {
  position: absolute;
  left: 12px;
  top: 0px;
}
.pin_tr {
  position: absolute;
  right: 12px;
  top: 0px;
}
.pin_br {
  position: absolute;
  right: 12px;
  bottom: 0px;
}
.pin_bl {
  position: absolute;
  left: 12px;
  bottom: 0px;
}

.tit_light_home {
  color: #fff;
  text-align: center;
  font-size: 28px;
  font-style: normal;
  font-weight: 800;
  line-height: 32px;
}
.txt_light_home {
  color: #babfc9;
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px;
}
.pic_home_mt {
  margin-top: -10rem;
}

.crd_dark_home {
  border-radius: 16px;
  border: 1px solid #2e3642;
  background: #13161b;
  height: 100%;
}
.img_crd_dark_home img {
  width: 100%;
}
.body_crd_dark_home {
  padding: 16px 24px 28px 24px;
}
.tit_crd_dark_home {
  color: #fff;
  text-align: right;
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 28px;
}
.txt_crd_dark_home {
  color: #babfc9;
  text-align: right;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
}
.pstm_tit {
  color: #15181e;

  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 40px;
  letter-spacing: -0.56px;
}
.pstm_txt {
  color: #3b4554;
  text-align: right;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px;
}
.pstm_itmes h4 {
  color: #191e24;
  text-align: right;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 26px;
}
.pstm_itmes p {
  color: #3b4554;
  text-align: right;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 26px;
}

.start_oping_tit {
  color: #191e24;
  text-align: center;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.btn_home_oping {
  border-radius: 9px;
  background: #298dff;
  display: flex;
  padding: 0px 23px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  height: 48px;
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px;
  text-decoration: none;
}
.show_more_home {
  color: #0f73e6;
  text-align: center;
  text-decoration: none;

  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 26px;
}
.start_oping_txt {
  color: #3b4554;
  text-align: center;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  line-height: 28px;
}
.icons_hiro {
  position: absolute;
  width: 52px;
  height: 52px;
}
.home_icons_set01 {
  right: 0;
  top: 15%;
  width: 58px;
  height: 58px;
}
.home_icons_set02 {
  right: 15%;
  top: 25%;
  width: 60px;
  height: 60px;
}
.home_icons_set03 {
  right: 5%;
  top: 40%;
  width: 54px;
  height: 54px;
}
.home_icons_set04 {
  left: 0%;
  top: 15%;
  width: 56px;
  height: 56px;
}
.home_icons_set05 {
  left: 20%;
  top: 30%;
}
.home_icons_set06 {
  left: 5%;
  top: 37%;
  width: 60px;
  height: 60px;
}

/* Define the floating animation */
@keyframes float {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}

/* Apply the animation to each icon set */
.home_icons_set01,
.home_icons_set02,
.home_icons_set03,
.home_icons_set04,
.home_icons_set05,
.home_icons_set06 {
  animation: float 3s ease-in-out infinite;
}

/* Define the floating animation */
@keyframes float {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}

/* Apply unique animations to each icon set */
.home_icons_set01 {
  animation: float 3s ease-in-out infinite;
}

.home_icons_set02 {
  animation: float 4s ease-in-out infinite;
}

.home_icons_set03 {
  animation: float 2.5s ease-in-out infinite;
}

.home_icons_set04 {
  animation: float 3.5s ease-in-out infinite;
}

.home_icons_set05 {
  animation: float 2.8s ease-in-out infinite;
}

.home_icons_set06 {
  animation: float 3.2s ease-in-out infinite;
}

.typewriter-line {
  overflow: hidden;
  /* border-right: 3px solid;  */
  opacity: 0; /* Start with opacity 0 */
  transition: opacity 0.5s ease-in; /* Fade-in effect */
}

@keyframes blink-caret {
  50% {
    border-color: transparent;
  }
}

.started_anm .dur01 {
  opacity: 0;
  animation-name: dur;
  animation-duration: 4s;
  animation-delay: 2s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards; /* Retain opacity: 1 after animation */
}

.started_anm .dur02 {
  opacity: 0;
  animation-name: dur;
  animation-duration: 4s;
  animation-delay: 4s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards; /* Retain opacity: 1 after animation */
}

.started_anm .dur03 {
  opacity: 0;
  animation-name: dur;
  animation-duration: 4s;
  animation-delay: 11s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards; /* Retain opacity: 1 after animation */
}

@keyframes dur {
  100% {
    opacity: 1;
  }
}

@media only screen and (max-width: 1200px) {
  .pic_home_mt {
    margin-top: 0rem;
  }
  .mt_mob_off {
    margin-top: 0 !important;
  }
}

@media only screen and (max-width: 768px) {
  /*Tablets [601px -> 1200px]*/
  .icons_hiro {
    display: none;
  }
  .home_mid_txt {
    font-size: 18px;
  }
}
