@charset "utf-8";

/*
Theme Name: genova_tpl
Theme URI: http://genova.co.jp/
Author: the Takahiro Sahashi
Author URI: http://pmen.net/
Description: genova template.
Version: 1.0
*/


/*!
 * normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css
 */

button,
hr,
input {
    overflow: visible
}

progress,
sub,
sup {
    vertical-align: baseline
}

[type=checkbox],
[type=radio],
legend {
    box-sizing: border-box;
    padding: 0
}

html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    box-sizing: content-box;
    height: 0
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: bolder
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
    outline: ButtonText dotted 1px
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    color: inherit;
    display: table;
    max-width: 100%;
    white-space: normal
}

textarea {
    overflow: auto
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

[hidden],
template {
    display: none
}


/*=============================================
  * reset by FC Dev
  *=============================================*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
main,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    outline: none;
    border: 0;
}

img {
    border: 0;
    /*	transform: translateZ(0);
     -moz-transform: translateZ(0);
     -webkit-transform: translateZ(0);*/
}

img,
input {
    vertical-align: middle;
}

h1,
h2,
h3,
h4,
h5,
h6,
address {
    margin: 0;
    padding: 0;
    font-style: normal;
    font-weight: normal;
    border: 0;
}

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

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

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

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

table,
caption,
th,
td {
    font-style: normal;
    font-weight: normal;
}

hr {
    margin: 0;
    padding: 0;
}

iframe {
    margin: 0;
    padding: 0;
    border: 0;
}

form,
fieldset,
input,
button,
select,
optgroup,
option,
textarea,
label,
legend {
    margin: 0;
    padding: 0;
    outline: none;
}

span,
em,
strong,
dfn,
code,
samp,
kbd,
var,
cite,
abbr,
acronym,
q,
br,
ins,
del,
a,
img,
object {
    margin: 0;
    padding: 0;
    font-style: normal;
    font-weight: inherit;
    border: 0;
}


/* =====================================
■BASE
===================================== */

html {
    font-size: 62.5%;
    overflow-x: hidden;
}

body {
    /* font-family: "ヒラギノ角ゴ W3 JIS2004", "Hiragino Kaku Gothic W3 JIS2004"; */
    font-weight: 400;
    font-size: 16px;
    background: #fff;
    color: #22201E;
    line-height: 32px;
    position: relative;
    -webkit-text-size-adjust: 100%;
    font-family: "Noto Sans JP", serif;
    letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
    body{
        font-size: 15px;
        line-height: 32px;
    }
}

body.home {
    /* font-family: 'Noto Sans JP', sans-serif; */
	
}

.fnt-noto {
    font-family: "Noto Sans JP", serif;
}

.fnt-manrope {
    font-family: "Manrope", sans-serif;
}

.fnt-zenkaku {
    font-family: "Zen Kaku Gothic New", sans-serif;
}

.fnt-zenold{
    font-family: "Zen Old Mincho", serif;
  }

.fnt-Prompt {
    font-family: 'Prompt', sans-serif;
}

.fnt-dnp-shuei-gothic-kin-std {
    font-family: dnp-shuei-gothic-kin-std, sans-serif;
    font-style: normal;
    font-weight: 400;
}

.fnt-hina{
  font-family: "Hina Mincho", serif;
  font-weight: 400;
  font-style: normal;
}


.fnt-reimin {
	font-family: 'a-otf-ud-reimin-pr6n';
	font-style: normal;
	font-weight: 500;	
}
.fnt-hiragino {
	font-family: 'hiragino-kaku-gothic';
	font-style: normal;
	font-weight: normal;
}


.hina-mincho-regular {
  font-family: "Hina Mincho", serif;
  font-weight: 400;
  font-style: normal;
}
.fnt-opt {
    font-family: 'Optima';
    font-style: normal;
    font-weight: normal; 
}


 @font-face {
    font-family: 'Optima';
    font-style: normal;
    font-weight: normal;
    src: local('Optima'), url('./font/Optima.woff') format('woff');
    }

    @font-face {
    font-family: 'Optima Medium';
    font-style: normal;
    font-weight: normal;
    src: local('Optima Medium'), url('./Optima Medium.woff') format('woff');
    }
    


