@charset "UTF-8";
/* 
font-family: "Noto Sans JP", sans-serif;
font-family: "Noto Serif", serif;
font-family: "Zen Kaku Gothic New", sans-serif;
*/
body {
  font-size: 16px;
  font-family: "游ゴシック", "Zen Kaku Gothic New", sans-serif;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #222222;
  min-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

/*--------------------cmn--------------------*/
.cmn_ttl {
  font-size: 70px;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 300;
  color: #8c8c8c;
  text-align: center;
  font-family: "Noto Serif", serif;
  padding-bottom: 0.6714285714em;
  position: relative;
  z-index: 1;
  margin-bottom: 60px;
}
.cmn_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 0.4285714286em;
  height: 0.0142857143em;
  background: #8c8c8c;
  transform: translate(-50%, 0%);
}

.cmn_dl {
  width: 100%;
}
.cmn_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}
.cmn_dl_box dt {
  width: 270px;
  padding: 15px;
  border-bottom: 1px solid #8c8c8c;
  text-align: center;
}
.cmn_dl_box dd {
  width: calc(100% - 270px);
  padding: 15px 15px 15px 50px;
  border-bottom: 1px solid #cccccc;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.cmn_dl_box dd span {
  width: 30%;
  display: block;
  margin-top: -7px;
  margin-left: 10px;
}
.cmn_dl_box dd span img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cmn_dl_box:first-child dt {
  padding-top: 0;
}
.cmn_dl_box:first-child dd {
  padding-top: 0;
}

.cmn_btn {
  width: 270px;
  padding: 17px 20px;
  background: #e5e4dc;
  position: relative;
  z-index: 1;
}
.cmn_btn:not(:last-child) {
  margin-bottom: 20px;
}
.cmn_btn::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 20px;
  width: 41px;
  height: 23px;
  transform: translate(0%, -50%);
  background: url(/img/common/arrowb.png) no-repeat center center/contain;
}
.cmn_btn p {
  font-size: 17px;
  line-height: enm(24, 17);
  letter-spacing: 0.2em;
  font-weight: 700;
  color: #222222;
}

/*--------------------cmn--------------------*/
/*--------------------header--------------------*/
.header {
  width: 100%;
  position: absolute;
  z-index: 10;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0%);
  padding: 20px 50px;
}
.header_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.header_right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
}
.header_nav {
  border-right: 1px solid #fff;
  padding-right: 20px;
}
.header_nav_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 30px;
}
.header_nav_item {
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #fff;
  position: relative;
  z-index: 1;
}
.header_nav_item a {
  color: #fff;
}
.header_info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 25px;
}
.header_tel p {
  font-size: 17px;
  line-height: 1;
  letter-spacing: 0em;
  font-weight: 500;
  color: #fff;
}
.header_sns {
  margin-top: 4px;
}

.dropdown__lists {
  display: none; /*デフォルトでは非表示の状態にしておく*/
  width: 140px;
  position: absolute;
  top: 25px;
  left: 50%;
  transform: translate(-50%, 0%);
  background-color: rgba(255, 255, 255, 0.3);
  padding: 15px 5px;
  text-align: center;
}

.gnavi__list:hover .dropdown__lists {
  display: block; /*Gナビメニューにホバーしたら表示*/
}

.gnavi__list p {
  margin-bottom: -10px;
  padding-bottom: 10px;
}

.dropdown__list {
  transition: all 0.3s;
  position: relative;
}
.dropdown__list:not(:last-child) {
  margin-bottom: 15px;
}

.dropdown__list a {
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #fff;
}

