/*!
 * default.css
 * updatedAt: 2016.03.14
 * createdAt: 2016.03.01
 */
/*--------------------------------------------------------------------------------
	#tmpl_main
--------------------------------------------------------------------------------*/
#tmpl_main {
	position: relative;
	width: 100% !important;
	min-width: 950px;
	color: #000;
	font-size: 117.5%;
}

#tmpl_main a:hover {
	text-decoration: none;
}
@media(max-width:640px) {
	#tmpl_main { min-width: 320px; overflow: hidden; font-size: 100%;}
	#tmpl_main a { word-break:keep-all !important}
}

/*==================================================

  .eco-container

==================================================*/
.eco-container {
  margin: 0 auto;
  max-width: 2000px;
  box-shadow: 0 0 6px 0 rgba(0,0,0,0.3);
}
.ielegacy .eco-container {
  max-width: 1600px;
  border-right: 1px solid #eee;
  border-left: 1px solid #eee;
}
.eco-container .bold {
  font-family: "SST W55 Bold", sans-serif;
}
.eco-container .rimg {
  line-height: 0;
}
.eco-container .rimg img {
  width: 100%;
  height: auto;
  line-height: 0;
}
.eco-container .sp-appear {
  display: none;
}

@media screen and (max-width: 640px) {
  .eco-container .pc-appear {
    display: none;
  }
  .eco-container .sp-appear {
    display: block;
  }
  .eco-container img.sp-appear,
  .eco-container span.sp-appear {
    display: inline;
  }
}
@media screen and (max-width: 480px) {
  .eco-container {
    font-size: 87.5%;
  }
}

/*==================================================

  .visual

==================================================*/
.visual {
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}
.visual .inner-wrap {
  position: relative;
  margin: 0 auto;
}
.visual .inner {
  position: relative;
  margin: 0 auto;
  width: 940px;
}

@media screen and (min-width: 1600px) {
  .visual .inner {
    width: 58.75%;
  }
}


/*==================================================

  .mainvisual

==================================================*/
.mainvisual {
  background-image: url(../img/mainvisual.jpg);
}
.mainvisual .inner-wrap {
  min-height: 613px;
}
.mainvisual .inner {
  padding-bottom: 613px;
  padding-bottom: 37%;
}
.mainvisual h2 {
  position: absolute;
  left: 0;
  top: 0;
  margin-left: 0;
  padding-top: 180px;
  padding-top: 19.148936%;
  width: 470px;
  width: 50%;
}

@media screen and (max-width: 640px) {
  .mainvisual .inner-wrap {
    min-height: 1px;
  }
  .mainvisual .inner {
    padding-bottom: 372px;
    padding-bottom: 58.125%;
    width: auto;
  }
  .mainvisual h2 {
    margin-left: 32px;
    margin-left: 5%;
    padding-top: 90px;
    padding-top: 14.0625%;
    width: 53.59375%;
  }
}


/*==================================================

  .content

==================================================*/
.content {
  position: relative;
  margin: 0 auto;
  width: 940px;
}
.content:after {
  clear: both;
  display: block;
  content: "";
}
.content .sec-ttl {
  position: relative;
  z-index: 1;
  margin: 0 0 0 -26px;
  width: 501px;
}
.content .sec-txt {
  position: relative;
  z-index: 0;
  margin-top: 5px;
  font-size: 100%;
  line-height: 1.6;
  color: #058900;
}
.content .sec-note {
  margin-top: 10px;
  font-size: 75%;
  line-height: 1.4;
}
.content.midokoro .frame {
  position: relative;
  margin: 0 15px;
  padding: 23px 0 26px;
  border-radius: 10px;
  background-image: url(../img/midokoro_bg.png);
}
.content.midokoro .frame:after {
  clear: both;
  display: block;
  content: "";
}
.content.midokoro .fukidashi {
  width: 103px;
}
.content.midokoro strong {
  display: block;
  margin: 0 0 10px;
}
.content.midokoro p {
  margin-left: 4px;
  font-size: 87.5%;
  line-height: 1.5;
}