@font-face {
    font-family: '';
    src: url('font/UDReiminPr6-Medium-AlphaNum.eot');
    src: url('font/UDReiminPr6-Medium-AlphaNum.eot?#iefix') format('embedded-opentype'),
        url('font/UDReiminPr6-Medium-AlphaNum.woff2') format('woff2'),
        url('font/UDReiminPr6-Medium-AlphaNum.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
   font-family: 'hiragino-kaku-gothic';
    src: url('font/HiraKakuStdN-W4-AlphaNum.eot');
    src: url('font/HiraKakuStdN-W4-AlphaNum.eot?#iefix') format('embedded-opentype'),
        url('font/HiraKakuStdN-W4-AlphaNum.woff2') format('woff2'),
        url('font/HiraKakuStdN-W4-AlphaNum.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}




a {
    text-decoration: none;
    color: #333;
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
}

a:focus,
*:focus {
    outline: none;
}

a[href^="tel:"] {
    pointer-events: none;
    cursor: text;
}

@media screen and (max-width: 767px) {
    body {
        /* font-size: 16px; */
        /* line-height: 32px; */
    }
    a[href^="tel:"] {
        pointer-events: auto;
        cursor: pointer;
    }
}


/* =====================================
■MODULE
===================================== */


/*--------------------------------------
汎用
--------------------------------------*/


/* float */

.fr {
    float: right !important;
}

.fl {
    float: left !important;
}


/* clears */

.clearfix {
    *zoom: 1;
}

.clearfix:after {
    content: "";
    display: table;
    clear: both;
}

.cl {
    clear: both !important;
}


/* text indent */

.textHide {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
}


/* text-align */

.tac {
    text-align: center !important;
}

.tar {
    text-align: right !important;
}

.tal {
    text-align: left !important;
}


/* font-weight */

.fb {
    font-weight: bold !important;
}

.h3-noimage {
    margin-top: 35px;
}


/*--------------------------------------
Icon fonts
--------------------------------------*/

@font-face {
    font-family: 'icomoon';
    src: url('img/fonts/icomoon.eot');
    src: url('img/fonts/icomoon.eot#iefix') format('embedded-opentype'), url('img/fonts/icomoon.ttf') format('truetype'), url('img/fonts/icomoon.woff') format('woff'), url('img/fonts/icomoon.svg#icomoon') format('svg');
    font-weight: normal;
    font-style: normal;
}

[class*='icon-']:not([class*='eicon-']):before {
    display: inline-block;
    font-family: 'icomoon';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    vertical-align: baseline;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.icon-blog:before {
    content: "\e900";
}

.icon-category:before {
    content: "\e901";
}

.icon-check:before {
    content: "\e902";
}

.icon-checked:before {
    content: "\e903";
}

.icon-down:before {
    content: "\e904";
}

.icon-facebook:before {
    content: "\e905";
}

.icon-google:before {
    content: "\e906";
}

.icon-line:before {
    content: "\e907";
}

.icon-twitter:before {
    content: "\e908";
}

.icon-arrow02:before {
    content: "\e909";
}

.icon-arrow01:before {
    content: "▶︎";
}

.icon-search:before {
    content: "\e911";
}

.icon-tag:before {
    content: "\e912";
}


/*--------------------------------------
Pc sp change
--------------------------------------*/

.sp {
    display: none !important;
}

.mb {
    display: none;
}

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

@media screen and (max-width: 480px) {
    .mb {
        display: block;
    }
    .pcm {
        display: none;
    }
}


/* =====================================
■Layout
===================================== */


/*--------------------------------------
container
--------------------------------------*/

.container {
    width: 100%;
    max-width: 1120px;
    padding: 0 20px;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
}

.container:after {
    content: "";
    display: block;
    clear: both;
}

.page-id-43 .elementor-section.elementor-section-boxed>.elementor-container {
    max-width: none !important;
    padding: 0;
}

@media (max-width: 767px) {
    .container {
        padding: 0 20px;
    }
}


/*--------------------------------------
header
--------------------------------------*/

#wrapper {
    height: 100%;
    box-sizing: border-box;
}

body:not(.page-id-43) #wrapper {
    padding-top: 105px;
}

@media screen and (max-width: 1060px) and (min-width: 768px) {
    body:not(.page-id-43) #wrapper {
        padding-top: 80px;
    }
}

@media screen and (max-width: 767px) {
    body:not(.page-id-43) #wrapper {
        padding-top: 62px;
    }
}

#header {
/*
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
    background-color: rgba(255, 255, 255, 0.69);
    font-family: 'Zen Old Mincho', serif;
    font-weight: 400;
*/

/*
    position: absolute;
    top: 0;
    right: 0;
    height: 100px;
    left: 0;
    z-index: 7;
*/
	transition: all .4s ease;

}




#header .wrap {
    max-width: 100%;
}

.fnt-hiragino {
    font-family: 'ヒラギノ明朝 W3 JIS2004', Hiragino Mincho W3 JIS2004, sans-serif;
}

.fnt-shueigo {
    font-family: dnp-shuei-gothic-kin-std, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.fnt-shueigoB {
    font-family: dnp-shuei-gothic-kin-std, sans-serif;
    font-weight: 600;
    font-style: normal;
}





/* gnav */

#header .header_menu {}

#header .header_menu .g_nav {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    padding: 0px 33px 0 0px;
}

