@charset "UTF-8";
/* Contents Menu
-------------------------------------------------------------------------------------
【PC/SP】
	**:normalize
	**:icon
	**:reset
	**:base contents
		header/gnav/breadChumbs/mv/contents/footer/newslist/
	**:indent
	**:size
	**:wide
	**:section
	**:compo parts
		btn/box/list/head/table/float/column/topcontrol/roBtn/
	**:pager
	**:form
-------------------------------------------------------------------------------------*/
/* normalize
-------------------*/
/*! normalize.css v2.0.1 | MIT License | git.io/normalize */
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary { display: block; }

audio, canvas, video { display: inline-block; }

audio:not([controls]) { display: none; height: 0; }

[hidden] { display: none; }

html { font-family: sans-serif; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

body { margin: 0; }

h1 { font-size: 2em; }

abbr[title] { border-bottom: 1px dotted; }

b, strong { font-weight: 700; }

dfn { font-style: italic; }

mark { background: #ff0; color: #000; }

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

pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }

q { quotes: "\201C" "\201D" "\2018" "\2019"; }

small { font-size: 80%; }

sub { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; top: -.5em; }

sub { bottom: -.25em; }

img { border: 0; }

svg:not(:root) { overflow: hidden; }

figure { margin: 0; }

fieldset { border: 1px solid silver; margin: 0 2px; padding: .35em .625em .75em; }

legend { border: 0; padding: 0; }

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

button, input { line-height: normal; }

button, html input[type="button"] { -webkit-appearance: button; cursor: pointer; }

input[type=reset], input[type=submit] { -webkit-appearance: button; cursor: pointer; }

button[disabled] { cursor: default; }

input[disabled] { cursor: default; }
input[type=checkbox], input[type=radio] { box-sizing: border-box; padding: 0; }
input[type=search] { -webkit-appearance: textfield; -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

textarea { overflow: auto; vertical-align: top; }

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

body.is-win { font-weight: 600; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; }
body.is-win #header h1 { font-weight: bold; }

/* icon
-------------------*/
@font-face { font-family: 'icon'; src: url("fonts/icon.eot?12d0xm"); src: url("fonts/icon.eot?12d0xm#iefix") format("embedded-opentype"), url("fonts/icon.ttf?12d0xm") format("truetype"), url("fonts/icon.woff?12d0xm") format("woff"), url("fonts/icon.svg?12d0xm#icon") format("svg"); font-weight: normal; font-style: normal; }
[class^="icon-"], [class*=" icon-"] { /* use !important to prevent issues with browser extensions that change fonts */ font-family: 'icon' !important; speak: none; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; line-height: 1; /* Better Font Rendering =========== */ -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.icon-chevron-small-down:before { content: "\e900"; }

.icon-chevron-small-left:before { content: "\e901"; }

.icon-chevron-small-right:before { content: "\e902"; }

.icon-chevron-small-up:before { content: "\e903"; }

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

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

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

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

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

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

.icon-key:before { content: "\e90a"; }

.icon-light-up:before { content: "\e90b"; }

.icon-location:before { content: "\e90c"; }

.icon-magnifying-glass:before { content: "\e90d"; }

.icon-mail:before { content: "\e90e"; }

.icon-mobile:before { content: "\e90f"; }

.icon-pencil:before { content: "\e910"; }

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

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

.icon-signal:before { content: "\e913"; }

.icon-stopwatch:before { content: "\e914"; }

.icon-tablet:before { content: "\e915"; }

.icon-tv:before { content: "\e916"; }

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

.icon-instagram:before { content: "\e918"; }

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

.icon-youtube:before { content: "\e91a"; }

.icon-warning:before { content: "\e91b"; }

.icon-open-book:before { content: "\e91c"; }

.icon-attachment:before { content: "\e91d"; }

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

.icon-cog:before { content: "\e91f"; }

.icon-location-pin:before { content: "\e920"; }

.icon-message:before { content: "\e921"; }

.icon-new-message:before { content: "\e922"; }

.icon-old-phone:before { content: "\e923"; }

.icon-typing:before { content: "\e924"; }

.icon-confirmation:before { content: "\e927"; }

.icon-user:before { content: "\e925"; }

.icon-user-solid-circle:before { content: "\e926"; }

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

@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 100; src: url(fonts/notoserif/SourceHanSerifJP-ExtraLight.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-ExtraLight.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 200; src: url(fonts/notoserif/SourceHanSerifJP-Light.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-Light.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 300; src: url(fonts/notoserif/SourceHanSerifJP-Regular.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-Regular.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 400; src: url(fonts/notoserif/SourceHanSerifJP-Medium.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-Medium.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 500; src: url(fonts/notoserif/SourceHanSerifJP-SemiBold.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-SemiBold.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 600; src: url(fonts/notoserif/SourceHanSerifJP-Bold.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-Bold.woff) format("woff"); }
@font-face { font-family: 'notoserif'; font-style: normal; font-weight: 700; src: url(fonts/notoserif/SourceHanSerifJP-Heavy.woff2) format("woff2"), url(fonts/notoserif/SourceHanSerifJP-Heavy.woff) format("woff"); }
.notoserif1 { font-weight: 100; font-family: 'notoserif'; }

.notoserif2 { font-weight: 200; font-family: 'notoserif'; }

.notoserif3 { font-weight: 300; font-family: 'notoserif'; }

.notoserif4 { font-weight: 400; font-family: 'notoserif'; }

.notoserif5 { font-weight: 500; font-family: 'notoserif'; }

.notoserif6 { font-weight: 600; font-family: 'notoserif'; }

.notoserif7 { font-weight: 700; font-family: 'notoserif'; }

/* reset
-------------------*/
html { background-color: #FFF; font-size: 62.5%; /* sets the base font to 10px for easier math */ }

body, h1, h2, h3, h4, h5, h6, pre, ul, ol, li, dl, dt, dd, p, img { margin: 0; padding: 0; }

body { font-family: YuGothic, '游ゴシック', Meiryo, メイリオ, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", verdana, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; color: #333; font-size: 17px; font-size: 1.7rem; /* sets the default sizing to make sure nothing is actually 10px */ line-height: 1; letter-spacing: 0.08em; /*	min-width:1000px;*/ background: url(../../images/foot_bg.jpg) no-repeat bottom; padding-top: 92px; }
body * { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }

#fancybox-wrap { -webkit-box-sizing: content-box !important; -moz-box-sizing: content-box !important; -o-box-sizing: content-box !important; -ms-box-sizing: content-box !important; box-sizing: content-box !important; }
#fancybox-wrap * { -webkit-box-sizing: content-box !important; -moz-box-sizing: content-box !important; -o-box-sizing: content-box !important; -ms-box-sizing: content-box !important; box-sizing: content-box !important; }

#fancybox-tmp, #fancybox-loading { -webkit-box-sizing: content-box !important; -moz-box-sizing: content-box !important; -o-box-sizing: content-box !important; -ms-box-sizing: content-box !important; box-sizing: content-box !important; }

a { color: #333; text-decoration: none; cursor: pointer; outline: none; -webkit-transition: all .3s ease-in-out; transition: all .3s ease-in-out; }
a:link, a:hover, a:focus { color: #333; text-decoration: none; cursor: pointer; outline: none; -webkit-transition: all .3s ease-in-out; transition: all .3s ease-in-out; }
a:hover { text-decoration: underline; }

ul, ol { list-style-type: none; }

::selection, ::-moz-selection { background-color: #f5e4f7; }

#contents p { line-height: 1.7; }

hr.ancHr { font-size: 0 !important; line-height: 0 !important; visibility: hidden !important; margin: 0; padding: 0; }

/* base contents
-------------------*/
/*header*/
#header { background-color: #FFF; width: 1000px; position: relative; margin: auto; position: fixed; top: 0; left: 0; width: 100%; z-index: 600; }
#header img { padding-right: 20px; }
#header h1 { display: inline; font-weight: normal; color: #7b6835; font-size: 1.6rem; }
#header .psBtn { position: absolute; right: 0; top: 0; width: 130px; text-align: center; }
#header .psBtn a { background-color: #01a89e; display: block; color: #FFF; font-size: 1.4rem; line-height: 1.4; padding: 25px 10px 15px; -webkit-border-bottom-right-radius: 10px; -webkit-border-bottom-left-radius: 10px; -moz-border-radius-bottomright: 10px; -moz-border-radius-bottomleft: 10px; border-bottom-right-radius: 10px; border-bottom-left-radius: 10px; box-shadow: 0px 4px 11px -2px rgba(0, 0, 0, 0.24); -webkit-transform: translateY(-10px); -moz-transform: translateY(-10px); -ms-transform: translateY(-10px); -o-transform: translateY(-10px); transform: translateY(-10px); }
#header .psBtn a:hover { text-decoration: none; -webkit-transform: translateY(0px); -moz-transform: translateY(0px); -ms-transform: translateY(0px); -o-transform: translateY(0px); transform: translateY(0px); }
#header .hdInr { margin: 0 auto; max-width: 1200px; width: 97%; padding: 25px 0; position: relative; }
#header .tagline { color: #FFF; font-size: 1.1rem !important; font-weight: normal; padding: 10px 0; }
#header .logo { float: left; text-align: center; width: 200px; }
#header .logo a { background-color: #448CBC; color: #FFF; display: block; float: left; padding: 30px; width: 200px; }
#header .hdR { background-color: #448CBC; color: #FFF; float: right; width: 600px; }
#header .hdR p { padding: 20px; }

#spHeader, .spMenu, .psBtnSp { display: none; }

/*gNav*/
#gNav { margin: 0 auto; max-width: 1000px; width: 97%; }
#gNav ul { width: 100%; overflow: hidden; }
#gNav ul li { float: left; text-align: center; width: 20%; }
#gNav ul li a { background-color: #F9F9F9; color: #448CBC; display: block; padding: 10px 0; }

#spNav, #spFixed { display: none; }

#fixedBtn { position: fixed; right: 0; top: 150px; z-index: 9999; }
#fixedBtn img { padding: 0; }

#fixedBtn02 { width: 100%; left: 0; bottom: 0; position: fixed; z-index: 9999; text-align: center; padding: 10px; background: rgba(255, 255, 255, 0.4); -webkit-transition: all .15s ease-in-out; -moz-transition: all .15s ease-in-out; -ms-transition: all .15s ease-in-out; -o-transition: all .15s ease-in-out; transition: all .15s ease-in-out; }
#fixedBtn02 img { padding: 0; }

/*mv*/
#mv { display: table; background-image: url(/images/mv.jpg); background-repeat: no-repeat; -webkit-background-size: cover; background-size: cover; background-position: center center; width: 100%; line-height: 0; height: calc(100vh - 92px); height: -webkit-calc(100vh - 92px); width: 100%; position: relative; }
#mv .mvInr { display: table-cell; vertical-align: middle; }

/*breadChumbs*/
#breadChumbs { margin: 0 auto; padding: 10px 0; max-width: 1200px; width: 97%; }
#breadChumbs p { font-size: 1.1rem !important; margin: 0 10px; }
#breadChumbs p a { display: inline-block; }
#breadChumbs p i { font-size: 120%; vertical-align: text-top; }

/*contents*/
#contents { margin: auto 0; width: 100%; overflow: hidden; }
#contents.wInr { max-width: 1200px; width: 97%; }

#main { background-color: #FFF; float: right; margin: 0 auto; max-width: 950px; width: 78%; }

/*sideNav*/
#sideNav { float: left; max-width: 200px; width: 20%; }
#sideNav h3 { background-color: #448CBC; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: 1px solid #448CBC; color: #FFF; display: block; margin-bottom: 1px; padding: 20px; text-decoration: none; }
#sideNav h3::before { content: attr(data-text); display: block; font-weight: normal; font-family: 'Josefin Sans', sans-serif; }
#sideNav ul { width: 100%; }
#sideNav ul li { margin-bottom: 1px; width: 100%; }
#sideNav ul li a { background-color: #448CBC; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: 1px solid #448CBC; color: #FFF; display: block; padding: 20px; text-decoration: none; }
#sideNav ul li a:hover { background-color: #FFF; color: #448CBC; }

/*footer*/
#footer { background: #7b6835; margin-top: 40px; width: 100%; color: #FFF; }
#footer .ftInr { margin: 0 auto; max-width: 1200px; width: 97%; }
#footer .ftInr .ftTagline { color: #FFF; font-size: 1.1rem !important; font-weight: normal; }

small#copyright { display: block; font-size: 1.3rem !important; padding: 10px 0; text-align: center; width: 100%; }

/*newsList*/
.newsList { overflow: hidden; }
.newsList li { overflow: hidden; margin-bottom: 30px; width: 100%; }
.newsList figcaption { font-weight: bold; font-size: 1.6rem; margin-bottom: 10px; line-height: 1.4; }
.newsList li .img { border: 1px solid #CCC; display: table; float: left; line-height: 0; margin-bottom: 10px; margin-right: 1em; height: 150px; width: 30%; }
.newsList li .img span { display: table-cell; vertical-align: middle; text-align: center; line-height: 0; }
.newsList li .img span img { max-height: 148px; max-width: 100%; line-height: 0; }
.newsList li a { display: block; height: 150px; overflow: hidden; position: relative; }
.newsList li a::before { background-color: #FFF; font-size: 1.8rem; bottom: 0; content: "…"; position: absolute; right: 0; }
.newsList li a::after { background-color: #FFF; content: ""; height: 100%; position: absolute; width: 100%; }
.newsList li .tx { line-height: 1.5 !important; }

/*文字数オーバー*/
/* indent
-------------------*/
.center { text-align: center !important; }

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

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

.top0 { margin-top: 0 !important; }

.top5 { margin-top: 5px !important; }

.top10 { margin-top: 10px !important; }

.top15 { margin-top: 15px !important; }

.top20 { margin-top: 20px !important; }

.top25 { margin-top: 25px !important; }

.top30 { margin-top: 30px !important; }

.top35 { margin-top: 35px !important; }

.top40 { margin-top: 40px !important; }

.btm0 { margin-bottom: 0 !important; }

.btm5 { margin-bottom: 5px !important; }

.btm10 { margin-bottom: 10px !important; }

.btm15 { margin-bottom: 15px !important; }

.btm20 { margin-bottom: 20px !important; }

.btm25 { margin-bottom: 25px !important; }

.btm30 { margin-bottom: 30px !important; }

.btm35 { margin-bottom: 35px !important; }

.btm40 { margin-bottom: 40px !important; }

.btm45 { margin-bottom: 45px !important; }

.btm50 { margin-bottom: 50px !important; }

.btm55 { margin-bottom: 55px !important; }

.btm60 { margin-bottom: 60px !important; }

.btm65 { margin-bottom: 65px !important; }

.btm70 { margin-bottom: 70px !important; }

.btm75 { margin-bottom: 75px !important; }

.btm80 { margin-bottom: 80px !important; }

.btm85 { margin-bottom: 85px !important; }

.btm90, .btm95 { margin-bottom: 90px !important; }

.pT0 { padding-top: 0 !important; }

.pT5 { padding-top: 5px !important; }

.pT10 { padding-top: 10px !important; }

.pT15 { padding-top: 15px !important; }

.pT20 { padding-top: 20px !important; }

.pT25 { padding-top: 25px !important; }

.pT30 { padding-top: 30px !important; }

.pT35 { padding-top: 35px !important; }

.pT40 { padding-top: 40px !important; }

.pT45 { padding-top: 45px !important; }

.pB0 { padding-bottom: 0 !important; }

.pB5 { padding-bottom: 5px !important; }

.pB10 { padding-bottom: 10px !important; }

.pB15 { padding-bottom: 15px !important; }

.pB20 { padding-bottom: 20px !important; }

.lm5 { margin-left: 5px !important; }

.lm10 { margin-left: 10px !important; }

.lm15 { margin-left: 15px !important; }

.lm20 { margin-left: 20px !important; }

.lm50 { margin-left: 50px !important; }

.lm60 { margin-left: 60px !important; }

.lm70 { margin-left: 70px !important; }

.rm5 { margin-right: 5px !important; }

.rm10 { margin-right: 10px !important; }

.rm15 { margin-right: 15px !important; }

.rm20 { margin-right: 20px !important; }

.vAT { vertical-align: top !important; }

.vAM { vertical-align: middle !important; }

.vAB { vertical-align: bottom !important; }

.bold { font-weight: bold; }

.normal { font-weight: normal; }

.is-pc { display: block; }

.is-sp { display: none; }

.spTel { pointer-events: none; }

.mincho { font-family: "Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; }

/* size
-------------------*/
.size10 { font-size: 1rem !important; }

.size11 { font-size: 1.1rem !important; }

.size12 { font-size: 1.2rem !important; }

.size13 { font-size: 1.3rem !important; }

.size14 { font-size: 1.4rem !important; }

.size15 { font-size: 1.5rem !important; }

.size16 { font-size: 1.6rem !important; }

.size17 { font-size: 1.7rem !important; }

.size18 { font-size: 1.8rem !important; }

.size19 { font-size: 1.9rem !important; }

.size20 { font-size: 2rem !important; }

.size21 { font-size: 2.1rem !important; }

.size22 { font-size: 2.2rem !important; }

.size23 { font-size: 2.3rem !important; }

.size24 { font-size: 2.4rem !important; }

/* wide
-------------------*/
.w5 { width: 5% !important; }

.w10 { width: 10% !important; }

.w15 { width: 15% !important; }

.w18 { width: 18% !important; }

.w20 { width: 20% !important; }

.w25 { width: 25% !important; }

.w30 { width: 30% !important; }

.w35 { width: 35% !important; }

.w40 { width: 40% !important; }

.w45 { width: 45% !important; }

.w50 { width: 50% !important; }

.w55 { width: 55% !important; }

.w60 { width: 60% !important; }

.w65 { width: 65% !important; }

.w70 { width: 70% !important; }

.w75 { width: 75% !important; }

.w80 { width: 80% !important; }

.w85 { width: 85% !important; }

.w90 { width: 90% !important; }

.w95 { width: 95% !important; }

.wFull { width: 100% !important; }

/* section
-------------------*/
section { clear: both; margin-bottom: 60px; }
section.last { margin-bottom: 0; }

.scInr, .scInrS { margin: 0 auto; max-width: 1000px; width: 97%; }

.scInrW { margin: 0 auto; max-width: 1400px; width: 97%; }

.aural span, span.aural { display: none; visibility: hidden; }

/* compo parts
-------------------*/
/*btn*/
.bscBtn01 a { background-color: #448CBC; border: 1px solid #448CBC; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; color: #FFF; display: inline-block; vertical-align: top; zoom: 1; /* Fix for IE7 */ *display: inline; /* Fix for IE7 */ padding: 13px 50px 10px; line-height: 140%; text-decoration: none; }
.bscBtn01 a:hover { background-color: #FFF; color: #448CBC; }
.bscBtn01 a i { margin-left: 0.5em; }

/*box*/
.bscBox01 { border: 1px solid #CCC; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 30px; }

.bscBox02 { background-color: #f9f7ec; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 5%; }

/*list*/
.indList, .indListS { margin-bottom: 15px; }

.indList li { line-height: 170%; text-indent: -1em; padding-left: 1em; margin-bottom: 5px; }

.indListS li { line-height: 170%; text-indent: -1em; padding-left: 1em; margin-bottom: 5px; font-size: 1.1rem !important; line-height: 130%; }

.indList li::before, .indListS li::before { content: '●'; font-size: 0.5em; margin-right: 5px; vertical-align: top; }

.numList, .numListS { margin-bottom: 15px; padding-left: 1.6em; }

.numList li { line-height: 150%; list-style: decimal outside none; margin-bottom: 5px; }

.numListS li { line-height: 150%; list-style: decimal outside none; margin-bottom: 5px; font-size: 1.1rem !important; line-height: 130%; }

/*head*/
h2.stitle { padding-bottom: 50px; }
h2.stitle img { max-width: 100%; }

.imgHead { font-size: 0; line-height: 0; }

.head01 { font-size: 2.4rem; text-align: center; margin-bottom: 30px; }
.head01::after { content: attr(data-text); font-size: 1.8rem; display: block; }

.head02 { border-left: 4px solid #448cbc; font-size: 2.0rem; margin-bottom: 20px; padding-left: 10px; }

.head03 { font-size: 1.7rem; margin-bottom: 20px; }
.head03::before { content: '■'; font-size: 1.3rem; margin-right: 5px; }

/*table*/
.bscTbl01 table { border-collapse: collapse; border-left: 1px solid #DDD; border-top: 1px solid #DDD; width: 100%; }
.bscTbl01 table th, .bscTbl01 table td { background-color: #FFF; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border-right: 1px solid #DDD; border-bottom: 1px solid #DDD; line-height: 1.4; padding: 20px 20px 17px; text-align: left; }
.bscTbl01 table th { background-color: #DDD; }
.bscTbl01 table tr.head th { background-color: #448CBC; color: #FFF; }

.tblScroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tblScroll table { -webkit-overflow-scrolling: touch; margin-bottom: 0; width: 1000px !important; }

/*float*/
.fltImgL { float: left; margin: 0 25px 20px 0; }

.fltImgR { float: right; margin: 0 0 20px 25px; }

.fltL { float: left; }

.fltR { float: right; }

.w100 { width: 100px; }

.w200 { width: 200px; }

.w300 { width: 300px; }

.w400 { width: 400px; }

.w450 { width: 450px; }

.w500 { width: 500px; }

.w600 { width: 600px; }

/*float-clear*/
.cf { zoom: 1; }
.cf:before { content: ""; display: table; }
.cf:after { content: ""; display: table; clear: both; }

br.clear, .clear { display: inline !important; display: none; clear: both; line-height: 0px; }

br.clear { clear: both; line-height: 0px; }

@media screen and (-webkit-min-device-pixel-ratio: 0) { br.clear { display: block !important; content: " "; } }
/*column*/
.clm4 { overflow: hidden; }
.clm4 li { float: left; margin-bottom: 20px; margin-right: 1.3%; width: 24%; }
.clm4 li:nth-child(4n) { margin-right: 0; }
.clm4 figcaption { font-weight: bold; font-size: 1.6rem; margin-bottom: 10px; line-height: 1.4; }

.clm3 { overflow: hidden; }
.clm3 li { float: left; margin-bottom: 20px; margin-right: 1.3%; width: 32.4%; }
.clm3 li:nth-child(3n) { margin-right: 0; }
.clm3 figcaption { font-weight: bold; font-size: 1.6rem; margin-bottom: 10px; line-height: 1.4; }

.clm2 { overflow: hidden; }
.clm2 li { float: left; margin-bottom: 20px; width: 48.5%; }
.clm2 li.even, .clm2 li:nth-child(2n) { float: right; }
.clm2 figcaption { font-weight: bold; font-size: 1.6rem; margin-bottom: 10px; line-height: 1.4; }

.clm4 li .img, .clm3 li .img, .clm2 li .img { border: 1px solid #CCC; display: table; line-height: 0; margin-bottom: 10px; height: 150px; width: 100%; }

.clm4 li .img span, .clm3 li .img span, .clm2 li .img span { display: table-cell; vertical-align: middle; text-align: center; line-height: 0; }

.clm4 li .img span img, .clm3 li .img span img, .clm2 li .img span img { max-height: 150px; max-width: 100%; line-height: 0; }

/* pager
-------------------*/
.pager { padding-top: 20px; text-align: center; }
.pager a { border: 1px solid #448CBC; color: #448CBC; display: inline-block; line-height: 1; margin: 0 2px; padding: 10px 12px; text-decoration: none; position: relative; }
.pager a:hover, .pager a.current { background-color: #448CBC; border: 1px solid #448CBC; color: #FFF; }
.pager a::after { content: attr(data-text); }
.pager a:last-child::after { display: none; }
.pager a:last-child::before { content: attr(data-text); }

/*topcontrol*/
#topcontrol { z-index: 900; }
#topcontrol a { background: url(../cmn_img/pagetop.png) center center no-repeat; background: url(../cmn_img/pagetop.png) center center no-repeat\9; /* IE8 */ *background: url(../cmn_img/pagetop.png) center center no-repeat; /* IE7 */ _background: url(../cmn_img/pagetop.png) center center no-repeat; /* IE6 */ display: block; height: 82px; width: 82px; filter: alpha(opacity=70) !important; opacity: 0.7 !important; -webkit-transition: all .3s ease-in-out; transition: all .3s ease-in-out; }
#topcontrol a:hover { filter: alpha(opacity=10) !important; opacity: 1 !important; -webkit-transform: scale(1.2); -moz-transform: scale(1.2); -ms-transform: scale(1.2); -o-transform: scale(1.2); transform: scale(1.2); }

/*roBtn*/
.roBtn:hover { filter: alpha(opacity=80); -moz-opacity: 0.8; opacity: 0.8; }

/* IE8 */
html > body .roBtn:hover { display: inline-block\9; zoom: 1\9; }

/* 新旧Firefox */
.roBtn:hover, x:-moz-any-link, .roBtn:hover { background: #fff; }

x:-moz-any-link, x:default { background: #fff; }

/* form
-------------------*/
.subscribeBtn { text-align: center; margin-bottom: 40px; }
.subscribeBtn input { background-color: #000; border: 1px solid #000; color: #FFF; display: inline-block; padding: 15px 100px 13px; line-height: 140%; text-decoration: none; -webkit-transition: all .3s ease-in-out; transition: all .3s ease-in-out; }
.subscribeBtn input:hover { background-color: #FFF; color: #000; }
.subscribeBtn input.gray { background-color: #666; border: 1px solid #666; color: #FFF; }
.subscribeBtn input.gray:hover { background-color: #ddd; color: #000; }

input { vertical-align: middle; }
input.textFocus { color: #333; }
input.wSS, input.wS, input.wM, input.wL, input.wLL { background-color: #FCFBF8; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: 1px solid #CCC; font-size: 1.3rem; line-height: 140%; padding: 8px 10px; }

.wSS { width: 85px; }

.wS { width: 170px; }

.wM { width: 270px; }

.wL { width: 470px; }

.wLL { width: 340px; }

.imeOn { ime-mode: active; }

.imeOff { ime-mode: disabled; }

textarea.txtarea { background-color: #FCFBF8; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: 1px solid #CCC; height: 200px; padding: 10px; width: 100%; }

option { font-size: 1.4rem !important; }

label { cursor: pointer; }
label:hover { color: #999; }

input[type="checkbox"], input[type="radio"] { margin-right: 3px; }

.formErr { color: #E54E52; font-weight: bold; }

select.slctArea { background-color: #FCFBF8; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; border: 1px solid #CCC; margin-bottom: 5px; padding: 8px; }

input.inputErr, textarea.inputErr { background-color: #FADFDE; }

input:focus, select:focus, textarea:focus { background-color: #EEE; }

.req { background-color: #a40000; color: #FFF; font-size: 1.1rem; margin-left: 3px; padding: 2px 5px; margin-right: 5px; vertical-align: middle; }

.errText { background-color: #fee8e6; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; color: #db584b; font-size: 1.1rem; padding: 3px 5px; margin-top: 5px; }

.cauText { color: #333; font-size: 1.1rem; line-height: 1.4 !important; margin-top: 5px; }

/* for SP
-------------------------------------------------------------------------------------*/
@media only screen and (max-width: 767px) { /* base contents -------------------*/
  /*header*/
  #header, #gNav { display: none; }
  #spHeader { background-color: #FFF; height: 60px; padding: 7px 3%; display: block; width: 100%; position: fixed; left: 0; top: 0; z-index: 980; }
  #spHeader .logo { padding-top: 7px; }
  #spHeader .logo img { height: 35px; width: auto; }
  #spHeader ul { overflow: hidden; zoom: 1; position: absolute; right: 55px; top: 16px; }
  #spHeader li { float: left; margin: 0 5px; text-align: center; }
  #spHeader li a { color: #FFF; font-size: 2.6rem; line-height: 1; }
  .spMenu, .psBtnSp { background: #A79C77; cursor: pointer; display: block; height: 60px; width: 60px; position: fixed; right: 0; top: 0; z-index: 1010; }
  .spMenu.psBtnSp, .psBtnSp.psBtnSp { background: none; text-align: center; right: 60px; }
  .spMenu.psBtnSp a, .psBtnSp.psBtnSp a { display: block; font-size: 11px; background-color: #01a89e; padding-top: 12px; color: #FFF; height: 60px; line-height: 1; text-decoration: none; }
  .spMenu.psBtnSp a i, .psBtnSp.psBtnSp a i { font-size: 1.5em; display: block; margin-bottom: 5px; }
  .spMenu span, .psBtnSp span { background-color: #FFF; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; display: inline-block; vertical-align: top; zoom: 1; /* Fix for IE7 */ *display: inline; /* Fix for IE7 */ height: 2px; width: 23px; position: absolute; left: 18px; -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1); transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1); }
  .spMenu small, .psBtnSp small { display: block; color: #FFF; /*font-family: 'Josefin Sans', sans-serif;*/ font-family: 'Playfair Display', serif; width: 100%; text-align: center; position: absolute; left: 0; bottom: 5px; }
  .spMenu span:nth-of-type(1), .psBtnSp span:nth-of-type(1) { top: 13px; }
  .spMenu span:nth-of-type(2), .psBtnSp span:nth-of-type(2) { top: 23px; }
  .spMenu span:nth-of-type(3), .psBtnSp span:nth-of-type(3) { top: 33px; }
  .spMenu.active, .psBtnSp.active { height: 60px; width: 60px; }
  .spMenu.active span, .psBtnSp.active span { background-color: #000; }
  .spMenu.active span:nth-of-type(1), .psBtnSp.active span:nth-of-type(1) { -webkit-transform: translateY(10px) rotate(-45deg); transform: translateY(10px) rotate(-45deg); }
  .spMenu.active span:nth-of-type(2), .psBtnSp.active span:nth-of-type(2) { opacity: 0; }
  .spMenu.active span:nth-of-type(3), .psBtnSp.active span:nth-of-type(3) { -webkit-transform: translateY(-10px) rotate(45deg); transform: translateY(-10px) rotate(45deg); }
  .spMenu.active small, .psBtnSp.active small { color: #000; }
  /*spNav*/
  #spNav { height: 100%; display: block; transition: all 550ms ease 0.25s; visibility: hidden; padding-top: 59px; width: 80%; position: fixed; right: -100%; top: 0; z-index: 990; }
  #spNav.active { visibility: visible; right: 0; }
  #spNav #spBg { background: rgba(0, 0, 0, 0.5); height: 100%; width: 500%; position: fixed; right: -50%; top: 0; z-index: -1; opacity: 0; transition: all 550ms ease 0.25s; pointer-events: none; }
  #spNav.active #spBg { right: 0; opacity: 1; pointer-events: auto; }
  #spNav::after { background: rgba(255, 255, 255, 0.8); background-color: #f9f9f9; content: ""; height: 100%; left: 0; position: absolute; top: 0; width: 100%; z-index: -1; }
  #spNav::before, #spNav::after { opacity: 0; transition: all 550ms ease 0.25s; }
  #spNav.active::before, #spNav.active::after { opacity: 1; }
  #spNav .closeBtn { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; padding: 15px 3%; text-align: right; }
  #spNav nav { border-top: 1px solid #FFF; }
  #spNav nav ul li { border-bottom: 1px solid #FFF; float: left; width: 50%; }
  #spNav nav ul li.even { border-left: 1px solid #FFF; }
  #spNav nav ul li a { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; color: #666; font-size: 1.1rem; font-weight: bold; text-align: center; display: block; padding: 15px 10px; }
  #spNav nav ul li a::before { color: #000; content: attr(data-text); display: block; font-size: 1.5rem; font-weight: normal; /*font-family: 'Josefin Sans', sans-serif;*/ font-family: 'Playfair Display', serif; margin-bottom: 5px; }
  #spNav nav ul li a:hover { background-color: #448CBC; color: #FFF; text-decoration: none; }
  #spNav nav ul li a:hover::before { color: #FFF; }
  /*breadChumbs*/
  #breadChumbs { display: none; }
  /*mv*/
  #mv { background-position: 65% center; }
  #mv div.mvInr { margin: 0 3%; width: auto; }
  /*contents*/
  #contents { margin: 0 auto; /*padding-top: 40px;*/ width: 100%; }
  #contents section { padding: 30px 0 20px; }
  #contents p, #contents li { font-size: 14px; }
  #main { float: none; margin: 0 3%; width: auto; }
  #sideNav { float: none; margin: 40px 3% 0; max-width: 100%; width: auto; }
  /*footer*/
  #footer { background-color: #696969; margin: 40px 0 0; width: 100%; }
  #footer div.ftInr { margin: 0 3%; width: auto; }
  small#copyright { font-size: 1rem !important; padding: 10px 0; text-align: center; width: 100%; }
  /*newsList*/
  .newsList li .img { height: 100px; }
  .newsList li .img span img { max-height: 100px; }
  .newsList li a { height: 102px; }
  .newsList li .tx { line-height: 1.5 !important; } }
@media only screen and (max-width: 767px) and (max-width: 640px) { .newsList li .img { float: none; width: 100%; }
  .newsList li .img span img { max-height: 100px; }
  .newsList li a { height: auto; }
  .newsList li a::before, .newsList li a::after { display: none; }
  .newsList li .tx { line-height: 1.5 !important; display: block; height: 60px; overflow: hidden; position: relative; }
  .newsList li .tx::before { background-color: #fff; bottom: 0; content: "…"; position: absolute; right: 0; }
  .newsList li .tx::after { background-color: #fff; content: ""; height: 100%; position: absolute; width: 100%; } }
@media only screen and (max-width: 767px) { /* indent -------------------*/
  body { margin-top: 60px; padding-top: 0; }
  .is-sp { display: block !important; }
  .is-pc { display: none !important; }
  .spImg { max-width: 100%; }
  a.spTel { color: #448cbc; pointer-events: auto; text-decoration: underline; }
  /* section -------------------*/
  section { margin-bottom: 50px; }
  .scInr, .scInrS, .scInrW { float: none; margin: 0 3%; width: auto; }
  /* compo parts -------------------*/
  /*btn*/
  .bscBtn01 a { display: block; padding: 20px 5%; margin-bottom: 10px; text-align: center; width: 100%; }
  /*box*/
  .bscBox01, .bscBox02 { padding: 5%; }
  /*table*/
  .bscTbl01 th, .bscTbl01 td { display: block; font-size: 1.1rem; padding: 10px 3%; width: 100% !important; }
  .bscTbl01.scroll th, .bscTbl01.scroll td { display: table-cell; }
  .tblScroll { padding-bottom: 5px; }
  .tblScroll::before { content: '※横スクロールができます。'; display: block; margin-bottom: 10px; }
  /*float*/
  .fltL, .fltR { float: none; }
  .fltImgL, .fltImgR { float: none; margin: 0; text-align: center; }
  .fltImgL img, .fltImgR img { max-width: 100%; margin-bottom: 5px; }
  br.clear_noie.spHide, div.clear_noie.spHide { display: none !important; }
  /*column*/
  .clm4 li { float: left; margin-right: 0; width: 48.5%; }
  .clm4 li.even, .clm4 li:nth-child(2n) { float: right; }
  .clm4 li:nth-child(4n) { margin-right: 0; }
  .clm3 li { float: left; margin-right: 0; width: 48.5%; }
  .clm3 li.even, .clm3 li:nth-child(2n) { float: right; }
  .clm4 li .img, .clm3 li .img, .clm2 li .img { height: 100px; }
  .clm4 li .img span img, .clm3 li .img span img, .clm2 li .img span img { max-height: 100px; }
  /*topcontrol*/
  #topcontrol { display: none; left: 0 !important; bottom: 0 !important; height: 40px; width: 100%; }
  #topcontrol a { display: block; height: 100%; padding: 10px 0; width: 100%; }
  /* pager -------------------*/
  .pager a::before, .pager a::after { display: none; }
  /* form -------------------*/
  .subscribeBtn input { padding: 15px 0 13px; margin-top: 5px; width: 100%; }
  input.wSS, input.wS, input.wM, input.wL, input.wLL { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
  .wSS { width: 30%; }
  .wS { width: 50%; }
  .wM, .wL, .wLL { width: 100%; }
  .imeOn { ime-mode: active; }
  .imeOff { ime-mode: disabled; }
  textarea.txtarea { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; height: 200px; width: 100%; }
  select.timearea { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 50%; }
  option { font-size: 1.4rem !important; }
  label { cursor: pointer; }
  label:hover { color: #999; }
  input[type="checkbox"], input[type="radio"] { margin-right: 3px; }
  .formErr { color: #E54E52; font-weight: bold; }
  input.inputErr, textarea.inputErr { background-color: #FADFDE; }
  .req { color: #FFF; font-size: 10px; line-height: 100%; margin-left: 3px; padding: 2px 5px; margin-right: 5px; vertical-align: middle; }
  .cauText { display: block; } }
/*SP END*/
