@charset "UTF-8";
* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* remember: box-sizing is not supported by IE7 :( */
  outline: none;
  vertical-align: top;
  margin: 0;
  padding: 0; }

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

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, lifieldset, 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;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

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

html {
  width: 100%;
  z-index: 1; }

body {
  min-width: 1px;
  line-height: 1; }

html, body {
  font-family: sans-serif;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

ul {
  font-size: 0px;
  list-style-type: none; }

blockquote, q {
  quotes: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  outline: none;
  display: block;
  color: inherit; }

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

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

input, button, textarea, select {
  font-size: 16px;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%; }

img {
  width: 100%; }

figure {
  font-size: 0; }

.bgimg {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat; }

header, div, span, p, h1, h2, h3, h4, figure, a, img, input[type="submiit"], .fa, *:after, *:before {
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease; }

p, h1, h2, h3, h4, h5 {
  display: block;
  position: relative;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
  padding: 0; }

input[type="radio"] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio;
  display: inline-block; }

.pc {
  display: block !important; }

.sp {
  display: none !important; }

.inline-pc {
  display: inline-block !important; }

.inline-sp {
  display: none !important; }

.wrapper {
  overflow: hidden; }

span {
  display: inline-block; }

main {
  display: block;
  height: 100%; }
main article {
  height: 100%; }

section {
  position: relative; }

@media only screen and (max-width: 768px) {
  .pc {
    display: none !important; }

  .sp {
    display: block !important; }

  .inline-pc {
    display: none !important; }

  .inline-sp {
    display: inline-block !important; }

  html, body {
    font-size: 3vw; } }