#header .header_menu .g_nav>li {
    vertical-align: middle;
    margin-left: 37px;
    position: relative;
}

#header .header_menu .g_nav>li>a,
#header .header_menu .g_nav>li>span {
    display: flex;
    align-items: center;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    font-size: 16px;
    padding: 0;
    letter-spacing: 0.05em;
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
    position: relative;
    flex-direction: column;
    justify-content: center;
    color: #434548;
    font-weight: 600;
    line-height: 35px;
    font-family: "dnp-shuei-gothic-kin-std", sans-serif;
}

.home #header .header_menu .g_nav>li>span {
	/* color: #fff; */
}

body.home #header .header_menu .g_nav>li>a,
body.home #header .header_menu .g_nav>li>span {
    /* color: #64522B; */
    /* line-height: 82px; */
}

body.has-nav #header .header_menu .g_nav>li>a,
body.has-nav #header .header_menu .g_nav>li>span {
    /*	color: #fff;*/
}

#header .header_menu .g_nav>li>a:hover,
#header .header_menu .g_nav>li>span:hover {
    opacity: 0.7;
}

#header .header_menu .g_nav>li>a>span,
#header .header_menu .g_nav>li>span>span {
    display: block;
    margin: 0 auto;
}

body.home.has-nav #header .header_menu .g_nav>li>a,
body.home.has-nav #header .header_menu .g_nav>li>span {
    /* color: #64522B; */
}

body.has-nav #header .header_menu .g_nav>li.active>a,
body.has-nav #header .header_menu .g_nav>li>a:hover {
    /*	color: #E0D3BD;*/
}




#header .header_menu .g_nav>li.active>a,
#header .header_menu .g_nav>li>a:hover {
    /* color: #22201E; */
}

body.has-nav #header .header_menu .g_nav>li.active>a,
body.has-nav #header .header_menu .g_nav>li>a:hover {
    /* color: #22201E; */
    opacity: .7;
}

body.has-nav #header .header_menu .g_nav>li>a,
body.has-nav #header .header_menu .g_nav>li>span {
	/* color: #22201E; */
}


.home #header .header_menu .g_nav>li.active>a,
.home #header .header_menu .g_nav>li>a:hover {
    /* color: #22201E; */
}


#header .header_menu .g_nav>li>a sub,
#header .header_menu .g_nav>li>span sub {
    /* font-size: 10px; */
    /* line-height: 1.2; */
    display: block;
    letter-spacing: 0.1em;
    /* padding-top: 10px; */
}

#header .header_menu .g_nav>li>span:hover+dl,
#header .header_menu .g_nav>li>span ul:hover {
    pointer-events: auto;
    filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
}

#header .header_menu .g_nav>li>span:hover {
    position: relative;
}

#header .header_menu .g_nav>li dl {
    pointer-events: none;
    position: absolute;
    top: 90%;
    right: 0;
    display: block;
    width: 250px;
    padding: 16px 30px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-color: #7B7A68;
    /* border-radius: 15px; */
    -moz-transition-duration: 0.6s;
    -o-transition-duration: 0.6s;
    -webkit-transition-duration: 0.6s;
    transition-duration: 0.6s;
    filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=0);
    /* opacity: 0; */
    opacity: 0;
    z-index: 99;
    left: 0;
    margin-left: -100px;
}

#header .header_menu .g_nav>li dl::before {
    /* content: ""; */
    position: absolute;
    top: -10px;
    left: 50%;
    margin-left: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 30px 30px 30px;
    border-color: transparent transparent #7B7A68 transparent;

}

#header .header_menu .g_nav>li dl dt {
    max-width: 1080px;
    margin: 0 auto 10px;
    font-size: 20px;
    line-height: 1.2;
    display: none;
}

#header .header_menu .g_nav>li dl ul {
    max-width: 1080px;
    margin: 0 auto;
    text-align: left;
}

#header .header_menu .g_nav>li dl li {
    display: block;
    margin-right: 0;
    line-height: 1.3;
    position: relative;
    font-size: 18px;
    padding: 15px 0;
    border-bottom: 1px solid #B2C1C3;
}

#header .header_menu .g_nav>li dl li:before {
    color: #00a0da;
    font-size: 14px;
    margin-right: 8px;
}

#header .header_menu .g_nav>li dl li:last-child {
    margin-right: 0;
}

#header .header_menu .g_nav>li dl li a {
    color: #fff;
    vertical-align: top;
}

#header .header_menu .g_nav>li dl a:hover {
    /* opacity: 1; */
    /* color: #E0D3BD; */
}

#header .header_menu .g_nav>li dl:hover {
    pointer-events: auto;
    filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
}