@media screen and (max-width: 640px) {
  .content {
    padding: 0 35px;
    padding: 0 5.46875% !important;
    width: auto;
  }
  .content .sec-ttl {
    margin: 0 0 0 -3.5087719% !important;
    width: 600px;
    width: 105.2631578%;
  }
  .content .sec-txt {
    margin-top: 10px;
  }
  .content.midokoro .frame {
    margin: 0;
    padding: 40px 30px;
    padding: 7.0175438% 5.2631578%;
  }
  .content.midokoro .fukidashi {
    width: 145px;
    width: 25.4385964%;
  }
  .content.midokoro strong {
    margin: 0 0 15px;
  }
  .content.midokoro strong img {
    width: 145%;
  }
  .content.midokoro p {
    margin-left: 0;
    font-size: 100%;
    line-height: 1.6;
  }
}
@media screen and (max-width: 480px) {
  .content.midokoro p {
    font-size: 87.5%;
    line-height: 1.5;
  }
}

/*--------------------------------------------------
  .intro
--------------------------------------------------*/
.intro {
  margin: 50px auto 65px;
}
.intro .left-box {
  float: left;
  width: 470px;
  font-family:"SST W55 Bold";
}
.intro .left-box p {
  font-size: 106.25%;
  font-family: "SST W55 Bold";
  line-height: 2;
  color: #058900;
}
.intro .right-box {
  float: right;
  width: 430px;
}
.intro .right-box h3 {
  margin-bottom: 19px;
  font-size: 106.25%;
  font-family: "SST W55 Bold";
  font-weight: normal;
  line-height: 1;
  color: #b36100;
  text-align: center;
  background-image: url(../img/intro_deco2016.png);
  background-repeat: no-repeat;
  background-position: center center;
}
.intro .right-box h4 {
  margin-bottom: 14px;
  color: #191919;
  font-size: 100%;
  font-family: "SST W55 Bold";
  font-weight: normal;
  line-height: 1;
}
.intro .frame {
  margin-top: 8px;
  padding: 0;
  /*width: 434px;*/
}
.intro .frame:after {
  clear: both;
  display: block;
  content: "";
}
.intro .frame .img-box {
  float: left;
  margin-right: 30px;
  margin-right: 4.883721%;
  width: 177px;
  width: 41.162791%;
}
.intro .frame .img-box img {
  width: 100%;
}
.intro .frame .txt-box {
	padding-top: 8px;
}
.intro .frame p {
  font-size: 75%;
  line-height: 1.7;
  overflow: hidden;
}

