@charset "UTF-8";

.sec-01 {
  margin-top: 200px;
}

.guide-nav {
  transition: 0.1s;
  float: left;
  width: 32%;
  position: sticky;
  top: 20px;
}



.nd {
  border-radius: 18px;
  background-color: #FFF;
  padding: 30px;
  box-sizing: border-box;
}

.nn-hd {
  padding-left: 1.5em;
  border-bottom: 2px solid #000;
  position: relative;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.17222222222;
}

.nn-hd::before {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 6px;
  background-color: #B88B68;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.nnl {
  margin-top: 10px;
}

.nnl li a {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.17222222222;
}

.nnl li.current a {
  color: #B88B68;
}

.guide-lst {
  float: right;
  width: 68%;
  padding-left: 32px;
  box-sizing: border-box;
}

.guide-unit {
  margin-bottom: 230px;
}

.guide-lst-hd {
  text-align: center;
  font-size: 3.0rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.3px;
  position: relative;
  margin-bottom: 58px;
}

.guide-lst-hd::after {
  position: absolute;
  display: block;
  content: '';
  width: 56px;
  height: 2px;
  background-color: #000;
  left: 0;
  right: 0;
  margin: auto;
  bottom: -30px;
}

.guide-lst-hd-sb {
  font-size: 1.803rem;
  font-weight: 400;
  line-height: 2.27953410982;
  letter-spacing: -0.361px;
}

.gl-01-map {
  height: 0;
  padding-top: 71%;
  background-size: contain;
  background-repeat: no-repeat;
}

.gl-01-map.cat-01 {
  background-image: url('../images/guide/guide-map-01.png');
}

.gl-01-map.cat-02 {
  background-image: url('../images/guide/guide-map-02.png');
}

.gl-01-map.cat-03 {
  background-image: url('../images/guide/guide-map-03.png');
}

.gl-01-map.cat-04 {
  background-image: url('../images/guide/guide-map-04.png');
}

.gl-01-map.cat-05 {
  background-image: url('../images/guide/guide-map-05.png');
}

.gl-01-ls-hd span {
  display: inline-block;
  vertical-align: middle;
}

.gl-01-num {
  margin-right: 17px;
  width: 36px;
  height: 36px;
  line-height: 36px;
  border-radius: 18px;
  color: #FFF;
  text-align: center;
  font-size: 1.872rem;
  font-weight: 500;
  letter-spacing: -0.187px;
}

.gl-01-num-01 {
  background-color: #4CC764;
}

.gl-01-num-02 {
  background-color: #EE888C;
}

.gl-01-num-03 {
  background-color: #44BCFF;
}

.gl-01-num-04 {
  background-color: #FF6E30;
}

.gl-01-num-05 {
  background-color: #B03BBA;
}

.gl-01-nv {
  font-size: 0;
  letter-spacing: 0;
  margin-top: 44px;
}

.gl-01-nv li {
  display: inline-block;
  color: #FFF;
  text-align: center;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 44px;
  height: 44px;
  letter-spacing: -0.26px;
  background-color: #939292;
  border-radius: 22px;
  width: 17%;
  margin-right: 2%;
  cursor: pointer;
}

.gl-01-nv .cat-02 {
  width: 20%;
}

.gl-01-nv .cat-01.current {
  background-color: #4CC764;
}

.gl-01-nv .cat-02.current {
  background-color: #EE888C;
}

.gl-01-nv .cat-03.current {
  background-color: #44BCFF;
}

.gl-01-nv .cat-04.current {
  background-color: #FF6E30;
}

.gl-01-nv .cat-05.current {
  background-color: #B03BBA;
}

.gl-01-ls-wrap {
  margin-top: 31px;
  width: calc(100% + 30px);
  margin-left: -15px;
  margin-right: -15px;
  font-size: 0;
  letter-spacing: 0;
}

.gl-01-ls-unit {
  width: calc(50% - 30px);
  margin-left: 15px;
  margin-right: 15px;
  display: inline-block;
  box-sizing: border-box;
  padding: 21px 34px;
  background-color: #fff;
  border-radius: 10px;
  margin-bottom: 31px;
  vertical-align: top;
  display: none;
}

.gl-01-ls-unit.current {
  display: inline-block;
}

.gl-01-ls-hd {
  font-size: 2.203rem;
  font-weight: 500;
  line-height: 1.22882433046;
  letter-spacing: -0.441px;
}

