@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:normal;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;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}input,select{vertical-align:middle}


/*================================================
 *  一般・共通設定
 ================================================*/
body {
    width:100%;
    margin:0 auto;
    font-size:14px;
    color:#382400;
    font-family:"メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
    line-height:1.6;
}


header {
    width:940px;
    margin:10px auto;
}

nav {
    width:100%;
}

#contents {
	width:940px;
	margin:20px auto;
}

#main {
    float:right;
    width:620px;
}


#main2 {
    float:right;
    width:670px;
}


#main3 {
    margin:0 auto;
    width:100%;
}

#sub {
    float:left;
    width:300px;
}
#sub2 {
	float:left;
	width:240px;
}

#subnav {
    display:none;
}

section {
	margin-bottom:30px;
}

a {
    color:#000;
}
a:hover {
    color:#e78f00;
}

h1 {
	font-size: 14px;
	color: #333333;
	font-weight: normal;
}
h1 a {
    color:#000;
    text-decoration:none;
}
h1 a:hover {
    color:#e78f00;
    text-decoration:underline;
}

h2 {
	margin-bottom:0.5em;
	padding-left:10px;
	font-size:18px;
	color:#333;
	border-bottom : 2px solid #7DCBFF;
	border-left : 10px ridge #84C8FB;
	background-color: #f7f5f1;
	line-height: 3em;
}

h3 {
	margin-bottom:0.5em;
	padding:2px 5px;
	color:#333333;
	font-size:16px;
	border-bottom:2px solid #7DCBFF;
	background-color: #f7f5f1;
	line-height: 3em;
}

h4 {
    margin-bottom:0.25em;
    font-size:16px;
    color:#333;
}
h4:before {
    content:"\002605";
    color:#f19500;
}

h5 {
    margin-bottom:0.25em;
    padding:2px;
    color:#000;
    font-size:16px;
    border-top:1px dotted #999;
    border-bottom:1px dotted #999;
    background:#f1f1f1;
}

h6 {
    margin-bottom:0.25em;
    color:#382400;
    font-size:14px;
    font-weight:bold;
}

.sample2 {
    position: relative;
    color: #393939;
    background: #c3e6ff;
    font-size: 14pt ;
    border: 1px solid #f1f2f2;
    margin: 10px 10px 21px 10px;
    padding: 10px 5px 10px 10px;
    border-radius: 3px;
}
.sample2:after, .sample2:before {
    content: "";
    position: absolute;
    top: 100%;
    height: 0;
    width: 0;
}
.sample2:after {
    left: 40px;
    border: 10px solid transparent;
    border-top: 10px solid #c3e6ff;
}
.sample2:before {
    left: 39px; 
    border: 11px solid transparent;
    border-top: 11px solid #f1f2f2;
}


p {
	margin:0 0 1em 0;
}

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

em {
    font-weight:bold;
}

strong {
	font-weight:bold;
	color:#008BE8;
}

pre {
    margin:1em 0;
    padding:1em;
}

blockquote {
    margin-bottom:1em;
    padding:1em;
    border:1px dotted #ddd;
    border-left:5px solid #ddd;
}

ul,ol,dl {
    margin:0 0 1em 0;
}
ul li {
    list-style:disc;
}
ol li {
    list-style:decimal;
}
li {
    margin-left:2em;
}

dt {
    margin-bottom:0.5em;
    border-bottom:1px dotted #ddd;
}
dt:before {
    content:"\0025a0";
}
dd {
    margin-bottom:1em;
}


table {
	border-collapse: collapse;
	margin-bottom:1em;
	border:1px solid #ddd;
	width:100%;
}
th.t_top {
    border-top: #be1309 4px solid;
}

