@charset "utf-8";

iframe,img{max-width:100%}

.slick-slider *,a[href]{outline:0}

.ff_en,.ff_min{font-weight:400}

#footer .info .language .current::after,
#pagetop a::before,
.w::after
{content:""}

html{font-size:62.5%}

body{background-color:#fff;
font-size:10px;
font-size:1rem;
line-height:2;
color:#313131;
word-wrap:break-word;
overflow-wrap:break-word;
font-family:"游ゴシック medium",
YuGothic,
"Hiragino Kaku Gothic ProN",
"ヒラギノ角ゴ ProN",
"Hiragino Kaku Gothic Pro",
"ヒラギノ角ゴ Pro W3",
"メイリオ",
Meiryo,
Verdana,
Arial,
Helvetica,
sans-serif;
-webkit-text-size-adjust:100%;
text-size-adjust:100%}

*,
::after,
::before
{-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
box-sizing:border-box}
img
{height:auto}
table
{border-collapse:collapse;
border-spacing:0;
line-height:1.8}
a[href]
{color:#bd9f6b;
text-decoration:underline}
.a_reverse a[href],
a[href].a_reverse,
a[href]:hover
{text-decoration:none}
sup
{font-size:1rem}
a[href^=http],
a[href^="mailto:"]
{display:inline-block;
word-break:break-all;
word-wrap:break-word;
overflow-wrap:break-word}
button,
label
{cursor:pointer}
button,
input,
select,
textarea
{max-width:100%;
margin:0;
vertical-align:middle;
font-family:inherit;
outline:0;
font-size:100%}
iframe
{vertical-align:middle}
.hidden
{display:none}


@media screen and (max-width:979px)
{body
{font-family:"Hiragino Kaku Gothic ProN",
"ヒラギノ角ゴ ProN",
"Hiragino Kaku Gothic Pro",
"ヒラギノ角ゴ Pro W3",
"メイリオ",
Meiryo,
Verdana,
Arial,
Helvetica,
sans-serif}
sup
{font-size:.4rem!important}
}



.bg_980_anniver.menubox777 .menubox777in .menubox2203,
.ff_min,
.floor_copy
{font-family:"Hiragino Mincho ProN",
"ヒラギノ明朝 ProN",
"ヒラギノ明朝 ProN W3",
"Hiragino Mincho Pro",
"ヒラギノ明朝 Pro W3",
HiraMinProN-W3,
"游明朝",
YuMincho,
"HGS明朝E",
"HG明朝E",
"メイリオ",
Meiryo,
serif}
.sp,
.sps
{display:none!important}


@media screen and (min-width:980px),
print
{.pc_break,
.pc_hidden
{position:relative;
overflow:hidden;
display:block;
height:0}
.fz_l_block
{font-size:1.6rem}
}


@media screen and (max-width:979px)
{.pc
{display:none!important}
.sp
{display:block!important}
br.sp,
em.sp,
img.sp,
span.sp,
strong.sp
{display:inline!important}
td.sp,
th.sp
{display:table-cell!important}
.sp_break
{position:relative;
display:block;
height:0;
overflow:hidden}
}


@media screen and (max-width:370px)
{.sps
{display:block!important}
br.sps,
em.sps,
img.sps,
spsan.sps,
strong.sps
{display:inline!important}
.sps_non
{display:none!important}
}


@media screen and (max-width:768px)
{[data-label] img
{display:none!important}
[data-label]::before
{content:attr(data-label)}
[data-label-r]::after
{display:block;
content:attr(data-label-r)}
}


@media screen and (min-width:371px)
{[data-label-r].spl_r_inline::after
{display:inline}
}


