@charset "utf-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url("css/add.css");


/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
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, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-size: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}

ol, ul {list-style: none;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
a img {border: 0;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}

body{
font-family: "メイリオ", Meiryo, Arial, Roboto, "Droid Sans", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
font-family: 'Noto Sans Japanese', sans-serif;
font-size: 87.5%;
line-height: 1.5;
color:#333333;
}

div.gray_box {
 padding:1em;
 background:#e4e4e4;
}
div.yellow_box {
 padding:1em;
 background:#fbf2ce;
 border:1px solid #222;
}
.page ol li, .archive ol li, .single ol li {
padding:0;
}

/* リンク設定
------------------------------------------------------------*/
a{
margin:0;
padding:0;
text-decoration:none;
outline:0;
vertical-align:baseline;
background:transparent;
font-size:100%;
color:#624e24;
}

a:hover, a:active{
outline: none;
color:#927a49;
}

a:hover img {
  opacity: .8;
}


/**** Clearfix ****/
.nav .panel:before,nav .panel:after, nav#mainNav:before,nav#mainNav:after, .newsTitle:before,.newsTitle:after{content: ""; display: table;}
nav .panel:after,nav#mainNav:after,.newsTitle:after{clear: both;}
nav .panel,nav#mainNav,.newsTitle{zoom: 1;}


/* フォーム
------------------------------------------------------------*/
input[type="text"],input[type="email"], textarea{
vertical-align:middle;
max-width:90%;
font-size: 100%;
line-height:30px;
height:30px;
padding:1px 5px;
border:1px solid #d4d4d7;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
color:#555;
background:#fcfcfc;
}

textarea{
height:auto;
line-height:1.5;
}

input[type="submit"],input[type="reset"],input[type="button"]{
padding:10px 50px;
background: #4f4d4d;
border:0;
color:#fff;
}

input[type="submit"]:hover,input[type="reset"]:hover,input[type="button"]:hover{
background: #808080;
cursor:pointer;
}

*:first-child+html input[type="submit"]{padding:3px;}


/* レイアウト
------------------------------------------------------------*/
.inner{
margin:0 auto;
width:1060px;
}

#header{
  overflow:hidden;
  padding:15px 0;
}

#wrapper {
  overflow: hidden;
  padding: 30px 0;
}

.home #wrapper {
  padding: 30px 0 0;
}

.home #content{
width:100%;
box-sizing:border-box;
}

#content {
  float:right;
  width: 68%;
}

#sidebar{
float:left;
width:28%;
}

#footer{
clear:both;
background: #aaa;
padding: 15px 0;
color: #fff;
}


/* ヘッダー
*****************************************************/

/* サイト説明文
----------------------------------*/
/*
#header h1{
padding:5px 0;
color: #333333;
font-size:87.5%;
font-weight:normal;
text-align: right;
}
*/


/* ロゴ (サイトタイトル)
----------------------------------*/
#header h1{
clear:both;
float:left;
color: #333333;
font-size:160%;
font-weight:bold;
}

/* トップページ　スライド画像
----------------------------------*/
#mainImg{
line-height:0;
text-align:center;
margin: 0 auto;
z-index:0;
position: relative;
max-width: 1060px;
overflow: hidden;
}