th {
	border-bottom: #e3e3e3 1px dotted;
	text-align: left;
	padding: 0px;
	font-weight: normal;
}
td.t_top {
	border-top: #b3b3b3 4px solid;
}
td {
	border-bottom: #e3e3e3 1px dotted;
	text-align: left;
	padding: 10px;
}
tr:hover {
    background: #3D80DF;
    color: #FFFFFF;
}



/*================================================
 *  ヘッダー
 ================================================*/
header {
    position:relative;
}
header h1 {
    margin-bottom:20px;
}

.contact {
    position:absolute;
    top:0;
    right:0;
    vertical-align:top;

}
.contact span {
    color:#fff;
    font-size:16px;
    vertical-align:middle;
    background:url(../images/mail.png) 0 0 no-repeat;
}

.contact a {
	display:block;
	padding:5px 10px 5px 29px;
	color:#fff;
	background:#f19500;
	border-radius:4px;
	text-decoration:underline;
	background:#7DCBFF url(../images/mail.png) 10px 50% no-repeat;
}

.contact a:hover {
	color:#fff;
	background:#0099FF url(../images/mail.png) 10px 50% no-repeat;
}

.summary {
    clear:both;
}

/*================================================
 *  グローバルナビゲーション
 ================================================*/
nav {
    margin-bottom:10px;
    padding:0;
    background:#f7f5f1;
    overflow:hidden;
}
nav ul {
    width:940px;
    margin:0 auto;
    padding:0;
}
nav li {
    float:left;
    list-style:none;
    margin:0;
    padding:0;
}
nav li a {
	display:block;
	width:157px;
	padding:10px 0;
	color:#000;
	text-align:center;
	text-decoration:underline;
}
nav li:first-child a {
    width:155px;
}
nav li a:hover {
	color:#000;
	text-decoration:none;
	background:#ddd;
}

/*================================================
 *  サブコンテンツ
 ================================================*/
.submenu li {
    margin:0;
    padding:0;
    list-style:none;
}
.submenu li a:before {
    content:"\0025a0";
    color:#000;
}


.submenu li a {
    display:block;
    padding:5px 2px;
    color:#000;
    border-bottom:1px dotted #ddd;
    text-decoration:none;
}
.submenu li a:hover {
    background:#eee;
}

.bnr li {
    margin:0 0 10px 0;
    padding:0;
    list-style:none;
}
.bnr li a:hover {
    opacity:0.8;
    filter:alpha(opacity=80);
    -ms-filter:"alpha( opacity=80 )";
}
.bnr img {
    width:300px;
}

/*================================================
 *  フッター
 ================================================*/
footer {
    clear:both;
}

.footmenu {
    width:100%;
    padding:20px 0;
    overflow:hidden;
    border-top:1px dotted #ccc;
    border-bottom:1px dotted #ccc;
}
.footmenu ul {
    position:relative;
    float:left;
    left:50%;
    margin:0;
}
.footmenu li {
    position:relative;
    left:-50%;
    float:left;
    list-style:none;
    padding:0 10px;
    font-size:12px;
    text-align:center;
}

.copyright {
	clear:both;
	padding:20px 0;
	font-size:14px;
	text-align:center;
}

/*================================================
 *  ページトップへの戻り
 ================================================*/
.totop {
    position:fixed;
    bottom:15px;
    right:15px;
}
.totop a {
    display:block;
    text-decoration:none;
}
.totop img {
	background:#7DCBFF;
}
.totop img:hover {
	background:#0099FF;
}

/*================================================
 *  クラス
 ================================================*/
.textL {
    text-align:left;
}

.textR {
    text-align:right;
}

.list {
    padding:0 0 0 0.5em;
}

.list li {
    margin:0;
    padding:0 0 0 15px;
    list-style:none;
    background:url(../images/check.png) 0 5px no-repeat;
}

.photo {
	overflow:hidden;
	margin:20px 0;
	padding:10px;
	border:5px solid #ddd;
	background:#fff;
	line-height: 2em;
}

.photos {
	overflow:hidden;
	margin:0px 0;
	padding:10px;
	border:5px solid #ddd;
	background:#fff;
}

