@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@200;300;400;500;600;700;800;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Hind:wght@300;400;500;600;700&display=swap");
:root {
  --vw: 1vw;
}

html {
  font-size: 10px;
  margin: auto;
}

body {
  margin: auto;
  padding: 0;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, 游ゴシック体, "Yu Gothic", YuGothic, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #000;
  font-feature-settings: "palt";
  letter-spacing: 0.06em;
  background: #F2F2F2;
  font-weight: 500;
}
body.menuon {
  overscroll-behavior: none;
  overflow: hidden;
  height: 100vh;
}

img {
  vertical-align: bottom;
}

p, li, dt, dd, h3, th, td {
  font-size: 1.8rem;
  line-height: 2;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  p, li, dt, dd, h3, th, td {
    font-size: 1.5rem;
  }
}

a {
  text-decoration: none;
}

ul, dl, dt, dd {
  padding-left: 0;
  margin: auto;
}

h3 {
  margin: auto;
}

figure {
  margin: 0;
}

strong {
  font-weight: bold;
}

section {
  padding: 12rem 0;
}
@media only screen and (max-width: 767px) {
  section {
    padding: 8rem 0 4rem;
  }
}

/*--------------------------------------------------------------
class
--------------------------------------------------------------*/
.en {
  font-family: "Hind", sans-serif;
}

._ib {
  display: inline-block;
}

._nw {
  white-space: nowrap;
}

@media print, screen and (min-width: 768px) {
  ._sp:not(._pc) {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  ._pc:not(._sp) {
    display: none !important;
  }
}
.nameandtype {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  .nameandtype {
    margin-bottom: 2.4rem;
  }
}

.h_name {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.4375;
  margin-top: -0.45em;
}
@media only screen and (max-width: 767px) {
  .h_name {
    font-size: 2.2rem;
    margin-top: auto;
  }
}

p.type {
  font-size: 2rem;
  font-weight: 500;
}
@media only screen and (max-width: 767px) {
  p.type {
    font-size: 1.7rem;
  }
}

.spec {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 1.8;
}

.h_en {
  text-align: center;
  margin-bottom: 10rem;
}
@media only screen and (max-width: 767px) {
  .h_en {
    margin-bottom: 5.6rem;
  }
  .h_en img {
    height: 2.2rem;
    width: auto;
  }
}

.inner {
  max-width: 108rem;
  padding: 0 4rem;
  margin: auto;
}
@media only screen and (max-width: 767px) {
  .inner {
    padding: 0 2.4rem;
  }
}

.flex {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 767px) {
  .flex {
    flex-direction: column;
    gap: 4rem;
  }
}

/*--------------------------------------------------------------
header
--------------------------------------------------------------*/
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding: 3.2rem 4rem 0;
  display: flex;
  justify-content: space-between;
}
header nav {
  display: flex;
  gap: 4rem;
  justify-content: flex-start;
  align-items: flex-start;
}
header nav a {
  display: block;
  font-size: 1.6rem;
  font-family: "Hind", sans-serif;
  position: relative;
}
header nav a::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 0;
  bottom: 0;
  transition: opacity 0.2s ease-in-out, transform 0.2s ease-in-out;
}
header nav a:not(:hover)::after {
  transition: opacity 0.35s ease-in-out, transform 0.2s 0.4s ease-in-out;
  opacity: 0;
  transform: translateY(0.25em);
}
@media only screen and (max-width: 767px) {
  header {
    padding: 4rem 2.4rem;
  }
  header .logo img {
    height: 8rem;
    width: auto;
  }
  header nav {
    display: none;
  }
}

/*--------------------------------------------------------------
top
--------------------------------------------------------------*/
#top {
  padding: 0;
}
#top img {
  width: 100%;
}

