@charset "UTF-8";
/*====== reset.css =====*/
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: 0 0; }

body { font-size: 14px; line-height: 1.4; font-family: Verdana,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ','ＭＳ Ｐゴシック','MS P Gothic',sans-serif; }

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

ul { list-style: none; }

blockquote, q { quotes: none; }

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

a { margin: 0; padding: 0; border: 0; font-size: 100%; vertical-align: baseline; background: 0 0; }

ins { background-color: #ff9; color: #000; text-decoration: none; }

mark { background-color: #ff9; color: #000; font-style: italic; font-weight: 700; }

del { text-decoration: line-through; }

abbr[title], dfn[title] { border-bottom: 1px dotted #000; cursor: help; }

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

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

address { font-style: normal; }

/*====== clearfix =====*/
.clearfix::after { content: "."; display: block; clear: both; height: 0; visibility: hidden; }

.clearfix { min-height: 1px; }

* html .clearfix { height: 1px; /*¥*/      /*/
height: auto;
overflow: hidden;
/**/ }

/*====== box-sizing =====*/
html { -webkit-box-sizing: border-box; box-sizing: border-box; }

*, *::before, *::after { -webkit-box-sizing: inherit; box-sizing: inherit; }

#wrapper { overflow: hidden; }

/*====== font =====*/
body {
    background: #fcfcfa;
    font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3", "Hiragino Kaku Gothic Pro", "Helvetica Neue", "游ゴシック Medium", "メイリオ", Meiryo, sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: 18px;
    line-height: 1.55;
    color: #000;
}
@media screen and (max-width: 767px) { body { font-size: 13px; } }

h1, h2, h3, h4, h5, h6 { /*color: #000;*/ }

input, textarea { font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3", "Hiragino Kaku Gothic Pro", "Helvetica Neue", "游ゴシック Medium", "メイリオ", Meiryo, sans-serif; font-weight: 500; }

.font-h,
.catch,
.page-title,
.h-01,
.h-02,
.num-box,
.nav-anchor,
.nav-price,
.news-article .more,
.pager-list,
.pager-detail,
button {
    font-family: "FOT-筑紫A丸ゴシック Std D";
    font-weight: 500;
}
.font-en,
.tel {
    font-family: 'Roboto', sans-serif;
}

.font-big { font-size: 111%; }
.font-small { font-size: 89%; }

.font-bold { font-weight: 700; }

.font-ker { -webkit-font-feature-settings: "palt"; font-feature-settings: "palt"; }
.font-ker1 { letter-spacing: -0.4em; }
.font-ker2 { letter-spacing: -0.08em; }

.tleft { text-align: left; }
.tcenter { text-align: center; }
.tright { text-align: right; }

/*====== link =====*/
a { color: #000; text-decoration: none; -webkit-transition: .6s; transition: .6s; }

a:hover { color: #2c883a; }

a.o-hover:hover { opacity: .7; }

.no-link { cursor: pointer; }

/*====== button =====*/
button { outline: none; cursor: pointer; }

/*====== img =====*/
img { max-width: 100%; height: auto; vertical-align: top; }
iframe { max-width: 100%; vertical-align: top; }

.icon {
    vertical-align: text-bottom;
    margin: 0 0.8em -0.05em 0;
}
.icon-arrow {
    vertical-align: middle;
    margin: 0 0 0.25em 0.8em;
}

/* thumbnail */
.thumb {
    position: relative;
    width: 100%;
    height: 0;
	overflow: hidden;
}
.thumb img {
    width: 100%; height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    font-family: 'object-fit: cover;'; /*IE対策*/
    -o-object-position: 50% 50%;
       object-position: 50% 50%;
    position: absolute;
    top: 0; bottom: 0;
    left: 0; right: 0;
    margin: auto;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}

/*====== common style =====*/
.color-green,
.must { color: #2c883a; }

.color-red { color: rgb(224, 0, 0); }

.w100 { width: 100%; }

.m-inner {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-width: 1400px;
    width: 89.33%;
}
.m-inner.is-s {
    max-width: 815px;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.flex.is-wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
}

ul.disc > li { padding-left: 1.1em; text-indent: 0; position: relative; }
ul.disc > li::before { content: "・"; position: absolute; left: 0; }

.mtp-20 { margin-top: -20px !important; }
.mtp-30 { margin-top: -30px !important; }
.mtp-40 { margin-top: -40px !important; }

.mtp0 { margin-top: 0 !important; }
.mtp5 { margin-top: 5px !important; }
.mtp10 { margin-top: 10px !important; }
.mtp15 { margin-top: 15px !important; }
.mtp20 { margin-top: 20px !important; }
.mtp25 { margin-top: 25px !important; }
.mtp30 { margin-top: 30px !important; }
.mtp35 { margin-top: 35px !important; }
.mtp40 { margin-top: 40px !important; }
.mtp45 { margin-top: 45px !important; }
.mtp50 { margin-top: 50px !important; }
.mtp55 { margin-top: 55px !important; }
.mtp60 { margin-top: 60px !important; }
.mtp70 { margin-top: 70px !important; }
.mtp80 { margin-top: 80px !important; }

.mbt0 { margin-bottom: 0 !important; }
.mbt5 { margin-bottom: 5px !important; }
.mbt10 { margin-bottom: 10px !important; }
.mbt15 { margin-bottom: 15px !important; }
.mbt20 { margin-bottom: 20px !important; }
.mbt25 { margin-bottom: 25px !important; }
.mbt30 { margin-bottom: 30px !important; }
.mbt35 { margin-bottom: 35px !important; }
.mbt40 { margin-bottom: 40px !important; }
.mbt45 { margin-bottom: 45px !important; }
.mbt50 { margin-bottom: 50px !important; }
.mbt55 { margin-bottom: 55px !important; }
.mbt60 { margin-bottom: 60px !important; }
.mbt70 { margin-bottom: 70px !important; }
.mbt80 { margin-bottom: 80px !important; }

.ptp0 { padding-top: 0 !important; }
.ptp5 { padding-top: 5px !important; }
.ptp10 { padding-top: 10px !important; }
.ptp15 { padding-top: 15px !important; }
.ptp20 { padding-top: 20px !important; }
.ptp25 { padding-top: 25px !important; }
.ptp30 { padding-top: 30px !important; }
.ptp35 { padding-top: 35px !important; }
.ptp40 { padding-top: 40px !important; }
.ptp45 { padding-top: 45px !important; }
.ptp50 { padding-top: 50px !important; }
.ptp55 { padding-top: 55px !important; }
.ptp60 { padding-top: 60px !important; }
.ptp70 { padding-top: 70px !important; }
.ptp80 { padding-top: 80px !important; }

.pbt0 { padding-bottom: 0 !important; }
.pbt5 { padding-bottom: 5px !important; }
.pbt10 { padding-bottom: 10px !important; }
.pbt15 { padding-bottom: 15px !important; }
.pbt20 { padding-bottom: 20px !important; }
.pbt25 { padding-bottom: 25px !important; }
.pbt30 { padding-bottom: 30px !important; }
.pbt35 { padding-bottom: 35px !important; }
.pbt40 { padding-bottom: 40px !important; }
.pbt45 { padding-bottom: 45px !important; }
.pbt50 { padding-bottom: 50px !important; }
.pbt55 { padding-bottom: 55px !important; }
.pbt60 { padding-bottom: 60px !important; }
.pbt70 { padding-bottom: 70px !important; }
.pbt80 { padding-bottom: 80px !important; }

.iblock { display: inline-block; }

.relative { position: relative; }

.fleft { float: left; }
.fright { float: right; }

/* Parallax */
.t--u {
	-webkit-transform: translate(0, -100px);
	    -ms-transform: translate(0, -100px);
	        transform: translate(0, -100px);
}
.u--t {
	-webkit-transform: translate(0, 100px);
	    -ms-transform: translate(0, 100px);
	        transform: translate(0, 100px);
}
.r--l {
	-webkit-transform: translate(100px, 0);
	    -ms-transform: translate(100px, 0);
	        transform: translate(100px, 0);
}
.l--r {
	-webkit-transform: translate(-100px, 0);
	    -ms-transform: translate(-100px, 0);
	        transform: translate(-100px, 0);
}
.s--b {
    -webkit-transform: scale(0);
        -ms-transform: scale(0);
            transform: scale(0);
}
.u--t {
	opacity: 0;
	-webkit-transition: .5s;
	transition: .5s;
}
.t--u,
.r--l,
.l--r {
	opacity: 0;
	-webkit-transition: .5s;
	transition: .5s;
	-webkit-transition-delay: .2s;
	        transition-delay: .2s;
}
.t--u.active,
.u--t.active,
.r--l.active,
.l--r.active {
    opacity: 1;
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
}

.s--b {
	opacity: 0;
	-webkit-transition: .8s;
	transition: .8s;
	-webkit-transition-delay: .2s;
	        transition-delay: .2s;
}
.s--b.active {
    opacity: 1;
    -webkit-transform: scale(1);
        -ms-transform: scale(1);
            transform: scale(1);
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}

.show {
    opacity: 0;
    -webkit-transition: 1s;
	transition: 1s;
	-webkit-transition-delay: .1s;
	        transition-delay: .1s;
}
.show.active {
    opacity: 1;
}