@media screen and (min-width: 768px) {
    #header .header_menu .g_nav>li dl {
        pointer-events: none;
    }
}

.cameraContent.cameracurrent {
    z-index: 9;
}

@media screen and (max-width: 1500px) {
    #header .header_logo {

    left: 20px;
    }
    body.home #header .header_logo {
    }
    #header .header_menu .g_nav {
        padding-top: 0px;
    }
    #header .header_menu .g_nav>li {
        margin-left: 42px;
    }
}

@media screen and (max-width: 1400px) {
    #header .header_menu .g_nav>li>a,
    #header .header_menu .g_nav>li>span {
        font-size: 18px;
    }
}

@media screen and (max-width: 1200px) {
    #header .header_logo {

    }
    body.home #header .header_logo {
    }
    #header .header_menu .g_nav>li>a,
    #header .header_menu .g_nav>li>span {
  
    }
    #header .header_menu .g_nav {
        padding-right: 0px;
    }
    #header .header_menu .g_nav>li {
    }
    #header .header_menu .g_nav>li dl {
        width: 250px;
        padding: 15px 20px;
        margin-left: -100px;
    }
}

@media screen and (max-width: 1100px) {
    #header .header_menu .g_nav>li>a,
    #header .header_menu .g_nav>li>span {
    }
    #header .header_menu .g_nav>li {
        /* margin-left: 15px; */
    }
    #header .header_menu .g_nav>li dl {
        padding: 10px 30px;
    }
    #header .header_menu .g_nav>li dl li a {
        font-size: 13px;
    }
    #header .header_menu .g_nav>li dl ul {
        text-align: left;
    }
    #header .header_menu .g_nav>li dl li {
        padding: 10px 0 5px;
    }
    #header .header_menu .g_nav>li dl {
        padding: 10px 20px 20px;
    }
}

@media screen and (max-width: 999px) {
    #header .header_menu .g_nav {
    padding: 0px 0px 0 0px;
}
#header .header_menu .g_nav>li {
	margin-left: 25px;
}

#header .header_menu .g_nav>li>a, #header .header_menu .g_nav>li>span {
	font-size: 15px;
}
.home #header .header_menu {
	/* top: 50px; */
}
	#header .header_logo,
    body.home #header .header_logo {
        /* left: 70px; */
		max-width: 175px;
    }
    body.home.has-nav #header .header_logo {
        left: 30px;
    }
    body.home #header .header_menu {
        /* right: 80px; */
		/* top: 50px!important; */
    }
    body.home.has-nav #header .header_menu {
        /* right: 50px; */
		/* top: 0!important; */
    }
    
}

@media screen and (max-width: 767px) {
    #header {
		position: fixed;
		top: 0;
		right: 0;
		left: 0;
		z-index: 999;
		transition: all .4s ease;
		}
	.home #header {
	}
	.has-nav.home #header {
	}
	
	
	
    /* logo */
    body.home #header .header_logo,
    #header .header_logo {
        /* width: 45%; */
        margin: 0;
        /* top: 20px!important; */
        /* left: 20px; */
        /* max-width: 180px!important; */
    }
    body.home #header .header_logo{
        /* top: 35px!important; */
        /* left: 35px!important; */
    }
    #header .header_logo img {
        width: 100%;
        max-width: 100%;
    }
    #header .header_logo a:hover {
        text-decoration: none;
    }
    #header .toggleMenu {
        display: block;
    }
    .toggleMenu {
        width: 74px;
        height: 74px;

        text-align: left;
        color: #fff;
        cursor: pointer;
        position: fixed;
        top: 0px;
        right: 0px;
        z-index: 9999;
        padding: 15px;
    }
    .toggleMenu {
        top: 0px;
        right: 0px;
        padding: 0px;
    }
    .toggleMenu.active{
        top: 0px;
        right: 0px;
        /* width: 60px; */
        /* height: 60px; */
    }
    .has-nav .toggleMenu {
        position: fixed;
        background: none;
        /* top: 0px; */
        /* right: 0px; */
    }
    .home .toggleMenu {
        /* background: #fff; */
    }
    .toggleMenu .menu-trigger {
        display: block;
        background: url('./img/ham.png') center/cover;
    }
    .toggleMenu.active .menu-trigger {
        background: url('./img/ham_on.png') center/cover;
    }
    .menu-trigger,
    .menu-trigger span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    .menu-trigger {
        position: relative;
        width: 74px;
        height: 60px;
        margin: 0;
    }
    .toggleMenu.active .menu-trigger{
        width: 74px;
        height: 60px;
    }
    .menu-trigger span:nth-of-type(1) {
        top: 0;
    }
    .menu-trigger span:nth-of-type(2) {
        top: 10px;
    }
    .menu-trigger span:nth-of-type(3) {
        bottom: 0;
    }
    .toggleMenu.active .menu-trigger span:nth-of-type(1) {
        -webkit-transform: translateY(10px) rotate(-45deg);
        transform: translateY(10px) rotate(-45deg);
    }
    .toggleMenu.active .menu-trigger span:nth-of-type(2) {
        opacity: 0;
    }
    .toggleMenu.active .menu-trigger span:nth-of-type(3) {
        -webkit-transform: translateY(-10px) rotate(45deg);
        transform: translateY(-10px) rotate(45deg);
    }
    #header .right_box,
    #header .g_nav {
        display: none;
    }
    #header .header_menu {
        top: 0!important;
        right: -100%!important;
        bottom: 0;
        opacity: 0;
        visibility: hidden;
        transition: all 0.2s ease;
        overflow: auto;
        padding-bottom: 0px;
        background: #fff;
        z-index: 998;
        width: 100%;
        /* min-height: 100vh; */
    }
    #header .header_menu .mn-inside {
        /* padding: 0 20px 20vw; */
    }
