@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  background: transparent;
  font-size: 100%;
  vertical-align: baseline;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  background: transparent;
  font-size: 100%;
  vertical-align: baseline;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
  border: 0;
  border-top: 1px solid #cccccc;
}

input, select {
  vertical-align: middle;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

svg,
img {
  max-width: 100%;
  vertical-align: middle;
}

li {
  list-style: none;
}

h1, h2, h3, h4, h5, h6, th, dt {
  font-weight: inherit;
}

article, main, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, picture {
  display: block;
}

@media screen and (min-width: 961px) {
  :root {
    --header-height: 120px;
  }
}

@media screen and (max-width: 960px) {
  :root {
    --header-height: 60px;
  }
}

/*----------------------------------------------------
	レスポンシブ
----------------------------------------------------*/
@media screen and (min-width: 561px) {
  .sp {
    display: none;
  }
}

@media screen and (min-width: 961px) {
  .sp-tab {
    display: none;
  }
}

@media screen and (max-width: 960px) {
  .pc {
    display: none;
  }
}

@media screen and (max-width: 560px) {
  .pc-tab {
    display: none;
  }
}

@media screen and (max-width: 560px) {
  .tab {
    display: none;
  }
}

@media screen and (min-width: 961px) {
  .tab {
    display: none;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .sp-pc {
    display: none;
  }
}

/*----------------------------------------------------
	フォント
----------------------------------------------------*/
html {
  font-size: 16px;
}

body {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  word-wrap: break-word;
  color: #3B4043;
  line-height: 1.5;
  font-family: source-han-sans-japanese, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", sans-serif;
}

.serif {
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
}

@font-face {
  font-style: normal;
  font-weight: normal;
  src: url("../font/AmericanTypewriter.woff2") format("woff2"), url("../font/AmericanTypewriter.woff") format("woff");
  font-family: 'American Typewriter';
  font-display: swap;
}

/*----------------------------------------------------
	リンク
----------------------------------------------------*/
a {
  color: #3B4043;
  text-decoration: none;
  transition: color .3s ease-out, background .3s ease-out, border .3s ease-out, box-shadow .3s ease-out;
}

a .alpha {
  transition: color .3s ease-out, background .3s ease-out, border .3s ease-out, opacity .3s ease-out, box-shadow .3s ease-out;
}

a img {
  transition: color .3s ease-out, background .3s ease-out, border .3s ease-out, opacity .3s ease-out, box-shadow .3s ease-out, -webkit-transform .3s ease-out;
  transition: color .3s ease-out, background .3s ease-out, border .3s ease-out, opacity .3s ease-out, box-shadow .3s ease-out, transform .3s ease-out;
  transition: color .3s ease-out, background .3s ease-out, border .3s ease-out, opacity .3s ease-out, box-shadow .3s ease-out, transform .3s ease-out, -webkit-transform .3s ease-out;
}

@media (hover: hover) {
  a:hover .alpha {
    opacity: 0.7;
  }
}

.link-text a {
  color: #1DA1F2;
}

@media (hover: hover) {
  .link-text a:hover {
    text-decoration: underline;
  }
}

a.link-text {
  color: #1DA1F2;
}

@media (hover: hover) {
  a.link-text:hover {
    text-decoration: underline;
  }
}

@media (hover: hover) {
  a[href^='tel:'] {
    pointer-events: none;
  }
}

@media (hover: none) {
  a, button {
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }
}

[data-scroll-target] {
  display: block;
  position: relative;
  top: calc(-1 * var(--header-height));
  content: '';
  pointer-events: none;
}

/*----------------------------------------------------
	コンテナ
----------------------------------------------------*/
.container {
  position: relative;
  width: 100%;
  max-width: 1280px;
  margin-right: auto;
  margin-left: auto;
  padding-right: 40px;
  padding-left: 40px;
}

@media screen and (min-width: 961px) and (max-width: 1366px) {
  .container {
    max-width: initial;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .container {
    max-width: initial;
    padding-right: 20px;
    padding-left: 20px;
  }
}

@media screen and (max-width: 560px) {
  .container {
    max-width: initial;
    padding-right: 20px;
    padding-left: 20px;
  }
}

.container--l {
  max-width: 1420px;
}

/*----------------------------------------------------
	body
----------------------------------------------------*/
html {
  height: 100%;
}

body {
  height: 100%;
}

body.no-scroll {
  height: 100vh;
  overflow: hidden;
}

@-webkit-keyframes bodyLeaving {
  0%, 100% {
    opacity: 1;
  }
  30%, 70% {
    opacity: 0;
  }
}

@keyframes bodyLeaving {
  0%, 100% {
    opacity: 1;
  }
  30%, 70% {
    opacity: 0;
  }
}

.body-wrap {
  width: 100%;
  min-height: 100%;
  overflow: hidden;
}

/*----------------------------------------------------
	header-content
----------------------------------------------------*/
.header-content {
  height: 100%;
}

.header-content__wrap {
  position: relative;
  height: 100%;
}

@media screen and (min-width: 961px) {
  .header-content__wrap {
    display: flex;
    flex-direction: column;
  }
  .header-content__wrap:before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 111px;
    height: 11px;
    background: #3b4043;
    content: '';
  }
  .header-content__wrap:after {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 2px;
    height: calc(100% - 20px);
    background: #3b4043;
    content: '';
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .header-content__wrap:before {
    width: 5.78125vw;
    height: 0.57292vw;
  }
  .header-content__wrap:after {
    width: 0.10417vw;
    height: calc(100% - (20/1920*100vw));
  }
}

@media screen and (max-width: 960px) {
  .header-content__wrap:before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 1.40187vw;
    height: 13.31776vw;
    background: #3b4043;
    content: '';
  }
  .header-content__wrap:after {
    display: block;
    position: absolute;
    bottom: 0;
    left: 1.86916vw;
    width: calc(100% - (8/428*100vw));
    height: 0.46729vw;
    background: #3b4043;
    content: '';
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .header-content__wrap:before {
    width: 1.30208vw;
    height: 8.33333vw;
  }
  .header-content__wrap:after {
    left: 2.34375vw;
    width: calc(100% - (13/768*100vw));
    height: 0.26042vw;
  }
}

/*----------------------------------------------------
	header-logo
----------------------------------------------------*/
@media screen and (min-width: 961px) {
  .header-logo {
    padding: 48px 0 0 21px;
  }
  .header-logo img {
    width: 68px;
    height: 168px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .header-logo {
    padding: 2.5vw 0 0 1.09375vw;
  }
  .header-logo img {
    width: 3.54167vw;
    height: 8.75vw;
  }
}

@media screen and (max-width: 960px) {
  .header-logo {
    padding: 0vw 0 0 5.33333vw;
  }
  .header-logo img {
    width: 20.8vw;
    height: 8.53333vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .header-logo {
    padding: 0vw 0 0 4.81771vw;
  }
  .header-logo img {
    width: 11.19792vw;
    height: 4.55729vw;
  }
}

/*----------------------------------------------------
	ヘッダー メニュー
----------------------------------------------------*/
@media screen and (max-width: 960px) {
  .header-menu {
    z-index: 200;
    position: absolute;
    top: 1.33333vw;
    right: 1.33333vw;
    width: 10.66667vw;
    height: 10.66667vw;
    cursor: pointer;
  }
  .header-menu div {
    position: relative;
  }
  .header-menu span {
    display: block;
    position: absolute;
    left: 4vw;
    width: 6.66667vw;
    height: 0.648vw;
    background: #3b4043;
    transition: .35s ease-in-out;
  }
  .header-menu span:nth-child(1) {
    top: 2.66667vw;
  }
  .header-menu span:nth-child(2) {
    top: 4.53333vw;
  }
  .header-menu span:nth-child(3) {
    top: 6.4vw;
    width: 4.26667vw;
  }
  .header-menu.open span:nth-child(1) {
    -webkit-transform: rotate(45deg);
    top: 4.53333vw;
            transform: rotate(45deg);
  }
  .header-menu.open span:nth-child(2) {
    left: 50%;
    width: 0;
  }
  .header-menu.open span:nth-child(3) {
    -webkit-transform: rotate(-45deg);
    top: 4.53333vw;
    width: 6.66667vw;
            transform: rotate(-45deg);
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .header-menu {
    top: 0vw;
    right: 0.65104vw;
    width: 7.8125vw;
    height: 7.8125vw;
  }
  .header-menu span {
    left: 2.21354vw;
    width: 3.90625vw;
    height: 0.3724vw;
  }
  .header-menu span:nth-child(1) {
    top: 2.60417vw;
  }
  .header-menu span:nth-child(2) {
    top: 3.64583vw;
  }
  .header-menu span:nth-child(3) {
    top: 4.6875vw;
    width: 2.34375vw;
  }
  .header-menu.open span:nth-child(1) {
    top: 3.64583vw;
  }
  .header-menu.open span:nth-child(3) {
    top: 3.64583vw;
    width: 3.90625vw;
  }
}

/*----------------------------------------------------
	ヘッダーナビ
----------------------------------------------------*/
.header-nav {
  position: relative;
}

.header-nav ul {
  display: flex;
  flex-direction: column;
}

.header-nav li + li {
  margin-top: 14px;
}

.header-nav ._instagram {
  margin-top: 40px;
}

.header-nav ._instagram img:nth-child(2) {
  display: none;
}

.header-nav li {
  font-weight: 300;
  font-size: 15px;
  font-family: "American Typewriter", "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.3em;
}

.header-nav a {
  display: block;
  padding: 10px 0 10px 20px;
}

@media screen and (min-width: 961px) {
  .header-nav {
    margin-top: auto;
    margin-bottom: 110px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .header-nav {
    margin-bottom: 5.72917vw;
  }
  .header-nav li + li {
    margin-top: 0.72917vw;
  }
  .header-nav ._instagram {
    margin-top: 2.08333vw;
  }
  .header-nav li {
    font-size: 0.78125vw;
  }
  .header-nav a {
    padding: 0.52083vw 0 0.52083vw 1.04167vw;
  }
}

@media screen and (max-width: 960px) {
  .header-nav {
    display: none;
    z-index: 100;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(255, 255, 255, 0.8);
  }
  .header-nav.open {
    display: flex;
  }
  .header-nav ul {
    display: flex;
    justify-content: center;
    width: 57.94393vw;
    height: 127.80374vw;
    margin: auto;
    background: rgba(59, 64, 67, 0.8);
  }
  .header-nav a {
    padding: 0.65em 1em;
    color: #fff;
    font-size: 3.50467vw;
    text-align: center;
  }
  .header-nav ._instagram {
    margin-top: 9.34579vw;
  }
  .header-nav ._instagram img:nth-child(1) {
    display: none;
  }
  .header-nav ._instagram img:nth-child(2) {
    display: inline-block;
    width: 4.6729vw;
  }
}

@media screen and (min-width: 961px) {
  .header-nav-indicator {
    z-index: 3;
    position: absolute;
    top: 0;
    left: 0;
    width: 2px;
    height: 45px;
    background: #fbdfd4;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .header-nav-indicator {
    height: 2.34375vw;
  }
}

/*----------------------------------------------------
	ヘッダー
----------------------------------------------------*/
header {
  -webkit-transform: translateY(0);
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
          transform: translateY(0);
}

@media screen and (min-width: 961px) {
  header {
    top: 23px;
    left: 32px;
    width: 146px;
    height: calc(100vh - 23px - 30px);
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  header {
    top: 1.19792vw;
    left: 1.66667vw;
    width: 7.60417vw;
    height: calc(100vh - (23/1920*100vw) - (30/1920*100vw));
  }
}

@media screen and (max-width: 960px) {
  header {
    top: 0;
    left: 4.20561vw;
    width: 92.05607vw;
    height: 13.31776vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  header {
    top: 0;
    left: 3.38542vw;
    width: 92.44792vw;
    height: 8.33333vw;
  }
}

@-webkit-keyframes headerScrollDown {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}

@keyframes headerScrollDown {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}

@-webkit-keyframes headerScrollUp {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes headerScrollUp {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@media screen and (min-width: 961px) {
  .header-content__wrap {
    display: flex;
  }
}

@media screen and (max-width: 960px) {
  .header-content__wrap {
    display: flex;
    align-items: center;
  }
}

/*----------------------------------------------------
	main
----------------------------------------------------*/
main {
  position: relative;
}

/*----------------------------------------------------
	フッター
----------------------------------------------------*/
footer {
  background: #3b4043;
  color: #fff;
}

.footer-content {
  font-size: 12px;
  letter-spacing: 0.06em;
}

@media screen and (min-width: 961px) {
  .footer-content {
    display: flex;
    align-items: center;
    height: 97.2px;
    padding: 29px 45px 36px 73px;
  }
  .footer-content ._logo {
    margin-right: 3em;
  }
  .footer-content ._logo img {
    width: 74.6px;
    height: 32.32px;
  }
  .footer-content span + span {
    margin-left: 2.2em;
  }
  .footer-content ._instagram {
    display: none;
  }
  .footer-content .copyright {
    margin-left: auto;
  }
}

@media screen and (min-width: 961px) and (max-width: 1366px) {
  .footer-content {
    display: flex;
    align-items: center;
    height: 69.13px;
    padding: 21.4px 25.5px 31px 34px;
    font-size: 11px;
  }
  .footer-content ._logo {
    margin-right: 3em;
  }
  .footer-content ._logo img {
    width: 53.05px;
    height: 22.98px;
  }
  .footer-content span + span {
    margin-left: 2.2em;
  }
  .footer-content .copyright {
    margin-left: auto;
  }
}

@media screen and (max-width: 960px) {
  .footer-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 52.33645vw;
    padding: 7.00935vw 2.33645vw 4.43925vw;
    font-size: 2.1028vw;
    line-height: 2em;
    letter-spacing: 0.06em;
  }
  .footer-content ._logo {
    margin-bottom: 3.50467vw;
  }
  .footer-content ._logo img {
    width: 10.51402vw;
    height: 4.6729vw;
  }
  .footer-content ._instagram {
    margin-top: auto;
  }
  .footer-content ._instagram img {
    width: 4.6729vw;
  }
  .footer-content .copyright {
    margin-top: 2.33645vw;
  }
}

/*----------------------------------------------------
	.about-lalupa
----------------------------------------------------*/
.about-lalupa {
  position: relative;
}

@media screen and (max-width: 960px) {
  .about-lalupa {
    margin-top: 14.71963vw;
  }
}

.about-lalupa__head {
  margin-left: 192px;
}

.about-lalupa__head ._title {
  display: inline-flex;
  flex-direction: row-reverse;
  align-items: flex-start;
}

.about-lalupa__head ._title span {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  display: inline-flex;
  align-items: center;
  width: 67px;
  padding: 0.3em 0;
  background: #3b4043;
  color: #fff;
  font-weight: 500;
  font-size: 53px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.19em;
  text-align: center;
          writing-mode: vertical-rl;
}

.about-lalupa__head ._title span + span {
  margin-right: 18px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-lalupa__head {
    margin-left: 10vw;
  }
  .about-lalupa__head ._title span {
    width: 3.48958vw;
    font-size: 2.76042vw;
  }
  .about-lalupa__head ._title span + span {
    margin-right: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .about-lalupa__head {
    margin-left: 53.73832vw;
  }
  .about-lalupa__head ._title span {
    width: 9.34579vw;
    font-size: 7.00935vw;
  }
  .about-lalupa__head ._title span + span {
    margin-right: 2.57009vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-lalupa__head {
    margin-left: 54.81771vw;
  }
  .about-lalupa__head ._title span {
    width: 7.16146vw;
    font-size: 5.33854vw;
  }
  .about-lalupa__head ._title span + span {
    margin-right: 1.5625vw;
  }
}

.about-lalupa__pic {
  margin-top: -80px;
  margin-bottom: 60px;
  text-align: center;
}

.about-lalupa__pic img {
  width: 600px;
  height: auto;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-lalupa__pic {
    margin-top: -4.16667vw;
    margin-bottom: 3.125vw;
  }
  .about-lalupa__pic img {
    width: 31.25vw;
  }
}

@media screen and (max-width: 960px) {
  .about-lalupa__pic {
    margin-top: 1.86916vw;
    margin-bottom: 0vw;
  }
  .about-lalupa__pic img {
    width: 67.75701vw;
    margin-left: -2.33645vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-lalupa__pic {
    margin-top: -7.8125vw;
    margin-bottom: 0vw;
  }
  .about-lalupa__pic img {
    width: 52.08333vw;
    margin-left: 1.04167vw;
  }
}

.about-lalupa__txt ._title {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.2em;
  text-decoration: underline;
}

.about-lalupa__txt ._txt {
  margin-top: 22px;
  font-size: 18px;
  line-height: 2.22222;
  letter-spacing: 0.06em;
}

@media screen and (min-width: 961px) {
  .about-lalupa__txt {
    position: absolute;
    top: 560px;
    left: 950px;
    margin-right: -100px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-lalupa__txt {
    top: 29.16667vw;
    left: 49.47917vw;
  }
  .about-lalupa__txt ._title {
    font-size: 0.9375vw;
  }
  .about-lalupa__txt ._txt {
    margin-top: 1.14583vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .about-lalupa__txt {
    width: 66.82243vw;
    margin-top: 2.57009vw;
    margin-right: auto;
    margin-left: auto;
    padding-bottom: 9.34579vw;
    color: #fff;
  }
  .about-lalupa__txt ._title {
    font-size: 2.57009vw;
  }
  .about-lalupa__txt ._txt {
    margin-top: 3.03738vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-lalupa__txt {
    width: 62.5vw;
    margin-top: 0vw;
    padding-bottom: 8.59375vw;
  }
  .about-lalupa__txt ._title {
    font-size: 1.95312vw;
  }
  .about-lalupa__txt ._txt {
    margin-top: 2.60417vw;
    font-size: 2.08333vw;
  }
}

.about-lalupa__point ._point1 {
  position: absolute;
  top: 60px;
  left: 708px;
}

.about-lalupa__point ._point1 img {
  width: 307px;
  height: auto;
}

.about-lalupa__point ._point2 {
  position: absolute;
  top: 280px;
  left: 1030px;
}

.about-lalupa__point ._point2 img {
  width: 257px;
  height: auto;
}

.about-lalupa__point ._point3 {
  position: absolute;
  top: 270px;
  left: -90px;
}

.about-lalupa__point ._point3 img {
  width: 256px;
  height: auto;
}

.about-lalupa__point ._point4 {
  position: absolute;
  top: 500px;
  left: 105px;
}

.about-lalupa__point ._point4 img {
  width: 257px;
  height: auto;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-lalupa__point ._point1 {
    top: 3.125vw;
    left: 36.875vw;
  }
  .about-lalupa__point ._point1 img {
    width: 15.98958vw;
  }
  .about-lalupa__point ._point2 {
    top: 14.58333vw;
    left: 53.64583vw;
  }
  .about-lalupa__point ._point2 img {
    width: 13.38542vw;
  }
  .about-lalupa__point ._point3 {
    top: 14.0625vw;
    left: -4.6875vw;
  }
  .about-lalupa__point ._point3 img {
    width: 13.33333vw;
  }
  .about-lalupa__point ._point4 {
    top: 26.04167vw;
    left: 5.46875vw;
  }
  .about-lalupa__point ._point4 img {
    width: 13.38542vw;
  }
}

@media screen and (max-width: 960px) {
  .about-lalupa__point {
    position: relative;
  }
  .about-lalupa__point ._point1 {
    top: -13.5514vw;
    left: 15.42056vw;
  }
  .about-lalupa__point ._point1 img {
    width: 24.76636vw;
  }
  .about-lalupa__point ._point2 {
    top: 3.73832vw;
    left: 64.95327vw;
  }
  .about-lalupa__point ._point2 img {
    width: 19.85981vw;
  }
  .about-lalupa__point ._point3 {
    top: 21.02804vw;
    left: 2.80374vw;
  }
  .about-lalupa__point ._point3 img {
    width: 20.56075vw;
  }
  .about-lalupa__point ._point4 {
    top: 24.76636vw;
    left: 74.76636vw;
  }
  .about-lalupa__point ._point4 img {
    width: 20.56075vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-lalupa__point ._point1 {
    top: -29.81771vw;
    left: 26.43229vw;
  }
  .about-lalupa__point ._point1 img {
    width: 23.30729vw;
  }
  .about-lalupa__point ._point2 {
    top: -7.68229vw;
    left: 9.375vw;
  }
  .about-lalupa__point ._point2 img {
    width: 17.05729vw;
  }
  .about-lalupa__point ._point3 {
    top: 5.33854vw;
    left: 70.3125vw;
  }
  .about-lalupa__point ._point3 img {
    width: 19.53125vw;
  }
  .about-lalupa__point ._point4 {
    top: 12.10938vw;
    left: 13.02083vw;
  }
  .about-lalupa__point ._point4 img {
    width: 17.1875vw;
  }
}

/*----------------------------------------------------
	.about-onayami
----------------------------------------------------*/
.about-onayami {
  position: relative;
}

.about-onayami__head ._title {
  display: inline-flex;
  flex-direction: row-reverse;
  align-items: flex-start;
}

.about-onayami__head ._title span {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  display: inline-flex;
  align-items: center;
  width: 67px;
  padding: 0.3em 0;
  background: #3b4043;
  color: #fff;
  font-weight: 500;
  font-size: 53px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.19em;
  text-align: center;
          writing-mode: vertical-rl;
}

.about-onayami__head ._title span + span {
  margin-right: 18px;
}

@media screen and (min-width: 961px) {
  .about-onayami__head {
    position: absolute;
    top: 60px;
    left: 856px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami__head {
    top: 3.125vw;
    left: 44.58333vw;
  }
  .about-onayami__head ._title span {
    width: 3.48958vw;
    font-size: 2.76042vw;
  }
  .about-onayami__head ._title span + span {
    margin-right: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .about-onayami__head {
    margin-left: 54.6729vw;
  }
  .about-onayami__head ._title span {
    width: 8.8785vw;
    font-size: 7.00935vw;
  }
  .about-onayami__head ._title span + span {
    margin-right: 2.1028vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami__head {
    margin-left: 57.03125vw;
  }
  .about-onayami__head ._title span {
    width: 7.16146vw;
    font-size: 5.46875vw;
  }
  .about-onayami__head ._title span + span {
    margin-right: 1.5625vw;
  }
}

.about-onayami__lead ._title {
  font-weight: bold;
  font-size: 18px;
  line-height: 2.22222;
  letter-spacing: 0.2em;
  text-decoration: underline;
}

.about-onayami__lead ._txt {
  margin-top: 30px;
  font-size: 18px;
  line-height: 2.22222;
  letter-spacing: 0.06em;
}

@media screen and (min-width: 961px) {
  .about-onayami__lead {
    margin-left: 187px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami__lead ._title {
    font-size: 0.9375vw;
  }
  .about-onayami__lead ._txt {
    margin-top: 1.14583vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .about-onayami__lead {
    width: 66.82243vw;
    margin-top: 14.01869vw;
    margin-right: auto;
    margin-left: auto;
  }
  .about-onayami__lead ._title {
    font-size: 2.57009vw;
  }
  .about-onayami__lead ._txt {
    margin-top: 3.03738vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami__lead {
    width: 37.76042vw;
    margin-top: 0vw;
    margin-right: auto;
    margin-left: 16.53646vw;
  }
  .about-onayami__lead ._title {
    font-size: 1.43229vw;
  }
  .about-onayami__lead ._txt {
    margin-top: 2.60417vw;
    font-size: 2.08333vw;
  }
}

.about-onayami__body {
  position: relative;
  margin-top: 120px;
}

@media screen and (min-width: 961px) {
  .about-onayami__body {
    height: 1278px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami__body {
    height: 66.5625vw;
    margin-top: 6.25vw;
  }
}

@media screen and (max-width: 960px) {
  .about-onayami__body {
    margin-top: 23.36449vw;
  }
}

@media screen and (max-width: 960px) {
  .about-onayami__body {
    margin-top: 8.98438vw;
  }
}

.about-onayami__foot ._title {
  font-weight: bold;
  font-size: 18px;
  line-height: 2.22222;
  letter-spacing: 0.2em;
  text-decoration: underline;
}

.about-onayami__foot ._txt {
  margin-top: 30px;
  font-size: 18px;
  line-height: 2.22222;
  letter-spacing: 0.06em;
}

@media screen and (min-width: 961px) {
  .about-onayami__foot {
    margin-top: 35px;
    margin-left: 784px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami__foot {
    margin-top: 1.82292vw;
    margin-left: 40.83333vw;
  }
  .about-onayami__foot ._title {
    font-size: 0.9375vw;
  }
  .about-onayami__foot ._txt {
    margin-top: 1.14583vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .about-onayami__foot {
    width: 66.82243vw;
    margin-top: 14.01869vw;
    margin-right: auto;
    margin-left: auto;
  }
  .about-onayami__foot ._title {
    font-size: 2.57009vw;
  }
  .about-onayami__foot ._txt {
    margin-top: 3.03738vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami__foot {
    width: 40.36458vw;
    margin-top: 8.85417vw;
    margin-right: auto;
    margin-left: 16.27604vw;
  }
  .about-onayami__foot ._title {
    font-size: 1.95312vw;
  }
  .about-onayami__foot ._txt {
    margin-top: 3.38542vw;
    font-size: 2.08333vw;
  }
}

.about-onayami-item {
  -webkit-animation: aboutItem 2s ease-in-out infinite;
  text-align: center;
          animation: aboutItem 2s ease-in-out infinite;
}

@media screen and (min-width: 961px) {
  .about-onayami-item {
    position: absolute;
  }
}

@media screen and (max-width: 560px) {
  .about-onayami-item + .about-onayami-item {
    margin-top: 11.91589vw;
  }
  .about-onayami-item:not(:last-of-type) .about-onayami-item__foot {
    display: none;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami-item:nth-of-type(odd) {
    margin-left: calc(50% - (96/768*100vw));
  }
  .about-onayami-item:nth-of-type(even) {
    margin-right: calc(50% - (96/768*100vw));
  }
  .about-onayami-item + .about-onayami-item {
    margin-top: -3.125vw;
  }
}

.about-onayami-item--1 {
  -webkit-animation-delay: 0s;
  top: 0;
  left: 298px;
          animation-delay: 0s;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item--1 {
    top: 0vw;
    left: 15.52083vw;
  }
}

.about-onayami-item--2 {
  -webkit-animation-delay: 0.5s;
  top: 293px;
  left: 640px;
          animation-delay: 0.5s;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item--2 {
    top: 15.26042vw;
    left: 33.33333vw;
  }
}

.about-onayami-item--3 {
  -webkit-animation-delay: 1.0s;
  top: 465px;
  left: 34px;
          animation-delay: 1.0s;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item--3 {
    top: 24.21875vw;
    left: 1.77083vw;
  }
}

.about-onayami-item--4 {
  -webkit-animation-delay: 1.5s;
  top: 723px;
  left: 888px;
          animation-delay: 1.5s;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item--4 {
    top: 37.65625vw;
    left: 46.25vw;
  }
}

.about-onayami-item--5 {
  -webkit-animation-delay: 2.0s;
  top: 823px;
  left: 396px;
          animation-delay: 2.0s;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item--5 {
    top: 42.86458vw;
    left: 20.625vw;
  }
}

.about-onayami-item__pic {
  position: relative;
  width: 319px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.about-onayami-item__pic img {
  image-rendering: -webkit-optimize-contrast;
}

.about-onayami-item__pic ._txt {
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item__pic {
    width: 16.61458vw;
  }
}

@media screen and (max-width: 560px) {
  .about-onayami-item__pic {
    width: 55.37383vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami-item__pic {
    width: 42.96875vw;
  }
}

.about-onayami-item__foot img {
  width: 71px;
  height: 124px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about-onayami-item__foot img {
    width: 3.69792vw;
    height: 6.45833vw;
  }
}

@media screen and (max-width: 560px) {
  .about-onayami-item__foot img {
    width: 8.64486vw;
    height: 16.35514vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about-onayami-item__foot img {
    width: 5.07812vw;
    height: 11.84896vw;
  }
}

@-webkit-keyframes aboutItem {
  0% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
  50% {
    -webkit-transform: translate(0, 15px);
            transform: translate(0, 15px);
  }
  100% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
}

@keyframes aboutItem {
  0% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
  50% {
    -webkit-transform: translate(0, 15px);
            transform: translate(0, 15px);
  }
  100% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
}

/*----------------------------------------------------
	.about
----------------------------------------------------*/
.about {
  position: relative;
  background: url(../img/bg-stripe.png);
}

.about:after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0px;
  width: 100%;
  height: 283px;
  background: transparent linear-gradient(0deg, #58605671 0%, #EDEDEA6C 100%) 0% 0% no-repeat padding-box;
  content: '';
  mix-blend-mode: multiply;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about:after {
    height: 14.73958vw;
  }
}

@media screen and (max-width: 960px) {
  .about {
    background-size: 10px 17px;
  }
  .about:after {
    height: 65.42056vw;
    background: transparent linear-gradient(0deg, #586056BE 0%, #787E76AC 64%, #D9D9D9 100%) 0% 0% no-repeat padding-box;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .about:after {
    height: 37.63021vw;
  }
}

.about__wrap {
  z-index: 2;
  position: relative;
  max-width: 1280px;
  margin: auto;
  padding: 160px 0 97px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about__wrap {
    max-width: 66.66667vw;
    padding: 8.33333vw 0 5.05208vw;
  }
}

@media screen and (max-width: 960px) {
  .about__wrap {
    padding: 14.01869vw 0 0;
  }
}

/*----------------------------------------------------
	.about__bubble
----------------------------------------------------*/
.about__bubble > div {
  display: inline-block;
  z-index: 10;
  position: absolute;
}

.about__bubble img {
  height: auto;
  opacity: 0.5;
}

.about__bubble ._bubble1 {
  right: calc(50% + 337px);
  bottom: 2520px;
}

.about__bubble ._bubble1 img {
  width: 144px;
}

.about__bubble ._bubble2 {
  bottom: 2145px;
  left: calc(50% + 573px);
}

.about__bubble ._bubble2 img {
  width: 143px;
}

.about__bubble ._bubble3 {
  bottom: 1458px;
  left: calc(50% + 224px);
}

.about__bubble ._bubble3 img {
  width: 100px;
}

.about__bubble ._bubble4 {
  right: calc(50% + 423px);
  bottom: 1124px;
}

.about__bubble ._bubble4 img {
  width: 113px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .about__bubble ._bubble1 {
    right: calc(50% + (337/1920*100vw));
    bottom: 131.25vw;
  }
  .about__bubble ._bubble1 img {
    width: 7.5vw;
  }
  .about__bubble ._bubble2 {
    bottom: 111.71875vw;
    left: calc(50% + (573/1920*100vw));
  }
  .about__bubble ._bubble2 img {
    width: 7.44792vw;
  }
  .about__bubble ._bubble3 {
    bottom: 75.9375vw;
    left: calc(50% + (224/1920*100vw));
  }
  .about__bubble ._bubble3 img {
    width: 5.20833vw;
  }
  .about__bubble ._bubble4 {
    right: calc(50% + (423/1920*100vw));
    bottom: 58.54167vw;
  }
  .about__bubble ._bubble4 img {
    width: 5.88542vw;
  }
}

@media screen and (max-width: 560px) {
  .about__bubble ._bubble1 {
    right: calc(50% + (105/375*100vw));
    bottom: 688vw;
  }
  .about__bubble ._bubble1 img {
    width: 17.6vw;
  }
  .about__bubble ._bubble2 {
    bottom: 591.2vw;
    left: calc(50% + (118/375*100vw));
  }
  .about__bubble ._bubble2 img {
    width: 19.46667vw;
  }
  .about__bubble ._bubble3 {
    bottom: 350.93333vw;
    left: calc(50% + (104/375*100vw));
  }
  .about__bubble ._bubble3 img {
    width: 18.66667vw;
  }
  .about__bubble ._bubble4 {
    right: calc(50% + (107/375*100vw));
    bottom: 436.8vw;
  }
  .about__bubble ._bubble4 img {
    width: 18.66667vw;
  }
}

/*----------------------------------------------------
	beautiful
----------------------------------------------------*/
.beautiful {
  position: relative;
  background: url(../img/bg-stripe.png);
}

@media screen and (max-width: 960px) {
  .beautiful {
    background-size: 10px 17px;
  }
}

.beautiful__wrap {
  max-width: 900px;
  margin: auto;
  padding: 190px 0 282px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful__wrap {
    max-width: 46.875vw;
    padding: 9.89583vw 0 14.6875vw;
  }
}

@media screen and (max-width: 960px) {
  .beautiful__wrap {
    padding: 15.18692vw 0 27.1028vw;
  }
}

.beautiful__head ._title {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 67px;
  height: 400px;
  margin-left: auto;
  background: #3b4043;
  color: #fff;
  font-weight: 500;
  font-size: 53px;
  line-height: 1.20755;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.19em;
  text-align: center;
          writing-mode: vertical-rl;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful__head ._title {
    width: 3.48958vw;
    height: 20.83333vw;
    font-size: 2.76042vw;
  }
}

@media screen and (max-width: 560px) {
  .beautiful__head ._title {
    width: 9.34579vw;
    height: 54.90654vw;
    margin-right: auto;
    margin-left: auto;
    font-size: 7.00935vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .beautiful__head ._title {
    width: 7.03125vw;
    height: 41.40625vw;
    margin-right: 24.34896vw;
    font-size: 5.33854vw;
  }
}

.beautiful-item {
  -webkit-animation: beautifulItem 2s ease-in-out infinite;
  position: relative;
          animation: beautifulItem 2s ease-in-out infinite;
}

.beautiful-item--1 {
  -webkit-animation-delay: -1s;
  width: 619px;
  height: 638px;
  margin-top: -225px;
  padding: 172px 128px 0;
  background: url(../img/beautiful-bg1.png) center center/cover;
          animation-delay: -1s;
}

.beautiful-item--1 ._no {
  position: absolute;
  top: -83px;
  left: 66px;
}

.beautiful-item--1 ._no img {
  width: 94px;
  height: 84px;
}

.beautiful-item--1 ._lalupa {
  position: absolute;
  top: -48px;
  left: 98px;
}

.beautiful-item--1 ._lalupa img {
  width: 181px;
  height: 154px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful-item--1 {
    width: 32.23958vw;
    height: 33.22917vw;
    margin-top: -11.71875vw;
    padding: 8.95833vw 6.66667vw 0;
  }
  .beautiful-item--1 ._no {
    top: -4.32292vw;
    left: 3.4375vw;
  }
  .beautiful-item--1 ._no img {
    width: 4.89583vw;
    height: 4.375vw;
  }
  .beautiful-item--1 ._lalupa {
    top: -2.5vw;
    left: 5.10417vw;
  }
  .beautiful-item--1 ._lalupa img {
    width: 9.42708vw;
    height: 8.02083vw;
  }
}

@media screen and (max-width: 560px) {
  .beautiful-item--1 {
    width: 57.00935vw;
    height: 58.8785vw;
    margin-top: 19.85981vw;
    margin-right: auto;
    margin-left: auto;
    padding: 16.35514vw 11.68224vw 0;
  }
  .beautiful-item--1 ._no {
    top: -7.94393vw;
    left: 13.5514vw;
  }
  .beautiful-item--1 ._no img {
    width: 13.08411vw;
    height: 11.68224vw;
  }
  .beautiful-item--1 ._lalupa {
    top: -7.94393vw;
    left: 19.15888vw;
  }
  .beautiful-item--1 ._lalupa img {
    width: 25.23364vw;
    height: 21.49533vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .beautiful-item--1 {
    width: 40.49479vw;
    height: 41.79688vw;
    margin-top: -11.06771vw;
    margin-left: 20.70312vw;
    padding: 12.23958vw 7.8125vw 0;
  }
  .beautiful-item--1 ._no {
    top: -6.51042vw;
    left: 1.5625vw;
  }
  .beautiful-item--1 ._no img {
    width: 9.24479vw;
    height: 8.33333vw;
  }
  .beautiful-item--1 ._lalupa {
    top: -5.72917vw;
    left: 5.46875vw;
  }
  .beautiful-item--1 ._lalupa img {
    width: 17.96875vw;
    height: 15.23438vw;
  }
}

.beautiful-item--2 {
  width: 678px;
  height: 699px;
  margin-top: -20px;
  margin-left: auto;
  padding: 193px 147px 0;
  background: url(../img/beautiful-bg2.png) center center/cover;
}

.beautiful-item--2 ._no {
  position: absolute;
  top: -106px;
  right: 97px;
}

.beautiful-item--2 ._no img {
  width: 94px;
  height: 84px;
}

.beautiful-item--2 ._lalupa {
  position: absolute;
  top: -83px;
  right: 191px;
}

.beautiful-item--2 ._lalupa img {
  width: 119px;
  height: 206px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful-item--2 {
    width: 35.3125vw;
    height: 36.40625vw;
    margin-top: -1.04167vw;
    padding: 10.05208vw 7.65625vw 0;
  }
  .beautiful-item--2 ._no {
    top: -5.52083vw;
    right: 5.05208vw;
  }
  .beautiful-item--2 ._no img {
    width: 4.89583vw;
    height: 4.375vw;
  }
  .beautiful-item--2 ._lalupa {
    top: -4.32292vw;
    right: 9.94792vw;
  }
  .beautiful-item--2 ._lalupa img {
    width: 6.19792vw;
    height: 10.72917vw;
  }
}

@media screen and (max-width: 560px) {
  .beautiful-item--2 {
    width: 63.31776vw;
    height: 61.4486vw;
    margin-top: 36.68224vw;
    margin-right: auto;
    margin-left: auto;
    padding: 18.2243vw 11.68224vw 0;
  }
  .beautiful-item--2 ._no {
    top: -11.21495vw;
    right: auto;
    left: 39.25234vw;
  }
  .beautiful-item--2 ._no img {
    width: 13.08411vw;
    height: 11.68224vw;
  }
  .beautiful-item--2 ._lalupa {
    top: -13.5514vw;
    right: 22.8972vw;
  }
  .beautiful-item--2 ._lalupa img {
    width: 15.65421vw;
    height: 27.1028vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .beautiful-item--2 {
    width: 46.74479vw;
    height: 45.3125vw;
    margin-top: 18.75vw;
    margin-right: 19.14062vw;
    padding: 12.23958vw 7.8125vw 0;
  }
  .beautiful-item--2 ._no {
    top: -8.85417vw;
    right: auto;
    left: 36.19792vw;
  }
  .beautiful-item--2 ._no img {
    width: 9.63542vw;
    height: 8.59375vw;
  }
  .beautiful-item--2 ._lalupa {
    top: -8.85417vw;
    right: 10.15625vw;
  }
  .beautiful-item--2 ._lalupa img {
    width: 10.67708vw;
    height: 18.35938vw;
  }
}

.beautiful-item__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  margin-right: -20px;
  font-weight: 500;
  line-height: 1;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
}

.beautiful-item__head ._txt1 {
  width: 100%;
  margin-bottom: 16px;
  font-size: 47px;
  letter-spacing: 0.06em;
}

.beautiful-item__head ._txt2 {
  font-size: 94px;
}

.beautiful-item__head ._txt3 {
  font-size: 47px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful-item__head {
    margin-right: -1.04167vw;
  }
  .beautiful-item__head ._txt1 {
    margin-bottom: 0.83333vw;
    font-size: 2.44792vw;
  }
  .beautiful-item__head ._txt2 {
    font-size: 4.89583vw;
  }
  .beautiful-item__head ._txt3 {
    font-size: 2.44792vw;
  }
}

@media screen and (max-width: 560px) {
  .beautiful-item__head {
    flex-direction: column;
    align-items: center;
    margin-right: 0;
    text-align: center;
  }
  .beautiful-item__head ._txt1 {
    margin-bottom: 2.33645vw;
    font-size: 5.14019vw;
  }
  .beautiful-item__head ._txt2 {
    margin-bottom: 2.33645vw;
    font-size: 13.08411vw;
  }
  .beautiful-item__head ._txt3 {
    font-size: 5.14019vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .beautiful-item__head {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .beautiful-item__head ._txt1 {
    margin-bottom: 1.30208vw;
    font-size: 4.16667vw;
  }
  .beautiful-item__head ._txt2 {
    margin-bottom: 1.30208vw;
    font-size: 11.19792vw;
  }
  .beautiful-item__head ._txt3 {
    font-size: 4.16667vw;
  }
}

.beautiful-item__body2,
.beautiful-item__body {
  margin-top: 14px;
  font-size: 18px;
  line-height: 2.11111;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful-item__body2,
  .beautiful-item__body {
    margin-top: 0.72917vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .beautiful-item__body2,
  .beautiful-item__body {
    display: none;
    margin-top: 1.16822vw;
    font-size: 3.03738vw;
    text-align: center;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .beautiful-item__body2,
  .beautiful-item__body {
    font-size: 2.34375vw;
  }
}

@media screen and (max-width: 960px) {
  .beautiful-item__body2 {
    display: block;
  }
}

/*----------------------------------------------------
	.beautiful__bubble
----------------------------------------------------*/
.beautiful__bubble > div {
  display: inline-block;
  z-index: 10;
  position: absolute;
}

.beautiful__bubble img {
  height: auto;
  opacity: 0.5;
}

.beautiful__bubble ._bubble1 {
  bottom: 1554px;
  left: calc(50% + 806px);
}

.beautiful__bubble ._bubble1 img {
  width: 234px;
}

.beautiful__bubble ._bubble2 {
  right: calc(50% + 740px);
  bottom: 313px;
}

.beautiful__bubble ._bubble2 img {
  width: 275px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .beautiful__bubble ._bubble1 {
    bottom: 80.9375vw;
    left: calc(50% + (806/1920*100vw));
  }
  .beautiful__bubble ._bubble1 img {
    width: 12.1875vw;
  }
  .beautiful__bubble ._bubble2 {
    right: calc(50% + (740/1920*100vw));
    bottom: 16.30208vw;
  }
  .beautiful__bubble ._bubble2 img {
    width: 14.32292vw;
  }
}

@media screen and (max-width: 560px) {
  .beautiful__bubble ._bubble1 {
    bottom: 329.86667vw;
    left: calc(50% + (118/375*100vw));
  }
  .beautiful__bubble ._bubble1 img {
    width: 32vw;
  }
  .beautiful__bubble ._bubble2 {
    right: calc(50% + (121/375*100vw));
    bottom: 134.13333vw;
  }
  .beautiful__bubble ._bubble2 img {
    width: 35.46667vw;
  }
}

@-webkit-keyframes beautifulItem {
  0% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
  50% {
    -webkit-transform: translate(0, 15px);
            transform: translate(0, 15px);
  }
  100% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
}

@keyframes beautifulItem {
  0% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
  50% {
    -webkit-transform: translate(0, 15px);
            transform: translate(0, 15px);
  }
  100% {
    -webkit-transform: translate(0, 0px);
            transform: translate(0, 0px);
  }
}

/*----------------------------------------------------
	contact
----------------------------------------------------*/
.contact {
  background: rgba(214, 213, 213, 0.8);
}

.contact__wrap {
  max-width: 740px;
  margin-right: auto;
  margin-left: auto;
  padding: 190px 0 265px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .contact__wrap {
    width: 38.54167vw;
    padding: 9.89583vw 0 13.80208vw;
  }
}

@media screen and (max-width: 560px) {
  .contact__wrap {
    padding: 17.52336vw 0 31.30841vw;
  }
}

.contact__lead {
  margin-top: 40px;
  color: #3b4043;
  font-size: 18px;
  line-height: 2.66667;
  letter-spacing: 0.06em;
  text-align: center;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .contact__lead {
    margin-top: 2.08333vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .contact__lead {
    margin-top: 8.8785vw;
    margin-right: auto;
    margin-left: auto;
    font-size: 3.03738vw;
    line-height: 2.07692;
  }
}

@media screen and (max-width: 560px) {
  .contact__lead {
    width: 51.40187vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .contact__lead {
    margin-top: 7.29167vw;
    font-size: 2.08333vw;
  }
}

.contact__body {
  margin-top: 70px;
  margin-right: auto;
  margin-left: auto;
}

.contact__body ._submit {
  margin-top: 149px;
  text-align: center;
}

.contact__body ._message {
  text-align: center;
}

.contact__body ._message span {
  display: inline-block;
  margin-top: 40px;
  font-size: 18px;
  line-height: 2.66667;
  letter-spacing: 0.06em;
  text-align: center;
}

.contact__body ._message .is-error {
  color: #f00;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .contact__body {
    margin-top: 3.64583vw;
  }
  .contact__body ._submit {
    margin-top: 7.76042vw;
  }
}

@media screen and (max-width: 960px) {
  .contact__body {
    width: 61.68224%;
    margin-top: 11.68224vw;
  }
  .contact__body ._submit {
    margin-top: 11.21495vw;
  }
  .contact__body ._message span {
    margin-top: 8.8785vw;
    font-size: 3.03738vw;
    line-height: 2.07692;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .contact__body {
    width: 48.4375%;
    margin-top: 7.29167vw;
  }
  .contact__body ._submit {
    margin-top: 8.85417vw;
  }
}

/*----------------------------------------------------
	loading
----------------------------------------------------*/
.loading__wrap {
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  pointer-events: none;
}

.loading__bg {
  -webkit-transform: translate(-50%, 0);
  z-index: 3;
  position: absolute;
  bottom: 0%;
  left: 50%;
  width: 100vw;
  height: 120vh;
          transform: translate(-50%, 0);
  background-color: #fff;
}

.loading__bg:before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: linear-gradient(to top, #d1d1d1 0%, rgba(203, 203, 203, 0.97) 43.35%, rgba(215, 217, 212, 0.87) 77.34%, rgba(255, 255, 255, 0.78) 100%);
  content: '';
}

.loading__txt {
  -webkit-transform: translate(-50%, -50%);
  display: flex;
  z-index: 4;
  position: absolute;
  top: 50%;
  left: 50%;
          transform: translate(-50%, -50%);
  color: #3b4043;
  font-weight: bold;
  font-size: 1.31772vw;
  letter-spacing: 0.2em;
}

.loading__txt span {
  display: inline-block;
  opacity: 0;
}

@media screen and (max-width: 560px) {
  .loading__txt {
    top: 48%;
    font-size: 4vw;
    white-space: nowrap;
  }
}

.loading__bubble span {
  -webkit-transform: scale(0);
  z-index: 10;
  position: absolute;
  width: 21.22987vw;
          transform: scale(0);
  background: url(../img/ico_bubble.png) center center/contain no-repeat;
  opacity: 0.5;
}

.loading__bubble span:before {
  display: block;
  width: 100%;
  padding-top: 103.10345%;
  content: '';
}

.loading__bubble span:nth-child(1) {
  top: calc(50% - 21.66911vw);
  left: calc(50% - 54.39239vw);
  width: 15.37335vw;
}

.loading__bubble span:nth-child(2) {
  top: calc(50% - 2.19619vw);
  left: calc(50% - 42.67936vw);
  width: 16.69107vw;
}

.loading__bubble span:nth-child(3) {
  top: calc(50% - 18.44802vw);
  left: calc(50% - 36.45681vw);
  width: 18.37482vw;
}

.loading__bubble span:nth-child(4) {
  top: calc(50% - 4.61201vw);
  left: calc(50% - 51.61054vw);
  width: 6.8082vw;
}

.loading__bubble span:nth-child(5) {
  top: calc(50% + 0.95168vw);
  left: calc(50% - 46.33968vw);
  width: 16.91069vw;
}

.loading__bubble span:nth-child(6) {
  top: calc(50% - 37.40849vw);
  left: calc(50% - 20.4978vw);
  width: 20.64422vw;
}

.loading__bubble span:nth-child(7) {
  top: calc(50% - 17.13031vw);
  left: calc(50% - 3.22108vw);
  width: 6.51537vw;
}

.loading__bubble span:nth-child(8) {
  top: calc(50% + 3.58712vw);
  left: calc(50% - 21.44949vw);
  width: 6.8082vw;
}

.loading__bubble span:nth-child(9) {
  top: calc(50% + 7.24744vw);
  left: calc(50% - 18.08199vw);
  width: 18.08199vw;
}

.loading__bubble span:nth-child(10) {
  top: calc(50% + 18.1552vw);
  left: calc(50% - 37.92094vw);
  width: 21.22987vw;
}

.loading__bubble span:nth-child(11) {
  top: calc(50% + 21.15666vw);
  left: calc(50% - 45.90044vw);
  width: 6.88141vw;
}

.loading__bubble span:nth-child(12) {
  top: calc(50% + 24.9634vw);
  left: calc(50% - 2.92826vw);
  width: 6.51537vw;
}

.loading__bubble span:nth-child(13) {
  top: calc(50% - 24.9634vw);
  right: calc(50% - 19.3265vw);
  width: 15.15373vw;
}

.loading__bubble span:nth-child(14) {
  top: calc(50% - 37.04246vw);
  right: calc(50% - 40.48316vw);
  width: 21.22987vw;
}

.loading__bubble span:nth-child(15) {
  top: calc(50% - 26.1347vw);
  right: calc(50% - 49.26794vw);
  width: 6.88141vw;
}

.loading__bubble span:nth-child(16) {
  top: calc(50% - 18.59444vw);
  right: calc(50% - 47.95022vw);
  width: 16.91069vw;
}

.loading__bubble span:nth-child(17) {
  top: calc(50% - 6.73499vw);
  right: calc(50% - 28.55051vw);
  width: 6.8082vw;
}

.loading__bubble span:nth-child(18) {
  top: calc(50% - 6.44217vw);
  right: calc(50% - 53.00146vw);
  width: 15.37335vw;
}

.loading__bubble span:nth-child(19) {
  top: calc(50% + 0.51245vw);
  right: calc(50% - 39.89751vw);
  width: 20.64422vw;
}

.loading__bubble span:nth-child(20) {
  top: calc(50% + 10.54173vw);
  right: calc(50% - 26.79356vw);
  width: 20.64422vw;
}

.loading__bubble span:nth-child(21) {
  top: calc(50% + 10.54173vw);
  right: calc(50% - 51.24451vw);
  width: 16.69107vw;
}

@media screen and (max-width: 560px) {
  .loading__bubble span:nth-child(1) {
    top: calc(50% - 46.25vw);
    left: calc(50% - 116.09375vw);
    width: 32.8125vw;
  }
  .loading__bubble span:nth-child(2) {
    top: calc(50% - 4.6875vw);
    left: calc(50% - 91.09375vw);
    width: 35.625vw;
  }
  .loading__bubble span:nth-child(3) {
    top: calc(50% - 39.375vw);
    left: calc(50% - 77.8125vw);
    width: 39.21875vw;
  }
  .loading__bubble span:nth-child(4) {
    top: calc(50% - 9.84375vw);
    left: calc(50% - 110.15625vw);
    width: 14.53125vw;
  }
  .loading__bubble span:nth-child(5) {
    top: calc(50% + 2.03125vw);
    left: calc(50% - 98.90625vw);
    width: 36.09375vw;
  }
  .loading__bubble span:nth-child(6) {
    top: calc(50% - 79.84375vw);
    left: calc(50% - 43.75vw);
    width: 44.0625vw;
  }
  .loading__bubble span:nth-child(7) {
    top: calc(50% - 36.5625vw);
    left: calc(50% - 6.875vw);
    width: 13.90625vw;
  }
  .loading__bubble span:nth-child(8) {
    top: calc(50% + 7.65625vw);
    left: calc(50% - 62.5vw);
    width: 14.53125vw;
  }
  .loading__bubble span:nth-child(9) {
    top: calc(50% + 15.46875vw);
    left: calc(50% - 38.59375vw);
    width: 38.59375vw;
  }
  .loading__bubble span:nth-child(10) {
    top: calc(50% + 38.75vw);
    left: calc(50% - 80.9375vw);
    width: 45.3125vw;
  }
  .loading__bubble span:nth-child(11) {
    top: calc(50% + 45.15625vw);
    left: calc(50% - 97.96875vw);
    width: 14.6875vw;
  }
  .loading__bubble span:nth-child(12) {
    top: calc(50% + 53.28125vw);
    left: calc(50% - 6.25vw);
    width: 13.90625vw;
  }
  .loading__bubble span:nth-child(13) {
    top: calc(50% - 53.28125vw);
    right: calc(50% - 41.25vw);
    width: 32.34375vw;
  }
  .loading__bubble span:nth-child(14) {
    top: calc(50% - 79.0625vw);
    right: calc(50% - 86.40625vw);
    width: 45.3125vw;
  }
  .loading__bubble span:nth-child(15) {
    top: calc(50% - 55.78125vw);
    right: calc(50% - 105.15625vw);
    width: 14.6875vw;
  }
  .loading__bubble span:nth-child(16) {
    top: calc(50% - 39.6875vw);
    right: calc(50% - 102.34375vw);
    width: 36.09375vw;
  }
  .loading__bubble span:nth-child(17) {
    top: calc(50% - 14.375vw);
    right: calc(50% - 60.9375vw);
    width: 14.53125vw;
  }
  .loading__bubble span:nth-child(18) {
    top: calc(50% - 13.75vw);
    right: calc(50% - 113.125vw);
    width: 32.8125vw;
  }
  .loading__bubble span:nth-child(19) {
    top: calc(50% + 1.09375vw);
    right: calc(50% - 85.15625vw);
    width: 44.0625vw;
  }
  .loading__bubble span:nth-child(20) {
    top: calc(50% + 22.5vw);
    right: calc(50% - 57.1875vw);
    width: 44.0625vw;
  }
  .loading__bubble span:nth-child(21) {
    top: calc(50% + 22.5vw);
    right: calc(50% - 109.375vw);
    width: 35.625vw;
  }
}

.loading__lalupa {
  -webkit-transform: translate(-50%, -50%) scale(1);
  z-index: 2;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 19.91215vw;
          transform: translate(-50%, -50%) scale(1);
}

.loading__lalupa img {
  width: 100%;
  height: auto;
  will-change: transform;
}

.loading__lalupa img.on {
  -webkit-animation: shake-lalupa 2.0s 0.5s linear;
          animation: shake-lalupa 2.0s 0.5s linear;
}

@media screen and (max-width: 560px) {
  .loading__lalupa {
    width: 53.33333vw;
  }
}

.loading__bgW {
  -webkit-transform: translate(-50%, -50%);
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
          transform: translate(-50%, -50%);
  background: linear-gradient(0deg, #8f8c8c 0%, rgba(152, 149, 149, 0.97) 43.35%, rgba(172, 174, 169, 0.87) 77.34%, rgba(238, 235, 235, 0.78) 100%);
}

.loading__bgW:before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  content: '';
}

.loading__bgW span {
  -webkit-transform: scale(0);
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 21.22987vw;
  height: 21.88873vw;
          transform: scale(0);
  background: url(../img/ico_bubble.png) center center/contain;
  opacity: 0.8;
}

/*----------------------------------------------------
	mv
----------------------------------------------------*/
.mv {
  display: flex;
  position: relative;
  height: 100vh;
  background: transparent linear-gradient(0deg, #D1D1D1 0%, #CBCBCBF7 43%, #D7D9D4DE 77%, #FFFFFFC6 100%) 0% 0% no-repeat padding-box;
}

.mv:after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 241px;
  background: transparent linear-gradient(0deg, #586056BE 0%, #787E76AC 37%, #D9D9D9 100%) 0% 0% no-repeat padding-box;
  content: '';
  mix-blend-mode: multiply;
  opacity: 1;
}

@media screen and (min-width: 961px) {
  .mv:after {
    height: 12.55208vw;
  }
}

@media screen and (max-width: 960px) {
  .mv:after {
    height: calc(50% - 41.33333vw);
  }
}

.mv__wrap {
  width: 100%;
  height: 100%;
  max-height: 1073px;
  margin: auto auto 0;
}

.mv__body {
  z-index: 2;
  position: relative;
  height: 100%;
  opacity: 0;
}

.mv__body ._txt1 {
  left: 1090px;
  color: #3b4043;
  font-weight: 600;
  font-size: 28px;
  line-height: 1.67857;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.15em;
  text-align: center;
}

.mv__body ._ec {
  position: absolute;
  width: 18.69159vw;
}

.mv__body ._pic1[data-animation-lalupa] {
  -webkit-animation: shake-lalupa 2.5s linear infinite;
          animation: shake-lalupa 2.5s linear infinite;
  will-change: transform;
}

.mv__body ._pic1 [data-animation-awa] {
  -webkit-animation: shake-awa 2.5s 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) infinite;
          animation: shake-awa 2.5s 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) infinite;
  will-change: transform;
}

.mv__body ._pic1 ._awa1 {
  position: absolute;
  top: 2.36626%;
  left: 16.72598%;
  width: 7.96875vw;
  height: auto;
}

.mv__body ._pic1 ._awa2 {
  position: absolute;
  top: 43.72428%;
  left: 3.73665%;
  width: 7.55208vw;
  height: auto;
}

.mv__body ._pic1 ._awa3 {
  position: absolute;
  top: 55.55556%;
  left: 72.06406%;
  width: 7.8125vw;
  height: auto;
}

.mv__body ._pic1 ._awa4 {
  position: absolute;
  top: 76.44033%;
  left: 13.52313%;
  width: 6.77083vw;
  height: auto;
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .mv__body ._ec {
    bottom: 59.89583vw;
    left: 9.11458vw;
    width: 32.71028vw;
  }
}

@media screen and (min-width: 961px) {
  .mv__body ._txt1 {
    position: absolute;
    bottom: 38.38542vw;
    left: 56.77083vw;
    font-size: 1.45833vw;
  }
  .mv__body ._txt2 {
    position: absolute;
    bottom: 26.97917vw;
    left: 53.64583vw;
  }
  .mv__body ._txt2 img {
    width: 26.66667vw;
    height: 9.73958vw;
  }
  .mv__body ._txt3 {
    position: absolute;
    bottom: 22.39583vw;
    left: 64.16667vw;
  }
  .mv__body ._txt3 img {
    width: 6.31615vw;
    height: 2.55208vw;
  }
  .mv__body ._ec {
    bottom: 40.625vw;
    left: 14.58333vw;
    width: 9.58333vw;
  }
  .mv__body ._pic1 {
    position: absolute;
    bottom: 2.08333vw;
    left: 21.19792vw;
  }
  .mv__body ._pic1 img {
    width: 27.1875vw;
    height: auto;
  }
  .mv__body ._pic2 {
    position: absolute;
    bottom: 4.84375vw;
    left: 57.39583vw;
  }
  .mv__body ._pic2 img {
    width: 20.3125vw;
    height: auto;
  }
  .mv__body ._fukidashi {
    position: absolute;
    bottom: 37.13542vw;
    left: 43.4375vw;
  }
  .mv__body ._fukidashi img {
    width: 9.375vw;
    height: 8.38542vw;
  }
}

@media screen and (max-width: 960px) {
  .mv__body ._txt1 {
    position: absolute;
    bottom: calc(50% - -61.6vw);
    left: 19.73333vw;
    font-size: 4vw;
  }
  .mv__body ._txt2 {
    position: absolute;
    bottom: calc(50% - -34.66667vw);
    left: 15.46667vw;
  }
  .mv__body ._txt2 img {
    width: 67.46667vw;
    height: auto;
  }
  .mv__body ._txt3 {
    position: absolute;
    bottom: calc(50% - -26.13333vw);
    left: 43.73333vw;
  }
  .mv__body ._txt3 img {
    width: 13.33333vw;
    height: 5.33333vw;
  }
  .mv__body ._ec {
    position: absolute;
    bottom: calc(50% + 2.66667vw);
    left: 5.33333vw;
    width: 18.69159vw;
  }
  .mv__body ._pic1 {
    position: absolute;
    bottom: calc(50% - 66.93333vw);
    left: 12.53333vw;
  }
  .mv__body ._pic1 img {
    width: 44.53333vw;
    height: 77.06667vw;
  }
  .mv__body ._pic1 ._awa1 {
    width: 12.26667vw;
  }
  .mv__body ._pic1 ._awa2 {
    width: 11.73333vw;
  }
  .mv__body ._pic1 ._awa3 {
    width: 11.73333vw;
  }
  .mv__body ._pic1 ._awa4 {
    width: 10.4vw;
  }
  .mv__body ._pic2 {
    position: absolute;
    bottom: calc(50% - 70.66667vw);
    left: 45.33333vw;
  }
  .mv__body ._pic2 img {
    width: 53.33333vw;
    max-width: none;
    height: auto;
  }
  .mv__body ._fukidashi {
    position: absolute;
    bottom: calc(50% - 9.86667vw);
    left: 54.13333vw;
  }
  .mv__body ._fukidashi img {
    width: 14.13333vw;
    height: 12.8vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .mv__body ._txt1 {
    bottom: 91.14583vw;
    left: 33.46354vw;
    font-size: 2.34375vw;
  }
  .mv__body ._txt2 {
    position: absolute;
    bottom: 70.3125vw;
    left: 24.73958vw;
  }
  .mv__body ._txt2 img {
    width: 50.52083vw;
    height: 18.48958vw;
  }
  .mv__body ._txt3 {
    position: absolute;
    bottom: 62.23958vw;
    left: 44.53125vw;
  }
  .mv__body ._txt3 img {
    width: 10.9375vw;
    height: 4.42708vw;
  }
  .mv__body ._pic1 {
    position: absolute;
    bottom: 3.77604vw;
    left: 15.10417vw;
  }
  .mv__body ._pic1 img {
    width: 37.5vw;
    height: 64.84375vw;
  }
  .mv__body ._pic1 ._awa1 {
    width: 10.28646vw;
  }
  .mv__body ._pic1 ._awa2 {
    width: 9.76562vw;
  }
  .mv__body ._pic1 ._awa3 {
    width: 10.02604vw;
  }
  .mv__body ._pic1 ._awa4 {
    width: 8.72396vw;
  }
  .mv__body ._pic2 {
    position: absolute;
    bottom: 5.20833vw;
    left: 46.875vw;
  }
  .mv__body ._pic2 img {
    width: 49.47917vw;
    max-width: none;
  }
  .mv__body ._fukidashi {
    position: absolute;
    bottom: 62.10938vw;
    left: 8.72396vw;
  }
  .mv__body ._fukidashi img {
    width: 10.54688vw;
    height: 9.24479vw;
  }
}

/*----------------------------------------------------
	.mv__bubble
----------------------------------------------------*/
.mv__bubble > div {
  display: inline-block;
  z-index: 10;
  position: absolute;
}

.mv__bubble img {
  height: auto;
  opacity: 0.5;
}

.mv__bubble ._bubble1 {
  -webkit-animation-delay: -2.0s !important;
  bottom: 32.13542vw;
  left: 82.29167vw;
          animation-delay: -2.0s !important;
}

.mv__bubble ._bubble1 img {
  width: 19.79167vw;
}

.mv__bubble ._bubble2 {
  -webkit-animation-delay: -1.5s !important;
  bottom: 48.33333vw;
  left: 50.78125vw;
          animation-delay: -1.5s !important;
}

.mv__bubble ._bubble2 img {
  width: 9.11458vw;
}

.mv__bubble ._bubble3 {
  -webkit-animation-delay: -1.0s !important;
  bottom: 43.17708vw;
  left: 49.58333vw;
          animation-delay: -1.0s !important;
}

.mv__bubble ._bubble3 img {
  width: 4.32292vw;
}

.mv__bubble ._bubble4 {
  -webkit-animation-delay: -0.5s !important;
  bottom: 9.73958vw;
  left: 50.98958vw;
          animation-delay: -0.5s !important;
}

.mv__bubble ._bubble4 img {
  width: 6.40625vw;
}

.mv__bubble ._bubble5 {
  -webkit-animation-delay: 0s !important;
  bottom: 3.54167vw;
  left: 12.23958vw;
          animation-delay: 0s !important;
}

.mv__bubble ._bubble5 img {
  width: 13.22917vw;
}

.mv__bubble [data-animation-bubble] {
  -webkit-animation: floating-bubble 1.8s ease-in-out infinite alternate;
          animation: floating-bubble 1.8s ease-in-out infinite alternate;
}

@media screen and (max-width: 960px) {
  .mv__bubble ._bubble1 {
    display: none;
  }
  .mv__bubble ._bubble2 {
    bottom: calc(50% - -9.33333vw);
    left: -5.33333vw;
  }
  .mv__bubble ._bubble2 img {
    width: 48vw;
  }
  .mv__bubble ._bubble3 {
    bottom: calc(50% - 44vw);
    left: 53.33333vw;
  }
  .mv__bubble ._bubble3 img {
    width: 34.66667vw;
  }
  .mv__bubble ._bubble4 {
    bottom: calc(50% - 52vw);
    left: 84vw;
  }
  .mv__bubble ._bubble4 img {
    width: 10.66667vw;
  }
  .mv__bubble ._bubble5 {
    bottom: calc(50% - 102.66667vw);
    left: -5.33333vw;
  }
  .mv__bubble ._bubble5 img {
    width: 32vw;
  }
}

@-webkit-keyframes shake-lalupa {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  5% {
    -webkit-transform: translate3d(-0.8vw, 0, 0);
            transform: translate3d(-0.8vw, 0, 0);
  }
  10% {
    -webkit-transform: translate3d(0.8vw, 0, 0);
            transform: translate3d(0.8vw, 0, 0);
  }
  15% {
    -webkit-transform: translate3d(-0.53333vw, 0, 0);
            transform: translate3d(-0.53333vw, 0, 0);
  }
  20% {
    -webkit-transform: translate3d(0.53333vw, 0, 0);
            transform: translate3d(0.53333vw, 0, 0);
  }
  25% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  30% {
  }
  35% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}

@keyframes shake-lalupa {
  0% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  5% {
    -webkit-transform: translate3d(-0.8vw, 0, 0);
            transform: translate3d(-0.8vw, 0, 0);
  }
  10% {
    -webkit-transform: translate3d(0.8vw, 0, 0);
            transform: translate3d(0.8vw, 0, 0);
  }
  15% {
    -webkit-transform: translate3d(-0.53333vw, 0, 0);
            transform: translate3d(-0.53333vw, 0, 0);
  }
  20% {
    -webkit-transform: translate3d(0.53333vw, 0, 0);
            transform: translate3d(0.53333vw, 0, 0);
  }
  25% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  30% {
  }
  35% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  100% {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}

@-webkit-keyframes shake-awa {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  3% {
    -webkit-transform: scale(0.92);
            transform: scale(0.92);
  }
  10% {
    -webkit-transform: scale(1.24);
            transform: scale(1.24);
  }
  15% {
    -webkit-transform: scale(0.92);
            transform: scale(0.92);
  }
  20% {
    -webkit-transform: scale(1.24);
            transform: scale(1.24);
  }
  25% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes shake-awa {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  3% {
    -webkit-transform: scale(0.92);
            transform: scale(0.92);
  }
  10% {
    -webkit-transform: scale(1.24);
            transform: scale(1.24);
  }
  15% {
    -webkit-transform: scale(0.92);
            transform: scale(0.92);
  }
  20% {
    -webkit-transform: scale(1.24);
            transform: scale(1.24);
  }
  25% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes floating-bubble {
  0% {
    -webkit-transform: translateY(-15px);
            transform: translateY(-15px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes floating-bubble {
  0% {
    -webkit-transform: translateY(-15px);
            transform: translateY(-15px);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

/*----------------------------------------------------
	mv2
----------------------------------------------------*/
.mv2 {
  display: flex;
  position: relative;
  height: 100vh;
  background: rgba(214, 213, 213, 0.25);
}

.mv2:after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 241px;
  background: transparent linear-gradient(0deg, #586056BE 0%, #787E76AC 37%, #D9D9D9 100%) 0% 0% no-repeat padding-box;
  content: '';
  mix-blend-mode: multiply;
  opacity: 1;
}

@media screen and (min-width: 961px) {
  .mv2:after {
    height: 12.55208vw;
  }
}

@media screen and (max-width: 960px) {
  .mv2 {
    height: 88.78505vw;
  }
  .mv2:after {
    height: 21.96262vw;
  }
}

.mv2__wrap {
  z-index: 2;
  position: relative;
  width: 100%;
  height: 100%;
  margin: auto auto;
}

.mv2__body {
  z-index: 2;
  position: relative;
  height: 100%;
  text-align: center;
}

.mv2__body ._txt1 {
  color: #3b4043;
  font-weight: 500;
  font-size: 33px;
  line-height: 1.78788;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.06em;
  text-align: center;
}

.mv2__body ._lalupa {
  position: relative;
}

.mv2__body ._lalupa ._light._light {
  -webkit-mask-image: linear-gradient(120deg, transparent 0%, transparent 20%, rgba(255, 255, 255, 0.3) 20%, rgba(255, 255, 255, 0.3) 50%, transparent 50%);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 200% 200%;
  -webkit-mask-position: 120% 0%;
  -webkit-animation: shake-tuya 3.5s ease infinite;
  position: absolute;
  top: 0;
  left: 0;
          animation: shake-tuya 3.5s ease infinite;
          mask-image: linear-gradient(120deg, transparent 0%, transparent 20%, rgba(255, 255, 255, 0.3) 20%, rgba(255, 255, 255, 0.3) 50%, transparent 50%);
          mask-position: 120% 0%;
          mask-repeat: no-repeat;
          mask-size: 200% 200%;
  opacity: 1;
}

.mv2__body ._lalupa[data-animation-tuya] img {
  opacity: 0.35;
}

@media screen and (min-width: 961px) {
  .mv2__body ._txt1 {
    position: absolute;
    bottom: 35.46875vw;
    left: 40.98958vw;
    font-size: 1.71875vw;
  }
  .mv2__body ._fukidashi {
    position: absolute;
    bottom: 15.83333vw;
    left: 32.08333vw;
  }
  .mv2__body ._fukidashi img {
    width: 16.04167vw;
    height: 14.42708vw;
  }
  .mv2__body ._lalupa {
    position: absolute;
    bottom: 3.33333vw;
    left: 37.23958vw;
  }
  .mv2__body ._lalupa img {
    width: 32.5vw;
    height: 27.65625vw;
  }
}

@media screen and (max-width: 960px) {
  .mv2__body ._txt1 {
    position: absolute;
    bottom: 60.04673vw;
    left: 19.15888vw;
    font-size: 4.20561vw;
  }
  .mv2__body ._fukidashi {
    position: absolute;
    bottom: 25.70093vw;
    left: 17.75701vw;
  }
  .mv2__body ._fukidashi img {
    width: 31.54206vw;
    height: auto;
  }
  .mv2__body ._lalupa {
    position: absolute;
    bottom: 3.73832vw;
    left: 29.6729vw;
  }
  .mv2__body ._lalupa img {
    width: 56.07477vw;
    height: auto;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .mv2__body ._txt1 {
    position: absolute;
    bottom: 51.04167vw;
    left: 24.73958vw;
    font-size: 3.38542vw;
  }
  .mv2__body ._fukidashi {
    position: absolute;
    bottom: 23.56771vw;
    left: 23.30729vw;
  }
  .mv2__body ._fukidashi img {
    width: 25vw;
    height: auto;
  }
  .mv2__body ._lalupa {
    position: absolute;
    bottom: 4.16667vw;
    left: 34.375vw;
  }
  .mv2__body ._lalupa img {
    width: 45.3125vw;
    height: auto;
  }
}

/*----------------------------------------------------
	.mv2__bubble
----------------------------------------------------*/
.mv2__bubble > div {
  display: inline-block;
  z-index: 10;
  position: absolute;
}

.mv2__bubble img {
  height: auto;
  opacity: 0.5;
}

.mv2__bubble ._bubble1 {
  -webkit-animation-delay: 0s !important;
  bottom: 26.66667vw;
  left: 74.42708vw;
          animation-delay: 0s !important;
}

.mv2__bubble ._bubble1 img {
  width: 13.22917vw;
}

.mv2__bubble ._bubble2 {
  -webkit-animation-delay: 0.5s !important;
  bottom: 4.27083vw;
  left: 73.80208vw;
          animation-delay: 0.5s !important;
}

.mv2__bubble ._bubble2 img {
  width: 6.40625vw;
}

.mv2__bubble ._bubble3 {
  -webkit-animation-delay: 1.0s !important;
  bottom: 39.32292vw;
  left: 25.46875vw;
          animation-delay: 1.0s !important;
}

.mv2__bubble ._bubble3 img {
  width: 6.66667vw;
}

.mv2__bubble ._bubble4 {
  -webkit-animation-delay: 1.5s !important;
  bottom: 8.59375vw;
  left: 17.03125vw;
          animation-delay: 1.5s !important;
}

.mv2__bubble ._bubble4 img {
  width: 7.86458vw;
}

.mv2__bubble [data-animation-bubble] {
  -webkit-animation: floating-bubble 1.8s ease-in-out infinite alternate;
          animation: floating-bubble 1.8s ease-in-out infinite alternate;
}

@-webkit-keyframes shake-tuya-opacity {
  0% {
    opacity: 0.35;
  }
  3% {
    opacity: 0.25;
  }
  10% {
    opacity: 0.65;
  }
  50% {
    opacity: 0.35;
  }
  100% {
    opacity: 0.35;
  }
}

@keyframes shake-tuya-opacity {
  0% {
    opacity: 0.35;
  }
  3% {
    opacity: 0.25;
  }
  10% {
    opacity: 0.65;
  }
  50% {
    opacity: 0.35;
  }
  100% {
    opacity: 0.35;
  }
}

@-webkit-keyframes shake-tuya {
  0% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
    opacity: 0.8;
  }
  20% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
  }
  65% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
  }
  80% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
    opacity: 0.8;
  }
  81% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
    opacity: 0;
  }
  100% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
    opacity: 0;
  }
}

@keyframes shake-tuya {
  0% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
    opacity: 0.8;
  }
  20% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
  }
  65% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
  }
  80% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
    opacity: 0.8;
  }
  81% {
    -webkit-mask-position: -90% 0%;
            mask-position: -90% 0%;
    opacity: 0;
  }
  100% {
    -webkit-mask-position: 140% 0%;
            mask-position: 140% 0%;
    opacity: 0;
  }
}

/*----------------------------------------------------
	product
----------------------------------------------------*/
.product {
  position: relative;
  background: url(../img/bg-stripe.png);
}

@media screen and (max-width: 960px) {
  .product {
    background-size: 10px 17px;
  }
}

.product__wrap {
  position: relative;
  max-width: 1000px;
  margin-right: auto;
  margin-left: auto;
  padding: 8.33333vw 0 16.14583vw;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product__wrap {
    max-width: 52.08333vw;
  }
}

@media screen and (max-width: 960px) {
  .product__wrap {
    padding: 20.79439vw 0 34.57944vw;
  }
}

.product__head .titleA ._ja {
  width: 307px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product__head .titleA ._ja {
    width: 15.98958vw;
  }
}

@media screen and (max-width: 560px) {
  .product__head .titleA ._ja {
    width: 46.72897vw;
  }
}

.product-item {
  margin-top: 11.71875vw;
  text-align: center;
}

@media screen and (max-width: 960px) {
  .product-item {
    margin-top: 16.35514vw;
  }
  .product-item + .product-item {
    margin-top: 28.97196vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item + .product-item {
    margin-top: 20.44271vw;
  }
}

.product-item__head {
  color: #3b4043;
  font-weight: 500;
  font-size: 35px;
  line-height: 1.71429;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.06em;
  text-align: center;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product-item__head {
    font-size: 1.82292vw;
  }
}

@media screen and (max-width: 960px) {
  .product-item__head {
    font-size: 4.6729vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item__head {
    font-size: 3.38753vw;
  }
}

.product-item__pic ._product1 img {
  width: 211px;
  height: auto;
}

.product-item__pic ._product2 {
  margin-top: 30px;
  margin-bottom: 20px;
}

.product-item__pic ._product2 img {
  width: 196px;
  height: auto;
}

.product-item__pic ._product3 {
  margin-top: 30px;
  margin-bottom: 20px;
}

.product-item__pic ._product3 img {
  width: 240px;
  height: auto;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product-item__pic ._product1 img {
    width: 10.98958vw;
  }
  .product-item__pic ._product2 {
    margin-top: 1.5625vw;
    margin-bottom: 1.04167vw;
  }
  .product-item__pic ._product2 img {
    width: 10.20833vw;
  }
  .product-item__pic ._product3 {
    margin-top: 1.5625vw;
    margin-bottom: 1.04167vw;
  }
  .product-item__pic ._product3 img {
    width: 12.5vw;
  }
}

@media screen and (max-width: 960px) {
  .product-item__pic ._product1 img {
    width: 34.11215vw;
  }
  .product-item__pic ._product2 {
    margin-top: 5.14019vw;
    margin-bottom: 5.14019vw;
  }
  .product-item__pic ._product2 img {
    width: 28.50467vw;
  }
  .product-item__pic ._product3 {
    margin-top: 7.00935vw;
    margin-bottom: 4.6729vw;
  }
  .product-item__pic ._product3 img {
    width: 35.04673vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item__pic ._product1 img {
    width: 23.4375vw;
  }
  .product-item__pic ._product2 {
    margin-top: 2.86458vw;
    margin-bottom: 2.86458vw;
  }
  .product-item__pic ._product2 img {
    width: 20.3125vw;
  }
  .product-item__pic ._product3 {
    margin-top: 2.86458vw;
    margin-bottom: 2.86458vw;
  }
  .product-item__pic ._product3 img {
    width: 28.64583vw;
  }
}

.product-item__point ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.product-item__point li {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 32px;
  margin-top: 10px;
  margin-left: 10px;
  padding: 0 1.2em;
  border: 1px solid #cddbc6;
  border-radius: 16px;
  background: rgba(219, 232, 213, 0.4);
  font-weight: 500;
  font-size: 20px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
}

.product-item__point ._point1 {
  max-width: 500px;
  margin-right: auto;
  margin-left: auto;
}

.product-item__point ._point2 li {
  border: 1px solid #fbdfd4;
  background: rgba(251, 223, 212, 0.4);
}

.product-item__point ._point3 {
  margin-inline: auto;
}

.product-item__point ._point3 li {
  border: 1px solid #cddbc6;
  background: rgba(219, 232, 213, 0.4);
}

@media screen and (min-width: 961px) {
  .product-item__point ._point3 {
    max-width: 500px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product-item__point li {
    height: 1.66667vw;
    margin-top: 0.52083vw;
    margin-left: 0.52083vw;
    border-radius: 0.83333vw;
    font-size: 1.04167vw;
  }
  .product-item__point ._point3 {
    max-width: 27.08333vw;
  }
}

@media screen and (max-width: 960px) {
  .product-item__point ._point1 {
    max-width: 67.75701vw;
    margin-right: auto;
    margin-left: auto;
  }
  .product-item__point li {
    height: 5.7243vw;
    margin-top: 2.57009vw;
    margin-left: 1.63551vw;
    border-radius: 3.73832vw;
    font-size: 3.50467vw;
  }
  .product-item__point ._point3 {
    max-width: 70.09346vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item__point ._point1 {
    max-width: 38.02083vw;
  }
  .product-item__point ._point2 {
    max-width: 44.27083vw;
    margin-right: auto;
    margin-left: auto;
  }
  .product-item__point li {
    height: 3.38542vw;
    margin-top: 1.30208vw;
    margin-left: 0.91146vw;
    border-radius: 1.95312vw;
    font-size: 1.95312vw;
  }
  .product-item__point ._point3 {
    max-width: 65.10417vw;
  }
}

.product-item__name {
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin-top: 44px;
}

.product-item__name ._logo {
  width: 80px;
  height: 32px;
  margin-right: 20px;
}

.product-item__name ._logo img {
  width: auto;
  height: 100%;
}

.product-item__name ._name {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.2em;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product-item__name ._logo {
    width: 4.16667vw;
    height: 1.66667vw;
    margin-right: 1.04167vw;
  }
  .product-item__name ._name {
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .product-item__name {
    margin-top: 10.51402vw;
  }
  .product-item__name ._logo {
    width: 13.78505vw;
    height: 5.60748vw;
    margin-right: 2.80374vw;
  }
  .product-item__name ._name {
    font-size: 2.80374vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item__name {
    margin-top: 4.55729vw;
  }
  .product-item__name ._logo {
    width: 10.02604vw;
    height: 4.03646vw;
    margin-right: 2.60417vw;
  }
  .product-item__name ._name {
    font-size: 1.95312vw;
  }
}

.product-item__price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin-top: 10px;
}

.product-item__price span {
  font-weight: normal;
  font-size: 25px;
  font-family: "American Typewriter";
  letter-spacing: 0.06em;
}

.product-item__price ._t1 {
  margin-right: 0.2em;
}

.product-item__price ._t2 {
  margin-right: 1.5em;
}

.product-item__price ._t5 {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-left: 0.2em;
  font-weight: 500;
  font-size: 20px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 960px) {
  .product-item__price {
    margin-top: 2.33645vw;
  }
  .product-item__price span {
    font-size: 4.6729vw;
  }
  .product-item__price ._t5 {
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .product-item__price {
    margin-top: 0.78125vw;
  }
  .product-item__price span {
    font-size: 2.73438vw;
  }
  .product-item__price ._t5 {
    font-size: 1.69271vw;
  }
}

/*----------------------------------------------------
	.product__bubble
----------------------------------------------------*/
.product__bubble > div {
  display: inline-block;
  z-index: 10;
  position: absolute;
}

.product__bubble img {
  height: auto;
  opacity: 0.5;
}

.product__bubble ._bubble1 {
  bottom: 2168px;
  left: calc(50% + 372px);
}

.product__bubble ._bubble1 img {
  width: 112px;
}

.product__bubble ._bubble2 {
  right: calc(50% + 563px);
  bottom: 1852px;
}

.product__bubble ._bubble2 img {
  width: 99px;
}

.product__bubble ._bubble3 {
  right: calc(50% + 357px);
  bottom: 1424px;
}

.product__bubble ._bubble3 img {
  width: 142px;
}

.product__bubble ._bubble4 {
  bottom: 998px;
  left: calc(50% + 521px);
}

.product__bubble ._bubble4 img {
  width: 141px;
}

.product__bubble ._bubble5 {
  bottom: 237px;
  left: calc(50% + 228px);
}

.product__bubble ._bubble5 img {
  width: 99px;
}

.product__bubble ._bubble6 {
  right: calc(50% + 407px);
  bottom: 81px;
}

.product__bubble ._bubble6 img {
  width: 112px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .product__bubble ._bubble1 {
    bottom: 112.91667vw;
    left: calc(50% + (372/1920*100vw));
  }
  .product__bubble ._bubble1 img {
    width: 5.83333vw;
  }
  .product__bubble ._bubble2 {
    right: calc(50% + (563/1920*100vw));
    bottom: 96.45833vw;
  }
  .product__bubble ._bubble2 img {
    width: 5.15625vw;
  }
  .product__bubble ._bubble3 {
    right: calc(50% + (357/1920*100vw));
    bottom: 74.16667vw;
  }
  .product__bubble ._bubble3 img {
    width: 7.39583vw;
  }
  .product__bubble ._bubble4 {
    bottom: 51.97917vw;
    left: calc(50% + (521/1920*100vw));
  }
  .product__bubble ._bubble4 img {
    width: 7.34375vw;
  }
  .product__bubble ._bubble5 {
    bottom: 12.34375vw;
    left: calc(50% + (228/1920*100vw));
  }
  .product__bubble ._bubble5 img {
    width: 5.15625vw;
  }
  .product__bubble ._bubble6 {
    right: calc(50% + (407/1920*100vw));
    bottom: 4.21875vw;
  }
  .product__bubble ._bubble6 img {
    width: 5.83333vw;
  }
}

@media screen and (max-width: 560px) {
  .product__bubble ._bubble1 {
    bottom: 358.66667vw;
    left: calc(50% + (117/375*100vw));
  }
  .product__bubble ._bubble1 img {
    width: 14.13333vw;
  }
  .product__bubble ._bubble2 {
    right: calc(50% + (136/375*100vw));
    bottom: 254.13333vw;
  }
  .product__bubble ._bubble2 img {
    width: 10.66667vw;
  }
  .product__bubble ._bubble3 {
    bottom: 224.8vw;
    left: calc(50% + (67/375*100vw));
  }
  .product__bubble ._bubble3 img {
    width: 26.66667vw;
  }
  .product__bubble ._bubble4 {
    right: calc(50% + (117/375*100vw));
    bottom: 172vw;
  }
  .product__bubble ._bubble4 img {
    width: 18.13333vw;
  }
  .product__bubble ._bubble5 {
    bottom: 134.13333vw;
    left: calc(50% + (125/375*100vw));
  }
  .product__bubble ._bubble5 img {
    width: 12.8vw;
  }
  .product__bubble ._bubble6 {
    right: calc(50% + (78/375*100vw));
    bottom: 12.26667vw;
  }
  .product__bubble ._bubble6 img {
    width: 14.13333vw;
  }
}

/*----------------------------------------------------
	shop
----------------------------------------------------*/
.shop__wrap {
  max-width: 1236px;
  margin: auto;
  padding: 208px 0 306px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .shop__wrap {
    max-width: 64.375vw;
    padding: 10.83333vw 0 15.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .shop__wrap {
    padding: 16.82243vw 0 23.83178vw;
  }
}

.shop__head .titleA ._ja {
  width: 415px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .shop__head .titleA ._ja {
    width: 21.61458vw;
  }
}

@media screen and (max-width: 960px) {
  .shop__head .titleA ._ja {
    width: 60.74766vw;
  }
}

.shop__body {
  margin-top: 155px;
}

@media screen and (max-width: 960px) {
  .shop__body {
    margin-top: 14.01869vw;
  }
}

.shop-item {
  display: -ms-grid;
  display: grid;
}

.shop-item + .shop-item {
  margin-top: 173px;
}

@media screen and (min-width: 961px) {
  .shop-item:nth-of-type(odd) {
    -ms-grid-columns: 48.54369% 5.42071% 46.0356%;
    -ms-grid-rows: auto 1fr;
    grid-column-gap: 5.42071%;
    grid-template-rows: auto 1fr;
    grid-template-columns: 48.54369% 46.0356%;
        grid-template-areas: "head pic" "body pic";
  }
  .shop-item:nth-of-type(even) {
    -ms-grid-columns: 46.0356% 5.42071% 48.54369%;
    -ms-grid-rows: auto 1fr;
    grid-column-gap: 5.42071%;
    grid-template-rows: auto 1fr;
    grid-template-columns: 46.0356% 48.54369%;
        grid-template-areas: "pic head" "pic body";
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .shop-item + .shop-item {
    margin-top: 9.01042vw;
  }
}

@media screen and (max-width: 960px) {
  .shop-item {
        grid-template-areas: "head" "pic" "body";
    width: 60.74766vw;
    margin-right: auto;
    margin-left: auto;
  }
  .shop-item + .shop-item {
    margin-top: 16.1215vw;
  }
}

.shop-item__head {
  grid-area: head;
}

.shop-item__head ._name {
  color: #3b4043;
  font-weight: 500;
  font-size: 20px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.13em;
  text-align: left;
}

@media screen and (min-width: 961px) {
  .shop-item__head {
    padding-top: 16px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .shop-item__head {
    padding-top: 0.83333vw;
  }
  .shop-item__head ._name {
    font-size: 1.04167vw;
  }
}

@media screen and (max-width: 960px) {
  .shop-item__head ._name {
    font-size: 3.03738vw;
    text-align: center;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .shop-item__head ._name {
    font-size: 2.08333vw;
    text-align: center;
  }
}

.shop-item__body {
  grid-area: body;
}

.shop-item__body ._txt1 {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-top: 16px;
  font-size: 30px;
  line-height: 1.93333;
  letter-spacing: 0.03em;
}

.shop-item__body ._txt2 {
  margin-top: 30px;
  font-size: 18px;
  line-height: 2.11111;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .shop-item__body ._txt1 {
    margin-top: 0.83333vw;
    font-size: 1.5625vw;
  }
  .shop-item__body ._txt2 {
    margin-top: 1.5625vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 560px) {
  .shop-item__body {
    padding-right: calc(100% - 90.76923%);
  }
  .shop-item__body ._txt1 {
    -webkit-font-feature-settings: normal;
            font-feature-settings: normal;
  }
  .shop-item__body ._txt2 {
    line-height: 1.76923;
  }
}

@media screen and (max-width: 960px) {
  .shop-item__body ._txt1 {
    margin-top: 3.27103vw;
    font-size: 3.73832vw;
  }
  .shop-item__body ._txt2 {
    margin-top: 3.27103vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .shop-item__body ._txt1 {
    margin-top: 3.90625vw;
    font-size: 2.73438vw;
    text-align: center;
  }
  .shop-item__body ._txt2 {
    margin-top: 3.125vw;
    font-size: 2.08333vw;
    text-align: center;
  }
}

.shop-item__pic {
  grid-area: pic;
}

@media screen and (min-width: 961px){
  .shop-item__head {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .shop-item:nth-of-type(even) > .shop-item__head {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .shop-item__body {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .shop-item:nth-of-type(even) > .shop-item__body {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
  .shop-item__pic {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 3;
  }
  .shop-item:nth-of-type(even) > .shop-item__pic {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
  }
}

@media screen and (max-width: 960px){
  .shop-item > .shop-item__head {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .shop-item > .shop-item__body {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .shop-item > .shop-item__pic {
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
}

.shop-item__pic img {
  height: auto;
}

@media screen and (max-width: 960px) {
  .shop-item__pic {
    margin-top: 3.97196vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .shop-item__pic {
    margin-top: 5.20833vw;
  }
}

/*----------------------------------------------------
	top-mv
----------------------------------------------------*/
/*----------------------------------------------------
	widget-item
----------------------------------------------------*/
#slide01 {
  position: relative;
}

.section1.section1 {
  background: #000 url(../img/pic2.jpg) center center/cover;
}

.widget-item {
  margin: 50px 0;
  padding: 50px 0;
  background-color: #eee;
}

/*----------------------------------------------------
	xxx
----------------------------------------------------*/
.swiper-slide img {
  height: auto;
}

/*----------------------------------------------------
	voice
----------------------------------------------------*/
.voice__wrap {
  padding: 218px 0 296px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice__wrap {
    padding: 11.35417vw 0 15.41667vw;
  }
}

@media screen and (max-width: 960px) {
  .voice__wrap {
    padding: 17.75701vw 0 30.37383vw;
  }
}

@media screen and (max-width: 560px) {
  .voice__head .titleA ._ja {
    padding-top: 0.3em;
    padding-bottom: 0.3em;
    font-size: 4.20561vw;
  }
}

.voice__body {
  display: flex;
  padding-top: 163px;
  padding-left: 237px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice__body {
    padding-top: 8.48958vw;
    padding-left: 12.34375vw;
  }
}

@media screen and (max-width: 960px) {
  .voice__body {
    padding-top: 17.05607vw;
    padding-left: 21.26168vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice__body {
    padding-top: 13.41146vw;
    padding-left: 9.11458vw;
  }
}

/*----------------------------------------------------
	voice-item
----------------------------------------------------*/
.voice-item.voice-item {
  position: relative;
  flex-shrink: 0;
  width: 590px;
  height: 400px;
  padding: 85px 40px 20px 85px;
}

.voice-item.voice-item:last-of-type .voice-item__ico {
  display: none;
}

@media screen and (min-width: 961px) {
  .voice-item.voice-item {
    margin-right: 113px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice-item.voice-item {
    width: 30.72917vw;
    height: 20.83333vw;
    margin-right: 5.88542vw;
    padding: 4.42708vw 2.08333vw 1.04167vw 4.42708vw;
  }
}

@media screen and (max-width: 960px) {
  .voice-item.voice-item {
    width: 58.64486vw;
    height: 79.43925vw;
    margin-right: 11.68224vw;
    padding: 9.34579vw 8.17757vw 4.6729vw 9.81308vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item.voice-item {
    width: 52.08333vw;
    height: 36.06771vw;
    margin-right: 6.51042vw;
    padding: 7.68229vw 3.64583vw 3.90625vw 7.29167vw;
  }
}

.voice-item__line1:before {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 85.83196%;
  height: 3px;
  background-color: #3b4043;
  content: '';
}

.voice-item__line1:after {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 3px;
  height: 86.46081%;
  background-color: #3b4043;
  content: '';
}

@media screen and (max-width: 560px) {
  .voice-item__line1:before {
    width: 84.86056%;
    height: 3px;
  }
  .voice-item__line1:after {
    width: 3px;
    height: 92.09726%;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item__line1:before {
    width: 85.5%;
    height: 3px;
  }
  .voice-item__line1:after {
    width: 3px;
    height: 86.6426%;
  }
}

.voice-item__line2:before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 92.91598%;
  height: 3px;
  background-color: #3b4043;
  content: '';
}

.voice-item__line2:after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 3px;
  height: 53.20665%;
  background-color: #3b4043;
  content: '';
}

@media screen and (max-width: 560px) {
  .voice-item__line2:before {
    width: 84.86056%;
    height: 3px;
  }
  .voice-item__line2:after {
    width: 3px;
    height: 72.94833%;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item__line2:before {
    width: 92.75%;
  }
  .voice-item__line2:after {
    height: 53.06859%;
  }
}

.voice-item__pic {
  position: absolute;
  top: -26px;
  left: -60px;
  text-align: center;
}

.voice-item__pic img {
  width: 120px;
  height: 120px;
}

.voice-item__pic ._person {
  margin-top: 15px;
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: 0.06em;
  text-align: center;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice-item__pic {
    top: -1.35417vw;
    left: -3.125vw;
  }
  .voice-item__pic img {
    width: 6.25vw;
    height: 6.25vw;
  }
  .voice-item__pic ._person {
    margin-top: 0.78125vw;
    font-size: 1.14583vw;
  }
}

@media screen and (max-width: 960px) {
  .voice-item__pic {
    top: -5.84112vw;
    left: -7.71028vw;
  }
  .voice-item__pic img {
    width: 15.42056vw;
    height: 15.42056vw;
  }
  .voice-item__pic ._person {
    margin-top: 1.86916vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item__pic {
    top: -3.25521vw;
    left: -4.29688vw;
  }
  .voice-item__pic img {
    width: 10.28646vw;
    height: 10.28646vw;
  }
  .voice-item__pic ._person {
    margin-top: 1.04167vw;
    font-size: 2.08333vw;
  }
}

.voice-item__body ._title {
  color: #3b4043;
  font-size: 30px;
  line-height: 1.93333;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

.voice-item__body ._txt {
  margin-top: 10px;
  color: #231815;
  font-size: 18px;
  line-height: 2.11111;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice-item__body ._title {
    font-size: 1.5625vw;
  }
  .voice-item__body ._txt {
    margin-top: 0.52083vw;
    font-size: 0.9375vw;
  }
}

@media screen and (max-width: 960px) {
  .voice-item__body ._title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 4.20561vw;
  }
  .voice-item__body ._txt {
    margin-top: 2.33645vw;
    font-size: 3.03738vw;
    line-height: 1.76923;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item__body ._title {
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    font-size: 2.86458vw;
  }
  .voice-item__body ._txt {
    margin-top: 1.30208vw;
    font-size: 1.69271vw;
  }
}

.voice-item__ico {
  -webkit-transform: translateX(50%);
  display: inline-flex;
  position: absolute;
  top: 44.5%;
  right: 0;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
          transform: translateX(50%);
  border-radius: 10px;
  background: #3b4043;
}

.voice-item__ico img {
  width: 6px;
  height: 9px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .voice-item__ico {
    width: 1.45833vw;
    height: 1.45833vw;
    border-radius: 0.52083vw;
  }
  .voice-item__ico img {
    width: 0.3125vw;
    height: 0.46875vw;
  }
}

@media screen and (max-width: 960px) {
  .voice-item__ico {
    width: 5.37383vw;
    height: 5.37383vw;
  }
  .voice-item__ico img {
    width: 1.16822vw;
    height: 1.86916vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .voice-item__ico {
    width: 2.34375vw;
    height: 2.34375vw;
  }
  .voice-item__ico img {
    width: 0.52083vw;
    height: 0.78125vw;
  }
}

/*----------------------------------------------------
	xxx
----------------------------------------------------*/
/*----------------------------------------------------
	アニメーション
----------------------------------------------------*/
.fadeIn {
  display: none;
}

.fadeIn.show {
  -webkit-animation: fadeIn 0.6s linear;
  display: block;
          animation: fadeIn 0.6s linear;
}

.anime {
  visibility: hidden;
  opacity: 0;
}

.anime.opacity {
  opacity: 1;
}

.animated {
  visibility: visible;
}

.fadeIn.animated {
  -webkit-animation: fadeIn .5s forwards;
          animation: fadeIn .5s forwards;
}

.fadeInUp.animated {
  -webkit-animation: fadeInUp .5s forwards;
          animation: fadeInUp .5s forwards;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@-webkit-keyframes fadeInUp {
  from {
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
    opacity: 0;
  }
  to {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
}

@keyframes fadeInUp {
  from {
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
    opacity: 0;
  }
  to {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
}

/*----------------------------------------------------
	btn
----------------------------------------------------*/
.btnA {
  cursor: pointer;
}

/*----------------------------------------------------
	contact-btn
----------------------------------------------------*/
.contact-btn {
  z-index: 20;
  position: fixed;
  right: 92px;
  bottom: 92px;
}

.contact-btn ._pic {
  z-index: 2;
  position: absolute;
  bottom: 128px;
  left: 0;
  width: 100%;
  text-align: center;
}

.contact-btn ._pic img {
  width: 140px;
  height: 119px;
}

.contact-btn ._txt {
  z-index: 3;
  position: absolute;
  bottom: 62px;
  left: 0;
  width: 100%;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.55556;
  letter-spacing: 0.06em;
  text-align: center;
}

.contact-btn ._bg img {
  -webkit-filter: drop-shadow(0px 3px 10px rgba(0, 0, 0, 0.16));
  -webkit-animation: contactRotation 6s linear infinite;
  width: 190px;
  height: 182px;
          animation: contactRotation 6s linear infinite;
          filter: drop-shadow(0px 3px 10px rgba(0, 0, 0, 0.16));
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .contact-btn {
    right: 4.79167vw;
    bottom: 4.79167vw;
  }
  .contact-btn ._pic {
    bottom: 6.66667vw;
  }
  .contact-btn ._pic img {
    width: 7.29167vw;
    height: 6.19792vw;
  }
  .contact-btn ._txt {
    bottom: 3.22917vw;
    font-size: 0.9375vw;
  }
  .contact-btn ._bg img {
    width: 9.89583vw;
    height: 9.47917vw;
  }
}

@media screen and (max-width: 960px) {
  .contact-btn {
    top: calc(100vh - 150/428*100vw);
    right: 3.50467vw;
    bottom: auto;
    opacity: 0;
    transition: top .3s ease, opacity .3s ease-out;
  }
  .scrolled .contact-btn {
    opacity: 1;
  }
  .contact-btn ._pic {
    bottom: 12.14953vw;
  }
  .contact-btn ._pic img {
    width: 12.85047vw;
    height: auto;
  }
  .contact-btn ._txt {
    bottom: 5.37383vw;
    font-size: 1.86916vw;
  }
  .contact-btn ._bg img {
    width: 18.69159vw;
    height: auto;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .contact-btn {
    top: 39.97396vw;
    right: 3.38542vw;
    bottom: auto;
  }
  .scrolled .contact-btn {
    top: calc(100vh - 150/768*100vw);
  }
  .contact-btn ._pic {
    bottom: 9.76562vw;
  }
  .contact-btn ._pic img {
    width: 11.84896vw;
    height: auto;
  }
  .contact-btn ._txt {
    bottom: 4.42708vw;
    font-size: 1.43229vw;
  }
  .contact-btn ._bg img {
    width: 14.0625vw;
    height: auto;
  }
}

@-webkit-keyframes contactRotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes contactRotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

/*----------------------------------------------------
	フォーム
----------------------------------------------------*/
input[type=submit] {
  -webkit-appearance: none;
  border: none;
  border-radius: 0;
  outline: none;
  transition: all .3s ease-out;
}

button {
  -webkit-appearance: none;
  border: none;
  border-radius: 0;
  outline: none;
}

button, input, select, textarea {
  font-size: 100%;
  font-family: inherit;
}

input[type="text"],
input[type="email"] {
  width: 100%;
  height: 50px;
  padding: 10px 1em;
  border: 1px solid #d6d5d5;
  border-radius: 0;
  outline: none;
  background: #fff;
}

input[type="text"]:focus,
input[type="email"]:focus {
  border: 1px solid #3b4043;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  input[type="text"],
  input[type="email"] {
    height: 2.60417vw;
  }
}

@media screen and (max-width: 960px) {
  input[type="text"],
  input[type="email"] {
    height: 10.04673vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  input[type="text"],
  input[type="email"] {
    height: 7.8125vw;
  }
}

textarea {
  width: 100%;
  height: 140px;
  padding: 10px 1em;
  border: 1px solid #d6d5d5;
  border-radius: 0;
  outline: none;
  background: #fff;
}

textarea:focus {
  border: 1px solid #3b4043;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  textarea {
    height: 7.29167vw;
  }
}

@media screen and (max-width: 960px) {
  textarea {
    height: 28.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  textarea {
    height: 22.13542vw;
  }
}

input[type="radio"],
input[type="checkbox"] {
  position: relative;
  top: -0.125em;
  width: 0.875em;
  height: 0.875em;
  margin-right: 0.25em;
}

input[type="submit"] {
  width: 182.93px;
  height: 50px;
  background: #3b4043;
  color: #fff;
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  cursor: pointer;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  input[type="submit"] {
    width: 9.5276vw;
    height: 2.60417vw;
    font-size: 0.83333vw;
  }
}

@media screen and (max-width: 960px) {
  input[type="submit"] {
    height: 10.04673vw;
    font-size: 3.03738vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  input[type="submit"] {
    height: 7.8125vw;
    font-size: 2.08333vw;
  }
}

.input-group + .input-group {
  margin-top: 20px;
}

.input-group dt {
  color: #858a8d;
  font-size: 12px;
}

.input-group dd {
  margin-top: 4px;
}

@media screen and (min-width: 961px) and (max-width: 1920px) {
  .input-group + .input-group {
    margin-top: 1.04167vw;
  }
  .input-group dt {
    font-size: 0.625vw;
  }
  .input-group dd {
    margin-top: 0.20833vw;
  }
}

@media screen and (max-width: 960px) {
  .input-group + .input-group {
    margin-top: 4.20561vw;
  }
  .input-group dt {
    font-size: 2.33645vw;
  }
  .input-group dd {
    margin-top: 0.93458vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .input-group + .input-group {
    margin-top: 3.125vw;
  }
  .input-group dt {
    font-size: 1.5625vw;
  }
  .input-group dd {
    margin-top: 0.78125vw;
  }
}

.input-submit.is-disabled {
  opacity: 0.5;
  pointer-events: none;
}

p.help-block {
  color: #F00;
  font-size: 12px;
}

@media screen and (max-width: 960px) {
  p.help-block {
    font-size: 1.5625vw;
  }
}

/*----------------------------------------------------
	legacy-browser
----------------------------------------------------*/
.legacy-browser {
  display: flex;
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background-color: #fff;
}

.legacy-browser__body {
  color: #000;
  line-height: 2;
  text-align: center;
}

.legacy-browser__body a {
  color: #1DA1F2;
}

@supports (display: grid) {
  .legacy-browser {
    display: none;
    z-index: -1;
    pointer-events: none;
  }
}

/*----------------------------------------------------
	ボタン
----------------------------------------------------*/
/*----------------------------------------------------
	見出し
----------------------------------------------------*/
/*----------------------------------------------------
	pagetop
----------------------------------------------------*/
.pagetop {
  position: absolute;
  right: 42.5px;
  bottom: 157.1px;
}

.pagetop a {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.pagetop ._ico {
  margin-bottom: 12.5px;
}

.pagetop ._txt {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  font-weight: normal;
  font-size: 13px;
  font-family: 'American Typewriter';
  letter-spacing: 0.15em;
          writing-mode: vertical-rl;
}

@media screen and (min-width: 961px) {
  .pagetop ._ico img {
    height: 51.91px;
  }
}

@media screen and (min-width: 961px) and (max-width: 1366px) {
  .pagetop {
    right: 32px;
    bottom: 69.7px;
  }
  .pagetop ._ico {
    margin-bottom: 14.3px;
  }
  .pagetop ._ico img {
    height: 59.36px;
  }
  .pagetop ._txt {
    font-size: 12px;
  }
}

@media screen and (max-width: 960px) {
  .pagetop {
    right: 4.53333vw;
    bottom: 18.66667vw;
  }
  .pagetop ._ico {
    margin-bottom: 2.93333vw;
  }
  .pagetop ._ico img {
    height: 11.73333vw;
  }
  .pagetop ._txt {
    font-size: 2.66667vw;
  }
}

/*----------------------------------------------------
	slick
----------------------------------------------------*/
/* Arrows */
.slick-prev,
.slick-next {
  display: block;
  z-index: 10;
  position: absolute;
  top: 50%;
  width: 1rem;
  height: 1rem;
  padding: 0;
  border: none;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  outline: none;
  background: transparent;
  color: transparent;
  font-size: 0;
  line-height: 0;
  cursor: pointer;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: .25;
}

.slick-prev {
  -webkit-transform: translate(0, -50%) rotate(-135deg);
  left: 1rem;
          transform: translate(0, -50%) rotate(-135deg);
}

.slick-next {
  -webkit-transform: translate(0, -50%) rotate(45deg);
  right: 1rem;
          transform: translate(0, -50%) rotate(45deg);
}

/* Dots */
.slick-dots {
  -webkit-transform: translate(-50%, -200%);
  display: flex;
  position: absolute;
  top: 100%;
  left: 50%;
          transform: translate(-50%, -200%);
}

.slick-dots li {
  width: 16px;
  height: 16px;
  font-size: 0;
}

.slick-dots li:not(:last-child) {
  margin-right: 16px;
}

.slick-dots li button {
  display: block;
  width: 16px;
  height: 16px;
  padding: 0;
  border: 0;
  border-radius: 100%;
  outline: none;
  background-color: #fff;
  font-size: 0;
  line-height: 0;
}

.slick-dots li.slick-active button {
  background-color: #ccc;
}

@media screen and (max-width: 960px) {
  .slick-dots li {
    width: 10px;
    height: 10px;
  }
  .slick-dots li:not(:last-child) {
    margin-right: 10px;
  }
  .slick-dots li button {
    width: 10px;
    height: 10px;
    border-radius: 100%;
  }
  .slick-dots li.slick-active button {
    background-color: #ccc;
  }
}

:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  */
}

/* Common Styles */
/* Bullets */
/* Progress */
/*----------------------------------------------------
	title
----------------------------------------------------*/
.titleA {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.titleA ._en {
  font-weight: normal;
  font-size: 20px;
  font-family: "American Typewriter";
  letter-spacing: 0.2em;
}

.titleA ._ja {
  margin-top: 10px;
  padding: 0 0.8em;
  background-color: #3B4043;
  color: #fff;
  font-weight: 500;
  font-size: 40px;
  line-height: 1.65;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
  letter-spacing: 0.2em;
}

.titleA ._ja span {
  margin-left: 0.2em;
}

@media screen and (min-width: 561px) and (max-width: 1920px) {
  .titleA ._en {
    font-size: 1.04167vw;
  }
  .titleA ._ja {
    margin-top: 0.52083vw;
    font-size: 2.08333vw;
  }
}

@media screen and (max-width: 560px) {
  .titleA ._en {
    font-size: 3.03738vw;
  }
  .titleA ._ja {
    font-size: 5.60748vw;
  }
}

@media screen and (min-width: 561px) and (max-width: 960px) {
  .titleA ._en {
    font-size: 2.21354vw;
  }
  .titleA ._ja {
    font-size: 3.64583vw;
  }
}

/*----------------------------------------------------
	汎用クラス
----------------------------------------------------*/
.bold,
.strong {
  font-weight: bold;
}

.center {
  text-align: center;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.indent {
  padding-left: 1em;
  text-indent: -1em;
}

.indent--2 {
  padding-left: 2em;
  text-indent: -2em;
}

.hide {
  display: none;
}

.break_line {
  display: inline-block;
}

/*----------------------------------------------------
	widget-editor
----------------------------------------------------*/
.widget-editor {
  font-size: 16px;
  line-height: 2;
}

.widget-editor h1 {
  margin: 0.67em 0;
  font-weight: bold;
  font-size: 2em;
}

.widget-editor h2 {
  margin-top: 0.83em;
  margin-bottom: 0.83em;
  font-weight: bold;
  font-size: 1.5em;
}

.widget-editor h3 {
  display: block;
  margin-top: 1em;
  margin-bottom: 1em;
  font-weight: bold;
  font-size: 1.17em;
}

.widget-editor h4 {
  margin-top: 1.33em;
  margin-bottom: 1.33em;
  font-weight: bold;
  font-size: 1em;
}

.widget-editor h5 {
  margin-top: 1.67em;
  margin-bottom: 1.67em;
  font-weight: bold;
  font-size: 0.83em;
}

.widget-editor strong {
  font-weight: bold;
}

.widget-editor em {
  font-style: italic;
}

.widget-editor ul {
  margin-left: 1.5em;
}

.widget-editor li {
  list-style: disc;
}

.widget-editor > * + * {
  margin-top: 1.5em;
  word-break: break-all;
}

.widget-editor a {
  color: #31A2F2;
  text-decoration: underline;
}

.widget-editor a:hover {
  text-decoration: none;
}

.widget-editor table th {
  font-weight: bold;
}

.widget-editor table th,
.widget-editor table td {
  padding: .5em .5em;
  border: 1px solid #ccc;
}

.widget-editor a {
  color: #1DA1F2;
  text-decoration: underline;
}

.widget-editor a:hover {
  text-decoration: none;
}

@media screen and (max-width: 560px) {
  .widget-editor {
    font-size: 14px;
  }
}