.gl-01-ls-img {
  padding-top: 67%;
  margin-bottom: 8px;
  margin-top: 12px;
  background-size: cover;
  background-position: center;
}

.gl-01-ls-a,
.step-lnk,
.job-lnk,
.residence-lnk,
.counter-lnk {
  width: 100%;
  display: block;
  height: 54px;
  line-height: 54px;
  text-align: center;
  font-size: 1.5848rem;
  font-weight: 400;
  letter-spacing: -0.317px;
  border: 2px solid #000;
  border-radius: 28px;
}

.step-lnk {
  margin-top: 10px;
}

.gl-01-ls-a+a {
  margin-top: 8px;
}


.gl-02-lst {
  margin-top: 64px;
}

.gl-02-lst li {
  font-size: 0;
  letter-spacing: 0;
  margin-bottom: 32px;
}

.attraction-cont {
  vertical-align: middle;
  display: inline-block;
  width: 39%;
  box-sizing: border-box;
  padding-left: 42px;
  padding-right: 42px;
  border-left: 2px solid #000;
  border-right: 2px solid #000;
}

.attraction-img {
  vertical-align: middle;
  display: inline-block;
  width: calc(61% - 32px);
}

.attraction-num {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.30944444444;
  letter-spacing: -0.36px;
  margin-bottom: 11px;
}

.attraction-hd {
  text-align: center;
  font-size: 2.0rem;
  font-weight: 500;
  line-height: 1.1785;
  letter-spacing: -0.4px;
  margin-bottom: 11px;
}

.attraction-p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.56875;
  letter-spacing: -0.32px;
}

.gl-02-lst>li>div:first-child {
  margin-right: 32px;
}

.type-lst {
  margin-top: 57px;
}

.type-lst li {
  border: solid 2px #000;
  border-radius: 19px;
  padding: 40px 45px;
  margin-bottom: 15px;
  display: table;

}

.type-lst .type-01 {
  background-color: #FFEEC2;
}

.type-lst .type-02 {
  background-color: #C1E8C8;
}

.type-lst .type-03 {
  background-color: #DBEAEC;
}

.type-lst .type-04 {
  background-color: #C8BDDC;
}

.type-lst .type-05 {
  background-color: #FFC2C2;
}

.type-lst .type-06 {
  background-color: #FFBB9D;
}

.type-hd {
  display: table-cell;
  width: 34%;
  vertical-align: middle;
  font-size: 3.0rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.3px;
}

.type-cont {
  display: table-cell;
  width: 66%;
  vertical-align: middle;
  font-size: 1.803rem;
  font-weight: 400;
  line-height: 1.78036605657;
  letter-spacing: -0.361px;
}

.step-lst {
  margin-top: 87px;
  padding-left: 30px;
}

.step-lst li {
  background-color: #fff;
  border-radius: 14px;
  padding: 30px 55px;
  display: table;
  margin-bottom: 10px;
  counter-increment: step-lst;
  position: relative;
}

.step-lst>li:before {
  content: counter(step-lst);
  position: absolute;
  font-size: 3.1434rem;
  display: block;
  width: 60px;
  height: 60px;
  line-height: 60px;
  background-color: #000;
  color: #fff;
  top: 0;
  bottom: 0;
  margin: auto;
  left: -30px;
  text-align: center;
  border-radius: 30px;

}

.step-hd {
  display: table-cell;
  vertical-align: middle;
  width: 45%;
  font-size: 2.203rem;
  font-weight: 500;
  line-height: 1.22882433046;
  letter-spacing: -0.441px;
}

.step-cont-wrap {
  width: 55%;
  display: table-cell;
  vertical-align: middle;
}

.step-lnk+a {
  margin-top: 10px;
}

.cost-box {
  margin-top: 65px;
  background-color: #fff;
  border-radius: 23px;
  padding: 25px 84px 57px;
}

.guide-lst-sbhd-wrap {
  text-align: center;
  margin-bottom: 30px
}

.guide-lst-sbhd {
  display: inline-block;
  text-align: center;
  font-size: 2.0rem;
  font-weight: 500;
  line-height: 2.25;
  letter-spacing: -0.2px;
  padding: 0 10px 10px;
  ;
  border-bottom: solid 1px #000;
}

