@charset "utf-8";

/* =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:90%/1.5 "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
color:#333;
-webkit-text-size-adjust: none;
}


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

a:hover, a:active{
-webkit-transition:opacity 1s;-moz-transition:opacity 1s;-o-transition:opacity 1s;
outline: none;
color:#5f91ca;
}

@media only screen and (min-width: 960px){
  a img:hover{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"], textarea{
vertical-align:middle;
max-width:90%;
line-height:30px;
height:30px;
padding:1px 5px;
border:1px solid #d4d4d7;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
font-size:100%;
color:#555;
background:#fcfcfc;
}

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

input[type="submit"],input[type="reset"],input[type="button"]{
padding:3px 10px;
background: #044f82;
background: -moz-linear-gradient(top, #2e669c 0%, #044f82 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#2e669c), color-stop(100%,#044f82));
background: -webkit-linear-gradient(top, #2e669c 0%,#044f82 100%);
background: -o-linear-gradient(top, #2e669c 0%,#044f82 100%);
background: -ms-linear-gradient(top, #2e669c 0%,#044f82 100%);
background: linear-gradient(to bottom, #2e669c 0%,#044f82 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2e669c', endColorstr='#044f82',GradientType=0 );
border:0;
border-radius:3px;
-webkit-border-radius:3px;
-moz-border-radius:3px;
line-height:1.5;
font-size:100%;
color:#fff;
}

input[type="submit"]:hover,input[type="reset"]:hover,input[type="button"]:hover{
background: #044f82;
background: -moz-linear-gradient(top, #044f82 0%, #2e669c 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#044f82), color-stop(100%,#2e669c));
background: -webkit-linear-gradient(top, #044f82 0%,#2e669c 100%);
background: -o-linear-gradient(top, #044f82 0%,#2e669c 100%);
background: -ms-linear-gradient(top, #044f82 0%,#2e669c 100%);
background: linear-gradient(to bottom, #044f82 0%,#2e669c 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#044f82', endColorstr='#2e669c',GradientType=0 );
}

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


/* レイアウト
------------------------------------------------------------*/
#wrapper, .inner{
margin:0 auto;
width:940px;
}

#header{overflow:hidden;}

#content{
float:right;
width:625px;
padding:30px 0;
}

#sidebar{
float:left;
width:265px;
padding:30px 0;
}

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


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

/* サイト説明文
----------------------------------*/
#header h1{
padding:10px 0 0 3px;
color: #2e669c;
font-size:90%;
font-weight:normal;
}


/* ロゴ (サイトタイトル)
----------------------------------*/
#header h2{
clear:both;
float:left;
padding-top:20px;
color: #2e669c;
font-size:160%;
font-weight:bold;
}
#header h2 img{
  width: auto;
  height: 51px; /* 画像の高さ */
}
@media only screen and (max-width: 644px){
  #header h2 img{
    max-width: 170px; /* 画像の横幅 */
    width: 100%;
    height: auto;
    margin-right: 100px;
  }
}


/* コンタクトインフォメーション
----------------------------------*/
#headerInfo{
float:right;
text-align:left;
padding-top:10px;
}

#headerInfo p{
padding:2px 0 2px 80px;
color:#2e669c;
font-size:12px;
font-weight:bold;
background:url(images/openTime.png) no-repeat 0 2px;
}

#headerInfo p.tel{background:url(images/tel.png) no-repeat 0 4px;font-size:16px;}

#headerInfo p.address{background-image:url(images/address.png);}

#headerInfo p.contact{background:url(images/contact.png) no-repeat 0 2px;font-size:13px;}


/* トップページ　メイン画像
----------------------------------*/
#mainImg{
line-height:0;
text-align:center;
z-index:0;
}


/* タイポグラフィ
*****************************************************/
h2.title{
clear:both;
margin:30px 0 20px;
padding:7px 0 5px 25px;
font-size:110%;
color: #044f82;
border-bottom:1px solid #ccc;
background:url(images/headingBg.png) no-repeat 0 50%;
}

h2.first{margin-top:0;}