body.home #header .header_menu {
	top: 0!important;
}
	
	.nav-Opened #header .header_menu {
		opacity: 1;
		visibility: visible;
		right: 0px!important;
	}
	.contact-g .brand-o {
		padding-bottom: 20vw;
	}
	
    #header .btnmenu {
        margin: 0 auto 5px;
        width: 75vw;
        text-align: center;
    }
    #header .header_menu .ttl {
        text-align: center;
        margin-top: 20px;
        font-size: 20px;
        color: #FFFFFF;
    }
    .toggleMenu.active+.header_menu {
        opacity: 1 !important;
        visibility: visible !important;
    }
    #header .header_menu .g_nav {
        display: block;
        text-align: center;
    }
    #header .header_menu .g_nav {
        padding: 80px 50px 9vw;
    }
    #header .header_menu .g_nav>li {
        position: relative;
        border-left: none;
        margin-left: 0;
        border-bottom: 1px solid #A3A3A3;
    }
    #header .header_menu .g_nav>li+li {}
    #header .header_menu .g_nav>li>a,
    #header .header_menu .g_nav>li>span {
        width: 100%;
        padding: 17px 0 10px;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        display: block;
        text-align: left;
        height: auto;
        color: #64522B;
        font-size: 18px;
        letter-spacing: 0.05em;
        font-weight: 400;
        line-height: 34px;
    }
    #header .header_menu .g_nav>li dl::before {
        display: none;
    }
    #header .header_menu .g_nav>li dl {
        margin-left: 0;
    }
    #header .header_menu .g_nav>li dl li:last-child {
        border-bottom: none;
    }
    body.has-nav #header .header_menu .g_nav>li>a,
    body.has-nav #header .header_menu .g_nav>li>span {
        color: #64522B;
    }
    #header .header_menu .g_nav>li>a span,
    #header .header_menu .g_nav>li>span span {
        margin: 0;
        transition: all .5s ease;
    }
    #header .header_menu .g_nav>li:first-child {
    }
    /* #header .header_menu .g_nav > li:first-child a sub {
		font-size: 17px;
		padding-left: 30px;
		display: block;
		margin: 0;
	} */
    #header .header_menu .g_nav>li:first-child a span {
        padding-top: 0;
    }
    #header .header_menu .g_nav>li:first-child a:before {
        top: 23px;
        left: 20px;
        margin-left: 0;
    }
    #header .header_menu .g_nav>li>a:hover,
    #header .header_menu .g_nav>li>span:hover,
    #header .header_menu .g_nav>li.active>a {
        background: transparent;
        color: #E0D3BD;
        padding-left: 0;
    }
    body.home #header .header_menu .g_nav>li>a,
    body.home #header .header_menu .g_nav>li>span {
        color: #64522B;
        line-height: 30px;
    }
    body.home #header .header_menu .g_nav>li.active>a,
    body.home #header .header_menu .g_nav>li>a:hover {
        color: #9CC4A7;
    }
    body.home.has-nav #header .header_menu .g_nav>li>a,
    body.home.has-nav #header .header_menu .g_nav>li>span {
        color: #64522B;
    }
    body.home.has-nav #header .header_menu .g_nav>li.active>a,
    body.home.has-nav #header .header_menu .g_nav>li>a:hover {
        color: #E0D3BD;
    }
    #header .header_menu .g_nav>li>span:after {
        content: "";
        position: absolute;
        top: 50%;
        right: 20px;
        width: 14px;
        height: 14px;
        color: #fff;
        transform: translateY(-50%);
        background: url('./img/arrow_menu.png') center/cover;
    }
    #header .header_menu .g_nav>li.hover>span:after {
        
        transform: translateY(-50%) rotate(180deg);
        margin-top: 0;
        color: #E0D3BD;
        background-image: url('./img/arrow_menu_on.png');
        height: 2px;
        /* right: 11px; */
    }
    #header .header_menu .g_nav>li>a sub,
    #header .header_menu .g_nav>li>span sub {
        /* margin: -2px 0 0 8px; */
        vertical-align: middle;
        bottom: 0;
        color: #fff;
        padding-top: 0;
        /* font-size: 12px; */
        /* display: none; */
    }
    #header .header_menu .g_nav>li dl {
        position: relative;
        top: 0;
        background: none;
        padding: 0;
        width: 100%;
    }
    #header .header_menu .g_nav>li dl li:before {
        /* display: none; */
    }
    #header .header_menu .g_nav>li dl li {
        padding-left: 0;
    }
    #header .header_menu .g_nav>li dt {
        display: none;
    }
    #header .header_menu .g_nav>li ul {
        position: inherit;
        display: none;
        top: 0;
        padding: 0;
    }
    #header .header_menu .g_nav>li ul li {
        display: block;
        margin-right: 0;
        border-top: 1px solid #fff;
        padding: 0;
    }
    #header .header_menu .g_nav>li ul li a {
        position: relative;
        display: block;
        padding: 12px 0 12px 30px;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        text-align: left;
        font-size: 18px;
        font-weight: 400;
        color: #3D4E50;
    }
    #header .header_menu .g_nav>li dl a:hover {
        color: #333;
    }
    #header .header_menu .g_nav>li ul li a:hover {
        text-decoration: none;
        background: #ddd;
        /*    color: #fff;*/
    }
    #header .header_menu .g_nav>li.hover ul {
        display: block;
        filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
        opacity: 1;
    }
    /*スマホ時サブメニューが消える現象を回避*/
    #header .header_menu .g_nav>li>span {
        position: relative;
    }
    #header .header_menu .g_nav>li.hover>span+dl,
    #header .header_menu .g_nav>li>span:hover+dl {
        pointer-events: auto;
        opacity: 1;
    }
    #header .block-bot li {
        width: 220px;
        margin: 0 auto 25px;
        line-height: 1;
    }
    body.home.has-nav #header .toggleMenu {
        /* position: fixed; */
        /* background: none; */
        /* top: 5px; */
        /* right: 10px; */
    }
    body.home.has-nav #header .header_logo {
        top: 15px!important;
        left: 20px;
    }

    .has-nav #header::before {
        height: 70px;
    }
    .nav-Opened .toggleMenu {
        background: none;
    }
    
    
    
    
}

