@charset "utf-8";

/*--Base------------------------------------------------------------*/

html,body {
	width: 100%;
	height: 100%;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

html {
	overflow-y: scroll;
}

/*--Reset-----------------------------------------------------------*/

* {
	margin: 0;
	padding: 0;
}

a {
	text-decoration: none;
}

img {
	border: none;
	vertical-align: middle;
}

ul,ol {
	list-style: none;
}

/*--Text------------------------------------------------------------*/

body {
	font-size: 12px;
	font-weight: normal;
	line-height: 1.5;
    font-family: "游ゴシック体","游ゴシック","Yu Gothic","YuGothic","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ","Meiryo",sans-serif;
}

h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
}

/*--Link------------------------------------------------------------*/

a,
a:link {
	color: #333333;
}

a:visited {
	color: #333333;
}

a:hover,
a:active {
	color: #777777;
}

a:focus {
	outline: none;
}

/*--HTML5-----------------------------------------------------------*/

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

/*--sample----------------------------------------------------------*/

/*--layout----------------------------------------------------------*/

#wrapper {
	width: 100%;
}

#header {
	border-top: 1px #666 solid;
	border-bottom: 1px #666 solid;
	height: 40px;
	margin: 0;
	padding: 0;
}

#header header {
	margin: 0 auto;
}

#topLogo {
	margin: 20px auto;
	width: 100%;
}


#contents {
	margin: 0 auto;
}

.topLogo {
	margin: 20px auto;
	width: 200px;
}

#main {
	margin: 0 auto;
	width: 96%;
}

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

#footer {
	border-top: 1px solid #666666;
	margin-top: 12px;
	padding-bottom: 60px;
	position: relative;
}

#footer footer {
	margin: 0 auto;
	height: 120px;
}

#header header,
#contents,
#footer footer {
	width: 100%;/*�Z���^�[�Œ� or ���L�b�h���C�A�E�g�̕ύX(���L�b�h���C�A�E�g�ɂ���ꍇ��width��100%�ɕύX)*/
}

/*--common----------------------------------------------------------*/

#header h1,
#header h2,
#contents h3,
#header p,
#contents p,
#footer p {
	padding: 0px;
}


/*--top----------------------------------------------------------*/

.topWorksTitle {
	font-size: 14px;
	text-align: center;
	color: #333333;
	margin-top: 50px;
}

.worksListbox {
	margin-top: 20px;
}

.worksText {
	color: #666666;
	font-size: 10px;
	margin-left: 20px;
	margin-right: 20px;
	font-weight: normal;
}

.worksNewImg {
	margin-top: -2px;
}

.moreBtn {
	margin: 20px auto;
	text-align: center;
	border: 1px #333333 solid;
	padding: 3px;
	width: 100px;
}

.topEventBox01 {
	float: left;
	width: 48%;
	text-align: center;
	margin-top: 30px;
}

.topEventBox02 {
	float: right;
	width: 48%;
	text-align: center;
	margin-top: 30px;
}

.topEventList01 {
	overflow: hidden;
}

/* clearfix */
.topEventList01:before,
.topEventList01:after {
    content: "";
    display: table;
}
 
.topEventList01:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.topEventList01 {
    zoom: 1;
}


 #globnav {
        background: #fff;
        margin-bottom: 10px;
    }
    .table-row{
        display: table;
        width: 100%;
        list-style-type: none;
    }
    .table-cell{
        display: table-cell;
		border-right: 1px #666 solid;
    }
    .table-cell-last{
        display: table-cell;
    }
    .table-fixed.home{
        width: 40px;
		height: 40px;
        color: #000;
        background: #fff;
		border-right: 1px #666 solid;
    }
    .table-row li {
        padding: 0;
        color: #666;
        text-align: center;
        width: 32%;
        font-size: 12px;
		line-height: 40px;
    }

.menuHeader {
	color: #FFF;
	width: 200px;
	background-color: #00468C;
	height: 40px;
	line-height: 40px;
	font-size: 12px;
}

.menuCateTitle {
	color: #000;
	font-size: 13px;
	padding: 10px 0;
}

.menuCatelist {
	font-size: 12px;
	padding-top: 10px;
	padding-left: 10px;
	padding-bottom: 10px;
}

