html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 62.5%;/*rem�Z�o�����₷�����邽�߂�*/
}
body {
  font-family: Poppins, 
    'Helvetica Neue',
    Arial,
    YuGothic,
    'Yu Gothic',
    Meiryo,
    sans-serif;
}

h1, h2, h3 {color:#414a52!important}
h1 {text-align: center; margin-bottom: 10px;}

/* hr */
hr {
  height: 0;
  margin: 0;
  padding: 0;
  border: 0;
}
hr .line {
  border-top: 1px solid #ccc;
}

img { width: 100%;}
a {text-decoration: none; color: #414a52;}

/* �{�^�� */
.btn,
a.btn,
button.btn {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #414a52;
  border-radius: 0.5rem;
}
a.btn-border {
  border: 2px solid #414a52;
  border-radius: 0;
  background: #fff;
}

a.btn-border:hover {
  color: #fff;
  background: #8A9097;
}
.btn--white, a.btn--white {
    border: 1px solid #ccc;
}

/* Window.open�{�^�� */
button {
  border: 1px solid #ccc;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #414a52;
  border-radius: 0.5rem;
}


/* ��{���C�A�E�g - SP */
section .container, footer .container {padding: 10px 20px;}
section p {font-size: 14px;line-height: 24px;}
.has-padding {padding: 25px 0!important;}
.column_bottom { margin-bottom: 30px}

.frame {
  margin: 10px 0px;
  position: relative;
  width: 100%;
  height: auto;
}

.layer {
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/simulator/base.png);
  background-repeat: no-repeat;
  background-size: 100%;
  width: 100%;
  height: auto;
}
.frame img {
	width: 100%;
}
.layer img {
	width: 100%;
}

.select_panel {
  background-color: #fff;
  padding: 10px 20px;
}
.select_panel p {
  font-size: 18px; 
  font-weight: 500;
  line-height: 140%;
  margin: 0px;
  padding: 0px;
}
.select_panel p span {
  font-size: 80%;
}
.select_btn { padding: 20px 20px;}
.select_btn .variation { padding: 10px 0px 30px 0px; clear: both;}
.select_btn p { margin: 0 0 5px 0; padding: 0; clear: both;}
.select_list li { width:12%; float: left; margin: 0 5% 2% 0; text-align: center; vertical-align: center; line-height: 120%;}
.select_list li:nth-child(6n){ margin: 0 0 2% 0;}
.select_btn img { width: 100%;}

.product_page_btn { clear: both;text-align:center; margin: 20px 0px;}

.other_model { text-align:center;}
.other_model p { font-weight: 600; margin: 30px 0; font-size: 20px;}
.other_model ul { margin: 0; padding: 0;}
.other_model li { float: left; width: 45%; margin: 0 10% 5% 0; font-size: 80%;}
.other_model li:nth-child(2n){ margin: 0 0 5% 0;}
.other_model li img { width: 100%;}

footer .footer-nav ul.footer-primary-nav li {
    display: block;
    margin: 0px!important;
    padding: 15px 0;
    border-bottom: 0px!important;
}

@media only screen and (max-width: 820px){
.br-sp {display: none;}
}

/* moblie */
@media only screen and (max-width: 768px) {
.sp_only {display: none;}
}

/* Tablet */
@media only screen and (min-width: 768px) {
.pc_only {display: none;}
}

/* PC */
@media only screen and (min-width: 1024px) {
section .container {width: 1025px;}
.select_btn .color_list { width:10%; float: left; margin-right: 5%; font-size: 10px; line-height: 120%;}
}



/* �w�b�_�[ */
.header-nav-wrapper .logo{padding: 32px 0 10px 40px!important;border-bottom:solid 0px!important;background-color:#FFF!important}
.header-nav-wrapper .logo h1 {text-align: left;}
.header-nav-wrapper nav ul li a:before{background-color:#666!important}
.navicon{padding:46px 35px;background-color:transparent}
.nav-toggle span,.nav-toggle span:before,.nav-toggle span:after{width:25px!important;height:2px!important;background:#414a52!important}
.nav-toggle.active span{background-color:transparent!important}
.header-nav-wrapper nav ul li a{ color:#414a52!important}

@media screen and (max-width: 480px){
.header-nav-wrapper{border-bottom:solid 0px!important;background:#fff!important}
.header-nav-wrapper .logo{padding: 20px 0 10px 15px!important;}
.header-nav-wrapper nav ul li a{ font-size: 24px;}
}

@media screen and (max-width: 1024px){
.primary-nav-wrapper{background-color:#dfdfdf!important}
}

/* �t�b�^�[ */
.footer-branding {margin: 20px 0 0 0!important;}
.footer-branding h5 { font-size: 24px;font-weight:400;color:#fff!important;}
footer .footer-nav {border: 0!important}
.footer-nav a:hover {color:#8A9097!important;}


/* Main Image �X���C�_�[ */
.slick_main li img, .slick_main_sp li img { width: 100%;}
@media screen and (min-width: 481px){
.slick_main_sp { display: none;}
}
@media screen and (max-width: 480px){
.slick_main { display: none;}
}
#main-slick .relative {position: relative;}
#main-slick span {color:#fff;font-size: 60%;position: absolute;left: 4px;bottom: 0px;}


/* �X���C�p�[ */

.swiper-wrapper {
  /* wrapper�̃T�C�Y�𒲐� */
  width: 100%;
}
.swiper-slide {
  /* �X���C�h�̃T�C�Y�𒲐��A���g�̃e�L�X�g�z�u�����A�w�i�F */
  width: 100%;
  text-align: center;
  padding: 10px;
}
.swiper-pagination-bullets {
  position: static;
  width: 100px;
}
.swiper-pagination-bullet {
  width: 12px !important;
  height: 12px !important;
  margin: 0 0 0 10px !important;
  background: #333;
}

.swiper-pagination-bullet:first-child {
  margin: 0 !important;
}
.swiper-button-prev,
.swiper-button-next {
  width: 24px; /* �{�^���̕� */
  height: 40px; /* �{�^���̍��� */
  background-size: 24px 40px; /* �\���������T�C�Y */
  transform: translateY(-50%);
  margin-top: 0;
}





/* �����X�N���[�� */
/*
IE11�΍�
----------------------------*/
_:-ms-lang(x)::-ms-backdrop,
.showcase {
  display: -ms-grid;
  overflow: hidden;
}
/*----------------------------*/

.showcase__wrap {
  display: flex;
  overflow: hidden;
}
.showcase__list {
  display: flex;
  list-style: none;
}
.showcase__list--left{
animation :infinity-scroll-left 25s infinite linear 0.5s both;
}
.showcase__item {
  width: calc(100vw / 2);
}
.showcase__item > img{
   width: 100%;
}
.showcase__wrap:hover .showcase__list--left{
  animation-play-state: paused;
}
@media only screen and (min-width: 1025px) {
.showcase__item {
  width: calc(100vw / 4);
}
}
/* �E���獶�� */
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}


/* �t�H���g�T�C�Y */
@media screen and (max-width: 767px){ /* SP/small Tablet */
    #intro h2, #sub_intro h2, #sub_text h2, #detail h3 { font-weight: 700; font-size: 20px; line-height: 1.5; text-align: center;}
    #detail h3 span { font-weight: 100; font-size: 30px; display:block; line-height: 1.2; }
    #detail h4 { font-weight: 700; font-size: 18px; line-height: 1.5; }
    #intro p, #sub_intro p, #sub_text p, #detail .lead { font-weight: 300; font-size:14px;text-align: left; line-height: 1.8; }
}
@media screen and (min-width: 768px){ /* PC/Tablet */
    #intro h2, #sub_intro h2, #sub_text h2, #detail h3  { font-weight: 700; font-size: 24px; line-height: 1.5; text-align: center;}
    #detail h3 span { font-weight: 100; font-size: 32px; display:block; line-height: 1.2; }
    #detail h4 { font-weight: 700; font-size: 20px; line-height: 1.5; }
    #intro p, #sub_intro p, #sub_text p, #detail .lead { font-weight: 400; font-size:16px;text-align: center; line-height: 1.8; }
    #detail .text p { font-weight: 400; font-size:16px;text-align: left; line-height: 1.6; }
}



/* �C���g�� */
#intro {margin-top: 60px;}
#intro h2 { margin-bottom: 30px;}
#sub_intro span {color:#fff;font-size: 60%;position: absolute;left: 4px;bottom: 5px;margin: 8% 25%;}
#sub_intro {padding-bottom: 40px;}
#sub_intro .relative {position: relative;}
#sub_intro img {width:50%;margin: 8% 25%;}
#sub_intro h2 { margin-bottom: 30px;}
#sub_intro p { padding-bottom: 30px;}

/* �X�N���[���摜�̉��̕��� */
#sub_text {padding-bottom: 40px;}
#sub_text h2 { margin-bottom: 30px;}
#sub_text p { padding-bottom: 30px;}

/* �f�B�e�B�[�� */
#detail h3 { margin: 40px 0 30px 0; }
#detail h3 span { padding-bottom:5px; }
#detail h4 { margin: 0 0 10px 0;}
#detail .text { margin: 20px 0 50px 0;}
#detail .lead { margin-bottom: 30px;}
@media screen and (min-width: 768px){
    #detail .first {padding-right: 2.5%;}
    #detail .last {padding-left: 2.5%;}
}


/* �o���G�[�V�����X�N���[�� */
#variation h3 { font-weight: 300;font-size: 30px;text-align: center; margin: 40px 0 60px 0;}
.scroll_list ul {
	margin: 0; padding: 0;
}
.scroll_list li {
    list-style: none;
}
.scroll_item_inr p {
    font-size: 200%;
}
@media screen and (min-width: 1024px) {
.horizontal_scroll_wrap {
    width: 100%;
    overflow : hidden;
    margin: 0;
}
.scroll_list li {
    float: left;
    margin-right: 5%;
    height: 380px;
}
.scroll_list li:nth-child(2n) {
    margin-right: 0%;
}
.scroll_list li img { height:14.55em; }
.scroll_item_info {
    margin-top: 10px;
    text-align: center;
}
.scroll_item_ttl {
    font-size: 14px;
    color: #484848;
    line-height: 1.2;
}
.scroll_item_ttl span {
    font-size: 14px;
    font-weight: 500;
}
}
@media screen and (max-width: 1023px) {
.horizontal_scroll_wrap {
    height: 210px;
    overflow-y: hidden;
    margin: 0 0 30px 0 ;
}
.scroll_list {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    padding-bottom: 50px;
    margin: 20px 0 0;
    -webkit-overflow-scrolling: touch;
}
.scroll_list li img { width: auto; height:8em; }
.scroll_item {
    padding: 5px;
    display: inline-block;
    vertical-align: top;
    width:auto;
}
.scroll_item_inr {
    display: block;
}
.scroll_item_info {
    white-space: normal;
    padding: 4px 1px;
    text-align: center;
}
.scroll_item_ttl {
    height: 52px;
    font-size: 11px;
    color: #484848;
    line-height: 1.4;
    display: flex; /* ���Ƃ̏c�̕��шʒu�����p */
    align-items: center;
    justify-content: center;
}
.scroll_item_ttl span {
    font-size: 11px;
    font-weight: 500;
}
}


/* �f�U�C�i�[ */
#designer .relative {position: relative;}
#designer span {color:#fff;font-size: 60%;position: absolute;left: 4px;bottom: 5px;}
#designer h4 {margin:30px 0 5px 0;}
#designer .first, #designer .last {margin-bottom: 30px;}
#designer .more {text-align: center;}
#designer .more p {font-size: 200%;}
@media screen and (min-width: 768px){
#designer .first {padding-right: 2.5%;}
#designer .last {padding-left: 2.5%;}
}


/* �Ǐ]�����N�i�V�~�����[�^�[�j */
@media screen and (min-width: 481px){
.floating-banner_sp { display: none;}
}
@media screen and (max-width: 480px){
.floating-banner_pc { display: none;}
}

.floating-banner {
    position: fixed;
    z-index: 99999;
    bottom: 10px;
    right: 10px;
}
.floating-banner:hover {
    opacity: .9;
}
.banner {
    width: 200px;/* �o�i�[�̉��� */
    height: 200px;
    padding: 0px;
    background: linear-gradient(86.13deg, #085b27 -3.42%, #0a3c1d 59.59%);/* �o�i�[�̔w�i�F */
    color: #fff;/* �o�i�[���̕����F */
    border-radius: 50%;
    font-weight: bold;
    text-align: center;
}

.floating-banner a {
    text-decoration: none;/* �����N�ɉ���������Ȃ��悤�� */
}
.copy {
    font-size: 12px;
    color: #f4f4f4;
    line-height: 1.2;
}
.cta {
    display: inline-block;
    width: 120px;
    height: 30px;
    line-height: 30px;
    font-size: 14px;
    background: #f4f4f4;/* �{�^���̔w�i */
    box-shadow: 0px 0px 30px #0a3c1d;/* �{�^���̉e */
    border-radius: 25px;
    margin: 0
}
@media screen and (max-width: 990px) {
    .floating-banner {
        display: none;
    }
}
@media screen and (max-width: 480px) {
    .floating-banner {
        bottom: -6px;
        right: 0px;
    }
    .floating-banner {
        display: inline-block;
    }
    .banner {
        width: 100%;
        height: auto;
        padding: 0px;
        border-radius: 0px;
    }
    .sp {
        display: none;
    }
    .copy {
        font-size: 12px;
    }
    .cta {
        height: 24px;
        line-height: 24px;
        font-size: 12px;
    }
}

/* Variation �摜�I���}�E�X���� */
.scroll_item_thum img:hover {opacity: 0.8;}

/* Variation ��󒲐� */
.scroll_item_info .fa {transform: rotateZ(-90deg); font-size: 200%;}
.scroll_item_info p {padding: 5px 10px;}
.scroll_item_info {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}



/* ���[�_�� */
*{
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
.content{
    margin: 0 auto;
    padding: 40px;
}
.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
}
.modal__bg{
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    left: 50%;
    padding: 20px;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 96%;
}
.modal__content .cover_name {
    font-weight: 700;
    font-size: 120%;
}
.modal__content .cover_name span{
    font-weight: 500;
    font-size: 80%;
}
.modal__content li{
    float: left;
    width: 19.2%;
    margin-right: 1%;
    font-size: 80%;
}
.modal__content li img{
    width: 100%;
}
.modal__content li:nth-child(5n){ margin: 0;}
.modal__content .arrow {
    font-size: 80%;
    text-align: center;
}
.modal-close {
    font-size: 200%;
    text-align: center;
}

/* ���[�_�� - Tablet */
@media only screen and (min-width: 600px) {
.modal{
    height: 100%;
    width: 500px;
}
.modal__bg{
    height: 100%;
    width: 100%;
}
}

/* ���[�_�� - PC */
@media only screen and (min-width: 1025px) {
.modal{
    height: 100%;
    width: 500px;
}
.modal__bg{
    height: 100%;
    width: 100%;
}
}

/* ���[�_�� index.html�@�\�Љ�p */
.detail-modal {
    width: 100%;
}
.detail-modal .modal__content {
    width:80%;
    max-width:1000px;
    height:auto;
    max-height:100%;
}

/* �X���C�_�[ index.html�@�\�Љ�p */
.slide-items {
  width: 100%;
  height: 100%;
  margin: 50px auto;
}
.slide-items li {
  margin: 0 10px;
}
.slide-items img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.slick-prev:before,
.slick-next:before {
  color: black;
}
.slick-dots li button:before {
  font-size: 18px;
  top: 6px;
}


/* LightBox �N���[�Y�{�^�� */
.round_btn {
  display: block;
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border: 2px solid #fff; /* �g�̒��� */
  border-radius: 50%;  /* �ۂ݂̓x���� */
  background: #333; /* �{�^���̔w�i�F */
  text-align: right;
}
 
.round_btn::before, .round_btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px; /* �_�̕��i�����j */
  height: 22px; /* �_�̍��� */
  background: #fff; /* �o�c��̐F */
}
 
.round_btn::before {
  transform: translate(-50%,-50%) rotate(45deg);
}
 
.round_btn::after {
  transform: translate(-50%,-50%) rotate(-45deg);
}

/* YouTube���惌�X�|���V�u�Ή� */
.slide-items .movie {
  width: 100%;
  aspect-ratio: 16 / 12;
}
.movie iframe {
  width: 100%;
  height: 100%;
}

/* �}�b�v�����N��PC/SP�摜�ؑ� */
.areamap_pc { display: block !important; }
.areamap_sp { display: none !important; }
 
@media only screen and (max-width: 750px) {
    .areamap_pc { display: none !important; }
    .areamap_sp { display: block !important; }
}


/* ���r���E�f�C�ڍ׃y�[�W */
.intro-jumbotron {
  background-image: url("../img/designer/bg_01.jpg");
  background-size: cover;
  background-position: left 0%;
  min-height: 580px;
}
.profile {
  margin-top: 250px;
  padding: 20px 10px 10px 15px;
  background:rgba(0,0,0,0.4);
}
.profile h2, .profile p {
  color: #fff!important;
  text-shadow: 1px 2px 3px #424242;
  padding:0;
}
.profile .text {
  margin-top: 10px;
}
.profile .text_en {
  font-size:70%;
  line-height: 1.6em;
  margin-top: 15px;
}
.vertically-long {
  width: 60%;
}
.designer-contents .row {
  margin-top:20px;
}
.designer-contents h2 {
  font-size:200%;
  margin:0 0 10px;
}
.designer-contents h3 {
  font-size:160%;
  margin:60px 0 30px;
}
.designer-contents .foundation-img {
  position: relative;
  margin:0;
  padding:0;
}
.foundation-img p {
  margin:0;
  padding:0;
}
.designer-contents .credit {
  position: absolute;
  font-size: 9px;
  line-height: 1.0em;
  text-align: right;
  bottom: 11px;
  right: 5px;
}
.designer-contents .credit_w {
  position: absolute;
  font-size: 9px;
  line-height: 1.0em;
  bottom: 3px;
  left: 5px;
  color: #ccc;
}
.designer-contents .wh {
  color: #fff;
}
.designer-contents .gy {
  color: #ccc;
}

.designer-contents .credit_g {
  position: absolute;
  font-size: 9px;
  bottom: 10px;
  right: 5px;
  color: #666;
  text-align: right;
  line-height: 1.0em;
}
.designer-contents .img_caption_jp {
  margin:5px 0 0 0;
  padding:0;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.4em;
  color:#888888;
}
.designer-contents .img_caption {
  margin-top:5px;
  font-size: 9px;
  line-height: 1.4em;
  color:#888888;
}


#Philosophy .container {
background-color:#e0dfd7;
}
.philosophy .wise_saying {
  font-family: '������','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
  font-size: 18px;
  line-height: 1.6em;
  margin: 25px 10px;
  font-weight: 700;
}
#Masterpiece h3 {
  font-size:160%;
  margin:40px 0;
  text-align: center;
}
#Masterpiece .foundation-img {
  width: 80%;
  margin-left: 10%;
}
#Masterpiece .foundation-img img {
  border: 1px solid #ccc;
}
#Masterpiece .img_caption_jp {
  margin:0 0 30px;
  text-align: center;
  color:#414a52;
}

@media screen and (min-width: 576px) and (max-width: 992px) {
.profile {
  margin-top: 320px;
}
.vertically-long {
  width: 50%;
}
#Philosophy {
background-color:#e0dfd7;
}
}

@media screen and (min-width: 992px) {
.intro-jumbotron {
  background-position: center 0%;
  min-height: 600px;
}
.profile {
  margin-top: 120px;
  padding: 0px;
  margin-left: 55%;
  background:rgba(255,255,255,0);
}
.profile h2, .profile p {
  color: #fff!important;
  text-shadow: 1px 2px 3px #424242;
}
.designer-contents .row {
  margin-top:120px;
}
.designer-contents h2 {
  font-size: 280%;
  margin:0 0 30px;
}
.designer-contents h3 {
  font-size:180%;
  margin:0px 0 70px;
  line-height: 1.6em;
}
.vertically-long {
  width: 100%;
}
#Philosophy .container {
background-color: transparent;
}
.philosophy-jumbotron {
  background-image: url("../img/designer/bg_02.jpg");
  background-size: cover;
  background-position: center 0%;
  min-height: 700px;
}
.philosophy {
  padding: 120px 0 0 0;
  margin-left: 55%;
  background:rgba(255,255,255,0);
}
#Masterpiece h3 {
  margin:0 0 60px;
}
#Masterpiece .foundation-img {
  width: 100%;
  margin: 0;
}
#Masterpiece .img_caption_jp {
  margin:10px 0 60px;
}
}


/* CP�o�i�[ */
.campaign {
	text-align: center;
	margin-bottom: 50px;
}

.campaign img {
	width:100%;
	max-width: 612px;
}