@media screen and (min-width:980px)
{.a_reverse a[href]:hover,
a[href].a_reverse:hover
{text-decoration:underline}
.basic_trs,
.basic_trs *,
.basic_trs ::after,
.basic_trs ::before,
.basic_trs::after,
.basic_trs::before,
a[href],
a[href]::after,
a[href]::before,
button
{-webkit-transition:color .2s ease-in-out,
background .2s ease-in-out,
border .2s ease-in-out,
opacity .2s ease-in-out;
-o-transition:color .2s ease-in-out,
background .2s ease-in-out,
border .2s ease-in-out,
opacity .2s ease-in-out;
transition:color .2s ease-in-out,
background .2s ease-in-out,
border .2s ease-in-out,
opacity .2s ease-in-out}
}
.ff_en
{font-family:"PT Serif",
serif}
.fwb
{font-weight:700}
.fwn,
.normal
{font-weight:400}
.normal
{font-size:14px;
font-size:1.4rem;
line-height:2;
color:#302000}
.db
{display:block}
.dib
{display:inline-block}
.c_theme
{color:#a0824f}
.red
{color:#cc1c17}
.bg_pattern
{background:url(/common/images/parts/bg_pattern.jpg) 50% 0}
.bg_coupon
{background-color:#fff9ec}
.bg_pattern2
{background:url(/common/images/parts/bg_pattern2.jpg) 50% 0}
.bg_color_be
{background-color:#ede4d2}
.bg_color_wg
{background-color:#f8f5ef}


@media screen and (max-width:979px)
{.bg_pattern
{-webkit-background-size:237px;
background-size:237px}
.bg_pattern2
{-webkit-background-size:250px;
background-size:250px}
}
a[href] .hv_zoom
{background-repeat:no-repeat;
-webkit-background-size:cover;
background-size:cover}


@media screen and (min-width:980px),
print
{.hv_wh a,
a .hv_wh,
a.hv_wh,
button.hv_wh
{position:relative;
display:inline-block;
vertical-align:middle;
overflow:hidden}
.hv_wh a::after,
a .hv_wh::after,
a.hv_wh::after,
button.hv_wh::after
{content:"";
position:absolute;
left:0;
right:0;
top:0;
bottom:0;
background-color:rgba(255,
255,
255,
0);
-webkit-transition:background .2s;
-o-transition:background .2s;
transition:background .2s;
z-index:3}
.hv_wh a[href]:hover::after,
a[href].hv_wh:hover::after,
a[href]:hover .hv_wh::after,
button.hv_wh:hover::after
{background-color:rgba(255,
255,
255,
.3)}
.hv_wh.a20 a[href]:hover::after,
a[href].hv_wh.a20:hover::after,
a[href]:hover .hv_wh.a20::after,
button.hv_wh.a20:hover::after
{background-color:rgba(255,
255,
255,
.2)}
.hv_wh.a10 a[href]:hover::after,
a[href].hv_wh.a10:hover::after,
a[href]:hover .hv_wh.a10::after,
button.hv_wh.a10:hover::after
{background-color:rgba(255,
255,
255,
.1)}
a[href] .hv_op
{-webkit-transition:opacity .2s;
-o-transition:opacity .2s;
transition:opacity .2s}
.hv_op a[href]:hover,
a[href].hv_op:hover,
a[href]:hover .hv_op
{opacity:.7}
.hv_op.a20 a[href]:hover,
a[href].hv_op.a20:hover,
a[href]:hover .hv_op.a20
{opacity:.8}
.hv_op.a10 a[href]:hover,
a[href].hv_op.a10:hover,
a[href]:hover .hv_op.a10
{opacity:.9}
a[href] .hv_zoom
{-webkit-transition:-webkit-transform .5s,
opacity .5s;
-o-transition:-o-transform .5s,
opacity .5s;
transition:transform .5s,
opacity .5s;
-webkit-transform:scale(1.01);
-ms-transform:scale(1.01);
-o-transform:scale(1.01);
transform:scale(1.01)}
a[href]:hover .hv_zoom
{-webkit-transform:scale(1.05);
-ms-transform:scale(1.05);
-o-transform:scale(1.05);
transform:scale(1.05);
opacity:.7}
}
.target,
.w
{position:relative}
.target
{display:block;
width:1px;
top:-70px}
.target.pt
{top:-100px}


@media screen and (max-width:979px)
{.target
{top:-60px}
.target.pt
{top:-80px}
}
.w
{max-width:1230px;
margin:0 auto;
padding:0 15px}
.w820,
.w980
{margin-left:auto;
margin-right:auto}
.w.m
{max-width:1010px}
.w::after
{display:table;
clear:both}
.mw
{min-width:1100px}
.w980
{width:980px}
.w820
{width:820px}


@media screen and (max-width:979px)
{.w
{padding:0;
width:auto!important;
max-width:none!important}
.w>.slide
{max-width:1229px!important}
.mw
{min-width:0}
.w980
{width:100%}
.sp_pd
{padding-left:15px!important;
padding-right:15px!important}
.sp_full
{margin-left:-15px!important;
margin-right:-15px!important}
}


@media screen and (max-width:820px)
{.w820
{width:100%}
}


@media screen and (max-width:370px)
{.target
{top:-50px}
.target.pt
{top:-70px}
.sp_full
{margin-left:-8px!important;
margin-right:-8px!important}
.sp_pd
{padding-left:8px!important;
padding-right:8px!important}
}


@media screen and (min-width: 980px),
print {
    #header {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        height: 100px;
        background-color: #fff;
        z-index: 1000;
    }
    #header .gnav > ul {
        display: table;
        width: 980px;
        margin: 0 auto;height: 100px;
        table-layout: fixed;
    }
    #header .gnav > ul > li {
        display: table-cell;
        vertical-align: middle;
    }

    #header .gnav > ul > li > a {
        position: relative;
        display: table;
        width: 100%;
        text-align: center;
        text-decoration: none;
        font-weight: bold;
        font-size: 1.5rem;
        line-height: 1.2;
        color:#313131;
    }


#header .gnav ul li{
width: 110px;
}
#header .gnav ul li.w_top{
width: 170px;
}

#header .gnav li.logo4000{
width: 290px;/*----------A------------
global navigationの全体幅が980pxにならないので、
420pxから450pxに修正しています。
*/
text-align: left;
}
#header .gnav li.logo4000 a{
display: inline;
text-align: left;
}

