@charset "utf-8";

@import url("header.css");
@import url("nav.css");
@import url("footer.css");

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wdth,wght@0,75..100,100..900;1,75..100,100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');
/*
body * { border:0.02px solid #000000; background:rgba(000,000,000,0.1)}
*/

html,
body {
 width: 100%;
 font-size: 62.5%;
 color: #333;
 background-image: url(../_image/common/bg.jpg);
 background-size: 150px auto;
}

html {}

body {}

#wrap {
 min-width: 1024px !important;
 overflow-x: hidden !important;
}

.showPc {}

.showSp {
 display: none;
}

#wrap::before,
#wrap::after {
 content: "";
 display: block;
 position: fixed;
 bottom: 0;
 width: 35vw;
 height: 24vw;
 background-image: url(../_image/common/kome-bottom.webp);
 background-size: 100% auto;
 background-repeat: no-repeat;
 background-position: bottom right;
 z-index: 10;
 pointer-events: none;
}

#wrap::before {
 left: 0;
}

#wrap::after {
 right: 0;
 transform: scale(-1, 1);
}

@media only screen and (max-width:1024px) {

 html,
 body {}
}

@media only screen and (max-width:640px) {

 html,
 body {
  width: 640px;
  min-width: 640px;
  /*font-size: 106.67%;*/
  font-size: 90%;
 }

 #wrap {
  width: 640px !important;
  min-width: 640px !important;
 }

 #wrap::before,
 #wrap::after {
  width: 40vw;
  height: 34vw;
  background-size: auto 100%;
 }

 .showPc {
  display: none !important;
 }

 .showSp {
  display: block;
 }

}


/* --------------------------------------------

変数設定

---------------------------------------------- */
:root {}


/* --------------------------------------------

fonts

---------------------------------------------- */
body,
input,
select,
select option,
textarea,
h1,
h2,
h3,
h4,
h5,
h6 {
 font-family: "Zen Kaku Gothic New", sans-serif;
 font-optical-sizing: auto;
 font-weight: 500;
 font-style: normal;
 font-size: 1.8rem;
 line-height: 1.4;
 letter-spacing: 0.025em;
}

body,
input,
select,
select option,
textarea,
table,
th,
td,
p {
 font-weight: 500;
 font-style: normal;
 font-feature-settings: "palt";
 text-align: justify;
 text-justify: inter-ideograph;
}

p {
 line-height: 2;
}

b,
strong {
 font-weight: 700;
}

small {
 display: inline-block;
 font-size: 0.85em;
}

a {
 color: #333;
 text-decoration: none;
 transition: 0.3s;
}

a:hover {}

a img {}

a:hover img {}


/* セレクト時の色指定 */
::selection {
 background: rgba(222, 198, 11, 0.25);
}

::-moz-selection {
 background: rgba(222, 198, 11, 0.25);
 /*Firefox*/
}


.ff-en {
 font-family: "Roboto", sans-serif;
 font-optical-sizing: auto;
 font-weight: <weight>;
 font-style: normal;
 font-variation-settings:
  "wdth"<width>;
}


@media only screen and (max-width:640px) {

 body,
 input,
 select,
 select option,
 textarea,
 h1,
 h2,
 h3,
 h4,
 h5,
 h6 {
  font-size: 1.6rem;
 }
}



/* --------------------------------------------

#main

---------------------------------------------- */

.flex {
 display: flex;
 align-items: flex-start;
 justify-content: space-between;
 flex-wrap: wrap;
 margin: auto;
}

main {
 position: relative;
}

@media only screen and (max-width:640px) {}





/* --------------------------------------------

飾りイラスト

---------------------------------------------- */
.deco {
 position: absolute;
 pointer-events: none;
}

.deco-kome-l,
.deco-kome-r {
 width: 26vw;
 max-width: 450px;
 height: 26vw;
 max-height: 450px;
 background-repeat: no-repeat;
 background-size: cover;
 z-index: 1;
}

.deco-kome-l ~ div,
.deco-kome-l ~ section,
.deco-kome-l ~ p,
.deco-kome-r ~ div,
.deco-kome-r ~ section,
.deco-kome-r ~ p {
 position: inherit;
 z-index: 3;
}

.deco-kome-l {
 left: 0;
 background-image: url(../_image/common/kome-left.webp);
}

.deco-kome-r {
 right: 0;
 background-image: url(../_image/common/kome-right.webp);
}


@media only screen and (max-width:640px) {

 .deco-kome-l,
 .deco-kome-r {
  width: 40vw;
  height: 40vw;
 }
}



/* --------------------------------------------

ボタン

---------------------------------------------- */
.btn {
 position: relative;
 z-index: 3;
 background-color: #F36200;
 transition: 0.2s;
}

.btn-def {
 display: inline-block;
 width: 16em;
 margin: 0 12px;
 padding: 1.2em;
 color: #fff;
 text-align: center;
 border-radius: 5em;
}

.btn:hover {
 background-color: rgb(250, 127, 44);
}

.btn-p {
 display: inline-block;
 width: 330px;
 padding-bottom: 15px;
 line-height: 150px;
 text-align: center;
 font-size: 1.8rem;
 font-weight: 600;
 background-image: url(../_image/common/btn.webp);
 background-repeat: no-repeat;
 background-size: 100% auto;
 background-position: center;
 background-color: rgba(243, 98, 0, 0);
}

.btn-p:hover {
 color: #F36200;
 background-color: rgba(243, 98, 0, 0);
}