/*--------------------header--------------------*/
/*--------------------footer--------------------*/
.footer {
  width: 100%;
  padding: 60px 0 100px;
  background: #262626;
}
.footer_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.footer_logo {
  margin-bottom: 40px;
}
.footer_address {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  margin-bottom: 15px;
}
.footer_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  width: 380px;
  margin-bottom: 30px;
}
.footer_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
}
.footer_dl_box dt {
  padding-right: 10px;
  border-right: 1px solid #fff;
  margin-right: 10px;
}
.footer_link {
  width: 380px;
  border: 1px solid #fff;
  padding: 15px 20px;
  position: relative;
  z-index: 1;
}
.footer_link::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 20px;
  width: 41px;
  height: 23px;
  transform: translate(0%, -50%);
  background: url(/img/common/arrow.png) no-repeat center center/contain;
}
.footer_link p {
  font-size: 17px;
  line-height: 1.4117647059em;
  letter-spacing: 0.15em;
  font-weight: 700;
  color: #fff;
}
.footer_nav {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 90px;
  margin-bottom: 136px;
}
.footer_nav_list:first-child .footer_nav_item:nth-child(2) {
  margin-bottom: 25px;
}
.footer_nav_list:first-child .footer_nav_item:nth-child(3) {
  margin-bottom: 25px;
}
.footer_nav_item {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
}
.footer_nav_item:not(:last-child) {
  margin-bottom: 35px;
}
.footer_nav_item a {
  color: #fff;
}

.copy_right {
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.08em;
  font-weight: 500;
  color: #808080;
  font-family: "Noto Sans JP", sans-serif;
}
.copy_right a {
  color: #808080;
}

/*--------------------footer--------------------*/
/*--------------------mv--------------------*/
.mv {
  width: 100%;
  position: relative;
  z-index: 1;
  height: clamp(606.66px, 47.3958333333vw, 910px);
}
.mv_catch {
  width: 19.9479166667%;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.mv_wrap {
  position: absolute;
  z-index: -1;
  bottom: 30px;
  right: 50px;
  transform: translate(0%, 0%);
}
.mv_btn {
  width: 270px;
  padding: 8.5px 20px;
  border: 1px solid #fff;
  position: relative;
  z-index: 1;
}
.mv_btn:not(:last-child) {
  margin-bottom: 20px;
}
.mv_btn::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 20px;
  width: 41px;
  height: 23px;
  transform: translate(0%, -50%);
  background: url(/img/common/arrow.png) no-repeat center center/contain;
}
.mv_btn p {
  font-size: 17px;
  line-height: enm(24, 17);
  letter-spacing: 0.2em;
  font-weight: 700;
  color: #fff;
}

/*--------------------swiper--------------------*/
.swiper {
  position: absolute;
  z-index: -5;
  left: 0%;
  top: 0%;
  width: 100%;
  height: 100%;
}

.swiper-slide {
  width: 100%;
  height: 100%;
}

.swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*--------------------swiper--------------------*/
/*--------------------mv--------------------*/
/*--------------------sv--------------------*/
.sv {
  width: 100%;
  height: 570px;
  position: relative;
  z-index: 1;
}
.sv_img {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -3;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.sv_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sv_catch {
  width: 100%;
  text-align: center;
  font-size: 66px;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: 500;
  color: #fff;
  position: absolute;
  z-index: -2;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.sv_wrap {
  position: absolute;
  z-index: -1;
  bottom: 30px;
  right: 50px;
  transform: translate(0%, 0%);
}
.sv_btn {
  width: 270px;
  padding: 8.5px 20px;
  border: 1px solid #fff;
  position: relative;
  z-index: 1;
}
.sv_btn:not(:last-child) {
  margin-bottom: 20px;
}
.sv_btn::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 20px;
  width: 41px;
  height: 23px;
  transform: translate(0%, -50%);
  background: url(/img/common/arrow.png) no-repeat center center/contain;
}
.sv_btn p {
  font-size: 17px;
  line-height: enm(24, 17);
  letter-spacing: 0.2em;
  font-weight: 700;
  color: #fff;
}

/*--------------------sv--------------------*/
/*--------------------company--------------------*/
.company {
  width: 100%;
  padding-bottom: 0;
}
.company .cmn_dl {
  margin-bottom: 70px;
}

.company2 {
  width: 100%;
  padding-bottom: 0;
}
.company2 .cmn_dl {
  margin-bottom: 70px;
}
.company2_ttl {
  font-size: 32px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  position: relative;
  color: #222222;
  z-index: 1;
  margin-bottom: 80px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.company2_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 0.9375em;
  height: 0.03125em;
  background: #8c8c8c;
  transform: translate(-50%, 0%);
}

.googlemap {
  width: 100%;
  height: 430px;
}
.googlemap iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border: none;
}

