img {
  height: auto;
}

.fixed-btn {
  position: fixed;
  bottom: 0;
  width: 100%;
  text-align: center;
  background: linear-gradient(
    135deg,
    rgba(106, 195, 239, 1) 0%,
    rgba(27, 137, 201, 1) 100%
  );
  border: 2px solid #fff;
  border-radius: 1rem 1rem 0 0;
  padding: 1.5rem 3rem 1.5rem 1.5rem;
  transition: opacity 0.3s;
  z-index: 1;
}
@media (min-width: 769px) {
  .fixed-btn {
    width: auto;
    border-radius: 1rem;
    right: 1.5rem;
    bottom: 1.5rem;
  }
}

.fixed-btn span {
  position: relative;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}

.fixed-btn span:after {
  content: "";
  height: 13px;
  width: 8px;
  display: inline-block;
  background-image: url(https://cdn.sitekitt.com/san-shin-kizai/img/arr-w.svg);
  background-size: cover;
  position: absolute;
  right: -1.5rem;
  margin-top: 0.2rem;
}

.fixed-btn:hover span:after {
  animation: icon-x 0.3s;
}

.wrap-bim-sanshin .wrap-md {
  max-width: 600px;
  margin-inline: auto;
}

.wrap-bim-sanshin .wrap-lg {
  max-width: 800px;
  margin-inline: auto;
}

.wrap-bim-sanshin .wrap-xl {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: 0;
}

.wrap-bim-sanshin {
  color: #292929;
  line-height: 1.8;
  margin-inline: 3rem;
}

.headline-image {
  width: 18rem;
  text-align: center;
  margin-inline: auto;
}

@media (min-width: 769px) {
  .headline-image {
    width: 20.4rem;
  }
}

@media (min-width: 769px) {
  .flow {
    display: block;
    margin-top: 4.5rem;
    max-width: 1260px;
    margin-inline: auto;
  }
}

.headline-text {
  color: #005ca2;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  margin-top: 3rem;
}
@media (min-width: 769px) {
  .headline-text {
    font-size: 2.1rem;
    margin-top: 4rem;
  }
}

.headline-text + p {
  font-size: 1.2rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}
@media (min-width: 769px) {
  .headline-text + p {
    font-size: 1.4rem;
  }
}

.nav_merit {
  display: grid;
  gap: 5rem;
  margin-top: 2.5rem;
}
@media (min-width: 769px) {
  .nav_merit {
    max-width: 1260px;
    margin-inline: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 2rem;
    row-gap: 5rem;
  }
}
@media (min-width: 1101px) {
  .nav_merit {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.nav_merit a {
  position: relative;
  min-height: 2.5rem;
  height: 100%;
  display: block;
  border-radius: 2rem;
  border: 3px solid #f0f0f0;
  text-align: center;
  padding: 5rem 2rem;
  display: grid;
  place-content: center;
}

.nav_merit a:hover .arrow {
  animation: icon-y 0.3s;
}

.nav_merit a .icon-number {
  background: #0092d8;
  border-radius: 50%;
  width: 4.9rem;
  height: 4.9rem;
  position: absolute;
  top: -2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: grid;
  place-content: center;
}

.nav_merit a .icon-number span {
  color: #fff;
  font-size: 2.6rem;
  font-weight: bold;
  line-height: 1;
}

.nav_merit a h3 {
  color: #005ca2;
  font-size: 1.8rem;
}

.nav_merit a p {
  color: #595757;
  font-size: 1.4rem;
  margin-top: 0.5rem;
}

.nav_merit a .arrow {
  width: 2rem;
  position: absolute;
  left: 50%;
  bottom: 2rem;
  transform: translateX(-50%);
}

.wrap-merit-flow.first {
  margin-top: 6rem;
  border-top: 1px solid #dddddd;
}
@media (min-width: 769px) {
  .wrap-merit-flow.first {
    margin-top: 10rem;
  }
}

.wrap-merit-flow {
  padding-top: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #dddddd;
}
@media (min-width: 769px) {
  .wrap-merit-flow {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}

.wrap-merit-flow p {
  font-size: 1.4rem;
  margin-top: 2rem;
}
@media (min-width: 769px) {
  .wrap-merit-flow p {
    font-size: 1.6rem;
  }
}

.number-title {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  color: #0092d8;
  font-size: 2.1rem;
  font-weight: bold;
  line-height: 1.2;
}

.number-title span {
  display: grid;
  place-content: center;
  width: 4.9rem;
  height: 4.9rem;
  color: #fff;
  font-size: 2.6rem;
  border-radius: 50%;
  background: #0092d8;
  flex-shrink: 0;
}

.merit-flow__content {
  margin-top: 3.5rem;
}

.merit-flow__content figcaption {
  color: #595757;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}

.merit-flow__content figure {
  position: relative;
}

.merit-flow__content figure:not(:last-child):after {
  content: "";
  background: url(https://cdn.sitekitt.com/san-shin-kizai/bim-sanshin/img/arr-flow.svg)
    no-repeat center / contain;
  width: 5.3rem;
  height: 3.9rem;
  position: absolute;
}
@media (max-width: 768px) {
  .merit-flow__content figure:not(:last-child):after {
    left: 50%;
    bottom: -5.5rem;
    transform: translateX(-50%);
  }
}
@media (min-width: 769px) {
  .merit-flow__content figure:not(:last-child):after {
    top: 55%;
    right: -6rem;
    transform: translateY(-50%) rotate(-90deg);
  }
}

.merit-flow__content figure img {
  margin-top: 1.5rem;
  border: 1px solid #dddddd;
  border-radius: 1rem;
}

.wrap-merit-flow .merit-flow__item img {
  margin-top: 2rem;
}
@media (min-width: 769px) {
  .wrap-merit-flow .merit-flow__item img {
    margin-top: 4rem;
  }
}

.wrap-outlook {
  font-size: 1.4rem;
  margin-top: 4rem;
}
@media (min-width: 769px) {
  .wrap-outlook {
    font-size: 1.6rem;
    margin-top: 6.5rem;
  }
}

.outlook-content {
  margin-top: 3rem;
  gap: 3rem;
}
@media (min-width: 769px) {
  .outlook-content {
    gap: 5rem;
  }
}

.outlook-content + p,
.outlook-content + p + p {
  margin-top: 2rem;
}
@media (min-width: 769px) {
  .outlook-content + p,
  .outlook-content + p + p {
    margin-top: 3rem;
  }
}

.headline-bg-grade {
  background: url(https://cdn.sitekitt.com/san-shin-kizai/bim-sanshin/img/bg-gradation.jpg)
    no-repeat center / cover;
  color: #595757;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  border-radius: 1.5rem;
  padding: 1rem;
}
@media (min-width: 769px) {
  .headline-bg-grade {
    font-size: 2.6rem;
  }
}

.headline-bg-grade + p {
  margin-top: 1.5rem;
}
@media (min-width: 769px) {
  .headline-bg-grade + p {
    margin-top: 4rem;
  }
}

h3.headline-border {
  position: relative;
  color: #595757;
  font-size: 1.8rem;
  font-weight: bold;
  padding-left: 1.8rem;
}

h3.headline-border:before {
  background-color: #005ca2;
  border-radius: 4px;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 8px;
}

h3.headline-border + p {
  margin-top: 1.5rem;
}

.text-right {
  text-align: right;
}

.br-sp {
  display: block;
}
@media (min-width: 769px) {
  .br-sp {
    display: none;
  }
}

.grid {
  display: grid;
}

.gap-sm {
  gap: 2rem;
}

.gap-md {
  gap: 3.5rem;
}

.gap-xl {
  gap: 7rem;
}

@media (min-width: 769px) {
  .row-2-pc {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .row-3-pc {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .row-12-pc {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }
  .col-5-pc {
    grid-column: span 5 / span 5;
  }
  .col-7-pc {
    grid-column: span 7 / span 7;
  }
  .gap-xl-pc {
    gap: 7rem;
  }
}

@media (max-width: 768px) {
  .br-pc {
    display: none;
  }
}

.hr-sp {
  border: none;
  background: #dddddd;
  margin-top: 3rem;
  margin-bottom: 3rem;
}
@media (min-width: 769px) {
  .hr-sp {
    display: none;
  }
}

@keyframes icon-x {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
  40% {
    opacity: 0;
  }
  49.9% {
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
    opacity: 0;
  }
  50% {
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes icon-y {
  0% {
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    opacity: 1;
  }
  40% {
    opacity: 0;
  }
  49.9% {
    -webkit-transform: translate(-50%, 50%);
    transform: translate(-50%, 50%);
    opacity: 0;
  }
  50% {
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    opacity: 1;
  }
}