/*--------------------------------------------------------------
concept
--------------------------------------------------------------*/
#concept {
  background: url(../images/bg_concept.png);
  text-align: center;
  padding: 14.4rem 0;
}
#concept h2 {
  font-size: 3.6rem;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 767px) {
  #concept {
    background-size: 1.2rem auto;
    padding: 9.6rem 0;
  }
  #concept h2 {
    font-size: 3rem;
    margin-left: -0.2em;
    margin-right: -0.2em;
  }
  #concept p {
    text-align: left;
  }
}

/*--------------------------------------------------------------
lineup
--------------------------------------------------------------*/
#lineup .lineuplist {
  display: flex;
  flex-direction: column;
  gap: 6.4rem;
}
#lineup p.spec {
  margin-top: 3rem;
}
@media only screen and (min-width: 768px) {
  #lineup .lineuplist {
    gap: 16.8rem;
  }
  #lineup .flex {
    align-items: center;
  }
  #lineup .flex:nth-child(odd) {
    flex-direction: row-reverse;
  }
  #lineup .flex figure {
    width: 39%;
  }
  #lineup .flex .txt {
    width: 50%;
  }
  #lineup p.spec {
    margin-top: 4rem;
  }
}

/*--------------------------------------------------------------
location
--------------------------------------------------------------*/
#location .map {
  width: 56%;
}
#location .map iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 58/46;
  filter: grayscale(100%);
}
#location .txt {
  width: 36%;
}
#location .txt .h_name {
  margin-right: -0.4em;
}
#location .txt dl {
  margin-top: 4rem;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
#location .txt dl dt {
  font-size: 2rem;
  line-height: 1.6;
}
#location .txt dl dd {
  line-height: 1.8;
}
@media only screen and (max-width: 767px) {
  #location .map {
    width: 100%;
  }
  #location .map iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 327/397;
    filter: grayscale(100%);
  }
  #location .txt {
    width: 100%;
  }
  #location .txt dl {
    margin-top: 2.4rem;
    gap: 2.4rem;
  }
  #location .txt dl dt {
    font-size: 1.7rem;
  }
}

/*--------------------------------------------------------------
about
--------------------------------------------------------------*/
#about {
  padding-bottom: 8rem;
}
@media only screen and (min-width: 768px) {
  #about {
    padding-bottom: 20rem;
  }
  #about .flex {
    flex-direction: row-reverse;
    align-items: center;
  }
  #about .flex figure {
    width: 39%;
  }
  #about .flex .txt {
    width: 53%;
  }
}

/*--------------------------------------------------------------
footer
--------------------------------------------------------------*/
footer {
  background: #B6D3CB;
  padding: 4rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
footer .left {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 31rem;
}
footer .left .logo {
  margin: 0;
}
footer .left nav ul {
  display: flex;
  gap: 2.2rem;
}
footer .left nav ul li a {
  text-decoration: underline;
  display: inline-block;
}
footer .left nav ul li a:hover {
  text-align: none;
}
footer .right {
  text-align: right;
}
footer .right .copyright {
  margin-top: 2rem;
}
@media only screen and (max-width: 767px) {
  footer {
    padding: 4rem 2.4rem;
    flex-direction: column;
    gap: 29rem;
    justify-content: space-between;
    align-items: flex-start;
  }
  footer .left {
    gap: 4rem;
  }
  footer .left .company img {
    width: 7.5rem;
  }
  footer .left nav ul {
    display: flex;
    gap: 2.2rem;
  }
  footer .left nav ul li a {
    text-decoration: underline;
  }
  footer .left nav ul li a:hover {
    text-align: none;
  }
  footer .right {
    width: 100%;
    text-align: right;
  }
  footer .right .company img {
    height: 2rem;
    width: auto;
  }
  footer .right .copyright {
    margin-top: 1rem;
  }
}

/*--------------------------------------------------------------

--------------------------------------------------------------*/
/*--------------------------------------------------------------

--------------------------------------------------------------*/
/*--------------------------------------------------------------

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