.dateLabel{
margin:-10px 0 10px;
text-align:right;
font:italic 1em "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

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

.post ul{margin: 0 0 10px 10px;}

.post ul li{
margin-bottom:5px;
padding-left:15px;
background:url(images/bullet.png) no-repeat 0 8px;
}

.post ol{margin: 0 0 10px 30px;}

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

.post h1{
margin:20px 0;
padding:7px 0 5px 25px;
font-size:150%;
color: #044f82;
border-bottom:1px solid #ccc;
background:url(images/headingBg.png) no-repeat 0 50%;
}

.post h2{
margin:10px 0;
padding-bottom:2px;
font-size:130%;
font-weight:normal;
color: #044f82;
border-bottom:2px solid #2e669c;
}

.post h3{
margin:10px 0;
font-size:120%;
font-weight:normal;
color:#2e669c;
border-bottom:1px solid #2e669c;
}

.post blockquote {
clear:both;
padding:10px 0 10px 15px;
margin:10px 0 25px 30px;
border-left:5px solid #ccc;
}
 
.post blockquote p{padding:5px 0;}

.post table{
border: 1px #2e669c solid;
border-collapse: collapse;
border-spacing: 0;
margin:10px 0 20px;
}

.post table th{
padding:7px 10px 7px 5px;
border: #2e669c solid;
border-width: 0 0 1px 1px;
font-weight:bold;
color:#fff;
background:#5f91ca;
}

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

.post dt{font-weight:bold;}

.post dd{padding-bottom:10px;margin-left: 1em;}

.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;}



/* サイドバー　ウィジェット
*****************************************************/
section.widget{
padding-bottom:20px;
margin-bottom:20px;
}

section.widget h3{
clear:both;
margin:0 0 10px;
padding:7px 0 5px 20px;
font-size:100%;
font-weight:normal;
color: #044f82;
border-bottom:1px solid #ccc;
background:url(images/heading2Bg.png) no-repeat 0 50%;
}

section.widget li{
margin: 0 10px 10px 5px;
border-bottom: 1px solid #ccc;
}

section.widget a{
display:block;
padding:3px 0 3px 13px;
background:url(images/arrow.png) no-repeat 0 50%;
}

section.widget a:hover{background-position: 3px 50%;}

p.banner{padding-bottom:7px;}

#contactBanner{
width:265px;
height:70px;
padding-top:70px;
background:url(images/banners/bannerTel.png) no-repeat;
}

#contactBanner p.tel{
display:inline;
padding-left:80px;
margin-left:30px;
text-align:center;
font-weight:bold;
background:url(images/tel.png) no-repeat;
}

#searchform input[type="text"]{
line-height:1.7;
height:24px;
width:130px;
vertical-align:bottom;
}


/* 更新情報
-------------*/
.newsTitle{
clear:both;
margin:15px 0 20px;
padding:7px 0 5px 20px;
font-size:100%;
color: #044f82;
border-bottom:1px solid #ccc;
background:url(images/heading2Bg.png) no-repeat 0 50%;
}

.newsTitle h3{
float:left;
font-weight:normal;
}

.newsTitle p{
float:right;
padding:0 0 0 10px;
font-size:.8em;
background:url(images/arrow.png) no-repeat 0 50%;
}

.news{padding-bottom:40px;}

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

.news p{
display:block;
padding:5px 0;
color:#044f82;
font-style:italic;
font:italic 110% "Palatino Linotype", "Book Antiqua", Palatino, serif;
}

.news span{
color:#2e669c;
font:normal 90% Arial, "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
}

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

.news a:hover span{color:#5f91ca;}



/* フッター
*****************************************************/
#footerLogo{
float:left;
width:265px;
}

#footerLogo img{
max-width:240px;
height:auto;
}

#footer ul{
float:right;
width:625px;
font-size:95%;
padding-bottom:20px;
}

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

#footer ul li{
display:inline-block;
vertical-align:text-top;
text-align:left;
padding:5px 0;
margin-left:15px;
background:url(images/arrow.png) no-repeat 0 12px;
}

#footer ul li a{
display:block;
padding:0 0 0 12px;
overflow:hidden;
}

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

#footer ul li li{
display:block;
padding:0;
margin-left:5px;
background:url(images/arrow2.png) no-repeat 0 6px;
}