@media screen and (max-width: 480px) {}


/*--------------------------------------
SIDE
--------------------------------------*/

#sidebar {
    display: none;
}


/*--------------------------------------
FOOTER
--------------------------------------*/

#footer {
    background: #fff;
    background-size: cover;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0.05em;
    padding: 66px 20px;
    font-family: 'hiragino-kaku-gothic';
    font-weight: 400;
}


#footer .logo {
		max-width: 277px;
		margin-bottom: 14px;
	}
#footer .logo img {
    width: 100%;
    height: auto;
}

#footer .info {
		line-height: 24px;
		margin-bottom: 17px;
		    font-weight: normal;
	}
#footer .sitemaplink {
		font-size: 12px;
	}

#footer .sitemaplink a:hover {
    text-decoration: underline;
}

#footer p {
    margin-bottom: 0;
}
#footer .copy {
	position: absolute;
	font-size: 12px;
	right: 0;
	bottom: 0;
}


#footer .container {
    position: relative;
}







@media(max-width: 767px) {
	#footer {
		padding: 15vw 6vw 25vw;
	}

#footer .logo {
		margin-bottom: 5vw;
	}
	
#footer .copy {
	position: relative;
	left: 0;
	right: auto;
}
	
#footer .info {
		margin-bottom: 13px;
	}

}


#wpfront-scroll-top-container {
    right: 20px !important;
    bottom: 60px !important;
}

#wpfront-scroll-top-container:hover img {
    opacity: 0.8 !important;
}

.sitemap_box {
    padding: 40px 0 32px;
}



.sitemap_box li a:hover {
    text-decoration: underline !important;
}

@media screen and (max-width: 767px) {
    

    .sitemap_box {
        padding: 30px 0 50px;
    }
    .sitemap_box li:last-child {
        padding-right: 0;
    }
    .sitemap_box li {
        float: none !important;
    }
    #wpfront-scroll-top-container {
        display: none !important;
    }
}

@media screen and (max-width: 480px) {

}

@media screen and (max-width: 400px) {

}

@keyframes anibg {
    from {
        background-position: 0 0;
    }
    to {
        background-position: -500vw 0;
    }
}