#main-nav ul li {
	padding-bottom: 10px;
}

.menuLine {
	margin-top: 10px;
	margin-bottom: 10px;
	width: 198px;
    border:none;
    border-top: dotted 1px #ccc;
    height:1px;
    color:#FFFFFF;
}

.topSlider {
	margin-top: 10px;
}

.enterNavBox01Center {
	text-align: center;
	margin-top: 10px;	
}

.enterNavBox01 {
	float: left;
	width: 49%;
}
.enterNavBox02 {
	float: right;
	width: 49%;
}
.enterNavBox01-2 {
	float: left;
	width: 48%;
}
.enterNavBox02-2 {
	float: right;
	width: 48%;
	font-size: 10px;
}

.enterNavContainer {
	overflow: hidden;
	width: 100%;
	margin-top: 10px;
}

/* clearfix */
.enterNavContainer:before,
.enterNavContainer:after {
    content: "";
    display: table;
}
 
.enterNavContainer:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.enterNavContainer {
    zoom: 1;
}

.enterNavContainer02 {
	overflow: hidden;
	width: 100%;
	margin-top: 0px;
}

/* clearfix */
.enterNavContainer02:before,
.enterNavContainer02:after {
    content: "";
    display: table;
}
 
.enterNavContainer02:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.enterNavContainer02 {
    zoom: 1;
}

.contntTitle01 {
	text-align: center;
	margin-top: 50px;
	margin-bottom: 30px;
}

.info_tel {
	text-align: center;
	font-size: 12px;
	color: #666666;
	font-weight: bold;
}
.info_tel span {
	font-size: 10px;
}

.snsLinkBox01 {
	float: left;
	margin-right: 0px;
	width: 45%;
	text-align: center;
}

.snsLinkBox02 {
	float: left;
	margin-right: 0px;
	width: 45%;
	text-align: center;
}

.iconW {
	width: 65%;
}

.snsLinkBoxContainer {
	overflow: hidden;
	margin: 10px auto 0 auto;
	width: 85%;
}

/* clearfix */
.snsLinkBoxContainer:before,
.snsLinkBoxContainer:after {
    content: "";
    display: table;
}
 
.snsLinkBoxContainer:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.snsLinkBoxContainer {
    zoom: 1;
}

.footerMenuBox01 {
	float: left;
	width: 50%;
}
.footerMenuBox02 {
	float: left;
	width: 50%;
}

.footerMenu {
	overflow: hidden;
	width: 70%;
	margin: 20px auto 20px auto;
	text-align: center;
	font-size: 10px;
}

/* clearfix */
.footerMenu:before,
.footerMenu:after {
    content: "";
    display: table;
}
 
.footerMenu:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.footerMenu {
    zoom: 1;
}

.copyright {
	text-align: center;
	font-size: 8px;
}

.marginTop5 {
	margin-top: 5px;
}


/*--トップに戻るボタン----------------------------------------------------------*/
.pagetop {
    display: none;
    position: fixed;
    bottom: 90px;
    right: 15px;
}
.pagetop a {
    display: block;
    background-color: #fff;
    text-align: center;
    color: #222;
    font-size: 12px;
    text-decoration: none;
    padding: 0;
	filter:alpha(opacity=80);
    -moz-opacity: 0.8;
    opacity: 0.8;
}
.pagetop a:hover {
    display: block;
    background-color: #fff;
    text-align: center;
    color: #fff;
    font-size: 12px;
    text-decoration: none;
    padding:0;
	filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}
/*--トップに戻るボタン----------------------------------------------------------*/

.topBannerBox {
	width: 100%;
	margin: 10px auto 0 auto;
	text-align: center;
}

.topBannerBox02 {
	width: 100%;
	margin: 30px auto 0 auto;
	text-align: center;
}

.newsBox {
	position: relative;
	margin-top: 20px;
	color: #333;
}

.newsTitle {
	font-size: 15px;
	font-weight: bold;
	background-color: #00468C;
	color: #FFF;
	padding-left: 10px;
}

.newsText01 {
	font-size: 14px;
	margin-top: 10px;
	font-weight: bold;
	padding: 10px;
}
.newsText01 span {
	font-size: 15px;
	color: #900;
	font-weight: bold;
}