/* タイポグラフィ
*****************************************************/
h2.title{
clear:both;
margin:0px 0 20px;
padding:10px 0 10px 10px;
font-size:130%;
color: #252525;}

h2.first{margin-top:0;}



h3 {
  font-size: 130%;
}

ul.thumb {
  margin-bottom: 30px;
}

ul.thumb li {
  padding: 10px 0;
  border-bottom: 1px solid #333333;
}

ul.thumb li time {
  margin-right: 3em;
}

.post p{padding-bottom:10px;}

.post a {
  text-decoration: underline;
}

.page-id-40 .post a {
  text-decoration: none;
}

.post a:hover {
  text-decoration: none;
}

.post ol li{list-style:decimal;}

.post ul li {
  padding: 5px 0;
  margin: 5px 0;
}

.post ul li a {
  border-bottom: 1px solid #2c75d9;
  padding-left: 2em;
  background: url(images/arrow.png) no-repeat 5px center;
  background-size: 15px;

}

.post ul li ul {
  padding-left: 2em;
}

.post ul li ul li {
  display: inline-block;
  width: 24%;
}

.post h2{
margin-bottom: 1em;
padding:5px 0;
font-size:1.8em;
color: #2c75d9;
padding: 0.5em 0;
border-top: solid 3px #2c75d9;
border-bottom: solid 3px #2c75d9;
}

.post h3{
  position: relative;
      margin-bottom: 1em;
      margin-top: 1em;
      color: #222;
      font-size: 1.4em;
      font-weight: bold;
      padding: .5em 0 .5em .75em;
      text-shadow: 2px 1px 1px #eee;
      background: #c3ccda;
      border-radius: 5px;
}

.post h3::before {
  content: "\f0c4";
  font-family: "fontawesome";
  margin-right: .5em;
}

.post h4{
  border-bottom: solid 3px #d9c7ad;
  position: relative;
  font-size: 1.2em;
  margin-bottom: 1em;
  padding: 5px 0;
}

.post h4:after {
  position: absolute;
content: " ";
display: block;
border-bottom: solid 3px #2c75d9;
bottom: -3px;
width: 20%;
}

.post table{
width: 100% !important;
border: 1px #2e2c2c solid;
border-collapse: collapse;
border-spacing: 0;
margin:10px 0 20px;
}

.post table th{
padding:10px;
border: #2e2c2c solid;
border-bottom: 1px solid #fff;
border-width: 0 0 1px 1px;
font-weight:bold;
color:#fff;
text-align: center;
background:#2c75d9;
}

.post table tr:last-child th {
  border-bottom: 0;
}

.post table td{
padding:10px;
border: 1px #2e2c2c solid;
border-width: 0 0 1px 1px;
background:#fff;
}

.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;}

.post img{max-width:100%;height:auto;}

img.aligncenter {
display: block;
margin:5px auto;
}

img.alignright, img.alignleft{
padding:4px;
margin:0 0 2px 7px;
display:inline;
}

img.alignleft{margin: 0 7px 2px 0;}

.alignright{float:right;}
.alignleft{float: left;}



/* サイドバー　ウィジェット
*****************************************************/
#sidebar {
      box-shadow: 0px 5px 20px 0px rgba(0,0,0,0.1);
}
#sidebar h3{
  font-weight: bold;
  font-weight: 1.2em;
  padding: .5em;
  border-bottom: 3px solid #c3ccda;
  box-sizing: border-box;
}

#sidebar ul {
  background: #ededed;
  padding-bottom: 0;
}

#sidebar ul li {
  padding: .5em;
  border-bottom: 1px solid #fff;
  background: url(images/r_arrow2.png) no-repeat 95% center;
  background-size: 3%;
  transition: .5s all ease;
}

#sidebar ul li:last-child {
  border-bottom: 0;
}

#sidebar ul li:hover {
  background: url(images/r_arrow2.png) no-repeat 98% center;
  background-size: 3%;
}

#sidebar a{
display:block;
color: #333;
}

/* 更新情報
-------------*/

.news p{
clear:both;
padding-bottom:2px;
border-bottom: 1px solid #bab48d;
}

.news p a{
display:block;
padding:5px 0;
color:#252525;
}

.news span{padding-left:10px;}

.news a:hover span{color:#927a49;}



/* フッター
*****************************************************/
#footerLogo{
width:250px;
margin: 0 auto;
padding-top: 15px;
}

#footerLogo img{
display: block;
max-width:250px;
height:auto;
margin: 0 auto;
}

#footer .f_top {
  padding:10px 0;
  background: #ccc;
}

#footer .f_bottom {
  padding: 10px 0;
  background:#8c8c8c;
}

#footer ul{
font-size:95%;
display: inline-block;
padding-bottom: 0;
}

#footer ul ul{padding-bottom:0;width:auto;}

#footer ul li{
display:inline-block;
vertical-align:text-top;
text-align:left;
padding:3px 20px;
background:url(images/arrow_white.png) no-repeat left center;
background-size: 15px;
}

#footer ul li a{
display:block;
overflow:hidden;
text-decoration: underline;
color: #fff;
}

#footer ul li a:hover {
  text-decoration: none;
}

*:first-child+html #footer ul li{display:inline;}
*:first-child+html #footer ul ul,*:first-child+html #footer ul li li a,*:first-child+html #footer ul li li{display:none;}

#copyright{
clear:both;
padding:5px;
text-align:right;
font-style:normal;
font-size:85%;
display: inline-block;
float: right;
zoom:1;
}


/* page navigation
------------------------------------------------------------*/
.pagenav{
clear:both;
width: 100%;
height: 30px;
margin: 5px 0 20px;
}