#header .gnav>ul>li>a.current span,
#header .gnav>ul>li>a:hover span{
color:#2f557c;
border-bottom:1px solid #2f557c;

}
#header .gnav li.contact{
background-color:#2f557c;

text-decoration:none;
text-align:center;
font-weight:700;
font-size:1.4rem;
line-height:1.6;
width:200px;
height:100px;display: table;

}

#header .gnav li.contact a{
color:#fff;
display: table-cell;
table-layout: fixed;
vertical-align: middle;
text-align: center;
}


}








@media screen and (min-width: 980px) {

    /* height low
	------------------------------------------------------------- */
    body.move #header {
        -webkit-transition: -webkit-transform 0.4s;
        -o-transition: -o-transform 0.4s;
        transition: transform 0.4s;
    }

    body.move #header .contact a > *,
    body.move #header .contact a > * span {
        -webkit-transition: -webkit-transform 0.4s;
        -o-transition: -o-transform 0.4s;
        transition: transform 0.4s;
    }

/*
-----------E------------
スクロールすると、global navigationが狭くなる現象がありましたので
以下をコメントアウトしています。
ひとつ飛ばしての項目も同様です。

    body.scroll #header {
        -webkit-transform: translateY(-50px);
        -ms-transform: translateY(-50px);
        -o-transform: translateY(-50px);
        transform: translateY(-50px);
    }

    body.scroll #header .contact a > * {
        -webkit-transform: translateY(27px);
        -ms-transform: translateY(27px);
        -o-transform: translateY(27px);
        transform: translateY(27px);
    }

    body.scroll #header .contact a > * span {
        -webkit-transform: translateY(-4px);
        -ms-transform: translateY(-4px);
        -o-transform: translateY(-4px);
        transform: translateY(-4px);
    }*/

    body.scroll #header .gnav ul li.logo4000 {
        display: table-cell !important;
    }

/*    body.scroll #header .gnav > ul > li.logo4000 {
        width: 52px !important;
    }*/

    body.scroll #header .gnav > ul > li.logo4000 > a {
        padding: 10px 12px 0px 0;
    }

    body.scroll #header .gnav > ul > li.logo4000 > a::before {
        background: #ffffff;
    }

    body.scroll #header .gnav > ul > li.logo4000 > a:hover > *,
    body.scroll #header .gnav > ul > li.logo4000 > a.current > * {
        background-color: rgba(255, 0, 0, 0) !important;
    }
}










header .slide{
z-index: 0;
}
header .slide .page_title_bg01 .en_name,
header .slide .page_title_bg02 .en_name,
header .slide .page_title_bg03 .en_name,
header .slide .page_title_bg04 .en_name,
header .slide .page_title_bg05 .en_name,
header .slide .page_title_bg06 .en_name {
font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN",
            "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo",
            Verdana, Arial, Helvetica, sans-serif;
margin-bottom: 5px;
    font-size: 6.0rem;
    line-height: 1.2;
    text-align: left;
}



header .slide .page_title_bg01 .title,
header .slide .page_title_bg02 .title,
header .slide .page_title_bg03 .title,
header .slide .page_title_bg04 .title,
header .slide .page_title_bg05 .title,
header .slide .page_title_bg06 .title {
    margin-top: 20px;
    font-size: 2.8rem;
    line-height: 1.3;
}


header .slide p.copy {
    font-size: 2.0rem;
    line-height: 1.4; 
    text-align: left;   
}