#footer ul li li a{padding:0 0 0 8px;}

*: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:center;
font-style:normal;
font-size:85%;
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:#044f82;
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;
word-break: break-all;
}


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

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

ul.thumb h3 a{color:#fff;}

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


/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 1025px){
  nav#mainNav{
  clear:both;
  padding:20px 0 10px;
  position:relative;
  z-index:200;
  }
  
  .panel ul{
  background:url(images/sep.png) no-repeat 50% 50%;
  }

  .panel ul li{
  float: left;
  position: relative;
  padding:0 15px 0 15px;
  height:40px;
  line-height:40px;
  background:url(images/sep.png) no-repeat 100% 50%;
  }

  .panel ul li a{
  display: block;
  text-align: center;
  _float:left;
  padding:0 7px;
  }

  nav div.panel{
  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:#5f91ca;
  }
  
  .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;
  border-radius:0 0 6px 6px;
  border:1px solid #ccc;
  }
  
  .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:#888;font-weight:bold;}
  
  .panel ul li:hover ul li{
  margin:0;
  background: #fff;
  border-bottom:1px solid #dadcdc;
  box-shadow: 1px 1px 3px #ccc;
  }
  
  .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{
  clear:both;
  width:100%;
  margin:0 auto;
  padding:20px 0;
  }
  
  nav#mainNav .inner{width:98%;}
  
  nav#mainNav a.menu{
  width:100%;
  display:block;
  height:40px;
  line-height:40px;
  font-weight: bold;
  text-align:left;
  color:#fff;
  border:1px solid #2e669c;
  background: #2e669c url(images/menuOpen.png) no-repeat 5px 10px;
  }
  
  nav#mainNav a#menu span{padding-left:2.5em;}
  
  nav#mainNav a.menuOpen{
  border-bottom:0;
  color:#fff;
  background: #5f91ca url(images/menuOpen.png) no-repeat 5px -32px;
  }
  
  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 #2e669c;
  }

  .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:#2e669c;
  background:#fff;
  }

 .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{
  background:#f1ffff;
  }

  .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:#fff url(images/sub1.png) no-repeat 20px 50%;}

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

  .panel ul li li a span{padding-left:35px;}
  
  nav div.panel{float:none;}
  
  #mainImg{margin-bottom:20px;}
}


/* 959px以下から 1カラム表示
------------------------------------------------------------*/
@media only screen and (max-width: 959px){
  #wrapper, #header, .inner{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{
  clear:both;
  width:95%;
  float:none;
  margin:0 auto;
  padding:10px 0;
  }
  
  #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;}  
}


/* 幅648px以下から  トップページの３画像調節
------------------------------------------------------------*/
@media only screen and (max-width: 648px){
  .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;}
}


/* 幅644px以下から ヘッダー等微調節
------------------------------------------------------------*/
@media only screen and (max-width: 644px){
  #header{width:98%;padding:0 1%;text-align:center;}
  #header h2,#footerLogo,#headerInfo{float:none;padding:0;}
  #footerLogo, #footer ul{padding-bottom:20px;}
  #headerInfo{width:250px;margin:0 auto;}
  #headerInfo{width:275px;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;}
}


/*-------------------------
   TWD
--------------------------*/

/* ******************************
 * 画面サイズ別の表示・非表示
 * 
 * ～ 644px スマホ
 * ～ 959px iPad（1カラム表示）
 * ～1024px iPad
 * 1025px～ PC
 * **************************** */