/*--------------------company--------------------*/
/*--------------------gai--------------------*/
.service {
  width: 100%;
}
.service_flex {
  width: 1180px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: row-reverse;
  gap: 55px;
}
@media screen and (max-width: 1280px) {
  .service_flex {
    margin: 0 auto;
  }
}
.service_img {
  width: 560px;
  height: 406px;
}
.service_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.service_box {
  width: calc(100% - 615px);
}
.service_ttl {
  margin-bottom: 40px;
  text-align: left;
}
.service_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 0%;
  width: 0.4285714286em;
  height: 0.0142857143em;
  background: #8c8c8c;
  transform: translate(0%, 0%);
}
.service_txt {
  font-size: 17px;
  line-height: 2.2352941176em;
  letter-spacing: 0.06em;
  font-weight: 500;
}

.area {
  width: 100%;
  background: url(/img/gai/bgarea.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
}
.area_flex {
  width: 910px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 45px;
  margin: 0 auto;
}
.area_img {
  width: 580px;
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 50%;
  transform: translate(80%, -50%);
  height: 664px;
}
.area_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.area_box {
  width: calc(100% - 580px);
}
.area_ttl {
  text-align: left;
  margin-bottom: 40px;
}
.area_ttl::before {
  left: 0;
  transform: translate(0%, 0%);
}
.area_txt {
  font-size: 16px;
  line-height: 2.125em;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.add {
  width: 100%;
}
.add_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}
.add_flex:not(:last-child) {
  margin-bottom: 100px;
  flex-direction: row-reverse;
}
.add_flex:first-child .add_box {
  padding: 80px 15px 88px 80px;
}
.add_flex:first-child .add_img {
  margin-right: -90px;
}
.add_flex:last-child .add_img {
  margin-left: -90px;
}
.add_flex:last-child .add_box {
  padding: 80px 80px 88px 15px;
}
.add_img {
  width: 700px;
  height: 470px;
  margin-top: 40px;
  z-index: 2;
}
.add_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.add_box {
  width: 670px;
  background: #f0f0f0;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.add_box_ttl {
  font-size: 30px;
  line-height: 1.5333333333em;
  letter-spacing: 0.2em;
  font-weight: 500;
  position: relative;
  z-index: 1;
  padding-bottom: 1.4em;
  text-align: center;
  margin-bottom: 32px;
}
.add_box_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 0.0333333333em;
  height: 0.6666666667em;
  background: #a6a6a6;
  transform: translate(-50%, 0%);
}
.add_txt {
  text-align: center;
  font-size: 16px;
  line-height: 2.125em;
  letter-spacing: 0.06em;
  font-weight: 500;
}

.flow {
  width: 100%;
  background: #f0f0f0;
}
.flow_item {
  background: #fff;
  width: 100%;
  padding: 40px 80px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 60px;
}
.flow_item:not(:last-child) {
  margin-bottom: 30px;
}
.flow_img {
  width: 150px;
  height: 150px;
}
.flow_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.flow_box {
  width: calc(100% - 210px);
}
.flow_box_ttl {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  margin-bottom: 10px;
}
.flow_box_ttl_mini {
  font-size: 32px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #8c8c8c;
  font-family: "Noto Serif", serif;
  margin-right: 15px;
}
.flow_box_ttl_big {
  font-size: 50px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: #8c8c8c;
  font-family: "Noto Serif", serif;
  margin-right: 30px;
}
.flow_txt {
  font-size: 17px;
  line-height: 2.2352941176em;
  letter-spacing: 0.06em;
  font-weight: 500;
}