header .slide .page_title_bg01,
header .slide .page_title_bg02,
header .slide .page_title_bg03,
header .slide .page_title_bg04,
header .slide .page_title_bg05,
header .slide .page_title_bg06 {
    text-align: center;
	width: 100%;
    position: relative;
    background-position: 50%;
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    background-size: cover;

    display: table;
    padding: 250px 200px;
    color: #fff;
    line-height: 1.5;
    font-size: 2rem;
    font-weight: bold;
    text-shadow: 0 0 8px rgba(37, 17, 0, 0.8);
}

header .slide .page_title_bg01 > *,
header .slide .page_title_bg02 > *,
header .slide .page_title_bg03 > *,
header .slide .page_title_bg04 > *,
header .slide .page_title_bg05 > *,
header .slide .page_title_bg06 > * {
    display: table-cell;
    vertical-align: middle;
}



@media screen and (min-width: 1100px),
print {/*----------B------------
min-widthの数値をが980pxになっていましたが、
1100pxが切り替えの基準（横スクロールが出るポイント）になっていたので
修正しています。
プリントではまずいかもしれません。*/

    header .slide .page_title_bg01,
    header .slide .page_title_bg02,
    header .slide .page_title_bg03,
    header .slide .page_title_bg04,
    header .slide .page_title_bg05,
    header .slide .page_title_bg06 {
/*
1100pxを基準にすると、
global navigationとの間に空きができてしまう場合があるので
コメントアウトしました。
下記に、この部分だけ980pxを基準にした切り替えを作成しました。
    margin-top: 100px;*/
        height: 860px;
        overflow: hidden;
    }
}

@media screen and (max-width: 1099px) {/*----------C------------
B同様に1100pxが切り替えの基準になっていたので
max-widthの数値も979pxから修正しています。*/

    header .slide .page_title_bg01,
    header .slide .page_title_bg02,
    header .slide .page_title_bg03,
    header .slide .page_title_bg04,
    header .slide .page_title_bg05,
    header .slide .page_title_bg06 {
     
        height: 350px;
        font-size: 1.2rem;
        overflow: hidden;
        padding: 25px;
    }
    header .slide .page_title_bg01 .en_name,
header .slide .page_title_bg02 .en_name,
header .slide .page_title_bg03 .en_name,
header .slide .page_title_bg04 .en_name,
header .slide .page_title_bg05 .en_name,
header .slide .page_title_bg06 .en_name {
    font-size: 4.5rem;
    line-height: 1.2;
}

}





/*----------D------------
スライドの文章が全体の幅を超えるとスライダーが崩れてしまうので
max-width: 599pxで、文字サイズで調整しています。
付け加えています*/
@media screen and (max-width: 599px) {

    header .slide .page_title_bg01 .en_name,
header .slide .page_title_bg02 .en_name,
header .slide .page_title_bg03 .en_name,
header .slide .page_title_bg04 .en_name,
header .slide .page_title_bg05 .en_name,
header .slide .page_title_bg06 .en_name {
    font-size: 2.4rem;
    line-height: 1.2;
}

}



header .slide .page_title_bg01,
header .slide .page_title_bg02,
header .slide .page_title_bg03,
header .slide .page_title_bg04,
header .slide .page_title_bg05,
header .slide .page_title_bg06 {
margin-top: 100px;
}
@media screen and (max-width: 979px) {
header .slide .page_title_bg01,
header .slide .page_title_bg02,
header .slide .page_title_bg03,
header .slide .page_title_bg04,
header .slide .page_title_bg05,
header .slide .page_title_bg06 {
margin-top: 0;
}

}











@media screen and (max-width: 979px) {
    #fixNav {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
        background-color: #2f557c;
        z-index: 8500;
        border-top: 1px solid #fff;
    }
       #header .gnav li.logo4000{
    display: none;
    }
    

    #fixNav ul {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
    }

    #fixNav li {
        position: relative;
        width: 100%;
    }

    #fixNav li + li::before {
        content: "";
        position: absolute;
        top: 7px;
        bottom: 7px;
        left: 0;
        border-left: 1px solid rgba(255, 255, 255, 0.6);
    }
    #fixNav li > *{display: block;}

    #fixNav li a {
        position: relative;
        display: table;
        color: #fff;
        text-decoration: none;
        font-size: 1.3rem;
        line-height: 1.3;
        width: 100%;
    }
    #fixNav li a span{
    display: table-cell;
        width: 100%;
    height: 60px;
        text-align: center;
        vertical-align: middle;
    }