.map {
    overflow:hidden;
    margin:20px 0;
    padding:10px;
    border:5px solid #ddd;
    background:#fff;
}

iframe { 
　　 border:none;    

}

.imgL {
	float:left;
	margin:0 15px 0px 0;
}

.imgR {
    float:right;
    margin:0 0 10px 10px;
}

.info dt {
    border-bottom:none;
}
.info dd {
	padding-bottom:1em;
	border-bottom:1px solid #ddd;
	padding-top: 1em;
}

/*================================================
 *  トップページ
 ================================================*/
/* スライドショー */
.slide {
    position:relative;
    overflow:hidden;
    padding-bottom:25px;
}

.slideno {
	position:relative;
	padding-bottom:25px;
	text-align: center;
}
.slidePrev {
    position:absolute;
    cursor:pointer;
    z-index:100;
}

.slideNext {
    position:absolute;
    cursor:pointer;
    z-index:100;
}

.slidePrev img {
    position:absolute;
    width:50px;
    height:60px;
}

.slideNext img {
    position:absolute;
    width:50px;
    height:60px;
}

.slideInner {
    position:relative;
    margin:0;
    padding:0;
}
.slideInner li {
    float:left;
    margin:0;
    padding:0;
    list-style:none;
}
.slideInner li img {
    margin:0 5px;
    padding:0;
}

.filterPrev {
    position:absolute;
    left:0;
    opacity:0.5;
    filter:alpha(opacity=50);
    background-color:#fff;
}

.filterNext {
    position:absolute;
    right:0;
    opacity:0.5;
    filter:alpha(opacity=50);
    background-color:#fff;
}

.controlNav {
      position:absolute;
      float:left;
      left:50%;
      bottom:0;
}
.controlNav span {
      position:relative;
      left:-50%;
      float:left;
      margin:5px;
      -webkit-border-radius:5px;
      -moz-border-radius:5px;
      border-radius:5px;
      width:10px;
      height:10px;
      overflow:hidden;
      background:#ccc;
      text-indent:-9999px;
      vertical-align:middle;
}
.controlNav span:hover {
      background:#999;
      cursor:pointer;
}
.controlNav span.current {
      background:#f19500;
}

/* トップナビ */
* html .topNavi {
    height:1em;
    overflow:visible;
}

.topNavi {
    overflow:hidden;
    position:relative;
    margin-right:-2%;
    margin-top:20px;
    margin-bottom:20px;
}

.topNaviColumn {
    display:inline;
    width:32%;
    float:left;
    margin-right:1%;
}

.topNaviCon {
    position:relative;
    display:block;
    box-sizing:border-box;
    overflow:hidden;
    padding:10px;
    text-decoration:none;
    color:#000;
    transition:background 0s ease 0s, border 0.5s ease-out 0s;
    background:#f1f1f1;
    border:1px solid #f1f1f1;
    border-radius:4px;
}

.topNaviCon:hover {
    color:#000;
    background:#fff9f5 none repeat scroll 0 0;
    border:1px solid #f19500;
    transition:background 0s ease 0s, border 0.5s ease-out 0s;
}

.topNaviCon h2 {
	margin:10px;
	padding:0;
	font-size:14px;
	font-weight:bold;
	color:#0099FF;
	border:none;
	text-decoration: underline;
}

.topNaviCon:hover h2 {
    color:#f19500;
}

.topNaviCon p {
    margin:10px;
}

.topNaviPhoto img {
	width:100%;
}


* html .topNavi2 {
    height:1em;
    overflow:visible;
}

.topNavi2 {
	overflow:hidden;
	position:relative;
	margin-right:-2%;
	margin-top:0px;
	margin-bottom:20px;
}

.topNaviColumn2 {
	display:inline;
	width:48%;
	float:left;
	margin-right:1%;
}