.prev{float:left}

.next{float:right;}

#pageLinks{
clear:both;
color:#4f4d4d;
text-align:center;
}


/* トップページ 最新記事3件 + お勧め商品
------------------------------------------------------------*/
.thumbWrap{
width:645px;
margin-right:-20px;
}

.thumbWrap li{
float:left;
width: 195px;
margin:0 20px 0 0;
padding:2px 0 40px;
background:none;
}


/* 最新記事リンク */
ul.thumb h3{
margin-top:10px;
padding:1px;
font-weight:normal;
font-size:100%;
text-align:center;
background:#fff;
border:1px solid #bcbcbc;
}

ul.thumb h3 span{
display:block;
padding:2px 3px;
background:#dedabc;
}

ul.thumb h3:hover{background:#f1efe4;}

ul.thumb h3:hover span{background:#e3dfc4;}

/*flex_box*/
div.flex_box, .flex_box {
	overflow: hidden;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack:justify;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
div.flex_box > div, .flex_box > div {width: 48%;}
div.flex_box > div.thcal, .flex_box > div.thcal {width: 33%;}
div.flex_box > div.focal, .flex_box > div.focal {width: 25%;}


/* 調整 */
img { vertical-align: middle;}
strong { font-weight: bold;}
a:hover img { opacity: 0.8;}
.contactInfo { float: right;}
ul.c_banner {overflow: hidden;}
ul.c_banner li {float: left;}
ul.c_banner li:first-child {margin-right: 20px;}
ul.s_banner li {margin-bottom: 20px;}

/*!追加*/
.post span.small {
  font-size: .75em;
}

img {
  max-width: 100%;
}

iframe {
  width: 100%;
}

/* .single .post br {
  display: none;
} */

.single .post table br {
}

.single .post table a {
  text-decoration: underline;
  color: #d9392d;
}

.single .post table a:hover {
  text-decoration: none;
}

.single .post table th {
  width: 20%;
}

ul.side-list li.post-251,
ul.side-list li.post-253,
ul.side-list li.post-46,
ul.side-list li.post-349 {
  display: none !important;
}

div.flex_box.illust-area {
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}

div.flex_box > div.flex.flex4 {
  width: 24%;
  margin-bottom: 15px;
}

div.flex_box > div.flex.flex4 .illust-img {
  min-height: 100px;
}

div.flex_box > div.flex.flex4 img {
  max-height: 100px;
  width: auto;
}


/*common*/
.center {text-align: center;}
.posi_rel {position: relative;}
.posi_ab {position: absolute;}
.bold {font-weight: bold;}



/* メインメニュー PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
  nav#mainNav{
  clear:both;
  position:relative;
  z-index:200;
  }

  .panel ul{
  }

  .panel ul li{
  float: left;
  position: relative;
  width: 14.2%;
  height:50px;
  line-height:50px;
  border-left: 1px dotted #ccc;
  box-sizing: border-box;
  }

  .panel ul li:last-child {
    border-right: 1px solid #ccc;
    line-height: 1.5;
  }

  .panel ul li a{
  display: block;
  text-align: center;
  color:#333;
  }

  nav div.panel{
  width: 100%;
  display:block !important;
  float:left;
  }

  a#menu{display:none;}

  /* 親メニュー */
  .panel ul li.current-menu-item a, .panel ul li a:hover, .panel ul li a:active, .panel ul li.current-menu-parent a{
    color: #2c75d9;
  }

  .panel ul li.current-menu-item a::after, .panel ul li a:hover::after, .panel ul li a:active::after, .panel ul li.current-menu-parent a::after{
    position: absolute;
    content:"";
    width: 0;
	  height: 0;
    bottom: -8%;
    left:0;
    right: 0;
    margin: auto;
	  border: 6px solid transparent;
	  border-top: 6px solid #2c75d9;
  }
  .panel ul ul{width:160px;}

  .panel ul li ul{display: none;}

  .panel ul li li{
  float: none;
  height:40px;
  line-height:40px;
  width:160px;
  padding:0;
  }

  .panel ul li:hover ul{
  display: block;
  position: absolute;
  top:40px;
  left:-7px;
  z-index:500;
  }

  .panel ul li li a{
  width:100%;
  height:40px;
  padding:0;
  line-height:40px;
  font-size:95%;
  text-align:left;
  }

  .panel ul li li a span{padding:0 10px;}

  .panel ul li li a:hover,.panel ul li li.current-menu-item a{color:#fff;}

  .panel ul li:hover ul li{
  margin:0;
  background: #2d2c2d;
  border-bottom:1px dotted #4f4d4d;
  }

  .panel ul li:hover ul li:last-child{
  border:0;
  border-radius:0 0 6px 6px;
  }
}


/* メインメニュー iPadサイズ以下から
------------------------------------------------------------*/
@media only screen and (max-width:1024px){
  nav#mainNav{
  display: none;
  clear:both;
  width:100%;
  margin:0 auto;
  padding:20px 0;
  background:#242223;
  }

  nav#mainNav .inner{width:95%;}

  nav#mainNav a.menu{
  width:100%;
  display:block;
  height:40px;
  line-height:40px;
  font-weight: bold;
  text-align:left;
  color:#fff;
  background: #473a1c;
  border:1px solid #726749;
  }

  nav#mainNav a#menu span{padding-left:2.5em;}

  nav#mainNav a.menuOpen{
  border-bottom:0;
  color:#fff;
  background: #473a1c;
  }

  nav#mainNav a#menu:hover{cursor:pointer;}

  nav .panel{
  display: none;
  width:100%;
  position: relative;
  right: 0;
  top:0;
  z-index: 1;
  border:1px solid #726749;
  }

  .panel ul{margin:0;padding:0;}

  .panel ul li{
  float: none;
  clear:both;
  width:100%;
  height:auto;
  line-height:1.2;
  }

  .panel ul li a,.panel ul li.current-menu-item li a{
  display: block;
  width:100%;
  padding:1em 0;
  text-align:left;
  color:#b6a68a;
  background:#2d2c2d;
  }

 .panel ul li a span{padding-left:1em;}

  .panel ul li.current-menu-item a,.panel ul li a:hover,.panel ul li.current-menu-item a,.panel ul li a:active, .panel ul li li.current-menu-item a, .panel ul li.current-menu-item li a:hover, .panel ul li.current-menu-item li a:active{
  color:#fff;
  background:#181616;
  }

  .panel ul li li{
  float:left;
  border:0;
  }

  .panel ul li li a, .panel ul li.current-menu-item li a, .panel ul li li.current-menu-item a{background:#2d2c2d url(images/sub1.png) no-repeat 20px 50%;}

  .panel ul li li a:hover, .panel ul li.current-menu-item li a:hover{background:#181616 url(images/sub1.png) no-repeat 20px 50%;}

  .panel ul li li:last-child a{background:#2d2c2d url(images/subLast.png) no-repeat 20px 50%;}
  .panel ul li li:last-child a:hover,.panel ul li.current-menu-item li:last-child a:hover{background:#181616 url(images/subLast.png) no-repeat 20px 50%;}

  .panel ul li li a span{padding-left:35px;}

  nav div.panel{float:none;}

  /* 追加 */
  .inner {
    width: 95%;
  }

  li.responsive-menu-item .responsive-menu-item-link br {
    display: none;
  }

  #mainImg p.catchcopy {
    padding: 10em 0;
    top:15%;
  }

  .section.t-access .t-contact {
    padding: 3em;
  }

  .section.t-access .t-contact span.tel {
    font-size: 2em;
  }
}


/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
  #wrapper, #header{width:100%;}

  #header h1, #header h2{padding:10px;}
  #headerInfo{padding-right:10px;}

  .panel ul, .thumbWrap{margin:0 auto;}
  .panel ul ul{padding:0;}

  nav div.panel{float:none;}

  #mainImg img{width:98%;height:auto;}

  #content, #sidebar{
  width: 95%;
  clear:both;
  float:none;
  margin:0 auto;
  }

  #banners{width:100%;margin:0 auto;text-align:center;}
  #banners p{width:30%; float:left;margin:0 1% 0 2%;}
  #banners p img{width:100%;height:auto;}

  section.widget_search{text-align:center;}
  #contactBanner{margin:0 auto;}

  #footer{margin:0;border:0;text-align:center;}

  #footerLogo, #footer ul{
  float:none;
  width:auto;
  padding-bottom:20px;
  text-align:center;
  }

  #footer ul{
  padding-top:20px;
  border-top:1px solid #ccc;
  }

  #footer ul ul{padding-top:0;border:0;}

  /* 調整 */
  img {
    max-width: 100%;
  }

  #header {
    padding: 10px;
    box-sizing:border-box;
  }

  #header h1,#header h2,.contactInfo {
    margin-bottom: 10px;
  }

  #header h1 {
    text-align: center;
    padding: 0;
  }
  .contactInfo {
    float: none;
  }

  #content {
    background: none;
    margin-bottom: 30px;
  }

  ul.c_banner li{
    float: none;
    margin-bottom: 20px;
  }

  ul.c_banner li:first-child {
    margin-right: 0;
  }

  ul.c_banner li img,#sidebar img {
    display: block;
    margin: 0 auto;
  }

  /* 追加 */
  #header h1 {
    float: none;
  }
  #mainImg p.catchcopy {
    padding: 8em 0;
    top:13%;
    font-size: 1em;
  }

  .contactInfo {
    text-align: center;
  }

  .section.t-about {
    background: url(images/bg01.png) no-repeat;
    background-size: cover;
    margin-bottom: 2em;
  }
  .section#third {
    background: url(images/bg03.png) no-repeat;
    background-size: cover;
    margin-bottom: 2em;
  }

  .section.t-about .inner-box .inner-text {
    width: 80%;
    height: 100%;
    left:0;
    right: 0;
  }

  .section.t-torikumi {
    background: url(images/bg02.png) no-repeat right center;
    background-size: cover;
  }

  .tab-none {
    opacity: 0;
  }

  .section.t-torikumi .inner-box .inner-text {
    width: 80%;
    height: 100%;
    left:0;
    right: 0;
  }

  .section.t-access .t-contact div.flex_box > div{
    width: 100%;
    text-align: center;
    margin: 10px 0;
  }

  /* 追加CSS */
  #sidebar {
    margin-bottom: 30px;
  }
  #sidebar ul.side-list {
    display: none;
  }

  #sidebar ul li {
    background-size: 12px;
  }

}