.visible-xs,
.visible-sm,
.visible-md,
.visible-lg,
.visible-xs-inline,
.visible-sm-inline,
.visible-md-inline,
.visible-lg-inline {
  display: none !important;
}
@media screen and (max-width: 644px) {
  .visible-xs {
    display: block !important;
  }
  .visible-xs-inline {
    display: inline !important;
  }
  table.visible-xs {
    display: table;
  }
  tr.visible-xs {
    display: table-row !important;
  }
  th.visible-xs,
  td.visible-xs {
    display: table-cell !important;
  }
}
@media screen and (min-width: 645px) and (max-width: 959px) {
  .visible-sm {
    display: block !important;
  }
  .visible-sm-inline {
    display: inline !important;
  }
  table.visible-sm {
    display: table;
  }
  tr.visible-sm {
    display: table-row !important;
  }
  th.visible-sm,
  td.visible-sm {
    display: table-cell !important;
  }
}
@media screen and (min-width: 960px) and (max-width: 1024px) {
  .visible-md {
    display: block !important;
  }
  .visible-md-inline {
    display: inline !important;
  }
  table.visible-md {
    display: table;
  }
  tr.visible-md {
    display: table-row !important;
  }
  th.visible-md,
  td.visible-md {
    display: table-cell !important;
  }
}
@media screen and (min-width: 1025px) {
  .visible-lg {
    display: block !important;
  }
  .visible-lg-inline {
    display: inline !important;
  }
  table.visible-lg {
    display: table;
  }
  tr.visible-lg {
    display: table-row !important;
  }
  th.visible-lg,
  td.visible-lg {
    display: table-cell !important;
  }
}

@media screen and (max-width: 644px) {
  .hidden-xs {
    display: none !important;
  }
}
@media screen and (min-width: 645px) and (max-width: 959px) {
  .hidden-sm {
    display: none !important;
  }
}
@media screen and (min-width: 960px) and (max-width: 1024px) {
  .hidden-md {
    display: none !important;
  }
}
@media screen and (min-width: 1025px) {
  .hidden-lg {
    display: none !important;
  }
}


/* 横幅レスポンシブ */
.img-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

/* 空行 */
.kuugyou {
  display: block;
  width: 1px;
  height: 0.5em;
}

/* 回り込み解除 */
.clear-both {
  clear: both;
}

/* 小さいフォントサイズを設定 */
.small {
  font-size: 90%;
}
.xsmall {
  font-size: 80%;
}

/* 大きいフォントサイズを設定 */
.large {
  font-size: 115%;
}
.xlarge {
  font-size: 140%;
}

/* 太字 */
.strong {
  font-weight: bold;
}
/* 細字 */
.hosoji {
  font-weight: normal;
}
/* 斜め字 */
.italic {
  font-style: italic;
}
/* 下線 */
.underline {
  text-decoration: underline;
}
a.underline:hover,
a.underline:active {
  text-decoration: none;
}

/* 文字色 黒 */
.text-black {
  color: #333;
}

/* 文字色 赤 */
.text-red {
  color: #d83800;
}

/* 文字色 オレンジ */
.text-orange {
  color: #d86000;
}

/* 文字色 緑 */
.text-green {
  color: #008000;
}

/* 文字色 青 */
.text-blue {
  color: #292b94;
}

/* 文字色 グレー */
.text-gray {
  color: #888;
}

/* 文字色 ピンク */
.text-pink {
  color: #e44880;
}

/* 行間 */
.line-h130 {
  line-height: 130%;
}
.line-h160 {
  line-height: 160%;
}
.line-h180 {
  line-height: 180%;
}

/* 改行禁止 */
.nowrap {
  white-space: nowrap;
}

/* 仕切り線 */
hr {
  height: 0;
  -webkit-box-sizing: content-box;
     -moz-box-sizing: content-box;
          box-sizing: content-box;
  margin-top: 15px;
  margin-bottom: 15px;
  border: 0;
  border-top: 1px solid #dfdfdf;
}
.hr-dotted {
  margin-top: 15px;
  margin-bottom: 15px;
  border-top: 1px dotted #a8a8a8;
}

/* ※印 */
ul.kome,
.post ul.kome {
  margin: 0;
  padding: 0;
  vertical-align: top;
  font-weight: bold;
}
ul.kome li,
.post ul.kome li {
  list-style: none;
  background: none;
  margin-left: 1.5em;
  margin-bottom: 0.5em;
  padding: 0;
  font-weight: normal;
}
ul.kome li:before,
.post ul.kome li:before {
  content: "※";
  margin-left: -1.5em;
  letter-spacing: 0.5em;
}

/* 角丸 */
.kadomaru {
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
}