@media screen and (max-width: 640px) {
  .intro {
    margin-top: 40px;
  }
  .intro .left-box {
    float: none;
    width: auto;
  }
  .intro .left-box p {
    line-height: 1.8;
  }
  .intro .right-box {
    float: none;
    margin-top: 30px;
    width: auto;
  }
  .intro .right-box strong {
    background: none;
  }
  .intro .frame {
    padding: 15px;
  }
  .intro .frame em {
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 480px) {
  .intro .frame {
    padding: 0;
  }
  .intro .frame .txt-box {
    padding-top: 2px;
  }
  .intro .right-box h3 {
	background-image: none;
  }
  .intro .right-box h4 {
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 320px) {
  .intro .right-box strong {
    font-size: 100%;
  }
}

.sample {
  position: relative;
  margin-bottom: 120px;
  padding-top: 24px;
}
.sample h3 {
  position: absolute;
  top: 0;
  left: 16px;
  width: 140px;
  height: 140px;
  box-sizing: border-box;
  margin: 0;
  color: #FFF;
  font-size: 112.5%;
  font-family: "SST W55 Bold";
  font-weight: normal;
  line-height: 1.39;
  text-align: center;
  border-radius: 100%;
}
@media(max-width:640px) {
	.sample h3{
		font-size: 125%;
    line-height:  1.3em;
	}
}
.sample h3 span {
  display: none;
}
.sample ul {
  margin: 0 84px;
}
.sample ul li {
  float: left;
  width: 360px;
  padding: 0 5px;
}
.sample ul li img {
  width: 100%;
}

h2.sec-h {
  width: 545px;
  margin: 0 auto 28px;
}
h2.sec-h img {
  display: block;
  width: 100%;
}

@media screen and (max-width: 640px) {
  .sample{
    margin-bottom: 80px;
    padding: 0 5.46875% !important;
  }
  .sample h3 {
    position: static;
    width: 100%;
    height: auto;
    box-sizing: border-box;
    margin-bottom: 8px;
    padding: 12px 4px;
    font-size: 125%;
    line-height: 1.3;
    border-radius: 8px;
    background-color: #d1471d;
  }
  .sample h3 span {
    display: inline;
  }
  .sample h3 img {
    display: none;
  }
  .sample ul {
    margin: 0;
  }
  .sample ul li {
    float: none;
    width: 100%;
    margin: 0 0 8px 0;
    padding: 0;
  }
  h2.sec-h {
    width:  100%;
	box-sizing: border-box;
    margin: 0 0 40px;
    padding: 0 3% !important;
  }
}
@media screen and (max-width: 480px) {
  
}


/*--------------------------------------------------
  .sec-01
--------------------------------------------------*/
.sec-01 {
  padding-bottom: 127px;
  background-image: url(../img/next1.png);
  background-repeat: no-repeat;
  background-position: 352px bottom;
  background-position: 37.4468085% bottom;
}
.sec-01 .right-box {
  float: right;
  margin: -49px 0 0;
  width: 429px;
  line-height: 0;
}
.sec-01 .right-box img {
  width: 455px;
}
.sec-01 .left-box {
  float: left;
  width: 471px;
}
.sec-01 .img-02 {
  margin-top: 10px;
}

@media screen and (max-width: 640px) {
  .sec-01 {
    background: none;
  }
  .sec-01 .right-box {
    float: none;
    margin: 20px auto 0;
    width: 78.9473684%;
  }
  .sec-01 .right-box img {
    width: 100%;
    height: auto;
  }
  .sec-01 .left-box {
    float: none;
    width: auto;
  }
  .sec-01 .img-02 {
    margin-top: 30px;
  }
}

/*--------------------------------------------------
  .sec-02
--------------------------------------------------*/
.sec-02 {
  margin-top: -33px;
}

/* .float-box
--------------------------------------------------*/
.sec-02 .float-box {
  position: absolute;
  top: 0;
  right: -22px;
  z-index: 2;
  padding-top: 153px;
  width: 475px;
}
.sec-02 .sec-ttl {
  position: relative;
  z-index: 1;
}
.sec-02 .sec-txt span {
  display: none;
}
.sec-02 .sec-txt img {
  margin: -41px 0 0 -46px;
}
.sec-02 .float-box p {
  position: relative;
  z-index: 1;
  margin-top: 10px;
}
.sec-02 .float-box .grade {
  position: absolute;
  left: -50px;
  bottom: -42px;
  z-index: 0;
  width: 559px;
  height: 159px;
  background-image: url(../img/sec_02_txt_bg.png);
  background-repeat: no-repeat;
  background-position: center center;
}

@media screen and (max-width: 640px) {
  .sec-02 {
    margin-top: 50px;
  }
  .sec-02 .float-box {
    position: static;
    padding: 0;
    width: auto;
  }
  .sec-02 .sec-txt span {
    display: inline;
  }
  .sec-02 .sec-txt img {
    display: none;
  }
  .sec-02 .float-box .grade {
    display: none;
  }
}

/* .visual
--------------------------------------------------*/
.sec-02 .visual {
  background-image: url(../img/sec_02_visual.jpg);
}
.sec-02 .visual .inner-wrap {
  min-height: 866px;
}
.sec-02 .visual .inner {
  padding-bottom: 866px;
  padding-bottom: 54.125%;
}
.sec-02 .visual .inner p {
  position: absolute;
  right: 16px;
  right: 1.7021276%;
  top: 0;
  padding-top: 490px;
  padding-top: 52.1276595%;
  width: 217px;
  width: 23.0851063%;
}

@media screen and (max-width: 640px) {
  .sec-02 .visual {
    margin-top: 20px;
  }
  .sec-02 .visual .inner-wrap {
    min-height: 1px;
  }
  .sec-02 .visual .inner {
    padding-bottom: 428px;
    padding-bottom: 66.875%;
    width: auto;
  }
  .sec-02 .visual .inner p {
    right: 57%;
    padding-top: 31.5625%;
    width: 232px;
    width: 36.25%;
  }
}

/* .midokoro
--------------------------------------------------*/
.sec-02 .midokoro {
  margin-top: 50px;
  padding-bottom: 144px;
  background-image: url(../img/next1.png);
  background-repeat: no-repeat;
  background-position: 464px bottom;
  background-position: 49.3617021% bottom;
}
.sec-02 .midokoro .fukidashi {
  position: absolute;
  left: -31px;
  top: -19px;
}
.sec-02 .midokoro .person {
  position: absolute;
  left: 40px;
  bottom: 0;
  width: 127px;
  height: auto;
}
.sec-02 .midokoro .txt-box {
  float: left;
  margin: 0 0 0 189px;
  width: 535px;
}
.sec-02 .midokoro strong {
  width: 326px;
}
.sec-02 .midokoro .img-box {
  float: right;
  margin: 20px 30px 0 0;
  width: 139px;
}

@media screen and (max-width: 640px) {
  .sec-02 .midokoro {
    margin-top: 30px;
    padding-bottom: 0;
    background: none;
  }
  .sec-02 .midokoro .fukidashi {
    left: 6.5%;
    top: auto;
    bottom: 0;
    padding-bottom: 42%;
  }
  .sec-02 .midokoro .person {
    left: 30px;
    left: 5.2631578%;
    width: 160px;
    width: 28.0701754%;
  }
  .sec-02 .midokoro .txt-box {
    float: none;
    margin: 0;
    width: auto;
  }
  .sec-02 .midokoro strong {
    width: 63.9215686%;
  }
  .sec-02 .midokoro .txt-box p {
    float: right;
    width: 340px;
    width: 66.666%;
  }
  .sec-02 .midokoro .img-box {
    margin: 20px 7% 0 0;
    width: 50%;
  }
}

/*--------------------------------------------------
  .sec-03
--------------------------------------------------*/
.sec-03 {
  position: relative;
  z-index: 1;
  margin-top: 20px;
}
.sec-03 .content {
  padding-bottom: 110px;
  background-image: url(../img/next2.png);
  background-repeat: no-repeat;
  background-position: 209px bottom;
  background-position: 22.234% bottom;
}
.sec-03 .sec-ttl {
  margin-left: -19px;
}
.sec-03 .right-box {
  float: right;
  width: 482px;
}
.sec-03 .right-box:after {
  clear: both;
  display: block;
  content: "";
}
.sec-03 .img-01 {
  float: right;
  margin: 10px 0 0 30px;
  width: 226px;
}
.sec-03 .left-box {
  float: left;
  margin-left: 13px;
  width: 409px;
}

@media screen and (max-width: 640px) {
  .sec-03 {
    margin-top: 50px;
  }
  .sec-03 .content {
    padding-bottom: 0;
    background: none;
  }
  .sec-03 .right-box {
    float: none;
    width: auto;
  }
  .sec-03 .left-box {
    float: none;
    margin: 20px auto 0;
    width: 507px;
    width: 88.9473684%;
  }
  .sec-03 .img-01 {
    float: none;
    margin: 30px 0 0 0;
    width: auto;
    text-align: center;
  }
  .sec-03 .img-01 img {
    max-width: 309px;
    width: 65%;
  }
}

/*--------------------------------------------------
  .sec-04
--------------------------------------------------*/
.sec-04 {
  margin-top: -36px;
}

/* .float-box
--------------------------------------------------*/
.sec-04 .float-box {
  position: absolute;
  top: 0;
  left: 25px;
  z-index: 2;
  padding-top: 186px;
  width: 475px;
}
.sec-04 .sec-ttl {
  position: relative;
  z-index: 1;
}
.sec-04 .sec-txt span {
  display: none;
}
.sec-04 .sec-txt img {
  margin: -41px 0 0 -46px;
}
.sec-04 .float-box p {
  position: relative;
  z-index: 1;
  margin-top: 10px;
}
.sec-04 .float-box .grade {
  position: absolute;
  left: -48px;
  bottom: -28px;
  z-index: 0;
  width: 557px;
  height: 158px;
  background-image: url(../img/sec_04_txt_bg.png);
  background-repeat: no-repeat;
  background-position: center center;
}

@media screen and (max-width: 640px) {
  .sec-04 {
    margin-top: 50px;
  }
  .sec-04 .float-box {
    position: static;
    padding: 0;
    width: auto;
  }
  .sec-04 .float-box .grade {
    display: none;
  }
  .sec-04 .sec-txt span {
    display: inline;
  }
  .sec-04 .sec-txt img {
    display: none;
  }
}

/* .visual
--------------------------------------------------*/
.sec-04 .visual {
  background-image: url(../img/sec_04_visual.jpg);
}
.sec-04 .visual .inner-wrap {
  min-height: 838px;
}
.sec-04 .visual .inner {
  padding-bottom: 838px;
  padding-bottom: 52.375%;
}
.sec-04 .visual .inner p {
  position: absolute;
  left: 445px;
  left: 47.3405255%;
  top: 0;
  padding-top: 362px;
  padding-top: 38.5106382%;
  width: 176px;
  width: 18.7234042%;
}

@media screen and (max-width: 640px) {
  .sec-04 .visual {
    margin-top: 15px;
  }
  .sec-04 .visual .inner-wrap {
    min-height: 1px;
  }
  .sec-04 .visual .inner {
    padding-bottom: 528px;
    padding-bottom: 82.5%;
    width: auto;
  }
  .sec-04 .visual .inner p {
    left: 334px;
    left: 52.1875%;
    padding-top: 134px;
    padding-top: 20.9375%;
    width: 176px;
    width: 27.5%;
  }
}

/* .midokoro
--------------------------------------------------*/
.sec-04 .midokoro {
  margin-top: 20px;
  padding-bottom: 111px;
  background-image: url(../img/next1.png);
  background-repeat: no-repeat;
  background-position: 480px bottom;
}
.sec-04 .midokoro .fukidashi {
  position: absolute;
  right: 122px;
  top: -72px;
}
.sec-04 .midokoro .person {
  position: absolute;
  right: 26px;
  bottom: 0;
  width: 171px;
  height: auto;
}
.sec-04 .midokoro .txt-box {
  float: left;
  margin: 0 0 0 32px;
  width: 370px;
}
.sec-04 .midokoro strong {
  width: 308px;
}
.sec-04 .midokoro .img-box {
  float: left;
  margin: 20px 0 0 20px;
  width: 283px;
}

@media screen and (max-width: 640px) {
  .sec-04 .midokoro {
    margin-top: 30px;
    padding-bottom: 0;
    background: none;
  }
  .sec-04 .midokoro .fukidashi {
    right: 1.5%;
    top: auto;
    bottom: 0;
    padding-bottom: 45.4385964%;
  }
  .sec-04 .midokoro .person {
    right: 12px;
    right: 2.1052631%;
    width: 180px;
    width: 31.5789473%;
  }
  .sec-04 .midokoro .txt-box {
    float: none;
    margin: 0;
    width: auto;
  }
  .sec-04 .midokoro strong {
    width: 60.3921568%;
  }
  .sec-04 .midokoro .txt-box p {
    width: 330px;
    width: 64.7058823%;
  }
  .sec-04 .midokoro .img-box {
    margin: 25px 0 0;
    width: 330px;
    width: 64.7058823%;
  }
}

/*--------------------------------------------------
  .sec-05
--------------------------------------------------*/
.sec-05 .content {
  padding-bottom: 122px;
  background-image: url(../img/next3.png);
  background-repeat: no-repeat;
  background-position: 391px bottom;
}
.sec-05 .txt-box {
  float: right;
  margin: 10px 0 0;
  width: 476px;
}
.sec-05 .img-01 {
  float: left;
  width: 426px;
}
.sec-05 .img-01 img {
  margin-left: -101px;
  width: 527px;
}
.sec-05 .img-02 {
  margin: 20px 0 0;
  float: right;
  width: 465px;
}

@media screen and (max-width: 640px) {
  .sec-05 {
    margin-top: 50px;
  }
  .sec-05 .content {
    padding-bottom: 0;
    background: none;
  }
  .sec-05 .txt-box {
    float: none;
    margin: 0;
    width: auto;
  }
  .sec-05 .img-01 {
    float: none;
    margin: 20px auto 0;
    width: 543px;
    width: 95.2631578%;
  }
  .sec-05 .img-01 img {
    margin: 0;
    width: 100%;
  }
  .sec-05 .img-02 {
    margin: 30px auto 0;
    float: none;
    width: auto;
  }
}

/*--------------------------------------------------
  .sec-06
--------------------------------------------------*/
.sec-06 {
  margin-top: 15px;
}
.sec-06 .content {
  padding-bottom: 48px;
}
.sec-06 .txt-box {
  position: relative;
  z-index: 1;
  width: 480px;
}
.sec-06 .img-01 {
  margin: -32px 0 0 16px;
}
.sec-06 .next {
  position: absolute;
  bottom: 0;
  z-index: 1;
  width: 100%;
  height: 76px;
  background-image: url(../img/next4.png);
  background-repeat: no-repeat;
  background-position: 466px bottom;
}

@media screen and (max-width: 640px) {
  .sec-06 {
    margin-top: 50px;
  }
  .sec-06 .txt-box {
    width: auto;
  }
  .sec-06 .img-01 {
    margin: 20px 0 0;
  }
  .sec-06 .img-01 img {
    margin-left: -4%;
    width: 108%;
  }
  .sec-06 .next {
    display: none;
  }
}

/*--------------------------------------------------
  .sec-07
--------------------------------------------------*/
.sec-07 {
  margin-top: 20px;
}
.sec-07 h3 {
  margin: 0 auto;
  width: 594px;
}
.sec-07 .img-box {
  margin: 23px 0 0 350px;
  width: 405px;
}

@media screen and (max-width: 640px) {
  .sec-07 {
    margin-top: 50px;
  }
  .sec-07 h3 {
    width: 450px;
    width: 78.9473684%;
  }
  .sec-07 .img-box {
    margin: 30px auto 0;
    width: 462px;
    width: 81.0526315%;
  }
}
@media screen and (max-width: 480px) {
  .sec-07 h3 {
    width: 95%;
  }
}

/* .midokoro
--------------------------------------------------*/
.sec-07 .midokoro {
  margin-top: 40px;
}
.sec-07 .midokoro .fukidashi {
  position: absolute;
  left: -43px;
  top: -11px;
}
.sec-07 .midokoro .person {
  position: absolute;
  left: 40px;
  bottom: 0;
  width: 127px;
  height: auto;
}
.sec-07 .midokoro .txt-box {
  float: left;
  margin: 0 0 0 190px;
  width: 510px;
}
.sec-07 .midokoro strong {
  width: 348px;
}
.sec-07 .midokoro .img-box {
  float: right;
  margin: 20px 40px 0 0;
  width: 144px;
}

@media screen and (max-width: 640px) {
  .sec-07 .midokoro {
    margin-top: 30px;
  }
  .sec-07 .midokoro .fukidashi {
    left: 6.0%;
    top: auto;
    bottom: 0;
    padding-bottom: 44%;
  }
  .sec-07 .midokoro .person {
    left: 30px;
    left: 5.2631578%;
    width: 160px;
    width: 28.0701754%;
  }
  .sec-07 .midokoro .txt-box {
    float: none;
    margin: 0;
    width: auto;
  }
  .sec-07 .midokoro strong {
    width: 68.2352941%;
  }
  .sec-07 .midokoro .txt-box p {
    float: right;
    width: 340px;
    width: 66.666%;
  }
  .sec-07 .midokoro .img-box {
    margin: 20px 7% 0 0;
    width: 50%;
  }
}

/*--------------------------------------------------
  .guide
--------------------------------------------------*/
.guide {
  margin-top: 100px;
  padding: 55px 0 35px;
  color: #fff;
  background: #058900;
}
.guide .heading:after,
.guide .heading .info:after,
.guide .flow-box:after,
.guide .flow:after {
  clear: both;
  display: block;
  content: "";
}

@media screen and (max-width: 640px) {
  .guide {
    margin-top: 60px;
    padding: 40px 0 35px;
  }
}

/* .heading
--------------------------------------------------*/
.guide .heading h3 {
  float: left;
  margin-left: -5px;
  width: 480px;
}
.guide .heading .info {
  float: right;
  margin-top: 12px;
}
.guide .heading span {
  margin-left: -0.5em;
  margin-right: -0.5em;
}
.guide .heading span.s2 {
  margin-left: 0;
  margin-right: 0;
}
.guide .heading em {
  clear: both;
  display: block;
  padding-top: 5px;
  font-size: 75%;
}
.guide .heading ul {
  margin-bottom: 8px;
}
.guide .heading ul:after {
  clear: both;
  display: block;
  content: "";
}
.guide .heading ul li {
  float: left;
  margin-left: 8px;
  padding: 0 14px;
  font-size: 87.5%;
  font-weight: bold;
  line-height: 23px;
  color: #007700;
  text-align: center;
  background: #ffff00;
}
.guide .heading ul li:first-child {
  margin-left: 0;
  padding: 0 20px;
}
.guide .heading p {
  margin: 0;
  color: #fff;
  font-size: 80%;
  line-height: 1;
}
.guide p.intro-txt {
  margin-top: 30px;
  font-size: 112.5%;
  line-height: 1.6;
}

@media screen and (max-width: 640px) {
  .guide .heading h3 {
    float: none;
    margin: 0;
    width: auto;
  }
  .guide .heading .info {
    float: none;
    margin-top: 25px;
  }
  .guide .heading ul li {
    margin-left: 2%;
    padding: 0;
    width: 37%;
    font-size: 93.8%;
    line-height: 30px;
  }
  .guide .heading ul li:nth-child(3) {
    width: 40%;
  }
  .guide .heading ul li:first-child {
    padding: 0;
    width: 19%;
  }
  .guide .heading p {
    font-size: 93.8%;
	text-align: center;  
  }
  .guide .heading em {
    padding-top: 10px;
    font-size: 81.3%;
  }
}
@media screen and (max-width: 480px) {
  .guide .heading ul li {
    font-size: 87.5%;
  }
  .guide .heading p {
    font-size: 87.5%;
  }
}
@media screen and (max-width: 320px) {
  .guide .heading ul li {
    font-size: 81.3%;
  }
  .guide .heading p {
    font-size: 81.3%;
  }
}

/* .flow-box
--------------------------------------------------*/
.guide .flow-box {
  margin-top: 40px;
}
.guide .flow-box strong {
  display: block;
  margin: 0 0 25px;
  width: 202px;
}
.guide .flow {
  float: left;
  margin-left: 21px;
  width: 219px;
}
.guide strong + .flow {
  margin-left: 0;
}
.guide .flow .rimg {
  position: relative;
}
.guide .flow .rimg:after {
  position: absolute;
  left: -25px;
  top: 50%;
  z-index: 1;
  display: block;
  margin-top: -20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 0 20px 30px;
  border-color: transparent transparent transparent #ffff00;
  content: "";
}
.guide strong + .flow .rimg:after {
  display: none;
}
.guide .flow .txt-box {
  margin: 15px 5px 0;
}
.guide .flow em {
  display: block;
  font-size: 93.8%;
  line-height: 1.3;
}
.guide .flow p {
  margin-top: 3px;
  font-size: 75%;
  line-height: 1.6;
}

@media screen and (max-width: 640px) {
  .guide .flow-box strong {
    margin: 0 auto 15px;
    max-width: 288px;
    width: 65%;
  }
  .guide .flow {
    float: none;
    display: table;
    margin: 20px 0 0;
    width: 100%;
  }
  .guide .flow .rimg {
    display: table-cell;
    width: 220px;
    width: 38.5964912%;
    vertical-align: middle;
  }
  .guide .flow .rimg:after {
    left: 50%;
    top: 0;
    z-index: 1;
    margin-top: -25px;
    margin-left: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 20px 0 20px;
    border-color: #ffff00 transparent transparent transparent;
    content: "";
  }
  .guide .flow .txt-box {
    margin: 0;
    padding: 0 0 0 30px;
    padding: 0 0 0 5.2631578%;
    display: table-cell;
    vertical-align: middle;
  }
  .guide .flow em {
    font-size: 112.5%;
  }
  .guide .flow p {
    font-size: 93.8%;
  }
}
@media screen and (max-width: 480px) {
  .guide .flow {
    margin: 10px 0 0;
  }
  .guide .flow p {
    font-size: 81.3%;
  }
  .guide .flow .rimg:after {
    margin-top: -10px;
    margin-left: -10px;
    border-width: 15px 10px 0 10px;
  }
}

/* .apply
--------------------------------------------------*/
.guide .apply {
  margin-top: 60px;
  text-align: center;
}
.guide .apply strong {
  display: block;
  margin: 0 auto 13px;
  width: 280px;
}
.guide .apply a.btn {
  display: block;
  margin: 0 auto;
  max-width: 700px;
  line-height: 82px;
  background-color: #d1471d;
  border-radius: 5px;
  transition: background-color 0.2s;
  -ms-transition: background-color 0.2s;
  -moz-transition: background-color 0.2s;
  -webkit-transition: background-color 0.2s;
}
.guide .apply a.btn:hover {
  background-color: #f58867;
}
.guide .apply a.btn h4 {
  margin-left: 149px;
  margin-left: 25.4266211%;
  padding: 25px 0 25px;
  width: 322px;
  width: 46%;
}
.guide .apply p {
  margin-top: 7px;
  font-size: 75%;
  line-height: 1.3;
}

@media screen and (max-width: 640px) {
  .guide .apply strong {
    width: 453px;
    width: 79.4736842%;
  }
}
@media screen and (max-width: 480px) {
  .guide .apply a.btn h4 {
    margin-left: 16%;
    width: 72%;
  }
}

/* .address
--------------------------------------------------*/
.guide .address {
  margin-top: 25px;
  text-align: center;
}
.guide .address strong {
  display: block;
  font-size: 100%;
  line-height: 1.3;
}
.guide .address p {
  margin-top: 2px;
  font-size: 75%;
  line-height: 1.4;
}

/*--------------------------------------------------
  .recycle
--------------------------------------------------*/
.recycle {
  margin-top: 70px;
  padding-bottom: 80px;
}
.recycle h3 {
  font-size: 168.8%;
  line-height: 1.4;
  color: #058900;
}
.recycle p.intro-txt {
  margin-top: 10px;
  font-size: 87.5%;
  line-height: 1.6;
}
.recycle h4 {
  margin-top: 50px;
  font-size: 112.5%;
  line-height: 1.4;
}
.recycle .img-box {
  position: relative;
  margin-top: 30px;
}
.recycle .img-box img {
  margin-left: -259px;
}
.recycle .txt-box {
  margin: -178px 0 70px 490px;
  width: 450px;
}
.recycle .txt-box strong {
  display: block;
  font-size: 93.8%;
  line-height: 1.3;
}
.recycle .txt-box p {
  margin-top: 3px;
  font-size: 87.5%;
  line-height: 1.6;
}
.recycle .txt-box p.note {
  font-size: 68.8%;
}
.recycle .conclusion {
  margin-top: 10px;
  font-size: 112.5%;
  line-height: 2.0;
  color: #058900;
  text-align: center;
}

@media screen and (max-width: 640px) {
  .recycle {
    margin-top: 50px;
    padding-bottom: 12.5%
  }
  .recycle h3 br {
    display: none;
  }
  .recycle .img-box img {
    margin-left: -35%;
    width: 135%;
  }
  .recycle .txt-box {
    position: static;
    width: 100%;
  }
  .recycle .conclusion {
    margin-top: 60px;
  }
  .recycle .conclusion br {
    display: none;
  }
}
@media screen and (max-width: 480px) {
  .recycle h3 {
    font-size: 156.3%;
  }
}
@media screen and (max-width: 360px) {
  .recycle .conclusion {
    font-size: 106.3%;
  }
}
@media screen and (max-width: 320px) {
  .recycle .conclusion {
    font-size: 100%;
  }
}