.btn::after {
 content: "";
 display: inline-block;
 width: 1.4em;
 height: 1.4em;
 margin: -0.2em 0 0 0.5em;
 vertical-align: middle;
 background-image: url(../_image/common/icon-arrow.svg);
 background-repeat: no-repeat;
 background-size: 100%;
}

.btn-text {
 background-color: rgba(243, 98, 0, 0);
}

.btn-text::after {
 display: none;
}

.btn-text::before {
 content: "";
 display: inline-block;
 width: 1.4em;
 height: 1.4em;
 margin: -0.2em 0.5em 0 0;
 vertical-align: middle;
 background-image: url(../_image/common/icon-arrow.svg);
 background-repeat: no-repeat;
 background-size: 100%;
}

.btn-text:hover {
 color: #F36200;
 background-color: rgba(243, 98, 0, 0);
}


.btn span {}


@media only screen and (max-width:640px) {
 .btn-p {
  width: calc(330px * 1.2);
  line-height: calc(150px * 1.2);
  font-size: 1.6rem;
 }
}




/* --------------------------------------------

下層ページ共通　ヘッダー

---------------------------------------------- */
.pageHeader {
 position: relative;
}

.pageHeader figure {
 overflow: hidden;
}


.pageHeader h1 {
 position: absolute;
 top: 45.5%;
 left: 14.7%;
}

.pageHeader h1 em {
 font-size: 6rem;
 font-weight: 500;
 letter-spacing: 0.2em;
 color: #F36200;
}

.pageHeader h1 p {
 font-size: 1.8rem;
 font-weight: 700;
 letter-spacing: 0.2em;
 line-height: 1.1;
 text-align: center;
}

.pageHeader-text {
 margin: 342px 0 92px;
}

.pageHeader-text h1 {
 position: relative;
 top: 0;
 left: 0;
 text-align: center;
}

.pageHeader-text h1 em {
 text-align: center;
}



@media only screen and (max-width:640px) {
 .pageHeader {
  padding-top: 96px;
  height: 114vw;
 }

 .pageHeader figure {
  height: 67vw;
 }

 .pageHeader figure img {
  height: 100%;
  object-fit: cover;
 }

 .pageHeader h1 {
  width: 100%;
  top: 80%;
  left: 0%;
  text-align: center;
 }

 .pageHeader h1 em {
  font-size: 4.6rem;
 }

 .pageHeader h1 p {
  font-size: 1.6rem;
 }

 .pageHeader-text {
  height: 32vw;
  margin: 128px 0 92px;
 }

 .pageHeader-text h1 {
  top: 0;
  left: 0;
 }
}






/* --------------------------------------------

お知らせ

---------------------------------------------- */
.onlineshopLink {
 width: 88%;
 max-width: 1080px;
 margin: 136px auto;
 padding: 32px 5% 48px;
 background-image: url(../_image/common/onlneshop.jpg);
 background-position: center;
 background-repeat: no-repeat;
 background-size: cover;
 border-radius: 30px;
}

.onlineshopLink h2 {
 text-align: center;
 line-height: 2.4;
}

.onlineshopLink h2 .ff-en {
 font-size: 1.6rem;
 letter-spacing: 0.15em;
 color: #F36200;
}

.onlineshopLink h2 em {
 font-size: 2.2rem;
 font-weight: 700;
}

.onlineshopLink div {
 margin: 32px 0 0;
 justify-content: center;
}

.onlineshopLink div a {}

@media only screen and (max-width:640px) {
 .onlineshopLink {
  padding: 32px 5% 48px;
  background-position: center right 15%;
 }

 .onlineshopLink h2 {}

 .onlineshopLink h2 .ff-en {}

 .onlineshopLink h2 em {}

 .onlineshopLink div {}

 .onlineshopLink div a {
  margin: 12px;
 }
}



/* --------------------------------------------

Google reCAPTCHA

---------------------------------------------- */
.grecaptcha-badge {
 visibility: hidden;
}

.gRecaptcha {
 font-size: 1.0rem;
 text-align: center;
 opacity: 0.4;
}



/* --------------------------------------------

校正用　制作中ページ

---------------------------------------------- */
.pendPagesBody {
 height: 100vh;
 background: #000;
}

.pendPagesBody #wrap::before,
.pendPagesBody #wrap::after {
 display: none!important;
}

/*html,body {
 background-image: url(../_00/mockup.jpg);
 background-size: 1780px;
 background-position: top center;
 background-repeat: no-repeat;
 background-color: #fff;
 }*/

.pendPages {
 position: fixed;
 z-index: 1;
 top: 150px;
 right: 10%;
 width: 80%;
 font-size: 1.8rem;
 color: red;
 font-weight: 500;
 line-height: 50px;
 color: #fff;
 text-align: center;
 border: 2px solid #fff;
 background: rgba(255, 0, 0, 0.65);
 z-index: 10;
}

.pendImageWrap {
 position: relative;
 left: 50%;
 width: 1366px;
 height: 760px;
 top: 65px;
 margin-left: calc(-1366px / 2);
 margin-bottom: 150px;
 overflow: scroll;
 overflow-y: scroll;
}

.pendImage {
 display: block;
 /*position: relative;
 left: 50%;
 width: 1366px;
 margin-left: calc(-1366px / 2);*/
}

.pendImage img {}

@media only screen and (max-width:640px) {
 .pendImage {
  /*width: 120vw;
  margin-left: -60vw;*/
 }
}