/* フォーム */
form th {
  width: 30%;
}
form td {
  width: 70%;
}
.error_list {
  list-style: disc;
  margin: 10px 0 10px 20px;
}

/* 横幅100％ */
.w100per {
  width: 100%;
}

/* インデント */
.danraku {
  margin-left: 1em;
  width: auto;
}

/* 文字の配置 */
.text-left {
  text-align: left;
}
.text-right {
  text-align: right;
}
.text-center {
  text-align: center;
}

/* センタリング */
.center-box {
  display: table;
  margin-left: auto;
  margin-right: auto;
}
/* 右寄せ */
.right-box {
  display: table;
  margin-left: auto;
  margin-right: 0;
}
/* 左寄せ */
.left-box {
  display: table;
  margin-left: 0;
  margin-right: auto;
}

/* 右寄せ */
.float-right {
  float: right;
  margin: 0 0 5px 7px;
}
img.float-right,
img.float-right-all {
  float: right;
  margin: 0;
  padding: 0 4px 4px 11px;
  background-color: #fff;
}
@media only screen and (max-width: 644px){
  img.float-right {
    float: none;
    display: block;
    padding: 0;
    margin: 5px auto;
    padding: 0;
  }
  img.float-right-all {
    float: right;
    margin: 0;
    padding: 0 4px 4px 11px;
    max-width: 45%;
    background-color: #fff;
  }
}
/* 左寄せ */
.float-left {
  float: left;
  margin: 0 7px 5px 0;
}
img.float-left,
img.float-left-all {
  float: left;
  margin: 0;
  padding: 0 11px 4px 4px;
  background-color: #fff;
}
@media only screen and (max-width: 644px){
  img.float-left {
    float: none;
    display: block;
    padding: 0;
    margin: 5px auto;
    padding: 0;
  }
  img.float-left-all {
    float: left;
    margin: 0;
    padding: 0 11px 4px 4px;
    max-width: 45%;
    background-color: #fff;
  }
}

/* 回り込み解除 */
.clear-both {
  clear: both;
}

/* 注意書き */
.post .notice,
.post .notice th,
.post .notice td {
  border: none;
  color:#252525;
  background-color: #fff;
  margin: 0;
  padding-top: 0;
  padding-right: 0;
}
.post .notice,
.post .notice th {
  padding-left: 0;
}
.notice {
  line-height: 130%;
}
.notice th,
.notice td {
  vertical-align: top;
  padding-bottom: 5px;
}
.notice th {
  padding-right: 5px;
  white-space: nowrap;
}


/*-------------------------
   メールフォーム（横並び）
--------------------------*/
.post .table-form {
  display: table;
  width: 100%;
  margin: 0;
  border: none;
}
.post .table-form-tr {
  display: table-row;
  width: 100%;
}
.post .table-form-th {
  display: table-cell;
  border: none;
  vertical-align: top;
  white-space: nowrap;
  padding: 10px 20px 7px 5px;
  width: 10%;
  background: none;
  color: #252525;
  font-weight: normal;
}
.post .table-form-td {
  display: table-cell;
  border: none;
  padding: 7px 10px 7px 5px;
  vertical-align: top;
  width: 90%;
  background: none;
}
.table-form-hr {
  display: table-cell;
  padding-top: 8px;
  border-bottom: 1px dotted #b8b8b8;
}
@media only screen and (max-width: 644px){
  .post .table-form-tr {
    display: table;
    margin-top: 10px;
  }
  .post .table-form-th,
  .post .table-form-td {
    display: table-row;
    _width: 100%;
    padding: 0;
  }
}