.newsText02 {
	font-size: 13px;
	padding: 10px;
}

.newsOrange {
	color: #F60;
}
.newsRed {
	color: #900;
}

.newsLine {
	margin-top: 10px;
	margin-bottom: 10px;
	width: 100%;
    border:none;
    border-top: dotted 1px #ccc;
    height:1px;
    color:#FFFFFF;
}

.topNewsArea {
	margin: 0 auto;
	width: 96%;
}

.topNewsTitle01 {
	float: left;
	font-size: 16px;
	font-weight: bold;
}
.topNewsTitle02 {
	float: right;
	font-size: 14px;
}

.topNewsTitleContainer {
	overflow: hidden;
	margin-top: 45px;
	margin-bottom: 20px;
	width: 100%;
	border-bottom: 1px dotted #3A3325;
	padding-bottom: 20px;
}

/* clearfix */
.topNewsTitleContainer:before,
.topNewsTitleContainer:after {
    content: "";
    display: table;
}
 
.topNewsTitleContainer:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.topNewsTitleContainer {
    zoom: 1;
}

#feed01  li {
	line-height: 120%;
	padding-bottom: 16px;
}
#feed02  li {
	line-height: 120%;
	padding-bottom: 16px;
}

.newYearBox {
	width: 100%;
	text-align: center;
	margin-top:30px;
}

.footerTel01 {
	float: left;
	width: 50%;
}

.footerTelContainer {
	overflow: hidden;
	margin-top: 20px;
}

/* clearfix */
.footerTelContainer:before,
.footerTelContainer:after {
    content: "";
    display: table;
}
 
.footerTelContainer:after {
    clear: both;
}
 
/* For IE 6/7 (trigger hasLayout) */
.footerTelContainer {
    zoom: 1;
}

.yoyaku {
	position: fixed;
	bottom: 120px;
	right: -125px;
	z-index: 9999;
}

.yoyaku02 {
	position: fixed;
	bottom: 0;
	width: 100%;
	z-index: 9999;
	background-color: #F3E2BF;
	text-align: center;
	color: #000;
	font-weight: bold;
	font-size: 18px;
	padding: 20px 0;
}

.yoyakuImg {
	margin-top: 10px;
	text-align: center;
}

.topTitleBg {
	text-align: center;
	width: 100%;
	height: 230px;
	background-color: #DF9D00;
	padding: 60px 0;
}

/*SW*/

.swTitle01 {
	color: #FFF;
	font-weight: bold;
	font-size: 24px;
}

.swTitle02 {
	color: #000;
	font-weight: bold;
	font-size: 20px;
	text-align: center;
	margin-top: 40px;
	line-height: 120%;
}

.swTitle03 {
	color: #000;
	font-weight: bold;
	font-size: 18px;
	text-align: center;
	margin-top: 40px;
}

.swTitle04 {
	color: #fff;
	font-weight: bold;
	font-size: 22px;
	text-align: center;
	background-color: #DF9D00;
	line-height: 40px;
	height: 40px;
}

.swTitle05 {
	color: #000;
	font-weight: bold;
	font-size: 22px;
	text-align: center;
	margin-top: 50px;
	line-height: 120%;
}

.swTitle06 {
	color: #333333;
	font-weight: bold;
	font-size: 16px;
	text-align: center;
	background-color: #ECEAD6;
	padding: 20px 0;
	width: 100%;
	margin: 30px auto;
}


.swText01 {
	color: #FFF;
	font-size: 15px;
	width: 90%;
	margin: 20px auto 0 auto;
	line-height: 180%;
}

.swText02 {
	color: #000;
	font-size: 15px;
	width: 90%;
	margin: 30px auto 0 auto;
	text-align: center;
	line-height: 180%;
}

.swText02-2 {
	color: #000;
	font-size: 15px;
	width: 90%;
	margin: 20px auto 0 auto;
	text-align: center;
	line-height: 180%;
}

.swText03 {
	color: #000;
	font-size: 12px;
	width: 90%;
	margin: 10px auto 0 auto;
	text-align: center;
}

.swText04 {
	color: #000;
	font-size: 15px;
	width: 90%;
	margin: 30px auto 0 auto;
	text-align: left;
}