.logosp{
width: 100%;
text-align: center;
padding: 10px;
}

}




/*     footer    */

.footer{
color:#fff;
background: #2f557c;
text-align: center;
}

.footer02 .logo{
margin-bottom: 40px;
}

.footer02{
padding:60px;
font-size: 140%;
}

.footer02 .address{
margin-bottom: 40px;
}

.footer02 .bold{
font-weight: bold;
font-size: 140%;
}

.footer02 a{
color:#fff;
text-decoration: none;
}

.footer02 .link a:hover{
text-decoration: underline;
}

.footer02 .contact{
display:block;
margin:0 auto;
width:380px;
padding:10px;
font-weight: bold;
border: 1px solid #fff;
margin-bottom: 60px;
}

.footer02 .contact:hover{
color:#2f557c;
background: #fff;
}

.footer .copy{
background: #252a2c;
padding:20px;
font-size: 120%;
}

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

.footer02 .link{
display: none !important;
}

.footer02 .contact{
display: none !important;
}

.footer02 .address{
margin: 0;
}

.footer .copy{
margin-bottom:50px;
}



}


.page_title p{padding-top: 90px;}

.page_title p span.ff_en{
font-family:"游ゴシック medium",
YuGothic,
"Hiragino Kaku Gothic ProN",
"ヒラギノ角ゴ ProN",
"Hiragino Kaku Gothic Pro",
"ヒラギノ角ゴ Pro W3",
"メイリオ",
Meiryo,
Verdana,
Arial,
Helvetica,
sans-serif;
font-weight: bold;
letter-spacing: 2px;
border-bottom: solid 1px #ffffff;
padding-bottom: 5px;
}

header.page_title p span.ff_jp{
line-height: 2;
display: block;
font-size: 1.3rem;
}

@media screen and (max-width:979px){
.page_title p{padding-top: 40px;}
}

.js_service_box li{
cursor: pointer;
}
.back_btn{
cursor: pointer;
padding: 10px;
text-align: center;
background-color:#2f557c;
color: #fff;
font-size: 1.4rem;
}

.back_btn:hover{
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}
.back_btn a{
color: #fff;
text-decoration: none;
display: block;
}

#pagetop,
#pagetop a {
    width: 70px;
    height: 70px
}
#footer {
    position: relative;
    background-color: #a18451;
    font-size: 1.4rem;
    color: #fff
}
#pagetop {
    position: fixed;
    overflow: hidden;
    bottom: 0;
    right: 0;
    z-index: 1000
}
#pagetop a {
    display: block;
    background-color: #c3a516;
    border: 2px solid #c3a516;
    -webkit-transition: -webkit-transform 0.3s ease-in-out, background 0.2s ease-in-out;
    -o-transition: -o-transform 0.3s ease-in-out, background 0.2s ease-in-out;
    transition: transform 0.3s ease-in-out, background 0.2s ease-in-out;
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    -o-transform: translateX(100%);
    transform: translateX(100%)
}
#pagetop a::before {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    margin: -3px 0 0 -4px;
    border-top: 3px solid #fff;
    border-left: 3px solid #fff;
    -webkit-transform: scaleY(0.8) rotate(45deg);
    -ms-transform: scaleY(0.8) rotate(45deg);
    -o-transform: scaleY(0.8) rotate(45deg);
    transform: scaleY(0.8) rotate(45deg)
}
#pagetop.show a {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0)
}
@media print {
    #pagetop {
        display: none
    }
}
@media screen and (min-width:1230px) {
    #pagetop a:hover {
        background-color: #fff
    }
    #pagetop a:hover::before {
        border-color: #c3a516
    }
}
@media screen and (max-width:1229px) {
    #footer {
        padding-bottom: 50px;
        font-size: 1.1rem
    }
    #pagetop,
    #pagetop a {
        width: 50px;
        height: 50px
    }
}

.service_item li a {
        text-decoration: none;
        color: #65747c;
    }
    
@media screen and (max-width:768px) {
.back_btn{
cursor: pointer;
padding: 0px;
text-align: center;
background-color:#2f557c;
color: #fff;
font-size: 1.4rem;
}
   .back_btn a{
cursor: pointer;
padding: 10px;
text-align: center;
background-color:#2f557c;
color: #fff;
font-size: 1.4rem;
margin: 15px 0;
display: block;
}
}



#header .gnav li.contact a:hover{
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}
#header .gnav li.contact a:hover span{
color:#fff !important;
}