.cost-lst {
  width: calc(100% + 22px);
  margin-left: -11px;
  margin-right: -11px;
  font-size: 0;
  letter-spacing: 0;
}

.cost-lst li {
  width: calc(33.3% - 22px);
  margin-left: 11px;
  margin-right: 11px;
  display: inline-block;
  vertical-align: top;
  margin-bottom: 22px;
  margin-top: 30px;
}

.cost-img {
  padding-top: 52%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.const-hd {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.5;
  letter-spacing: -0.18px;
}

.cost-cont {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.56875;
  letter-spacing: -0.32px;
}

.graph-box {
  background-color: #fff;
  border-radius: 23px;
  padding: 25px 51px 44px;
  margin-top: 36px;
}

.graph-p {
  font-size: 1.803rem;
  font-weight: 400;
  line-height: 2.27953410982;
  letter-spacing: -0.361px;
  margin-top: 24px;
  margin-bottom: 24px;
}

.job-lst-wrap,
.residence-box {
  background-color: #fff;
  border-radius: 23px;
  padding: 35px 40px 1px;
  margin-top: 50px;
}

.job-lst li,
.residence-lst li {
  display: table;
  width: 100%;
  counter-increment: job-lst;
  position: relative;
  margin-bottom: 53px;
}

.job-lst>li:before,
.residence-lst>li:before {
  color: #FFF;
  content: counter(job-lst);
  position: absolute;
  display: block;
  width: 39px;
  height: 39px;
  line-height: 39px;
  background-color: #000;
  top: 0;
  left: 0px;
  text-align: center;
  border-radius: 30px;
  font-size: 2.0097rem;
  font-weight: 400;
}

.job-cont-box,
.residence-lst-cont {
  display: table-cell;
  width: 66%;
  padding-left: 64px;
  box-sizing: border-box;
  padding-right: 34px;
  margin-bottom: 15px;
}

.job-img-wrap,
.residence-img-wrap {
  display: table-cell;
  width: 34%;
  vertical-align: top;
}

.job-img,
.residence-img {

  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  padding-top: 88%;
  height: 0;
}

.job-lnk+a,
.residence-lnk+a {
  margin-top: 15px;
}

.job-hd,
.residence-lst-cont-hd {
  margin-bottom: 15px;
  font-size: 2.203rem;
  font-weight: 500;
  line-height: 1.22882433046;
  letter-spacing: -0.441px;
}

.job-cont,
.residence-lst-cont-p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.56875;
  letter-spacing: -0.32px;
  margin-bottom: 15px;
}

.recruit-box {
  background-color: #fff;
  border-radius: 23px;
  padding: 35px 40px 40px;
  margin-top: 40px;
}

.recruit-cont-box-wrap {
  margin-top: 24px;
  margin-bottom: 24px;
  display: table;
  width: 100%;
}

.recruit-cont-box {
  display: table-cell;
  width: 65%;
  box-sizing: border-box;
  font-size: 1.803rem;
  font-weight: 400;
  line-height: 2.27953410982;
  letter-spacing: -0.361px;
  padding-right: 24px;
}

.recruit-img-box {
  display: table-cell;
  background-repeat: no-repeat;
  width: 35%;
  height: 0;
  padding-top: 27%;
}

.support-box {
  position: relative;
  background-color: #fff;
  margin-top: 22px;
  display: table;
  width: 100%;
  padding-left: 17%;
  padding-right: 17%;
  box-sizing: border-box;
  padding-top: 30px;
  padding-bottom: 30px;
  transition: 0.8s;
}

.support-box:hover {
  opacity: 0.8;
}

.support-img {
  width: 105px;
  height: 105px;
  display: table-cell;
  vertical-align: middle;
}

.support-cont {
  display: table-cell;
  width: calc(100% - 105px);
  vertical-align: middle;
  box-sizing: border-box;
  padding-left: 31px;
}

.counter-lst li {
  background-color: #fff;
  border-radius: 25px;
  margin-bottom: 16px;
  padding: 24px 26.5px;
  display: table;
  width: 100%;
  box-sizing: border-box;
}

.counter-hd {
  display: table-cell;
  width: 36%;
}

.counter-cont {
  display: table-cell;
  width: 64%;
  box-sizing: border-box;
  padding-left: 17px;
}

.counter-tag {
  text-align: center;
  font-size: 2.0rem;
  font-weight: 500;
  line-height: 34px;
  height: 34px;
  letter-spacing: -0.2px;
  background-color: #FFC2C2;
  border-radius: 18px;
}