.swText05 {
	color: #000;
	font-size: 20px;
	margin: 20px auto 0 auto;
	line-height: 180%;
	text-align: center;
}

.fontBold {
	font-weight: bold;
}

.margintop10 {
	margin-top:10px;
}

.margintop20 {
	margin-top:20px;
}

.margintop30 {
	margin-top:30px;
}

.margintop40 {
	margin-top:40px;
}

.margintop50 {
	margin-top:50px;
}

.margintop60 {
	margin-top:60px;
}

.textCenter {
	text-align: center;
}

.textRight {
	text-align: right;
}

.colorOra {
	color: #DF9D00;
}

.colorPur {
	color: #39347F;
}

.colorPink {
	color: #D44759;
}

.colorBlu {
	color: #1AB3CC;
}

.fontSize11 {
	font-size: 11px;
}

.fontSize14 {
	font-size: 14px;
}

.fontSize16 {
	font-size: 16px;
}

.fontSize18 {
	font-size: 18px;
}

.fontSize20 {
	font-size: 20px;
}

.fontSize22 {
	font-size: 22px;
}

.fontSize24 {
	font-size: 24px;
}

.fontSize26 {
	font-size: 26px;
}

.lineHeight140 {
	line-height: 120%;
}

.swZehBox {
	background-color: #EEEEEE;
	padding: 40px 0;
	margin-top: 40px;
}

.swNav {
	position: fixed;
	bottom: 0;
	width: 100%;
	z-index: 9999;
	text-align: center;
	padding: 10px 0;
}

.yoyakuImg {
	margin-top: 10px;
	text-align: center;
}

.swNavBox {
	display: flex;
	margin: 0 auto;
	padding: 0 2%;
	width: 98%;
	max-width: 100%; 
}

.swNavBox01{
	padding: 0 1%;
}

.swTopLogo {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	padding: 20px 0;
}

.topInstaTitle {
	font-size: 14px;
	text-align: center;
	color: #333333;
	margin-top: 50px;
	padding-bottom: 30px;
}

.instaBox {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	height: 465px;
	overflow: hidden;
}

/*フォトコンテスト*/

.mainBox01 {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	height: 770px;
}

.mainBox01inner {
	text-align: center;
	margin-top: -38px;
}

.mainBox02 {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-color: #3F822E;
	height: 459px;
	margin-top: 38px;
}

.mainBox02inner {
	text-align: center;
}

.footerBox {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	background-color: #D2E4A2;
}

.contactBox {
	margin: 50px auto 0 auto;
	width: 100%;
	text-align: center;
}

.contactText01 {
	margin: 5px auto;
	font-size: 14px;
	width: 100%;
	text-align: center;
}

.copyBox {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	font-size: 14px;
	background-color: #3F822E;
	color: #fff;
	height: 52px;
	line-height: 52px;
}

.toTop {
	margin: 110px auto 15px auto;
	width: 100%;
	height: 10px;
	text-align: right;
}

.img001 {
	margin: -80px auto;
	width: 100%;
	text-align: center;
}

.img002 {
	margin: 200px auto;
	width: 100%;
	text-align: center;
}

.textBox01 {
	width: 100%;
	text-align: center;
	font-size: 16px;
	font-weight: bold;
	color: #221F1F;
	margin: 0 auto;
	padding: 30px 0;
}

.textBox02 {
	background-color: #3F822E;
	width: 100%;
	text-align: left;
	height: 50px;
	line-height: 50px;
	font-size: 24px;
	font-weight: bold;
	color: #fff;
	margin: 0 auto;
	padding-left: 20px;
}

.textBox03 {
	width: 100%;
	text-align: left;
	font-size: 20px;
	font-weight: bold;
	color: #3F812D;
	margin: 41px auto 0 auto;
	border-bottom: 2px solid #3F822E;
	text-indent: 15px;
}

.textBox04 {
	width: 100%;
	text-align: left;
	font-size: 18px;
	font-weight: 400;
	color: #221F1F;
	margin: 10px auto 0 auto;
	padding-left: 15px;
}

.textBox05 {
	width: 100%;
	text-align: left;
	font-size: 18px;
	font-weight: 400;
	color: #221F1F;
	margin: 0 auto;
	padding-left: 65px;
	text-indent: -25px;
}

