@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;700;800&family=Shippori+Mincho&display=swap");
section, nav, article, aside, hgroup, header, footer, figure, figcaption, details {
  display: block;
}

html, body, div, span, applet, object, iframe, strong, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, legend, caption, tbody, tfoot, thead, table, label, tr, th, td, figure {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Shippori Mincho', serif;
  font-weight: 400;
  color: #000;
  line-height: 1.8;
}

li {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

a {
  text-decoration: none;
  color: #000;
}

img {
  vertical-align: top;
  max-width: 100%;
}

hr {
  height: 1px;
  background-color: #ccc;
  border: 0;
}

.video-container {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.video-container iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 1;
}

.pc_only {
  display: block;
}

.pc_only_inline {
  display: inline;
}

.sp_only,
.sp_only_inline {
  display: none;
}

.wrap {
  max-width: 1000px;
  padding: 0 30px;
  margin: 0 auto;
}
.wrap:after {
  content: "";
  display: block;
  clear: both;
}

.to_top {
  -webkit-transition: top .6s ease, opacity .6s ease;
  transition: top .6s ease, opacity .6s ease;
  position: relative;
  top: 50px;
  opacity: 0;
}

.isAnimate.show.to_top {
  top: 0;
  opacity: 1;
}

.to_top_left {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  position: relative;
  top: 50px;
  left: 50px;
  opacity: 0;
}

.isAnimate.show.to_top_left {
  top: 0;
  left: 0;
  opacity: 1;
}

.to_top_right {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  position: relative;
  top: 50px;
  right: 50px;
  opacity: 0;
}

.isAnimate.show.to_top_right {
  top: 0;
  right: 0;
  opacity: 1;
}

.h {
  text-align: center;
  font-size: 28px;
  line-height: 1.4;
}

.btn a {
  display: inline-block;
  padding: 14px 50px 14px 20px;
  border-radius: 4px;
  background: #1d1d1d;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.btn a:after {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background: url("../images/icon_sprite.png") no-repeat 0 -144px;
  background-size: 100% auto;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.btn a:hover {
  background: #373737;
}

.sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.sns li {
  width: 22px;
  height: 22px;
  margin: 0 10px;
}
.sns li a {
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("../images/icon_sprite.png");
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 100% auto;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.sns li a:hover {
  opacity: 0.8;
}
.sns li.yt {
  width: 30px;
  height: 30px;
}
.sns li.in a {
  background-position: 0 -22px;
}
.sns li.tw a {
  background-position: 0 -44px;
}
.sns li.ti a {
  background-position: 0 -66px;
}

.coming_soon {
  text-align: center;
}
.coming_soon h1 {
  font-size: 2rem;
}

/*=======================================
	layout
=======================================*/
header {
  text-align: center;
  padding-top: 80px;
  margin-bottom: 100px;
}
header .logo {
  font-family: "Montserrat", sans-serif;
  font-size: 28px;
  font-weight: bold;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 1rem;
}
header ul {
  line-height: 1.2;
}
header li {
  margin: 0 0 .6rem;
}
header li:last-of-type {
  margin-bottom: 0;
}
header li a {
  display: inline-block;
}
header li.current a {
  font-weight: bold;
  border-bottom: 1px solid #000;
  padding-bottom: .3rem;
  pointer-events: none;
}

footer {
  background: #f9f9f9;
  line-height: 1.4;
  padding: 50px 0 30px;
  margin-top: 130px;
}
footer ul {
  max-width: 160px;
  margin: 0 auto;
}
footer li {
  margin-bottom: 1em;
  padding-left: 18px;
  position: relative;
}
footer li:before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
}
footer li a {
  display: inline-block;
}
footer li a:hover {
  text-decoration: underline;
}
footer li.icon a {
  padding-right: 30px;
  position: relative;
}
footer li.icon a:after {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background-image: url("../images/icon_sprite.png");
  background-repeat: no-repeat;
  background-position: 0 -64px;
  background-size: 100% auto;
  position: absolute;
  top: 56%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
footer li.icon.line a:after {
  width: 18px;
  height: 18px;
  background-position: 0 -90px;
}
footer li.back {
  text-align: center;
  padding-left: 0;
}
footer li.back:before {
  display: none;
}
footer li.back a {
  padding-left: 30px;
  position: relative;
}
footer li.back a:after {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background-image: url("../images/icon_sprite.png");
  background-repeat: no-repeat;
  background-position: 0 -126px;
  background-size: 100% auto;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
}
footer p {
  font-size: 12px;
  text-align: center;
  margin-top: 40px;
}

/*=======================================
	home
=======================================*/
.home h1 {
  text-align: center;
  font-size: 28px;
  margin-bottom: 70px;
}
.home h1 + p {
  text-align: center;
  font-size: 18px;
  margin-bottom: 60px;
}
.home h1 + p span {
  font-size: .8888888em;
}
.home nav {
  font-size: 22px;
  line-height: 1.4;
  max-width: 300px;
  margin: 0 auto;
}
.home li {
  border-bottom: 1px solid #dbdbdb;
  margin-bottom: 10px;
}
.home li a {
  display: block;
  padding: 8px;
  position: relative;
}
.home li a:after {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background: url("../images/icon_sprite.png") no-repeat 0 -126px;
  background-size: 100% auto;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.home li a:hover:after {
  right: -5px;
}

/*=======================================
	biz
=======================================*/
.biz section {
  text-align: center;
  margin-bottom: 80px;
}
.biz h2 {
  margin-bottom: 30px;
}
.biz h2 span {
  display: inline-block;
  font-size: 22px;
  line-height: 1.4;
  padding: 0 40px;
  position: relative;
}
.biz h2 span:before,
.biz h2 span:after {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: #767676;
  position: absolute;
  top: 50%;
  left: 0;
}
.biz h2 span:after {
  left: auto;
  right: 0;
}
.biz .btn {
  margin-top: 30px;
}
.biz .btn a {
  min-width: 210px;
  text-align: left;
}

/*=======================================
	company
=======================================*/
.company .h {
  margin-bottom: 70px;
}
.company dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 820px;
  margin: 0 auto;
  line-height: 2;
}
.company dt, .company dd {
  margin-bottom: 30px;
}
.company dt {
  width: 140px;
  padding-right: 70px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  letter-spacing: 0.05em;
  position: relative;
}
.company dt:before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: #767676;
  position: absolute;
  top: 1em;
  right: 28px;
}
.company dd {
  width: 680px;
}
.company dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.company dd li {
  margin-right: 1em;
}
.company dd .s {
  font-size: .75em;
}
.company .sns {
  margin-top: 50px;
}

/*=======================================
	profile
=======================================*/
.profile figure {
  max-width: 240px;
  margin: 40px auto 50px;
  padding: 40px 0;
  position: relative;
}
.profile figure img {
  position: relative;
  z-index: 1;
}
.profile figure:before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background: #191b1f;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.profile figure + p {
  line-height: 2.7;
}
.profile .sns {
  margin-top: 80px;
}

/*=======================================
	news
=======================================*/
.news .h {
  margin-bottom: 60px;
}
.news dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  max-width: 640px;
  margin: 0 auto;
}
.news dt, .news dd {
  margin-bottom: 30px;
}
.news dt {
  width: 210px;
  padding-right: 70px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}