/*
-------------------------------------------
Color
-------------------------------------------
*/
.wh {
  color: #fff; }

.blk {
  color: #292721; }

.gray {
  color: #F6F5F6; }

.gold {
  color: #BA9D47; }

.orange {
  color: #F69956; }

.bg-wh {
  background-color: #fff; }

.bg-blk {
  background-color: #292721; }

.bg-gray {
  background-color: #F6F5F6; }

.bg-gold {
  background-color: #BA9D47; }

.bg-orange {
  background-color: #F69956; }

/*
-------------------------------------------
Font 
-------------------------------------------
*/
@font-face {
  font-family: 'talesha';
  src: url("../font/talesha-slant.ttf") format("ttf"), url("../font/talesha-slant.woff") format("woff"); }
html, body {
  font-family: "Helvetica Neue",Arial,'Noto Sans JP', sans-serif;
  font-size: 10px;
  line-height: 1.8;
  letter-spacing: 0px;
  background-color: #F6F5F6;
  color: #292721;
  font-weight: 400; }

.mf {
  font-family: 'talesha'; }

.italic {
  font-style: italic; }

@media only screen and (max-width: 768px) {
  html, body {
    font-size: 3vw; }

  .italic {
    font-style: normal; } }
/*
-------------------------------------------
display-system
-------------------------------------------
*/
.flex {
  display: flex !important; }

.f-start {
  justify-content: flex-start; }

.f-end {
  justify-content: flex-end; }

.f-center {
  justify-content: center; }

.f-space {
  justify-content: space-between; }

.a-start {
  align-items: start; }

.a-center {
  align-items: center; }

.a-end {
  align-items: end; }

.f-wrap {
  flex-wrap: wrap; }

.f-l-wrap {
  flex-wrap: wrap-reverse; }

@media only screen and (max-width: 768px) {
  .f-center-sp {
    justify-content: center; }

  .f-wrap-sp {
    flex-wrap: wrap; }

  .f-l-wrap-sp {
    flex-wrap: wrap-reverse; }

  .f-space-sp {
    justify-content: space-between; } }
/*
-------------------------------------------
text
-------------------------------------------
*/
/* font-size */
.xxl-heading {
  font-size: 2.8vw; }

.xl-heading {
  font-size: 2.4vw; }

.l-heading {
  font-size: 2vw; }

.m-heading {
  font-size: 1.8vw; }

.heading {
  font-size: 1.6vw; }

.xxl-text {
  font-size: 1.5vw; }

.xl-text {
  font-size: 1.3vw; }

.l-text {
  font-size: 1.2vw; }

.m-text {
  font-size: 1.1vw; }

.text {
  font-size: 1vw; }

.s-text {
  font-size: .9vw; }

.xs-text {
  font-size: .8vw; }

/* font-weight */
.fw400 {
  font-weight: 400; }

.fw500 {
  font-weight: 500; }

.fw600 {
  font-weight: 600; }

.fw700 {
  font-weight: 700; }

/* light-height */
.lh20 {
  line-height: 2; }

.lh18 {
  line-height: 1.8; }

.lh16 {
  line-height: 1.6; }

.lh15 {
  line-height: 1.5; }

.lh10 {
  line-height: 1; }

@media only screen and (max-width: 768px) {
  /* font-size */
  .xxl-heading {
    font-size: 8.4vw; }

  .xl-heading {
    font-size: 7.2vw; }

  .l-heading {
    font-size: 6vw; }

  .m-heading {
    font-size: 5.4vw; }

  .heading {
    font-size: 4.8vw; }

  .xxl-text {
    font-size: 4.5vw; }

  .xl-text {
    font-size: 3.8vw; }

  .l-text {
    font-size: 3.6vw; }

  .m-text {
    font-size: 3.4vw; }

  .text {
    font-size: 3.2vw; }

  .s-text {
    font-size: 3vw; }

  .xs-text {
    font-size: 2.8vw; }

  /* light-height */
  .sp-lh20 {
    line-height: 2; }

  .sp-lh18 {
    line-height: 1.8; }

  .sp-lh16 {
    line-height: 1.6; }

  .sp-lh15 {
    line-height: 1.5; }

  .sp-lh10 {
    line-height: 1; } }
/*
-------------------------------------------
inner
-------------------------------------------
*/
.xl-inner {
  width: 90vw;
  margin: 0 auto;
  position: relative; }

.main-inner {
  width: 68vw;
  margin: 0 auto;
  position: relative; }

.single-inner {
  width: 54vw;
  margin: 0 auto;
  position: relative; }

.l-inner {
  width: 84vw;
  margin: 0 auto;
  position: relative; }

.m-inner {
  width: 80vw;
  margin: 0 auto;
  position: relative; }

.s-inner {
  width: 74vw;
  margin: 0 auto;
  position: relative; }

.xs-inner {
  width: 62vw;
  margin: 0 auto;
  position: relative; }

@media only screen and (max-width: 768px) {
  .xl-inner {
    width: 88vw; }

  .l-inner {
    width: 92vw; }

  .main-inner {
    width: 80vw;
    margin: 0 auto;
    position: relative; } }
/*
-------------------------------------------
Appearance
-------------------------------------------
*/
.rad-l {
  border-radius: 1.2vw;
  -webkit-border-radius: 1.2vw; }

.rad {
  border-radius: .8vw;
  -webkit-border-radius: .8vw; }

.rad-s {
  border-radius: .4vw;
  -webkit-border-radius: .4vw; }

.rad-xs {
  border-radius: .2vw;
  -webkit-border-radius: .2vw; }

.rad-cir {
  border-radius: 1000px;
  -webkit-border-radius: 1000px; }

@media only screen and (max-width: 768px) {
  .rad-l {
    border-radius: 3.6vw;
    -webkit-border-radius: 3.6vw; }

  .rad {
    border-radius: 1.6vw;
    -webkit-border-radius: 1.6vw; }

  .rad-s {
    border-radius: 1.2vw;
    -webkit-border-radius: 1.2vw; }

  .rad-xs {
    border-radius: .6vw;
    -webkit-border-radius: .6vw; } }
/* shadow */
.shadow {
  box-shadow: 0px 1.2vw 3.6vw 0px rgba(15, 29, 35, 0.05); }

.g-shadow {
  box-shadow: 0px 0.6vw 1.8vw 0px rgba(27, 193, 89, 0.15); }

.g-cir-shadow {
  border-radius: 1000px;
  box-shadow: 0px 0.6vw 1.8vw 0px rgba(27, 193, 89, 0.15); }

/* border */
/* other */
.ovh {
  overflow: hidden; }

/* align */
.t-center {
  text-align: center; }

@media only screen and (max-width: 768px) {
  .t-center-sp {
    text-align: center !important; } }
/* opacity */
.opa-l {
  opacity: 0.25; }

.opa {
  opacity: 0.5; }

.opa-s {
  opacity: 0.75; }

.hidden {
  display: none; }

/*
-------------------------------------------
Compornents
-------------------------------------------
*/
/* btn */
/*
-------------------------------------------
Margin & Padding
-------------------------------------------
*/
.sec-pt-l {
  padding-top: 8vw; }

.sec-pt {
  padding-top: 6vw; }

.sec-pt-s {
  padding-top: 4.8vw; }

.sec-pb-l {
  padding-bottom: 8vw; }

.sec-pb {
  padding-bottom: 6vw; }

.sec-pb-s {
  padding-bottom: 4.8vw; }

.pt-l {
  padding-top: 2.8vw; }

.pt {
  padding-top: 2vw; }

.pt-s {
  padding-top: 1.2vw; }

.pb-l {
  padding-bottom: 2.8vw; }

.pb {
  padding-bottom: 2vw; }

.pb-s {
  padding-bottom: 1.2vw; }

.pad-l {
  padding: 2.8vw; }

.pad {
  padding: 2vw; }

.pad-s {
  padding: 1.2vw; }

.mb-xxxl {
  margin-bottom: 6vw; }

.mb-xxl {
  margin-bottom: 4.8vw; }

.mb-xl {
  margin-bottom: 3.6vw; }

.mb-l {
  margin-bottom: 2.8vw; }

.mb {
  margin-bottom: 2vw; }

.mb-s {
  margin-bottom: 1.2vw; }

.mb-xs {
  margin-bottom: .8vw; }

.mb-xxs {
  margin-bottom: .4vw; }

@media only screen and (max-width: 768px) {
  .sec-pt-l {
    padding-top: 20vw; }

  .sec-pt {
    padding-top: 16vw; }

  .sec-pt-s {
    padding-top: 9.2vw; }

  .sec-pb-l {
    padding-bottom: 20vw; }

  .sec-pb {
    padding-bottom: 16vw; }

  .sec-pb-s {
    padding-bottom: 10vw; }

  .pt-l {
    padding-top: 8.4vw; }

  .pt {
    padding-top: 6vw; }

  .pt-s {
    padding-top: 3.6vw; }

  .pb-l {
    padding-bottom: 8.4vw; }

  .pb {
    padding-bottom: 6vw; }

  .pb-s {
    padding-bottom: 3.6vw; }

  .pad-l {
    padding: 7.2vw; }

  .pad {
    padding: 6vw; }

  .pad-s {
    padding: 4.8vw; }

  .mb-xxxl {
    margin-bottom: 14.4vw; }

  .mb-xxl {
    margin-bottom: 12vw; }

  .mb-xl {
    margin-bottom: 9.6vw; }

  .mb-xl-sp {
    margin-bottom: 9.6vw; }

  .mb-l {
    margin-bottom: 8.4vw; }

  .mb-l-sp {
    margin-bottom: 8.4vw; }

  .mb {
    margin-bottom: 6vw; }

  .mb-sp {
    margin-bottom: 6vw; }

  .mb-s {
    margin-bottom: 4.8vw; }

  .mb-s-sp {
    margin-bottom: 4.8vw; }

  .mb-xs {
    margin-bottom: 3vw; }

  .mb-xs-sp {
    margin-bottom: 3vw; }

  .mb-xxs {
    margin-bottom: 1.2vw; }

  .mb-xxs-sp {
    margin-bottom: 1.2vw; } }
/*
-------------------------------------------
Btn
-------------------------------------------
*/
/*
-------------------------------------------
PRODUCT
-------------------------------------------
*/
header {
  width: 100%;
  position: fixed;
  z-index: 10000;
  left: 0;
  top: 0; }
header .xl-inner {
  height: 7.2vw; }
header .logo {
  display: block; }
header .logo img {
  width: 12vw; }
header .logo:hover {
  opacity: .5; }
header .fixed-logo {
  display: none; }
header .nav {
  gap: 1.6vw; }
header .nav ul {
  gap: 0vw; }
header .nav ul li a {
  opacity: .5;
  padding: 1vw .8vw;
  border-radius: .4vw;
  -webkit-border-radius: .4vw;
  line-height: 1;
  color: #292721; }
header .nav ul li a:hover {
  opacity: 1;
  color: #BA9D47; }
header .nav ul li.inactive a {
  opacity: .5; }

header.page .xl-inner {
  border-bottom: 1px solid rgba(255, 255, 255, 0); }
header.page .nav ul li a {
  color: #292721; }

.btn-head {
  padding: .8vw 1.2vw;
  gap: .6vw; }
.btn-head img {
  width: 2vw; }
.btn-head:hover {
  opacity: .8; }

header.js_hide {
  top: -10vw; }

header.fixed {
  background-color: #fff;
  padding: 0vw 0;
  box-shadow: 0px 1.2vw 3.6vw 0px rgba(15, 29, 35, 0.05); }
header.fixed .xl-inner {
  height: 5.4vw; }
header.fixed .logo-area .logo {
  display: none; }
header.fixed .logo-area .fixed-logo {
  display: block; }
header.fixed .logo-area .fixed-logo img {
  width: 12vw; }
header.fixed .btn-head {
  padding: .6vw .8vw;
  gap: .6vw; }
header.fixed .btn-head img {
  width: 1.6vw; }
header.fixed .btn-head:hover {
  opacity: .8; }
header.fixed .nav ul li a {
  color: #292721; }

.fixed-cta {
  position: fixed;
  right: 0;
  bottom: -10vw;
  z-index: 10; }
.fixed-cta a {
  padding: 1.4vw 1.4vw;
  border-radius: .6vw 0 0 0; }
.fixed-cta a span {
  display: block; }
.fixed-cta svg {
  display: block;
  width: 1.6vw;
  margin: 0 auto 0.8vw;
  color: #fff; }

.fixed-cta.appear {
  bottom: 0; }

@media only screen and (max-width: 768px) {
  header {
    padding: 0;
    top: 0; }
  header .xl-inner {
    width: 92vw;
    height: 16vw; }
  header .nav {
    gap: 4.8vw; }
  header .nav .logo img {
    width: 32vw;
    margin-top: 3vw; }
  header .cta {
    gap: 2.4vw; }

  header.js_hide {
    top: -18vw; }

  header.fixed {
    padding: 4.8vw 0; }
  header.fixed .logo-area .fixed-logo img {
    width: 32vw;
    margin-top: 2vw; }

  .btn-head {
    padding: 3.2vw;
    gap: 1.8vw; }
  .btn-head img {
    width: 6vw; }
  .btn-head:hover {
    opacity: .8; }

  .menu-trigger {
    width: 10vw;
    height: 10vw;
    background-color: #BA9D47;
    position: relative; }
  .menu-trigger span {
    width: 50%;
    height: 1px;
    background-color: #fff;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    transition: all .3s ease-out;
    -webkit-transition: all .3s ease-out; }
  .menu-trigger span:nth-of-type(1) {
    top: -2vw; }
  .menu-trigger span:nth-of-type(2) {
    top: 2vw; }

  .sp-nav {
    position: fixed;
    background-color: #F6F5F6;
    width: 100%;
    height: 100vh;
    z-index: 1000;
    left: -100%;
    top: 0;
    padding-top: 24vw;
    padding-left: 0; }
  .sp-nav ul li {
    margin-bottom: 4.8vw; }
  .sp-nav ul li:last-child {
    margin-bottom: 0vw; }
  .sp-nav .sp-nav-inner {
    width: 88vw;
    margin: 0 auto;
    position: relative; }
  .sp-nav .btn-area a {
    width: 100%;
    gap: 3.2vw;
    padding: 4vw 0; }
  .sp-nav .btn-area a svg {
    color: #fff;
    width: 5.2vw; }
  .sp-nav ul {
    padding-bottom: 10.8vw; }
  .sp-nav ul li.main {
    gap: 1.2vw;
    padding-bottom: 5.2vw;
    margin-bottom: 5.2vw;
    border-bottom: 1px dotted rgba(255, 255, 255, 0.1); }
  .sp-nav ul li.main .icon {
    width: 8vw;
    height: 8vw;
    border-radius: 1000px;
    border: 1px solid rgba(255, 255, 255, 0.1); }
  .sp-nav ul li.main .icon svg {
    width: 4vw;
    color: rgba(255, 255, 255, 0.5); }
  .sp-nav ul li.main a {
    gap: 3.2vw;
    padding: 0vw;
    font-size: 4vw;
    font-weight: 500;
    color: #fff; }
  .sp-nav ul li.inactive a {
    opacity: .5; }
  .sp-nav ul li.sub {
    padding: 4vw 0; }
  .sp-nav ul li.sub a {
    font-size: 3.5vw;
    color: #fff;
    opacity: .7; }
  .sp-nav .cta {
    width: 100%;
    gap: 5%; }
  .sp-nav .cta a {
    width: 47.5%;
    text-align: center;
    display: block;
    padding: 4vw 0;
    font-size: 3.8vw;
    line-height: 1.5;
    height: auto; }

  .sp-nav.opend {
    left: 0 !important; }

  .menu-trigger.active span:nth-of-type(1) {
    transform: rotate(-45deg);
    top: 0; }

  .menu-trigger.active span:nth-of-type(2) {
    transform: rotate(45deg);
    top: 0; }

  .fixed-cta-sp {
    position: fixed;
    right: 0;
    bottom: -14vw;
    z-index: 10; }
  .fixed-cta-sp a {
    gap: 2.8vw; }
  .fixed-cta-sp a {
    padding: 3.6vw 4vw 3.2vw 4.4vw;
    border-radius: 1.8vw 0 0 0; }
  .fixed-cta-sp svg {
    width: 4.8vw;
    color: #fff; }

  .fixed-cta-sp.appear {
    bottom: 0; } }
/*
-------------------------------------------
FV
-------------------------------------------
*/
.fv {
  padding: 16vw 0;
  background-color: #292721;
  background-image: url(../img/fv-bg.jpg);
  /*background-image: url(../img/slide01.jpg);*/
  background-size: cover;
  background-position: center;
  border-radius: 0 0 2.4vw 2.4vw; }
.fv:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0); }
.fv .copy {
  position: relative;
  z-index: 2; }
.fv .copy > span {
  font-size: 3.6vw;
  line-height: 1.2; }
.fv .tags {
  gap: .4vw;
  margin-bottom: 1vw; }
.fv .tags li {
  line-height: 1;
  color: #fff;
  padding: .5vw .6vw .4vw;
  background-color: #BA9D47; }

.page-company .fv {
  padding: 16vw 0 6vw;
  background-color: #F6F5F6;
  background-image: none; }

.btn {
  display: inline-block;
  padding: 1.2vw 1.6vw; }
.btn span {
  position: relative;
  top: .2vw; }
.btn .flex {
  gap: 1.2vw; }
.btn .icon {
  border-radius: 1000px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  width: 2vw;
  height: 2vw; }
.btn .icon svg {
  width: 1.2vw;
  color: #fff; }

@media only screen and (max-width: 768px) {
  .fv {
    /*padding: 44vw 0;*/
    padding: 64vw 0 24vw;
    border-radius: 0 0 7.2vw 7.2vw;
    background-position: bottom right -51vw; }
  .fv:after {
    background-color: rgba(255, 255, 255, 0.4); }
  .fv .main-inner {
    width: 86vw; }
  .fv .copy > span {
    font-size: 7.8vw; }
  .fv .tags {
    gap: 1.2vw;
    margin-bottom: 3vw; }
  .fv .tags li {
    line-height: 1;
    color: #fff;
    padding: 1.5vw 1.8vw 1.2vw;
    background-color: #BA9D47; }

  .page-company .fv {
    padding: 32vw 0 12vw; }

  .btn {
    padding: 3.6vw 4.8vw; }
  .btn span {
    position: relative;
    top: .6vw; }
  .btn .flex {
    gap: 2.4vw; }
  .btn .icon {
    width: 6vw;
    height: 6vw; }
  .btn .icon svg {
    width: 3.2vw;
    color: #fff; }

  .top-cta {
    padding: 12vw 0 0 !important; }
  .top-cta .text-content {
    margin-bottom: 0important;
    padding: 12vw 12vw 0important; } }
/*
-------------------------------------------
CONCEPT
-------------------------------------------
*/
.concept {
  padding: 12vw 0; }
.concept .text-content {
  width: 45%; }
.concept .img-content {
  width: 45%;
  margin-top: 4vw; }
.concept .img-content .swiper {
  height: 24vw; }
.concept .img-content .swiper .swiper-wrapper {
  width: 100%;
  height: 100%; }
.concept .img-content .swiper .swiper-pagination-bullet {
  background: #292721;
  opacity: 0.4; }
.concept .img-content .swiper .swiper-pagination-bullet-active {
  opacity: 1;
  background: #BA9D47; }
.concept .img-content .swiper .swiper-slide {
  background-size: cover;
  background-position: center; }
.concept .img-content .swiper .image01 {
  background-image: url(../img/slide01.jpg); }
.concept .img-content .swiper .image02 {
  background-image: url(../img/slide02.jpg); }
.concept .img-content .swiper .image03 {
  background-image: url(../img/slide03.jpg); }
.concept .img-content .swiper .image04 {
  background-image: url(../img/slide04.jpg); }
.concept .img-content .swiper .image05 {
  background-image: url(../img/slide05.jpg); }

@media only screen and (max-width: 768px) {
  .concept {
    padding: 24vw 0; }
  .concept .text-content {
    width: 100%;
    margin-bottom: 8vw; }
  .concept .img-content {
    width: 100%;
    margin-top: 4vw; }
  .concept .img-content .swiper {
    height: 60vw; } }
/*
-------------------------------------------
SV
-------------------------------------------
*/
.sv {
  padding: 0vw 0 12vw; }
.sv .text-content {
  width: 45%; }
.sv .img-content {
  width: 45%;
  margin-top: 0vw; }

@media only screen and (max-width: 768px) {
  .sv {
    padding: 0vw 0 24vw; }
  .sv .text-content {
    width: 100%;
    margin-bottom: 8vw; }
  .sv .img-content {
    width: 100%;
    margin-top: 0vw; } }
/*
-------------------------------------------
VISION
-------------------------------------------
*/
.vision .l-inner > img {
  position: absolute; }
.vision .il01 {
  width: 12vw;
  left: 8vw;
  top: 10vw; }
.vision .il02 {
  width: 10vw;
  right: 13vw;
  top: 4vw; }
.vision .il03 {
  width: 16vw;
  left: 0vw;
  top: 32vw; }
.vision .il04 {
  width: 20vw;
  right: -6vw;
  top: 20vw; }
.vision .l-inner {
  padding: 8vw 0; }
.vision .main-inner h2, .vision .main-inner h3 {
  text-align: center; }
.vision ul li {
  width: 30%; }
.vision ul li .head {
  padding: 2.8vw 0;
  text-align: center;
  position: relative; }
.vision ul li .head span {
  display: block;
  width: 2.4vw;
  height: 2.4vw;
  position: absolute;
  top: 1vw;
  left: 1vw;
  padding-top: 0.2vw; }
.vision ul li .text-content {
  padding: 2vw; }

@media only screen and (max-width: 768px) {
  .vision .l-inner > img {
    position: absolute; }
  .vision .il01 {
    width: 24vw;
    left: 10vw;
    top: 22vw; }
  .vision .il02 {
    width: 18vw;
    right: 19vw;
    top: 15vw; }
  .vision .il03 {
    width: 27vw;
    left: -8vw;
    top: 78vw; }
  .vision .il04 {
    width: 31vw;
    right: -9vw;
    top: 64vw; }
  .vision .l-inner {
    padding: 27vw 0 8vw; }
  .vision .main-inner h2 {
    text-align: center; }
  .vision .main-inner h3 {
    width: 80%;
    margin-left: 10%;
    text-align: left;
    font-size: 3.2vw; }
  .vision ul li {
    width: 100%;
    margin-bottom: 8vw; }
  .vision ul li .head {
    padding: 8.4vw 0; }
  .vision ul li .head span {
    display: block;
    width: 7.2vw;
    height: 7.2vw;
    position: absolute;
    top: 3vw;
    left: 3vw;
    padding-top: 0.7vw; }
  .vision ul li .text-content {
    padding: 6vw; }
  .vision ul li:last-child {
    margin-bottom: 0; } }
/*
-------------------------------------------
MENU
-------------------------------------------
*/
.menu {
  padding: 8vw 0 0; }
.menu .main-inner {
  border: 1px solid rgba(41, 39, 33, 0.1); }
.menu .main-inner .text-content {
  width: 50%;
  padding: 4.8vw 4vw;
  border-left: 0.4vw solid #F69956;
  border-right: 1px solid rgba(41, 39, 33, 0.1); }
.menu .main-inner .link-content {
  text-align: center;
  width: 50%; }
.menu .main-inner .link-content .btn svg {
  width: 1.4vw;
  color: #fff; }
.menu .main-inner .tag {
  padding: .8vw .8vw .4vw; }

.popup-menu {
  background-color: rgba(0, 0, 0, 0.5);
  height: 100vh;
  width: 100%;
  position: fixed;
  top: 0;
  right: -100vw;
  z-index: 100000;
  -webkit-transition: all 0.6s ease;
  -moz-transition: all 0.6s ease;
  -o-transition: all 0.6s ease;
  transition: all 0.6s ease; }
.popup-menu .close-btn {
  width: 20vw;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0; }
.popup-menu .close-btn svg {
  width: 2vw;
  transform: rotate(45deg);
  position: absolute;
  top: 2vw;
  left: 16vw;
  color: #fff; }
.popup-menu .popup-box {
  width: 80vw;
  height: 100%;
  overflow: auto;
  position: absolute;
  top: 0;
  right: 0;
  background-color: #fff; }
.popup-menu .popup-box .popup-inner {
  padding: 6vw; }
.popup-menu .popup-box .popup-title {
  padding-bottom: 3.2vw;
  margin-bottom: 4vw;
  border-bottom: 1px solid rgba(41, 39, 33, 0.1); }
.popup-menu .popup-box .contents .col2 img {
  width: 30%; }
.popup-menu .popup-box .contents .col2 .text-content {
  width: 65%; }
.popup-menu .popup-box .contents .heading {
  padding-left: 1vw;
  border-left: 2px solid #F69956; }
.popup-menu .popup-box .contents ul li {
  position: relative;
  padding-left: 1.2vw; }
.popup-menu .popup-box .contents ul li:before {
  content: "";
  width: .4vw;
  height: .4vw;
  border-radius: 1000px;
  background-color: #F69956;
  position: absolute;
  left: 0;
  top: 0.5vw; }

.popup-menu.opend {
  right: 0; }

.section-title {
  text-align: center;
  border: none !important; }
.section-title h2 {
  font-size: 3.2vw; }

@media only screen and (max-width: 768px) {
  .menu {
    padding: 20vw 0 0; }
  .menu .main-inner {
    width: 86vw; }
  .menu .main-inner .text-content {
    width: 100%;
    padding: 9.6vw 8vw;
    border-left: none;
    border-top: 3px solid #F69956;
    border-right: none;
    border-bottom: 1px solid rgba(41, 39, 33, 0.1); }
  .menu .main-inner .link-content {
    text-align: center;
    width: 100%;
    padding: 9.6vw 8vw; }
  .menu .main-inner .link-content .btn {
    width: 100%;
    text-align: center; }
  .menu .main-inner .link-content .btn svg {
    width: 4.2vw; }
  .menu .main-inner .tag {
    padding: 2.8vw 2.4vw 2vw; }

  .section-title {
    text-align: center;
    border: none !important; }
  .section-title h2 {
    font-size: 9.6vw;
    margin-bottom: .8vw; }

  .popup-menu .close-btn {
    width: 10vw; }
  .popup-menu .close-btn svg {
    width: 6vw;
    top: 4vw;
    left: 2vw; }
  .popup-menu .popup-box {
    width: 90vw; }
  .popup-menu .popup-box .popup-inner {
    padding: 10vw; }
  .popup-menu .popup-box .popup-title {
    padding-bottom: 7.2vw;
    margin-bottom: 6vw; }
  .popup-menu .popup-box .contents .col2 img {
    width: 100%;
    margin-bottom: 6vw; }
  .popup-menu .popup-box .contents .col2 .text-content {
    width: 100%; }
  .popup-menu .popup-box .contents .heading {
    padding-left: 3vw;
    border-left: 2px solid #F69956; }
  .popup-menu .popup-box .contents ul li {
    position: relative;
    padding-left: 3.6vw; }
  .popup-menu .popup-box .contents ul li:before {
    content: "";
    width: 1.2vw;
    height: 1.2vw;
    top: 1.5vw; } }
/*
-------------------------------------------
COURSE
-------------------------------------------
*/
.course {
  padding: 8vw 0 4vw; }
.course .main-inner .course-slide {
  border: 1px solid rgba(41, 39, 33, 0.1); }
.course .main-inner .text-content {
  width: 50%;
  padding: 4.8vw 0vw 4.8vw 6vw; }
.course .main-inner .text-content ul {
  width: 90%;
  border: 1px solid rgba(41, 39, 33, 0.1);
  padding: 1.6vw; }
.course .main-inner .text-content ul li {
  gap: .4vw; }
.course .main-inner .text-content ul li svg {
  width: 1.4vw;
  color: #F69956; }
.course .main-inner .text-content ul li p {
  position: relative;
  top: .1vw; }
.course .main-inner .img-content {
  text-align: center;
  width: 45%;
  padding: 4vw 6vw 4vw 0; }
.course .main-inner .img-content .cl-content {
  background-color: #EFECE4;
  padding: 2vw 2vw 1.2vw; }
.course .main-inner .img-content .cl-content .head .price {
  padding: 2vw 3.2vw 1.2vw;
  border-bottom: 2px solid #EFECE4; }
.course .main-inner .img-content .cl-content .head .price > span {
  display: block;
  padding: .6vw 0 .2vw;
  text-align: center; }
.course .main-inner .img-content .cl-content .head .side-note {
  padding: 1.2vw 0 .8vw; }
.course .main-inner .img-content .cl-content .head h4 {
  font-size: 3.6vw; }
.course .main-inner .img-content .cl-content .head h4 span {
  font-size: 2.8vw; }
.course .main-inner .img-content .cl-content .caption {
  padding-top: 1.2vw; }
.course .main-inner .tag {
  padding: .8vw .8vw .4vw; }

.course-slider {
  margin-top: 10vw; }
.course-slider .swiper-slide {
  opacity: 0;
  transition: .6s; }
.course-slider .swiper-slide-active {
  opacity: 1; }

.course-pagination {
  left: 10%;
  width: 80%;
  bottom: auto;
  top: -7vw !important;
  margin: 4vw 0;
  text-align: center;
  position: absolute; }
.course-pagination .swiper-pagination-bullet {
  width: 25%;
  margin: 0;
  border-radius: 0;
  height: 2px;
  background-color: #292721; }
.course-pagination .swiper-pagination-bullet p {
  font-weight: bold;
  position: relative;
  top: -2.8vw;
  font-size: 1.1vw;
  color: #292721; }
.course-pagination .swiper-pagination-bullet-active {
  background-color: #BA9D47; }
.course-pagination .swiper-pagination-bullet-active p {
  color: #BA9D47; }

.swiper-button-prev, .swiper-button-next {
  height: 4vw;
  width: 4vw;
  top: 14.5vw; }

.swiper-button-prev {
  left: -2vw; }

.swiper-button-next {
  right: -2vw; }

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after, .swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 4vw;
  margin: auto;
  width: 4vw; }

/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
  background-image: url(../img/slide-arrow-prev.png); }

/* 次への矢印カスタマイズ */
.swiper-button-next::after {
  background-image: url(../img/slide-arrow.png); }

@media only screen and (max-width: 768px) {
  .course {
    padding: 20vw 0 4vw; }
  .course .main-inner {
    width: 86vw; }
  .course .main-inner .text-content {
    width: 100%;
    padding: 9.6vw 8vw 8vw 8vw; }
  .course .main-inner .text-content ul {
    width: 100%;
    padding: 4.8vw; }
  .course .main-inner .text-content ul li {
    gap: 2.4vw; }
  .course .main-inner .text-content ul li svg {
    width: 4.2vw; }
  .course .main-inner .text-content ul li p {
    position: relative;
    top: .3vw; }
  .course .main-inner .img-content {
    text-align: center;
    width: 100%;
    padding: 0vw 8vw 8vw 8vw; }
  .course .main-inner .img-content .cl-content {
    padding: 4vw 4vw 3.2vw; }
  .course .main-inner .img-content .cl-content .head .price {
    padding: 4vw 6.4vw 3.6vw; }
  .course .main-inner .img-content .cl-content .head .price > span {
    padding: 1.6vw 0 0.6vw; }
  .course .main-inner .img-content .cl-content .head .side-note {
    padding: 3.2vw 4vw 2vw; }
  .course .main-inner .img-content .cl-content .head h4 {
    font-size: 8.8vw; }
  .course .main-inner .img-content .cl-content .head h4 span {
    font-size: 7.2vw; }
  .course .main-inner .img-content .cl-content .caption {
    padding-top: 3.6vw; }

  .course-slider {
    margin-top: 35vw; }

  .course-pagination {
    left: 0%;
    width: 100%;
    bottom: auto;
    margin: 4vw 0;
    top: -15vw !important; }
  .course-pagination .swiper-pagination-bullet {
    width: 47%;
    margin: 0 0 12vw !important;
    height: 1px; }
  .course-pagination .swiper-pagination-bullet p {
    top: -8vw;
    font-size: 3.2vw; }

  .swiper-button-prev, .swiper-button-next {
    height: 10vw;
    width: 10vw;
    top: 72.5vw; }

  .swiper-button-prev {
    left: -5vw; }

  .swiper-button-next {
    right: -5vw; }

  /* 前へ次への矢印カスタマイズ */
  .swiper-button-prev::after, .swiper-button-next::after {
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 10vw;
    margin: auto;
    width: 10vw; } }
/*
-------------------------------------------
FLOW
-------------------------------------------
*/
.flow {
  padding: 0vw 0 0; }
.flow .l-inner {
  height: 32vw;
  position: relative;
  z-index: 1;
  top: 10vw;
  background-color: #292721;
  background-image: url(../img/flow-bg.jpg);
  background-size: cover;
  background-position: center; }
.flow .main-inner {
  position: relative;
  top: -2vw;
  z-index: 2;
  padding: 6vw 6vw; }
.flow .main-inner .text-content {
  width: 50%; }
.flow .main-inner .text-content .section-title {
  text-align: left; }
.flow .main-inner .text-content ul {
  width: 90%;
  border: 1px solid rgba(41, 39, 33, 0.1);
  padding: 1.6vw; }
.flow .main-inner .text-content ul li {
  gap: .4vw; }
.flow .main-inner .text-content ul li svg {
  width: 1.4vw;
  color: #F69956; }
.flow .main-inner .text-content ul li p {
  position: relative;
  top: .1vw; }
.flow .main-inner .img-content {
  text-align: center;
  width: 40%; }
.flow .main-inner .img-content ul {
  position: relative; }
.flow .main-inner .img-content ul:before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  width: 1px;
  height: 100%;
  left: 2vw;
  top: 0;
  border-right: 0.2vw dotted #F69956; }
.flow .main-inner .img-content ul li {
  position: relative;
  z-index: 2;
  margin-bottom: 1.2vw;
  padding: .8vw;
  gap: 1vw; }
.flow .main-inner .img-content ul li span {
  display: block;
  width: 2.4vw;
  height: 2.4vw;
  padding-top: 0.8vw; }
.flow .main-inner .img-content ul li p {
  position: relative;
  top: .2vw; }
.flow .main-inner .img-content ul li:last-child {
  margin-bottom: 0; }

@media only screen and (max-width: 768px) {
  .flow {
    padding: 0vw 0 0; }
  .flow .l-inner {
    height: 64vw;
    position: relative;
    z-index: 1;
    top: 20vw;
    background-color: #292721;
    background-image: url(../img/flow-bg.jpg);
    background-size: cover;
    background-position: center; }
  .flow .main-inner {
    width: 86vw;
    position: relative;
    top: -2vw;
    z-index: 2;
    padding: 12vw 6vw; }
  .flow .main-inner .text-content {
    width: 100%;
    margin-bottom: 12vw; }
  .flow .main-inner .text-content .section-title {
    text-align: center; }
  .flow .main-inner .text-content ul {
    width: 90%;
    border: 1px solid rgba(41, 39, 33, 0.1);
    padding: 1.6vw; }
  .flow .main-inner .text-content ul li {
    gap: .4vw; }
  .flow .main-inner .text-content ul li svg {
    width: 1.4vw;
    color: #F69956; }
  .flow .main-inner .text-content ul li p {
    position: relative;
    top: .1vw; }
  .flow .main-inner .img-content {
    text-align: center;
    width: 100%; }
  .flow .main-inner .img-content ul {
    position: relative; }
  .flow .main-inner .img-content ul:before {
    z-index: 1;
    width: 1px;
    left: 6vw;
    border-right: 2px dotted #F69956; }
  .flow .main-inner .img-content ul li {
    position: relative;
    z-index: 2;
    margin-bottom: 3.6vw;
    padding: 2.4vw;
    gap: 3vw; }
  .flow .main-inner .img-content ul li span {
    display: block;
    width: 7.2vw;
    height: 7.2vw;
    padding-top: 2.4vw; }
  .flow .main-inner .img-content ul li p {
    position: relative;
    top: .2vw; }
  .flow .main-inner .img-content ul li:last-child {
    margin-bottom: 0; } }
/*
-------------------------------------------
CASE
-------------------------------------------
*/
.case {
  padding: 0vw 0 8vw; }
.case .main-inner .case-slide {
  border: 1px solid rgba(41, 39, 33, 0.1);
  background-color: #F6F5F6;
  padding: 4vw 0 3.2vw;
  text-align: center; }
.case .main-inner .case-slide img {
  width: 60%; }
.case .main-inner .swiper-button-prev, .case .main-inner .swiper-button-next {
  top: 19vw; }
.case .main-inner .swiper-container {
  overflow: hidden; }
.case .main-inner .swiper-pagination {
  bottom: -2vw; }
.case .main-inner .swiper-pagination-bullet {
  background: #292721;
  opacity: 0.4; }
.case .main-inner .swiper-pagination-bullet-active {
  opacity: 1;
  background: #BA9D47; }

@media only screen and (max-width: 768px) {
  .case {
    padding: 6vw 0 20vw; }
  .case .main-inner {
    width: 86vw; }
  .case .main-inner .case-slide {
    border: 1px solid rgba(41, 39, 33, 0.1);
    background-color: #F6F5F6;
    padding: 8vw 0 6vw;
    text-align: center; }
  .case .main-inner .case-slide img {
    width: 80%; }
  .case .main-inner .swiper-button-prev, .case .main-inner .swiper-button-next {
    top: 34vw; }
  .case .main-inner .swiper-container {
    overflow: hidden; }
  .case .main-inner .swiper-pagination {
    bottom: -4vw; }
  .case .main-inner .swiper-pagination-bullet {
    background: #292721;
    opacity: 0.4; }
  .case .main-inner .swiper-pagination-bullet-active {
    opacity: 1;
    background: #BA9D47; } }
/*
-------------------------------------------
FAQ
-------------------------------------------
*/
.faq {
  border-top: 0.2vw solid #F6F5F6;
  padding: 8vw 0 8vw; }
.faq ul li {
  border: 1px solid rgba(41, 39, 33, 0.1);
  overflow: hidden; }
.faq ul li .faq-q {
  padding: 1.2vw; }
.faq ul li .faq-q .flex {
  gap: 1.2vw; }
.faq ul li .faq-q .flex h4 {
  position: relative;
  top: .2vw; }
.faq ul li .faq-q span {
  display: block;
  width: 2.4vw;
  height: 2.4vw;
  padding-top: 0.6vw;
  text-align: center; }
.faq ul li .faq-q figure {
  width: 2.4vw;
  transform: rotate(180deg); }
.faq ul li .faq-a {
  padding: 0vw 1.2vw;
  height: 0;
  overflow: hidden;
  background-color: #F6F5F6; }
.faq ul li .faq-a .flex {
  gap: 1.2vw; }
.faq ul li .faq-a .flex p {
  position: relative;
  top: .2vw; }
.faq ul li .faq-a span {
  display: block;
  width: 2.4vw;
  height: 2.4vw;
  padding-top: 0.6vw;
  text-align: center; }
.faq ul li.open .faq-a {
  padding: 1.2vw;
  height: auto;
  overflow: hidden; }
.faq ul li.open .faq-a figure {
  transform: rotate(0deg); }

@media only screen and (max-width: 768px) {
  .faq {
    border-top: 2px solid #F6F5F6;
    padding: 20vw 0 20vw; }
  .faq .main-inner {
    width: 86vw; }
  .faq ul li .faq-q {
    padding: 3.6vw; }
  .faq ul li .faq-q .flex {
    gap: 3.6vw; }
  .faq ul li .faq-q .flex h4 {
    position: relative;
    top: .6vw; }
  .faq ul li .faq-q span {
    width: 7.2vw;
    height: 7.2vw;
    padding-top: 1.8vw; }
  .faq ul li .faq-q figure {
    width: 7.2vw; }
  .faq ul li .faq-a {
    padding: 0vw 3.6vw; }
  .faq ul li .faq-a .flex {
    gap: 3.6vw; }
  .faq ul li .faq-a .flex p {
    top: .6vw;
    width: 68vw; }
  .faq ul li .faq-a span {
    width: 7.2vw;
    height: 7.2vw;
    padding-top: 1.8vw; }
  .faq ul li.open .faq-a {
    padding: 3.6vw; } }
/*
-------------------------------------------
INFO
-------------------------------------------
*/
.info {
  padding: 0vw 0 8vw; }
.info .section-title {
  text-align: left; }
.info .text-content {
  width: 50%;
  padding: 6vw; }
.info .text-content ul li h4 {
  opacity: .7; }
.info .text-content ul li p a {
  margin-left: .6vw;
  display: inline-block; }
.info .img-content {
  width: 50%;
  position: relative;
  top: -4vw; }
.info .img-content iframe {
  width: 100%;
  height: 100%; }
.info .btn-head {
  width: 21vw; }

@media only screen and (max-width: 768px) {
  .info {
    padding: 0vw 0 20vw; }
  .info .section-title {
    text-align: center; }
  .info .text-content {
    width: 100%;
    padding: 12vw;
    margin-bottom: 8vw; }
  .info .text-content ul li h4 {
    opacity: .7; }
  .info .text-content ul li p a {
    margin-left: 1.8vw;
    display: inline-block; }
  .info .img-content {
    width: 100%;
    height: 48vw;
    position: relative;
    top: 0vw; }
  .info .img-content iframe {
    width: 100%;
    height: 100%; }
  .info .btn-head {
    width: 100%; } }
/*
-------------------------------------------
FOOTER
-------------------------------------------
*/
footer {
  padding: 2.8vw 0 4vw; }
footer > .l-inner {
  height: 7.2vw; }
footer .logo {
  display: block; }
footer .logo img {
  width: 12vw; }
footer .logo:hover {
  opacity: .5; }
footer .fixed-logo {
  display: none; }
footer .nav {
  gap: 2.4vw; }
footer .nav ul {
  gap: 0vw; }
footer .nav ul li a {
  padding: 1vw 1.2vw;
  border-radius: .4vw;
  -webkit-border-radius: .4vw;
  line-height: 1;
  color: #fff; }
footer .nav ul li a:hover {
  color: #BA9D47; }
footer .nav ul li.inactive a {
  opacity: .5; }

@media only screen and (max-width: 768px) {
  footer {
    padding: 8.4vw 0 4vw; }
  footer > .l-inner {
    height: auto; }
  footer .logo {
    display: block; }
  footer .logo img {
    width: 36vw;
    margin: 4vw auto 6vw; }
  footer .logo:hover {
    opacity: .5; }
  footer .fixed-logo {
    display: none; }
  footer .nav {
    width: 100%;
    gap: 0%;
    margin-bottom: 8vw; }
  footer .nav ul {
    margin-bottom: 12vw;
    gap: 5%; }
  footer .nav ul li {
    width: 47.5%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
  footer .nav ul li a {
    padding: 4.8vw 0vw 4vw;
    color: #fff; }
  footer .nav ul li a:hover {
    color: #BA9D47; }
  footer .nav ul li.inactive a {
    opacity: .5; } }
/*
-------------------------------------------
OUTLINE
-------------------------------------------
*/
.outline {
  padding-bottom: 8vw; }
.outline li {
  padding-bottom: 2vw;
  border-bottom: 1px solid rgba(41, 39, 33, 0.1); }

@media only screen and (max-width: 768px) {
  .outline {
    padding-bottom: 16vw; }
  .outline .main-inner {
    width: 86vw; }
  .outline li {
    padding-bottom: 4vw; }

  .swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    left: -5vw !important;
    width: 96vw !important; } }
