@charset "UTF-8";
/*************************
        reset
*************************/
html, body, h1, h2, h3, h4, ul, ol, dl, li, dt, dd, p, div, span, img, a, table, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: normal;
  font-size: 100%;
  vertical-align:top;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
article, header, footer, aside, figure, figcaption, nav, section { 
  display:block;
}
body {
  line-height: 1;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
ol, ul,li {
  list-style: none;
  list-style-type: none;
}
img {
	display: block;
	border: none;
	max-width: 100%;
}
a {
	text-decoration: none;
	display: block;
}
/*************************
        margin
*************************/
.mt5{margin-top: 5px;}
.mt10{margin-top:10px;}
.mt15 {margin-top:15px;}
.mt20 {margin-top: 20px;}
.mt25 {margin-top: 25px;}
.mt30 {margin-top: 30px;}
.mt35 {margin-top: 35px;}
.mt40 {margin-top: 40px;}
.mt45 {margin-top: 45px;}
.mt50 {margin-top: 50px;}
.mt60 {margin-top: 60px;}
.mt70 {margin-top: 70px;}
.mt80 {margin-top: 80px;}
.mt90 {margin-top: 90px;}
.mt100 {margin-top: 100px;}

.mr5{margin-right: 5px;}
.mr10{margin-right:10px;}
.mr15 {margin-right:15px;}
.mr20 {margin-right: 20px;}

.mb5{margin-bottom: 5px;}
.mb10{margin-bottom:10px;}
.mb15 {margin-bottom:15px;}
.mb20 {margin-bottom: 20px;}
.mb25 {margin-bottom: 25px;}
.mb30 {margin-bottom: 30px;}
.mb35 {margin-bottom: 35px;}
.mb40 {margin-bottom: 40px;}
.mb45 {margin-bottom: 45px;}
.mb50 {margin-bottom: 50px;}
.mb60 {margin-bottom: 60px;}
.mb70 {margin-bottom: 70px;}
.mb80 {margin-bottom: 80px;}
.mb90 {margin-bottom: 90px;}
.mb100 {margin-bottom: 100px;}

.ml5{margin-left: 5px;}
.ml10{margin-left:10px;}
.ml15 {margin-left:15px;}
.ml20 {margin-left: 20px;}

.m-auto {margin-left: auto;margin-right: auto;}
.left-contents {float:left;}
.right-contents {float:right;}

.clear {clear:both;}

.plr20 {padding-left: 20px;padding-right: 20px;}
/*************************
       clearfix
*************************/
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

/*************************
        config
*************************/
body {
	font-size: 100%;
	font-family: "游ゴシック Medium", "游ゴシック", "游ゴシック体", YuGothic, "Yu Gothic M", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ ProN", "メイリオ", "sans-serif";
	font-weight: 400;
	line-height: 1.65;
	color: #333;
	text-align: justify;
	word-wrap: break-word;
	letter-spacing: 0.05em;
}
.wrap {
    overflow: hidden;
}
.sp-on {
	display: none;
}
.pc-on{
	display: block;
}
@media screen and (max-width:750px) {
	.sp-on {
		display: block;
	}
	.pc-on {
		display: none;
	}
}
.mw1200 {
	max-width: 1200px;
	margin: 0 auto;
}
.mw960 {
	max-width: 960px;
	margin: 0 auto;
}
.mw800 {
	max-width: 800px;
	margin: 0 auto;
}
.mw640 {
	max-width: 640px;
	margin: 0 auto;
}
.mw480 {
	max-width: 480px;
	margin: 0 auto;
}
a.btn {
	transition: .3s;
	display: block;
}
a.btn:hover {
	opacity: .8;
}

/*****************
  コンテンツ
******************/
.mv {
    background: url("../images/bg_pat01.jpg") repeat left top;
    background-size: 78px 78px;
    padding: 80px 20px;
    width: 100%;
    animation: bgiLoop 5s linear infinite;
}
@keyframes bgiLoop {
    0% { background-position: 0 0;}
  100% { background-position: -78px 156px;}
}
.info {
    padding: 60px 20px;
}
.info .l {
    float: left;
    width: 48%;
}
.info .r {
    float: right;
    width: 48%;
}
.h3 {
    background: #fff000;
    padding: 20px;
    font-size: 22px;
    font-weight: bold;
    text-align: center;
    color: #000;
    margin-bottom: 30px;
}
.main {
    background: url("../images/bg_pat02.jpg") repeat left top;
    background-size: 78px 78px;
    padding: 80px 20px;
    border-top: 10px solid #fff000;
    border-bottom: 10px solid #fff000;
    animation: bgiLoop 5s linear infinite;
}
.bg_w {
    padding: 40px 20px;
    background: #fff;
    border: 4px solid #fff000;
    box-shadow: 3px 3px 8px #ccc;
}
.theme li {
    margin-bottom: 30px;
    border-left: 4px solid #fff000;
    padding: 20px 10px;
    background-color: #FFFCDF;
}
.theme_text01 {
    font-weight: bold;
    margin-bottom: 10px;
}
.theme_text01 span {
    background: #fff000;
    padding: 4px 8px;
    display: inline-block;
    margin-right: 0.5em;
    vertical-align: middle;
    font-weight: bold;
}
.theme_text02 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
    border-bottom: 2px solid #fff000;
}
.theme_text03 {
    font-weight: bold;
    margin-bottom: 5px;
}
.theme_text04 {
    font-size: 13px;
}
.bnr li {
    max-width: 500px;
    margin: 0 auto 30px;
}
.cap {
    font-size: 11px;
}
.dev {
    padding: 40px 20px;
    text-align: center;
}
.dev li {
    display: inline-block;
    margin: 10px;
}
.reserve {
    max-width: 500px;
    margin: 10px auto 0;
    text-align: center;
    height: 80px;
}
.reserve a {
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    background: #E83F6F;
    line-height: 80px;
}
.copyright {
    font-size: 12px;
    text-align: center;
    padding: 15px 20px;
    background: #FFF000;
}
.shousai {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #ddd;
    font-size: 13px;
}
.shousai th {
    width: 30%;
    padding: 15px;
    background: #FFF000;
    border-bottom: 1px dotted #fff;
    font-weight: bold;
}
.shousai td {
    width: 70%;
    padding: 15px;
    border-bottom: 1px dotted #ddd;
}
.gmap {
    font-size: 12px;
}
.gmap a {
    color: #000;
    text-decoration: underline;
}
.cv {
    margin-top: 40px;
    text-align: center;
}
.cv_text01 {
    font-size: 24px;
    font-weight: bold;
}

