@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap');


div.youtube { position: relative; width: 100%; padding-top: 56.25%; }
div.youtube iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }

#globalMenuSp { display: none; }
nav { display: block; }

body { font-family: "Noto Serif JP", serif; font-weight:200; background: url("../img/comon-background.jpg")top center; color: #4a3100; line-height: 300%; }

a { color:#034b9f; text-decoration:underline; }
a:hover { color:#000; text-decoration:none; }

/* ベースレイアウト定義 */

section,header,footer { width:100%; max-width: 1100px; margin:0 auto; padding: 40px 20px; overflow:hidden; position: relative; }

header { /*margin-top: 20px;*/ padding: 30px 20px; }
header #logo { float: left; }
header nav { float: right; }
header nav { writing-mode:vertical-rl; -ms-writing-mode: tb-rl; letter-spacing: 2px; }
header nav ul li { margin: 0 0 0 10px; }
header a { color: #4a3100; text-decoration: none; }
header a:hover { color: #b49b6a; text-decoration: none; }

header span { font-size: 50%; line-height: normal; display: inline-block; margin-top: 10px; }

.tate { writing-mode:vertical-rl; -ms-writing-mode: tb-rl; text-align: left; letter-spacing: 1px; }
.text-combine { text-combine-upright: all; -webkit-text-combine: horizontal; -ms-text-combine-horizontal: all; }

/* タイトル定義 */

.text-title { font-size: 150%; font-weight: bold; margin-left: 40px; display:block; letter-spacing: 4px; }
.text-large { font-size: 150%; letter-spacing: 4px; }
.text-normal { font-size: 120%; letter-spacing: 2px; }
.text-small { font-size: 85%; letter-spacing: 0; }
.text-small-sec { font-size: 65%; letter-spacing: 0; }



/* ボタン定義 */




/* ページ個別設定 */

header div#logo img { width: 100%; max-width: 310px; margin-top: 30px; }
#main-image { height: 486px/*676px*/; text-align: center; position: relative; z-index: 1; background-size: cover; }
#main-imae-copy { color: #fff; font-weight: 600; font-size: 200%; letter-spacing: 10px; text-shadow: 0 0 10px #333; width:100%; max-width: 1200px; margin:0 auto; padding: 350px 20px 0; text-align: left; }

#message { background: url("../img/background-01.png") no-repeat left bottom 20px; max-width: 1200px; }
#message div.titlebox { background: url("../img/title-back-01.png")no-repeat top right; padding: 93px 33px; letter-spacing: 2px; }
#message div.under { text-align: right; padding-bottom: 20px; }
#message img { max-width: 100%; display: block; margin: 0 5%; }

#product { width: 627px; }
#product div.titlebox { background: url("../img/title-back-02.png")no-repeat top right; padding: 93px 26px; width: 100%; margin: 0 auto; letter-spacing: 2px; }

#product-box-A { overflow: hidden; }
#product-box-A img { display: block; width: 80%; float: right; }
#product-box-A .title { float: right; padding-right: 40px; }
#product-box-A .text-title { border-left: 1px solid #b49b6a; margin-left: 0; display: block; height: -moz-fit-content; }

#product-box-B .text-title { float: right; margin: 0; font-weight: normal; }
#product-box-B img { display: inline-block; width: 85%; }
#product-box-B div { width: 44%; display: block; /*border: 1px solid #b49b6a;*/ margin: 20px; overflow: hidden; float: right; }

#product-box-C { overflow: hidden; }
#product-box-C img { display: block; width: 100%; float: right; }
#product-box-C .title-01 { position: absolute; right: 0; bottom: 20px; }
#product-box-C .title-02 { position: absolute; top: 0; left: 35%; }
#product-box-C .text-title { border-left: 1px solid #b49b6a; margin-left: 0; display: block; height: -moz-fit-content; font-weight: normal; }

#product-box-D img { display: block; width: 55%; float: right; }
#product-box-D .text-title { border-left: 1px solid #b49b6a; margin-left: 0; display: block; height: -moz-fit-content; font-weight: normal; }
#product-box-D p { display: block; border: 1px solid #b49b6a; padding: 10px 0; font-size: 150%; margin-left: 30px; }
#product-box-D .tate { float: right; padding-right: 40px; font-weight: normal; }

#product-box-E .text-title { float: right; margin: 0; font-weight: normal; }
#product-box-E img { display: inline-block; width: 90%; float: right; }
#product-box-E div { width: 100%; display: block; /*border: 1px solid #b49b6a;*/ margin: 20px 0 20px 0; overflow: hidden; float: right; }

#product-box-F { text-align: center; }
#product-box-F div.line { width:300px; height: 10px; margin: 0 auto; background-color: #bac6d5; }
#product-box-F div { margin: 20px auto 0; width: 50px; }
#product-box-F p { display: block; border: 1px solid #b49b6a; padding: 10px 0; font-size: 150%; margin: 0 auto; }

#product-box-G .text-title { float: right; margin: 0; font-weight: normal; }
#product-box-G img { display: inline-block; width: 85%; }
#product-box-G div.a { width: 50%; display: block; /*border: 1px solid #b49b6a;*/ margin: 20px; overflow: hidden; float: right; }
#product-box-G div.b { width: 40%; display: block; /*border: 1px solid #b49b6a;*/ margin: 20px; overflow: hidden; float: right; }


#product-box-H { overflow: hidden; }
#product-box-H img { display: block; width: 100%; float: right; }
#product-box-H .title-01 { position: absolute; right: 40px; top: 20px; }
#product-box-H .title-02 { position: absolute; top: 20px; left: 41%; }
#product-box-H .title-03 { position: absolute; right: 40px; bottom: 40%; }
#product-box-H .text-title { margin-left: 0; display: block; height: -moz-fit-content; font-weight: normal; }

#product-box-I { max-width: 1000px; background: url("../img/background-02.png") no-repeat left bottom 0px; }
#product-box-I div { border-top: 1px solid #000; padding: 40px 40px 179px 40px; color: #333; line-height: 180%; }
#product-box-I div span.text-large { display: block; }
#product-box-I div p { padding: 0 37px 37px 37px; }
#product-box-I img { float: right; width: 30%; padding-left: 20px; }

#work div.titlebox:first-child { background: url("../img/title-back-03.png")no-repeat top right; padding: 93px 33px; width: 91.5%;
height: 100%;
max-height: 700px; }
#work div.titlebox { background: none; padding: 93px 102px 0 0; letter-spacing: 2px; float: right; margin-top: 20px; clear: both; line-height: 180%; }
#work div p { display: block; background: url("../img/background-04.png")no-repeat; background-size: contain; color: #fff; padding-top: 20px; font-size: 120%; margin: -10px 0 0 20px; line-height: 300%; }
#work img { max-width: 60%; display: block; margin: 104px 5% 0; float: left; }

#product-box-K div { margin: 20px auto 0; width: 50px; }
#product-box-K div img { width: 100%; }
#product-box-K p { display: block; border: 1px solid #b49b6a; padding: 10px 0; font-size: 150%; margin: 0 auto; }

#product-box-L { background: url("../img/background-03.png") no-repeat left bottom 20px; padding: 30px 181px 285px 0; }
#product-box-L img { display: block; width: 40%; float: right; }
#product-box-L .text-title { border-left: 1px solid #b49b6a; margin-left: 0; display: block; height: -moz-fit-content; font-weight: normal; }
#product-box-L p { display: block; border: 1px solid #b49b6a; padding: 10px 0; font-size: 150%; margin-left: 30px; }
#product-box-L .tate { float: right; padding-right: 40px; font-weight: normal; }

#original .title { font-size: 180%; border-left:1px solid #b49b6a; border-right:1px solid #b49b6a; text-align: center; width:510px; margin: 0 auto;}
#original p { width: 33%; margin: 60px 0.5% 0; height: 140px; border: 1px solid #b49b6a; vertical-align: middle; text-align: center; line-height: 180%; padding: 30px 20px 20px 20px; }
#original a { color: #4a3100; text-decoration: none; }
#original a:hover { color: #b49b6a; text-decoration: underline; }
#original .box { display: flex; align-items: center; justify-content: center; }

#link .title { font-size: 180%; border-left:1px solid #b49b6a; border-right:1px solid #b49b6a; text-align: center; width:300px; margin: 0 auto;}
#link p { width: 33%; margin: 60px 0.5% 0; height: 140px; border: 1px solid #b49b6a; vertical-align: middle; text-align: center; line-height: 180%; padding: 20px; }
#link a { color: #4a3100; text-decoration: none; }
#link a:hover { color: #b49b6a; text-decoration: underline; }
#link .box { display: flex; align-items: center; justify-content: center; }

#about { font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif"; max-width: 1000px; }
#about div { float: left; color: #fff; font-size: 150%; width: 200px; background-color: #627c8e; text-align: center; margin-right: 40px; clear: both; padding-top: 8px; }
#about ul { float: left; }
#about ul li { float: left; }
#about ul li.box-A { white-space: nowrap; margin-right: 20px; clear: both; }
#about ul li.box-B {  }
#about ul li.box-C { clear: both; }

#contact .title { font-size: 180%; border-left:1px solid #b49b6a; border-right:1px solid #b49b6a; text-align: center; width:300px; margin: 0 auto;}
#contact a { display: block; margin: 0 auto; border: 1px solid #b49b6a; width: 500px; padding: 10px; text-align: center; }
#contact a { color: #4a3100; text-decoration: none; }
#contact a:hover { color: #b49b6a; text-decoration: underline; }

#form input.txtmode3 { width:150px; }
#form input.txtmode4 { width:50%; display:block; margin:0 0 0 0; }
#form input,textarea { margin: 0px 2px 20px 2px; width: 99%; -webkit-appearance: none; border:1px solid #b1b1b1; background-color:#fff; border-radius:0px; font-size:100%; padding:17px 20px; -webkit-box-sizing:border-box; box-sizing:border-box; }
#form input:focus { border:solid 1px #EEA34A; }
#form textarea:focus { border:solid 1px #EEA34A; }
#form p { font-size:120%; font-weight:normal; color:#392a0b; overflow:visible; text-align:left; margin: 0 0 20px 0; }
#form p span { padding:2px; border:1px solid #e56830; margin-left:15px; color:#e56830; font-size:75%; }
#form p span.placeholder { padding:2px; border:none; margin-left:15px; color:#999; font-size:75%; }

#form input.cpform_btn { margin:30px auto 0; display: block; width: 320px; padding: 0.8em; text-align: center; text-decoration: none; color: #009640; border: 2px solid #009640; border-radius: 30px; transition: .4s; line-height:200%; }
#form input.cpform_btn:hover { background:#009640; color:#fff; }
input.cpform_btn { margin:30px auto 0; display: block; width: 320px; padding: 0.8em; text-align: center; text-decoration: none; color: #009640; border: 2px solid #009640; border-radius: 30px; transition: .4s; line-height:200%; }
input.cpform_btn:hover { background:#009640; color:#fff; }

input.cpform_btn_ore { margin:30px auto 0; display: block; width: 320px; padding: 0.8em; text-align: center; text-decoration: none; color: #eaa511; border: 2px solid #eaa511; border-radius: 30px; transition: .4s; line-height:200%; }
input.cpform_btn_ore:hover { background:#eaa511; color:#fff; }
#form input.cpform_btn_red { margin:30px auto 0; display: block; width: 320px; padding: 0.8em; text-align: center; text-decoration: none; color: #ff0000; border: 2px solid #ff0000; border-radius: 30px; transition: .4s; line-height:200%; }
#form input.cpform_btn_red:hover { background:#ff0000; color:#fff; }

input.cpform_btn_red { margin:30px auto 0; display: block; width: 320px; padding: 0.8em; text-align: center; text-decoration: none; color: #ff0000; border: 2px solid #ff0000; border-radius: 30px; transition: .4s; line-height:200%; }
input.cpform_btn_red:hover { background:#ff0000; color:#fff; }

form { width: 100%; max-width: 700px; display: block; margin: 0 auto; }
form table { width: 100%; display: block; margin: 0 auto; }
form td { padding: 20px; width:30%; }
form td:last-child { width: 70%; }

p.thanks-box { display: block; width: 100%; max-width: 700px; margin: 40px auto; }

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



.button{
  position: fixed;
  right: 30px;
  bottom: 40%;
  color: #fff;
  background: #4a3100;
  padding: 10px;
  cursor: pointer;
  transition: .3s;
  font-size: 100%;
  
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
}

.button:hover { background: #b49b6a; }

/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}



@media screen and (orientation: portrait) {

#globalMenuSp {
　　position: fixed;
    z-index: 4;
    top: 0;
    left: 0;
    color: #000;
    text-align: center;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 100%;
    padding-top:-100px;
}

#globalMenuSp ul {
    background: rgba(0,73,122,0.65);
　　margin: 0 auto;
    padding: 0;
    width: 100%;
    display:inherit;
}

#globalMenuSp ul li {
    font-size: 3.0em;
    list-style-type: none;
    padding: 0;
    width: 100%;
    border-bottom: 1px dotted #fff;
}

/* 最後はラインを描かない */
#globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

#globalMenuSp ul li a {
    display: block;
    color: #fff;
    padding: 1em 0;
}

/* このクラスを、jQueryで付与・削除する */
#globalMenuSp.active {
    transform: translateY(0%);
}

/*ハンバーガー用CSS*/
.navToggle {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    right: 13px;
    top: 12px;
    width: 105px;
    height: 99px;
    cursor: pointer;
    z-index: 5;
    text-align: center;
}

.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 56px;
    border-bottom: solid 5px rgb(28, 92, 145);
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}

.navToggle span:nth-child(1) {
    top: 33px;
}

.navToggle span:nth-child(2) {
    top: 55px;
}

.navToggle span:nth-child(3) {
    top: 77px;
}

.navToggle span:nth-child(4) {
    border: none;
    color: #eee;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}

/*ハンバーガーメニュータップ後CSS*/
/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    border-bottom: solid 3px #eee;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    border-bottom: solid 3px #eee;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

#globalMenuSp { display: block; top:0; position: fixed; }
nav { display: none; }

}