/*-------------------------
   メールフォーム
--------------------------*/
.box-form {
  border: 1px solid #ccc;
  padding: 15px 25px 10px 15px;
  margin: 20px 0 5px;
  border-radius: 4px;
}
@media screen and (min-width: 960px) {
  .box-form {
    padding: 20px 40px 25px 30px;
  }
}
input[type="submit"],
input[type="button"] {
  marginm: 10px 0;
  padding: 6px 25px;
  line-height: 1;
  border-radius: 3px;
}
input:not([type="submit"]):not([type="button"]):not([type="radio"]):not([type="checkbox"]),
textarea {
  margin-bottom: 10px;
  padding: 3px 6px;
  background-color: #fff;
  border: 1px dashed #b8b8b8;
  border-radius:3px;
}
input[type="radio"],
input[type="checkbox"] {
  margin: 8px 3px;
}
select {
  margin-bottom: 10px;
  padding: 2px 6px;
  background-color: #f8fafc;
  border:1px dashed #b8b8b8;
  border-radius:3px;
}
input:not([type="submit"]):not([type="button"]):not([type="radio"]):not([type="checkbox"]):focus,
textarea:focus,
select:focus {
  border: 1px solid #afafaf;
}
.form-w100per {
  width: 95%;
  max-width:95%;
}
.form-w30per {
  width: 30%;
}
.form-wshort {
  width: 50px;
}
@media screen and (max-width:620px) {
  .form-w30per {
    width: 100%;
  }
}
.bikou {
  font-size: 90%;
  margin: -5px 0 10px;
}
@media screen and (max-width:959px) {
  .bikou {
    font-size: 85%;
  }
}


/*-------------------------
   ボックス
--------------------------*/
.waku {
  display: inline-block;
  background:#fcf8ef;
  border:1px #2e669c solid;
  border:2px #2e669c dotted;
  padding: 15px;
  margin: 10px 0;
  border-radius: 10px;
}


/*-------------------------
   写真をテーブル上に右寄せ
--------------------------*/
.pic-box {
  position: relative;
}
.pic-right {
  position: absolute;
  right: 0;
  margin: 11px 1px 0 0;
  padding: 28px 28px 0 28px;
  background-color: #fff;
}
@media only screen and (max-width: 959px){
  .pic-right {
    padding: 20px 20px 0 20px;
  }
}
@media screen and (max-width:644px) {
  .pic-right {
    position: relative;
    margin: 0;
    padding: 0;
    text-align: center;
  }
}


/*-------------------------
   ミニタイトル
--------------------------*/
.mini-title{
  display: inline-block;
  margin: 10px 0 2px;
  padding: 3px 10px 1px;
  line-height: 1;
  border:1px solid #a848a8;
  border-radius: 30px;
  font-size: 85%;
  color: #a848a8;
  position: relative;
  left: -3px;
}
.mini-title2{
  display: inline-block;
  margin: 10px 5px 10px 0;
  padding: 5px 15px 3px;
  line-height: 1;
  text-align: center;
  background-color: #e87078;
  border-radius: 3px;
  font-size: 100%;
   color: #a848a8;
  color: #fff;
  position: relative;
  left: -3px;
}


/*-------------------------
   Googleマップをレスポンシブに
--------------------------*/
.google-map {
  position: relative;
  padding-bottom: 43.01%;
  height: 0;
  overflow: hidden;
}
.google-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width:644px) {
  .google-map {
    padding-bottom: 250px;
  }
}


/*-------------------------
   ツイッター
--------------------------*/

.twitter-timeline {
  visibility: hidden;
}
.twitter {
  width: 180px;
  float: right;
  text-align: center;
}
.twitter-mb {
  display: none;
}
@media only screen and (max-width:959px){
  .twitter {
    width: 100%;
    float: none;
    text-align: center;
  }
  .twitter-pc {
    display: none;
  }
  .twitter-mb {
    display: block;
  }
}


/*-------------------------
   写真一覧
--------------------------*/
.post ul.gallery {
  list-style: none !important;
  margin: 0 auto;
  white-space: nowrap;
}
.post ul.gallery > li {
  display: block;
  display: inline-block;
  width: 32%;
  margin: 0;
  padding: 0;
  background: none;
  vertical-align: top;
  position: relative;
}
.post ul.gallery > li + li {
  margin-left: 5px;
}
.post ul.gallery > li img {
/*   float: left;
  width: 40%; */
  height: auto;
  margin: 0;
}
.post ul.gallery > li span {
  display: block;
  font-size: 80%;
  margin-bottom: 10px;
}
@media screen and (max-width:620px) {
  .post ul.gallery > li + li {
    margin-left: 0;
  }
  .post ul.gallery > li img {
    margin: 0 5px 0 0;
  }
}