.info {
  width: 100%;
  padding: 100px 0;
}
.info_box {
  width: 100%;
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}
.info_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  width: calc(100% - 20px);
  height: calc(100% - 20px);
  transform: translate(-50%, -50%);
  border: 1px solid #fff;
}
.info_ttl {
  font-size: 70px;
  line-height: 1;
  letter-spacing: 0.07em;
  font-weight: 300;
  color: #fff;
  font-family: "Noto Serif", serif;
}
.info_txt {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  color: #fff;
  margin-top: 30px;
}
.info_btn {
  position: absolute;
  z-index: -1;
  bottom: 25px;
  right: 35px;
  transform: translate(0%, 0%);
}
.info_btn p {
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  color: #fff;
  position: relative;
  z-index: 1;
  padding-right: 3.75em;
}
.info_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 2.5625em;
  height: 1.4375em;
  transform: translate(0%, -50%);
  background: url(/img/common/arrow.png) no-repeat center center/contain;
}

#infogai .info_box {
  padding: 100px 65px;
  background: url(/img/gai/bgabout.png) no-repeat center center/cover;
}

#infokan .info_box {
  padding: 125px 65px;
  background: url(/img/kan/bgonline.png) no-repeat center center/cover;
}

/*--------------------gai--------------------*/
/*--------------------kan--------------------*/
.kan_page .add {
  background: #f0f0f0;
}
.kan_page .add_box {
  background: #fff;
}

/*--------------------kan--------------------*/
/*--------------------about--------------------*/
.gre {
  width: 100%;
  position: relative;
  z-index: 1;
}
.gre_inner {
  position: relative;
  z-index: 1;
}
.gre_inner::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 520px;
  right: -200px;
  width: 380px;
  height: 280px;
  transform: translate(0%, 0%);
  background: url(/img/about/img03.png) no-repeat center center/contain;
}
@media screen and (max-width: 1600px) {
  .gre_inner::before {
    width: 290px;
    height: 214px;
    top: 380px;
    right: -70px;
  }
}
.gre::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 120px;
  left: 0%;
  width: 590px;
  height: 640px;
  transform: translate(0%, 0%);
  background: url(/img/about/img01.png) no-repeat center center/contain;
}
@media screen and (max-width: 1800px) {
  .gre::before {
    width: 320px;
    height: 348px;
    top: 420px;
  }
}
.gre::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 160px;
  right: 0%;
  width: 530px;
  height: 505px;
  transform: translate(0%, 0%);
  background: url(/img/about/img02.png) no-repeat center center/contain;
}
@media screen and (max-width: 1600px) {
  .gre::after {
    width: 370px;
    height: 353px;
  }
}
.gre_txt {
  text-align: center;
}
.gre_txt p {
  font-size: 17px;
  line-height: 2.1176470588em;
  letter-spacing: 0.1em;
  font-weight: 500;
}
.gre_txt p:not(:last-child) {
  margin-bottom: 45px;
}

.servicea {
  width: 100%;
  background: #f0f0f0;
}
.servicea_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 50px;
  flex-direction: row-reverse;
}
.servicea_flex:not(:last-child) {
  margin-bottom: 60px;
}
.servicea_box {
  width: calc(100% - 560px);
}
.servicea_box_ttl {
  font-size: 56px;
  line-height: 1;
  letter-spacing: 0.12em;
  font-weight: 300;
  margin-bottom: 20px;
  color: #8c8c8c;
  font-family: "Noto Serif", serif;
}
.servicea_box_sub {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  position: relative;
  z-index: 1;
  padding-bottom: 1.2em;
  margin-bottom: 40px;
}
.servicea_box_sub::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 0%;
  width: 1.2em;
  height: 0.04em;
  transform: translate(0%, 0%);
  background: #a6a6a6;
}
.servicea_img {
  width: 510px;
  height: 385px;
}
.servicea_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.servicea_txt {
  font-size: 16px;
  line-height: 2.125em;
  letter-spacing: 0.04em;
  font-weight: 500;
  margin-bottom: 40px;
}

