@charset "UTF-8";

.circle-layout {
  margin: auto;
  width:  16rem;
}

.circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  width: 8rem;
  height: 8rem;
}

.flow {
  position: relative;
  color: #fff;
  background-color: #ababab;
  flex: 0 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0;
  height: 1.75rem;
}
.flow.white {
  color: #595757;
  background-color: #fff;
  border: 1px solid #ababab;
}
.flow.transparent {
  background-color: transparent;
}
.flow-division {
  display: flex;
  justify-content: space-between;
  flex: 0 1 auto;
}
.flow-division .flow {
  flex: 0 1 40%;
}
.space {
  flex: 1 1 auto;
  height: 2.5rem;
}

.flow-line {
  position: relative;
  z-index: 2;
}
.house_building {
	padding-top: 100px;
}
#flow {
  padding-top: 140px!important;
  margin-top:-100px;
}
#land-search {
  padding-top: 100px!important;
  margin-top: -100px;
}

/* sp only */
@media (max-width: 576px) {
  .come-true03 {
    position: relative;
    flex-grow: 1.75;
  }
  .come-true03:before {
    content: "";
    position: absolute;
    width: 100%;
    padding-top: 64%;
  }
  .come-true03 > .img-fluid {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .flow-arrow {
    position: absolute;
    z-index: 1;
    top: 2.25rem;
    bottom: 4.0rem;
    left: 50%;
    width: 3.5rem;
    background-color: #e9e4da;
    transform: translateX(-50%);
  }
  .flow-arrow:before {
    content: "";
    display: inline-block;
    background-color: transparent;
    border-top: 1.75rem solid #fff;
    border-left: 1.75rem solid transparent;
    border-right: 1.75rem solid transparent;
  }
  .flow-arrow:after {
    content: "";
    display: inline-block;
    background-color: transparent;
    border-top: 2.5rem solid #e9e4da;
    border-left: 2.5rem solid transparent;
    border-right: 2.5rem solid transparent;
    position: absolute;
    bottom: -2.5rem;
    left: 50%;
    transform: translateX(-50%);
  }
}

/* pc only */
@media (min-width: 576px) {
  .container-half {
    margin-right: 33.333333%;
  }

  .flow-arrow {
    position: absolute;
    z-index: 1;
    top: 1.65rem;
    left: 3.5rem;
    right: 2.75rem;
    height: 3.5rem;
    background-color: #e9e4da;
  }
  .flow-arrow:before {
    content: "";
    display: inline-block;
    background-color: transparent;
    border-top: 1.75rem solid transparent;
    border-left: 1.75rem solid #fff;
    border-bottom: 1.75rem solid transparent;
  }
  .flow-arrow:after {
    content: "";
    display: inline-block;
    background-color: transparent;
    border-top: 2.5rem solid transparent;
    border-left: 2.5rem solid #e9e4da;
    border-bottom: 2.5rem solid transparent;
    position: absolute;
    right: -2.5rem;
    top: 50%;
    transform: translateY(-50%);
  }

  .flow-arrow.reverse {
    top: auto;
    left: 18rem;
    right: 0.5rem;
    bottom: 1.65rem;
    transform: rotate(180deg);
  }

  .flow-line + .flow-line {
    margin-top: 4rem;
  }

  .flow {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
  .flow,
  .flow-division {
    flex: 0 1 auto;
    height: 15rem;
    min-width: 2rem;
    font-size: 90%;
  }
  .flow span {
    writing-mode: horizontal-tb;
  }
  .flow-colspan {
    flex: 0 1 auto;
    min-width: 6rem;
    height: 15rem;
  }
  .flow.tall {
    height: 34rem;
    max-height: 34rem;
  }
  .flow-division {
    flex-direction: column;
  }
  .flow-division .flow {
    flex: 0 1 100%;
    max-height: 6.75rem;
  }
  .space {
    flex: 1 1 auto;
    min-height: 1rem;
    min-width: 2rem;
    font-size:90%;
  }

  .flow .flow-caption {
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
  }

  .flow-image {
    position: absolute;
    left: 0;
    bottom: 0;
    height: 100%;
  }
}