.textBox05red {
	width: 100%;
	text-align: left;
	font-size: 18px;
	font-weight: 400;
	color: #B20000;
	margin: 0 auto;
	padding-left: 65px;
	text-indent: -25px;
}

.textBox06 {
	width: 100%;
	text-align: left;
	font-size: 18px;
	font-weight: 400;
	color: #221F1F;
	margin: 10px auto 0 auto;
	padding-left: 65px;
	text-indent: -25px;
}

.formBox01 {
	width: 100%;
	text-align: center;
	margin: 140px auto 0 auto;
}

.infoBox01 {
	width: 100%;
	text-align: center;
	margin: 80px auto 0 auto;
	color: #201F1F;
	font-size: 20px;
	font-weight: bold;
}

.infoBox02 {
	width: 100%;
	text-align: center;
	margin: 55px auto 0 auto;
	color: #201F1F;
	font-size: 20px;
	font-weight: bold;
}

.infoBox03 {
	width: 100%;
	text-align: center;
	margin: 100px auto 0 auto;
	color: #201F1F;
	font-size: 20px;
	font-weight: bold;
}

.formMainBox01 {
	margin: 0 auto;
	width: 100%;
	text-align: center;
	margin-top: 25px;
}

.formTextBox01 {
	width: 100%;
	text-align: center;
	margin: 40px auto 0 auto;
	color: #3F802C;
	font-size: 60px;
	font-weight: bold;
}

.formTextBox02 {
	font-size: 16px;
}

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

.contactTextBox01 {
	width: 100%;
	text-align: left;
	margin: 40px auto 0 auto;
	color: #000000;
	font-size: 18px;
}

.contactTable {
	border-collapse: collapse;
	width: 100%;
	margin: 40px auto;
	color: #000000;
	font-size: 18px;
	text-align: left;
}

.contactTable th {
	font-weight: normal;
	padding: 15px;
	background-color: #EEEEEE;
	border: 1px solid #AAAAAA;
}

.contactTable td {
	padding: 15px 0px 15px 7px;
	border: 1px solid #AAAAAA;
}

.formRed {
	color: #B20000;
	font-size: 14px;
	text-align: left;
}

input[type="text"]{
    padding: 0;
    line-height: 26px;
    height: 28px;
}

#photoInfo01 {
	color: #000000;
	font-size: 20px;
	text-align: center;
	font-weight:bold;
}

.submitBtn {
	text-align: center;
	margin-top: 123px;
}

.privacyTitle01 {
	text-align: center;
	margin-top: 62px;
	font-size: 40px;
	font-weight:bold;
	color: #3F812D;
}

.privacyTitle02 {
	text-align: left;
	height: 50px;
	background-color: #3F812D;
	font-size: 30px;
	font-weight:bold;
	color: #fff;
	width: 100%;
	margin: 62px auto 0 auto;
	line-height: 50px;
	padding-left: 30px;
}

.privacyText01 {
	text-align: left;
	font-size: 18px;
	color: #211F1F;
	width: 100%;
	margin: 30px auto 0 auto;
	line-height: 150%;
}

.privacyText02 {
	text-align: left;
	font-size: 22px;
	color: #3F802C;
	width: 100%;
	margin: 60px auto 0 auto;
	line-height: 150%;
	border-bottom: 2px solid #3F802C;
	text-indent: 12px;
	font-weight:bold;
	padding-bottom: 5px;
}

.privacyText03 {
	text-align: left;
	font-size: 18px;
	color: #211F1F;
	width: 100%;
	margin: 15px auto 0 auto;
	line-height: 150%;
	text-indent: 15px;
}

.privacyText04 {
	text-align: left;
	font-size: 18px;
	color: #211F1F;
	width: 100%;
	margin: 0 auto;
	line-height: 120%;
	text-indent: 15px;
}

.privacyText05 {
	text-align: left;
	font-size: 18px;
	color: #211F1F;
	width: 100%;
	margin: 15px auto 0 auto;
	line-height: 150%;
	padding-left: 30px;
}

.linkBoxLixil {
	text-align: center;
	margin-top: 30px;
}