.topNaviCon2 {
    position:relative;
    display:block;
    box-sizing:border-box;
    overflow:hidden;
    padding:10px;
    text-decoration:none;
    color:#000;
    transition:background 0s ease 0s, border 0.5s ease-out 0s;
    background:#f1f1f1;
    border:1px solid #f1f1f1;
    border-radius:4px;
}

.topNaviCon2:hover {
    color:#000;
    background:#fff9f5 none repeat scroll 0 0;
    border:1px solid #f19500;
    transition:background 0s ease 0s, border 0.5s ease-out 0s;
}

.topNaviCon2 h2 {
    margin:10px;
    padding:0;
    font-size:14px;
    font-weight:bold;
    color:#f19500;
    border:none;
}

.topNaviCon:hover2 h2 {
    color:#f19500;
}

.topNaviCon2 p {
    margin:10px;
}

.topNaviPhoto2 img {
    width:100%;
}




.style1 {
	color: #FF6633;
	font-size: 16px;
}
.style2 {
	color: #0066FF;
	font-size: 16px;
}
.style3 {
	font-size: 16px;
	font-weight: bold;
	color: #FF6600
}

.style5 {color: #0033CC}
.style6 {
	font-size: 16px;
	font-weight: bold;
	color: #879980
}
.style7 {
	color: #003333
}
.style8 {font-size: 12px}
.style9 {color: #FF3366}
.style10 {color: #660000}
.style11 {color: #FFFFFF}
.style12 {color: #333333}
.style13 {
	color: #E78F00;
	font-weight: normal;
	font-size: 16px;
}
.style14 {color: #86899D}
.style15 {
	font-size: 18px;
	font-weight: bold;
	color: #646464
	}

.style16 {
	font-size: 18px;
	font-weight: bold;
	color: #FF6600
	}




.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; }
.embed-container iframe, .embed-container object, .embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }


/*================================================
 *  スマートフォン向けデザイン
 ================================================*/
@media screen and (max-width:779px) {
    body {
        box-sizing:border-box;
        width:100%;
        padding:0 10px;
    }
	body > h1 {
	display: none;
}

    header {
        width:100%;
    }

    header h1 {
        margin-bottom:0;
    }

    .contact {
        position:relative;
        float:right;
        margin:10px 0;
    }

    #contents {
        width:100%;
}

    #main {
        float:none;
        width:100%;
    }
	
	 #main3 {
        float:none;
        width:100%;
    }


    #sub {
        float:none;
        width:100%;
    }

    .bnr {
        overflow:hidden;
        margin-right:-2%;
    }

    .bnr li {
        float:left;
        width:48%;
        margin:0 2% 2% 0;
    }

    .bnr li img {
        width:100%;
    }

   .totop {
    display:none !important;
    }

    /* メインメニュー */
    nav {
        display:block;
        position:relative;
        width:100%;
    }
    nav h3 {
        cursor:pointer;
        margin-bottom:0;
        color:#fff;
        background:#999;
        border:none;
    }
    nav h3:after {
        position:absolute;
        content:"\0025bc";
        top:3px;
        right:5px;
    }
    nav h3.menuOpen:after {
        position:absolute;
        content:"\0025b2";
        top:3px;
        right:5px;
    }
    nav ul {
        width:100%;
    }

    nav li {
        width:33.33%;
        margin:0;
        padding:0;
        list-style:none;
    }
    navv li a:before {
        content:"\0025a0";
        color:#5b4111;
    }
    nav li:first-child a {
        width:100%;
    }

    nav li a {
        display:block;
        width:100%;
        border-bottom:1px dotted #ddd;
        text-decoration:none;
    }

    /* トップナビ */
    .topNavi {
        margin-right:0;
    }

    .topNaviColumn {
        display:block;
        box-sizing:border-box;
        width:100%;
        float:none;
        margin-right:0;
        margin-bottom:10px;
    }

}