/* 幅648px以下から  トップページの３画像調節
------------------------------------------------------------*/
@media only screen and (max-width: 667px){
  .thumbWrap{width:100%;margin:0 auto;text-align:center;}
  .thumbWrap ul.thumb li{width:30%; float:left;margin:0 1% 0 2%;}
  .thumbWrap img{width:100%;height:auto;}

  /* 追加 */
  #mainImg p.catchcopy {
    background-size: contain;
    padding: 6em 0;
  }

  .tab-none {
    display: none;
  }

  .section.t-about .inner-box .inner-text,
  .section.t-torikumi .inner-box .inner-text {
    position: static;
  }

  .section.t-access .map {
    margin-bottom: 2em;
  }

  .section.t-access .t-contact {
    width: 100%;
  }

  /* 下層追加CSS */
  .page h2.title.first, .archive h2.title.first, .single h2.title.first {
    font-size: 1.5em;
  }

  #sidebar h3 {
    background: url(images/b_arrow.png) no-repeat 95% center;
    background-size: 20px;
  }

  #sidebar h3.active {
    background: url(images/t_arrow.png) no-repeat 95% center;
    background-size: 20px;
  }
  .post table td {
    padding: 5px 3px !important;
  }
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
  #header{text-align:center;}
  #header h2,#footerLogo,#headerInfo{float:none;padding:0;}
  #headerInfo{width:250px;margin:0 auto;}
  img.alignright, img.alignleft{display: block; margin:5px auto;}
  .alignright,.alignleft{float:none;}
  #footer ul{text-align:left;padding:15px;}
  #footer ul ul{padding:0;}
}

/* スマホ用 */
@media only screen and (max-width: 599px) {
  .post .scroll {
    overflow: auto;
  }

  .post .scroll table {
    width: 700px;
  }

  .page-id-431 div.flex_box > div {
    width: 100%;
  }

  #mainImg p.catchcopy {
    position: static;
    width: 80%;
    margin-top: 2em;
  }

  #header a.h-con {
    margin-top: 10px;
  }

  .section.greeting {
    padding-top: 0;
  }

  .section.t-about .inner-box .inner-text, .section.t-torikumi .inner-box .inner-text {
    width: 95%;
  }

  .section.t-access .t-contact {
    padding: 1em;
  }

  #copyright {
    font-size: 75%;
  }

  .post h3 {
    font-size: 1.2em;
  }

  .page-id-52 div.flex_box > div,
  .page-id-52 div.flex_box > div {
    width: 100%;
  }

  .single .post table th,
  .single .post table td {
    width: 100% !important;
    display: block;
    box-sizing: border-box;
  }


}