.counter-tag.tokyo {
  background-color: #DBEAEC;
}

.counter-name {
  margin-top: 15px;
  text-align: center;
  font-size: 2.0rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.2px;
}

.counter-cont-01 {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.5625;
  letter-spacing: -0.32px;
  border-bottom: solid 1px #000;
  padding-bottom: 18px;
}

.counter-cont-02 {
  padding-top: 10px;
}

.counter-cont-02 dl {
  display: table;
}

.counter-cont-02 dt {
  display: table-cell;
  width: 90px;
}

.counter-cont-02 dd {
  display: table-cell;
  width: calc(100% - 90px);
}

.counter-lnk {
  margin-top: 15px;
}

.question-lst dl {
  border-bottom: 2px solid #000;
  padding-left: 65px;
  box-sizing: border-box;
}

.question-lst dt {
  position: relative;
  display: table;
  padding-right: 67px;
  width: 100%;
  box-sizing: border-box;
}

.question-lst dt p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.66666666667;
  letter-spacing: -0.18px;
  height: 80px;
  box-sizing: border-box;
  vertical-align: middle;
  display: table-cell;
  padding-top: 10px;
  padding-bottom: 10px;
  width: 100%;
}

.question-lst dt::before {
  content: 'Q.';
  width: 37px;
  height: 37px;
  display: block;
  position: absolute;
  background-color: #B88B68;
  border-radius: 19px;
  left: -65px;
  top: 0;
  bottom: 0;
  margin: auto;
  text-align: center;
  line-height: 37px;
  color: #fff;
}

.question-lst dd {
  display: none;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.56875;
  letter-spacing: -0.32px;
  padding-bottom: 31px;
}

.question-lst .opened dd {
  display: block;
  height: auto;
}

.oc-bnt {
  position: absolute;
  width: 33px;
  height: 33px;
  cursor: pointer;
  right: 0;
  top: 0;
}

.oc-bnt::before {
  content: '';
  display: block;
  position: absolute;
  width: 29px;
  height: 3px;
  background-color: #B88B68;
  left: 0;
  right: 0;
  top: 10px;
  bottom: 0;
  margin: auto;
}

.oc-bnt::after {
  content: '';
  display: block;
  position: absolute;
  width: 29px;
  height: 3px;
  background-color: #B88B68;
  left: 0;
  right: 0;
  top: 10px;
  bottom: 0;
  margin: auto;
  transform: rotate(90deg);
  transition: 0.5s;
}

.opened .oc-bnt::after {
  transform: rotate(0deg);
}

.step-cont {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.56875;
  letter-spacing: -0.32px;
}
@media only screen and (min-width: 1001px) and (max-width: 1790px) {
.guide-nav {
  top: 170px;
}
.nnl li a {
    font-size: 1.6rem;
}
}
@media only screen and (min-width: 1001px) and (max-width: 1205px) {
.gl-01-ls-hd span {
    font-size: 18px;
}
.gl-01-num {
    margin-right: 5px;
    width: 30px;
    height: 30px;
    line-height: 30px;
    border-radius: 15px;
}
.gl-01-ls-unit {
    padding: 21px 30px;
}
}



