@charset "UTF-8";
@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap";
.pc {
  display: block; }
  @media only screen and (max-width: 768px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media only screen and (max-width: 768px) {
    .sp {
      display: block; } }

html {
  scroll-behavior: smooth; }

body {
  width: 750px;
  margin: 0 auto;
  font-size: 18px;
  letter-spacing: 0.04em;
  position: relative; }
  @media only screen and (max-width: 768px) {
    body {
      width: 100%;
      font-size: 0.95rem;
      letter-spacing: -0.02em; } }

.mincho {
  font-family: "游明朝", YuMincho, "Kozuka Mincho Pro", "Kozuka Mincho Std", "小塚明朝 Pro R", "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Sawarabi Mincho", serif; }

.mt40 {
  margin-top: 40px; }

.mb40 {
  margin-bottom: 40px; }
  @media only screen and (max-width: 768px) {
    .mb40 {
      margin-bottom: 4%; } }

.mb50 {
  margin-bottom: 50px; }
  @media only screen and (max-width: 768px) {
    .mb50 {
      margin-bottom: 6%; } }

.mb60 {
  margin-bottom: 60px; }
  @media only screen and (max-width: 768px) {
    .mb60 {
      margin-bottom: 9%; } }

.mb70 {
  margin-bottom: 70px; }
  @media only screen and (max-width: 768px) {
    .mb70 {
      margin-bottom: 9%; } }

.mb80 {
  margin-bottom: 80px; }
  @media only screen and (max-width: 768px) {
    .mb80 {
      margin-bottom: 12%; } }

.mb100 {
  margin-bottom: 100px; }
  @media only screen and (max-width: 768px) {
    .mb100 {
      margin-bottom: 15%; } }

.anchor_link {
  padding-top: 50px;
  margin-top: -50px;
  display: block; }

img {
  width: 100%;
  display: block;
  margin: 0 auto; }

a, a:focus {
  outline: none; }

header {
  padding: 20px 0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 1; }
  header h1 {
    text-align: center;
    line-height: 1; }

main {
  padding-top: 70px; }

object {
  pointer-events: none; }

/*　ハンバーガーボタン　*/
.hamburger {
  display: block;
  position: fixed;
  z-index: 3;
  right: 13px;
  top: 12px;
  width: 42px;
  height: 42px;
  cursor: pointer; }

.hamburger span {
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 6px;
  background: #111;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }

.hamburger span:nth-child(1) {
  top: 10px; }

.hamburger span:nth-child(2) {
  top: 20px; }

.hamburger span:nth-child(3) {
  top: 30px; }

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top: 16px;
  left: 6px;
  background: #111;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  transform: rotate(-45deg); }

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 16px;
  background: #111;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg); }

nav.globalMenuSp {
  position: fixed;
  z-index: 2;
  top: 0;
  right: 0;
  color: #111;
  background: #f8f8f8;
  width: 30%;
  height: 100%;
  display: none;
  transition: opacity .6s ease, visibility .6s ease; }
  @media only screen and (max-width: 768px) {
    nav.globalMenuSp {
      width: 70%; } }

nav.globalMenuSp ul {
  margin: 70px auto 0;
  padding: 0;
  width: 100%; }
  @media only screen and (max-width: 768px) {
    nav.globalMenuSp ul {
      margin-top: 50px; } }

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  transition: .4s all; }

nav.globalMenuSp ul li:last-child {
  padding-bottom: 0; }

nav.globalMenuSp ul li:hover {
  background: #555; }
  nav.globalMenuSp ul li:hover a {
    color: #fff; }

nav.globalMenuSp ul li a {
  display: block;
  padding: 15px 0 15px 50px;
  text-decoration: none; }
  @media only screen and (max-width: 768px) {
    nav.globalMenuSp ul li a {
      padding: 20px 0 20px 20px; } }

nav.globalMenuSp.active {
  display: block; }

.mv {
  position: relative; }
  .mv .title {
    /*background-color: #fff5f9;*/
    background-color: #ebefe6;
    padding: 40px;
    color: #111;
    font-size: 36px;
    line-height: 1.4; }
    .mv .title small {
      display: block;
      font-size: 26px; }
    @media only screen and (max-width: 768px) {
      .mv .title {
        padding: 5.3%;
        font-size: 1.2rem;
        line-height: 1.5; }
        .mv .title small {
          font-size: 0.8rem; } }

.inner {
  width: 670px;
  margin: 0 auto; }
  @media only screen and (max-width: 768px) {
    .inner {
      width: 90%; } }

section {
  padding: 60px 0; }
  @media only screen and (max-width: 768px) {
    section {
      padding: 9% 0; } }
  section h2 {
    font-size: 36px;
    font-weight: bold;
    line-height: 1.2;
    border-bottom: 2px solid #000;
    padding-bottom: 30px;
    margin-bottom: 30px; }
    @media only screen and (max-width: 768px) {
      section h2 {
        font-size: 1.3rem;
        line-height: 1.4;
        padding-bottom: 7%;
        margin-bottom: 7%; } }
  section h3 {
    font-size: 28px;
    font-weight: bold;
    padding-left: 20px;
    line-height: 1;
    border-left: 4px solid #000;
    margin-bottom: 30px; }
    @media only screen and (max-width: 768px) {
      section h3 {
        font-size: 1.2rem;
        margin-bottom: 4%;
        padding-left: 3%; } }

.movie {
  width: 100%;
  height: auto;
  padding-top: 56.25%;
  position: relative; }
  .movie video {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%; }

.mokuji {
  background-color: #f3f3f3;
  padding: 40px; }
  .mokuji h4 {
    font-weight: bold; }
  .mokuji ul li {
    line-height: 2.6; }
    .mokuji ul li a {
      text-decoration: underline;
      color: #111;
      transition: all 2s; }
      .mokuji ul li a:hover {
        opacity: 0.8; }
  @media only screen and (max-width: 768px) {
    .mokuji {
      padding: 8%; } }

.items img {
  margin-bottom: 50px; }
  .items img.caption-img {
    margin-bottom: 0; }
  @media only screen and (max-width: 768px) {
    .items img {
      margin-bottom: 7%; } }

.column3 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 670px;
  margin: 0 auto 50px; }
  @media only screen and (max-width: 768px) {
    .column3 {
      width: 100%;
      margin-bottom: 5%; } }
  .column3 li {
    width: 33%; }
    .column3 li img {
      margin-bottom: 0; }

.column {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 30px; }
  .column img {
    margin-bottom: 0; }
  .column li {
    width: 49.5%; }
    .column li:nth-of-type(n+3) {
      margin-top: 10px; }
  @media only screen and (max-width: 768px) {
    .column {
      display: block;
      margin-bottom: 6%; }
      .column li {
        width: 77.6119%;
        margin: 1% auto 0; }
        .column li:nth-of-type(n+3) {
          margin-top: 1%; } }

.caption {
  background: #eee;
  padding: 30px;
  margin-bottom: 60px; }
  .caption small {
    font-size: 24px; }
  @media only screen and (max-width: 768px) {
    .caption {
      padding: 5%;
      margin-bottom: 8%; }
      .caption small {
        font-size: 0.85rem; } }

.visual {
  margin-bottom: 0; }

.product {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 100px; }
  @media only screen and (max-width: 768px) {
    .product {
      margin-top: 15%; } }
  .product > div {
    width: 50%; }
    .product > div:nth-child(n+3) {
      margin-top: 50px; }
  .product img {
    width: 80%;
    display: block;
    margin: 0 auto; }
  .product dl {
    text-align: center;
    font-size: 18px;
    line-height: 1.4; }
    .product dl dt {
      font-weight: bold;
      margin: 25px 0 10px; }
    @media only screen and (max-width: 768px) {
      .product dl {
        font-size: 0.8rem; }
        .product dl dt {
          margin: 12.5px auto 5px; } }
  .product .btn {
    width: 240px;
    margin: 15px auto 0; }
    .product .btn a {
      display: block;
      line-height: 1;
      text-align: center;
      font-size: 20px;
      padding: 15px 0;
      color: #0455B5;
      background: #fff;
      border: 2px solid #0455B5;
      transition: all .3s; }
      .product .btn a:hover {
        opacity: 1;
        background: #0455B5;
        color: #fff; }
    @media only screen and (max-width: 768px) {
      .product .btn {
        width: 90%; }
        .product .btn a {
          font-size: 0.9rem; } }

.info {
  margin-top: 100px; }
  @media only screen and (max-width: 768px) {
    .info {
      margin-top: 15%; } }

.concept {
  width: 100%;
  background: #eee;
  font-size: 1.2rem;
  padding: 15px 0; }
  .concept h3 {
    font-weight: bold;
    margin-bottom: 5px !important;
    width: 90%;
    margin: auto; }
  .concept p {
    width: 90%;
    margin: auto; }

footer {
  margin-top: 50px;
  padding: 100px 0 40px;
  border-top: 1px solid #111;
  text-align: center; }
  @media only screen and (max-width: 768px) {
    footer {
      width: 90%;
      margin: 7% auto 0;
      padding: 15% 0 6%; } }
  footer ul {
    text-align: left;
    margin-bottom: 100px; }
    footer ul a {
      padding: 15px 0 15px 15px;
      position: relative;
      border: 1px solid #111;
      display: block;
      transition: all .3s;
      position: relative; }
      footer ul a:before {
        content: "";
        position: absolute;
        top: 50%;
        right: 15px;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 10px 0 10px 20px;
        margin-top: -10px;
        border-color: transparent transparent transparent #fff; }
        @media only screen and (max-width: 768px) {
          footer ul a:before {
            border-width: 5px 0 5px 10px;
            margin-top: -5px; } }
    footer ul li:first-child {
      margin-bottom: 10px; }
      footer ul li:first-child a {
        background: #111;
        color: #fff; }
    footer ul li:last-child a:before {
      border-color: transparent transparent transparent #111; }
  footer dl {
    font-size: 14px;
    pointer-events: none;
    margin-top: 20px; }

.hana {
  position: absolute;
  height: 0;
  width: 0;
  border: 10px solid pink;
  border-radius: 15px;
  border-top-right-radius: 0;
  border-bottom-left-radius: 0;
  z-index: 2; }
  .hana:after {
    content: "";
    display: block;
    position: absolute;
    top: -7px;
    left: -7px;
    height: 0;
    width: 0;
    border: 10px solid pink;
    border-radius: 15px;
    border-top-right-radius: 0;
    border-bottom-left-radius: 0;
    -webkit-transform: rotate(15deg);
    -ms-transform: rotate(15deg);
    transform: rotate(15deg); }

.-img4 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .-img4 li {
    width: 49%; }
    .-img4 li:nth-of-type(n+3) {
      margin-top: 2%; }

.-caption {
  margin-top: 40px; }
  @media only screen and (max-width: 768px) {
    .-caption {
      margin-top: 4%; } }
  .-caption img {
    margin: 0 auto; }
  .-caption p {
    background: #eee;
    padding: 30px; }
    @media only screen and (max-width: 768px) {
      .-caption p {
        padding: 5%; } }