.news dt:before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: #767676;
  position: absolute;
  top: 1em;
  right: 40px;
}
.news dd {
  width: 430px;
}
.news dd a {
  text-decoration: underline;
  position: relative;
}
.news dd a:hover {
  text-decoration: none;
}
.news dd a[target="_blank"]:after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 14px;
  height: 14px;
  background: url("../images/icon_sprite.png") no-repeat 0 -84px;
  background-size: 100% auto;
  margin-left: .6em;
}

/*=======================================
	privacy
=======================================*/
.privacy a:hover {
  text-decoration: underline;
}
.privacy .wrap {
  font-size: 14px;
}
.privacy .h {
  font-size: 22px;
  margin-bottom: 50px;
}
.privacy dt {
  font-weight: bold;
  margin-top: 2em;
}

/*=======================================
	coming_soon
=======================================*/
.coming_soon .h {
  margin-bottom: 80px;
}
.coming_soon .btn {
  text-align: center;
}

@media only screen and (max-width: 820px) {
  .company dl {
    display: block;
    line-height: 1.8;
    text-align: center;
  }
  .company dt, .company dd {
    margin-bottom: 0;
  }
  .company dt {
    width: auto;
    padding-right: 0;
    margin-bottom: 5px;
  }
  .company dt:before {
    width: 30px;
    height: 1px;
    margin: 0 auto 30px;
    position: static;
    top: auto;
    right: auto;
  }
  .company dt:first-of-type:before {
    display: none;
  }
  .company dd {
    width: auto;
    margin: 0 0 30px;
  }
  .company dd ul {
    display: block;
  }
  .company dd li {
    margin: 0;
  }
  .company dd .s {
    margin-top: 1em;
  }
}
/******************************************************************************************

	sp size

******************************************************************************************/
@media only screen and (max-width: 640px) {
  .pc_only,
  .pc_only_inline {
    display: none;
  }

  .sp_only {
    display: block;
  }

  .sp_only_inline {
    display: inline;
  }

  body {
    font-size: calc(100vw / ( 640 / 26 ));
  }

  .wrap {
    padding: 0 calc(100vw / ( 640 / 40 ));
  }

  .h {
    font-size: calc(100vw / ( 640 / 34 ));
  }

  .btn a {
    padding: calc(100vw / ( 640 / 24 )) calc(100vw / ( 640 / 70 )) calc(100vw / ( 640 / 24 )) calc(100vw / ( 640 / 30 ));
    border-radius: calc(100vw / ( 640 / 4 ));
    font-size: calc(100vw / ( 640 / 26 ));
  }
  .btn a:after {
    width: calc(100vw / ( 640 / 28 ));
    height: calc(100vw / ( 640 / 28 ));
    background: url("../images/icon_sprite.png") no-repeat 0 calc(100vw / ( 640 / -224 ));
    background-size: 100% auto;
    right: calc(100vw / ( 640 / 20 ));
  }

  .sns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .sns li {
    width: 22px;
    height: 22px;
    margin: 0 10px;
  }
  .sns li a {
    display: block;
    width: 100%;
    height: 100%;
    background-image: url("../images/icon_sprite.png");
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: 100% auto;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
  }
  .sns li a:hover {
    opacity: 0.8;
  }
  .sns li.yt {
    width: 30px;
    height: 30px;
  }
  .sns li.in a {
    background-position: 0 -22px;
  }
  .sns li.tw a {
    background-position: 0 -44px;
  }
  .sns li.ti a {
    background-position: 0 -66px;
  }

  .coming_soon h1 {
    font-size: 1.5rem;
  }

  /*=======================================
  	layout
  =======================================*/
  header {
    padding-top: calc(100vw / ( 640 / 40 ));
    margin-bottom: calc(100vw / ( 640 / 80 ));
  }
  header .logo {
    font-size: calc(100vw / ( 640 / 28 ));
  }
  header ul {
    font-size: calc(100vw / ( 640 / 24 ));
  }

  footer {
    padding: calc(100vw / ( 640 / 70 )) 0 calc(100vw / ( 640 / 40 ));
    margin-top: calc(100vw / ( 640 / 120 ));
  }
  footer ul {
    max-width: calc(100vw / ( 640 / 220 ));
    font-size: calc(100vw / ( 640 / 22 ));
  }
  footer li {
    padding-left: calc(100vw / ( 640 / 18 ));
    position: relative;
  }
  footer li:before {
    width: calc(100vw / ( 640 / 8 ));
    height: calc(100vw / ( 640 / 8 ));
    border-right: calc(100vw / ( 640 / 2 )) solid #000;
    border-bottom: calc(100vw / ( 640 / 2 )) solid #000;
  }
  footer li.icon a {
    padding-right: calc(100vw / ( 640 / 30 ));
  }
  footer li.icon a:after {
    width: calc(100vw / ( 640 / 20 ));
    height: calc(100vw / ( 640 / 20 ));
    background-position: 0 calc(100vw / ( 640 / -80 ));
  }
  footer li.icon.line a:after {
    width: calc(100vw / ( 640 / 24 ));
    height: calc(100vw / ( 640 / 24 ));
    background-position: 0 calc(100vw / ( 640 / -120 ));
  }
  footer li.back a {
    padding-left: calc(100vw / ( 640 / 30 ));
  }
  footer li.back a:after {
    width: calc(100vw / ( 640 / 18 ));
    height: calc(100vw / ( 640 / 18 ));
    background-position: 0 calc(100vw / ( 640 / -128 ));
  }
  footer p {
    font-size: calc(100vw / ( 640 / 18 ));
    margin-top: calc(100vw / ( 640 / 80 ));
  }

  /*=======================================
  	home
  =======================================*/
  .home h1 {
    font-size: calc(100vw / ( 640 / 36 ));
    margin-bottom: calc(100vw / ( 640 / 60 ));
  }
  .home h1 + p {
    font-size: calc(100vw / ( 640 / 26 ));
    margin-bottom: calc(100vw / ( 640 / 80 ));
  }
  .home nav {
    font-size: calc(100vw / ( 640 / 28 ));
    max-width: calc(100vw / ( 640 / 340 ));
  }
  .home li {
    margin-bottom: calc(100vw / ( 640 / 20 ));
  }
  .home li a {
    padding: calc(100vw / ( 640 / 10 ));
  }
  .home li a:after {
    width: calc(100vw / ( 640 / 18 ));
    height: calc(100vw / ( 640 / 18 ));
    background: url("../images/icon_sprite.png") no-repeat 0 calc(100vw / ( 640 / -128 ));
    background-size: 100% auto;
  }
  .home li a:hover:after {
    right: calc(100vw / ( 640 / -6 ));
  }

  /*=======================================
  	biz
  =======================================*/
  .biz section {
    margin-bottom: calc(100vw / ( 640 / 110 ));
  }
  .biz section p {
    text-align: left;
  }
  .biz h2 {
    margin-bottom: calc(100vw / ( 640 / 40 ));
  }
  .biz h2 span {
    font-size: calc(100vw / ( 640 / 28 ));
    padding: 0 calc(100vw / ( 640 / 50 ));
  }
  .biz h2 span:before,
  .biz h2 span:after {
    width: calc(100vw / ( 640 / 30 ));
  }
  .biz .btn {
    margin-top: calc(100vw / ( 640 / 60 ));
  }
  .biz .btn a {
    min-width: calc(100vw / ( 640 / 420 ));
  }

  /*=======================================
  	company
  =======================================*/
  .company .h {
    margin-bottom: calc(100vw / ( 640 / 70 ));
  }
  .company dl {
    display: block;
    line-height: 1.8;
    text-align: center;
  }
  .company dt, .company dd {
    margin-bottom: 0;
  }
  .company dt {
    width: auto;
    padding-right: 0;
    margin-bottom: calc(100vw / ( 640 / 10 ));
  }
  .company dt:before {
    width: calc(100vw / ( 640 / 30 ));
    height: calc(100vw / ( 640 / 2 ));
    margin: 0 auto calc(100vw / ( 640 / 50 ));
    position: static;
    top: auto;
    right: auto;
  }
  .company dt:first-of-type:before {
    display: none;
  }
  .company dd {
    width: auto;
    margin: 0 0 calc(100vw / ( 640 / 50 ));
  }
  .company dd ul {
    display: block;
  }
  .company dd li {
    margin: 0;
  }
  .company dd .s {
    margin-top: 1em;
  }
  .company .sns {
    margin-top: calc(100vw / ( 640 / 80 ));
  }

  /*=======================================
  	profile
  =======================================*/
  .profile figure {
    max-width: calc(100vw / ( 640 / 360 ));
    margin: calc(100vw / ( 640 / 70 )) auto;
    padding: calc(100vw / ( 640 / 40 )) 0;
  }
  .profile figure + p {
    line-height: 2;
  }
  .profile .sns {
    margin-top: calc(100vw / ( 640 / 80 ));
  }

  /*=======================================
  	news
  =======================================*/
  .news .h {
    margin-bottom: calc(100vw / ( 640 / 30 ));
  }
  .news dl {
    display: block;
    text-align: center;
  }
  .news dt, .news dd {
    margin-bottom: 0;
  }
  .news dt {
    width: auto;
    padding-right: 0;
    padding-top: calc(100vw / ( 640 / 60 ));
    margin-bottom: calc(100vw / ( 640 / 20 ));
  }
  .news dt:before {
    display: none;
  }
  .news dd {
    width: auto;
    border-bottom: calc(100vw / ( 640 / 2 )) solid #eee;
    padding-bottom: calc(100vw / ( 640 / 60 ));
  }
  .news dd a[target="_blank"]:after {
    width: calc(100vw / ( 640 / 24 ));
    height: calc(100vw / ( 640 / 24 ));
    background: url("../images/icon_sprite.png") no-repeat 0 calc(100vw / ( 640 / -144 ));
    background-size: 100% auto;
  }
  .news dd:last-of-type {
    border-bottom: none;
  }

  /*=======================================
  	privacy
  =======================================*/
  .privacy .wrap {
    font-size: calc(100vw / ( 640 / 26 ));
  }
  .privacy .h {
    font-size: calc(100vw / ( 640 / 28 ));
    margin-bottom: calc(100vw / ( 640 / 50 ));
  }

  /*=======================================
  	coming_soon
  =======================================*/
  .coming_soon .h {
    margin-bottom: calc(100vw / ( 640 / 80 ));
  }
}