@media only screen and (max-width: 1000px) {
  .sec-01 {
    margin-top: 41px;
  }

  .guide-nav {
    float: none;
    width: 100%;
    position: static;
  }

  .nd {
    border-radius: 18px;
    background-color: #FFF;
    padding: 28px 20px;
    box-sizing: border-box;
  }

  .guide-lst {
    float: none;
    width: 100%;
    padding-left: 0px;
  }

  .guide-lst-hd {
    margin-top: 140px;
  }

  .guide-lst-hd-sb {
    font-size: 1.8rem;
    font-weight: 400;
    line-height: 1.94444444444;
    letter-spacing: -0.36px;
  }

  .mapcatch-sp {
    text-align: center;
    margin-top: 92px;
  }

  .mapcatch-sp p {
    display: inline-block;
    font-size: 1.9717rem;
    font-weight: 500;
    line-height: 1.22878734087;
    letter-spacing: -0.394px;
    position: relative;
  }

  .mapcatch-sp p::before {
    content: '';
    display: block;
    position: absolute;
    width: 38px;
    height: 2px;
    background-color: #000;
    transform: rotate(45deg);
    left: -35px;
    bottom: 17px;
  }

  .mapcatch-sp p::after {
    content: '';
    display: block;
    position: absolute;
    width: 38px;
    height: 2px;
    background-color: #000;
    transform: rotate(-45deg);
    right: -35px;
    bottom: 17px;
  }

  .gl-01-map {
    position: relative;
  }

  .gl-01-map::after {
    position: absolute;
    content: '';
    display: block;
    width: 40%;
    height: 20%;
    background-color: #EBE8E4;
    bottom: 0%;
    left: 4%;
  }

  .gl-01-nv .cat-02::after {
    content: '';
    display: block;
  }

  .gl-01-nv li {
    display: inline-block;
    font-size: 1.9432rem;
    font-weight: 500;
    letter-spacing: -0.194px;
    line-height: 32px;
    height: 32px;
    border-radius: 16px;
    width: auto;
    margin-right: 11px;
    padding: 0 33px;
    margin-bottom: 11px;
  }

  .gl-01-nv {
    margin-top: 38px;
  }

  .gl-01-ls-wrap {
    margin-top: 38px;
    width: calc(100% + 14px);
    margin-left: -7px;
    margin-right: -7px;
  }

  .gl-01-ls-unit {
    width: calc(50% - 14px);
    margin-left: 7px;
    margin-right: 7px;
    padding: 16px 15px;
    border-radius: 10px;
    margin-bottom: 14px;
  }

  .gl-01-num {
    margin-right: 7px;
    width: 18px;
    height: 18px;
    border-radius: 9px;
    font-size: 1.0rem;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: -0.098px;
  }

  .gl-01-ls-hd {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 0.880214285714;
    letter-spacing: -0.28px;
    height: 25px;
  }

  .gl-01-ls-hd span:last-child {
    max-width: calc(100% - 28px);
  }

  .gl-02-lst>li>div:first-child {
    margin-left: auto;
    margin: auto;
  }

  .gl-01-ls-a,
  .step-lnk,
  .job-lnk,
  .residence-lnk,
  .counter-lnk {
    height: 33px;
    line-height: 33px;
    font-size: 1.2234rem;
    letter-spacing: -0.245px;
    border: 2px solid #000;
    border-radius: 24px;
  }

  a.external::after {
    width: 16px;
    height: 16px;
    vertical-align: -2px;
    margin-left: 8px;
  }

  .gl-01-ls-a+a {
    margin-top: 4px;
  }

  .guide-unit {
    margin-bottom: 164px;
  }

  .attraction-cont {
    display: block;
    max-width: 310px;
    width: 100%;
    box-sizing: border-box;
    margin: auto;
    padding-left: 42px;
    padding-right: 42px;
    border-left: 2px solid #000;
    border-right: 2px solid #000;
  }

  .attraction-img {
    width: 100%;
    padding: 0 17px;
    box-sizing: border-box;
    margin-top: 33px;
    margin-bottom: 32px;
    text-align: center;
  }

  .type-lst {
    margin-top: 38px;
    width: calc(100% + 16px);
    margin-left: -8px;
    margin-right: -8px;
    font-size: 0;
    letter-spacing: 0;
  }

  .type-lst li {
    width: calc(50% - 16px);
    box-sizing: border-box;
    margin-left: 8px;
    margin-right: 8px;
    border-radius: 9px;
    padding: 10px 13px;
    margin-bottom: 11px;
    display: inline-block;
    vertical-align: top;
  }

  .type-hd {
    display: block;
    width: 100%;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.50394444444;
    letter-spacing: -0.36px;
    margin-bottom: 5px;
  }

  .type-cont {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: -0.28px;
  }

  .type-hd br {
    display: none;
  }

  .step-lst>li:before {
    position: static;
    font-size: 2.077rem;
    display: inline-block;
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 20px;
    vertical-align: middle;
  }

  .step-lst li {
    border-radius: 14px;
    padding: 20px 19px;
    display: block;
    margin-bottom: 10px;
  }

  .step-lst {
    padding-left: 0px;
  }

  .step-hd {
    display: inline-block;
    width: calc(100% - 70px);
    font-size: 2.203rem;
    font-weight: 500;
    line-height: 1.22882433046;
    letter-spacing: -0.441px;
    vertical-align: middle;
    margin-left: 22px;
  }

  .step-hd br {
    display: none;
  }

  .step-cont-wrap {
    width: 100%;
    display: block;
  }

  .step-cont {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.56875;
    letter-spacing: -0.32px;
  }

  .step-lnk {
    height: 54px;
    line-height: 54px;
    font-size: 1.5848rem;
    letter-spacing: -0.317px;
    border-radius: 27px;
  }

  .cost-box {
    margin-top: 38px;
    padding: 25px 19px 25px;
  }

  .cost-lst {
    width: calc(100% + 18px);
    margin-left: -9px;
    margin-right: -9px;
    font-size: 0;
    letter-spacing: 0;
  }

  .cost-lst li {
    width: calc(50% - 18px);
    margin-left: 9px;
    margin-right: 9px;
    margin-bottom: 17px;
    margin-top: 0px;
  }

  .const-hd {
    text-align: center;
    font-size: 1.4211rem;
    font-weight: 500;
    line-height: 2.49996481599;
    letter-spacing: -0.142px;
  }

  .cost-cont {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: -0.28px;
  }

  .graph-box {
    border-radius: 23px;
    padding: 35px 20px 25px;
    margin-top: 12px;
  }

  .graph-p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 2.1875;
    letter-spacing: -0.32px;
  }

  .job-lst li,
  .residence-lst li {
    display: block;
    width: 100%;
    counter-increment: job-lst;
    position: relative;
    margin-bottom: 53px;
  }

  .job-cont-box,
  .residence-lst-cont {
    display: block;
    width: 100%;
    padding-left: 0px;
    box-sizing: border-box;
    padding-right: 0px;
    margin-bottom: 15px;
  }

  .job-img,
  .residence-img {
    display: block;
    width: 100%;
    padding-top: 67%;
    height: 0;
  }

  .job-hd,
  .residence-lst-cont-hd {
    padding-left: 2.5em;
  }

  .job-lst>li:before,
  .residence-lst>li:before {
    top: -7px;
  }

  .job-cont,
  .residence-lst-cont-p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.56875;
    letter-spacing: -0.32px;
    margin-bottom: 15px;
    margin-top: 15px;
  }

  .job-lnk,
  .residence-lnk,
  .counter-lnk {
    height: 54px;
    line-height: 54px;
    font-size: 1.5848rem;
    letter-spacing: -0.317px;
    border-radius: 27px;
  }

  .recruit-box {
    background-color: #fff;
    border-radius: 23px;
    padding: 35px 20px 25px;
    margin-top: 12px;
  }

  .recruit-cont-box-wrap {
    margin-top: 24px;
    margin-bottom: 24px;
    display: block;
    width: 100%;
  }

  .recruit-cont-box {
    display: block;
    width: 100%;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 2.1875;
    letter-spacing: -0.32px;
    padding-right: 0px;
  }

  .recruit-img-box {
    margin-top: 20px;
    display: block;
    background-repeat: no-repeat;
    width: 100%;
    padding-top: 100%;
    background-size: cover;
  }

  .job-lst-wrap,
  .residence-box {
    background-color: #fff;
    border-radius: 23px;
    padding: 35px 20px 1px;
    margin-top: 50px;
  }

  .support-box {
    margin-top: 22px;
    display: table;
    padding: 10px;
  }

  .support-cont {
    display: table-cell;
    width: calc(100% - 105px);
    padding-left: 14px;
    font-size: 1.803rem;
    line-height: 1.39212423738;
    letter-spacing: -0.361px;
  }

  .counter-hd {
    display: block;
    width: 100%;
    padding: 0 32px;
    box-sizing: border-box;
  }

  .counter-lst li {
    background-color: #fff;
    border-radius: 25px;
    padding: 24px 16px;
    display: block;
    width: 100%;
  }

  .counter-cont {
    display: block;
    width: 100%;
    padding-left: 17px;
  }

  .counter-tag {
    border-radius: 18px;
    font-size: 2.0rem;
    line-height: 34px;
    height: 34px;
  }

  .counter-name {
    line-height: 28px;
    letter-spacing: -0.2px;
    margin-bottom: 11px;
  }

  .counter-cont-01 {
    border-bottom: solid 1px #000;
    padding-bottom: 18px;
  }
.gl-01-map {
    padding-top: 79%;
    width: calc(100% + 28px);
    margin-left: -14px;
}
}