body.nav-Opened,
body.nav-Opened *,
body.nav-Opened *:hover,
body.nav-Opened *:focus,
body.nav-Opened *:active {
    touch-action: none !important;
    pointer-events: none !important;
}

body.nav-Opened .toggleMenu,
body.nav-Opened .header_menu,
body.nav-Opened .header_menu *,
body.nav-Opened .header_logo,
body.nav-Opened .header_logo * {
    touch-action: auto !important;
    pointer-events: visible !important;
}

body.nav-Opened {
    overflow: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: none !important;
    pointer-events: none !important;
}

body.nav-Opened .header_logo {}

body.nav-Opened #header:before {
    background: #FFFCF2;
}

#ft-fixed {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 996;
    width: 100%;
    opacity: 1;
    visibility: visible;
    transition: opacity .4s ease;
}

#ft-fixed ul {
    display: flex;
    flex-wrap: wrap;
}

#ft-fixed ul li {
    width: 33.333%;
}

#ft-fixed ul li img {
    width: 100%;
    height: auto;
}

.has-nav #ft-fixed {
    /*
	opacity: 1;
	visibility: visible;
*/
}

@media screen and (min-width: 767px) {
    #ft-fixed {
        display: block;
        width: 400px;
        left: auto;
        right: 0;
    }
}

#footer {

}


/*=============================================
 * ft_fixed_shared
 *=============================================*/

#ft_fixed {
    position: fixed;
    bottom: 0;
    right: 0;
    left: 0;
    transition: 0.2s;
    z-index: 999;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    /* background: #fff; */
    /* height: 50px; */
}

#ft_fixed li {
    /* width: 40.7%; */
}

#ft_fixed li:last-child {
    /* width: 18.6%;
    text-transform: uppercase;
    border: none; */
}

#ft_fixed a {
    /* box-sizing: border-box;
    display: flex;
    height: 100%;
    font-weight: 700;
    justify-content: center;
    align-items: center;
    font-size: 19px;
    background: none; */
}

#ft_fixed a:hover,
#ft_fixed a:focus,
#ft_fixed a:active,
#ft_fixed a:visited {
    opacity: 1 !important;
}

.btn-yellow {
    color: #000;
    background: #ffda2a;
}

.btn-green {
    color: #fff;
    background: #18aa90;
}


/*=============================================
 * hamburger
 *=============================================*/

.hamburger {
    color: #000;
    position: relative;
    height: 50px;
}

.hamburger:after {
    content: "menu";
    position: absolute;
    bottom: 1px;
    left: 0;
    width: 100%;
    text-align: center;
    letter-spacing: 0;
    font-size: 9px;
    font-weight: 700;
    line-height: 1.5;
}

.hamburger span,
.hamburger span:before,
.hamburger span:after {
    width: 39px;
    height: 3px;
    background: #03273b;
    border-radius: 5px;
}

.hamburger span {
    top: 19px;
    right: 0;
    left: 0;
    margin: auto;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.075s;
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger span:before,
.hamburger span:after {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    transition: 0.15s ease;
}

.hamburger span:before {
    top: -10px;
    transition: top 0.075s 0.12s ease, opacity 0.075s ease;
}

.hamburger span:after {
    bottom: -10px;
    transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.navOpen .hamburger:after {
    content: "close";
}

.navOpen .hamburger span,
.navOpen .hamburger span:before,
.navOpen .hamburger span:after {
    width: 28px;
}

.navOpen .hamburger span {
    transform: rotate(45deg);
    transition-delay: 0.12s;
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.navOpen .hamburger span:before {
    top: 0;
    opacity: 0;
    transition: top 0.075s ease, opacity 0.075s 0.12s ease;
    -webkit-transition: top 0.075s ease, opacity 0.075s 0.12s ease;
    -moz-transition: top 0.075s ease, opacity 0.075s 0.12s ease;
    -ms-transition: top 0.075s ease, opacity 0.075s 0.12s ease;
    -o-transition: top 0.075s ease, opacity 0.075s 0.12s ease;
}

.navOpen .hamburger span:after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

@media only screen and (min-width: 1200px) {
    #ft_fixed {
        display: none;
    }
}


/* iPhone X */

@media only screen and (min-device-width: 375px) and (min-device-height: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait) {
    #footer:after {
        background: #fff;
        content: '';
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 36px;
        z-index: 99;
    }
    #ft_fixed {
        bottom: calc(env(safe-area-inset-bottom) - 0px);
    }
    #pagetop {
        bottom: calc(env(safe-area-inset-bottom) + 90px);
    }
}


/* iPhone XR */

@media only screen and (min-device-width: 414px) and (min-device-height: 896px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
    #footer:after {
        background: #fff;
        content: '';
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 36px;
        z-index: 99;
    }
    #ft_fixed {
        bottom: calc(env(safe-area-inset-bottom) - 0px);
    }
    #pagetop {
        bottom: calc(env(safe-area-inset-bottom) + 90px);
    }
}