@media screen and (max-width:750px) {
body {
    font-size: 14px;
    padding-bottom: 50px;
 }
.mv {
    background: url("../images/bg_pat01.jpg") repeat left top;
    background-size: 39px 39px;
    padding: 0;
    height: 500px;
    position: relative;
}
.title {
    padding: 80px 20px;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: 0;
}
.info {
    padding: 50px 20px;
}
.info .l {
    float: none;
    width: 100%;
}
.info .r {
    float: none;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
.h3 {
    padding: 20px;
    font-size: 16px;
    margin-bottom: 30px;
}
.main {
    background: url("../images/bg_pat02.jpg") repeat left top;
    background-size: 39px 39px;
    padding: 40px 20px;
    border-top: 10px solid #fff000;
}
.bg_w {
    padding: 20px;
    background: #fff;
    border: 4px solid #fff000;
    box-shadow: 3px 3px 8px #ccc;
}
.theme li {
    margin-bottom: 30px;
    border-left: 4px solid #fff000;
    padding: 20px 10px;
    background-color: #FFFCDF;
}
.theme_text01 {
    font-weight: bold;
    margin-bottom: 10px;
}
.theme_text01 span {
    margin-bottom: 0.5em;
}
.theme_text02 {
    font-size: 20px;
    font-weight: bold;
}
.theme_text03 {
    font-weight: bold;
    margin-bottom: 5px;
}
.theme_text04 {
    font-size: 13px;
}
.bnr li {
    width: 100%;
    margin-bottom: 30px;
}
.cap {
    font-size: 11px;
}
.reserve {
    max-width: 400px;
    margin: 10px auto 0;
    text-align: center;
    height: 60px;
}
.reserve a {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    background: #E83F6F;
    line-height: 60px;
}
.shousai th {
    display: block;
    width: 100%;
    border-bottom: 1px dotted #fff;
}
.shousai td {
    display: block;
    width: 100%;
    border-bottom: 1px dotted #ddd;
}
    .sp_fix {
        text-align: center;
        position: fixed;
        z-index: 100;
        left: 0;
        bottom: 0;
        width: 100%;
    }
    .sp_fix li {
        float: left;
    }
    .sp_fix li a {
        font-size: 12px;
        padding: 10px 6px 6px;
        color: #fff;
    }
    .sp_fix li a i {
        font-size: 18px;
    }
    .sp_fix li.menu01 {
        width: 25%;
        background: #009d95;
    }
    .sp_fix li.menu02 {
        width: 25%;
        background: #004097;
    }
    .sp_fix li.menu03 {
        width: 50%;
        background: #E83F6F;
    }
}

/*************************
       clearfix
*************************/
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

/*************************
       20200610追加分
*************************/
.message {
	margin-bottom: 50px;
}
.mes_ttl {
	color: #fff;
	background: #222;
	text-align: center;
	padding: 20px 10px;
	font-weight: bold;
}
.mes_text {
	padding: 20px;
	background: #F7F1D0;
}
.mes01 {
	text-align: center;
	padding: 10px;
	border: 1px dashed #666;
}
.mes02 {
	margin-top: 15px;
}
.mes02 span {
	color: #fff;
	background: #222;
	text-align: center;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.5em;
	margin-right: 0.5em;
	display: inline-block;
	border-radius: 50%;
}
@media screen and (max-width:750px) {
	
}