/*--------------------about--------------------*/
/*--------------------top--------------------*/
.top_about {
  width: 100%;
}
.top_about_ttl {
  font-size: 32px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  position: relative;
  text-align: center;
  padding-bottom: 0.9375em;
  color: #222222;
  z-index: 1;
  margin-bottom: 50px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.top_about_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 0.9375em;
  height: 0.03125em;
  background: #8c8c8c;
  transform: translate(-50%, 0%);
}
.top_about_txt {
  font-size: 17px;
  line-height: 2.2352941176em;
  letter-spacing: 0.1em;
  font-weight: 500;
  text-align: center;
  margin-bottom: 50px;
}
.top_about_btn {
  margin: 0 auto;
}

.sep {
  width: 100%;
  height: clamp(493.33px, 38.5416666667vw, 740px);
}
.sep img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top_page .top_service {
  padding-bottom: 0;
}
.top_page .servicea_flex:first-child {
  flex-direction: row;
}
.top_page .servicea_flex:not(:last-child) {
  margin-bottom: 80px;
}
.top_page .servicea_box {
  width: calc(100% - 630px);
}
.top_page .servicea_img {
  width: 580px;
  height: 380px;
}
.top_page .servicea_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

#infotop {
  position: relative;
  z-index: 1;
  padding-bottom: 125px;
}
#infotop::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 100%;
  height: 320px;
  transform: translate(-50%, 0%);
  background: #f0f0f0;
}
#infotop .info_box {
  padding: 125px 65px;
  background: url(/img/top/img03.png) no-repeat center center/cover;
}

.top_con {
  width: 100%;
  background: url(/img/top/bgcon.png) no-repeat center center/cover;
}
.top_con_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 30px;
}
.top_con_ttl {
  padding-bottom: 0.4285714286em;
  margin-bottom: 50px;
}
.top_con_txt {
  text-align: center;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  margin-bottom: 40px;
}
.top_con_tel p {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0em;
  font-weight: 500;
}
.top_con_tel p span {
  display: block;
  width: 90%;
  margin-top: -5px;
}
.top_con_btn {
  width: 360px;
  border: 1px solid #222222;
  padding: 20.5px;
}
.top_con_btn p {
  font-size: 17px;
  line-height: 1;
  letter-spacing: 0.16em;
  font-weight: 500;
  position: relative;
  z-index: 1;
  padding-left: 2em;
}
.top_con_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 1.4117647059em;
  height: 0.9411764706em;
  transform: translate(0%, -50%);
  background: url(/img/common/mailb.png) no-repeat center center/contain;
}
.top_con_btn p::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 2.4117647059em;
  height: 1.3529411765em;
  transform: translate(0%, -50%);
  background: url(/img/common/arrowb.png) no-repeat center center/contain;
}
.top_con_sns {
  width: 33px;
  height: 33px;
}
.top_con_sns img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top_news_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 60px;
  margin-bottom: 50px;
}
.top_news_ttl {
  width: 220px;
  padding: 0;
  margin-bottom: 0;
}
.top_news_ttl::before {
  display: none;
}
.top_news_post {
  width: calc(100% - 280px);
  border-top: 1px solid #8c8c8c;
  padding-top: 40px;
  margin-top: 40px;
}
.top_news_btn {
  text-align: right;
}
.top_news_btn p {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.2em;
  font-weight: 500;
  display: inline-block;
  position: relative;
  z-index: 1;
  padding-right: 3.75em;
}
.top_news_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 2.5625em;
  height: 1.4375em;
  transform: translate(0%, -50%);
  background: url(/img/common/arrowb.png) no-repeat center center/contain;
}

/*--------------------top--------------------*//*# sourceMappingURL=style.css.map */