@charset "utf-8";
/* CSS Document */
/*---------------
agency
---------------*/
#agency h2 {
  width: 1200px;
  margin: 0 auto 98px;
}

.agency-top {
  margin: 0;
  padding: 280px 0;
  text-align: center;
  background: #fff url("../images/agencymain.jpg") no-repeat center top;
  background-size: cover;
}
.agenc-maintxt_text {
  margin: 0 auto;
  padding: 0;
  color: #fff;
  display: block;
  font-size: 3rem;
  background:#f00;
  border-radius: 60rem;
  width: 55rem;
  text-align: center;
}
.agenc-maintxt {
  margin: 0;
  padding: 0;
  color: #fff;
  display: block;
  font-size: 6rem;
}
.agenc-subtxt {
  text-align: center;
  margin: 0;
  padding: 0;
  color: #fff;
  font-size: 2.5rem;
}

.agency-text {
  text-align: center;
}

.agency-text h3 {
  margin: 0;
  padding: 100px 0 30px;
  font-size: 3rem;
  text-align: center;
}

.agency-text p {
  margin: 0;
  font-size: 1.8rem;
  font-weight: 300;
  line-height: 1.7;
}

.agency-content {
  margin: 0 auto;
  padding: 180px 100px 0;
}

.agency-content h3 {
  color: #266ec7;
  font-size: 7.2rem;
  line-height: 1.2;
  font-family: 'Roboto', sans-serif;
  margin-bottom: 50px;
  text-align: center;
}

.agency-content h3 span {
  display: block;
  color: #000;
  font-size: 1.5rem;
  font-weight: 400;
  font-family: 'Noto Sans JP', sans-serif;
}


.produtype {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.produtype > * {
    flex-shrink: 0;
}

.type {
    width: 100%;
    box-shadow: 0 -1px #e6e6e6;
    margin-left: auto;
    padding-top: 5.5rem;
    margin-top: 5.5rem;
}

.type-label {
    float: left;
    padding-top: .5rem;
    width: 6.5rem;
    margin-left: -6.5rem;
    color: #266ec7;
    font-size: 2rem;
}

.type-icon {
    display: block;
    margin-bottom: 1rem;
    background-size: cover;
    float: left;
    width: 60px;
    height: 60px;
}

.type01 {
  background: #fff url("../images/typeicon01.png") no-repeat center top;
}


.type02 {
  background: #fff url("../images/typeicon02.png") no-repeat center top;
}

.type03{
  background: #fff url("../images/typeicon3.png") no-repeat center top;
}


.type-title {
    margin-left: 8rem;
    font-size: 3.5rem;
    line-height: 1;
    color: #266ec7;
}

.type-titlesub {
    margin-top: 1rem;
    margin-left: 8rem;
    font-size: 1.5rem;
    line-height: 1.5em;
}

.type-text {
    font-size: 1.5rem;
    line-height: 2em;
    margin-top: 2.5rem;
    font-weight: 300;
    clear: left;
}


.agency-explanation {
    margin: 100px auto 0;
    padding: 9rem 2rem;
    text-align: center;
    font-size: 3.1rem;
    color: #fff;
    background: #266ec7;
    line-height: 2;
}

.explanation-text {
    margin: 0;
    padding: 0;
}

.point {
    margin: 0;
    padding: 0;
    display: flex;
}

.reverse {
    flex-direction: row-reverse;
}
.point-img {
    padding: 0;
    width: 40rem;
    height: 38rem;
    border-radius: .5rem;
    margin-bottom: 1.5rem;
    flex-shrink: 0;
    align-self: flex-start;
    margin-left: 2.75rem;
    margin-right: 2.75rem;
}

.point01 {
    background: #fff url("../images/pointimg01.png") no-repeat center top;
}

.point02 {
    background: #fff url("../images/pointimg2.png") no-repeat center top;
}

.point03 {
    background: #fff url("../images/pointimg3.png") no-repeat center top;
}

.point-textBlock {
    -ms-grid-row-align: center;
    align-self: center;
    flex-grow: 1;
    margin-left: 2.75rem;
    margin-right: 2.75rem;
}

.point-title {
    font-size: 3rem;
    line-height: 1.1em;
    margin-bottom: 4.5rem;
    letter-spacing: -.03em;
}

.point-description {
    font-size: 1.5rem;
    line-height: 2em;
    font-weight: 300;
}

.agency-flow {
    margin: 0;
    padding: 0;
    text-align: center;
}


.flow01 {
    margin: 50px auto;
    padding: 5em;
    background: #fafafa;
}

.flow-label {
    margin: 0;
    padding: 0;
    font-size: 2rem;
    color: #266ec7;
}

.flow-title {
    margin: 0;
    padding: 0;
    font-size: 3rem;
    color: #266ec7;
}

.flow-subtxt {
    margin: 0;
    padding-top: 1.5em;
    padding-bottom: 1.5em;
    font-size: 1.5rem;
    font-weight: 300;
}

.flow-contact {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.flow-sec {
    padding: .5rem;;
    margin: -.5rem;
    display: flex;
}

.flow-sec li{
    padding: .5rem;;
    width: 50%;
}

.flow-tap{
    position: relative;
    display: block;
    padding: 1rem;
    text-align: center;
    background-color: #fff;
    padding-top: 66px;
    padding-bottom: 66px;
    border-radius: .5rem;
}

.contact-tex {
    margin: 0;
    display: block;
    font-size: 1.5rem;
    padding-bottom: 1.5rem;
}

.contact-time{
    margin: 0;
    display: block;
    font-size: 1.5rem;
    color: #266ec7;
}

.contact-link{
    margin: 0 auto; 
    font-size: 3rem;
    color: #266ec7;
    display: flex;
    align-items: center;
    justify-content: center;
}



.arrow-group {
    width: 32px;
    height: 32px;
    border: 1px solid #266ec7;
    border-radius: 50%;
    margin: 0 .3em;
    display: flex;
    justify-content: center;
    align-items: center;
}

.arrow {
  width: 9px;
  height: 9px;
  border: 0px;
  border-top: solid 2px #266ec7;
  border-right: solid 2px #266ec7;
  transform: rotate(45deg);
  margin-right: 5px;
}

.foottxt{
    font-size: 1.5rem;
    font-weight: 300;
    line-height: 2em;
    padding: 0 100px;
}

@media screen and (max-width: 1200px) {
  #agency h2 {
    width: 980px;
  }