/* iPhone 11 */

@media only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 2),
only screen and (device-width: 375px) and (device-height: 812px) and (-webkit-device-pixel-ratio: 3),
only screen and (device-width: 414px) and (device-height: 896px) and (-webkit-device-pixel-ratio: 3) {
    #footer:after {
        background: #fff;
        content: '';
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 36px;
        z-index: 99;
    }
    #ft_fixed {
        bottom: calc(env(safe-area-inset-bottom) - 0px);
    }
    #pagetop {
        bottom: calc(env(safe-area-inset-bottom) + 90px);
    }
}

@media only screen and (min-width: 500px) {
    #footer:after {
        display: none !important;
    }
}



*:after, *:before {
	pointer-events: none;
}
.img-parallax {
	clip: rect(0, auto, auto, 0);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}
.object-fit-cover {
	position: relative;
}
.object-fit-cover img {
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100%;
	width: 100%;
}
ol {
	list-style: decimal;
	margin-left: 20px;
}
.txt_center, .txt-center {
	text-align: center;
}
.fnt-zen {
	font-family: 'Zen Old Mincho', serif;
}
/*=============================================
 * text vertical
 *=============================================*/
.bd_none {
	border: none !important;
}
/*================index==============*/
.txt-vertical {
	cursor: vertical-text;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	word-wrap: break-word;
}
.txt-vertical .txt-latin {
	cursor: vertical-text;
	direction: rtl;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: sideways-right;
	-o-text-orientation: sideways-right;
	-ms-text-orientation: upright;
	-ms-text-orientation: sideways-right;
	-moz-text-orientation: sideways-right;
	-webkit-text-orientation: sideways-right;
}

@media screen and (min-width: 768px) {
.txt-vertical1 {
	cursor: vertical-text;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	word-wrap: break-word;
}
.txt-vertical1 .txt-latin {
	cursor: vertical-text;
	direction: rtl;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: sideways-right;
	-o-text-orientation: sideways-right;
	-ms-text-orientation: upright;
	-ms-text-orientation: sideways-right;
	-moz-text-orientation: sideways-right;
	-webkit-text-orientation: sideways-right;
}
.object-fit-cover-pc {
	position: relative;
}
.object-fit-cover-pc img {
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100%;
	width: 100%;
}
}
.d_flex {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: wrap;
}
img {
	vertical-align: middle;
}
#wrapper {
	padding-top: 0 !important;
}


body #wrapper {

}
body #wrapper {
	position: relative;
}




.wrap {
	max-width: 1110px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
    box-sizing: border-box;
    padding: 0px 16px;
}
@media screen and (max-width: 767px) {
    .wrap{
        padding: 0px 20px;
    }
}
#main {
	position: relative;
	z-index: 2;
}



@media (min-height: 1500px) { 
	#main {
		min-height: 1237px;
	}
}















.footer-fixed{
    position: fixed;
    z-index: 99;
    bottom: 0px;
    right: 0px;
    width: auto;
    display: flex;
    flex-direction: column;

    align-items: flex-end;
}
.footer-fixed li{
    width: 80px;
    margin-top: 2px;
}


.footer-fixed img{
    min-height: 50px;
    object-fit: cover;
    width: 100%;    
}
@media screen and (min-width:768px) {
    .footer-fixed li:has(.btnTel):hover img{
        content: url('./img/btn_telfixed_on.jpg');
    }
    .footer-fixed li:has(.btnTel):hover {
        width: 330px;
    }
}
@media screen and (max-width: 767px) {
    .footer-fixed{
        display: flex;
        justify-content: space-between;
        flex-direction: row;
        left: 0px;
        right: 0;
        width: 100%;
    }
    .footer-fixed li{
        width: auto;
        margin: 0px;
    }

    /* .footer-fixed li:last-child{
        position: absolute;
        bottom: 80px;
        right: 3%;
        width: 25%;
    } */
    .footer-fixed img{
        min-height: unset;
    }
}
.btn-fixed{
    width: 133px;
    position: fixed;
    bottom: 90px;
    right: 4%;
    z-index: 99;
    margin: 0px;
}
@media screen and (max-width: 767px){
    .btn-fixed{
        width: 25%;
        bottom: 80px;
        right: 33%;
    }
}
.nav-Opened .footer-fixed, .nav-Opened .btn-fixed{
    z-index: 0;
    opacity: 0;
}

/*=============================================
 * .toggle
 *=============================================*/

 .toggle {
}
.toggle .toggle-link {
	cursor: pointer;
	position: relative;
}
.toggle .toggle-main {
	display: none;
}
.toggle.active .toggle-main {
	display: block;
}